:root {
	--font-family-base: 'Pretendard', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Apple SD Gothic Neo', 'Malgun Gothic', sans-serif;
	--site-container-max: 1240px;
	/* 모바일 비주얼 공통 높이 (메인·서브 동일, 768×600 비율 기준) */
	--hero-visual-mobile-height: clamp(220px, 78.125vw, 280px);
}

@media (min-width: 1200px) {
	.container:not(.container-bs):not(.container-xl-custom):not(.container-xxl-custom) {
		max-width: var(--site-container-max);
	}
}

html,
body {
	background-color: #eef1f5;
}

html,
body,
button,
input,
select,
textarea,
a {
	font-family: var(--font-family-base);
}

a {
	text-decoration: none;
}

a:not(.btn):hover,
a:not(.btn):focus {
	text-decoration: none;
}

.pretendard-medium {
	font-weight: 500;
}

.pretendard-bold {
	font-weight: 700;
}

.text-color-gradient {
	background: linear-gradient(to right, var(--primary, #0088cc), var(--primary, #0088cc));
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	display: inline-block;
}

.text-6 {
	font-size: 2rem !important;
}

/* Sub page — background visual */
.sub-page-head {
	position: relative;
	min-height: var(--sub-visual-height, 300px);
	border-bottom: 1px solid #e8edf3;
	background-color: #fafbfc;
	background-image: var(--sub-visual-pc);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}

.sub-page-head--minimal {
	background-image: none;
	background: linear-gradient(180deg, #fafbfc 0%, #f4f6f8 100%);
}

/* Sub page — title + breadcrumb (below hero) */
.sub-page-bar {
	background: #fff;
}

.sub-page-bar__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem 2rem;
	padding: 2rem 0;
}

.sub-page-bar__menu {
	margin: 0;
	font-weight: 700;
	line-height: 40px;
}

.sub-page-bar__breadcrumb {
	display: inline-flex;
	align-items: center;
	flex-shrink: 0;
	padding: 0.5rem 1rem;
	background: #f6f8fb;
	border: 1px solid #e3e9ef;
	border-radius: 999px;
}

.sub-page-bar__trail {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-end;
	list-style: none;
	margin: 0;
	padding: 0;
	font-size: 13px;
	font-weight: 500;
	line-height: 1.4;
	color: #6b7785;
}

.sub-page-bar__trail li {
	display: inline-flex;
	align-items: center;
}

.sub-page-bar__trail li + li::before {
	content: "";
	display: block;
	width: 14px;
	height: 14px;
	margin: 0 0.3rem;
	flex-shrink: 0;
	background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23c5ced8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m9 18 6-6-6-6'/%3E%3C/svg%3E") center / contain no-repeat;
}

.sub-page-bar__trail a,
.sub-page-bar__trail-label {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
}

.sub-page-bar__trail-icon {
	width: 14px;
	height: 14px;
	flex-shrink: 0;
	color: #8a96a3;
}

.sub-page-bar__trail a {
	color: #6b7785;
	text-decoration: none;
	transition: color 0.15s ease;
}

.sub-page-bar__trail a:hover,
.sub-page-bar__trail a:focus-visible {
	color: var(--primary, #0088cc);
}

.sub-page-bar__trail a:hover .sub-page-bar__trail-icon,
.sub-page-bar__trail a:focus-visible .sub-page-bar__trail-icon {
	color: var(--primary, #0088cc);
}

.sub-page-bar__trail li[aria-current="page"] .sub-page-bar__trail-label {
	color: var(--primary, #0088cc);
	font-weight: 600;
}

.sub-page-bar__trail li[aria-current="page"] .sub-page-bar__trail-icon {
	color: var(--primary, #0088cc);
}

.hero-legacy {
	height: var(--hero-visual-height, 600px);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	border-bottom: 1px solid #e8edf3;
}

.hero-legacy--minimal {
	background-color: #fafbfc;
	background-image: none;
}

.hero-legacy--minimal.hero-legacy--overlay {
	background: linear-gradient(180deg, #fafbfc 0%, #f4f6f8 100%);
}

.hero-legacy--overlay {
	position: relative;
}

.hero-legacy__container {
	height: 100%;
	padding-top: 1.5rem;
	padding-bottom: 1.5rem;
}

.hero-legacy__container > .container {
	height: 100%;
}

.hero-legacy__row {
	width: 100%;
	min-height: 100%;
}

.hero-legacy__col--left--has-countdown {
	padding-top: var(--countdown-hero-margin-top, 4rem);
	padding-left: var(--countdown-hero-margin-left, 0);
	padding-bottom: 1.5rem;
}

.hero-legacy__col--right {
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
}

.hero-legacy__animation {
	display: block;
	max-width: min(100%, 420px);
	height: auto;
	margin: 0 auto;
}

@media (min-width: 992px) {
	.hero-legacy__animation {
		margin-left: 0;
		margin-right: auto;
	}
}

/* Countdown */
.countdown-modern--header {
	padding: 0.8rem 0;
}

.countdown-modern--header .countdown-modern__label {
	color: var(--primary, #0088cc);
}

.hero-legacy__animation + .countdown-modern--hero {
	margin-top: 1rem;
}

.countdown-modern--hero {
	display: inline-flex;
	flex-direction: row;
	align-items: center;
	flex-wrap: nowrap;
	gap: 0.85rem;
	margin: 0;
	padding: 0.55rem 1rem 0.55rem 0.75rem;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.92);
	border: 1px solid color-mix(in srgb, var(--primary) 12%, transparent);
	backdrop-filter: blur(8px);
}

.countdown-modern--hero .countdown-modern__label {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0;
	color: #475569;
	font-size: 0.8125rem;
	font-weight: 600;
	letter-spacing: -0.01em;
	white-space: nowrap;
	flex-shrink: 0;
}

.countdown-modern__label-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 1.5rem;
	height: 1.5rem;
	border-radius: 50%;
	background: var(--primary-rgba-10);
	color: var(--primary);
}

.countdown-modern__label-icon svg.lucide-icon {
	width: 0.85rem;
	height: 0.85rem;
	stroke-width: 2.1;
	color: var(--primary);
}

.countdown-modern__label-text {
	line-height: 1.25;
}

.countdown-modern__tiles {
	display: flex;
	align-items: center;
	padding: 0;
	flex-shrink: 0;
}

.countdown-face {
	display: inline-flex;
	align-items: baseline;
	gap: 0.65rem;
	white-space: nowrap;
	line-height: 1;
}

.countdown-face__days {
	display: inline-flex;
	align-items: baseline;
	gap: 0.08rem;
}

.countdown-face__days-num {
	font-size: 1.375rem;
	font-weight: 700;
	color: var(--primary);
	font-variant-numeric: tabular-nums;
	letter-spacing: -0.03em;
}

.countdown-face__days-unit {
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--primary);
}

.countdown-face__sep {
	font-size: 1.125rem;
	font-weight: 700;
	color: color-mix(in srgb, var(--primary) 25%, transparent);
	line-height: 1;
}

.countdown-face__clock {
	display: inline-flex;
	align-items: baseline;
	font-variant-numeric: tabular-nums;
}

.countdown-face__clock-num {
	font-size: 1.375rem;
	font-weight: 600;
	color: #1e293b;
	letter-spacing: 0.03em;
	min-width: 2ch;
	text-align: center;
}

.countdown-face__colon {
	font-size: 1.125rem;
	font-weight: 500;
	color: var(--primary-rgba-40);
	padding: 0 0.08rem;
	line-height: 1;
}

.countdown-modern__ended {
	font-size: 0.8125rem;
	font-weight: 500;
	color: #64748b;
	padding: 0;
	background: transparent;
	display: inline;
	white-space: nowrap;
}

/* Hero video */
.hero-video-wrap {
	flex-shrink: 0;
}

/* 좌측·하단: 상단·좌측 여백만큼 아래·오른쪽으로 이동 */
.hero-video-wrap--left,
.hero-video-wrap--below {
	margin-top: var(--video-hero-margin-top, 0);
	margin-left: var(--video-hero-margin-left, 0);
}

/* 우측: 하단·우측 정렬 기준 — 상단=위로, 좌측=왼쪽으로 이동 */
.hero-video-wrap--right {
	margin-bottom: var(--video-hero-margin-top, 0);
	margin-left: var(--video-hero-margin-left, 0);
}

.hero-video-wrap.hero-video--desktop {
	display: block;
}

.hero-video-wrap.hero-video--mobile {
	display: none;
}

.hero-video {
	overflow: hidden;
	border: 4px solid #fff;
	border-radius: 14px;
	box-shadow: 0 10px 28px rgba(0, 0, 0, 0.18);
	background: #111;
}

.hero-video--portrait {
	width: clamp(200px, 20vw, 260px);
	aspect-ratio: 9 / 16;
}

.hero-video--landscape {
	width: clamp(280px, 42vw, 520px);
	aspect-ratio: 16 / 9;
}

.hero-video__iframe,
.hero-video__file {
	display: block;
	width: 100%;
	height: 100%;
	border: 0;
	object-fit: cover;
	object-position: center center;
	background: #111;
}

.hero-video-mobile-section {
	display: none;
}

.hero-legacy__col--left .hero-video-wrap.hero-video--desktop {
	display: inline-block;
}

.hero-video-below-section {
	display: block;
	text-align: center;
	padding: 0 1rem;
	margin-top: -0.25rem;
	margin-bottom: 0.5rem;
}

.hero-video-below-section .hero-video-wrap.hero-video--mobile {
	display: inline-block;
}

@media (max-width: 768px) {
	.hero-legacy,
	.sub-page-head {
		height: var(--hero-visual-mobile-height);
		min-height: var(--hero-visual-mobile-height);
	}

	.sub-page-head:not(.sub-page-head--minimal) {
		background-image: var(--sub-visual-mobile, var(--sub-visual-pc));
	}

	.sub-page-bar__inner {
		align-items: flex-start;
		flex-direction: column;
		gap: 0.75rem;
		padding: 2rem 0 0;
	}

	.sub-page-bar__menu {
		line-height: 1.35;
	}

	.sub-page-bar__menu.text-6 {
		font-size: 1.625rem !important;
	}

	.sub-page-bar__breadcrumb {
		align-self: flex-start;
		padding: 0.45rem 0.85rem;
	}

	.sub-page-bar__trail {
		font-size: 12px;
	}

	.hero-legacy {
		background-image: url('/img/tmp/hero-mobile.svg');
		background-size: cover;
	}

	.hero-legacy--overlay .countdown-modern--hero {
		display: none;
	}

	.hero-video-wrap.hero-video--desktop {
		display: none;
	}

	.hero-video-mobile-section {
		display: block;
		text-align: center;
		padding: 0 1rem;
		margin-top: -0.25rem;
		margin-bottom: 0.5rem;
	}

	.hero-video-wrap.hero-video--mobile {
		display: inline-block;
	}

	.hero-video-wrap.hero-video--mobile .hero-video--portrait {
		width: clamp(180px, 52vw, 240px);
	}

	.hero-video-wrap.hero-video--mobile .hero-video--landscape {
		width: min(100%, 420px);
	}
}

#header .header-logo {
	margin: 0 1rem 0 0;
}

#header.header-effect-shrink .header-container > .header-row {
	align-items: center;
}

html.sticky-header-active #header.header-effect-shrink .header-container > .header-row {
	align-items: center;
	min-height: 70px;
}

html.sticky-header-active #header.header-effect-shrink .header-container .header-column {
	align-self: center;
}

html.sticky-header-active #header.header-effect-shrink .header-nav {
	align-self: center;
}

#header .header-nav.header-nav-line #mainNav > li > a {
	font-size: 1rem;
	font-weight: 600;
	text-transform: none;
	letter-spacing: -0.3px;
	color: #333;
}

#header .header-nav.header-nav-line #mainNav > li > a:hover,
#header .header-nav.header-nav-line #mainNav > li.open > a,
#header .header-nav.header-nav-line #mainNav > li:hover > a {
	background: transparent !important;
	color: #333 !important;
}

#header .header-nav.header-nav-line #mainNav > li > a.active,
#header .header-nav.header-nav-line #mainNav > li > a.active:hover {
	color: var(--primary) !important;
}

@media (max-width: 991px) {
	#header .header-nav.header-nav-line #mainNav > li > a.active,
	#header .header-nav.header-nav-line #mainNav > li > a.active:hover,
	#header .header-nav.header-nav-line #mainNav > li > a.active:focus,
	#header .header-nav.header-nav-line #mainNav > li.open > a.active,
	#header .header-nav.header-nav-line #mainNav > li.dropdown.open > a.active {
		color: #fff !important;
		background: var(--primary, #0088cc) !important;
	}

	#header .header-nav.header-nav-line #mainNav > li.open > a:not(.active),
	#header .header-nav.header-nav-line #mainNav > li:hover > a:not(.active) {
		background: transparent !important;
		color: #333 !important;
	}
}

/* Language switcher dropdown */
#header .language-switcher__menu {
	min-width: 11rem;
	margin-top: 0.35rem !important;
	padding: 0.4rem;
	border: 0 !important;
	border-top: 0 !important;
	border-radius: 12px;
	background: #fff;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}

#header .language-switcher__option {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	font-size: 0.8125rem;
	padding: 0.5rem 0.65rem;
	border-radius: 8px;
	color: #666;
	transition: background-color 0.2s ease, color 0.2s ease;
}

#header .language-switcher__option-label {
	flex: 1 1 auto;
	min-width: 0;
}

#header .language-switcher__option:hover,
#header .language-switcher__option:focus {
	color: #444;
	background: rgba(0, 0, 0, 0.04) !important;
}

#header .language-switcher__option.is-active {
	color: var(--primary);
	background: var(--primary-rgba-10) !important;
	font-weight: 500;
}

#header .language-switcher__check {
	flex-shrink: 0;
	color: var(--primary);
}

#header svg.language-switcher__check.lucide {
	width: 0.875rem;
	height: 0.875rem;
	stroke-width: 2.5;
}

/* Nav submenu — 레거시 GNB 선택 효과 (좌측 바 + 연한 배경) */

#header #mainNav > li.dropdown > .nav-submenu__menu {
	min-width: 11rem;
	margin-top: 0 !important;
	padding: 0.5rem;
	border: 0 !important;
	border-top: 0 !important;
	border-radius: 12px !important;
	overflow: visible;
	background: rgba(255, 255, 255, 0.98);
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.12), 0 0 0 1px rgba(0, 0, 0, 0.04);
}

/* header-nav-main-square 가 dropdown-menu 를 border-radius:0 으로 덮어씀 */
#header .header-nav-main.header-nav-main-square nav > ul#mainNav > li.dropdown > .nav-submenu__menu {
	border-radius: 12px !important;
}

#header .nav-submenu__option {
	position: relative;
	display: flex;
	align-items: center;
	gap: 0.6rem;
	font-size: 0.93em !important;
	font-weight: 500;
	padding: 0.625rem 1rem !important;
	margin: 2px 0;
	border-radius: 8px;
	border-bottom: 0 !important;
	color: #444;
	transition: background-color 0.2s ease, color 0.2s ease, padding-left 0.2s ease;
}

#header .nav-submenu__option-label {
	flex: 1 1 auto;
	min-width: 0;
}

#header .nav-submenu__option:not(.is-active):hover,
#header .nav-submenu__option:not(.is-active):focus {
	color: var(--primary, #0088cc) !important;
	background: linear-gradient(
		135deg,
		color-mix(in srgb, var(--primary) 8%, transparent),
		color-mix(in srgb, var(--primary) 5%, transparent)
	) !important;
	padding-left: 1.375rem !important;
}

#header .nav-submenu__option:not(.is-active):hover::before,
#header .nav-submenu__option:not(.is-active):focus::before {
	content: '';
	position: absolute;
	left: 0.5rem;
	top: 50%;
	transform: translateY(-50%);
	width: 4px;
	height: 1rem;
	background: var(--primary, #0088cc);
	border-radius: 2px;
}

#header .nav-submenu__option.is-active,
#header .nav-submenu__option.is-active:hover,
#header .nav-submenu__option.is-active:focus,
#header .nav-submenu__option.active,
#header .nav-submenu__option.active:hover,
#header .nav-submenu__option.active:focus {
	color: var(--primary, #0088cc) !important;
	background: linear-gradient(
		135deg,
		color-mix(in srgb, var(--primary) 8%, transparent),
		color-mix(in srgb, var(--primary) 5%, transparent)
	) !important;
	font-weight: 600 !important;
	font-size: 0.93em !important;
	padding-left: 1.375rem !important;
}

#header .nav-submenu__option.is-active::before,
#header .nav-submenu__option.is-active:hover::before,
#header .nav-submenu__option.is-active:focus::before,
#header .nav-submenu__option.active::before {
	content: '';
	position: absolute;
	left: 0.5rem;
	top: 50%;
	transform: translateY(-50%);
	width: 4px;
	height: 1rem;
	background: var(--primary, #0088cc);
	border-radius: 2px;
}

#header .nav-submenu__option.is-active .nav-submenu__option-label,
#header .nav-submenu__option.is-active:hover .nav-submenu__option-label,
#header .nav-submenu__option.is-active:focus .nav-submenu__option-label {
	color: inherit;
	font-weight: 600;
}

@media (min-width: 992px) {
	#header .header-nav-main #mainNav > li.dropdown {
		position: relative;
	}

	#header .header-nav-main #mainNav > li.dropdown.open > a,
	#header .header-nav-main #mainNav > li.dropdown:hover > a,
	#header .header-nav-main #mainNav > li.dropdown.accessibility-open > a {
		border-radius: 0 !important;
	}

	#header .header-nav-main #mainNav > li.dropdown:hover > .nav-submenu__menu,
	#header .header-nav-main #mainNav > li.dropdown.open > .nav-submenu__menu,
	#header .header-nav-main #mainNav > li.dropdown.accessibility-open > .nav-submenu__menu {
		top: 100% !important;
		margin-top: 0 !important;
		opacity: 1 !important;
		transform: none !important;
		pointer-events: auto;
		border-radius: 12px !important;
		overflow: visible;
	}

	/* 대메뉴 → 서브메뉴 이동 시 hover 끊김 방지 (dead zone 브릿지) */
	#header .header-nav-main #mainNav > li.dropdown > .nav-submenu__menu::before {
		content: '';
		position: absolute;
		top: -12px;
		left: 0;
		right: 0;
		height: 12px;
	}

	#header .header-nav-main #mainNav > li.dropdown .nav-submenu__menu li a {
		transform: none !important;
		border-bottom: 0 !important;
	}

	#header .header-nav-main #mainNav > li.dropdown .nav-submenu__menu li:hover > a,
	#header .header-nav-main #mainNav > li.dropdown .nav-submenu__menu li:focus > a {
		background-color: transparent;
	}

	#header .header-nav.header-nav-line #mainNav > li.dropdown > a.active,
	#header .header-nav.header-nav-line #mainNav > li.dropdown > a.active:hover {
		color: var(--primary) !important;
	}
}

@media (max-width: 991px) {
	#header #mainNav > li.dropdown > .nav-submenu__menu {
		position: static !important;
		float: none;
		width: auto;
		margin: 0.35rem 0 0.5rem 0.75rem !important;
		padding: 0.35rem;
		border: 0 !important;
		border-radius: 12px !important;
		overflow: hidden;
		background: rgba(0, 0, 0, 0.03);
		box-shadow: none;
	}

	#header #mainNav > li.dropdown > .nav-submenu__menu .nav-submenu__option {
		font-size: 0.875rem;
		padding: 0.55rem 0.7rem;
	}
}

@media (min-width: 992px) {
	#header .header-nav-main nav {
		display: flex;
		align-items: center;
		flex-wrap: nowrap;
		gap: 0.5rem 1.25rem;
	}

	#header .header-actions {
		display: flex;
		align-items: center;
		gap: 0.5rem;
		flex-shrink: 0;
		margin-left: 0.25rem;
		padding-left: 1.25rem;
		border-left: 1px solid rgba(0, 0, 0, 0.08);
	}
}

#header .header-action-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.45rem;
	padding: 0.55rem 1.1rem;
	border-radius: 999px;
	font-size: 0.875rem;
	font-weight: 600;
	line-height: 1.35;
	letter-spacing: -0.02em;
	text-decoration: none;
	white-space: nowrap;
	border: 1px solid transparent;
	transition: background-color 0.22s ease, border-color 0.22s ease, color 0.22s ease;
}

#header .header-action-btn__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.15rem;
	height: 1.15rem;
	border-radius: 50%;
	font-size: 0.55rem;
	transition: transform 0.22s ease, background-color 0.22s ease;
}

#header .header-action-btn__icon svg.lucide-icon {
	width: 0.65rem;
	height: 0.65rem;
	stroke-width: 2.5;
}

#header .header-btn-collapse-nav svg.lucide-icon {
	width: 1.25rem;
	height: 1.25rem;
}

#header .header-action-btn--ghost {
	background: rgba(0, 0, 0, 0.03);
	color: #555;
	border-color: rgba(0, 0, 0, 0.08);
}

#header .header-action-btn--ghost:hover {
	background: rgba(0, 0, 0, 0.06);
	border-color: rgba(0, 0, 0, 0.12);
	color: #333;
}

#header .header-action-btn--ghost .header-action-btn__icon {
	background: rgba(0, 0, 0, 0.06);
	color: #666;
}

#header .header-action-btn--ghost:hover .header-action-btn__icon {
	background: rgba(0, 0, 0, 0.09);
	color: #444;
}

#header .header-action-btn--primary {
	background: var(--primary);
	color: #fff;
	border-color: var(--primary);
}

#header .header-action-btn--primary .header-action-btn__icon {
	background: rgba(255, 255, 255, 0.18);
}

#header .header-action-btn--primary:hover {
	background: var(--primary--100, #0077b3);
	border-color: var(--primary--100, #0077b3);
	color: #fff;
}

#header .header-action-btn--primary:hover .header-action-btn__icon {
	transform: translateX(2px);
}

/* ==========================================================================
   btn-modern — 사이트 공통 (게시판·공모요강·CTA 통일)
   ========================================================================== */
html .btn.btn-modern,
html .button-group .btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.35rem;
	margin: 0;
	padding: 0.6rem 1.8rem;
	font-size: 0.9rem;
	font-weight: 600;
	border-radius: 6px;
	text-transform: none;
	letter-spacing: -0.02em;
	line-height: 1.35;
	transition: filter 0.2s ease, background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

html .btn.btn-modern.btn-lg {
	padding: 0.75rem 2rem;
}

html .btn.btn-modern.btn-sm {
	padding: 0.45rem 1rem;
	font-size: 0.8125rem;
}

html .btn.btn-modern .lucide-icon svg.lucide,
html .btn.btn-modern svg.lucide.lucide-icon {
	width: 1rem;
	height: 1rem;
	flex-shrink: 0;
}

html .btn-primary.btn-modern,
html .btn-primary.btn-modern:hover,
html .btn-primary.btn-modern:focus,
html .btn-primary.btn-modern:active,
html .btn-primary.btn-modern:not(:disabled):not(.disabled):active {
	background: var(--primary, #0088cc) !important;
	background-image: none !important;
	border-color: var(--primary, #0088cc) !important;
	color: #fff !important;
	box-shadow: none !important;
	transform: none;
}

html .btn-primary.btn-modern:hover {
	filter: brightness(1.03);
	color: #fff !important;
}

html .btn-primary.btn-modern:active,
html .btn-primary.btn-modern:not(:disabled):not(.disabled):active {
	filter: brightness(0.95);
	color: #fff !important;
}

html .btn-primary.btn-modern:focus,
html .btn-primary.btn-modern:focus-visible {
	box-shadow: 0 0 0 2px color-mix(in srgb, var(--primary) 35%, transparent) !important;
}

html .btn-secondary.btn-modern,
html .btn-secondary.btn-modern:hover,
html .btn-secondary.btn-modern:focus,
html .btn-secondary.btn-modern:active,
html .btn-secondary.btn-modern:not(:disabled):not(.disabled):active {
	background: #f5f6f8 !important;
	background-image: none !important;
	border-color: #dee2e6 !important;
	color: #4b5563 !important;
	font-weight: 500;
	box-shadow: none !important;
	transform: none;
	filter: none;
}

html .btn-secondary.btn-modern:hover,
html .btn-secondary.btn-modern:focus,
html .btn-secondary.btn-modern:focus-visible {
	background: #ebedf0 !important;
	border-color: #ccc !important;
	color: #374151 !important;
}

html .btn-secondary.btn-modern:active,
html .btn-secondary.btn-modern:not(:disabled):not(.disabled):active {
	background: #dde1e6 !important;
	border-color: #aeb6c2 !important;
	color: #374151 !important;
}

html .btn-warning.btn-modern,
html .btn-warning.btn-modern:hover,
html .btn-warning.btn-modern:focus,
html .btn-warning.btn-modern:active,
html .btn-warning.btn-modern:not(:disabled):not(.disabled):active {
	background: #f59e0b !important;
	background-image: none !important;
	border-color: #f59e0b !important;
	color: #fff !important;
	box-shadow: none !important;
	transform: none;
}

html .btn-warning.btn-modern:hover {
	filter: brightness(0.95);
	color: #fff !important;
}

html .btn-danger.btn-modern,
html .btn-danger.btn-modern:hover,
html .btn-danger.btn-modern:focus,
html .btn-danger.btn-modern:active,
html .btn-danger.btn-modern:not(:disabled):not(.disabled):active {
	background: #ef4444 !important;
	background-image: none !important;
	border-color: #ef4444 !important;
	color: #fff !important;
	box-shadow: none !important;
	transform: none;
}

html .btn-danger.btn-modern:hover {
	filter: brightness(0.95);
	color: #fff !important;
}

@media (prefers-reduced-motion: reduce) {
	html .btn.btn-modern,
	html .button-group .btn {
		transition: none;
	}
}

@media (max-width: 991px) {
	#header .header-nav-main nav.show,
	#header .header-nav-main nav.collapsing {
		display: flex;
		flex-direction: column;
		align-items: stretch;
	}

	#header .header-nav-main nav.show > #mainNav,
	#header .header-nav-main nav.collapsing > #mainNav {
		width: 100%;
	}

	#header .header-actions {
		display: flex;
		flex-direction: column;
		gap: 0.5rem;
		width: 100%;
		margin-top: 0.75rem;
		padding-top: 0.85rem;
		border-top: 1px solid rgba(0, 0, 0, 0.08);
	}

	#header .header-action-btn {
		width: 100%;
		padding: 0.75rem 1rem;
		font-size: 0.9375rem;
	}
}

#header .header-top-borders {
	border-bottom-color: rgba(0, 0, 0, 0.06);
}

#header .container {
	position: relative;
}

@media (max-width: 767px) {
	#header .container {
		width: 100%;
	}
}

#header .header-top-social-icons {
	margin-left: 0;
	margin-right: 0.75rem;
}

#header .header-top-social-icons li {
	margin-right: 0.35rem;
}

#header .header-top-social-icons li:last-child {
	margin-right: 0;
}

#header .header-language-switcher {
	display: inline-flex;
	align-items: center;
	padding-left: 0.75rem;
	margin-left: 0.25rem;
	border-left: 1px solid rgba(0, 0, 0, 0.05);
}

#header .language-switcher__toggle {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.35rem 0.75rem;
	border: 0;
	border-radius: 999px;
	background: rgba(0, 0, 0, 0.04);
	font-size: 0.8125rem;
	font-weight: 500;
	line-height: 1.4;
	color: #666;
	transition: background-color 0.25s ease, color 0.25s ease, box-shadow 0.25s ease;
}

#header .language-switcher__toggle:hover,
#header .language-switcher__toggle:focus,
#header .language-switcher__toggle.show {
	color: #444;
	background: rgba(0, 0, 0, 0.06);
	box-shadow: none;
}

#header .language-switcher__trigger-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1rem;
	height: 1rem;
	font-size: 0.8rem;
	opacity: 0.75;
}

#header .language-switcher__trigger-icon .flag {
	margin: 0;
}

#header .language-switcher__caret {
	display: inline-flex;
	transition: transform 0.25s ease, opacity 0.25s ease;
}

#header svg.language-switcher__caret.lucide {
	width: 0.55rem;
	height: 0.55rem;
	opacity: 0.45;
}

#header .language-switcher__toggle.show .language-switcher__caret {
	transform: rotate(180deg);
}

#header .language-switcher__toggle.show svg.language-switcher__caret.lucide {
	opacity: 0.65;
}

#header .language-switcher__trigger-icon svg.lucide-icon {
	width: 0.8rem;
	height: 0.8rem;
	opacity: 0.75;
}

#header .language-switcher__option-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.25rem;
	flex-shrink: 0;
}

#header .language-switcher__option-icon .flag {
	margin: 0;
}

#header .language-switcher__code {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.25rem;
	height: 1.25rem;
	border-radius: 50%;
	background: rgba(0, 0, 0, 0.06);
	font-size: 0.625rem;
	font-weight: 600;
	letter-spacing: 0.02em;
	color: #888;
}

#header .language-switcher__option.is-active .language-switcher__code {
	background: var(--primary-rgba-20);
	color: var(--primary);
}

@media (max-width: 575px) {
	#header .language-switcher__label {
		display: none;
	}

	#header .language-switcher__toggle {
		padding: 0.4rem 0.55rem;
	}

	#header .header-logo img {
		width: 80% !important;
		height: auto !important;
	}
}

/* Home hub — 공모주제·응모대상 + 바로가기 카드 + 공지 */
.home-highlights {
	margin-bottom: 1.5rem;
}

.home-highlights__track {
	display: flex;
	align-items: stretch;
	border-radius: 16px;
	border: 1px solid #e2e8ef;
	background: #fff;
	overflow: hidden;
	box-shadow: 0 4px 24px rgba(26, 33, 48, 0.04);
}

.home-highlights__panel {
	flex: 1 1 0;
	min-width: 0;
	display: flex;
	align-items: center;
	gap: 1.25rem;
	padding: 1.35rem 1.5rem;
}

.home-highlights__panel--theme {
	flex: 2 1 0;
	background: linear-gradient(
		135deg,
		color-mix(in srgb, var(--primary) 7%, #fff) 0%,
		#fff 55%
	);
}

.home-highlights__panel--eligibility {
	flex: 3 1 0;
	background: linear-gradient(
		135deg,
		#fff 45%,
		color-mix(in srgb, var(--primary) 5%, #f8fafc) 100%
	);
}

.home-highlights__divider {
	flex: 0 0 1px;
	align-self: stretch;
	background: linear-gradient(
		180deg,
		transparent 0%,
		#e2e8ef 18%,
		#e2e8ef 82%,
		transparent 100%
	);
}

.home-highlights__head {
	flex-shrink: 0;
}

.home-highlights__badge {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	padding: 0.45rem 0.85rem;
	border-radius: 999px;
	font-size: 0.8125rem;
	font-weight: 700;
	line-height: 1;
	letter-spacing: -0.02em;
	color: var(--primary);
	background: color-mix(in srgb, var(--primary) 14%, #fff);
	border: 1px solid color-mix(in srgb, var(--primary) 28%, transparent);
	white-space: nowrap;
}

.home-highlights__badge-icon {
	width: 0.95rem;
	height: 0.95rem;
}

.home-highlights__body {
	flex: 1 1 auto;
	min-width: 0;
}

.home-highlights__theme-text {
	margin: 0;
	font-size: clamp(1.125rem, 2vw, 1.5rem);
	font-weight: 700;
	line-height: 1.35;
	letter-spacing: -0.03em;
	color: #1a2130;
	word-break: keep-all;
}

.home-highlights__theme-sub {
	margin: 0.35rem 0 0;
	font-size: 0.875rem;
	font-weight: 500;
	line-height: 1.5;
	color: #667085;
}

.home-highlights__eligibility-text {
	margin: 0;
	font-size: 1rem;
	font-weight: 600;
	line-height: 1.55;
	letter-spacing: -0.02em;
	color: #1a2130;
	word-break: keep-all;
}

.home-highlights__divisions {
	display: flex;
	flex-wrap: nowrap;
	gap: 0.4rem;
	margin: 0.85rem 0 0;
	padding: 0;
	list-style: none;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
}

.home-highlights__divisions::-webkit-scrollbar {
	display: none;
}

.home-highlights__division {
	display: inline-flex;
	flex-shrink: 0;
	align-items: center;
	gap: 0.25rem;
	padding: 0.4rem 0.65rem;
	border-radius: 8px;
	font-size: 0.8125rem;
	line-height: 1.3;
	white-space: nowrap;
	color: #1a2130;
	background: color-mix(in srgb, var(--primary) 8%, #fff);
	border: 1px solid color-mix(in srgb, var(--primary) 16%, #e2e8ef);
}

.home-highlights__division-name {
	font-weight: 700;
	color: #1a2130;
}

.home-highlights__division-desc {
	font-weight: 500;
	color: #667085;
}

@media (max-width: 991px) {
	.home-highlights__track {
		flex-direction: column;
	}

	.home-highlights__divider {
		flex: 0 0 auto;
		width: 100%;
		height: 1px;
		background: linear-gradient(
			90deg,
			transparent 0%,
			#e2e8ef 12%,
			#e2e8ef 88%,
			transparent 100%
		);
	}

	.home-highlights__panel {
		flex-direction: column;
		align-items: flex-start;
		gap: 0.85rem;
		padding: 1.15rem 1.25rem;
	}
}

@media (max-width: 575px) {
	.home-highlights {
		margin-bottom: 1.25rem;
	}

	.home-highlights__theme-text {
		font-size: 1.125rem;
	}

	.home-highlights__eligibility-text {
		font-size: 0.9375rem;
	}
}

.home-hub {
	--home-notice-font-size: 0.9375rem;
	--home-notice-line-height: 1.5;
	--home-notice-max-items: 4;
	--home-notice-item-height: calc(var(--home-notice-font-size) * var(--home-notice-line-height) + 1rem);
	--home-notice-list-min-height: calc(var(--home-notice-item-height) * var(--home-notice-max-items));
	padding: 2.5rem 0;
	background: #fff;
}

.home-hub-cards {
	margin-top: 0;
	margin-bottom: 0;
}

/* 바로가기 — 타일 카드 */
.home-tile-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	height: 100%;
	padding: 1.1rem 0.75rem 1.05rem;
	border-radius: 16px;
	border: 1px solid #e2e8ef;
	background: #fff;
	position: relative;
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	gap: 1rem;
	isolation: isolate;
	transition: border-color 0.3s ease, transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}

.home-tile-card::before {
	content: "";
	position: absolute;
	inset: 0;
	background: var(--primary);
	transform: scaleY(0);
	transform-origin: bottom center;
	transition: transform 0.42s cubic-bezier(0.22, 1, 0.36, 1);
	z-index: 0;
}

.home-tile-card:hover,
.home-tile-card:focus-visible {
	border-color: var(--primary);
	transform: translateY(-4px);
	text-decoration: none;
	color: inherit;
}

.home-tile-card:hover::before,
.home-tile-card:focus-visible::before {
	transform: scaleY(1);
}

.home-tile-card__visual {
	position: relative;
	z-index: 1;
	width: 118px;
	height: 118px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.home-tile-card__visual::before {
	content: "";
	position: absolute;
	width: 100px;
	height: 100px;
	border-radius: 50%;
	border: 1px solid color-mix(in srgb, var(--primary) 16%, transparent);
	box-shadow:
		0 0 14px var(--primary-rgba-10),
		0 0 28px color-mix(in srgb, var(--primary) 5%, transparent);
	pointer-events: none;
	transition: border-color 0.35s ease, box-shadow 0.35s ease;
}

.home-tile-card__icon {
	position: relative;
	z-index: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 0;
	transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}

.home-tile-card__icon .lucide-icon {
	color: var(--primary);
	transition: color 0.3s ease;
}

.home-tile-card__icon svg.lucide-icon {
	width: 2.875rem;
	height: 2.875rem;
	stroke-width: 1.9;
	transform: scale(var(--lucide-optical-scale, 1));
	transform-origin: center;
}

.home-tile-card__icon svg.lucide-icon[data-lucide="file-text"] {
	--lucide-optical-scale: 1.1;
}

.home-tile-card__icon svg.lucide-icon[data-lucide="book-open"] {
	--lucide-optical-scale: 1.06;
}

.home-tile-card:hover .home-tile-card__visual::before,
.home-tile-card:focus-visible .home-tile-card__visual::before {
	border-color: rgba(255, 255, 255, 0.35);
	box-shadow:
		0 0 16px rgba(255, 255, 255, 0.2),
		0 0 32px rgba(255, 255, 255, 0.08);
}

.home-tile-card:hover .home-tile-card__icon,
.home-tile-card:focus-visible .home-tile-card__icon {
	transform: scale(1.05);
}

.home-tile-card:hover .home-tile-card__icon .lucide-icon,
.home-tile-card:focus-visible .home-tile-card__icon .lucide-icon {
	color: #fff;
}

.home-tile-card__label {
	position: relative;
	z-index: 1;
	display: inline-block;
	max-width: 100%;
	padding-bottom: 0.55rem;
	font-weight: 600;
	font-size: 1.0625rem;
	line-height: 1.35;
	letter-spacing: -0.03em;
	color: #1a2130;
	text-align: center;
	transition: color 0.3s ease;
}

.home-tile-card__label::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: 0;
	width: 1.125rem;
	height: 2px;
	border-radius: 2px;
	background: var(--primary);
	transform: translateX(-50%);
	transition: width 0.38s cubic-bezier(0.22, 1, 0.36, 1), background-color 0.3s ease;
}

.home-tile-card:hover .home-tile-card__label,
.home-tile-card:focus-visible .home-tile-card__label {
	color: #fff;
}

.home-tile-card:hover .home-tile-card__label::after,
.home-tile-card:focus-visible .home-tile-card__label::after {
	width: 100%;
	background: rgba(255, 255, 255, 0.85);
}

@media (prefers-reduced-motion: reduce) {
	.home-tile-card,
	.home-tile-card::before,
	.home-tile-card__visual::before,
	.home-tile-card__icon,
	.home-tile-card__icon .lucide-icon,
	.home-tile-card__label,
	.home-tile-card__label::after {
		transition: none;
	}

	.home-tile-card:hover,
	.home-tile-card:focus-visible {
		transform: none;
	}

	.home-tile-card:hover::before,
	.home-tile-card:focus-visible::before {
		transform: scaleY(1);
	}

	.home-tile-card:hover .home-tile-card__icon,
	.home-tile-card:focus-visible .home-tile-card__icon {
		transform: none;
	}

	.home-tile-card:hover .home-tile-card__label::after,
	.home-tile-card:focus-visible .home-tile-card__label::after {
		width: 100%;
	}
}

.home-notice-card {
	border-radius: 16px;
	overflow: hidden;
	border: 1px solid #e2e8ef;
	background: #fff;
	display: flex;
	flex-direction: column;
}

.home-notice-card .card-body {
	padding: 1.75rem;
	display: flex;
	flex-direction: column;
	flex: 1 1 auto;
}

.home-notice-card__header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-bottom: 1rem;
	margin-bottom: 1rem;
	border-bottom: 1px solid #eef2f6;
}

.home-notice-card__heading {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--primary);
}

.home-notice-card__heading .lucide-icon {
	color: var(--primary);
}

.home-notice-card__heading svg.lucide-icon {
	width: 1rem;
	height: 1rem;
	stroke-width: 2.25;
}

.home-notice-card__more {
	display: inline-flex;
	align-items: center;
	gap: 0.2rem;
	padding: 0.4rem 0.75rem;
	border-radius: 8px;
	font-size: 0.8125rem;
	font-weight: 600;
	line-height: 1;
	letter-spacing: -0.01em;
	color: var(--primary);
	background: color-mix(in srgb, var(--primary) 6%, transparent);
	border: 1px solid color-mix(in srgb, var(--primary) 18%, transparent);
	text-decoration: none;
	transition: background-color 0.22s ease, border-color 0.22s ease, color 0.22s ease, transform 0.22s ease;
}

.home-notice-card__more svg.lucide-icon {
	width: 0.85rem;
	height: 0.85rem;
	stroke-width: 2.5;
	transition: transform 0.22s ease;
}

.home-notice-card__more:hover {
	color: var(--primary);
	background: color-mix(in srgb, var(--primary) 12%, transparent);
	border-color: color-mix(in srgb, var(--primary) 32%, transparent);
	transform: translateY(-1px);
}

.home-notice-card__more:hover svg.lucide-icon {
	transform: translateX(2px);
}

.home-notice-list {
	flex: 1 1 auto;
	min-height: var(--home-notice-list-min-height);
}

.home-notice-list--empty {
	display: flex;
	align-items: center;
	justify-content: center;
}

.home-notice-list--empty .home-notice-empty {
	height: auto;
	width: 100%;
}

.home-notice-list__item {
	padding: 0.5rem 0;
	border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

.home-notice-list__item:first-child {
	padding-top: 0;
}

.home-notice-list__item:last-child {
	border-bottom: 0;
	padding-bottom: 0;
}

.home-notice-list__text {
	display: flex;
	align-items: center;
	gap: 0.35rem;
	min-width: 0;
	font-size: var(--home-notice-font-size);
	line-height: var(--home-notice-line-height);
	color: #333;
}

.home-notice-list__text::before {
	content: "\2022";
	flex-shrink: 0;
	font-weight: bold;
	color: var(--primary);
}

.home-notice-list__text a {
	flex: 1 1 auto;
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	color: inherit;
	text-decoration: none;
	transition: color 0.2s ease;
}

.home-notice-list__text a:hover {
	color: var(--primary);
}

.home-notice-list__badge {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	padding: 0.1rem 0.4rem;
	border-radius: 4px;
	font-size: 0.6875rem;
	font-weight: 600;
	line-height: 1.2;
	color: var(--primary);
	background: var(--primary-rgba-10);
}

.home-notice-list__date {
	flex-shrink: 0;
	font-size: 0.8125rem;
	color: #999;
	font-variant-numeric: tabular-nums;
	white-space: nowrap;
}

.home-notice-empty {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	margin: 0;
	padding: 0;
	text-align: center;
	font-size: var(--home-notice-font-size);
	line-height: var(--home-notice-line-height);
	color: #999;
}

@media (max-width: 575px) {
	.home-tile-card {
		padding: 0.95rem 0.6rem 0.9rem;
		gap: 0.8rem;
	}

	.home-tile-card__visual {
		width: 104px;
		height: 104px;
	}

	.home-tile-card__visual::before {
		width: 88px;
		height: 88px;
	}

	.home-tile-card__icon svg.lucide-icon {
		width: 2.5rem;
		height: 2.5rem;
	}

	.home-tile-card__label {
		font-size: 0.9375rem;
		padding-bottom: 0.45rem;
	}

	.home-notice-card .card-body {
		padding: 1.25rem;
	}
}

/* Footer — split layout (policy left / contact+logos right) */
#footer.footer-filaflow {
	background: #f8f9fa;
	border-top: 1px solid rgba(0, 0, 0, 0.06) !important;
	margin-top: 0;
	margin-bottom: 0;
	padding-bottom: 0;
}

#footer.footer-filaflow h1,
#footer.footer-filaflow h2,
#footer.footer-filaflow h3,
#footer.footer-filaflow h4,
#footer.footer-filaflow h5,
#footer.footer-filaflow h6 {
	color: #333;
}

#footer.footer-filaflow a:not(.btn):not(.no-footer-css):not(.footer-filaflow__policy-link) {
	color: #555;
}

#footer.footer-filaflow a:not(.btn):not(.no-footer-css):not(.footer-filaflow__policy-link):hover {
	color: var(--primary);
}

#footer.footer-filaflow .footer-copyright.footer-copyright-style-light {
	background: #eef1f5;
	border-top: 1px solid rgba(0, 0, 0, 0.06);
	margin: 0;
	padding: 0.45rem 0;
}

#footer.footer-filaflow .footer-copyright .container {
	margin-bottom: 0;
	padding-top: 0;
	padding-bottom: 0;
}

#footer.footer-filaflow .footer-filaflow__copyright {
	font-size: 0.8rem;
	color: #999;
	line-height: 1.3;
	margin: 0;
}

#footer.footer-filaflow a.footer-filaflow__policy-link {
	font-size: 0.88rem;
	font-weight: 600;
	color: #666;
	text-decoration: none;
}

#footer.footer-filaflow a.footer-filaflow__policy-link:hover,
#footer.footer-filaflow a.footer-filaflow__policy-link:focus,
#footer.footer-filaflow a.footer-filaflow__policy-link:active {
	color: color-mix(in srgb, var(--primary, #0088cc) 70%, #666);
	text-decoration: underline;
}

#footer.footer-filaflow .footer-filaflow__policy-sep {
	margin: 0 0.5rem;
	color: #ccc;
}

#footer.footer-filaflow .footer-filaflow__office-title {
	font-size: 0.92rem;
	font-weight: 700;
	color: #333;
}

#footer.footer-filaflow .footer-filaflow__info-text {
	font-size: 0.9rem;
	color: #666;
	line-height: 1.8;
}

#footer.footer-filaflow .footer-filaflow__contact-label {
	color: #333;
	font-weight: 600;
	font-size: 0.92rem;
	margin-right: 0.75rem;
}

#footer.footer-filaflow svg.footer-filaflow__info-icon.lucide {
	width: 0.85rem;
	height: 0.85rem;
	stroke-width: 2.25;
	color: var(--primary);
}

#footer.footer-filaflow .footer-filaflow__info-icon {
	display: inline-flex;
	align-items: center;
	margin-right: 0.25rem;
}

#footer.footer-filaflow .footer-filaflow__kakao-icon {
	display: inline-block;
	width: 1rem;
	height: 1rem;
	margin-right: 0.25rem;
	object-fit: contain;
	flex-shrink: 0;
}

#footer.footer-filaflow .footer-filaflow__contact-lines {
	display: inline;
}

#footer.footer-filaflow .footer-filaflow__info-line {
	display: inline-flex;
	align-items: center;
}

#footer.footer-filaflow .footer-filaflow__info-sep {
	margin: 0 0.5rem;
	color: #ccc;
}

#footer.footer-filaflow .footer-filaflow__logo-col {
	text-align: right;
}

#footer.footer-filaflow .footer-filaflow__logo-area {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	justify-content: center;
	gap: 1rem;
	width: 100%;
	height: 100%;
	margin-left: auto;
}

#footer.footer-filaflow .footer-filaflow__logo-group {
	display: flex;
	flex-wrap: nowrap;
	align-items: center;
	justify-content: flex-end;
	gap: 1rem;
	width: 100%;
	max-width: 100%;
	margin-left: auto;
}

#footer.footer-filaflow .footer-filaflow__logo-item {
	flex: 0 0 auto;
}

#footer.footer-filaflow .footer-filaflow__contact {
	text-align: right;
}

#footer.footer-filaflow .footer-filaflow__primary-contact .footer-filaflow__contact-lines,
#footer.footer-filaflow .footer-filaflow__extra-inquiry .footer-filaflow__contact-lines {
	display: inline-flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-end;
	gap: 0;
}

#footer.footer-filaflow .footer-partner-logo-item {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: center;
	justify-content: center;
	gap: 0.55rem;
	flex-shrink: 0;
	white-space: nowrap;
}

#footer.footer-filaflow .footer-partner-logo-item__label {
	flex-shrink: 0;
	font-size: 0.82rem;
	font-weight: 600;
	color: #555;
	white-space: nowrap;
}

#footer.footer-filaflow .footer-partner-logo-item__image {
	display: flex;
	align-items: center;
	justify-content: center;
	min-width: 0;
}

#footer.footer-filaflow .footer-partner-logo-item__link {
	display: flex;
	align-items: center;
	justify-content: center;
}

#footer.footer-filaflow .footer-partner-logo-item__link img {
	width: auto;
	max-width: none;
	object-fit: contain;
	display: block;
}

@media (max-width: 767px) {
	#footer.footer-filaflow .footer-filaflow__left {
		text-align: center;
	}

	#footer.footer-filaflow .footer-filaflow__logo-col {
		text-align: center;
	}

	#footer.footer-filaflow .footer-filaflow__logo-area {
		align-items: center;
		justify-content: center;
		height: auto;
		margin-top: 1.2rem;
		padding-top: 1rem;
		border-top: 1px solid #e0e0e0;
	}

	#footer.footer-filaflow .footer-filaflow__logo-group {
		justify-content: center;
		flex-wrap: nowrap;
		gap: 0.65rem;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}

	#footer.footer-filaflow .footer-filaflow__contact {
		text-align: center;
	}

	#footer.footer-filaflow .footer-filaflow__primary-contact .footer-filaflow__contact-lines,
	#footer.footer-filaflow .footer-filaflow__extra-inquiry .footer-filaflow__contact-lines {
		flex-direction: row;
		flex-wrap: wrap;
		justify-content: center;
	}

	#footer.footer-filaflow .footer-filaflow__contact-lines {
		display: flex;
		flex-direction: column;
		align-items: center;
		gap: 0.4rem;
	}

	#footer.footer-filaflow .footer-filaflow__info-sep {
		display: none;
	}

	#footer.footer-filaflow .footer-filaflow__primary-contact .footer-filaflow__info-sep,
	#footer.footer-filaflow .footer-filaflow__extra-inquiry .footer-filaflow__info-sep {
		display: inline;
	}

	#footer.footer-filaflow .footer-filaflow__info-line {
		justify-content: center;
	}

	#footer.footer-filaflow .footer-partner-logo-item__link img {
		height: 28px !important;
		width: auto !important;
	}
}
