@charset 'utf-8';

/* ���� */
:root{
    --baseFont: 'Pretendard', 'Noto Sans KR', 'Malgun Gothic', 'verdana', sans-serif;
	--engFont: 'Nunito Sans', 'Pretendard', 'Noto Sans KR', 'Malgun Gothic', 'verdana', sans-serif;
	--Lato: 'Lato', 'Pretendard', 'Noto Sans KR', 'Malgun Gothic', 'verdana', sans-serif;
	--Noto: 'Noto Sans KR', 'Pretendard', 'Malgun Gothic', 'verdana', sans-serif;
	--Roboto: 'Roboto', 'Pretendard', 'Malgun Gothic', 'verdana', sans-serif;
	--Inter: 'Inter', 'Pretendard', 'Malgun Gothic', 'verdana', sans-serif;
	--mainColor: #1CA538;
	--blue: #062E96;
	--headerH: 100px;
	--vh: 100%;
}

*{  box-sizing: border-box; word-break: keep-all; line-height: 1.3; }
body.lock{ overflow: hidden; }

.w1920{ max-width: 1920px; width: 100%; margin: 0 auto; }
.w1720{ max-width: 1720px; width: 100%; margin: 0 auto; }
.w1600{ max-width: 1600px; width: 100%; margin: 0 auto; }

@media screen and (max-width: 1760px){
	.w1720{ padding: 0 20px; }
}

@media screen and (max-width: 1640px){
	.w1600{ padding: 0 20px; }
}

@media screen and (max-width: 1350px){
	:root{
		--headerH: 80px;
	}
}

@media screen and (max-width: 1000px){
	:root{
		--headerH: 70px;
	}
}

/* privacy */
.privacy * { font-size: 1.6rem; line-height: 1.625; }
.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: 100px 0; }
.privacy .textBox h3{ font-size: 2.2rem; margin-bottom: 5px; }

.privacy .pBox { gap: 30px 0; margin: 40px 0; }

.privacy .dlBox { gap: 50px 0; }
.privacy .dlBox > dl > dt { font-size: 1.8rem; font-weight: 500; }
.privacy .dlBox > dl > dd > p { margin: 5px 0; }
.privacy .dlBox > dl > dd > ul { padding: 0 0 0 20px; }
.privacy .dlBox > dl > dd ul:only-child{ margin-top: 5px; }

.privacy .square { 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::before { content: "-"; position: absolute; top: 0; left: 0; }
.privacy .square > p { width: 100%; padding: 0 0 0 13px; }

.privacy .subTextBox { gap: 24px 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: 80px 0; }

	.privacy .pBox{ gap: 15px 0; }
	
	.privacy .dlBox { gap: 30px 0; }
}

@media screen and (max-width: 900px){
	.privacy .dlBox > dl > dt { font-size: 1.7rem; }
	.privacy * { font-size: 1.5rem; }
	.privacy .dlBox > dl > dd > ul { padding: 0 0 0 10px; }
}


/* header */
#header{ width: 100%; position: fixed; top: 0; left: 0; z-index: 900; }
#header::before{ content: ""; width: 100%; height: 100%; background: #fff; border-bottom: 1px solid #EEE; position: absolute; top: 0; left: 0; z-index: -1; opacity: 0; transition: opacity 0.5s 0.3s; }
#header .logo{ display: inline-block; position: relative; opacity: 1; transition: opacity 0.5s; }
#header .logo a{ position: absolute; top: 0; right: 0; bottom: 0; left: 0; z-index: 10; }
#header .flex-box{ height: var(--headerH); display: flex; justify-content: space-between; align-items: center; }

#header nav{ margin-left: 70px; opacity: 1; transition: opacity 0.5s; }
#header .depth01{ display: flex; }
#header .depth01 > li{ position: relative; }
#header .depth01 > li > a{ display: flex; justify-content: center; align-items: center; width: 175px; height: var(--headerH); font-size: 1.8rem; font-weight: 400; color: #fff; text-align: center; transition: font-weight 0.5s 0.3s, color 0.5s 0.3s; }
#header .depth02{ width: 100%; position: absolute; text-align: center; display: none; }
#header .depth02 > li{ background: #fff; border: 1px solid rgba(221, 221, 221, 0.5); }
#header .depth02 > li:not(:last-of-type){ border-bottom: none; }
#header .depth02 > li > a, #header .depth02 > li > button{ display: inline-block; width: 100%; font-size: 1.6rem; font-weight: 500; color: #666; letter-spacing: -0.02em; padding: 17px 15px; transition: color 0.5s; }
#header .depth02 > li > a span{ display: inline-block; background: var(--mainColor); font-family: var(--baseFont); font-size: 1.4rem; font-weight: 400; color: #fff; line-height: 1; padding: 7px 10px; border-radius: 10px; margin: -6px 0; margin-right: 5px; }

#header .right{ display: flex; align-items: center; position: relative; }

#header .sns{ margin-right: 95px; opacity: 1; transition: opacity 0.5s; }
#header .sns ul{ display: flex; }
#header .sns ul li{ width: 34px; height: 34px; background: rgba(0, 0, 0, 0.3); border-radius: 50%; position: relative; transition: background 0.5s 0.3s; }
#header .sns ul li:not(:last-of-type){ margin-right: 12px; }
#header .sns ul li img{ position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); filter: invert(0); -webkit-filter: invert(0); transition: filter 0.5s 0.3s; }
#header .sns ul li a{ position: absolute; top: 0; right: 0; bottom: 0; left: 0; z-index: 10; }

#header .lang{ position: relative; opacity: 1; transition: opacity 0.5s; }
#header .lang button{ display: flex; align-items: center; gap: 10px; background: none; border: none; font-family: var(--Lato); font-size: 1.4rem; font-weight: 700; color: #fff; letter-spacing: -0.02em; padding: 20px; padding-left: 28px; position: relative; transition: color 0.5s 0.3s; }
#header .lang button::before, #header .lang button::after{ position: absolute; filter: invert(0); -webkit-filter: invert(0); transition: filter 0.5s 0.3s, transform 0.5s, top 0.5s; }
#header .lang button::before{ content: url("/img/common/lang_icon.svg"); display: inline-block; top: 52%; left: 0; transform: translateY(-50%) rotate(0); }
#header .lang button::after{ content: url("/img/common/lang_arrow.svg"); display: inline-block; position: absolute; top: 45%; right: 0; transform: translateY(-50%); }
#header .lang ul{ width: 100%; background: #333; border-radius: 10px; position: absolute; top: calc(100% - 10px); padding: 7px 0; display: none; }
#header .lang ul li a{ display: inline-block; width: 100%; font-family: var(--Lato); font-size: 1.4rem; font-weight: 700; color: #fff; text-align: center; opacity: 0.4; padding: 1px 10px; }
#header .lang ul li.on a{ opacity: 1; }

#header .lang.hover button::after{ top: 54%; transform: translateY(-50%) rotate(-180deg); }

#header .menu{ background: none; border: none; padding: 20px; margin-right: -20px; overflow: hidden; }
#header .menu span{ display: inline-block; width: 22px; height: 2px; background: #fff; border-radius: 990px; vertical-align: middle; position: relative; transition: transform 0.5s, background 0.5s 0.3s; }
#header .menu span::before, #header .menu span::after{ content: ""; width: 100%; height: 100%; background: #fff; border-radius: inherit; position: absolute; left: 0; transform: rotate(0); transition: transform 0.5s, top 0.5s, background 0.5s 0.3s; }
#header .menu span::before{ top: -7px; }
#header .menu span::after{ top: 7px; }

/* header - hover */
#header.hover .depth01 > li > a{ color: #111; transition-delay: unset; }
#header.hover::before{ opacity: 1; transition-delay: unset; }
#header.hover .sns ul li{ background: #EEE; transition-delay: unset; }
/* #header.hover .sns ul li img{ filter: invert(1); -webkit-filter: invert(1); transition-delay: unset; } */
#header.hover .lang button{ color: #111; transition-delay: unset; }
#header.hover .lang button::before, #header.hover .lang button::after{ filter: invert(1); -webkit-filter: invert(1); transition-delay: unset; }
#header.hover .menu span{ background: #111; transition-delay: unset; }
#header.hover .menu span::before, #header.hover .menu span::after{ background: #111; transition-delay: unset; }

/* header - scroll */
#header.scroll .depth01 > li > a{ font-weight: 500; color: #111; transition-delay: unset; }
#header.scroll::before{ opacity: 1; transition-delay: unset; }
#header.scroll .sns ul li{ background: #EEE; transition-delay: unset; }
/*
#header.scroll .sns ul li img{ filter: invert(1); -webkit-filter: invert(1); transition-delay: unset; }
*/
#header.scroll .lang button{ color: #111; transition-delay: unset; }
#header.scroll .lang button::before, #header.scroll .lang button::after{ filter: invert(1); -webkit-filter: invert(1); transition-delay: unset; }
#header.scroll .menu span{ background: #111; transition-delay: unset; }
#header.scroll .menu span::before, #header.scroll .menu span::after{ background: #111; transition-delay: unset; }

@media screen and (hover: hover){
	#header .depth01 > li:hover > a{ font-weight: 600; color: #000; transition-delay: unset; }
	#header .depth02 > li:hover > a, #header .depth02 > li:hover > button{ color: var(--mainColor); transition-delay: unset; }
}

@media screen and (max-width: 1440px){
	#header nav{ margin-left: 30px; }
	#header .sns{ margin-right: 30px; }
}

@media screen and (max-width: 1350px){
	#header nav{ display: none; }
}

@media screen and (max-width: 1000px){
	#header .logo img{ width: auto; height: calc(var(--headerH) - 20px); }
	#header .sns{ margin-right: 20px; }
	#header .sns ul li:not(:last-of-type){ margin-right: 10px; }
}


/* menu */
#menu{ width: 100%; height: 100%; position: fixed; top: 0; left: 0; z-index: 850; background: url("/img/common/menu_bg.jpg") no-repeat center center / cover; display: none; }
#menu::before{ content: ""; width: calc(100% - 20px); height: 210px; background: url("/img/common/menu_logo.svg") no-repeat bottom right / contain; position: absolute; bottom: 0; right: 0; pointer-events: none; }
#menu > div{ height: 100%; position: relative; z-index: 10; }
#menu .pt{ padding-top: var(--headerH); }
#menu h2{ font-family: var(--engFont); font-size: 7.3rem; font-weight: 800; color: #1B1B1B; padding: 10px 0 40px; transform: translateY(-50px); opacity: 0; transition: transform 1s 0.5s, opacity 1s 0.5s; }
#menu .mobile{ display: none; }

#menu .depth01{ display: flex; margin-left: -20px; }
#menu .depth01 a{ display: block; line-height: 1.3; }
#menu .depth01 > li{ width: calc(100% / 5); }
#menu .depth01 > li > a{ font-size: 3rem; font-weight: 600; color: #000; padding: 25px 20px; transform: translateY(50px); opacity: 0; transition: transform 1s, opacity 1s; }
#menu .depth02 > li{ transform: translateY(50px); opacity: 0; transition: transform 1s, opacity 1s; }
#menu .depth02 > li > a{ font-size: 1.8rem; font-weight: 400; color: #888; padding: 10px 20px; transition: color 0.5s; }

/* body - open */
body.open{ overflow-y: hidden; }
body.open #header{ background: transparent; }
body.open #header nav{ opacity: 0; pointer-events: none; }
body.open #header::before{ opacity: 0; }
body.open #header .logo, body.open #header nav, body.open #header .sns, body.open #header .lang{ opacity: 0; }
body.open #header .menu span{ background: #000; }
body.open #header .menu span::before, body.open #header .menu span::after{ background: #000; top: 0; }
body.open #header .menu span{ transform: translateX(100px); }
body.open #header .menu span::before{ transform: translateX(-100px) rotate(45deg); }
body.open #header .menu span::after{ transform: translateX(-100px) rotate(-45deg); }

body.open #menu h2, body.open #menu .depth01 > li > a, body.open #menu .depth02 > li{ transform: translateY(0); opacity: 1; }

body.open #floating{ opacity: 0 !important; pointer-events: none; }

@media screen and (hover: hover){
	#menu .depth02 > li:hover > a{ color: var(--mainColor); }
}

@media screen and (max-width: 1600px){
	#menu h2{ font-size: 6rem; }

	#menu .depth01 > li > a{ font-size: 2.6rem; }
}

@media screen and (max-width: 1280px){
	#menu h2{ font-size: 5rem; padding: 10px 0 20px; }

	#menu .depth01 > li > a{ font-size: 2.2rem; padding: 10px 20px; }
	#menu .depth02 > li > a{ font-size: 1.7rem; }
}

@media screen and (max-width: 1000px){
	#menu h2{ font-size: 4rem; padding: 10px 0; }
	#menu .pc{ display: none; }
	#menu .mobile{ display: block; }

	#menu .nav{ height: calc(100% - var(--headerH) - 100px); overflow-y: auto; }
	#menu .nav::-webkit-scrollbar{ width: 24px; }
	#menu .nav::-webkit-scrollbar-thumb{  background: #666; background-clip: padding-box; border: 7px solid transparent; border-radius: 100px; }
	#menu .nav::-webkit-scrollbar-track{ background: #eee; background-clip: padding-box; border: 7px solid transparent; border-radius: 100px; }
	#menu .depth01{ display: block; }
	#menu .depth01 > li{ width: 100%; position: relative; }
	#menu .depth01 > li::after{ content: ""; width: 100%; height: 49px; position: absolute; top: 0; left: 0; z-index: 10; cursor: pointer; }

	#menu .depth02{ display: none; padding-bottom: 7px; }
	#menu .depth02 > li > a{ padding: 7px 20px; }
}

@media screen and (max-width: 600px){
	#menu .depth01 > li > a{ font-size: 2.5rem; }
	#menu .depth02 > li > a{ font-size: 1.8rem; }
}


/* floating */
#floating{ position: fixed; bottom: 40px; right: 30px; z-index: 900; opacity: 1; transition: opacity 0.5s; }
#floating.opacity{ opacity: 0; pointer-events: none; }
#floating > ul > li:not(:last-of-type){ margin-bottom: 10px; }
#floating > ul > li button{ width: 60px; height: 60px; border-radius: 10px; box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.14); backdrop-filter: blur(9px); -webkit-backdrop-filter: blur(9px); }
#floating > ul > li .kakao{ background: #FAE100; border: none; }
#floating > ul > li .inquiry{ background: rgb(28, 165, 56, 0.78); border: 1px solid var(--mainColor); }
#floating > ul > li #top{ background: #fff; border: none; }

#floating .inquiry-popup{ width: 100%; height: 100%; background: rgba(0, 0, 0, 0.4); position: fixed; top: 0; left: 0; display: none; }
#floating .blank{ position: absolute; top: 0; right: 0; bottom: 0; left: 0; }
#floating .popup{ width: 700px; background: #fff; border-radius: 15px; padding: 30px; position: absolute; bottom: 40px; right: 160px; box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.14); }
#floating .popup .close{ background: none; border: none; padding: 20px; position: absolute; top: 15px; right: 15px; }
#floating .popup .title{ display: flex; align-items: center; margin-bottom: 20px; }
#floating .popup .title .icon{ width: 48px; height: 48px; background: rgb(28, 165, 56, 0.78); border: 1px solid var(--mainColor); border-radius: 10px; padding: 10px; }
#floating .popup .title .icon img{ height: auto; }
#floating .popup .title h6{ font-family: var(--engFont); font-size: 2.4rem; font-weight: 700; color: #000; letter-spacing: -0.02em; padding-left: 20px; }
#floating .popup .scroll-box{ max-height: 53vh; overflow-y: auto; }
#floating .popup .scroll-box::-webkit-scrollbar{ width: 24px; }
#floating .popup .scroll-box::-webkit-scrollbar-thumb{  background: #666; background-clip: padding-box; border: 7px solid transparent; border-radius: 100px; }
#floating .popup .scroll-box::-webkit-scrollbar-track{ background: #eee; background-clip: padding-box; border: 7px solid transparent; border-radius: 100px; }

#floating .inquiry-form .title h6{ width: calc(100% - 48px); }
#floating .inquiry-form{ --height: 50px; /* display: none; */ }
#floating .inquiry-form .form *{ font-size: 1.6rem; color: #000; outline: none; }
#floating .inquiry-form .form .line.flex{ display: flex; gap: 10px; }
#floating .inquiry-form .form .line.flex2{ display: flex; gap: 10px; }
#floating .inquiry-form .form .line:not(:last-of-type){ margin-bottom: 10px; }
#floating .inquiry-form .form .input{ display: flex; background: #F6F6F6; border: none; border-radius: 5px; -webkit-border-raidus: 5px; padding: 0 25px; }
#floating .inquiry-form .form .flex .input:first-of-type{ width: 345px; }
#floating .inquiry-form .form .flex .input:last-of-type{ width: calc(100% - 355px); }
#floating .inquiry-form .form .flex2 .input{ width: calc(100% - var(--height) - 10px); }
#floating .inquiry-form .form .input > span, #floating .inquiry-form .form input::placeholder, #floating .inquiry-form .form textarea::placeholder{ font-weight: 600; color: #000; }
#floating .inquiry-form .form .input > span{ width: 160px; height: var(--height); display: flex; align-items: center; }

/* select custom */
#floating .inquiry-form .selectric-box{ width: calc(100% - 160px); }
#floating .inquiry-form .selectric-box .selectric{ border: none; }
#floating .inquiry-form .selectric-box .selectric .label{ display: flex; align-items: center; height: var(--height); font-weight: 600; color: #000; margin: 0; padding-right: 20px; }
#floating .inquiry-form .selectric-box .selectric .button{ width: 20px; height: var(--height); }
#floating .inquiry-form .selectric-box .selectric .button:after{ width: 100%; height: 100%; background: #F6F6F6 url("/img/common/inquiry_arrow.svg") no-repeat center right / auto; border: none; }
#floating .inquiry-form .selectric-box .selectric-items{ width: calc(100% + 20px) !important; background: #F6F6F6; border: none; border-radius: 0 0 5px 5px; left: 50%; transform: translateX(-50%); overflow: hidden; box-shadow: 0px 5px 10px rgba(0, 0, 0, 0.2); }
#floating .inquiry-form .selectric-box .selectric-items li{ font-size: 1.5rem; font-weight: 400; padding: 5px 10px; }
#floating .inquiry-form .selectric-box .selectric-items li.highlighted{ background: var(--mainColor) !important; color: #fff; }
#floating .inquiry-form .selectric-box .selectric-items li:hover{ background: unset; }

#floating .inquiry-form .form input, #floating .inquiry-form .form textarea{ width: 100%; border: none; background: #F6F6F6; }
#floating .inquiry-form .form input{ height: var(--height); }
#floating .inquiry-form .form button{ width: var(--height); height: var(--height); background: #333; border-radius: 5px; -webkit-border-radius: 5px; border: none; }
#floating .inquiry-form .form textarea{ resize: none; height: 100px; padding: 15px 0; }

#floating .inquiry-form .radio-list{ display: flex; flex-wrap: wrap; gap: 0 40px; padding: 5px 0; }
#floating .inquiry-form .radio-list input{ display: none; }
#floating .inquiry-form .radio-list label{ display: inline-block; position: relative; padding: 10px 0; padding-left: 30px !important; cursor: pointer; }
#floating .inquiry-form .radio-list label::before{ content: ""; width: 20px; height: 20px; border: 2px solid #BBB; border-radius: 50%; box-sizing: border-box; position: absolute; top: calc((1.2em / 2) + 10px); left: 0; transform: translateY(-50%); }
#floating .inquiry-form .radio-list input:checked + label::after{ content: ""; width: 8px; height: 8px; background: var(--mainColor); border-radius: 50%; position: absolute; top: calc((1.2em / 2) + 10px); left: calc(20px / 2); transform: translate(-50%, -50%); }

#floating .inquiry-form .form .auto span{ width: 125px; }
#floating .inquiry-form .form .auto figure{ width: 120px; height: var(--height); position: relative; overflow: hidden; }
#floating .inquiry-form .form .auto figure img{ width: 100%; height: 100%; object-fit: cover; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); }
#floating .inquiry-form .form .auto input{ width: calc(100% - 125px - 120px); padding-left: 20px; }

#floating .inquiry-form .agree{ display: flex; justify-content: space-between; align-items: center; margin-top: 20px; }
#floating .inquiry-form .agree .radio-list{ gap: 0; }
#floating .inquiry-form .agree .radio-list *{ font-size: 1.4rem; font-weight: 500; color: #000; }
#floating .inquiry-form .agree .radio-list label{ letter-spacing: -0.02em; }
#floating .inquiry-form .agree .radio-list button.policy{ font-family: var(--baseFont); letter-spacing: -0.02em; border: none; background: none; text-decoration-line: underline; text-underline-position : under; padding: 0 10px; }
#floating .inquiry-form .submit{ width: 290px; height: 50px; background: #333; border: none; border-radius: 5px; font-family: var(--baseFont); font-size: 1.7rem; font-weight: 500; color: #fff; }

#floating .policy-popup{ display: none; }
#floating .policy-popup .title{ display: block; text-align: center; }
#floating .popup.policy-popup .scroll-box{ max-height: calc(53vh + 15px); }
#floating .policy-popup .scroll-box dl:not(:last-of-type){ margin-bottom: 20px; }
#floating .policy-popup dl dt{ font-size: 1.8rem; font-weight: 600; color: #111; letter-spacing: -0.02em; margin-bottom: 10px; }
#floating .policy-popup dl dd{ font-size: 1.6rem; font-weight: 400; color: #111; letter-spacing: -0.02em; line-height: 1.5; }

@media screen and (max-width: 1640px){
	#floating{ right: 20px; }
}

@media screen and (max-width: 1600px){
	#floating .popup .title h6{ font-size: 2.2rem; }
}

@media screen and (max-width: 1280px){
	#floating .popup .title .icon{ width: 40px; height: 40px; padding: 5px; }
	#floating .popup .title h6{ font-size: 2rem; }

	#floating .inquiry-form{ --height: 45px; }
	#floating .inquiry-form .title h6{ width: calc(100% - 40px); padding-left: 15px; }
	#floating .inquiry-form .form *{ font-size: 1.5rem; }
	#floating .inquiry-form .form .input{ padding: 0 15px; }
	#floating .inquiry-form .form .input > span{ width: 140px; }

	#floating .inquiry-form .selectric-box{ width: calc(100% - 140px); }

	#floating .inquiry-form .radio-list{ padding: 3px 0; gap: 0 20px; }

	#floating .inquiry-form .form .auto figure{ width: 110px; }
	#floating .inquiry-form .form .auto input{ width: calc(100% - 140px - 110px); }

	#floating .inquiry-form .submit{ height: 45px; }
}

@media screen and (max-width: 900px){
	#floating .popup{ right: 20px; }
}

@media screen and (max-width: 740px){
	#floating .popup{ width: calc(100% - 40px); padding: 20px; }
	#floating .popup .close{ top: 0; right: 0; }

	#floating .inquiry-form .form .line.flex{ flex-direction: column; }
	#floating .inquiry-form .form .flex .input{ width: 100% !important; }

	#floating .inquiry-form .form .line.flex2 .auto > span{ width: 110px; }
	#floating .inquiry-form .form .auto input{ width: calc(100% - 110px - 110px); }
}

@media screen and (max-width: 700px){
	#floating .popup .scroll-box{ max-height: calc(100vh - 180px); }

	#floating .inquiry-form .agree{ flex-wrap: wrap; flex-direction: colum; }
	#floating .inquiry-form .submit{ width: 100%; margin-top: 10px; }

	#floating .popup.policy-popup .scroll-box{ max-height: calc(100vh - 260px); }
}


/* footer */
#footer{ background: #222; padding: 80px 0 60px; }
#footer *{ color: #fff; }
#footer .flex-box{ display: flex; justify-content: space-between; }
#footer .logo{ display: inline-block; position: relative; }
#footer .logo a{ position: absolute; top: 0; right: 0; bottom: 0; left: 0; z-index: 10; }

#footer .dl{ margin: 60px 0 50px; }
#footer .dl dl:not(:last-of-type){ margin-bottom: 20px; }
#footer .dl dt{ font-size: 1.8rem; font-weight: 600; letter-spacing: -0.02em; margin-bottom: 10px; }
#footer .dl dd{ font-size: 1.6rem; font-weight: 400; letter-spacing: -0.02em; }
#footer .dl dd div{ display: flex; flex-wrap: wrap; gap: 0 10px; }
#footer .dl dd p{ color: #BBB; line-height: 1.625; }
#footer .dl dd p span{ color: #fff; line-height: inherit; }

#footer .policy{ display: inline-block; font-size: 1.7rem; font-weight: 500; letter-spacing: -0.02em; text-decoration-line: underline; text-underline-position : under; padding: 15px; margin-top: -15px; margin-left: -15px; }
#footer .copyright{ font-size: 1.6rem; font-weight: 300; opacity: 0.5; }

#footer .nav{ margin-top: 5px; }
#footer .depth01{ display: flex; }
#footer .depth01 a{ display: block; line-height: 1.3; letter-spacing: -0.02em; }
#footer .depth01 > li{ width: 170px; }
#footer .depth01 > li > a{ font-size: 2rem; font-weight: 700; padding: 25px 5px; }

#footer .depth02 > li > a{ font-size: 1.6rem; font-weight: 300; opacity: 0.5; padding: 5px; }

@media screen and (max-width: 1600px){
	#footer .dl dt{ font-size: 1.7rem; }

	#footer .depth01 > li{ width: 160px; }
	#footer .depth01 > li > a{ font-size: 1.8rem; }
}

@media screen and (max-width: 1500px){
	#footer{ padding: 40px 0 30px; }

	#footer .dl{ display: flex; flex-wrap: wrap; gap: 20px 50px; margin: 30px 0; }
	#footer .dl dl:not(:last-of-type){ margin-bottom: 0; }
	
	#footer .nav{ display: none; }
}

@media screen and (max-width: 1280px){
	#footer .dl dt{ font-size: 1.6rem; margin-bottom: 5px; }
	#footer .dl dd{ font-size: 1.5rem; }

	#footer .policy{ font-size: 1.6rem; }
	#footer .copyright{ font-size: 1.5rem; }
}