/* =============================================
   SHAWARMA CLASSIC — SECTIONS
   #FFFFFF · #E94E1B · #EF7D00 — LIGHT THEME
   ============================================= */

/* ── MARQUEE ── */
.marquee-strip {
  background:var(--accent); padding:12px 0; overflow:hidden;
  border-block:1px solid rgba(255,255,255,0.18);
}
.marquee-track { display:flex; animation:marqueeScroll 24s linear infinite; white-space:nowrap; }
.marquee-item  { display:flex; align-items:center; gap:12px; padding-inline:32px; font-size:13px; font-weight:700; color:rgba(255,255,255,.92); letter-spacing:.5px; }
.marquee-sep   { color:rgba(255,255,255,.45); font-size:10px; }
@keyframes marqueeScroll { from{transform:translateX(0)} to{transform:translateX(-50%)} }
[dir="ltr"] .marquee-track { animation-direction:reverse; }

/* ── STORY TEASER (homepage) ── */
.story-grid { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
@media (max-width:768px) { .story-grid { grid-template-columns:1fr; gap:40px; } }
.story-text { font-size:15px; color:var(--ink-60); line-height:1.80; margin-top:8px; }
.story-features { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:24px; }
@media (max-width:480px) { .story-features { grid-template-columns:1fr; } }

.story-feat {
  display:flex; flex-direction:column; gap:6px;
  background:var(--bg-section); border:2px solid transparent;
  border-radius:var(--r-md); padding:18px 16px;
  transition:all var(--dur-med) var(--ease);
}
.story-feat:hover { border-color:var(--brand); background:#fff; transform:translateY(-3px); box-shadow:var(--shadow-md); }
.story-feat-img  {
  width:40px; height:40px; border-radius:var(--r-sm);
  overflow:hidden;
}
.story-feat-img img { width:100%; height:100%; object-fit:contain; }
.story-feat-title { font-size:14px; font-weight:800; color:var(--ink); }
.story-feat-desc  { font-size:12px; color:var(--ink-60); line-height:1.55; }

/* Story stat cards */
.story-stats-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.story-stat-card {
  background:var(--bg-section); border:2px solid transparent;
  border-radius:var(--r-md); padding:24px 18px; text-align:center;
  transition:all var(--dur-med);
}
.story-stat-card:hover { border-color:var(--brand); background:#fff; box-shadow:var(--shadow-md); }
.story-stat-card.brand  { background:var(--brand); border-color:var(--brand); }
.story-stat-card.accent { background:var(--accent); border-color:var(--accent); }
.story-stat-val  { font-size:clamp(30px,4vw,44px); font-weight:900; color:var(--brand); line-height:1; }
.story-stat-card.brand  .story-stat-val { color:#fff; }
.story-stat-card.accent .story-stat-val { color:#fff; }
.story-stat-lbl  { font-size:12px; font-weight:500; color:var(--ink-60); margin-top:4px; }
.story-stat-card.brand  .story-stat-lbl { color:rgba(255,255,255,.75); }
.story-stat-card.accent .story-stat-lbl { color:rgba(255,255,255,.80); }

/* ── MENU ── */
.menu-header { display:flex; align-items:flex-end; justify-content:space-between; gap:24px; flex-wrap:wrap; margin-bottom:36px; }
.menu-tabs   { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.menu-tab {
  padding:9px 20px; border-radius:var(--r-full);
  font-size:13px; font-weight:700; cursor:pointer;
  background:var(--bg-section); border:2px solid transparent;
  color:var(--ink-60); transition:all var(--dur-fast);
}
.menu-tab:hover  { border-color:var(--brand); color:var(--brand); }
.menu-tab.active { background:var(--brand); border-color:var(--brand); color:#fff; }

.menu-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:20px; }

.menu-card {
  background:#fff; border:2px solid rgba(26,8,0,0.08);
  border-radius:var(--r-lg); overflow:hidden;
  box-shadow:var(--shadow-sm); cursor:pointer;
  transition:all var(--dur-med) var(--ease);
}
.menu-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-5px); border-color:rgba(233,78,27,0.20); }

.menu-card-img-slot {
  width:100%; height:180px;
  background:var(--bg-section); position:relative; overflow:hidden;
}
.menu-card-img-slot img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .5s var(--ease); }
.menu-card:hover .menu-card-img-slot img { transform:scale(1.04); }

.menu-card-img-fallback {
  width:100%; height:100%;
  display:flex; align-items:center; justify-content:center;
  flex-direction:column; gap:8px; background:var(--bg-section);
}
.menu-card-img-fallback-emoji { font-size:48px; }
.menu-card-img-fallback-label { font-size:11px; color:var(--ink-40); font-weight:600; }

.menu-card-badge {
  position:absolute; top:10px; inset-inline-end:10px;
  padding:4px 10px; border-radius:var(--r-full);
  font-size:10px; font-weight:800;
  background:var(--brand); color:#fff;
}
.menu-card-badge.accent-badge { background:var(--accent); }
.menu-card-badge.new { background:#fff; color:var(--brand); border:2px solid var(--brand); }

.menu-card-body  { padding:16px; }
.menu-card-name  { font-size:15px; font-weight:800; color:var(--ink); margin-bottom:5px; }
.menu-card-desc  { font-size:12px; color:var(--ink-60); line-height:1.55; margin-bottom:12px; }
.menu-card-footer { display:flex; align-items:center; justify-content:space-between; }
.menu-card-price { font-size:17px; font-weight:900; color:var(--accent); }
.menu-card-add {
  padding:7px 14px; border-radius:var(--r-sm);
  background:var(--brand); color:#fff;
  font-size:12px; font-weight:700; transition:all var(--dur-fast);
}
.menu-card-add:hover { background:var(--brand-dark); }

/* ── PROMO (brand-red surface) ── */
.promo-section { background:var(--brand); padding-block:var(--section-pad); }
.promo-grid    { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
@media (max-width:768px) { .promo-grid { grid-template-columns:1fr; gap:36px; } }

.promo-tag {
  display:inline-flex; align-items:center; gap:8px;
  padding:5px 14px; border-radius:var(--r-full);
  background:rgba(255,255,255,0.15); border:1px solid rgba(255,255,255,0.30);
  font-size:11px; font-weight:700; letter-spacing:1px; color:#fff; margin-bottom:16px;
}
.promo-title { font-size:clamp(32px,5vw,60px); font-weight:900; color:#fff; line-height:1; margin-bottom:14px; }
.promo-title .highlight { color:var(--accent); text-shadow:0 2px 16px rgba(239,125,0,.35); }
.promo-sub   { font-size:14px; color:rgba(255,255,255,0.80); line-height:1.80; margin-bottom:28px; }

.promo-img-slot {
  width:100%; max-width:440px; height:340px;
  border-radius:var(--r-xl); overflow:hidden;
  background:rgba(255,255,255,0.12);
  border:2px solid rgba(255,255,255,0.25);
  position:relative; margin-inline:auto;
}
.promo-img-slot img { width:100%; height:100%; object-fit:cover; }
.promo-img-slot-fallback {
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  flex-direction:column; gap:12px;
}
.promo-img-slot-fallback span { font-size:64px; }

/* ── APP (accent-orange surface) ── */
.app-section { background:var(--accent); padding-block:var(--section-pad); }
.app-grid    { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
@media (max-width:768px) { .app-grid { grid-template-columns:1fr; gap:36px; } }

.app-perks { display:flex; flex-direction:column; gap:14px; margin-top:24px; }
.app-perk  {
  display:flex; align-items:flex-start; gap:14px;
  background:rgba(255,255,255,0.15);
  border:1px solid rgba(255,255,255,0.22);
  border-radius:var(--r-md); padding:16px 18px;
  transition:all var(--dur-med);
}
.app-perk:hover { background:rgba(255,255,255,0.24); }
.app-perk-icon {
  width:44px; height:44px; flex-shrink:0;
  border-radius:var(--r-sm);
  background:rgba(255,255,255,0.22);
  border:1px solid rgba(255,255,255,0.28);
  display:flex; align-items:center; justify-content:center; overflow:hidden;
}
.app-perk-icon img { width:26px; height:26px; object-fit:contain; filter:brightness(0) invert(1); }
.app-perk-title { font-size:14px; font-weight:800; color:#fff; margin-bottom:3px; }
.app-perk-desc  { font-size:12px; color:rgba(255,255,255,.82); line-height:1.55; }

.app-phone-slot { display:flex; align-items:center; justify-content:center; }
.app-phone-img  {
  width:100%; max-width:300px; border-radius:var(--r-xl);
  box-shadow:0 16px 56px rgba(233,78,27,0.20);
  border:3px solid rgba(255,255,255,0.30);
}
.app-store-btns { display:flex; gap:12px; flex-wrap:wrap; margin-top:24px; }
.app-store-btn  {
  display:block; border-radius:var(--r-sm); overflow:hidden;
  border:2px solid rgba(255,255,255,0.35); transition:all var(--dur-fast);
}
.app-store-btn:hover { border-color:#fff; transform:translateY(-2px); }
.app-store-btn img  { height:44px; width:auto; display:block; }

/* ── BRANCHES (bg-section surface) ── */
.branches-section { background:var(--bg-section); }
.branch-cards-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:18px; }

.branch-card {
  background:#fff; border:2px solid rgba(26,8,0,0.08);
  border-radius:var(--r-lg); overflow:hidden;
  transition:all var(--dur-med) var(--ease);
  text-decoration:none; color:inherit; display:block;
}
.branch-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:rgba(233,78,27,0.20); }
.branch-card-img  {
  width:100%; height:160px; background:var(--bg-section);
  overflow:hidden; position:relative;
}
.branch-card-img img { width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease); }
.branch-card:hover .branch-card-img img { transform:scale(1.04); }
.branch-card-body { padding:18px; }
.branch-card-name { font-size:15px; font-weight:800; color:var(--ink); margin-bottom:4px; }
.branch-card-addr { font-size:12px; color:var(--ink-60); line-height:1.55; margin-bottom:10px; display:flex; align-items:flex-start; gap:6px; }
.branch-card-addr img { width:14px; height:14px; margin-top:1px; flex-shrink:0; }
.branch-card-meta { display:flex; gap:6px; flex-wrap:wrap; }

/* ── CONTACT ── */
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start; }
@media (max-width:768px) { .contact-grid { grid-template-columns:1fr; gap:40px; } }

.contact-info-list { display:flex; flex-direction:column; gap:14px; margin-top:24px; }
.contact-info-item {
  display:flex; align-items:center; gap:16px;
  background:var(--bg-section); border:2px solid transparent;
  border-radius:var(--r-md); padding:16px 18px;
  transition:all var(--dur-med);
}
.contact-info-item:hover { border-color:var(--brand); background:#fff; box-shadow:var(--shadow-sm); }
.contact-info-icon {
  width:44px; height:44px; flex-shrink:0;
  border-radius:var(--r-sm);
  background:var(--brand-soft); border:2px solid rgba(233,78,27,0.18);
  display:flex; align-items:center; justify-content:center; overflow:hidden;
}
.contact-info-icon img { width:22px; height:22px; object-fit:contain; }
.contact-info-label { font-size:11px; font-weight:700; letter-spacing:.5px; color:var(--ink-40); text-transform:uppercase; margin-bottom:2px; }
.contact-info-value { font-size:15px; font-weight:700; color:var(--ink); }

.contact-form {
  background:#fff; border:2px solid rgba(26,8,0,0.08);
  border-radius:var(--r-xl); padding:32px;
  box-shadow:var(--shadow-sm);
  transition:box-shadow var(--dur-med);
}
.contact-form:hover { box-shadow:var(--shadow-md); }
.contact-form-title { font-size:20px; font-weight:800; color:var(--ink); margin-bottom:24px; }

/* ── FOOTER ── */
footer { background:var(--brand); }
.footer-grid {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px;
  padding-block:56px; max-width:var(--max-w); margin-inline:auto;
  padding-inline:var(--gutter);
}
@media (max-width:900px)  { .footer-grid { grid-template-columns:1fr 1fr; gap:32px; } }
@media (max-width:520px)  { .footer-grid { grid-template-columns:1fr; } }

.footer-logo { margin-bottom:16px; }
.footer-logo img { height:44px; filter:brightness(0) invert(1); }
.footer-brand-desc { font-size:13px; color:rgba(255,255,255,0.72); line-height:1.75; }
.footer-socials { display:flex; gap:10px; margin-top:20px; }
.footer-social-link {
  width:36px; height:36px; border-radius:50%;
  background:rgba(255,255,255,0.14); border:1px solid rgba(255,255,255,0.22);
  display:flex; align-items:center; justify-content:center;
  transition:all var(--dur-fast);
}
.footer-social-link:hover { background:rgba(255,255,255,0.28); border-color:rgba(255,255,255,0.40); transform:translateY(-2px); }
.footer-social-link img { width:16px; height:16px; filter:brightness(0) invert(1); }

.footer-col-title { font-size:11px; font-weight:800; letter-spacing:1.5px; text-transform:uppercase; color:rgba(255,255,255,0.55); margin-bottom:14px; }
.footer-links { display:flex; flex-direction:column; gap:8px; }
.footer-links a { font-size:13px; color:rgba(255,255,255,0.78); transition:color var(--dur-fast); }
.footer-links a:hover { color:#fff; }

.footer-bottom {
  display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:12px; padding:16px var(--gutter);
  border-top:1px solid rgba(255,255,255,0.14);
  max-width:var(--max-w); margin-inline:auto;
}
.footer-copy  { font-size:12px; color:rgba(255,255,255,0.60); }
.footer-legal { display:flex; gap:16px; }
.footer-legal a { font-size:12px; color:rgba(255,255,255,0.60); transition:color var(--dur-fast); }
.footer-legal a:hover { color:#fff; }

/* ── LOCATIONS PAGE ── */
.city-section { padding-block:60px 0; }
.city-section:first-of-type { padding-top:30px; }
.city-section-header {
  display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:16px; padding-bottom:24px;
  border-bottom:2px solid rgba(233,78,27,0.12); margin-bottom:28px;
}
.city-name-badge    { display:inline-flex; align-items:center; gap:14px; }
.city-flag-dot      { width:14px; height:14px; border-radius:50%; background:var(--brand); box-shadow:0 0 14px rgba(233,78,27,0.40); flex-shrink:0; }
.city-name-badge h2 { font-size:clamp(24px,3.5vw,36px); font-weight:900; color:var(--ink); }
.city-branch-count  { font-size:12px; font-weight:700; color:var(--ink-40); letter-spacing:.5px; }

.location-cards-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:20px;
}

/* Location card — full clickable, image top, no action buttons */
.location-card {
  background:#fff; border:2px solid rgba(26,8,0,0.08);
  border-radius:var(--r-lg); overflow:hidden;
  transition:all var(--dur-med) var(--ease);
  text-decoration:none; display:block; color:inherit; cursor:pointer;
}
.location-card:hover {
  border-color:var(--brand);
  transform:translateY(-5px);
  box-shadow:var(--shadow-lg);
}

/* Image slot at top of location card */
.location-card-img-wrap {
  width:100%; height:180px;
  overflow:hidden; position:relative; background:var(--bg-section);
}
.location-card-img-wrap img {
  width:100%; height:100%; object-fit:cover; display:block;
  transition:transform .5s var(--ease);
}
.location-card:hover .location-card-img-wrap img { transform:scale(1.04); }

/* Image placeholder when no real photo */
.location-card-img-placeholder {
  width:100%; height:180px;
  background:var(--bg-section);
  display:flex; align-items:center; justify-content:center;
  flex-direction:column; gap:8px; position:relative; overflow:hidden;
}
.loc-img-pattern {
  position:absolute; inset:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(233,78,27,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(233,78,27,0.05) 1px, transparent 1px);
  background-size:28px 28px;
}
.loc-img-glow {
  position:absolute; inset:0;
  background:radial-gradient(ellipse 60% 50% at 50% 80%, rgba(233,78,27,0.10) 0%, transparent 65%);
}
.loc-card-emoji  { font-size:44px; position:relative; z-index:1; }
.loc-card-label  { font-size:11px; font-weight:700; color:var(--ink-40); position:relative; z-index:1; letter-spacing:.5px; }

.location-card-body { padding:18px 18px 14px; }
.location-card-name { font-size:16px; font-weight:800; color:var(--ink); margin-bottom:8px; }
.location-card-address {
  font-size:13px; color:var(--ink-60); line-height:1.5;
  margin-bottom:12px; display:flex; align-items:flex-start; gap:7px;
}
.location-card-address img { width:14px; height:14px; flex-shrink:0; margin-top:2px; }
.location-card-meta { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }

.loc-meta-badge {
  display:inline-flex; align-items:center; gap:5px;
  padding:4px 10px; border-radius:var(--r-full);
  font-size:11px; font-weight:700;
}
.loc-meta-open     { background:rgba(239,125,0,0.10); color:var(--accent-dark); border:1px solid rgba(239,125,0,0.25); }
.loc-meta-delivery { background:var(--brand-soft); color:var(--brand); border:1px solid rgba(233,78,27,0.20); }
.loc-meta-hours    { font-size:11px; color:var(--ink-40); font-weight:600; margin-inline-start:auto; }

/* Arrow chevron at bottom of card */
.location-card-arrow {
  display:flex; align-items:center; justify-content:flex-end;
  padding:12px 18px; border-top:1px solid rgba(26,8,0,0.06);
  color:var(--brand); font-size:12px; font-weight:700; gap:6px;
  transition:gap var(--dur-fast);
}
.location-card-arrow img { width:14px; height:14px; }
.location-card:hover .location-card-arrow { gap:10px; }

/* ── INDIVIDUAL BRANCH PAGE ── */
.branch-detail-hero {
  padding-top:calc(var(--nav-h) + 48px);
  padding-bottom:48px;
  background:linear-gradient(135deg, var(--brand-soft) 0%, transparent 50%), var(--bg);
}
.branch-hero-grid {
  display:grid; grid-template-columns:1fr 340px; gap:48px; align-items:start;
}
@media(max-width:900px) { .branch-hero-grid { grid-template-columns:1fr; } }

.branch-breadcrumb {
  display:flex; align-items:center; gap:8px;
  font-size:12px; color:var(--ink-40); margin-bottom:20px; flex-wrap:wrap;
}
.branch-breadcrumb a          { color:var(--brand); transition:opacity .15s; }
.branch-breadcrumb a:hover    { opacity:.75; }
.branch-breadcrumb span       { opacity:.4; }

.branch-live-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(239,125,0,0.08); border:1px solid rgba(239,125,0,0.25);
  color:var(--accent-dark); font-size:12px; font-weight:700;
  padding:5px 14px; border-radius:var(--r-full); margin-bottom:14px;
}
.branch-live-dot {
  width:7px; height:7px; background:var(--accent); border-radius:50%;
  animation:pulse-accent 1.5s ease-in-out infinite;
}
@keyframes pulse-accent {
  0%,100% { box-shadow:0 0 0 0 rgba(239,125,0,0.5); }
  50%      { box-shadow:0 0 0 6px rgba(239,125,0,0); }
}

.branch-info-card {
  background:#fff; border:2px solid rgba(26,8,0,0.08);
  border-radius:var(--r-xl); padding:28px;
  position:sticky; top:calc(var(--nav-h) + 20px);
  box-shadow:var(--shadow-md);
}
.branch-info-card-title { font-size:11px; font-weight:800; color:var(--ink-40); letter-spacing:1.5px; text-transform:uppercase; margin-bottom:20px; }
.branch-info-row {
  display:flex; align-items:flex-start; gap:14px;
  padding-block:14px; border-bottom:1px solid rgba(26,8,0,0.06);
}
.branch-info-row:last-of-type { border-bottom:none; }
.branch-info-icon {
  width:38px; height:38px; background:var(--brand-soft);
  border:2px solid rgba(233,78,27,0.15); border-radius:var(--r-sm);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.branch-info-icon img { width:20px; height:20px; }
.branch-info-label { font-size:11px; color:var(--ink-40); margin-bottom:3px; font-weight:600; letter-spacing:.5px; text-transform:uppercase; }
.branch-info-value { font-size:14px; font-weight:700; color:var(--ink); line-height:1.4; }

/* Branch map visual */
.branch-map-embed {
  width:100%; aspect-ratio:16/9;
  border-radius:var(--r-lg); overflow:hidden;
  background:var(--bg-section); border:2px solid rgba(233,78,27,0.15);
  margin-bottom:24px; position:relative;
  display:flex; align-items:center; justify-content:center;
}
.branch-map-pattern {
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(233,78,27,0.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(233,78,27,0.05) 1px,transparent 1px);
  background-size:44px 44px;
}
.branch-map-glow {
  position:absolute; inset:0;
  background:radial-gradient(ellipse 55% 50% at 50% 60%, rgba(233,78,27,0.10) 0%, transparent 65%);
}
.branch-map-pin-lg { position:relative; z-index:1; display:flex; flex-direction:column; align-items:center; gap:10px; }
.pin-shape-lg {
  width:50px; height:50px; background:var(--brand);
  border-radius:50% 50% 50% 0; transform:rotate(-45deg);
  box-shadow:0 0 30px rgba(233,78,27,0.35);
  display:flex; align-items:center; justify-content:center;
}
.pin-shape-lg img { width:22px; height:22px; transform:rotate(45deg); filter:brightness(0) invert(1); }
.pin-label-lg { font-size:14px; font-weight:900; color:var(--ink); }

/* ── RESERVATION / FOOD TRUCK PAGE ── */
.res-layout {
  display:grid; grid-template-columns:1fr 400px; gap:60px; align-items:start;
}
@media(max-width:1024px) { .res-layout { grid-template-columns:1fr; } }

.res-perk-card {
  background:var(--bg-section); border:2px solid transparent;
  border-radius:var(--r-md); padding:18px 20px;
  display:flex; gap:16px; align-items:flex-start;
  transition:all var(--dur-med) var(--ease);
}
.res-perk-card:hover { background:#fff; border-color:var(--brand); box-shadow:var(--shadow-sm); }
.res-perk-icon {
  width:44px; height:44px; border-radius:var(--r-sm);
  background:var(--brand-soft); border:2px solid rgba(233,78,27,0.15);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.res-perk-icon img { width:22px; height:22px; }
.res-perk-title { font-size:14px; font-weight:700; color:var(--ink); margin-bottom:3px; }
.res-perk-desc  { font-size:12px; color:var(--ink-60); line-height:1.5; }

/* Form card */
.res-form-card {
  background:#fff; border:2px solid rgba(26,8,0,0.08);
  border-radius:var(--r-xl); overflow:hidden;
  position:sticky; top:calc(var(--nav-h) + 24px);
  box-shadow:var(--shadow-md);
}
.res-form-header {
  padding:24px 28px 20px;
  border-bottom:1px solid rgba(26,8,0,0.06);
  background:linear-gradient(135deg, var(--brand-soft) 0%, transparent 60%);
}
.res-form-header-title { font-size:18px; font-weight:800; color:var(--ink); }
.res-form-header-sub   { font-size:13px; color:var(--ink-60); margin-top:4px; }

/* Step dots */
.res-steps-bar { display:flex; align-items:center; padding:20px 28px; border-bottom:1px solid rgba(26,8,0,0.06); }
.step-dot {
  width:28px; height:28px; border-radius:50%;
  background:var(--bg-section); border:2px solid rgba(26,8,0,0.12);
  display:flex; align-items:center; justify-content:center;
  font-size:11px; font-weight:800; color:var(--ink-40);
  transition:all var(--dur-med) var(--ease); flex-shrink:0;
}
.step-dot.active { background:var(--brand); border-color:var(--brand); color:#fff; box-shadow:0 0 12px rgba(233,78,27,0.30); }
.step-dot.done   { background:rgba(239,125,0,0.10); border-color:rgba(239,125,0,0.35); color:var(--accent-dark); }
.step-line { flex:1; height:2px; background:rgba(26,8,0,0.08); }

/* Step panels */
.res-step { display:none; padding:24px 28px; flex-direction:column; gap:16px; }
.res-step.active { display:flex; }

/* Form navigation */
.res-form-nav { display:flex; gap:10px; padding:20px 28px; border-top:1px solid rgba(26,8,0,0.06); }
.res-form-nav .btn { flex:1; }

/* Success panel */
.res-success-panel {
  display:none; padding:40px 28px;
  flex-direction:column; align-items:center; text-align:center; gap:14px;
}
.res-success-icon { font-size:40px; }
.res-success-title { font-size:20px; font-weight:900; color:var(--ink); }
.res-success-sub   { font-size:14px; color:var(--ink-60); line-height:1.6; max-width:280px; }

/* ── OUR STORY PAGE ── */
.story-page-hero {
  padding-top:calc(var(--nav-h) + 60px);
  padding-bottom:80px;
  background:linear-gradient(135deg, var(--brand-soft) 0%, transparent 50%), var(--bg);
  position:relative; overflow:hidden;
}
.story-page-hero::before {
  content:'2014';
  position:absolute; bottom:-20px; inset-inline-end:-10px;
  font-size:clamp(120px,20vw,200px); font-weight:900;
  color:rgba(233,78,27,0.05); line-height:1;
  pointer-events:none; user-select:none;
}

/* Stats strip */
.stats-strip { background:var(--brand); padding:48px var(--gutter); }
.stats-strip-grid {
  max-width:var(--max-w); margin-inline:auto;
  display:grid; grid-template-columns:repeat(4,1fr); gap:24px; text-align:center;
}
@media(max-width:640px) { .stats-strip-grid { grid-template-columns:1fr 1fr; } }
.stats-strip-num   { font-size:clamp(36px,5vw,56px); font-weight:900; color:#fff; line-height:1; }
.stats-strip-label { font-size:13px; color:rgba(255,255,255,0.75); margin-top:6px; font-weight:500; }

/* Timeline */
.timeline { position:relative; padding-inline-start:40px; }
.timeline::before {
  content:''; position:absolute; top:0; bottom:0;
  inset-inline-start:14px; width:3px;
  background:linear-gradient(to bottom, var(--brand), rgba(233,78,27,0.10));
  border-radius:3px;
}
.timeline-item    { position:relative; margin-bottom:48px; }
.timeline-dot {
  position:absolute; inset-inline-start:-33px; top:6px;
  width:18px; height:18px; border-radius:50%;
  background:#fff; border:3px solid var(--brand);
  box-shadow:0 0 16px rgba(233,78,27,0.30);
}
.timeline-year  { font-size:12px; font-weight:800; letter-spacing:2px; color:var(--brand); margin-bottom:6px; text-transform:uppercase; }
.timeline-title { font-size:clamp(18px,2vw,22px); font-weight:900; color:var(--ink); margin-bottom:8px; line-height:1.2; }
.timeline-body  { font-size:14px; color:var(--ink-60); line-height:1.75; max-width:560px; }

/* Values grid */
.values-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
@media(max-width:768px) { .values-grid { grid-template-columns:1fr 1fr; } }
@media(max-width:480px) { .values-grid { grid-template-columns:1fr; } }

.value-card {
  background:#fff; border:2px solid rgba(26,8,0,0.08);
  border-radius:var(--r-lg); padding:28px 24px;
  transition:all var(--dur-med) var(--ease); position:relative; overflow:hidden;
}
.value-card::before {
  content:''; position:absolute; top:0; inset-inline-start:0;
  width:3px; height:100%; background:var(--brand); opacity:0;
  transition:opacity var(--dur-med);
}
.value-card:hover { border-color:var(--brand); transform:translateY(-4px); box-shadow:var(--shadow-md); }
.value-card:hover::before { opacity:1; }
.value-icon {
  width:50px; height:50px; border-radius:var(--r-md);
  background:var(--brand-soft); border:2px solid rgba(233,78,27,0.18);
  display:flex; align-items:center; justify-content:center; margin-bottom:16px;
  overflow:hidden;
}
.value-icon img { width:26px; height:26px; }
.value-title { font-size:16px; font-weight:800; color:var(--ink); margin-bottom:8px; }
.value-desc  { font-size:13px; color:var(--ink-60); line-height:1.65; }

/* Founders */
.founders-grid { display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center; }
@media(max-width:768px) { .founders-grid { grid-template-columns:1fr; } }
.founder-quote-card {
  background:#fff; border:2px solid rgba(233,78,27,0.15);
  border-radius:var(--r-xl); padding:36px; position:relative;
  box-shadow:var(--shadow-sm);
}
.founder-quote-mark { font-size:80px; color:rgba(233,78,27,0.12); line-height:.8; font-family:Georgia,serif; display:block; margin-bottom:12px; }
.founder-quote-text { font-size:clamp(16px,1.8vw,20px); font-weight:700; color:var(--ink); line-height:1.55; margin-bottom:24px; }
.founder-name  { font-size:15px; font-weight:800; color:var(--brand); }
.founder-title { font-size:12px; color:var(--ink-60); margin-top:2px; }

/* Cinematic story rows */
.story-cinematic { display:grid; grid-template-columns:1fr 1fr; min-height:420px; }
@media(max-width:768px) { .story-cinematic { grid-template-columns:1fr; } }
.story-cinematic-img { position:relative; overflow:hidden; min-height:320px; background:var(--bg-section); }
.story-cinematic-img img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .7s var(--ease); }
.story-cinematic:hover .story-cinematic-img img { transform:scale(1.04); }
.story-cinematic-text {
  padding:56px 52px; display:flex; flex-direction:column; justify-content:center;
  background:var(--bg-section);
}
@media(max-width:900px) { .story-cinematic-text { padding:40px 28px; } }
.story-cinematic-year  { font-size:11px; letter-spacing:3px; text-transform:uppercase; color:var(--brand); font-weight:800; margin-bottom:14px; }
.story-cinematic-title { font-size:clamp(22px,3vw,34px); font-weight:900; color:var(--ink); line-height:1.15; margin-bottom:16px; }
.story-cinematic-body  { font-size:14px; color:var(--ink-60); line-height:1.8; }

/* Pull quote */
.story-pull-quote {
  padding:80px var(--gutter); background:var(--brand);
  text-align:center; position:relative; overflow:hidden;
}
.story-pull-quote::before {
  content:'"'; position:absolute; top:-20px; left:50%; transform:translateX(-50%);
  font-size:300px; color:rgba(255,255,255,0.06); font-family:Georgia,serif;
  line-height:1; pointer-events:none; user-select:none;
}
.story-pull-text   { font-size:clamp(20px,3.5vw,36px); font-weight:900; color:#fff; line-height:1.35; max-width:800px; margin-inline:auto; position:relative; z-index:1; }
.story-pull-source { font-size:14px; color:rgba(255,255,255,0.72); margin-top:20px; font-weight:600; position:relative; z-index:1; }

/* Mosaic */
.story-mosaic { display:grid; grid-template-columns:2fr 1fr; grid-template-rows:240px 240px; gap:4px; }
@media(max-width:640px) { .story-mosaic { grid-template-columns:1fr; grid-template-rows:auto; } }
.story-mosaic-main { grid-row:1/3; }
.story-mosaic-item { overflow:hidden; position:relative; background:var(--bg-section); }
.story-mosaic-item img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .6s var(--ease); }
.story-mosaic-item:hover img { transform:scale(1.05); }

/* Image placeholder for story sections */
.story-img-placeholder {
  width:100%; height:100%;
  display:flex; align-items:center; justify-content:center;
  background:var(--bg-section); flex-direction:column; gap:10px;
  position:relative; overflow:hidden;
}
.story-img-placeholder-grid {
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(233,78,27,0.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(233,78,27,0.05) 1px,transparent 1px);
  background-size:40px 40px;
}
.story-img-placeholder-content { position:relative; z-index:1; text-align:center; }
.story-img-placeholder-emoji   { font-size:clamp(52px,8vw,80px); display:block; margin-bottom:10px; }
.story-img-placeholder-label   { font-size:12px; color:var(--ink-40); font-weight:600; letter-spacing:.5px; }

/* Banner */
.story-banner {
  height:320px;
  background:linear-gradient(rgba(233,78,27,0.82) 0%, rgba(233,78,27,0.70) 100%),
    url('https://shawarmaclassic.com/wp-content/uploads/2024/05/image-3.png') center/cover no-repeat;
  display:flex; align-items:center; justify-content:center; text-align:center;
}
.story-banner-text { font-size:clamp(32px,6vw,72px); font-weight:900; color:#fff; line-height:1; }
.story-banner-text em { color:var(--accent); font-style:normal; }

/* Ingredients */
.story-ingredients { display:flex; overflow-x:auto; scrollbar-width:none; -ms-overflow-style:none; }
.story-ingredients::-webkit-scrollbar { display:none; }
.story-ingredient {
  flex:0 0 180px; padding:32px 20px; text-align:center;
  border-inline-end:1px solid rgba(26,8,0,0.07);
  transition:background var(--dur-med);
}
.story-ingredient:hover { background:var(--brand-soft); }
.story-ingredient-emoji { font-size:44px; display:block; margin-bottom:12px; }
.story-ingredient-name  { font-size:14px; font-weight:800; color:var(--ink); margin-bottom:5px; }
.story-ingredient-desc  { font-size:12px; color:var(--ink-60); line-height:1.5; }

/* ── FOOD TRUCK PAGE ── */
.truck-hero {
  position:relative; padding-top:calc(var(--nav-h) + 48px);
  overflow:hidden;
  background:linear-gradient(180deg, var(--brand-soft) 0%, rgba(239,125,0,0.05) 50%, var(--bg) 100%);
}
.truck-hero::before {
  content:''; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(233,78,27,0.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(233,78,27,0.04) 1px,transparent 1px);
  background-size:60px 60px; pointer-events:none;
}

.truck-hero-inner { max-width:720px; margin-inline:auto; text-align:center; padding-bottom:48px; }

.truck-hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 16px; border-radius:var(--r-full);
  background:var(--brand-soft); border:2px solid rgba(233,78,27,0.25);
  color:var(--brand); font-size:13px; font-weight:700; margin-bottom:20px;
}
.truck-badge-dot {
  width:7px; height:7px; border-radius:50%; background:var(--brand);
  animation:pulse-brand 1.5s ease-in-out infinite;
}
@keyframes pulse-brand {
  0%,100% { box-shadow:0 0 0 0 rgba(233,78,27,0.5); }
  50%      { box-shadow:0 0 0 6px rgba(233,78,27,0); }
}

.truck-hero-title { font-size:clamp(44px,8vw,88px); font-weight:900; color:var(--ink); line-height:1; margin-bottom:20px; }
.truck-title-highlight { color:var(--brand); }
.truck-hero-sub { font-size:clamp(14px,1.5vw,17px); color:var(--ink-60); line-height:1.75; max-width:560px; margin-inline:auto; margin-bottom:28px; }

.truck-svg-wrap {
  max-width:600px; margin-inline:auto; margin-bottom:28px;
  filter:drop-shadow(0 8px 32px rgba(233,78,27,0.16));
}
.truck-svg { width:100%; height:auto; display:block; }

.truck-hero-actions { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* Schedule strip */
.truck-schedule-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); gap:14px; }
.truck-sched-card {
  background:#fff; border:2px solid rgba(26,8,0,0.08);
  border-radius:var(--r-md); padding:18px 16px; transition:all var(--dur-med);
}
.truck-sched-card:hover { border-color:var(--brand); box-shadow:var(--shadow-sm); }
.truck-sched-day { font-size:15px; font-weight:900; color:var(--ink); margin-bottom:10px; }
.truck-sched-location { display:flex; align-items:center; gap:6px; font-size:12px; color:var(--ink-60); margin-bottom:6px; line-height:1.4; }
.truck-sched-location img { width:12px; height:12px; flex-shrink:0; }
.truck-sched-time { font-size:11px; color:var(--ink-40); font-weight:600; margin-bottom:10px; direction:ltr; text-align:start; }
.truck-sched-status {
  display:inline-block; padding:3px 10px; border-radius:var(--r-full); font-size:11px; font-weight:700;
}
.truck-sched-status.active { background:rgba(239,125,0,0.10); border:1px solid rgba(239,125,0,0.25); color:var(--accent-dark); }

/* Perk cards */
.truck-perk-card {
  background:var(--bg-section); border:2px solid transparent;
  border-radius:var(--r-lg); padding:28px 24px; text-align:center;
  transition:all var(--dur-med) var(--ease);
}
.truck-perk-card:hover { border-color:var(--brand); background:#fff; transform:translateY(-5px); box-shadow:var(--shadow-md); }
.truck-perk-emoji { font-size:40px; margin-bottom:14px; display:block; }
.truck-perk-title { font-size:16px; font-weight:800; color:var(--ink); margin-bottom:8px; }
.truck-perk-desc  { font-size:13px; color:var(--ink-60); line-height:1.6; }

/* ── SITE FOOTER (full) ── */
.site-footer { background:var(--brand); }
.footer-top  { padding-bottom:0; }

.social-links { display:flex; gap:10px; margin-top:18px; }
.social-btn {
  width:38px; height:38px; border-radius:50%;
  background:rgba(255,255,255,0.16); border:1px solid rgba(255,255,255,0.25);
  display:flex; align-items:center; justify-content:center;
  transition:all var(--dur-fast);
}
.social-btn:hover { background:rgba(255,255,255,0.30); border-color:rgba(255,255,255,0.45); transform:translateY(-2px); }
.social-btn img { width:16px; height:16px; filter:brightness(0) invert(1); }

/* ── CONTACT ── */
.contact-section { background:var(--bg-section); }
.contact-grid    { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start; }
@media (max-width:768px) { .contact-grid { grid-template-columns:1fr; gap:36px; } }

.contact-info { display:flex; flex-direction:column; gap:16px; }

.contact-item {
  display:flex; align-items:flex-start; gap:16px;
  background:#fff; border:2px solid rgba(26,8,0,0.08);
  border-radius:var(--r-md); padding:16px 18px;
  transition:all var(--dur-med);
}
.contact-item:hover { border-color:var(--brand); box-shadow:var(--shadow-sm); }

.contact-icon {
  width:44px; height:44px; flex-shrink:0; border-radius:var(--r-sm);
  background:var(--brand-soft); border:2px solid rgba(233,78,27,0.18);
  display:flex; align-items:center; justify-content:center; overflow:hidden;
}
.contact-icon img { width:22px; height:22px; }

.contact-item-label { font-size:11px; font-weight:700; letter-spacing:.5px; color:var(--ink-40); text-transform:uppercase; margin-bottom:2px; }
.contact-item-value { font-size:15px; font-weight:700; color:var(--ink); }

/* ── HERO SCROLL LINE ── */
.scroll-line {
  width:1px; height:38px;
  background:linear-gradient(to bottom,rgba(255,255,255,0.55),transparent);
  animation:scrollPulse 2s var(--ease) infinite;
}
@keyframes scrollPulse { 0%,100%{opacity:.6} 50%{opacity:.15} }

/* ── BRANCH CARD (homepage) ── */
.branch-card-img-slot {
  width:100%; height:160px;
  background:var(--bg-section); position:relative; overflow:hidden;
}
.branch-card-img-slot img { width:100%; height:100%; object-fit:cover; display:block; transition:transform .5s var(--ease); }
.branch-card:hover .branch-card-img-slot img { transform:scale(1.04); }
.img-grid-overlay {
  position:absolute; inset:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(233,78,27,0.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(233,78,27,0.05) 1px,transparent 1px);
  background-size:24px 24px;
}
.branch-hours { font-size:11px; color:var(--ink-40); font-weight:600; }
