/*
 * SDWS — San Diego Watercolor Society
 * Global design system overrides applied on top of the compiled theme.css.
 */

/* === SDWS design tokens ================================================ */

:root {
	--color-primary:   #2a7a88; /* darkened from #3a9aaa — 4.96:1 with white, passes WCAG AA */
	--color-brand-700: #1a5a68; /* hover/dark variant of --color-primary */

	--transition-base: 0.15s ease;
	--border-thick:    2px solid var(--color-black);

	--font-size-ui:    0.9375rem; /* 15px — buttons, card body */
	--font-size-label: 0.8125rem; /* 13px — eyebrows, meta labels */

	--max-width-prose: 720px; /* readable line length for body text and intros */
}

/* Override Jill theme preset — its class-based vars have higher specificity than :root */
.theme--jill.scheme--preset {
	--color-brand-700: #1a5a68;
}

/* === Base ============================================================== */

*,
*::before,
*::after {
	border-radius: 0 !important; /* SDWS: no rounded corners anywhere */
}

body {
	font-family: var(--font-body);
	font-size: 18px;
	color: var(--color-black);
	background-color: var(--color-white);
}

/* === Typography ======================================================== */

h1,
h2,
h3,
h4,
h5,
h6 {
	font-family: var(--font-body);
	color: var(--color-black);
	line-height: 1.15;
}

h1,
h2 {
	font-weight: 300;
}

h3,
h4,
h5,
h6 {
	font-weight: 700;
}

/* Homepage hero — only place display font is used in body content */
.sdws-hero-title {
	font-family: var(--font-display);
	font-weight: 300;
}

p,
li,
td,
th,
label,
input,
select,
textarea {
	font-family: var(--font-body);
}

/* === Links ============================================================= */

/* Body/content links: underlined by default, turn teal on hover */
a {
	color: var(--color-black);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.15em;
	transition: color var(--transition-base);
}

a:hover,
a:focus-visible {
	color: var(--color-primary);
	text-decoration: underline;
}

a:focus-visible {
	outline: 2px solid var(--color-primary);
	outline-offset: 2px;
}

/* Nav, card titles, UI links — no underline, just color on hover */
.sdws-header__nav a,
.sdws-card__title a {
	text-decoration: none;
}

/* !important needed to override inline color styles in templates */
.sdws-header__nav a:hover,
.sdws-header__nav a:focus-visible,
.sdws-dropdown__menu a:hover,
.sdws-dropdown__menu a:focus-visible {
	color: var(--color-primary) !important;
	text-decoration: none;
}

.site-footer a:hover,
.site-footer a:focus-visible {
	color: var(--color-primary) !important; /* original teal — safe on black footer bg (5.69:1) */
	text-decoration: none;
}

.sdws-card__title a:hover,
.sdws-card__title a:focus-visible {
	color: var(--color-primary);
	text-decoration: none;
}

/* Buttons: never underline, only bg changes */
.sdws-btn,
.sdws-btn:hover,
.sdws-btn:focus-visible {
	text-decoration: none !important;
}

/* Teal sections: white links, underline on hover */
.sdws-section--teal a:not(.sdws-btn) {
	color: var(--color-white);
	text-decoration: none;
}

.sdws-section--teal a:not(.sdws-btn):hover,
.sdws-section--teal a:not(.sdws-btn):focus-visible {
	text-decoration: underline;
}

/* === Images ============================================================ */

img {
	display: block;
	max-width: 100%;
	height: auto;
}

.sdws-img-crop {
	width: 100%;
	object-fit: cover;
	object-position: center;
}

.sdws-img-4-3 {
	aspect-ratio: 4 / 3;
}
.sdws-img-3-2 {
	aspect-ratio: 3 / 2;
}
.sdws-img-16-9 {
	aspect-ratio: 16 / 9;
}
.sdws-img-square {
	aspect-ratio: 1 / 1;
}

/* === Sections ========================================================== */

.sdws-section {
	padding-top: var(--space-section);
	padding-bottom: var(--space-section);
}

.sdws-section--lg {
	padding-top: var(--space-section-lg);
	padding-bottom: var(--space-section-lg);
}

.sdws-section--teal {
	background-color: var(--color-primary);
	color: var(--color-white);
}

.sdws-section--teal h1,
.sdws-section--teal h2,
.sdws-section--teal h3,
.sdws-section--teal p {
	color: var(--color-white);
}

.sdws-section--sand {
	background-color: var(--color-sand);
}

.sdws-section--aqua {
	background-color: var(--color-aqua-light);
}

.sdws-section--off-white {
	background-color: var(--color-off-white);
}

.sdws-container {
	max-width: var(--max-width);
	margin-inline: auto;
	padding-inline: 2rem;
}

/* === Buttons =========================================================== */

.sdws-btn {
	display: inline-block;
	font-family: var(--font-body);
	font-size: var(--font-size-ui);
	font-weight: 500;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	text-decoration: none;
	padding: 0.875rem 2rem;
	border: var(--border-thick);
	cursor: pointer;
	transition:
		background-color var(--transition-base),
		color var(--transition-base);
	line-height: 1;
}

/* Filled black */
.sdws-btn--primary {
	background-color: var(--color-black);
	color: var(--color-white);
	border-color: var(--color-black);
}

.sdws-btn--primary:hover {
	background-color: #222;
	color: var(--color-white);
}

/* Outlined black */
.sdws-btn--outline {
	background-color: transparent;
	color: var(--color-black);
	border-color: var(--color-black);
}

.sdws-btn--outline:hover {
	background-color: var(--color-black);
	color: var(--color-white);
}

/* Filled teal */
.sdws-btn--teal {
	background-color: var(--color-primary);
	color: var(--color-white);
	border-color: var(--color-primary);
}

.sdws-btn--teal:hover {
	background-color: var(--color-brand-700);
	color: var(--color-white);
	border-color: var(--color-brand-700);
}

/* White filled (for use on teal/dark backgrounds) */
.sdws-btn--white {
	background-color: var(--color-white);
	color: var(--color-black);
	border-color: var(--color-white);
}

.sdws-btn--white:hover {
	background-color: transparent;
	color: var(--color-white);
}

/* White outline / ghost (secondary action on teal/dark backgrounds) */
.sdws-btn--white-outline {
	background-color: transparent;
	color: var(--color-white);
	border-color: var(--color-white);
}

.sdws-btn--white-outline:hover {
	background-color: var(--color-white);
	color: var(--color-black);
}

/* === Unified card ====================================================== */

.sdws-card {
	border: var(--border);
	background: var(--color-white);
	display: flex;
	flex-direction: column;
}

.sdws-card__image {
	width: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
	display: block;
}

.sdws-card__placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 200px;
	background: var(--color-sand);
}

.sdws-card__placeholder span {
	font-size: var(--font-size-xs);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	opacity: 0.4;
}

.sdws-card__body {
	padding: var(--space-lg);
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
}

.sdws-card__eyebrow {
	font-size: var(--font-size-xs);
	font-weight: 500;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--color-black);
	margin: 0;
}

.sdws-card__title {
	font-weight: 700;
	font-size: 1.5rem;
	color: var(--color-black);
	margin: 0;
}

.sdws-card__meta {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
}

.sdws-card__meta li {
	font-size: var(--font-size-sm);
	color: var(--color-black);
}

.sdws-card__excerpt {
	font-size: var(--font-size-ui);
	line-height: 1.65;
	color: var(--color-black);
}

.sdws-card__buttons {
	display: flex;
	gap: var(--space-sm);
	flex-wrap: wrap;
	margin-top: auto;
	padding-top: var(--space-sm);
	border-top: var(--border);
}

.sdws-card__btn {
	font-size: var(--font-size-sm);
	padding: 0.625rem 1.25rem;
}

/* Horizontal card variant (image left, body right) */

.sdws-card--horizontal {
	flex-direction: row;
}

.sdws-card__image-col {
	width: 220px;
	min-width: 220px;
	flex-shrink: 0;
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

.sdws-card__image-col .sdws-card__image {
	flex: 1 1 auto;
	min-height: 0;
	width: 100%;
	aspect-ratio: unset;
	object-fit: cover;
	object-position: center;
	contain-intrinsic-size: none;
}

.sdws-card__image-col .sdws-card__placeholder {
	flex: 1 1 auto;
	min-height: 160px;
}

@media (max-width: 600px) {
	.sdws-card--horizontal {
		flex-direction: column;
	}

	.sdws-card__image-col {
		width: 100%;
		min-width: unset;
		aspect-ratio: 4 / 3;
	}
}

/* Exhibition list — stacked with shared borders */

.sdws-exhibition-list {
	display: flex;
	flex-direction: column;
}

.sdws-exhibition-list > .sdws-card + .sdws-card {
	border-top: none;
}

/* Empty state notice */

.sdws-empty-notice {
	color: var(--color-black);
	opacity: 0.5;
}

/* === Gallery grid ====================================================== */

.sdws-gallery-section {
	padding-top: 2rem;
}

.sdws-gallery-section__header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 1.5rem;
}

.sdws-gallery-section__meta {
	display: flex;
	align-items: baseline;
	gap: 1rem;
}

.sdws-gallery-section__label {
	font-size: 0.8125rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	font-weight: 500;
	margin: 0;
}

.sdws-gallery-section__caption {
	font-size: 0.875rem;
	margin: 0;
}

.sdws-gallery-section__view-all {
	font-size: 0.8125rem;
	letter-spacing: 0.05em;
	text-decoration: underline;
	white-space: nowrap;
	color: inherit;
}

.sdws-gallery-grid {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 0;
}

.sdws-gallery-grid__item {
	aspect-ratio: 1 / 1;
	overflow: hidden;
	opacity: 0;
	transition: opacity 0.6s ease;
}

.sdws-gallery-grid__item.is-visible {
	opacity: 1;
}

.sdws-gallery-grid__item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.sdws-gallery-grid__item--placeholder {
	background: var(--color-block-1);
}

.sdws-gallery-grid__link {
	position: relative;
	display: block;
	width: 100%;
	height: 100%;
	cursor: zoom-in;
}

.sdws-gallery-grid__meta {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: 0.5rem 0.625rem;
	background: linear-gradient(to top, rgba(0, 0, 0, 0.72) 0%, transparent 100%);
	color: #fff;
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
	opacity: 0;
	transform: translateY(4px);
	transition: opacity 0.25s ease, transform 0.25s ease;
	pointer-events: none;
}

.sdws-gallery-grid__link:hover .sdws-gallery-grid__meta,
.sdws-gallery-grid__link:focus-visible .sdws-gallery-grid__meta {
	opacity: 1;
	transform: translateY(0);
}

.sdws-gallery-grid__meta-title {
	display: block;
	font-size: 0.75rem;
	font-weight: 600;
	line-height: 1.2;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.sdws-gallery-grid__meta-artist {
	display: block;
	font-size: 0.65rem;
	opacity: 0.85;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.sdws-gallery-grid__sold {
	position: absolute;
	top: 0.5rem;
	right: 0.5rem;
	background: var(--color-black);
	color: var(--color-white);
	font-size: 0.625rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	padding: 0.2rem 0.4rem;
	pointer-events: none;
}

.sdws-gallery-grid__link img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s ease;
}

.sdws-gallery-grid__link:hover img {
	transform: scale(1.04);
}

@media (max-width: 1024px) {
	.sdws-gallery-grid {
		grid-template-columns: repeat(4, 1fr);
	}
}

@media (max-width: 600px) {
	.sdws-gallery-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* === Gallery page ======================================================= */

.sdws-gallery-page__caption {
	font-size: 1.125rem;
	margin-top: 0.5rem;
	opacity: 0.85;
}

.sdws-gallery-page-section {
	padding: 0;
}

.sdws-gallery-page-grid {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	gap: 0;
}

.sdws-gallery-page-grid .sdws-gallery-grid__item {
	opacity: 1;
}

@media (max-width: 1280px) {
	.sdws-gallery-page-grid {
		grid-template-columns: repeat(6, 1fr);
	}
}

@media (max-width: 900px) {
	.sdws-gallery-page-grid {
		grid-template-columns: repeat(4, 1fr);
	}
}

@media (max-width: 480px) {
	.sdws-gallery-page-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

/* === Lightbox =========================================================== */

.sdws-lightbox {
	position: fixed;
	inset: 0;
	z-index: 9000;
	background: rgba(0, 0, 0, 0.92);
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.25s ease;
}

.sdws-lightbox.is-open {
	opacity: 1;
	pointer-events: all;
}

body.lightbox-is-open {
	overflow: hidden;
}

.sdws-lightbox__frame {
	max-width: 90vw;
	max-height: 90vh;
	display: flex;
	align-items: center;
	justify-content: center;
}

.sdws-lightbox__img {
	display: block;
	max-width: 90vw;
	max-height: 90vh;
	object-fit: contain;
}

.sdws-lightbox__close,
.sdws-lightbox__prev,
.sdws-lightbox__next {
	position: fixed;
	background: transparent;
	border: none;
	color: #fff;
	cursor: pointer;
	line-height: 1;
	padding: 0.5rem;
	z-index: 9001;
}

.sdws-lightbox__close {
	top: 1.25rem;
	right: 1.5rem;
	font-size: 1.5rem;
}

.sdws-lightbox__prev,
.sdws-lightbox__next {
	top: 50%;
	transform: translateY(-50%);
	font-size: 3rem;
	opacity: 0.7;
	transition: opacity 0.15s;
}

.sdws-lightbox__prev:hover,
.sdws-lightbox__next:hover {
	opacity: 1;
}

.sdws-lightbox__prev:disabled,
.sdws-lightbox__next:disabled {
	opacity: 0.15;
	cursor: default;
}

.sdws-lightbox__prev {
	left: 1rem;
}

.sdws-lightbox__next {
	right: 1rem;
}

/* === Format nav (workshops jump links) ================================= */

.sdws-format-nav {
	border-bottom: var(--border);
	background: var(--color-off-white);
}

.sdws-format-nav__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
}

.sdws-format-nav__list li a {
	display: block;
	padding: 0.875rem 1.5rem;
	font-size: var(--font-size-label);
	font-weight: 500;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	text-decoration: none;
	color: var(--color-black);
	border-right: var(--border);
	transition: color var(--transition-base);
}

.sdws-format-nav__list li:first-child a {
	padding-left: 0;
}

.sdws-format-nav__list li:last-child a {
	border-right: none;
}

.sdws-format-nav__list li a:hover,
.sdws-format-nav__list li a:focus-visible {
	color: var(--color-primary);
}

/* === Eyebrow label ===================================================== */

.sdws-eyebrow {
	font-size: var(--font-size-label);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	font-weight: 500;
	margin: 0 0 1.25rem;
}

.sdws-section--teal .sdws-eyebrow {
	opacity: 0.8;
}

/* === Homepage hero ===================================================== */

/* Homepage hero section — slightly less top padding per client request */
.sdws-section--home-hero {
	padding-top: 100px;
}

/* Larger clamp range than sdws-page-title — homepage h1 only */
.sdws-hero-title {
	font-size: clamp(2.5rem, 6vw, 4.5rem);
	line-height: 1.1;
	margin: 0 0 1.5rem;
}

.sdws-hero__sub {
	font-size: 1.125rem;
	max-width: var(--max-width-prose);
	margin: 0 0 2.5rem;
	line-height: 1.7;
}

.sdws-hero__actions {
	display: flex;
	gap: var(--space-md);
	flex-wrap: wrap;
}

.sdws-hero-image img {
	width: 100%;
	height: auto;
	display: block;
	object-fit: cover;
}

/* === I-show promo block ================================================ */

.sdws-ishow-title {
	font-size: clamp(2rem, 5vw, 3.5rem);
	line-height: 1.15;
	margin: 0 0 1rem;
}

.sdws-ishow-dates {
	font-size: 1.125rem;
	font-weight: 700;
	margin: 0 0 0.5rem;
}

.sdws-ishow-meta {
	font-size: var(--font-size-md);
	margin: 0 0 0.5rem;
}

.sdws-ishow-body {
	font-size: var(--font-size-ui);
	margin: 0 0 2rem;
}

/* Featured callout — optional image layout */

.sdws-ishow__layout {
	display: block;
}

.sdws-ishow--with-image {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: var(--space-2xl);
	align-items: stretch;
}

.sdws-ishow__img-col {
	width: 320px;
	display: flex;
	align-items: stretch;
}

.sdws-ishow__img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: top center;
	display: block;
}

@media (max-width: 768px) {
	.sdws-ishow--with-image {
		grid-template-columns: 1fr;
		gap: var(--space-xl);
	}

	.sdws-ishow__img-col {
		width: 100%;
		max-width: 240px;
	}
}

/* === Section header row (title + action links inline) ================= */

.sdws-section-header {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	flex-wrap: wrap;
	gap: var(--space-md);
	margin-bottom: 2.5rem;
	padding-bottom: 1.25rem;
	border-bottom: var(--border);
}

.sdws-section-header__title {
	font-size: 2.25rem;
	margin: 0;
}

.sdws-section-header__actions {
	display: flex;
	gap: var(--space-sm);
	flex-wrap: wrap;
}

/* === Empty state message =============================================== */

.sdws-empty-state {
	opacity: 0.5;
}

/* === Layout utility modifiers ========================================== */

/* Centered section header (search results page, etc.) */
.section__header--centered {
	text-align: center;
	margin-bottom: var(--space-xl);
}

/* Centered container variant (no-results, empty states) */
.container--centered {
	text-align: center;
}

/* Google Maps embed iframe — no default browser border */
.c-map-embed__map iframe {
	border: 0;
}

/* === 404 page ========================================================== */

.sdws-error-404 {
	text-align: center;
}

.sdws-error-404__search {
	margin-top: var(--space-lg);
}

.sdws-error-404__back {
	margin-top: var(--space-lg);
}

/* === Grid utilities ==================================================== */

.sdws-grid-3 {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-lg);
}

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

@media (max-width: 900px) {
	.sdws-grid-3 {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 600px) {
	.sdws-grid-3,
	.sdws-grid-2 {
		grid-template-columns: 1fr;
	}
}

/* === Page header utilities ============================================= */

.sdws-section--bordered-bottom {
	border-bottom: var(--border);
}

/* Responsive h1 used on inner-page headers */
.sdws-page-title {
	font-size: clamp(2.5rem, 5vw, 4rem);
	margin: 0 0 1rem;
}

/* Intro paragraph beneath a page title */
.sdws-page-intro {
	font-size: var(--font-size-lg);
	max-width: var(--max-width-prose);
	line-height: 1.7;
	margin: 0;
}

/* h2 that divides content sections with a bottom rule */
.sdws-section-heading {
	font-size: 2rem;
	margin: 0 0 2rem;
	padding-bottom: var(--space-md);
	border-bottom: var(--border);
}

.sdws-section-heading--no-rule {
	border-bottom: none;
	padding-bottom: 0;
	margin-bottom: var(--space-md);
}

/* === Button modifiers ================================================== */

.sdws-btn--lg {
	font-size: 1.125rem;
	padding: 1.125rem 2.75rem;
}

/* === Container width modifier ========================================== */

.sdws-container--narrow {
	max-width: 720px;
}

/* === Donate page ======================================================= */

.sdws-donate {
	padding-bottom: var(--space-section);
}

.sdws-donate .sdws-page-title {
	margin-bottom: var(--space-lg);
}

.sdws-donate__intro-wrap {
	max-width: 780px;
}

.sdws-donate__intro p {
	font-size: 1.125rem;
	line-height: 1.75;
	margin-bottom: 1.25rem;
}

.sdws-donate__scroll-note {
	font-size: 1rem;
	line-height: 1.65;
	max-width: 600px;
	margin: 1.5rem 0 0.25rem;
	font-style: italic;
	opacity: 0.75;
}

.sdws-donate__intro-wrap > .sdws-btn {
	margin-top: 1rem;
}

/* Full-bleed banner image between intro and awards */
.sdws-donate__banner {
	overflow: hidden;
}

.sdws-donate__banner-img {
	display: block;
	width: 100%;
	height: 420px;
	object-fit: cover;
	object-position: center;
}

/* Award sections — vertical stack, each full width */
.sdws-donate__sections {
	display: flex;
	flex-direction: column;
	gap: 0;
	margin-bottom: 2.5rem;
}

/* Sections 1, 2, 4 — centered layout with row of award boxes */
.sdws-donate__award-section {
	padding: 2.5rem 0;
	border-bottom: var(--border);
	text-align: center;
}

.sdws-donate__award-section .sdws-donate__section-title,
.sdws-donate__award-section .sdws-donate__section-note {
	text-align: center;
}

/* Section 3 — left-aligned card, leave as-is */
.sdws-donate__award-group {
	border: var(--border);
	border-left: 6px solid var(--color-primary);
	padding: 1.75rem 1.5rem;
	margin: 2.5rem 0;
}

/* Row of individual award boxes */
.sdws-donate__award-row {
	display: flex;
	justify-content: center;
	gap: 1.25rem;
	flex-wrap: wrap;
	margin-top: var(--space-lg);
}

/* Individual award box */
.sdws-donate__award-box {
	border: var(--border);
	border-top: 6px solid var(--color-primary);
	padding: 1.75rem 2rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	justify-content: center;
	gap: 0.4rem;
	flex: 1 1 200px;
	max-width: 300px;
}

.sdws-donate__award-box--wide {
	max-width: 420px;
}

.sdws-donate__award-amount {
	display: block;
	font-size: 2rem;
	font-weight: 700;
	color: var(--color-primary);
	line-height: 1;
}

.sdws-donate__award-name {
	display: block;
	font-size: 1.0625rem;
	font-weight: 600;
	line-height: 1.3;
}

.sdws-donate__award-meta {
	display: block;
	font-size: var(--font-size-sm);
	opacity: 0.6;
	margin-top: 0.125rem;
}

/* Section titles and notes */
.sdws-donate__section-title {
	font-size: 1.0625rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	margin-bottom: var(--space-xs);
	color: var(--color-black);
}

.sdws-donate__section-note {
	font-size: var(--font-size-ui);
	opacity: 0.6;
	margin-bottom: 0;
}

.sdws-donate__section-body {
	font-size: var(--font-size-md);
	line-height: 1.65;
}

/* Deadline bar */
.sdws-donate__deadline {
	border-left: 4px solid var(--color-primary);
	padding: var(--space-md) 1.5rem;
	margin-bottom: 0;
	font-size: 1.0625rem;
	line-height: 1.6;
	background: var(--color-off-white);
}

/* Tax note */
.sdws-donate__tax-section {
	padding-top: 0;
}

.sdws-donate-tax-note {
	padding-top: var(--space-xl);
	font-size: var(--font-size-ui);
	opacity: 0.6;
	line-height: 1.6;
}

@media (max-width: 768px) {
	.sdws-donate__award-box {
		flex: 1 1 160px;
	}

	.sdws-donate__banner-img {
		height: 260px;
	}
}

/* === CTA band ========================================================== */

.sdws-cta {
  text-align: center;
}

.sdws-cta__body {
  max-width: var(--max-width-prose);
  margin-inline: auto;
}

.sdws-cta__title {
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  margin: 0 0 1rem;
}

.sdws-cta__copy {
  font-size: 1.0625rem;
  line-height: 1.7;
}

.sdws-cta__copy p {
  margin: 0 0 0.5rem;
}

.sdws-cta__copy p:last-child {
  margin-bottom: 0;
}

.sdws-cta__copy a {
  font-weight: 500;
}

.sdws-cta__actions {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 1.5rem;
}

.sdws-cta .sdws-eyebrow {
  margin-bottom: 0.75rem;
}

/* === Pagination ======================================================== */

.pagination {
	margin-top: var(--space-3xl);
	padding-top: var(--space-xl);
	border-top: var(--border);
}

.pagination__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.375rem;
	list-style: none;
	padding: 0;
	margin: 0;
}

.pagination__list a.page-numbers,
.pagination__list span.page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.75rem;
	height: 2.75rem;
	padding: 0 0.5rem;
	border: var(--border);
	font-size: var(--font-size-sm);
	font-family: var(--font-body);
	font-weight: 500;
	letter-spacing: 0.04em;
	text-decoration: none;
	color: var(--color-black);
	background: var(--color-white);
	transition:
		background var(--transition-base),
		color var(--transition-base);
}

.pagination__list a.page-numbers:hover {
	background: var(--color-black);
	color: var(--color-white);
}

.pagination__list span.page-numbers.current {
	background: var(--color-black);
	color: var(--color-white);
}

.pagination__list .page-numbers.dots {
	border: none;
	background: transparent;
	min-width: 1.5rem;
	letter-spacing: 0;
}

.pagination__list a.page-numbers.prev,
.pagination__list a.page-numbers.next {
	min-width: auto;
	padding: 0 1rem;
	font-size: var(--font-size-label);
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

/* === Back to top ======================================================= */

.back-to-top {
	position: fixed;
	bottom: 2rem;
	right: 2rem;
	z-index: 900;
	width: 2.75rem;
	height: 2.75rem;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #000;
	color: #fff;
	border: none;
	cursor: pointer;
	-webkit-appearance: none;
	appearance: none;
	transition: background-color var(--transition-base);
}

.back-to-top svg {
	display: block;
	stroke: #fff;
}

.back-to-top:hover {
	background: #333;
}

.back-to-top[hidden] {
	display: none;
}

/* === Navigation overrides ============================================== */

/* Sticky shell that wraps the banner + header */
.site-header-shell {
	position: sticky;
	top: 0;
	z-index: 100;
}

.site-header {
	border-bottom: var(--border);
	background-color: var(--color-white);
	/* sticky / z-index handled by .site-header-shell */
}

/* Header inner flex row */
.sdws-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 70px;
	gap: var(--space-lg);
}

/* Logo link */
.sdws-header__logo-link {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	text-decoration: none;
}

/* Logo image (max-width set inline via PHP; the rest is here) */
.sdws-header__logo-img {
	height: auto;
	max-height: 50px;
	display: block;
}

/* Fallback raw <img> logo */
.sdws-header__logo-img-fallback {
	max-height: 50px;
	width: auto;
	display: block;
}

/* Site name text (when logo_mode === 'site_name') */
.sdws-header__site-name {
	font-size: var(--font-size-lg);
	font-weight: 700;
	color: var(--color-black);
	line-height: 1.2;
}

/* Divider + text title beside logo image */
.sdws-header__site-title {
	font-family: var(--font-display);
	font-size: 1.125rem;
	font-weight: 400;
	letter-spacing: 0.06em;
	color: var(--color-black);
	line-height: 1.2;
	margin-left: 0.875rem;
	padding-left: 0.875rem;
	white-space: nowrap;
}

/* Desktop nav wrapper */
.sdws-header__nav {
	display: flex;
	align-items: center;
	gap: 0;
}

/* Desktop nav UL */
.sdws-header__nav-list {
	display: flex;
	align-items: center;
	gap: 0.125rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

/* Nav CTA button */
.sdws-header__cta {
	flex-shrink: 0;
	padding: var(--space-xs) 1.25rem;
	font-size: var(--font-size-sm);
	font-weight: 600;
	text-decoration: none;
	color: var(--color-white);
	background: var(--color-black);
	border: var(--border-thick);
	white-space: nowrap;
}

.sdws-header__cta:hover {
	background: #222;
	color: var(--color-white);
}

/* Hamburger toggle */
.sdws-menu-toggle {
	display: none;
	flex-direction: column;
	gap: 5px;
	background: none;
	border: none;
	cursor: pointer;
	padding: var(--space-xs);
}

.sdws-menu-toggle__bar {
	display: block;
	width: 24px;
	height: 2px;
	background: var(--color-black);
}

/* === Top banner ========================================================= */

.sdws-top-banner {
	text-align: center;
	padding: var(--space-xs) 1rem;
	font-size: var(--font-size-sm);
	font-weight: 500;
}

.sdws-top-banner--dark {
	background: var(--color-black);
	color: var(--color-white);
}

.sdws-top-banner--light {
	background: var(--color-off-white, var(--color-off-white));
	color: var(--color-black);
	border-bottom: var(--border);
}

.sdws-top-banner--brand {
	background: var(--color-primary, var(--color-primary));
	color: var(--color-white);
}

.sdws-top-banner__link {
	color: inherit;
	text-decoration: underline;
}

/* === Mobile menu overlay ================================================ */

.sdws-mobile-menu {
	display: none;
	position: fixed;
	inset: 0;
	background: var(--color-white);
	z-index: 500;
	overflow-y: auto;
	padding: var(--space-xl);
}

.sdws-mobile-menu__header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: var(--space-2xl);
	border-bottom: var(--border);
	padding-bottom: var(--space-lg);
}

.sdws-mobile-menu__title {
	font-size: var(--font-size-lg);
	font-weight: 700;
}

.sdws-menu-close {
	background: none;
	border: none;
	cursor: pointer;
	font-size: 1.5rem;
	line-height: 1;
	padding: var(--space-2xs);
	color: #000;
	-webkit-appearance: none;
	appearance: none;
}

/* Mobile nav UL */
.sdws-mobile-nav-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0;
}

/* === Responsive nav visibility ========================================= */

@media (min-width: 769px) {
	.sdws-menu-toggle {
		display: none !important;
	}

	.sdws-header__nav {
		display: flex !important;
	}
}

@media (max-width: 768px) {
	.sdws-header__nav {
		display: none !important;
	}

	.sdws-menu-toggle {
		display: flex !important;
	}

	.sdws-header__site-title {
		display: none;
	}
}

/* === Dropdown =========================================================== */

/* Reveal on hover / keyboard focus */
.sdws-dropdown:hover .sdws-dropdown__menu,
.sdws-dropdown:focus-within .sdws-dropdown__menu {
	display: block !important;
}

/* Remove border from last dropdown item */
.sdws-dropdown__menu li:last-child a {
	border-bottom: none;
}

/* Dropdown parent <li> */
.sdws-dropdown {
	position: relative;
}

/* Dropdown submenu */
.sdws-dropdown__menu {
	display: none;
	position: absolute;
	top: 100%;
	left: 0;
	background: var(--color-white);
	border: var(--border);
	min-width: 220px;
	list-style: none;
	margin: 0;
	padding: 0;
	z-index: 200;
}

/* Top-level nav link */
.sdws-nav__link {
	padding: var(--space-xs) 0.875rem;
	font-size: var(--font-size-md);
	font-weight: 400;
	letter-spacing: 0.02em;
	color: var(--color-black);
	text-decoration: none;
	display: block;
}

/* Dropdown toggle <button> */
.sdws-dropdown__toggle {
	padding: var(--space-xs) 0.875rem;
	font-size: var(--font-size-md);
	font-weight: 400;
	letter-spacing: 0.02em;
	color: var(--color-black);
	background: none;
	border: none;
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: 0.375rem;
	font-family: var(--font-body);
}

/* Current-page indicator on nav link or toggle */
.sdws-nav__link--current,
.sdws-dropdown__toggle--current {
	border-bottom: 2px solid var(--color-primary);
}

/* Dropdown child link */
.sdws-nav__link--child {
	padding: var(--space-sm) 1rem;
	font-size: var(--font-size-md);
	color: var(--color-black);
	text-decoration: none;
	display: block;
	border-bottom: var(--border);
}

/* Active nav link via aria-current */
.sdws-header__nav a[aria-current="page"] {
	border-bottom: 2px solid var(--color-primary);
}

/* Custom-logo sizing */
.sdws-header__logo-link .custom-logo {
	max-height: 50px;
	width: auto;
	display: block;
}

/* === Mobile nav walker ================================================== */

.sdws-mobile-nav__item {
	border-bottom: var(--border);
}

.sdws-mobile-nav__sub-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

/* Parent label (non-clickable group heading) */
.sdws-mobile-nav__label {
	display: block;
	padding: 0.6rem 0;
	font-size: var(--font-size-xs);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--color-black);
	opacity: 0.45;
}

/* Top-level link */
.sdws-mobile-nav__link {
	display: block;
	padding: var(--space-md) 0;
	font-size: 1.5rem;
	font-weight: 600;
	color: var(--color-black);
	text-decoration: none;
}

/* Child (depth > 0) link */
.sdws-mobile-nav__link--child {
	padding: var(--space-sm) 1.25rem;
	font-size: var(--font-size-lg);
}

/* === Footer ============================================================ */

.site-footer {
	background-color: var(--color-black);
	color: var(--color-white);
	padding: var(--space-3xl) 0 2rem;
}

.site-footer a {
	color: var(--color-white);
}

.site-footer a:hover {
	text-decoration: underline;
}

.sdws-footer__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-2xl);
	margin-bottom: var(--space-2xl);
	border-bottom: 1px solid #333;
	padding-bottom: var(--space-2xl);
}

.sdws-footer__col-heading {
	font-family: var(--font-body);
	font-size: var(--font-size-xs);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	font-weight: 500;
	color: var(--color-white);
	margin: 0 0 1.25rem;
	opacity: 0.6;
}

.sdws-footer__address {
	font-size: var(--font-size-ui);
	line-height: 1.7;
	color: var(--color-white);
	margin: 0 0 0.75rem;
}

.sdws-footer__directions-link {
	font-size: var(--font-size-sm);
	font-weight: 500;
	text-decoration: none;
	border-bottom: 1px solid var(--color-white);
}

.sdws-footer__links {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0.625rem;
}

.sdws-footer__link {
	font-size: var(--font-size-ui);
	text-decoration: none;
	opacity: 0.85;
}

.sdws-footer__contact-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
}

.sdws-footer__contact-label {
	font-size: 0.8rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	opacity: 0.6;
	display: block;
	margin-bottom: 0.2rem;
}

.sdws-footer__membership-note {
	margin-top: var(--space-md);
	font-size: 0.85rem;
	opacity: 0.8;
}

.sdws-footer__social {
	display: flex;
	align-items: center;
	gap: var(--space-lg);
	padding-bottom: var(--space-xl);
}

.sdws-footer__social-label {
	font-size: var(--font-size-xs);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	opacity: 0.6;
	white-space: nowrap;
}

.sdws-footer__social-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-2xs) 1.25rem;
}

.sdws-footer__social-link {
	font-size: var(--font-size-ui);
	text-decoration: none;
	opacity: 0.85;
}

.sdws-footer__social-link:hover {
	opacity: 1;
	text-decoration: underline;
}

.sdws-footer__bottom {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-md);
	padding-top: var(--space-xl);
	border-top: 1px solid #333;
}

.sdws-footer__legal {
	display: flex;
	flex-direction: column;
	gap: var(--space-2xs);
}

.sdws-footer__financial-note {
	font-size: var(--font-size-label);
	opacity: 0.5;
	margin: 0;
	line-height: 1.5;
}

.sdws-footer__copyright {
	font-size: var(--font-size-label);
	opacity: 0.5;
	margin: 0;
}

.sdws-footer__util-links {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 1.25rem;
	align-items: center;
}

.sdws-footer__util-link {
	font-size: var(--font-size-label);
	opacity: 0.5;
	text-decoration: none;
}

.sdws-footer__util-link:hover {
	opacity: 0.8;
}

@media (max-width: 768px) {
	.sdws-footer__grid {
		grid-template-columns: 1fr;
	}
}

/* === Format section header (workshops / archive) ======================== */

/* Wrapper above the card grid: caps width, adds spacing + bottom rule */
.sdws-format-header {
	max-width: var(--max-width-prose);
	margin-bottom: 2.5rem;
	padding-bottom: var(--space-lg);
	border-bottom: var(--border);
}

/* Compact wrapper variant (no max-width cap, used in archive) */
.sdws-format-header--full {
	max-width: none;
}

/* h2 inside the format header — zero bottom margin when no description */
.sdws-format-header .sdws-section-heading {
	margin-bottom: 0;
	border-bottom: none;
	padding-bottom: 0;
}

/* When a description follows, restore spacing below the heading */
.sdws-format-header--has-description .sdws-section-heading {
	margin-bottom: var(--space-sm);
}

/* Description paragraph inside a format header */
.sdws-format-description {
	font-size: var(--font-size-md);
	line-height: 1.7;
	color: var(--color-black);
	max-width: var(--max-width-prose);
	margin: 0;
}

/* "Coming soon" placeholder inside an empty format section */
.sdws-workshops-empty {
	color: var(--color-black);
	opacity: 0.5;
}

/* === Calendar page ====================================================== */

/* Page header section — white bg + bottom border, tighter vertical padding */
.sdws-section--calendar-header {
	background: var(--color-white);
	border-bottom: var(--border);
	padding-top: var(--space-2xl);
	padding-bottom: 2.5rem;
}

/* Calendar embed section — white bg, no vertical padding */
.sdws-section--calendar-embed {
	background: var(--color-white);
	padding-top: 0;
	padding-bottom: 0;
}

/* Fallback container when TEC plugin is not active */
.sdws-calendar-fallback {
	padding-top: var(--space-2xl);
	padding-bottom: var(--space-2xl);
}

/* Fallback notice text */
.sdws-calendar-fallback__notice {
	color: var(--color-black);
	opacity: 0.5;
	font-size: var(--font-size-md);
}

/* Install link inside the fallback notice */
.sdws-calendar-fallback__link {
	color: var(--color-black);
	font-weight: 500;
}

/* === Tribe Events Calendar embed iframe ================================ */

iframe[data-tec-events-ece-iframe='true'] {
	width: 100%;
	height: calc(100vw + 100px);
	max-width: 100%;
	display: block;
	border: 0;
}

@media screen and (min-width: 600px) {
	iframe[data-tec-events-ece-iframe='true'] {
		height: 100vw;
	}
}

@media screen and (min-width: 853px) {
	iframe[data-tec-events-ece-iframe='true'] {
		height: 1065px;
	}
}

/* === Tribe Events Calendar overrides =================================== */

/* Strip rounded corners and apply theme fonts site-wide */
.tribe-events,
.tribe-events * {
	border-radius: 0 !important;
	font-family: var(--font-body) !important;
}

/* Navigation bar */
.tribe-events .tribe-events-c-nav__list {
	gap: 0;
}
.tribe-events .tribe-events-c-nav__prev,
.tribe-events .tribe-events-c-nav__next {
	color: var(--color-black);
	font-weight: 600;
	text-decoration: none;
}
.tribe-events .tribe-events-c-nav__prev:hover,
.tribe-events .tribe-events-c-nav__next:hover {
	text-decoration: underline;
}

/* View-switcher tabs */
.tribe-events .tribe-events-c-view-selector__button,
.tribe-events .tribe-events-c-view-selector__list-item-link {
	border: var(--border);
	color: var(--color-black);
	background: var(--color-white);
	font-size: var(--font-size-label);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	padding: 0.4rem 0.9rem;
}
.tribe-events .tribe-events-c-view-selector__list-item-link--is-active,
.tribe-events .tribe-events-c-view-selector__list-item-link:hover {
	background: var(--color-black);
	color: var(--color-white);
}

/* Month grid */
.tribe-events .tribe-events-calendar td,
.tribe-events .tribe-events-calendar th {
	border-color: var(--color-black);
}
.tribe-events .tribe-events-calendar__month-grid-cell--current .tribe-events-calendar__month-grid-cell-date-link {
	color: var(--color-primary);
	font-weight: 700;
}

/* Event dots / pills in month view */
.tribe-events .tribe-events-calendar__month-grid-cell-event .tribe-events-calendar__month-grid-cell-event-title a {
	color: var(--color-black);
	font-weight: 500;
}
.tribe-events .tribe-events-calendar__month-grid-cell-event-bar-inner {
	background: var(--color-primary);
}

/* List view event rows */
.tribe-events .tribe-events-calendar-list__event-row {
	border-top: var(--border);
}
.tribe-events .tribe-events-calendar-list__event-title a {
	color: var(--color-black);
	font-family: var(--font-body);
	font-size: var(--font-size-lg);
	font-weight: 700;
}
.tribe-events .tribe-events-calendar-list__event-title a:hover {
	color: var(--color-primary);
}
.tribe-events .tribe-events-calendar-list__event-datetime {
	color: var(--color-black);
	font-size: var(--font-size-sm);
	letter-spacing: 0.04em;
	text-transform: uppercase;
}
.tribe-events .tribe-events-calendar-list__event-cost {
	color: var(--color-accent);
	font-weight: 600;
}

/* Category badges */
.tribe-events .tribe-event-categories a {
	color: var(--color-primary);
	font-size: var(--font-size-xs);
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

/* Buttons */
.tribe-events .tribe-common-c-btn,
.tribe-events .tribe-common-c-btn-border {
	border-radius: 0 !important;
	border: var(--border);
	color: var(--color-black);
	background: transparent;
	font-family: var(--font-body) !important;
	font-size: var(--font-size-label);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	padding: var(--space-xs) 1.25rem;
}
.tribe-events .tribe-common-c-btn:hover,
.tribe-events .tribe-common-c-btn-border:hover {
	background: var(--color-black);
	color: var(--color-white);
}

/* ── Map Section ─────────────────────────────────────────── */
.sdws-map-section {
	border-top: var(--border);
	border-bottom: var(--border);
	background: var(--color-off-white);
	overflow: hidden;
}

.sdws-map-section__inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	min-height: 520px;
}

.sdws-map-section__info {
	padding-top: 4.5rem;
	padding-bottom: 4.5rem;
	padding-right: 3.5rem;
	padding-left: max(2rem, calc((100vw - var(--max-width)) / 2 + 2rem));
	display: flex;
	flex-direction: column;
	justify-content: center;
	border-right: var(--border);
}

.sdws-map-section__label {
	font-size: 0.6875rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	font-weight: 500;
	color: var(--color-black);
	margin: 0 0 2.75rem;
}

.sdws-map-section__org {
	font-family: var(--font-body);
	font-size: clamp(2rem, 2.75vw, 2.875rem);
	line-height: 1.08;
	color: var(--color-black);
	margin: 0 0 2.75rem;
	font-weight: 400;
}

.sdws-map-section__address {
	font-style: normal;
	font-size: var(--font-size-md);
	line-height: 1.9;
	color: var(--color-black);
	margin: 0 0 2.25rem;
	opacity: 0.75;
}

.sdws-map-section__directions {
	display: inline-block;
	font-size: var(--font-size-xs);
	font-weight: 500;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--color-black);
	text-decoration: none;
	border-bottom: var(--border);
	padding-bottom: 3px;
	width: fit-content;
	transition: opacity var(--transition-base);
}

.sdws-map-section__directions:hover {
	opacity: 0.45;
}

.sdws-map-section__map {
	position: relative;
}

.sdws-map-section__map iframe {
	position: absolute;
	inset: 0;
	width: 100% !important;
	height: 100% !important;
	min-height: 400px;
	border: none !important;
	display: block;
	filter: grayscale(15%) contrast(1.05);
}

@media (max-width: 768px) {
	.sdws-map-section__inner {
		grid-template-columns: 1fr;
	}

	.sdws-map-section__info {
		border-right: none;
		border-bottom: var(--border);
		padding: var(--space-2xl) 1.5rem;
	}

	.sdws-map-section__map {
		min-height: 320px;
	}
}

/* Remove TEC's default blue accents */
.tribe-events .tribe-events-c-nav__list-item-link--is-active,
.tribe-events a {
	color: var(--color-black);
}
.tribe-events a:hover {
	color: var(--color-primary);
}

/* === Breadcrumb ========================================================== */

.sdws-breadcrumb__list {
	list-style: none;
	padding: 0;
	margin: 0 0 1.25rem;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	font-size: var(--font-size-xs);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	font-weight: 500;
	color: var(--color-black);
	opacity: 0.6;
}

.sdws-breadcrumb__item + .sdws-breadcrumb__item::before {
	content: '/';
	padding: 0 0.5rem;
}

.sdws-breadcrumb__item a {
	color: inherit;
	text-decoration: none;
}

.sdws-breadcrumb__item a:hover,
.sdws-breadcrumb__item a:focus-visible {
	color: var(--color-primary);
	text-decoration: none;
	opacity: 1;
}

/* On teal hero */
.sdws-section--teal .sdws-breadcrumb__list {
	color: var(--color-white);
	opacity: 0.75;
}

.sdws-section--teal .sdws-breadcrumb__item a:hover,
.sdws-section--teal .sdws-breadcrumb__item a:focus-visible {
	color: var(--color-white);
	opacity: 1;
}

/* === Exhibition single =================================================== */

.sdws-exhibition-eyebrow {
	font-size: var(--font-size-label);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	font-weight: 500;
	margin: 0 0 1rem;
	color: var(--color-white);
	opacity: 0.8;
}

.sdws-section--teal .sdws-page-title {
	color: var(--color-white);
	margin-bottom: var(--space-md);
}

.sdws-exhibition-dates {
	font-size: var(--font-size-lg);
	font-weight: 500;
	color: var(--color-white);
	margin: 0 0 0.5rem;
}

.sdws-exhibition-awards {
	font-size: var(--font-size-md);
	color: var(--color-white);
	margin: 0 0 2rem;
}

.sdws-exhibition-hero__actions {
	display: flex;
	gap: var(--space-md);
	flex-wrap: wrap;
	margin-bottom: var(--space-xl);
	margin-top: var(--space-xl);
}

.sdws-btn--white-outline {
	background-color: transparent;
	color: var(--color-white);
	border-color: rgba(255, 255, 255, 0.6);
}

.sdws-btn--white-outline:hover {
	background-color: rgba(255, 255, 255, 0.15);
	color: var(--color-white);
}

.sdws-exhibition-back-link {
	font-size: var(--font-size-sm);
	color: var(--color-white);
	opacity: 0.7;
	text-decoration: none;
	border-bottom: 1px solid rgba(255, 255, 255, 0.4);
	padding-bottom: 1px;
}

.sdws-exhibition-back-link:hover,
.sdws-exhibition-back-link:focus-visible {
	opacity: 1;
	color: var(--color-white);
	text-decoration: none;
}

.sdws-exhibition-content {
	font-size: 1.0625rem;
	line-height: 1.8;
	color: var(--color-black);
}

.sdws-exhibition-content--spaced {
	margin-top: var(--space-lg);
}

/* Key dates table */

.sdws-dates-table {
	width: 100%;
	border-collapse: collapse;
	font-size: var(--font-size-md);
}

.sdws-dates-table tr {
	border-top: var(--border);
}

.sdws-dates-table td {
	padding: 0.875rem 0;
	vertical-align: top;
	color: var(--color-black);
}

.sdws-dates-table__label {
	font-weight: 500;
	white-space: nowrap;
	padding-right: var(--space-lg);
	width: 14rem;
}

/* Juror */

.sdws-juror {
	display: grid;
	gap: 2.5rem;
	align-items: start;
}

.sdws-juror--with-image {
	grid-template-columns: 300px 1fr;
}

@media (max-width: 600px) {
	.sdws-juror--with-image {
		grid-template-columns: 1fr;
	}
}

.sdws-juror__image {
	width: 100%;
	display: block;
	object-fit: cover;
}

.sdws-juror__content {
	max-width: var(--max-width-prose);
}

.sdws-juror__name {
	font-size: var(--font-size-xl);
	margin: 0 0 0.25rem;
	color: var(--color-black);
}

.sdws-juror__role {
	font-size: var(--font-size-sm);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	font-weight: 500;
	margin: 0 0 1.25rem;
	color: var(--color-black);
}

.sdws-juror__bio {
	font-size: var(--font-size-md);
	line-height: 1.75;
	color: var(--color-black);
}

/* === Workshop single ===================================================== */

.sdws-workshop-instructor {
	font-size: var(--font-size-label);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	font-weight: 500;
	margin: 0 0 0.75rem;
	color: var(--color-black);
}

.sdws-workshop-meta {
	display: flex;
	gap: var(--space-sm);
	flex-wrap: wrap;
	align-items: stretch;
	margin-top: var(--space-lg);
}

.sdws-workshop-meta .sdws-btn {
	display: flex;
	align-items: center;
}

.sdws-workshop-meta__item {
	border: var(--border);
	padding: var(--space-xs) 1rem;
	font-size: var(--font-size-ui);
	font-weight: 600;
	color: var(--color-black);
	line-height: 1.3;
}

.sdws-workshop-meta__label {
	display: block;
	font-size: 0.625rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	font-weight: 400;
	opacity: 0.5;
	margin-bottom: 0.2rem;
}

/* === Content two-column layout =========================================== */

.sdws-content-2-col {
	display: grid;
	grid-template-columns: 1fr 1.25fr;
	gap: var(--space-3xl);
	align-items: start;
}

@media (max-width: 800px) {
	.sdws-content-2-col {
		grid-template-columns: 1fr;
		gap: var(--space-xl);
	}
}

.sdws-workshop-featured-img {
	width: 100%;
	height: auto;
	display: block;
}

.sdws-workshop-content {
	font-size: 1.0625rem;
	line-height: 1.8;
	color: var(--color-black);
}

.sdws-workshop-buttons {
	display: flex;
	gap: var(--space-sm);
	flex-wrap: wrap;
	margin-top: var(--space-xl);
}

.sdws-workshop-resources {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--space-md);
}

.sdws-resource-note {
	font-size: var(--font-size-md);
	color: var(--color-black);
	margin: 0;
	opacity: 0.7;
}

/* === The Events Calendar — single event override ========================== */

/* Layout helper: single-column when no featured image */
.sdws-content-2-col--no-image {
	grid-template-columns: 1fr;
}

/* TEC notices ("This event has passed", etc.) */
.sdws-tribe-notice {
	margin-top: 1.25rem;
}

.sdws-tribe-notice .tribe-events-notices {
	display: block;
	padding: 0;
	margin: 0;
}

.sdws-tribe-notice .tribe-events-notices ul {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-xs);
}

.sdws-tribe-notice .tribe-events-notices li {
	font-size: var(--font-size-label);
	letter-spacing: 0.05em;
	text-transform: uppercase;
	font-weight: 500;
	opacity: 0.55;
}

/* Add-to-calendar widget */
.sdws-tribe-cal-widget {
	margin-top: var(--space-xl);
}

.sdws-tribe-cal-widget .tribe-add-to-calendar {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-xs);
	align-items: center;
}

.sdws-tribe-cal-widget .tribe-add-to-calendar button,
.sdws-tribe-cal-widget .tribe-add-to-calendar a {
	font-family: var(--font-body);
	font-size: var(--font-size-label);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	border: var(--border);
	padding: var(--space-xs) 1rem;
	background: transparent;
	color: var(--color-black);
	cursor: pointer;
	text-decoration: none;
	transition:
		background 0.15s,
		color 0.15s,
		border-color 0.15s;
}

.sdws-tribe-cal-widget .tribe-add-to-calendar button:hover,
.sdws-tribe-cal-widget .tribe-add-to-calendar a:hover {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-white);
}

/* TEC meta details section (venue, organizer) */
.sdws-tribe-meta .tribe-events-single-section {
	padding: 0;
	border: none;
	background: transparent;
}

.sdws-tribe-meta .tribe-events-meta-group {
	margin-bottom: var(--space-xl);
}

.sdws-tribe-meta .tribe-events-single-section-header {
	font-family: var(--font-body);
	font-size: var(--font-size-xs);
	letter-spacing: 0.1em;
	text-transform: uppercase;
	font-weight: 600;
	color: var(--color-black);
	opacity: 0.5;
	margin: 0 0 0.75rem;
	padding: 0;
	border: none;
}

.sdws-tribe-meta .tribe-venue,
.sdws-tribe-meta .tribe-organizer {
	font-size: var(--font-size-ui);
	line-height: 1.7;
	color: var(--color-black);
}

.sdws-tribe-meta .tribe-events-abbr,
.sdws-tribe-meta .tribe-venue-location a,
.sdws-tribe-meta .tribe-organizer-url a,
.sdws-tribe-meta .tribe-organizer-email a {
	color: var(--color-primary);
	text-decoration: none;
}

.sdws-tribe-meta .tribe-venue-location a:hover,
.sdws-tribe-meta .tribe-organizer-url a:hover,
.sdws-tribe-meta .tribe-organizer-email a:hover {
	text-decoration: underline;
}

/* Prev / Next event navigation */
.sdws-tribe-nav {
	display: flex;
	justify-content: space-between;
	gap: var(--space-xl);
}

.sdws-tribe-nav__prev,
.sdws-tribe-nav__next {
	flex: 1;
}

.sdws-tribe-nav__next {
	text-align: right;
}

.sdws-tribe-nav a {
	display: inline-flex;
	flex-direction: column;
	gap: var(--space-2xs);
	border: var(--border);
	padding: var(--space-sm) 1.25rem;
	text-decoration: none;
	color: var(--color-black);
	transition:
		background 0.15s,
		color 0.15s,
		border-color 0.15s;
	max-width: 28rem;
}

.sdws-tribe-nav__next a {
	align-items: flex-end;
}

.sdws-tribe-nav a:hover {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-white);
}

.sdws-tribe-nav__label {
	font-family: var(--font-body);
	font-size: var(--font-size-xs);
	letter-spacing: 0.1em;
	text-transform: uppercase;
	font-weight: 600;
	opacity: 0.6;
}

.sdws-tribe-nav a:hover .sdws-tribe-nav__label {
	opacity: 0.85;
}

.sdws-tribe-nav__title {
	font-size: var(--font-size-ui);
	font-weight: 400;
	line-height: 1.4;
}

/* Suppress default TEC chrome within our custom content override only */
.sdws-tribe-single .tribe-events-back,
.sdws-tribe-single #tribe-events-header,
.sdws-tribe-single #tribe-events-footer,
.sdws-tribe-single .tribe-events-nav-pagination {
	display: none;
}

/* === TEC single event — Add to Calendar (production V2 selectors) ======= */

/* Make the dropdown container position:relative so the menu anchors to it */
.tribe-events-c-subscribe-dropdown {
	position: relative;
	display: inline-block;
}

/* The button — natural width, 1px border, teal hover */
.tribe-events .tribe-events-c-subscribe-dropdown__button {
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
	border: var(--border);
	background: transparent;
	padding: 0.625rem 1.25rem;
	cursor: pointer;
	transition:
		background 0.15s,
		border-color 0.15s,
		color 0.15s;
	width: auto;
}

.tribe-events .tribe-events-c-subscribe-dropdown__button:hover {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-white);
}

/* Strip inner button's own border/background */
.tribe-events .tribe-events-c-subscribe-dropdown__button-text {
	background: transparent;
	border: none;
	padding: 0;
	color: inherit;
	cursor: pointer;
	font-family: var(--font-body);
	font-size: var(--font-size-ui);
}

/* Icon turns white on hover (SVG with currentColor) */
.tribe-events .tribe-events-c-subscribe-dropdown__button:hover svg,
.tribe-events .tribe-events-c-subscribe-dropdown__button:hover .tribe-common-c-svgicon {
	color: var(--color-white);
	fill: currentColor;
	stroke: currentColor;
}

/* Dropdown list — styled like nav dropdown */
.tribe-events-c-subscribe-dropdown__content {
	position: absolute;
	top: 100%;
	left: 0;
	background: var(--color-white);
	border: var(--border);
	border-top: none;
	min-width: 200px;
	z-index: 200;
}

.tribe-events-c-subscribe-dropdown__list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.tribe-events-c-subscribe-dropdown__list-item-link {
	display: block;
	padding: var(--space-sm) 1rem;
	color: var(--color-black);
	text-decoration: none;
	font-size: var(--font-size-ui);
	border-bottom: var(--border);
	transition: color var(--transition-base);
}

.tribe-events-c-subscribe-dropdown__list-item:last-child .tribe-events-c-subscribe-dropdown__list-item-link {
	border-bottom: none;
}

.tribe-events-c-subscribe-dropdown__list-item-link:hover,
.tribe-events-c-subscribe-dropdown__list-item-link:focus-visible {
	color: var(--color-primary);
	text-decoration: none;
}

/* === TEC single event — Prev/Next nav (production V2 selectors) ========= */

body.single-tribe_events #tribe-events-footer {
	display: none;
}

body.single-tribe_events #tribe-events-header {
	border-bottom: var(--border);
}

.tribe-events-sub-nav {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	justify-content: space-between;
	gap: var(--space-xl);
	max-width: var(--max-width);
	margin-inline: auto;
	padding-inline: 2rem;
	padding-top: var(--space-2xl);
	padding-bottom: var(--space-2xl);
}

.tribe-events-nav-previous,
.tribe-events-nav-next {
	flex: 1;
}

.tribe-events-nav-next {
	text-align: right;
}

.tribe-events-nav-previous a,
.tribe-events-nav-next a {
	display: inline-flex;
	flex-direction: column;
	gap: var(--space-2xs);
	border: var(--border);
	padding: var(--space-sm) 1.25rem;
	text-decoration: none;
	color: var(--color-black);
	transition:
		background 0.15s,
		color 0.15s,
		border-color 0.15s;
	max-width: 28rem;
}

.tribe-events-nav-next a {
	align-items: flex-end;
}

.tribe-events-nav-previous a:hover,
.tribe-events-nav-next a:hover {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-white);
}

/* Hide the original «/» span arrows */
.tribe-events-nav-previous a span,
.tribe-events-nav-next a span {
	display: none;
}

/* Inject "← Previous Event" / "Next Event →" labels */
.tribe-events-nav-previous a::before {
	content: '← Previous Event';
	font-size: var(--font-size-xs);
	letter-spacing: 0.1em;
	text-transform: uppercase;
	font-weight: 600;
	opacity: 0.6;
}

.tribe-events-nav-next a::before {
	content: 'Next Event →';
	font-size: var(--font-size-xs);
	letter-spacing: 0.1em;
	text-transform: uppercase;
	font-weight: 600;
	opacity: 0.6;
}

.tribe-events-nav-previous a:hover::before,
.tribe-events-nav-next a:hover::before {
	opacity: 0.85;
}

/* === Plan Your Visit page ============================================== */

.sdws-visit__header-intro {
	font-size: 1.125rem;
	max-width: var(--max-width-prose);
	line-height: 1.7;
	margin: 1rem 0 0;
	color: var(--color-white);
}

/* --- Split: photo left / info right ----------------------------------- */

.sdws-visit__split {
	display: grid;
	grid-template-columns: 1fr 1fr;
	min-height: 560px;
}

.sdws-visit__photo-col {
	overflow: hidden;
	position: relative;
}

.sdws-visit__photo {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center top;
	display: block;
}

.sdws-visit__detail-col {
	background-color: var(--color-off-white);
	display: flex;
	align-items: center;
}

.sdws-visit__detail-inner {
	padding: 4rem 3.5rem;
	width: 100%;
}

/* Info cards — repeater-driven */
.sdws-visit__info-card {
	padding: 1.5rem 0;
	border-bottom: var(--border);
}

.sdws-visit__info-card:first-child {
	padding-top: 0;
}

.sdws-visit__info-card:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.sdws-visit__info-card-heading {
	font-size: var(--font-size-label);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	font-weight: 600;
	margin: 0 0 0.75rem;
}

.sdws-visit__info-card-body p {
	margin: 0 0 0.5rem;
	line-height: 1.75;
}

.sdws-visit__info-card-body p:last-child {
	margin-bottom: 0;
}

.sdws-visit__info-card-body a {
	color: var(--color-black);
	text-decoration: underline;
	text-underline-offset: 3px;
}

.sdws-visit__info-card-body a:hover {
	color: var(--color-primary);
}

.sdws-visit__info-card-body em {
	font-size: 0.875rem;
	opacity: 0.65;
}

/* Map wrapper — flush, no extra padding */
.sdws-visit__map-wrap {
	line-height: 0; /* remove inline-block gap */
}

.sdws-visit__map-wrap .c-map-embed {
	margin: 0;
}

.sdws-visit__map-wrap .c-map-embed__map {
	border-radius: 0;
	box-shadow: none;
	height: var(--sc-map-height, 440px);
}

/* --- Responsive -------------------------------------------------------- */

@media (max-width: 1023px) {
	.sdws-visit__split {
		grid-template-columns: 1fr;
	}

	.sdws-visit__photo-col {
		min-height: 360px;
		max-height: 480px;
	}

	.sdws-visit__detail-inner {
		padding: 3rem 2rem;
	}
}

@media (max-width: 599px) {
	.sdws-visit__photo-col {
		min-height: 280px;
	}

	.sdws-visit__detail-inner {
		padding: 2rem 1.25rem;
	}
}

/* === Motion preferences ================================================ */

@media (prefers-reduced-motion: reduce) {
	a,
	.sdws-btn,
	.back-to-top {
		transition: none;
	}
}
