/* basic css */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, details, figcaption, figure, dialog,
footer, header, hgroup, menu, nav, section {margin: 0; padding: 0; border: 0;}
article, aside, details, figcaption, figure, dialog,
footer, header, hgroup, menu, nav, section {display: block;}
html, body { height:auto;}
body { color:#4c4c4c; line-height:1.6; letter-spacing: -0.5px; -webkit-text-size-adjust:none; }
h1, h2, h3, h4, h5, h6 {font-size: 100%;font-weight: normal;}
a:link { color: inherit; text-decoration: none; }
a:visited { color: inherit; text-decoration: none; }
a:hover { color: inherit; text-decoration: none; }
a:active { color: inherit; text-decoration: none; }
a:focus { color: inherit; text-decoration: none; }
select, input, textarea {font-size: 100%;vertical-align: middle; }
input {margin: 0;padding: 0;}
ol, ul {list-style: none;}
label {cursor: pointer;}
legend, caption {width: 0;height: 0; visibility: hidden; font-size: 0;line-height: 0;}
button {cursor: pointer;}
button:focus {outline: 1px dotted;}
img {vertical-align: top;}
/* table {} */

/*.hidden {position: absolute;width: 0;height: 0;visibility: hidden;font-size: 0;line-height: 0; top:-9999px}*/


input[type="text"] {box-sizing:border-box; -webkit-appearance:none;appearance:none;}
input:-ms-input-placeholder {color:#808080}
input::-webkit-input-placeholder {color:#808080}
input::-moz-placeholder {color:#808080}
input::-moz-placeholder {color:#808080}
/* textarea {} */

html, body {height:auto; -ms-overflow-style: none;}

::-webkit-scrollbar {

display:none;

}



/* layout*/


header { position: fixed; width: 100%; z-index:99999; top: 0; left: 0; }


.navi { position: absolute;  width: 100%; height: 7.25rem; right: 0px; top: 0px; z-index: 9999; border: none; background: none; transition: height 0.3s, background 0.3s, border 0.3s; background: none; border: none; display: none; text-align: center;
/*background: #fff; border-bottom: 1px solid #ddd; transition: background 0.5s, box-shadow 0.5s;*/
}

#logo { width: 218px; height: 31px; line-height: 100%; font-weight: 800; transform: translateY(0px); position: absolute; top: 0; left: 6.25rem; bottom: 0; margin: auto; z-index: 99999999; transition: 0.3s; transform-origin: left center; }
#logo a { display: inline-block; width: 100%; height: 100%;  left:0px; background: url(../img/common/logo2.png) center no-repeat; background-size: cover; text-indent:-9999px; transition: 0.3s; }
/* #logo a { display: block; width: 100%; height: 100%; transition: 0.3s; } */

/* body.main #logo a { background: url(../img/common/logo.png) center no-repeat; background-size: cover; } */

/*.navi.active2 { background-color: #fff; border-bottom: 1px solid #ddd; }*/

/*body.main .navi.active { background-color: #fff; border-bottom: 1px solid #ddd; }
body.main .navi.active2 { background-color: #fff; border-bottom: 1px solid #ddd; }*/

.navi.white #logo { color: #fff; }
.navi.white #logo a { background: url(../img/common/logo.png) center no-repeat; background-size: cover; }
.navi.white2 #logo { color: #fff; }
.navi.white2 #logo a { background: url(../img/common/logo2.png) center no-repeat; background-size: cover; }

.navi.over { background-color: #fff; border-bottom: 1px solid #ddd; }
.navi.over #logo a { background: url(../img/common/logo.png) center no-repeat; background-size: cover; }

.navi.active { height: 6.25rem; background-color: #fff; border-bottom: 1px solid #ddd; }
.navi.active #logo a { background: url(../img/common/logo2.png) center no-repeat; background-size: cover; }

/* .navi.active #logo a { background: url(../img/common/logo.png) center no-repeat; background-size: cover; } */

.navi.active #logo { color: #000; }
.navi.over #logo { color: #000; }
/*  */

.gnb { position: relative; display: inline-block; transform: translateX(-3rem); z-index:2; overflow:hidden; height: 100%; letter-spacing:0; z-index: 99; transition: 0.3s; }
.gnb>ul>li { position:relative; float:left; text-align:center; margin: 0 1.25rem; }

.navi .depth1 { position:relative; display:block; color: #303030; font-size: 0.9375rem; font-weight: 500; letter-spacing: -0.3px; line-height: 7.25rem; margin: 0px; padding: 0px 0.25rem;transition: 0.3s; text-transform: uppercase; letter-spacing: 0.0187rem; }
.gnb>ul>li:hover>a { color: #fff799 !important; }
/* .gnb>ul>li:nth-child(4) { width: 207px; height: 34px; } */
.gnb>ul>li>ul { display: block; margin-top: 1rem; opacity: 0; transform: translateY(1.25rem); }
.gnb>ul>li>ul>li { float: none; height: 1.875rem; width: auto; }
.gnb>ul>li>ul>li.line2 { height: auto; line-height: 102%; margin-top: 0.25rem; }
.gnb>ul>li>ul>li>a { font-size: 0.813rem; color: #000; font-weight: 500; letter-spacing: -0.7px; }
.gnb>ul>li>ul>li>a:hover { color: #2e1263; }
.gnb .line { position: absolute; display: block; top: 2rem; height: 1px; width: 12px; background: #fff799; left: 0; right: 0; margin: auto; z-index:-99; transition: 0.35s; opacity: 1; transform: rotate(45deg) translate(-0.75rem,0rem); opacity: 0; }
.navi-bg { position: absolute; display: block; width: 100%; height: 0px; left: 0; top: calc(7.25rem + 1px); z-index:1; overflow: hidden; transition: 0.3s; }
.navi-bg .white-bg { width:100%; height: 8rem; background: #fff; border-bottom: 1px solid #dedede; }

body.main .navi .depth1 { color: #000; }
/*body.main .gnb>ul>li:hover>a { color: #004e71 !important; }
body.main .gnb .line { background: #004e71; }*/

.navi.white .gnb .depth1 { color: rgba(255,255,255,1); }
.navi.white .gnb>ul>li:hover>a { color:#fff799 !important; }
.navi.white .gnb .line { background: #fff799; }

.navi.active .navi-bg { top: calc(6.25rem + 1px); }
.navi.active .gnb .depth1 { color: #303030; line-height: 6.25rem; }
/* .navi.active .gnb .line { bottom: 2rem; } */
.navi.active .gnb>ul>li:hover>a { color:#2e1263 !important; }
.navi.active .gnb .line { background: #2e1263 !important; }

.navi.over .gnb .depth1 { color: #303030; }
.navi.over .gnb .line { background: #2e1263; }
.navi.over .gnb>ul>li:hover>a { color:#2e1263 !important; }

/*  */

.top_fixed_wrap { position: absolute; height: 2.5rem; top: 0; bottom: 0; margin: auto; right: 6.25rem; z-index: 999; display: flex; justify-content: flex-end; align-items: center; }

.tel_wrap { margin-right: 1.875rem; margin-right: 1rem; padding-right: 1rem; position: relative; }
 .tel_wrap::after { width: 1px; height: 40%; content: ''; position: absolute; right: 0; top: 0; bottom: 0; margin: auto; background-color: #000; transition: 0.3s; } 
.tel_wrap .tel { height: 2.5rem; display: flex; justify-content: flex-end; }
.tel_wrap .tel a { width: 100%; height: 100%; display: flex; justify-content: flex-end; align-items: center; }
.tel_wrap .tel a div { width: 2.25rem; height: 2.5rem; background: url(../img/common/tel.png) center no-repeat; transition: 0.3s; background-size: 1.125rem; }
.tel_wrap .tel a p { font-family: 'lexend'; color: #000; font-size: 1.75rem; line-height: 100%; font-weight: 600; letter-spacing: 0.0125rem; transition: 0.3s; margin-top: -1px; }

.top_fixed_wrap h4 { font-family: 'Poppins', sans-serif; font-size: 0.75rem; color: #000;}
.top_fixed_wrap h4 b { font-weight: 700; font-size: 1.4rem;}
.navi.white .top_fixed_wrap h4 { color: #fff;}
.navi.active .top_fixed_wrap h4 { color: #000;}

.navi.white .tel_wrap a p { color: #fff; }
.navi.white .tel_wrap::after { background-color: #fff; }
.navi.white .tel_wrap .tel a div { background: url(../img/common/tel2.png) center no-repeat; background-size: 1.125rem; }
.navi.white2 .tel_wrap a p { color: #fff; }
.navi.white2 .tel_wrap::after { background-color: #fff; }
.navi.white2 .tel_wrap .tel a div { background: url(../img/common/tel2.png) center no-repeat; background-size: 1.125rem; }

.navi.over .tel_wrap a p { color: #000; }
.navi.over .tel_wrap::after { background-color: #000; }
.navi.over .tel_wrap .tel a div { background: url(../img/common/tel.png) center no-repeat; background-size: 1.125rem; }

.navi.active .tel_wrap a p { color: #000; }
.navi.active .tel_wrap::after { background-color: #000; }
.navi.active .tel_wrap .tel a div { background: url(../img/common/tel.png) center no-repeat; background-size: 1.125rem; }

.top_const { width: 112px; height: 29px; background: url(../img/common/dy.png) center no-repeat; background-size: cover; transform: translateY(-6px); transition: 0.3s; }

.navi.white .top_const { background: url(../img/common/dy2.png) center no-repeat; background-size: cover; }
.navi.white2 .top_const { background: url(../img/common/dy2.png) center no-repeat; background-size: cover; }
.navi.over .top_const { background: url(../img/common/dy.png) center no-repeat; background-size: cover; }
.navi.active .top_const { background: url(../img/common/dy.png) center no-repeat; background-size: cover; }

.reserve { position: relative; width: 11rem; height: 2.5rem; display: flex; justify-content: center; z-index: 999; border-radius: 2.5rem; color: #fff; cursor: pointer; margin-right: 1rem; }
.reserve:after { content:''; width: 100%; height: 2.5rem; position: absolute; right: 0; top: 0; border-radius: 2.5rem; border: 1px solid #241915; background-color: #241915; box-sizing: border-box;  z-index: -1; transition: 0.3s; }
.reserve h2 { font-size: 1.125rem; line-height: 2.45rem; position: absolute; left: 3.438rem; opacity: 0; transition: 0.3s; font-weight: 500; letter-spacing: 0.063rem; }
.reserve p { font-size: 1rem; line-height: 2.4rem; text-transform: uppercase; text-align: center; /* padding-left: 1.625rem; */ letter-spacing: 0px; font-weight: 800; position: relative; z-index: 3; transition: 0.3s; }
.reserve>a>div { position: absolute; width: 2.5rem; height: 2.5rem; position: absolute; right: 0.325rem; top: 0; bottom: 0; margin: auto; transition: 0.3s; z-index: 9; }
.reserve>a>div:after { content:''; width: 13%; height: 13%; border-bottom: 1px solid #000; border-right: 1px solid #000; transform: rotate(45deg); position: absolute; left: 0; right: 0; top: -5%; bottom: 0; margin: auto; transition: 0.3s; display: none; }

/* .reserve.pc { display: flex; } */
.reserve.mo { width: 2.5rem; display: none; }

.reserve.active:after { background-color: transparent; width: 100%; }
.reserve.active h2 { opacity: 1; left: 1.563rem; }
/*.reserve.active p { opacity: 0; }*/
/* .reserve.active .reserve>a>div { background: url(../img/common/reserve.png) center no-repeat; } */
/*
body.main .reserve { color: #fff; }
body.main .reserve:after { border: 1px solid #fff; background-color: #fff; }
body.main .reserve>a>div { background: url(../img/common/reserve2.png) center no-repeat; }
body.main .reserve.active:after { background-color: transparent; }
body.main .reserve.active .reserve>a>div { background: url(../img/common/reserve.png) center no-repeat; }
*/
.navi.white .reserve { color: #fff; }
.navi.white .reserve:after { border: 1px solid #fff; background-color: #241915; border: 1px solid #241915; }
.navi.white .reserve>a>div:after { border-bottom: 1px solid #fff; border-right: 1px solid #fff; }
.navi.white .reserve.active:after { background-color: transparent; }
/*.navi.white .reserve.active .reserve>a>div { background: url(../img/common/reserve2.png) center no-repeat; }*/
.navi.white2 .reserve { color: #fff; }
.navi.white2 .reserve:after { border: 1px solid #fff; background-color: #241915; border: 1px solid #241915; }
.navi.white2 .reserve>a>div:after { border-bottom: 1px solid #fff; border-right: 1px solid #fff; }
.navi.white2 .reserve.active:after { background-color: transparent; }

.navi.over .reserve { color: #fff; }
.navi.over .reserve:after { border: 1px solid #fff; background-color: #241915; border: 1px solid #241915; }
.navi.over .reserve>a>div:after { border-bottom: 1px solid #000; border-right: 1px solid #000; }
.navi.over .reserve.active:after { background-color: transparent; }

.navi.active .reserve { color: #fff; }
.navi.active .reserve:after { border: 1px solid #fff; background-color: #241915; border: 1px solid #241915; }
.navi.active .reserve>a>div:after { border-bottom: 1px solid #000; border-right: 1px solid #000; }
.navi.active .reserve.active:after { background-color: transparent; }

/*  */

.bgm_fixed_wrap { width: auto; height: 100%; left: 6.25rem; display: flex; justify-content: flex-start; align-items: center; position: absolute; top: 0; z-index: 999; }

.bgm_wrap { width: 3.125rem; height: 3.125rem; border-radius: 3.125rem; border: 1px solid #000; box-sizing: border-box; transition: 0.3s; position: relative; transition: 0.3s; }
.bgm_wrap p { font-size: 0.75rem; line-height: 100%; color: #000; margin-right: 0.5rem; font-weight: 500; position: absolute; left: 100%; top: 0; bottom: 0; margin: auto; display: flex; justify-content: flex-start; align-items: center; padding-left: 0.875rem; width: 150%; transition: 0.3s; }
.bgm_wrap a { width: 100%; height: 100%; display: block; border-radius: 3.125rem; position: relative; z-index: 9; }

/* #audio { } */
audio { outline: none; }
.bgm_line { text-align: center; height: 2.25rem; width: 2.25rem; position: absolute; left: 0; right: 0; top: 4px; margin: auto; }
.bgm_line ul { width: 100%; height: 50%; position: absolute; left: 0; right: 0; top: 0; bottom: 0; margin: auto; display: flex; justify-content: center; align-items: flex-end; }
.bgm_line ul li { width: 2px; height: 2px; background-color: #000; display: inline-block; margin-left: 1px; transition: background 0.3s; }
.bgm_line ul li:nth-child(1) { margin-left: 0; }

.bgm_box { position: relative; width: 100%; height: 96px; }
.bgm_box img { position: absolute; left: 0; top: 0; cursor: pointer; }

/* .bgm_img01 { } */
.bgm_img02 { display: none; }

.navi.white .bgm_wrap { border: 1px solid #fff; }
.navi.white .bgm_wrap p { color: #fff; }
.navi.white .bgm_line ul li { background-color: #fff; }

.navi.active .bgm_wrap { border: 1px solid #000; }
.navi.active .bgm_line ul li { background-color: #000; }



.sns_wrap { height: 100%; z-index: 90; margin-left: 2.725rem; }
.sns_wrap ul { height: 100%; display: flex; justify-content: flex-end; align-items: center; }
.sns_wrap ul li { float: left; width: 2rem; height: 2rem; overflow: hidden; position: relative; margin-left: 0.625rem; }
.sns_wrap ul li img { position: absolute; left: 0; right: 0; top: 0; bottom: 0; margin: auto; transition: 0.3s; }
.sns_box { width: 100%; height: 100%; position: relative; }
.sns_box a { width: 100%; height: 100%; display: block; }
.sns_txt { transform: translateX(2rem); }
.sns_txt.white { opacity: 1; }
.sns_txt.color { opacity: 0; }
.sns_img.white { opacity: 1; }
.sns_img.color { opacity: 0; position: absolute; left: 0; top: 0; bottom: 0; right: 0; margin: auto; }
.sns_wrap ul li:after { content:''; position: absolute; right: 0; bottom: 0; width: 0; height: 1px; background-color: #fff; transition: 0.5s; z-index: -1; }

.sns_wrap ul li:hover .sns_img { transform: translateX(-2rem); }
.sns_wrap ul li:hover .sns_txt { transform: translateX(0); }
.sns_wrap ul li:hover:after { width: 100%; }

.navi.active .sns_txt.white { opacity: 0; }
.navi.active .sns_txt.color { opacity: 1; }
.navi.active .sns_img.white { opacity: 0; }
.navi.active .sns_img.color { opacity: 1; }
.navi.active .sns_wrap ul li:after { background-color: #222; }

.navi.white .sns_txt.white { opacity: 0; } 
.navi.white .sns_txt.color { opacity: 1; }
.navi.white .sns_img.white { opacity: 0; }
.navi.white .sns_img.color { opacity: 1; }
.navi.white .sns_wrap ul li:after { background-color: #222; }


/**/

/**/

.ham { z-index: 9999999; position: fixed; right: 5.5rem; top: 33px; width: 50px; height: 50px; cursor: pointer; opacity: 1; border-radius: 100%; transition: right 0.5s, top 0.3s; box-sizing: border-box; display: none; }
.ham:after { content: ''; width: 100%; height: 100%; position: absolute; right: 0; top: 0; margin: auto; border-radius: 100%; border: 1px solid #05364b; box-sizing: border-box; z-index: -1; transition: 0.3s; opacity: 0; }
.ham span { display: block; background: #05364b; margin: auto; width: 24px; height: 1px; border-radius: 0px; transition: 0.25s; }
.ham .bar1 { margin-top: 14px; margin-bottom: 9px; }
/* .ham .bar2 { width: 12px; transform: translateX(4px); } */
.ham .bar3 { margin-top: 9px; }

.ham.active2 { top: 25px; }
.ham.active2:after { background-color: none !important; border: 1px solid #05364b !important; }
.ham.active2 span { background-color: #05364b !important; }
.ham.active3 { top: 35px; }
.ham.pop { top: 35px; }
.ham.active2.pop { top: 25px; }
.ham.active3.active2 { top: 25px; }


.ham.active { transition: 0.5s, top 0.4s, right 0.5s 0.2s; right: 25px; top: 33px; }
/* .ham.active:after { background-color: #05364b !important; border: 1px solid #05364b !important; opacity: 1; } */
.ham.active span { width: 100%; background-color: #000 !important; }

.ham.active .bar1 { transform: rotate(45deg); margin-top: 25px; }
.ham.active .bar2 { opacity: 0; }
.ham.active .bar3 { transform: rotate(-45deg); margin-top: -11px; }

.ham.white:after { border: 1px solid #fff; }
.ham.white span { background: #fff; }


/*  */

.site_wrap { width: 100%; height: 100%; position: fixed; right: 0; top: 0; z-index: -1; display: flex; justify-content: flex-end; align-items: center; transition: z-index 0s 1.2s; }
.site_bg { width: 100%; height: 100%; position: fixed; right: 0; top: 0; z-index: -1; background-color: #000; opacity: 0; transition: z-index 0s 1.2s, opacity 1.33s cubic-bezier(.26,1,.48,1); }

.site_map { width: 48%; height: 98%; margin-right: 0.5%; display: flex; justify-content: center; align-items: flex-start; padding-right: 5.75rem; padding: 0; box-sizing: border-box; position: relative; }
.site_map:after { content:''; position: absolute; width: 0%; height: 100%; background-color: #fff; border-radius: 0.625rem; right: 0; top: 0; z-index: -1; transition: 1.0s cubic-bezier(.641,.005,.095,1.05); }
.site_map>div { height: 100%; opacity: 0; transform: translateY(-3.125rem); display: flex; flex-wrap: wrap; justify-content: center; align-items: center; position: relative; flex-wrap: wrap; transition: 0.8s 0s; }
.site_map>div>div { width: 100%; transform: translateY(3rem); }
.site_logo { width: 207px; height: 34px; margin: auto; text-align: center; }
.site_logo a { width: 100%; height: 100%; }
.site_map ul { text-align: center; margin-top: 58%; margin-top: 0%; margin-top: 3.75rem; }
.site_map ul li { font-size: 3.25rem; line-height: 150%; margin: 0; position: relative; font-weight: 700; color: #ccc; overflow: hidden; letter-spacing: -0.3125rem; opacity: 0; transition: 0.6s 0.0s; }
/* .site_map ul li:nth-child(5) { transition: 0.6s 0.0s }
.site_map ul li:nth-child(4) { transition: 0.6s 0.15s }
.site_map ul li:nth-child(3) { transition: 0.6s 0.3s }
.site_map ul li:nth-child(2) { transition: 0.6s 0.45s }
.site_map ul li:nth-child(1) { transition: 0.6s 0.6s } */
.site_map ul li span { display: inline-block; transition: 0.4s; padding-right: 1.25rem; }
.site_map ul li span:last-child { position: absolute; left: 0; right: 0; margin: auto; top: 0; transform: translateY(5.25rem); color: #6e4840; }

/* .site_map h6 { width: 200%; font-size: 0.75rem; line-height: 100%; position: absolute; right: -50%; bottom: 8%; text-align: center; text-transform: uppercase; } */

.site_map ul li a:hover span:first-child { transform: translateY(-5.25rem); }
.site_map ul li a:hover span:last-child { transform: translateY(0); }

.site_wrap.active { opacity: 1; z-index: 9999; transition: 0s; }
.site_bg.active { opacity: 0.85; z-index: 9998; transition: 0s, opacity 1.33s cubic-bezier(.26,1,.48,1); }
.site_wrap.active .site_map:after { width: 100%; transition: 1.0s cubic-bezier(.41,.005,.095,0.95); }
.site_wrap.active .site_map>div { opacity: 1; transform: translate(0); transition: 0.8s 0.4s; }
.site_wrap.active .site_map ul li:nth-child(1) { opacity: 1; transition: 0.6s 0.4s }
.site_wrap.active .site_map ul li:nth-child(2) { opacity: 1; transition: 0.6s 0.55s }
.site_wrap.active .site_map ul li:nth-child(3) { opacity: 1; transition: 0.6s 0.7s }
.site_wrap.active .site_map ul li:nth-child(4) { opacity: 1; transition: 0.6s 0.85s }
.site_wrap.active .site_map ul li:nth-child(5) { opacity: 1; transition: 0.6s 1s }
.site_wrap.active .site_map ul li:nth-child(6) { opacity: 1; transition: 0.6s 1.15s }


/**/




header.hide { opacity: 0; z-index: -100; transition: 0.6s; }
#logo.hide { opacity: 0; z-index: -100; transition: 0.6s; }
.ham.hide { opacity: 0; z-index: -100; transition: 0.6s; }




@media screen and (-webkit-min-device-pixel-ratio:0){ 

}

@media all and (max-width: 1800px) { 

	.navi .depth1 { font-size: 0.83rem;}
	.tel_wrap .tel { transform: scale(0.9); }
}


@media all and (max-width: 1700px) { 

	.gnb>ul>li { margin: 0 0.9rem; }

}

@media all and (max-width: 1600px) { 

	#logo { width: 170px; height: 24px; }

}

@media all and (max-width: 1400px) { 
	
	
	.gnb { display: none; }
/*	.top_fixed_wrap { right: 5%; }*/
	.top_fixed_wrap { right: calc(5% + 0rem); }
	.right_scroll_wrap { display: none; }

    .reserve { width: 10.5rem; }
    .tel_wrap .tel a p { margin-top: 0; }

/*	.ham { right: calc(5% + 8.425rem); }*/
	.ham { left: 4%; top: 25px; }
    .ham.active { right: 28px; top: 25px !important; }
    .ham.active2 { top: 19px; }
    /* .ham .bar1 { margin-top: 17px; } */
	.gnb_wrap { display: block; }

/*	.right_scroll_img { height: 6rem; }*/
	.right_scroll_img { background: url(../img/scroll3.png) center no-repeat; background-size: cover; }
	.right_scroll { background-color: #bbb; }

/**/

    .site_map { width: 70%; max-width: 600px; padding-left: 4.5rem; padding-left: 0; }
    /* .site_map ul { transform: translateY(1rem); margin-top: 8.5rem; } */

    .site_logo { top: 10%; top: 65px; }
    /* .site_logo img { width: 150px; height: 23px; } */


}	

@media all and (max-width: 1000px) { 

	.ham { top: 31px; }
	.ham.active { top: 31px !important; }
	.ham.active2 { top: 22px; }

}


@media all and (min-width: 520px) and (max-width: 767px) { 

	.ham { top: 27px !important; }
	.ham.active { top: 27px !important; }
	.ham.active2 { top: 18px !important; }
	.top_fixed_wrap { right: calc(5% + 2.75rem) !important; }

}


@media all and (max-width: 767px) { 
	
	.navi { height: 6rem; }
	.navi.active { height: 4.75rem; }
	#logo { width: 146px; height: 24px; left: 5%; right: revert; }
	.right_scroll_wrap { width: 0.725rem; right: 5%; top: revert; bottom: 4%; transform: translateY(0px); }
	.right_scroll_img { width: 90%; }
    
    .tel_wrap { margin: 0; padding-right: 0; }
    .tel_wrap::after { display: none; }
    .tel_wrap .tel a div { width: 36px; height: 36px; border-radius: 100%; background: #05364b url(../img/common/tel2.png) center no-repeat; background-size: 14px !important; }
    .tel_wrap .tel a p { display: none; }

    .navi.white .tel_wrap .tel a div { background: #fff url(../img/common/tel.png) center no-repeat; background-size: 14px !important; }
    .navi.active .tel_wrap .tel a div { background: #05364b url(../img/common/tel2.png) center no-repeat; background-size: 14px !important; }
    .navi.over .tel_wrap .tel a div { background: #05364b url(../img/common/tel2.png) center no-repeat; background-size: 14px !important; }

	.top_fixed_wrap { right: calc(5% + 3.5rem); }
	.sns_wrap { display: none; }
	.bgm_wrap { width: 8.75rem; margin-left: 0.5rem; }
    .bgm_wrap p { font-size: 0.975rem; }

    .top_guest { width: 36px; height: 36px; margin-left: 0.325rem; }
    .top_guest>div { width: 5px; height: 5px; right: 25%; top: 25%; }
    .top_open { display: none; }

	.ham { width: 36px; height: 36px; top: 18px; left: revert; right: 5%; }
    .ham:after { opacity: 1; }
    .ham.active2:after { box-sizing: border-box; }
	.ham.active { right: 20px; left: revert; top: 18px !important; }
	.ham.active::after { opacity: 0; }
	.ham.active2 { top: 11px; }
    .ham span { width: 15px; }
    .ham .bar1 { margin-top: 11px; margin-bottom: 5px; }
    /* .ham .bar2 { width: 10px; transform: translateX(3px); } */
    .ham .bar3 { margin-top: 5px; }
    .ham.active .bar1 { margin-top: 18px; }
    .ham.active .bar3 { margin-top: -7px; }

	.gnb_wrap { max-width: 100%; }

/**/

    .site_map { width: 100%; height: 100%; margin-right: 0; max-width: revert; justify-content: center; text-align: center; padding-left: 0; }
    .site_map:after { border-radius: 0; }
    .site_map>div { width: 100%; }
    .site_txt h1 { display: none; }
    /* .site_map ul { text-align: center; transform: translateY(1rem); } */
    .site_map ul li { font-size: 2.75rem; line-height: 170%; }

    .site_logo { left: 5%; top: 34px; }
    /* .site_logo img { width: 146px; height: 24px; } */

    .site_map h6 { width: 100%; text-align: center; font-size: 0.875rem; }

}	