/* venue.css — styling for /alerts/<category>/<slug>/ pages + per-category hubs. */
.venue-crumbs { max-width: 1080px; margin: 14px auto 0; padding: 0 20px; font-size: .88rem; color: var(--purple-700, #5a4a7a); }
.venue-crumbs a { color: var(--purple-700, #5a4a7a); text-decoration: none; }
.venue-crumbs a:hover { color: var(--gold-700, #8a6a38); }

.venue-hero { max-width: 880px; margin: 0 auto; padding: 40px 20px 32px; text-align: center; }
.venue-hero .eyebrow { display: inline-block; letter-spacing: .08em; text-transform: uppercase; font-size: .78rem; color: var(--gold-700, #8a6a38); margin: 14px 0 8px; }
.venue-hero h1 { font-family: var(--font-display, "Cormorant Garamond", Georgia, serif); font-size: clamp(2rem, 5vw, 3.2rem); line-height: 1.08; color: var(--purple-900, #2a1f4a); margin: 0 0 16px; }
.venue-hero__lede { font-size: 1.1rem; line-height: 1.55; color: var(--purple-800, #3a2e5a); max-width: 720px; margin: 0 auto 24px; }
.venue-hero__cta { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; margin-bottom: 10px; }
.venue-hero__legal { font-size: .9rem; color: var(--purple-700, #5a4a7a); margin-top: 8px; }
.venue-hero--hub { padding-bottom: 24px; }

.venue-stats { max-width: 1080px; margin: 16px auto 0; padding: 28px 20px; background: var(--cream-50, #fdfbf6); border-top: 1px solid rgba(58, 46, 90, 0.08); border-bottom: 1px solid rgba(58, 46, 90, 0.08); }
.venue-stats__h { font-family: var(--font-display, "Cormorant Garamond", Georgia, serif); font-size: 1.5rem; text-align: center; color: var(--purple-900, #2a1f4a); margin: 0 0 4px; }
.venue-stats__sub { text-align: center; font-size: .92rem; color: var(--purple-700, #5a4a7a); margin: 0 0 22px; }
.venue-stats__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 18px; margin: 0; padding: 0; }
.venue-stat { background: #fff; border: 1px solid rgba(58, 46, 90, 0.10); border-radius: 12px; padding: 18px 20px; text-align: center; }
.venue-stat dt { font-size: .82rem; letter-spacing: .04em; text-transform: uppercase; color: var(--purple-700, #5a4a7a); margin: 0 0 8px; }
.venue-stat dd { margin: 0; font-family: var(--font-display, "Cormorant Garamond", Georgia, serif); font-size: 2rem; color: var(--gold-700, #8a6a38); }
.venue-stat small { display: block; font-size: .8rem; color: var(--purple-700, #5a4a7a); margin-top: 6px; }
.venue-stats__empty { text-align: center; margin-top: 16px; font-size: .92rem; color: var(--purple-700, #5a4a7a); font-style: italic; }

.venue-why { max-width: 1080px; margin: 40px auto 0; padding: 0 20px; }
.venue-why h2, .venue-how h2, .venue-faq h2, .venue-related h2 { font-family: var(--font-display, "Cormorant Garamond", Georgia, serif); font-size: clamp(1.5rem, 3vw, 2.1rem); color: var(--purple-900, #2a1f4a); text-align: center; margin: 0 0 22px; }
.venue-why__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 18px; }
.venue-why__card { background: #fff; border: 1px solid rgba(58, 46, 90, 0.10); border-radius: 12px; padding: 22px; }
.venue-why__card h3 { font-size: 1.05rem; color: var(--purple-900, #2a1f4a); margin: 0 0 10px; }
.venue-why__card p { margin: 0; font-size: .95rem; line-height: 1.55; color: var(--purple-800, #3a2e5a); }

.venue-how { max-width: 880px; margin: 48px auto 0; padding: 0 20px; }
.venue-how__steps { list-style: none; counter-reset: step; padding: 0; margin: 0; }
.venue-how__steps li { counter-increment: step; padding: 14px 14px 14px 56px; position: relative; margin-bottom: 12px; background: var(--cream-50, #fdfbf6); border-radius: 10px; font-size: .98rem; color: var(--purple-800, #3a2e5a); }
.venue-how__steps li::before { content: counter(step); position: absolute; left: 14px; top: 50%; transform: translateY(-50%); width: 30px; height: 30px; background: var(--purple-900, #2a1f4a); color: var(--gold-300, #e4d2ae); border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font-family: var(--font-display, "Cormorant Garamond", Georgia, serif); font-weight: 600; }
.venue-how__cta { text-align: center; margin-top: 22px; }

.venue-faq { max-width: 880px; margin: 48px auto 0; padding: 0 20px; }
.venue-faq__item { background: #fff; border: 1px solid rgba(58, 46, 90, 0.10); border-radius: 10px; padding: 14px 18px; margin-bottom: 10px; }
.venue-faq__item summary { cursor: pointer; font-weight: 600; color: var(--purple-900, #2a1f4a); font-size: 1.02rem; list-style: none; }
.venue-faq__item summary::-webkit-details-marker { display: none; }
.venue-faq__item summary::before { content: '+'; margin-right: 10px; color: var(--gold-700, #8a6a38); font-weight: 700; }
.venue-faq__item[open] summary::before { content: '–'; }
.venue-faq__item p { margin: 12px 0 0; color: var(--purple-800, #3a2e5a); font-size: .95rem; line-height: 1.6; }

.venue-related { max-width: 1080px; margin: 56px auto 0; padding: 0 20px; }
.venue-related__grid { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 12px; }
.venue-related__grid li a { display: block; background: var(--cream-50, #fdfbf6); border: 1px solid rgba(58, 46, 90, 0.10); border-radius: 10px; padding: 14px 16px; text-decoration: none; color: var(--purple-900, #2a1f4a); transition: border-color .15s ease, background .15s ease; }
.venue-related__grid li a:hover { border-color: var(--gold-500, #c9a665); background: #fff; }
.venue-related__grid li strong { display: block; font-family: var(--font-display, "Cormorant Garamond", Georgia, serif); font-size: 1.05rem; color: var(--purple-900, #2a1f4a); margin-bottom: 4px; }
.venue-related__grid li span { display: block; font-size: .82rem; color: var(--purple-700, #5a4a7a); }

.venue-park { max-width: 1080px; margin: 24px auto 0; padding: 0 20px; }
.venue-park h2 { font-family: var(--font-display, "Cormorant Garamond", Georgia, serif); font-size: 1.4rem; color: var(--purple-900, #2a1f4a); border-bottom: 1px solid rgba(58, 46, 90, 0.10); padding-bottom: 6px; margin-bottom: 14px; }
.venue-park__list { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 10px; }
.venue-park__list li a { display: block; background: #fff; border: 1px solid rgba(58, 46, 90, 0.10); border-radius: 10px; padding: 12px 14px; text-decoration: none; color: var(--purple-900, #2a1f4a); }
.venue-park__list li a:hover { border-color: var(--gold-500, #c9a665); background: var(--cream-50, #fdfbf6); }
.venue-park__list li strong { display: block; font-family: var(--font-display, "Cormorant Garamond", Georgia, serif); font-size: 1.04rem; margin-bottom: 2px; }
.venue-park__list li span { display: block; font-size: .82rem; color: var(--purple-700, #5a4a7a); }

.venue-footer { max-width: 880px; margin: 64px auto 0; padding: 28px 20px 60px; border-top: 1px solid rgba(58, 46, 90, 0.08); }
.venue-footer__disclaimer { font-size: .82rem; color: var(--purple-700, #5a4a7a); line-height: 1.5; margin: 0 0 14px; }
.venue-footer__contact { font-size: .82rem; color: var(--purple-700, #5a4a7a); margin: 0; }
.venue-footer__contact a { color: var(--purple-700, #5a4a7a); text-decoration: underline; }

.visually-hidden { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }

/* Agent-contributed photos. Hero band sits between breadcrumbs and the H1 hero. */
.venue-photo-hero { max-width: 1180px; margin: 18px auto 0; padding: 0 20px; position: relative; }
.venue-photo-hero img { display: block; width: 100%; max-height: 420px; object-fit: cover; border-radius: 14px; box-shadow: 0 8px 24px rgba(42, 31, 74, 0.10); }
.venue-photo-hero__cap { position: absolute; left: 32px; right: 32px; bottom: 14px; display: flex; flex-wrap: wrap; align-items: baseline; gap: 8px 16px; padding: 10px 14px; background: linear-gradient(180deg, rgba(42, 31, 74, 0.0) 0%, rgba(42, 31, 74, 0.72) 100%); border-radius: 0 0 14px 14px; color: #fff; }
.venue-photo-hero__caption { font-size: .95rem; line-height: 1.45; }
.venue-photo-hero__credit { font-size: .78rem; opacity: .88; letter-spacing: .02em; }
@media (max-width: 640px) {
  .venue-photo-hero img { max-height: 280px; }
  .venue-photo-hero__cap { left: 28px; right: 28px; bottom: 8px; padding: 8px 10px; }
  .venue-photo-hero__caption { font-size: .85rem; }
}

.venue-gallery { max-width: 1180px; margin: 48px auto 0; padding: 0 20px; }
.venue-gallery h2 { font-family: var(--font-display, "Cormorant Garamond", Georgia, serif); font-size: clamp(1.5rem, 3vw, 2.1rem); color: var(--purple-900, #2a1f4a); text-align: center; margin: 0 0 6px; }
.venue-gallery__sub { text-align: center; font-size: .92rem; color: var(--purple-700, #5a4a7a); margin: 0 0 22px; }
.venue-gallery__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 14px; }
.venue-gallery__item { margin: 0; background: #fff; border: 1px solid rgba(58, 46, 90, 0.10); border-radius: 12px; overflow: hidden; display: flex; flex-direction: column; }
.venue-gallery__item img { display: block; width: 100%; aspect-ratio: 4 / 3; object-fit: cover; }
.venue-gallery__cap { padding: 12px 14px; display: flex; flex-direction: column; gap: 4px; }
.venue-gallery__caption { font-size: .92rem; line-height: 1.45; color: var(--purple-900, #2a1f4a); }
.venue-gallery__credit { font-size: .76rem; color: var(--purple-700, #5a4a7a); letter-spacing: .02em; }

/* SMS demo — phone-frame mock with venue-tailored example alert.
   Sits between live-stats and the why-cards. Scoped to .venue-sms-demo. */
.venue-sms-demo { max-width: 1080px; margin: 48px auto 0; padding: 0 20px; }
.venue-sms-demo__h { font-family: var(--font-display, "Cormorant Garamond", Georgia, serif); font-size: clamp(1.5rem, 3vw, 2.1rem); color: var(--purple-900, #2a1f4a); text-align: center; margin: 0 0 6px; }
.venue-sms-demo__sub { text-align: center; font-size: .92rem; color: var(--purple-700, #5a4a7a); margin: 0 0 28px; font-style: italic; }
.venue-sms-demo__stage { display: grid; grid-template-columns: minmax(260px, 320px) 1fr; gap: 40px; align-items: center; max-width: 880px; margin: 0 auto; }
@media (max-width: 720px) {
  .venue-sms-demo__stage { grid-template-columns: 1fr; gap: 24px; justify-items: center; text-align: center; }
}

.venue-sms-phone { margin: 0; width: 100%; max-width: 320px; background: #1c1530; border-radius: 36px; padding: 12px; box-shadow: 0 18px 40px rgba(42, 31, 74, 0.28), 0 2px 6px rgba(42, 31, 74, 0.18); position: relative; }
.venue-sms-phone__notch { position: absolute; top: 12px; left: 50%; transform: translateX(-50%); width: 110px; height: 26px; background: #1c1530; border-radius: 0 0 18px 18px; z-index: 2; }
.venue-sms-phone__screen { background: #f5f1ea; border-radius: 26px; overflow: hidden; min-height: 420px; display: flex; flex-direction: column; }
.venue-sms-phone__statusbar { display: flex; justify-content: space-between; align-items: center; padding: 14px 22px 6px; color: #2a1f4a; font-size: .82rem; font-weight: 600; font-variant-numeric: tabular-nums; }
.venue-sms-phone__icons { display: inline-flex; gap: 6px; align-items: center; color: #2a1f4a; }
.venue-sms-phone__icons svg { display: block; }
.venue-sms-phone__icons svg rect { fill: currentColor; }
.venue-sms-phone__sender { display: flex; flex-direction: column; align-items: center; gap: 6px; padding: 14px 16px 10px; border-bottom: 1px solid rgba(42, 31, 74, 0.08); }
.venue-sms-phone__avatar { width: 44px; height: 44px; border-radius: 50%; background: var(--purple-900, #2a1f4a); color: var(--gold-300, #e4d2ae); display: flex; align-items: center; justify-content: center; font-family: var(--font-display, "Cormorant Garamond", Georgia, serif); font-weight: 700; font-size: 1rem; letter-spacing: .02em; }
.venue-sms-phone__sender-name { font-size: .82rem; color: var(--purple-800, #3a2e5a); font-weight: 600; }
.venue-sms-phone__thread { flex: 1; padding: 18px 14px 22px; display: flex; flex-direction: column; align-items: flex-start; gap: 6px; min-height: 220px; }

.venue-sms-phone__typing { display: inline-flex; gap: 4px; background: #e6e1d6; border-radius: 18px; padding: 10px 14px; align-self: flex-start; }
.venue-sms-phone__typing[hidden] { display: none; }
.venue-sms-phone__typing span { width: 7px; height: 7px; border-radius: 50%; background: #6f6582; animation: smsTypingDot 1.2s infinite ease-in-out; }
.venue-sms-phone__typing span:nth-child(2) { animation-delay: .15s; }
.venue-sms-phone__typing span:nth-child(3) { animation-delay: .3s; }
@keyframes smsTypingDot {
  0%, 60%, 100% { opacity: .35; transform: translateY(0); }
  30% { opacity: 1; transform: translateY(-3px); }
}

.venue-sms-bubble { display: block; max-width: 92%; background: #e6e1d6; color: var(--purple-900, #2a1f4a); border-radius: 18px 18px 18px 4px; padding: 12px 14px; text-decoration: none; font-size: .9rem; line-height: 1.42; transition: background .15s ease, transform .15s ease; opacity: 0; transform: translateY(8px) scale(.96); }
.venue-sms-bubble.is-in { opacity: 1; transform: translateY(0) scale(1); animation: smsPop .35s cubic-bezier(.34,1.56,.64,1) both; }
.venue-sms-bubble:hover, .venue-sms-bubble:focus-visible { background: #d9d3c5; outline: none; }
.venue-sms-bubble:focus-visible { box-shadow: 0 0 0 2px var(--gold-500, #c9a665); }
.venue-sms-bubble__brand { display: block; font-size: .72rem; font-weight: 700; letter-spacing: .02em; color: var(--purple-700, #5a4a7a); margin-bottom: 4px; text-transform: none; }
.venue-sms-bubble__body { display: block; }
.venue-sms-bubble__link { display: block; margin-top: 6px; font-size: .82rem; color: #1f4e8c; word-break: break-all; }
.venue-sms-phone__stamp { font-size: .68rem; color: var(--purple-700, #5a4a7a); padding: 0 6px; margin-top: 2px; opacity: 0; transition: opacity .25s ease .1s; }
.venue-sms-phone__stamp.is-in { opacity: 1; }
@keyframes smsPop {
  0%   { opacity: 0; transform: translateY(10px) scale(.92); }
  80%  { opacity: 1; transform: translateY(-2px) scale(1.02); }
  100% { opacity: 1; transform: translateY(0) scale(1); }
}

.venue-sms-demo__aside { display: flex; flex-direction: column; gap: 14px; align-items: flex-start; }
@media (max-width: 720px) { .venue-sms-demo__aside { align-items: center; } }
.venue-sms-demo__caption { font-size: .98rem; line-height: 1.55; color: var(--purple-800, #3a2e5a); margin: 0; }
.venue-sms-demo__replay { background: transparent; border: 1px solid rgba(58, 46, 90, 0.20); color: var(--purple-900, #2a1f4a); border-radius: 999px; padding: 7px 16px; font-size: .85rem; font-family: inherit; cursor: pointer; display: inline-flex; align-items: center; gap: 6px; transition: border-color .15s ease, background .15s ease; }
.venue-sms-demo__replay:hover { border-color: var(--gold-500, #c9a665); background: var(--cream-50, #fdfbf6); }
.venue-sms-demo__replay:focus-visible { outline: none; box-shadow: 0 0 0 2px var(--gold-500, #c9a665); }
.venue-sms-demo__cta { margin-top: 4px; }

@media (prefers-reduced-motion: reduce) {
  .venue-sms-bubble, .venue-sms-bubble.is-in { animation: none !important; transform: none !important; opacity: 1 !important; }
  .venue-sms-phone__stamp { opacity: 1 !important; transition: none !important; }
  .venue-sms-phone__typing span { animation: none !important; opacity: .6 !important; }
}
