@charset "utf-8";
/*
Theme Name:Maria
Author:Verve
*/

/* WP */
/* -------------------------------------------------- */
/* 投稿の画像配置 */
.alignright { display: block; margin: 0 0 10px auto; }/* 配置位置 左 */
.alignleft { display: block; margin: 0 auto 10px 0; }/* 配置位置 右 */
.aligncenter { display: block; margin: 0 auto 10px; }/* 配置位置 中央 */
/* .alignright { float: right; padding: 0px 0 10px 10px; } *//* 後続のテキスト左回り込み */
/*.alignleft { float: left; padding: 0px 10px 10px 0; }*//* 後続テキスト右回り込み */

/* LINK */
/* -------------------------------------------------- */
a:link,
a:visited { text-decoration: none; color: #333333; }
a:hover  { text-decoration: none; color: #333333; 	transition: 0.3s ease-in-out;
}
a:active { text-decoration: none; color: #333333; }
a:hover img{
	transition: 0.3s ease-in-out;
}

/* FONT FAMILY */
/* -------------------------------------------------- */

.min{
	font-family: "Noto Serif JP", serif;
	font-optical-sizing: auto;
	font-style: normal;
}
.oswald{
    font-family: 'Oswald', sans-serif;
	font-weight: 200;
}
.mplus {
  font-family: "M PLUS 1p", sans-serif;
  font-weight: 400;
  font-style: normal;
}
.roboto {
  font-family: "Roboto", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 400;
  font-variation-settings:
    "wdth" 100;
}

/* CLEARFIX */
/* -------------------------------------------------- */
.cf:before,
.cf:after {
    content: " ";
    display: table;
}

.cf:after {
    clear: both;
}

.cf {
    *zoom: 1;
}

.center{
	text-align: center;
}
.rightTxt{
	text-align: right;
}
/* MARGIN */
/* -------------------------------------------------- */

.mb10{margin-bottom: 10px !important;}
.mb15{margin-bottom: 15px !important;}
.mb20{margin-bottom: 20px !important;}
.mb25{margin-bottom: 25px !important;}
.mb30{margin-bottom: 30px !important;}
.mb40{margin-bottom: 40px !important;}
.mb45{margin-bottom: 45px !important;}
.mb50{margin-bottom: 50px !important;}
.mb55{margin-bottom: 55px !important;}
.mb65{margin-bottom: 65px !important;}
.mb70{margin-bottom: 70px !important;}
.mb75{margin-bottom: 75px !important;}
.mb100{margin-bottom: 100px !important;}

.mb1rem{margin-bottom: 1.0rem !important}
.mb3rem{margin-bottom: 3.0rem !important}

/* OUTLINE */
/* -------------------------------------------------- */
html {
	font-size: 62.5%;/* 10px */
}
body {
	color: #1a1a1a;
	font-size: 1.4rem;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 400;
	font-feature-settings : "palt";
	line-height: normal;
	width: 100%;
	-webkit-text-size-adjust: 100%;
}

#container {
	position: relative;
	overflow: hidden;
}

/*アニメーション設定*/
.blur {
 opacity: 0;
 -webkit-filter: blur(8px);
 filter: blur(8px);
 -webkit-transition: all 1s ease-out;
 transition: all 1s ease-out;
}
.blur.on {
 opacity: 1;
 -webkit-filter: blur(0);
 filter: blur(0);
}
.fadeInLeft {
 opacity: 0;
 -webkit-transform: translateX(-30px);
 transform: translateX(-30px);
 -webkit-transition: all 1.2s ease-out;
 transition: all 1.2s ease-out;
}
.fadeInLeft.on {
 opacity: 1;
 -webkit-transform: translateX(0);
 transform: translateX(0);
}
.fadeInUp {
 opacity: 0;
 -webkit-transform: translateY(40px);
 transform: translateY(40px);
 -webkit-transition: all 1s ease-out;
 transition: all 1s ease-out;
}
.fadeInUp.on {
 opacity: 1;
 -webkit-transform: translateY(0);
 transform: translateY(0);
}
.fadeIn {
 opacity: 0;
 -webkit-transition: all 1s ease-out;
 transition: all 1s ease-out;
}
.fadeIn.on {
 opacity: 1;
}
.delay250 {
 transition-delay: 250ms;
}
.delay500 {
 transition-delay: 500ms;
}
.delay1000 {
 transition-delay: 1000ms;
}
.delay1500 {
 transition-delay: 1500ms;
}


/* RESPONSIVE */
/* -------------------------------------------------- */
@media screen and (min-width: 768px) {
        /* 768px以上用（PC用）の記述 */

	body {
		background: url("img/bg@2x.jpg") no-repeat;
		background-size: cover;
		background-position: top center;
	}


    #container {
        min-width: 1280px;
    }
    .contentWrap1{
        width: 960px;
        margin: 0 auto;
		box-sizing: border-box;
    }
    .contentWrap2{
        width: 960px;
        margin: 0 auto;
		box-sizing: border-box;
    }
	.contentWrap3{
        width: 960px;
        margin: 0 auto;
		box-sizing: border-box;
	}
	.contentWrap4{
        width: 100%;
        margin: 0 auto;
		box-sizing: border-box;
	}
    #header{
		position: absolute;
		top: 0;
		width: 100vw;
        box-sizing: border-box;
        z-index: 10;
		padding-top: 65px;
    }
    .topHeader{
		top: 0px;
    }
	/*スクロール時設定*/
	
    #menu{
		width: 835px;
        display: flex;
        justify-content: space-between;
		box-sizing: border-box;
		position: absolute;
		right: 0;
    }
    .menuWrap {
        width: 665px;
        box-sizing: border-box;
		display: flex;
        justify-content: space-between;
		align-items: center;
    }
	.headerLogo {
		width: 226px;
		display: inline-block;
		vertical-align: top;
	}
	.headerName{
		font-size: 1.6rem;
		font-weight: 500;
	}
	.headerTel{
		width: 44px;
	}
/* 電話番号モーダル */
	.headerTel {
	  position: relative;
	  display: inline-block;
	}

	.headerTel .telTooltip {
	  position: absolute;
	  left: 50%;
	  bottom: calc(100% + 10px);
	  transform: translateX(-50%) translateY(6px);
	  white-space: nowrap;
	  background: #fff;
	  border: 1px solid #ddd;
	  box-shadow: 0 6px 18px rgba(0,0,0,.12);
	  border-radius: 8px;
	  padding: 8px 12px;
	  font-size: 1.6rem;
		font-weight: bold;
	  line-height: 1.4;
	  opacity: 0;
	  pointer-events: none;
	  transition: opacity .18s ease, transform .18s ease;
	  z-index: 1000;
	}

	.headerTel .telTooltip::after {
	  content: "";
	  position: absolute;
	  top: 100%;
	  left: 50%;
	  transform: translateX(-50%);
	  border: 8px solid transparent;
	  border-top-color: #fff;
	  filter: drop-shadow(0 2px 1px rgba(0,0,0,.06));
	}

	/* ホバーでも表示したいとき */
	@media (hover: hover) and (pointer: fine) {
	  .headerTel:hover .telTooltip {
		opacity: 1;
		transform: translateX(-50%) translateY(0);
		pointer-events: auto;
	  }
	}

	/* 表示固定クラス */
	.headerTel.is-open .telTooltip {
	  opacity: 1;
	  transform: translateX(-50%) translateY(0);
	  pointer-events: auto;
	}

	
/*メニュー用*/

    .headerMenuBtn{
        position: fixed;
        right: 65px;
        top: 68px;
		z-index: 1000;
		transition: 0.3s;
    }
	#header.smaller .headerMenuBtn{
		top: 30px;
    }
	.menuSlideWrap{
		width: 960px;
		margin: 0 auto;
		padding-top: 80px;
	}
    .menuSlide01{
        position: fixed;
        top: 0px;
        width: 100%;
        height: 100vh;
		background: #23bfcb;
        text-align: left;
        left: 100%;
        transition: 0.5s;
        z-index: 999;
		box-sizing: border-box;
    }
    .menuSlide01.current{
        left: 0;
    }
	.menuLogo{
        display: inline-block;
		position: relative;
        padding-top: 10px;
		padding-left: 24px;
		z-index: 900;
		margin-bottom: 30px;
		color: #fff !important;
	}
	.menuLists {
		text-align: left;
		width: 100%;
		margin: 0 auto 40px;
		display: flex;
		justify-content: flex-start;
		flex-wrap: wrap;
		column-gap: 25px;
	}
	.menuList{
        display: inline-block;
		box-sizing: border-box;
		text-align: center;
		width: 220px;
		margin-bottom: 20px;
    }
	.menuLink1 {
		display: block;
		position: relative;
		color: #fff !important;
		font-size: 1.6rem;
		line-height: 5rem;
		letter-spacing: 0.05em;
		border: 1px solid #fff;
		border-radius: 10px;
	}
	.menuLink1:hover {
		background: #fff;
		color: #23bfcb !important;
	}
	.subLists {
		width: 100%;
		display: flex;
		justify-content: space-around;
		flex-wrap: wrap;
		padding-top: 20px;
		margin-bottom: -10px;
	}
	.subLink {
		display: block;
		position: relative;
		color: #fff !important;
		line-height: 3rem;
		font-size: 1.2rem;
		border: 1px solid #fff;
		width: 100px;
		margin-bottom: 10px;
		border-radius: 6px;
	}
	.subLink:hover {
		background: #fff;
		color: #23bfcb !important;
	}

/*ハンバーガメニュー*/
/*ベース*/
	.menu-trigger {
        display: inline-block;
        transition: all .4s;
        box-sizing: border-box;
        vertical-align: middle;
        height: 62px;
        width: 62px;
        position: relative;
        z-index: 104;
        margin: 0;
        border-radius: 8px;
		background: #fff;
		border: 1px solid rgba(26,26,26,0.6);
	}

    .menu-trigger span {
        display: inline-block;
        transition: all .4s;
        box-sizing: border-box;
        position: absolute;
        left: 50%;
		transform: translateX(-50%);
        width: 32px;
        height: 5px;
        background-color: #1a1a1a;
        border-radius: 3px;
    }
    .menu-trigger.current{
    }
    .menu-trigger.current span{
		background: #1a1a1a;
    }

    .menu-trigger span:nth-of-type(1) {
        top: 18px;
    }
    .menu-trigger span:nth-of-type(2) {
        top: 28px;
    }
    .menu-trigger span:nth-of-type(3) {
        top: 38px;
    }
	
    /*動き*/
    .menu-trigger.current span:nth-of-type(1) {
        transform: translate(-50%, 9px) rotate(-45deg);
    }
    .menu-trigger.current span:nth-of-type(2) {
        left: 50%;
        opacity: 0;
        animation: active-menu-bar02 .8s forwards;
    }
    .menu-trigger.current span:nth-of-type(3) {
        transform: translate(-50%, -11px) rotate(45deg);
    }
	.headerBtn{
		display: flex;
		margin: 0 auto 20px;
		position: relative;
		justify-content: center;
		align-items: center;
        font-size: 1.6rem;
        font-weight: 500;
		width: 220px;
		height: 60px;
		background: #fff;
		text-align: center;
		border-radius: 16px;
		box-sizing: border-box;
	}

	#goTop{
        width:79px;
        height: 80px;
        position: fixed;
        right: 0;
        bottom: 0px;
        z-index: 100;
    }
    .goTopBtn{
        display: block;
        width:80px;
        height: 80px;
        background: #5f503c;
    }
    .goTopBtn:hover{
        opacity: 0.8;
    }
    #gMap{
        width: 100%;
        height: 580px;
    }
    #gMap iframe{
        width: 100%;
        height: 580px;
    }
	
	/*中面共通*/
    .inHeader{
		transition: 0.5s;
    }
	.inMain{
		padding-top: 150px;
	}

    /*Footer*/

	footer {
		background: #f7f7f7;
	}
    .footerWrap{
        width: 960px;
        margin: 0 auto;
        padding: 55px 0 50px;
		box-sizing: border-box;
		align-items: center;
    }
	.footerLogo{
		width: 226px;
	}
	.footerNameW{
		text-align: left;
		width: 605px;
	}
	.footerNameEn{
		font-size: 1.6rem;
		margin-bottom: 10px;
	}
	.footerName{
		font-size: 1.6rem;
	}
	.footerTel{
		width: 44px;
	}
	
	.footerInfo{
        width: 960px;
        margin: 0 auto 45px;
		text-align: center;
		align-items: center;
	}
	.footerInfoL{
		width: 274px;
	}
	.footerTtl{
		letter-spacing: 0.2em;
	}
	.footerInfoR{
		text-align: left;
		width: 695px;
	}
	.footerInfo1W{
		margin-bottom: 15px;
		padding-bottom: 15px;
		border-bottom: 1px solid rgba(26,26,26,0.4);
	}
	.footerInfo01{
		width: 325px;
	}
	.footerinfoName{
		font-size: 1.7rem;
		font-weight: bold;
	}
	.footerInfoAdd{
		font-weight: 500;
	}
	.footerInfo02{
		width: 370px;
	}
	.footerInfo2W{
		
	}

    .copyright{
		width: 100%;
        text-align: center;
		line-height: 3.4rem;
        color: #fff;
		background: #1a1a1a;
    }

/*commonタイトル*/
	.commonTtl01En{
		font-size: 6rem;
		font-weight: bold;
		color: #dee0e1;
	}
	.commonTtl01{
		font-size: 2.2rem;
		font-weight: 500;
		display: block;
		background: #1a1a1a;
		color: #fff;
		border-radius: 4px;
		line-height: 3.9rem;
	}
	.commonTtl02{
		font-size: 3rem;
		background: #f2f2f2;
		line-height: 7.5rem;
		padding-left: 30px;
	}
	.commonTtl03En{
		font-size: 6rem;
		font-weight: bold;
		color: #dee0e1;
	}
	.commonTtl03{
		font-size: 2.2rem;
		font-weight: 500;
		display: inline-block;
		background: #1a1a1a;
		color: #fff;
		border-radius: 4px;
		line-height: 3.9rem;
		padding: 0 20px;
	}

	
/*commonテキスト*/
	.commonTxt01{
		font-size: 1.8rem;
		line-height: 3.1rem;
	}
	.commonTxt02{
		font-size: 2rem;
		line-height: 3.4rem;
		font-weight: 500;
	}

/*commonボタン*/

}
@media screen and (max-width: 767px) {
        /* 767px以下用（スマートフォン用）の記述 */
	body {
		background: url("img/bg_sp.jpg") repeat-y;
		background-size: contain;
		background-position: top center;
	}

	#container {
        width: 100%;
/*        overflow: clip;
*/        overflow: hidden;
		font-size: 1.4rem;
    }
    .contentWrap1{
        width: 90%;
        margin: 0 auto;
    }
    .contentWrap2{
        width: 90%;
        margin: 0 auto;
    }
    .contentWrap3{
        width: 90%;
        margin: 0 auto;
    }
    .contentWrap4{
        width: 90%;
        margin: 0 auto;
    }
    #header{
        width: 100%;
        height: 60px;
        box-sizing: border-box;
        position: absolute;
        z-index: 9999;
    }
    .topHeader{
		top: 0px;
    }
	/*スクロール時設定*/

    #menu{
        width: 100%;
		box-sizing: border-box;
    }
    .menuWrap {
        width: 100%;
        box-sizing: border-box;
		position: relative;
    }
	.headerLogo {
		width: 150px;
		display: inline-block;
		vertical-align: top;
		padding: 5px 0 0 110px;
	}
	.headerName{
		font-size: 1rem;
		font-weight: 500;
	}

/* 電話番号モーダル */
	
	.headerTel {
	  position: absolute;
	  display: inline-block;
		top: 15px;
		right: 60px;
		width: 30px;
	}

	.headerTel .telTooltip {
	  position: absolute;
	  left: 50%;
	  bottom: calc(100% + 10px);
	  transform: translateX(-50%) translateY(6px);
	  white-space: nowrap;
	  background: #fff;
	  border: 1px solid #ddd;
	  box-shadow: 0 6px 18px rgba(0,0,0,.12);
	  border-radius: 8px;
	  padding: 8px 12px;
	  font-size: 1.6rem;
		font-weight: bold;
	  line-height: 1.4;
	  opacity: 0;
	  pointer-events: none;
	  transition: opacity .18s ease, transform .18s ease;
	  z-index: 1000;
	}

	.headerTel .telTooltip::after {
	  content: "";
	  position: absolute;
	  top: 100%;
	  left: 50%;
	  transform: translateX(-50%);
	  border: 8px solid transparent;
	  border-top-color: #fff;
	  filter: drop-shadow(0 2px 1px rgba(0,0,0,.06));
	}

	/* ホバーでも表示したいとき */
	@media (hover: hover) and (pointer: fine) {
	  .headerTel:hover .telTooltip {
		opacity: 1;
		transform: translateX(-50%) translateY(0);
		pointer-events: auto;
	  }
	}

	/* 表示固定クラス */
	.headerTel.is-open .telTooltip {
	  opacity: 1;
	  transform: translateX(-50%) translateY(0);
	  pointer-events: auto;
	}

    .headerMenuBtn{
        position: fixed;
        right: 10px;
        top: 10px;
		z-index: 1000;
		transition: 0.3s;
    }
	.menuSlideWrap{
		width: 100%;
		margin: 0 auto;
		padding-top: 60px;
	}
    .menuSlide01{
        position: fixed;
        top: 0px;
        width: 100%;
        height: 100vh;
		background: #23bfcb;
        text-align: left;
        left: 100%;
        transition: 0.5s;
        z-index: 999;
		box-sizing: border-box;
    }
    .menuSlide01.current{
        left: 0;
    }
	.menuLogo{
        display: inline-block;
		position: relative;
        padding-top: 10px;
		padding-left: 24px;
		z-index: 900;
		margin-bottom: 30px;
		color: #fff !important;
	}
    .menuLists {
        text-align: center;
        width: 100%;
        margin: 0 auto 40px;
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
        column-gap: 25px;
    }
    .menuList {
        display: inline-block;
        box-sizing: border-box;
        text-align: center;
        width: 280px;
        margin-bottom: 10px;
    }
    .menuLink1 {
        display: block;
        position: relative;
        color: #fff !important;
        font-size: 1.6rem;
        line-height: 3.4rem;
        letter-spacing: 0.05em;
        border: 1px solid #fff;
        border-radius: 10px;
    }
	.menuLink1:hover {
		background: #fff;
		color: #23bfcb !important;
	}
	.subLists {
		width: 100%;
		display: flex;
		justify-content: space-around;
		flex-wrap: wrap;
		padding-top: 10px;
		margin-bottom: -10px;
	}
    .subLink {
        display: block;
        position: relative;
        color: #fff !important;
        line-height: 2.4rem;
        font-size: 1.2rem;
        border: 1px solid #fff;
        width: 120px;
        margin-bottom: 10px;
        border-radius: 6px;
    }
	.subLink:hover {
		background: #fff;
		color: #23bfcb !important;
	}

/*ハンバーガメニュー*/
/*ベース*/
	.menu-trigger {
        display: inline-block;
        transition: all .4s;
        box-sizing: border-box;
        vertical-align: middle;
        height: 40px;
        width: 40px;
        position: relative;
        z-index: 104;
        margin: 0;
        border-radius: 6px;
		background: #fff;
		border: 1px solid rgba(26,26,26,0.6);
	}

    .menu-trigger span {
        display: inline-block;
        transition: all .4s;
        box-sizing: border-box;
        position: absolute;
        left: 50%;
		transform: translateX(-50%);
        width: 20px;
        height: 3px;
        background-color: #1a1a1a;
        border-radius: 3px;
    }
    .menu-trigger.current{
    }
    .menu-trigger.current span{
		background: #1a1a1a;
    }

    .menu-trigger span:nth-of-type(1) {
        top: 10px;
    }
    .menu-trigger span:nth-of-type(2) {
        top: 18px;
    }
    .menu-trigger span:nth-of-type(3) {
        top: 26px;
    }
	
    /*動き*/
    .menu-trigger.current span:nth-of-type(1) {
        transform: translate(-50%, 8px) rotate(-45deg);
    }
    .menu-trigger.current span:nth-of-type(2) {
        left: 50%;
        opacity: 0;
        animation: active-menu-bar02 .8s forwards;
    }
    .menu-trigger.current span:nth-of-type(3) {
        transform: translate(-50%, -8px) rotate(45deg);
    }
	.headerBtn{
		display: flex;
		margin: 0 auto 20px;
		position: relative;
		justify-content: center;
		align-items: center;
        font-size: 1.6rem;
        font-weight: 500;
		width: 220px;
		height: 60px;
		background: #fff;
		text-align: center;
		border-radius: 16px;
		box-sizing: border-box;
	}

    #goTop{
        width: 40px;
        height: 40px;
        position: fixed;
        right: 0;
        bottom: 30px;
        z-index: 100;
    }
    .goTopBtn{
        display: block;
        width:40px;
        height: 40px;
        background: #5f503c;
    }
    .goTopBtn:hover{
        opacity: 0.8;
    }
    .goTopBtn img{
        width: 100%;
        height: auto;
    }
    #gMap{
        width: 100%;
        height: 300px;
    }
    #gMap iframe{
        width: 100%;
        height: 300px;
    }

    /*Footer*/

	footer {
		background: #f7f7f7;
	}
    .footerWrap{
        width: 100%;
        margin: 0 auto;
        padding: 55px 0 50px;
		box-sizing: border-box;
		display: block !important;
		text-align: center;
    }
	.footerLogo{
		width: 226px;
		display: inline-block;
		margin-bottom: 20px;
	}
    .footerNameW {
        text-align: center;
        width: 100%;
        display: block;
        margin-bottom: 20px;
    }
	.footerNameEn{
		font-size: 1.4rem;
		margin-bottom: 10px;
	}
	.footerName{
		font-size: 1.4rem;
	}
    .footerTel {
        width: 44px;
        position: relative;
        right: 0;
    }
	
	.footerInfo{
        width: 90%;
        margin: 0 auto 45px;
		text-align: center;
		display: block !important;
	}
	.footerInfoL{
		width: 100%;
		margin-bottom: 30px;
	}
	.footerTtl{
		letter-spacing: 0.2em;
	}
	.footerInfoR{
		text-align: left;
		width: 100%;
	}
	.footerInfo1W{
		display: block !important;
	}
	.footerInfo01{
		width: 100%;
		border-bottom: 1px solid rgba(26,26,26,0.4);
		margin-bottom: 15px;
		padding-bottom: 15px;
	}
	.footerinfoName{
		font-size: 1.7rem;
		font-weight: bold;
	}
	.footerInfoAdd{
		font-weight: 500;
	}
	.footerInfo02{
		width: 100%;
		border-bottom: 1px solid rgba(26,26,26,0.4);
		margin-bottom: 15px;
		padding-bottom: 15px;
	}
	.footerInfo2W{
		display: block !important;
	}

    .copyright{
		width: 100%;
        text-align: center;
		line-height: 3.4rem;
        color: #fff;
		background: #1a1a1a;
    }

/*commonタイトル*/
	.commonTtl01En{
		font-size: 2.8rem;
		font-weight: bold;
		color: #dee0e1;
	}
	.commonTtl01{
		font-size: 1.4rem;
		font-weight: 500;
		background: #1a1a1a;
		color: #fff;
		border-radius: 4px;
		line-height: 3rem;
		display: inline-block;
		padding: 0 15px;
	}
	.commonTtl02{
		font-size: 2.4rem;
		background: #f2f2f2;
		line-height: 6rem;
		padding-left: 15px;
	}
	.commonTtl03En{
		font-size: 2.8rem;
		font-weight: bold;
		color: #dee0e1;
	}
	.commonTtl03{
		font-size: 1.4rem;
		font-weight: 500;
		background: #1a1a1a;
		color: #fff;
		border-radius: 4px;
		line-height: 3rem;
		display: inline-block;
		padding: 0 15px;
	}
	.commonTtl04{
		font-size: 2.2rem;
	}

	
/*commonテキスト*/
	.commonTxt01{
		font-size: 1.4rem;
		line-height: 3.1rem;
	}
	.commonTxt02{
		font-size: 1.4rem;
		line-height: 3.4rem;
		font-weight: 500;
	}

/*commonボタン*/


}


/*ハンバーガーメニュー動き*/

@-webkit-keyframes active-menu-bar02 {
  100% {
    height: 0;
  }
}
@keyframes active-menu-bar02 {
  100% {
    height: 0;
  }
}
