@charset "utf-8";
@import url(init.css);

:root {
  --viewport: 750;
  --gold: #BAA170;
  --blue: #CEE3F8;
}
@media screen and (min-width:768px) {
  :root {
    --viewport: 1518;
  }
}

img {
  height: auto;
}
.font-oswald {
  font-family: 'Oswald', sans-serif;
  font-weight: normal;
}
.font_gold {
  color: var(--gold);
}
.font_white {
  color: #fff;
}
.fw_medium {
  font-weight: 500;
}
.bg_white {
  background: #fff !important;
}
.bg_black {
  background: #000;
}
.bg_gray {
  background: #3C3A39;
}
.relative {
  position: relative;
}
.flex {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.zoomIn.is-animated {
  animation: zoomIn 0.8s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}
@keyframes zoomIn {
  0% {
    transform: scale(0.8);
    opacity: 0;
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

.cta {
  font-weight: bold;
  text-align: center;
  background: #e8e8e8;
  padding: calc(100vw / var(--viewport) * 80) 0;
  position: relative;
}
.cta a {
  color: #fff;
  font-size: calc(100vw / var(--viewport) * 28);
  text-align: center;
  background: #741519;
  width: calc(100vw / var(--viewport) * 602);
  height: calc(100vw / var(--viewport) * 108);
  display: flex;
  justify-content: center;
  align-items: center;
  border: calc(100vw / var(--viewport) * 6) solid #fff;
  border-radius: calc(100vw / var(--viewport) * 14);
  margin: 0 auto;
  box-shadow: calc(100vw / var(--viewport) * 5) calc(100vw / var(--viewport) * 5) 0 #BFBFBF;
  animation: zoom infinite 2.2s;
}
@keyframes zoom {
  0% {
    scale: 1;
  }
  50% {
    scale: 1.1;
  }
  100% {
    scale: 1;
  }
}
@media screen and (min-width:1518px) {
  .cta {
    padding: 80px 0;
  }
  .cta a {
    font-size: 28px;
    width: 602px;
    height: 108px;
    border: 6px solid #fff;
    border-radius: 14px;
    box-shadow: 5px 5px 0 #BFBFBF;
  }
}

body {
  font-family: "Noto Sans JP", system-ui, -apple-system, "Hiragino Sans", "Segoe UI", "Meiryo", sans-serif;
  font-weight: 400;
}

#header {
  width: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 2;
}
#header .logo {
  width: calc(100vw / var(--viewport) * 74);
  margin-right: calc(100vw / var(--viewport) * 27);
}
#header .name {
  width: calc(100vw / var(--viewport) * 406);
}
@media screen and (max-width:767px) {
  #header {
    background: #000;
  }
  #header .flex {
    justify-content: flex-start;
    align-items: center;
  }
  #header .logo {
    margin-top: calc(100vw / var(--viewport) * 14);
    margin-left: calc(100vw / var(--viewport) * 13);
  }
}
@media screen and (min-width: 768px) {
  #header .logo {
    display: none;
  }
  #header .name {
    width: 24%;
    min-width: 300px;
    max-width: 462px;
    position: absolute;
    top: 30px;
    left: 30px;
  }
}

@media screen and (max-width:767px) {
  .pcMenu {
    display: none;
  }
}
@media screen and (min-width:768px) {
  .pcMenu {
    position: fixed;
    top: 70px;
    left: 4%;
  }
  .pcMenu p {
    color: #fff;
    font-size: 34px;
    font-weight: 500;
  }
  .pcMenu li {
    margin-top: 7px;
  }
  .pcMenu a {
    color: #fff;
    display: flex;
    align-items: stretch;
  }
  .pcMenu a span.number {
    color: #000;
    font-size: calc(100vw / var(--viewport) * 26);
    font-weight: 500;
    width: calc(100vw / var(--viewport) * 35);
    height: calc(100vw / var(--viewport) * 35);
    background: var(--gold);
    border: 1px solid var(--gold);
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .pcMenu a span.text {
    font-size: calc(100vw / var(--viewport) * 18);
    border: 1px solid #fff;
    border-left: none;
    width: 100%;
    padding: 0 25px;
    display: flex;
    justify-content: flex-start;
    align-items: center;
  }
}
@media screen and (min-width:1518px) {
  .pcMenu {
    top: 90px;
  }
  .pcMenu li {
    margin-top: 9px;
  }
  .pcMenu a span.number {
    font-size: 26px;
    width: 38px;
    height: 38px;
  }
  .pcMenu a span.text {
    font-size: 19px;
  }
}

#wrapper {
  background: #E8E8E8;
  width: 100%;
  margin: 0 auto;
}
#wrapper:before,
#wrapper:after {
  content: "";
  display: inline-block;
  width: 1px;
  height: 100%;
  position: fixed;
  top: 0;
  z-index: 3;
}
#wrapper:before {
  border-left: 1px solid var(--gold);
  left: 0;
}
#wrapper:after {
  border-right: 1px solid var(--gold);
  right: 0;
}
@media screen and (min-width: 768px) {
  #wrapper {
    width: 50%;
    max-width: 750px;
    position: absolute;
    top: 0;
    left: 50%;
  }
  #wrapper:before,
  #wrapper:after {
    position: absolute;
  }
}
#wrapper.no-events {
  pointer-events: none;
}

#mv {
  background: url(../img/mv/mv_sp.webp) top center no-repeat, #000;
  background-size: 100% auto;
  height: calc(100vw / var(--viewport) * 1039);
  position: relative;
  border-bottom: 6px solid var(--gold);
}
#mv video {
  width: 100%;
  height: auto;
  position: absolute;
  left: 0;
  top: 0;
}
#mv h1 img {
  width: calc(100vw / var(--viewport) * 417);
  margin: calc(100vw / var(--viewport) * 40) 0 0 calc(100vw / var(--viewport) * 24);
  opacity: 0;
}
#mv #img_mv01 img {
  width: calc(100vw / var(--viewport) * 294);
  margin: calc(100vw / var(--viewport) * 20) 0 0 calc(100vw / var(--viewport) * 32);
  opacity: 0;
}
#mv #counter {
  color: #fff;
  text-align: center;
  position: absolute;
  left: 0;
  right: 0;
  bottom: calc(100vw / var(--viewport) * 20);
  margin: 0 auto;
}
#mv #counter .midashi {
  font-size: calc(100vw / var(--viewport) * 30);
  margin-bottom: 0.2em;
}
#mv #counter .counter {
  font-size: calc(100vw / var(--viewport) * 43);
  font-weight: 500;
}
#mv #counter .counter img {
  height: calc(100vw / var(--viewport) * 65);
}
#mv #counter .odometer.odometer-auto-theme {
  color: var(--gold);
  font-size: calc(100vw / var(--viewport) * 70);
  font-weight: bold;
  background: none;
  padding: 0;
}
#mv #counter .odometer.odometer-auto-theme .odometer-inside {
  line-height: 1;
}
#mv #counter .odometer.odometer-auto-theme .odometer-digit {
  background: none;
  box-shadow: none;
  padding: 0 0.08em;
}
#mv #counter .odometer.odometer-auto-theme .odometer-digit:last-child {
  color: var(--gold);
}
#mv #counter .period {
  font-size: calc(100vw / var(--viewport) * 21);
}
@media screen and (min-width:1518px) {
  #mv {
    height: 1039px;
  }
  #mv h1 img {
    width: 417px;
    margin: 40px 0 0 24px;
  }
  #mv #img_mv01 img {
    width: 294px;
    margin: 20px 0 0 32px;
  }
  #mv #counter {
    bottom: 20px;
  }
  #mv #counter .midashi {
    font-size: 30px;
  }
  #mv #counter .counter {
    font-size: 43px;
  }
  #mv #counter .counter img {
    height: 65px;
  }
  #mv #counter .odometer.odometer-auto-theme {
    font-size: 70px;
  }
  #mv #counter .period {
    font-size: 21px;
  }
}

.bannerArea {
  background: #646464;
  padding: calc(100vw / var(--viewport) * 44) 0 0;
}
.bannerArea .button {
  padding: calc(100vw / var(--viewport) * 60) 0;
}
.bannerArea .button a {
  color: #000;
  font-size: calc(100vw / var(--viewport) * 29);
  background: #BBA171;
  width: calc(100vw / var(--viewport) * 452);
  height: calc(100vw / var(--viewport) * 85);
  display: flex;
  justify-content: center;
  align-items: center;
  border: calc(100vw / var(--viewport) * 4) solid #fff;
  border-radius: calc(100vw / var(--viewport) * 10);
  margin: 0 auto;
}
@media screen and (min-width:1518px) {
  .bannerArea {
    padding: 44px 0 0;
  }
  .bannerArea .button {
    padding: 60px 0;
  }
  .bannerArea .button a {
    font-size: 29px;
    width: 452px;
    height: 85px;
    border: 4px solid #fff;
    border-radius: 10px;
  }
}

section .inner {
  padding-left: calc(100vw / var(--viewport) * 22);
  padding-right: calc(100vw / var(--viewport) * 22);
}
@media screen and (min-width:1518px) {
  section .inner {
    padding-left: 22px;
    padding-right: 22px;
  }
}

.midashiBox {
  width: 100%;
  height: calc(100vw / var(--viewport) * 106);
  background: #000;
  display: flex;
  justify-content: flex-start;
}
.midashiBox .number {
  font-size: calc(100vw / var(--viewport) * 64);
  font-weight: 500;
  background: var(--gold);
  width: calc(100vw / var(--viewport) * 106);
  display: flex;
  justify-content: center;
  align-items: center;
}
.midashiBox h2 {
  color: #fff;
  font-size: calc(100vw / var(--viewport) * 31);
  font-weight: bold;
  width: calc(100% - calc(100vw / var(--viewport) * 64));
  display: flex;
  justify-content: flex-start;
  align-items: center;
  padding-left: calc(100vw / var(--viewport) * 41);
}
@media screen and (min-width:1518px) {
  .midashiBox {
    height: 106px;
  }
  .midashiBox .number {
    font-size: 64px;
    width: 106px;
  }
  .midashiBox h2 {
    font-size: 31px;
    width: calc(100% - 64px);
    padding-left: 41px;
  }
}

.lead {
  color: #fff;
  text-align: center;
  padding: calc(100vw / var(--viewport) * 35) calc(100vw / var(--viewport) * 22) calc(100vw / var(--viewport) * 53);
  position: relative;
}
.lead h3 {
  line-height: 1.5;
  margin-bottom: calc(100vw / var(--viewport) * 30);
}
.lead h3 .sub {
  font-size: calc(100vw / var(--viewport) * 32);
}
.lead h3 .h3 {
  font-size: calc(100vw / var(--viewport) * 44);
}
.lead .text {
  font-size: calc(100vw / var(--viewport) * 26);
}
.lead .after {
  font-size: calc(100vw / var(--viewport) * 41);
  font-weight: bold;
  position: absolute;
  left: 0;
  right: 0;
  bottom: calc(100vw / var(--viewport) * -58);
  z-index: 1;
}
.lead .after:after {
  content: '';
  position: absolute;
  top: calc(100vw / var(--viewport) * 7);
  left: 0;
  right: 0;
  margin: 0 auto;
  width: calc(100vw / var(--viewport) * 255);
  height: calc(100vw / var(--viewport) * 100);
  background: #3C3A39;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  pointer-events: none;
  z-index: -1;
}
@media screen and (min-width:1518px) {
  .lead {
    padding: 35px 22px 53px;
  }
  .lead h3 {
    margin-bottom: 30px;
  }
  .lead h3 .sub {
    font-size: 32px;
  }
  .lead h3 .h3 {
    font-size: 44px;
  }
  .lead .text {
    font-size: 26px;
  }
  .lead .after {
    font-size: 41px;
    bottom: -58px;
  }
  .lead .after:after {
    top: 7px;
    width: 255px;
    height: 100px;
  }
}

#sec01 {
  padding: 0 0 calc(100vw / var(--viewport) * 84);
  margin: 0 0 calc(100vw / var(--viewport) * 50);
}
#sec01 .lead {
  margin-bottom: calc(100vw / var(--viewport) * 102);
}
#sec01 .img01,
#sec01 .img02,
#sec01 .img03 {
  margin-top: calc(100vw / var(--viewport) * 7);
  padding-bottom: calc(100vw / var(--viewport) * 23);
}
#sec01 .image {
  width: 100%;
  height: calc(100vw / var(--viewport) * 400);
  position: relative;
}
#sec01 .image:after {
  content: "";
  background: #fff;
  width: 100%;
  height: calc(100vw / var(--viewport) * 400);
  position: absolute;
  top: 0;
  left: 0;
  transition: 0s all .2s;
  opacity: 0;
}
#sec01 .img02 .image {
  height: calc(100vw / var(--viewport) * 391);
}
#sec01 .img02 .image:after {
  height: calc(100vw / var(--viewport) * 391);
}
#sec01 .image img {
  transition: 0s all .8s;
  opacity: 0;
}
#sec01 .image.active img {
  opacity: 1;
}
#sec01 .image.active:after {
  animation: passbar 1s ease .2s 1 normal forwards;
  opacity: 1;
}
@keyframes passbar {
    0% {
        left: 0;
        width: 0
    }

    60% {
        left: 0;
        width: 100.1%
    }

    100% {
        left: 100%;
        width: 0
    }
}
#sec01 .nayami {
  color: #fff;
  font-size: calc(100vw / var(--viewport) * 40);
  font-weight: bold;
  text-align: center;
  margin-bottom: calc(100vw / var(--viewport) * 22);
}
#sec01 .nayami:after {
  content: '';
  display: block;
  width: calc(100vw / var(--viewport) * 72);
  height: calc(100vw / var(--viewport) * 35);
  background: #fff;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  margin: calc(100vw / var(--viewport) * 8) auto 0;
}
#sec01 .imgBox {
  position: relative;
}
#sec01 .imgBox .case {
  width: calc(100vw / var(--viewport) * 532);
  position: absolute;
  left: calc(100vw / var(--viewport) * 31);
  bottom: 0;
}
#sec01 .imgBox .img05 {
  width: calc(100vw / var(--viewport) * 320);
  position: absolute;
  top: calc(100vw / var(--viewport) * 60);
  right: calc(100vw / var(--viewport) * 28);
  opacity: 0;
}
@media screen and (min-width:1518px) {
  #sec01 {
    padding: 0 0 84px;
    margin: 0 0 50px;
  }
  #sec01 .lead {
    margin-bottom: 102px;
  }
  #sec01 .img01,
  #sec01 .img02,
  #sec01 .img03 {
    margin-top: 1px;
    padding-bottom: 23px;
  }
  #sec01 .image {
    height: 400px;
  }
  #sec01 .image:after {
    height: 400px;
  }
  #sec01 .img02 .image {
    height: 391px;
  }
  #sec01 .img02 .image:after {
    height: 391px;
  }
  #sec01 .nayami {
    font-size: 40px;
    margin-bottom: 22px;
  }
  #sec01 .nayami:after {
    width: 72px;
    height: 35px;
    margin: 8px auto 0;
  }
  #sec01 .imgBox .case {
    width: 532px;
    left: 31px;
  }
  #sec01 .imgBox .img05 {
    width: 320px;
    top: 60px;
    right: 28px;
  }
}

#sec02 {
  padding: 0 0 calc(100vw / var(--viewport) * 84);
}
#sec02 .imgBox {
  position: relative;
}
#sec02 .imgBox p {
  color: #fff;
  font-size: calc(100vw / var(--viewport) * 27);
  font-weight: bold;
  text-align: center;
  position: absolute;
  top: calc(100vw / var(--viewport) * 28);
  left: 0;
  right: 0;
  margin: 0 auto;
}
#sec02 .videobBox {
  background: #000;
}
#sec02 video {
  width: 100%;
}
@media screen and (min-width:1518px) {
  #sec02 {
    padding: 0 0 84px;
  }
  #sec02 .imgBox p {
    font-size: 27px;
    top: 28px;
  }
}

.type {
  padding: 0 0 calc(100vw / var(--viewport) * 82);
}
.type .flex {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.type .flex li {
  width: calc(100vw / var(--viewport) * 331);
}
.type .flex li:nth-child(n+3) {
  margin-top: calc(100vw / var(--viewport) * 30);
}
.type .flex li img {
  width: calc(100vw / var(--viewport) * 309);
  display: block;
  margin: 0 auto;
}
.type .flex li figcaption {
  color: var(--gold);
  font-size: calc(100vw / var(--viewport) * 24);
  font-weight: bold;
  text-align: center;
  width: 100%;
  height: calc(100vw / var(--viewport) * 43);
  background: #000;
  display: flex;
  justify-content: center;
  align-items: center;
}
.type .flex li .text {
  font-size: calc(100vw / var(--viewport) * 22);
  width: calc(100vw / var(--viewport) * 309);
  margin: calc(100vw / var(--viewport) * 14) auto 0;
}
@media screen and (min-width:1518px) {
  .type {
    padding: 0 0 82px;
  }
  .type .flex li {
    width: 331px;
  }
  .type .flex li:nth-child(n+3) {
    margin-top: 30px;
  }
  .type .flex li img {
    width: 309px;
  }
  .type .flex li figcaption {
    font-size: 24px;
    height: 43px;
  }
  .type .flex li .text {
    font-size: 22px;
    width: 309px;
    margin: 14px auto 0;
  }
}

#sec03 {
  margin: 0 0 calc(100vw / var(--viewport) * 50);
}
#sec03 .lead {
  color: #000;
}
#sec03 .lead h3 {
  margin-bottom: 0;
}
#sec03 .tabs {
  width: calc(100vw / var(--viewport) * 625);
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin: 0 auto;
}
#sec03 .tabs li {
  width: 30.56%;
}
#sec03 .tabs li.active {
  width: 36.8%;
}
#sec03 .tabs li:not(.active) {
  cursor: pointer;
}
#sec03 .bodys .box {
  background: #000;
  padding: calc(100vw / var(--viewport) * 32) calc(100vw / var(--viewport) * 30) calc(100vw / var(--viewport) * 76);
}
#sec03 .bodys .box:nth-child(n+2) {
  display: none;
}
#sec03 .bodys .box .flex figure {
  width: 50%;
}
#sec03 .bodys .box .flex figcaption {
  font-size: calc(100vw / var(--viewport) * 28);
  font-weight: bold;
  text-align: center;
  width: 100%;
  height: calc(100vw / var(--viewport) * 56);
  display: flex;
  justify-content: center;
  align-items: center;
}
#sec03 .bodys .box .flex figure:nth-child(1) figcaption {
  background: #9F9592;
}
#sec03 .bodys .box .flex figure:nth-child(2) figcaption {
  background: #BAA171;
}
#sec03 .bodys .box .text {
  color: #fff;
  font-size: calc(100vw / var(--viewport) * 22);
  margin-top: calc(100vw / var(--viewport) * 42);
}
@media screen and (min-width:1518px) {
  #sec03 {
    margin: 0 0 50px;
  }
  #sec03 .tabs {
    width: 625px;
  }
  #sec03 .bodys .box {
    padding: 32px 30px 76px;
  }
  #sec03 .bodys .box .flex figcaption {
    font-size: 28px;
    height: 56px;
  }
  #sec03 .bodys .box .text {
    font-size: 22px;
    margin-top: 42px;
  }
}

#sec04 .points {
  width: calc(100vw / var(--viewport) * 706);
  display: flex;
  justify-content: space-between;
  margin: calc(100vw / var(--viewport) * 22) auto 0;
}
#sec04 .points li {
  text-align: center;
  width: 31%;
}
#sec04 .points li .title {
  color: var(--gold);
  font-size: calc(100vw / var(--viewport) * 39);
  font-weight: bold;
  background: #000;
  height: calc(100vw / var(--viewport) * 73);
  display: flex;
  justify-content: center;
  align-items: center;
}
#sec04 .points li .con {
  color: #fff;
  font-size: calc(100vw / var(--viewport) * 18);
  font-weight: 500;
  line-height: 1.44;
  background: #646464;
  height: calc(100vw / var(--viewport) * 108);
  display: flex;
  justify-content: center;
  align-items: center;
}
#sec04 .box {
  color: #fff;
  background: #000;
  padding: calc(100vw / var(--viewport) * 36) calc(100vw / var(--viewport) * 30) calc(100vw / var(--viewport) * 54);
  position: relative;
}
#sec04 .box01 {
  margin-top: calc(100vw / var(--viewport) * 128);
}
#sec04 .box02,
#sec04 .box03 {
  margin-top: calc(100vw / var(--viewport) * 117);
}
#sec04 .box02 {
  padding-left: 0;
  padding-right: 0;
  padding-bottom: 0;
}
#sec04 .box02 .text {
  padding-left: calc(100vw / var(--viewport) * 30);
  padding-right: calc(100vw / var(--viewport) * 30);
}
#sec04 .box:before {
  color: var(--gold);
  font-size: calc(100vw / var(--viewport) * 49);
  font-weight: bold;
  text-align: center;
  background: #000;
  width: calc(100vw / var(--viewport) * 281);
  height: calc(100vw / var(--viewport) * 92);
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: calc(100vw / var(--viewport) * -92);
  left: 0;
  right: 0;
  margin: 0 auto;
}
#sec04 .box01:before {
  content: "POINT1";
}
#sec04 .box02:before {
  content: "POINT2";
}
#sec04 .box03:before {
  content: "POINT3";
}
#sec04 .box h3 {
  text-align: center;
  line-height: 1.3;
  margin-bottom: calc(100vw / var(--viewport) * 28);
}
#sec04 .box h3 .sub {
  font-size: calc(100vw / var(--viewport) * 30);
}
#sec04 .box h3 .sub_small {
  font-size: calc(100vw / var(--viewport) * 20);
  display: inline-block;
  margin-bottom: calc(100vw / var(--viewport) * 11);
}
#sec04 .box h3 .h3 {
  font-size: calc(100vw / var(--viewport) * 44);
}
#sec04 .box .text {
  font-size: calc(100vw / var(--viewport) * 24);
  margin-bottom: calc(100vw / var(--viewport) * 45);
}
#sec04 .box03 ul li {
  width: 47.83%;
}
#sec04 .box03 ul li:nth-child(n+3) {
  margin-top: calc(100vw / var(--viewport) * 33);
}
#sec04 .box03 ul li img {
  height: calc(100vw / var(--viewport) * 208);
  display: block;
  margin: 0 auto calc(100vw / var(--viewport) * 34);
}
#sec04 .box03 ul li .midashi {
  text-align: center;
  margin-bottom: calc(100vw / var(--viewport) * 17);
}
#sec04 .box03 ul li .midashi .sub {
  font-size: calc(100vw / var(--viewport) * 26);
  display: inline-block;
  margin-bottom: calc(100vw / var(--viewport) * 7);
}
#sec04 .box03 ul li .midashi .font_gold {
  font-size: calc(100vw / var(--viewport) * 30);
  font-weight: bold;
}
#sec04 .box03 ul li .text {
  font-size: calc(100vw / var(--viewport) * 22);
  margin-bottom: 0;
}
@media screen and (min-width:1518px) {
  #sec04 .points {
    width: 706px;
    margin: 22px auto 0;
  }
  #sec04 .points li .title {
    font-size: 39px;
    height: 73px;
  }
  #sec04 .points li .con {
    font-size: 18px;
    height: 108px;
  }
  #sec04 .box {
    padding: 36px 30px 54px;
  }
  #sec04 .box01 {
    margin-top: 128px;
  }
  #sec04 .box02,
  #sec04 .box03 {
    margin-top: 117px;
  }
  #sec04 .box02 .text {
    padding-left: 30px;
    padding-right: 30px;
  }
  #sec04 .box:before {
    font-size: 49px;
    width: 281px;
    height: 92px;
    top: -92px;
  }
  #sec04 .box h3 {
    margin-bottom: 28px;
  }
  #sec04 .box h3 .sub {
    font-size: 30px;
  }
  #sec04 .box h3 .sub_small {
    font-size: 20px;
    margin-bottom: 11px;
  }
  #sec04 .box h3 .h3 {
    font-size: 44px;
  }
  #sec04 .box .text {
    font-size: 24px;
    margin-bottom: 45px;
  }
  #sec04 .box03 ul li:nth-child(n+3) {
    margin-top: 33px;
  }
  #sec04 .box03 ul li img {
    height: 208px;
    margin: 0 auto 34px;
  }
  #sec04 .box03 ul li .midashi {
    margin-bottom: 17px;
  }
  #sec04 .box03 ul li .midashi .sub {
    font-size: 26px;
    margin-bottom: 7px;
  }
  #sec04 .box03 ul li .midashi .font_gold {
    font-size: 30px;
  }
  #sec04 .box03 ul li .text {
    font-size: 22px;
  }
}

#sec05 .new {
  color: #fff;
  font-size: calc(100vw / var(--viewport) * 40);
  font-weight: bold;
  text-align: center;
  background: #741519;
  width: 100%;
  height: calc(100vw / var(--viewport) * 80);
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}
#sec05 .new:after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: calc(100vw / var(--viewport) * -22);
  width: calc(100vw / var(--viewport) * 22);
  height: calc(100vw / var(--viewport) * 22);
  background: #741519;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  margin: 0 auto;
  z-index: 1;
}
#sec05 .bg_gray {
  color: #fff;
  padding: calc(100vw / var(--viewport) * 25) 0;
  margin-bottom: calc(100vw / var(--viewport) * 60);
}
#sec05 .bg_gray .text {
  font-size: calc(100vw / var(--viewport) * 18);
  display: table;
  width: calc(100vw / var(--viewport) * 673);
  margin: 0 auto;
}
#sec05 .ttl_aco {
  color: #fff;
  font-size: calc(100vw / var(--viewport) * 28);
  font-weight: bold;
  background: #000;
  width: 100%;
  height: calc(100vw / var(--viewport) * 100);
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  cursor: pointer;
}
#sec05 .ttl_aco:before,
#sec05 .ttl_aco:after {
  content: "";
  background: #fff;
  display: inline-block;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: calc(100vw / var(--viewport) * 37);
}
#sec05 .ttl_aco:before {
  width: calc(100vw / var(--viewport) * 36);
  height: calc(100vw / var(--viewport) * 4);
}
#sec05 .ttl_aco:after {
  width: calc(100vw / var(--viewport) * 4);
  height: calc(100vw / var(--viewport) * 36);
  right: calc(100vw / var(--viewport) * 54);
}
#sec05 .ttl_aco.active:after {
  display: none;
}
#sec05 .body_aco {
  background: #3C3A39;
  padding: calc(100vw / var(--viewport) * 34) calc(100vw / var(--viewport) * 30) calc(100vw / var(--viewport) * 50);
  display: none;
}
#sec05 .body_aco ul:nth-child(2) {
  margin-top: calc(100vw / var(--viewport) * 60);
}
#sec05 .body_aco ul li {
  width: 48.9%;
}
#sec05 .body_aco ul li.badge {
  position: relative;
}
#sec05 .body_aco ul li.badge:after {
  content: "";
  background: url(../img/off5.webp) center center no-repeat;
  background-size: 100% auto;
  width: calc(100vw / var(--viewport) * 83);
  height: calc(100vw / var(--viewport) * 83);
  position: absolute;
  top: calc(100vw / var(--viewport) * 10);
  right: calc(100vw / var(--viewport) * 10);
}
#sec05 .body_aco .midashi {
  color: #fff;
  background: #000;
  height: calc(100vw / var(--viewport) * 127);
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
}
#sec05 .body_aco .midashi .font_gold {
  font-size: calc(100vw / var(--viewport) * 33);
  font-weight: bold;
  display: inline-block;
}
#sec05 .body_aco .midashi .sub {
  font-size: calc(100vw / var(--viewport) * 22);
  font-weight: 500;
  line-height: 1.34;
}
#sec05 .priceBox {
  height: calc(100vw / var(--viewport) * 110);
  background: #E8E8E8;
  display: flex;
  justify-content: space-between;
  margin-top: calc(100vw / var(--viewport) * 15);
}
#sec05 .priceBox .count,
#sec05 .priceBox .price {
  display: flex;
  justify-content: center;
  align-items: center;
}
#sec05 .priceBox .count {
  font-size: calc(100vw / var(--viewport) * 33);
  font-weight: bold;
  width: calc(100vw / var(--viewport) * 98);
  background: #BBA171;
}
#sec05 .priceBox .price {
  width: calc(100% - calc(100vw / var(--viewport) * 98));
}
#sec05 .priceBox .price img {
  height: calc(100vw / var(--viewport)* 44);
  transform: translateY(9%);
}
#sec05 .priceBox .price--campaign {
  width: calc(100% - calc(100vw / var(--viewport) * 98));
  display: flex;
  flex-direction: column;
  justify-content: center;
}
#sec05 .priceBox .price--campaign .price {
  width: 100%;
}
#sec05 .priceBox .price--campaign .price .strike {
  margin-bottom: 0.3em;
  position: relative;
}
#sec05 .priceBox .price--campaign .price .strike:after {
  content: "";
  border-bottom: calc(100vw / var(--viewport) * 5) dashed var(--gold);
  width: 110%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
#sec05 .priceBox .price--campaign .price .strike img {
  height: calc(100vw / var(--viewport) * 38);
}
#sec05 .body_aco .caution {
  color: #fff;
  font-size: calc(100vw / var(--viewport) * 18);
  margin-top: calc(100vw / var(--viewport) * 16);
}
#sec05 .higeStart {
  margin-top: calc(100vw / var(--viewport) * 49);
}
#sec05 .body_aco .higeStart .midashi {
  justify-content: center;
}
#sec05 .parts {
  background: #3C3A39;
  /*padding-bottom: calc(100vw / var(--viewport) * 50);*/
  margin-bottom: calc(100vw / var(--viewport) * 60);
}
#sec05 > .title,
#sec05 .parts .title {
  color: #fff;
  font-size: calc(100vw / var(--viewport) * 28);
  font-weight: bold;
  height: calc(100vw / var(--viewport) * 100);
  background: #000;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: calc(100vw / var(--viewport) * 60);
}
#sec05 .parts ul {
  /*padding: calc(100vw / var(--viewport) * 34) calc(100vw / var(--viewport) * 30) 0;*/
}
#sec05 .parts ul li {
  width: 48.9%;
}
#sec05 .parts ul li:nth-child(n+3) {
  margin-top: calc(100vw / var(--viewport)* 60);
}
#sec05 .parts ul li .midashi {
  color: #fff;
  background: #000;
  height: calc(100vw / var(--viewport)* 70);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
#sec05 .parts ul li .midashi .font_gold {
  font-size: calc(100vw / var(--viewport) * 33);
  font-weight: bold;
  display: inline-block;
}
#sec05 .parts .caution {
  color: #fff;
  font-size: calc(100vw / var(--viewport)* 18);
  margin: calc(100vw / var(--viewport)* 16) calc(100vw / var(--viewport) * 30) 0;
}
#sec05 .ginza {
  background: #3C3A39;
  padding: 0 0 calc(100vw / var(--viewport) * 54);
}
#sec05 .ginza .title {
  font-size: calc(100vw / var(--viewport) * 28);
  font-weight: bold;
  text-align: center;
  background: #BBA171;
  width: 100%;
  height: calc(100vw / var(--viewport) * 100);
  display: flex;
  justify-content: center;
  align-items: center;
}
#sec05 .ginza .photo {
  width: 100%;
  padding: calc(100vw / var(--viewport) * 30) calc(100vw / var(--viewport) * 30) 0;
}
#sec05 .ginza ul {
  padding: calc(100vw / var(--viewport) * 15) calc(100vw / var(--viewport) * 30) 0;
}
#sec05 .ginza ul li {
  width: 48.9%;
}
#sec05 .ginza .priceBox .count {
  font-size: calc(100vw / var(--viewport) * 30);
  text-align: center;
  line-height: 1.13;
}
#sec05 .ginza > .priceBox {
  margin: calc(100vw / var(--viewport) * 15) calc(100vw / var(--viewport) * 30) 0;
}
#sec05 .ginza > .priceBox .count {
  width: calc(100vw / var(--viewport) * 186);
}
#sec05 .ginza > .priceBox .price {
  width: calc(100% - calc(100vw / var(--viewport) * 186));
}
#sec05 .ginza .caution {
  color: #fff;
  font-size: calc(100vw / var(--viewport) * 18);
  margin: calc(100vw / var(--viewport) * 16) calc(100vw / var(--viewport) * 30) 0;
}
@media screen and (min-width:1518px) {
  #sec05 .new {
    font-size: 40px;
    height: 80px;
  }
  #sec05 .new:after {
    bottom: -22px;
    width: 22px;
    height: 22px;
  }
  #sec05 .bg_gray {
    padding: 25px 0;
    margin-bottom: 60px;
  }
  #sec05 .bg_gray .text {
    font-size: 18px;
    width: 673px;
  }
  #sec05 .ttl_aco {
    font-size: 28px;
    height: 100px;
  }
  #sec05 .ttl_aco:before,
  #sec05 .ttl_aco:after {
    right: 37px;
  }
  #sec05 .ttl_aco:before {
    width: 36px;
    height: 4px;
  }
  #sec05 .ttl_aco:after {
    width: 4px;
    height: 36px;
    right: 54px;
  }
  #sec05 .body_aco {
    padding: 34px 30px 50px;
  }
  #sec05 .body_aco ul:nth-child(2) {
    margin-top: 60px;
  }
  #sec05 .body_aco .midashi {
    height: 127px;
  }
  #sec05 .body_aco .midashi .font_gold {
    font-size: 33px;
  }
  #sec05 .body_aco .midashi .sub {
    font-size: 22px;
  }
  #sec05 .priceBox {
    height: 110px;
    margin-top: 15px;
  }
  #sec05 .priceBox .count {
    font-size: 33px;
    width: 98px;
  }
  #sec05 .priceBox .price {
    width: calc(100% - 98px);
  }
  #sec05 .priceBox .price img {
    height: 44px;
  }
  #sec05 .body_aco .caution {
    font-size: 18px;
    margin-top: 16px;
  }
  #sec05 .higeStart {
    margin-top: 49px;
  }
  #sec05 .parts {
    padding-bottom: 50px;
    margin-bottom: 60px;
  }
  #sec05 .parts .title {
    font-size: 28px;
    height: 100px;
    margin-top: 60px;
  }
  #sec05 .parts ul {
    padding: 34px 30px 0;
  }
  #sec05 .parts ul li:nth-child(n+3) {
    margin-top: 60px;
  }
  #sec05 .parts ul li .midashi {
    height: 70px;
  }
  #sec05 .parts ul li .midashi .font_gold {
    font-size: 33px;
  }
  #sec05 .parts .caution {
    font-size: 18px;
    margin: 16px 30px 0;
  }
  #sec05 .ginza {
    padding: 0 0 54px;
  }
  #sec05 .ginza .title {
    font-size: 28px;
    height: 100px;
  }
  #sec05 .ginza .photo {
    padding: 30px 30px 0;
  }
  #sec05 .ginza ul {
    padding: 15px 30px 0;
  }
  #sec05 .ginza .priceBox .count {
    font-size: 30px;
  }
  #sec05 .ginza > .priceBox {
    margin: 15px 30px 0;
  }
  #sec05 .ginza > .priceBox .count {
    width: 186px;
  }
  #sec05 .ginza > .priceBox .price {
    width: calc(100% - 186px);
  }
  #sec05 .ginza .caution {
    font-size: 18px;
    margin: 16px 30px 0;
  }
}

#sec06 .inner {
  padding: calc(100vw / var(--viewport) * 40) calc(100vw / var(--viewport) * 30) calc(100vw / var(--viewport) * 54);
}
#sec06 .inner .box {
  margin-bottom: calc(100vw / var(--viewport) * 50);
}
#sec06 .inner .box img {
  border-bottom: 2px solid #BBA171;
}
#sec06 .inner .box .text {
  color: #fff;
  font-size: calc(100vw / var(--viewport) * 22);
  background: #000;
  padding: calc(100vw / var(--viewport) * 28) calc(100vw / var(--viewport) * 32) calc(100vw / var(--viewport) * 55);
}
@media screen and (min-width:1518px) {
  #sec06 .inner {
    padding: 40px 30px 54px;
  }
  #sec06 .inner .box {
    margin-bottom: 50px;
  }
  #sec06 .inner .box .text {
    font-size: 22px;
    padding: 28px 32px 55px;
  }
}

#sec07 {
  overflow: hidden;
}
#sec07 .inner .text {
  font-size: calc(100vw / var(--viewport) * 24);
  font-weight: 500;
  text-align: center;
  margin-top: calc(100vw / var(--viewport) * 46);
}
#sec07 .relative {
  padding-top: 1px;
  margin-top: calc(100vw / var(--viewport) * 45);
}
#sec07 .relative:before {
  content: "\025c0 \025c0 \025c0";
  position: absolute;
  top: -1em;
  right: calc(100vw / var(--viewport)* 22);
}
#sec07 .tableArea {
  margin-top: calc(100vw / var(--viewport)* 70);
  position: relative;
  overflow-x: auto;
  overflow-y: hidden;
}
#sec07 .slider2 {
  margin: calc(100vw / var(--viewport) * 20) 0 0;
  overflow: visible;
}
#sec07 .inner li {
  background: none;
}
#sec07 .inner li .box {
  margin-bottom: calc(100vw / var(--viewport) * 28);
}
#sec07 .inner .midashi {
  color: #fff;
  flex-wrap: nowrap;
  justify-content: space-between;
}
#sec07 .inner .midashi div {
  color: #BBA171;
  font-size: calc(100vw / var(--viewport) * 32);
  font-weight: bold;
  background: #000;
  width: calc(100% - calc(100vw / var(--viewport) * 82));
  height: calc(100vw / var(--viewport) * 76);
  display: flex;
  align-items: center;
  justify-content: center;
}
#sec07 .inner .midashi .number {
  color: var(--gold);
  font-size: calc(100vw / var(--viewport) * 40);
  font-weight: 900;
  width: calc(100vw / var(--viewport) * 82);
  margin-right: calc(100vw / var(--viewport) * 10);
}
#sec07 .inner .con {
  flex-wrap: nowrap;
  justify-content: space-between;
}
#sec07 .inner .con div {
  width: 50%;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: center;
  align-content: center;
}
#sec07 .inner .con div.left {
  color: #fff;
  font-size: calc(100vw / var(--viewport) * 22);
  text-align: left;
  line-height: 1.6;
  background: #000;
  padding: 0 calc(100vw / var(--viewport) * 20);
  margin-top: calc(100vw / var(--viewport) * 9);
}
#sec07 .inner .box01 .con div.left {
  line-height: 1.4;
}
#sec07 .inner .box01 .con div.left p:nth-child(1) {
  font-size: calc(100vw / var(--viewport) * 18);
}
#sec07 .inner .box01 .con div.left p:nth-child(2) {
  font-size: calc(100vw / var(--viewport) * 22);
}
#sec07 .inner .box01 .con div.left p:nth-child(3) {
  font-size: calc(100vw / var(--viewport) * 44);
}
#sec07 .inner .box01 .con div.left p:nth-child(3) a {
  color: #fff;
  white-space: nowrap;
}
#sec07 .inner .box01 .con div.left p:nth-child(4) {
  font-size: calc(100vw / var(--viewport) * 25);
}
#sec07 .inner .box01 .con div.left .title {
  text-align: center;
  width: 100%;
  background: #BBA170;
  margin-top: 2px;
}
#sec07 .inner .box01 .con div.left .title a {
  color: #000;
  padding: 3px 0;
  display: block;
}
#sec07 .inner .con div.right {
  margin-left: calc(100vw / var(--viewport) * 9);
}
#sec07 .inner .con div a {
  text-decoration: none;
}
@media screen and (min-width:1518px) {
  #sec07 .inner .text {
    font-size: 24px;
    margin-top: 46px;
  }
  #sec07 .relative {
    margin-top: 45px;
  }
  #sec07 .relative:before {
    right: 22px;
  }
  #sec07 .tableArea {
    margin-top: 70px;
  }
  #sec07 .slider2 {
    margin: 20px 0 0;
  }
  #sec07 .inner li .box {
    margin-bottom: 28px;
  }
  #sec07 .inner .midashi div {
    font-size: 32px;
    width: calc(100% - 82px);
    height: 76px;
  }
  #sec07 .inner .midashi .number {
    font-size: 40px;
    width: 82px;
    margin-right: 10px;
  }
  #sec07 .inner .con div.left {
    font-size: 22px;
    padding: 0 20px;
    margin-top: 9px;
  }
  #sec07 .inner .box01 .con div.left p:nth-child(1) {
    font-size: 18px;
  }
  #sec07 .inner .box01 .con div.left p:nth-child(2) {
    font-size: 22px;
  }
  #sec07 .inner .box01 .con div.left p:nth-child(3) {
    font-size: 44px;
  }
  #sec07 .inner .box01 .con div.left p:nth-child(4) {
    font-size: 25px;
  }
  #sec07 .inner .con div.right {
    margin-left: 9px;
  }
}

#sec08 {
  margin: 0 0 calc(100vw / var(--viewport) * 50);
}
#sec08 .inner {
  padding: calc(100vw / var(--viewport) * 37) calc(100vw / var(--viewport) * 30) 0;
}
#sec08 .tabs li {
  margin-bottom: calc(100vw / var(--viewport) * 30);
  cursor: pointer;
}
#sec08 .box02,
#sec08 .box03 {
  display: none;
}
#sec08 .box {
  padding-bottom: calc(100vw / var(--viewport) * 36);
}
#sec08 .box .ttl_aco {
  margin-top: calc(100vw / var(--viewport) * 50);
  position: relative;
}
#sec08 .box .ttl_aco:nth-child(1) {
  margin-top: 0;
}
#sec08 .box .ttl_aco:before {
  content: "";
  width: calc(100vw / var(--viewport) * 36);
  height: calc(100vw / var(--viewport) * 6);
  background: #000;
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
}
#sec08 .box .ttl_aco:after {
  content: "";
  width: calc(100vw / var(--viewport) * 6);
  height: calc(100vw / var(--viewport) * 36);
  background: #000;
  position: absolute;
  top: 50%;
  right: calc(100vw / var(--viewport) * 15);
  transform: translateY(-50%);
}
#sec08 .box .ttl_aco.active:after {
  display: none;
}
#sec08 .box .qBox {
  width: calc(100vw / var(--viewport) * 618);
  display: flex;
  align-items: center;
  padding-bottom: calc(100vw / var(--viewport) * 15);
  border-bottom: calc(100vw / var(--viewport) * 2) solid #000;
}
#sec08 .box .qBox p {
  font-size: calc(100vw / var(--viewport) * 28);
  font-weight: bold;
}
#sec08 .box .qBox img {
  width: calc(100vw / var(--viewport) * 44);
  max-width: 44px;
  margin-right: calc(100vw / var(--viewport) * 20);
}
#sec08 .box .aBox {
  color: var(--gold);
  width: calc(100vw / var(--viewport) * 544);
  display: flex;
  align-items: center;
  padding-top: calc(100vw / var(--viewport) * 15);
  margin-left: calc(100vw / var(--viewport) * 110);
}
#sec08 .box .aBox p {
  font-size: calc(100vw / var(--viewport) * 28);
  font-weight: bold;
}
#sec08 .box .aBox img {
  width: calc(100vw / var(--viewport) * 48);
  max-width: 48px;
  margin-right: calc(100vw / var(--viewport) * 20);
}
#sec08 .box .body_aco {
  line-height: 1.75;
  margin-top: calc(100vw / var(--viewport) * 36);
  margin-left: calc(100vw / var(--viewport) * 110);
  display: none;
}
#sec08 .box .body_aco p {
  font-size: calc(100vw / var(--viewport) * 24);
}
#sec08 .doctorBox .imgBox {
  position: relative;
}
#sec08 .doctorBox .imgBox .textBox {
  color: #fff;
  font-size: calc(100vw / var(--viewport) * 21);
  line-height: 1.63;
  position: absolute;
  top: calc(100vw / var(--viewport) * 20);
  left: calc(100vw / var(--viewport) * 278);
}
#sec08 .doctorBox .imgBox .textBox .flex {
  justify-content: flex-start;
  align-items: center;
}
#sec08 .doctorBox .imgBox .textBox .flex .detail {
  font-size: calc(100vw / var(--viewport) * 19);
}
#sec08 .doctorBox .imgBox .textBox .flex .name {
  font-size: calc(100vw / var(--viewport) * 37);
  font-weight: 500;
  margin-left: calc(100vw / var(--viewport) * 16);
}
#sec08 .doctorBox .imgBox .textBox .text span {
  width: calc(100vw / var(--viewport) * 72);
  display: inline-block;
}
#sec08 .doctorBox .imgBox .textBox .gakkai {
  font-size: calc(100vw / var(--viewport) * 22);
  font-weight: 500;
  margin-top: calc(100vw / var(--viewport) * 8);
}
#sec08 .doctorBox .under {
  color: #fff;
  font-size: calc(100vw / var(--viewport) * 22);
  background: #000;
  padding: calc(100vw / var(--viewport) * 33) calc(100vw / var(--viewport) * 30) calc(100vw / var(--viewport) * 77);
}
#sec08 .doctorBox .under .big {
  font-size: calc(100vw / var(--viewport) * 25);
  font-weight: 500;
}
@media screen and (min-width:1518px) {
  #sec08 {
    margin: 0 0 50px;
  }
  #sec08 .inner {
    padding: 37px 30px 0;
  }
  #sec08 .tabs li {
    margin-bottom: 30px;
  }
  #sec08 .box {
    padding-bottom: 36px;
  }
  #sec08 .box .ttl_aco {
    margin-top: 50px;
  }
  #sec08 .box .ttl_aco:nth-child(1) {
    margin-top: 0;
  }
  #sec08 .box .ttl_aco:before {
    width: 36px;
    height: 6px;
  }
  #sec08 .box .ttl_aco:after {
    width: 6px;
    height: 36px;
    right: 15px;
  }
  #sec08 .box .qBox {
    width: 618px;
    padding-bottom: 15px;
    border-bottom: 2px solid #000;
  }
  #sec08 .box .qBox p {
    font-size: 28px;
  }
  #sec08 .box .qBox img {
    margin-right: 20px;
  }
  #sec08 .box .aBox {
    width: 544px;
    padding-top: 15px;
    margin-left: 110px;
  }
  #sec08 .box .aBox p {
    font-size: 28px;
  }
  #sec08 .box .aBox img {
    margin-right: 20px;
  }
  #sec08 .box .body_aco {
    margin-top: 36px;
    margin-left: 110px;
  }
  #sec08 .box .body_aco p {
    font-size: 24px;
  }
  #sec08 .doctorBox .imgBox .textBox {
    font-size: 21px;
    top: 20px;
    left: 278px;
  }
  #sec08 .doctorBox .imgBox .textBox .flex .detail {
    font-size: 19px;
  }
  #sec08 .doctorBox .imgBox .textBox .flex .name {
    font-size: 37px;
    margin-left: 16px;
  }
  #sec08 .doctorBox .imgBox .textBox .text span {
    width: 72px;
  }
  #sec08 .doctorBox .imgBox .textBox .gakkai {
    font-size: 22px;
    margin-top: 8px;
  }
  #sec08 .doctorBox .under {
    font-size: 22px;
    padding: 33px 30px 77px;
  }
  #sec08 .doctorBox .under .big {
    font-size: 25px;
  }
}

#sec09 .inner {
  width: 100%;
  background: #646464;
  padding: calc(100vw / var(--viewport) * 30) calc(100vw / var(--viewport) * 30) calc(100vw / var(--viewport) * 60);
  box-sizing: border-box;
}
#sec09 .flex {
  flex-wrap: wrap;
  justify-content: space-between;
}
#sec09 .flex .relative {
  text-align: center;
  width: 48%;
  margin-bottom: calc(100vw / var(--viewport) * 30);
  position: relative;
}
#sec09 .flex li .title {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}
#sec09 .flex li .title div {
  line-height: 1.2;
  position: absolute;
}
#sec09 .flex li .title div p:nth-child(1) {
  font-size: calc(100vw / var(--viewport) * 24);
}
#sec09 .flex li .title div p:nth-child(2) {
  font-size: calc(100vw / var(--viewport) * 32);
  font-weight: 500;
}
#sec09 .flex li .btn_more {
  font-size: calc(100vw / var(--viewport) * 22);
  font-weight: bold;
  line-height: calc(100vw / var(--viewport) * 64);
  background: #000;
  border-top: 1px solid #fff;
  cursor: pointer;
}
#sec09 .flex li + .body_more {
  text-align: left;
  width: calc(100vw / var(--viewport) * 690);
  background: rgba(255, 255, 255, 0.93);
  padding-bottom: calc(100vw / var(--viewport) * 42);
  position: absolute;
  top: 0;
  left: 0;
  box-sizing: border-box;
  z-index: 1;
  display: none;
}
#sec09 .flex .relative:nth-child(2n) li + .body_more {
  left: initial;
  right: 0;
}
#sec09 .flex li + .body_more .outer {
  height: 0;
  padding-bottom: 38.11%;
  overflow: hidden;
  position: relative;
}
#sec09 .flex li + .body_more .outer iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
#sec09 .flex li + .body_more dl {
  font-size: calc(100vw / var(--viewport) * 24);
  line-height: 1.75;
  margin: calc(100vw / var(--viewport) * 30);
  display: flex;
  flex-wrap: wrap;
}
#sec09 .flex li + .body_more dt {
  width: 5em;
}
#sec09 .flex li + .body_more dd {
  width: calc(100% - 5em);
}
@media screen and (min-width:1518px) {
  #sec09 .inner {
    padding: 30px 30px 60px;
  }
  #sec09 .flex .relative {
    margin-bottom: 30px;
  }
  #sec09 .flex li .title div p:nth-child(1) {
    font-size: 24px;
  }
  #sec09 .flex li .title div p:nth-child(2) {
    font-size: 32px;
  }
  #sec09 .flex li .btn_more {
    font-size: 22px;
    line-height: 64px;
  }
  #sec09 .flex li + .body_more {
    width: 690px;
    padding-bottom: 42px;
  }
  #sec09 .flex li + .body_more dl {
    font-size: 24px;
    margin: 30px;
  }
}

#footer {
  color: #fff;
  text-align: center;
  background: #000;
  padding: calc(100vw / var(--viewport) * 30) calc(100vw / var(--viewport) * 30) calc(100vw / var(--viewport) * 264);
}
#footer .caution {
  font-size: calc(100vw / var(--viewport) * 17);
  text-align: left;
}
#footer .l-footer__logo {
  width: calc(100vw / var(--viewport) * 99);
  max-width: 100px;
  margin: calc(100vw / var(--viewport) * 70) auto 0;
}
#footer a {
  color: #fff;
}
#footer .footerflex1 {
  display: none;
}
#footer .footerText {
  font-size: calc(100vw / var(--viewport)* 15);
}
@media screen and (max-width:767px) {
  #footer .copy-right {
    font-size: calc(100vw / var(--viewport) * 18);
    letter-spacing: 0;
    line-height: 0;
  }
  footer .displayFlex {
    display: none;
  }
}
@media screen and (min-width:768px) {
  #footer {
    padding-bottom: calc(100vw / var(--viewport) * 30);
  }
  .displayFlex {
    display: flex;
    justify-content: center;
    line-height: 1.6;
    color: #fff;
  }
  #footer .copy-right {
    font-size: 16px;
  }
  #footer .footerflex1 {
    display: block;
    margin: calc(100vw / var(--viewport)* 10) 0.6em 0 0;
  }
  #footer .footerflex1 a {
    text-decoration: underline;
  }
  #footer .footerflex2 {
    margin: calc(100vw / var(--viewport)* 10) 0 0 0.6em;
  }
}
@media screen and (min-width:1518px) {
  #footer {
    padding-top: 30px;
    padding-bottom: 30px;
  }
  #footer .l-footer__logo {
    width: 99px;
    margin: 0 auto 20px;
  }
  #footer .footerText {
    font-size: 15px;
  }
}

@media screen and (max-width:767px) {
  .background {
    display: none;
  }
  .pcBanner {
    display: none;
  }
}
@media screen and (min-width: 768px) {
  .background img {
    width: 100vw;
    height: 100%;
    object-fit: cover;
    object-position: top;
    position: fixed;
    top: 0;
    left: 0;
    z-index: -1;
  }
}

.pcBanner {
  display: none;
}
@media screen and (min-width:768px) {
  .pcBanner {
    display: block;
    position: fixed;
    width: 39.1%;
    max-width: 884px;
    left: 3.36%;
    bottom: 22%;
  }
}

.cta-bottomFixedArea {
  width: 750px;
  position: fixed;
  left: 50%;
  bottom: 0;
}
@media screen and (max-width:767px) {
  .cta-bottomFixedArea {
    width: 100%;
    left: 0;
    display: none;
  }
}
@media screen and (min-width:768px) {
  .cta-bottomFixedArea {
    width: 32.03%;
    max-width: 615px;
    left: 5.36%;
    bottom: 7.81%;
  }
  .cta-bottomFixedArea a {
    display: block;
    animation: zoom infinite 2.2s;
  }
  @keyframes zoom {
    0% {
      scale: 1;
    }
    50% {
      scale: 1.1;
    }
    100% {
      scale: 1;
    }
  }
}

[data-animate="fadeInUp"] {
  opacity: 0;
}
@-webkit-keyframes fadeInUp {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 20px, 0);
    transform: translate3d(0, 20px, 0)
  }
  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0)
  }
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 20px, 0);
    transform: translate3d(0, 20px, 0)
  }
  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0)
  }
}
