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

*{
	font-weight: 200;
	padding: 0;
	margin:0;
	-webkit-box-sizing: border-box;
			box-sizing: border-box;
	font-family: "Noto Sans JP";
  scroll-behavior:smooth;
}

p,a,span,h1,h2,h3,h4,h5,h6,td,th{
  color: #40220f;
  font-family: fot-tsukuardgothic-std, sans-serif;
  font-weight: 900;
  font-style: normal;
}

a{
	text-decoration: none;
	letter-spacing: 5px;
	transition: .3s;
/*    -webkit-transform: scale(1.001,1);
    -moz-transform: scale(1.001,1);
    -ms-transform: scale(1.001,1);
    -o-transform: scale(1.001,1);
    transform: scale(1.001,1);*/
}

a:hover{
  opacity: .5;
	transition: .4s;
}

li{
	list-style: none;
}

h1,h2,h3,h4,h5,h6,p{
/*    -webkit-transform: scale(1.001,1);
    -moz-transform: scale(1.001,1);
    -ms-transform: scale(1.001,1);
    -o-transform: scale(1.001,1);
    transform: scale(1.001,1);*/
}

h1{	
}
h2{
  font-size: 32px;
  line-height: 45px;
}
h3{
}
h4{	
}
h5{	
}
h6{	
}
p,p span{
  font-size: 16px;
  line-height: 26px;
}
hr{
}

.clear{
	clear:both;
}

.fa{
	color: #fff;
}
body{
	overflow-x: hidden;
  -webkit-text-size-adjust: 100%;
}

.spOnly{
  display: none;
}

.flexBox{
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
}

.spbr{
  display: none;
}

input, button, select, textarea {
    -webkit-appearance: none;
}

/*==============================
共通
==============================*/



/*==============================
ヘッダ
==============================*/
.headAnimesp{
  display: none;
}
header{
  width: 100vw;
  height: 38vw;
  overflow: hidden;
  position: relative;
  background-color: #fff;
}

header > .circle,
header > img{
  position: absolute;
}

header > .circle{
  width: 30vw;
  height: 30vw;
  background-color: #FFF352;
  padding-top: 10%;
  border-radius: 500px;
  z-index: 10;
  top: -8vw;
  right: 0;
  left: 0;
  margin: auto;
  animation-name: mainTitle01;  animation-duration: 20s;
  animation-delay: 0s;
  opacity: 0;
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
}

header > .circle img{
  display: block;
  width: 80%;
  margin: 0 auto;
}

header > img{
  width: 21vw;
  padding-top: 10%;
  z-index: 11;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  animation-name: mainTitle02;  animation-duration: 20s;
  animation-delay: 0s;
  opacity: 0;  
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
}

.headAnime{
  position: absolute;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: space-between;
}

.headAnime > div{
  position: relative;
  width: 40%;
}

.headAnime div > span{
  width: 100%;
  position: absolute;
  background-color: #BF0008;
  padding: 25px 70px 15px;
  font-size: 40px;
  color: #fff;
  transform: rotate(-3deg);
  top: -2vw;
  left: -2vw;
  z-index: 9;
}

.headAnime div > img{
  position: absolute;
  z-index: 8;
}

.headAnime div > img:first-of-type{
  position: absolute;
  width: 90%;
  bottom: -6vw;
  right: 0;
  left: 0;
  margin: auto;
}

.headAnime div:last-of-type > img:last-of-type{
  width: 30%;
  top: 1vw;
  right: 1vw;
}

.glayCover{
  position: absolute;
  width: 50vw;
  height: 100%;
  background-color: rgba(0,0,0,.5);
  z-index: 8;
}

.headAnime div:first-of-type .glayCover{
  top: 0;
  left: 0;
}

.headAnime div:last-of-type .glayCover{
  top: 0;
  right: 0;
}

.move01 div:first-of-type > img:first-of-type{
  width: 100%;
}

.move01 div:first-of-type > img:nth-of-type(2){
  width: 20%;
  right: 5vw;
  top: 5vw;
}

.move01 div:first-of-type > img:nth-of-type(3){
  width: 28%;
  left: 6vw;
  top: 6vw;
}

.move01 div:last-of-type > img:first-of-type{
  width: 90%;
  bottom: -3vw;
}

.move02 div:first-of-type > img:first-of-type{
  width: 90%;
}

.move02 div:first-of-type > img:nth-of-type(2){
  width: 25%;
  right: 6vw;
  top: 7vw;
}

.move02 div:first-of-type > img:nth-of-type(3){
  width: 28%;
  left: 12vw;
  top: 7vw;
}

.move02 div:first-of-type > img:nth-of-type(4){
  width: 18%;
  left: 6vw;
  top: 8vw;
}

.move02 div:last-of-type > img:first-of-type{
  width: 90%;
  bottom: -3vw;
}

.move03 div:first-of-type > img:first-of-type{
  width: 90%;
  right: -5vw;
}

.move03 div:first-of-type > img:nth-of-type(2){
  width: 22%;
  right: 12vw;
  top: 5vw;
}

.move03 div:first-of-type > img:nth-of-type(3){
  width: 28%;
  left: 7vw;
  top: 7vw;
}

.move03 div:first-of-type > img:nth-of-type(4){
  width: 24%;
  left: 1vw;
  top: 12vw;
}

.move03 div:last-of-type > img:first-of-type{
  width: 95%;
  bottom: -5vw;
}

.move01{  
  animation-name: mainBox01;  animation-duration: 20s;
  animation-delay: 0s;
  opacity: 0;  
  animation-iteration-count: infinite;
}

.move02{  
  animation-name: mainBox02;  animation-duration: 20s;
  animation-delay: 0s;
  opacity: 0;  
  animation-iteration-count: infinite;
}

.move03{  
  animation-name: mainBox03;  animation-duration: 20s;
  animation-delay: 0s;
  opacity: 0;  
  animation-iteration-count: infinite;
}

.move01 div:first-of-type .glayCover{
  animation-name: glay01;  animation-duration: 20s;
  animation-delay: 0s;  
  animation-iteration-count: infinite;
}

.move01 div:last-of-type .glayCover{
  animation-name: glay02;  animation-duration: 20s;
  animation-delay: 0s;  
  animation-iteration-count: infinite;
}

.move02 div:first-of-type .glayCover{
  animation-name: glay03;  animation-duration: 20s;
  animation-delay: 0s;  
  animation-iteration-count: infinite;
}

.move02 div:last-of-type .glayCover{
  animation-name: glay04;  animation-duration: 20s;
  animation-delay: 0s;  
  animation-iteration-count: infinite;
}

.move03 div:first-of-type .glayCover{
  animation-name: glay05;  animation-duration: 20s;
  animation-delay: 0s;  
  animation-iteration-count: infinite;
}

.move03 div:last-of-type .glayCover{
  animation-name: glay06;  animation-duration: 20s;
  animation-delay: 0s;  
  animation-iteration-count: infinite;
}

.come01{
  animation-name: come01;  animation-duration: 20s;
  animation-delay: 0s;  
  animation-iteration-count: infinite;  
}

.come02{
  animation-name: come02;  animation-duration: 20s;
  animation-delay: 0s;  
  animation-iteration-count: infinite;  
}

.come03{
  animation-name: come03;  animation-duration: 20s;
  animation-delay: 0s;  
  animation-iteration-count: infinite;  
}

.come04{
  animation-name: come04;  animation-duration: 20s;
  animation-delay: 0s;  
  animation-iteration-count: infinite;  
}

.come05{
  animation-name: come05;  animation-duration: 20s;
  animation-delay: 0s;  
  animation-iteration-count: infinite;  
}

.come06{
  animation-name: come06;  animation-duration: 20s;
  animation-delay: 0s;  
  animation-iteration-count: infinite;  
}

.come07{
  animation-name: come07;  animation-duration: 20s;
  animation-delay: 0s;  
  animation-iteration-count: infinite;  
}

.come08{
  animation-name: come08;  animation-duration: 20s;
  animation-delay: 0s;  
  animation-iteration-count: infinite;  
}

.come09{
  animation-name: come09;  animation-duration: 20s;
  animation-delay: 0s;  
  animation-iteration-count: infinite;  
}

.come10{
  animation-name: come10;  animation-duration: 20s;
  animation-delay: 0s;  
  animation-iteration-count: infinite;  
}

.come11{
  animation-name: come11;  animation-duration: 20s;
  animation-delay: 0s;  
  animation-iteration-count: infinite;  
}

@keyframes mainTitle01{
  0%{
    opacity: 0;
    top: -100vh;
  }
  2%{
    opacity: 1;
    top: -8vw;
  }  
  100%{
    opacity: 1;
    top: -8vw;
  }
}

@keyframes mainTitle02{
  2%{
    opacity: 0;
    bottom: -100vh;
  }
  4%{
    opacity: 1;
    bottom: 0;
  }
  100%{
    opacity: 1;
    bottom: 0;    
  }
}

@keyframes mainBox01{
  0%{
    opacity: 0;
  }
  4%{
    opacity: 0;
  }
  5%{
    opacity: 1;
  }
  39%{
    opacity: 1;
  }
  40%{
    opacity: 0;
  }
}

@keyframes mainBox02{
  0%{
    opacity: 0;
  }
  39%{
    opacity: 0;
  }
  40%{
    opacity: 1;
  }
  69%{
    opacity: 1;
  }
  70%{
    opacity: 0;
  }
}

@keyframes mainBox03{
  0%{
    opacity: 0;
  }
  69%{
    opacity: 0;
  }
  70%{
    opacity: 1;
  }
  99%{
    opacity: 1;
  }
  100%{
    opacity: 0;
  }
}

@keyframes come01{
  0%{
    opacity: 0;
  }
  8%{
    opacity: 0;
    transform: scale(0.1);
  }
  9%{
    opacity: 1;
    transform: scale(1.1);
  }
  10%{
    opacity: 1;
    transform: scale(1);
  }
  
  39%{
    opacity: 1;
  }
  
  40%{
    opacity: 0;
  }
  100%{
    opacity: 0;
  }
}

@keyframes come02{
  0%{
    opacity: 0;
  }
  13%{
    opacity: 0;
    transform: scale(0.1);
  }
  14%{
    opacity: 1;
    transform: scale(1.1);
  }
  15%{
    opacity: 1;
    transform: scale(1);
  }
  
  39%{
    opacity: 1;
  }
  
  40%{
    opacity: 0;
  }
  100%{
    opacity: 0;
  }
}

@keyframes come03{
  0%{
    opacity: 0;
  }
  30%{
    opacity: 0;
    transform: scale(0.1);
  }
  31%{
    opacity: 1;
    transform: scale(1.1);
  }
  32%{
    opacity: 1;
    transform: scale(1);
  }
  
  39%{
    opacity: 1;
  }
  
  40%{
    opacity: 0;
  }
  100%{
    opacity: 0;
  }
}

@keyframes come04{
  0%{
    opacity: 0;
  }
  44%{
    opacity: 0;
    transform: scale(0.1);
  }
  45%{
    opacity: 1;
    transform: scale(1.1);
  }
  46%{
    opacity: 1;
    transform: scale(1);
  }
  
  69%{
    opacity: 1;
  }
  
  70%{
    opacity: 0;
  }
  100%{
    opacity: 0;
  }
}

@keyframes come05{
  0%{
    opacity: 0;
  }
  47%{
    opacity: 0;
    transform: scale(0.1);
  }
  48%{
    opacity: 1;
    transform: scale(1.1);
  }
  49%{
    opacity: 1;
    transform: scale(1);
  }
  
  69%{
    opacity: 1;
  }
  
  70%{
    opacity: 0;
  }
  100%{
    opacity: 0;
  }
}

@keyframes come06{
  0%{
    opacity: 0;
  }
  51%{
    opacity: 0;
    transform: scale(0.1);
  }
  52%{
    opacity: 1;
    transform: scale(1.1);
  }
  53%{
    opacity: 1;
    transform: scale(1);
  }
  
  69%{
    opacity: 1;
  }
  
  70%{
    opacity: 0;
  }
  100%{
    opacity: 0;
  }
}

@keyframes come07{
  0%{
    opacity: 0;
  }
  64%{
    opacity: 0;
    transform: scale(0.1);
  }
  65%{
    opacity: 1;
    transform: scale(1.1);
  }
  66%{
    opacity: 1;
    transform: scale(1);
  }
  
  69%{
    opacity: 1;
  }
  
  70%{
    opacity: 0;
  }
  100%{
    opacity: 0;
  }
}

@keyframes come08{
  0%{
    opacity: 0;
  }
  73%{
    opacity: 0;
    transform: scale(0.1);
  }
  74%{
    opacity: 1;
    transform: scale(1.1);
  }
  75%{
    opacity: 1;
    transform: scale(1);
  }
  
  99%{
    opacity: 1;
  }
  100%{
    opacity: 0;
  }
}

@keyframes come09{
  0%{
    opacity: 0;
  }
  77%{
    opacity: 0;
    transform: scale(0.1);
  }
  78%{
    opacity: 1;
    transform: scale(1.1);
  }
  79%{
    opacity: 1;
    transform: scale(1);
  }
  
  99%{
    opacity: 1;
  }
  100%{
    opacity: 0;
  }
}

@keyframes come10{
  0%{
    opacity: 0;
  }
  81%{
    opacity: 0;
    transform: scale(0.1);
  }
  82%{
    opacity: 1;
    transform: scale(1.1);
  }
  83%{
    opacity: 1;
    transform: scale(1);
  }
  
  99%{
    opacity: 1;
  }
  100%{
    opacity: 0;
  }
}

@keyframes come11{
  0%{
    opacity: 0;
  }
  94%{
    opacity: 0;
    transform: scale(0.1);
  }
  95%{
    opacity: 1;
    transform: scale(1.1);
  }
  96%{
    opacity: 1;
    transform: scale(1);
  }
  
  99%{
    opacity: 1;
  }
  100%{
    opacity: 0;
  }
}

@keyframes glay01{
  0%{
    opacity: 0;
  }
  9%{
    opacity: 0;
  }
  10%{
    opacity: 0;
  }
  11%{
    opacity: 0;
  }
  24%{
    opacity: 0;
  }
  25%{
    opacity: 1;
  }
  100%{
    opacity: 1;
  }
}

@keyframes glay02{
  0%{
    opacity: 0;
  }
  9%{
    opacity: 1;
  }
  10%{
    opacity: 1;
  }
  11%{
    opacity: 1;
  }
  24%{
    opacity: 1;
  }
  25%{
    opacity: 0;
  }
  100%{
    opacity: 0;
  }
}

@keyframes glay03{
  0%{
    opacity: 0;
  }
  39%{
    opacity: 0;
  }
  40%{
    opacity: 0;
  }
  
  59%{
    opacity: 0;
  }
  
  60%{
    opacity: 1;
  }
  
  100%{
    opacity: 1;
  }
}

@keyframes glay04{
  0%{
    opacity: 0;
  }
  9%{
    opacity: 0;
  }
  39%{
    opacity: 1;
  }
  40%{
    opacity: 1;
  }
  
  59%{
    opacity: 1;
  }
  
  60%{
    opacity: 0;
  }
  
  100%{
    opacity: 0;
  }
}

@keyframes glay05{
  0%{
    opacity: 0;
  }
  69%{
    opacity: 0;
  }
  70%{
    opacity: 0;
  }
  
  89%{
    opacity: 0;
  }
  
  90%{
    opacity: 1;
  }
  
  99%{
    opacity: 1;
  }
  
  100%{
    opacity: 1;
  }
}

@keyframes glay06{
  0%{
    opacity: 0;
  }
  69%{
    opacity: 1;
  }
  
  84%{
    opacity: 1;
  }
  
  89%{
    opacity: 1;
  }
  
  90%{
    opacity: 0;
  }
  
  99%{
    opacity: 0;
  }
  
  100%{
    opacity: 0;
  }
}

/*==============================
メイン
==============================*/

#troubleWrap{
  position: relative;
  text-align: center;
}

#troubleWrap::after{
  content: "";
  display: block;
  position: absolute;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 35px 35px 0 35px;
  border-color: #fff transparent transparent transparent;
  bottom: -35px;
  right: 0;
  left: 0;
  margin: auto;
  z-index: 10;
}

#troubleWrap h2{
  position: relative;
  background-color: #3e3a39;
  padding: 50px 15px;
  transform: rotate(0deg);
  margin-bottom: 100px;
}

#troubleWrap h2 img{
  width: 100%;
  max-width: 1200px;
}

#troubleWrap h2::after{
  content: "";
  display: block;
  position: absolute;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 35px 35px 0 35px;
  border-color: #3e3a39 transparent transparent transparent;
  bottom: -35px;
  right: 0;
  left: 0;
  margin: auto;
}

#troubleWrap ul{
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

#troubleWrap ul li{
  width: 30%;
  margin-bottom: 50px;
}

#troubleWrap ul li img{
  width: 100%;
}

#aboutWrap{
  position: relative;
  text-align: center;
  background-color: #e8e3da;
  padding-bottom: 100px;
}

#aboutWrap h2{
  position: relative;
  background-image: url("../img/aboutBack.png");
  background-size: cover;
  background-position: center;
  height: 400px;
  padding: 0 15px;
  margin-bottom: 100px;
}

#aboutWrap h2 img{
  position: relative;
  width: 100%;
  max-width: 1200px;
  top: -50px;
}

#aboutWrap > div:first-of-type{
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  background-image: url("../img/aboutBorder.png");
  background-size: 100% 100%;
  background-position: center center;
  padding: 30px 50px;
  margin-bottom: 50px;
  
}

#aboutWrap > div:first-of-type img{
  width: 70%;
  margin-bottom: 10px;
}

#aboutWrap > div:first-of-type p{
  font-size: 30px;
  line-height: 40px;
  font-weight: 900;
}

#aboutWrap > h3{
  font-size: 30px;
  margin-top: 10px;
  margin-bottom: 10px;
}

#aboutWrap > h3 > img:first-of-type{
  margin-right: 10px;
}

#aboutWrap > h3 > img:last-of-type{
  margin-left: 10px;
}

#aboutWrap > div:nth-of-type(2){
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  display: flex;
  padding: 0 15px;
  justify-content: space-between;
}

#aboutWrap > div:nth-of-type(2) > div{
  border: 2px solid #cd925e;
  border-radius: 10px;
  padding: 5px;
  width: 48%;
}

#aboutWrap > div:nth-of-type(2) > div > div:first-of-type{
  position: relative;
  border: 2px solid #f8c6bd;
  border-radius: 10px 10px 0 0; 
  background-color: #fff;
  padding: 10px;
}

#aboutWrap > div:nth-of-type(2) > div > div:first-of-type h4{
  font-size: 40px;
}

#aboutWrap > div:nth-of-type(2) > div:first-of-type > div:first-of-type h4{
  font-size: 50px;
  margin: 8px 0;
  position: relative;
  z-index: 1;
}

#aboutWrap > div:nth-of-type(2) > div > div:first-of-type img{
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 20%;
  font-size: 20px;
  z-index: 0;
}

#aboutWrap > div:nth-of-type(2) > div:first-of-type > div:first-of-type img{
  width: 30%;
}

#aboutWrap > div:nth-of-type(2) > div > div:first-of-type span{
  display: inline-block;
  padding: 0px 15px;
  background-color: rgba(206,203,229,.5);
  margin: 0 5px;
  font-size: 26px;
  margin-bottom: -50px;
  position: relative;
  font-size: 20px;
  z-index: 1;
}

#aboutWrap > div:nth-of-type(2) > div > div:last-of-type{
  border: 2px solid #f8c6bd;
  background-color: #f8c6bd;
  border-radius: 0 0 10px 10px;
  padding: 10px;
}

#aboutWrap > img{
  max-width: 100%;
}

#aboutWrap > img:nth-of-type(2){
  width: 100%;
  margin: 50px 0;
}

#aboutWrap > div{
  position: relative;
  width: 100%;
  max-width: 1000px;
  margin: 0 auto 20px;
  padding: 0 15px;
}

#aboutWrap > div > ul{
  width: 100%;
  display: flex;
  justify-content: space-between;
}

#aboutWrap > div > ul li{
  width: 24%;
  border: 2px solid #cd925e;
  border-radius: 10px;
  padding: 5px;
}

#aboutWrap > div > ul li div{
  position: relative;
  border: 2px solid #f8c6bd;
  border-radius: 10px;  
  background-color: #fff;
  padding: 10px;
  overflow: hidden;
}

#aboutWrap > div > ul li div::after{
  content: "";
  position: absolute;
  width: 100%;
  height: 50px;
  z-index: 0;
  left: 0;
  bottom: 0;
  background-color: #f8c6bd;
}

#aboutWrap > div > ul li div h5{
  position: relative;
  font-size: 24px;
  line-height: 40px;
  z-index: 2;
}

#aboutWrap > div > ul li div img{
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 60%;
  z-index: 1;
}

#aboutWrap > div:nth-of-type(3) > img{
  width: 20%;
  position: absolute;
  bottom: -20px;
  right: -16%;
}

#caseWrap{
  position: relative;
  text-align: center;
}

#caseWrap::after{
  content: "";
  display: block;
  position: absolute;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 35px 35px 0 35px;
  border-color: #fff transparent transparent transparent;
  bottom: -35px;
  right: 0;
  left: 0;
  margin: auto;
  z-index: 10;
}

#caseWrap h2{
  width: 100%;
  padding: 50px 15px 100px;
  background-image: url("../img/caseBack.png");
  background-size: 100% 100%;
  background-position: center center;
  background-color: #e3dccd;
}

#caseWrap h2 img{
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}

#caseWrap ul{
  width: 100%;
  margin: 0 auto;
}

#caseWrap ul li{
  border-bottom: 2px solid #c9a063;
  background-color: #e3dccd;
}

#caseWrap ul li:last-of-type{
  border-bottom: none;
}

#caseWrap ul li:nth-of-type(2n){
  background-color: #fff;  
}

#caseWrap ul li div{
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  position: relative;
  justify-content: space-between;
  padding: 50px 15px;
}

#caseWrap ul li div img{
  align-self: center;
}

#caseWrap ul li div img:nth-of-type(1){
  width: 35%;
}

#caseWrap ul li div img:nth-of-type(2){
  width: 50%;
}

#caseWrap ul li div img:nth-of-type(3),
#caseWrap ul li div img:nth-of-type(4){
  position: absolute;
}

#caseWrap ul li div img:nth-of-type(3){
  width: 20%;
  bottom: 50px;
  left: 34%;
}

#caseWrap ul li div img:nth-of-type(4){
  width: 10%;
  top: 50px;
  left: 38%;
}

#caseWrap ul li div img:last-of-type{
  position: absolute;
  width: 15%;
  top: 10%;
  right: -10%;
}

#priceWrap{
  padding: 100px 15px;
  background-color: #d2cce6;
  text-align: center;
}

#priceWrap h2{
  width: 100%;
  max-width: 1200px;
  margin: 0 auto 20px;
}

#priceWrap h2 img{
  width: 100%;
}

#priceWrap > div{
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  background-color: #fff;
  background-image: url("../img/priceDeco02.png");
  background-size: 95% 90%;
  background-repeat: no-repeat;
  background-position: 50%;
  padding: 100px 50px;
}

#priceWrap > div h3{
  display: inline-block;
  font-size: 26px;
  padding: 0px 100px 20px;
  color: #fff;
  background-image: url("../img/priceDeco.png");
  background-size: 100% 100%;
  margin-bottom: 20px;
}

#priceWrap > div > img{
  width: 100%;
  margin-top: 20px;
  margin-bottom: 20px;
}

#priceWrap > div > table{
  margin: 0 auto;
}

#priceWrap > div > table th,
#priceWrap > div > table td{
  text-align: left;
  font-size: 32px;
  line-height: 46px;
}

#priceWrap > div > table th{
  padding-right: 20px;
}

#priceWrap > div > table th::before{
  content: "●";
  color: #eb6364;
}
#priceWrap > div > table:last-of-type td{
  line-height: 16px;
}
#priceWrap > div > table:last-of-type td span{
  font-size: 16px;
  line-height: 16px;
  letter-spacing: -2px;
}

#flowWrap{
  text-align: center;
  padding-bottom: 50px;
}

#flowWrap h2{
  transform: rotate(0);
  padding: 50px 15px 100px;
  margin-bottom: 50px;
  background-image: url("../img/flowBack.png");
  background-size: 100% 100%;
}

#flowWrap h2 img{
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}

#flowWrap h3{
  width: 100%;
  max-width: 600px;
  margin: 0 auto 20px;
}

#flowWrap h3 img{
  width: 100%;
}

#flowWrap > ul{
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
}

#flowWrap > ul li{
  width: 33.3333%;
  display: flex;
  background-color: #e3dccd;
  padding: 40px;
}

#flowWrap > ul li:nth-of-type(2n){
  background-color: #e60012;
}

#flowWrap > ul li img{
  width: 40%;
  margin-right: 20px;
  align-self: flex-start;
}

#flowWrap > ul li div{
  text-align: left;
}

#flowWrap > ul li div h3{
  font-size: 50px;
  line-height: 50px;
  margin-bottom: 0;
  color: #e60012;
}

#flowWrap > ul li div h3 span{
  font-size: 30px;
  margin-right: 5px;
}

#flowWrap > ul li div p{
  font-size: 20px;
}

#flowWrap > ul li:nth-of-type(2n) div h3{
  color: #fff;
}

#flowWrap > ul li:nth-of-type(2n) div h3 span{
  color: #fff;
}

#flowWrap > ul li:nth-of-type(2n) div p{
  color: #fff;
}

#contactWrap{
  text-align: center;
  padding-bottom: 50px;
}

#contactWrap h2{
  position: relative;
  padding: 50px 15px;
  font-size: 50px;
  color: #fff;
  background-color: #3e3a39;
  text-align: center;
  margin-bottom: 70px;
}

#contactWrap h2::after{
  content: "";
  display: block;
  position: absolute;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 35px 35px 0 35px;
  border-color: #3e3a39 transparent transparent transparent;
  bottom: -35px;
  right: 0;
  left: 0;
  margin: auto;
  z-index: 10;
}


#contactWrap select,
#contactWrap input[type="text"],
#contactWrap textarea{
  display: block;
  width: 100%;
  max-width: 1000px;
  margin: 0 auto 5px;
  padding: 5px;
  border:0;
  padding:10px;
  border:solid 1px #ccc;
  background-color: #fafafa;
  font-family: fot-tsukuardgothic-std, sans-serif;
  font-weight: 900;
}

input[type="submit"],
input[type="button"]{
  display: inline-block;
  margin-top: 20px;
  background-color: #e60012;
  padding: 10px 100px;
  margin-bottom: 10px;
  cursor: pointer;
  color: #fff;
  border:none;
  font-size: 22px;
  font-family: fot-tsukuardgothic-std, sans-serif;
  font-weight: 900;
}

/*==============================
フッタ
==============================*/

#footCompany{
  padding: 50px;
  display: flex;
  justify-content: center;
  background-color: #e3dccd;
}

#footCompany > div{
  margin-right: 50px;
}
#footCompany > div img{
  display: block;
  width: 100px;
}
#footCompany > div a{
  display: inline-block;
  margin-top: 20px;
  background-color: #e60012;
  padding: 10px 30px;
  color: #fff;
  letter-spacing: 0;
}

footer > p{
  padding: 10px;
  text-align: center;
  background-color: #3e3a39;
  color: #fff;
}

/*==============================
レスポンシブ
==============================*/

@media screen and (max-width: 1600px) {
}

@media screen and (max-width: 1400px) {
  .headAnime div > span{
    padding: 15px 30px 5px 50px;
  }
}

@media screen and (max-width: 1300px) {
}

@media screen and (max-width: 1200px) {
  #aboutWrap h2{
    height: 33vw;
  }

  #aboutWrap h2 img{
    top: -4.166666vw;
  }
  
  #troubleWrap ul{
    max-width: 800px;
  }
  
  #aboutWrap > div:first-of-type{
    max-width: 800px;
  }
  
  #aboutWrap > div:first-of-type p{
    font-size: 20px;
  }
  
  #aboutWrap > div:nth-of-type(2){
    max-width: 750px;
  }
  
  #aboutWrap > div{
    max-width: 750px;
  }
  
  #aboutWrap > div > ul li div h5{
    font-size: 16px;
    line-height: 26px;
  }
  
  #aboutWrap > img{
    width: 30vw;
  }
}

@media screen and (max-width: 1000px) {
  .headAnime div > span{
    font-size: 26px;
    padding: 15px 30px 5px 30px;
  }
  
  #troubleWrap ul{
    max-width: 600px;
  }
  
  #troubleWrap ul li{
    width: 48%;
  }
  
  #contactWrap select, #contactWrap input[type="text"], #contactWrap textarea{
    max-width: 600px;
  }
}

@media screen and (max-width: 800px) {
  #aboutWrap > div:first-of-type{
    max-width: 600px;
    padding: 15px 30px;
  }
  #aboutWrap > div:first-of-type p{
    line-height: 30px;
  }
  
  #aboutWrap > div:nth-of-type(2){
    max-width: 500px;
    flex-wrap: wrap;
  }
  
  #aboutWrap > div:nth-of-type(2) > div{
    width: 100%;
    margin-bottom: 20px;
  }
  
  #aboutWrap > div{
    max-width: 500px;
  }
  
  #aboutWrap > div > ul{
    flex-wrap: wrap;
  }
  
  #aboutWrap > div > ul li{
    width: 48%;
    margin-bottom: 20px;
  }
  
  #aboutWrap > div:nth-of-type(3) > img{
    width: 30%;
    right: -20%;
    bottom: 1vw;
  }
  
  #caseWrap h2{
    padding: 20px 15px 40px;
  }
  
  #priceWrap > div{
    padding: 50px 50px;
  }
  
  #priceWrap > div h3{
    font-size: 20px;
    margin-bottom: 20px;
  }
  
  #priceWrap > div > table th, #priceWrap > div > table td{
    font-size: 20px;
    line-height: 20px;
  }
  #flowWrap h2{
    padding: 20px 15px 40px;
  }
  
  #flowWrap h3 img{
    max-width: 300px;
  }
  
  #contactWrap h2{
    padding: 20px 15px;
    font-size: 26px;
  }
  
  #footCompany{
    flex-wrap: wrap;
  }
  
  #footCompany > div{
    width: 100%;
    margin-right: 0;
    margin-bottom: 20px;
  }
  
  #footCompany > table{
    width: 100%;
  }
  
  #footCompany > table tr > td:first-of-type{
    padding-right: 10px;
  }
}

@media screen and (max-width: 600px){
  
  .headAnime{
    display: none;
  }
  
  .headAnime div > span{
    display: none;
  }
  
  #troubleWrap h2{
    padding: 30px 15px;
    margin-bottom: 70px;
  }
  
  #troubleWrap ul{
    max-width: 300px;
  }
  
  #troubleWrap ul li{
    width: 100%;
    margin-bottom: 40px;
  }
  
  #troubleWrap::after{
    display: none;
  }
  
  #aboutWrap{
    padding-bottom: 50px;
  }
  
  #aboutWrap h2{
    margin-bottom: 30px;
  }
  
  #aboutWrap h2 img{
    top: -1vw;
  }
  
  #aboutWrap > div:first-of-type{
    max-width: 330px; 
    margin-bottom: 30px;
  }
  
  #aboutWrap > div:first-of-type img{
    width: 100%;
    margin-bottom: 5px;
  }
  
  #aboutWrap > div:first-of-type p{
    font-size: 16px;
    line-height: 20px;
  }
  
  #aboutWrap > div:nth-of-type(2){
    max-width: 300px;
  }
  
  #aboutWrap > img:nth-of-type(2){
    margin: 20px 0;
  }
  
  #aboutWrap > div:nth-of-type(2) > div:first-of-type > div:first-of-type h4{
    font-size: 40px;
  }
  
  #aboutWrap > div{
    max-width: 300px;
  }
  
  #aboutWrap > div > ul li{
    width: 100%;
  }
  
  #aboutWrap > h3{
    font-size: 20px;
  }
  
  #aboutWrap > h3 img{
    width: 30px;
  }
  
  #aboutWrap > div:nth-of-type(3) > img{
    width: 40%;
    right: -10%;
    bottom: -100px;
  }
  
  #caseWrap h2{
    padding: 20px 15px 30px;
  }
  
  #caseWrap ul li div{
    flex-wrap: wrap;
    padding-bottom: 40px;
  }
  
  #caseWrap ul li div img:nth-of-type(1){
    margin-bottom: 20px;
  }
  #caseWrap ul li div img:nth-of-type(1),
  #caseWrap ul li div img:nth-of-type(2){
    width: 100%;
  }
  
  #caseWrap ul li div img:nth-of-type(4){
    display: none;
  }
  
  
  #caseWrap ul li div img:nth-of-type(3){
    display: none;
  }
  
  #caseWrap ul li div img:last-of-type{
    width: 30%;
    top: auto;
    bottom: 60vw;
    right: 0%;
  }
  
  #caseWrap ul li:nth-of-type(1) div img:last-of-type{
    bottom: 50vw;    
  }
  
  #caseWrap ul li:nth-of-type(3) div img:last-of-type{
    bottom: 55vw;    
  }
  
  #caseWrap ul li:nth-of-type(4) div img:last-of-type{
    bottom: 50vw;    
  }
  
  #caseWrap ul li:nth-of-type(6) div img:last-of-type{
    bottom: 50vw;    
  }
  
  #priceWrap{
    padding: 60px 15px 30px;
  }
  
  #priceWrap > div{
    padding: 50px 30px;
  }
  
  #priceWrap > div h3{
    font-size: 20px;
    margin-bottom: 20px;
    padding: 0 50px 15px;
  }

  #priceWrap > div > table th{
    padding-right: 10px;
  }
  
  #priceWrap > div > table th, #priceWrap > div > table td{
    font-size: 16px;
    line-height: 26px;
  }
  
  #priceWrap > div > table:last-of-type td span{
    font-size: 10px;
  }
  
  #flowWrap{
    padding-bottom: 0px;
  }
  
  #flowWrap h2{
    margin-bottom: 30px;
  }

  #flowWrap > ul{
    display: flex;
    flex-wrap: wrap;
  }
  
  #flowWrap > ul li{
    width: 100%;
    padding: 30px 20px;
  }
  
  #contactWrap select, #contactWrap input[type="text"], #contactWrap textarea{
    max-width: 330px;
  }
  
  #footCompany{
    padding: 50px 15px;
  }
  
  #footCompany > table td,
  #footCompany > table th{
    font-size: 12px;
  }
  
  footer > p{
    font-size: 12px;
  }
  
  #footCompany > div{
    text-align: center;
  }
  
  #footCompany > div img{
    margin: 0 auto;
  }
}

@media screen and (max-width: 600px){  
  header{
    height: 76vw;
  }
  
  header > img{
    width: 30%;
    left: 2%;
    right: auto;
    bottom: 0;
    top: auto;
  }
  
  header > .circle{
    width: 42vw;
    height: 42vw;
    bottom: -63vw;
    right: -3vw;
    left: auto;
    top: auto;
    padding: 12% 1%;
  }
  
  .headAnime{
    display: none;
  }

  .headAnimesp{
    position: absolute;
    width: 100%;
    height: 100%;
  }

  .headAnimesp > div{
    position: relative;
    width: 100%;
    height: 100%;
  }

  .headAnimesp div > img{
    position: absolute;
    z-index: 8;
  }

  .headAnimesp div > img:first-of-type{
    position: absolute;
    width: 90%;
    bottom: -6vw;
    right: 0;
    left: 0;
    margin: auto;
  }

  .headAnimesp{
    display: block;
  }

  .move01sp div > img:first-of-type{
    width: 100%;
    right: -5vw;
  }

  .move01sp div > img:nth-of-type(2){
    width: 23%;
    right: -2vw;
    top: -2vw;
  }

  .move01sp div > img:nth-of-type(3){
    width: 28%;
    left: 26vw;
    top: -2vw;
  }

  .move02sp div > img:first-of-type{
    width: 80%;
    bottom: -5vw;
  }

  .move02sp div > img:last-of-type{
    width: 30%;
    right: 1vw;
    top: 1vw;
  }

  .move03sp div > img:first-of-type{
    width: 90%;
    bottom: -5vw;
  }

  .move03sp div > img:nth-of-type(2){
    width: 24%;
    right: 30vw;
    top: -2vw;
  }

  .move03sp div > img:nth-of-type(3){
    width: 27%;
    left: 20vw;
    top: -2vw;
  }

  .move03sp div > img:nth-of-type(4){
    width: 18%;
    left: 6vw;
    top: 4vw;
  }

  .move04sp div > img:first-of-type{
    width: 80%;
    bottom: -0vw;
  }

  .move04sp div > img:last-of-type{
    width: 30%;
    right: 1vw;
    top: 1vw;
  }

  .move05sp div > img:first-of-type{
    width: 80%;
    right: -0vw;
  }

  .move05sp div > img:nth-of-type(2){
    width: 23%;
    right: 40vw;
    top: -2vw;
  }

  .move05sp div > img:nth-of-type(3){
    width: 28%;
    left: 14vw;
    top: 2vw;
  }

  .move05sp div > img:nth-of-type(4){
    width: 25%;
    left: -2vw;
    top: 12vw;
  }

  .move06sp div > img:first-of-type{
    width: 80%;
    bottom: -5vw;
  }

  .move06sp div > img:last-of-type{
    width: 30%;
    right: 1vw;
    top: 1vw;
  }

  .move01sp{  
    animation-name: mainBox01sp;  animation-duration: 30s;
    animation-delay: 0s;
    opacity: 0;  
    animation-iteration-count: infinite;
  }

  .move02sp{  
    animation-name: mainBox02sp;  animation-duration: 30s;
    animation-delay: 0s;
    opacity: 0;  
    animation-iteration-count: infinite;
  }

  .move03sp{  
    animation-name: mainBox03sp;  animation-duration: 30s;
    animation-delay: 0s;
    opacity: 0;  
    animation-iteration-count: infinite;
  }

  .move04sp{  
    animation-name: mainBox04sp;  animation-duration: 30s;
    animation-delay: 0s;
    opacity: 0;  
    animation-iteration-count: infinite;
  }

  .move05sp{  
    animation-name: mainBox05sp;  animation-duration: 30s;
    animation-delay: 0s;
    opacity: 0;  
    animation-iteration-count: infinite;
  }

  .move06sp{  
    animation-name: mainBox06sp;  animation-duration: 30s;
    animation-delay: 0s;
    opacity: 0;  
    animation-iteration-count: infinite;
  }

  .come01sp{
    animation-name: come01sp;  animation-duration: 30s;
    animation-delay: 0s;  
    animation-iteration-count: infinite;  
  }

  .come02sp{
    animation-name: come02sp;  animation-duration: 30s;
    animation-delay: 0s;  
    animation-iteration-count: infinite;  
  }

  .come03sp{
    animation-name: come03sp;  animation-duration: 30s;
    animation-delay: 0s;  
    animation-iteration-count: infinite;  
  }

  .come04sp{
    animation-name: come04sp;  animation-duration: 30s;
    animation-delay: 0s;  
    animation-iteration-count: infinite;  
  }

  .come05sp{
    animation-name: come05sp;  animation-duration: 30s;
    animation-delay: 0s;  
    animation-iteration-count: infinite;  
  }

  .come06sp{
    animation-name: come06sp;  animation-duration: 30s;
    animation-delay: 0s;  
    animation-iteration-count: infinite;  
  }

  .come07sp{
    animation-name: come07sp;  animation-duration: 30s;
    animation-delay: 0s;  
    animation-iteration-count: infinite;  
  }

  .come08sp{
    animation-name: come08sp;  animation-duration: 30s;
    animation-delay: 0s;  
    animation-iteration-count: infinite;  
  }

  .come09sp{
    animation-name: come09sp;  animation-duration: 30s;
    animation-delay: 0s;  
    animation-iteration-count: infinite;  
  }

  .come10sp{
    animation-name: come10sp;  animation-duration: 30s;
    animation-delay: 0s;  
    animation-iteration-count: infinite;  
  }

  .come11sp{
    animation-name: come11sp;  animation-duration: 30s;
    animation-delay: 0s;  
    animation-iteration-count: infinite;  
  }
}


  @keyframes mainBox01sp{
    0%{
      opacity: 1;
    }
    22%{
      opacity: 1;
    }
    23%{
      opacity: 0;
    }
    99%{
      opacity: 0;
    }
    100%{
      opacity: 1;
    }
  }

  @keyframes mainBox02sp{
    0%{
      opacity: 0;
    }
    22%{
      opacity: 0;
    }
    23%{
      opacity: 1;
    }
    32%{
      opacity: 1;
    }
    33%{
      opacity: 0;
    }
    70%{
      opacity: 0;
    }
  }

  @keyframes mainBox03sp{
    0%{
      opacity: 0;
    }
    32%{
      opacity: 0;
    }
    33%{
      opacity: 1;
    }
    53%{
      opacity: 1;
    }
    54%{
      opacity: 0;
    }
    100%{
      opacity: 0;
    }
  }

  @keyframes mainBox04sp{
    0%{
      opacity: 0;
    }
    53%{
      opacity: 0;
    }
    54%{
      opacity: 1;
    }
    63%{
      opacity: 1;
    }
    64%{
      opacity: 0;
    }
    100%{
      opacity: 0;
    }
  }

  @keyframes mainBox05sp{
    0%{
      opacity: 0;
    }
    63%{
      opacity: 0;
    }
    64%{
      opacity: 1;
    }
    83%{
      opacity: 1;
    }
    84%{
      opacity: 0;
    }
    100%{
      opacity: 0;
    }
  }

  @keyframes mainBox06sp{
    0%{
      opacity: 0;
    }
    83%{
      opacity: 0;
    }
    84%{
      opacity: 1;
    }
    99%{
      opacity: 1;
    }
    100%{
      opacity: 0;
    }
  }

  @keyframes come01sp{
    0%{
      opacity: 0;
    }
    5%{
      opacity: 0;
      transform: scale(0.1);
    }
    6%{
      opacity: 1;
      transform: scale(1.1);
    }
    7%{
      opacity: 1;
      transform: scale(1);
    }

    39%{
      opacity: 1;
    }

    40%{
      opacity: 0;
    }
    100%{
      opacity: 0;
    }
  }

  @keyframes come02sp{
    0%{
      opacity: 0;
    }
    9%{
      opacity: 0;
      transform: scale(0.1);
    }
    10%{
      opacity: 1;
      transform: scale(1.1);
    }
    11%{
      opacity: 1;
      transform: scale(1);
    }

    39%{
      opacity: 1;
    }

    40%{
      opacity: 0;
    }
    100%{
      opacity: 0;
    }
  }

  @keyframes come03sp{
    0%{
      opacity: 0;
    }
    25%{
      opacity: 0;
      transform: scale(0.1);
    }
    26%{
      opacity: 1;
      transform: scale(1.1);
    }
    27%{
      opacity: 1;
      transform: scale(1);
    }

    39%{
      opacity: 1;
    }

    40%{
      opacity: 0;
    }
    100%{
      opacity: 0;
    }
  }

  @keyframes come04sp{
    0%{
      opacity: 0;
    }
    38%{
      opacity: 0;
      transform: scale(0.1);
    }
    39%{
      opacity: 1;
      transform: scale(1.1);
    }
    40%{
      opacity: 1;
      transform: scale(1);
    }

    69%{
      opacity: 1;
    }

    70%{
      opacity: 0;
    }
    100%{
      opacity: 0;
    }
  }

  @keyframes come05sp{
    0%{
      opacity: 0;
    }
    42%{
      opacity: 0;
      transform: scale(0.1);
    }
    43%{
      opacity: 1;
      transform: scale(1.1);
    }
    44%{
      opacity: 1;
      transform: scale(1);
    }

    69%{
      opacity: 1;
    }

    70%{
      opacity: 0;
    }
    100%{
      opacity: 0;
    }
  }

  @keyframes come06sp{
    0%{
      opacity: 0;
    }
    46%{
      opacity: 0;
      transform: scale(0.1);
    }
    47%{
      opacity: 1;
      transform: scale(1.1);
    }
    48%{
      opacity: 1;
      transform: scale(1);
    }

    69%{
      opacity: 1;
    }

    70%{
      opacity: 0;
    }
    100%{
      opacity: 0;
    }
  }

  @keyframes come07sp{
    0%{
      opacity: 0;
    }
    59%{
      opacity: 0;
      transform: scale(0.1);
    }
    60%{
      opacity: 1;
      transform: scale(1.1);
    }
    61%{
      opacity: 1;
      transform: scale(1);
    }

    69%{
      opacity: 1;
    }

    70%{
      opacity: 0;
    }
    100%{
      opacity: 0;
    }
  }

  @keyframes come08sp{
    0%{
      opacity: 0;
    }
    69%{
      opacity: 0;
      transform: scale(0.1);
    }
    70%{
      opacity: 1;
      transform: scale(1.1);
    }
    71%{
      opacity: 1;
      transform: scale(1);
    }

    99%{
      opacity: 1;
    }
    100%{
      opacity: 0;
    }
  }

  @keyframes come09sp{
    0%{
      opacity: 0;
    }
    72%{
      opacity: 0;

      transform: scale(0.1);
    }
    73%{
      opacity: 1;
      transform: scale(1.1);
    }
    74%{
      opacity: 1;
      transform: scale(1);
    }

    99%{
      opacity: 1;
    }
    100%{
      opacity: 0;
    }
  }

  @keyframes come10sp{
    0%{
      opacity: 0;
    }
    76%{
      opacity: 0;
      transform: scale(0.1);
    }
    77%{
      opacity: 1;
      transform: scale(1.1);
    }
    78%{
      opacity: 1;
      transform: scale(1);
    }

    99%{
      opacity: 1;
    }
    100%{
      opacity: 0;
    }
  }

  @keyframes come11sp{
    0%{
      opacity: 0;
    }
    89%{
      opacity: 0;
      transform: scale(0.1);
    }
    90%{
      opacity: 1;
      transform: scale(1.1);
    }
    91%{
      opacity: 1;
      transform: scale(1);
    }

    99%{
      opacity: 1;
    }
    100%{
      opacity: 0;
    }
  }