@charset "UTF-8";

/**
 * collapsible.css 2.2.1
 *
 * HEIGHT / WIDTH ANIMATION
 * max-height animated between 0 and scrollHeight (set by JS).
 * .collapsible.horizontal uses max-width instead — coming feature, not finalized.
 *
 * STATES
 * off : .collapsible, .collapsible > *
 * on  : .collapsible.opened, .collapsible.opened > *
 *
 * VARIANTS
 * .truncated   — starts at a capped height instead of 0; closing gradient via ::after
 * .horizontal  — animates max-width instead of max-height (coming feature)
 *
 * TOGGLE
 * .collapsible-toggle — trigger button; icon rotates on .active via icomoon
 *
 * max-height / max-width values are set dynamically by collapsible.js
 */


/* ============================================== */
/* ==================== VARS ==================== */
/* ============================================== */

/**
 * Override in project CSS to customize per context.
 * --truncated-gradient-height and --truncated-gradient-color
 * control the fade-out effect on .truncated collapsibles.
 */

:root {
	--collapsible-icon: var(--icon-chevron-right);
	--collapsible-icon-rotate: 90deg;
	--truncated-gradient-height: 2em;
	--truncated-gradient-color: var(--bright-rgb);
}


/* ==================================================== */
/* ==================== ANIMATIONS ==================== */
/* ==================================================== */


/* ========== COLLAPSIBLE ========== */

.collapsible {
	transition:
		max-height var(--duration-normal),
		max-width var(--duration-normal),
		margin var(--duration-fast),
		padding var(--duration-fast);
	transition-delay: calc(var(--duration-fast) / 2);
}
.collapsible > * {
	transition:
		opacity var(--duration-normal),
		margin var(--duration-fast);
}
.collapsible,
.collapsible > * {
	transition-timing-function: var(--easeOutQuint);
}

.collapsible.opened {
	transition-delay: 0s;
}
.collapsible.opened,
.collapsible.opened > * {
	transition-timing-function: var(--easeInQuint);
}
.collapsible.opened > * {
	transition-delay: calc(var(--duration-fast) / 2);
}


/* ========== TOGGLE ========== */

.collapsible-toggle::before {
	transition: transform var(--duration-fast);
	transition-timing-function: var(--easeOutQuint);
}
.collapsible-toggle.active::before {
	transition-timing-function: var(--easeInQuint);
}


/* ========== TRUNCATED ========== */

.collapsible.truncated::after {
	transition: opacity var(--duration-normal);
}


/* ===================================================== */
/* ==================== COLLAPSIBLE ==================== */
/* ===================================================== */


/* ========== DEFAULT ========== */

.collapsible {
	position: relative;
	display: block;
	overflow: hidden;
	max-height: 0;
}
.collapsible > * {
	opacity: 0;
}
.collapsible:not(.opened):not(.horizontal):not(.truncated) {
	margin-top: 0;
}

/* ========== OPENED ========== */

.collapsible.opened {
	max-height: none;
	padding: 0;
}
.collapsible.opened > * {
	opacity: 1;
}


/* ========== HORIZONTAL — coming feature ========== */

.collapsible.horizontal {
	max-height: none;
	max-width: 0;
}
.collapsible.horizontal.opened {
	max-width: none;
}
.collapsible.horizontal > * {
	opacity: 0;
}


/* ========== TRUNCATED ========== */

.collapsible.truncated {
	overflow: hidden;
}
.collapsible.truncated > * {
	opacity: 1;
	margin: 0;
}

.collapsible.truncated::after {
	content: '';
	position: absolute;
	inset: auto 0 0 0;
	height: var(--truncated-gradient-height);
	background: linear-gradient(
		to bottom,
		rgba(var(--truncated-gradient-color), 0) 0%,
		rgba(var(--truncated-gradient-color), .8) 50%,
		rgba(var(--truncated-gradient-color), 1) 100%
	);
	pointer-events: none;
}
.collapsible.truncated.opened::after {
	opacity: 0;
}

.collapsible.truncated:not(.opened) .read-more-hidden {
	display: none;
}
.collapsible.truncated.opened .read-more-hidden {
	display: block;
}


/* ========== MARKERS ========== */

.more-tag,
.more-marker {
	display: none !important;
}


/* ================================================ */
/* ==================== TOGGLE ==================== */
/* ================================================ */


/* ========== DEFAULT ========== */

.collapsible-toggle {
	display: inline-flex;
	align-items: center;
	gap: 1em;
	cursor: pointer;
	text-decoration: none;
	width: auto !important;
}
.collapsible-toggle * {
	text-decoration: none;
}


/* ========== ICON ========== */

.collapsible-toggle::before {
	content: "";
	order: 2;
	height: 1em;
	aspect-ratio: 1/1;
	background: currentColor;
	mask-image: var(--collapsible-icon);
	mask-size: contain;
	mask-repeat: no-repeat;
	mask-position: center;
	backface-visibility: hidden;
	transform: rotate(0deg);
}
.collapsible-toggle.active::before {
	transform: rotate(var(--collapsible-icon-rotate));
}


/* ================================================ */
/* ==================== CUSTOM ==================== */
/* ================================================ */

/**
 * Project-specific overrides.
 *
 * Example — white gradient on a dark background section:
 * .dark-section .collapsible.truncated {
 *     --truncated-gradient-color: 30, 30, 30;
 * }
 *
 * Example — reposition icon for inline entry layout:
 * .entry .collapsible-toggle::before {
 *     position: absolute;
 *     bottom: 0;
 *     right: 0;
 * }
 */