@charset "UTF-8";
/*--レスポンシブ--*/
/*--呼び出し例

.pc{
  display: block;
  @include mq("sp") {
    display: none;
  }
}

.sp{
  display: none;
  @include mq("sp") {
    display: block;
  }
}

--*/
/*--定義--*/
/*----共通部分----*/
html {
  font-size: 100%;
}

body {
  font-family: "Noto Sans JP", "ヒラギノ角ゴ ProN", sans-serif;
  font-weight: 300;
  color: #151515;
  width: 100%;
  font-size: 0.9rem;
  background-color: white;
  margin: 0 auto;
}

.wrapper {
  margin: 0 10%;
}
@media screen and (max-width: 800px) {
  .wrapper {
    margin: 0 5%;
  }
}

@media screen and (max-width: 800px) {
  .pc {
    display: none;
  }
}

.sp {
  display: none;
}
@media screen and (max-width: 800px) {
  .sp {
    display: block;
  }
}

/*---その他のjs設定---*/
.js-fade {
  opacity: 0;
  visibility: hidden;
  transform: translateY(50px);
  transition: opacity 1s, visibility 1s, transform 1s;
}

.scroll {
  opacity: 1;
  visibility: visible;
  transform: translateY(0px);
}

/*---header---*/
header {
  display: flex;
  justify-content: space-between;
  background-color: #2C1F72;
  color: white;
  position: sticky;
  top: 0;
  z-index: 100;
}
@media screen and (max-width: 800px) {
  header {
    justify-content: center;
    height: 10vw;
    align-items: center;
    background-color: #FFFF02;
  }
}
header h1 {
  width: 30%;
  background-color: white;
}
@media screen and (max-width: 800px) {
  header h1 {
    width: 50%;
    height: 100%;
    position: relative;
  }
  header h1 img {
    -o-object-fit: contain;
       object-fit: contain;
    height: 10vw;
    position: absolute;
    top: 0;
    left: 0;
  }
}
header h1 img {
  vertical-align: middle;
  width: 100%;
  padding: 0 2%;
}
header .action {
  display: flex;
  width: 40%;
  justify-content: center;
  align-items: center;
  background-color: #FFFF02;
}
@media screen and (max-width: 800px) {
  header .action {
    display: block;
    width: 50%;
  }
}
header .action .time {
  width: 70%;
  height: 100%;
  text-align: center;
  padding-right: 10px;
  background-color: #2C1F72;
}
@media screen and (max-width: 800px) {
  header .action .time {
    display: none;
  }
}
header .action .time span {
  font-weight: bold;
  font-size: 1.5vw;
}
header .action .time p {
  font-size: 1vw;
  border-top: solid white 0.5px;
}
header .action .tel a img {
  width: 100%;
  padding: 0 5%;
}
@media screen and (max-width: 800px) {
  header .action .tel a img {
    padding: 0;
    width: 90%;
  }
}
@media screen and (max-width: 800px) {
  header .action .tel {
    text-align: center;
  }
}

/*--top&top2--*/
#top img {
  width: 100%;
  vertical-align: middle;
}

#top2 img {
  width: 100%;
  vertical-align: middle;
}

/*--step--*/
#step_pc {
  background-color: #EBEEFF;
}
#step_pc .wrapper {
  display: flex;
  justify-content: space-between;
  padding: 5vw 0 2vw;
}
#step_pc .wrapper .container {
  width: 20vw;
  height: 25vw;
}
#step_pc .wrapper .container .label {
  background-color: #2C1F72;
  color: #FFFF02;
  font-weight: bold;
  font-size: 1.8vw;
  text-align: center;
  padding: 1vw 0;
}
#step_pc .wrapper .container .body {
  background-color: white;
  height: 23vw;
  padding: 1.2vw;
}
#step_pc .wrapper .container .body .title {
  font-weight: bold;
  font-size: 1.5vw;
  color: #2C1F72;
  text-align: center;
  margin: 2vw 0;
}
#step_pc .wrapper .container .body p {
  font-size: 1.1vw;
  font-weight: 600;
  line-height: 2vw;
}
#step_pc .wrapper .triangle {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 17px 0 17px 17px;
  border-color: transparent transparent transparent #2C1F72;
  margin: 14vw 1.5vw;
}

#step_sp {
  background-color: #EBEEFF;
}
#step_sp .wrapper {
  padding: 10vw 0 5vw;
}
#step_sp .wrapper .contain {
  display: flex;
  justify-content: center;
  margin-bottom: 15vw;
  margin-left: 5vw;
}
#step_sp .wrapper .contain .container {
  width: 80%;
}
#step_sp .wrapper .contain .container .label {
  background-color: #2C1F72;
  color: #FFFF02;
  padding: 1vw 0;
  text-align: center;
}
#step_sp .wrapper .contain .container .label p {
  font-weight: bold;
  font-size: 3vw;
}
#step_sp .wrapper .contain .container .body {
  background-color: white;
  height: 100%;
  padding: 1.2vw 3vw;
}
#step_sp .wrapper .contain .container .body .title {
  font-weight: bold;
  font-size: 3vw;
  color: #2C1F72;
  text-align: center;
  margin: 3vw 0;
}
#step_sp .wrapper .contain .container .body p {
  font-size: 2.2vw;
  font-weight: 600;
  line-height: 4.2vw;
}
#step_sp .wrapper .contain .triangle {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 17px 0 17px 17px;
  border-color: transparent transparent transparent #2C1F72;
  margin: 23vw 2vw 0;
}
#step_sp .wrapper .contain .triangle.last {
  border-color: #EBEEFF;
}

/*--cta--*/
#cta {
  background-color: #2C1F72;
}
#cta .wrapper {
  padding: 2.5vw 0 3.5vw;
}
#cta .wrapper .container {
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 800px) {
  #cta .wrapper .container {
    display: block;
  }
}
#cta .wrapper .container .soudan {
  background-color: #FFFF02;
  border-radius: 5px;
  width: 45%;
}
@media screen and (max-width: 800px) {
  #cta .wrapper .container .soudan {
    width: 100%;
  }
}
#cta .wrapper .container .soudan p {
  color: #2C1F72;
  font-weight: 800;
  font-size: 2.1vw;
  text-align: center;
  padding: 2vw 0;
  margin: 0;
}
@media screen and (max-width: 800px) {
  #cta .wrapper .container .soudan p {
    font-size: 3.5vw;
  }
}
#cta .wrapper .container .tel {
  color: white;
  width: 55%;
  text-align: center;
}
@media screen and (max-width: 800px) {
  #cta .wrapper .container .tel {
    width: 100%;
    margin: 2vw 0;
  }
}
#cta .wrapper .container .tel a {
  font-size: 4vw;
  font-weight: bold;
  text-decoration: none;
  color: white;
  letter-spacing: 0.2vw;
}
@media screen and (max-width: 800px) {
  #cta .wrapper .container .tel a {
    font-size: 7vw;
    letter-spacing: 0.5vw;
  }
}
#cta .wrapper .container .tel img {
  width: 4vw;
  margin: 2vw 2vw 0;
}
@media screen and (max-width: 800px) {
  #cta .wrapper .container .tel img {
    width: 6.2vw;
  }
}
#cta .wrapper .container .tel p {
  font-size: 1.4vw;
  font-weight: 300;
  margin-right: 5vw;
  margin-top: 0;
}
@media screen and (max-width: 800px) {
  #cta .wrapper .container .tel p {
    font-size: 2vw;
  }
}
#cta .wrapper p {
  color: white;
  font-size: 0.9vw;
  font-weight: 400;
  margin-top: 1.5vw;
  text-align: center;
}
@media screen and (max-width: 800px) {
  #cta .wrapper p {
    text-align: center;
  }
}
#cta .wrapper p br {
  display: none;
}
@media screen and (max-width: 800px) {
  #cta .wrapper p br {
    display: block;
  }
}

/*--results--*/
#results {
  background-image: url(./img/4000_bg.jpg);
  background-size: cover;
}
#results .wrapper {
  padding: 2vw 0 0;
}
#results .wrapper h2 {
  color: #2C1F72;
  font-weight: 800;
  font-size: 2.5vw;
  width: 60%;
  letter-spacing: 0.4vw;
  text-align: center;
  background: linear-gradient(transparent 70%, #FFFF02 60%);
  margin-left: 4vw;
  margin-bottom: 2vw;
}
#results .wrapper h2 span {
  color: #C3041A;
  font-size: 5.5vw;
}
@media screen and (max-width: 800px) {
  #results .wrapper h2 {
    width: 100%;
    margin: 5vw auto;
    font-size: 4.5vw;
  }
  #results .wrapper h2 span {
    font-size: 8vw;
  }
}
#results .wrapper .contain {
  display: flex;
}
@media screen and (max-width: 800px) {
  #results .wrapper .contain {
    display: block;
  }
}
#results .wrapper .contain .text {
  width: 60%;
}
@media screen and (max-width: 800px) {
  #results .wrapper .contain .text {
    width: 100%;
  }
}
#results .wrapper .contain .text .item {
  color: white;
  font-size: 2vw;
  font-weight: 800;
  background-color: #2C1F72;
  border-radius: 50px;
  text-align: center;
  padding: 1.8vw 0;
  margin: 2vw 0 0 0;
}
#results .wrapper .contain .text .item span {
  color: #FFFF02;
  font-size: 2vw;
}
@media screen and (max-width: 800px) {
  #results .wrapper .contain .text .item {
    font-size: 3.5vw;
    padding: 2vw 0;
    margin: 4vw 0 0 0;
  }
  #results .wrapper .contain .text .item span {
    font-size: 3.5vw;
  }
}
#results .wrapper .contain .text p {
  font-size: 2vw;
  font-weight: 800;
  text-align: left;
  margin-left: 6vw;
  margin-top: 3vw;
  margin-bottom: 2vw;
}
#results .wrapper .contain .text p span {
  color: #C3041A;
  font-size: 3.5vw;
}
#results .wrapper .contain .text p .pc {
  display: none;
}
@media screen and (max-width: 800px) {
  #results .wrapper .contain .text p {
    font-size: 4.5vw;
    margin-top: 5vw;
    line-height: 8.5vw;
  }
  #results .wrapper .contain .text p span {
    font-size: 7vw;
  }
  #results .wrapper .contain .text p .pc {
    display: block;
  }
}
#results .wrapper .contain .text .sp {
  background-image: url(./img/4000_man.png);
  background-size: 40%;
  background-position: right;
}
#results .wrapper .contain .text .sp p {
  padding-bottom: 5vw;
}
#results .wrapper .contain img {
  width: 40%;
}
@media screen and (max-width: 800px) {
  #results .wrapper .contain img {
    width: 35%;
  }
}

/*--needs--*/
#needs {
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 800px) {
  #needs {
    display: block;
  }
}
#needs .img {
  width: 35%;
}
#needs .img img {
  width: 100%;
  vertical-align: middle;
}
@media screen and (max-width: 800px) {
  #needs .img {
    width: 80%;
    margin: 7vw auto;
  }
  #needs .img img {
    border-radius: 20px;
  }
}
#needs .text {
  width: 65%;
  padding: 3vw;
  margin-right: 10%;
}
@media screen and (max-width: 800px) {
  #needs .text {
    width: 80%;
    margin: 0 auto;
    padding: 0;
  }
}
#needs .text p {
  color: #2C1F72;
  font-weight: bold;
  font-size: 1.6vw;
  line-height: 4vw;
}
#needs .text p span {
  background: linear-gradient(transparent 50%, #FFFF02 60%);
}
@media screen and (max-width: 800px) {
  #needs .text p {
    font-size: 3vw;
    line-height: 8vw;
    margin-bottom: 5vw;
  }
}

/*--rank--*/
#rank h2 {
  background-color: #2C1F72;
  color: white;
  font-weight: bold;
  font-size: 3vw;
  padding: 4vw 0 4vw 28vw;
}
@media screen and (max-width: 800px) {
  #rank h2 {
    font-size: 5vw;
    padding: 3vw 0 5vw 12vw;
  }
}
#rank h2 .yellow {
  color: #FFFF02;
}
#rank h2 .yellow span {
  font-size: 4.5vw;
  font-family: Arial, Helvetica, sans-serif;
}
@media screen and (max-width: 800px) {
  #rank h2 .yellow span {
    font-size: 7vw;
  }
}
#rank .triangle_bg {
  background-color: #EBEEFF;
  display: flex;
  justify-content: center;
}
#rank .triangle_bg .triangle {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 2.5vw 2.5vw 0 2.5vw;
  border-color: #2C1F72 transparent transparent transparent;
}
#rank .contain {
  background-color: #EBEEFF;
}
#rank .contain .wrapper {
  display: flex;
  padding: 4vw 0;
}
@media screen and (max-width: 800px) {
  #rank .contain .wrapper {
    display: block;
  }
}
#rank .contain .wrapper .img {
  width: 40%;
}
#rank .contain .wrapper .img img {
  width: 100%;
}
@media screen and (max-width: 800px) {
  #rank .contain .wrapper .img {
    width: 100%;
  }
}
#rank .contain .wrapper .text {
  width: 60%;
  padding: 1.2vw 0 1vw 3vw;
  font-size: 1.2vw;
  font-weight: bold;
  color: #2C1F72;
  line-height: 2.2vw;
}
@media screen and (max-width: 800px) {
  #rank .contain .wrapper .text {
    width: 100%;
    font-size: 3.2vw;
    line-height: 8vw;
    margin-top: 3vw;
  }
}
#rank .contain .wrapper .text p .red {
  color: #C3041A;
}
#rank .contain .wrapper .text p span {
  background: linear-gradient(transparent 50%, #FFFF02 60%);
}

/*--history--*/
#history {
  background-color: #2C1F72;
  padding-bottom: 5vw;
}
#history h2 {
  color: white;
  font-weight: bold;
  font-size: 3vw;
  margin: 0 10% 0.7vw;
  text-align: center;
  padding: 5vw 0 1vw;
}
#history h2 br {
  display: none;
}
@media screen and (max-width: 800px) {
  #history h2 {
    font-size: 5vw;
    padding: 10vw 0 2vw;
  }
  #history h2 br {
    display: block;
  }
}
#history .border {
  margin: 0 auto 4vw;
  width: 8vw;
  height: 0.3vw;
  background: #FFFF02;
}
#history .container {
  display: flex;
}
@media screen and (max-width: 800px) {
  #history .container {
    display: block;
  }
}
#history .container .text {
  width: 40%;
  margin: 0 2vw 0 10%;
  color: white;
  font-weight: bold;
  font-size: 1.5vw;
  line-height: 3.4vw;
}
@media screen and (max-width: 800px) {
  #history .container .text {
    width: auto;
    margin: 10vw 5vw 12vw;
  }
}
#history .container .text p span {
  color: #FFFF02;
}
@media screen and (max-width: 800px) {
  #history .container .text p {
    font-size: 3.2vw;
    line-height: 8vw;
  }
}
#history .container .img {
  width: 60%;
}
#history .container .img img {
  width: 100%;
}
@media screen and (max-width: 800px) {
  #history .container .img {
    width: 100%;
  }
}

/*--license--*/
#license {
  background-color: #2C1F72;
  padding-bottom: 5vw;
}
#license h2 {
  color: white;
  font-weight: bold;
  font-size: 3vw;
  margin: 0 10% 0.7vw;
  text-align: center;
  padding: 5vw 0 1vw;
}
#license h2 br {
  display: none;
}
@media screen and (max-width: 800px) {
  #license h2 {
    font-size: 5vw;
    padding: 5vw 0 2vw;
  }
  #license h2 br {
    display: block;
  }
}
#license .border {
  margin: 0 auto 4vw;
  width: 8vw;
  height: 0.3vw;
  background: #FFFF02;
}
#license .container {
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 800px) {
  #license .container {
    display: block;
  }
}
#license .container .img {
  width: 30%;
  text-align: right;
}
#license .container .img img {
  width: 60%;
}
@media screen and (max-width: 800px) {
  #license .container .img {
    width: 100%;
    text-align: center;
    margin: 8vw 0 0;
  }
  #license .container .img img {
    width: 50%;
  }
}
#license .container .text {
  width: 65%;
  margin-left: 5vw;
  color: white;
  font-weight: bold;
  font-size: 1.5vw;
  line-height: 3.4vw;
}
@media screen and (max-width: 800px) {
  #license .container .text {
    width: auto;
    margin: 4vw 0 5vw;
  }
}
#license .container .text p span {
  color: #FFFF02;
}
@media screen and (max-width: 800px) {
  #license .container .text p {
    font-size: 3.2vw;
    line-height: 8vw;
  }
}

/*--quality--*/
#quality {
  width: 100%;
}
#quality .c-video {
  position: relative;
  width: 100%;
  background: rgba(0, 0, 0, 0.3);
  -webkit-backdrop-filter: blur(5px);
          backdrop-filter: blur(5px);
}
#quality .c-video__title {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 10;
  transform: translate(-50%, -50%);
  padding: 30px;
  text-align: center;
  font-size: 1.8vw;
  font-weight: bold;
  line-height: 4.5vw;
  white-space: nowrap;
  color: white;
  text-align: left;
}
#quality .c-video__title span {
  font-size: 2.5vw;
}
@media screen and (max-width: 800px) {
  #quality .c-video__title {
    font-size: 3vw;
    line-height: 7vw;
    margin: 0;
    padding: 0;
    width: 80%;
  }
  #quality .c-video__title span {
    font-size: 5vw;
  }
}
#quality .c-video a {
  background-color: #2C1F72;
  color: white;
  font-size: 1.4vw;
  font-weight: bold;
  text-decoration: none;
  text-align: center;
  z-index: 11;
  position: absolute;
  top: 66%;
  left: 66%;
  padding: 1.2vw 1.8vw;
}
@media screen and (max-width: 800px) {
  #quality .c-video a {
    top: 80%;
    left: 70%;
  }
}
#quality .c-video__embed {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

/*--example--*/
#example {
  background-color: #EBEEFF;
  padding-bottom: 7vw;
}
#example .wrapper h2 {
  color: #2C1F72;
  font-weight: bold;
  font-size: 3vw;
  margin: 0 10% 0.7vw;
  text-align: center;
  padding: 5vw 0 1vw;
}
#example .wrapper h2 br {
  display: none;
}
@media screen and (max-width: 800px) {
  #example .wrapper h2 {
    font-size: 5vw;
    padding: 10vw 0 2vw;
  }
  #example .wrapper h2 br {
    display: block;
  }
}
#example .wrapper .border {
  margin: 0 auto 4vw;
  width: 8vw;
  height: 0.3vw;
  background: #FFFF02;
}
#example .wrapper .container {
  background-color: white;
  margin-bottom: 3.2vw;
  padding: 3vw 3vw 2vw 3vw;
  box-shadow: 5px 5px 10px -5px rgba(0, 0, 0, 0.3);
}
@media screen and (max-width: 800px) {
  #example .wrapper .container {
    padding: 5vw 3vw 4vw 3vw;
  }
}
#example .wrapper .container .title {
  border-left: 5px solid #FFFF02;
  padding-left: 1vw;
}
#example .wrapper .container .title h3 {
  font-size: 2vw;
}
@media screen and (max-width: 800px) {
  #example .wrapper .container .title h3 {
    font-size: 3.5vw;
  }
}
#example .wrapper .container .title h4 {
  font-size: 1.5vw;
}
@media screen and (max-width: 800px) {
  #example .wrapper .container .title h4 {
    font-size: 2.5vw;
  }
}
#example .wrapper .container .image {
  display: flex;
  width: 100%;
  margin-top: 3vw;
  justify-content: space-between;
}
@media screen and (max-width: 800px) {
  #example .wrapper .container .image {
    display: block;
  }
}
#example .wrapper .container .image .box {
  width: 25%;
}
@media screen and (max-width: 800px) {
  #example .wrapper .container .image .box {
    width: 100%;
    height: 60%;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
#example .wrapper .container .image .box p {
  font-weight: bold;
  font-size: 1.2vw;
  margin: 0 0 0.5vw 0.5vw;
}
@media screen and (max-width: 800px) {
  #example .wrapper .container .image .box p {
    font-size: 3vw;
    margin: 0 0 1vw 1vw;
  }
}
#example .wrapper .container .image .box img {
  width: 100%;
}
@media screen and (max-width: 800px) {
  #example .wrapper .container .image .box img {
    height: 60%;
  }
}
#example .wrapper .container .image .triangle {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 30px 0 30px 30px;
  border-color: transparent transparent transparent #FFFFAC;
  margin: 8vw auto;
}
@media screen and (max-width: 800px) {
  #example .wrapper .container .image .triangle {
    border-top: 50px solid #FFFFAC;
    border-right: 50px solid transparent;
    border-left: 50px solid transparent;
    margin: 1vw auto;
  }
}
#example .wrapper .container .image .none {
  border-color: transparent transparent transparent white;
}
@media screen and (max-width: 800px) {
  #example .wrapper .container .image .none {
    display: none;
  }
}

/*--flow--*/
#flow {
  background-color: #2C1F72;
  padding: 1.5vw 0 10vw;
}
#flow h2 {
  color: white;
  font-weight: bold;
  font-size: 3vw;
  margin: 0 10% 0.7vw;
  text-align: center;
  padding: 5vw 0 1vw;
}
#flow h2 br {
  display: none;
}
@media screen and (max-width: 800px) {
  #flow h2 {
    font-size: 5vw;
    padding: 10vw 0 2vw;
  }
  #flow h2 br {
    display: block;
  }
}
#flow .border {
  margin: 0 auto 4vw;
  width: 8vw;
  height: 0.3vw;
  background: #FFFF02;
}
#flow .wrapper {
  background-color: white;
}
#flow .wrapper .box {
  padding: 4vw;
}
@media screen and (max-width: 800px) {
  #flow .wrapper .box {
    padding: 8vw 8vw 2vw;
  }
}
#flow .wrapper .box .step {
  display: flex;
  align-items: center;
  line-height: 3vw;
  margin-bottom: 3vw;
}
@media screen and (max-width: 800px) {
  #flow .wrapper .box .step {
    display: block;
    text-align: center;
  }
}
#flow .wrapper .box .step img {
  margin-right: 2vw;
  width: auto;
}
@media screen and (max-width: 800px) {
  #flow .wrapper .box .step img {
    width: 60%;
    margin: 0 auto;
  }
}
@media screen and (max-width: 800px) {
  #flow .wrapper .box .step .text {
    margin: 5vw 0 10vw;
  }
}
#flow .wrapper .box .step .text span {
  color: #2C1F72;
  font-weight: 500;
  font-size: 1.4vw;
}
@media screen and (max-width: 800px) {
  #flow .wrapper .box .step .text span {
    font-size: 4vw;
  }
}
#flow .wrapper .box .step .text h3 {
  color: #151515;
  font-weight: bold;
  font-size: 2vw;
}
@media screen and (max-width: 800px) {
  #flow .wrapper .box .step .text h3 {
    font-size: 5vw;
    margin: 5vw 0;
  }
}
#flow .wrapper .box .step .text p {
  font-size: 1.2vw;
  line-height: 2vw;
  margin-top: 1.2vw;
  font-weight: 400;
}
@media screen and (max-width: 800px) {
  #flow .wrapper .box .step .text p {
    text-align: left;
    font-size: 3vw;
    line-height: 6vw;
    margin-bottom: 5vw;
  }
}

/*--store--*/
#store {
  background-image: url(./img/store_bg.png);
  background-size: cover;
}
@media screen and (max-width: 800px) {
  #store {
    background-image: url(./img/store_bg_sp.jpg);
    padding-bottom: 8vw;
  }
}
#store h2 {
  color: white;
  font-weight: bold;
  font-size: 2.7vw;
  margin: 0 10% 0.7vw;
  text-align: center;
  padding: 5vw 0 1vw;
}
#store h2 span {
  color: #C3041A;
  font-size: 4.5vw;
  text-shadow: 0.5px 0.5px 0px white, -0.5px -0.5px 0px white, -0.5px 0.5px 0px white, 0.5px -0.5px 0px white, 0.5px 0px 0px white, -0.5px 0px 0px white, 0px 0.5px 0px white, 0px -0.5px 0px white;
}
@media screen and (max-width: 800px) {
  #store h2 span {
    font-size: 7vw;
  }
}
@media screen and (max-width: 800px) {
  #store h2 {
    font-size: 5vw;
    padding: 10vw 0 2vw;
  }
  #store h2 br {
    display: block;
  }
}
#store .border {
  margin: 0 auto 4vw;
  width: 8vw;
  height: 0.3vw;
  background: #FFFF02;
}
#store .container {
  display: flex;
}
@media screen and (max-width: 800px) {
  #store .container {
    display: block;
  }
}
#store .container div {
  width: 42%;
}
@media screen and (max-width: 800px) {
  #store .container div {
    width: 0%;
  }
}
#store .container .box {
  width: 58%;
  background-color: white;
  padding: 5vw;
}
@media screen and (max-width: 800px) {
  #store .container .box {
    display: block;
    width: 80%;
    margin: 0 auto;
  }
}
#store .container .box .list {
  width: 100%;
}
#store .container .box .list:first-child {
  margin-bottom: 2vw;
}
#store .container .box .list h3 {
  background-color: #2C1F72;
  color: white;
  font-weight: bold;
  font-size: 1.6vw;
  padding: 0.5vw 1vw;
  width: 30%;
  letter-spacing: 0.4vw;
  text-align: center;
}
@media screen and (max-width: 800px) {
  #store .container .box .list h3 {
    font-size: 2.8vw;
  }
}
#store .container .box .list ul {
  padding: 1vw 2vw 1.5vw 4vw;
  border: solid 1px #2C1F72;
}
@media screen and (max-width: 800px) {
  #store .container .box .list ul {
    padding: 3vw 3vw 4vw 6vw;
  }
}
#store .container .box .list ul li {
  font-size: 1.4vw;
  font-weight: 400;
  margin-top: 0.8vw;
}
@media screen and (max-width: 800px) {
  #store .container .box .list ul li {
    font-size: 2.5vw;
  }
}

/*--voice--*/
#voice {
  background-image: url(./img/voice_bg.jpg);
  background-size: cover;
  padding-bottom: 5vw;
}
#voice .wrapper h2 {
  color: #2C1F72;
  font-weight: bold;
  font-size: 2.7vw;
  margin: 0 10% 0.7vw;
  text-align: center;
  padding: 5vw 0 1vw;
}
@media screen and (max-width: 800px) {
  #voice .wrapper h2 {
    font-size: 5vw;
    padding: 10vw 0 2vw;
  }
}
#voice .wrapper .border {
  margin: 0 auto 4vw;
  width: 8vw;
  height: 0.3vw;
  background: #FFFF02;
}
#voice .wrapper .container {
  display: flex;
  justify-content: space-around;
}
@media screen and (max-width: 800px) {
  #voice .wrapper .container {
    display: block;
  }
}
#voice .wrapper .container .title-box {
  margin: 1em 0;
  padding: 2vw 4vw 3vw;
  position: relative;
  background-color: white;
  width: 42%;
  text-align: center;
  box-shadow: 12px 12px #2C1F72;
}
@media screen and (max-width: 800px) {
  #voice .wrapper .container .title-box {
    box-shadow: 7px 7px #2C1F72;
    width: 80%;
    margin: 5vw auto 10vw;
    padding: 2vw 4vw 7vw;
  }
}
#voice .wrapper .container .title-box-title {
  position: absolute;
  top: -0.8em;
  left: 40%;
  font-weight: bold;
  font-size: 1.3vw;
  background-color: #2C1F72;
  color: white;
  padding: 0.2vw 2vw;
}
@media screen and (max-width: 800px) {
  #voice .wrapper .container .title-box-title {
    font-size: 3vw;
  }
}
#voice .wrapper .container .title-box p {
  margin: 0;
  padding: 0;
  text-align: left;
  font-size: 1.2vw;
  font-weight: 500;
  line-height: 2.5vw;
}
#voice .wrapper .container .title-box p span {
  background: linear-gradient(transparent 50%, #FFFF02 60%);
}
@media screen and (max-width: 800px) {
  #voice .wrapper .container .title-box p {
    font-size: 3vw;
    line-height: 5vw;
  }
}
#voice .wrapper .container img {
  width: 25%;
  margin: 2vw 0 1.5vw;
}
@media screen and (max-width: 800px) {
  #voice .wrapper .container img {
    margin: 7vw 0 1.5vw;
  }
}

/*--shop--*/
#shop .wrapper h2 {
  color: #2C1F72;
  font-weight: bold;
  font-size: 2.7vw;
  margin: 0 10% 0.7vw;
  text-align: center;
  padding: 5vw 0 1vw;
}
@media screen and (max-width: 800px) {
  #shop .wrapper h2 {
    font-size: 5vw;
    padding: 10vw 0 2vw;
  }
}
#shop .wrapper .border {
  margin: 0 auto;
  width: 8vw;
  height: 0.3vw;
  background: #FFFF02;
}
#shop .wrapper .shop_main {
  display: flex;
  background-image: url(./img/shop_bg.jpg);
  background-position: bottom;
  background-size: cover;
  height: 42vw;
}
@media screen and (max-width: 800px) {
  #shop .wrapper .shop_main {
    display: block;
    background-image: none;
    height: 100%;
  }
}
#shop .wrapper .shop_main div {
  width: 55%;
}
@media screen and (max-width: 800px) {
  #shop .wrapper .shop_main div {
    width: 0%;
  }
}
#shop .wrapper .shop_main .text {
  background-color: white;
  width: 45%;
  height: 75%;
  padding: 4vw 3vw 4vw 0;
}
@media screen and (max-width: 800px) {
  #shop .wrapper .shop_main .text {
    width: 100%;
    background-color: white;
    height: auto;
    padding: 8vw 1vw 5vw;
  }
}
#shop .wrapper .shop_main .text h3 {
  font-size: 2.2vw;
  margin-bottom: 3vw;
}
@media screen and (max-width: 800px) {
  #shop .wrapper .shop_main .text h3 {
    font-size: 4vw;
    margin-bottom: 5vw;
  }
}
#shop .wrapper .shop_main .text dl {
  display: flex;
  flex-wrap: wrap;
  font-size: 1.5vw;
  line-height: 2.7vw;
}
@media screen and (max-width: 800px) {
  #shop .wrapper .shop_main .text dl {
    font-size: 2.7vw;
    line-height: 7vw;
  }
}
#shop .wrapper .shop_main .text dl dt {
  width: 30%;
  font-weight: bold;
}
#shop .wrapper .shop_main .text dl dd {
  width: 70%;
  font-weight: 500;
}
#shop .wrapper .shop_main .text p {
  font-size: 1.2vw;
  font-weight: 500;
  margin-top: 1.5vw;
  line-height: 1.8vw;
}
@media screen and (max-width: 800px) {
  #shop .wrapper .shop_main .text p {
    font-size: 2.4vw;
    line-height: 5vw;
  }
}
#shop .wrapper .shop_main .sp {
  width: 100%;
}
#shop .wrapper .shop_main .sp img {
  width: 100%;
  margin-bottom: 2vw;
}

/*--footer--*/
footer {
  background-color: #2C1F72;
  color: white;
  text-align: center;
  padding: 1vw 0;
}/*# sourceMappingURL=style.css.map */