@charset "utf-8";
/* 共通style --------------------------------*/
body{
    margin: 0 auto;
    font-family: 'Open Sans', Helvetica, Arial, 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Meiryo, メイリオ, sans-serif;
    color: #404040; 
}
body{
    background-image: none;
} 
header{
    margin: 0 auto;
}
header .inner{
    width: 100%;
    background: -moz-linear-gradient(to bottom,#92c1ff,#FFF 50%,#FFF); 
    background: -webkit-linear-gradient(to bottom,#92c1ff,#FFF 50%,#FFF); 
    background: linear-gradient(to bottom,#92c1ff,#FFF 50%,#FFF); 
}
h1{
    margin: 0 auto;
    text-align: center;
    line-height: 2.4;
    font-size: 2.4rem;
    position: relative;
    display: inline-block;
    left: 0;
    right: 0;
    width: 100%;
    padding-top: 10px;
}
h1 span.logi_name{
    font-size: 1.9rem;
    font-weight: 500;
}
h1 span.logi_name:after{
    content: '';
    position: absolute;
    bottom: 90px;
    display: inline-block;
    width: 40px;
    height: 3px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    background-color: #2C5EB7;
}
h1 span.logi_name{
    font-size: 1.9rem;
    font-weight: 500;
}
h1 span.logi_name:after{
    content: '';
    position: absolute;
    bottom: 90px;
    display: inline-block;
    width: 40px;
    height: 3px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    background-color: #2C5EB7;
}
h2{
    text-align: center;
    background-color: #3d3d3d;
    margin-bottom: 0;
    padding: 15px 0;
    color: #ffffff;
}
p.first{
    text-align: center;
    font-size: 1.6rem;
    margin: 30px 0 20px;
    line-height: 1.8;
}
footer small {
    color: #ffffff;
    text-align: center;
    margin: 0 auto;
    display: block;
    padding: 30px 0;
    font-size: 82%;
    font-family: Arial, Helvetica, sans-serif;
    background: #161616;
}
#page_top{
    width: 50px;
    height: 50px;
    position: fixed;
    right: 10px;
    bottom: 110px;
    background: #3f98ef;
    opacity: 0.6;
    border-radius: 50%;
}
#page_top a{
    position: relative;
    display: block;
    width: 50px;
    height: 50px;
    text-decoration: none;
}
#page_top a::before{
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    content: '\f102';
    font-size: 25px;
    color: #fff;
    position: absolute;
    width: 25px;
    height: 25px;
    top: -5px;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    text-align: center;
}
/*SlideToggle*/
ul.accordion__menu{
    width: 560px;
    margin: 0 auto 40px;
    padding: 0;
}
.menu__item {
    background: #ffffff;
    cursor: pointer;
    display: block;
    margin-bottom: 1px;
    text-decoration: none;
}
.menu__item__link {
    color: #3f98ef;
    border:#3f98ef solid 1px;
    display: block;
    line-height: 45px;
    padding: 0 1rem;
    position: relative;
    text-decoration: none;
    text-align: center;
    border-radius: 5px;
}
.menu__item__link:after {
    color: #ffffff;
    background: #3f98ef;
    content: '\f067';
    display: block;
    font-family: "Font Awesome 5 Free";
    line-height: 45px;
    position: absolute;
    right: 0;
    text-align: center;
    top: 0;
    width: 45px;
    font-weight: bold;
}
.menu__item__link.on:after {
    content: '\f068';
}
ul.submenu {
    display: none;
    background: #ffffff;
    padding: 20px 0 0 0;
}
ul.submenu li{
    line-height: 1.6;
    list-style: none;
    margin-bottom: 1em;
    text-indent: -1em;
    padding-left: 1em;
}
ul.submenu li:before {
    content:  "";
    width:  8px;
    height:  8px;
    display:  inline-block;
    background-color: #3f98ef;
    border-radius:  50%;
    margin-right: 0.5em;
}
ul.menu{
    display: flex;
	justify-content: center;
    margin: 0 auto 50px;
    padding: 0;
}
ul.menu li{
    list-style-type: none;
	padding-left: 0;
}
ul.menu li a {
    display: block;
    color: #ffffff;
    text-decoration: none;
    border-radius: 40px;
    background: #2C5EB7;
    margin: 0 20px;
    padding: 15px 0;
    position: relative;
    font-size: 1.1rem;
    width: 190px;
    box-sizing: border-box;
    text-align: center;
}
ul.menu li a:after{
    content: '';
    position: absolute;
    width: 6px;
    height: 6px;
    border: 1px solid;
    border-color:  transparent transparent #ffffff #ffffff;
    transform: rotate(-45deg);
    left: 50%;
    bottom: 10px;
}
.tours{
    margin: 0 auto;
}
#box_01,
#box_02,
#box_03{
    margin: 0 auto 120px;
    width:100%;
}
.fa {
    padding-left: .7em;
}
/*offer
------------------------------------------*/
.offer{
    padding: 10px;
    background: -moz-linear-gradient(left, #3f98ef, #2C5EB7);
    background: -webkit-linear-gradient(left, #3f98ef, #2C5EB7);
    background: linear-gradient(to right, #3f98ef, #2C5EB7);
}
.offer .inner{
    background: #ffffff;
}
.offer p{
    color: #ffffff;
    font-size: 1.8rem;
    padding: 0 0 .3vw;
    margin: 0;
    text-align: center;
}
.offer .inner p{
    color: #012072;
    padding: 0;
}
.offer p.first{
    font-weight: 600;
    text-align: center;
    line-height: 1.4;
    padding: 0;
}
.offer .tel a{
    color: #012072;
    text-decoration: none;
}
.offer .btn--contact a{
    background: url(../images/icn-mail.png) no-repeat 70px center, -moz-linear-gradient(top center, #ade210 0%, #2f9337 100%);
    background: url(../images/icn-mail.png) no-repeat 70px center, -webkit-linear-gradient(top center, #ade210 0%, #2f9337 100%);
    background: url(../images/icn-mail.png) no-repeat 70px center, linear-gradient(to bottom, #ade210, #2f9337);
    background-size: 45px 45px,100% 100%;
    color: #ffffff;
    border-radius: 6px;
    box-sizing: border-box;
    text-decoration: none;
    font-weight: bold;
    padding-left: 140px;
    box-shadow: 0 3px #0e3d72;
    display: block;
}
footer small {
    color: #ffffff;
    text-align: center;
    margin: 0 auto;
    display: block;
    padding: 30px 0;
    font-size: 82%;
    font-family: Arial, Helvetica, sans-serif;
    background: #161616;
}
/*page_top
------------------------------------------*/
#page_top{
    width: 50px;
    height: 50px;
    position: fixed;
    right: 10px;
    bottom: 110px;
    background: #3f98ef;
    opacity: 0.6;
    border-radius: 50%;
}
#page_top a{
    position: relative;
    display: block;
    width: 50px;
    height: 50px;
    text-decoration: none;
}
#page_top a::before{
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    content: '\f102';
    font-size: 25px;
    color: #fff;
    position: absolute;
    width: 25px;
    height: 25px;
    top: -5px;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    text-align: center;
}
/*バーガーボタン*/
* {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}
::before , ::after {
	box-sizing: inherit;
}
button {
	margin: 0;
	padding: 0;
	outline: 0;
	border: 0;
	border-radius: 0;
	background: transparent;
	color: inherit;
	vertical-align: middle;
	text-align: inherit;
	font: inherit;
	-webkit-appearance: none;
	appearance: none;
}
.btn {
	position: absolute;
	top: 4vw;
	right: 16px;
	z-index: 10;
	width: 40px;
	height: 40px;
}
.btn-line {
	display: block;
	position: relative;
	width: 100%;
	height: 4px;
	background-color: #535353;
	transition: .2s;
}
.btn-line::before , .btn-line::after {
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	background-color: #535353;
	transition: .5s;
}
.btn-line::before {
	transform: translateY(-16px);
}
.btn-line::after {
	transform: translateY(16px);
}
.btn-line.open {
	background-color: transparent;
}
.btn-line.open::before , .btn-line.open::after {
	content: "";
	background-color: #535353;
	transition: .2s;
}
.btn-line.open::before {
	transform: rotate(45deg);
}
.btn-line.open::after {
	transform: rotate(-45deg);
}
.nav__menu {
	display: flex;
	flex-direction: column;
	position: fixed;
	right: -70%;
	width: 70%;
	height: 100vh;
	background-color: rgba(43, 43, 43, 0.9);
	color: #efefef;
	transition: .3s;
    z-index: 1;
}
.nav__menu li.menu-list {
	display: flex;
	align-items: center;
	justify-content: center;
    border-bottom: dotted 1px #bbbbbb;
    position: relative;
}
.nav__menu li.menu-list:hover {
	background-color: rgba(31, 31, 31, 0.5);
	color: #333;
	cursor: pointer;
	transition: .3s;
}
.nav__menu li.menu-list a{
    color: #ffffff;
    text-decoration: none;
    width: 100%;
	height: auto;
    padding: 4vw;
    display: block;
}
.nav__menu li.menu-list a::after {
    content: '';
    position: absolute;
    width: 6px;
    height: 6px;
    border: 1px solid;
    border-top-color: currentcolor;
    border-right-color: currentcolor;
    border-bottom-color: currentcolor;
    border-left-color: currentcolor;
    border-color: transparent transparent #ffffff #ffffff;
    transform: rotate(225deg);
    right: 5%;
    top:50%;
}
.nav__menu.open {
	position: absolute;
	right: 0;
}
 /* PC ------------------------------------------------------------------------------------------------------*/
@media print, screen and (min-width:768px){
h1{
    margin-bottom: 40px;
}
.sp--only{
    display: none;
}
.logo {
    margin: 15px auto;
    width: 1000px;
}
.logo img{
    width: 190px;
}
.wrapper{
    margin: 0 auto;
    width: 1000px;
}
header{
    padding: 15px 0;
}
.btn {
    top: 25px;
}
.menu {
    width: 30%;
}
.nav__menu{
    width: 30%;
}
.nav__menu li.menu-list a{
    padding: 15px 20px;
}
/*offer
------------------------------------------*/
.offer{
    width: 1000px;
    margin: 0 auto 120px;
    overflow: hidden;
    box-sizing: border-box;
}
.offer .inner{
    padding: 30px;
}
.offer .btn--contact a{
    width: 630px;
    height: 80px;
    font-size: 1.8rem;
    margin: 0 auto 30px;
    line-height: 80px;
}
.offer .btn--contact a:hover {
    opacity: 0.7;
    filter: alpha(opacity=70);
    -ms-filter: "alpha(opacity=70)";
}
.offer .btn--contact a,
.offer .btn--contact a:before,
.offer .btn--contact a:after {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-transition: all .3s;
    transition: all .3s;
}
.offer p.first{
    font-size: 2.8rem;
    text-align: center;
    margin-bottom: 20px;
}
.offer .tel{
    overflow: hidden;
    margin: 0 auto;
    width: 630px;
}
.offer .tel p.txt--catch{
    float: left;
    text-align: center;
    font-size: 1.4rem;
    font-weight: 600;
    line-height: 1.2;
    margin-bottom: 0;
    margin-top: 8px;
}
.offer .tel p.txt--tel{
    float: right;
    font-size: 3.4rem;
    font-weight: 600;
    background-image: url(../images/icn-tel.png);
    background-position: left center;
    background-repeat: no-repeat;
    background-size: 11%;
    display: inline-block;
    padding-left: 40px;
    margin-bottom: 0;
    margin-top: 0;
}
*::-ms-backdrop, .offer .tel p.txt--tel {
    font-size: 4.4rem;
}
}
/* sp ------------------------------------------------------------------------------------------------------*/
@media only screen and (max-width: 767px)  {
.pc--only{
    display: none;
}
header{
    padding: 4vw 0;
}
header .wrapper{
    background-size: 60% auto;
    background-position: center 0.5vw;
    padding: 30vw 4vw 5vw;
}
.logo{  
    margin:4vw auto;
    width: 100%;
    text-align: center;
}
.logo img{
    width: 50%;
}
.wrapper{
    margin: 0 auto;
    width: 100%;
    box-sizing: border-box;
}
h1{
    font-size: 2.1rem;
    padding-top: 13vw;
}
h1.top{
    padding-top: 0;
}
h1 span.logi_name::after {
    bottom: 2.6em;
}
h1 span.logi_name {
    font-size: 1.7rem;
}
h1 span.logi_name::after {
    bottom: 2.8em;
}
h2{
    font-size: 1.4rem;
    padding: 2vw 0;
}
p.first {
    font-size: 1.1rem;
    margin: 0 4vw 10vw;
    line-height: 1.8;
}
ul.accordion__menu{
    width: 100%;
    margin: 0 auto 4vw;
}
ul.menu li a {
    padding: 3vw 3vw 5vw;
    border-right: #fff 1px dotted;
    font-size: 1.0rem;
    margin: 0;
    width: auto;
    border-radius: 0;
}
.menu__item__link {
    margin: 0 4vw;
    line-height: 30px;
}
.menu__item__link:after {
    line-height: 60px;
}
ul.submenu {
    padding: 20px 4vw 0 8vw;
}
#box_01, #box_02, #box_03 {
    margin: 0 auto 20vw;
}
#page_top{
    bottom:16vw;
}
/*offer
--------------------------------------------*/
.offer {
    padding: 2vw;
    margin: 0 auto 20vw;
}
.offer .inner{
    padding: 6vw;
}
.offer .btn--contact a {
    line-height: 60px;
    background-position: 18vw center;
    background-size: 30px 30px,100% 100%;
    padding-left: 30vw;
    margin-bottom: 4vw;
    font-size: 1.6rem;
}
.offer p{
    font-size: 1.4rem;
    padding: 0 0 1.8vw;
    line-height: 1.3;
}
.offer .tel p{
    padding: 0;
}
.offer .tel p.txt--catch {
    text-align: center;
    font-size: 1.1rem;
    font-weight: 600;
    line-height: 1.2;
    margin-bottom: 2vw;
}
.offer .tel p.txt--catch br{
    display:none;
}
.offer .tel p.txt--tel {
    font-size: 2.2rem;
    font-weight: 600;
    text-align: center;
    background-image: url(../images/icn-tel.png);
    background-position: left center;
    background-repeat: no-repeat;
    background-size: 9%;
    display: table;
    margin: 0 auto;
    padding-left: 25px;
}
.offer .tel a{
    text-decoration: none;
    color: #012072;
}
#page_top{
    bottom:16vw;
}
footer small {
    padding: 4vw 0;
}
}
  