﻿@charset "utf-8";
/* CSS Document */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400&family=Shippori+Mincho:wght@400;500&display=swap');
html{font-size: 15px;}
#wrap{margin: 0 auto;}
.hvr_font_normal:hover{font-weight: normal}
.hvr_up{transition: .5s;}
.hvr_up:hover{transform: translateY(-3px)}
.is_font_normal{font-weight: normal!important;}


/* =============================================
　　font
============================================= */
body {
	line-height: 1.8!important;
	font-family: "Noto Sans JP", YuGothic,"Yu Gothic","游ゴシック体","游ゴシック","ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","メイリオ",Meiryo,Osaka,"ＭＳ Ｐゴシック","MS PGothic","Helvetica Neue",Helvetica,Arial,sans-serif!important;
}
.font_shippori{
	font-family: 'Shippori Mincho', "游明朝", "YuMincho", "ＭＳ Ｐ明朝", "MS PMincho","ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "Sawarabi Mincho", "serif";
}
footer .more_bt{font-weight: 600;}


/* =============================================
　　loading
============================================= */
#loading{
	position: fixed;
	height: 100%;
	width: 100%;
	z-index: 999999;
}
.load_logo{
	top: 49%!important;
	left: 50%;
	z-index: 100;
}
.load_logo{
	animation-name: loader;
	animation-duration: 3s;
	animation-timing-function: ease;
	animation-iteration-count: 1;
}
@keyframes loader {
	0% {opacity: 0;}
	100% {opacity: 1;}
}

.load_box_wrap{
	top: 0;
	left: 0;
	z-index: 99;
}
.load_box_wrap .box{
	top: 0;
    transition: width cubic-bezier(0.215, 0.61, 0.355, 1) 0.5s;
}

.load_box_wrap .box:nth-of-type(1){right: 0;transition-delay: .4s}
.load_box_wrap .box:nth-of-type(2){right: 20%;transition-delay: .3s}
.load_box_wrap .box:nth-of-type(3){right: 40%;transition-delay: .2s}
.load_box_wrap .box:nth-of-type(4){right: 60%;transition-delay: .1s}
.load_box_wrap .box:nth-of-type(5){right: 80%}
.load_box_wrap .box.slideout{width: 0!important;}



/* =============================================
　　header
============================================= */
header{z-index: 999;}
#logo img{max-width: 300px;transition: .5s}
#header.active #logo img{max-width: 250px;}

/* nav_menu */
#nav_menu {
    width: auto !important;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 9999;
}
.button_container, .shop_link {
    position: relative;
    height: 110px;
    width: 116px;
    cursor: pointer;
    z-index: 9999;
    -webkit-transition: opacity .25s ease;
    transition: opacity .25s ease;
}
.button_container.active{
	background-color: transparent;
}
.button_container.active .posi_center{
	width: 42px;
    height: 52px;
}
.button_container.active .top {
	-webkit-transform: translateY(16px) translateX(0) rotate(45deg);
	transform: translateY(16px) translateX(0) rotate(45deg);
	background: #222;
	width: 40px;
}
.button_container.active .middle {
	opacity: 0;
	background: #222;
}
.button_container.active .bottom {
	-webkit-transform: translateY(-5px) translateX(0) rotate(-45deg);
	transform: translateY(-5px) translateX(0) rotate(-45deg);
	background: #222;
	width: 40px;
}
.button_container:hover span {
	opacity: .6;
}
.button_container .posi_center {
	width: 50px;
    height: 42px;
}
.shop_link div.posi_center {
	width: 100%;
    height: 100%;
}
.button_container span {
    background: #fff;
    border: none;
    height: 2px;
    width: 100%;
    position: absolute;
    top: 9px;
    left: 0;
    -webkit-transition: all .35s ease;
    transition: all .35s ease;
    cursor: pointer;
}
.button_container span:nth-of-type(2) {
	top: 20px;
	width: 34px;
	text-align: left;
}
.button_container span:nth-of-type(3) {
	top: 31px;
	width: 21px;
}
/* overlay 追加*/
.overlay .menu_box {
	box-sizing: border-box;
	padding-left: 14vw;
	opacity: 0;
	transition: opacity .5s .4s;
	max-width: 75%;
	overflow: auto;
}
.overlay.open .menu_box {
	opacity: 1;
}
.overlay .menu_bg_box {
    position: relative;
    top: 0;
    left: 0;
    width: 25vw;
    height: 100vh;
}
.overlay .menu_bg_box_wrap {
	overflow: hidden;
	transform: translate(-100%, 0);
	transition: transform cubic-bezier(0.215, 0.61, 0.355, 1) 0.5s;
	width: 25%;
}
.overlay .menu_bg_box {
	display: block;
	transform: translate(100%, 0);
	transition: transform cubic-bezier(0.215, 0.61, 0.355, 1) 0.5s;
}
.overlay.open .menu_bg_box_wrap,
.overlay.open .menu_bg_box {
	transform: translate(0, 0);
	transition-delay: .3s;
}


/* overlay */
.overlay {
	position: fixed;
	top: 0;
	right: 0;
	width: 100%;
	height: 100%;
	opacity: 0;
	visibility: hidden;
	-webkit-transition: opacity .25s, visibility .35s, height .35s;
	transition: opacity .25s, visibility .35s, height .35s;
	overflow: hidden;
	z-index: 999!important;
}
.overlay.open {
	opacity: 1;
	visibility: visible;
	height:100%;
}
.overlay nav {
    position: absolute;
    width: 70%;
    height: 70vh;
    top: 50%;
    left: 0;
    right: 0;
    margin: auto;
    -webkit-transform: translateY(-50%) translateX(0%);
    transform: translateY(-50%) translateX(0%);
    text-align: left;
    background-color: #fff;
    padding: 5% 0 0;
}

.overlay ul:not(.sns_links) li {
	display: block;
	opacity: 1;
}
.overlay ul:not(.sns_links) li a {
	display: block;
	position: relative;
	padding-top: 5px;
	padding-bottom: 10px;
}
.overlay .sns_links li {
    max-width: 25px;
    margin: 0 25px 3% 0;
}


/* =============================================
　　footer
============================================= */
#gmap{
	width: 100%;
    height: 500px;
}
footer .sns_links li {
    max-width: 30px;
    margin: 35px 14px;
}
footer .bg_box{height: 400px}
.bottom_wrap{background-color: #333333}
footer .f_btn_box p {width: calc(50% - 20px);}
#copyright{color: #fff}

/* page-top */
#page-top{
	position: fixed;
	right: 30px;
	z-index: 99;
}
#page-top a{
	display: block;
	width: 50px;
	height: 50px;
	position: relative;
}

/* =============================================
　　animation
============================================= */
.scrollanim{
	opacity: 0;
    -webkit-transform: translate(0, 20px);
    -ms-transform: translate(0, 20px);
    transform: translate(0, 20px);
}
.scrollanim.start {
    -webkit-transition: opacity 1s cubic-bezier(0.31, 0.15, 0.31, 1),-webkit-transform 1s cubic-bezier(0.31, 0.15, 0.31, 1);
    transition: opacity 1s cubic-bezier(0.31, 0.15, 0.31, 1),-webkit-transform 1s cubic-bezier(0.31, 0.15, 0.31, 1);
    transition: opacity 1s cubic-bezier(0.31, 0.15, 0.31, 1),transform 1s cubic-bezier(0.31, 0.15, 0.31, 1);
    transition: opacity 1s cubic-bezier(0.31, 0.15, 0.31, 1),transform 1s cubic-bezier(0.31, 0.15, 0.31, 1),-webkit-transform 1s cubic-bezier(0.31, 0.15, 0.31, 1);
    opacity: 1;
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
}


/* =============================================
　　共通
============================================= */

/*--- scrollbar ------------------------------------*/
#intro .modal_box .over_box::-webkit-scrollbar, #contents_wrap .con_txt div.txt::-webkit-scrollbar {
  width: 2px;
  height: 10px;
}
#intro .modal_box .over_box::-webkit-scrollbar-track, #contents_wrap .con_txt div.txt::-webkit-scrollbar-track {
  border-radius: 5px;
  box-shadow: 0 0 4px #aaa inset;
}
#intro .modal_box .over_box::-webkit-scrollbar-thumb, #contents_wrap .con_txt div.txt::-webkit-scrollbar-thumb {
  border-radius: 5px;
  background: #333;
}

/*--- page_title ------------------------------------*/
#page_title{background: url( "../Dup/img/page_title_bg.jpg" ) center / cover no-repeat ;}
#page_title::before {
	display: inline-block;
	content: "";
	width: 100%;
	height: 100%;
	background: rgba(255,255,255,0.8);
	position: absolute;
	bottom: 0;
	right: 0;
	left: 0;
	margin: auto;
}
#page_title h2 span.font_anim{
	height: 55px;
    overflow: hidden;
}
#page_title h2 .anim{
	position: relative;
	top: 20px;
	right: 10px;
	opacity: 0;
}
#page_title .border{
	display: block;
	position: relative;
    top: 25px;
    margin: auto;
	height: 3px;
	width: 0;
	opacity: 0;
	border-radius: 10px;
}
#page_title .border.b_anim{
	animation: bWidth .8s ease-in-out forwards;
}
@keyframes bWidth {
  0% {
    width: 0;
	opacity: 0;
  }
  100% {
    width: 80px;
	opacity: 1;
  }
}

/*--- カテゴリーリスト ------------------------------------*/
.cate_list::before {
    content: "CATEGORY";
    display: inline-block;
    font-size: 12px;
    color: #767676;
    position: absolute;
	letter-spacing: 2px;
    top: -45px;
    left: 0;
	border-bottom: 1px solid
}
.cate_list li a::before {
    content: "\025bc";
    display: inline-block;
    font-size: 9px;
    color: #333333;
    position: absolute;
    top: 9px;
    right: 12px;
}


/* =============================================
　　index.html
============================================= */

/*--- 動画 ------------------------------------*/
.video_wrap {
    position: relative;
    overflow: hidden;
    width: 100%;
    height: 100vh;
}
video {
    min-width: 100%;
    min-height: 100vh;
    z-index: 1;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}


/*--- main_img ------------------------------------*/
.vegas-timer{display: none}
#main_img {z-index: 0;height: 100vh;}

#pc_nav{
	z-index: 1;
	bottom: 0;
    right: 0;
    background-color: rgba(255,255,255,0.6);
	backdrop-filter: blur(10px);
}


/*--- intro ------------------------------------*/
#intro .intro_img {
	margin-left: auto;
    overflow: hidden;
    position: relative;
    width: 100%;
    height: 800px!important;
}
#intro .txt_wrap{
	padding: 0 80px 0 14%;
}
span.bg_box {
    content: "";
    display: block;
    width: 20%;
    position: absolute;
    z-index: -1;
}
#intro span.bg_box {
    height: 47%;
    top: 0;
    left: 0;
}
#intro .modal_bt{
	cursor: pointer;
	border-radius: 45px;
	width: 250px;
	box-sizing: border-box;
}
#intro .modal_bg{
     top: 0;
	left: 0;
     background-color: rgba(0,0,0,0.6);
     z-index: 9
}
#intro .modal_box{
     max-height: 80%;
     overflow-y: auto;
     z-index: 10
}
#intro .modal_box .over_box_wrap::after {
	content: '';
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 38px;
	background: linear-gradient(to bottom, rgba(255,255,255,0.5) 0%,rgba(255,255,255,1) 100%);
}
#intro .modal_box .over_box {
	padding: 0 20px 50px 40px;
    height: 335px;
    overflow: auto;
}
#intro .modal_box .btn_close {
    box-sizing: border-box;
    position: absolute;
    top: 20px;
    right: 20px;
    width: 60px;
    height: 60px;
    border-radius: 100px;
    cursor: pointer;
    transition: transform 0.2s ease-in;
    z-index: 1;
}
#intro .modal_bt::before, #intro .modal_bt::after, #intro .modal_box .btn_close::before, #intro .modal_box .btn_close::after {
    position: absolute;
    top: 0;
    bottom: 0;
    height: 1px;
    background-color: #333;
    margin: auto;
    content: '';
}
#intro .modal_bt::before, #intro .modal_bt::after{
	right: 20px;
	width: 14px
}
#intro .modal_bt::before {
    transform: rotate(90deg);
}
#intro .modal_box .btn_close::before, #intro .modal_box .btn_close::after {
	left: 0;
    right: 0;
	width: 45px
}
#intro .modal_box .btn_close::before {
    transform: rotate(45deg);
}
#intro .modal_box .btn_close::after {
    transform: rotate(-45deg);
}


/*--- contents_links ------------------------------------*/
#contents_links span.bg_box  {
    height: calc(200% + 10px);
    top: -100px;
    right: 0;
}
#contents_links .box_wrap .box {
    border: 6px solid rgba(255,255,255,0);
}
#contents_links .box_wrap .box .posi_center{
	z-index: 2;
}
#contents_links .box_wrap h3 {
    width: 6.33333%!important;
    padding-right: 0.5%;
    padding-top: 0.6%;
}
#contents_links .box_wrap .box.first {
    width: 26.33333%!important;
}
#contents_links .box_wrap .box a {
    display: block;
    padding-top: 52%;
    position: relative;
    overflow: hidden;
    height: 100%;
    box-sizing: border-box;
}
#contents_links .box_wrap .box a h4 {
    position: relative;
	background-color: rgba(255,255,255,0.45);
	padding: 10px 25px 14px;
}
#contents_links .box_wrap .box a::after {
    content: "";
    background-position: center center;
    background-size: cover;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transition: ease 0.6s;
    z-index: 1;
    opacity: 1;
}
#contents_links .box_wrap .box a:hover::after {
    transform: scale(1.05);
    opacity: 0.9;
}


/*--- contents_wrap ------------------------------------*/
#contents_wrap {
	width: 100%!important;
	z-index: 3;
	-webkit-backface-visibility:hidden;
	backface-visibility:hidden;
}
#contents_wrap .bg_container {
	position: relative;
    width: 100%;
    height: 100vh;
	padding: 10vh 0;
	box-sizing: border-box;
	overflow: hidden;
}
#contents_wrap h2 {
    padding-bottom: 8vh;
	line-height: 42px;
}
#contents_wrap .title_wrap{z-index: 1}
#contents_wrap .con_item{
	z-index: -1;
	min-width: 150px;
	width: 25%;
}
#contents_wrap .con_txt div.txt {
    margin-top: 4vh;
    max-height: 40vh;
    overflow: auto;
	position: relative;
	z-index: 4;
}

/* contents box anim */
#contents_wrap .tab_content .box {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	width: 100%;
	margin: auto;
	z-index: 1;
}
#contents_wrap .tab_content .box.active{z-index: 3;}
#contents_wrap .tab_content .box .con_img,
#contents_wrap .tab_content .box .con_txt .title_wrap,
#contents_wrap .tab_content .box .con_txt div.txt {
	opacity: 0;
	transition: all 0.5s .15s;
	transform: translateY(30px);
    transition-timing-function: cubic-bezier(0,0,0,1);
}
#contents_wrap .tab_content .box.active .con_img,
#contents_wrap .tab_content .box.active .con_txt .title_wrap,
#contents_wrap .tab_content .box.active .con_txt div.txt {
	opacity: 1!important;
	transform: translateY(0);
    transition-duration: 1s;
    transition-delay: .5s;
}
#contents_wrap .tab_content .box.active .con_txt .title_wrap,
#contents_wrap .tab_content .box.active .con_txt div.txt {
    transition-delay: .65s;
}

/* tab_buttons */
#tab_buttons {
	display: flex;
    justify-content: space-between;
    margin-top: 0;
    position: absolute;
    left: 7%;
    top: 50%;
    transform: translateY(-50%);
}
#tab_buttons .stepber {
    position: relative;
    width: 1px;
    height: 44.64vh;
}
#tab_buttons .stepber ul li {
    transform: translateX(-50%);
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    left: 0;
    width: 50px;
    height: 50px;
    text-align: center;
	border-radius: 50%;
    border: 1px solid #63636d;
}
#tab_buttons .stepber ul li:first-child {
    top: 0;
}
#tab_buttons .stepber ul li:nth-child(2) {
    top: 100px;
}
#tab_buttons .stepber ul li:nth-child(3) {
    top: 200px;
}
#tab_buttons .stepber ul li:nth-child(4) {
    top: 75%;
}
#tab_buttons .stepber ul li:before {
    content: "";
    display: block;
    position: absolute;
}
#tab_buttons .stepber ul li span.no {
    position: relative;
    top: -1px;
    z-index: 3;
}
#tab_buttons .stepber ul li span.before{
	width: 100%;
	height: 100%;
	border-radius: 50%;
	opacity: 0;
	transform: translate(-50%,-50%) scale(0);
}
#tab_buttons .stepber ul li span.no, #tab_buttons .stepber ul li span.before {
	transition: all 0.6s cubic-bezier(0.23, 1, 0.32, 1) .02s;
}
#tab_buttons .stepber ul li span.active{
	color: #fff;
}
#tab_buttons .stepber ul li span.active.before{
	opacity: 1;
	transform: translate(-50%,-50%) scale(1.3);
}


/*--- top_cms ------------------------------------*/
#top_cms1 .top_cms_title h3, #top_cms2 .top_cms_title h3{
	z-index: 2;
	transform: translateY(-15px);
}
#top_cms1 .top_cms_title p, #top_cms2 .top_cms_title p {
    font-size: 80px;
    opacity: 0.35;
    bottom: 0;
    left: 50%;
	transform: translateX(-50%);
    z-index: 1;
    letter-spacing: 6px;
}
#top_cms2 .top_cms_box:last-of-type {
    padding-bottom: 0;
    border-bottom: none;
}



/* =============================================
　　page2
============================================= */
.pager li{
	margin: 0 10px;
}
.pager li a{
	width: 60px;
	height: 60px;
}


/* =============================================
　　page8
============================================= */
#page8 .hvr_form:hover{
	transform: translateY(-5px);
}
#page8 #form_box .box input::-webkit-input-placeholder,#page8 #form_box .box textarea::-webkit-input-placeholder{
	font-family: "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic,"ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic",  sans-serif;
	opacity: 0.8;
}
#page8 #form_box .box input:-moz-placeholder,#page8 #form_box .box textarea:-moz-placeholder{
	font-family: "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic,"ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic",  sans-serif;
	opacity: 0.8;
}
#page8 #form_box .box input::-moz-placeholder,#page8 #form_box .box textarea::-moz-placeholder{
	font-family: "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic,"ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic",  sans-serif;
	opacity: 0.8;
}
#page8 #form_box .box input:-ms-input-placeholder,#page8 #form_box .box textarea:-ms-input-placeholder{
	font-family: "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic,"ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic",  sans-serif;
	opacity: 0.8;
}
#page8 #form_box .box input,#page8 #form_box .box textarea{
	outline: none;
	border-style: none;
	-webkit-appearance: none;
	-webkit-tap-highlight-color: rgba(0,0,0,0);
}
#page8 input[type="submit"].btn,
#page8 input[type="reset"].btn{
	-webkit-appearance: none;
	/*background: transparent;*/
	outline: none;
	border: 1px solid #fff;
	cursor: pointer;
	color: #fff;
}
#page8 input[type="submit"].btn:disabled{
    cursor: default;
}
.g-recaptcha > div{
	margin: 0 auto;
}
#page8 #form_box .box input, #page8 #form_box .box textarea {
	background-color: #f5f5f5;
}

/* =============================================
　　page10
============================================= */
#page10 ul li {
    width: 45%!important;
}
#page10 ul li a::before {
    content: "\025bc";
    display: inline-block;
    font-size: 9px;
    color: #333333;
    position: absolute;
    top: 5px;
    left: 0;
}


/* =============================================
　　IE,幅
============================================= */

/* ---------- IE ---------- */
@media all and (-ms-high-contrast: none){
/*.pager li a .posi_center{top: 55%;}*/
.cate_list li a::before{top: 12px;}
#page7 .d_table{padding-bottom: 5px;}
#page8 .mail_contact_tel,#page8 .contact_tel{padding-top: 35px;}
#page8 .contact_tel_wrap .d_flex.border_color4{padding-bottom: 5px;}
#page9 a{padding-bottom: 0;}
#page10 ul li a::before{top: 6px;}
}

/* ---------- 1500 ---------- */
@media screen and (max-width: 1500px){
#contents_wrap .contents_inner{padding: 0 4% 0 10%}
#contents_wrap .con_img {width: 45%;}
#contents_wrap .con_txt {width: 55%;}
#contents_wrap .con_txt div.txt{max-height: 45vh;}
}
/* ---------- 1280 ---------- */
@media screen and (max-width: 1280px){
#contents_wrap .contents_inner{padding: 0 3% 0 10%}
#contents_wrap .con_img {padding-right: 40px;width: 40%;}
#contents_wrap .con_txt {width: 60%;}
}
/* ---------- 1180 ---------- */
@media screen and (max-width: 1180px){
footer .info_txt{padding: 40px;}
footer .f_btn_box p {width: 100%;margin-bottom: 15px;}
footer .map iframe{height: 600px}
}

/* ---------- タブレット ---------- */
@media screen and (max-width: 768px){
/* scrollbar */
#contents_wrap .con_txt div.txt::-webkit-scrollbar {
  width: 0;
  height: 0;
}
#contents_wrap .con_txt div.txt::-webkit-scrollbar-track {
  border-radius: 0;
  box-shadow: none;
}
#contents_wrap .con_txt div.txt::-webkit-scrollbar-thumb {
  border-radius: 5px;
  background: transparent;
}

/* top */
#main_img{height: 54vh!important}
#intro span.bg_box{height: 23%;}	
#intro .txt_wrap {padding: 0 12% 70px;}
#intro .intro_img{height: 622px!important;}	
#contents_links .box_wrap h3{width: 100%!important;padding-right: 0;padding-top: 0;padding-bottom: 25px}
#contents_links .box_wrap .box.first {width: 90%!important;}
#contents_links .box_wrap .box a{padding-top: 33%;}

#contents_wrap .bg_container{padding: 150px 0;overflow: visible;height: 100%;}
#contents_wrap .contents_inner{padding: 0 5%;}
#contents_wrap .con_img{padding-right: 0}
#contents_wrap h2{padding-bottom: 60px;}
#contents_wrap .con_txt div.txt{max-height: 100%;overflow: scroll;}
#tab_buttons{display: none!important}
#contents_wrap .tab_content .box{display: flex!important;position: static;opacity: 1!important}
#contents_wrap .tab_content .box .con_img, #contents_wrap .tab_content .box .con_txt .title_wrap, #contents_wrap .tab_content .box .con_txt div.txt{opacity: 1!important}
#contents_wrap .tab_content .box:last-of-type{padding-bottom: 0}
.con_txt div.txt {margin-top: 55px;}
#top_cms1 .top_cms_title p, #top_cms2 .top_cms_title p{font-size: 70px;letter-spacing: 2px;}

/* under */
#page_title .box {padding: 220px 0 120px;}
.cate_list{margin-bottom: 60px;}
footer .bg_box{height: 300px;}
}

/* ---------- スマートフォン ---------- */
@media screen and (max-width: 667px){
.overlay{font-size: 14px}
header{position: fixed}
#header{background-color: #fff}
#logo,#nav_menu{position: static}
.button_container, .shop_link{height: 68px;width: 71px;}
.overlay{-webkit-transition: opacity .45s;transition: opacity .45s}
.overlay .menu_box {
	padding-top: 75px;
    padding-left: 34px;
    position: relative;
    width: 85vw;
    max-width: 85vw;
    margin-left: auto;
    background-color: rgba(255,255,255,0.8);
    backdrop-filter: blur(3px);
	opacity: 1;
}
.overlay .menu_bg_box{position: absolute;width: 100%;height: 100%;}
.overlay .menu_bg_box_wrap,
.overlay .menu_bg_box {
	transform: none!important;
}
.overlay .sns_links li{max-width: 20px;}
.overlay ul:not(.sns_links) li a{padding-bottom: 8px;}
	
.sns_links li{margin: 4%;}
footer .map iframe{height: 400px}

#page-top{right: 15px;}
#page-top a img {
    height: 30px;
    width: 30px;
}
/* top */
#main_img{height: 40vh!important;margin-top: 66px;}
span.bg_box{width: 39%;}
#intro span.bg_box{height: 300px;}
#contents_links span.bg_box{top: -64px}
#intro .txt_wrap {padding: 0 10% 60px;}
#intro .intro_img {height: 316px!important;}

#intro .modal_box .btn_close{top: 0px; right: 5px;}
#intro .modal_box .btn_close::before, #intro .modal_box .btn_close::after{width: 34px;}
#intro .modal_box .over_box {
    padding: 30px 10px 0;
    height: 100%;
    overflow: visible;
}
#intro .modal_box .over_box_wrap::after{display: none}
#intro .modal_bt{width: 100%;}
	
#top_cms1 .top_cms_title p, #top_cms2 .top_cms_title p {
    font-size: 35px;
    letter-spacing: 2px;
    opacity: 1;
    bottom: 46px;
}
#contents_links .box_wrap .box.first{width: 100%!important;}
#contents_links .box_wrap .box a {padding-top: 50%;}
#contents_wrap .bg_container{padding: 70px 0 80px;}
.con_txt div.txt {margin-top: 30px;}	

/* under */
#page_title {padding-top: 120px;padding-bottom: 84px;}
#page_title h2 span.font_anim{height: 32px;}
.cate_list {margin-top: 80px!important;}
.cate_list li a::before {
    top: 8px;
	right: auto;
    left: 5px;
    transform: scale(0.7);
}
	
/* page2 */
.pager li{
	margin: 0 5px!important;
}
.pager li a{
	width: 45px;
	height: 40px;
}
/* page10 */
#page10 ul li {
    width: 90%!important;
}
#page10 ul li a::before {
    top: 2px;
    transform: scale(0.7);
}
}
