@charset "utf-8";
html {overflow-y: scroll;font-size: 10px !important;}
body{line-height: 1.8em;color: #201c1b;-webkit-font-smoothing: antialiased;-moz-osx-font-smoothing: grayscale;margin: 0;width: 100%;position: relative;font-family: eb-garamond, "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;letter-spacing: 0.02em;font-size: 10px !important; background: #c9c4b9;overflow: hidden;}
h1,h2,h3,h4,h5,h6 {padding: 0;margin: 0;font-weight: inherit;font-size: inherit;color: inherit;}
p,ul,ol {padding: 0;margin: 0;}
.jst{ text-align: justify;}
.cl:after {content: "";clear: both;display: block;}
.none {display: none;}
div {padding: 0;margin: 0;line-height: 1em;font-family: inherit !important;}
img {border: 0;border-style: none;width: 100%; image-rendering: -webkit-optimize-contrast;}
a img:hover {opacity: 0.5;-webkit-transition: 0.4s;-moz-transition: 0.4s;-o-transition: 0.4s;transition: 0.4s;}
li {list-style-type: none;}
a {cursor: pointer;display: block;}
a:link {text-decoration: none;font-weight: inherit; color: inherit;}
a:visited {text-decoration: none;color: inherit;}
a:hover {text-decoration: none;color: inherit;}
a:active {text-decoration: none;color: inherit;}
a,a:hover {-webkit-transition: 0.7s;-moz-transition: 0.7s;-o-transition: 0.7s;transition: 0.7s;}
::selection {background: #444;color: #fff;}
::-moz-selection {background: #a8dedc;color: #fff;}
.goth {font-family: acumin-pro, "游ゴシック", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;}
.pc,.on_pc {display: block;}
.sp,.on_sp {display: none;}
.in,.in2 {padding: 0 5%;max-width:1500px;position: relative;width:calc(105% - 200px); box-sizing: border-box; }
.tr {-webkit-transition: 0.7s;-moz-transition: 0.7s;-o-transition: 0.7s;transition: 0.7s;}
.hdn {overflow: hidden;}
/*共通tips*/
.blk {display: block;}
.tbl {display: table;}
.po_re {position: relative;}
.po_ab {position: absolute;}
.f_w {color: #d8d4cd !important;}
.f_rd{color: #7a2e1f !important;}
.f_bk {color: #444 !important;}
.f12 {font-size: 1.2rem;}
.f13 {font-size: 1.3rem;}
.f14 {font-size: 1.4rem;}
.f15 {font-size: 1.5rem;}
.f16 {font-size: 1.6rem;}
.f17 {font-size: 1.7rem;}
.f18 {font-size: 1.8rem;}
.f19 {font-size: 1.9rem;}
.f20 {font-size: 2rem;}
.lh12{line-height: 1.2em;}
.lh13{line-height: 1.3em;}
.lh14{line-height: 1.4em;}
.lh15{line-height: 1.5em;}
.lh16{line-height: 1.6em !important;}
.lh17{line-height: 1.7em;}
.lh18{line-height: 1.8em;}
.lh19{line-height: 1.9em;}
.lh20{line-height: 2em;}
.fw4 {font-weight: 400;}
.fw5 {font-weight: 500;}
.fw6 {font-weight: 600;}
.fw7 {font-weight: 700;}
.ls07 {letter-spacing: 0.07em;}
.ls1 {letter-spacing: 0.1em;}
.ls15 {letter-spacing: 0.15em;}
.ls2 {letter-spacing: 0.2em;}
.shdimg {-webkit-filter: drop-shadow(0 0 15px rgba(0, 0, 0, 0.5));}
.shdtx {text-shadow: 0 0 7px rgba(0, 0, 0, 0.9);}
.w100 {width: 100%;display: block;}
.bg_bk {background: #444;}
.bg_w {background: #fff;}
.cover {background-size: cover;background-position: center;}
.box {box-sizing: border-box;}
.tt{ writing-mode: vertical-rl; white-space: nowrap;}
.flx{ display: flex; flex-wrap: wrap;}
.flx_cen{ display: flex; align-items: center;flex-wrap: wrap;}
.flx_rev{ flex-direction: row-reverse;}
.flx_bet{ display: flex; justify-content: space-between; flex-wrap: wrap;}
.flx_bot{align-items: flex-end;}
.flx_stt{align-items: flex-start;}
.flx_bet_cen{ display: flex; justify-content: space-between; align-items: center;flex-wrap: wrap;}

body{animation: fadeIn 2s ease 0s 1 normal;-webkit-animation: fadeIn 2s ease 0s 1 normal; }
@keyframes fadeIn {0% {opacity: 0}100% {opacity: 1}}
@-webkit-keyframes fadeIn {0% {opacity: 0}100% {opacity: 1}}

/*header*/
.header{position: fixed; top: 0; left: 0; width: 100%; padding:0; z-index: 100; box-sizing: border-box; pointer-events:none;}
.hd_wrap{ width: 200px; float: right; padding: 40px 25px; height: 100vh; box-sizing: border-box; position: relative;}
.logo{ max-width: 118px; margin: auto; padding: 0 0 calc(30px + 2%) 0; width: 70%;pointer-events:all;}
.hd_mn{ padding: 5px;pointer-events:all;}
.hd_mn li{ width: 20%; writing-mode: vertical-rl; white-space: nowrap; vertical-align: middle; font-size: 1.25rem; line-height: 36px;position: relative;}
.hd_mn li p{position: absolute; top: calc(100% + 50px); writing-mode: vertical-rl; white-space: nowrap; vertical-align: middle; left: calc(50% - 22px); font-size: 1rem; letter-spacing: 0.1em;color: #7a2e1f; height: 100px;}
.hd_mn li p:before{ position: absolute; content: ""; display: block; height: 25px; top: -35px; width: 1px; background: #aca8a5; left:50%; font-weight: 600;}
.hd_mn2{ position: absolute; bottom: 25px; left: 25px; width:calc(100% - 50px); border-top: 1px solid #aca8a5; z-index: 99999999999; pointer-events: auto;}
.hd_mn2 li{border-bottom: 1px solid #aca8a5;}
.hd_mn2 li a{ padding: 12px 0 12px 30px; font-size: 1.2rem; line-height: 1em; letter-spacing: 0.05em;}
.hdmn2_1{ background: url(../images/hd_ic_map.png) left center/14px no-repeat;}
.hdmn2_2{ background: url(../images/hd_ic_mail.png) left center/14px no-repeat;}
.hdmn2_3{ background: url(../images/hd_ic_bag.png) left center/14px no-repeat;}
.hd_bg{ position: absolute; z-index: 0; background: url(../images/hd_bg.jpg) center/cover no-repeat; width: 40%; height: 50vh; padding: 40px 0 0 25px;}
.hd_insta{width: 15px; margin: 0 0 15px 0;}
.hd_eng{ max-width: 320px; margin: 0 0 30px 0;}
.cn_hd{ padding: 0 0 0 15px;}

.loading {
  width: 100vw;
  height: 100vh;
  transition: all 1.3s;
 background: url(../images/opening.jpg) center/cover no-repeat;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
  opacity: 1;
  visibility: visible;
}

.loading.is-active {
  opacity: 0;
  visibility: hidden;
}

.loading-animation {
  width: 100vw;
  height: 100vh;
  transition: all 1.3s;
  background-color: #20a3ea;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
}

.loading-animation.is-active {
  opacity: 1;
  visibility: visible;
}

/*index*/
.contents{padding: 40px 0 0 0; position: relative; z-index: 1;}
.mv{ height: calc(100vh - 212px); min-height: 650px; width: calc(100% - 200px); padding:0 0 0 15px; box-sizing: border-box; position: relative; margin: 0 0 calc(50px + 5%) 0;}
.mv .bx-viewport,.mv .bx-wrapper,.idx_it_sl .bx-viewport,.idx_it_sl .bx-wrapper,.cf_sl .bx-viewport,.cf_sl .bx-wrapper{ width: 100%; height: 100%; z-index: 1;}
.mv_sl{ width: 100%; height: 100%;}
.mv_sl li{ width: 100%; height: 100%; background-position: center; background-size: cover;}
.mv_cont{ position: absolute; left: 10%; bottom: 10%; max-width: 170px; z-index: 2;}
.mv_logo{padding: 0 0 calc(30px + 5%);}
.mv_copy{color: #fff; width: 100%; font-size: 3.6rem; line-height: 1.5em;text-align: center;}
.mv_copy p{display: inline-block;writing-mode: vertical-rl; white-space: nowrap;}
.idx_cpt_tx{ width: 100%;  position: relative; padding: 0 10px 0 0; box-sizing: border-box;font-size: 2.2rem; line-height: 2.2em;}
.idx_cpt_tx font{ position: relative; z-index: 1;}
.idx_en{ display: table; position: absolute; color: #fff; font-size: 13.2rem; line-height: 1em; right: -35px; top:-60px; z-index: 0; opacity: 0.5;}
.idx_cpt_img_w{ margin:calc(-50px - 7%) 0 calc(60px + 7%) 0;}
.idx_cpt_img{ width: 74%; position: relative;}
.idx_cpt_r{width: 25%; text-align: right;}
.idx_lnk1{ background: url(../images/lnk_icon_red.png) left center/30px no-repeat; display:inline-table; font-size: 1.6rem !important; padding: 15px 0 15px 40px;}
.idx_lnk2{ background: url(../images/lnk_icon_red.png) center top/30px no-repeat; display:inline-table; font-size: 1.6rem!important; padding: 40px 15px 0 15px;}
.idx_cpt_imgtx{ position: absolute; left: 0; bottom: calc(100% + 20px); font-size: 3.5rem; line-height: 1.4em; font-weight: 500;}
.idx_str_mv{ width:calc(100% - 30px); margin: 0 15px; background: url(../images/idx_str_mv.jpg) center/cover no-repeat; height: calc(27vw + 180px); position: relative;}
.idx_en2{ left: 2%; top:-70px;}
.idx_str_w{margin: 0 0 calc(50px + 5%) 0;}
.idx_str_cnt{}
.idx_str_l{ width: 52%; padding: calc(30px + 4%) 0 0 0;}
.idx_str_tx{ font-size: 2.2rem; line-height: 2em;}
.idx_str_r{ width: 35%; margin: calc(-30px - 6%) 3% 0 0;}
.idx_str_imgtx{ position: absolute; right: -5%; bottom: 90%; font-size: 2.4rem; line-height: 1.2em; font-weight: 500; max-width: 350px; width: 80%;}
.idx_itm_w{ width: 100%; background: #e0ddd7; padding: calc(30px + 2%) 0 calc(30px + 4%) 0;}
.idx_itemttl{ font-size: 1.2rem; line-height: 1em; text-align: center; letter-spacing: 0.07em; margin: 0 0 calc(20px + 2%) 0;}
.idx_itemttl span{ font-size: 1.8em; line-height: 1.7em; color: #7a2e1f; display: block; padding: 8px 0 0 0;}
.idx_it_lnk{ width: 80px;}
.idx_it_prd{ width: calc(100% - 80px);}
.idx_it_sl{}
.idx_it_img{ width: 65%;}
.idx_it_infbx{ width: 30%;}
.idx_it_name{ display: table; margin: 0 auto calc(15px + 3.5%) auto;}
.idx_it_name a{font-size: 2.4rem; line-height: 1.1em; background: url(../images/lnk_icon_red.png) center top/20px no-repeat; padding: 28px 0 0 0;}
.idx_it_name a span{font-size:0.7em;}
.idx_it_tx{ display: table; margin: auto; font-size: 1.5rem; line-height: 1.9em;}
.bx-pager{ width: 100%; text-align: center; padding: 20px 0 0 0;}
.bx-pager-item{text-indent: -9999px; display: inline-block; margin: 0 5px;}
.bx-pager-link{background: #201c1b;border-radius: 50px; width: 12px; height: 12px; }
.bx-pager-link.active{background: #fff;border-radius: 50px; width: 12px; height: 12px; }
/*footer*/
.footer{ position: relative; z-index: 101;}
.ft_bg{background: url(../images/ft_bg.jpg) center/cover; padding: calc(15px + 2%) 0;}

.ft_bg_txt{ display: table; margin: auto; font-size: 1.45rem; line-height: 2.2em;}
.ft_logo{ position: absolute; right: 5%; width: 132px; top: calc(50% - 10px);}
.ft_btm{background: #201c1b; padding: calc(30px + 2%) 0 0 0;}
.ft_btmin{padding: 0 5%; max-width: 1700px; margin: auto; box-sizing: border-box;}
.ft_btm_lnk{ width: 300px;}
.ft_btm_lnk li{ width: 100%; background: #000; margin: 0 0 1px 0;}
.ft_btm_lnk li:last-child{margin:30px 0 0 0;}
.ft_btm_lnk li a{padding: 14px 0 14px 60px;line-height: 20px;}
.ft_btm_lnktx{ font-size: 1.2rem; line-height: 25px; padding: 0 0 10px 0; font-weight: 600;}
.ft_lnk1{ font-size: 2rem; background: url(../images/ft_icon_phone.png) 5% center/20px no-repeat;}
.ft_lnk2{ font-size: 1.4rem; background: url(../images/ft_icon_mail.png) 5% center/20px no-repeat;}
.ft_lnk3{ font-size: 1.4rem; background: url(../images/ft_icon_bag.png) 5% center/20px no-repeat;}
.ft_btm_cnt{ width: calc(100% - 350px); max-width: 700px; margin: 35px 0 0 0;}
.ft_mn{ width: 40%;}
.ft_mn li{ width: 20%;writing-mode: vertical-rl; white-space: nowrap;}
.ft_mn li a{background: url(../images/ft_menu_icon.png) center top/12px no-repeat; padding:18px 10px 0 10px; line-height: 12px; font-size: 1.4rem;}
.ft_btm_inf{width: 57%;}
.ft_btm_infli li{border-top:1px solid #534e4b; padding: 14px 0; font-size: 1.2rem; line-height: 1.2em; font-weight: 600;}
.ft_btm_sns li{border:1px solid #534e4b; text-align: center; width: 49%;}
.ft_btm_sns a{ text-align: center; padding: 12px 10px 12px 30px; font-size: 1.3rem;}
.ft_btm_sns1{ background: url(../images/ft_icon_insta.png) 6% center/15px no-repeat;}
.ft_btm_sns2{ background: url(../images/ft_icon_map.png) 6% center/15px no-repeat;}
.copy{ font-size: 1.2rem; text-align: center; padding:calc(30px + 3%) 0 25px 0;}
/*contents*/
.cnt_mv{width: calc(100% - 215px); margin: 0 0 calc(30px + 3.5%) 15px; max-height: 440px; position: relative; height: 55vw; background-position: center; background-size: cover;}
.cnt_mv_cf{width: calc(100% - 215px); margin: 0 0 calc(30px + 3.5%) 15px; max-height: 700px; position: relative; height:60vw; background-position: center; background-size: cover;}
.cnt_ttl{color: #d8d4cd; text-align: center; vertical-align: middle; display: table; height: 100%; margin: auto;font-size: 2.3rem; line-height: 1em;font-weight: 600;}
.cnt_ab_w1{ margin: 0 0 calc(50px + 6.5%) 0;}
.cnt_ttl_en{ position: absolute; top: calc(50% - 10px); font-size: 1.5rem; left: 5%; color: #d8d4cd; line-height: 20px; height: 20px; font-weight: 500;}
.cnt_mv_mini{ position: absolute; bottom: 10px; left: 10px; font-size: 1.2rem; line-height: 1.2em; font-weight: 600;}
.cnt_ttl_en:before{background: #d8d4cd; height: 1px; width: 25vw; content: ""; display: block; left: calc(100% + 30px); top: 50%; position: absolute;}
.cnt_ttlen{text-align: center; line-height: 1em; padding:0 0 calc(10px + 1.6%) 0; font-weight: 500;}
.cnt_ab_itr{ font-size: 2rem; line-height: 2.4em; display: table; margin:0 auto calc(30px + 2%) auto;}
.cnt_ab_itr2{ margin:0 auto calc(20px + 2%) auto;}
.cnt_ab_itrimg{ width: 65%;}
.cnt_ab_itrimg li{ width: 50%;}
.cnt_ab_itrbg{ background: url(../images/ab_itrbg.jpg) center/cover no-repeat; z-index: -1; width: 65%; margin: calc(50px + 3%) 0 0 -30%; height: 24vw;}
.cnt_ab_w2{ margin: 0 0 calc(30px + 4.5%) 0;}
.cnt_ab2_l{ width: 25%;}
.cnt_ab2_r{ width: 75%;}
.cnt_ttljp{font-size: 2.4rem;line-height: 1em; display: table; margin:0 auto calc(25px + 1%) auto;}
.cnt_ttljp2{ line-height: 1.6em; padding: 0 0 calc(20px + 20%) 0;}
.cnt_ab2_rbx{ width: 50%;}
.cnt_ab2_name{ font-size: 2.4rem; border-bottom: 1px solid #aca8a5; padding:  calc(15px + 2%) 0 10px 0; line-height: 1em; display: table; letter-spacing: 0.1em;}
.cnt_ab2_name span{ font-size: 0.5em; padding: 0 15px 0 0;}
.cnt_ab2_tx{padding: calc(15px + 1.5%) 0 0 0;}
.cnt_ab_w3{ padding: calc(20px + 3.5%) 0 calc(30px + 4.5%) 0; background: #b2aa9b;}
.cnt_ab3_r{ width: 150px;}
.cnt_ab3_l{ width: calc(100% - 150px);}
.cnt_ab3_img{padding: 0 0 calc(10px + 1%) 0;}
.cnt_ab3_img img{width: 50%;}
.cnt_ab3_li{padding: 0 0 1.5% 0;}
.cnt_ab3_li li{padding: 30px 0; width: 48%; border-bottom: 1px solid #938f8c;}
.cnt_ab3_li li:last-child{width: 100%; border: none;}
.cnt_ab3li_ttl{ font-size: 1.2rem; line-height: 20px; width: 70px;}
.cnt_ab3li_tx{ font-size: 1.7rem; line-height: 20px; width: calc(100% - 75px); word-break: break-all;}
.cnt_ab3li_lnk{margin: 15px 0 0 0; border: 1px solid #938f8c; background: #c9c4b9; font-size: 0.7em; padding: 5px 15px; border-radius:50px; line-height: 15px; display: table;}
.cnt_ab3li_tx span{font-size: 0.7em;}
#map_canvas{width: 100%; height:calc(150px + 30vw);}
.cnt_ab_acs{border: 1px solid #938f8c; width: 100%; padding:calc(15px + 0.5%); box-sizing: border-box; margin: 0 0 calc(10px + 1%) 0;}
.cnt_acs_img{ width: 45%;}
.cnt_acs_img li{ width:calc(33.33% - 2px);}
.cnt_acs_txb{ width: 50%;}
.cnt_acs_ttl{ font-size: 1.55rem; line-height: 1.4em; padding: 0 0 calc(10px + 1%) 0;}
.cnt_lucomp_ttl{ font-size: 1.45rem; line-height: 1.4em; padding: 0 0 calc(10px + 1%) 0; font-weight: 600;}

.cnt_st_w1{ padding: 0 0 calc(60px + 4%) 0;}
.cnt_st_imgb{width: 55%;}
.cnt_st_txb{width: 43%;}
.cnt_st_txb_ttl{ width: 150px;}
.cnt_st_txb_tx{ width: calc(100% - 150px); font-size: 1.4rem; line-height: 1.7em;}
.idx_st1_imgli{ width: 45%; padding: calc(30px + 3%) 0 0 0; margin: 0 0 0 auto;}
.idx_st1_imgli img{ width: 50%;}
.idx_st2_imgli{ width: 100%; padding: calc(30px + 4%) 0 0 0; margin: 0 0 0 auto;}
.idx_st2_imgli img{ width: 50%;}
.idx_st3_imgli{padding: calc(30px + 4%) 0 0 0;}
.idx_st3_imgli1 { width: 50%;}
.idx_st3_imgli1 li{ width: calc(50% - 3px);}
.idx_st3_imgli2 { width: 30%;}

.cnt_lu_w{ padding: 0 0 calc(30px + 3%) 0;}
.cnt_lubx{ padding: 0 0 calc(30px + 1%) 0;}
.cnt_lu_img{ width: 55%;}
.cnt_lu_txb{ width: 40%;}
.cnt_lu_ttl{ vertical-align: middle; font-size: 2.2rem; line-height: 1.25em; width: 60px; padding: 0 15px 0 0;}
.cnt_lu_ttl2{writing-mode:horizontal-tb !important; width: 100% !important; padding: 0 0 15px 0 !important; font-size: 2rem; letter-spacing: -0.08em;}
.cnt_lu_ttl span{display: block; font-size: 0.6em;}
.cnt_lu_tx{ width: calc(100% - 80px);}
.cnt_lu_tx img{width: 70px; padding: 0 0 10px 0;}
.cnt_lu_txp{ font-size: 1.5rem; line-height: 1.7em;}
.cnt_lu_cmpli{ width: 55.3%;}
.cnt_lu_cmpli li{ width: 49.5%;}
.cnt_lu_cmp_txb{ width: 40%;}

.fun_teacof{ background: url(../images/fun_bg.jpg) center/cover no-repeat; padding: calc(20px + 1%) 0; margin:0 0 calc(40px + 3%) 0;}
.fun_itr_img{ width: 65%;}
.fun_itr_img li{ width: 49.5%;}
.fun_itr_txb{ width: 30%;}
.fun_itr_ttl{ font-size: 1.6rem; line-height: 1.6em; margin: 0 0 calc(15px + 1.5%) 0;}

.fun_bx{ margin: 0 0 calc(35px + 1.5%) 0;}
.funbx_img{ width: 50%;}
.funbx_txb{ width: 43%;}
.funbx_txbttl{font-size: 1.8rem; width: 100px; text-align: center; background: url(../images/ttl_icon_green.png) center top/30px no-repeat; padding: 35px 0 0 0;}
.funbx_txbtx{ width: calc(100% - 120px); font-size: 1.3rem; line-height: 1.7em;}
#map_canvas_api{width: 100%; height: calc(200px + 20vw); filter: grayscale(80%);}
#map_canvas_api iframe{width: 100%; height: 100%;}

/*cafe*/
.cf_itr{ align-items: flex-end;}
.cf_sl{ width:80%; position: relative;}
.cf_sltx{ width: 17%; padding: 0 0 70px 0; letter-spacing: -0.01em;}
.cf_sltx p{font-size: 1.3rem; line-height: 1.7em; margin: 0 0 15px 0;}
.cf_sl .bx-pager{ width: 100%; text-align: center; padding: 20px 0 0 0; position: absolute; left: 0; bottom:85px;z-index: 1;}
.cf_sld p{ text-align: right; height: 70px; line-height: 70px; font-size:1.1rem; font-weight: 600;}
.cf_ist{ border: 1px solid #938f8c; background: url(../images/caf_ist.png) 10px center/12px no-repeat;padding: 0 10px 0 22px; height: 30px; line-height: 30px; border-radius: 3px; text-align: center; font-size: 1.1rem; }
.cf_shp{ border: 1px solid #938f8c; padding: 0 10px; height: 30px; line-height: 30px; border-radius: 3px; text-align: center; font-size: 1.1rem; }
.cf_sub{width: 30%; margin: 0 0 0 auto;}
.cf_sub li{width: 49%;}
.cf_gen{line-height: 70px; font-weight: 500; height: 70px;}
.cf_genw{padding: 0 0 calc(50px + 5%) 0;}
.cf_genimg{ width: 66%;}
.cf_genimg li{ width: 49%;}
.cf_genif{ width: 30%;}
.cf_genbx{border-top:1px solid #938f8c; padding: calc(15px + 3%) 0;}
.cf_gen_ttl{ width: 70px;}
.cf_gen_tx{ width: calc(100% - 75px); font-size: 1.4rem; line-height: 1.5em;}
.cf_gen_tx2{ font-size: 1.2rem; line-height: 1.5em;}
.cf_gen_tx span{font-size: 0.8em; display: block; line-height: 1.45em;}
.cf_genli li{ width: 49%;}
/*▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲*/
@media screen and (max-width: 1400px) {
    /*header*/

} /*▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲*/
@media screen and (max-width: 1024px) {
    body {}
    .in,.in2 {width:calc(105% - 170px);}
    /*header*/
    .hd_wrap{ width: 170px;padding: 30px 15px;}
    .hd_mn li{ font-size: 1.15rem; line-height:35px;position: relative;}
    .hd_mn li p{position: absolute; left: calc(50% - 17px);}
    .hd_mn2 li a{ padding: 10px 0 10px 25px; font-size: 1.1rem;}
    
    /*index*/
    .hd_eng{ zoom:90%; }
    .mv{ height: calc(100vh - 200px); width: calc(100% - 170px);}
    .idx_cpt_tx{ font-size: 2.2rem;}
    .idx_en{ font-size: 11.5rem;}
    .idx_lnk1,.idx_lnk2{ display:inline-table; font-size: 1.5rem!important;}
    .idx_cpt_imgtx{ font-size: 3rem;}
    .idx_str_r{ width: 40%; margin: calc(-30px - 4%) 2% 0 0;}
    .idx_cpt_tx,.idx_str_tx{ font-size: 2rem;}
    .idx_str_imgtx{ font-size: 2rem;}
    .idx_it_name a{font-size: 2rem; background: url(../images/lnk_icon_red.png) center top/15px no-repeat; padding: 20px 0 0 0;}
    .idx_it_tx{font-size: 1.4rem;}
    
    /*footer*/
    .ft_btm_lnk{ width: 260px;}
    .ft_btm_cnt{ width: calc(100% - 300px);}
    .ft_lnk1{ font-size: 1.8rem;}
    .ft_lnk2,.ft_lnk3{ font-size: 1.3rem; }
    
    /*contents*/
    .cnt_mv,.cnt_mv_cf{width: calc(100% - 185px);}
    .cnt_ttl_en:before{width: 23vw;}
    .cnt_ab_itr{ font-size: 1.75rem; line-height: 2em;}
    .cnt_ttljp{font-size: 2.2rem;}
    .cnt_ab2_name{ font-size: 2rem;}
    .cnt_ab3_r{ width: 120px;}
    .cnt_ab3_l{ width: calc(100% - 120px);}
    .cnt_ab3li_ttl{ font-size: 1rem; line-height: 18px; width:50px; font-weight: 600;}
    .cnt_ab3li_tx{ font-size: 1.5rem; line-height: 18px; width: calc(100% - 55px);}
    .cnt_st_txb_ttl{ width: 120px;}
    .cnt_st_txb_tx{ width: calc(100% - 120px); font-size: 1.3rem;}
    
    .cnt_lu_ttl{ font-size:1.8rem;}
    .cnt_lu_txp{ font-size: 1.45rem;}
    .fun_itr_ttl{ font-size: 1.5rem;}
    
    .funbx_txbttl{font-size: 1.7rem; width: 80px; background: url(../images/ttl_icon_green.png) center top/20px no-repeat; padding: 25px 0 0 0;}
    .funbx_txbtx{ width: calc(100% - 100px); font-size: 1.3rem; line-height: 1.7em;}
    
    /*cafe*/
	.cf_sl{ width:100%; position: relative;}
	.cf_sltx{ width: 50%; padding: 0; letter-spacing: -0.01em; margin: 0 auto 0 0;}
	.cf_sltx p{font-size: 1.2rem;}
	.cf_sub{width: 40%; margin: 0 0 0 auto;}
	.cf_gen_ttl{ width:100%; padding: 0 0 10px 0;}
	.cf_gen_tx{ width: 100%; font-size: 1.3rem;}
	.cf_genli li{ width: 100%; margin: 0 0 4px 0;}
} /*▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲*/

@media screen and (max-width: 769px) {
    body {}
    .pc {display: none !important;}
    .sp {display: block !important;}
    .in2 {padding: 0;}
    .f13 {font-size: 1.25rem;}
    .f14 {font-size: 1.3rem;}
    .f15 {font-size: 1.4rem !important;}
    .f16 {font-size: 1.5rem !important;}
    .f17 {font-size: 1.6rem;}
    .f18 {font-size: 1.7rem;}
    .f19 {font-size: 1.8rem;}
    .f20 {font-size: 1.9rem;}
    .in,.in2 {width:calc(105% - 140px);}
    /*header*/
    .hd_wrap{ width: 140px;padding: 30px 15px;}
    .hd_mn li{ font-size: 1.2rem; line-height:27px;position: relative;}
    .hd_mn li p{position: absolute; left: calc(50% - 15px);}
    .hd_mn2 li a{ padding: 10px 0 10px 14px; font-size: 1rem; letter-spacing: 0;}
    .hdmn2_1{ background: url(../images/hd_ic_map.png) left center/8px no-repeat;}
    .hdmn2_2{ background: url(../images/hd_ic_mail.png) left center/8px no-repeat;}
    .hdmn2_3{ background: url(../images/hd_ic_bag.png) left center/8px no-repeat;}
    .hd_mn2{ bottom: 15px; left: 15px; width:calc(100% - 27px);}
    /*menu*/
     
    *, *:before, *:after {padding: 0;margin: 0;box-sizing: border-box;}
    .cp_cont {height: 65vh;}
    .cp_offcm01 {position:absolute;right:-5px;display: inline-block; top:calc(50% - 20px);}
    .smaller .cp_offcm01 {top: 0;}
    /* menu */
    .cp_offcm01 .cp_menu {
	position: fixed;
	top: 0;
	right: -100vw;
	width: 250px;
	height: 100%;
	cursor: pointer;
	-webkit-transition: 0.8s transform;
	        transition: 0.8s transform;
	-webkit-transition-timing-function: cubic-bezier(.38,.52,.23,.99);
	        transition-timing-function: cubic-bezier(.38,.52,.23,.99);
	background-color: #fff;
	opacity: 0.95;
}
.cp_offcm01 .cp_menu ul {
	margin: 0;
	padding: 0;
}
.cp_offcm01 .cp_menu li {
	list-style: none;
}
.cp_offcm01 .cp_menu li a ,.cp_offcm01 .cp_menu li p{
	display: block;
	padding: 20px;
	text-decoration: none;
	color: #333;
}

.cp_offcm01 #cp_toggle01 {
	position: absolute;
	display: none;
	opacity: 0;
}
.cp_offcm01 #cp_toggle01:checked ~ .cp_menu {
	-webkit-transform: translateX(-100vw);
	        transform: translateX(-100vw);
}
/* menu toggle */
.cp_offcm01 #cp_toggle01 ~ label {
	display: block;
	padding: 0.5em;
	cursor: pointer;
	-webkit-transition: 0.5s transform;
	        transition: 0.5s transform;
	text-align: center;
	color: #333333;
}
.cp_offcm01 #cp_toggle01:checked ~ label {
	-webkit-transform: translateX(-250px);
	        transform: translateX(-250px);
}
.cp_offcm01 #cp_toggle01 ~ label::before {
	content: '';
    background: url(../images/bag_off.png) center/100% no-repeat;
    display: block;
    width: 25px; height: 25px;
}
.cp_offcm01 #cp_toggle01:checked ~ label::before {
	content:'';
    background: url(../images/bag_on.png) center/100% no-repeat;
}
/* contents */
.cp_contents {
	color: #333333;
	text-align: center;
}
    .hd_mn_sp{ padding:calc(20px + 3%) 0 0 0 !important; box-sizing: border-box;}
    .hd_mn_sp li{ font-size: 1.3rem;}
    .hd_mn_sp li span{ font-size: 1rem; padding: 0 0 0 15px; font-weight: 700; color: #0aada8; letter-spacing: 0.1em;font-family: 'Montserrat', sans-serif !important;}
    .hd_mn_insp{ display: none;}
    .hd_mn_insp li a{padding: 13px 25px !important;}
    
    /*footer*/
    .hideClass {
  transform: translateY(-60px);
}

    /*index*/
    .contents{padding: 20px 0 0 0;}
    .hd_insta{width: 12px; margin: 0 0 10px 0;}
    .hd_eng{ max-width: 320px; margin: 0 0 20px 0; line-height: 1.5em; zoom:80%; }
    .cn_hd{ padding: 0 0 0 15px;}
    .mv{ height: calc(100vh - 136px); width: calc(100% - 140px);}
    .mv_cont{ width: 25%; z-index: 2;}
    .mv_logo{padding: 0 0 calc(15px + 3%);}
    .mv_copy{ font-size: 3rem; }
    
    .idx_cpt_tx,.idx_str_tx{ font-size: 1.7rem; line-height: 2em;}
    .idx_en{ font-size: 11rem;right: -35px; top:-40px;}
    .idx_lnk1{ background: url(../images/lnk_icon_red.png) left center/20px no-repeat; font-size: 1.4rem!important; padding: 15px 0 15px 30px;}
    .idx_lnk2{ background: url(../images/lnk_icon_red.png) center top/20px no-repeat; font-size: 1.4rem!important; padding: 30px 15px 0 15px;}
    .idx_cpt_imgtx{ font-size: 2.2rem;}
    .idx_str_tx{ line-height: 1.8em;}
    .idx_str_l{ width: 48%; padding: calc(30px + 4%) 0 0 0;}
    .idx_str_r{ width: 45%; margin: calc(-30px - 4%) 0 0 0;}
    .idx_it_lnk{ width: 50px;}
    .idx_it_prd{ width: calc(100% - 50px);}
    .idx_it_name a{font-size: 1.8rem;}
    .idx_it_tx{font-size: 1.3rem; line-height: 1.65em;}
    
    /*footer*/
    .ft_btm_lnk{ width: 220px;}
    .ft_btm_cnt{ width: calc(100% - 260px);}
    .ft_mn li a{font-size: 1.2rem;}
    
    /*contents*/
    .cnt_mv,.cnt_mv_cf{width: calc(100% - 155px);}
    .cnt_ttl{font-size: 2rem;}
    .cnt_ttl_en{font-size: 1.3rem;}
    .cnt_ttl_en:before{width: 20vw;}
    .cnt_ab_itr{ font-size: 1.7rem; line-height: 1.9em;}
    
    .cnt_ab_itrimg{ width: 75%;}
    .cnt_ab_itrbg{width: 75%; margin: calc(50px + 3%) 0 0 -50%;}
    
    .cnt_acs_img{ width: 100%;margin: 0 0 15px 0;}
    .cnt_acs_txb{ width: 100%;}
    
    .cnt_ttljp{font-size: 2rem;}
    .cnt_ttljp2{font-size: 1.7rem; line-height: 1.6em;}
    .cnt_ab2_l{ width: 20%;}
    .cnt_ab2_r{ width: 80%;}
    .cnt_ab2_name{ font-size: 1.8rem;}
    .cnt_ab3_li li{padding: 20px 0; width: 48%; border-bottom: 1px solid #938f8c;}
    .cnt_ab3li_tx{ font-size: 1.45rem;}
    .cnt_st_txb_ttl{ width: 70px;}
    .cnt_st_txb_tx{ width: calc(100% - 70px); font-size: 1.25rem; letter-spacing: -0.02em;}
    
    
    
    .cnt_lu_ttl{ font-size:1.6rem; width: 40px;}
    .cnt_lu_tx{width: calc(100% - 60px);}
    .cnt_lu_txp{ font-size: 1.25rem;}
	
	.cnt_lu_cmpli{width: 100%; margin: 0 0 calc(15px + 2%) 0;}
	.cnt_lu_cmp_txb{ width: 100%;}

    

    .fun_itr_img{ width: 50%;}
    .fun_itr_txb{ width: 45%;}
    
    .funbx_txbttl{font-size: 1.7rem; width: 80px; background: url(../images/ttl_icon_green.png) center top/20px no-repeat; padding: 25px 0 0 0;}
    .funbx_txbtx{ width: calc(100% - 80px); font-size: 1.2rem; line-height: 1.7em;}

} /*▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲▲*/
@media screen and (max-width: 630px) {
    body {}
    .on_pc {display: none;}
    .on_sp {display: block !important;}
    .f14 {font-size: 1.25rem;}
    .f15 {font-size: 1.35rem !important;}
    .f16 {font-size: 1.45rem !important;}
    .f17 {font-size: 1.55rem;}
    .f18 {font-size: 1.65rem;}
    .f19 {font-size: 1.75rem;}
    .f20 {font-size: 1.85rem;}
    .in,.in2 {width: 100%;}
    /*header*/
    .header{ height: 70px; padding:5%; box-sizing: border-box;}
    .smaller{ background: #e0ddd7;padding: 2.5% 5%; height: 60px;}
    
    .hd_wrap{ width: 100%; float: none; padding:0; height: auto;}
    .logo{ width: 70px; margin: 0; padding: 0;}
    .smaller .logo{ width: 40px; margin: 0; padding: 0;}
    /*index*/
    .contents{padding: calc(70px + 10%) 0 0 0; position: relative; z-index: 1;}
    .mv{ height: calc(60vh - 120px); width:100%; padding: 0 2%; min-height: 550px;}
    .mv_cont{ left: 7%; bottom: 7%; min-width: 120px;}
    .mv_copy{ font-size: 2.8rem; }
    
    .idx_cpt_tx,.idx_str_tx{ font-size: 1.65rem; padding: 0; letter-spacing: 0.05em;}
    .idx_en{ font-size: 9rem;right: -30px; top:-50px;}
    
    .idx_cpt_img_w{ margin:calc(10px + 4%) 0 calc(60px + 7%) 0;}
    .idx_cpt_img{ width: 100%; margin: 0 0 10px 0; }
    .idx_cpt_r{width: 100%; text-align: center;}
    .idx_lnk1,.idx_lnk2{ font-size: 1.3rem!important;}
    .idx_cpt_imgtx{left: -3%; bottom:10px; font-size: 2.2rem;}
    .idx_str_l{ width: 100%; padding: calc(30px + 4%) 0 calc(15px + 2%) 0;}
    .idx_str_r{ width:100%; margin:0; padding: 0 0 0 20%;}
    .idx_str_imgtx{ position: absolute; right: auto; bottom: 10%; font-size: 2rem; left: 0;}
    .idx_it_img{ width: 100%; margin: 0 0 calc(20px + 2%) 0;}
    .idx_it_infbx{ width: 100%;}
    .idx_it_name{ display: table; margin: 0 auto calc(15px + 3.5%) auto; width: 40px; float: right;}
    .idx_it_tx{ width: calc(100% - 60px); float: left; padding: 30px 0 0 0;}
    
    /*footer*/
    .ft_btm_lnk{ width:100%;}
    .ft_btm_cnt{ width: 100%;}
    .ft_mn{ width: 300px; margin: 0 auto calc(20px + 3%) auto;}
    .ft_btm_inf{width: 100%;}
    .ft_mn li{}
    .ft_mn li a{ line-height: 25px; width: 25px; padding: 25px; display: table;}
    .ft_logo{  right: calc(50% - 50px); width: 102px; top: 50px;}
    .ft_bg{padding: calc(95px + 4%) 0 calc(15px + 2%) 0;}
    
    /*contents*/
    .cnt_mv,.cnt_mv_cf{width:100%; margin: 0 0 calc(25px + 2%) 0;height:90vw;}
    .cnt_ttl{font-size: 1.65rem;}
    .cnt_ttl_en{font-size: 1.2rem;}
    .cnt_ttl_en:before{width: 17vw;}
    .cnt_ab_itr{ font-size: 1.45rem; line-height: 1.6em;}
    .cnt_ab_itrimg{ width: 85%;}
    .cnt_ab_itrbg{margin: calc(30px + 3%) 0 0 -60%;}
    .cnt_ttlen{padding:0 0 calc(5px + 1.5%) 0;}
    .cnt_ttljp{font-size: 1.9rem;}
    .cnt_ttljp2{font-size: 1.65rem; padding: 0;}
    .cnt_ab2_l,.cnt_ab2_r,.cnt_ab3_r,.cnt_ab3_l,.cnt_st_imgb,.cnt_st_txb{ width: 100%;}
    .cnt_ab2_name{ font-size: 1.7rem;}
    .cnt_acs_ttl{ font-size: 1.4rem;}
    
    .cnt_st_imgb{width: 100%; padding: 0 0 calc(15px + 1.5%) 0;}
    .idx_st1_imgli{ width: 75%;}
    .idx_st3_imgli1 { width: 80%;}
    .idx_st3_imgli2 { width: 40%; margin: 40px 0 0 auto;}
    
    .cnt_lu_img{ width: 100%; margin: 0 0 calc(15px + 2%) 0;}
    .cnt_lu_txb{ width: 100%; margin: 0 0 calc(35px + 2%) 0;}
    .cnt_lu_ttl{ font-size:1.6rem; width:60px; padding: 0 40px 0 0;}
    .cnt_lu_tx{width: calc(100% - 100px);}
    
    .fun_itr_img{ width: 100%; margin: 0 0 calc(15px + 1%) 0;}
    .fun_itr_txb{ width: 100%;}
    
    .funbx_img{ width: 100%; margin: 0 0 calc(15px + 2%) 0;}
    .funbx_txb{ width: 100%; margin: 0 0 calc(25px + 2%) 0; }
	
	
	/*cafe*/
	.cf_sltx{ width: 100%; padding: 0 0 30px 0;}
	.cf_sub{width: 50%; margin: 0 0 0 auto;}
	.cf_genimg{ width: 100%; padding: 0 0 20px 0;}
	.cf_genif{ width: 100%;}
	.cf_gen_ttl{ width: 70px; padding: 0;}
	.cf_gen_tx{ width: calc(100% - 75px);}
	.cf_genli li{ width: 49%;}
	.cf_sld p{ height: 50px; line-height: 50px; font-size:0.9rem; text-align: left; letter-spacing: -0.03em; }
}