/* ==========================================================================
 * Single-venue page sections.
 *
 * Loaded only on `is_singular('dgd_venue')` (see functions.php). Composes the
 * cinema-poster vocabulary (frame brackets, mono eyebrow, hard-edge offset
 * CTAs, fuchsia / cyan / buttercup accent rotation) over five new sections
 * that sit between the hero and the newsletter cta:
 *   - .dgd-venue-quickbar         (chip row right under the hero)
 *   - .dgd-venue-events           (events at this venue, concierge grid)
 *   - .dgd-venue-gallery          (curator-picked photos, masonry grid)
 *   - .dgd-venue-hours            (7-day schedule with today highlighted)
 *   - .dgd-venue-map-section      (single-pin Leaflet map)
 *   - .dgd-venue-similar          (more like this — concierge grid)
 *   - .dgd-vsticky                (mobile sticky save/directions bar)
 *
 * Tokens come from theme.json so a style variation (or palette change) flows
 * through automatically; no hardcoded hex values.
 * ========================================================================== */

/* ----- Quickbar ----------------------------------------------------------- */

.dgd-venue-quickbar {
	background: var(--wp--preset--color--deep-plum, #1A1440);
	border-top: 1px solid var(--wp--preset--color--border, #3A2D6A);
	border-bottom: 1px solid var(--wp--preset--color--border, #3A2D6A);
	padding-block: clamp(0.75rem, 0.5rem + 1vw, 1.25rem);
}
.dgd-venue-quickbar__inner {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 0.75rem;
	align-items: center;
}
.dgd-venue-quickbar__chip {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.5rem 0.85rem;
	border: 1px solid var(--wp--preset--color--border, #3A2D6A);
	border-radius: 999px;
	font-family: var(--wp--preset--font-family--mono, "JetBrains Mono", monospace);
	font-size: 0.78rem;
	letter-spacing: 0.04em;
	color: var(--wp--preset--color--soft-text, #C8BFDC);
	text-decoration: none;
	transition: border-color 160ms ease, color 160ms ease, background-color 160ms ease;
}
a.dgd-venue-quickbar__chip:hover,
a.dgd-venue-quickbar__chip:focus-visible {
	color: var(--wp--preset--color--ink, #F4EEE0);
	border-color: var(--wp--preset--color--neon-cyan, #00C8E6);
	background: rgba(0, 200, 230, 0.08);
}
.dgd-venue-quickbar__chip--status {
	border-color: transparent;
	background: transparent;
	padding: 0;
}
.dgd-venue-quickbar__chip--status .dgd-badge {
	font-size: 0.78rem;
}
.dgd-venue-quickbar__socials {
	display: inline-flex;
	gap: 0.25rem;
	align-items: center;
}
.dgd-venue-quickbar__social {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border: 1px solid var(--wp--preset--color--border, #3A2D6A);
	border-radius: 50%;
	color: var(--wp--preset--color--soft-text, #C8BFDC);
	transition: color 160ms ease, border-color 160ms ease, transform 160ms ease;
}
.dgd-venue-quickbar__social:hover,
.dgd-venue-quickbar__social:focus-visible {
	color: var(--wp--preset--color--ink, #F4EEE0);
	border-color: var(--wp--preset--color--neon-fuchsia, #FF3889);
	transform: translateY(-1px);
}
.dgd-venue-quickbar__cta {
	margin-inline-start: auto;
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.55rem 1rem;
	background: var(--wp--preset--color--neon-fuchsia, #FF3889);
	color: var(--wp--preset--color--ivory, #0C0820);
	font-family: var(--wp--preset--font-family--mono, "JetBrains Mono", monospace);
	font-size: 0.8rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	text-decoration: none;
	border: 0;
	border-radius: 0;
	box-shadow: 4px 4px 0 var(--wp--preset--color--ink, #F4EEE0);
	transition: transform 120ms ease, box-shadow 120ms ease;
}
.dgd-venue-quickbar__cta:hover,
.dgd-venue-quickbar__cta:focus-visible {
	transform: translate(2px, 2px);
	box-shadow: 2px 2px 0 var(--wp--preset--color--ink, #F4EEE0);
}
@media (max-width: 600px) {
	.dgd-venue-quickbar__cta {
		margin-inline-start: 0;
		flex-basis: 100%;
		justify-content: center;
		margin-top: 0.25rem;
	}
}

/* ----- Section heads (shared across venue sections) ---------------------- */

.dgd-venue-events .dgd-sec-head,
.dgd-venue-similar .dgd-sec-head,
.dgd-venue-hours .dgd-sec-head,
.dgd-venue-gallery .dgd-sec-head,
.dgd-venue-map-section .dgd-sec-head {
	margin-bottom: clamp(1rem, 0.5rem + 1vw, 1.75rem);
}

/* ----- Events at venue ---------------------------------------------------- */

.dgd-venue-events {
	padding-block: clamp(2.5rem, 1.5rem + 3vw, 4.5rem);
}
.dgd-venue-events--empty {
	padding-block: clamp(1.5rem, 1rem + 1vw, 2.5rem);
}
.dgd-venue-events__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: clamp(1rem, 0.5rem + 1vw, 1.5rem);
}

/* "Add all to Trip" — mono ghost button styled like a section eyebrow link. */
.dgd-add-all-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.6rem 1rem;
	background: transparent;
	border: 1px dashed var(--wp--preset--color--border, #3A2D6A);
	color: var(--wp--preset--color--neon-fuchsia, #FF3889);
	font-family: var(--wp--preset--font-family--mono, "JetBrains Mono", monospace);
	font-size: 0.78rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	cursor: pointer;
	transition: border-color 160ms ease, color 160ms ease, background-color 160ms ease;
}
.dgd-add-all-btn:hover,
.dgd-add-all-btn:focus-visible {
	color: var(--wp--preset--color--ink, #F4EEE0);
	border-color: var(--wp--preset--color--neon-fuchsia, #FF3889);
	border-style: solid;
	background: rgba(255, 56, 137, 0.08);
}

/* ----- Gallery ------------------------------------------------------------ */

.dgd-venue-gallery {
	padding-block: clamp(2rem, 1rem + 2vw, 3.5rem);
	background: var(--wp--preset--color--night, #0F0B23);
}
.dgd-venue-gallery__grid {
	position: relative;
	column-count: 3;
	column-gap: 0.75rem;
	padding: 1.25rem;
}
.dgd-venue-gallery__grid > .cinema-frame {
	pointer-events: none;
}
.dgd-venue-gallery__item {
	display: block;
	break-inside: avoid;
	margin-bottom: 0.75rem;
	overflow: hidden;
	border-radius: 4px;
	border: 1px solid var(--wp--preset--color--border, #3A2D6A);
	transition: transform 200ms ease, border-color 200ms ease, box-shadow 200ms ease;
}
.dgd-venue-gallery__img {
	display: block;
	width: 100%;
	height: auto;
	object-fit: cover;
	transition: transform 400ms ease;
}
.dgd-venue-gallery__item:hover,
.dgd-venue-gallery__item:focus-visible {
	border-color: var(--wp--preset--color--neon-violet, #6B33FF);
	box-shadow: 0 0 0 2px rgba(107, 51, 255, 0.35);
}
.dgd-venue-gallery__item:hover .dgd-venue-gallery__img {
	transform: scale(1.03);
}
/* Migrated from non-canonical 900/540 to the site-wide 1024/480 tiers so
   the gallery follows the same breakpoint rhythm as the rest of the site. */
@media (max-width: 1024px) {
	.dgd-venue-gallery__grid { column-count: 2; }
}
@media (max-width: 480px) {
	.dgd-venue-gallery__grid { column-count: 1; }
}

/* ----- Hours table -------------------------------------------------------- */

.dgd-venue-hours {
	padding-block: clamp(2rem, 1rem + 2vw, 3.5rem);
}
.dgd-venue-hours__table {
	display: grid;
	gap: 0;
	max-width: 540px;
	margin-inline: auto;
	border: 1px solid var(--wp--preset--color--border, #3A2D6A);
	background: rgba(255, 255, 255, 0.02);
}
.dgd-venue-hours__row {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 1rem;
	align-items: baseline;
	padding: 0.75rem 1rem;
	border-bottom: 1px solid var(--wp--preset--color--border, #3A2D6A);
	font-family: var(--wp--preset--font-family--mono, "JetBrains Mono", monospace);
	font-size: 0.92rem;
	color: var(--wp--preset--color--soft-text, #C8BFDC);
}
.dgd-venue-hours__row:last-child {
	border-bottom: 0;
}
.dgd-venue-hours__row.is-today {
	color: var(--wp--preset--color--ink, #F4EEE0);
	background: rgba(255, 56, 137, 0.08);
	box-shadow: inset 4px 0 0 var(--wp--preset--color--neon-fuchsia, #FF3889);
}
.dgd-venue-hours__row.is-closed {
	color: var(--wp--preset--color--muted, #A89FC4);
	font-style: italic;
}
.dgd-venue-hours__row.is-unknown {
	color: var(--wp--preset--color--muted, #A89FC4);
	opacity: 0.7;
}
.dgd-venue-hours__day {
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	font-size: 0.84rem;
	display: flex;
	align-items: center;
	gap: 0.5rem;
}
.dgd-venue-hours__pill {
	display: inline-block;
	padding: 0.1rem 0.45rem;
	background: var(--wp--preset--color--neon-fuchsia, #FF3889);
	color: var(--wp--preset--color--ivory, #0C0820);
	font-size: 0.65rem;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	border-radius: 2px;
}
.dgd-venue-hours__time {
	margin: 0;
	font-variant-numeric: tabular-nums;
}
.dgd-venue-hours__note {
	display: block;
	margin-top: 0.15rem;
	font-style: italic;
	font-size: 0.78rem;
	color: var(--wp--preset--color--muted, #A89FC4);
}
.dgd-venue-hours__placeholder {
	color: var(--wp--preset--color--muted, #A89FC4);
}
.dgd-venue-hours__fallback {
	max-width: 540px;
	margin-inline: auto;
	font-family: var(--wp--preset--font-family--mono, "JetBrains Mono", monospace);
	font-size: 0.95rem;
	color: var(--wp--preset--color--soft-text, #C8BFDC);
	text-align: center;
}

/* ----- Map section -------------------------------------------------------- */

.dgd-venue-map-section {
	padding-block: clamp(2rem, 1rem + 2vw, 3.5rem);
}
.dgd-venue-map {
	position: relative;
	width: 100%;
	aspect-ratio: 16 / 9;
	background: var(--wp--preset--color--night, #0F0B23);
	border: 2px solid var(--wp--preset--color--neon-cyan, #00C8E6);
	box-shadow: 6px 6px 0 var(--wp--preset--color--ink, #F4EEE0);
	z-index: 0;
}
.dgd-venue-map .leaflet-control-attribution {
	font-family: var(--wp--preset--font-family--mono, "JetBrains Mono", monospace);
	font-size: 0.65rem;
	background: rgba(15, 11, 35, 0.8);
	color: var(--wp--preset--color--soft-text, #C8BFDC);
}
.dgd-venue-map-section__address {
	margin-top: 1rem;
	font-family: var(--wp--preset--font-family--mono, "JetBrains Mono", monospace);
	font-size: 0.85rem;
	color: var(--wp--preset--color--soft-text, #C8BFDC);
	text-align: center;
}
@media (max-width: 700px) {
	.dgd-venue-map {
		aspect-ratio: 4 / 3;
		box-shadow: 4px 4px 0 var(--wp--preset--color--ink, #F4EEE0);
	}
}

/* ----- Similar venues ----------------------------------------------------- */

.dgd-venue-similar {
	padding-block: clamp(2.5rem, 1.5rem + 3vw, 4.5rem);
	background: var(--wp--preset--color--night, #0F0B23);
}
.dgd-venue-similar__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: clamp(1rem, 0.5rem + 1vw, 1.5rem);
}

/* ----- Mobile sticky bar -------------------------------------------------- */

.dgd-vsticky {
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	display: none;
	gap: 0.5rem;
	padding: 0.6rem max(1rem, env(safe-area-inset-left)) calc(0.6rem + env(safe-area-inset-bottom)) max(1rem, env(safe-area-inset-right));
	background: rgba(15, 11, 35, 0.96);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	border-top: 1px solid var(--wp--preset--color--border, #3A2D6A);
	z-index: 9000;
	transform: translateY(100%);
	transition: transform 240ms ease;
}
.dgd-vsticky.is-stuck {
	transform: translateY(0);
}
.dgd-vsticky__btn {
	flex: 1 1 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.45rem;
	padding: 0.85rem 0.5rem;
	background: transparent;
	border: 1px solid var(--wp--preset--color--border, #3A2D6A);
	color: var(--wp--preset--color--ink, #F4EEE0);
	font-family: var(--wp--preset--font-family--mono, "JetBrains Mono", monospace);
	font-size: 0.85rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	text-decoration: none;
	cursor: pointer;
}
.dgd-vsticky__btn--save {
	background: var(--wp--preset--color--neon-fuchsia, #FF3889);
	color: var(--wp--preset--color--ivory, #0C0820);
	border-color: var(--wp--preset--color--neon-fuchsia, #FF3889);
}
.dgd-vsticky__btn--save.is-saved {
	background: var(--wp--preset--color--neon-mint, #3DF5C9);
	border-color: var(--wp--preset--color--neon-mint, #3DF5C9);
	color: var(--wp--preset--color--ivory, #0C0820);
}
.dgd-vsticky__btn--save.is-saved svg {
	fill: currentColor;
}
@media (max-width: 768px) {
	.dgd-vsticky {
		display: flex;
	}
}

/* ----- Reduced motion ----------------------------------------------------- */

@media (prefers-reduced-motion: reduce) {
	.dgd-venue-gallery__item,
	.dgd-venue-gallery__img,
	.dgd-venue-quickbar__chip,
	.dgd-venue-quickbar__cta,
	.dgd-venue-quickbar__social,
	.dgd-vsticky,
	.dgd-add-all-btn {
		transition: none !important;
	}
	.dgd-venue-gallery__item:hover .dgd-venue-gallery__img {
		transform: none;
	}
}
