/*
 * Universal Block frontend styles.
 *
 * These rules are intentionally plain CSS. Each block writes its editable
 * values into --ub-* variables, and this file decides how those values behave.
 */

.ub-block,
.ub-block *,
.ub-block *::before,
.ub-block *::after {
	box-sizing: border-box;
}

.ub-block {
	--ub-display: initial;
	--ub-width: initial;
	--ub-max-width: initial;
	--ub-min-height: initial;
	--ub-color: initial;
	--ub-background: initial;
	--ub-border: initial;
	--ub-radius: initial;
	--ub-shadow: initial;
	--ub-transition: initial;
	--ub-overflow: initial;
	--ub-position: initial;
	--ub-z-index: initial;
	--ub-text-align: initial;
	--ub-font-family: initial;
	--ub-font-size: initial;
	--ub-font-weight: initial;
	--ub-line-height: initial;
	--ub-letter-spacing: initial;
	--ub-text-transform: initial;
	--ub-text-decoration: initial;
	--ub-hover-color: var(--ub-color);
	--ub-hover-background: var(--ub-background);
	--ub-hover-border: var(--ub-border);
	--ub-hover-shadow: var(--ub-shadow);
	--ub-hover-transform: none;
	--ub-hover-opacity: 1;
	--ub-flex-direction: initial;
	--ub-flex-wrap: initial;
	--ub-justify: initial;
	--ub-align: initial;
	--ub-flex: initial;
	--ub-align-self: initial;
	--ub-order: initial;
	--ub-grid-column: initial;
	--ub-grid-row: initial;
	--ub-grid-columns: initial;
	--ub-grid-rows: initial;
	--ub-padding: initial;
	--ub-padding-tablet: initial;
	--ub-padding-mobile: initial;
	--ub-margin: initial;
	--ub-margin-tablet: initial;
	--ub-margin-mobile: initial;
	--ub-gap: initial;
	--ub-gap-tablet: initial;
	--ub-gap-mobile: initial;
	--ub-object-fit: initial;
	--ub-object-position: initial;
	--ub-aspect-ratio: initial;
	--ub-icon-size: initial;
	--ub-icon-stroke-width: initial;
	--ub-display-default: block;
	--ub-width-default: auto;
	--ub-max-width-default: none;
	--ub-min-height-default: 0;
	--ub-color-default: inherit;
	--ub-background-default: transparent;
	--ub-border-default: 0;
	--ub-radius-default: 0;
	--ub-shadow-default: none;
	--ub-transition-default: none;
	--ub-overflow-default: visible;
	--ub-position-default: static;
	--ub-z-index-default: auto;
	--ub-text-align-default: inherit;
	--ub-font-family-default: inherit;
	--ub-font-size-default: inherit;
	--ub-font-weight-default: inherit;
	--ub-line-height-default: inherit;
	--ub-letter-spacing-default: inherit;
	--ub-text-transform-default: none;
	--ub-text-decoration-default: inherit;
	--ub-flex-default: initial;
	--ub-align-self-default: auto;
	--ub-order-default: 0;
	--ub-grid-column-default: auto;
	--ub-grid-row-default: auto;
	--ub-padding-default: 0;
	--ub-margin-default: 0;
	--ub-gap-default: normal;

	display: var(--ub-display, var(--ub-display-default));
	width: var(--ub-width, var(--ub-width-default));
	max-width: var(--ub-max-width, var(--ub-max-width-default));
	min-height: var(--ub-min-height, var(--ub-min-height-default));
	color: var(--ub-color, var(--ub-color-default));
	background: var(--ub-background, var(--ub-background-default));
	border: var(--ub-border, var(--ub-border-default));
	border-radius: var(--ub-radius, var(--ub-radius-default));
	box-shadow: var(--ub-shadow, var(--ub-shadow-default));
	transition: var(--ub-transition, var(--ub-transition-default));
	overflow: var(--ub-overflow, var(--ub-overflow-default));
	position: var(--ub-position, var(--ub-position-default));
	z-index: var(--ub-z-index, var(--ub-z-index-default));
	text-align: var(--ub-text-align, var(--ub-text-align-default));
	font-family: var(--ub-font-family, var(--ub-font-family-default));
	font-size: var(--ub-font-size, var(--ub-font-size-default));
	font-weight: var(--ub-font-weight, var(--ub-font-weight-default));
	line-height: var(--ub-line-height, var(--ub-line-height-default));
	letter-spacing: var(--ub-letter-spacing, var(--ub-letter-spacing-default));
	text-transform: var(--ub-text-transform, var(--ub-text-transform-default));
	text-decoration: var(--ub-text-decoration, var(--ub-text-decoration-default));
	flex: var(--ub-flex, var(--ub-flex-default));
	align-self: var(--ub-align-self, var(--ub-align-self-default));
	order: var(--ub-order, var(--ub-order-default));
	grid-column: var(--ub-grid-column, var(--ub-grid-column-default));
	grid-row: var(--ub-grid-row, var(--ub-grid-row-default));
	padding: var(--ub-padding, var(--ub-padding-default));
	margin: var(--ub-margin, var(--ub-margin-default));
	gap: var(--ub-gap, var(--ub-gap-default));
}

.ub-block.ub-has-hover:hover,
.ub-block.ub-has-hover:focus-visible {
	color: var(--ub-hover-color);
	background: var(--ub-hover-background);
	border: var(--ub-hover-border);
	box-shadow: var(--ub-hover-shadow);
	transform: var(--ub-hover-transform);
	opacity: var(--ub-hover-opacity);
}

.ub-element {
	flex-direction: var(--ub-flex-direction, row);
	flex-wrap: var(--ub-flex-wrap, nowrap);
	justify-content: var(--ub-justify, normal);
	align-items: var(--ub-align, normal);
	grid-template-columns: var(--ub-grid-columns, none);
	grid-template-rows: var(--ub-grid-rows, none);
}

.ub-element > :first-child {
	margin-top: 0;
}

.ub-element > :last-child {
	margin-bottom: 0;
}

.ub-link {
	--ub-display-default: inline-flex;
	--ub-border-default: 0;
	--ub-radius-default: 0;
	--ub-gap-default: 0.5em;
	--ub-align: center;
	--ub-justify: center;
	--ub-line-height-default: 1.1;
	--ub-text-decoration-default: none;

	align-items: var(--ub-align, center);
	justify-content: var(--ub-justify, center);
	flex-wrap: nowrap;
	transition: var(--ub-transition, var(--ub-transition-default));
}

.ub-link.ub-has-hover:hover,
.ub-link.ub-has-hover:focus-visible {
	color: var(--ub-hover-color);
	background: var(--ub-hover-background);
	border: var(--ub-hover-border);
	box-shadow: var(--ub-hover-shadow);
	transform: var(--ub-hover-transform);
	opacity: var(--ub-hover-opacity);
	text-decoration: var(--ub-text-decoration, var(--ub-text-decoration-default));
}

.ub-link:focus-visible {
	outline: 2px solid currentColor;
	outline-offset: 3px;
}

.ub-link--button {
	--ub-padding-default: 0.85em 1.15em;
	--ub-radius-default: 0.45em;
	--ub-background-default: #111;
	--ub-color-default: #fff;
}

.ub-link--ghost {
	--ub-padding-default: 0.85em 1.15em;
	--ub-radius-default: 0.45em;
	--ub-border-default: 1px solid currentColor;
}

.ub-link--icon {
	--ub-padding-default: 0.65em;
	--ub-radius-default: 999px;
}

.ub-link__icon {
	display: inline-flex;
	flex: 0 0 auto;
	align-items: center;
	justify-content: center;
	width: var(--ub-icon-size, 1em);
	height: var(--ub-icon-size, 1em);
}

.ub-link__icon svg {
	display: block;
	width: 100%;
	height: 100%;
	stroke-width: var(--ub-icon-stroke-width, 2);
}

.ub-image {
	--ub-display-default: block;
	--ub-overflow-default: hidden;

	line-height: 0;
}

.ub-image a,
.ub-image img {
	display: block;
}

.ub-image img {
	width: 100%;
	max-width: 100%;
	height: auto;
	aspect-ratio: var(--ub-aspect-ratio, auto);
	object-fit: var(--ub-object-fit, cover);
	object-position: var(--ub-object-position, center center);
	border-radius: inherit;
}

.ub-image[style*="--ub-aspect-ratio"] img {
	height: 100%;
}

.ub-icon {
	--ub-display-default: inline-flex;
	--ub-icon-size-default: 24px;
	--ub-gap-default: 0;

	align-items: center;
	justify-content: center;
	line-height: 0;
	width: var(--ub-width, auto);
	height: var(--ub-min-height, auto);
}

.ub-icon svg {
	display: block;
	width: var(--ub-icon-size, var(--ub-icon-size-default));
	height: var(--ub-icon-size, var(--ub-icon-size-default));
	stroke-width: var(--ub-icon-stroke-width, 2);
}

.ub-custom-html {
	--ub-display-default: block;
}

.ub-icon svg,
.ub-link__icon svg {
	flex: 0 0 auto;
}

.ub-meta {
	--ub-display-default: inline-flex;
	--ub-gap-default: 0.35em;

	align-items: baseline;
	line-height: var(--ub-line-height, inherit);
}

.ub-meta__label {
	color: inherit;
	font-weight: inherit;
}

.ub-meta__value {
	color: inherit;
	font-weight: inherit;
}

.ub-meta--image img,
.ub-meta__image {
	display: block;
	max-width: 100%;
	height: auto;
}

.ub-meta__link {
	color: inherit;
	text-decoration: none;
}

.ub-meta--list {
	--ub-display-default: block;
}

.ub-meta__list {
	display: grid;
	gap: 0.7em;
	padding: 0;
	margin: 0;
	list-style: none;
}

@media (max-width: 1024px) {
	.ub-block {
		padding: var(--ub-padding-tablet, var(--ub-padding, var(--ub-padding-default)));
		margin: var(--ub-margin-tablet, var(--ub-margin, var(--ub-margin-default)));
		gap: var(--ub-gap-tablet, var(--ub-gap, var(--ub-gap-default)));
	}
}

@media (max-width: 700px) {
	.ub-block {
		padding: var(--ub-padding-mobile, var(--ub-padding-tablet, var(--ub-padding, var(--ub-padding-default))));
		margin: var(--ub-margin-mobile, var(--ub-margin-tablet, var(--ub-margin, var(--ub-margin-default))));
		gap: var(--ub-gap-mobile, var(--ub-gap-tablet, var(--ub-gap, var(--ub-gap-default))));
	}
}
