@charset "utf-8";
:root{
  --main-color: #1a4c71;
  --sub-color: #858ea0;
  --txt-color: #333;
  --root-margin: 240px auto 0;
  --font-mincho: "游明朝", "Yu Mincho", "Times New Roman", "Hiragino Mincho ProN", "MS PMincho", serif;
  --font-gothic: "游ゴシック", "Yu Gothic", "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Meiryo", sans-serif;
}
.cf::after {
  content: "";
  display: block;
  clear: both;
}


@media only screen and (max-width: 768px) {
/* -------------------------------- 
common
-------------------------------- */
html{
	font-size: 48%;
/*	font-size: calc(40.625% + 0.25vw);*/
}
body{
  width: 100vw;
  overflow-x: hidden;
	font-weight: 500;
	font-size: 3.6vw;
	font-family: var(--font-gothic);
}
.lsp{
	letter-spacing: -1px;
}
.sub-txt{
	line-height: 1.75;
}
a{
	color: #333;
	text-decoration: none;
	transition: .6s;
}
a:hover{
	transition: .6s;
}
img{
	width: 100%;
	height: auto;
}
.en,.date,.price{
  font-family: var(--font-mincho);
}

/* セクションパーツ */
.en{
  color: var(--sub-color);
  font-size: 12vw;
  font-weight: bold;
  line-height: 1;
  text-align: right;
  letter-spacing: 1px;
}
.en span{
  color: var(--main-color);
  font-size: 16vw;
}
.parts01-block .in:first-of-type{
}
.parts01-block .in:last-of-type{
  width: 77vw;
  margin: 22vw 0 0 auto;
}
.parts01-block .catch{
  position: relative;
  width: 66vw;
  margin: 5vw 0 0;
  font-size: 4vw;
  line-height: 1.75;
  letter-spacing: -.5px;
}
.parts01-block .catch::before{
  content: "";
  display: block;
  position: absolute;
  bottom: -6vw;
  left: -6vw;
  width: 72vw;
  height: .5vw;
  background: var(--sub-color);
}
.parts01-block.left h2{
  width: 66vw;
  margin: 0 0 0 auto;
  box-sizing: border-box;
}
.parts01-block.left .catch{
  margin: 5vw 0 0 auto;
}
.parts01-block.left .catch::before{
  left: inherit;
  right: -6vw;
}
.parts01-block.left .in:last-of-type{
  margin: 22vw auto 0 0;
}
.parts01-block.left .in:last-of-type .en{
  text-align: left;
}
.parts01-block .lead-txt{
  margin: 7vw 0 0;
  line-height: 1.5;
}
.sub-txt{
	line-height: 1.75;
}

/* ボタンパーツ01 */
.btn-01{
  margin: 4vw 0 0;
}
.btn-01 a{
  display: block;
  width: 27.5vw;
  margin: 0 0 0 auto;
  padding: 3.25vw 0;
  background: var(--main-color);
  border-radius: 5vw;
  box-sizing: border-box;
  color: #fff;
  text-align: center;
  font-weight: bold;
}

/* ボタンパーツ02 */
.btn-02{
  margin: 20vw 0 0;
  text-align: center;
}
.btn-02 a{
  display: block;
  width: 31.8vw;
  margin: 0 auto;
}
.btn-02 a span{
  display: block;
}
.btn-02 a span:first-of-type{
  position: relative;
  padding: 0 0 2vw;
  font-size: 3vw;
  text-align: left;
  transition: .6s;
}
.btn-02 a span:last-of-type{
  padding: 2vw 0 0;
  font-weight: bold;
  text-align: right;
  transition: .6s;
}
.btn-02 a span:first-of-type::before{
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 31.8vw;
  height: 2px;
  background: var(--main-color);
  transition: .6s;
}
.btn-02 a span:first-of-type::after{
  content: "";
  display: block;
  position: absolute;
  bottom: 2px;
  right: 0;
  width: 1vw;
  height: 2px;
  background: var(--main-color);
  transform: rotate(38deg);
}


/* -------------------------------- 
パンくず
-------------------------------- */
#Pan{
	padding: 4vw 0;
}
#Pan ul{
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-justify-content: flex-start;
	justify-content: flex-start;
	-webkit-align-items: stretch;
	align-items: stretch;
	width: 88vw;
	margin: 0 auto;
  font-size: 3vw;
	text-align: center;
}
#Pan li:nth-of-type(n+2)::before{
	content: "＞";
	padding: 0 1.5vw;
}
#Pan a{
  color: var(--main-color);
  font-weight: bold;
}


/* -------------------------------- 
header
-------------------------------- */
header{
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
  background: #fff;
  border-bottom: 1px solid #707070;
  color: #333;
  transition: .3s;
	z-index: 999;
}
header h1{
  font-size: 1rem;
}
header a{
  color: #333;
}
.top-block{
  padding: 4vw 0 0;
}
.header-block{
  position: relative;
  width: 88vw;
  margin: 0 auto;
}
.top-block{
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: center;
	align-items: center;
  position: relative;
  padding: 3.5vw 0 0;
  font-size: 1.2rem;
}
.top-block::before{
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: -50vw;
  width: 200vw;
  height: 1px;
  background: #fff;
}
.top-block::before{
  display: none;
}
.top-block p{
  display: none;
}
.top-block ul{
  display: none;
}
.down-block{
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: center;
	align-items: center;
  padding: 0 0 3.5vw;
  font-size: 1.2rem;
}
.logo{
  width: 46vw;
  height: auto;
}
.down-block nav{
  margin: 0 45px 0 auto;
}
.down-block nav ul{
  position: absolute;
  right: 100vw;
}
.hum{
  height: 3vw;
  cursor: pointer;
}
.hum div{
  width: 5vw;
  height: 2px;
  background: #454545;
}
.hum div + div{
  margin: 1vw 0 0;
}
.menu-block{
  position: absolute;
  top: 0;
  right: 100vw;
}
#Content{
  margin: 34vw 0 0;
}
.under #Content{
  margin: 18vw 0 0;
  padding: 16vw 0 0;
}


/* header下層 */
body.open{
  overflow: hidden;
  height: 100%;
}
.open .header-block{
  position: static;
  color: #333;
}
.open .header-block a{
  color: #333;
}
.hum.open{
  position: relative;
  z-index: 999;
}
.hum.open div{
  background: #333;
}
.hum.open div:nth-of-type(1){
  transform: rotate(45deg);
  transition: .6s;
}
.hum.open div:nth-of-type(2){
  display: none;
  transition: .6s;
}
.hum.open div:nth-of-type(3){
  margin-top: -.5vw;
  transform: rotate(-45deg);
  transition: .6s;
}
.menu-block.open{
  overflow-y: auto;
  position: absolute;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: #efefef;
  transition: .6s;
}
.menu-block .inner{
  width: 88vw;
  margin: 0 auto;
  padding: 60px 0;
}
.menu-block .inner > ul + ul{
  margin-top: 11.5vw;
}
.menu-block .menu-in{
  margin-top: 20vw;
}
.menu-block .inner > ul:nth-of-type(1){
  text-align: right;
}
.menu-block .inner > ul:nth-of-type(1) li + li{
  margin-top: 4vw;
}
.menu-block .inner > ul:nth-of-type(1) a{
  display: block;
  position: relative;
  width: 100%;
  color: var(--main-color);
  font-size: 4vw;
  font-weight: bold;
}
.menu-block .inner > ul:nth-of-type(1) li a::before{
  content: "";
  display: block;
  position: absolute;
  bottom: 4px;
  left: 0;
  width: 60vw;
  height: 2px;
  background: var(--sub-color);
  transition: .6s;
}
.menu-block .inner > ul:nth-of-type(1) li a::after{
  content: "";
  display: block;
  position: absolute;
  bottom: 6px;
  left: 58vw;
  width: 2vw;
  height: 2px;
  background: var(--main-color);
  transform: rotate(38deg);
  transition: .6s;
}
.menu-block .inner > ul:nth-of-type(1) li a span::before{
  content: "";
  display: block;
  position: absolute;
  bottom: 4px;
  left: 40vw;
  width: 20vw;
  height: 2px;
  background: var(--main-color);
  transition: .6s;
  z-index: 1;
}
.menu-block .inner > ul:nth-of-type(2) li + li{
  margin-top: 6vw;
}
.menu-block .menu-in .img + p{
  margin-top: 3vw;
  font-size: 3.6vw;
  font-weight: bold;
}
.menu-block .menu-in .img + p + p{
  margin-top: 3vw;
  font-size: 3.6vw;
  line-height: 1.5;
}
.menu-block .menu-in ul{
  margin-top: 8vw;
  font-size: 4vw;
}
.menu-block .menu-in li + li{
  margin-top: 5vw;
}
.menu-block .menu-in ul a{
  position: relative;
  display: block;
  padding-left: 11.3vw;
  color: var(--main-color);
  font-weight: bold;
}
.menu-block .menu-in ul a::before{
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
}
.menu-block .menu-in li:nth-of-type(1) a::before{
  width: 5.28vw;
  height: 4.15vw;
  background: url("https://www.freespirits-kobe.mom/assets/img/common_ico-mail.svg") top/contain no-repeat;
}
.menu-block .menu-in li:nth-of-type(2) a::before{
  width: 5.28vw;
  height: 5.33vw;
  background: url("https://www.freespirits-kobe.mom/assets/img/common_ico-question.svg") top/contain no-repeat;
}
.menu-block .menu-in li:nth-of-type(3) a::before{
  left: calc(1.18vw/2);
  width: 4.1vw;
  height: 6vw;
  background: url("https://www.freespirits-kobe.mom/assets/img/common_ico-pin.svg") top/contain no-repeat;
}
.menu-block .menu-in a:hover{
  color: var(--sub-color);
}


/* -------------------------------- 
footer
-------------------------------- */
footer{
  width: 100vw;
  overflow-x: hidden;
  margin: 32.5vw 0 0;
  background: #fff;
}
.under footer{
  margin-top: 0;
}
.footer-map{
  position: relative;
}
.map-in iframe{
  width: 100%;
  height: 85vw;
}
.footer-map .fmap-block{
  width: 100%;
}
.footer-map .img{
}
.footer-map .in{
  padding: 5vw 6vw 0;
  background: #fff;
  box-sizing: border-box;
}
.footer-map .ttl{
  position: relative;
  padding: 0 0 2vw;
  font-weight: bold;
}
.footer-map .ttl::before{
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 77vw;
  height: 2px;
  background: var(--sub-color);
}
.footer-map .ttl::after{
  content: "";
  display: block;
  position: absolute;
  bottom: 2px;
  left: 76vw;
  width: 1vw;
  height: 2px;
  background: var(--sub-color);
  transform: rotate(38deg);
}
.footer-map .ttl span::before{
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 4.7vw;
  height: 2px;
  background: var(--main-color);
  z-index: 1;
}
.footer-map .add{
  margin: 4vw 0 0;
  line-height: 1.5;
}
.footer-map .btn-01{
  margin: 6vw 0 0 auto;
}
footer nav{
  width: 88vw;
  margin: 20vw auto 0;
}
footer nav .fnav-block{
  margin: 0 0 8vw;
  padding: 7vw 0 0;
  border-top: .8vw solid #efefef;
}
footer nav .fnav-ttl a{
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: center;
	align-items: center;
}
footer nav .fnav-ttl .ttl{
  position: relative;
  padding: 0 6vw 0 0;
  background: #fff;
  font-size: 4vw;
  font-weight: bold;
}
footer nav .fnav-ttl .ttl::before{
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  width: 77vw;
  height: 2px;
  margin: -1px 0 0;
  background: var(--sub-color);
  z-index: -1;
}
footer nav .fnav-ttl .ttl::after{
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  width: 32.4vw;
  height: 2px;
  margin: -1px 0 0;
  background: var(--main-color);
  transition: .6s;
  z-index: -1;
}
footer nav .fnav-ttl span{
  display: inline-block;
  position: relative;
  padding: 0 5.6vw 0 0;
  background: #fff;
  box-sizing: border-box;
  color: var(--main-color);
}
footer nav .fnav-ttl span::before{
  content: "";
  display: block;
  position: absolute;
  top: -1vw;
  right: 1.2vw; 
  width: 1.2vw;
  height: .4vw;
  background: var(--main-color);
  transform: rotate(45deg);
}
footer nav .fnav-ttl span::after{
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: 1.2vw; 
  width: 1.2vw;
  height: .4vw;
  background: var(--main-color);
  transform: rotate(-45deg);
}
footer nav .fnav-block dl{
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-justify-content: flex-start;
	justify-content: flex-start;
	-webkit-align-items: stretch;
	align-items: stretch;
  width: 77vw;
  margin: 7vw auto 0;
}
footer nav .fnav-block dt{
  width: 100%;
  font-weight: bold;
}
footer nav .fnav-block dd + dt,
footer nav .fnav-block dt + dt{
  margin: 6vw 0 0;
}
footer nav .fnav-block dt span{
  padding: 0 0 0 3.3vw;
  font-weight: normal;
}
footer nav .fnav-block dd{
  position: relative;
  width: 100%;
  margin: 6vw 0 0;
  padding: 0 0 0 8.4vw;
  box-sizing: border-box;
}
footer nav .fnav-block dd::before{
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  display: block;
  width: 5.5vw;
  height: 2px;
  background: var(--sub-color);
}
footer .flogo{
  width: 50%;
  margin: 0 auto 6vw;
}
footer .copy{
  padding: 20px 0;
  background: var(--sub-color);
	color: #fff;
	text-align: center;
}
footer .copy{
	color: #fff;
  font-size: 1.6rem;
	text-align: center;
}
}


@media only screen and (min-width: 769px) {
/* -------------------------------- 
common
-------------------------------- */
html{
	font-size: 62.5%;
/*	font-size: calc(40.625% + 0.25vw);*/
}
body{
  overflow-x: hidden;
	min-width: 980px;
	background: #fff;
	font-weight: 500;
	font-size: 1.6rem;
	font-family: var(--font-gothic);
}
h1{
	color: #fff;
}
a{
	color: #333;
	text-decoration: none;
	transition: .6s;
}
a:hover{
	transition: .6s;
}
a:hover img{
	opacity: .8;
}
img{
	width: 100%;
	height: auto;
}
.lsp{
	letter-spacing: -1px;
}
.en,.date,.price{
  font-family: var(--font-mincho);
}

/* セクションパーツ */
.en{
  color: var(--sub-color);
  font-size: 6rem;
  font-weight: bold;
  line-height: 1;
  text-align: center;
  letter-spacing: 6px;
}
.en span{
  color: var(--main-color);
  font-size: 8rem;
}
.parts01-block{
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: stretch;
	align-items: stretch;
}
.parts01-block.left{
  flex-direction: row-reverse;
}
.parts01-block .in:first-of-type{
  width: 440px;
}
.parts01-block .in:last-of-type{
  width: 482px;
  padding: 50px 0 0;
}
.parts01-block .catch{
  position: relative;
  margin: 20px 0 0;
  font-size: 2rem;
  line-height: 1.5;
  letter-spacing: -.5px;
}
.parts01-block .catch::before{
  content: "";
  display: block;
  position: absolute;
  bottom: -80px;
  left: 0;
  width: 100%;
  height: 3px;
  background: var(--sub-color);
}
.parts01-block .lead-txt{
  margin: 60px 0 0;
  line-height: 1.5;
}
.sub-txt{
	line-height: 1.75;
}

/* ボタンパーツ01 */
.btn-01{
  margin: 20px 0 0;
}
.btn-01 a{
  display: block;
  width: 120px;
  margin: 0 0 0 auto;
  padding: 10px 0;
  background: var(--main-color);
  border: 2px solid var(--main-color);
  border-radius: 50px;
  box-sizing: border-box;
  color: #fff;
  text-align: center;
  font-weight: bold;
}
.btn-01 a:hover{
  background: #fff;
  border: 2px solid var(--main-color);
  box-sizing: border-box;
  color: var(--main-color);
}

/* ボタンパーツ02 */
.btn-02{
  margin: 75px 0 0;
  text-align: center;
}
.btn-02 a{
  display: block;
  width: 150px;
  margin: 0 auto;
}
.btn-02 a span{
  display: block;
}
.btn-02 a span:first-of-type{
  position: relative;
  padding: 0 0 10px;
  font-size: 1.2rem;
  text-align: left;
  transition: .6s;
}
.btn-02 a span:last-of-type{
  padding: 10px 0 0;
  font-weight: bold;
  text-align: right;
  transition: .6s;
}
.btn-02 a span:first-of-type::before{
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 150px;
  height: 3px;
  background: var(--main-color);
  transition: .6s;
}
.btn-02 a span:first-of-type::after{
  content: "";
  display: block;
  position: absolute;
  bottom: 3px;
  right: 0;
  width: 10px;
  height: 3px;
  background: var(--main-color);
  transform: rotate(38deg);
  transition: .6s;
}
.btn-02 a:hover span:first-of-type,
.btn-02 a:hover span:last-of-type{
  color: var(--main-color);
  transition: .6s;
}
.btn-02 a:hover span:first-of-type::before,
.btn-02 a:hover span:first-of-type::after{
  background: var(--sub-color);
  transition: .6s;
}


/* -------------------------------- 
パンくず
-------------------------------- */
#Pan{
	padding: 15px 0;
}
#Pan ul{
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-justify-content: flex-start;
	justify-content: flex-start;
	-webkit-align-items: stretch;
	align-items: stretch;
	width: 980px;
	margin: 0 auto;
	line-height: 1.75;
	text-align: center;
}
#Pan li:nth-of-type(n+2)::before{
	content: "＞";
	padding: 0 10px;
}
#Pan a{
  color: var(--main-color);
  font-weight: bold;
}
#Pan a:hover{
  color: #333;
}


/* -------------------------------- 
header
-------------------------------- */
header{
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
  color: #fff;
	z-index: 999;
}
header a{
  color: #fff;
}
.header-block{
  position: relative;
  width: 980px;
  margin: 0 auto;
}
.top-block{
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: center;
	align-items: center;
  position: relative;
  padding: 11px 0;
  font-size: 1.2rem;
}
.top-block::before{
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: -50vw;
  width: 200vw;
  height: 1px;
  background: #fff;
}
.top-block p{
  margin: 0 30px 0 auto;
}
.top-block ul{
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: center;
	align-items: center;
  width: 70px;
}
.top-block li:nth-of-type(1){
  width: 18px;
  height: auto;
}
.top-block li:nth-of-type(2){
  width: 16px;
  height: auto; 
}
.top-block li:nth-of-type(3){
  width: 17px;
  height: auto;
}
.down-block{
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: center;
	align-items: center;
  padding: 5px 0 10px;
  font-size: 1.2rem;
}
.logo{
  width: 233px;
  height: auto;
}
.down-block nav{
  margin: 0 45px 0 auto;
}
.down-block nav ul{
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: stretch;
	align-items: stretch;
  width: 545px;
}
.hum{
  height: 20px;
  cursor: pointer;
}
.hum div{
  width: 30px;
  height: 3px;
  background: #fff;
  transition: .6s;
}
.hum div + div{
  margin: 5px 0 0;
}
.menu-block{
  position: absolute;
  top: 0;
  left: 100vw;
  width: 100vw;
  transition: .6s;
}

/* header w-color */
header.w-color{
  position: fixed;
  background: #fff;
  border-bottom: 1px solid #454545;
  color: #333;
  transition: .3s;
}
.w-color h1{
  color: #333;
}
.w-color a{
  color: #333;
}
.w-color .top-block::before{
  background: #efefef;
}
.w-color .top-block p{
  margin: 0 30px 0 auto;
}
.w-color .hum div{
  background: #454545;
}

/* header下層 */
.under h1{
  color: #333;
}
.under header{
  background: #fff;
  border-bottom: 1px solid #454545;
  color: #333;
}
.under header a{
  color: #333;
}
.under .top-block::before{
  background: #efefef;
}
.top-block p{
  margin: 0 30px 0 auto;
}
.under .hum div{
  background: #454545;
}
.under #Content{
  margin: 170px 0 0;
}

/* header下層 */
.open .header-block{
  position: static;
  color: #333;
}
.open .header-block a{
  color: #333;
}
.hum.open{
  position: relative;
  z-index: 999;
}
.hum.open div{
  background: #333;
}
.hum.open div:nth-of-type(1){
  transform: rotate(45deg);
  transition: .6s;
}
.hum.open div:nth-of-type(2){
  display: none;
  transition: .6s;
}
.hum.open div:nth-of-type(3){
  margin-top: -3px;
  transform: rotate(-45deg);
  transition: .6s;
}

.menu-block.open{
  position: absolute;
  top: 0;
  left: 0;
  width: 100vw;
  background: #efefef;
  transition: .6s;
}
.menu-block .inner{
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: stretch;
	align-items: stretch;
  width: 980px;
  margin: 0 auto;
  padding: 60px 0;
}
.menu-block .inner > ul{
  width: 265px;
}
.menu-block .menu-in{
  width: 233px;
  margin-right: 80px;
}
.menu-block .inner > ul:nth-of-type(1){
  width: 213px;
  text-align: right;
}
.menu-block .inner > ul:nth-of-type(1) li + li{
  margin-top: 23px;
}
.menu-block .inner > ul:nth-of-type(1) a{
  display: block;
  position: relative;
  width: 100%;
  color: var(--main-color);
  font-size: 1.6rem;
  font-weight: bold;
}
.menu-block .inner > ul:nth-of-type(1) li a::before{
  content: "";
  display: block;
  position: absolute;
  bottom: 4px;
  left: 0;
  width: 100px;
  height: 2px;
  background: var(--sub-color);
  transition: .6s;
}
.menu-block .inner > ul:nth-of-type(1) li a::after{
  content: "";
  display: block;
  position: absolute;
  bottom: 6px;
  left: 92px;
  width: 8px;
  height: 2px;
  background: var(--main-color);
  transform: rotate(38deg);
  transition: .6s;
}
.menu-block .inner > ul:nth-of-type(1) li a span::before{
  content: "";
  display: block;
  position: absolute;
  bottom: 4px;
  left: 69px;
  width: 31px;
  height: 2px;
  background: var(--main-color);
  transition: .6s;
  z-index: 1;
}
.menu-block .inner > ul:nth-of-type(1) a:hover{
  color: var(--sub-color);
}
.menu-block .inner > ul:nth-of-type(1) li a:hover span::before{
  left: 49px;
  width: 51px;
  transition: .6s;
}
.menu-block .inner > ul:nth-of-type(2) li + li{
  margin-top: 26px;
}
.menu-block .menu-in .img + p{
  margin-top: 15px;
  font-weight: bold;
}
.menu-block .menu-in .img + p + p{
  margin-top: 10px;
  line-height: 1.5;
}
.menu-block .menu-in ul{
  margin-top: 20px;
}
.menu-block .menu-in li + li{
  margin-top: 13px;
}
.menu-block .menu-in ul a{
  position: relative;
  display: block;
  padding-left: 30px;
  color: var(--main-color);
  font-weight: bold;
}
.menu-block .menu-in ul a::before{
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
}
.menu-block .menu-in li:nth-of-type(1) a::before{
  width: 14px;
  height: 11px;
  background: url("https://www.freespirits-kobe.mom/assets/img/common_ico-mail.svg") top/contain no-repeat;
}
.menu-block .menu-in li:nth-of-type(2) a::before{
  width: 14px;
  height: 14px;
  background: url("https://www.freespirits-kobe.mom/assets/img/common_ico-question.svg") top/contain no-repeat;
}
.menu-block .menu-in li:nth-of-type(3) a::before{
  left: 2px;
  width: 10px;
  height: 16px;
  background: url("https://www.freespirits-kobe.mom/assets/img/common_ico-pin.svg") top/contain no-repeat;
}
.menu-block .menu-in a:hover{
  color: var(--sub-color);
}


/* -------------------------------- 
footer
-------------------------------- */
footer{
  margin: 200px 0 0;
  background: #fff;
}
.under footer{
  margin-top: 0;
}
.footer-map{
  position: relative;
}
.footer-map .map-in iframe{
  width: 100%;
  height: 628px;
}
.footer-map .fmap-block{
  position: absolute;
  top: 200px;
  left: 50%;
  width: 980px;
  margin: 0 0 0 calc(-980px/2);
}
.footer-map .img{
  width: 399px;
}
.footer-map .in{
  width: 399px;
  padding: 30px 30px 40px;
  background: #fff;
  box-sizing: border-box;
}
.footer-map .ttl{
  position: relative;
  padding: 0 0 8px;
  font-weight: bold;
}
.footer-map .ttl::before{
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 266px;
  height: 2px;
  background: var(--sub-color);
  transition: .6s;
}
.footer-map .ttl::after{
  content: "";
  display: block;
  position: absolute;
  bottom: 2px;
  left: 261px;
  width: 5px;
  height: 2px;
  background: var(--sub-color);
  transform: rotate(38deg);
  transition: .6s;
}
.footer-map .ttl span::before{
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 43px;
  height: 2px;
  background: var(--main-color);
  transition: .6s;
  z-index: 1;
}
.footer-map .add{
  margin: 8px 0 0;
  font-size: 1.2rem;
  line-height: 1.5;
}
.footer-map .btn-01{
  margin: 16px 0 0 auto;
}
footer nav{
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: stretch;
	align-items: stretch;
  width: 980px;
  margin: 0 auto;
  padding: 70px 0;
}
footer nav .fnav-block{
  width: 208px;
}
footer nav .fnav-ttl a{
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: center;
	align-items: center;
}
footer nav .fnav-ttl .ttl{
  position: relative;
  padding: 0 15px 0 0;
  background: #fff;
  font-weight: bold;
}
footer nav .fnav-ttl .ttl::before{
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  width: 176px;
  height: 2px;
  margin: -1px 0 0;
  background: var(--sub-color);
  z-index: -1;
}
footer nav .fnav-ttl .ttl::after{
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  width: 125px;
  height: 2px;
  margin: -1px 0 0;
  background: var(--main-color);
  transition: .6s;
  z-index: -1;
}
footer nav .fnav-ttl a:hover .ttl::after{
  width: 176px;
  transition: .6s;
}
footer nav .fnav-ttl span{
  display: inline-block;
  position: relative;
  width: 33px;
  padding: 0 14px 0 10px;
  background: #fff;
  box-sizing: border-box;
  color: var(--main-color);
  font-size: 1.2rem;
}
footer nav .fnav-ttl span::before{
  content: "";
  display: block;
  position: absolute;
  top: -3px;
  right: 0;
  width: 5px;
  height: 2px;
  background: var(--main-color);
  transform: rotate(45deg);
}
footer nav .fnav-ttl span::after{
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  width: 5px;
  height: 2px;
  background: var(--main-color);
  transform: rotate(-45deg);
}
footer nav .fnav-block dl{
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-justify-content: flex-start;
	justify-content: flex-start;
	-webkit-align-items: stretch;
	align-items: stretch;
  margin: 26px 0 0;
}
footer nav .fnav-block dt{
  width: 100%;
  font-weight: bold;
}
footer nav .fnav-block dd + dt,
footer nav .fnav-block dt + dt{
  margin: 16px 0 0;
}
footer nav .fnav-block dt span{
  padding: 0 0 0 10px;
  font-weight: normal;
  font-size: 14px;
}
footer nav .fnav-block:nth-of-type(2) dt span{
  display: none;
}
footer nav .fnav-block dd{
  position: relative;
  width: 100%;
  margin: 16px 0 0;
  padding: 0 0 0 48px;
  box-sizing: border-box;
  font-size: 14px;
}
footer nav .fnav-block dd::before{
  content: "";
  position: absolute;
  top: 50%;
  left: 12px;
  display: block;
  width: 28px;
  height: 1px;
  background: var(--sub-color);
  transition: .6s;
}
footer nav .fnav-block a:hover{
  color: var(--main-color);
}
footer nav .fnav-block dd:hover::before{
  background: var(--main-color);
  transition: .6s;
}
footer .flogo{
  width: 200px;
  margin: 0 auto 30px;
}
footer .copy{
  padding: 20px 0;
  background: var(--sub-color);
	color: #fff;
	text-align: center;
}
}



@media only screen and (min-width: 1400px) {
html{
	font-size: 62.5%;
}
}