/* =============================================================================
   Pacific Avenue Bowl - site styles
   Consumes brand tokens from assets/brand.css by NAME. No hardcoded brand hex.
   Mobile-first, accessible, vanilla CSS.
   ============================================================================= */

/* --------------------------------- Reset --------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  background: var(--pab-bg);
  color: var(--pab-ink);
  font-family: var(--pab-font-body);
  font-size: var(--pab-text-base);
  line-height: var(--pab-leading-body);
  font-weight: var(--pab-weight-body);
}
img, svg { max-width: 100%; height: auto; display: block; }
h1, h2, h3, h4 { font-family: var(--pab-font-display); line-height: var(--pab-leading-heading); margin: 0; letter-spacing: var(--pab-tracking-display); }
p { margin: 0; }
a { color: var(--pab-primary); }
ul { margin: 0; padding: 0; list-style: none; }

/* Smooth scroll with header offset; reduced-motion handled below */
html { scroll-behavior: smooth; scroll-padding-top: 96px; }

.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}

/* ------------------------------ Skip link -------------------------------- */
.skip-link {
  position: absolute; left: var(--pab-space-sm); top: -100px;
  background: var(--pab-primary); color: var(--pab-primary-ink);
  padding: var(--pab-space-2xs) var(--pab-space-sm);
  border-radius: var(--pab-radius-sm); z-index: 200;
  font-weight: var(--pab-weight-bold); text-decoration: none;
}
.skip-link:focus-visible { top: var(--pab-space-2xs); }

/* ------------------------------ Container --------------------------------- */
.container {
  width: 100%; max-width: var(--pab-container-max);
  margin-inline: auto;
  padding-inline: var(--pab-container-pad);
}
@media (min-width: 960px) {
  .container { padding-inline: var(--pab-container-pad-md); }
}

/* ------------------------- Focus visibility ------------------------------- */
:focus-visible {
  outline: 3px solid var(--pab-focus);
  outline-offset: 2px;
  border-radius: var(--pab-radius-sm);
}

/* ----------------------------- Demo banner -------------------------------- */
.demo-banner {
  background: var(--pab-warning-tint);
  border-bottom: 2px solid var(--pab-warning);
  color: var(--pab-ink);
  display: flex; align-items: center; gap: var(--pab-space-2xs);
  padding: var(--pab-space-2xs) var(--pab-container-pad);
  font-size: var(--pab-text-sm);
}
.demo-banner p { margin: 0; }
.demo-banner strong { color: var(--pab-warning); }
.demo-banner__dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--pab-warning); flex: 0 0 auto;
}

/* ------------------------------- Buttons ---------------------------------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: var(--pab-space-2xs);
  min-height: var(--pab-tap-primary);
  padding: var(--pab-space-2xs) var(--pab-space-md);
  font-family: var(--pab-font-body);
  font-size: var(--pab-text-base);
  font-weight: var(--pab-weight-bold);
  border: 2px solid transparent;
  border-radius: var(--pab-radius);
  cursor: pointer; text-decoration: none;
  transition: background-color var(--pab-duration) var(--pab-ease),
              border-color var(--pab-duration) var(--pab-ease),
              transform var(--pab-duration) var(--pab-ease);
}
.btn--primary { background: var(--pab-primary); color: var(--pab-primary-ink); }
.btn--primary:hover { background: var(--pab-primary-hover); }
.btn--primary:active { background: var(--pab-primary-active); }
.btn--accent { background: var(--pab-accent); color: var(--pab-accent-ink); }
.btn--accent:hover { background: var(--pab-accent-hover); }
.btn--ghost {
  background: var(--pab-surface); color: var(--pab-ink);
  border-color: var(--pab-line);
}
.btn--ghost:hover { background: var(--pab-surface-2); }
.btn--lg { min-height: 56px; font-size: var(--pab-text-md); padding-inline: var(--pab-space-lg); }
.btn--block { width: 100%; }
.btn[disabled], .btn[aria-disabled="true"] {
  opacity: 0.5; cursor: not-allowed;
}

/* ---------------------------- Header / nav -------------------------------- */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: var(--pab-surface);
  border-bottom: 1px solid var(--pab-line);
}
.site-header.is-scrolled { box-shadow: var(--pab-shadow); }
.site-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--pab-space-sm);
  min-height: 64px;
  padding-block: var(--pab-space-2xs);
}
.logo { display: inline-flex; align-items: center; gap: var(--pab-space-2xs); text-decoration: none; color: var(--pab-ink); }
.logo__mark { width: 44px; height: 44px; }
.logo__text { font-family: var(--pab-font-display); font-weight: var(--pab-weight-bold); font-size: var(--pab-text-md); white-space: nowrap; }

.primary-nav { display: flex; align-items: center; }

.nav-toggle {
  display: inline-flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 4px;
  min-width: var(--pab-tap-min); min-height: var(--pab-tap-min);
  background: var(--pab-surface); border: 2px solid var(--pab-line);
  border-radius: var(--pab-radius-sm); cursor: pointer; color: var(--pab-ink);
}
.nav-toggle__bars, .nav-toggle__bars::before, .nav-toggle__bars::after {
  content: ""; display: block; width: 22px; height: 2px; background: var(--pab-ink); position: relative;
}
.nav-toggle__bars::before { position: absolute; top: -6px; }
.nav-toggle__bars::after { position: absolute; top: 6px; }
.nav-toggle__label { font-size: 11px; font-weight: var(--pab-weight-bold); }

.nav-menu { display: none; }
.header-reserve { display: none; }

/* Mobile menu panel (open state) */
.nav-menu.is-open {
  display: flex; flex-direction: column;
  position: fixed; top: 0; right: 0; bottom: 0;
  width: min(86vw, 360px);
  background: var(--pab-surface);
  box-shadow: var(--pab-shadow-pop);
  padding: var(--pab-space-2xl) var(--pab-space-md) var(--pab-space-md);
  gap: var(--pab-space-2xs);
  z-index: 150;
  overflow-y: auto;
}
.nav-menu.is-open .nav-link,
.nav-menu.is-open .nav-menu__reserve .btn {
  display: flex; align-items: center;
  min-height: 52px;
  width: 100%;
  padding: var(--pab-space-2xs) var(--pab-space-sm);
  font-size: var(--pab-text-md); font-weight: var(--pab-weight-medium);
  color: var(--pab-ink); text-decoration: none;
  border-radius: var(--pab-radius); border-bottom: 1px solid var(--pab-line-soft);
}
.nav-menu.is-open .nav-menu__reserve { margin-top: var(--pab-space-sm); }
.nav-menu.is-open .nav-link.is-active { background: var(--pab-surface-2); }

.menu-backdrop {
  position: fixed; inset: 0; background: rgba(11,18,48,0.4); z-index: 140;
}

/* Desktop nav */
@media (min-width: 768px) {
  .nav-toggle { display: none; }
  .nav-menu {
    display: flex; align-items: center; gap: var(--pab-space-xs);
    position: static; width: auto; flex-direction: row;
    background: none; box-shadow: none; padding: 0;
  }
  .nav-menu .nav-menu__reserve { display: none; }
  .nav-link {
    display: inline-flex; align-items: center; min-height: var(--pab-tap-min);
    padding: var(--pab-space-2xs) var(--pab-space-2xs);
    color: var(--pab-ink); text-decoration: none; font-weight: var(--pab-weight-medium);
    border-bottom: 3px solid transparent; border-radius: var(--pab-radius-sm);
  }
  .nav-link:hover { color: var(--pab-primary); }
  .nav-link.is-active { color: var(--pab-primary); border-bottom-color: var(--pab-primary); }
  .header-reserve { display: inline-flex; }
}
@media (min-width: 960px) {
  .nav-menu { gap: var(--pab-space-sm); }
}

/* -------------------------------- Hero ------------------------------------ */
.hero { position: relative; overflow: hidden; background: var(--pab-ink); }
.hero__art { position: absolute; inset: 0; background-image: var(--pab-hero-scrim); z-index: 1; }
.hero__lanes {
  position: absolute; inset: 0; z-index: 0; opacity: 0.95;
  background:
    repeating-linear-gradient(90deg,
      color-mix(in srgb, var(--pab-accent) 12%, transparent) 0 2px,
      transparent 2px 56px),
    radial-gradient(120% 90% at 50% -10%,
      color-mix(in srgb, var(--pab-ink) 78%, var(--pab-accent)) 0%,
      var(--pab-ink) 45%,
      color-mix(in srgb, var(--pab-ink) 80%, black) 100%);
}
.hero__inner {
  position: relative; z-index: 2;
  padding-block: var(--pab-space-3xl) var(--pab-space-2xl);
  color: var(--pab-surface);
  max-width: 760px;
}
.hero__eyebrow {
  text-transform: uppercase; letter-spacing: var(--pab-tracking-eyebrow);
  font-size: var(--pab-text-sm); font-weight: var(--pab-weight-bold);
  color: var(--pab-accent); margin-bottom: var(--pab-space-sm);
}
.hero__title { font-size: var(--pab-text-3xl); color: var(--pab-surface); margin-bottom: var(--pab-space-2xs); }
.hero__tagline { font-size: var(--pab-text-xl); font-family: var(--pab-font-display); color: var(--pab-accent); margin-bottom: var(--pab-space-sm); }
.hero__lead { font-size: var(--pab-text-md); color: var(--pab-surface); margin-bottom: var(--pab-space-lg); }
.hero__cta { display: flex; flex-direction: column; gap: var(--pab-space-2xs); margin-bottom: var(--pab-space-sm); }
.hero__note { font-size: var(--pab-text-sm); color: var(--pab-surface); color: color-mix(in srgb, var(--pab-surface) 82%, var(--pab-ink)); }

@media (min-width: 600px) {
  .hero__cta { flex-direction: row; flex-wrap: wrap; }
  .hero__cta .btn { flex: 0 1 auto; }
}
@media (min-width: 960px) {
  .hero__inner { padding-block: var(--pab-space-4xl); }
  .hero__title { font-size: 3.75rem; }
}

/* ------------------------------ Sections ---------------------------------- */
.section { padding-block: var(--pab-section-pad); }
.section--alt { background: var(--pab-surface-2); }
@media (min-width: 960px) { .section { padding-block: var(--pab-section-pad-md); } }

.section-head { max-width: 720px; margin-bottom: var(--pab-space-lg); }
.eyebrow {
  text-transform: uppercase; letter-spacing: var(--pab-tracking-eyebrow);
  font-size: var(--pab-text-sm); font-weight: var(--pab-weight-bold);
  color: var(--pab-primary); margin-bottom: var(--pab-space-2xs);
}
.section-title { font-size: var(--pab-text-xl); margin-bottom: var(--pab-space-2xs); }
@media (min-width: 960px) { .section-title { font-size: var(--pab-text-2xl); } }
.section-lead { font-size: var(--pab-text-md); color: var(--pab-ink-muted); }

.block-title { font-size: var(--pab-text-lg); margin: var(--pab-space-xl) 0 var(--pab-space-sm); }
.block-title--flush { margin-top: 0; }
.block-note { color: var(--pab-ink-muted); margin-bottom: var(--pab-space-sm); font-size: var(--pab-text-base); }
.block-note--warn {
  display: inline-block; background: var(--pab-warning-tint);
  border-left: 4px solid var(--pab-warning); color: var(--pab-ink);
  padding: var(--pab-space-2xs) var(--pab-space-sm); border-radius: var(--pab-radius-sm);
}
.block-foot { color: var(--pab-ink-muted); margin-top: var(--pab-space-sm); font-size: var(--pab-text-sm); }

/* ------------------------------ Card grids -------------------------------- */
.card-grid { display: grid; gap: var(--pab-space-sm); grid-template-columns: 1fr; }
@media (min-width: 600px) {
  .card-grid--2, .card-grid--3 { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 960px) {
  .card-grid--3 { grid-template-columns: repeat(3, 1fr); }
}

/* Price cards */
.price-card {
  background: var(--pab-surface); border: 1px solid var(--pab-line-soft);
  border-radius: var(--pab-radius); padding: var(--pab-space-md);
  box-shadow: var(--pab-shadow);
}
.price-card__label { font-weight: var(--pab-weight-medium); color: var(--pab-ink-muted); margin-bottom: var(--pab-space-2xs); }
.price-card__price { font-family: var(--pab-font-display); font-size: var(--pab-text-2xl); color: var(--pab-ink); }
.price-card__note { color: var(--pab-ink-muted); font-size: var(--pab-text-sm); }
.price-card__blurb { margin-top: var(--pab-space-2xs); font-size: var(--pab-text-sm); color: var(--pab-ink-muted); }
.price-card--feature { border: 2px solid var(--pab-accent); }
.fn-marker { color: var(--pab-warning); font-weight: var(--pab-weight-bold); }
.footnote { margin-top: var(--pab-space-sm); font-size: var(--pab-text-sm); color: var(--pab-ink-muted); }

/* Callout */
.callout {
  margin-top: var(--pab-space-lg);
  background: var(--pab-surface); border: 1px solid var(--pab-line);
  border-radius: var(--pab-radius); padding: var(--pab-space-md);
  display: flex; flex-direction: column; gap: var(--pab-space-sm);
  box-shadow: var(--pab-shadow);
}
.callout__text { font-size: var(--pab-text-base); }
@media (min-width: 768px) {
  .callout { flex-direction: row; align-items: center; justify-content: space-between; }
  .callout .btn { flex: 0 0 auto; }
}

/* Info cards */
.info-card {
  background: var(--pab-surface); border: 1px solid var(--pab-line-soft);
  border-radius: var(--pab-radius); padding: var(--pab-space-md);
  box-shadow: var(--pab-shadow);
}
.info-card__title { font-size: var(--pab-text-lg); margin-bottom: var(--pab-space-2xs); color: var(--pab-ink); }
.info-card__price { font-weight: var(--pab-weight-bold); color: var(--pab-primary); margin-bottom: var(--pab-space-2xs); }
.info-card p { color: var(--pab-ink-muted); }

/* ----------------------------- Standings ---------------------------------- */
.standings {
  margin-top: var(--pab-space-xl);
  background: var(--pab-surface); border: 1px solid var(--pab-line);
  border-radius: var(--pab-radius); padding: var(--pab-space-md);
  box-shadow: var(--pab-shadow);
}
.standings__head { display: flex; flex-wrap: wrap; align-items: center; gap: var(--pab-space-sm); margin-bottom: var(--pab-space-sm); }
.badge {
  display: inline-flex; align-items: center; text-transform: uppercase;
  letter-spacing: 0.08em; font-weight: var(--pab-weight-bold); font-size: var(--pab-text-sm);
  padding: 4px var(--pab-space-2xs); border-radius: var(--pab-radius-pill);
}
.badge--sample { background: var(--pab-warning); color: var(--pab-warning-ink); }

.standings__table { width: 100%; border-collapse: collapse; }
.standings__table caption { caption-side: bottom; text-align: left; color: var(--pab-ink-muted); font-size: var(--pab-text-sm); padding-top: var(--pab-space-sm); }
.standings__table th, .standings__table td { text-align: left; padding: var(--pab-space-2xs) var(--pab-space-xs); border-bottom: 1px solid var(--pab-line-soft); }
.standings__table thead th { color: var(--pab-ink); border-bottom: 2px solid var(--pab-line); font-size: var(--pab-text-sm); text-transform: uppercase; letter-spacing: 0.04em; }
.standings__table tbody th { font-weight: var(--pab-weight-bold); }
.standings__table tbody tr:nth-child(odd) { background: var(--pab-bg); }

.standings__cards { display: none; }
.standings__note { display: none; margin-top: var(--pab-space-sm); color: var(--pab-ink-muted); font-size: var(--pab-text-sm); }
.standings-card {
  display: grid; grid-template-columns: auto 1fr; gap: var(--pab-space-2xs) var(--pab-space-sm);
  align-items: center; padding: var(--pab-space-sm) 0; border-bottom: 1px solid var(--pab-line-soft);
}
.standings-card__rank {
  grid-row: span 2; width: 40px; height: 40px; border-radius: 50%;
  background: var(--pab-accent); color: var(--pab-accent-ink);
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--pab-font-display); font-weight: var(--pab-weight-bold); font-size: var(--pab-text-md);
}
.standings-card__team { font-weight: var(--pab-weight-bold); font-size: var(--pab-text-md); }
.standings-card__stats { display: flex; gap: var(--pab-space-md); margin: 0; }
.standings-card__stats div { display: flex; flex-direction: column; }
.standings-card__stats dt { font-size: var(--pab-text-sm); color: var(--pab-ink-muted); }
.standings-card__stats dd { margin: 0; font-weight: var(--pab-weight-bold); }

@media (max-width: 599px) {
  .standings__table { display: none; }
  .standings__cards { display: block; }
  .standings__note { display: block; }
}

/* ------------------------------- Parties ---------------------------------- */
.party-card {
  background: var(--pab-surface); border: 1px solid var(--pab-line-soft);
  border-radius: var(--pab-radius); padding: var(--pab-space-md);
  box-shadow: var(--pab-shadow);
}
.party-card--feature { border: 2px solid var(--pab-primary); }
.party-card__title { font-size: var(--pab-text-lg); margin-bottom: var(--pab-space-2xs); }
.party-card__price { font-family: var(--pab-font-display); font-size: var(--pab-text-2xl); color: var(--pab-primary); margin-bottom: var(--pab-space-2xs); }
.party-card__price span { font-family: var(--pab-font-body); font-size: var(--pab-text-base); color: var(--pab-ink-muted); }
.party-card p { color: var(--pab-ink-muted); }

.details-strip {
  margin-top: var(--pab-space-sm);
  background: var(--pab-surface-2); border-radius: var(--pab-radius);
  padding: var(--pab-space-sm) var(--pab-space-md); color: var(--pab-ink);
  font-size: var(--pab-text-sm);
}
.section--alt .details-strip { background: var(--pab-surface); }

.banquet {
  margin-top: var(--pab-space-xl);
  background: var(--pab-surface); border: 1px solid var(--pab-line-soft);
  border-radius: var(--pab-radius); padding: var(--pab-space-md); box-shadow: var(--pab-shadow);
}
.banquet p { color: var(--pab-ink-muted); }

/* ----------------------------- Eat / venues ------------------------------- */
.venue-card {
  background: var(--pab-surface); border: 1px solid var(--pab-line-soft);
  border-radius: var(--pab-radius); padding: var(--pab-space-md); box-shadow: var(--pab-shadow);
}
.venue-card__title { font-size: var(--pab-text-lg); margin-bottom: var(--pab-space-3xs); }
.venue-card__hours { color: var(--pab-primary); font-weight: var(--pab-weight-bold); margin-bottom: var(--pab-space-2xs); }
.venue-card p { color: var(--pab-ink-muted); margin-bottom: var(--pab-space-2xs); }
.menu-label {
  display: inline-block; margin-top: var(--pab-space-2xs);
  background: var(--pab-warning-tint); border-left: 4px solid var(--pab-warning);
  padding: 4px var(--pab-space-2xs); border-radius: var(--pab-radius-sm);
  font-size: var(--pab-text-sm); color: var(--pab-ink);
}
.menu-list { margin-top: var(--pab-space-2xs); display: flex; flex-wrap: wrap; gap: var(--pab-space-2xs); }
.menu-list li {
  background: var(--pab-surface-2); padding: var(--pab-space-3xs) var(--pab-space-xs);
  border-radius: var(--pab-radius-pill); font-size: var(--pab-text-sm); font-weight: var(--pab-weight-medium);
}

/* -------------------------------- Visit ----------------------------------- */
.visit-grid { display: grid; gap: var(--pab-space-lg); grid-template-columns: 1fr; }
@media (min-width: 960px) { .visit-grid { grid-template-columns: 1fr 1fr; gap: var(--pab-space-xl); } }
.visit-col > .btn { margin-top: var(--pab-space-sm); }

.hours-table { width: 100%; border-collapse: collapse; margin-bottom: var(--pab-space-sm); }
.hours-table th, .hours-table td { text-align: left; padding: var(--pab-space-2xs) var(--pab-space-xs); border-bottom: 1px solid var(--pab-line-soft); }
.hours-table th { font-weight: var(--pab-weight-bold); }
.hours-table td { color: var(--pab-ink-muted); }
.hours-extra { font-size: var(--pab-text-sm); color: var(--pab-ink-muted); margin-bottom: var(--pab-space-2xs); }

.contact-card {
  background: var(--pab-surface); border: 1px solid var(--pab-line-soft);
  border-radius: var(--pab-radius); padding: var(--pab-space-md); box-shadow: var(--pab-shadow);
  margin-bottom: var(--pab-space-sm);
}
.contact-card__address { font-style: normal; font-size: var(--pab-text-md); margin-bottom: var(--pab-space-sm); }
.contact-row { margin-bottom: var(--pab-space-2xs); }
.contact-row__label { display: inline-block; min-width: 64px; font-weight: var(--pab-weight-bold); color: var(--pab-ink-muted); }
.contact-card__note { font-size: var(--pab-text-sm); color: var(--pab-ink-muted); margin: 0 0 var(--pab-space-sm); }
.contact-card__parking { font-size: var(--pab-text-sm); color: var(--pab-ink-muted); margin: var(--pab-space-2xs) 0; }
.contact-social { font-size: var(--pab-text-sm); margin-bottom: var(--pab-space-sm); }

.map-card {
  background: var(--pab-surface-2); border: 1px solid var(--pab-line);
  border-radius: var(--pab-radius); min-height: 200px;
  display: flex; align-items: center; justify-content: center; text-align: center;
}
.map-card__inner { padding: var(--pab-space-md); color: var(--pab-ink-muted); }
.map-card__pin {
  display: inline-block; width: 28px; height: 28px; border-radius: 50% 50% 50% 0;
  transform: rotate(-45deg); background: var(--pab-primary); margin-bottom: var(--pab-space-2xs);
}
.map-card__addr { font-weight: var(--pab-weight-bold); color: var(--pab-ink); }
.map-card__note { font-size: var(--pab-text-sm); margin-top: var(--pab-space-2xs); }

/* -------------------------------- Footer ---------------------------------- */
.site-footer { background: var(--pab-ink); color: var(--pab-surface); color: color-mix(in srgb, var(--pab-surface) 82%, var(--pab-ink)); padding-block: var(--pab-space-xl); margin-bottom: 72px; }
.site-footer__inner { display: grid; gap: var(--pab-space-lg); grid-template-columns: 1fr; }
@media (min-width: 768px) { .site-footer__inner { grid-template-columns: 2fr 1fr 1fr; } .site-footer { margin-bottom: 0; } }
.site-footer__brand { display: flex; gap: var(--pab-space-sm); align-items: flex-start; }
.site-footer__tagline { font-family: var(--pab-font-display); font-size: var(--pab-text-md); color: var(--pab-surface); }
.site-footer__heading { font-size: var(--pab-text-base); color: var(--pab-accent); margin-bottom: var(--pab-space-2xs); font-family: var(--pab-font-body); text-transform: uppercase; letter-spacing: var(--pab-tracking-eyebrow); }
.site-footer a { color: var(--pab-surface); text-decoration: none; }
.site-footer a:hover { color: var(--pab-accent); text-decoration: underline; }
.site-footer__links li { margin-bottom: var(--pab-space-3xs); }
.site-footer__links a { display: inline-flex; min-height: var(--pab-tap-min); align-items: center; }
.site-footer__contact address { font-style: normal; line-height: 1.8; }
.site-footer__fine { margin-top: var(--pab-space-lg); padding-top: var(--pab-space-sm); border-top: 1px solid rgba(255,255,255,0.18); font-size: var(--pab-text-sm); color: var(--pab-surface); color: color-mix(in srgb, var(--pab-surface) 72%, var(--pab-ink)); }
.site-footer__demo { margin-top: var(--pab-space-2xs); }
.site-footer__note { margin-top: var(--pab-space-2xs); font-size: var(--pab-text-sm); color: var(--pab-ink-muted); }

/* -------------------------- Mobile reserve bar ---------------------------- */
.mobile-reserve-bar {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 90;
  background: var(--pab-surface); border-top: 1px solid var(--pab-line);
  padding: var(--pab-space-2xs) var(--pab-container-pad);
  box-shadow: 0 -2px 8px rgba(20,33,61,0.10);
}
@media (min-width: 768px) { .mobile-reserve-bar { display: none; } }

/* ============================== MODAL ===================================== */
.modal { position: fixed; inset: 0; z-index: 300; display: flex; align-items: flex-end; justify-content: center; }
.modal[hidden] { display: none; }
.modal__backdrop { position: absolute; inset: 0; background: rgba(11,18,48,0.55); }
.modal__dialog {
  position: relative; z-index: 1;
  background: var(--pab-surface); width: 100%; max-width: 560px;
  max-height: 100dvh; display: flex; flex-direction: column;
  border-radius: var(--pab-radius-lg) var(--pab-radius-lg) 0 0;
  box-shadow: var(--pab-shadow-pop); overflow: hidden;
}
@media (min-width: 600px) {
  .modal { align-items: center; padding: var(--pab-space-sm); }
  .modal__dialog { max-height: 92dvh; border-radius: var(--pab-radius-lg); }
}
.modal__head { padding: var(--pab-space-sm) var(--pab-space-md); border-bottom: 1px solid var(--pab-line-soft); background: var(--pab-surface); }
.modal__head-top { display: flex; align-items: center; gap: var(--pab-space-2xs); }
.modal__title { font-size: var(--pab-text-lg); flex: 1 1 auto; text-align: center; }
.modal__back, .modal__close {
  min-width: var(--pab-tap-min); min-height: var(--pab-tap-min);
  display: inline-flex; align-items: center; justify-content: center; gap: 4px;
  background: var(--pab-surface); border: 2px solid var(--pab-line); border-radius: var(--pab-radius-sm);
  cursor: pointer; color: var(--pab-ink); font-weight: var(--pab-weight-medium); font-size: var(--pab-text-base);
  padding-inline: var(--pab-space-2xs);
}
.modal__close { font-size: var(--pab-text-lg); }
.modal__progress { margin-top: var(--pab-space-2xs); }
.modal__step-indicator { font-size: var(--pab-text-sm); color: var(--pab-ink-muted); margin-bottom: 4px; }
.progressbar { height: 6px; background: var(--pab-surface-2); border-radius: var(--pab-radius-pill); overflow: hidden; }
.progressbar__fill { height: 100%; width: 14%; background: var(--pab-primary); transition: width var(--pab-duration) var(--pab-ease); }
.modal__demo-line { margin-top: var(--pab-space-2xs); font-size: var(--pab-text-sm); color: var(--pab-warning); font-weight: var(--pab-weight-medium); }

.modal__body { padding: var(--pab-space-md); overflow-y: auto; flex: 1 1 auto; }
.modal__foot { padding: var(--pab-space-sm) var(--pab-space-md); border-top: 1px solid var(--pab-line-soft); background: var(--pab-surface); }
.modal__hint { font-size: var(--pab-text-sm); color: var(--pab-ink-muted); margin-bottom: var(--pab-space-2xs); min-height: 1.2em; }

/* Step content */
.step__heading { font-size: var(--pab-text-lg); margin-bottom: var(--pab-space-2xs); }
.step__helper { color: var(--pab-ink-muted); margin-bottom: var(--pab-space-sm); font-size: var(--pab-text-base); }

/* Chips (shared primitive) */
.chip {
  display: inline-flex; align-items: center; justify-content: center;
  min-height: var(--pab-tap-primary); min-width: 56px;
  padding: var(--pab-space-2xs) var(--pab-space-sm);
  background: var(--pab-surface); color: var(--pab-ink);
  border: 2px solid var(--pab-line); border-radius: var(--pab-radius-pill);
  font-family: var(--pab-font-body); font-size: var(--pab-text-base); font-weight: var(--pab-weight-medium);
  cursor: pointer;
}
.chip:hover { background: var(--pab-surface-2); }
.chip[aria-pressed="true"], .chip[aria-checked="true"], .chip.is-selected {
  background: var(--pab-primary); color: var(--pab-primary-ink); border-color: var(--pab-primary);
}
.chip-group { display: flex; flex-wrap: wrap; gap: var(--pab-tap-gap); }
.chip-group--stack { flex-direction: column; }
.chip-group--stack .chip { width: 100%; justify-content: flex-start; }

/* Stepper */
.stepper { display: flex; align-items: center; gap: var(--pab-space-sm); justify-content: center; margin-block: var(--pab-space-sm); }
.stepper__btn {
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--pab-surface); border: 2px solid var(--pab-primary); color: var(--pab-primary);
  font-size: var(--pab-text-2xl); line-height: 1; cursor: pointer; display: inline-flex; align-items: center; justify-content: center;
}
.stepper__btn[disabled] { opacity: 0.4; cursor: not-allowed; border-color: var(--pab-line); color: var(--pab-ink-muted); }
.stepper__value { font-family: var(--pab-font-display); font-size: var(--pab-text-3xl); min-width: 64px; text-align: center; }

/* Calendar */
.calendar { margin-top: var(--pab-space-sm); border: 1px solid var(--pab-line-soft); border-radius: var(--pab-radius); padding: var(--pab-space-2xs); }
.calendar__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--pab-space-2xs); }
.calendar__title { font-weight: var(--pab-weight-bold); font-family: var(--pab-font-display); font-size: var(--pab-text-md); }
.calendar__nav {
  width: var(--pab-tap-min); height: var(--pab-tap-min); border-radius: var(--pab-radius-sm);
  background: var(--pab-surface); border: 2px solid var(--pab-line); cursor: pointer; color: var(--pab-ink); font-size: var(--pab-text-md);
}
.calendar__nav[disabled] { opacity: 0.4; cursor: not-allowed; }
.calendar__grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.calendar__dow { text-align: center; font-size: var(--pab-text-sm); color: var(--pab-ink-muted); font-weight: var(--pab-weight-bold); padding: 4px 0; }
.calendar__day {
  min-height: 44px; border: 1px solid var(--pab-line-soft); border-radius: var(--pab-radius-sm);
  background: var(--pab-surface); color: var(--pab-ink); cursor: pointer; font-size: var(--pab-text-base);
}
.calendar__day[disabled] { opacity: 0.3; cursor: not-allowed; }
.calendar__day.is-selected { background: var(--pab-primary); color: var(--pab-primary-ink); border-color: var(--pab-primary); font-weight: var(--pab-weight-bold); }
.calendar__day--empty { border: none; background: none; cursor: default; }

/* Fields */
.field { margin-bottom: var(--pab-space-sm); }
.field__label { display: block; font-weight: var(--pab-weight-bold); margin-bottom: var(--pab-space-3xs); }
.field__input {
  width: 100%; min-height: var(--pab-tap-primary); padding: var(--pab-space-2xs) var(--pab-space-sm);
  font-size: var(--pab-text-base); font-family: var(--pab-font-body);
  border: 2px solid var(--pab-line); border-radius: var(--pab-radius); background: var(--pab-surface); color: var(--pab-ink);
}
.field__input:focus-visible { border-color: var(--pab-focus); }

/* Review summary */
.summary { list-style: none; margin: 0 0 var(--pab-space-sm); padding: 0; }
.summary li { display: flex; justify-content: space-between; gap: var(--pab-space-sm); padding: var(--pab-space-2xs) 0; border-bottom: 1px solid var(--pab-line-soft); }
.summary__label { font-weight: var(--pab-weight-bold); color: var(--pab-ink-muted); }
.summary__value { text-align: right; flex: 1 1 auto; }
.summary__edit { background: none; border: none; color: var(--pab-primary); font-weight: var(--pab-weight-bold); cursor: pointer; text-decoration: underline; font-size: var(--pab-text-sm); padding: 4px; min-height: var(--pab-tap-min); }
.review-demo { background: var(--pab-warning-tint); border-left: 4px solid var(--pab-warning); padding: var(--pab-space-sm); border-radius: var(--pab-radius-sm); font-size: var(--pab-text-sm); }

/* Confirmation */
.confirm { text-align: center; }
.confirm__mark { width: 72px; height: 72px; margin: 0 auto var(--pab-space-sm); border-radius: 50%; background: var(--pab-success); color: var(--pab-success-ink); display: flex; align-items: center; justify-content: center; font-size: var(--pab-text-2xl); }
.confirm__title { font-size: var(--pab-text-xl); margin-bottom: var(--pab-space-2xs); color: var(--pab-success); }
.confirm__body { color: var(--pab-ink); margin-bottom: var(--pab-space-sm); }
.confirm__recap { text-align: left; background: var(--pab-surface-2); border-radius: var(--pab-radius); padding: var(--pab-space-sm); margin-bottom: var(--pab-space-sm); font-size: var(--pab-text-sm); }
.confirm__recap dt { font-weight: var(--pab-weight-bold); color: var(--pab-ink-muted); }
.confirm__recap dd { margin: 0 0 var(--pab-space-2xs); }
.confirm__ref { font-size: var(--pab-text-sm); color: var(--pab-ink-muted); margin-bottom: var(--pab-space-sm); }
.confirm__actions { display: flex; flex-direction: column; gap: var(--pab-space-2xs); }
@media (min-width: 480px) { .confirm__actions { flex-direction: row; } .confirm__actions .btn { flex: 1; } }

/* ============================== PENNY ===================================== */
.penny-launcher {
  position: fixed; right: var(--pab-space-sm); bottom: 84px; z-index: 95;
  display: inline-flex; align-items: center; gap: var(--pab-space-2xs);
  min-height: 56px; padding: var(--pab-space-2xs) var(--pab-space-md);
  background: var(--pab-accent); color: var(--pab-accent-ink);
  border: 2px solid var(--pab-ink); border-radius: var(--pab-radius-pill);
  font-family: var(--pab-font-body); font-weight: var(--pab-weight-bold); font-size: var(--pab-text-base);
  cursor: pointer; box-shadow: var(--pab-shadow-pop);
}
.penny-launcher__icon { display: inline-flex; }
@media (min-width: 768px) { .penny-launcher { bottom: var(--pab-space-md); } }
.penny-launcher.is-hidden { display: none; }

.penny { position: fixed; inset: 0; z-index: 310; display: flex; align-items: flex-end; justify-content: flex-end; }
.penny[hidden] { display: none; }
.penny__dialog {
  background: var(--pab-surface); display: flex; flex-direction: column;
  width: 100%; height: 100dvh; box-shadow: var(--pab-shadow-pop);
}
@media (min-width: 600px) {
  .penny { padding: var(--pab-space-sm); pointer-events: none; }
  .penny__dialog { width: 360px; height: min(70vh, 600px); border-radius: var(--pab-radius-lg); pointer-events: auto; }
}
.penny__head { background: var(--pab-ink); color: var(--pab-surface); padding: var(--pab-space-sm) var(--pab-space-md); }
.penny__head-row { display: flex; align-items: flex-start; justify-content: space-between; }
.penny__title { font-size: var(--pab-text-lg); color: var(--pab-surface); }
.penny__subtitle { font-size: var(--pab-text-sm); color: var(--pab-accent); }
.penny__close { width: var(--pab-tap-min); height: var(--pab-tap-min); background: rgba(255,255,255,0.12); border: 2px solid rgba(255,255,255,0.4); border-radius: var(--pab-radius-sm); color: var(--pab-surface); font-size: var(--pab-text-lg); cursor: pointer; }
.penny__disclaimer { margin-top: var(--pab-space-2xs); font-size: var(--pab-text-sm); color: var(--pab-surface); color: color-mix(in srgb, var(--pab-surface) 84%, var(--pab-ink)); background: rgba(255,255,255,0.08); padding: var(--pab-space-2xs); border-radius: var(--pab-radius-sm); }

.penny__log { flex: 1 1 auto; overflow-y: auto; padding: var(--pab-space-sm); display: flex; flex-direction: column; gap: var(--pab-space-2xs); }
.msg { max-width: 85%; padding: var(--pab-space-2xs) var(--pab-space-sm); border-radius: var(--pab-radius); font-size: var(--pab-text-base); line-height: 1.45; }
.msg--penny { align-self: flex-start; background: var(--pab-surface-2); color: var(--pab-ink); border-bottom-left-radius: 4px; }
.msg--user { align-self: flex-end; background: var(--pab-primary); color: var(--pab-primary-ink); border-bottom-right-radius: 4px; }
.msg__action { margin-top: var(--pab-space-2xs); }
.msg__action .btn { font-size: var(--pab-text-sm); min-height: var(--pab-tap-min); }

.penny__starters { display: flex; flex-wrap: wrap; gap: var(--pab-tap-gap); padding: 0 var(--pab-space-sm) var(--pab-space-2xs); }
.penny__starters .chip { min-height: var(--pab-tap-min); font-size: var(--pab-text-sm); }
.penny__starters[hidden] { display: none; }

.penny__composer { display: flex; gap: var(--pab-space-2xs); padding: var(--pab-space-sm); border-top: 1px solid var(--pab-line-soft); }
.penny__input { flex: 1 1 auto; min-height: var(--pab-tap-primary); padding: var(--pab-space-2xs) var(--pab-space-sm); border: 2px solid var(--pab-line); border-radius: var(--pab-radius); font-size: var(--pab-text-base); font-family: var(--pab-font-body); }
.penny__send { min-height: var(--pab-tap-primary); padding-inline: var(--pab-space-md); background: var(--pab-primary); color: var(--pab-primary-ink); border: none; border-radius: var(--pab-radius); font-weight: var(--pab-weight-bold); cursor: pointer; }

/* ----------------------- Reduced motion ----------------------------------- */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition: none !important; animation: none !important; }
}
