/**
 * CFUL 2026 — Components
 *
 * Upcoming-events cards + list (Figma nodes 421:1679 card caption,
 * 421:1680 list row title, 421:1683 list row date). Data/markup in
 * inc/events.php + template-parts/home/upcoming-events.php +
 * template-parts/cards/event-card.php.
 */

/* -------------------------------------------------------------------- */
/* Section spacing helper                                                */
/* -------------------------------------------------------------------- */

.cful-upcoming {
	display: flex;
	flex-direction: column;
	gap: var(--space-8);
	/* The bleed carousel's gutter math uses 100vw (which includes the
	   scrollbar), so on screens wider than --container-max it can overshoot
	   the content area by ~half a scrollbar. Clip here — at the content-area
	   edge — to absorb that overshoot without a page-level scrollbar. `clip`
	   (not `hidden`) so no scroll container is created. */
	overflow-x: clip;
}

/* -------------------------------------------------------------------- */
/* Event card                                                           */
/* -------------------------------------------------------------------- */

.cful-event-card {
	border-radius: var(--radius-card);
	display: flex;
	flex-direction: column;
	overflow: hidden;
}

.cful-event-card__image-wrap {
	aspect-ratio: 4 / 3;
	overflow: hidden;
}

.cful-event-card__image {
	display: block;
	height: 100%;
	object-fit: cover;
	object-position: top center;
	width: 100%;
}

.cful-event-card__image--placeholder {
	background: var(--cful-white-alt);
}

.cful-event-card__caption {
	background: var(--card-accent, var(--color-primary));
	color: var(--cful-white);
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	min-height: 290px;
	padding: var(--space-5);
}

.cful-event-card__title {
	font-family: var(--font-sans);
	font-size: var(--text-2xl);
	font-weight: var(--fw-bold);
	line-height: var(--leading-tight);
	margin: 0;
}

.cful-event-card__title a {
	color: inherit;
}

.cful-event-card__title a:hover,
.cful-event-card__title a:focus-visible {
	text-decoration: underline;
}

.cful-event-card__date {
	font-family: var(--font-sans);
	font-size: var(--text-xl);
	font-weight: var(--fw-regular);
	margin: 0;
	margin-top: auto;
}

.cful-event-card__dept {
	font-family: var(--font-sans);
	font-size: var(--text-xl);
	margin: 0;
}

.cful-event-card__dept-label {
	font-weight: var(--fw-semibold);
}

.cful-event-card__dept-sub {
	font-weight: var(--fw-regular);
}

.cful-event-card__dept-label + .cful-event-card__dept-sub::before {
	content: " ";
}

/* -------------------------------------------------------------------- */
/* Events list                                                          */
/* -------------------------------------------------------------------- */

.cful-events-list {
	display: flex;
	flex-direction: column;
	gap: var(--space-6);
	margin-block: var(--space-9) var(--space-7);
}

.cful-events-list__row {
	align-items: baseline;
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	justify-content: space-between;
}

.cful-events-list__main {
	align-items: baseline;
	width: 100%;
	padding-bottom: var(--space-3);
	border-bottom: var(--border-hairline);
}

.cful-events-list__title {
	font-family: var(--font-sans);
	font-size: var(--text-2xl);
	font-weight: var(--fw-bold);
	line-height: var(--leading-tight);
	margin: 0;
}

.cful-events-list__title a {
	color: inherit;
}

.cful-events-list__title a:hover,
.cful-events-list__title a:focus-visible {
	text-decoration: underline;
}

.cful-events-list__dept {
	font-family: var(--font-sans);
	font-size: var(--text-xl);
	margin: 0;
}

.cful-events-list__dept-label {
	font-weight: var(--fw-semibold);
}

.cful-events-list__dept-sub {
	font-weight: var(--fw-regular);
}

.cful-events-list__dept-label + .cful-events-list__dept-sub::before {
	content: " ";
}

.cful-events-list__date {
	font-family: var(--font-sans);
	font-size: var(--text-xl);
	font-weight: var(--fw-semibold);
	text-transform: uppercase;
	margin: 0;
}

/* -------------------------------------------------------------------- */
/* Department color utilities                                          */
/* -------------------------------------------------------------------- */

.dept-praxis {
	--card-accent: var(--dept-praxis);
}
.dept-lancog {
	--card-accent: var(--dept-lancog);
}
.dept-hphil {
	--card-accent: var(--dept-hphil);
}

/* -------------------------------------------------------------------- */
/* Generic templates — page header                                     */
/* -------------------------------------------------------------------- */

.cful-page-header {
	margin-bottom: var(--space-7);
}

.cful-page-header .cful-section-label {
	margin-bottom: var(--space-2);
}

.cful-page-header__title {
	font-family: var(--font-serif);
	font-size: var(--text-xl);
	font-weight: var(--fw-semibold);
	line-height: var(--leading-tight);
	margin: 0;
}

.cful-page-header__description {
	color: var(--color-text);
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	line-height: var(--leading-normal);
	margin-top: var(--space-3);
}

/* -------------------------------------------------------------------- */
/* Generic templates — entry (loop item / single)                      */
/* -------------------------------------------------------------------- */

.cful-entry {
	margin-bottom: var(--space-8);
	padding-bottom: var(--space-7);
}

.cful-entry:not(:last-child) {
	border-bottom: var(--border-hairline);
}

.cful-entry__header {
	margin-bottom: var(--space-4);
}

.cful-entry__title {
	font-family: var(--font-serif);
	font-size: var(--text-3xl);
	font-weight: var(--fw-semibold);
	line-height: var(--leading-tight);
	margin: 0 0 var(--space-2);
}

.cful-entry__title a {
	color: inherit;
}

.cful-entry__title a:hover,
.cful-entry__title a:focus-visible {
	text-decoration: underline;
}

.cful-entry__meta {
	color: var(--color-section-label);
	display: flex;
	flex-wrap: wrap;
	font-family: var(--font-sans);
	font-size: var(--text-xs);
	gap: var(--space-3);
	margin: 0;
}

.cful-entry__meta--type {
	font-weight: var(--fw-semibold);
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.cful-entry__permalink {
	font-size: var(--text-xs);
	margin: var(--space-1) 0 0;
	word-break: break-all;
}

.cful-entry__permalink a {
	color: var(--color-section-label);
}

.cful-entry__thumbnail {
	margin: var(--space-4) 0;
}

.cful-entry__thumbnail img {
	width: 100%;
}

.cful-entry__content {
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	line-height: var(--leading-normal);
}

.cful-entry__content > * + * {
	margin-top: var(--space-4);
}

.cful-entry__more a {
	font-weight: var(--fw-semibold);
	text-decoration: underline;
}

.cful-entry--none {
	padding-bottom: 0;
}

.cful-entry--none .cful-entry__title {
	font-size: var(--text-xl);
}

.cful-entry--none .cful-search-form {
	margin-top: var(--space-5);
	max-width: 480px;
}

/* -------------------------------------------------------------------- */
/* Post navigation (single.php) + back links                           */
/* -------------------------------------------------------------------- */

.cful-post-nav {
	border-top: var(--border-hairline);
	display: flex;
	justify-content: space-between;
	margin-top: var(--space-7);
	padding-top: var(--space-5);
}

.cful-post-nav .nav-previous,
.cful-post-nav .nav-next {
	max-width: 48%;
}

.cful-post-nav .nav-next {
	margin-left: auto;
	text-align: right;
}

.cful-post-nav__label {
	color: var(--color-section-label);
	display: block;
	font-size: var(--text-xs);
	letter-spacing: 0.04em;
	margin-bottom: var(--space-1);
	text-transform: uppercase;
}

.cful-post-nav__title {
	font-family: var(--font-serif);
	font-size: var(--text-md);
}

.cful-back-link {
	margin-top: var(--space-6);
}

.cful-back-link a,
.cful-404__home-link a {
	font-weight: var(--fw-semibold);
	text-decoration: underline;
}

/* -------------------------------------------------------------------- */
/* Pagination                                                           */
/* -------------------------------------------------------------------- */

.cful-pagination {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
	margin-top: var(--space-7);
}

.cful-pagination .nav-links {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-2);
}

.cful-pagination .page-numbers {
	border: var(--border-hairline);
	color: var(--color-text);
	display: inline-flex;
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	min-height: 40px;
	min-width: 40px;
	align-items: center;
	justify-content: center;
	padding: var(--space-2) var(--space-3);
	text-decoration: none;
}

.cful-pagination .page-numbers.current {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-primary-contrast);
}

.cful-pagination .page-numbers:hover,
.cful-pagination .page-numbers:focus-visible {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-primary-contrast);
}

.cful-page-links {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-2);
}

.cful-page-links a {
	border: var(--border-hairline);
	display: inline-flex;
	min-height: 40px;
	min-width: 40px;
	align-items: center;
	justify-content: center;
	padding: var(--space-1) var(--space-3);
}

/* -------------------------------------------------------------------- */
/* Event tag (department chip used outside the card/list components)   */
/* -------------------------------------------------------------------- */

.cful-event-tag {
	align-items: center;
	background: var(--card-accent, var(--color-primary));
	color: var(--cful-white);
	display: inline-flex;
	flex-wrap: wrap;
	font-family: var(--font-sans);
	font-size: var(--text-xs);
	gap: var(--space-2);
	margin: 0 0 var(--space-3);
	padding: var(--space-2) var(--space-3);
}

.cful-event-tag__label {
	font-weight: var(--fw-semibold);
}

.cful-event-tag__sub {
	font-weight: var(--fw-regular);
	opacity: 0.9;
}

/* -------------------------------------------------------------------- */
/* Events archive (archive-events.php)                                 */
/* -------------------------------------------------------------------- */

.cful-events-archive-section {
	margin-bottom: var(--space-8);
}

.cful-events-archive-section__heading {
	font-family: var(--font-sans);
	font-size: var(--text-lg);
	font-weight: var(--fw-semibold);
	margin: 0 0 var(--space-5);
}

.cful-events-list__row--archive {
	border-left: 4px solid var(--card-accent, var(--color-primary));
	padding-left: var(--space-4);
}

/* -------------------------------------------------------------------- */
/* Comments (comments.php)                                             */
/* -------------------------------------------------------------------- */

.cful-comments {
	border-top: var(--border-hairline);
	margin-top: var(--space-8);
	padding-top: var(--space-7);
}

.cful-comments__title {
	font-family: var(--font-serif);
	font-size: var(--text-lg);
	margin: 0 0 var(--space-5);
}

.cful-comments__list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.cful-comments__list .comment {
	border-top: var(--border-hairline);
	padding-block: var(--space-5);
}

.cful-comments__list .children {
	list-style: none;
	margin: 0;
	padding-left: var(--space-6);
}

.cful-comments__list .comment-author {
	font-weight: var(--fw-semibold);
}

.cful-comments__list .comment-author .says {
	display: none;
}

.cful-comments__list .comment-metadata {
	color: var(--color-section-label);
	font-size: var(--text-xs);
	margin-bottom: var(--space-2);
}

.cful-comments__list .comment-metadata a {
	color: inherit;
}

.cful-comments__list .comment-content > * + * {
	margin-top: var(--space-3);
}

.cful-comments__list .reply {
	margin-top: var(--space-2);
}

.cful-comments__list .comment-reply-link {
	font-size: var(--text-xs);
	font-weight: var(--fw-semibold);
	text-decoration: underline;
}

.cful-comments__closed {
	color: var(--color-section-label);
	font-size: var(--text-sm);
	margin-top: var(--space-5);
}

.cful-comment-form {
	margin-top: var(--space-6);
}

.cful-comment-form p {
	margin-bottom: var(--space-4);
}

.cful-comment-form label {
	display: block;
	font-size: var(--text-xs);
	font-weight: var(--fw-medium);
	margin-bottom: var(--space-1);
}

.cful-comment-form input[type="text"],
.cful-comment-form input[type="email"],
.cful-comment-form input[type="url"],
.cful-comment-form textarea {
	border: var(--border-hairline);
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	min-height: 40px;
	padding: var(--space-2) var(--space-3);
	width: 100%;
}

.cful-comment-form textarea {
	min-height: 140px;
}

.cful-comment-form .form-submit input[type="submit"] {
	background: var(--color-primary);
	border: 0;
	color: var(--color-primary-contrast);
	cursor: pointer;
	font-family: var(--font-sans);
	font-size: var(--text-sm);
	font-weight: var(--fw-semibold);
	min-height: 40px;
	padding: var(--space-3) var(--space-5);
}

/* -------------------------------------------------------------------- */
/* Responsive (mobile collapse, ~899px and below)                      */
/* -------------------------------------------------------------------- */

@media (max-width: 899px) {
	.cful-post-nav {
		flex-direction: column;
		gap: var(--space-4);
	}

	.cful-post-nav .nav-previous,
	.cful-post-nav .nav-next {
		max-width: 100%;
	}

	.cful-post-nav .nav-next {
		margin-left: 0;
		text-align: left;
	}

	.cful-entry__title {
		font-size: var(--text-xl);
	}

	.cful-events-list__date {
		text-align: left;
	}

	.cful-comments__list .children {
		padding-left: var(--space-4);
	}
}

/* -------------------------------------------------------------------- */
/* Recent publications — editorial citation list (Figma node 421:1688)  */
/* -------------------------------------------------------------------- */

.cful-pub-list {
	display: flex;
	flex-direction: column;
	gap: var(--space-6);
	list-style: none;
	margin: 0;
	padding: 0;
}

.cful-pub-list__item {
	font-family: var(--font-serif);
	font-size: var(--text-2xl);
	line-height: var(--leading-snug);
}

.cful-pub-list__byline {
	font-weight: var(--fw-bold);
}

.cful-pub-list__title {
	color: inherit;
	text-decoration: none;
}

a.cful-pub-list__title:hover,
a.cful-pub-list__title:focus-visible {
	text-decoration: underline;
}
