@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Zen+Maru+Gothic:wght@400;700&display=swap');

/* reset */
*,::after,::before{box-sizing:border-box}html{line-sizing:normal}body{margin:0}[hidden]{display:none}h1,h2,h3,h4,h5,h6{margin:0}pre{white-space:pre-wrap}hr{border-style:solid;border-width:1px 0 0;color:inherit;height:0;overflow:visible}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle;max-width:100%}audio:not([controls]){display:none}picture{display:contents}source{display:none}canvas,img,svg,video{height:auto}audio{width:100%}img{border-style:none}svg{overflow:hidden}article,aside,details,figcaption,figure,footer,header,hgroup,main,nav,section{display:block}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0}ol,ul {list-style: none;padding: 0;margin: 0;}

html {
  font-family: "Zen Maru Gothic", serif;
  line-height: 1.5;
  padding: 0;
  margin: 0;
  background: #fff;
  color: #4C4C4C;
  letter-spacing: -0.01em;
  scroll-behavior: smooth;
}
body {
  position: relative;
}
.pagetop {
  position: fixed;
  right: 5%;
  bottom: 5%;
}
.active{
  opacity: 1;
  visibility: visible;
}
@media only screen and (min-width:768px){ /*for PC*/
	body{
		width: 100%;
		min-width: 1120px;
    font-size: 1rem;
	}
  .pagetop img{
     transition: all 0.3s ease;
  }
  .pagetop img:hover{
    cursor: pointer;
    opacity: 0.7;
  }
	br.sp{
		display: none;
	}
}
@media only screen and (max-width:767px){ /*for SP*/
  html, body {
    font-size: 3.8vw;
  }
	body{
		min-width: 320px;
	}
  .pagetop img {
    width: 18vw;
  }
}
/* mainVisual
******************************************/
#mainVisual {
  overflow: hidden; 
}
#mainVisual .mvWrap {
  width: 100%;
  height: 100%;
}
#mainVisual h1, #mainVisual .yasumin {
  text-align: center;
}
#mainVisual h1 img, #mainVisual .yasumin img{
  display: inline-block;
}
@media only screen and (min-width:768px){ /*for PC*/
  #mainVisual {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    padding: 4vw 0;
    height: auto;
    min-height: 85vh;
    min-height: 85dvh;
  }
  #mainVisual h1 {
    margin-bottom: 50px;
  }
  #mainVisual h1 img{
    width: 50%;
    max-width: 762px;
  }
  #mainVisual .yasumin img {
    width: 36%;
    max-width: 609px; 
  }
}
@media only screen and (max-width:767px){ /*for SP*/
  #mainVisual {
    padding: 15vw 5vw 17vw 5vw;
  }
  #mainVisual h1 {
    margin-bottom: 8vw;
  }
  #mainVisual h1 img{
    max-width: 98%;
  }
  #mainVisual .yasumin img {
    max-width: 70%; 
  }
}
.textAnime {
  animation: textfade 1s linear forwards 0s;
}
.yasuminAnime {
  animation: bound 1.5s linear forwards 0.9s;
  opacity: 0;
}
@keyframes textfade {
  0% {
    opacity: 0;
    transform: scale(0.5);
  }
  40% {
    opacity: 1;
    transform: scale(1.3);
  }
  80% {
    transform: scale(1);
  }
  100% {
    transform: scale(1);
  }
}
@keyframes bound {
  0%   { opacity: 0; transform: scale(0.8, 1.4) translate(0%, -100%); }
  10%  { opacity: 1; transform: scale(0.8, 1.4) translate(0%, -15%); }
  20%  { transform: scale(1.4, 0.6) translate(0%, 30%); }
  30%  { opacity: 1; transform: scale(0.9, 1.1) translate(0%, -10%); }
  40%  { opacity: 1; transform: scale(0.95, 1.2) translate(0%, -30%); }
  50%  { opacity: 1; transform: scale(0.95, 1.2) translate(0%, -10%); }
  60%  { opacity: 1; transform: scale(1.1, 0.9) translate(0%, 5%); }
  70%  { opacity: 1; transform: scale(1.0, 1.0) translate(0%, 0%); }
  100% { opacity: 1; transform: scale(1.0, 1.0) translate(0%, 0%); }
}
/* download
******************************************/
#download {
  background: #90D1D7;
}
#download h2{
  text-align: center;
}
#download h2 img{
  display: inline-block;
}
#download .dlList li{
  width: 92%;
  margin: 0 auto;
}
#download .dlList .dlBtn a{
  display: block;
}
@media only screen and (min-width:768px){ /*for PC*/
  #download {
    padding: 130px 0 160px 0;
  }
  #download h2{
    margin-bottom: 130px;
  }
  #download h2 img{
    max-width: 800px;
  }
  #download .dlList li{
    max-width: 855px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    padding-left: 9px;
  }
  #download .dlList li + li {
    margin-top: 70px;  
  }
  #download .dlList li .dlBtn{
    width: 554px;
  }
  #download .dlList li .dlBtn img{
    transition: all 0.3s ease;
  }
  #download .dlList li .dlBtn a:hover img{
    transform: scale(.95);
  }
}
@media only screen and (max-width:767px){ /*for SP*/
  #download {
    padding: 12vw 4vw;
  }
  #download h2 {
    margin-bottom: 6vw
  }
  #download h2 img{
    max-width: 90%;
  }
  #download .dlList li{
    text-align: center;
  }
  #download .dlList li .pmpImg img{
    max-width: 50%;
    display: inline-block;
  }
  #download .dlList li .dlBtn{
    width: 90%;
    margin: 4vw auto 0 auto;
  }
  #download .dlList li + li {
    margin-top: 10vw;  
  }
}
/* character
******************************************/
#character h2{
  text-align: center;
}
#character h2 img{
  display: inline-block;
}
#character .aboutChara {
  width: 92%;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-end;
}
#character .charaText {
  width: 92%;
  margin: 0 auto;
  text-align: center;
}
#character .charaText img{
  display: inline-block;
}
@media only screen and (min-width:768px){ /*for PC*/
  #character {
    padding: 100px 0 167px 0;  
  }
  #character h2 {
    margin-bottom: 100px;
  }
  #character h2 img{
    max-width: 574px;
  }
  #character .aboutChara {
    max-width: 1266px;
  }
  #character .aboutChara .chara01{
    max-width: 779px;
    width: 65%;
  }
  #character .aboutChara .chara02{
    max-width: 407px;
    width: 33%;
  }
  #character .charaText {
    margin-top: 128px;
  }
  #character .charaText img {
    width: 850px;
  }
}
@media only screen and (max-width:767px){ /*for SP*/
  #character {
    padding: 14vw 2vw 12vw 2vw;
  }
  #character h2 {
    margin-bottom: 7vw;
  }
  #character h2 img{
    max-width: 82%;
  }
  #character .aboutChara .chara02{
    width: 60%;
    margin-left: auto;
    margin-right: auto;
    margin-top: 8vw;
    padding-right: 6vw;
  }
  #character .charaText {
    margin-top: 8vw;
  }
}
/* contact
******************************************/
#contact .contactTitle{
  text-align: center;
  font-weight: bold;
}
#contact .contactLink{
  margin:  0 auto;
  font-size: 1.75rem;
  color: #4C4C4C;
  line-height: 1.2;
}
#contact .contactLink th,
#contact .contactLink td{
  padding-bottom: 0.8em;
}
#contact .contactLink a{
  display: inline-block;
  position: relative;
  color: #4C4C4C;
}
#contact .contactLink th{
  text-align: left;
  font-weight: normal;
}
#contact .contactLink td{
  text-align: left;
}
#contact .contactLink a::before{
  content: '';
  display: inline-block;
  background: url("../images/icon_mail.svg") no-repeat center center / 100% auto;
  position: absolute;
  left: 0;
}
@media only screen and (min-width:768px){ /*for PC*/
  #contact {
    padding: 105px 0 80px 0;
  }
  #contact .contactTitle{
    font-size: 2rem;
    margin-bottom: 30px;
  }
  #contact .contactLink th {
    padding-right: 1.5em;
  }
  #contact .contactLink a{
    padding-left: 54px;
  }
  #contact .contactLink a:hover{
    text-decoration: none;
  }
  #contact .contactLink a::before{
    width: 44px;
    height: 30px;
    top: 6px;
  }
  #contact .contactLink span{
    width: 10em;
  }
}
@media only screen and (max-width:767px){ /*for SP*/
  #contact {
    padding: 5vw 0 14vw 0;
  }
  #contact .contactTitle{
    font-size: 1.5rem;
    margin-bottom: 4vw;
  }
  #contact .contactLink{
    font-size: 1rem;
  }
  #contact .contactLink th {
    padding-right: 1em;
  }
  #contact .contactLink a{
    padding-left: 5.5vw;
  }
  #contact .contactLink a::before{
    width: 4vw;
    height: 3vw;
    top: 1vw;
  }
}
/* footer
******************************************/
footer {
  width: 92%;
  max-width: 1640px;
  margin: 0 auto;
}
footer .ttl {
  text-align: center;
  background: url("../images/foot_border.svg") no-repeat center center / 1640px auto;
}
footer .ttl span{
  display: inline-block;
  background: #fff;
  padding: 0 42px;
}
footer .ttl span img{
  width: 138px;
}
footer .bnr{
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}
@media only screen and (min-width:768px){ /*for PC*/
  footer {
    padding: 80px 0 150px 0;
  }
  footer .ttl {
    margin-bottom: 95px;
  }
  footer .bnr {
    gap: 60px;
  }
  footer .bnr li a{
    transition: all 0.3s ease;
  }
  footer .bnr li a:hover{
    opacity: .6;
  }
}
@media only screen and (max-width:767px){ /*for SP*/
  footer {
    padding: 10vw 4vw 10vw 4vw;
  }
  footer .ttl {
    padding-bottom: 2vw;
  }
  footer .ttl span img{
    width: 24vw;
  }
  footer .bnr {
    padding: 0 3vw;
    gap: 6vw;
  }
  footer .bnr li {
    width: 46%;
  }
}
