/**
 * Vital Report magazine layout: header, search drawer, hero, post grid.
 */

/* -------------------------------------------------------------------------
   Header
   ------------------------------------------------------------------------- */
.vital-header {
	background-color: var(--wp--preset--color--vital-cream, #f9f9f5);
	border-bottom: 1px solid color-mix(in srgb, var(--wp--preset--color--vital-forest, #1a3c34) 12%, transparent);
}

.vital-header__row {
	align-items: center;
	gap: clamp(1rem, 3vw, 2.5rem);
	flex-wrap: wrap;
	justify-content: space-between;
}

.vital-header__nav-left,
.vital-header__nav-right {
	flex: 1 1 0;
	min-width: min(100%, 10rem);
}

.vital-header__nav-left .wp-block-navigation {
	justify-content: flex-start;
}

.vital-header__nav-right .wp-block-navigation {
	justify-content: flex-end;
}

.vital-header__brand {
	flex: 0 1 auto;
	text-align: center;
	order: 0;
}

@media (max-width: 781px) {
	.vital-header__brand {
		flex: 1 1 100%;
		order: -1;
	}

	.vital-header__nav-left,
	.vital-header__nav-right {
		flex: 1 1 calc(50% - 0.5rem);
	}
}

.vital-header__brand .wp-block-site-title a {
	color: var(--wp--preset--color--vital-forest, #1a3c34);
	font-weight: 700;
	letter-spacing: 0.04em;
	text-decoration: underline;
	text-underline-offset: 0.15em;
}

.vital-header__brand .wp-block-site-tagline {
	color: var(--wp--preset--color--vital-muted, #5c7a72);
	font-size: var(--wp--preset--font-size--small, 0.875rem);
	letter-spacing: 0.12em;
	margin-top: 0.25rem;
	text-transform: uppercase;
}

.vital-header__nav-left .wp-block-navigation-item__content,
.vital-header__nav-right .wp-block-navigation-item__content {
	color: var(--wp--preset--color--vital-forest, #1a3c34);
	font-weight: 700;
	text-decoration: underline;
	text-underline-offset: 0.15em;
}

.vital-header__actions {
	align-items: center;
	display: flex;
	flex: 0 0 auto;
	gap: 0.75rem;
	justify-content: flex-end;
}

/* -------------------------------------------------------------------------
   Search trigger (pill) + drawer
   ------------------------------------------------------------------------- */
.vital-search-shell {
	position: relative;
}

.vital-search-toggle--pill {
	align-items: center;
	background: #fff;
	border: 1px solid var(--wp--preset--color--vital-forest, #1a3c34);
	border-radius: 999px;
	color: var(--wp--preset--color--vital-muted, #5c7a72);
	cursor: pointer;
	display: inline-flex;
	font: inherit;
	font-size: var(--wp--preset--font-size--small, 0.875rem);
	gap: 0.5rem;
	max-width: min(100%, 16rem);
	padding: 0.35rem 0.75rem 0.35rem 0.35rem;
	text-align: left;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.vital-search-toggle--pill:hover,
.vital-search-toggle--pill:focus-visible {
	border-color: var(--wp--preset--color--vital-forest, #1a3c34);
	box-shadow: 0 0 0 2px color-mix(in srgb, var(--wp--preset--color--vital-forest, #1a3c34) 25%, transparent);
	outline: none;
}

.vital-search-toggle__icon {
	align-items: center;
	background: var(--wp--preset--color--vital-forest, #1a3c34);
	border-radius: 50%;
	color: #fff;
	display: inline-flex;
	flex-shrink: 0;
	height: 2rem;
	justify-content: center;
	width: 2rem;
}

.vital-search-toggle__icon svg {
	display: block;
	height: 1rem;
	width: 1rem;
}

.vital-search-toggle__label {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.vital-search-backdrop {
	background: color-mix(in srgb, var(--wp--preset--color--vital-forest, #1a3c34) 45%, transparent);
	inset: 0;
	opacity: 0;
	pointer-events: none;
	position: fixed;
	transition: opacity 0.25s ease;
	z-index: 99998;
}

.vital-search-backdrop.is-visible {
	opacity: 1;
	pointer-events: auto;
}

.vital-search-drawer {
	background: var(--wp--preset--color--vital-cream, #f9f9f5);
	bottom: 0;
	box-shadow: -8px 0 32px color-mix(in srgb, #000 12%, transparent);
	max-width: min(100vw, 28rem);
	overflow: auto;
	padding: clamp(1.5rem, 4vw, 2.5rem);
	position: fixed;
	right: 0;
	top: 0;
	transform: translateX(100%);
	transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	width: 100%;
	z-index: 99999;
}

.vital-search-drawer.is-open {
	transform: translateX(0);
}

.vital-search-drawer__header {
	align-items: flex-start;
	display: flex;
	gap: 1rem;
	justify-content: space-between;
	margin-bottom: 1.5rem;
}

.vital-search-drawer__title {
	color: var(--wp--preset--color--vital-forest, #1a3c34);
	font-size: var(--wp--preset--font-size--large, 1.25rem);
	font-weight: 700;
	margin: 0;
}

.vital-search-drawer__close {
	background: transparent;
	border: 1px solid color-mix(in srgb, var(--wp--preset--color--vital-forest, #1a3c34) 35%, transparent);
	border-radius: 999px;
	color: var(--wp--preset--color--vital-forest, #1a3c34);
	cursor: pointer;
	flex-shrink: 0;
	font: inherit;
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	padding: 0.4rem 0.85rem;
	text-transform: uppercase;
}

.vital-search-drawer__close:hover,
.vital-search-drawer__close:focus-visible {
	background: color-mix(in srgb, var(--wp--preset--color--vital-tan, #e6dfd1) 60%, transparent);
	outline: none;
}

/* Drawer search form (core markup aligned with wp-block-search) */
.vital-drawer-search {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.vital-drawer-search .vital-drawer-search__field {
	width: 100%;
}

.vital-drawer-search .vital-drawer-search__input {
	background: #fff;
	border: 1px solid var(--wp--preset--color--vital-forest, #1a3c34);
	border-radius: 0.35rem;
	box-sizing: border-box;
	color: var(--wp--preset--color--vital-forest, #1a3c34);
	font: inherit;
	font-size: 1rem;
	padding: 0.75rem 1rem;
	width: 100%;
}

.vital-drawer-search .vital-drawer-search__input:focus {
	box-shadow: 0 0 0 2px color-mix(in srgb, var(--wp--preset--color--vital-forest, #1a3c34) 25%, transparent);
	outline: none;
}

.vital-drawer-search .vital-drawer-search__submit {
	align-self: flex-start;
	background: var(--wp--preset--color--vital-tan, #e6dfd1);
	border: none;
	border-radius: 0.25rem;
	color: var(--wp--preset--color--vital-forest, #1a3c34);
	cursor: pointer;
	font: inherit;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	padding: 0.65rem 1.25rem;
	text-transform: uppercase;
}

.vital-drawer-search .vital-drawer-search__submit:hover,
.vital-drawer-search .vital-drawer-search__submit:focus-visible {
	filter: brightness(0.97);
	outline: none;
}

body.vital-search-open {
	overflow: hidden;
}

/* -------------------------------------------------------------------------
   Homepage: hero + grid
   ------------------------------------------------------------------------- */
.vital-home {
	background-color: var(--wp--preset--color--vital-cream, #f9f9f5);
}

.vital-hero {
	margin-bottom: clamp(2rem, 5vw, 4rem);
}

.vital-hero .vital-hero__media .wp-block-post-featured-image {
	margin: 0;
}

.vital-hero .vital-hero__media .wp-block-post-featured-image img {
	display: block;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.vital-hero .vital-hero__content .wp-block-post-date {
	color: var(--wp--preset--color--vital-muted, #5c7a72);
	font-size: var(--wp--preset--font-size--small, 0.875rem);
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.vital-hero .vital-hero__content .wp-block-post-title {
	color: var(--wp--preset--color--vital-forest, #1a3c34);
	font-weight: 700;
	line-height: 1.15;
	margin-top: 0.5rem;
}

.vital-hero .vital-hero__content .wp-block-post-title a {
	color: inherit;
	text-decoration: underline;
	text-underline-offset: 0.12em;
}

.vital-hero .vital-hero__content .wp-block-post-excerpt {
	color: color-mix(in srgb, var(--wp--preset--color--vital-forest, #1a3c34) 85%, #fff);
	margin-top: 1rem;
}

.vital-hero .vital-hero__content .wp-block-read-more {
	margin-top: 1.25rem;
}

.vital-hero .vital-hero__content .wp-block-read-more a,
.vital-card .wp-block-read-more a {
	background: var(--wp--preset--color--vital-tan, #e6dfd1);
	border-radius: 0.2rem;
	color: var(--wp--preset--color--vital-forest, #1a3c34);
	display: inline-block;
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	padding: 0.55rem 1rem;
	text-decoration: none;
	text-transform: uppercase;
}

.vital-hero .vital-hero__content .wp-block-read-more a:hover,
.vital-card .wp-block-read-more a:hover {
	filter: brightness(0.96);
}

.vital-post-grid .wp-block-post-template.is-layout-grid {
	gap: clamp(1.5rem, 3vw, 2.5rem);
}

@media (max-width: 960px) {
	.vital-post-grid .wp-block-post-template.is-layout-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
	}
}

@media (max-width: 600px) {
	.vital-post-grid .wp-block-post-template.is-layout-grid {
		grid-template-columns: 1fr !important;
	}
}

.vital-post-grid .vital-card .wp-block-post-featured-image {
	aspect-ratio: 1 / 1;
	margin: 0;
	overflow: hidden;
}

.vital-post-grid .vital-card .wp-block-post-featured-image img {
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.vital-post-grid .vital-card .wp-block-post-date {
	color: var(--wp--preset--color--vital-muted, #5c7a72);
	font-size: 0.75rem;
	letter-spacing: 0.05em;
	margin-top: 0.75rem;
	text-transform: uppercase;
}

.vital-post-grid .vital-card .wp-block-post-title {
	color: var(--wp--preset--color--vital-forest, #1a3c34);
	font-size: clamp(1rem, 2.2vw, 1.1rem);
	font-weight: 700;
	line-height: 1.25;
	margin-top: 0.35rem;
}

.vital-post-grid .vital-card .wp-block-post-title a {
	color: inherit;
	text-decoration: underline;
	text-underline-offset: 0.1em;
}

.vital-post-grid .vital-card .wp-block-post-excerpt {
	color: color-mix(in srgb, var(--wp--preset--color--vital-forest, #1a3c34) 78%, #fff);
	font-size: var(--wp--preset--font-size--small, 0.875rem);
	line-height: 1.45;
	margin-top: 0.5rem;
}

.vital-post-grid .vital-card .wp-block-read-more {
	margin-top: 0.85rem;
}

/* -------------------------------------------------------------------------
   Interior / About pages
   ------------------------------------------------------------------------- */
.vital-page--interior .wp-block-post-content,
.vital-page--about .wp-block-post-content {
	margin-left: auto;
	margin-right: auto;
	max-width: 42rem;
}

.vital-page__excerpt {
	color: var(--wp--preset--color--vital-muted, #5c7a72);
	font-size: var(--wp--preset--font-size--large, 1.25rem);
	line-height: 1.45;
	margin-top: 0.75rem;
}

.vital-page__excerpt--lead {
	margin-left: auto;
	margin-right: auto;
	max-width: 36rem;
}

.vital-page__excerpt .wp-block-post-excerpt__excerpt:empty {
	display: none;
}

.vital-page__rule {
	margin-bottom: var(--wp--preset--spacing--50, 2rem);
	margin-top: var(--wp--preset--spacing--40, 1.5rem);
	opacity: 0.45;
}

.vital-page--about .wp-block-post-featured-image img {
	display: block;
	max-height: min(70vh, 32rem);
	object-fit: cover;
	width: 100%;
}
