@charset "UTF-8";
/*
デザイン上のpxサイズをvwに変換
viewportはデザインの横幅サイズ
*/
/*
メディアクエリ
記述例
body{
  @include ms-w('max',1200){
    background-color: red;
  }
}
*/
/*
ICON FONT
*/
/************************************************************
SCREEN ALL
*************************************************************/
.pagelinks-fl {
  padding: 100px 0;
}
@media (min-width:769px) {
  .pagelinks-fl-boxes {
    display: flex;
    justify-content: space-between;
    gap: 20px;
  }
}
@media (max-width:768px) {
  .pagelinks-fl-boxes {
    margin-inline: auto;
    display: flex;
    flex-direction: column;
    gap: 30px;
    width: 85.3333333333vw;
  }
}
.pagelinks-fl-box {
  margin: 0;
  color: #674498;
  font-weight: 500;
  line-height: 1.7em;
  letter-spacing: 0.1em;
  width: 100%;
  height: 100px;
  justify-content: flex-start;
}
@media (min-width:769px) {
  .pagelinks-fl-box {
    padding-left: 40px;
  }
}
@media (max-width:768px) {
  .pagelinks-fl-box {
    padding-left: 50px;
  }
}
@media (min-width:769px) {
  .pagelinks-fl-box {
    font-size: clamp(16.7px, 1.3888888889vw, 20px);
  }
}
@media (max-width:768px) {
  .pagelinks-fl-box {
    font-size: clamp(20px, 5.3333333333vw, 20px);
  }
}

/************************************************************
SCREEN SP
*************************************************************/
@media (max-width:768px) {
  .pagelinks {
    padding: 100px 0;
  }
  .pagelinks .pagelinks-boxes {
    width: 85.3333333333vw;
    max-width: 400px;
    margin: 0 auto;
  }
  .pagelinks .pagelinks-boxes .pagelinks-box {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    color: #674498;
    font-size: 20px;
    font-weight: 500;
    line-height: 1.7em;
    letter-spacing: 0.1em;
    height: 100px;
    border-radius: 6px;
    border: 1px solid #674498;
    background: #FFF;
    box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
    position: relative;
  }
  .pagelinks .pagelinks-boxes .pagelinks-box:nth-of-type(n+2) {
    margin-top: 30px;
  }
}
/************************************************************
SCREEN PC
*************************************************************/
@media (min-width:769px) {
  .pagelinks {
    padding: 200px 0;
  }
  .pagelinks .pagelinks-boxes {
    display: flex;
    justify-content: center;
  }
  .pagelinks .pagelinks-boxes .pagelinks-box {
    margin: 0 40px;
    color: #674498;
    font-size: 20px;
    font-weight: 500;
    line-height: 1.7em;
    letter-spacing: 0.1em;
    width: 320px;
    height: 100px;
  }
}
/************************************************************
SCREEN ALL
*************************************************************/
.main-contents-container {
  margin-inline: auto;
  background-color: white;
  position: relative;
  z-index: 1;
  margin-top: 20px;
}
@media (min-width:769px) {
  .main-contents-container {
    width: 88.88%;
  }
}
@media (max-width:768px) {
  .main-contents-container {
    width: 100%;
  }
}

.main-content-box {
  margin-inline: auto;
}
@media (min-width:769px) {
  .main-content-box {
    width: 92.19%;
  }
}
@media (max-width:768px) {
  .main-content-box {
    width: 89.3333333333vw;
  }
}

.overflow-scroll-content {
  overflow-x: auto;
  width: 100%;
  /*@include media.sp{
    padding:0 func.getvw(20);
  }*/
  scrollbar-width: none;
}
.overflow-scroll-content::-webkit-scrollbar {
  display: none;
}
@media (max-width:768px) {
  .overflow-scroll-content-inner {
    display: inline-flex;
    padding: 0 5.3333333333vw;
  }
}

.overflow-scroll-bar {
  margin-top: 12px;
  display: block;
  width: 100%;
}
@media (min-width:769px) {
  .overflow-scroll-bar {
    padding: 0 9%;
  }
}
@media (max-width:768px) {
  .overflow-scroll-bar {
    padding: 0 5.3333333333vw;
  }
}
.overflow-scroll-bar-track {
  height: 8px;
  position: relative;
  background: #ccc;
  border-radius: 999px;
}
.overflow-scroll-bar-thum {
  width: 40%;
  height: 8px;
  background: #674498;
  border-radius: 999px;
  position: absolute;
  top: 0;
  left: 0;
}

.end-txt-frame {
  border-radius: 10px;
  border: 1px solid #674498;
}
@media (min-width:769px) {
  .end-txt-frame {
    padding: 20px 30px;
  }
}
@media (max-width:768px) {
  .end-txt-frame {
    padding: 20px;
  }
}
@media (min-width:769px) {
  .end-txt-frame {
    margin-top: 38px;
  }
}
@media (max-width:768px) {
  .end-txt-frame {
    margin-top: 20px;
  }
}
@media (min-width:769px) {
  .end-txt-frame {
    display: flex;
    justify-content: center;
  }
}
.end-txt-frame-txt {
  color: #674498;
  font-weight: 700;
  line-height: 1.7em;
  letter-spacing: 0.1em;
}
@media (min-width:769px) {
  .end-txt-frame-txt {
    font-size: 20px;
  }
}
@media (max-width:768px) {
  .end-txt-frame-txt {
    font-size: 18px;
  }
}
.end-txt-frame-txt-black {
  color: #252525 !important;
}
@media (min-width:769px) {
  .end-txt-frame ol {
    margin-top: 16px;
  }
}
@media (max-width:768px) {
  .end-txt-frame ol {
    margin-top: 12px;
  }
}
@media (max-width:768px) {
  .end-txt-frame ol {
    margin-left: -0.5em;
  }
}
.end-txt-frame ol li {
  color: #674498;
  line-height: 1.7em;
  letter-spacing: 0.1em;
  position: relative;
  list-style: decimal;
  margin-top: 1em;
}
@media (min-width:769px) {
  .end-txt-frame ol li {
    font-size: 18px;
  }
}
@media (max-width:768px) {
  .end-txt-frame ol li {
    font-size: 16px;
  }
}
.end-txt-frame ol li strong {
  font-weight: 700;
}

/************************************************************
SCREEN SP
*************************************************************/
@media (max-width:768px) {
  .anchor-target {
    margin-top: -120px;
    padding-top: 120px;
  }
  .title-bar {
    color: #674498;
    font-size: 20px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    letter-spacing: 0.1em;
    text-align: center;
    border-top: 1px solid #674498;
    border-bottom: 1px solid #674498;
    width: 89.3333333333vw;
    margin: 0 auto;
    padding: 10px 0;
  }
  .title-bar .lt-sp {
    letter-spacing: 1em;
  }
  .sub-title-bar {
    color: #674498;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.7em;
    letter-spacing: 0.1em;
    padding: 11px 0 11px 35px;
    background-color: #FAF8FF;
    position: relative;
  }
  .sub-title-bar::before {
    content: "";
    width: 25px;
    height: 2px;
    display: block;
    background-color: #674498;
    position: absolute;
    top: 24px;
    left: 0;
  }
  .sub-title-bar .icon-blank {
    transform: scale(0.9);
    display: inline-block;
  }
}
/************************************************************
SCREEN PC
*************************************************************/
@media (min-width:769px) {
  .anchor-target {
    margin-top: -160px;
    padding-top: 160px;
  }
  .title-bar {
    color: #674498;
    font-size: 32px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    letter-spacing: 0.1em;
    text-align: center;
    border-top: 1px solid #674498;
    border-bottom: 1px solid #674498;
    width: 92.19%;
    margin: 0 auto;
    padding: 16px 0;
  }
  .title-bar .lt-sp {
    letter-spacing: 1em;
  }
  .sub-title-bar {
    color: #674498;
    font-size: 24px;
    font-weight: 500;
    line-height: 1.7em;
    letter-spacing: 0.1em;
    padding: 15px 0 15px 53px;
    background-color: #FAF8FF;
    position: relative;
  }
  .sub-title-bar::before {
    content: "";
    width: 35px;
    height: 2px;
    display: block;
    background-color: #674498;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
  }
  .sub-title-bar .icon-blank {
    transform: scale(0.8);
    display: inline-block;
  }
  main {
    overflow: hidden;
    padding-bottom: 200px;
  }
  main::before {
    content: "";
    background-image: url("/wp-content/themes/tohaku2309/assets/images/home/mist-purple.jpg");
    background-size: 1200px 1200px;
    width: 1200px;
    height: 1200px;
    display: block;
    position: absolute;
    right: -500px;
    top: 80%;
    margin-top: -600px;
  }
  main::after {
    content: "";
    background-image: url("/wp-content/themes/tohaku2309/assets/images/home/mist-purple.jpg");
    background-size: 1200px 1200px;
    width: 1200px;
    height: 1200px;
    display: block;
    position: absolute;
    left: -300px;
    bottom: -500px;
  }
}
/************************************************************
SCREEN ALL
*************************************************************/
@media (min-width:769px) {
  .about {
    padding-top: 100px;
  }
}
@media (max-width:768px) {
  .about {
    padding-top: 50px;
  }
}
.about-top-txts {
  margin-top: 30px;
}
.about-top-txt {
  font-size: 15px;
  letter-spacing: 0.1em;
}
@media (min-width:769px) {
  .about-top-txt {
    line-height: 2.2;
  }
}
@media (max-width:768px) {
  .about-top-txt {
    line-height: 1.7;
  }
}
.about-top-txt + .about-top-txt {
  margin-top: 1em;
}
.about-top-txt-strong {
  font-weight: 700;
}
.about-price-frame {
  background-color: #FAF8FF;
}
@media (min-width:769px) {
  .about-price-frame {
    margin-top: 30px;
  }
}
@media (max-width:768px) {
  .about-price-frame {
    margin-top: 20px;
  }
}
@media (min-width:769px) {
  .about-price-frame {
    padding: 30px;
  }
}
@media (max-width:768px) {
  .about-price-frame {
    padding: 5.3333333333vw;
  }
}
.about-price-frame-title {
  color: #674498;
  font-weight: 700;
  line-height: 1.7em;
  letter-spacing: 0.1em;
}
@media (min-width:769px) {
  .about-price-frame-title {
    font-size: 20px;
  }
}
@media (max-width:768px) {
  .about-price-frame-title {
    font-size: 18px;
  }
}
.about-price-frame-txt {
  margin-top: 8px;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.5em;
}
.about-price-frame-table-container {
  margin-top: 16px;
}
.about-price-frame-tables {
  position: relative;
}
@media (min-width:769px) {
  .about-price-frame-tables {
    display: flex;
    justify-content: space-between;
    gap: 23px;
  }
}
@media (max-width:768px) {
  .about-price-frame-tables {
    display: flex;
    flex-direction: column;
    gap: 8px;
  }
}
.about-price-frame-tables-arrow {
  background-color: #674498;
}
@media (min-width:769px) {
  .about-price-frame-tables-arrow {
    height: 43px;
  }
}
@media (max-width:768px) {
  .about-price-frame-tables-arrow {
    height: 14px;
  }
}
@media (min-width:769px) {
  .about-price-frame-tables-arrow {
    width: 14px;
  }
}
@media (max-width:768px) {
  .about-price-frame-tables-arrow {
    width: 43px;
  }
}
@media (min-width:769px) {
  .about-price-frame-tables-arrow {
    min-width: 14px;
  }
}
@media (max-width:768px) {
  .about-price-frame-tables-arrow {
    min-width: 43px;
  }
}
@media (min-width:769px) {
  .about-price-frame-tables-arrow {
    margin: auto 0;
    clip-path: polygon(0 0, 100% 50%, 0 100%);
  }
}
@media (max-width:768px) {
  .about-price-frame-tables-arrow {
    margin: 0 auto;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
  }
}
.about-price-frame-table {
  border-collapse: collapse;
  border: 1px solid #ccc;
  background-color: #fff;
}
@media (min-width:769px) {
  .about-price-frame-table {
    width: 50%;
  }
}
@media (max-width:768px) {
  .about-price-frame-table {
    width: 100%;
  }
}
.about-price-frame-table th, .about-price-frame-table td {
  border: 1px solid #ccc;
  color: #252525;
}
.about-price-frame-table thead th {
  background-color: #E4DBF7;
  text-align: center;
  font-weight: 700;
  font-size: 16px;
  padding: 10px 20px;
}
.about-price-frame-table tbody {
  /*tr{
    &:nth-child(1){
      th,td{ height: 80px; }
    }
    &:nth-child(2){
      th,td{ height: 40px; }
    }
    &:nth-child(3){
      th,td{ height: 60px; }
    }
  }*/
}
.about-price-frame-table tbody th {
  background-color: #faf8ff;
  text-align: center;
  font-weight: 700;
  font-size: 14px;
  padding: 0 10px;
  white-space: nowrap;
}
.about-price-frame-table tbody td {
  background-color: #fff;
  padding: 10px 20px;
  font-size: 15px;
  letter-spacing: 1.5px;
  vertical-align: middle;
}
.about-price-frame-table-fee-lines {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.about-price-frame-table-fee-line {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  column-gap: 8px;
}
.about-price-frame-table-fee-label {
  font-size: 15px;
  letter-spacing: 1.5px;
}
.about-price-frame-table-fee-text {
  font-size: 15px;
  letter-spacing: 1.5px;
}
.about-price-frame-table-fee-text strong {
  font-weight: 700;
  font-size: 22px;
  color: #674498;
}
.about-price-frame-table-fee-amount {
  display: inline-flex;
  align-items: baseline;
  gap: 2px;
  color: #674498;
  font-weight: 700;
  letter-spacing: 0.44px;
}
.about-price-frame-table-fee-number {
  font-size: 22px;
}
.about-price-frame-table-fee-unit {
  font-size: 16px;
  letter-spacing: 0.32px;
}
.about-price-frame-table-fee-sub {
  margin-top: 8px;
  font-size: 12px;
  letter-spacing: 0.1em;
  line-height: 1.7;
}
.about-price-frame-table-target {
  letter-spacing: 0.1em;
}
@media (min-width:769px) {
  .about-price-frame-table-target {
    line-height: 1.7;
  }
}
@media (max-width:768px) {
  .about-price-frame-table-target {
    line-height: 1.4;
  }
}
@media (min-width:769px) {
  .about-price-frame-table-target {
    font-size: 15px;
  }
}
@media (max-width:768px) {
  .about-price-frame-table-target {
    font-size: 13px;
  }
}
@media (min-width:769px) {
  .about-price-frame-table-target--fixed-height {
    height: 100px;
  }
}
.about-price-frame-table-note {
  margin-top: 8px;
  letter-spacing: 0.12em;
}
@media (min-width:769px) {
  .about-price-frame-table-note {
    line-height: 1.7;
  }
}
@media (max-width:768px) {
  .about-price-frame-table-note {
    line-height: 1.2;
  }
}
@media (min-width:769px) {
  .about-price-frame-table-note {
    font-size: 12px;
  }
}
@media (max-width:768px) {
  .about-price-frame-table-note {
    font-size: 11px;
  }
}
.about-price-frame-table-rate {
  color: #674498;
  font-weight: 700;
  letter-spacing: 0.44px;
}
.about-price-frame-table-rate-prefix {
  font-size: 16px;
  letter-spacing: 0.32px;
}
.about-price-frame-table-rate-number {
  font-size: 22px;
}
.about-price-frame-table-rate-unit {
  font-size: 16px;
  letter-spacing: 0.32px;
}
@media (min-width:769px) {
  .about-flow {
    margin-top: 30px;
  }
}
@media (max-width:768px) {
  .about-flow {
    margin-top: 20px;
  }
}
.about-flow-txt {
  font-size: 15px;
  letter-spacing: 0.1em;
}
@media (min-width:769px) {
  .about-flow-txt {
    line-height: 2.2;
  }
}
@media (max-width:768px) {
  .about-flow-txt {
    line-height: 1.7;
  }
}
.about-flow-list {
  margin-top: 16px;
  margin-left: -0.5em;
  font-size: 15px;
  letter-spacing: 0.1em;
}
@media (min-width:769px) {
  .about-flow-list {
    line-height: 1.7;
  }
}
@media (max-width:768px) {
  .about-flow-list {
    line-height: 1.5;
  }
}
.about-flow-list-item {
  margin-top: 1em;
  list-style: number !important;
}
.about-flow-fig-container {
  background-color: #faf8ff;
}
@media (min-width:769px) {
  .about-flow-fig-container {
    width: 92.19%;
    margin-inline: auto;
    padding: 30px 40px;
  }
}
@media (max-width:768px) {
  .about-flow-fig-container {
    width: 940px;
    padding: 20px;
  }
}
.about-flow-fig {
  width: 100%;
  display: flex;
  justify-content: space-between;
  gap: 1.2727272727%;
}
@media (min-width:769px) {
  .about-flow-fig {
    font-size: clamp(8.35px, 0.6944444444vw, 999px);
  }
}
@media (max-width:768px) {
  .about-flow-fig {
    font-size: 8.1px;
  }
}
.about-flow-fig-part {
  position: relative;
}
.about-flow-fig-part--01 {
  width: 25.7713248639%;
  min-width: 25.7713248639%;
}
.about-flow-fig-part--01 .about-flow-fig-part-content {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.about-flow-fig-part--01 .about-flow-fig-part-content--01 {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.about-flow-fig-part--01 .about-flow-fig-part-txt-01 {
  font-weight: 700;
  letter-spacing: 0.02em;
  text-align: center;
  font-size: 1.8em;
  position: absolute;
  top: 12.2580645161%;
  left: -2%;
  width: 40.4929577465%;
}
.about-flow-fig-part--01 .about-flow-fig-part-txt-02 {
  font-weight: 700;
  text-align: center;
  font-size: 1.8em;
  position: absolute;
  top: 0.6451612903%;
  left: 44.8943661972%;
  width: 48.7676056338%;
}
.about-flow-fig-part--01 .about-flow-fig-part-txt-03 {
  font-weight: 700;
  text-align: center;
  font-size: 1.8em;
  position: absolute;
  top: 11.3548387097%;
  left: 44.8943661972%;
  width: 48.7676056338%;
}
.about-flow-fig-part--01 .about-flow-fig-part-txt-04 {
  font-weight: 700;
  text-align: center;
  color: #674498;
  font-size: 1.6em;
  position: absolute;
  top: 27.7419354839%;
  left: 26.4084507042%;
  width: 70.4225352113%;
}
.about-flow-fig-part--01 .about-flow-fig-part-txt-04 small {
  font-size: 0.75em;
}
.about-flow-fig-part--01 .about-flow-fig-part-txt-05 {
  font-weight: 700;
  text-align: center;
  font-size: 1.8em;
  position: absolute;
  line-height: 1.4;
  top: 48.3870967742%;
  left: 41.3732394366%;
  width: 70.4225352113%;
}
.about-flow-fig-part--01 .about-flow-fig-part-txt-06 {
  font-weight: 700;
  text-align: center;
  font-size: 1.8em;
  position: absolute;
  line-height: 1.4;
  top: 89.0322580645%;
  left: 41.3732394366%;
  width: 70.4225352113%;
}
.about-flow-fig-part--02 {
  width: 100%;
}
.about-flow-fig-part--02--01 .about-flow-fig-part-columns {
  display: flex;
  align-items: center;
}
.about-flow-fig-part--02--01 .about-flow-fig-part-column--01 {
  font-size: 1.8em;
  font-weight: 700;
  line-height: normal;
}
.about-flow-fig-part--02--01 .about-flow-fig-part-column--02 {
  width: 17.75%;
  min-width: 17.75%;
}
.about-flow-fig-part--02--01 .about-flow-fig-part-column--03 {
  width: 50%;
  padding-left: 2.875%;
}
.about-flow-fig-part--02--01 .about-flow-fig-part-column--03 .about-flow-fig-part-column-txt-01 {
  font-size: 1.6em;
  font-weight: 700;
  line-height: normal;
  margin-bottom: 0.5em;
}
.about-flow-fig-part--02--01 .about-flow-fig-part-column--03 .about-flow-fig-part-column-txt-boxes {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}
.about-flow-fig-part--02--01 .about-flow-fig-part-column--03 .about-flow-fig-part-column-txt-box {
  font-size: 1.2em;
  line-height: 1.5;
  white-space: nowrap;
}
.about-flow-fig-part--02--01 .about-flow-fig-part-frame {
  margin-top: 1.625%;
  width: 100%;
  background-color: #E4DBF7;
  padding: 2.5% 2.875%;
  border-radius: 10px;
}
.about-flow-fig-part--02--01 .about-flow-fig-part-frame-txt-01 {
  font-size: 1.6em;
  font-weight: 700;
  line-height: 1.5;
}
.about-flow-fig-part--02--01 .about-flow-fig-part-frame-txt-02 {
  font-size: 1.3em;
  line-height: 1.5;
  letter-spacing: 0.05em;
}
.about-flow-fig-part--02--02 {
  margin-top: 2.75%;
}
.about-flow-fig-part--02--02 .about-flow-fig-part-columns {
  display: flex;
}
.about-flow-fig-part--02--02 .about-flow-fig-part-column--01 {
  width: 72%;
  min-width: 72%;
}
.about-flow-fig-part--02--02 .about-flow-fig-part-column--01 .about-flow-fig-part-frame {
  width: 100%;
  background-color: #E4DBF7;
  padding: 3.4722222222% 3.9930555556%;
  border-radius: 10px;
}
.about-flow-fig-part--02--02 .about-flow-fig-part-column--01 .about-flow-fig-part-frame-txt-01 {
  margin-top: 1.3888888889%;
  font-size: 1.6em;
  font-weight: 700;
  line-height: 1.5;
}
.about-flow-fig-part--02--02 .about-flow-fig-part-column--01 .about-flow-fig-part-frame-txt-01:nth-child(1) {
  margin-top: 0;
}
.about-flow-fig-part--02--02 .about-flow-fig-part-column--01 .about-flow-fig-part-frame-txt-02 {
  font-size: 1.3em;
  line-height: 1.5;
  white-space: nowrap;
}
.about-flow-fig-part--02--02 .about-flow-fig-part-column--01 .about-flow-fig-part-frame-txt-02--margin-top {
  margin-top: 3.4722222222%;
}
.about-flow-fig-part--02--02 .about-flow-fig-part-column--02 {
  position: relative;
}
.about-flow-fig-part--02--02 .about-flow-fig-part-column--02 .about-flow-fig-part-column-pic {
  width: 94.6428571429%;
  transform: translateY(12%);
}
.about-flow-fig-part--02--02 .about-flow-fig-part-column--02 .about-flow-fig-part-column-txt {
  display: flex;
  align-items: flex-end;
  gap: 0.25em;
  font-size: 1.8em;
  font-weight: 700;
  position: absolute;
  left: 3%;
}
.about-flow-fig-part--02--02 .about-flow-fig-part-column--02 .about-flow-fig-part-column-txt small {
  font-size: 0.666em;
}
.about-flow-fig-part--02--02 .about-flow-fig-part-column--02 .about-flow-fig-part-column-txt-01 {
  top: 3%;
}
.about-flow-fig-part--02--02 .about-flow-fig-part-column--02 .about-flow-fig-part-column-txt-02 {
  top: 35%;
}
.about-flow-fig-part--02--02 .about-flow-fig-part-column--02 .about-flow-fig-part-column-txt-03 {
  top: 67%;
}
.about-flow-fig-part--02--03 {
  margin-top: 2.75%;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-columns {
  display: flex;
  justify-content: space-between;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-column--01 {
  width: 75%;
  min-width: 75%;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-column--02 {
  width: 100%;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-column .about-flow-fig-part-ticket-table-caption {
  font-size: 1.433em;
  font-weight: 700;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-column .about-flow-fig-part-ticket-table-container {
  margin-top: 1.3333333333%;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-column .about-flow-fig-part-ticket-table-container .ticket-table {
  table-layout: fixed;
  width: 100%;
  min-width: auto;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-column .about-flow-fig-part-ticket-table-container .ticket-table th,
.about-flow-fig-part--02--03 .about-flow-fig-part-column .about-flow-fig-part-ticket-table-container .ticket-table td {
  border: 1px solid #000;
  text-align: center;
  vertical-align: middle;
  padding: 0.25em 0;
  line-height: 1.5;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-column .about-flow-fig-part-ticket-table-container .ticket-table th.ticket-table-num--red,
.about-flow-fig-part--02--03 .about-flow-fig-part-column .about-flow-fig-part-ticket-table-container .ticket-table td.ticket-table-num--red {
  border: 4px solid red;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-column .about-flow-fig-part-ticket-table-container .ticket-table thead th {
  font-weight: 700;
  font-size: 1em;
  color: #000;
  background: #fff;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-column .about-flow-fig-part-ticket-table-container .ticket-table thead th.ticket-table-h {
  white-space: nowrap;
}
@media (max-width:768px) {
  .about-flow-fig-part--02--03 .about-flow-fig-part-column .about-flow-fig-part-ticket-table-container .ticket-table thead th.ticket-table-h {
    font-size: 1em;
  }
}
.about-flow-fig-part--02--03 .about-flow-fig-part-column .about-flow-fig-part-ticket-table-container .ticket-table-blank {
  width: auto;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-column .about-flow-fig-part-ticket-table-container .ticket-table-sub {
  font-weight: 700;
  font-size: 1em;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-column .about-flow-fig-part-ticket-table-container .ticket-table-note {
  margin-top: 0.5em;
  display: inline-block;
  font-weight: 700;
  font-size: 1em;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-column .about-flow-fig-part-ticket-table-container .ticket-table-year {
  font-weight: 700;
  color: #000;
  white-space: nowrap;
  letter-spacing: 0;
  font-size: 1.1875em;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-column .about-flow-fig-part-ticket-table-container .ticket-table-num {
  font-weight: 700;
  font-size: 1.1875em;
  color: #674498;
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-column .about-flow-fig-part-ticket-table-notes {
  margin-top: 1.6666666667%;
  font-size: 1.1em;
  line-height: 1.7;
  position: relative;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-column .about-flow-fig-part-ticket-table-notes-star {
  margin-top: 0;
  line-height: 1;
  position: absolute;
  top: 0;
  right: 0;
  font-size: 1.35em;
  color: #674498;
  font-weight: 700;
  letter-spacing: 0;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-frame {
  margin-top: 6%;
  width: 100%;
  background-color: #E4DBF7;
  padding: 3.3333333333% 3.8333333333%;
  border-radius: 10px;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-frame-txt-01 {
  margin-top: 2.7777777778%;
  font-size: 1.6em;
  font-weight: 700;
  line-height: 1.5;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-frame-txt-01:nth-child(1) {
  margin-top: 0;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-frame-txt-02 {
  font-size: 1.3em;
  line-height: 1.5;
  white-space: nowrap;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-circles {
  width: 82.5%;
  margin-left: auto;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 1em;
  position: relative;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-circles::before {
  content: "";
  display: block;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  background-color: #FADADD;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%) translateY(-140%);
  width: 2.6em;
  height: 1.6em;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-circles::after {
  content: "";
  display: block;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
  background-color: #FADADD;
  position: absolute;
  bottom: 20%;
  left: 0;
  transform: translateX(-140%);
  width: 1.6em;
  height: 2.6em;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-circle {
  width: 100%;
  padding-top: 100%;
  position: relative;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-circle-inner {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #FADADD;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-circle-txt-01 {
  font-size: 1.6em;
  font-weight: 700;
  line-height: 1.3;
  text-align: center;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-circle-txt-02 {
  text-align: center;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-circle-txt-02 span.number {
  font-size: 2.4em;
  font-weight: 900;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-circle-txt-02 span.symbol {
  font-size: 2em;
  font-weight: 900;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-circle-txt-02 span.txt {
  font-size: 1.6em;
  font-weight: 700;
  line-height: 1.3;
  text-align: center;
}
.about-flow-fig-part--02--03 .about-flow-fig-part-circle-txt-02 small {
  font-size: 1.4em;
  font-weight: 700;
}
.about-arrow {
  background: #674498;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
}
@media (min-width:769px) {
  .about-arrow {
    height: 32px;
  }
}
@media (max-width:768px) {
  .about-arrow {
    height: 20px;
  }
}
@media (min-width:769px) {
  .about-arrow {
    width: 100px;
  }
}
@media (max-width:768px) {
  .about-arrow {
    width: 80px;
  }
}
@media (min-width:769px) {
  .about-arrow {
    margin: 16px auto;
  }
}
@media (max-width:768px) {
  .about-arrow {
    margin: 10px auto;
  }
}

/************************************************************
SCREEN SP
*************************************************************/
/************************************************************
SCREEN PC
*************************************************************/
/************************************************************
SCREEN ALL
*************************************************************/
@media (min-width:769px) {
  .ticket {
    padding-top: 100px;
  }
}
@media (max-width:768px) {
  .ticket {
    padding-top: 50px;
  }
}
@media (min-width:769px) {
  .ticket-table-container {
    width: 92.19%;
    margin-inline: auto;
  }
}
.ticket-table-caption {
  font-size: 16px;
  font-weight: 700;
  margin: 30px 0 9px;
}
.ticket-table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
  min-width: 980px;
}
.ticket-table th,
.ticket-table td {
  border: 1px solid #000;
  text-align: center;
  vertical-align: middle;
  padding: 10px 8px;
  line-height: 1.2;
}
.ticket-table th.ticket-table-num--red,
.ticket-table td.ticket-table-num--red {
  border: 5px solid red;
}
.ticket-table thead th {
  font-weight: 700;
  font-size: 16px;
  color: #000;
  background: #fff;
}
@media (max-width:768px) {
  .ticket-table thead th.ticket-table-h {
    font-size: 15px;
  }
}
.ticket-table-blank {
  width: 13.64%;
}
.ticket-table-sub {
  font-weight: 700;
  font-size: 16px;
}
.ticket-table-note {
  margin-top: 0.5em;
  display: inline-block;
  font-weight: 700;
  font-size: 16px;
}
.ticket-table-year {
  font-weight: 700;
  color: #000;
  white-space: nowrap;
}
@media (min-width:769px) {
  .ticket-table-year {
    letter-spacing: 0.2em;
  }
}
@media (max-width:768px) {
  .ticket-table-year {
    letter-spacing: 0.1em;
  }
}
@media (min-width:769px) {
  .ticket-table-year {
    font-size: 19px;
  }
}
@media (max-width:768px) {
  .ticket-table-year {
    font-size: 15px;
  }
}
.ticket-table-num {
  font-weight: 700;
  font-size: 19px;
  color: #674498;
  letter-spacing: 0.02em;
  white-space: nowrap;
}
@media (min-width:769px) {
  .ticket-notes {
    margin-top: 0;
  }
}
@media (max-width:768px) {
  .ticket-notes {
    margin-top: 10px;
  }
}
.ticket-notes-txt {
  font-size: 13px;
  font-weight: 400;
  letter-spacing: 0.15em;
}
@media (min-width:769px) {
  .ticket-notes-txt {
    line-height: 1.7;
  }
}
@media (max-width:768px) {
  .ticket-notes-txt {
    line-height: 1.5;
  }
}
@media (min-width:769px) {
  .ticket-end-txt-frame {
    text-align: center;
  }
}
@media (min-width:769px) {
  .ticket-pics-container {
    margin-top: 40px;
  }
}
@media (max-width:768px) {
  .ticket-pics-container {
    margin-top: 30px;
  }
}
@media (min-width:769px) {
  .ticket-pics-columns {
    display: grid;
    grid-template-columns: 1.17fr 1fr;
    gap: clamp(41.75px, 3.4722222222vw, 100px);
  }
}
@media (max-width:768px) {
  .ticket-pics-columns {
    display: flex;
    flex-direction: column;
    gap: 30px;
  }
}
.ticket-pics-column-02 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}
@media (min-width:769px) {
  .ticket-pics-column-02 {
    gap: clamp(16.7px, 1.3888888889vw, 40px);
  }
}
@media (max-width:768px) {
  .ticket-pics-column-02 {
    gap: 3.4666666667vw;
  }
}
.ticket-pic-caption {
  text-align: center;
  font-size: 14px;
  font-weight: 700;
  margin-top: 10px;
}

/************************************************************
SCREEN ALL
*************************************************************/
@media (min-width:769px) {
  .data {
    padding-top: 100px;
  }
}
@media (max-width:768px) {
  .data {
    padding-top: 50px;
  }
}
@media (min-width:769px) {
  .data {
    padding-bottom: 30px;
  }
}
@media (max-width:768px) {
  .data {
    padding-bottom: 20px;
  }
}
.data-chart-container {
  margin-top: 30px;
  display: flex;
  flex-direction: column;
}
@media (min-width:769px) {
  .data-chart-container {
    gap: 90px;
  }
}
@media (max-width:768px) {
  .data-chart-container {
    gap: 20px;
  }
}
@media (min-width:769px) {
  .data-chart-columns {
    display: grid;
    grid-template-columns: 1.78fr 1fr;
    align-items: center;
    gap: clamp(50.1px, 4.1666666667vw, 120px);
  }
}
@media (max-width:768px) {
  .data-chart-columns {
    display: flex;
    flex-direction: column;
    gap: 30px;
  }
}
.data-chart-column--chart {
  width: 100%;
}
.data-chart-caption {
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.1em;
}
@media (min-width:769px) {
  .data-chart-caption {
    margin-bottom: 14px;
  }
}
@media (max-width:768px) {
  .data-chart-caption {
    margin-bottom: 30px;
  }
}
@media (min-width:769px) {
  .data-chart-caption {
    line-height: 2.2;
  }
}
@media (max-width:768px) {
  .data-chart-caption {
    line-height: 1.7;
  }
}
.data-chart-box {
  position: relative;
  margin-inline: auto;
  background-color: #E4DBF7;
}
@media (min-width:769px) {
  .data-chart-box {
    width: 100%;
  }
}
@media (max-width:768px) {
  .data-chart-box {
    width: 96%;
  }
}
@media (min-width:769px) {
  .data-chart-box {
    height: 80px;
  }
}
@media (max-width:768px) {
  .data-chart-box {
    height: 70px;
  }
}
.data-chart-box-axis-item {
  position: absolute;
  top: -10px;
  left: calc(var(--i) * 1%);
  height: calc(100% + 20px);
  width: 1px;
  background-color: #ccc;
}
.data-chart-box-axis-item-txt {
  position: absolute;
  bottom: -2em;
  left: calc(50% + 0.5em);
  transform: translateX(-50%);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.1em;
}
.data-chart-box-bar {
  position: absolute;
  top: 0;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  /*&-inner{
    padding:0 .25em;
    &-txt{
      @include media.resp(font-size,clamp(15px * 0.835,func.getvw(15,1440),15px),clamp(0px,func.getvw(10),10px));
      font-weight: 700;
      letter-spacing: 0.1em;
      line-height: 1.4em;
      text-align: center;
      &--white{
        color: white;
      }
      strong{
        display:inline-block;
        margin-top:0.25em;
        @include media.resp(font-size,clamp(22px * 0.835,func.getvw(22,1440),22px),clamp(0px,func.getvw(16),16px));
      }
    }
  }*/
}
.data-chart-box-bar--01 {
  left: 0;
  width: calc(var(--i) * 1%);
  background-color: #674498;
}
.data-chart-box-bar--02 {
  right: 0;
  width: calc(var(--i) * 1%);
  background-color: #E4DBF7;
}
.data-chart-box-bar-fukidashi {
  position: absolute;
  z-index: 10;
  display: inline-block;
  border: 1px solid #674498;
  background-color: #ffffff;
  box-shadow: 4px 4px 8px 0 rgba(0, 0, 0, 0.15);
  transform: translate3d(0, 0, 0);
  will-change: transform;
  font-weight: 700;
  line-height: 1em;
  letter-spacing: 0.1em;
  white-space: nowrap;
}
@media (min-width:769px) {
  .data-chart-box-bar-fukidashi {
    padding: 16px 8px 16px 16px;
  }
}
@media (max-width:768px) {
  .data-chart-box-bar-fukidashi {
    padding: 12px 5px 12px 12px;
  }
}
@media (min-width:769px) {
  .data-chart-box-bar-fukidashi {
    font-size: 16px;
  }
}
@media (max-width:768px) {
  .data-chart-box-bar-fukidashi {
    font-size: clamp(0px, 3.7333333333vw, 14px);
  }
}
@media (min-width:769px) {
  .data-chart-box-bar-fukidashi strong.-size-01 {
    font-size: 20px;
  }
}
@media (max-width:768px) {
  .data-chart-box-bar-fukidashi strong.-size-01 {
    font-size: clamp(0px, 4.8vw, 18px);
  }
}
@media (min-width:769px) {
  .data-chart-box-bar-fukidashi strong.-size-02 {
    font-size: 22px;
  }
}
@media (max-width:768px) {
  .data-chart-box-bar-fukidashi strong.-size-02 {
    font-size: clamp(0px, 5.3333333333vw, 20px);
  }
}
@media (min-width:769px) {
  .data-chart-box-bar-fukidashi--01 {
    left: 43.5064935065%;
  }
}
@media (max-width:768px) {
  .data-chart-box-bar-fukidashi--01 {
    left: 20%;
  }
}
@media (min-width:769px) {
  .data-chart-box-bar-fukidashi--02 {
    right: -28px;
  }
}
@media (max-width:768px) {
  .data-chart-box-bar-fukidashi--02 {
    right: -10px;
  }
}
@media (min-width:769px) {
  .data-chart-box-bar-fukidashi--03 {
    left: 35.8974358974%;
  }
}
@media (max-width:768px) {
  .data-chart-box-bar-fukidashi--03 {
    left: 20%;
  }
}
@media (min-width:769px) {
  .data-chart-box-bar-fukidashi--04 {
    right: -28px;
  }
}
@media (max-width:768px) {
  .data-chart-box-bar-fukidashi--04 {
    right: -10px;
  }
}
.data-chart-box-bar-fukidashi--up {
  bottom: 0;
}
@media (min-width:769px) {
  .data-chart-box-bar-fukidashi--up {
    transform: translateY(10px);
  }
}
@media (max-width:768px) {
  .data-chart-box-bar-fukidashi--up {
    transform: translateY(17px);
  }
}
.data-chart-box-bar-fukidashi--up .data-chart-box-bar-fukidashi-mask {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: white;
}
.data-chart-box-bar-fukidashi--up::before {
  content: "";
  position: absolute;
  top: 1px;
  left: 36px;
  border-style: solid;
  border-width: 0 26px 15px 0;
  border-color: transparent transparent #674498;
  transform: translate3d(-50%, -100%, 0);
  will-change: transform;
}
.data-chart-box-bar-fukidashi--up::after {
  content: "";
  position: absolute;
  top: 1px;
  left: 36px;
  border-style: solid;
  border-width: 0 23px 13.3px 0;
  border-color: transparent transparent #ffffff;
  transform: translate3d(calc(-50% - 0.2px), -100%, 0);
  will-change: transform;
}
.data-chart-box-bar-fukidashi--down {
  top: 0;
}
@media (min-width:769px) {
  .data-chart-box-bar-fukidashi--down {
    transform: translateY(-50%);
  }
}
@media (max-width:768px) {
  .data-chart-box-bar-fukidashi--down {
    transform: translateY(-60%);
  }
}
.data-chart-box-bar-fukidashi--down .data-chart-box-bar-fukidashi-mask {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: white;
}
.data-chart-box-bar-fukidashi--down::before {
  content: "";
  position: absolute;
  bottom: 1px;
  right: 125px;
  border-style: solid;
  border-width: 15px 26px 0 0;
  border-color: #674498 transparent transparent;
  transform: translate3d(-50%, 100%, 0);
  will-change: transform;
}
.data-chart-box-bar-fukidashi--down::after {
  content: "";
  position: absolute;
  bottom: 1px;
  right: 128px;
  border-style: solid;
  border-width: 13.3px 23px 0 0;
  border-color: #ffffff transparent transparent;
  transform: translate3d(calc(-50% - 0.2px), 100%, 0);
  will-change: transform;
}
.data-chart-txt {
  font-size: 15px;
  font-weight: 400;
  letter-spacing: 0.1em;
}
@media (min-width:769px) {
  .data-chart-txt {
    line-height: 2.2;
  }
}
@media (max-width:768px) {
  .data-chart-txt {
    line-height: 1.7;
  }
}
@media (max-width:768px) {
  .data-chart-txt {
    margin-top: 16px;
  }
}
.data-chart-txt strong {
  font-weight: 700;
  color: #674498;
}

/************************************************************
SCREEN ALL
*************************************************************/
@media (min-width:769px) {
  .future {
    padding-top: 100px;
  }
}
@media (max-width:768px) {
  .future {
    padding-top: 30px;
  }
}
.future-txt-container {
  margin-top: 30px;
}
.future-txt-01 {
  font-size: 15px;
  font-weight: 400;
  letter-spacing: 0.1em;
}
@media (min-width:769px) {
  .future-txt-01 {
    line-height: 2.2;
  }
}
@media (max-width:768px) {
  .future-txt-01 {
    line-height: 1.7;
  }
}
.future-txt-01 + .future-txt-01 {
  margin-top: 1em;
}
.future-txt-strong {
  font-weight: 700;
}
@media (min-width:769px) {
  .future-contents-table-container {
    margin: 24px 0;
  }
}
@media (max-width:768px) {
  .future-contents-table-container {
    margin: 20px 0;
  }
}
@media (min-width:769px) {
  .future-contents-table-container {
    display: flex;
    justify-content: center;
  }
}
@media (min-width:769px) {
  .future-contents-table-container .about-price-frame-table {
    width: auto;
  }
}
@media (min-width:769px) {
  .future-contents-table-container .only-future-sp {
    display: none;
  }
}

/************************************************************
SCREEN ALL
*************************************************************/
main {
  position: relative;
}

/************************************************************
SCREEN SP
*************************************************************/
@media (max-width:768px) {
  main {
    overflow: hidden;
  }
}
/************************************************************
SCREEN PC
*************************************************************/
@media (min-width:769px) {
  main {
    overflow: hidden;
  }
}