/* ============================================================
   UnderstandSEO — interactive.css
   Shared chrome for the interactive components: the accessible
   dialog shell, the "Demo preview" badge, and the mobile action
   bar safe-area handling. Component-specific styling lives in each
   component's own <style> block. Load after tokens.css /
   type-pairings.css, alongside interactive.js.
   ============================================================ */

/* ---- accessible dialog shell (cart, reserve, dish sheet, popup, mock) ---- */
.useo-dialog[hidden] { display: none; }
.useo-dialog {
  position: fixed; inset: 0; z-index: 1000;
  display: flex; align-items: center; justify-content: center;
  padding: 1rem;
}
.useo-dialog-backdrop {
  position: absolute; inset: 0;
  background: rgba(20, 16, 10, 0.55);
  backdrop-filter: blur(2px);
  animation: useo-fade 180ms ease both;
}
.useo-dialog-panel {
  position: relative; z-index: 1;
  width: 100%; max-width: 480px;
  max-height: min(88vh, 760px); overflow-y: auto;
  background: var(--surface); color: var(--ink);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: clamp(1.25rem, 4vw, 2rem);
  animation: useo-rise 220ms cubic-bezier(0.2, 0.7, 0.2, 1) both;
}
/* drawer variant: slides in from the right (cart) */
.useo-dialog.useo-drawer { justify-content: flex-end; padding: 0; }
.useo-dialog.useo-drawer .useo-dialog-panel {
  max-width: 420px; height: 100%; max-height: 100%;
  border-radius: 0; animation: useo-slide 240ms cubic-bezier(0.2,0.7,0.2,1) both;
}
.useo-dialog-close {
  position: absolute; top: 0.75rem; right: 0.75rem;
  width: 40px; height: 40px; border-radius: 50%;
  border: none; background: var(--surface-2); color: var(--ink);
  font-size: 1.25rem; line-height: 1; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
}
.useo-dialog-close:hover { background: var(--rule); }

.useo-demo-badge {
  display: inline-flex; align-items: center; gap: .4rem;
  font-family: var(--font-mono); font-size: 0.6875rem;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--accent-ink); background: var(--accent-soft);
  padding: 0.25rem 0.6rem; border-radius: var(--radius-pill);
}

@keyframes useo-fade { from { opacity: 0; } to { opacity: 1; } }
@keyframes useo-rise { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }
@keyframes useo-slide { from { transform: translateX(100%); } to { transform: none; } }
@media (prefers-reduced-motion: reduce) {
  .useo-dialog-backdrop, .useo-dialog-panel { animation: none; }
}

/* ---- mobile sticky action bar safe area ---- */
.useo-action-bar { padding-bottom: calc(0.75rem + env(safe-area-inset-bottom, 0px)); }


/* ============================================================
   INTERACTIVE COMPONENT STYLES (single source of truth)
   Linked by every template via interactive.css so a template can
   never be missing a component's styling. Components also carry an
   inline <style> for standalone preview; rules are identical.
   ============================================================ */

/* ===== menu-interactive (improved: wider + on-theme tabs) ===== */
#menu .container-prose { max-width: 1340px; }
.menu-i-tabs { display:flex; gap:.5rem; flex-wrap:wrap; }
.menu-i-tab {
  font-family:var(--font-body); font-size:.9375rem; font-weight:500; letter-spacing:.01em;
  padding:.55rem 1.25rem; border-radius:var(--radius-pill);
  border:1px solid var(--rule); background:transparent; color:var(--ink-2);
  cursor:pointer; transition:background 140ms ease,color 140ms ease,border-color 140ms ease;
}
.menu-i-tab:hover { background:var(--accent-soft); border-color:var(--accent-soft); color:var(--accent-ink); }
.menu-i-tab[aria-selected="true"] { background:var(--accent); color:#fff; border-color:var(--accent); }
.menu-i-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:1.75rem; }
.dish-card { display:flex; flex-direction:column; text-align:left; background:var(--bg);
  border:1px solid var(--rule); border-radius:var(--radius-lg); overflow:hidden; cursor:pointer;
  transition:transform 160ms ease, box-shadow 160ms ease; }
.dish-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.dish-card-media { position:relative; aspect-ratio:4/3; background:var(--surface-2); overflow:hidden; }
.dish-card-media img { width:100%; height:100%; object-fit:cover; display:block; }
.dish-badge { position:absolute; top:.85rem; left:.85rem; background:var(--accent); color:#fff;
  font-family:var(--font-mono); font-size:.625rem; letter-spacing:.08em; text-transform:uppercase;
  padding:.35rem .65rem; border-radius:var(--radius-pill); box-shadow:var(--shadow-sm); }
.dish-card-body { padding:1.25rem 1.25rem 1.4rem; display:flex; flex-direction:column; flex:1; }
.dish-card-head { display:flex; justify-content:space-between; align-items:baseline; gap:.75rem; }
.dish-name { font-size:1.25rem; }
.dish-price { font-family:var(--font-mono); font-weight:600; color:var(--accent-ink); white-space:nowrap; }
.dish-desc { color:var(--ink-2); font-size:.9375rem; line-height:1.5; margin-top:.45rem; }
.dish-tags { display:flex; flex-wrap:wrap; gap:.4rem; margin-top:.7rem; }
.dish-tags .tag { font-family:var(--font-mono); font-size:.625rem; letter-spacing:.05em; text-transform:uppercase;
  color:var(--ink-3); border:1px solid var(--rule); border-radius:var(--radius-sm); padding:.18rem .45rem; }
.dish-quote { font-family:var(--font-display); font-style:italic; font-size:.9375rem; color:var(--ink); margin-top:.85rem; line-height:1.4; }
.dish-quote span { font-style:normal; font-family:var(--font-mono); font-size:.6875rem; color:var(--ink-3); text-transform:uppercase; letter-spacing:.05em; }
.dish-card-actions { display:flex; align-items:center; gap:.75rem; margin-top:auto; padding-top:1.1rem; }
.dish-like { display:inline-flex; align-items:center; gap:.4rem; border:1px solid var(--rule); background:var(--surface);
  color:var(--ink-3); border-radius:var(--radius-pill); padding:.5rem .8rem; cursor:pointer; font-size:.8125rem;
  transition:background 140ms ease,color 140ms ease,border-color 140ms ease; }
.dish-like:hover { border-color:var(--accent); color:var(--accent); }
.dish-like[aria-pressed="true"] { color:var(--accent); border-color:var(--accent); background:var(--accent-soft); }
.dish-add { margin-left:auto; padding:.6rem 1.4rem; }
@media (max-width:560px){ .menu-i-grid { grid-template-columns:1fr; } }


/* ===== order-cart ===== */
.oc-toggle { display:flex; background:var(--surface-2); border-radius:var(--radius-pill); padding:.25rem; }
.oc-toggle-btn {
  flex:1; border:none; background:transparent; color:var(--ink-2);
  font-family:var(--font-body); font-weight:500; font-size:.9375rem;
  padding:.5rem; border-radius:var(--radius-pill); cursor:pointer;
}
.oc-toggle-btn[aria-selected="true"] { background:var(--surface); color:var(--ink); box-shadow:var(--shadow-sm); }
.oc-line { display:flex; align-items:center; gap:.75rem; padding:.75rem 0; border-bottom:1px solid var(--rule); }
.oc-line-name { flex:1; font-weight:500; }
.oc-line-name small { display:block; font-weight:400; color:var(--ink-3); font-family:var(--font-mono); font-size:.75rem; }
.oc-stepper { display:flex; align-items:center; gap:.5rem; }
.oc-stepper button {
  width:28px; height:28px; border-radius:50%; border:1px solid var(--rule);
  background:var(--surface); color:var(--ink); cursor:pointer; font-size:1rem; line-height:1;
}
.oc-qty { min-width:1.25rem; text-align:center; font-variant-numeric:tabular-nums; }
.oc-remove { background:none; border:none; color:var(--ink-3); cursor:pointer; font-size:.8125rem; text-decoration:underline; }

/* ===== reserve-widget ===== */
.rw-wrap { display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.rw-card {
  background:var(--surface); border:1px solid var(--rule); border-radius:var(--radius-lg);
  box-shadow:var(--shadow); padding:clamp(1.25rem,3vw,1.75rem);
  display:flex; flex-direction:column; gap:1rem;
}
.rw-row { display:flex; gap:.75rem; }
.rw-field { flex:1; display:flex; flex-direction:column; gap:.35rem; }
.rw-field span { font-family:var(--font-mono); font-size:.6875rem; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); }
.rw-field input, .rw-field select {
  font-family:var(--font-body); font-size:1rem; padding:.65rem .75rem;
  border:1px solid var(--rule); border-radius:var(--radius); background:var(--bg); color:var(--ink);
}
.rw-slots { border:none; padding:0; margin:0; }
.rw-slots legend { font-family:var(--font-mono); font-size:.6875rem; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); margin-bottom:.5rem; }
.rw-chip-row { display:flex; flex-wrap:wrap; gap:.5rem; }
.rw-chip { position:relative; }
.rw-chip input { position:absolute; opacity:0; inset:0; cursor:pointer; }
.rw-chip span {
  display:inline-flex; padding:.5rem .9rem; border-radius:var(--radius-pill);
  border:1px solid var(--rule); background:var(--bg); color:var(--ink-2);
  font-size:.9375rem; cursor:pointer; transition:all 120ms ease;
}
.rw-chip input:checked + span { background:var(--ink); color:var(--bg); border-color:var(--ink); }
.rw-chip input:focus-visible + span { outline:2px solid var(--accent); outline-offset:2px; }
.rw-chip-full span { opacity:.4; text-decoration:line-through; cursor:not-allowed; }
.rw-fullnote { font-size:.8125rem; color:var(--accent-ink); margin-top:.5rem; }
.rw-waitlist { background:none; border:none; color:var(--accent-ink); text-decoration:underline; cursor:pointer; font-size:.9375rem; }
@media (max-width:768px){ .rw-wrap { grid-template-columns:1fr; } }

/* ===== ordering-bar ===== */
.ordering-bar {
  position:fixed; left:0; right:0; bottom:0; z-index:900;
  display:none; gap:.5rem;
  background:var(--surface); border-top:1px solid var(--rule);
  box-shadow:0 -4px 16px rgba(0,0,0,.08);
  padding:.75rem 1rem;
}
.ob-btn {
  flex:1; display:inline-flex; flex-direction:column; align-items:center; gap:.15rem;
  padding:.4rem; border-radius:var(--radius); color:var(--ink-2);
  font-size:.75rem; font-weight:500; font-family:var(--font-body);
}
.ob-btn svg { color:var(--ink-3); }
.ob-primary { background:var(--accent); color:var(--bg); }
.ob-primary svg { color:var(--bg); }
@media (max-width:768px){
  .ordering-bar { display:flex; }
  /* keep page content clear of the bar */
  body { padding-bottom:5rem; }
}

/* ===== reviews-wall ===== */
.rwall-summary { display:grid; grid-template-columns:auto 1fr; gap:clamp(1.5rem,5vw,4rem); align-items:center;
  margin-top:1.75rem; padding:1.5rem; background:var(--bg); border:1px solid var(--rule); border-radius:var(--radius-lg); }
.rwall-score { text-align:center; }
.rwall-avg { font-family:var(--font-display); font-size:clamp(3rem,7vw,4.5rem); line-height:1; color:var(--ink); display:block; }
.rwall-stars { display:flex; gap:2px; justify-content:center; margin:.35rem 0; }
.rwall-count { font-size:.8125rem; color:var(--ink-3); }
.rwall-dist { display:flex; flex-direction:column; gap:.4rem; }
.rwall-distrow { display:flex; align-items:center; gap:.6rem; font-size:.8125rem; color:var(--ink-2); }
.rwall-distrow > span:first-child { width:2rem; font-variant-numeric:tabular-nums; }
.rwall-bar { flex:1; height:8px; background:var(--surface-2); border-radius:var(--radius-pill); overflow:hidden; }
.rwall-bar i { display:block; height:100%; background:var(--accent); border-radius:var(--radius-pill); }
.rwall-pct { width:3rem; text-align:right; font-variant-numeric:tabular-nums; color:var(--ink-3); }

.rwall-tabs { display:flex; gap:.5rem; flex-wrap:wrap; }
.rwall-tab { font-family:var(--font-body); font-size:.9375rem; font-weight:500; padding:.45rem 1rem;
  border-radius:var(--radius-pill); border:1px solid var(--rule); background:var(--bg); color:var(--ink-2); cursor:pointer; }
.rwall-tab[aria-selected="true"] { background:var(--ink); color:var(--bg); border-color:var(--ink); }

.rwall-grid { columns:3 260px; column-gap:1.25rem; }
.rwall-card { break-inside:avoid; margin:0 0 1.25rem; padding:1.25rem;
  background:var(--bg); border:1px solid var(--rule); border-radius:var(--radius); }
.rwall-card-top { display:flex; justify-content:space-between; align-items:center; margin-bottom:.6rem; }
.rwall-card-stars { color:#FBBC04; letter-spacing:1px; font-size:.9rem; }
.rwall-src { font-family:var(--font-mono); font-size:.625rem; text-transform:uppercase; letter-spacing:.06em;
  padding:.15rem .45rem; border-radius:var(--radius-sm); color:var(--ink-3); border:1px solid var(--rule); }
.rwall-src-google { color:#1a73e8; border-color:#1a73e8; }
.rwall-src-yelp { color:#d32323; border-color:#d32323; }
.rwall-src-facebook { color:#1877f2; border-color:#1877f2; }
.rwall-text { margin:0; font-size:.9375rem; line-height:1.55; color:var(--ink-2); }
.rwall-by { margin-top:.75rem; font-size:.8125rem; font-weight:500; color:var(--ink); }
.rwall-by span { color:var(--ink-3); font-weight:400; }
@media (max-width:680px){ .rwall-summary { grid-template-columns:1fr; } .rwall-grid { columns:1; } }

/* ===== promo-popup ===== */
.promo-panel { max-width:560px; padding:0; overflow:hidden; display:grid; grid-template-columns:1fr 1fr; }
.promo-media { background:var(--surface-2); }
.promo-media img { width:100%; height:100%; object-fit:cover; display:block; min-height:240px; }
.promo-body { padding:clamp(1.25rem,3vw,1.75rem); }
.promo-input { font-family:var(--font-body); font-size:1rem; padding:.7rem .85rem;
  border:1px solid var(--rule); border-radius:var(--radius); background:var(--bg); color:var(--ink); }
.promo-fine { font-size:.6875rem; color:var(--ink-3); margin-top:.75rem; line-height:1.4; }
@media (max-width:560px){ .promo-panel { grid-template-columns:1fr; } .promo-media{ display:none; } }

/* ===== loyalty-block ===== */
.loy-wrap { display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.loy-join { display:flex; gap:.6rem; flex-wrap:wrap; margin-top:1.5rem; }
.loy-input { flex:1; min-width:200px; font-family:var(--font-body); font-size:1rem; padding:.7rem .85rem;
  border:1px solid var(--rule); border-radius:var(--radius); background:var(--bg); color:var(--ink); }
.loy-card { background:var(--surface); border:1px solid var(--rule); border-radius:var(--radius-lg);
  box-shadow:var(--shadow); padding:clamp(1.25rem,3vw,1.75rem); }
.loy-card-head { display:flex; justify-content:space-between; align-items:center;
  padding-bottom:1rem; border-bottom:1px solid var(--rule); margin-bottom:1rem; }
.loy-card-label { font-family:var(--font-mono); font-size:.6875rem; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); }
.loy-points strong { font-family:var(--font-display); color:var(--accent-ink); }
.loy-ladder { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:.85rem; }
.loy-ladder li { display:flex; align-items:center; gap:1rem; }
.loy-tier { flex:0 0 auto; min-width:4.5rem; text-align:center;
  font-family:var(--font-mono); font-weight:600; font-size:.8125rem; color:var(--accent-ink);
  background:var(--accent-soft); border-radius:var(--radius-pill); padding:.35rem .6rem; }
.loy-reward { color:var(--ink); font-size:.9375rem; }
@media (max-width:768px){ .loy-wrap { grid-template-columns:1fr; } }
