@charset "utf-8";

/*==================== reset ====================*/
*{
  margin: 0;
  padding: 0;
	line-height: 1.5;
	font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";
}
ul,ol{
	list-style: none;
}
img{
	border: none;
	vertical-align: bottom;
	max-width: 100%;
	height: auto;
}
a{
	text-decoration: none;
  color: inherit;
}

/*==================== end ====================*/

/*==================== 共通 ====================*/
.container{
  max-width: 100vw;
  margin: 0 auto;
  /* padding: 10px 10% 50px; */
  /* background-attachment: fixed;
  background-position: center; */
  background-size: cover;
}
.pc {
  display: inline;
  width: 100%;
}
.sp {
  display: none;
  width: 100%;
}

/*==================== 共通:ボタン ====================*/
.btn{
  display: block;
  border: 2px solid #0080dc;
  border-radius: 100vh;
  width: 20%;
  padding: 20px 40px;
  text-align: center;
	vertical-align: middle;
  margin: 0 auto;
  color: #fff;
  background-color: #0080dc;
  font-size: 1.4vw;
  font-weight: bold;
  color: #fff;
  cursor: pointer;
  transition: .2s cubic-bezier(0.45, 0, 0.55, 1);
}
.btn:hover{
  background-color: #fff;
  color: #0080dc;
}

/* header : 961px以上1280px以下 */
@media screen and (max-width: 1280px) and (min-width: 961px){
   .btn{
    font-size: 2vw;
    width: 25%;
    }
}

/* btn : 768px以上961px以下 */
@media screen and (min-width: 768px) and (max-width: 961px){
 .btn{
    font-size: 2.2vw;
    width: 25%;
    }
  }

/* btn : 521px以上767px以下 */
@media (min-width: 521px) and (max-width: 767px) {
  .btn{
    font-size: 2.8vw;
    width: 30%;
    padding: 18px 30px;
    }
}

/* btn : 521px以下 */
@media screen and (max-width: 520px){
  .btn{
    font-size: 3.8vw;
    width: 45%;
    padding: 15px 25px;
}
}


/*==================== header ====================*/
.header{
  background-image: url(../img/header-bg_pc.png);
  padding: 30px 10px 40px;
  margin: 0 0 60px;
  background-attachment: fixed;
  background-size: auto;
  background-position: center;
}

header h1{
  margin: 0 auto;
  text-align: center;
  width: 45%;
  padding: 0 0 40px;
}

/* header : 961px以上1280px以下 */
@media screen and (max-width: 1280px) and (min-width: 961px){
  .header{
  margin: 0 0 50px;
}
  header h1{
    width: 60%;
  }
}

/* header : 521px以上961px以下 */
@media screen and (max-width: 960px) and (min-width: 521px){
  .header{
    margin: 0 0 45px;
    background-position: top;
  }  

  header h1{
    width: 70%;
    padding: 0 0 40px;
  }

}


/* header : 520px以下 */
@media screen and (max-width: 520px){
  .header{
    background: url(../img/header-bg_sp.png) no-repeat 0 0 / cover;
    background-position: center;
    padding: 50px 10px 30px;
    margin: 0 0 40px;
  }

  header h1{
    width: 75%;
    padding: 0 0 30px;
  }
  header h1 img.pc {
  display: none;
  }
  header h1 img.sp {
  display: inline;
  }
}

/*==================== main ====================*/
.main-btn{
  margin: 80px auto;
}

.onayami,.toiawase{
  margin: 0 auto;
  margin-bottom: 100px;
  width: 60%;
}

.onayami img{
  width: 100%;
  margin: 0 auto;
}

.toiawase img{
  display: block;
  width: 100%;
  margin: 0 auto 20px;
}

.toiawase p{
  font-size: 1.5rem;
  text-align: center;
  line-height: 1.5;
}

h2{
  text-align: center;
  font-size: 1.8rem;
  margin-bottom: 30px;
}

section .wrap{
  display: flex;
  width: 50%;
  margin: 0 auto;
  padding: 3% 0 3% 3%;
  align-items: flex-start;
  justify-content: center;
  background-color: #f0f0f0;
}

section .wrap{
  margin-bottom: 30px;
}

.wrap img{
  max-width: 200px;
  margin: auto;
}

h3,.author{
  text-align: center;
}

h3{
  font-size: 2rem;
}

.author{
  margin-bottom: 20px;
}

.text{
  margin: 0 auto;
  width:  80%;
}

.text a{
  text-decoration: underline;
}
.text a:hover{
  text-decoration: none;
}

/* main : 961px以上1280px以下 */
@media screen and (max-width: 1280px) and (min-width: 961px){
  section .wrap{
    width: 55%;
    padding: 3% 0 3% 3%;
  }
  h3{
    font-size: 1.65rem;
  }

}

/* main : 521px以上960px以下 */
@media screen and (max-width: 960px) and (min-width: 521px){
  .onayami,.toiawase{
    width: 80%;
    margin-bottom: 60px;
  }

  .toiawase p{
    font-size: 1.2rem;
  }

  h2{
    font-size: 1.8rem;
  }

  section .wrap{
    display: block;
    padding: 20px 0;
    width: 65%;
  }

  .wrap img{
    display: block;
    margin-bottom: 20px;
  }

  h3{
    font-size: 1.8rem;
  }
}

/* main : 520px以下 */
@media screen and (max-width: 520px){
.onayami{
  width: 80%;
  margin-bottom: 40px;
}

.onayami img.pc{
  display: none;
}

.onayami img.sp{
  display: block;
}

.toiawase{
  width: 80%;
  margin-bottom: 40px;
}

.toiawase p{
  font-size: .8rem;
}

h2{
  font-size: 1.7rem;
  margin-bottom: 20px;
}

section .wrap{
  display: block;
  padding: 20px 0;
  width: 80%;
}

.wrap img{
  display: block;
  margin-bottom: 20px;
}

h3{
  font-size: 1.5rem;
}

}


/*==================== footer ====================*/
footer .container{
  padding: 42px 0px;
  background-color: #343a40;
  text-align: center;
  font-size: 20px;
  line-height: 1.4;
}
.footer{
  display: flex;
  justify-content: center;
  list-style: none;
  text-align: center;
  text-decoration: none;
  padding-inline-start: 0px;
  max-width: 960px;
  margin: 0 auto;
}
ul.footer{
  margin-bottom: 42px;
}
.footer li a{
  color: #ffffff;
  padding: 0 20px;
}
.footer li a:hover{
  opacity: 0.5;
}
.ec-footerTitle{
  margin-bottom: 42px;
}
.ec-footerTitle__logo{
  margin-bottom: 10px;
}
.ec-footerTitle__logo img{
  width: 120px;
  text-align: center;
}
.ec-footerTitle__logo img:hover{
  opacity: 0.5;
}
.ec-footerTitle__copyright{
  font-size: 12px;
  color: #ffffff;
}
ul.footer{
  padding-left: 29px;
}
.ec-footerLicence{
  display: flex;
  max-width: 580px;
  margin: 0 auto;
  padding:0 20px;
  text-align: start;
}

/*==================== contact.html ====================*/
#contact main{
  padding: 60px 0;
  box-sizing: border-box;
}

.contact_h2_br{
  display: none;
}

.contact-box{
  width: 50%;
  margin: 0 auto 10px;
}

.contact_main h2{
  width: 60%;
  margin: auto;
  padding: 0 0 30px;
  font-size: 1.6rem;
}

.contact_main p{
  margin-bottom: 10px;
}

.contact_main p.contact-box{
  margin-bottom:30px;
}

@media screen and (max-width: 960px) and (min-width: 521px){
  #contact main{
    padding: 50px 0;
  }

  .contact_main h2{
    width: 90%;
    padding: 0 10px 30px;
  }  

  .contact-box{
    width: 90%;
    margin: 0 auto;
    padding: 0 10px;
    font-size: 1.6rem;
  }

  #email{
    width: 100%;
  }

  #tel{
    width: 100%;
  }

}


@media screen and (max-width: 520px){
  .contact_h2_br{
    display: inline;
  }

  .contact_main h2{
    width: 96%;
    font-size: 1.7rem;
    padding: 0 10px 20px;
    margin-bottom: 10px;
  }  

  .contact-box{
    width: 90%;
    margin: 0 auto;
    padding: 0 10px;
  }
  p.contact-box{
    font-size: 1rem;
  
  }

  #email{
    width: 100%;
  }

  #tel{
    width: 100%;
  }

}

/*==================== end ====================*/