@charset "utf-8";
/* CSS Document */

.all {
	overflow: hidden;
}

body {
  margin: 0;
  width: 100%;
  padding: 0;
  font-size: 16px;
  line-height: 45px;
  letter-spacing: 0;
  font-family: "游ゴシック""ヒラギノ";
  color: #333;
  background-color: white;
}
.container {
  width: 940px;
  margin-right: auto;
  margin-left: auto;
}
body header {
  display: flex;
  justify-content: space-between;
  height: 80px;
  margin: 0 auto;
  width: 940px;
  padding-top: 15px;
}
@media (max-width: 750px) {
  .sp-non {
    display: none;
  }
}

 .pc-non {
    display: none;
  }

@media (max-width: 750px) {
  .pc-non {
    display: inline-block;
  }
}


@media (max-width: 750px) {
  .container {
    width: 100%;
    padding-right: 30px;
    padding-left: 30px;
    margin-right: auto;
    margin-left: auto;
	 box-sizing: border-box;
  }
	body {
		font-size: 2.133333328vw;
	}
  body header {
    height: auto;
    margin: 0 auto;
    width: 100%;
    padding-top: 10px;
	  box-sizing: border-box;
  }
}


.header-left {
  font-size: 19px;
  font-weight: lighter;
}
.header-left span {
  font-size: 24px;
  font-weight: bold;
}
.header-btn a {
	position: fixed;
  display: block;
  box-sizing: border-box;
  width: 187px;
  height: 48px;
  padding: 18px 40px;
  font-size: 14px;
  text-decoration: none;
  background-color: #ED635E;
  color: white;
	padding-bottom: 3px;
  border-radius: 8px;
	border-bottom: 5px solid #EA544F;
  box-shadow: 0 0 8px #ED635E;
	z-index: 10;
}
.header-btn a:hover {
	-webkit-transform: translateY(4px);
  transform: translateY(2px);/*下に動く*/
  box-shadow: 0px 0px 8px #ED635E;/*影を小さく*/
  border-bottom: 2px solid  #EC5B56;
}


@media (max-width: 750px) {
	header {
		width: 100%;
		display: flex;
		justify-content: space-between;
	}
	.header-right{
		width: 50%;
			
	}
	

  .header-btn a {
	  text-align: center;
	  
	 width: 30vw;
	 margin-right: 0;
    height: auto;
	   padding: 0;
	  line-height: 320%;
	box-sizing: border-box;
    font-size: 0.65vw;
    border-radius: 4px;
    box-shadow: 0 0 8px #ED635E;

  }
	.header-left {
	width: 100%;
  margin-left: 10px;
  font-size: 4.8vw;
  font-weight: lighter;
}
.header-left span {
  font-size: 6vw;
  font-weight: bold;
}
}


.top-wrapper {
  width: 100%;
  margin: 0 20px;
  margin-top: 40px;
}
.top-wrapper .container {
  display: flex;
}


@media (max-width: 750px) {
  .top-wrapper {
    margin: 0;
  }
  .top-wrapper .container {
    display: flex;
    flex-direction: column-reverse;
  }
}


.top-wrapper .top-left {
  width: 360px;
  margin-top: 130px;
}

@media (max-width: 750px) {
  .top-wrapper .top-left {
    width: 100%;
    margin-top: 7%;
    padding-left: 10px;
    padding-right: 10px;
    box-sizing: border-box;
  }
}


.top-left h2 {
  font-size: 29px;
  font-weight: bolder;
  line-height: 50px;
  margin-bottom: 40px;
}
.sub-message {
  display: flex;
  flex-wrap: wrap;
  width: 350px;
  font-size: 14px;
}
.sub-message p {
  padding-bottom: 16px;
  line-height: 22px;
}
.check {
  width: 21px;
  height: 11px;
  padding-top: 3px;
  padding-right: 5px;
}


@media (max-width: 750px) {
  .top-left h2 {
    margin-bottom: 6%;
	  font-size: 1.6em;
	  line-height: 170%;
  }
  .sub-message p {
    padding-bottom: 15px;
    line-height: 137.5%;
  }
}




.top-right img {
  width: 545px;
  height: 385px;
  margin-top: 85px;
  z-index: 5;
  position: relative;
}
.top-img {
  position: relative;
}
.top-img::before {
  content: '';
  display: block;
  width: 160px;
  height: 144px;
  background-image: url("../images/1x/top-pattern1.png");
  position: absolute;
  top: 0;
  left: -40px;
}
.top-img::after {
  content: '';
  display: block;
  width: 473px;
  height: 415px;
  background-image: url("../images/1x/top-pattern2.png");
  position: absolute;
  top: 200px;
  right: -15px;
 z-index: -5;
}


@media (max-width: 750px) {
  .top-wrapper .top-right {
    margin: 0 auto;
  }
  .top-right img {
    max-width: 100%;
    height: auto;
    margin-top: 10%;
  }
  .top-img::before {
    width: 30%;
    height: 30%;
    background-image: url("../images/1x/top-pattern1.png");
    background-size: 100% auto;
    background-repeat: no-repeat;
    position: absolute;
    top: 30px;
    left: -30px;
  }
	
  .top-img::after {
    width: 75%;
    height: 75%;
    background-image: url("../images/1x/top-pattern2.png");
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    top: 120px;
    right: -50px;
  }
}


.top-btn a {
  display: block;
  box-sizing: border-box;
  width: 226px;
  height: 58px;
  padding: 23px 54px;
  font-size: 16px;
  text-decoration: none;
  background-color: #316CFF;
  color: white;
  border-radius: 8px;
  box-shadow: 0 0 10px #316CFF;
	border-bottom: solid 5px #2160FF;
}

.top-btn a:hover {
	-webkit-transform: translateY(4px);
  transform: translateY(2px);/*下に動く*/
  box-shadow: 0px 0px 8px #316CFF;/*影を小さく*/
  border-bottom: 2px solid  #2160FF;
}


@media (max-width: 750px) {
  .top-btn {
    width: 100%;
    margin: 0 auto;
	  margin-top: 4vw;
  }
  .top-btn a {
    width: 58%;
    text-align: center;
    padding: 0;
	  height: auto;
    border-radius: 7px;
    margin: 0 auto;
	 line-height: 410%;
    font-size: 3.4vw;
	  box-sizing: border-box;
  }
}


.about-wrapper {
  padding-top: 150px;
  width: 100%;
  margin-bottom: 100px;
}
@media (max-width: 750px) {
  .about-wrapper {
    padding-top: 18%;
    margin-bottom: 6.66666vw;
  }
}
.line {
  width: 50px;
}
.heading p {
  font-size: 32px;
  color: #E6E6E6;
  margin-bottom: 18px;
}
.heading h2 {
  font-size: 31px;
  margin-bottom: 50px;
}
@media (max-width: 750px) {
  .heading p {
    font-size: 1.5em;
    color: #E6E6E6;
    margin-bottom: 1.333vw;
  }
  .heading h2 {
    font-size: 1.5em;
    margin-bottom: 4.6666vw;
  }
}
.about-features {
  height: 440px;
  margin-left: 50px;
  display: flex;
}
@media (max-width: 750px) {
  .about-features {
	display: block;
    width: 80%;
	   height: auto;
    margin: 0 auto;
	padding: 4% 0;
	box-sizing: border-box;
    margin-top: 5vw;
    justify-content: center;
  }
}


.round {
  display: table;
  width: 144px;
  height: 144px;
  background-color: #F0F1F2;
  border-radius: 50%;
  margin: 0 auto;
  margin-top: 20px;
  margin-bottom: 30px;
  position: relative;
  overflow: hidden;
}
.round img {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}
.round-inner {
  display: table-cell;
  vertical-align: middle;
  text-align: center;
}
.round-about {
  display: table;
  width: 144px;
  height: 144px;
  background-color: #F0F1F2;
  border-radius: 50%;
  margin: 0 auto;
  margin-top: 20px;
  margin-bottom: 30px;
  position: relative;
  overflow: hidden;
}
.round-about img {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}
.round-inner-about {
  display: table-cell;
  vertical-align: middle;
  text-align: center;
}
@media (max-width: 750px) {
  .round {
    display: table;
    width: 130px;
    height: 130px;
    background-color: #F0F1F2;
    border-radius: 50%;
    margin: 0 auto;
    margin-top: 5px;
    margin-bottom: 30px;
    position: relative;
    overflow: hidden;
  }
  .round img {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
  }
  .round-inner {
    display: table-cell;
    vertical-align: middle;
    text-align: center;
  }
}
.about-features .f-list {
  width: 176px;
  height: 254px;
  background-color: #F9F9F9;
  border-radius: 8px;
  margin-left: 70px;
  box-shadow: 0 0 10px #B5B5B5;
}
.a-feature1 img {
  display: block;
  width: 130px;
  height: 130px;
  margin: 0 auto;
}
.a-feature2 img {
  display: block;
  width: 140px;
  height: 140px;
  margin-left: 18px;
}
.a-feature3 img {
  display: block;
  width: 120px;
  height: 120px;
  margin: 0 auto;
}
.about-features .f-list p {
  display: block;
  margin-top: 10px;
  font-size: 20px;
  text-align: center;
}
.a-feature1 {
  margin-top: 128px;
  margin-left: 140px;
}
.a-feature2 {
  margin-top: 60px;
}
.a-feature3 {
  margin-top: 128px;
}
@media (max-width: 750px) {
	

  .about-features .f-list {
    width: 76%;
    height: auto;
    margin: 0 auto;
	 box-sizing: border-box;
	  padding-top: 2px;
	  padding-bottom: 3.6vw;
	  margin-bottom: 4.5vw;
  }
  .a-feature1 {
    margin-top: 0;
    margin-left: 0;
  }
  .a-feature2 {
    margin-top: 0;
  }
  .a-feature3 {
    margin-top: 0;
  }
  .about-features .f-list p {
    display: block;
    margin-top: 0;
    font-size: 19px;
    text-align: center;
  }
  .round {
    margin-bottom: 2.2vw;
  }
}



.about-wrapper h3 {
  font-size: 31px;
  font-weight: normal;
  text-align: center;
  margin-top: 26px;
  letter-spacing: 1.5px;
}
.about-wrapper h3 span {
  display: inline-block;
  font-size: 39px;
  height: 2em;
  font-weight: bold;
  padding-right: 10px;
  margin-right: 5px;
  position: relative;
}
.about-wrapper h3 span::before {
  content: '';
  width: 100%;
  height: 30px;
  display: block;
  position: absolute;
  left: 0;
  bottom: 38px;
  mix-blend-mode: multiply;
  background-color: #FBE0E0;
}
@media (max-width: 750px) {
  .about-wrapper h3 {
    font-size: 1.3em;
    margin-top: 2vw;
  }
  .about-wrapper h3 span {
    font-size: 1.8em;
    height: 2em;
    font-weight: bold;
    letter-spacing: 4px;
    padding-bottom: 2px;
    padding-right: 5px;
  }
  .about-wrapper h3 span::before {
    height: 32px;
    bottom: 30px;
  }
}
.about2-wrapper {
  margin-bottom: 150px;
}
.about2-wrapper img {
  width: 492px;
  height: 346px;
  border-radius: 20px;
  margin-top: 40px;
}
.about-second {
  background-color: #E1EAFF;
  padding: 25px 15px;
  margin-bottom: 50px;
  align-items: center;
}
.about-second .container {
  display: flex;
}

.a-sentence {
  margin-left: 40px;
}
.a-sentence .impotant-line span {
  font-size: 28px;
  padding: 0 2px;
}
@media (max-width: 750px) {
  .about2-wrapper {
	  margin-top: 10vw;
    margin-bottom: 3vw;
  }
  .about2-wrapper img {
    width: 100%;
    height: auto;
    
    margin-left: 0;
  }
  .about-second {
    padding: 0;
    padding-bottom: 12.6vw;
    padding-top: 11vw;
    margin-bottom: 9.3vw;
  }
  .about-second .container {
    flex-direction: column;
    align-items: center;
    margin: 0 auto;
  
  }
}


.about-second h2 {
	font-size: 40px;
	padding-left: 8px;
	margin: 25px 0;
	background: linear-gradient(transparent 20%, #B5CEFF 20%);
	display: table;
}
.about-second p {
  line-height: 35px;
}
.impotant-line {
  height: 177px;
  width: 100%;
  background-image: url("../images/1x/about-pattern1.png");
  background-repeat: no-repeat;
}
.impotant-line h3 {
  padding: 50px 0;
  font-size: 22px;
  font-weight: normal;
  line-height: 40px;
}
.a-sentence, .a-sentence2 {
  margin: 0 15px;
  width: 390px;
}
@media (max-width: 750px) {
  .impotant-line {
	  margin: 0 auto;
    height: auto;
    width: 90%;
    background-image: url("../images/1x/about-pattern1.png");
    background-repeat: no-repeat;
    background-size: 280px 170px;
    margin-top:  2.6vw ;
	  margin-bottom: 2.6vw;
  }
  .impotant-line h3 {
    padding: 14vw 0;
    font-size: 1.2em;
    font-weight: normal;
    line-height: 181%;
  }
  .a-sentence, .a-sentence2 {
    text-align: center;
	  margin: 0; 
	  width: 100%;
  }
	
  .about-second h2 {
    margin: 0 auto;
    text-align: center;
    font-size: 2.375em;
    margin-top: 10px;
    margin-bottom: 25px;
  }
}
.about-third {
  background-color: #F5F5F5;
  padding: 20px 15px;
}
.about-third .container {
  display: flex;
}


.about-third h2 {
	padding-left: 5px;
	font-size: 40px;
	margin: 25px 0;
	background: linear-gradient(transparent 20%, #CCCCCC 20%);
	display: table;
}
.about-third h3 {
  font-size: 25px;
  font-weight: lighter;
  padding-bottom: 40px;
}
.about-third img {
  margin-right: 20px;
}
.impotant-line2 {
  height: 280px;
  background-image: url("../images/1x/about-pattern2.png");
  background-repeat: no-repeat;
  padding-top: 30px;
  line-height: 35px
}
	  
@media (max-width: 750px) {
  .about-third {
    background-color: #F5F5F5;
    padding: 0;
    padding-bottom: 12.6vw;
    padding-top: 12.6vw;
    margin-bottom: 10.666vw;
	text-align: center;
  }
  .about-third .container {
    display: flex;
	 width: 100%;
	     margin: 0 auto;
	  height: auto;
    flex-direction: column-reverse;
    align-content: center;
 
 
	
}
}



@media (max-width: 750px) {
  .a-sentence2 h2 {
    margin: 0 auto;
    padding: 0;
    font-size: 2.5em;
	
    margin-top: 25px;
    margin-bottom: 25px;
    background: linear-gradient(transparent 20%, #CCCCCC 20%);
    text-align: center;
  }
	
	.about-third h2 {
		text-align: center;
  padding: 0;
  font-size: 2.5em;
}

.about-third img {
  margin:0;
	margin-top: 40px;
}
	.impotant-line2 {
		width: 100%;
  height: auto;
  background-image: url("../images/1x/about-pattern2.png");
  background-repeat: no-repeat;
		background-position: center center;
  padding-top: 30px;
  line-height: 250%;
		margin: 0 auto;
		align-content: center;
}
	.about-third h3 {
  font-size: 1.562em;
  font-weight: lighter;
  padding-bottom: 30px;
}
	
}


.freetrial-wrapper {
  width: 888px;
  border: solid 4px #EFF6FF;
  border-radius: 30px;
  margin: 0 auto;
  padding-top: 60px;
  padding-bottom: 30px;
  margin-bottom: 150px;
  text-align: center;
}
.freetrial-wrapper .container {
  margin: 0 auto;
  width: 888px;
}
@media (max-width: 750px) {
  .freetrial-wrapper {
    width: 90%;
    border: solid 4px #EFF6FF;
    border-radius: 30px;
    margin: 0 auto;
    padding-top: 4%;
    padding-bottom: 4%;
    margin-bottom: 9.66666vw;
    text-align: center;
  }
  .freetrial-wrapper .container {
    width: 100%;
	  padding: 0;
  }
}
.freetrial-first {
  margin: 30px;
  line-height: 34px;
  position: relative;
}

.f-before {
	position: relative;
}
.freetrial-first .f-before::before {
  content: '';
  display: block;
  width: 18px;
  height: 18px;
	background-repeat: no-repeat;
	background-size: contain;
  background-image: url("../images/2x/check@2x.png");
  position: absolute;
  top: 0.6em;
  left: 17.2em;

}
.freetrial-first img {
  position: absolute;
  left: 250px;
  top: 8px;
}
.freetrial-first .important {
  font-size: 13px;
}
.freetrial-middle {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 364px;
  margin: 0 auto;
  margin-bottom: 40px;
}
.freetrial-middle .freelist {
  padding-top: 10px;
  padding-bottom: 20px;
 width: 219px;
  height: 290px;
  border: solid 1px #D0CFCF;
  border-radius: 30px;
  box-shadow: 0 0 10px #CFCFCF;
}
.freetrial-wrapper h2 {
  width: 560px;
  margin: 0 auto;
  font-size: 35px;
  margin-bottom: 50px;
  background: linear-gradient(transparent 70%, #BFD1FC 70%);
  text-align: center;
}
.freetrial-wrapper .other {
  font-size: 13px;
}
@media (max-width: 750px) {
  .f-heading h2 {
    width: 88%;
    margin: 0 auto;
    font-size: 5vw;
	  margin-top: 20px;
    margin-bottom: 20px;
    background: linear-gradient(transparent 70%, #BFD1FC 70%);
    text-align: center;
  }
  .freetrial-first {
  font-size: 0.875em;
  line-height: 200%;
 
}
	
	
  .freetrial-first img {
    position: absolute;
    left: 8px;
    top: 8px;
  }
  .freetrial-first .important {
    font-size: 0.8125em;
  }
  .freetrial-middle {
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: auto;
    margin: 0 auto;
    margin-bottom: 6vw;
  }
  .freetrial-middle .freelist {
    display: block;
    width: 80%;
    height: auto;
    border-radius: 20px;
	    margin-bottom: 6vw;
    
  }
  .freetrial-wrapper .other {
    font-size: 0.56em;
  }
	.freetrial-first .f-before::before {
  content: '';
  display: block;
  width: 18px;
  height: 18px;
	background-repeat: no-repeat;
	background-size: contain;
  background-image: url("../images/2x/check@2x.png");
  position: absolute;
  top: 0.6em;
  left: 1em;
	}
}
.free-btn a {
  display: block;
  margin: 0 auto;
  margin-top: 40px;
  margin-bottom: 40px;
  width: 226px;
  height: 58px;
  background-color: #316CFF;
  border-radius: 8px;
  box-shadow: 0 0 8px #316CFF;
  box-sizing: border-box;
  padding: 22px 0;
  color: white;
  text-decoration: none;
  align-items: center;
	border-bottom: solid 5px #2160FF;
}


.free-btn a:hover {
	-webkit-transform: translateY(4px);
  transform: translateY(2px);/*下に動く*/
  box-shadow: 0px 0px 8px #316CFF;/*影を小さく*/
  border-bottom: 2px solid  #2160FF;
}


.freelist img {
  width: 120px;
  height: 120px;
}
.freelist p {
  font-size: 14px;
  line-height: 24px;
	
}
.freelist, .step3 .half-price {
  font-size: 16px;
  margin-top: 10px;
  font-weight: lighter;
}
.free-list, .step2 {
  margin: 0 25px;
}
@media (max-width: 750px) {
  .free-btn a {
    font-size: 0.625em;
    margin-top: 20px;
    margin-bottom: 20px;
    width: 46%;
    height: auto;
	  line-height: 420%;
    border-radius: 8px;
    padding: 0;
  }
  .freelist {
    padding-top: 24px;
	  padding-bottom: 15px;
	  margin-bottom: 6vw;
  }
  .list-first {
    display: block;
  }
  .list-first h3 {
    font-size: 0.8125em;
	  margin-bottom: 10px;
  }
  .freelist img {
    width: 100%;
    height: auto;
  }
  .freelist p {
    margin: 20px 20px;
    font-size: 0.9em;
    line-height: 24px;
  }
  .freelist .step3 .half-price {
    font-size: 3vw;
    margin-top: 0;
	  padding-bottom: 10px;
    font-weight: lighter;
  }
  .free-list, .step2 {
    margin: 0;
  }
	.freelist, .step3 .half-price {
  margin-top: 0;
  
}
}
.telephone {
  display: flex;
  margin: 0 auto;
  width: 300px;
	margin-right: 274px;
}
.telephone img {
  width: 58px;
  height: 58px;
  margin-top: -15px;
}
.telephone h3 {
  font-size: 26px;
  font-weight: lighter;
}
@media (max-width: 750px) {
  .telephone {
    display: flex;
    margin: 0 auto;
	  padding-left: 15px;
	  box-sizing: border-box;
    width: 60%;
  }
  .telephone img {
    width: 20%;
    height: auto;
    margin-top:-10px;
  }
  .telephone h3 {
    font-size: 1.18em;
    font-weight: lighter;
  }
}
.features-wrapper {
  margin: 0 auto;
  margin-bottom: 150px;
}
.features-wrapper .heading h3 {
  font-size: 46px;
  padding: 0 8px;
}
.features-list .f-list {
  display: flex;
}

.features-list {
  margin-top: 60px;
}
.features-list img {
  margin-top: 15px;
  height: 261px;
  width: 398px;
  border-radius: 40px;
}

@media (max-width: 750px) {
	.features-wrapper {
	margin-bottom: 12.66666vw;
}
.features-wrapper .heading span {
  font-size: 1.6875em;
  margin-left: -5px;

}
	.features-wrapper .heading {
		margin-left: 0;
		line-height: 260%;
	}
.features-list .f-list {
  flex-direction: column;
  width: 100%;
  margin: 0 auto;
  margin-bottom: 6.666%;
}

.features-list { 
  margin: 0 auto;
  margin-top: 6.666%;
}
.features-list img {
	margin: 0 auto;
  margin-top: 5px;
  height: auto;
  width: 100%;
  border-radius: 30px;
  margin-bottom: 20px;
}
}

.f-contents {
	
  width: 470px;
  height: 320px;
  margin-left: 30px;
}
.f-contents h3 {
	display: inline;
  font-size: 20px;
  margin-bottom: 15px;
}

.f-contents h2 {
	display: inline;
  font-size: 20px;
  margin-bottom: 15px;
}
.f-contents p {
  line-height: 37px;
}
.f-list h2 {
	display: inline;
  font-size: 83px;
  color: #CAD9FF;
  margin-right: 5px;
}

@media (max-width: 750px) {
	.f-contents {
  width: 100%;
  height: auto;
  margin-left: 0;
}
.f-contents h3 {
  font-size: 1.25em;
  margin-bottom: 14px;
	text-align: left;
}
	.f-contents h2 {
		display: inline;
  font-size: 1.85em;
  margin-bottom: 14px;
	text-align: left;
}

.f-contents p {
  line-height: 200%;
margin-top: 4.6666vw;

}
.f-list h2 {
  font-size: 2.8em;
	
}
	.contents2,.contents3 h2 {
		display: inline-block;
	
	}

	.contents2 h3 {
		display: inline-block;
		line-height: 134%;
	
	}
	.contents3 h3 {
		display: inline-block;
		line-height: 134%;
	}
}
.schedule-wrapper {
  margin-bottom: 150px;
}


	
.schedule-wrapper .s-contents {
  margin-top: 50px;
}
.schedule-wrapper .s-contents .important {
  margin-top: 20px;
  font-size: 14px;
  margin-left: 30px;
}
.schedule-wrapper .s-contents .s-info {
  position: relative;
  margin-left: 30px;
}
.schedule-wrapper .s-contents img {
  position: absolute;
left: 280px;
}

@media (max-width: 750px) {
	.schedule-wrapper {
  margin-bottom: 150px;
}

	.schedule-wrapper .container {
		margin: 0 auto;
	}

	
.schedule-wrapper .s-contents {
  margin-top: 10.6vw;
	margin-left: 0;
	margin-right: 0;
}
.schedule-wrapper .s-contents .important {
  margin-top: 4.8vw;
  font-size: 0.875em;
  margin-left: 0;
	
}
.schedule-wrapper .s-contents .s-info {
	padding-left: 20px;
	box-sizing: border-box;
 font-size: 0.875em;
  position: relative;
  margin-left: 0;
	line-height: 130%;
}
.schedule-wrapper .s-contents img {
  position: absolute;
	left: 30px;
}

}
.s-table {
  margin: 0 auto;
  margin-top: 50px;
  border-radius: 70px;
  overflow-x: hidden;
  overflow-y: hidden;
  width: 737px;
  height: 460px;
  
  margin-bottom: 30px;
	box-shadow: 5px 5px 10px #B9CDFF;
}
.s-table table {
  width: 737px;
  height: 460px;
  box-shadow: 4px 4px 10px #B9CDFF;
}

@media (max-width: 750px) {
	
	.s-table {
  margin-top: 30px;
  border-radius: 50px;
  overflow-x: hidden;
  overflow-y: hidden;
  width: 569px;
  height: 330px;
  padding: -1px;
  box-shadow: 4px 4px 10px #B9CDFF;
	
		
}
.s-table table {
  width: 569px;
  height: 328px;
	box-sizing: border-box;
  padding: 0 5px;
  box-shadow: 4px 4px 10px #B9CDFF;
	  font-size: 12px;
}
	
	.js-scrollable {
		padding: 10px;
	}
}
table tr:nth-child(odd) {
  background-color: #F2F2F2
}
table .date {
  background-color: #A3BEFF;
  color: white;
  font-weight: lighter;
  border: solid 1px #FFFFFF;
  vertical-align: middle;
}
table tr:nth-child(1) {
  background-color: #5A89FF;
  color: white;
  height: 65px;
}
table tr:nth-child(1) th {
  border: solid 1px white;
  font-weight: lighter;
  vertical-align: middle;
}
table td {
  border: solid 1px #C4C4C4;
  box-sizing: border-box;
  vertical-align: middle;
  text-align: center;
  font-size: 26px;
  color: #808080;
  width: 85px;
}
teble .vertical {
  text-align: center;
  width: 150px;
}

@media (max-width: 750px) {
table .date {
  background-color: #A3BEFF;
  color: white;
  font-weight: lighter;
  border: solid 1px #FFFFFF;
  vertical-align: middle;
font-size: 12px;
}
table tr:nth-child(1) {
  background-color: #5A89FF;
  color: white;
  height: 54px;
}
table tr:nth-child(1) th {
  border: solid 1px white;
  font-weight: lighter;
  vertical-align: middle;
}
	

table td {
  border: solid 1px #C4C4C4;
  box-sizing: border-box;
  vertical-align: middle;
  text-align: center;
  font-size: 17px;
  color: #808080;
  width: 70px;
}
teble .vertical {
  text-align: center;
 width: 94px;
	
}
}
	
/*========= waveを描画するエリア設定 ===============*/
.waves {
  position: relative;
  width: 100%;
  height: 15vh;
  margin-bottom: -7px; /*Fix for safari gap*/
  min-height: 100px;
  max-height: 150px;
}
.content {
  position: relative;
  height: 20vh;
  text-align: center;
  background-color: #C0D2FF;
}
/* Animation */
.parallax > use {
  animation: move-forever 25s cubic-bezier(.55, .5, .45, .5) infinite;
}
.parallax > use:nth-child(1) {
  animation-delay: -2s;
  animation-duration: 7s;
}
.parallax > use:nth-child(2) {
  animation-delay: -3s;
  animation-duration: 10s;
}
.parallax > use:nth-child(3) {
  animation-delay: -4s;
  animation-duration: 13s;
}
.parallax > use:nth-child(4) {
  animation-delay: -5s;
  animation-duration: 20s;
}
@keyframes move-forever {
  0% {
    transform: translate3d(-90px, 0, 0);
  }
  100% {
    transform: translate3d(85px, 0, 0);
  }
}
/*Shrinking for mobile*/
@media (max-width: 750px) {
  .waves {
    height: 40px;
    min-height: 40px;
  }
  .content {
    height: 30vh;
  }
  h1 {
    font-size: 24px;
  }
}
.waves2 {
  position: relative;
  width: 100%;
  height: 15vh;
  margin-bottom: -7px; /*Fix for safari gap*/
  min-height: 100px;
  max-height: 150px;
}
.content2 {
  position: relative;
  height: 20vh;
  text-align: center;
  background-color: #C0D2FF;
}
/* Animation */
.parallax2 > use {
  animation: move-forever2 25s cubic-bezier(.55, .5, .45, .5) infinite;
}
.parallax2 > use:nth-child(1) {
  animation-delay: -2s;
  animation-duration: 7s;
}
.parallax2 > use:nth-child(2) {
  animation-delay: -3s;
  animation-duration: 10s;
}
.parallax2 > use:nth-child(3) {
  animation-delay: -4s;
  animation-duration: 13s;
}
.parallax2 > use:nth-child(4) {
  animation-delay: -5s;
  animation-duration: 20s;
}
@keyframes move-forever2 {
  0% {
    transform: translate3d(90px, 0, 0);
  }
  100% {
    transform: translate3d(-85px, 0, 0);
  }
}
/*Shrinking for mobile*/
@media (max-width: 768px) {
  .waves {
    height: 40px;
    min-height: 40px;
  }
  .content {
    height: 30vh;
  }
  h1 {
    font-size: 24px;
  }
}
.lessons-wrapper {
  padding-top: 100px;
  background-color: #C0D2FF;
  padding-bottom: 10px;
}
.lessons-wrapper .heading {
  text-align: center;
  margin-top: 5px;
  padding-bottom: 50px;
}
.lessons-wrapper .heading p {
  color: white;
}
.lessons-container {
  background-color: #C0D2FF;
  margin-bottom: 150px;
  padding: 10px 100px;
}

@media (max-width: 750px) {
 .lessons-wrapper {

  padding-top: 50px;
  background-color: #C0D2FF;
  padding-bottom: 10px;
}
.lessons-wrapper .heading {
  text-align: center;
  margin-top: 5px;
  padding-bottom: 0;
}
.lessons-wrapper .heading p {
  color: white;
}
.lessons-container {
  width: 100%;
  background-color: #C0D2FF;
  margin: 0 auto;
  margin-bottom: 6.7vw;
  padding: 10px 0;
}
}


.lessons-wrapper .lessons {
  display: flex;
  width: 888px;
  margin: 0 auto;
  flex-wrap: wrap;
  margin-top: 50px;
}
.lessons .l-list {
  width: 275px;
  margin: 0 auto;
  height: 386px;
  background-color: white;
  margin-right: 20px;
  border-radius: 20px;
  margin-bottom: 50px;
  text-align: center;
}

@media (max-width: 750px) {
	.lessons-wrapper .lessons {
  display: block;
  width: 100%;
  margin: 0 auto;
  flex-wrap: wrap;
  margin-top: 50px;
}
.lessons .l-list {
  width: 100%;
  margin: 0 auto;
  height: auto;
  background-color: white;
  margin-right: 0;
  border-radius: 15px;
	padding-top: 4vw;
	padding-bottom: 5vw;
  margin-bottom: 30px;
  text-align: center;
}
}
.l-list img {
  width: 104px;
  height: 104px;
  margin-bottom: 10px;
}
.l-list, .lesson2 img {
  width: 104px;
  height: 104px;
}
.l-list h3 {
  font-size: 20px;
  margin: 30px 0;
}
.l-list p {
  font-size: 14px;
  line-height: 22px;
}

@media (max-width: 750px) {
	.l-list .icon-background {
		margin-top: 0;
	}
	.l-list p {
  font-size: 14px;
  line-height: 190%;
}
	.l-list h3 {
  font-size: 20px;
  margin:0;
		margin-top: 5vw;
		margin-bottom: 4vw;
}
}
.message-wrapper {
  margin-top: 150px;
  margin-bottom: 150px;	
}
@media (max-width: 750px) {
	.message-wrapper {
  margin-top: 0;
  margin-bottom: 0;	
}
	.message-wrapper .container {
	width: 100%;
	margin: 0 auto;
  margin-top: 30px;
  margin-bottom: 10px;
}
}
.message-wrapper .m-top {
  display: flex;
  height: 640px;
  position: relative;
}
.m-top .m-top-copy {
  width: 580px;
  height: 560px;
  background-image: url("../images/2x/middle-pattern1@2x.png");
  background-size: contain;
  background-repeat: no-repeat;
}
.m-top-copy .copy-1 {
  background: linear-gradient(transparent 75%, #F5B9B8 75%);
}
.m-top-copy .copy-2 {
  background: linear-gradient(transparent 30%, #F5B9B8 30%)
}
.m-top h2 {
  text-align: center;
  font-size: 29px;
  line-height: 55px;
  margin-top: 180px;
  margin-left: 60px;
}
.m-top img {
  position: absolute;
  left: 526px;
  top: 100px;
  width: 268px;
  height: 363px;
}

@media (max-width: 750px) {
  .message-wrapper .m-top {
	 width: 100%;
	  margin: 0 auto;
  display: flex;
  flex-direction: column;
  height: auto;
  position: relative;
	  padding: 0 0;
	  box-sizing: border-box;
	  margin-left: 0;
	  margin-right: 0;
}
.m-top .m-top-copy {
  width: 100%;
	margin: 0 auto;
  height: auto;
	padding-bottom: 19vw;
	padding-top: 10vw;
  background-image: url("../images/2x/middle-pattern1@2x.png");
	background-size: 100% auto;
	background-size: contain;
  
  background-repeat: no-repeat;
}
.m-top-copy .copy-1 {
  background: linear-gradient(transparent 80%, #F5B9B8 80%);
}
.m-top-copy .copy-2 {
  background: linear-gradient(transparent 30%, #F5B9B8 30%)
}
.m-top h2 {
  text-align: center;
  font-size: 5.5vw;
  line-height: 200%;
  margin-top: 6vw;
  margin-left: 0;
}
.m-top img {
width: 50vw;
	margin: 0 auto;
  position: relative;
  left: 0;
  top: 0;
	margin-top: -8vw;
  padding-top: 0;
  height: auto;
}
}
.m-middle {
  margin-bottom: 20vw;
	
}
.m-middle .m-middle-sentence {
  height: 230px;
  margin-left: 60px;
}
.m-middle-sentence h2 {
  font-size: 35px;
  margin-bottom: 12px;
}
.m-middle-sentence p {
  line-height: 32px;
}

@media (max-width: 750px) {
	.m-middle {
	margin-top: 15vw;
}
.m-middle .m-middle-sentence {

  height: auto;
  margin:0 auto;
}
.m-middle-sentence h2 {
  font-size: 2.1875em;
	text-align: center;
  margin-bottom: 18px;
}
.m-middle-sentence p {
  line-height: 180%;
	text-align: center;
}
}
.m-middle2 {
  display: flex;
	
}
.message-wrapper .line2 {
  width: 102px;
  height: 20px;
  margin: 200px 16px 200px 20px;
}
.m-m-background1 {
  width: 346px;
  height: 337px;
  background-image: url("../images/2x/middle-pattern2-1@2x.png");
  background-size: contain;
  background-repeat: no-repeat;
  position: relative;
}
.m-m-background1 img {
  height: 285px;
  width: 222px;
  margin: 0 auto;
  position: absolute;
  top: 28px;
  left: 77px;
}
.m-m-background2 {
  width: 415px;
  height: 363px;
  background-image: url("../images/2x/middle-pattern2-2@2x.png");
  background-size: contain;
  background-repeat: no-repeat;
  position: relative;
}
.m-m-background2 img {
  height: 277px;
  width: 216px;
  margin: 0 auto;
  position: absolute;
  top: 30px;
  left: 100px;
}

@media (max-width: 750px) {
	.m-middle2 {
		width: 100%;
		margin:	0 auto;
  display: block;
		margin-left: 0;
		margin-right: 0;
}

.m-m-background1 {
	
	width: 100%;
	height: auto;
  background-image: url("../images/2x/middle-pattern2-1@2x.png");
  background-size: contain;
  background-repeat: no-repeat;
	margin-top: 3vw;
  position: relative;
}
.m-m-background1 img {
  height: 44.1%;
  width: 36.5%;
  margin: 0 auto;
  position:relative;
	margin-left: 10vw;
  top: 0;
  left: 0;
}
.m-m-background2 {
	width: 100%;
	margin-left: 28vw;
		margin-top: 3vw;
   height: auto;
  background-image: url("../images/2x/middle-pattern2-2@2x.png");
  background-size: contain;
  background-repeat: no-repeat;
  position: relative;
	
}
.m-m-background2 img {
 
  height: 46.9%;
  width: 48.8%;

  margin: 0 auto;
  margin-left: 10vw;
  position: relative;
  top: 0;
  left: 0;
}

}
.m-bottom {
  margin-top: 60px;
}
.m-bottom-sentence {
  height: 110px;
  margin-left: 60px;
}
.m-bottom-sentence h2 {
  font-size: 35px;
  margin-bottom: 12px;
  font-weight: lighter;
  line-height: 50px;
}
.m-bottom-sentence span {
  font-weight: bold;
  margin-right: 26px;
}
.m-bottom-sentence p {
  line-height: 32px;
}
.m-bottom2 {
  display: flex;
  margin-top: 100px;
}
.m-b-background1 {
  width: 381px;
  height: 367px;
  background-image: url("../images/2x/middle-pattern3-1@2x.png");
  background-size: contain;
  background-repeat: no-repeat;
  position: relative;
}
.m-b-background1 img {
  height: 322px;
  width: 350px;
  margin: 0 auto;
  position: absolute;
  top: -30px;
  left: 30px;
}
.m-b-background2 {
  width: 405px;
  height: 418px;
  background-image: url("../images/2x/middle-pattern3-2@2x.png");
  background-size: contain;
  background-repeat: no-repeat;
  position: relative;
}
.m-b-background2 img {
  height: 253px;
  width: 378px;
  margin: 0 auto;
  position: absolute;
  top: 34px;
  left: -20px;
}

@media (max-width: 750px) {
	.m-bottom {
  margin-top: 20%;
		
}
.m-bottom-sentence {
  height: auto;
  margin:0 auto;
}
.m-bottom-sentence h2 {
  font-size: 1.125em;
	margin-bottom: 0;
  font-weight: lighter;
  line-height: 200%;
text-align: center;
}
.m-bottom-sentence span {
	font-size: 2.1875em;
  font-weight: bold;
  margin-right: 0;
}
.m-bottom-sentence p {
  line-height: 180%;
	text-align: center;
}
.m-bottom2 {
  display: block;
	 margin-top: 10vw;
		position: relative;
		margin-left: 0;
		margin-right: 0;
}
	



.m-b-background1 {
  width: 100%;
  height: auto;
  background-image: url("../images/2x/middle-pattern3-1@2x.png");
  background-size: contain;
  background-repeat: no-repeat;
  position: relative;
}
	
.m-b-background1 img {
  height: 52.9%;
  width: 56.6%;
  margin: 0 auto;
  position: relative;
	margin-left: 0;
  top: 0;
  left: 0;
}
	
.m-b-background2 {
	margin-top: 3vw;
  width: 100%;
  height: auto;
  background-image: url("../images/2x/middle-pattern3-2@2x.png");
	margin-left: 23vw;
  background-size: contain;
  background-repeat: no-repeat;
  position: relative;
	padding-bottom: 5%;
}
	
.m-b-background2 img {
	text-align: center;
  height:  68.7%;
  width: 85.4%;
  margin: 0 auto;
  position: relative;
  top: 0;
  left: 0;
	margin-left: -50px;
	box-sizing: border-box;
	

}
}


.q-and-a-wrapper {
  margin-bottom: 150px;
}
input[type=radio] {
  display: none;
}
@media (max-width: 750px) {
	.q-and-a-wrapper {
  margin-bottom: 100px;
		
}
	.q-and-a-wrapper .container {
		width: 100%;
		margin: 0 auto;
	}
input[type=radio] {
  display: none;
}
}
.acd-label {
  display: block;
  color: #333;
  width: 860px;
  height: 127px;
  padding: 48px 0;
  margin-top: 30px;
  border-radius: 30px;
  background-color: white;
  font-size: 20px;
  box-shadow: 0 0 8px #B5B5B5;
  padding-left: 40px;
  position: relative;
}
.acd-label span {
  font-size: 33px;
  margin-right: 10px;
}
.acd-content {
  width: 860px;
  display: flex;
  color: white;
  background-color: #729BFF;
  font-size: 18px;
  border-radius: 0 0 30px 30px;
  height: 0;
  opacity: 0;
  transition: .5s;
  visibility: hidden;
}
@media (max-width: 750px) {
	.acd-label {
	margin: 0 auto;
  display: block;
  color: #333;
  width: 100%;
  height: 24vw;
  padding-top:  10vw;
	padding-bottom: 4vw;
  margin-top: 1vw;
  border-radius: 15px;
  background-color: white;
  font-size: 0.9em;
  box-shadow: 0 0 14px #DADADA;
  padding-left: 4vw;
		padding-right: 3vw;
  position: relative;
		line-height: 150%;
}
.acd-label span {
  font-size: 1.4em;
  margin-right: 1vw;
}
.acd-content {
	margin: 0 auto;
  width: 100%;
  display: flex;
  color: white;
  background-color: #729BFF;
  font-size: 0.8em;
  border-radius: 0 0 20px 20px;
  height: 0;
  opacity: 0;
  transition: .5s;
  visibility: hidden;
	padding-bottom: 5.3vw;
	box-sizing: border-box;
	
}
}


input[type="radio"]:checked + .acd-label {
  /*ここでチェックが入った状態の質問をいじれる,
	下の角丸をとる、そして隙間を詰める*/
  background-color: #729BFF;
  color: white;
  border-radius: 20px 20px 0 0;
  box-shadow: 5px 0 5px -5px #B5B5B5;
}
.acd-label .minas {
  position: absolute;
  right: 50px;
  top: 30px;
  width: 63px;
  height: 63px;
  display: none;
  transition: .5s;
}
.acd-label .plus {
  position: absolute;
  right: 50px;
  top: 28px;
  width: 63px;
  height: 63px;
  display: inline-block;
  transition: .5s;
}
.acd-content span {
  font-size: 2.06em;
  margin-right: 10px;
}

@media (max-width: 750px) {
	input[type="radio"]:checked + .acd-label {
  /*ここでチェックが入った状態の質問をいじれる,
	下の角丸をとる、そして隙間を詰める*/
  background-color: #729BFF;
  color: white;
  border-radius: 20px 20px 0 0;
  box-shadow: 5px 0 5px -5px #B5B5B5;
}
.acd-label .minas {
  position: absolute;
  right: 3vw;
  top: 2.5vw;
  width: 8.3vw;
  height: 8.3vw;
  display: none;
  transition: .5s;
}
.acd-label .plus {
  position: absolute;
  right: 3vw;
  top: 2.5vw;
  width: 8.3vw;
  height: 8.3vw;
  display: inline-block;
  transition: .5s;
}
.acd-content span {
  font-size: 1.4em;
  margin-right: 1vw;
}
}
input[type="radio"]:checked + .acd-label .plus {
  display: none;
  transition: .5s;
}
input[type="radio"]:checked + .acd-label .minas {
  display: inline-block;
  transition: .5s;
}
input[type="radio"]:checked + .acd-label + .acd-content {
  display: flex;
  width: 860px;
  height: 127px;
  opacity: 1;
  visibility: visible;
  padding: 40px 40px;
  color: white;
  background-color: #729BFF;
  font-size: 18px;
  border-radius: 0 0 30px 30px;
  margin-bottom: 20px;
  line-height: 30px;
}
.q-and-a-wrapper .heading {
  margin-bottom: 50px;
  text-align: right;
}
.check-form span {
  font-size: 33px;
  margin-right: 10px;
}

@media (max-width: 750px) {
	input[type="radio"]:checked + .acd-label .plus {
  display: none;
  transition: .5s;
}
input[type="radio"]:checked + .acd-label .minas {
  display: inline-block;
  transition: .5s;
}
input[type="radio"]:checked + .acd-label + .acd-content {
  display: flex;
  width: 100%;
  height: auto;
  opacity: 1;
  visibility: visible;
  padding-top: 0;
	padding-bottom: 10.6vw;
  color: white;
  background-color: #729BFF;
  font-size: 0.875em;
  border-radius: 0 0 15px 15px;
  margin-bottom: 8vw;
  line-height: 150%;
}
.q-and-a-wrapper .heading {
  margin-bottom: 50px;
	padding: 0 20px;
	box-sizing: border-box;
	
  text-align: right;
}
.check-form span {
  font-size: 2.06em;
  margin-right: 10px;
}
}

.form-wrapper {
  background-color: #F5F5F5;
  padding: 50px 0;
}
.form-wrapper .container {
  width: 770px;
  margin: 0 auto;
  text-align: center;
}

@media (max-width: 750px) {
	.form-wrapper {
  background-color: #F5F5F5;
  padding: 40px 0;
}
.form-wrapper .container {
  width: 100%;
  margin: 0 auto;
  text-align: center;
	align-content: center;
}
}

.form-wrapper .heading p {
  color: white;
}
.form-wrapper .heading .please {
  color: #333333;
  font-size: 16px;
  margin-top: 50px;
}
.form {
  padding-top: 40px;
  padding-bottom: 40px;
  margin-left: -30px;
  width: 800px;
}
.form .formlist {
  display: flex;
  margin-bottom: 30px;
}
.form .f-title {
	justify-content: space-between;
	display: flex;
  width: 138px;
  text-align: end;
  font-size: 18px;
  padding-top: 20px;
  margin-right: 20px;
}
.formlist input {
  width: 591px;
  height: 53px;
  border-radius: 10px;
  border: solid 1px white;
}

@media (max-width: 750px) {
	
.form-wrapper .heading .please {
  font-size: 0.8em;
  margin-top: 10.6vw;
}
.form {
  padding-top: 20px;
  padding-bottom: 20px;
  margin-left: 0;
padding-left: 0;
	padding-right: 5px;
	box-sizing: border-box;
  width: 90.3vw;
}
.form .formlist {
  display: block;
  margin-bottom: 0;
}
.form .f-title {
  display: flex;
	justify-content: space-between;
	
	width: 31vw;
	margin: 0 auto;
	 padding-top: 0;
  
  font-size: 0.9em;
  margin-top: 3vw;
	margin-bottom: 2vw;
  
}
	
	
	
.formlist input {
  width: 80vw;
  height: 12vw;
  border-radius: 8px;
  border: solid 1px white;
}
}


p.must {
  font-size: 12px;
  background-color: #729BFF;
  border-radius: 8px;
  height: 36px;
  width: 62px;
  color: white;
  line-height: 36px;
  box-sizing: border-box;
	text-align: center;
	margin-top: -10px;
 	
}
.q-5 {
  padding-left: 0;
}
.q-5 select {
  width: 596px;
  height: 56px;
  border-radius: 10px;
  border: solid 1px white;
}
.q-6 {
  padding-left: 0;
}
.q-6 textarea {
  width: 588px;
  height: 276px;
  border-radius: 10px;
  border: white;
}
@media (max-width: 750px) {
	.f-title p {
		line-height: 7vw;
		margin-right: 1vw
	}
	p.must {
  font-size: 0.5625em;
  border-radius: 6px;
  height: 7vw;
  width: 14vw;
  text-align: center;
	line-height: 250%;
  box-sizing: border-box;
  margin:  0;
			margin-top: 0;
 	
}
	 
	.q-5 select {
  width: 79vw;
  height: 10vw;
  border-radius: 10px;
  border: solid 1px white;
}
	.q-5 {
  padding-left: 0;
}
.q-6 {
  padding-left: 0;

}
	
	.q-6 p {
		padding-left: 2em;
	}
.q-6 textarea {
  width: 79vw;
  height: 36.8vw;
  border-radius: 10px;
  border: white;
}
}
.form-btn {
  display: flex;
  justify-content: center;
}
.form-btn a {
  display: block;
  box-sizing: border-box;
  width: 188px;
  height: 48px;
  padding: 18px 70px;
  font-size: 16px;
  text-decoration: none;
  background-color: #316CFF;
  color: white;
  border-radius: 8px;
  box-shadow: 0 0 8px #316CFF;
  text-align: center;
	 border-bottom: 5px solid  #2160FF;
}

.form-btn a:hover {
	-webkit-transform: translateY(4px);
  transform: translateY(2px);/*下に動く*/
  box-shadow: 0px 0px 8px #316CFF;/*影を小さく*/
  border-bottom: 2px solid  #2160FF;
}

@media (max-width: 750px) {
	
.form-btn a {
  display: block;
  box-sizing: border-box;
  width: 142px;
  height: 36px;
  padding: 12px 56px;
  font-size: 14px;
  border-radius: 8px;
	vertical-align: middle;

}

}
.access-wrapper {
  width: 750px;
  margin: 0 auto;
  margin-top: 150px;
  margin-bottom: 150px;
}
@media (max-width: 750px) {
	.access-wrapper {
  width: 100%;
  margin: 0 auto;
  margin-top: 70px;
  margin-bottom: 70px;
 margin-left:0;
}
}
.ggmap {
  position: relative;
  margin-left: 40px;
  margin-top: 50px;
  padding-bottom: 56.25%;
  padding-top: 30px;
  height: 0;
  overflow: hidden;
  border-radius: 30px;
}
.ggmap iframe, .ggmap object, .ggmap embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 656px;
 
  height: 464px;
  overflow: hidden;
  border-radius: 30px;
}
.access-wrapper .heading {
  margin-bottom: 50px;
}
.access-content {
  display: flex;
  width: 620px;
  margin: 0 auto;
  line-height: 28px;
}
.access-right {
  margin-left: 50px;
}
.access-right p {
  margin-left: 5px;
}
.access-left p {
  margin-bottom: 5px;
}
.a-info {
  display: flex;
  margin-bottom: 15px;
}

@media (max-width: 750px) {
	.ggmap {
  position: relative;
  align-content: center;
  padding-bottom: 100%;
  padding-top: 0;
  height: 0;
  overflow: hidden;
  border-radius: 30px;
	 margin-left: 0;	

		
}
.ggmap iframe, .ggmap object, .ggmap embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  border-radius: 30px;
}

.access-wrapper .heading {
  margin-bottom: 50px;
	margin-left: 0;
	}
.access-content {
  display: flex;
  width: 100%;
  margin: 0 auto;
  line-height: 125%;
	margin-top: 8vw;
	font-size: 0.8em
	}
.access-right {
  margin-left: 2vw;
  
}
.access-right p {
  margin-left: 0;
}
.access-left p {
  margin-bottom: 8px;
}
.a-info {
  display: flex;
  margin-bottom: 8px;
	line-height: 125%;
}

}
body footer {
  background-color: #CFDDFF;
  padding-top: 100px;
  text-align: center;
}
footer h2 {
  font-size: 34px;
  margin-bottom: 50px;
}
footer p {
  line-height: 30px;
}
.sns-icons {
  margin-top: 30px;
  margin-bottom: 90px;
}
.sns-icons img {
  width: 51px;
  height: 51px;
  margin-right: 20px;
}
@media (max-width: 750px) {
	body footer {
		width: 100%;
		height: auto;
  
  padding-top: 13vw;
  text-align: center;
}
footer h2 {
  font-size: 1.5em;
  margin-bottom: 6vw;
}
footer p {
  line-height: 160%;
}
.sns-icons {
  margin-top: 8vw;
  margin-bottom: 10vw;
}
.sns-icons img {
  width: 13.6vw;
  height: 13.6vw;
  margin-right: 3vw;
}
	.copy-right {
		font-size: 0.75em;
	}
}
/* Animation start */
/* アニメーション関連 */
.slideInDown {
  animation: slideInDown;
  animation-duration: 0.6s;
}
.zoomIn {
  animation: zoomIn;
  animation-duration: 1s;
}
.zoomIn2 {
  animation: zoomIn;
  animation-duration: 1s;
}
.zoomIn3 {
  animation: zoomIn;
  animation-duration: 1s;
}
.fadeIn2 {
  animation: fadeIn;
  animation-duration: 1s;
}


.headShake {
  animation: headShake;
  animation-duration: 1.5s;
}
.fadeInRight {
  animation: fadeInRight;
  animation-duration: 2s;
}
.fadeInRight2 {
  animation: fadeInRight;
  animation-duration: 2s;
  animation-delay: 0.2s;
}
.fadeInRight3 {
  animation: fadeInRight;
  animation-duration: 2s;
  animation-delay: 0.2s;
}
.fadeInLeft {
  animation: fadeInLeft;
  animation-duration: 1s;
}
.slideInUp {
  animation: slideInUp;
  animation-duration: 0.8s;
}
@media (max-width: 750px) {
	.fadeIn2 {
  animation: none;
  animation-duration: none;
}
.fadeInRight {
  animation: none;
  animation-duration: none;
}
.fadeInRight2 {
  animation: none;
  animation-duration: none;
  animation-delay:none;
}
.fadeInRight3 {
  animation: none;
  animation-duration: none;
  animation-delay: none;
}
.fadeInLeft {
  animation: none;
  animation-duration:none;
}
	
}
/*end*/