@charset 'utf-8';

/* ���� */
:root{
    --baseFont: 'Pretendard', 'Noto Sans KR', 'Malgun Gothic', 'verdana', sans-serif;
	--engFont: 'Poppins', 'Pretendard', 'Noto Sans KR', 'Malgun Gothic', 'verdana', sans-serif;
	--Noto: 'Noto Sans KR', 'Pretendard', 'Noto Sans KR', 'Malgun Gothic', 'verdana', sans-serif;
	--aosPlus: 100px;
	--aosMinus: -100px;
	--headerH: 90px;
	--headerT: 20px;
	--headerB: 35px;
	--pointColor: #263053;
	--shadow: 0px 0px 20px rgba(0, 0, 0, 0.05);
}

*{  box-sizing: border-box; word-break: keep-all; line-height: 1.3; }
body{ background: #F3F3F3; font-size: 17px; padding-top: calc(var(--headerH) + var(--headerT) + var(--headerB)); }
body *{ font-size: inherit; }
.ptH{ padding-top: calc(var(--headerH) + var(--headerTop)); }
.w1800{ max-width: 1800px; width: 100%; margin: 0 auto; }

@media screen and (max-width: 1840px){
	.w1800{ padding: 0 20px; }
}

@media screen and (max-width: 1280px){
	:root{
		--aosPlus: 50px;
		--aosMinus: -50px;
	}
}

/* privacy */
.privacy * { font-size: 1.6rem; line-height: 1.625; word-break: break-all; }
.privacy h3 { font-weight: 700; }
.privacy h4{ font-weight: 700; }
.privacy .textBox,
.privacy .pBox,
.privacy .dlBox,
.privacy .subTextBox { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-orient: vertical; -webkit-box-direction: normal; -ms-flex-direction: column; flex-direction: column; }

.privacy .textBox { gap: 50px 0; }
.privacy .textBox h5{ font-size: 1.8rem; font-weight: 700; }

.privacy .dlBox { gap: 30px 0; }
.privacy .dlBox > dl > dt { font-weight: 500; }
.privacy .dlBox > dl > dd > p { margin: 5px 0; }
.privacy .dlBox > dl > dd p + ul{ margin: 5px 0; }
.privacy .dlBox > dl > dd .dlBox{ margin-top: 15px; gap: 15px 0; }

.privacy .square li{ display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; gap: 0 5px; position: relative; padding-left: 12px; }
.privacy .square li::before { content: "-"; position: absolute; top: 0; left: 0; }

.privacy .subTextBox { gap: 15px 0; }
.privacy .subTextBox h6 { font-weight: 500; margin: 0 0 4px; }
.privacy .subText { margin: 4px 0; }
.privacy .subText dd { padding: 0 0 0 11px; }

.privacy .contact { margin: 60px 0 0; }
.privacy .contact ol { margin: 30px 0 0; }

@media screen and (max-width: 1250px){
	.privacy .textBox h3{ font-size: 2rem; }
	.privacy .textBox { gap: 30px 0; }

	.privacy .pBox{ gap: 10px 0; }
	
	.privacy .dlBox { gap: 20px 0; }
	.privacy .dlBox > dl > dd .dlBox{ margin-top: 10px; gap: 10px 0; }
}

@media screen and (max-width: 900px){
	.privacy .dlBox > dl > dd > ul { padding: 0 0 0 10px; }
}


/* header */
#header{ width: 100%; position: fixed; top: 0; left: 0; z-index: 900; padding-top: var(--headerT); transition: padding 0.5s; }
#header::before{ content: ""; max-width: var(--inner); width: 100%; height: var(--headerH); background: #111; border-radius: 20px; position: absolute; top: var(--headerT); left: calc(50% - 1px); transform: translateX(-50%); transition: max-width 0.5s, border-radius 0.5s, top 0.5s; }
#header .inner{ height: var(--headerH); display: flex; justify-content: space-between; align-items: center; padding: 0 40px; position: relative; }

/* header - scroll */
#header.scroll{ padding-top: 0; }
#header.scroll::before{ max-width: calc(100% + 1px); top: 0; border-radius: 0 0 20px 20px; }

#header nav{ width: 100%; position: absolute; top: 0; left: 50%; transform: translateX(-50%); pointer-events: none; }
#header .navBg{ width: 100%; height: 0; background: rgba(34, 34, 34, 0.7); border-radius: 20px; backdrop-filter: blur(30px); -webkit-backdrop-filter: blur(30px); position: absolute; top: calc(100% + 5px); left: 0; }
#header nav a{ display: inline-block; font-size: 1.7rem; color: #fff; }
#header .depth01{ display: flex; max-width: max-content; margin: 0 auto; pointer-events: auto; }
#header .depth01 > li:not(.flex){ position: relative; }
#header .depth01 > li > a{ height: var(--headerH); display: flex; justify-content: center; align-items: center; font-weight: 500; padding: 0 26px; text-align: center; position: relative; }
#header .depth01 > li > a::before{ content: ""; width: 4px; height: 4px; background: #fff; border-radius: 50%; position: absolute; top: calc((var(--headerH) / 2) - 1em); left: 50%; transform: translateX(0); opacity: 0; transition: opacity 0.5s, left 0.5s, transform 0.5s; }

#header .depth-wrap{ --ptb: 7px; --plr: 35px; position: absolute; top: 100%; left: 50%; transform: translateX(-50%); opacity: 0; transition: opacity 0.3s; padding: 37px; padding-top: 42px; pointer-events: none; }
#header .depth02{ width: max-content; display: flex; flex-wrap: wrap; justify-content: center; }
#header .flex .depth02{ --num: 2; height: calc((1.7rem + (var(--ptb) * 2)) * var(--num)); display: flex; flex-wrap: wrap; flex-direction: column; }
#header .depth02 > li > a{ font-weight: 400; letter-spacing: -0.02em; padding: var(--ptb) var(--plr); }

#header .right{ display: flex; align-items: center; }
#header .right button{ width: 62px; display: flex; align-items: center; background: none; border: none; font-family: var(--engFont); font-size: 1.6rem; font-weight: 400; color: #fff; letter-spacing: -0.02em; position: relative; padding: 10px 16px; overflow: hidden; transition: width 0.5s; }
#header .right button::after{ content: ""; width: 16px; height: 100%; background: #111; position: absolute; top: 0; right: 0; z-index: 10; }
#header .right button span{ display: inline-block; padding-left: 5px; }

#header .right ul{ display: flex; align-items: center; margin-right: -6px; }
#header .right ul li{ padding: 0 6px; position: relative; }
#header .right ul li::after{ content: ""; width: 1px; height: 10px; background: rgba(255, 255, 255, 0.5); position: absolute; top: 50%; right: 0; transform: translate(50%, -50%); }
#header .right ul li:last-of-type::after{ display: none; }


#header .menu{ display: none; }

#header .right.login .out{ display: none; }
#header .right.logout .in{ display: none; }

#header .depth01 > li:hover .depth-wrap{ opacity: 1; pointer-events: auto; transition-delay: 0.3s; }

@media screen and (hover: hover){
	#header .depth01 > li:hover > a::before{ left: 26px; transform: translateX(-100%); opacity: 1; }
	#header .right button:hover{ width: var(--width); }
}

@media screen and (max-width: 1840px){
	#header::before{ max-width: calc(100% - 40px); }
}

@media screen and (max-width: 1400px){
	:root{
		--headerH: 80px;
		--headerT: 20px;
		--headerB: 35px;
	}

	#header .inner{ padding: 0 20px; }
	#header nav{ display: none; }

	#header .right ul{ margin-right: 0; }
	#header .right ul li{ padding: 0; }
	#header .right ul li:last-of-type::after{ display: block; }
	#header .menu{ display: block; }
}

@media screen and (max-width: 1280px){
	:root{
		--headerH: 70px;
		--headerT: 20px;
		--headerB: 20px;
	}

	#header .logo img{ width: auto; height: 37px; }

	#header .right button{ width: 50px; font-size: 1.5rem; padding: 10px; }
	#header .right button::after{ width: 11px; }
}

@media screen and (max-width: 900px){
	#header .inner{ padding: 0 15px; }
}


/* menu */
#menu{ width: 100%; height: 100%; background: rgba(0, 0, 0, 0.5); position: fixed; top: 0; left: 0; z-index: 1000; display: none; }
#menu .blank{ width: 100%; height: 100%; }
#menu .inner{ max-width: 500px; width: 100%; height: 100%; background: #111; border-radius: 20px 0 0 20px; position: absolute; top: 0; right: 0; transform: translateX(100%); transition: transform 0.5s 0.3s; padding: 0 30px; }
#menu .close{ height: var(--headerH); display: flex; justify-content: flex-end; align-items: center; }
#menu .close button{ width: 62px; display: flex; align-items: center; background: none; border: none; font-family: var(--engFont); font-size: 1.6rem; font-weight: 400; color: #fff; letter-spacing: -0.02em; position: relative; padding: 10px 16px; overflow: hidden; transition: width 0.5s; margin-right: -16px; }
#menu .close button::after{ content: ""; width: 16px; height: 100%; background: #111; position: absolute; top: 0; right: 0; z-index: 10; }
#menu .close button span{ display: inline-block; padding-left: 5px; }

#menu .scroll{ height: calc(100% - var(--headerH) - 20px); overflow-x: clip; overflow-y: auto;  -ms-overflow-style: none; }
#menu .scroll::-webkit-scrollbar { display: none; }

#menu nav a{ display: block; font-size: 1.8rem; color: #fff; line-height: 1.3; }
#menu nav .depth01{ border-top: 1px solid rgba(255, 255, 255, 0.5); }
#menu nav .depth01 > li{ border-bottom: 1px solid rgba(255, 255, 255, 0.5); }
#menu nav .depth01 > li > a{ font-weight: 600; padding: 15px; }
#menu nav .depth02{ display: none; background: rgba(255, 255, 255, 0.1); backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); padding: 5px 0; border-top: 1px solid rgba(255, 255, 255, 0.5);; }
#menu nav .depth02 > li > a{ font-weight: 400; padding: 10px 15px; }

body.open{ overflow: hidden; }
body.open #menu .inner{ transform: translateX(0); }

@media screen and (hover: hover){
	/* menu */
	#menu .close button:hover{ width: 110px; }
}

@media screen and (max-width: 500px){
	#menu .inner{ border-radius: 0; }
}


/* top */
#top{ width: 78px; height: 78px; background: rgba(130, 130, 130, 0.1); border: 1px solid rgba(105, 105, 105, 0.6); border-radius: 50%; backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); position: fixed; bottom: 40px; right: 40px; z-index: 900; opacity: 0; transition: opacity 0.5s; pointer-events: none; }
#top.scroll{ opacity: 1; pointer-events: auto; }


/* footer */
#footer{ background: #111; padding: 95px 0 70px; overflow: hidden; }

#footer nav{ padding-bottom: 75px; border-bottom: 1px solid rgba(255, 255, 255, 0.15); }
#footer nav a{ display: block; }
#footer nav .depth01{ display: flex; margin: 0 -30px; }
#footer nav .depth01 > li{ width: calc(100% / 6); position: relative; }
#footer nav .depth01 > li::after{ content: ""; width: 1px; height: calc(100% - 20px); background: rgba(255, 255, 255, 0.15); position: absolute; top: 15px; right: 0; }
#footer nav .depth01 > li:last-of-type::after{ display: none; }
#footer nav .depth01 > li > a{ font-size: 1.8rem; font-weight: 600; color: #fff; letter-spacing: -0.02em; padding: 15px 30px; }

#footer nav .depth02 > li > a{ font-size: 1.6rem; font-weight: 400; color: #777; letter-spacing: -0.02em; line-height: 1.5; padding: 5px 30px; }

#footer .logo{ padding: 60px 0 40px; }

#footer .flex-box{ display: flex; justify-content: space-between; align-items: flex-end; }
#footer .flex-box *{ font-size: 1.7rem; font-weight: 400; color: #888; }
#footer .info{ overflow: hidden; }
#footer .info .flex{ display: flex; flex-wrap: wrap; margin: -5px -15px; }
#footer .info .flex p{ padding: 5px 15px; position: relative; }
#footer .info .flex p::after{ content: "|"; position: absolute; top: 5px; left: 0; transform: translateX(-50%); }
#footer .info .flex.none p::after{ display: none; }
#footer .info .flex p:first-of-type::after{ display: none; }
#footer .info .flex p span{ margin-left: 5px; }

#footer .dl dl{ display: flex; justify-content: flex-end; align-items: baseline; }
#footer .dl dt{ font-weight: 600; color: #fff; }
#footer .dl dd{ margin-right: -5px; }
#footer .dl dd a{ display: inline-block; padding: 5px; }

#footer .copyright{ font-size: 1.5rem; margin-top: 10px; }

@media screen and (max-width: 1700px){
	/* top */
	#top{ width: 70px; height: 70px; }

	/* footer */
	#footer{ padding: 70px 0; }
	#footer nav .depth01 > li::after{ height: calc(100% - 15px); top: 10px; }
	#footer nav .depth01{ display: flex; margin: 0 -20px; }
	#footer nav .depth01 > li > a{ padding: 10px 20px; }
	#footer nav .depth02 > li > a{ padding: 5px 20px; }
}

@media screen and (max-width: 1400px){
	/* footer */
	#footer nav{ display: none; }
	#footer .logo{ padding-top: 0; }

	/* top */
	#top{ width: 60px; height: 60px; bottom: 30px; right: 20px; }
}

@media screen and (max-width: 1280px){
	/* footer */
	#footer{ padding: 40px 0; }
	#footer .logo{ padding-bottom: 20px; }
	#footer .flex-box *{ font-size: 1.6rem; }
	#footer .info .flex{ margin: -5px -10px; }
	#footer .info .flex p{ padding: 5px 10px; }
}

@media screen and (max-width: 1000px){
	/* footer */
	#footer{ padding: 30px 0; }
	#footer .flex-box{ flex-direction: column; align-items: flex-start; }
	#footer .info{ padding-bottom: 2px; }
	#footer .info .flex{ margin: 0 -10px; }
	#footer .info .flex p{ padding: 2px 10px; }
	#footer .info .flex p::after{ top: 2px; }
	#footer .dl dl{ justify-content: flex-start; }
}



/* bottom */
#bottom{ margin-bottom: 100px; }
#bottom .shadow-box{ padding: 90px 100px; background: #fff; box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.05); border-radius: 20px; }

#bottom .title{ display: flex; flex-wrap: wrap; padding-bottom: 40px; }
#bottom .title h3{ font-size: 6rem; font-weight: 700; color: #111; letter-spacing: -0.02em; padding-right: 40px; }
#bottom .title ul{ display: flex; flex-direction: column; justify-content: center; }
#bottom .title ul li{ font-size: 1.7rem; font-weight: 300; color: #666; letter-spacing: -0.02em; line-height: 1.7; padding-left: 13px; position: relative; }
#bottom .title ul li::before{ content: "*"; position: absolute; top: 0; left: 0; }


/* form-table */
.form-table{
	--th: 310px;
	--height: 80px;
	--gray: #F4F4F4;
	--border: 1px solid rgba(0, 0, 0, 0.1);
	--radius: 20px;
	--fontSize: 1.7rem;
	--padding: 40px;
	--button: 175px;
}
.form-table *{ font-size: var(--fontSize); font-weight: 300; color: #333; letter-spacing: -0.02em; }
.form-table .th, .form-table th{ width: var(--th); }

.form-table table{ width: calc(100% + 20px); border-collapse: unset; border-spacing: 10px 14px; margin-left: -10px; }
.form-table th{ font-size: 1.8rem; font-weight: 400; color: #111; letter-spacing: -0.02em; border-radius: 20px; padding: 20px; position: relative; }
.form-table th::before{ content: ""; width: 100%; height: 100%; border: var(--border); border-radius: var(--radius); position: absolute; top: 0; left: 0; z-index: -1; box-sizing: border-box; }
.form-table th span{ color: #C12929; }
.form-table td{ position: relative; }
.form-table td::before{ content: ""; width: 100%; height: 100%; background: var(--gray); border-radius: var(--radius); position: absolute; top: 0; left: 0; z-index: -1; box-sizing: border-box; }
.form-table td span{ font-size: 1.8rem; font-weight: 400; color: #222; }

.form-table td.padding{ padding: var(--padding); }
.form-table td.border::before{ background: transparent; border: var(--border); }
.form-table td.none::before{ display: none; }

.form-table .min{ min-height: var(--height); display: flex; align-items: center; padding: 20px 30px; }
.form-table .min, .form-table .min *{ font-weight: 400; color: #777; }
.form-table .small p{ color: #666; padding-left: 10px; }

.form-table .flex{ display: flex; flex-wrap: wrap; align-items: center; }
.form-table .flex > *{ margin-right: 10px; }
.form-table .flex > *:last-child{ margin-right: 0; }
.form-table .td{ max-width: calc((100% - var(--th) - 20px) / 2); width: 100%; }
.form-table .max300{ max-width: 300px; }
.form-table .max225{ max-width: 225px; }
.form-table .max175{ max-width: 175px; }

.form-table input, .form-table textarea{ width: 100%; background: var(--gray); border: none; border-radius: var(--radius) !important; -webkit-border-radius: var(--radius) !important; font-weight: 400; outline: none; }
.form-table input::placeholder, .form-table textarea::placeholder{ color: #BBB; }
.form-table input{ height: var(--height); padding: 0 var(--padding); }
.form-table input.border{ background: none; border: 1px solid #DBDBDB; }
.form-table input.border::placeholder{ color: #222; }
.form-table textarea{ resize: none; height: 215px; padding: var(--padding); }
.form-table textarea::-webkit-scrollbar{ width: 30px; height: 30px; }
.form-table textarea::-webkit-scrollbar-thumb{ background: #DBDBDB; background-clip: padding-box; border: 12px solid transparent; border-radius: 100px; }
.form-table textarea::-webkit-scrollbar-track{ background: #F0F0F0; background-clip: padding-box; border: 14px solid transparent; border-radius: 100px; }

.form-table td button{ width: var(--button); height: var(--height); background: #fff; border: 1px solid rgba(0, 0, 0, 0.7); border-radius: var(--radius); font-size: 1.8rem; font-weight: 400; color: #111; letter-spacing: -0.02em; padding: 0; }

.form-table .selectric-box{ --padding: 30px; width: 100%; }
.form-table .selectric-box *{ font-size: 1.8rem; font-weight: 400; color: #222; }
.form-table .selectric-box .selectric{ background: #fff; border: 1px solid #DBDBDB; border-radius: var(--radius); }
.form-table .selectric-box .selectric .label{ width: 100%; height: var(--height); display: flex; align-items: center; background:  url("/img/sub/select_icon.svg") no-repeat center right var(--padding); padding: 0 var(--padding); margin: 0; }
.form-table .selectric-box .selectric .button{ display: none; }
.form-table .selectric-box .selectric-items{ background: #fff; border: 1px solid #DBDBDB; border-radius: var(--radius); overflow: hidden; top: calc(100% - 1px); }
.form-table .selectric-box .selectric-items .selectric-scroll::-webkit-scrollbar{ width: 24px; height: 24px; }
.form-table .selectric-box .selectric-items .selectric-scroll::-webkit-scrollbar-thumb{ background: var(--pointColor); background-clip: padding-box; border: 10px solid transparent; border-radius: 100px; }
.form-table .selectric-box .selectric-items .selectric-scroll::-webkit-scrollbar-track{ background: #E9E9E9; background-clip: padding-box; border: 10px solid transparent; border-radius: 100px; }
.form-table .selectric-box .selectric-items li{ padding: 10px var(--padding); }
.form-table .selectric-box .selectric-items li:hover{ background: #fff; color: var(--pointColor); }
.form-table .selectric-box .selectric-items li.highlighted{ background: var(--pointColor) !important; color: #fff !important; }
.form-table .selectric-box .selectric-items .selectric-group .selectric-group-label{ font-weight: 600; color: #111; }

.form-table .input-list{ display: flex; flex-wrap: wrap; justify-content: space-between; padding: calc(var(--padding) - 7px) var(--padding); }
.form-table .input-list li{ width: calc((100% - 20px) /2); }
.form-table .input-list li:only-child{ width: 100% !important; }
.form-table .input-list input{ display: none; }
.form-table .input-list label{ display: inline-block; padding: 7px; padding-left: 30px; position: relative; cursor: pointer; }
.form-table .input-list label::before, .form-table .input-list label::after{ content: ""; width: 18px; height: 18px; position: absolute; top: calc((1.3em / 2) + 7px); left: 0; transform: translateY(-50%); box-sizing: border-box; }
.form-table .input-list label::before{ border: 1px solid #999; }
.form-table .input-list label::after{ background: url("/img/common/checkbox_icon.svg") no-repeat center center / contain; opacity: 0; }

.form-table .input-list input:checked + label::before{ background: var(--pointColor); border: 1px solid var(--pointColor); }
.form-table .input-list input:checked + label::after{ opacity: 1; }

.form-table .input-list.radio label::before, .form-table .input-list.radio label::after{ border-radius: 50%; }
.form-table .input-list.radio label::after{ width: 8px; height: 8px; background: var(--pointColor); left: calc(18px / 2); transform: translate(-50%, -50%); }
.form-table .input-list.radio input:checked + label::before{ background: transparent; border: 2px solid var(--pointColor); }


.form-table .input-list.email{ padding: 20px 40px; }
.form-table .tel .flex > div{ width: calc((100% - 55px) / 3); }
.form-table .address td{ padding: 30px; }
.form-table .address td > input{ margin-top: 15px; }
.form-table .kcaptcha figure img{ height: var(--height) !important; border-radius: 5px; }
.form-table .kcaptcha .flex > div{ flex: 1 0 auto; }
.form-table .kcaptcha button{ width: var(--height); border: 1px solid rgba(0, 0, 0, 0.1); }
.form-table .file{ margin-right: 0; }
.form-table .file input{ display: none; }
.form-table .file label{ width: 175px; height: var(--height); display: flex; justify-content: center; align-items: center; border: 1px solid rgba(0, 0, 0, 0.7); border-radius: var(--radius); font-size: 1.8rem; font-weight: 500; color: #111; letter-spacing: -0.02em; }
.form-table .file + input{ width: calc(100% - 175px); padding: 0 20px; background: none; font-weight: 300; }
.form-table .file + input::placeholder{ font-weight: 300; color: #666; }

.form-table .agree{ padding: var(--padding); }
.form-table .scroll-box{ height: 170px; overflow-x: clip; overflow-y: auto; background: var(--gray); border-radius: var(--radius); padding: 30px; }
.form-table .scroll-box::-webkit-scrollbar{ width: 30px; height: 30px; }
.form-table .scroll-box::-webkit-scrollbar-thumb{ background: #DBDBDB; background-clip: padding-box; border: 12px solid transparent; border-radius: 100px; }
.form-table .scroll-box::-webkit-scrollbar-track{ background: #F0F0F0; background-clip: padding-box; border: 14px solid transparent; border-radius: 100px; }
.form-table .scroll-box *{ font-size: 1.6rem; color: #666; line-height: 1.6875; }

.form-table .agree .input-list{ padding: 0; margin: 15px 0 -7px; }


.form-table .submit{ display: flex; justify-content: center; padding-top: 60px; text-align: center; }
.form-table .submit > *{ width: 240px; height: 70px; background: #000; border: none; border-radius: 20px; font-family: var(--baseFont); font-size: 1.8rem; font-weight: 500; color: #fff; letter-spacing: -0.02em; }
.form-table .submit > *:not(:last-of-type){ margin-right: 10px; }
.form-table .submit > *.border{ background: #fff; border: 1px solid #666; font-weight: 600; color: #111; }

@media screen and (max-width: 1700px){
	/* bottom */
	#bottom{ margin-bottom: 60px; }
	#bottom .shadow-box{ padding: 60px 70px; }
	#bottom .title{ padding-bottom: 30px; }
	#bottom .title h3{ font-size: 4rem; }
	#bottom .title ul li{ font-size: 1.6rem; }

	/* form-table */
	.form-table{
		--th: 250px;
		--height: 75px;
		--padding: 30px;
		--button: 150px;
	}

	.form-table td button{ font-size: 1.7rem; }
	.form-table .selectric-box *{ font-size: 1.7rem; }

	.form-table .scroll-box{ padding: 20px; }
	.form-table .agree .input-list{ margin-top: 15px; }

	.form-table .input-list.email{ padding: 20px 30px; }

	.form-table .submit{ padding-top: 40px; }
	.form-table .submit > *{ width: 200px; height: 60px; }
}

@media screen and (max-width: 1500px){
	/* bottom */
	#bottom .shadow-box{ padding: 30px 40px; }

	/* form-table */
	.form-table colgroup{ display: none; }
	.form-table tr{ display: flex; flex-wrap: wrap; }
	.form-table tr:not(:last-of-type){ margin-bottom: 14px; }
	.form-table th{ display: flex; justify-content: center; align-items: center; }
	.form-table td{ width: calc(100% - var(--th) - 10px); margin-left: 10px; }
	.form-table tr th:not(:last-of-type), .form-table tr td:not(:last-of-type){ margin-bottom: 14px; }

	.form-table .small p{ padding-left: 0; margin-top: 10px; }

	.form-table .td{ max-width: calc((100% - 10px) / 2); }
}

@media screen and (max-width: 1280px){
	/* bottom */
	#bottom{ margin-bottom: 30px; }
	#bottom .shadow-box{ padding: 25px; }
	#bottom .title{ padding-bottom: 20px; }
	#bottom .title h3{ font-size: 3rem; }
	#bottom .title ul li{ font-size: 1.5rem; }

	/* form-table */
	.form-table{
		--th: 180px;
		--height: 60px;
		--fontSize: 1.6rem;
		--padding: 20px;
		--button: 130px;
		--radius: 15px;
	}

	.form-table th{ font-size: 1.7rem; }
	.form-table th br{ display: none; }
	.form-table td button{ font-size: 1.6rem; }

	.form-table .input-list label{ padding-left: 25px; }
	.form-table .input-list label::before, .form-table .input-list label::after{ width: 16px; height: 16px; }
	.form-table .input-list.radio label::after{ width: 7px; height: 7px; left: 8px; }

	.form-table .selectric-box{ --padding: 20px; }
	.form-table .selectric-box *{ font-size: 1.6rem; }

	.form-table .file label{ width: 150px; font-size: 1.6rem; }
	.form-table .file + input{ width: calc(100% - 150px); }
	
	.form-table .scroll-box{ border-radius: 15px; }
	.form-table .agree .input-list{ margin-top: 10px; }

	.form-table .min{ padding: 20px; }

	.form-table .address td{ padding: 20px; }
	.form-table .input-list.email{ padding: 15px 20px; }

	.form-table .submit{ padding-top: 20px; }
	.form-table .submit > *{ width: 160px; height: 55px; font-size: 1.7rem; }
}

@media screen and (max-width: 1150px){
	.form-table .input-list li{ width: 100%; }
}

@media screen and (max-width: 1000px){
	.form-table colgroup{ display: none; }
	.form-table tr{ display: flex; flex-direction: column; }
	.form-table tr:not(:last-of-type){ margin-bottom: 30px; }
	.form-table .th, .form-table th, .form-table td{ width: 100%; }
	.form-table th{ margin-bottom: 10px; padding: 15px; }
	.form-table td{ margin-left: 0; }
	.form-table tr th{ margin-bottom: 14px; }
	.form-table tr td:not(:last-of-type){ margin-bottom: 30px; }

	.form-table .max175{ max-width: 100%; }

	.form-table .td{ max-width: 100%; margin-right: 0; }
	.form-table .id .td{ max-width: calc(100% - var(--button) - 10px); margin-right: 10px; }

	.form-table .flex .max225{ max-width: calc(100% - var(--button) - 10px); width: 100%; }
	.form-table .flex.half > *{ width: calc((100% - 10px) / 2); }
	.form-table .address td{ padding: 15px; }
	.form-table .kcaptcha .flex > div{ max-width: calc(100% - var(--height) - 20px); width: min-content; }

	.form-table .file label{ width: 120px; }
	.form-table .file + input{ width: calc(100% - 120px); }
	.form-table .agree .input-list{ margin-top: 5px; }
}

@media screen and (max-width: 900px){
	/* bottom */
	#bottom .title{ flex-direction: column; }
	#bottom .title h3{ font-size: 2.6rem; padding-right: 0; padding-bottom: 10px; }
}