@charset "utf-8";

body {
	background: #F8FAFC;
}

/* 회원가입 이메일 자동완성 */
.autocomplete-suggestions {
	border: 1px solid #ccc;
	max-height: 150px;
	overflow-y: auto;
	position: relative;
	/* 	position: absolute;  */
	background-color: white;
	z-index: 1000;
	width: calc(100% - 22px);
}

/* ============== 쇼핑몰 브랜드(brand) - shopj02 brand02 기준 ============== */
.brand_wrap {
	padding-top: 30px;
}

.brand_wrap .common_tit {
	padding: 30px 30px 10px;
	text-align: center;
	font-size: 28px;
	color: #111;
}

.brand_wrap .common_desc {
	font-size: 16px;
	color: #666;
	margin: 8px 0 30px;
	text-align: center;
}

.brand_wrap .tab {
	width: 100%;
	overflow: hidden;
	margin-bottom: 30px;
	border: 0;
}

.brand_wrap .tab li {
	width: 16.66666666666667%;
	float: left;
}

.brand_wrap .tab li a {
	display: block;
	height: 41px;
	border: 1px solid #d9d9d9;
	font-size: 16px;
	color: #444;
	line-height: 2.5;
	text-align: center;
	border-right-width: 0;
}

.brand_wrap .tab li:nth-of-type(6n) a {
	border-right-width: 1px;
}

.brand_wrap .tab li:nth-of-type(n+7) a {
	border-top: 0;
}

.brand_wrap .tab li.on a {
	border-color: #007bc8;
	background: #007bc8;
	color: #fff;
	font-weight: 700;
	border-left: 1px solid #007bc8;
}

.brand_wrap .tab li:hover a {
	border-color: #007bc8;
	background: #007bc8;
	color: #fff;
	font-weight: 700;
	border-left: 1px solid #007bc8;
}

.brand_wrap .prd_list_wrap {}

.brand_wrap .prd_list {
	overflow: hidden;
}

.brand_wrap .prd_list li {
	float: left;
	width: 32%;
	margin-right: 2%;
	margin-bottom: 2%;
}

.brand_wrap .prd_list li:nth-of-type(3n) {
	margin-right: 0;
}

.brand_wrap .prd_list li>a {
	display: block;
	position: relative;
	padding-top: 100%;
	overflow: hidden;
}

.brand_wrap .prd_list li>a img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.brand_wrap .brand_info {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	text-align: center;
	background: rgba(0, 0, 0, 0.05);
}

.brand_wrap .brand_info:hover {
	background: rgba(0, 0, 0, 0.2);
}

.brand_wrap .brand_name {
	width: 100%;
	position: absolute;
	top: 50%;
	margin-top: -16px;
	text-align: center;
	color: #fff;
	line-height: 1.2em;
	font-weight: bold;
	font-size: 30px;
	letter-spacing: -0.05em;
}

.brand_wrap .prd_item_group {
	overflow: hidden;
	border: 1px solid #d9d9d9;
	border-top: 0;
	padding: 10px;
}

.brand_wrap .prd_item_group a {
	display: block;
	width: 30%;
	float: left;
}

.brand_wrap .prd_item_group a+a {
	margin-left: 5%;
}

.brand_wrap .prd_info {}

.brand_wrap .prd_img {
	position: relative;
	padding-top: 100%;
	overflow: hidden;
}

.brand_wrap .prd_img:hover:after {
	content: '';
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(0, 0, 0, 0.1);
}

.brand_wrap .prd_img img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.brand_wrap .prd_name {
	font-size: 13px;
	color: #444;
	line-height: 1.36;
	height: 2.71429em;
	overflow: hidden;
}

.brand_wrap .prd_price {
	font-size: 13px;
	color: #111;
}

.brand_wrap .prd_price strong {
	font-size: 15px;
}

/* 브랜드 헤더 (브랜드관 상단) */
.brand_wrap .brand_header {
	position: relative;
	height: 320px;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	background-color: #1a1a2e;
	margin-bottom: 40px;
	overflow: hidden;
}

.brand_wrap .brand_header_overlay {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: linear-gradient(135deg, rgba(0, 0, 0, 0.7) 0%, rgba(0, 0, 0, 0.4) 50%, rgba(0, 0, 0, 0.7) 100%);
}

.brand_wrap .brand_header_content {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	height: 100%;
	text-align: center;
	padding: 20px;
}

.brand_wrap .brand_logo {
	width: 120px;
	height: 120px;
	border-radius: 50%;
	background: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
	margin-bottom: 15px;
}

.brand_wrap .brand_logo img {
	max-width: 80%;
	max-height: 80%;
	object-fit: contain;
}

.brand_wrap .brand_logo_text {
	font-size: 24px;
	font-weight: bold;
	color: #333;
	text-align: center;
	padding: 10px;
}

.brand_wrap .brand_title {
	font-size: 32px;
	font-weight: 700;
	color: #fff;
	margin: 0 0 5px 0;
	text-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
}

.brand_wrap .brand_title_eng {
	font-size: 14px;
	color: rgba(255, 255, 255, 0.7);
	margin: 0 0 15px 0;
	letter-spacing: 2px;
	text-transform: uppercase;
}

.brand_wrap .brand_meta {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 20px;
	margin-bottom: 20px;
}

.brand_wrap .brand_meta .brand_visitor {
	font-size: 14px;
	color: rgba(255, 255, 255, 0.8);
}

.brand_wrap .brand_meta .brand_visitor i {
	margin-right: 5px;
}

.brand_wrap .brand_meta .brand_link {
	font-size: 14px;
	color: rgba(255, 255, 255, 0.8);
	text-decoration: none;
	transition: color 0.2s;
}

.brand_wrap .brand_meta .brand_link:hover {
	color: #fff;
}

.brand_wrap .brand_meta .brand_link i {
	margin-right: 5px;
}

.brand_wrap .brand_actions {}

.brand_wrap .btn_brand_info {
	display: inline-block;
	padding: 12px 30px;
	background: transparent;
	border: 2px solid rgba(255, 255, 255, 0.8);
	color: #fff;
	font-size: 14px;
	font-weight: 600;
	border-radius: 30px;
	cursor: pointer;
	transition: all 0.3s;
}

.brand_wrap .btn_brand_info:hover {
	background: #fff;
	color: #333;
	border-color: #fff;
}

.brand_wrap .btn_brand_info i {
	margin-right: 8px;
}

/* 기존 brand_cover 스타일 유지 (호환성) */
.brand_wrap .brand_cover {
	height: 260px;
	margin-bottom: 50px;
}

.brand_wrap .brand_cover .common_tit {
	padding: 0;
	height: 120px;
}

.brand_wrap .brand_cover .common_tit img {
	height: 120px;
}

.brand_wrap .brand_cover .brand_cover_btns {
	margin: 20px 0;
	text-align: center;
}

.brand_wrap .brand_cover .brand_cover_btns button {
	display: inline-block;
	min-width: 2.57143em;
	height: 2.57143em;
	padding: 0 0.85714em;
	border: 1px solid #c9c9c9;
	vertical-align: middle;
	text-align: center;
	transition: 0.15s;
	font-size: 14px;
	background: transparent;
	margin: 0 4px;
}

.brand_wrap .brand_cover .brand_cover_btns button:hover {
	border-color: #fff;
	background: rgba(0, 0, 0, 0.2);
}

.brand_wrap .brand_cover .brand_cover_btns button span {
	color: #fff;
}

.brand_wrap .brand_cover .brand_cover_btns button i {
	color: #fff;
}

.brand_wrap .brand_cover .brand_cover_visitor {
	color: #fff;
	opacity: 0.8;
	text-align: center;
	font-size: 14px;
}

.brand_wrap .brand_cover .brand_cover_visitor span {}

/* 브랜드 소개 팝업 */
.brand_wrap .brand_pop {
	display: none;
}

.brand_wrap .view_brand {
	position: fixed;
	overflow: auto;
	overflow-x: hidden;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	text-align: center;
	z-index: 5000;
	background-color: rgba(0, 0, 0, 0.5);
}

.brand_wrap .view_brand .box {
	width: 850px;
	min-height: 400px;
	position: fixed;
	left: 50%;
	left: 50%;
	margin-left: -425px;
	margin-top: 100px;
	z-index: 2500;
	box-sizing: border-box;
	padding: 25px;
	border-radius: 10px;
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.3);
	background-color: #fff;
}

.brand_wrap .view_brand .title {
	line-height: 40px;
	position: relative;
	margin-bottom: 20px;
	border-bottom: 1px solid #eee;
	padding-bottom: 15px;
}

.brand_wrap .view_brand .title h2 {
	font-size: 22px;
	color: #333;
	text-align: left;
	font-weight: 600;
}

.brand_wrap .view_brand .title .close {
	display: block;
	position: absolute;
	right: 0;
	top: 0;
	font-size: 24px;
	line-height: 40px;
	color: #999;
	font-weight: 400;
	transition: color 0.2s;
}

.brand_wrap .view_brand .title .close:hover {
	color: #333;
}

.brand_wrap .view_brand .info {
	text-align: left;
	font-size: 15px;
	line-height: 1.8;
	color: #555;
}

.brand_wrap .view_brand .info img {
	max-width: 100% !important;
	height: auto !important;
}

@media all and (max-width:1000px) {
	.brand_wrap .prd_list li {
		width: 49%;
	}

	.brand_wrap .prd_list li:nth-of-type(3n) {
		margin-right: 2%;
	}

	.brand_wrap .prd_list li:nth-of-type(2n) {
		margin-right: 0%;
	}

	.brand_wrap .view_brand .box {
		width: 80%;
		margin-left: -40%;
	}

	.brand_wrap .brand_header {
		height: 280px;
	}

	.brand_wrap .brand_logo {
		width: 100px;
		height: 100px;
	}

	.brand_wrap .brand_title {
		font-size: 26px;
	}
}

@media all and (max-width:640px) {
	.brand_wrap {
		padding-top: 4.6875vw;
	}

	.brand_wrap .common_tit {
		padding: 4.6875vw 4.6875vw 1.5625vw;
		font-size: 4.375vw;
		height: 18.75vw !important;
	}

	.brand_wrap .common_tit img {}

	.brand_wrap .common_desc {
		font-size: 2.5vw;
		margin: 1.25vw 0 4.6875vw;
	}

	.brand_wrap .tab {
		margin-bottom: 4.6875vw;
	}

	.brand_wrap .tab li {
		width: 25%;
	}

	.brand_wrap .tab li:nth-of-type(6n) a {
		border-right-width: 0;
	}

	.brand_wrap .tab li:nth-of-type(4n) a {
		border-right-width: 1px;
	}

	.brand_wrap .tab li:nth-of-type(n+5) a {
		border-top: 0;
	}

	.brand_wrap .tab li a {
		height: 6.40625vw;
		font-size: 2.5vw;
	}

	.brand_wrap .brand_name {
		margin-top: -2.5vw;
		font-size: 4.6875vw;
	}

	.brand_wrap .prd_item_group {
		padding: 1.5625vw;
	}

	.brand_wrap .prd_name {
		font-size: 2.03125vw;
	}

	.brand_wrap .prd_price {
		font-size: 2.03125vw;
	}

	.brand_wrap .prd_price strong {
		font-size: 2.34375vw;
	}

	.brand_wrap .prd_list li {
		width: 100%;
		margin-right: 0;
	}

	.brand_wrap .brand_cover {
		height: 40.625vw;
	}

	.brand_wrap .brand_cover .common_tit img {
		height: 18.75vw;
	}

	.brand_wrap .brand_cover .brand_cover_btns {
		margin: 3.125vw 0;
	}

	.brand_wrap .brand_cover .brand_cover_btns button {
		font-size: 2.1875vw;
		margin: 0 0.625vw;
	}

	.brand_wrap .brand_cover .brand_cover_visitor {
		font-size: 2.1875vw;
	}

	.brand_wrap .view_brand .box {
		width: 90%;
		margin-left: -45%;
		margin-top: 31.25vw;
		padding: 3.90625vw;
	}

	.brand_wrap .view_brand .title {
		line-height: 6.25vw;
		margin-bottom: 3.125vw;
	}

	.brand_wrap .view_brand .title h2 {
		font-size: 3.4375vw;
	}

	.brand_wrap .view_brand .title .close {
		font-size: 4.6875vw;
		line-height: 6.25vw;
	}

	.brand_wrap .view_brand .info {
		font-size: 2.1875vw;
	}

	/* 브랜드 헤더 모바일 */
	.brand_wrap .brand_header {
		height: 220px;
		margin-bottom: 20px;
	}

	.brand_wrap .brand_header_content {
		padding: 15px;
	}

	.brand_wrap .brand_logo {
		width: 70px;
		height: 70px;
		margin-bottom: 10px;
	}

	.brand_wrap .brand_logo_text {
		font-size: 16px;
	}

	.brand_wrap .brand_title {
		font-size: 20px;
		margin-bottom: 3px;
	}

	.brand_wrap .brand_title_eng {
		font-size: 11px;
		margin-bottom: 10px;
		letter-spacing: 1px;
	}

	.brand_wrap .brand_meta {
		flex-wrap: wrap;
		gap: 10px;
		margin-bottom: 12px;
	}

	.brand_wrap .brand_meta .brand_visitor,
	.brand_wrap .brand_meta .brand_link {
		font-size: 12px;
	}

	.brand_wrap .btn_brand_info {
		padding: 8px 20px;
		font-size: 12px;
	}
}

/* Section base */
.section {
	padding: 60px 0;
}

.section:first-of-type {
	padding-top: 200px;
}

/* Tag Badge */
.tag_badge {
	display: inline-flex;
	align-items: center;
	gap: 20px;
	padding: 14px 20px;
	background: #fff;
	border-radius: 50px;
	box-shadow: 0 0 4px rgba(0, 0, 0, 0.15);
}

.tag_badge .dot {
	flex-shrink: 0;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: linear-gradient(328deg, rgba(0, 77, 64, 0.60) 0%, rgba(0, 179, 149, 0.60) 25%, rgba(0, 127, 105, 0.60) 41%, rgba(87, 255, 226, 0.60) 60%, rgba(0, 179, 148, 0.60) 100%);
}

.tag_badge .text {
	color: #004D40;
	font-size: 18px;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.02em;
}

/* Section Page Intro */
.section_page_intro .inner {
	min-width: 0;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 20px;
}

.section_page_intro {
	padding-bottom: 30px;
}

.section_page_intro .title {
	margin: 0;
	font-size: 50px;
	font-weight: 700;
	color: #000;
	line-height: 1.2;
	word-break: keep-all;
}

/* Section Head */
.section_head {
	display: flex;
	align-items: center;
	gap: 16px;
	min-width: 0;
}

.section_head .icon_box {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 54px;
	height: 54px;
	background: #E0F2F1;
	border-radius: 16px;
}

.section_head .head_title {
	margin: 0;
	font-size: 40px;
	font-weight: 700;
	color: #101828;
	line-height: 1.3;
	word-break: keep-all;
}

/* Policy Card */
.policy_card {
	position: relative;
	padding: 60px;
	background: #fff;
	border: 1px solid #F3F4F6;
	border-radius: 32px;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08), 0 1px 2px rgba(0, 0, 0, 0.04);
	overflow: hidden;
}

.policy_card .card_bg {
	position: absolute;
	right: 42px;
	top: 42px;
	line-height: 0;
	pointer-events: none;
}

/* Section Definition / Facility 공통 inner */
.section_definition .inner,
.section_facility .inner {
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 40px;
}

/* Section Definition */
.section_definition .card_body {
	position: relative;
	display: flex;
	align-items: center;
	gap: 62px;
	min-width: 0;
}

.section_definition .quote_box {
	flex: 1;
	min-width: 0;
	padding: 32px 38px;
	background: rgba(224, 242, 240, 0.30);
	border-left: 5px solid #00695C;
	border-radius: 0 16px 16px 0;
}

.section_definition .quote_text {
	margin: 0;
	font-size: 24px;
	font-weight: 500;
	line-height: 1.6;
	color: #1E2939;
	word-break: keep-all;
}

.section_definition .quote_text strong {
	color: #004D40;
	font-weight: 700;
}

.section_definition .num_list {
	flex: 1;
	min-width: 0;
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 24px;
}

.section_definition .num_list li {
	display: flex;
	align-items: flex-start;
	gap: 16px;
}

.section_definition .num_list .num {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 26px;
	height: 26px;
	background: #004D40;
	border-radius: 50%;
	color: #fff;
	font-size: 13px;
	font-weight: 500;
	line-height: 1;
}

.section_definition .num_list .desc {
	flex: 1;
	min-width: 0;
	font-size: 20px;
	font-weight: 400;
	color: #4A5565;
	line-height: 1.5;
	word-break: keep-all;
}

/* Section Facility */
.section_facility .facility_list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
}

.section_facility .facility_card {
	flex: 0 0 calc((100% - 40px) / 3);
	min-width: 0;
	display: flex;
	align-items: center;
	gap: 20px;
	padding: 28px;
	background: #fff;
	border: 1px solid #F3F4F6;
	border-radius: 20px;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08), 0 1px 2px rgba(0, 0, 0, 0.04);
}

.section_facility .num_badge {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	background: #F9FAFB;
	border-radius: 50%;
	color: #99A1AF;
	font-size: 16px;
	font-weight: 700;
	line-height: 1;
}

.section_facility .facility_card .text {
	flex: 1;
	min-width: 0;
	font-size: 20px;
	font-weight: 500;
	color: #364153;
	line-height: 1.5;
	word-break: keep-all;
}

/* Section Type */
.section_type .inner {
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 40px;
}

.section_type .type_list {
	display: flex;
	flex-wrap: wrap;
	gap: 40px;
}

.section_type .type_card {
	position: relative;
	padding: 44px;
	background: #fff;
	border: 1px solid #F3F4F6;
	border-radius: 32px;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08), 0 1px 2px rgba(0, 0, 0, 0.04);
	overflow: hidden;
}

.section_type .card_icon {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 64px;
	height: 64px;
	border-radius: 20px;
}

.section_type .card_icon img {
	max-width: 32px;
	max-height: 32px;
	object-fit: contain;
}

.section_type .card_title {
	margin: 0;
	font-size: 26px;
	font-weight: 700;
	color: #101828;
	line-height: 1.3;
	word-break: keep-all;
}

.section_type .card_desc {
	margin: 0;
	font-size: 18px;
	font-weight: 400;
	color: #4A5565;
	line-height: 1.4;
	word-break: keep-all;
}

.section_type .iso_card {
	flex: 0 0 calc((100% - 40px) * 0.316);
	min-width: 0;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 32px;
}

.section_type .iso_card .card_icon {
	background: #FEF2F2;
}

.section_type .iso_card .card_tags {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

.section_type .iso_card .tag {
	padding: 6px 16px;
	background: #FEF2F2;
	border-radius: 50px;
	color: #E7000B;
	font-size: 14px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.02em;
}

.section_type .hazard_card {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 40px;
}

.section_type .hazard_card .hazard_head {
	display: flex;
	align-items: center;
	gap: 20px;
}

.section_type .hazard_card .card_icon {
	background: #FFF7ED;
}

.section_type .hazard_card .sub_list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.section_type .hazard_card .sub_item {
	flex: 0 0 calc((100% - 10px) / 2);
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 12px;
	padding: 22px;
	background: #F9FAFB;
	border-radius: 20px;
}

.section_type .hazard_card .sub_head {
	display: flex;
	align-items: center;
	gap: 10px;
}

.section_type .hazard_card .sub_icon {
	flex-shrink: 0;
	display: inline-flex;
	width: 24px;
	height: 24px;
}

.section_type .hazard_card .sub_icon img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.section_type .hazard_card .sub_title {
	font-size: 18px;
	font-weight: 700;
	color: #101828;
	line-height: 1.3;
}

.section_type .hazard_card .sub_desc {
	margin: 0;
	font-size: 16px;
	font-weight: 500;
	color: #6A7282;
	line-height: 1.6;
	word-break: keep-all;
}

.section_type .general_card {
	flex: 0 0 100%;
	min-width: 0;
	padding: 44px 62px;
	display: flex;
	align-items: center;
	gap: 40px;
	border-color: rgba(0, 77, 64, 0.10);
}

.section_type .general_card .card_bg {
	position: absolute;
	right: 22px;
	top: 22px;
	/* opacity: 0.10; */
	pointer-events: none;
	line-height: 0;
}

.section_type .general_card .general_left {
	flex-shrink: 0;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 24px;
}

.section_type .general_card .card_icon {
	width: 84px;
	height: 84px;
	background: #fff;
	border: 1px solid rgba(0, 77, 64, 0.20);
	border-radius: 24px;
}

.section_type .general_card .card_icon img {
	max-width: 42px;
	max-height: 42px;
}

.section_type .general_card .card_title {
	font-size: 32px;
	color: #004D40;
}

.section_type .general_card .general_desc {
	flex: 1;
	min-width: 0;
	margin: 0;
	font-size: 20px;
	font-weight: 400;
	color: #364153;
	line-height: 1.5;
	word-break: keep-all;
}

/* Section Notes */
.section_notes .inner {
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 40px;
}

.section_notes .notes_card {
	padding: 56px 80px;
	background: #fff;
	border: 1px solid #F3F4F6;
	border-radius: 32px;
}

.section_notes .dot_list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 36px;
}

.section_notes .dot_list li {
	display: flex;
	align-items: flex-start;
	gap: 20px;
}

.section_notes .dot_list .dot {
	flex-shrink: 0;
	width: 8px;
	height: 8px;
	margin-top: 10px;
	background: #26A69A;
	border-radius: 50%;
}

.section_notes .dot_list .text {
	flex: 1;
	min-width: 0;
	font-size: 18px;
	font-weight: 400;
	color: #4A5565;
	line-height: 1.5;
	word-break: keep-all;
}

.section_notes .note_emphasis {
	margin-top: 36px;
	display: flex;
	align-items: center;
	gap: 16px;
	padding: 24px;
	background: rgba(224, 242, 240, 0.20);
	border: 1px solid #E0F2F1;
	border-radius: 16px;
}

.section_notes .emphasis_icon {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
}

.section_notes .note_emphasis .text {
	flex: 1;
	min-width: 0;
	font-size: 16px;
	font-weight: 600;
	color: #004D40;
	line-height: 1.5;
	word-break: keep-all;
}

/* Section Law */
.section_law .inner {
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 32px;
}

.section_law .section_head .icon_box {
	width: 64px;
	height: 64px;
	background: #1E2939;
	border-radius: 13px;
}

.section_law .section_head .icon_box svg {
	width: 39px;
	height: 39px;
}

.law_table {
	background: #fff;
	border: 1px solid #E5E7EB;
	border-radius: 26px;
	box-shadow: 0 1.6px 3.3px rgba(0, 0, 0, 0.06), 0 1.6px 4.9px rgba(0, 0, 0, 0.10);
	overflow: hidden;
}

.law_table .table_head {
	display: flex;
	background: #F9FAFB;
	border-bottom: 1px solid #E5E7EB;
}

.law_table .table_head .cell {
	min-width: 0;
	padding: 30px 24px;
	font-size: 24px;
	font-weight: 700;
	color: #364153;
	text-align: center;
	border-right: 1px solid #E5E7EB;
}

.law_table .table_head .cell:last-child {
	border-right: none;
}

.law_table .table_body {
	display: flex;
	flex-direction: column;
}

.law_table .row {
	display: flex;
}

.law_table .row+.row {
	border-top: 2px solid #F3F4F6;
}

.law_table .row>.cell {
	min-width: 0;
	padding: 44px 50px;
	border-right: 1px solid #F3F4F6;
}

.law_table .row>.cell:last-child {
	border-right: none;
}

.law_4col .table_head .cell:nth-child(1),
.law_4col .row>.cell:nth-child(1) {
	flex: 0 0 19.25%;
}

.law_4col .table_head .cell:nth-child(2),
.law_4col .row>.cell:nth-child(2) {
	flex: 0 0 22.625%;
}

.law_4col .table_head .cell:nth-child(3),
.law_4col .row>.cell:nth-child(3) {
	flex: 0 0 24.5%;
}

.law_4col .table_head .cell:nth-child(4),
.law_4col .row>.cell:nth-child(4) {
	flex: 1;
}

.law_4col .row>.cell {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 20px;
}

.law_4col .cell_title {
	margin: 0;
	font-size: 23px;
	font-weight: 700;
	color: #1E2939;
	text-align: center;
	line-height: 1.4;
	word-break: keep-all;
}

.law_4col .cell_phone {
	font-size: 23px;
	font-weight: 400;
	color: #6A7282;
	text-align: center;
	line-height: 1.4;
}

.law_2col .table_head .cell:nth-child(1),
.law_2col .row>.cell:nth-child(1) {
	flex: 0 0 66.75%;
}

.law_2col .table_head .cell:nth-child(2),
.law_2col .row>.cell:nth-child(2) {
	flex: 1;
}

.law_2col .row>.cell.col_main {
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
}

.law_2col .row>.cell.col_dept {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: center;
	gap: 8px;
}

.law_2col .cell_text {
	flex: 1;
	min-width: 0;
	font-size: 20px;
	font-weight: 400;
	color: #364153;
	line-height: 1.5;
	word-break: keep-all;
}

.law_2col .cell_title {
	margin: 0;
	font-size: 20px;
	font-weight: 700;
	color: #364153;
	line-height: 1.4;
	word-break: keep-all;
}

.law_2col .cell_phone {
	font-size: 20px;
	font-weight: 400;
	color: #6A7282;
	line-height: 1.4;
}

/* Btn Link 공통 */
.btn_link {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	min-width: 167px;
	padding: 12px 28px;
	border: 1px solid #E5E7EB;
	border-radius: 13px;
	color: #4A5565;
	font-size: 18px;
	font-weight: 400;
	line-height: 1.3;
	transition: background-color .2s;
}

.btn_link svg {
	flex-shrink: 0;
	width: 20px;
	height: 20px;
}

.btn_link:hover {
	background: #F9FAFB;
}

/* Section Feedback */
.section_feedback .inner {
	min-width: 0;
}

.section_feedback .feedback_wrap {
	display: flex;
	align-items: flex-start;
	gap: 40px;
}

.section_feedback .feedback_form {
	flex: 1;
	min-width: 0;
	padding: 60px;
	background: #fff;
	border: 1px solid rgba(0, 77, 64, 0.20);
	border-radius: 34px;
}

.section_feedback .form_head {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin-bottom: 50px;
}

.section_feedback .form_title {
	margin: 0;
	font-size: 38px;
	font-weight: 700;
	color: #004D40;
	line-height: 1.2;
	word-break: keep-all;
}

.section_feedback .form_desc {
	margin: 0;
	font-size: 24px;
	font-weight: 500;
	color: #222;
	line-height: 1.4;
	word-break: keep-all;
}

.section_feedback .form_body {
	display: flex;
	flex-direction: column;
	gap: 40px;
}

.section_feedback .form_row {
	display: flex;
	gap: 30px;
}

.section_feedback .form_field {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.section_feedback .field_label {
	font-size: 22px;
	font-weight: 500;
	color: #000;
}

.section_feedback .field_input,
.section_feedback .field_select,
.section_feedback .field_textarea {
	width: 100%;
	padding: 18px 24px;
	background: #fff;
	border: 1.5px solid #DDD;
	border-radius: 10px;
	font-size: 22px;
	font-weight: 500;
	color: #000;
	line-height: 1.4;
	font-family: inherit;
}

.section_feedback .field_input::placeholder,
.section_feedback .field_textarea::placeholder {
	color: #888;
	font-weight: 500;
}

.section_feedback .field_select {
	appearance: none;
	-webkit-appearance: none;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
	background-repeat: no-repeat;
	background-position: right 20px center;
	padding-right: 60px;
	cursor: pointer;
}

.section_feedback .field_textarea {
	min-height: 193px;
	padding: 24px;
	resize: vertical;
}

.section_feedback .field_input:focus,
.section_feedback .field_select:focus,
.section_feedback .field_textarea:focus {
	outline: none;
	border-color: #004D40;
}

.section_feedback .field_label_row {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.section_feedback .anonymous_chk {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 18px;
	font-weight: 500;
	color: #666;
	cursor: pointer;
	white-space: nowrap;
}

.section_feedback .anonymous_chk input[type="checkbox"] {
	width: 22px;
	height: 22px;
	margin: 0;
	accent-color: #004D40;
	cursor: pointer;
}

.section_feedback .btn_submit {
	width: 100%;
	padding: 20px 24px;
	background: #004D40;
	border: none;
	border-radius: 10px;
	color: #fff;
	font-size: 32px;
	font-weight: 700;
	cursor: pointer;
	transition: opacity .2s;
	font-family: inherit;
}

.section_feedback .btn_submit:hover {
	opacity: .92;
}

.section_feedback .feedback_guide {
	flex: 0 0 calc(33% - 20px);
	min-width: 0;
	padding: 60px 30px 80px;
	background: #004D40;
	border-radius: 20px;
}

.section_feedback .guide_title {
	margin: 0 0 40px;
	font-size: 38px;
	font-weight: 700;
	color: #fff;
	line-height: 1.2;
}

.section_feedback .guide_list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 40px;
}

.section_feedback .guide_list li {
	display: flex;
	align-items: flex-start;
	gap: 10px;
}

.section_feedback .guide_list .dot_wrap {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 20px;
	height: 20px;
	padding: 5px;
	margin-top: 8px;
}

.section_feedback .guide_list .dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: linear-gradient(328deg, rgba(0, 77, 64, 0.60) 0%, rgba(0, 179, 149, 0.60) 25%, rgba(0, 127, 105, 0.60) 41%, rgba(87, 255, 226, 0.60) 60%, rgba(0, 179, 148, 0.60) 100%);
}

.section_feedback .guide_list .text {
	flex: 1;
	min-width: 0;
	font-size: 22px;
	font-weight: 700;
	color: #fff;
	line-height: 1.4;
	word-break: keep-all;
}

/* File Table */
.file_table {
	width: 100%;
	background: #fff;
	border-radius: 24px;
	overflow: hidden;
}

.file_table .table_head {
	display: flex;
	background: #EBF1F2;
}

.file_table .table_head .cell {
	min-width: 0;
	padding: 24px 20px;
	font-size: 26px;
	font-weight: 700;
	color: #222;
	text-align: center;
	line-height: 1.4;
}

.file_table .table_body {
	display: flex;
	flex-direction: column;
}

.file_table .row {
	display: flex;
	align-items: center;
	min-height: 100px;
}

.file_table .row>.cell {
	min-width: 0;
	padding: 16px 20px;
	font-size: 24px;
	font-weight: 400;
	color: #878787;
	text-align: center;
	line-height: 1.4;
}

.file_table .cell.col_name {
	flex: 1;
	min-width: 0;
	text-align: left;
	padding-left: 24px;
	word-break: keep-all;
}

.file_table .cell.col_type {
	flex: 0 0 14.375%;
}

.file_table .cell.col_date {
	flex: 0 0 18.75%;
}

.file_table .cell.col_size {
	flex: 0 0 10.625%;
}

.file_table .cell.col_action {
	flex: 0 0 10.625%;
}

.file_table .type_badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 4px 20px;
	background: #F1F5F9;
	border-radius: 40px;
	color: #878787;
	font-size: 24px;
	font-weight: 400;
	line-height: 1.4;
}

.file_table .btn_download {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	color: #666;
	transition: opacity .2s;
}

.file_table .btn_download:hover {
	opacity: .6;
}

/* Pagination */
.pagination {
	display: flex;
	align-items: center;
	gap: 40px;
}

.pagination .pg_arrow {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	color: rgba(0, 77, 64, 0.20);
	transition: color .2s;
}

.pagination .pg_arrow:hover {
	color: rgba(0, 77, 64, 0.60);
}

.pagination .pg_nums {
	display: flex;
	align-items: center;
	gap: 20px;
}

.pagination .pg_num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	color: #004D40;
	font-size: 30px;
	font-weight: 700;
	line-height: 1;
}

.pagination .pg_num.active {
	background: #004D40;
	color: #fff;
}

/* Section Dataroom / Center 공통 inner */
.section_dataroom .inner,
.section_center .inner {min-width:0; display:flex; flex-direction:column; align-items:center; gap:60px;}

/* 자료실 카테고리 필터 (1depth) */
.section_dataroom .cate_filter {width:100%; display:flex; flex-wrap:wrap; gap:16px;}
.section_dataroom .cate_btn {display:inline-flex; align-items:center; justify-content:center; padding:14px 32px; border:1px solid #D5DDDD; border-radius:50px; background:#fff; color:#004D40; font-size:24px; font-weight:500; line-height:1.2; word-break:keep-all; transition:all .2s;}
.section_dataroom .cate_btn:hover {border-color:#004D40;}
.section_dataroom .cate_btn.active {background:#004D40; border-color:#004D40; color:#fff;}

/* Edu List (교육센터 카드 그리드) */
.edu_list {width:100%; display:flex; flex-wrap:wrap; gap:40px;}
.edu_list .edu_card {flex:0 0 calc((100% - 120px) / 4); min-width:0; display:flex; flex-direction:column; gap:20px; color:#000;}
.edu_list .card_thumb {position:relative; width:100%; aspect-ratio:370/230; border-radius:24px; overflow:hidden; background:#F1F5F9;}
.edu_list .card_thumb img {width:100%; height:100%; object-fit:cover; transition:transform .3s;}
.edu_list .edu_card:hover .card_thumb img {transform:scale(1.05);}
.edu_list .card_info {display:flex; flex-direction:column; gap:8px; min-width:0;}
.edu_list .card_title {margin:0; font-size:28px; font-weight:700; color:#000; line-height:1.3; word-break:keep-all; display:-webkit-box; -webkit-line-clamp:2; line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;}
.edu_list .card_meta {margin:0; font-size:22px; font-weight:500; color:#444; line-height:1.4;}
.edu_list .no_data {flex:1 0 100%; text-align:center; padding:80px 0; font-size:18px; color:#666;}

/* 교육센터 리스트형 (모던) */
.edu_board_list {width:100%; background:#fff; border:1px solid #F3F4F6; border-radius:24px; box-shadow:0 1px 3px rgba(0,0,0,0.06); overflow:hidden;}
.edu_board_row {display:flex; align-items:center; gap:24px; padding:28px 36px; border-bottom:1px solid #E2E8F0; color:#000; transition:background .2s;}
.edu_board_row:last-child {border-bottom:0;}
.edu_board_row:hover {background:#F8FAFC;}
.edu_board_row .row_num {flex-shrink:0; width:64px; text-align:center; font-size:20px; font-weight:600; color:#94A3B8;}
.edu_board_row .row_num .noti {display:inline-flex; align-items:center; padding:6px 16px; border-radius:50px; background:#E0F2F1; color:#004D40; font-size:14px; font-weight:700;}
.edu_board_row .row_body {flex:1; min-width:0; display:flex; flex-direction:column; gap:6px;}
.edu_board_row .row_title_wrap {display:flex; align-items:center; gap:10px; min-width:0;}
.edu_board_row .row_title {font-size:22px; font-weight:700; color:#000; line-height:1.35; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; min-width:0; transition:color .2s;}
.edu_board_row:hover .row_title {color:#004D40;}
.edu_board_row .new_badge {flex-shrink:0; display:inline-flex; align-items:center; padding:3px 10px; border-radius:50px; background:#004D40; color:#fff; font-size:12px; font-weight:700;}
.edu_board_row .row_subtitle {font-size:17px; color:#64748B; line-height:1.4; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}
.edu_board_row .row_side {flex-shrink:0; display:flex; flex-direction:column; align-items:flex-end; gap:6px; font-size:16px; color:#64748B;}
.edu_board_row .row_date {display:inline-flex; align-items:center; gap:6px; white-space:nowrap;}
.edu_board_row .row_views {display:inline-flex; align-items:center; gap:6px; white-space:nowrap;}
.edu_board_row .row_views svg {flex-shrink:0;}
.section_center .no_data {width:100%; text-align:center; padding:80px 0; font-size:18px; color:#666;}
@media (max-width:1024px) {
	.edu_board_row {gap:18px; padding:24px 28px;}
	.edu_board_row .row_title {font-size:20px;}
}
@media (max-width:640px) {
	.edu_board_list {border-radius:18px;}
	.edu_board_row {gap:12px; padding:18px 16px;}
	.edu_board_row .row_num {width:auto; min-width:34px; font-size:15px;}
	.edu_board_row .row_num .noti {padding:4px 10px; font-size:12px;}
	.edu_board_row .row_title {font-size:16px;}
	.edu_board_row .row_subtitle {font-size:13px;}
	.edu_board_row .row_side {font-size:13px;}
}

@media (max-width:1280px) {
	.section {
		padding: 50px 0;
	}

	.section:first-of-type {
		padding-top: 180px;
	}

	.section_page_intro .title {
		font-size: 42px;
	}

	.section_head .icon_box {
		width: 48px;
		height: 48px;
	}

	.section_head .head_title {
		font-size: 32px;
	}

	.policy_card {
		padding: 50px;
	}

	.section_definition .card_body {
		gap: 40px;
	}

	.section_definition .quote_text {
		font-size: 20px;
	}

	.section_definition .num_list .desc {
		font-size: 18px;
	}

	.section_facility .facility_card {
		flex: 0 0 calc((100% - 20px) / 2);
	}

	.section_type .iso_card,
	.section_type .hazard_card {
		flex: 0 0 100%;
	}

	.section_type .general_card {
		padding: 36px 44px;
	}

	.section_notes .notes_card {
		padding: 48px 56px;
	}

	.section_law .section_head .icon_box {
		width: 56px;
		height: 56px;
	}

	.section_law .section_head .icon_box svg {
		width: 34px;
		height: 34px;
	}

	.law_table .table_head .cell {
		font-size: 20px;
		padding: 24px 18px;
	}

	.law_table .row>.cell {
		padding: 36px 30px;
	}

	.law_4col .cell_title {
		font-size: 20px;
	}

	.law_4col .cell_phone {
		font-size: 20px;
	}

	.law_2col .cell_text {
		font-size: 18px;
	}

	.law_2col .cell_title {
		font-size: 18px;
	}

	.law_2col .cell_phone {
		font-size: 18px;
	}

	.btn_link {
		min-width: 140px;
		padding: 10px 20px;
		font-size: 16px;
	}

	.section_feedback .feedback_form {
		padding: 50px 44px;
	}

	.section_feedback .form_title {
		font-size: 32px;
	}

	.section_feedback .form_desc {
		font-size: 20px;
	}

	.section_feedback .form_head {
		margin-bottom: 40px;
	}

	.section_feedback .form_body {
		gap: 32px;
	}

	.section_feedback .field_label {
		font-size: 18px;
	}

	.section_feedback .field_input,
	.section_feedback .field_select,
	.section_feedback .field_textarea {
		font-size: 18px;
		padding: 14px 20px;
	}

	.section_feedback .field_textarea {
		min-height: 160px;
		padding: 20px;
	}

	.section_feedback .btn_submit {
		font-size: 26px;
		padding: 18px 24px;
	}

	.section_feedback .feedback_guide {
		padding: 50px 28px 60px;
		flex: 0 0 calc(33% - 20px);
	}

	.section_feedback .guide_title {
		font-size: 32px;
		margin-bottom: 32px;
	}

	.section_feedback .guide_list {
		gap: 32px;
	}

	.section_feedback .guide_list .text {
		font-size: 18px;
	}

	.file_table {
		border-radius: 20px;
	}

	.file_table .table_head .cell {
		font-size: 20px;
		padding: 20px 16px;
	}

	.file_table .row {
		min-height: 84px;
	}

	.file_table .row>.cell {
		font-size: 20px;
		padding: 14px 16px;
	}

	.file_table .cell.col_name {
		padding-left: 20px;
	}

	.file_table .type_badge {
		font-size: 18px;
		padding: 4px 16px;
	}

	.section_dataroom .inner {
		gap: 48px;
	}

	.section_dataroom .cate_filter {gap:12px;}
	.section_dataroom .cate_btn {font-size:20px; padding:12px 26px;}

	.section_center .inner {gap:48px;}
	.edu_list {gap:30px;}
	.edu_list .edu_card {flex:0 0 calc((100% - 60px) / 3);}
	.edu_list .card_title {font-size:22px;}
	.edu_list .card_meta {font-size:18px;}
}

@media (max-width:1024px) {
	.section {
		padding: 50px 0;
	}

	.section:first-of-type {
		padding-top: 140px;
	}

	.section_page_intro .title {
		font-size: 34px;
	}

	.tag_badge {
		gap: 14px;
		padding: 12px 18px;
	}

	.tag_badge .text {
		font-size: 16px;
	}

	.section_head .icon_box {
		width: 44px;
		height: 44px;
	}

	.section_head .icon_box svg {
		width: 22px;
		height: 22px;
	}

	.section_head .head_title {
		font-size: 26px;
	}

	.policy_card {
		padding: 36px 28px;
	}

	.policy_card .card_bg svg {
		width: 110px;
		height: 110px;
	}

	.section_definition .card_body {
		flex-direction: column;
		align-items: stretch;
		gap: 30px;
	}

	.section_definition .quote_box {
		padding: 24px 28px;
	}

	.section_definition .quote_text {
		font-size: 18px;
	}

	.section_definition .num_list .desc {
		font-size: 17px;
	}

	.section_facility .facility_card {
		padding: 22px 24px;
	}

	.section_facility .num_badge {
		width: 36px;
		height: 36px;
		font-size: 14px;
	}

	.section_facility .facility_card .text {
		font-size: 17px;
	}

	.section_type .type_card {
		padding: 30px;
	}

	.section_type .type_list {
		gap: 24px;
	}

	.section_type .card_icon {
		width: 54px;
		height: 54px;
		border-radius: 16px;
	}

	.section_type .card_icon img {
		max-width: 28px;
		max-height: 28px;
	}

	.section_type .card_title {
		font-size: 22px;
	}

	.section_type .card_desc {
		font-size: 16px;
	}

	.section_type .hazard_card .sub_item {
		flex: 0 0 100%;
	}

	.section_type .general_card {
		flex-direction: column;
		align-items: flex-start;
		gap: 24px;
	}

	.section_type .general_card .card_icon {
		width: 64px;
		height: 64px;
	}

	.section_type .general_card .card_icon img {
		max-width: 32px;
		max-height: 32px;
	}

	.section_type .general_card .card_title {
		font-size: 24px;
	}

	.section_type .general_card .general_desc {
		font-size: 17px;
	}

	.section_notes .notes_card {
		padding: 36px 32px;
		border-radius: 24px;
	}

	.section_notes .dot_list {
		gap: 24px;
	}

	.section_notes .dot_list .text {
		font-size: 16px;
	}

	.section_notes .note_emphasis {
		margin-top: 28px;
		padding: 20px;
	}

	.section_notes .note_emphasis .text {
		font-size: 15px;
	}

	.section_law .section_head .icon_box {
		width: 50px;
		height: 50px;
	}

	.section_law .section_head .icon_box svg {
		width: 30px;
		height: 30px;
	}

	.law_table {
		border-radius: 20px;
	}

	.law_table .table_head .cell {
		font-size: 16px;
		padding: 18px 12px;
	}

	.law_table .row>.cell {
		padding: 24px 20px;
	}

	.law_4col .row>.cell {
		gap: 14px;
	}

	.law_4col .cell_title {
		font-size: 17px;
	}

	.law_4col .cell_phone {
		font-size: 17px;
	}

	.law_2col .row>.cell.col_main {
		gap: 14px;
	}

	.law_2col .cell_text {
		font-size: 15px;
	}

	.law_2col .cell_title {
		font-size: 15px;
	}

	.law_2col .cell_phone {
		font-size: 14px;
	}

	.btn_link {
		min-width: auto;
		padding: 8px 16px;
		font-size: 14px;
		gap: 8px;
	}

	.btn_link svg {
		width: 16px;
		height: 16px;
	}

	.section_feedback .feedback_wrap {
		flex-direction: column;
		gap: 24px;
	}

	.section_feedback .feedback_form {
		padding: 40px 30px;
		border-radius: 24px;
	}

	.section_feedback .form_title {
		font-size: 26px;
	}

	.section_feedback .form_desc {
		font-size: 17px;
	}

	.section_feedback .form_head {
		margin-bottom: 32px;
	}

	.section_feedback .form_body {
		gap: 24px;
	}

	.section_feedback .form_row {
		flex-direction: column;
		gap: 24px;
	}

	.section_feedback .field_label {
		font-size: 16px;
	}

	.section_feedback .field_input,
	.section_feedback .field_select,
	.section_feedback .field_textarea {
		font-size: 16px;
		padding: 12px 18px;
		border-radius: 8px;
	}

	.section_feedback .field_textarea {
		min-height: 140px;
		padding: 18px;
	}

	.section_feedback .btn_submit {
		font-size: 22px;
		padding: 16px 20px;
	}

	.section_feedback .feedback_guide {
		flex: 0 0 100%;
		width: 100%;
		padding: 40px 28px;
	}

	.section_feedback .guide_title {
		font-size: 26px;
		margin-bottom: 28px;
	}

	.section_feedback .guide_list {
		gap: 24px;
	}

	.section_feedback .guide_list .text {
		font-size: 16px;
	}

	.file_table {
		border-radius: 16px;
	}

	.file_table .table_head .cell {
		font-size: 16px;
		padding: 16px 10px;
	}

	.file_table .row {
		min-height: 72px;
	}

	.file_table .row>.cell {
		font-size: 16px;
		padding: 12px 10px;
	}

	.file_table .cell.col_name {
		padding-left: 16px;
	}

	.file_table .cell.col_type {
		flex: 0 0 13%;
	}

	.file_table .cell.col_date {
		flex: 0 0 18%;
	}

	.file_table .cell.col_size {
		flex: 0 0 12%;
	}

	.file_table .cell.col_action {
		flex: 0 0 11%;
	}

	.file_table .type_badge {
		font-size: 15px;
		padding: 3px 12px;
	}

	.file_table .btn_download {
		width: 32px;
		height: 32px;
	}

	.file_table .btn_download svg {
		width: 32px;
		height: 32px;
	}

	.section_dataroom .inner {
		gap: 36px;
	}

	.section_center .inner {gap:36px;}
	.edu_list {gap:24px;}
	.edu_list .edu_card {flex:0 0 calc((100% - 24px) / 2); gap:16px;}
	.edu_list .card_thumb {border-radius:20px;}
	.edu_list .card_title {font-size:20px;}
	.edu_list .card_meta {font-size:16px;}

	.pagination {
		gap: 24px;
	}

	.pagination .pg_nums {
		gap: 12px;
	}

	.pagination .pg_num {
		width: 36px;
		height: 36px;
		font-size: 22px;
	}
}

@media (max-width:640px) {
	.section {
		padding: 40px 0;
	}

	.section:first-of-type {
		padding-top: 110px;
	}

	.section_page_intro .inner {
		gap: 16px;
	}

	.section_page_intro .title {
		font-size: 26px;
	}

	.tag_badge {
		gap: 12px;
		padding: 10px 16px;
	}

	.tag_badge .dot {
		width: 8px;
		height: 8px;
	}

	.tag_badge .text {
		font-size: 14px;
	}

	.section_head {
		gap: 12px;
	}

	.section_head .icon_box {
		width: 40px;
		height: 40px;
		border-radius: 12px;
	}

	.section_head .icon_box svg {
		width: 20px;
		height: 20px;
	}

	.section_head .head_title {
		font-size: 22px;
	}

	.policy_card {
		padding: 28px 20px;
		border-radius: 24px;
	}

	.policy_card .card_bg {
		right: 16px;
		top: 16px;
	}

	.policy_card .card_bg svg {
		width: 80px;
		height: 80px;
	}

	.section_definition .card_body {
		gap: 24px;
	}

	.section_definition .quote_box {
		padding: 20px;
	}

	.section_definition .quote_text {
		font-size: 16px;
	}

	.section_definition .num_list {
		gap: 18px;
	}

	.section_definition .num_list .num {
		width: 22px;
		height: 22px;
		font-size: 12px;
	}

	.section_definition .num_list .desc {
		font-size: 15px;
	}

	.section_facility .facility_list {
		gap: 14px;
	}

	.section_facility .facility_card {
		flex: 0 0 100%;
		padding: 18px 20px;
		gap: 14px;
		border-radius: 16px;
	}

	.section_facility .num_badge {
		width: 32px;
		height: 32px;
		font-size: 13px;
	}

	.section_facility .facility_card .text {
		font-size: 15px;
	}

	.section_type .type_card {
		padding: 24px 20px;
		border-radius: 24px;
	}

	.section_type .type_list {
		gap: 18px;
	}

	.section_type .card_icon {
		width: 48px;
		height: 48px;
		border-radius: 14px;
	}

	.section_type .card_title {
		font-size: 18px;
	}

	.section_type .card_desc {
		font-size: 15px;
	}

	.section_type .iso_card {
		gap: 24px;
	}

	.section_type .iso_card .tag {
		font-size: 12px;
		padding: 5px 12px;
	}

	.section_type .hazard_card {
		gap: 24px;
	}

	.section_type .hazard_card .sub_item {
		padding: 18px 16px;
	}

	.section_type .hazard_card .sub_title {
		font-size: 16px;
	}

	.section_type .hazard_card .sub_desc {
		font-size: 14px;
	}

	.section_type .general_card {
		padding: 24px 20px;
	}

	.section_type .general_card .card_title {
		font-size: 22px;
	}

	.section_type .general_card .general_desc {
		font-size: 15px;
	}

	.general_desc br {
		display: none;
	}

	.section_notes .notes_card {
		padding: 24px 20px;
		border-radius: 20px;
	}

	.section_notes .dot_list {
		gap: 20px;
	}

	.section_notes .dot_list li {
		gap: 14px;
	}

	.section_notes .dot_list .dot {
		margin-top: 8px;
	}

	.section_notes .dot_list .text {
		font-size: 14px;
	}

	.section_notes .note_emphasis {
		margin-top: 24px;
		padding: 16px;
		gap: 12px;
	}

	.section_notes .emphasis_icon {
		width: 20px;
		height: 20px;
	}

	.section_notes .emphasis_icon svg {
		width: 20px;
		height: 20px;
	}

	.section_notes .note_emphasis .text {
		font-size: 14px;
	}

	.section_law .section_head .icon_box {
		width: 44px;
		height: 44px;
		border-radius: 11px;
	}

	.section_law .section_head .icon_box svg {
		width: 26px;
		height: 26px;
	}

	.section_law .inner {
		gap: 24px;
	}

	.law_table {
		border-radius: 16px;
	}

	.law_table .table_head {
		display: none;
	}

	.law_table .row {
		flex-direction: column;
	}

	.law_table .row>.cell {
		flex: 1 1 100%;
		padding: 18px 16px;
		border-right: none;
		border-bottom: 1px solid #F3F4F6;
	}

	.law_table .row>.cell:last-child {
		border-bottom: none;
	}

	.law_4col .row>.cell {
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
		gap: 14px;
	}

	.law_4col .cell_title {
		flex: 1;
		min-width: 0;
		font-size: 15px;
		text-align: left;
	}

	.law_4col .cell_phone {
		font-size: 14px;
		text-align: left;
	}

	.law_2col .row>.cell.col_main {
		flex-direction: column;
		align-items: flex-start;
		gap: 14px;
	}

	.law_2col .row>.cell.col_dept {
		gap: 4px;
	}

	.law_2col .cell_text {
		font-size: 14px;
	}

	.law_2col .cell_title {
		font-size: 14px;
	}

	.law_2col .cell_phone {
		font-size: 13px;
	}

	.btn_link {
		padding: 8px 14px;
		font-size: 13px;
	}

	.btn_link svg {
		width: 14px;
		height: 14px;
	}

	.section_feedback .feedback_form {
		padding: 28px 20px;
		border-radius: 20px;
	}

	.section_feedback .form_title {
		font-size: 22px;
	}

	.section_feedback .form_desc {
		font-size: 15px;
	}

	.section_feedback .form_head {
		margin-bottom: 24px;
		gap: 8px;
	}

	.section_feedback .form_body {
		gap: 20px;
	}

	.section_feedback .form_row {
		gap: 20px;
	}

	.section_feedback .field_label {
		font-size: 14px;
	}

	.section_feedback .field_input,
	.section_feedback .field_select,
	.section_feedback .field_textarea {
		font-size: 15px;
		padding: 11px 16px;
	}

	.section_feedback .field_textarea {
		min-height: 120px;
		padding: 16px;
	}

	.section_feedback .btn_submit {
		font-size: 18px;
		padding: 14px 18px;
	}

	.section_feedback .feedback_guide {
		padding: 28px 20px;
		border-radius: 16px;
	}

	.section_feedback .guide_title {
		font-size: 22px;
		margin-bottom: 20px;
	}

	.section_feedback .guide_list {
		gap: 20px;
	}

	.section_feedback .guide_list .text {
		font-size: 14px;
	}

	.file_table {border-radius:14px;}
	.file_table .table_head {display:none;}
	.file_table .table_body {padding:6px;}
	.file_table .row {position:relative; flex-direction:row; flex-wrap:wrap; align-items:center; align-content:flex-start; padding:16px 56px 16px 16px; gap:6px 12px; min-height:0; border-bottom:1px solid #F1F5F9;}
	.file_table .row:last-child {border-bottom:none;}
	.file_table .row > .cell {flex:0 0 auto; padding:0; text-align:left; min-width:0;}
	.file_table .cell.col_name {flex:0 0 100%; font-size:15px; font-weight:500; color:#333; line-height:1.4;}
	.file_table .cell.col_type {display:inline-flex;}
	.file_table .cell.col_date,
	.file_table .cell.col_size {font-size:12px; color:#888;}
	.file_table .cell.col_size {display:inline-block;}
	.file_table .cell.col_action {position:absolute; right:12px; top:50%; transform:translateY(-50%);}
	.file_table .type_badge {font-size:12px; padding:2px 10px;}
	.file_table .btn_download {width:30px; height:30px;}
	.file_table .btn_download svg {width:30px; height:30px;}

	.section_dataroom .inner {gap:24px;}
	.section_center .inner {gap:28px;}
	.edu_list {gap:16px;}
	.edu_list .edu_card {flex:0 0 calc((100% - 16px) / 2); gap:12px;}
	.edu_list .card_thumb {border-radius:16px;}
	.edu_list .card_info {gap:6px;}
	.edu_list .card_title {font-size:15px;}
	.edu_list .card_meta {font-size:13px;}
	.pagination {gap:12px;}
	.pagination .pg_nums {gap:4px;}
	.pagination .pg_num {width:28px; height:28px; font-size:16px;}
	.pagination .pg_arrow {width:20px; height:20px;}
	.pagination .pg_arrow svg {width:18px; height:18px;}
}



.programCon_custom01  {
	 margin-top: 200px;
	 margin-bottom: 100px;
}

/* ─── 협회활동 상세 (모던 UI) ─── */
.section_detail .inner {min-width:0; display:flex; flex-direction:column; align-items:stretch; gap:40px;}
.detail_back {display:inline-flex; align-items:center; gap:8px; align-self:flex-start; color:#004D40; font-size:18px; font-weight:600;}
.detail_back svg {flex-shrink:0;}
.detail_card {background:#fff; border:1px solid #F3F4F6; border-radius:32px; box-shadow:0 1px 3px rgba(0,0,0,0.08),0 1px 2px rgba(0,0,0,0.04); padding:60px; overflow:hidden;}
.detail_head {padding-bottom:32px; margin-bottom:40px; border-bottom:1px solid #E2E8F0;}
.detail_head .cate {display:inline-flex; align-items:center; margin-bottom:14px; padding:6px 16px; border-radius:50px; background:#E0F2F1; color:#004D40; font-size:15px; font-weight:600;}
.detail_title {margin:0 0 16px; font-size:36px; font-weight:700; color:#000; line-height:1.3; word-break:keep-all;}
.detail_subtitle {margin:-6px 0 18px; font-size:20px; font-weight:500; color:#64748B; line-height:1.4; word-break:keep-all;}
.detail_meta {display:flex; align-items:center; flex-wrap:wrap; gap:18px; font-size:18px; color:#64748B;}
.detail_meta .date {display:inline-flex; align-items:center; gap:8px;}
.detail_thumb {margin-bottom:40px; border-radius:24px; overflow:hidden; background:#F1F5F9;}
.detail_thumb img {width:100%; height:auto; display:block;}
.detail_body {font-size:18px; color:#334155; line-height:1.8; word-break:break-word;}
.detail_body img {max-width:100%; height:auto;}
.detail_files {margin-top:40px; padding-top:32px; border-top:1px solid #E2E8F0; display:flex; flex-direction:column; gap:14px;}
.detail_files .file_item {display:flex; align-items:center; gap:10px; font-size:17px; color:#334155;}
.detail_files .file_item svg {flex-shrink:0;}
.detail_files .file_item a {color:#004D40; font-weight:500; text-decoration:underline; text-underline-offset:3px; word-break:break-all;}
.detail_answer {margin-top:32px; padding:28px 32px; background:#F8FAFC; border-radius:20px;}
.detail_answer .answer_tit {margin:0 0 12px; font-size:18px; font-weight:700; color:#004D40;}
.detail_answer .answer_txt {font-size:17px; color:#334155; line-height:1.7;}
.detail_nav {display:flex; flex-direction:column; border-top:1px solid #E2E8F0;}
.detail_nav .nav_row {display:flex; align-items:center; gap:20px; padding:24px 8px; border-bottom:1px solid #E2E8F0; color:#000;}
.detail_nav .nav_row .label {flex-shrink:0; width:90px; font-size:17px; font-weight:700; color:#004D40;}
.detail_nav .nav_row .subj {min-width:0; flex:1; font-size:18px; color:#334155; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}
.detail_nav .nav_row.disabled .subj {color:#94A3B8;}
.detail_nav a.nav_row:hover .subj {color:#004D40;}
.detail_btns {display:flex; justify-content:center; margin-top:40px;}
.detail_btns .btn_list {display:inline-flex; align-items:center; justify-content:center; padding:16px 48px; border-radius:50px; background:#004D40; color:#fff; font-size:20px; font-weight:600; transition:all .2s;}
.detail_btns .btn_list:hover {background:#00382E;}

@media (max-width:1024px) {
	.section_detail .inner {gap:32px;}
	.detail_card {padding:40px;}
	.detail_title {font-size:30px;}
}
@media (max-width:640px) {
	.detail_card {padding:28px 22px; border-radius:24px;}
	.detail_head {padding-bottom:24px; margin-bottom:28px;}
	.detail_title {font-size:24px;}
	.detail_subtitle {font-size:16px;}
	.detail_meta {font-size:16px;}
	.detail_thumb {border-radius:16px; margin-bottom:28px;}
	.detail_body {font-size:16px;}
	.detail_nav .nav_row {gap:14px; padding:18px 4px;}
	.detail_nav .nav_row .label {width:64px; font-size:15px;}
	.detail_nav .nav_row .subj {font-size:16px;}
	.detail_btns .btn_list {padding:14px 36px; font-size:18px;}
}