.cm-tabs,
.cm-program,
.cm-congresses,
.cm-congress-detail,
.cm-speakers,
.cm-hotels {
	--cm-primary: #ff3341;
	--cm-primary-dark: #cc2934;
	--cm-primary-ultra-dark: #8b1d25;
	--cm-primary-light: #ffd8dc;
	--cm-primary-ultra-light: #fff1f2;
	--cm-secondary: #8f4fe0;
	--cm-secondary-dark: #6f37b4;
	--cm-secondary-light: #e6d7fb;
	--cm-base: #27374a;
	--cm-base-dark: #1f2c3b;
	--cm-base-ultra-dark: #111a24;
	--cm-base-light: #d7e0ea;
	--cm-base-ultra-light: #eef3f8;
	--cm-surface: #eef3f8;
	--cm-surface-alt: #f6f8fb;
	--cm-text: #111a24;
	--cm-text-soft: #667586;
	--cm-border: #d8e0e8;
	--cm-overlay: rgba(17, 26, 36, 0.12);
	--cm-black-alpha-18: rgba(15, 23, 36, 0.18);
	color: var(--cm-text);
	font-family: "Segoe UI", sans-serif;
}

.cm-tabs__nav {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	margin-bottom: 24px;
}

.cm-tabs__button,
.cm-chip,
.cm-button {
	border: 0;
	border-radius: 14px;
	background: var(--cm-base-ultra-light);
	color: var(--cm-base-dark);
	cursor: pointer;
	font-size: 16px;
	font-weight: 600;
	padding: 14px 22px;
	text-decoration: none;
	outline: 0;
	box-shadow: none;
	transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.cm-tabs__button.is-active,
.cm-chip.is-active,
.cm-button,
.cm-session__label {
	background: var(--cm-primary);
	color: var(--cm-white, #fff);
}

.cm-tabs__button:hover,
.cm-chip:hover,
.cm-button:hover {
	background: var(--cm-primary-ultra-light);
	color: var(--cm-primary-ultra-dark);
	transform: translateY(-1px);
}

.cm-tabs__button.is-active:hover,
.cm-chip.is-active:hover,
.cm-button:hover {
	background: var(--cm-primary-dark);
	color: var(--cm-white, #fff);
}

.cm-tabs__button:focus-visible,
.cm-chip:focus-visible,
.cm-button:focus-visible,
.cm-program__day-tab:focus-visible {
	outline: 0;
	box-shadow: 0 0 0 3px rgba(var(--cm-primary-rgb, 255, 51, 65), 0.18);
}

.cm-tabs__panel {
	display: none;
}

.cm-tabs__panel.is-active {
	display: block;
}

.cm-program__filters {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-bottom: 20px;
}

.cm-program__day-tabs {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-bottom: 20px;
}

.cm-program__day-tab {
	align-items: center;
	background: var(--cm-base-ultra-light);
	border: 0;
	border-radius: 18px;
	cursor: pointer;
	display: flex;
	gap: 10px;
	outline: 0;
	box-shadow: none;
	padding: 16px 20px;
	transition: background 0.2s ease, color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.cm-program__day-tab:hover {
	background: var(--cm-primary-ultra-light);
	transform: translateY(-1px);
}

.cm-program__day-tab:hover .cm-program__weekday {
	color: var(--cm-primary-dark);
}

.cm-program__day-tab:hover .cm-program__date {
	color: var(--cm-primary);
}

.cm-program__day-tab.is-active {
	background: var(--cm-white, #fff);
	box-shadow: 0 12px 28px var(--cm-overlay), 0 0 0 1px rgba(var(--cm-primary-rgb, 255, 51, 65), 0.14);
}

.cm-program__day-tab.is-active:hover {
	background: var(--cm-white, #fff);
	transform: none;
}

.cm-program__day-tab .cm-program__weekday,
.cm-program__day-tab .cm-program__date {
	margin: 0;
}

.cm-program__days {
	position: relative;
}

.cm-program__day {
	background: var(--cm-surface);
	border-radius: 24px;
	padding: 22px;
	display: none;
}

.cm-program__day.is-active {
	display: block;
}

.cm-program__weekday {
	color: var(--cm-text-soft);
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.cm-program__date {
	color: var(--cm-primary);
	font-size: 42px;
	font-weight: 800;
	line-height: 1;
}

.cm-program__list,
.cm-speakers,
.cm-hotels {
	display: grid;
	gap: 20px;
}

.cm-speakers {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.cm-congresses__grid {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 20px;
}

.cm-congress-card {
	display: grid;
	grid-template-rows: auto 1fr;
	flex: 0 1 calc((100% - 40px) / 3);
	max-width: calc((100% - 40px) / 3);
	min-width: 260px;
	background: var(--cm-white, #fff);
	border-radius: 24px;
	overflow: hidden;
	border: 1px solid var(--cm-border);
	box-shadow: 0 16px 40px var(--cm-overlay);
	transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.cm-congress-card:hover {
	transform: translateY(-6px);
	border-color: rgba(var(--cm-primary-rgb, 255, 51, 65), 0.24);
	box-shadow: 0 24px 48px var(--cm-overlay-strong, rgba(17, 26, 36, 0.2));
}

.cm-congress-card__media {
	position: relative;
	display: block;
	aspect-ratio: 2 / 3;
	background: linear-gradient(180deg, var(--cm-base-light), var(--cm-base-ultra-light));
	overflow: hidden;
}

.cm-congress-card__image,
.cm-congress-card__placeholder {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.35s ease, filter 0.35s ease;
}

.cm-congress-card:hover .cm-congress-card__image,
.cm-congress-card:hover .cm-congress-card__placeholder {
	transform: scale(1.04);
	filter: saturate(1.04);
}

.cm-congress-card__placeholder {
	background: linear-gradient(135deg, var(--cm-base-light), var(--cm-base-ultra-light));
}

.cm-congress-card__badge {
	position: absolute;
	top: 14px;
	left: 14px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 8px 12px;
	border-radius: 999px;
	background: rgba(var(--cm-base-rgb, 39, 55, 74), 0.84);
	color: var(--cm-white, #fff);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	transition: background 0.25s ease, transform 0.25s ease;
}

.cm-congress-card:hover .cm-congress-card__badge {
	background: rgba(var(--cm-primary-rgb, 255, 51, 65), 0.92);
	transform: translateY(-1px);
}

.cm-congress-card__content {
	display: grid;
	align-content: start;
	gap: 10px;
	padding: 18px;
}

.cm-congress-card__date {
	margin: 0;
	color: var(--cm-primary);
	font-size: 13px;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.cm-congress-card__content h3 {
	margin: 0;
	font-size: 18px;
	line-height: 1.18;
}

.cm-congress-card__content h3 a {
	color: inherit;
	text-decoration: none;
	transition: color 0.2s ease;
}

.cm-congress-card:hover .cm-congress-card__content h3 a {
	color: var(--cm-primary-dark);
}


.cm-congress-detail {
	display: grid;
	gap: 28px;
}

.cm-entity-detail {
	display: grid;
	gap: 28px;
}

.cm-entity-detail__hero {
	display: grid;
	grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
	gap: 28px;
	align-items: start;
}

.cm-entity-detail__media {
	border-radius: 24px;
	overflow: hidden;
	background: linear-gradient(135deg, var(--cm-base-light), var(--cm-base-ultra-light));
	box-shadow: 0 18px 42px var(--cm-overlay);
}

.cm-speaker-detail__media {
	aspect-ratio: 4 / 5;
}

.cm-hotel-detail__media {
	aspect-ratio: 4 / 3;
}

.cm-entity-detail__media img,
.cm-entity-detail__media svg,
.cm-entity-detail__media .cm-hotels__placeholder {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.cm-entity-detail__content {
	display: grid;
	align-content: start;
	gap: 14px;
	padding: 24px;
	background: var(--cm-white, #fff);
	border: 1px solid var(--cm-border);
	border-radius: 24px;
	box-shadow: 0 16px 40px var(--cm-overlay);
}

.cm-entity-detail__title {
	margin: 0;
	font-size: 36px;
	line-height: 1.08;
}

.cm-entity-detail__subtitle {
	margin: 0;
	color: var(--cm-text-soft);
	font-size: 18px;
	line-height: 1.5;
}

.cm-entity-detail__meta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin: 0;
	font-size: 15px;
	font-weight: 700;
}

.cm-entity-detail__description {
	font-size: 15px;
	line-height: 1.65;
}

.cm-entity-detail__links {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
}

.cm-entity-detail__text-link {
	color: var(--cm-primary);
	font-weight: 700;
	text-decoration: none;
}

.cm-entity-detail__section {
	display: grid;
	gap: 16px;
}

.cm-entity-detail__section h2 {
	margin: 0;
	font-size: 28px;
}

.cm-entity-detail__facts-inline {
	display: grid;
	gap: 10px;
	padding: 2px 0;
}

.cm-entity-detail__facts-inline p {
	margin: 0;
	color: var(--cm-text-soft);
	line-height: 1.5;
}

.cm-entity-detail__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.cm-chip.is-static {
	background: var(--cm-base-ultra-light);
	color: var(--cm-base-dark);
	cursor: default;
}

.cm-chip.is-static:hover {
	background: var(--cm-base-ultra-light);
	color: var(--cm-base-dark);
	transform: none;
}

.cm-entity-detail__gallery {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 14px;
}

.cm-entity-detail__gallery img {
	display: block;
	width: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
	border-radius: 18px;
	box-shadow: 0 12px 30px var(--cm-overlay);
}

.cm-template-congreso__inner {
	max-width: 1240px;
	margin: 0 auto;
	padding: 32px 20px 48px;
}

.cm-congress-detail__hero {
	display: grid;
	grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
	gap: 28px;
	align-items: start;
}

.cm-congress-detail__poster-frame {
	aspect-ratio: 2 / 3;
	border-radius: 24px;
	overflow: hidden;
	background: linear-gradient(135deg, var(--cm-base-light), var(--cm-base-ultra-light));
	box-shadow: 0 18px 42px var(--cm-overlay);
}

.cm-congress-detail__poster-frame img,
.cm-congress-detail__poster-frame .cm-congress-card__placeholder {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.cm-congress-detail__summary {
	display: grid;
	align-content: start;
	gap: 14px;
	padding: 24px;
	background: var(--cm-white, #fff);
	border: 1px solid var(--cm-border);
	border-radius: 24px;
	box-shadow: 0 16px 40px var(--cm-overlay);
}

.cm-congress-detail__status {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: fit-content;
	padding: 8px 12px;
	border-radius: 999px;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.cm-congress-detail__status.is-upcoming {
	background: var(--cm-primary-ultra-light);
	color: var(--cm-primary-ultra-dark);
}

.cm-congress-detail__status.is-ongoing {
	background: var(--cm-secondary-light);
	color: var(--cm-secondary-ultra-dark, var(--cm-secondary-dark));
}

.cm-congress-detail__status.is-past {
	background: var(--cm-base-ultra-light);
	color: var(--cm-base-dark);
}

.cm-congress-detail__title {
	margin: 0;
	font-size: 34px;
	line-height: 1.12;
}

.cm-congress-detail__subtitle {
	margin: 0;
	color: var(--cm-text-soft);
	font-size: 18px;
	line-height: 1.5;
}

.cm-congress-detail__facts {
	display: grid;
	gap: 0;
	border-top: 1px solid var(--cm-border);
	border-bottom: 1px solid var(--cm-border);
}

.cm-congress-detail__fact {
	display: flex;
	align-items: baseline;
	flex-wrap: wrap;
	gap: 8px 14px;
	padding: 14px 0;
	background: transparent;
	border-radius: 0;
	border-bottom: 1px solid var(--cm-border);
}

.cm-congress-detail__fact:last-child {
	border-bottom: 0;
}

.cm-congress-detail__fact-label {
	color: var(--cm-text-soft);
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.cm-congress-detail__fact-value {
	font-size: 16px;
	font-weight: 700;
}

.cm-congress-detail__cta {
	width: fit-content;
}

.cm-congress-detail__cta.is-disabled,
.cm-congress-detail__cta.is-disabled:hover {
	background: var(--cm-base-light);
	color: var(--cm-base-dark);
	cursor: not-allowed;
	transform: none;
	box-shadow: none;
}

.cm-congress-detail__section {
	display: grid;
	gap: 18px;
}

.cm-congress-detail__section-head h3 {
	margin: 0;
	font-size: 28px;
}

.cm-program__cluster {
	display: grid;
	gap: 18px;
	margin-bottom: 20px;
}

.cm-program__cluster.columns-2 {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.cm-program__cluster.columns-3 {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.cm-program__cluster.columns-4 {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.cm-program__lane {
	display: grid;
	gap: 18px;
	align-content: start;
}

.cm-session,
.cm-hotels__card {
	display: grid;
	grid-template-columns: 90px minmax(0, 1fr);
	background: var(--cm-white, #fff);
	border-radius: 20px;
	overflow: hidden;
	box-shadow: 0 12px 36px var(--cm-overlay);
}

.cm-session__time {
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 10px;
	color: var(--cm-white, #fff);
	font-size: 22px;
	font-weight: 800;
	padding: 20px 16px;
	text-align: center;
}

.cm-session__body,
.cm-hotels__content {
	padding: 18px 20px 20px;
}

.cm-session__label {
	border-radius: 999px;
	display: inline-block;
	font-size: 12px;
	margin-bottom: 12px;
	padding: 6px 12px;
}

.cm-session h3,
.cm-hotels__content h3 {
	font-size: 28px;
	line-height: 1.2;
	margin: 0 0 12px;
}

.cm-session__room,
.cm-hotels__meta,
.cm-hotels__price {
	color: var(--cm-text-soft);
	font-size: 16px;
	font-weight: 600;
	margin: 0 0 12px;
}

.cm-session__speakers {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 16px;
}

.cm-session__speaker,
.cm-session__speaker img {
	border-radius: 12px;
	height: 44px;
	width: 44px;
}

.cm-session__speaker {
	align-items: center;
	background: var(--cm-base-ultra-light);
	display: inline-flex;
	justify-content: center;
	overflow: hidden;
}

.cm-session__speaker-initial {
	font-weight: 800;
}

.cm-speakers__card {
	display: grid;
	grid-template-rows: auto 1fr;
	background: var(--cm-white, #fff);
	border-radius: 20px;
	overflow: hidden;
	border: 1px solid var(--cm-border);
	box-shadow: 0 12px 36px var(--cm-overlay);
}

.cm-hotels__card {
	grid-template-columns: minmax(180px, 260px) minmax(0, 1fr);
}

.cm-speakers__media,
.cm-speakers__image,
.cm-speakers__image--placeholder,
.cm-hotels__media img,
.cm-hotels__placeholder {
	display: block;
	width: 100%;
}

.cm-speakers__media {
	aspect-ratio: 4 / 5;
	background: linear-gradient(180deg, var(--cm-base-light), var(--cm-base-ultra-light));
	overflow: hidden;
}

.cm-speakers__image,
.cm-speakers__image--placeholder,
.cm-hotels__media img,
.cm-hotels__placeholder {
	height: 100%;
	object-fit: cover;
}

.cm-hotels__placeholder {
	background: linear-gradient(135deg, var(--cm-base-light), var(--cm-base-ultra-light));
	min-height: 220px;
}

.cm-speakers__content {
	display: grid;
	align-content: start;
	gap: 8px;
	padding: 14px 16px 16px;
}

.cm-speakers__content h3 {
	font-size: 18px;
	line-height: 1.22;
	margin: 0;
}

.cm-speakers__meta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin: 0;
	color: var(--cm-text-soft);
	font-size: 14px;
	font-weight: 600;
	line-height: 1.4;
}

.cm-speakers__flag {
	width: 18px;
	height: 14px;
	flex: 0 0 auto;
	border-radius: 2px;
	box-shadow: 0 0 0 1px rgba(var(--cm-base-rgb, 39, 55, 74), 0.12);
}

.cm-empty {
	background: var(--cm-white, #fff);
	border-radius: 18px;
	padding: 24px;
	border: 1px solid var(--cm-border);
}

.cm-pdf-embed iframe {
	display: block;
	width: 100%;
	height: var(--cm-pdf-height, 800px);
}

@media (max-width: 767px) {
	.cm-session,
	.cm-congress-card,
	.cm-hotels__card {
		grid-template-columns: 1fr;
		border-radius: 16px;
	}

	.cm-speakers {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 14px;
	}

	.cm-congresses__grid {
		gap: 16px;
	}

	.cm-congress-card {
		flex-basis: calc((100% - 16px) / 2);
		max-width: calc((100% - 16px) / 2);
	}

	.cm-congress-detail__hero {
		grid-template-columns: 1fr;
		gap: 18px;
	}

	.cm-entity-detail__hero {
		grid-template-columns: 1fr;
		gap: 18px;
	}

	.cm-congress-detail__summary {
		padding: 18px;
		border-radius: 18px;
	}

	.cm-entity-detail__content {
		padding: 18px;
		border-radius: 18px;
	}

	.cm-program__day-tabs {
		flex-wrap: nowrap;
		gap: 10px;
		overflow-x: auto;
		margin-bottom: 16px;
		padding-bottom: 8px;
		scrollbar-width: thin;
	}

	.cm-program__day-tab {
		flex: 0 0 auto;
		justify-content: flex-start;
		min-width: 82px;
		padding: 12px 14px;
		width: auto;
	}

	.cm-program__cluster.columns-2,
	.cm-program__cluster.columns-3,
	.cm-program__cluster.columns-4 {
		grid-auto-columns: minmax(280px, 86vw);
		grid-auto-flow: column;
		grid-template-columns: none;
		overflow-x: auto;
		padding-bottom: 8px;
		scrollbar-width: thin;
	}

	.cm-program__day {
		border-radius: 18px;
		padding: 14px;
	}

	.cm-program__list,
	.cm-program__lane {
		gap: 14px;
	}

	.cm-session__time {
		flex-direction: row;
		justify-content: flex-start;
		gap: 12px;
		font-size: 15px;
		padding: 12px 14px;
	}

	.cm-session h3,
	.cm-congress-card__content h3,
	.cm-congress-detail__title,
	.cm-entity-detail__title,
	.cm-hotels__content h3 {
		font-size: 18px;
		margin-bottom: 8px;
	}

	.cm-program__day-tab {
		justify-content: space-between;
	}

	.cm-program__weekday {
		font-size: 11px;
	}

	.cm-program__date {
		font-size: 24px;
	}

	.cm-session__body,
	.cm-congress-card__content,
	.cm-hotels__content {
		padding: 14px 16px 16px;
	}

	.cm-session__label {
		font-size: 11px;
		margin-bottom: 10px;
		padding: 5px 10px;
	}

	.cm-session__room,
	.cm-congress-detail__subtitle,
	.cm-entity-detail__subtitle,
	.cm-hotels__meta,
	.cm-hotels__price,
	.cm-session__excerpt,
	.cm-hotels__excerpt {
		font-size: 14px;
		line-height: 1.45;
		margin-bottom: 10px;
	}

	.cm-speakers__content {
		padding: 12px;
	}

	.cm-speakers__content h3 {
		font-size: 16px;
		margin: 0;
	}

	.cm-speakers__meta {
		font-size: 13px;
		margin: 0;
	}

	.cm-congress-card__date {
		font-size: 12px;
	}

	.cm-congress-detail__section-head h3 {
		font-size: 22px;
	}

	.cm-entity-detail__section h2 {
		font-size: 22px;
	}

	.cm-template-congreso__inner {
		padding: 20px 14px 36px;
	}

	.cm-session__speakers {
		gap: 8px;
		margin-top: 12px;
	}

	.cm-session__speaker,
	.cm-session__speaker img {
		height: 36px;
		width: 36px;
	}

	.cm-tabs__nav,
	.cm-program__filters {
		gap: 10px;
		margin-bottom: 16px;
	}

	.cm-tabs__button,
	.cm-chip,
	.cm-button {
		border-radius: 12px;
		font-size: 14px;
		padding: 11px 16px;
	}

	.cm-hotels__placeholder {
		min-height: 160px;
	}

	.cm-empty {
		border-radius: 14px;
		font-size: 14px;
		padding: 18px;
	}

	.cm-pdf-embed iframe {
		height: 500px;
	}
}

@media (max-width: 640px) {
	.cm-congress-card {
		flex-basis: 100%;
		max-width: 100%;
		min-width: 0;
	}
}

.cm-congress-image-lightbox-trigger {
	cursor: zoom-in;
	display: inline-block;
}

.cm-congress-image-lightbox-trigger img {
	display: block;
}

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

.cm-lightbox[hidden] {
	display: none;
}

.cm-lightbox {
	position: fixed;
	inset: 0;
	z-index: 99999;
}

.cm-lightbox__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(10, 16, 24, 0.82);
	backdrop-filter: blur(6px);
}

.cm-lightbox__dialog {
	position: relative;
	z-index: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	padding: 36px;
}

.cm-lightbox__image {
	display: block;
	max-width: min(92vw, 1280px);
	max-height: 88vh;
	width: auto;
	height: auto;
	border-radius: 18px;
	box-shadow: 0 28px 54px rgba(0, 0, 0, 0.34);
	background: #ffffff;
}

.cm-lightbox__close {
	position: absolute;
	top: 22px;
	right: 22px;
	width: 46px;
	height: 46px;
	border: 0;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.14);
	color: #ffffff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	backdrop-filter: blur(4px);
	transition: background-color 0.18s ease, transform 0.18s ease;
}

.cm-lightbox__close:hover,
.cm-lightbox__close:focus-visible {
	background: rgba(255, 255, 255, 0.22);
	transform: scale(1.03);
}

.cm-lightbox__close svg {
	width: 20px;
	height: 20px;
}

@media (max-width: 640px) {
	.cm-lightbox__dialog {
		padding: 18px;
	}

	.cm-lightbox__image {
		max-width: 94vw;
		max-height: 82vh;
		border-radius: 14px;
	}

	.cm-lightbox__close {
		top: 14px;
		right: 14px;
		width: 42px;
		height: 42px;
	}
}

.cm-countdown {
	margin: 0;
	max-width: none;
	width: 100%;
}

.cm-countdown__card {
	background:
		radial-gradient(circle at top right, var(--cm-primary-20, rgba(255, 51, 65, 0.2)), transparent 32%),
		linear-gradient(145deg, var(--cm-base, #27374a), var(--cm-base-dark, #1e293b));
	border: 1px solid var(--cm-base-light, #d8e2f1);
	border-radius: 28px;
	box-shadow: 0 20px 48px var(--cm-base-20, rgba(39, 55, 74, 0.2));
	color: var(--cm-white, #ffffff);
	display: grid;
	column-gap: 18px;
	row-gap: 20px;
	grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
	align-items: center;
	overflow: hidden;
	padding: 24px;
	position: relative;
	width: 100%;
}

.cm-countdown__card::after {
	background: linear-gradient(90deg, transparent, var(--cm-white-10, rgba(255, 255, 255, 0.1)), transparent);
	content: "";
	height: 1px;
	left: 28px;
	position: absolute;
	right: 28px;
	top: 50%;
	transform: translateY(-50%);
}

.cm-countdown__head {
	display: grid;
	align-content: center;
	gap: 10px;
	position: relative;
	z-index: 1;
}

.cm-countdown__eyebrow {
	color: var(--cm-primary-light, #ffd7db);
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.18em;
	margin: 0;
	text-transform: uppercase;
}

.cm-countdown__head h3 {
	font-size: clamp(24px, 3.6vw, 38px);
	line-height: 1.05;
	margin: 0;
}

.cm-countdown__title-link {
	color: var(--cm-white, #ffffff);
	display: inline;
	text-decoration: none;
}

.cm-countdown__title-link:hover,
.cm-countdown__title-link:focus-visible {
	color: var(--cm-white, #ffffff);
	text-decoration: none;
}

.cm-countdown__title-icon {
	align-items: center;
	background: var(--cm-white-12, rgba(255, 255, 255, 0.12));
	border: 1px solid var(--cm-white-18, rgba(255, 255, 255, 0.18));
	border-radius: 999px;
	display: inline-flex;
	height: 42px;
	justify-content: center;
	margin-left: 10px;
	vertical-align: middle;
	transition: transform 0.24s ease, background-color 0.24s ease, border-color 0.24s ease;
	width: 42px;
}

.cm-countdown__title-icon svg {
	display: block;
	height: 18px;
	width: 18px;
}

.cm-countdown__title-link:hover .cm-countdown__title-icon,
.cm-countdown__title-link:focus-visible .cm-countdown__title-icon {
	background: var(--cm-white-18, rgba(255, 255, 255, 0.18));
	border-color: var(--cm-white-25, rgba(255, 255, 255, 0.25));
	transform: translateX(3px);
}

.cm-countdown__date {
	color: var(--cm-base-ultra-light, #f1f5f9);
	font-size: 16px;
	margin: 0;
}

.cm-countdown__grid {
	display: grid;
	gap: 14px;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	align-items: center;
	align-self: center;
	position: relative;
	z-index: 1;
}

.cm-countdown__item {
	align-content: center;
	background: var(--cm-white-10, rgba(255, 255, 255, 0.1));
	border: 1px solid var(--cm-white-15, rgba(255, 255, 255, 0.15));
	border-radius: 22px;
	display: grid;
	min-height: 138px;
	padding: 20px 18px;
	text-align: center;
}

.cm-countdown__item span {
	color: var(--cm-white, #ffffff);
	display: block;
	font-size: clamp(30px, 4vw, 44px);
	font-weight: 800;
	letter-spacing: -0.04em;
	line-height: 1;
	margin-bottom: 10px;
}

.cm-countdown__item small {
	color: var(--cm-primary-light, #ffd7db);
	display: block;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}

@media (max-width: 900px) {
	.cm-countdown__card {
		grid-template-columns: 1fr;
		padding: 22px;
	}

	.cm-countdown__card::after {
		display: none;
	}
}

@media (max-width: 640px) {
	.cm-countdown__card {
		border-radius: 22px;
		gap: 20px;
		padding: 18px;
	}

	.cm-countdown__head h3 {
		font-size: 26px;
	}

	.cm-countdown__title-icon {
		height: 36px;
		margin-left: 8px;
		width: 36px;
	}

	.cm-countdown__date {
		font-size: 14px;
	}

	.cm-countdown__grid {
		gap: 10px;
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}

	.cm-countdown__item {
		border-radius: 18px;
		min-height: 116px;
		padding: 16px 12px;
	}

	.cm-countdown__item span {
		font-size: 28px;
	}
}
