/* ══════════════════════════════════════════════════════════════════════════════
   Sirens Pub-n-Grub — Shared Stylesheet
   Consolidated from: home.html, about.html, events.html,
                      menus.html, location.html, comments.html
   ══════════════════════════════════════════════════════════════════════════════ */

/* ── Layer declaration ── */
@layer reset, tokens, base, layout, components, utilities;

/* ── Reset ── */
@layer reset {
  *,
  *::before,
  *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
  }

  html {
    -webkit-text-size-adjust: 100%;
  }

  img,
  picture,
  video,
  canvas,
  svg {
    display: block;
    max-inline-size: 100%;
  }

  input,
  button,
  textarea,
  select {
    font: inherit;
  }

  p,
  h1,
  h2,
  h3,
  h4 {
    overflow-wrap: break-word;
  }

  ul[role="list"] {
    list-style: none;
  }

  body {
    min-block-size: 100svh;
  }
}

/* ── Design tokens ── */
@layer tokens {
  :root {
    --xxc9-color-bg:             oklch(16% 0.04 258);
    --xxc9-color-surface:        oklch(20% 0.04 255);
    --xxc9-color-surface-raised: oklch(24% 0.04 252);
    --xxc9-color-border:         oklch(36% 0.04 240);
    --xxc9-color-text-primary:   oklch(96% 0.003 90);
    --xxc9-color-text-secondary: oklch(72% 0.04 208);
    --xxc9-color-accent:         oklch(74% 0.05 85);
    --xxc9-color-accent-hover:   oklch(80% 0.06 85);
    --xxc9-color-coral:          oklch(70% 0.16 30);
    --xxc9-color-gold:           oklch(74% 0.05 85);
    --xxc9-color-pearl:          oklch(96% 0.003 90);
    --xxc9-color-error:          oklch(65% 0.2 25);
    --xxc9-color-on-image:       oklch(98% 0.004 90);
    --xxc9-color-on-image-muted: oklch(86% 0.025 208);

    --xxc9-space-xs:  clamp(0.25rem, 0.5vw, 0.5rem);
    --xxc9-space-sm:  clamp(0.5rem,  1vw,   0.75rem);
    --xxc9-space-md:  clamp(1rem,    2vw,   1.5rem);
    --xxc9-space-lg:  clamp(1.5rem,  3vw,   2.5rem);
    --xxc9-space-xl:  clamp(2.5rem,  5vw,   5rem);
    --xxc9-space-2xl: clamp(4rem,    8vw,   9rem);

    --xxc9-font-display: 'Instrument Serif', Georgia, serif;
    --xxc9-font-body:    'DM Sans', system-ui, sans-serif;

    --xxc9-size-xs:  clamp(0.7rem,   0.6rem + 0.3vw,  0.8rem);
    --xxc9-size-sm:  clamp(0.875rem, 0.8rem + 0.35vw, 1rem);
    --xxc9-size-md:  clamp(1rem,     0.9rem + 0.5vw,  1.125rem);
    --xxc9-size-lg:  clamp(1.2rem,   1rem   + 1vw,    1.5rem);
    --xxc9-size-xl:  clamp(1.5rem,   1rem   + 2vw,    2.25rem);
    --xxc9-size-2xl: clamp(2rem,     1rem   + 4vw,    4rem);
    --xxc9-size-3xl: clamp(2.8rem,   1rem   + 7vw,    7rem);

    --xxc9-leading-tight:  1.1;
    --xxc9-leading-snug:   1.3;
    --xxc9-leading-normal: 1.6;

    --xxc9-ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
    --xxc9-ease-spring:   cubic-bezier(0.34, 1.56, 0.64, 1);
    --xxc9-duration-fast:  120ms;
    --xxc9-duration-base:  280ms;
    --xxc9-duration-slow:  600ms;
    --xxc9-duration-crawl: 1200ms;

    --xxc9-radius-sm:   4px;
    --xxc9-radius-md:   8px;
    --xxc9-radius-lg:   16px;
    --xxc9-radius-pill: 999px;

    --xxc9-shadow-sm: 0 1px 3px  oklch(0% 0 0 / 0.3);
    --xxc9-shadow-md: 0 4px 16px oklch(0% 0 0 / 0.4);
    --xxc9-shadow-lg: 0 12px 48px oklch(0% 0 0 / 0.55);

    --xxc9-content-max:  1320px;
    --xxc9-gutter:       clamp(1.25rem, 5vw, 4.5rem);
    --xxc9-column-gap:   clamp(1rem, 2.5vw, 2rem);
  }
}

/* ── Light theme token overrides ── */
[data-theme="light"] {
  --xxc9-color-bg:             oklch(96% 0.003 90);
  --xxc9-color-surface:        oklch(99% 0.002 90);
  --xxc9-color-surface-raised: oklch(93% 0.005 90);
  --xxc9-color-border:         oklch(84% 0.03 208);
  --xxc9-color-text-primary:   oklch(20% 0.04 258);
  --xxc9-color-text-secondary: oklch(48% 0.04 208);
  --xxc9-color-accent:         oklch(60% 0.07 78);
  --xxc9-color-accent-hover:   oklch(54% 0.08 78);
  --xxc9-color-gold:           oklch(60% 0.07 78);
  --xxc9-color-pearl:          oklch(20% 0.04 258);
  --xxc9-shadow-sm: 0 1px 3px  oklch(20% 0.04 258 / 0.12);
  --xxc9-shadow-md: 0 4px 16px oklch(20% 0.04 258 / 0.14);
  --xxc9-shadow-lg: 0 12px 48px oklch(20% 0.04 258 / 0.18);
}

/* ── Base ── */
@layer base {
  html {
    font-family: var(--xxc9-font-body);
    color: var(--xxc9-color-text-primary);
    background-color: var(--xxc9-color-bg);
    -webkit-font-smoothing: antialiased;
    scroll-behavior: smooth;
  }

  body {
    overflow-x: hidden;
  }

  ::selection {
    background-color: var(--xxc9-color-accent);
    color: var(--xxc9-color-bg);
  }

  :focus-visible {
    outline: 2px solid var(--xxc9-color-accent);
    outline-offset: 3px;
    border-radius: var(--xxc9-radius-sm);
  }

  a {
    color: inherit;
  }
}

/* ── Layout ── */
@layer layout {
  .xxc9_container {
    inline-size: min(var(--xxc9-content-max), 100% - (var(--xxc9-gutter) * 2));
    margin-inline: auto;
  }
}

/* ── Components ── */
@layer components {

  /* ── Skip link ── */
  .xxc9_skip-link {
    position: absolute;
    inset-block-start: var(--xxc9-space-sm);
    inset-inline-start: var(--xxc9-space-sm);
    z-index: 9999;
    padding-block: var(--xxc9-space-xs);
    padding-inline: var(--xxc9-space-md);
    background-color: var(--xxc9-color-accent);
    color: var(--xxc9-color-bg);
    font-size: var(--xxc9-size-xs);
    font-weight: 500;
    text-decoration: none;
    border-radius: var(--xxc9-radius-sm);
    translate: 0 -300%;
    transition: translate var(--xxc9-duration-fast);
  }

  .xxc9_skip-link:focus {
    translate: 0 0;
  }

  /* ── Topbar (used on all pages except home.html) ── */
  .xxc9_topbar {
    background-color: var(--xxc9-color-bg);
    border-block-end: 1px solid var(--xxc9-color-border);
    position: sticky;
    inset-block-start: 0;
    z-index: 100;
  }

  .xxc9_topbar__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--xxc9-space-md);
    padding-block: var(--xxc9-space-md);
  }

  .xxc9_topbar__logo {
    display: flex;
    flex-direction: column;
    gap: 0.04em;
    text-decoration: none;
    flex-shrink: 0;
  }

  .xxc9_topbar__wordmark {
    font-family: var(--xxc9-font-display);
    font-style: italic;
    font-size: var(--xxc9-size-xl);
    color: var(--xxc9-color-pearl);
    line-height: 1;
    letter-spacing: -0.015em;
  }

  .xxc9_topbar__sub {
    font-size: var(--xxc9-size-xs);
    font-weight: 300;
    color: var(--xxc9-color-accent);
    text-transform: uppercase;
    letter-spacing: 0.28em;
  }

  .xxc9_topbar__menu {
    display: none;
    list-style: none;
    gap: var(--xxc9-space-lg);
    align-items: center;
  }

  .xxc9_topbar__item {
    position: relative;
  }

  .xxc9_topbar__link {
    font-size: var(--xxc9-size-xs);
    font-weight: 400;
    color: var(--xxc9-color-text-secondary);
    text-decoration: none;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding-block: var(--xxc9-space-xs);
    display: flex;
    align-items: center;
    gap: 0.3em;
    transition: color var(--xxc9-duration-fast) var(--xxc9-ease-out-expo);
  }

  .xxc9_topbar__link:hover,
  .xxc9_topbar__link[aria-current="page"] {
    color: var(--xxc9-color-pearl);
  }

  .xxc9_topbar__caret {
    inline-size: 0.9em;
    block-size: 0.9em;
    fill: none;
    opacity: 0.5;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 2;
  }

  .xxc9_topbar__dropdown {
    position: absolute;
    inset-block-start: calc(100% + 0.5rem);
    inset-inline-start: 50%;
    translate: -50% -6px;
    background-color: var(--xxc9-color-surface);
    border: 1px solid var(--xxc9-color-border);
    border-radius: var(--xxc9-radius-md);
    padding-block: var(--xxc9-space-xs);
    min-inline-size: 160px;
    box-shadow: var(--xxc9-shadow-lg);
    opacity: 0;
    pointer-events: none;
    list-style: none;
    transition: opacity var(--xxc9-duration-base) var(--xxc9-ease-out-expo), translate var(--xxc9-duration-base) var(--xxc9-ease-out-expo);
  }

  .xxc9_topbar__dropdown::before {
    content: '';
    position: absolute;
    inset-block-end: 100%;
    inset-inline: -10px;
    block-size: 1rem;
  }

  .xxc9_topbar__item:hover .xxc9_topbar__dropdown,
  .xxc9_topbar__item:focus-within .xxc9_topbar__dropdown {
    opacity: 1;
    pointer-events: auto;
    translate: -50% 0;
  }

  .xxc9_topbar__dropdown-link {
    display: block;
    padding-block: 0.55rem;
    padding-inline: var(--xxc9-space-md);
    font-size: var(--xxc9-size-xs);
    color: var(--xxc9-color-text-secondary);
    text-decoration: none;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    white-space: nowrap;
    border-radius: calc(var(--xxc9-radius-md) - 2px);
    transition: color var(--xxc9-duration-fast), background-color var(--xxc9-duration-fast);
  }

  .xxc9_topbar__dropdown-link:hover {
    color: var(--xxc9-color-pearl);
    background-color: oklch(100% 0 0 / 0.05);
  }

  .xxc9_topbar__actions {
    display: flex;
    align-items: center;
    gap: var(--xxc9-space-sm);
    flex-shrink: 0;
  }

  .xxc9_topbar__cta {
    display: none;
    padding-block: 0.6rem;
    padding-inline: var(--xxc9-space-md);
    border: 1px solid oklch(74% 0.05 85 / 0.5);
    color: var(--xxc9-color-accent);
    font-size: var(--xxc9-size-xs);
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    text-decoration: none;
    border-radius: var(--xxc9-radius-pill);
    min-block-size: 44px;
    align-items: center;
    transition: background-color var(--xxc9-duration-base), color var(--xxc9-duration-base), border-color var(--xxc9-duration-base);
  }

  .xxc9_topbar__cta:hover {
    background-color: var(--xxc9-color-accent);
    color: var(--xxc9-color-bg);
    border-color: var(--xxc9-color-accent);
  }

  .xxc9_topbar__hamburger {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 5px;
    background: transparent;
    border: none;
    cursor: pointer;
    min-block-size: 44px;
    min-inline-size: 44px;
    border-radius: var(--xxc9-radius-sm);
    padding: 0.5rem;
    transition: background-color var(--xxc9-duration-fast);
  }

  .xxc9_topbar__hamburger:hover {
    background-color: oklch(100% 0 0 / 0.07);
  }

  .xxc9_topbar__bar {
    display: block;
    inline-size: 22px;
    block-size: 1.5px;
    background-color: var(--xxc9-color-pearl);
    border-radius: 1px;
  }

  /* ── Mobile nav drawer ── */
  .xxc9_mobile-nav {
    position: fixed;
    inset: 0;
    z-index: 200;
    background-color: var(--xxc9-color-bg);
    padding-block: var(--xxc9-space-lg);
    padding-inline: var(--xxc9-gutter);
    display: flex;
    flex-direction: column;
    gap: var(--xxc9-space-lg);
    translate: 100% 0;
    transition: translate var(--xxc9-duration-slow) var(--xxc9-ease-out-expo);
  }

  .xxc9_mobile-nav.xxc9_is-open {
    translate: 0 0;
  }

  .xxc9_mobile-nav__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  .xxc9_mobile-nav__close {
    background: transparent;
    border: none;
    cursor: pointer;
    color: var(--xxc9-color-text-secondary);
    min-block-size: 44px;
    min-inline-size: 44px;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    transition: color var(--xxc9-duration-fast);
  }

  .xxc9_mobile-nav__close-icon {
    inline-size: 1.35rem;
    block-size: 1.35rem;
    fill: none;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 1.8;
  }

  .xxc9_mobile-nav__close:hover {
    color: var(--xxc9-color-pearl);
  }

  .xxc9_mobile-nav__list {
    list-style: none;
    display: flex;
    flex-direction: column;
  }

  .xxc9_mobile-nav__link {
    display: block;
    padding-block: var(--xxc9-space-md);
    font-family: var(--xxc9-font-display);
    font-style: italic;
    font-size: var(--xxc9-size-2xl);
    color: var(--xxc9-color-text-primary);
    text-decoration: none;
    border-block-end: 1px solid var(--xxc9-color-border);
    transition: color var(--xxc9-duration-fast);
  }

  .xxc9_mobile-nav__link:hover {
    color: var(--xxc9-color-accent);
  }

  .xxc9_mobile-nav__sub {
    display: flex;
    flex-direction: column;
    padding-inline-start: var(--xxc9-space-md);
  }

  .xxc9_mobile-nav__sub-link {
    display: block;
    padding-block: 0.6rem;
    font-size: var(--xxc9-size-sm);
    color: var(--xxc9-color-text-secondary);
    text-decoration: none;
    border-block-end: 1px solid oklch(26% 0.03 222 / 0.5);
    transition: color var(--xxc9-duration-fast);
  }

  .xxc9_mobile-nav__sub-link:hover {
    color: var(--xxc9-color-pearl);
  }

  .xxc9_mobile-nav__foot {
    margin-block-start: auto;
    display: flex;
    flex-direction: column;
    gap: var(--xxc9-space-sm);
  }

  .xxc9_mobile-nav__info {
    font-size: var(--xxc9-size-xs);
    color: var(--xxc9-color-text-secondary);
    line-height: var(--xxc9-leading-normal);
  }

  /* ── Buttons ── */
  .xxc9_btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding-block: 0.875rem;
    padding-inline: var(--xxc9-space-lg);
    font-family: var(--xxc9-font-body);
    font-size: var(--xxc9-size-xs);
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    text-decoration: none;
    border-radius: var(--xxc9-radius-pill);
    min-block-size: 52px;
    cursor: pointer;
    border: none;
    white-space: nowrap;
    transition: background-color var(--xxc9-duration-base) var(--xxc9-ease-out-expo), color var(--xxc9-duration-base) var(--xxc9-ease-out-expo), box-shadow var(--xxc9-duration-base) var(--xxc9-ease-out-expo), transform var(--xxc9-duration-fast) var(--xxc9-ease-spring);
  }

  .xxc9_btn:active {
    transform: scale(0.97);
  }

  .xxc9_btn--primary {
    background-color: var(--xxc9-color-accent);
    color: var(--xxc9-color-bg);
    box-shadow: 0 4px 28px oklch(74% 0.05 85 / 0.35);
  }

  .xxc9_btn--primary:hover {
    background-color: var(--xxc9-color-accent-hover);
    box-shadow: 0 6px 36px oklch(74% 0.05 85 / 0.5);
  }

  .xxc9_btn--outline {
    background-color: transparent;
    color: var(--xxc9-color-text-secondary);
    border: 1px solid var(--xxc9-color-border);
  }

  .xxc9_btn--outline:hover {
    color: var(--xxc9-color-pearl);
    border-color: oklch(46% 0.04 240);
    background-color: oklch(100% 0 0 / 0.05);
  }

  /* ── Page hero (shared structure, background set per-page below) ── */
  .xxc9_page-hero {
    padding-block: var(--xxc9-space-2xl) var(--xxc9-space-xl);
    border-block-end: 1px solid var(--xxc9-color-border);
  }

  .xxc9_page-hero__eyebrow {
    display: flex;
    align-items: center;
    gap: var(--xxc9-space-sm);
    margin-block-end: var(--xxc9-space-md);
  }

  .xxc9_page-hero__rule {
    display: block;
    inline-size: 1.75rem;
    block-size: 1px;
    background-color: var(--xxc9-color-accent);
  }

  .xxc9_page-hero__kicker {
    font-size: var(--xxc9-size-xs);
    color: var(--xxc9-color-accent);
    letter-spacing: 0.26em;
    text-transform: uppercase;
  }

  .xxc9_page-hero__heading {
    font-family: var(--xxc9-font-display);
    font-style: italic;
    font-size: var(--xxc9-size-3xl);
    color: var(--xxc9-color-pearl);
    line-height: var(--xxc9-leading-tight);
    letter-spacing: -0.02em;
  }

  .xxc9_page-hero__sub {
    font-size: var(--xxc9-size-md);
    font-weight: 300;
    color: var(--xxc9-color-text-secondary);
    line-height: var(--xxc9-leading-normal);
    max-inline-size: 54ch;
    margin-block-start: var(--xxc9-space-md);
  }

  /* ── Footer ── */
  .xxc9_footer {
    background-color: var(--xxc9-color-bg);
    border-block-start: 1px solid var(--xxc9-color-border);
    padding-block: var(--xxc9-space-xl) var(--xxc9-space-lg);
  }

  .xxc9_footer__inner {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--xxc9-space-xl);
  }

  .xxc9_footer__brand {
    display: flex;
    flex-direction: column;
    gap: var(--xxc9-space-sm);
  }

  .xxc9_footer__logo {
    inline-size: clamp(80px, 14vw, 140px);
    block-size: auto;
    display: block;
  }

  .xxc9_footer__wordmark {
    font-family: var(--xxc9-font-display);
    font-style: italic;
    font-size: var(--xxc9-size-xl);
    color: var(--xxc9-color-pearl);
    text-decoration: none;
    line-height: 1;
  }

  .xxc9_footer__tagline {
    font-size: var(--xxc9-size-xs);
    color: var(--xxc9-color-text-secondary);
    font-weight: 300;
    max-inline-size: 36ch;
    line-height: var(--xxc9-leading-normal);
  }

  .xxc9_footer__social {
    display: flex;
    flex-wrap: wrap;
    gap: var(--xxc9-space-xs);
    margin-block-start: var(--xxc9-space-sm);
  }

  .xxc9_footer__social-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-block-size: 2.75rem;
    font-size: var(--xxc9-size-xs);
    color: var(--xxc9-color-text-secondary);
    text-decoration: none;
    padding-block: 0.35rem;
    padding-inline: 0.65rem;
    border: 1px solid var(--xxc9-color-border);
    border-radius: var(--xxc9-radius-sm);
    transition: color var(--xxc9-duration-fast), border-color var(--xxc9-duration-fast);
  }

  .xxc9_footer__social-link:hover {
    color: var(--xxc9-color-pearl);
    border-color: oklch(46% 0.04 240);
  }

  .xxc9_footer__nav-wrap {
    display: flex;
    flex-direction: column;
    gap: var(--xxc9-space-xs);
  }

  .xxc9_footer__nav-label {
    font-size: var(--xxc9-size-xs);
    color: var(--xxc9-color-accent);
    letter-spacing: 0.2em;
    text-transform: uppercase;
    margin-block-end: var(--xxc9-space-sm);
    display: block;
  }

  .xxc9_footer__nav-link {
    display: flex;
    align-items: center;
    min-block-size: 2.75rem;
    font-size: var(--xxc9-size-sm);
    color: var(--xxc9-color-text-secondary);
    text-decoration: none;
    padding-block: 0.25rem;
    transition: color var(--xxc9-duration-fast);
  }

  .xxc9_footer__nav-link:hover {
    color: var(--xxc9-color-pearl);
  }

  .xxc9_footer__bottom {
    margin-block-start: var(--xxc9-space-xl);
    padding-block-start: var(--xxc9-space-md);
    border-block-start: 1px solid var(--xxc9-color-border);
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: var(--xxc9-space-sm);
  }

  .xxc9_footer__copy,
  .xxc9_footer__sister-note,
  .xxc9_footer__sister {
    font-size: var(--xxc9-size-xs);
    color: var(--xxc9-color-text-secondary);
    font-weight: 300;
  }

  .xxc9_footer__sister-note a,
  .xxc9_footer__sister a {
    color: var(--xxc9-color-accent);
    text-decoration: none;
    transition: color var(--xxc9-duration-fast);
  }

  .xxc9_footer__sister a:hover {
    color: var(--xxc9-color-accent-hover);
  }

  /* home.html uses .xxc9_footer__nav rather than .xxc9_footer__nav-wrap */
  .xxc9_footer__nav {
    display: flex;
    flex-direction: column;
    gap: var(--xxc9-space-xs);
  }

  /* ── Theme toggle ── */
  .xxc9_theme-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    min-block-size: 44px;
    min-inline-size: 44px;
    background: transparent;
    border: 1px solid oklch(100% 0 0 / 0.2);
    border-radius: var(--xxc9-radius-pill);
    cursor: pointer;
    color: var(--xxc9-color-text-secondary);
    transition: color var(--xxc9-duration-fast), border-color var(--xxc9-duration-fast), background-color var(--xxc9-duration-fast);
  }

  .xxc9_theme-toggle:hover {
    color: var(--xxc9-color-pearl);
    border-color: oklch(100% 0 0 / 0.4);
    background-color: oklch(100% 0 0 / 0.07);
  }

  .xxc9_theme-toggle__icon {
    inline-size: 1.05rem;
    block-size: 1.05rem;
    fill: none;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 1.8;
    pointer-events: none;
  }

  .xxc9_theme-toggle__icon--moon {
    display: none;
  }

  [data-theme="light"] .xxc9_theme-toggle__icon--sun {
    display: none;
  }

  [data-theme="light"] .xxc9_theme-toggle__icon--moon {
    display: block;
  }

  [data-theme="light"] .xxc9_theme-toggle {
    border-color: oklch(20% 0.04 258 / 0.2);
    color: var(--xxc9-color-text-secondary);
  }

  [data-theme="light"] .xxc9_theme-toggle:hover {
    border-color: oklch(20% 0.04 258 / 0.45);
    background-color: oklch(20% 0.04 258 / 0.06);
    color: var(--xxc9-color-pearl);
  }

  /* ── Responsive: shared topbar breakpoint ── */
  @media (width >= 768px) {
    .xxc9_topbar__menu {
      display: flex;
    }

    .xxc9_topbar__cta {
      display: flex;
    }

    .xxc9_topbar__hamburger {
      display: none;
    }

    .xxc9_footer__inner {
      grid-template-columns: 1fr 1fr 1fr;
    }
  }
}

/* ── Utilities ── */
@layer utilities {
  .xxc9_u-sr-only {
    position: absolute;
    inline-size: 1px;
    block-size: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }
}


/* ══════════════════════════════════════════════════════════════════════════════
   home.html
   ══════════════════════════════════════════════════════════════════════════════ */

/* ── home.html: site-nav (overlaid on hero, not sticky topbar) ── */
.xxc9_site-nav {
  position: absolute;
  inset-block-start: 0;
  inset-inline: 0;
  z-index: 100;
  padding-block: var(--xxc9-space-lg);
}

.xxc9_site-nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--xxc9-space-md);
}

.xxc9_site-nav__logo {
  display: flex;
  flex-direction: column;
  gap: 0.04em;
  text-decoration: none;
  flex-shrink: 0;
}

.xxc9_site-nav__wordmark {
  font-family: var(--xxc9-font-display);
  font-style: italic;
  font-size: var(--xxc9-size-xl);
  color: var(--xxc9-color-pearl);
  line-height: 1;
  letter-spacing: -0.015em;
}

.xxc9_site-nav__sub {
  font-size: var(--xxc9-size-xs);
  font-weight: 300;
  color: var(--xxc9-color-accent);
  text-transform: uppercase;
  letter-spacing: 0.28em;
}

.xxc9_site-nav__menu {
  display: none;
  list-style: none;
  gap: var(--xxc9-space-lg);
  align-items: center;
}

.xxc9_site-nav__item {
  position: relative;
}

.xxc9_site-nav__link {
  font-size: var(--xxc9-size-xs);
  font-weight: 400;
  color: var(--xxc9-color-text-secondary);
  text-decoration: none;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding-block: var(--xxc9-space-xs);
  transition: color var(--xxc9-duration-fast) var(--xxc9-ease-out-expo);
  display: flex;
  align-items: center;
  gap: 0.3em;
}

.xxc9_site-nav__link:hover,
.xxc9_site-nav__link[aria-current="page"] {
  color: var(--xxc9-color-pearl);
}

.xxc9_site-nav__caret {
  inline-size: 0.9em;
  block-size: 0.9em;
  fill: none;
  opacity: 0.5;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2;
}

.xxc9_site-nav__dropdown {
  position: absolute;
  inset-block-start: calc(100% + 0.5rem);
  inset-inline-start: 50%;
  translate: -50% -6px;
  background-color: var(--xxc9-color-surface);
  border: 1px solid var(--xxc9-color-border);
  border-radius: var(--xxc9-radius-md);
  padding-block: var(--xxc9-space-xs);
  min-inline-size: 160px;
  box-shadow: var(--xxc9-shadow-lg);
  opacity: 0;
  pointer-events: none;
  list-style: none;
  transition: opacity var(--xxc9-duration-base) var(--xxc9-ease-out-expo), translate var(--xxc9-duration-base) var(--xxc9-ease-out-expo);
}

.xxc9_site-nav__dropdown::before {
  content: '';
  position: absolute;
  inset-block-end: 100%;
  inset-inline: -10px;
  block-size: 1rem;
}

.xxc9_site-nav__item:hover .xxc9_site-nav__dropdown,
.xxc9_site-nav__item:focus-within .xxc9_site-nav__dropdown {
  opacity: 1;
  pointer-events: auto;
  translate: -50% 0;
}

.xxc9_site-nav__dropdown-link {
  display: block;
  padding-block: 0.55rem;
  padding-inline: var(--xxc9-space-md);
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-text-secondary);
  text-decoration: none;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
  transition: color var(--xxc9-duration-fast), background-color var(--xxc9-duration-fast);
  border-radius: calc(var(--xxc9-radius-md) - 2px);
}

.xxc9_site-nav__dropdown-link:hover {
  color: var(--xxc9-color-pearl);
  background-color: oklch(100% 0 0 / 0.05);
}

.xxc9_site-nav__actions {
  display: flex;
  align-items: center;
  gap: var(--xxc9-space-sm);
  flex-shrink: 0;
}

.xxc9_site-nav__cta {
  display: none;
  padding-block: 0.6rem;
  padding-inline: var(--xxc9-space-md);
  border: 1px solid oklch(74% 0.05 85 / 0.5);
  color: var(--xxc9-color-accent);
  font-size: var(--xxc9-size-xs);
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: var(--xxc9-radius-pill);
  min-block-size: 44px;
  align-items: center;
  transition: background-color var(--xxc9-duration-base) var(--xxc9-ease-out-expo), color var(--xxc9-duration-base) var(--xxc9-ease-out-expo), border-color var(--xxc9-duration-base) var(--xxc9-ease-out-expo);
}

.xxc9_site-nav__cta:hover {
  background-color: var(--xxc9-color-accent);
  color: var(--xxc9-color-bg);
  border-color: var(--xxc9-color-accent);
}

.xxc9_site-nav__hamburger {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 5px;
  background: transparent;
  border: none;
  cursor: pointer;
  min-block-size: 44px;
  min-inline-size: 44px;
  border-radius: var(--xxc9-radius-sm);
  padding: 0.5rem;
  transition: background-color var(--xxc9-duration-fast);
}

.xxc9_site-nav__hamburger:hover {
  background-color: oklch(100% 0 0 / 0.07);
}

.xxc9_site-nav__bar {
  display: block;
  inline-size: 22px;
  block-size: 1.5px;
  background-color: var(--xxc9-color-pearl);
  border-radius: 1px;
  transition: transform var(--xxc9-duration-base) var(--xxc9-ease-out-expo), opacity var(--xxc9-duration-fast);
}

/* ── home.html: eyebrow utility ── */
.xxc9_eyebrow {
  display: flex;
  align-items: center;
  gap: var(--xxc9-space-sm);
}

.xxc9_eyebrow__rule {
  display: block;
  inline-size: 1.75rem;
  block-size: 1px;
  background-color: var(--xxc9-color-accent);
  flex-shrink: 0;
}

.xxc9_eyebrow__text {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-accent);
  letter-spacing: 0.26em;
  text-transform: uppercase;
}

/* ── home.html: hero ── */
.xxc9_hero {
  position: relative;
  min-block-size: 100svh;
  overflow: hidden;
}

.xxc9_hero__video {
  position: absolute;
  inset: 0;
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 0;
}

.xxc9_hero__bg {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(to right, oklch(16% 0.04 258 / 0.82) 0%, oklch(16% 0.04 258 / 0.35) 40%, transparent 64%),
    linear-gradient(to top, oklch(14% 0.04 258 / 0.92) 0%, transparent 38%),
    radial-gradient(ellipse 130% 110% at 50% 50%, transparent 28%, oklch(14% 0.04 258 / 0.5) 72%, oklch(12% 0.04 258 / 0.85) 100%),
    linear-gradient(148deg, oklch(22% 0.08 210 / 0.6) 0%, oklch(15% 0.055 200 / 0.55) 22%, oklch(10% 0.04 218 / 0.5) 45%, oklch(17% 0.075 205 / 0.55) 65%, oklch(20% 0.1 52 / 0.5) 82%, oklch(11% 0.05 228 / 0.6) 100%);
}

.xxc9_hero__bg::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.12'/%3E%3C/svg%3E");
  background-size: 200px 200px;
  mix-blend-mode: overlay;
  opacity: 0.4;
  pointer-events: none;
}

.xxc9_hero__bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 48% 58% at 73% 42%, oklch(72% 0.04 208 / 0.22) 0%, transparent 65%),
    radial-gradient(ellipse 28% 38% at 88% 72%, oklch(74% 0.05 85 / 0.2) 0%, transparent 55%),
    radial-gradient(ellipse 22% 30% at 18% 72%, oklch(36% 0.04 240 / 0.14) 0%, transparent 60%);
  pointer-events: none;
}

.xxc9_hero__layout {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-rows: auto 1fr auto;
  min-block-size: 100svh;
  padding-inline: var(--xxc9-gutter);
  padding-block: var(--xxc9-space-lg);
  gap: var(--xxc9-space-md);
}

.xxc9_hero__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-self: center;
  max-inline-size: min(520px, 100%);
}

.xxc9_hero__eyebrow {
  display: flex;
  align-items: center;
  gap: var(--xxc9-space-sm);
  margin-block-end: var(--xxc9-space-md);
}

.xxc9_hero__rule {
  display: block;
  inline-size: 2rem;
  block-size: 1px;
  background-color: var(--xxc9-color-accent);
  flex-shrink: 0;
}

.xxc9_hero__kicker {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-accent);
  letter-spacing: 0.26em;
  text-transform: uppercase;
}

.xxc9_hero__heading {
  font-family: var(--xxc9-font-display);
  font-style: italic;
  font-size: var(--xxc9-size-3xl);
  color: var(--xxc9-color-pearl);
  line-height: var(--xxc9-leading-tight);
  letter-spacing: -0.02em;
  margin-block-end: var(--xxc9-space-lg);
  text-shadow: 0 2px 40px oklch(0% 0 0 / 0.55);
}

.xxc9_hero__heading em {
  font-style: normal;
  color: var(--xxc9-color-accent);
}

.xxc9_hero__lede {
  font-size: var(--xxc9-size-sm);
  font-weight: 300;
  color: var(--xxc9-color-text-secondary);
  line-height: var(--xxc9-leading-normal);
  max-inline-size: 44ch;
  margin-block-end: var(--xxc9-space-xl);
}

.xxc9_hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--xxc9-space-sm);
  align-items: center;
}

.xxc9_hero__foot {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--xxc9-space-md);
}

.xxc9_hero__address {
  font-style: normal;
}

.xxc9_hero__address-label {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-text-secondary);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-block-end: 0.2em;
  display: block;
}

.xxc9_hero__address-name {
  font-family: var(--xxc9-font-display);
  font-style: italic;
  font-size: var(--xxc9-size-lg);
  color: var(--xxc9-color-text-primary);
  display: block;
}

.xxc9_hero__address-street {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-text-secondary);
  display: block;
  margin-block-start: 0.2em;
}

.xxc9_hero__stats {
  display: none;
  align-items: center;
  gap: var(--xxc9-space-xl);
}

.xxc9_stat {
  display: flex;
  flex-direction: column;
  gap: 0.15em;
  text-align: center;
}

.xxc9_stat__num {
  font-family: var(--xxc9-font-display);
  font-style: italic;
  font-size: var(--xxc9-size-2xl);
  color: var(--xxc9-color-pearl);
  line-height: 1;
}

.xxc9_stat__label {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-text-secondary);
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.xxc9_stat-sep {
  display: block;
  inline-size: 1px;
  block-size: 2.25rem;
  background-color: var(--xxc9-color-border);
  flex-shrink: 0;
}

.xxc9_scroll-cue {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--xxc9-space-xs);
  text-decoration: none;
  color: var(--xxc9-color-text-secondary);
  flex-shrink: 0;
  transition: color var(--xxc9-duration-fast) var(--xxc9-ease-out-expo);
}

.xxc9_scroll-cue:hover {
  color: var(--xxc9-color-pearl);
}

.xxc9_scroll-cue__word {
  font-size: calc(var(--xxc9-size-xs) * 0.82);
  letter-spacing: 0.24em;
  text-transform: uppercase;
  writing-mode: vertical-rl;
}

.xxc9_scroll-cue__line {
  inline-size: 1px;
  block-size: 3.5rem;
  background: linear-gradient(to bottom, var(--xxc9-color-accent), transparent);
  border-radius: 1px;
}

@media (prefers-reduced-motion: no-preference) {
  .xxc9_scroll-cue__line {
    animation: xxc9-drip 2.4s var(--xxc9-ease-out-expo) infinite;
  }
}

@keyframes xxc9-drip {
  0%, 100% {
    opacity: 0.3;
    transform: scaleY(0.45);
    transform-origin: top;
  }

  55% {
    opacity: 1;
    transform: scaleY(1);
    transform-origin: top;
  }
}

/* home.html: hero logo — desktop (absolute, right side) */
.xxc9_hero__logo {
  position: absolute;
  inset-block: 0;
  inset-inline-end: 0;
  inline-size: clamp(380px, 50vw, 700px);
  block-size: 100%;
  object-fit: contain;
  object-position: 50% 30%;
  z-index: 2;
  display: none;
  pointer-events: none;
  padding: var(--xxc9-space-lg) var(--xxc9-space-xl);
  filter: drop-shadow(0 8px 40px oklch(0% 0 0 / 0.5));
}

/* home.html: hero logo — mobile (inline, above heading) */
.xxc9_hero__logo-mobile {
  display: block;
  inline-size: clamp(160px, 52vw, 260px);
  block-size: auto;
  margin-block-end: var(--xxc9-space-md);
  filter: drop-shadow(0 4px 20px oklch(0% 0 0 / 0.5));
}

/* ── home.html: intro section ── */
.xxc9_intro {
  padding-block: var(--xxc9-space-2xl);
  background-color: var(--xxc9-color-bg);
}

.xxc9_intro__inner {
  display: grid;
  gap: var(--xxc9-space-xl);
}

.xxc9_intro__copy {
  min-inline-size: 0;
}

.xxc9_intro__heading {
  font-family: var(--xxc9-font-display);
  font-style: italic;
  font-size: var(--xxc9-size-2xl);
  color: var(--xxc9-color-pearl);
  line-height: var(--xxc9-leading-snug);
  margin-block: var(--xxc9-space-md) var(--xxc9-space-lg);
}

.xxc9_intro__body {
  font-size: var(--xxc9-size-md);
  font-weight: 300;
  color: var(--xxc9-color-text-secondary);
  line-height: var(--xxc9-leading-normal);
  max-inline-size: 56ch;
}

.xxc9_intro__body + .xxc9_intro__body {
  margin-block-start: var(--xxc9-space-md);
}

.xxc9_intro__media {
  overflow: hidden;
  inline-size: 100%;
  aspect-ratio: 4 / 3;
  border: 1px solid var(--xxc9-color-border);
  border-radius: var(--xxc9-radius-md);
  background-color: var(--xxc9-color-surface);
}

.xxc9_intro__image {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  object-position: 52% 50%;
}

/* ── home.html: highlights grid ── */
.xxc9_highlights {
  padding-block: var(--xxc9-space-xl) var(--xxc9-space-2xl);
  background-color: var(--xxc9-color-bg);
  border-block-start: 1px solid var(--xxc9-color-border);
}

.xxc9_highlights__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--xxc9-space-md);
  margin-block-start: var(--xxc9-space-xl);
}

.xxc9_highlight-card {
  background-color: var(--xxc9-color-surface);
  border: 1px solid var(--xxc9-color-border);
  border-radius: var(--xxc9-radius-lg);
  padding: var(--xxc9-space-lg);
  display: flex;
  flex-direction: column;
  gap: var(--xxc9-space-md);
  transition: border-color var(--xxc9-duration-base) var(--xxc9-ease-out-expo), background-color var(--xxc9-duration-base) var(--xxc9-ease-out-expo);
}

.xxc9_highlight-card:hover {
  border-color: oklch(42% 0.04 240);
  background-color: var(--xxc9-color-surface-raised);
}

.xxc9_highlight-card__icon {
  inline-size: 2.5rem;
  block-size: 2.5rem;
  border-radius: var(--xxc9-radius-md);
  background-color: oklch(74% 0.05 85 / 0.12);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.xxc9_highlight-card__icon svg {
  inline-size: 1.35rem;
  block-size: 1.35rem;
  fill: none;
  stroke: var(--xxc9-color-accent);
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 1.7;
}

.xxc9_highlight-card__title {
  font-family: var(--xxc9-font-display);
  font-style: italic;
  font-size: var(--xxc9-size-xl);
  color: var(--xxc9-color-pearl);
  line-height: var(--xxc9-leading-snug);
}

.xxc9_highlight-card__body {
  font-size: var(--xxc9-size-sm);
  font-weight: 300;
  color: var(--xxc9-color-text-secondary);
  line-height: var(--xxc9-leading-normal);
  flex: 1;
}

.xxc9_highlight-card__items {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.4em;
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-text-secondary);
}

.xxc9_highlight-card__items li::before {
  content: '— ';
  color: var(--xxc9-color-accent);
}

.xxc9_highlight-card__link {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  font-size: var(--xxc9-size-xs);
  font-weight: 500;
  color: var(--xxc9-color-accent);
  text-decoration: none;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-block-start: auto;
  padding-block-start: var(--xxc9-space-sm);
  border-block-start: 1px solid var(--xxc9-color-border);
  transition: color var(--xxc9-duration-fast) var(--xxc9-ease-out-expo);
}

.xxc9_highlight-card__link::after {
  content: ' →';
}

.xxc9_highlight-card__link:hover {
  color: var(--xxc9-color-accent-hover);
}

/* ── home.html: bandingo section ── */
.xxc9_bandingo {
  padding-block: var(--xxc9-space-2xl);
  background: linear-gradient(135deg, oklch(20% 0.05 255) 0%, oklch(18% 0.04 258) 50%, oklch(22% 0.05 250) 100%);
  border-block: 1px solid var(--xxc9-color-border);
  overflow: hidden;
  position: relative;
}

.xxc9_bandingo::before {
  content: '';
  position: absolute;
  inset-block-start: -40%;
  inset-inline-start: 55%;
  inline-size: 60vw;
  block-size: 60vw;
  border-radius: 50%;
  background: radial-gradient(circle, oklch(72% 0.04 208 / 0.12) 0%, transparent 70%);
  pointer-events: none;
}

.xxc9_bandingo__inner {
  position: relative;
  z-index: 1;
  display: grid;
  gap: var(--xxc9-space-xl);
  align-items: center;
}

.xxc9_bandingo__label {
  display: inline-flex;
  align-items: center;
  gap: var(--xxc9-space-sm);
  margin-block-end: var(--xxc9-space-md);
}

.xxc9_bandingo__badge {
  font-size: var(--xxc9-size-xs);
  font-weight: 500;
  color: var(--xxc9-color-bg);
  background-color: var(--xxc9-color-gold);
  padding-block: 0.2em;
  padding-inline: 0.6em;
  border-radius: var(--xxc9-radius-sm);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.xxc9_bandingo__eyebrow {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-text-secondary);
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.xxc9_bandingo__heading {
  font-family: var(--xxc9-font-display);
  font-style: italic;
  font-size: var(--xxc9-size-2xl);
  color: var(--xxc9-color-pearl);
  line-height: var(--xxc9-leading-snug);
  margin-block-end: var(--xxc9-space-md);
}

.xxc9_bandingo__heading strong {
  font-style: normal;
  color: var(--xxc9-color-gold);
  font-weight: 400;
}

.xxc9_bandingo__copy {
  font-size: var(--xxc9-size-sm);
  font-weight: 300;
  color: var(--xxc9-color-text-secondary);
  line-height: var(--xxc9-leading-normal);
  max-inline-size: 52ch;
  margin-block-end: var(--xxc9-space-lg);
}

.xxc9_bandingo__tiles {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--xxc9-space-sm);
}

.xxc9_bandingo__tile {
  background-color: oklch(100% 0 0 / 0.05);
  border: 1px solid var(--xxc9-color-border);
  border-radius: var(--xxc9-radius-md);
  padding: var(--xxc9-space-md);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--xxc9-space-xs);
}

.xxc9_bandingo__tile-icon {
  display: flex;
  color: var(--xxc9-color-accent);
}

.xxc9_bandingo__tile-icon svg {
  inline-size: 1.6rem;
  block-size: 1.6rem;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 1.7;
}

.xxc9_bandingo__tile-label {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-text-secondary);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

/* ── home.html: gift card section ── */
.xxc9_gift {
  padding-block: var(--xxc9-space-2xl);
  background-color: var(--xxc9-color-bg);
  border-block-start: 1px solid var(--xxc9-color-border);
}

.xxc9_gift__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--xxc9-space-xl);
  align-items: center;
}

.xxc9_gift__img-wrap {
  border-radius: var(--xxc9-radius-lg);
  overflow: hidden;
  box-shadow: var(--xxc9-shadow-lg);
  max-inline-size: 420px;
  margin-inline: auto;
}

.xxc9_gift__img {
  inline-size: 100%;
  block-size: auto;
  display: block;
}

.xxc9_gift__kicker {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-accent);
  letter-spacing: 0.26em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: var(--xxc9-space-sm);
  margin-block-end: var(--xxc9-space-md);
}

.xxc9_gift__kicker-rule {
  display: block;
  inline-size: 1.75rem;
  block-size: 1px;
  background-color: var(--xxc9-color-accent);
  flex-shrink: 0;
}

.xxc9_gift__heading {
  font-family: var(--xxc9-font-display);
  font-style: italic;
  font-size: var(--xxc9-size-2xl);
  color: var(--xxc9-color-pearl);
  line-height: var(--xxc9-leading-snug);
  margin-block-end: var(--xxc9-space-md);
}

.xxc9_gift__copy {
  font-size: var(--xxc9-size-md);
  font-weight: 300;
  color: var(--xxc9-color-text-secondary);
  line-height: var(--xxc9-leading-normal);
  max-inline-size: 44ch;
  margin-block-end: var(--xxc9-space-lg);
}

/* ── home.html: info bar ── */
.xxc9_info-bar {
  padding-block: var(--xxc9-space-xl);
  background-color: var(--xxc9-color-surface);
  border-block-start: 1px solid var(--xxc9-color-border);
}

.xxc9_info-bar__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--xxc9-space-lg);
}

.xxc9_info-block__label {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-accent);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  margin-block-end: var(--xxc9-space-sm);
  display: block;
}

.xxc9_info-block__value {
  font-family: var(--xxc9-font-display);
  font-style: italic;
  font-size: var(--xxc9-size-lg);
  color: var(--xxc9-color-pearl);
  line-height: var(--xxc9-leading-snug);
}

.xxc9_info-block__sub {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-text-secondary);
  margin-block-start: 0.3em;
  display: block;
  line-height: var(--xxc9-leading-normal);
}

.xxc9_info-block__link {
  display: inline-block;
  margin-block-start: 0.6em;
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-accent);
  text-decoration: none;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: color var(--xxc9-duration-fast);
}

.xxc9_info-block__link:hover {
  color: var(--xxc9-color-accent-hover);
}

/* ── home.html: entry animations ── */
@media (prefers-reduced-motion: no-preference) {
  .xxc9_site-nav {
    opacity: 0;
    animation: xxc9-fadein var(--xxc9-duration-slow) var(--xxc9-ease-out-expo) 80ms forwards;
  }

  .xxc9_hero__eyebrow {
    opacity: 0;
    translate: 0 1rem;
    animation: xxc9-rise var(--xxc9-duration-slow) var(--xxc9-ease-out-expo) 260ms forwards;
  }

  .xxc9_hero__heading {
    opacity: 0;
    translate: 0 1.5rem;
    animation: xxc9-rise var(--xxc9-duration-slow) var(--xxc9-ease-out-expo) 420ms forwards;
  }

  .xxc9_hero__lede {
    opacity: 0;
    translate: 0 1rem;
    animation: xxc9-rise var(--xxc9-duration-slow) var(--xxc9-ease-out-expo) 560ms forwards;
  }

  .xxc9_hero__actions {
    opacity: 0;
    translate: 0 1rem;
    animation: xxc9-rise var(--xxc9-duration-slow) var(--xxc9-ease-out-expo) 680ms forwards;
  }

  .xxc9_hero__foot {
    opacity: 0;
    animation: xxc9-fadein var(--xxc9-duration-crawl) var(--xxc9-ease-out-expo) 1000ms forwards;
  }

  .xxc9_hero__logo {
    opacity: 0;
    scale: 0.94;
    animation: xxc9-platerise var(--xxc9-duration-crawl) var(--xxc9-ease-out-expo) 420ms forwards;
  }
}

@keyframes xxc9-rise {
  to {
    opacity: 1;
    translate: 0 0;
  }
}

@keyframes xxc9-fadein {
  to {
    opacity: 1;
  }
}

@keyframes xxc9-platerise {
  to {
    opacity: 1;
    scale: 1;
  }
}

/* ── home.html: light mode overrides ── */
[data-theme="light"] .xxc9_hero__bg {
  background:
    linear-gradient(to right, oklch(96% 0.003 90 / 0.9) 0%, oklch(96% 0.003 90 / 0.5) 42%, transparent 66%),
    linear-gradient(to top, oklch(96% 0.003 90 / 0.92) 0%, transparent 40%),
    radial-gradient(ellipse 130% 110% at 50% 50%, transparent 28%, oklch(92% 0.01 200 / 0.45) 72%, oklch(94% 0.008 210 / 0.78) 100%),
    linear-gradient(148deg, oklch(88% 0.03 210 / 0.5) 0%, oklch(90% 0.025 205 / 0.45) 30%, oklch(85% 0.035 200 / 0.4) 60%, oklch(92% 0.015 90 / 0.45) 100%);
}

[data-theme="light"] .xxc9_hero__heading {
  text-shadow: 0 1px 20px oklch(96% 0.003 90 / 0.6);
}

[data-theme="light"] .xxc9_bandingo {
  background: linear-gradient(135deg, oklch(93% 0.005 208) 0%, oklch(96% 0.003 90) 50%, oklch(91% 0.008 200) 100%);
}

[data-theme="light"] .xxc9_bandingo__tile {
  background-color: oklch(20% 0.04 258 / 0.05);
}

[data-theme="light"] .xxc9_highlight-card:hover {
  border-color: oklch(72% 0.04 208);
}

/* ── home.html: responsive ── */
@media (width >= 768px) {
  .xxc9_site-nav__menu {
    display: flex;
  }

  .xxc9_site-nav__cta {
    display: flex;
  }

  .xxc9_site-nav__hamburger {
    display: none;
  }

  .xxc9_hero__stats {
    display: flex;
  }

  .xxc9_hero__content {
    max-inline-size: 52%;
  }

  .xxc9_highlights__grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .xxc9_bandingo__inner {
    grid-template-columns: 1fr 1fr;
  }

  .xxc9_gift__inner {
    grid-template-columns: 1fr 1fr;
  }

  .xxc9_gift__img-wrap {
    max-inline-size: none;
    margin-inline: 0;
  }

  .xxc9_info-bar__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (width >= 1024px) {
  .xxc9_hero__logo {
    display: block;
  }

  .xxc9_hero__logo-mobile {
    display: none;
  }

  .xxc9_hero__content {
    max-inline-size: 46%;
  }

  .xxc9_intro__inner {
    grid-template-columns: minmax(0, 0.94fr) minmax(18rem, 1fr);
    align-items: center;
  }

  .xxc9_intro__media {
    aspect-ratio: 5 / 4;
  }
}


/* ══════════════════════════════════════════════════════════════════════════════
   about.html
   ══════════════════════════════════════════════════════════════════════════════ */

/* about.html: page hero background */
.xxc9_page-hero--about {
  background:
    linear-gradient(180deg, oklch(10% 0.04 258 / 0.65) 0%, oklch(16% 0.04 258 / 0.88) 100%),
    url('https://sirenspub-n-grub.com/wp-content/uploads/2026/04/sirens-sign-entrance.webp') center / cover no-repeat;
    height: auto;
    padding: 2em;
}

/* ── about.html: story section ── */
.xxc9_story {
  padding-block: var(--xxc9-space-2xl);
}

.xxc9_story__inner {
  display: grid;
  gap: var(--xxc9-space-2xl);
}

.xxc9_story__block {
  display: grid;
  gap: var(--xxc9-space-xl);
  align-items: start;
}

.xxc9_story__eyebrow {
  display: flex;
  align-items: center;
  gap: var(--xxc9-space-sm);
  margin-block-end: var(--xxc9-space-md);
}

.xxc9_story__rule {
  display: block;
  inline-size: 1.75rem;
  block-size: 1px;
  background-color: var(--xxc9-color-accent);
}

.xxc9_story__kicker {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-accent);
  letter-spacing: 0.26em;
  text-transform: uppercase;
}

.xxc9_story__heading {
  font-family: var(--xxc9-font-display);
  font-style: italic;
  font-size: var(--xxc9-size-2xl);
  color: var(--xxc9-color-pearl);
  line-height: var(--xxc9-leading-snug);
}

.xxc9_story__body {
  font-size: var(--xxc9-size-md);
  font-weight: 300;
  color: var(--xxc9-color-text-secondary);
  line-height: var(--xxc9-leading-normal);
  max-inline-size: 60ch;
}

.xxc9_story__body + .xxc9_story__body {
  margin-block-start: var(--xxc9-space-md);
}

/* ── about.html: pillars ── */
.xxc9_pillars {
  padding-block: var(--xxc9-space-xl) var(--xxc9-space-2xl);
  border-block-start: 1px solid var(--xxc9-color-border);
}

.xxc9_pillars__eyebrow {
  display: flex;
  align-items: center;
  gap: var(--xxc9-space-sm);
  margin-block-end: var(--xxc9-space-lg);
}

.xxc9_pillars__rule {
  display: block;
  inline-size: 1.75rem;
  block-size: 1px;
  background-color: var(--xxc9-color-accent);
}

.xxc9_pillars__kicker {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-accent);
  letter-spacing: 0.26em;
  text-transform: uppercase;
}

.xxc9_pillars__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--xxc9-space-md);
}

.xxc9_pillar {
  background-color: var(--xxc9-color-surface);
  border: 1px solid var(--xxc9-color-border);
  border-radius: var(--xxc9-radius-lg);
  padding: var(--xxc9-space-lg);
  display: flex;
  flex-direction: column;
  gap: var(--xxc9-space-sm);
  transition: border-color var(--xxc9-duration-base) var(--xxc9-ease-out-expo);
}

.xxc9_pillar:hover {
  border-color: oklch(44% 0.04 240);
}

.xxc9_pillar__icon {
  inline-size: 1.7rem;
  block-size: 1.7rem;
  fill: none;
  stroke: var(--xxc9-color-accent);
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 1.7;
}

.xxc9_pillar__title {
  font-family: var(--xxc9-font-display);
  font-style: italic;
  font-size: var(--xxc9-size-lg);
  color: var(--xxc9-color-pearl);
}

.xxc9_pillar__body {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-text-secondary);
  line-height: var(--xxc9-leading-normal);
}

/* ── about.html: CTA strip ── */
.xxc9_cta-strip {
  padding-block: var(--xxc9-space-xl);
  background-color: var(--xxc9-color-surface);
  border-block: 1px solid var(--xxc9-color-border);
}

.xxc9_cta-strip__inner {
  display: flex;
  flex-direction: column;
  gap: var(--xxc9-space-lg);
  align-items: flex-start;
}

.xxc9_cta-strip__heading {
  font-family: var(--xxc9-font-display);
  font-style: italic;
  font-size: var(--xxc9-size-2xl);
  color: var(--xxc9-color-pearl);
  line-height: var(--xxc9-leading-snug);
}

.xxc9_cta-strip__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--xxc9-space-sm);
}

/* ── about.html: responsive ── */
@media (width >= 768px) {
  .xxc9_story__block {
    grid-template-columns: 1fr 1fr;
  }

  .xxc9_pillars__grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .xxc9_cta-strip__inner {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }
}


/* ══════════════════════════════════════════════════════════════════════════════
   events.html
   ══════════════════════════════════════════════════════════════════════════════ */

/* events.html: page hero background */
.xxc9_page-hero--events {
  background:
    linear-gradient(180deg, oklch(10% 0.04 258 / 0.65) 0%, oklch(16% 0.04 258 / 0.88) 100%),
    url('https://sirenspub-n-grub.com/wp-content/uploads/2026/04/sirens-neon.webp') center / cover no-repeat;
        height: auto;
          padding: 2em;
}

/* ── events.html: event cards ── */
.xxc9_events {
  padding-block: var(--xxc9-space-2xl);
}

.xxc9_events__heading {
  font-family: var(--xxc9-font-display);
  font-style: italic;
  font-size: var(--xxc9-size-2xl);
  color: var(--xxc9-color-pearl);
  line-height: var(--xxc9-leading-snug);
  margin-block-end: var(--xxc9-space-xl);
}

.xxc9_event-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--xxc9-space-md);
}

.xxc9_event-card {
  background-color: var(--xxc9-color-surface);
  border: 1px solid var(--xxc9-color-border);
  border-radius: var(--xxc9-radius-lg);
  padding: var(--xxc9-space-lg);
  display: grid;
  gap: var(--xxc9-space-md);
  transition: border-color var(--xxc9-duration-base) var(--xxc9-ease-out-expo);
}

.xxc9_event-card:hover {
  border-color: oklch(44% 0.04 240);
}

.xxc9_event-card__head {
  display: flex;
  align-items: flex-start;
  gap: var(--xxc9-space-md);
}

.xxc9_event-card__icon {
  inline-size: 3rem;
  block-size: 3rem;
  border-radius: var(--xxc9-radius-md);
  background-color: oklch(74% 0.05 85 / 0.12);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.xxc9_event-card__icon svg {
  inline-size: 1.55rem;
  block-size: 1.55rem;
  fill: none;
  stroke: var(--xxc9-color-accent);
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 1.7;
}

.xxc9_event-card__icon--gold {
  background-color: oklch(74% 0.05 85 / 0.12);
}

.xxc9_event-card__icon--coral {
  background-color: oklch(70% 0.16 30 / 0.12);
}

.xxc9_event-card__icon--coral svg {
  stroke: var(--xxc9-color-coral);
}

.xxc9_event-card__title {
  font-family: var(--xxc9-font-display);
  font-style: italic;
  font-size: var(--xxc9-size-xl);
  color: var(--xxc9-color-pearl);
  line-height: var(--xxc9-leading-snug);
}

.xxc9_event-card__when {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-accent);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  margin-block-start: 0.25em;
  display: block;
}

.xxc9_event-card__body {
  font-size: var(--xxc9-size-sm);
  font-weight: 300;
  color: var(--xxc9-color-text-secondary);
  line-height: var(--xxc9-leading-normal);
}

/* ── events.html: private events CTA ── */
.xxc9_private {
  padding-block: var(--xxc9-space-xl) var(--xxc9-space-2xl);
  border-block-start: 1px solid var(--xxc9-color-border);
}

.xxc9_private__inner {
  background-color: var(--xxc9-color-surface);
  border: 1px solid var(--xxc9-color-border);
  border-radius: var(--xxc9-radius-lg);
  padding: var(--xxc9-space-xl);
  display: grid;
  gap: var(--xxc9-space-lg);
  align-items: center;
}

.xxc9_private__label {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-accent);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  display: block;
  margin-block-end: var(--xxc9-space-sm);
}

.xxc9_private__heading {
  font-family: var(--xxc9-font-display);
  font-style: italic;
  font-size: var(--xxc9-size-2xl);
  color: var(--xxc9-color-pearl);
  line-height: var(--xxc9-leading-snug);
  margin-block-end: var(--xxc9-space-md);
}

.xxc9_private__copy {
  font-size: var(--xxc9-size-sm);
  font-weight: 300;
  color: var(--xxc9-color-text-secondary);
  line-height: var(--xxc9-leading-normal);
  max-inline-size: 52ch;
  margin-block-end: var(--xxc9-space-lg);
}

.xxc9_private__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--xxc9-space-sm);
}

/* ── events.html: responsive ── */
@media (width >= 768px) {
  .xxc9_event-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .xxc9_private__inner {
    grid-template-columns: 1fr auto;
  }
}


/* ══════════════════════════════════════════════════════════════════════════════
   menus.html
   ══════════════════════════════════════════════════════════════════════════════ */

/* menus.html: page hero background */
.xxc9_page-hero--menus {
  background:
    linear-gradient(180deg, oklch(10% 0.04 258 / 0.65) 0%, oklch(16% 0.04 258 / 0.88) 100%),
    url('https://sirenspub-n-grub.com/wp-content/uploads/2026/04/tacos-fries.webp') center / cover no-repeat;
        height: auto;
          padding: 2em;
}

/* ── menus.html: tab nav ── */
.xxc9_tab-nav {
  background-color: var(--xxc9-color-bg);
  border-block-end: 1px solid var(--xxc9-color-border);
  position: sticky;
  inset-block-start: 65px;
  z-index: 50;
}

.xxc9_tab-nav__list {
  display: flex;
  gap: 0;
  list-style: none;
  overflow-x: auto;
  scrollbar-width: none;
}

.xxc9_tab-nav__list::-webkit-scrollbar {
  display: none;
}

.xxc9_tab-nav__btn {
  display: block;
  padding-block: var(--xxc9-space-md);
  padding-inline: var(--xxc9-space-lg);
  font-size: var(--xxc9-size-xs);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--xxc9-color-text-secondary);
  background: transparent;
  border: none;
  border-block-end: 2px solid transparent;
  cursor: pointer;
  white-space: nowrap;
  transition: color var(--xxc9-duration-fast), border-color var(--xxc9-duration-fast);
  min-block-size: 44px;
}

.xxc9_tab-nav__btn:hover {
  color: var(--xxc9-color-pearl);
}

.xxc9_tab-nav__btn[aria-selected="true"] {
  color: var(--xxc9-color-accent);
  border-block-end-color: var(--xxc9-color-accent);
}

/* ── menus.html: tab panels ── */
.xxc9_tab-panel {
  display: none;
  padding-block: var(--xxc9-space-2xl);
}

.xxc9_tab-panel[aria-hidden="false"] {
  display: block;
}

/* ── menus.html: menu sections ── */
.xxc9_menu-section {
  padding-block: var(--xxc9-space-xl);
}

.xxc9_menu-section + .xxc9_menu-section {
  border-block-start: 1px solid var(--xxc9-color-border);
}

.xxc9_menu-section__heading {
  font-family: var(--xxc9-font-display);
  font-style: italic;
  font-size: var(--xxc9-size-xl);
  color: var(--xxc9-color-pearl);
  margin-block-end: var(--xxc9-space-sm);
}

.xxc9_menu-section__note {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-text-secondary);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-block-end: var(--xxc9-space-lg);
  line-height: var(--xxc9-leading-normal);
}

.xxc9_menu-section__fineprint {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-text-secondary);
  font-style: italic;
  margin-block-start: var(--xxc9-space-md);
  line-height: var(--xxc9-leading-normal);
}

.xxc9_menu-feature {
  container-type: inline-size;
  display: grid;
  gap: var(--xxc9-space-lg);
  align-items: start;
}

.xxc9_menu-feature__list {
  min-inline-size: 0;
}

.xxc9_menu-feature__media {
  position: relative;
  overflow: hidden;
  inline-size: 100%;
  aspect-ratio: 4 / 3;
  border: 1px solid var(--xxc9-color-border);
  border-radius: var(--xxc9-radius-md);
  background-color: var(--xxc9-color-surface);
}

.xxc9_menu-feature__media::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to top, oklch(0% 0 0 / 0.18), transparent 46%),
    linear-gradient(to right, oklch(0% 0 0 / 0.08), transparent 34%);
  pointer-events: none;
}

.xxc9_menu-feature__img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
}

.xxc9_menu-feature--lunch .xxc9_menu-feature__img {
  object-position: 52% 50%;
}

.xxc9_menu-feature--munchies .xxc9_menu-feature__img {
  object-position: 64% 50%;
}

.xxc9_menu-feature--teasers .xxc9_menu-feature__img {
  object-position: 42% 50%;
}

.xxc9_menu-feature--handhelds .xxc9_menu-feature__img {
  object-position: 58% 50%;
}

.xxc9_menu-feature--deep-dives .xxc9_menu-feature__img {
  object-position: 48% 50%;
}

.xxc9_menu-feature--sides .xxc9_menu-feature__img {
  object-position: 34% 50%;
}

@media (width >= 768px) {
  .xxc9_menu-feature {
    grid-template-columns: minmax(0, 1fr) minmax(18rem, 38%);
    gap: var(--xxc9-space-xl);
  }

  .xxc9_menu-feature__media {
    aspect-ratio: 4 / 5;
    position: sticky;
    inset-block-start: calc(65px + var(--xxc9-space-lg));
  }
}

/* ── menus.html: menu items ── */
.xxc9_menu-list {
  list-style: none;
}

.xxc9_menu-item {
  display: grid;
  grid-template-columns: 1fr auto;
  column-gap: var(--xxc9-space-lg);
  row-gap: 0.25rem;
  padding-block: var(--xxc9-space-md);
  border-block-end: 1px solid oklch(100% 0 0 / 0.06);
  align-items: start;
}

.xxc9_menu-item:last-child {
  border-block-end: none;
}

.xxc9_menu-item__name {
  font-size: var(--xxc9-size-md);
  font-weight: 500;
  color: var(--xxc9-color-pearl);
  grid-column: 1;
  grid-row: 1;
}

.xxc9_menu-item__price {
  font-family: var(--xxc9-font-display);
  font-style: italic;
  font-size: var(--xxc9-size-lg);
  color: var(--xxc9-color-accent);
  grid-column: 2;
  grid-row: 1;
  white-space: nowrap;
  text-align: end;
  padding-block-start: 0.05em;
}

.xxc9_menu-item__desc {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-text-secondary);
  line-height: var(--xxc9-leading-normal);
  grid-column: 1;
  grid-row: 2;
}

.xxc9_menu-item__add {
  font-size: var(--xxc9-size-xs);
  color: oklch(62% 0.04 208);
  font-style: italic;
  grid-column: 1 / -1;
  grid-row: 3;
  margin-block-start: 0.2rem;
}

.xxc9_menu-item__proteins {
  font-size: var(--xxc9-size-xs);
  color: oklch(62% 0.04 208);
  grid-column: 1 / -1;
  margin-block-start: 0.25rem;
  line-height: var(--xxc9-leading-normal);
}

/* ── menus.html: subsections ── */
.xxc9_menu-subsection {
  margin-block-start: var(--xxc9-space-xl);
  padding-block-start: var(--xxc9-space-xl);
  border-block-start: 1px solid oklch(100% 0 0 / 0.08);
}

.xxc9_menu-subsection__heading {
  font-family: var(--xxc9-font-display);
  font-style: italic;
  font-size: var(--xxc9-size-lg);
  color: var(--xxc9-color-pearl);
  margin-block-end: var(--xxc9-space-sm);
}

.xxc9_menu-subsection__note {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-text-secondary);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-block-end: var(--xxc9-space-lg);
}

/* ── menus.html: happy hour specials ── */
.xxc9_hh-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--xxc9-space-sm);
}

.xxc9_hh-item {
  display: flex;
  align-items: center;
  gap: var(--xxc9-space-md);
  padding-block: var(--xxc9-space-md);
  border-block-end: 1px solid oklch(100% 0 0 / 0.07);
}

.xxc9_hh-item:last-child {
  border-block-end: none;
}

.xxc9_hh-item__price {
  font-family: var(--xxc9-font-display);
  font-style: italic;
  font-size: var(--xxc9-size-2xl);
  color: var(--xxc9-color-accent);
  flex-shrink: 0;
  min-inline-size: clamp(3rem, 8vw, 4.5rem);
}

.xxc9_hh-item__name {
  font-size: var(--xxc9-size-md);
  color: var(--xxc9-color-pearl);
}

/* ── menus.html: drinks / beer / wine columns ── */
.xxc9_drinks-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--xxc9-space-xl);
}

.xxc9_drinks-feature {
  display: grid;
  gap: var(--xxc9-space-lg);
  align-items: start;
}

.xxc9_drinks-feature__list {
  min-inline-size: 0;
}

.xxc9_drinks-feature__media {
  position: relative;
  overflow: hidden;
  inline-size: 100%;
  aspect-ratio: 4 / 3;
  border: 1px solid var(--xxc9-color-border);
  border-radius: var(--xxc9-radius-md);
  background-color: var(--xxc9-color-surface);
}

.xxc9_drinks-feature__media::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to top, oklch(0% 0 0 / 0.2), transparent 48%),
    linear-gradient(to right, oklch(0% 0 0 / 0.1), transparent 36%);
  pointer-events: none;
}

.xxc9_drinks-feature__img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  object-position: 50% 50%;
}

.xxc9_drinks-col__heading {
  font-family: var(--xxc9-font-display);
  font-style: italic;
  font-size: var(--xxc9-size-lg);
  color: var(--xxc9-color-pearl);
  margin-block-end: var(--xxc9-space-md);
  padding-block-end: var(--xxc9-space-sm);
  border-block-end: 1px solid var(--xxc9-color-border);
}

.xxc9_drinks-list {
  list-style: none;
  display: flex;
  flex-direction: column;
}

.xxc9_drinks-list__item {
  font-size: var(--xxc9-size-sm);
  color: var(--xxc9-color-text-secondary);
  padding-block: 0.55rem;
  border-block-end: 1px solid oklch(100% 0 0 / 0.05);
}

.xxc9_drinks-list__item:last-child {
  border-block-end: none;
}

.xxc9_drinks-list__item strong {
  color: var(--xxc9-color-pearl);
  font-weight: 500;
  display: block;
  font-size: var(--xxc9-size-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-block-start: var(--xxc9-space-md);
  padding-block-end: 0.3rem;
}

/* ── menus.html: cocktail items ── */
.xxc9_cocktail-item {
  padding-block: var(--xxc9-space-md);
  border-block-end: 1px solid oklch(100% 0 0 / 0.06);
}

.xxc9_cocktail-item:last-child {
  border-block-end: none;
}

.xxc9_cocktail-item__name {
  font-size: var(--xxc9-size-md);
  font-weight: 500;
  color: var(--xxc9-color-pearl);
  margin-block-end: 0.3rem;
}

.xxc9_cocktail-item__desc {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-text-secondary);
  line-height: var(--xxc9-leading-normal);
}

.xxc9_cocktail-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
}

/* ── menus.html: menu note banner ── */
.xxc9_menu-note {
  display: flex;
  align-items: flex-start;
  gap: var(--xxc9-space-sm);
  padding: var(--xxc9-space-md) var(--xxc9-space-lg);
  background-color: oklch(74% 0.05 85 / 0.07);
  border: 1px solid oklch(74% 0.05 85 / 0.22);
  border-radius: var(--xxc9-radius-md);
  margin-block-end: var(--xxc9-space-xl);
}

.xxc9_menu-note__text {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-text-secondary);
  line-height: var(--xxc9-leading-normal);
}

.xxc9_menu-note__text strong {
  color: var(--xxc9-color-accent);
  font-weight: 500;
}

/* ── menus.html: responsive ── */
@media (width >= 768px) {
  .xxc9_hh-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 0 var(--xxc9-space-2xl);
  }

  .xxc9_drinks-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .xxc9_drinks-feature {
    grid-column: 1 / -1;
    grid-template-columns: minmax(0, 1fr) minmax(18rem, 42%);
    gap: var(--xxc9-space-xl);
  }

  .xxc9_drinks-feature__media {
    aspect-ratio: 4 / 5;
  }

  .xxc9_cocktail-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 0 var(--xxc9-space-2xl);
  }
}

@media (width >= 1024px) {
  .xxc9_drinks-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}


/* ══════════════════════════════════════════════════════════════════════════════
   location.html
   ══════════════════════════════════════════════════════════════════════════════ */

/* location.html: page hero background */
.xxc9_page-hero--location {
  background:
    linear-gradient(180deg, oklch(10% 0.04 258 / 0.65) 0%, oklch(16% 0.04 258 / 0.88) 100%),
    url('https://sirenspub-n-grub.com/wp-content/uploads/2026/04/sirens-front.webp') center / cover no-repeat;
        height: auto;
          padding: 2em;
}

/* ── location.html: location content ── */
.xxc9_location {
  padding-block: var(--xxc9-space-2xl);
}

.xxc9_location__grid {
  display: grid;
  gap: var(--xxc9-space-xl);
}

.xxc9_map-embed {
  border-radius: var(--xxc9-radius-lg);
  overflow: hidden;
  border: 1px solid var(--xxc9-color-border);
  aspect-ratio: 4/3;
  background-color: var(--xxc9-color-surface);
}

.xxc9_map-embed iframe {
  inline-size: 100%;
  block-size: 100%;
  border: none;
  display: block;
}

.xxc9_location__details {
  display: flex;
  flex-direction: column;
  gap: var(--xxc9-space-lg);
}

.xxc9_detail-block__label {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-accent);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  margin-block-end: var(--xxc9-space-sm);
  display: block;
}

.xxc9_detail-block__value {
  font-family: var(--xxc9-font-display);
  font-style: italic;
  font-size: var(--xxc9-size-lg);
  color: var(--xxc9-color-pearl);
  line-height: var(--xxc9-leading-snug);
  display: block;
}

.xxc9_detail-block__sub {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-text-secondary);
  margin-block-start: 0.3em;
  display: block;
  line-height: var(--xxc9-leading-normal);
}

.xxc9_detail-block__link {
  display: inline-flex;
  align-items: center;
  gap: 0.3em;
  margin-block-start: 0.7em;
  font-size: var(--xxc9-size-xs);
  font-weight: 500;
  color: var(--xxc9-color-accent);
  text-decoration: none;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: color var(--xxc9-duration-fast);
}

.xxc9_detail-block__link:hover {
  color: var(--xxc9-color-accent-hover);
}

.xxc9_detail-block + .xxc9_detail-block {
  padding-block-start: var(--xxc9-space-lg);
  border-block-start: 1px solid var(--xxc9-color-border);
}

/* ── location.html: nearby section ── */
.xxc9_nearby {
  padding-block: var(--xxc9-space-xl) var(--xxc9-space-2xl);
  border-block-start: 1px solid var(--xxc9-color-border);
}

.xxc9_nearby__heading {
  font-family: var(--xxc9-font-display);
  font-style: italic;
  font-size: var(--xxc9-size-2xl);
  color: var(--xxc9-color-pearl);
  line-height: var(--xxc9-leading-snug);
  margin-block: var(--xxc9-space-md) var(--xxc9-space-lg);
}

.xxc9_nearby__sub {
  font-size: var(--xxc9-size-sm);
  font-weight: 300;
  color: var(--xxc9-color-text-secondary);
  line-height: var(--xxc9-leading-normal);
  max-inline-size: 52ch;
  margin-block-end: var(--xxc9-space-lg);
}

.xxc9_nearby__eyebrow {
  display: flex;
  align-items: center;
  gap: var(--xxc9-space-sm);
}

.xxc9_nearby__rule {
  display: block;
  inline-size: 1.75rem;
  block-size: 1px;
  background-color: var(--xxc9-color-accent);
}

.xxc9_nearby__kicker {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-accent);
  letter-spacing: 0.26em;
  text-transform: uppercase;
}

.xxc9_nearby__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--xxc9-space-sm);
}

.xxc9_nearby__item {
  min-inline-size: 0;
}

.xxc9_nearby__link {
  display: block;
  block-size: 100%;
  background-color: var(--xxc9-color-surface);
  border: 1px solid var(--xxc9-color-border);
  border-radius: var(--xxc9-radius-md);
  padding: var(--xxc9-space-md);
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-text-secondary);
  line-height: var(--xxc9-leading-normal);
  text-decoration: none;
  transition: border-color var(--xxc9-duration-fast), color var(--xxc9-duration-fast);
}

.xxc9_nearby__link:hover {
  border-color: oklch(42% 0.04 240);
  color: var(--xxc9-color-text-primary);
}

/* ── location.html: sister restaurant ── */
.xxc9_sister {
  padding-block: var(--xxc9-space-xl);
  background-color: var(--xxc9-color-surface);
  border-block: 1px solid var(--xxc9-color-border);
}

.xxc9_sister__inner {
  display: grid;
  gap: var(--xxc9-space-lg);
  align-items: center;
}

.xxc9_sister__label {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-accent);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  margin-block-end: var(--xxc9-space-sm);
  display: block;
}

.xxc9_sister__heading {
  font-family: var(--xxc9-font-display);
  font-style: italic;
  font-size: var(--xxc9-size-2xl);
  color: var(--xxc9-color-pearl);
  line-height: var(--xxc9-leading-snug);
  margin-block-end: var(--xxc9-space-md);
}

.xxc9_sister__copy {
  font-size: var(--xxc9-size-sm);
  font-weight: 300;
  color: var(--xxc9-color-text-secondary);
  line-height: var(--xxc9-leading-normal);
  max-inline-size: 52ch;
  margin-block-end: var(--xxc9-space-lg);
}

/* ── location.html: responsive ── */
@media (width >= 768px) {
  .xxc9_location__grid {
    grid-template-columns: 1fr 1fr;
  }

  .xxc9_map-embed {
    aspect-ratio: 16/9;
  }

  .xxc9_nearby__grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .xxc9_sister__inner {
    grid-template-columns: 1fr auto;
  }
}


/* ══════════════════════════════════════════════════════════════════════════════
   comments.html
   ══════════════════════════════════════════════════════════════════════════════ */

/* comments.html: page hero background */
.xxc9_page-hero--comments {
  background:
    linear-gradient(180deg, oklch(10% 0.04 258 / 0.65) 0%, oklch(16% 0.04 258 / 0.88) 100%),
    url('https://sirenspub-n-grub.com/wp-content/uploads/2026/04/sirens-neon-2.webp') center / cover no-repeat;
        height: auto;
          padding: 2em;
}

/* ── comments.html: contact layout ── */
.xxc9_contact {
  padding-block: var(--xxc9-space-2xl);
}

.xxc9_contact__inner {
  display: grid;
  gap: var(--xxc9-space-xl);
  align-items: start;
}

/* ── comments.html: form ── */
.xxc9_form {
  display: flex;
  flex-direction: column;
  gap: var(--xxc9-space-lg);
}

.xxc9_field {
  display: flex;
  flex-direction: column;
  gap: var(--xxc9-space-xs);
}

.xxc9_field__label {
  font-size: var(--xxc9-size-xs);
  font-weight: 500;
  color: var(--xxc9-color-text-secondary);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.xxc9_field__label abbr {
  text-decoration: none;
  color: var(--xxc9-color-accent);
}

.xxc9_field__input,
.xxc9_field__select,
.xxc9_field__textarea {
  inline-size: 100%;
  background-color: var(--xxc9-color-surface);
  border: 1px solid var(--xxc9-color-border);
  border-radius: var(--xxc9-radius-md);
  padding-block: 0.75rem;
  padding-inline: var(--xxc9-space-md);
  font-family: var(--xxc9-font-body);
  font-size: var(--xxc9-size-sm);
  color: var(--xxc9-color-text-primary);
  transition: border-color var(--xxc9-duration-fast), background-color var(--xxc9-duration-fast);
}

.xxc9_field__input::placeholder,
.xxc9_field__textarea::placeholder {
  color: oklch(45% 0.02 250);
}

.xxc9_field__input:hover,
.xxc9_field__textarea:hover {
  border-color: oklch(38% 0.05 222);
}

.xxc9_field__input:focus,
.xxc9_field__textarea:focus {
  border-color: var(--xxc9-color-accent);
  background-color: var(--xxc9-color-surface-raised);
  outline: none;
}

.xxc9_field__textarea {
  min-block-size: 160px;
  resize: vertical;
  line-height: var(--xxc9-leading-normal);
}

/* ── comments.html: consent checkbox ── */
.xxc9_consent {
  display: flex;
  gap: var(--xxc9-space-md);
  align-items: flex-start;
  padding: var(--xxc9-space-md);
  background-color: var(--xxc9-color-surface);
  border: 1px solid var(--xxc9-color-border);
  border-radius: var(--xxc9-radius-md);
}

.xxc9_consent__checkbox {
  inline-size: 20px;
  block-size: 20px;
  border: 1.5px solid var(--xxc9-color-border);
  border-radius: var(--xxc9-radius-sm);
  background-color: transparent;
  cursor: pointer;
  flex-shrink: 0;
  margin-block-start: 0.15rem;
  accent-color: var(--xxc9-color-accent);
}

.xxc9_consent__text {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-text-secondary);
  line-height: var(--xxc9-leading-normal);
}

.xxc9_consent__text strong {
  color: var(--xxc9-color-text-primary);
  font-weight: 500;
}

.xxc9_form__note {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-text-secondary);
}

/* ── comments.html: sidebar contact info ── */
.xxc9_contact-info {
  display: flex;
  flex-direction: column;
  gap: var(--xxc9-space-lg);
}

.xxc9_contact-block__label {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-accent);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  margin-block-end: var(--xxc9-space-sm);
  display: block;
}

.xxc9_contact-block__value {
  font-family: var(--xxc9-font-display);
  font-style: italic;
  font-size: var(--xxc9-size-lg);
  color: var(--xxc9-color-pearl);
  display: block;
}

.xxc9_contact-block__sub {
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-text-secondary);
  margin-block-start: 0.3em;
  display: block;
  line-height: var(--xxc9-leading-normal);
}

.xxc9_contact-block__link {
  display: inline-block;
  margin-block-start: 0.6em;
  font-size: var(--xxc9-size-xs);
  color: var(--xxc9-color-accent);
  text-decoration: none;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: color var(--xxc9-duration-fast);
}

.xxc9_contact-block__link:hover {
  color: var(--xxc9-color-accent-hover);
}

.xxc9_contact-block + .xxc9_contact-block {
  padding-block-start: var(--xxc9-space-lg);
  border-block-start: 1px solid var(--xxc9-color-border);
}

/* ── comments.html: form success message ── */
.xxc9_form-success {
  display: none;
  background-color: oklch(74% 0.05 85 / 0.1);
  border: 1px solid oklch(74% 0.05 85 / 0.3);
  border-radius: var(--xxc9-radius-lg);
  padding: var(--xxc9-space-xl);
  text-align: center;
}

.xxc9_form-success.xxc9_is-visible {
  display: block;
}

.xxc9_form-success__icon {
  margin-block-end: var(--xxc9-space-md);
  color: var(--xxc9-color-accent);
}

.xxc9_form-success__icon svg {
  inline-size: 2.5rem;
  block-size: 2.5rem;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 1.8;
}

.xxc9_form-success__heading {
  font-family: var(--xxc9-font-display);
  font-style: italic;
  font-size: var(--xxc9-size-2xl);
  color: var(--xxc9-color-pearl);
  margin-block-end: var(--xxc9-space-sm);
}

.xxc9_form-success__body {
  font-size: var(--xxc9-size-sm);
  color: var(--xxc9-color-text-secondary);
}

/* ── comments.html: responsive ── */
@media (width >= 768px) {
  .xxc9_contact__inner {
    grid-template-columns: 1fr 380px;
  }
}

/* ── Image-backed headers keep light copy in every theme ── */
.xxc9_hero .xxc9_hero__heading,
.xxc9_hero .xxc9_hero__address-name,
.xxc9_hero .xxc9_stat__num,
.xxc9_hero .xxc9_scroll-cue,
.xxc9_hero .xxc9_site-nav__wordmark,
.xxc9_hero .xxc9_site-nav__link,
.xxc9_page-hero--about .xxc9_page-hero__heading,
.xxc9_page-hero--events .xxc9_page-hero__heading,
.xxc9_page-hero--menus .xxc9_page-hero__heading,
.xxc9_page-hero--location .xxc9_page-hero__heading,
.xxc9_page-hero--comments .xxc9_page-hero__heading {
  color: var(--xxc9-color-on-image);
}

.xxc9_hero .xxc9_hero__lede,
.xxc9_hero .xxc9_hero__address-label,
.xxc9_hero .xxc9_hero__address-street,
.xxc9_hero .xxc9_stat__label,
.xxc9_hero .xxc9_site-nav__sub,
.xxc9_page-hero--about .xxc9_page-hero__sub,
.xxc9_page-hero--events .xxc9_page-hero__sub,
.xxc9_page-hero--menus .xxc9_page-hero__sub,
.xxc9_page-hero--location .xxc9_page-hero__sub,
.xxc9_page-hero--comments .xxc9_page-hero__sub {
  color: var(--xxc9-color-on-image-muted);
}

.xxc9_hero .xxc9_btn--outline {
  color: var(--xxc9-color-on-image-muted);
  border-color: oklch(100% 0 0 / 0.28);
}

.xxc9_hero .xxc9_btn--outline:hover {
  color: var(--xxc9-color-on-image);
  border-color: oklch(100% 0 0 / 0.48);
  background-color: oklch(100% 0 0 / 0.08);
}

.xxc9_hero .xxc9_theme-toggle {
  color: var(--xxc9-color-on-image-muted);
  border-color: oklch(100% 0 0 / 0.24);
}

.xxc9_hero .xxc9_theme-toggle:hover {
  color: var(--xxc9-color-on-image);
  border-color: oklch(100% 0 0 / 0.44);
  background-color: oklch(100% 0 0 / 0.08);
}

.xxc9_hero .xxc9_site-nav__bar {
  background-color: var(--xxc9-color-on-image);
}

[data-theme="light"] .xxc9_hero .xxc9_hero__heading,
[data-theme="light"] .xxc9_hero .xxc9_hero__address-name,
[data-theme="light"] .xxc9_hero .xxc9_stat__num,
[data-theme="light"] .xxc9_hero .xxc9_scroll-cue,
[data-theme="light"] .xxc9_hero .xxc9_site-nav__wordmark,
[data-theme="light"] .xxc9_hero .xxc9_site-nav__link {
  color: var(--xxc9-color-text-primary);
}

[data-theme="light"] .xxc9_hero .xxc9_hero__heading em,
[data-theme="light"] .xxc9_hero .xxc9_hero__kicker,
[data-theme="light"] .xxc9_hero .xxc9_site-nav__sub {
  color: var(--xxc9-color-accent);
}

[data-theme="light"] .xxc9_hero .xxc9_hero__lede,
[data-theme="light"] .xxc9_hero .xxc9_hero__address-label,
[data-theme="light"] .xxc9_hero .xxc9_hero__address-street,
[data-theme="light"] .xxc9_hero .xxc9_stat__label {
  color: var(--xxc9-color-text-secondary);
}

[data-theme="light"] .xxc9_hero .xxc9_btn--outline {
  color: var(--xxc9-color-text-secondary);
  border-color: var(--xxc9-color-border);
}

[data-theme="light"] .xxc9_hero .xxc9_btn--outline:hover {
  color: var(--xxc9-color-text-primary);
  border-color: oklch(20% 0.04 258 / 0.28);
  background-color: oklch(20% 0.04 258 / 0.05);
}

[data-theme="light"] .xxc9_hero .xxc9_theme-toggle {
  color: var(--xxc9-color-text-secondary);
  border-color: oklch(20% 0.04 258 / 0.2);
}

[data-theme="light"] .xxc9_hero .xxc9_theme-toggle:hover {
  color: var(--xxc9-color-text-primary);
  border-color: oklch(20% 0.04 258 / 0.45);
  background-color: oklch(20% 0.04 258 / 0.06);
}

[data-theme="light"] .xxc9_hero .xxc9_site-nav__bar {
  background-color: var(--xxc9-color-text-primary);
}
