@charset "UTF-8";
/* ----------------------------------------------------------------------------------------------------
*  基本情報  * --------------------------------------------------------------------------------------------------*/
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=BIZ+UDPMincho&family=Crimson+Text:ital,wght@0,400;0,600;0,700;1,400;1,600;1,700&family=Hina+Mincho&family=Nanum+Gothic&family=Noto+Serif+JP:wght@200..900&family=Zen+Old+Mincho&display=swap");

html,
body {
  height: 100%;
}
html {
  font-size: 62.5%;
  overflow-y: scroll;
}
body,
h1,
h2,
h3,
h4,
h5,
h6,
p,
address,
ul,
ol,
li,
dl,
dt,
dd,
table,
th,
td,
img,
form,
figure,
button {
  margin: 0;
  padding: 0;
  border: none;
  font-size: 16px;
  line-height: calc(24 / 16);
  font-style: normal;
  font-weight: normal;
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, sans-serif;
  text-align: left;
  color: var(--black);
}
div,
h1,
h2,
h3,
h4,
h5,
h6,
p,
dl,
dt,
dd,
ol,
ul,
li,
form,
input,
textarea,
button,
table,
tr,
th,
td,
article,
aside,
footer,
header,
hgroup,
nav,
section,
a,
span,
img {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}
body {
  background-color: #ffffff;
}
a {
  color: var(--black);
  font-size: 16px;
  text-decoration: none;
  transition: opacity 0.3s ease-out;
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, sans-serif !important;
}
a img {
  transition: opacity 0.3s ease-out;
}
a:hover {
  opacity: 0.7;
  background-color: transparent;
}
a:hover img {
  opacity: 0.7;
}
figure {
  text-align: center;
  line-height: 0;
}
.sp {
  display: none;
}
.wrap {
  width: 100%;
  max-width: 950px;
  margin: auto;
}
img {
  width: 100%;
}
#navwrap li,
#online_menu li,
footer li {
  list-style-type: none;
}
.inline_block {
  display: inline-block;
}
/* 米印 */
.note {
  font-size: 14px;
  margin-top: 16px;
  color: #959ca0;
}
/* 価格など */
.small_txt {
  font-size: 0.8em;
}

@media screen and (min-width: 821px) {
  html {
    scroll-behavior: smooth;
  }
}

@media screen and (max-width: 820px) {
  html,
  body {
    overflow-x: hidden;
    overflow-y: auto; /* これを追加 */
  }
  body {
    min-width: inherit;
  }
  figure {
    width: 100%;
    text-align: center;
  }
  img {
    display: block;
    margin: 0 auto;
    max-width: 100%;
    width: 100%;
    height: auto;
  }
  p,
  li,
  th,
  td {
    font-size: 16px;
    line-height: 1.6;
  }
  .sp {
    display: block;
  }
  .pc {
    display: none;
  }
}
@media screen and (max-width: 1300px) {
  .wrap,
  #pricing {
    padding: 4vw;
  }
}
/* ------------------------------
    text/font
------------------------------ */
:root {
  --black: #303233;
  --blue: #6393c2;
  --blue_txt: #0156a9;
}
.blue_txt {
  color: var(--blue_txt);
}
.blue {
  color: var(--blue);
}
.ta_c {
  text-align: center;
}
.fwb {
  font-weight: bold;
}
.link_txt {
  text-decoration: underline;
  color: var(--blue);
}
.menu_info {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 24px;
  text-decoration: underline;
  color: var(--blue);
}
.menu_info::before {
  content: "";
  width: 0;
  height: 0;
  margin-right: 0.2em;
  margin-top: 0.2em;
  border-left: 9px solid var(--blue_txt);
  border-top: 6px solid transparent;
  border-bottom: 6px solid transparent;
}
.menu_info:hover {
  color: var(--blue_txt);
}
.marker_red {
  background: linear-gradient(transparent 77%, #fe7667 77%, #fe7667 96%, transparent 96%);
  padding: 4px 6px;
}
.marker {
  background: linear-gradient(transparent 50%, rgba(255, 220, 123) 50%);
  display: inline;
  background-repeat: no-repeat;
  background-size: 0% 100%;
  transition: background-size 1.2s;
}
/* マーカーが引かれる際に付与するクラス */
.marker.on {
  background-size: 100% 100%;
}

.udl {
  background: linear-gradient(transparent 84%, var(--black) 84%, var(--black) 92%, transparent 92%);
  padding-bottom: 3px;
}
@media screen and (max-width: 820px) {
  .udl,
  .mac .udl {
    background: none;
    border-bottom: 1px solid var(--black);
    padding: 0.05em 0;
  }
}

/* ------------------------------
    float
------------------------------ */
@media screen and (min-width: 821px) {
  .f_left {
    float: left;
  }
  .f_right {
    float: right;
  }
}

/* ------------------------------
    clearfix
------------------------------ */
.clear {
  clear: both;
}
.o_hidden {
  overflow: hidden;
}

/* ------------------------------
*  btn
------------------------------ */
.btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 280px;
  height: 54px;
  font-weight: bold;
  background: linear-gradient(90deg, #6393c2 0%, #0156a9 50%, #6393c2 100%);
  background-size: 200% 100%;
  background-position: 0 0;
  box-shadow: 0px 0px 8px rgba(0, 0, 0, 0.16);
  border-radius: 100px;
  cursor: pointer;
  margin: 0 auto;
  transition: background-position 0.5s ease, transform 0.2s ease;
  overflow: hidden;
}
.btn a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  color: #fff;
  font-size: 18px;
  text-decoration: none;
  padding: 0 20px;
}
@media (any-hover: hover) {
  .btn {
    transition: background-position 0.3s ease, box-shadow 0.3s ease;
  }
  .btn:hover {
    background-position: 100% 0;
    opacity: 1;
    box-shadow: none;
  }
}

.white_btn {
  background: #fff;
  border: solid 1px #f5fcff;
}
.white_btn a {
  color: var(--black);
}
.white_btn a:hover {
  opacity: 0.7;
}
.blue_link {
  background: #fff;
  border: solid 1px var(--blue_txt);
}
.blue_link a {
  color: var(--blue_txt);
}
.blue_link:hover a {
  opacity: 0.7;
}

/* 矢印 */
.arrow {
  position: absolute;
  top: 50%; /* ボタンの垂直中央に配置 */
  right: 10px; /* ボタン右端から10px */
  transform: translateY(-50%); /* 垂直方向の中央揃え */
  display: inline-block;
  width: 7px; /* 矢印の幅 */
  height: 7px; /* 矢印の高さ */
}
.arrow::before {
  position: absolute;
  content: "";
  width: 7px;
  height: 7px;
  border-top: solid 2px #ffffff;
  border-right: solid 2px #ffffff;
  left: -4px;
  top: 0;
  transform: rotate(45deg);
}
.white_btn .arrow::before {
  border-top: solid 2px var(--black);
  border-right: solid 2px var(--black);
}
.blue_link .arrow::before {
  border-top: solid 2px var(--blue_txt);
  border-right: solid 2px var(--blue_txt);
}
.btn_wrap li .arrow::before {
  left: 0px;
  width: 5px;
  height: 5px;
}

@media screen and (max-width: 820px) {
  .btn {
    width: 92vw;
    max-width: 430px;
    height: 16vw;
    max-height: 70px;
    color: #000;
    padding: 1.067vw 3.2vw;
    font-family: Roboto;
    margin-top: 5vw;
  }
  .btn a {
    font-size: 16px;
  }
  .floating-button.pc {
    display: none;
  }
}
/* ------------------------------
*  fix_btn
------------------------------ */
/* 追従ボタンのスタイル */
.floating-button {
  position: fixed; /* 画面に固定 */
  right: 0; /* 画面右端に配置 */
  top: 50%; /* 縦方向の中央 */
  transform: translateY(-50%);
  width: 60px; /* 幅 */
  height: 260px; /* 高さ */
  background-color: #fff; /* 背景色 */
  border-radius: 20px 0 0 20px; /* 左端を丸める */
  box-shadow: 0 0 6px rgba(0, 0, 0, 0.1); /* 影を追加 */
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0; /* 初期状態では非表示 */
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
/* ボタン内部のスタイル */
.button-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}
/* 縦書きのスタイル */
.vertical-text {
  writing-mode: vertical-rl; /* 文字を縦書きにする */
  font-size: 16px;
  font-weight: bold;
  color: #000;
  line-height: 1.5;
}
/* LINEアイコン */
.button-content img {
  width: 45px; /* アイコンサイズ */
  height: 45px;
  cursor: pointer;
  margin-top: 12px;
}
/* ホバー時の効果 */
.floating-button:hover a {
  opacity: 0.7;
  color: var(--blue_txt);
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
.floating-button:hover img {
  opacity: 0.7;
}

/* ------------------------------
*  header
------------------------------ */
.fix_menu {
  position: fixed;
  width: 22%; /* ナビゲーションの横幅 */
  top: 0;
  left: 0; /* 左に固定 */
  height: 100vh; /* ビューポート全体の高さ */
  background-color: #fff;
  box-shadow: 2px 0 5px rgba(0, 0, 0, 0.1); /* 少しの影を追加 */
  z-index: 999;
  padding: 6% 0 3%;
  display: flex;
  flex-direction: column; /* 縦並び */
  align-items: center; /* 水平方向で中央揃え */
  justify-content: center;
  gap: 3%;
}
.fv_logo img {
  width: 75px;
  height: auto;
}
.header_menu {
  display: flex;
  flex-direction: column; /* 縦方向に配置 */
  list-style: none;
  padding: 0;
  margin-bottom: 40px;
  padding: 0 4vw;
  gap: 4px;
}
.header_menu li {
  text-align: center;
}
.header_menu li a {
  text-decoration: none;
  color: var(--black); /* テキストの色 */
  font-size: 14px;
  font-weight: bold;
  text-align: center;
  transition: background-color 0.3s ease; /* ホバー時のアニメーション */
}
.header_menu li a:hover {
  color: var(--blue_txt);
  text-decoration: underline;
}
.sns_flex {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
}
.sns_flex img {
  width: 30px;
  height: auto;
  display: block;
}
.header_menu .sns_flex {
  margin: 32px auto;
}
#navwrap .btn {
  width: 235px;
  height: 48px;
  margin-top: 4px;
}
#navwrap .btn a {
  color: #fff;
  font-size: 14px;
}
#navwrap .btn:hover a {
  text-decoration: none;
}
#navwrap .white_btn a {
  color: var(--black);
}
#navwrap .white_btn:hover a {
  color: var(--blue_txt);
  text-decoration: none;
}
#navwrap {
  position: static; /* 左固定なので静的に設定 */
  padding: 0;
}
#switch {
  display: none;
}
@media screen and (min-width: 1101px) {
  .floating-button .line_icon {
    margin-top: 8px;
  }
  #navwrap .sp {
    display: none;
  }
}
@media screen and (max-width: 1100px) {
  #switch ~ label {
    padding: 12px 12px;
    width: 60px;
    height: 60px;
    background: #fff;
    position: fixed;
    box-sizing: border-box;
    top: 0;
    right: 0;
    z-index: 999;
    cursor: pointer;
  }
  #switch ~ label span {
    display: block;
    width: 26px;
    height: 3px;
    top: 50%;
    left: 0;
    right: 0;
    margin: auto;
    background: var(--black);
    position: absolute;
    -webkit-transition: 0.8s transform;
    transition: 0.8s transform;
    border-radius: 10px;
  }
  #switch ~ label span:before,
  #switch ~ label span:after {
    content: "";
    display: block;
    background: var(--black);
    position: absolute;
    width: 26px;
    height: 3px;
    left: 0;
    right: 0;
    margin: auto;
    border-radius: 10px;
  }
  #switch ~ label span:before {
    top: -9px;
  }
  #switch ~ label span:after {
    top: 9px;
  }
  /* ハンバーガーメニューのデザイン（クロスアニメーション付き） */
  #switch ~ label {
    padding: 20px 14px 20px 12px;
    width: 65px;
    height: 60px;
    background: #fff;
    position: fixed;
    box-sizing: border-box;
    top: 0;
    right: 0;
    z-index: 999;
    cursor: pointer;
  }
  #switch ~ label span {
    display: block;
    width: 26px;
    height: 3px;
    background: var(--blue);
    position: relative;
    margin: 6px auto;
    transition: all 0.8s ease;
    border-radius: 10px;
  }
  #switch ~ label span:before,
  #switch ~ label span:after {
    content: "";
    display: block;
    background: var(--blue);
    position: absolute;
    width: 26px;
    height: 3px;
    left: 0;
    border-radius: 10px;
    transition: all 0.8s ease;
  }
  #switch ~ label span:before {
    top: -9px;
    right: -10px;
  }
  #switch ~ label span:after {
    top: 9px;
    left: -10px;
  }
  /* ハンバーガーメニューをクロスさせる動き */
  #switch:checked ~ label span {
    background: transparent;
  }
  #switch:checked ~ label span:before {
    transform: rotate(45deg);
    top: 0;
    left: -3px;
  }
  #switch:checked ~ label span:after {
    transform: rotate(-45deg);
    top: 0;
    left: 3px;
  }
  /* メニューを右からスライドインさせる */
  #navwrap {
    padding-top: 0;
    position: fixed;
    top: 0;
    right: -100%; /* 初期状態で右画面外に配置 */
    width: 80%;
    height: 100%;
    background: #fff;
    transition: right 0.6s ease; /* スライドインのアニメーション */
    padding: 80px 0 60px;
    box-sizing: border-box;
  }
  #switch:checked ~ #navwrap {
    right: 0; /* メニューが表示される際に右からスライドイン */
  }
  .header_menu {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin-bottom: 5vw;
  }
  .header_menu li {
    margin: 0 auto 8px;
  }
  .header_menu li a {
    color: var(--black);
    font-size: 14px; /* モバイル時は少し小さく */
  }
  .scroll-prevent {
    position: fixed;
    z-index: -1;
    width: 100%;
    height: 100%;
  }
  .fv_logo {
    position: absolute;
    padding: 11px 0 8px 18px;
    top: 0;
    left: 0;
    height: auto;
    width: 60px;
  }
  .fix_menu {
    height: 60px;
    width: 100vw;
  }
  .fv_logo_txt {
    font-size: 13px;
    padding: 8px 32px;
    line-height: 1.5;
  }
  .fv_logo_txt .small_txt {
    font-size: 11px;
  }
  .header_menu li + li::before {
    display: none;
  }
  #navwrap .btn {
    margin-top: 0;
    width: 100%;
  }
  .line {
    position: relative;
  }
  .line_icon {
    position: absolute;
    content: "";
    background: url("../img/LINE_icon.png") no-repeat center / contain;
    width: 31px;
    height: 31px;
    top: 7px;
    top: 50%;
    transform: translateY(-50%);
    left: 18px;
  }
  .header_menu .sns_flex {
    margin: 16px auto;
  }
  #navwrap .sp {
    display: flex;
  }
  body.scroll-lock {
    position: fixed;
    width: 100%;
    overflow: hidden;
  }
  [id] {
    scroll-margin-top: 60px;
  }
}

/* ------------------------------
*  main
------------------------------ */
main {
  margin-left: 22%;
}
.wrap {
  max-width: 950px;
  margin: auto;
}
.thumbnail {
  position: relative;
  max-width: 100%;
  height: 250px;
  background: url("../img/thumbnail.jpg") repeat-x center / cover;
  z-index: 2;
}
section {
  padding: 104px 0;
}
h2 {
  font-size: 36px;
  color: var(--blue_txt);
  text-align: center;
  font-weight: bold;
  margin-bottom: 48px;
}
h3 {
  font-size: 24px;
  text-align: center;
  font-weight: bold;
  margin-bottom: 32px;
}
.txt {
  max-width: 950px;
  margin: 0 auto;
  text-align: center;
}
.txt + .txt {
  margin-top: 24px;
}

@media screen and (max-width: 1100px) {
  .scroll {
    overflow-y: scroll;
  }
  main {
    margin-left: 0;
  }
  section {
    padding: 7vw 0;
  }
  h2 {
    margin-bottom: 9.6vw;
  }
  h3 {
    margin-bottom: 4.267vw;
  }
  .txt + .txt {
    margin-top: 3.2vw;
  }
}
@media screen and (max-width: 820px) {
  .thumbnail {
    background: url("../img/thumbnail_sp.jpg") no-repeat center / cover;
    width: 100%;
    height: 260px;
  }
}

/* ------------------------------
*  fv
------------------------------ */
.fv {
  position: relative;
  width: 100%;
  min-height: 832px;
  padding: 120px 0 0 120px;
  overflow: hidden;
}
.fv_1,
.fv_2,
.fv_3,
.fv_4 {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.fv_1 {
  background: url("../img/fv_1.jpg") no-repeat top center / cover;
  animation: slide-animation-01 24s infinite;
}
.fv_2 {
  background: url("../img/fv_2.jpg") no-repeat top center / cover;
  animation: slide-animation-02 24s infinite;
}
.fv_3 {
  background: url("../img/fv_3.jpg") no-repeat top center / cover;
  animation: slide-animation-03 24s infinite;
}
.fv_4 {
  background: url("../img/fv_4.jpg") no-repeat top center / cover;
  animation: slide-animation-04 24s infinite;
}
@keyframes slide-animation-01 {
  0% {
    opacity: 1;
    transform: scale(1);
  }
  30% {
    opacity: 1;
  }
  40% {
    opacity: 0;
    transform: scale(1.2);
  }
  90% {
    opacity: 0;
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes slide-animation-02 {
  0% {
    opacity: 0;
  }
  30% {
    opacity: 0;
    transform: scale(1.2);
  }
  40% {
    opacity: 1;
  }
  60% {
    opacity: 1;
  }
  70% {
    opacity: 0;
    transform: scale(1);
  }
  100% {
    opacity: 0;
  }
}
@keyframes slide-animation-03 {
  0% {
    opacity: 0;
  }
  60% {
    opacity: 0;
    transform: scale(1);
  }
  70% {
    opacity: 1;
  }
  90% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    transform: scale(1.2);
  }
}
@keyframes slide-animation-04 {
  0% {
    opacity: 0;
  }
  30% {
    opacity: 0;
    transform: scale(1.2);
  }
  40% {
    opacity: 1;
  }
  60% {
    opacity: 1;
  }
  70% {
    opacity: 0;
    transform: scale(1);
  }
  100% {
    opacity: 0;
  }
}
.fv::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to right, rgba(37, 69, 80, 0.5), rgba(200, 237, 249, 0));
}

.fv .ttl {
  position: relative;
  z-index: 1;
  font-size: 64px;
  color: #fff;
  margin-bottom: 51px;
  line-height: 1.3;
  text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.1);
}
.fv p {
  position: relative;
  z-index: 1;
  font-size: 18px;
  color: #fff;
  margin: 0 auto;
  text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.1);
}
@media screen and (max-width: 820px) {
  .fv {
    padding: 5vw 0;
    margin-top: 60px;
    min-height: 80vw;
  }
  .fv::after {
    min-height: 80vw;
  }
  .fv_1 {
    background: url("../img/fv_1_sp.jpg") no-repeat top center / cover;
  }
  .fv_2 {
    background: url("../img/fv_2_sp.jpg") no-repeat top center / cover;
  }
  .fv_3 {
    background: url("../img/fv_3_sp.jpg") no-repeat top center / cover;
  }
  .fv_4 {
    background: url("../img/fv_4_sp.jpg") no-repeat top center / cover;
  }
  .fv .ttl {
    font-size: 48px;
    color: #fff;
    margin-bottom: 5vw;
    letter-spacing: 0.2em;
    padding: 64vw 0 0 5vw;
    text-shadow: 2px 2px 2px rgba(0, 0, 0, 0.1);
  }
  .fv p {
    color: #fff;
    margin: 0 auto;
    padding: 0 5vw;
    font-size: 16px;
  }
}
/* ------------------------------
*  profile
------------------------------ */
#profile {
  background-color: #f5f8fb;
}
#profile .f_left {
  width: 52%;
  margin-right: 4%;
  margin-bottom: 56px;
}
#profile dt {
  font-size: 22px;
  font-weight: bold;
  margin-bottom: 8px;
  line-height: 1;
}
#profile dd {
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 72px;
}
#profile p + p {
  margin-top: 40px;
}
@media screen and (max-width: 820px) {
  #profile .f_left {
    width: 100%;
    margin-bottom: 5vw;
  }
  #profile dt {
    margin-bottom: 3vw;
    text-align: center;
  }
  #profile dd {
    margin-bottom: 9.6vw;
    text-align: center;
  }
  #profile p + p,
  #profile .inner {
    margin-top: 5vw;
  }
}
/* ------------------------------
*  pricing
------------------------------ */
@media screen and (min-width: 821px) {
  #pricing .flex_container {
    display: flex;
    align-items: start;
    justify-content: center;
    margin: 48px auto;
    gap: 20px;
  }
  #pricing #subscription_menu .flex_container {
    margin: 48px auto 64px;
  }
  /* circle_flex */
  #pricing .circle_flex {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: start;
    gap: 48px;
    padding-top: 16px;
    margin: 48px auto;
  }
  #pricing .contents_box {
    position: relative;
    margin-bottom: 16px;
    text-align: center;
  }
  #subscription_menu .contents_box {
    width: 36%;
    max-width: 600px;
  }
  #pricing .contents_box img {
    width: 200px;
    height: 200px;
    border-radius: 50%;
    margin: 16px auto;
  }
  #pricing .contents_box .number {
    font-size: 40px;
    color: var(--blue);
    text-align: center;
    font-weight: bold;
    font-family: "Crimson Text", serif;
    font-weight: 700;
    font-style: italic;
    line-height: 1;
    vertical-align: middle;
  }
  #pricing .contents_box .number span {
    font-size: 20px;
    margin-right: 6px;
  }
  #pricing .contents_box .plan_txt {
    color: var(--blue);
  }
  #pricing .circle_flex + .txt {
    margin-bottom: 64px;
  }
  #plan_training .flex_container {
    gap: 40px;
  }
  #plan_training,
  #online_menu,
  #subscription_menu {
    margin-top: 104px;
  }
  #plan_training .btn,
  #online_menu .btn {
    margin-top: 48px;
  }
  #plan_training .blue_link,
  #subscription_menu .blue_link {
    margin-top: 24px;
  }

  #online_menu .flex_container {
    position: relative;
    margin-bottom: 100px;
  }
  #online_menu .flex_container::after {
    position: absolute;
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-color: var(--blue) transparent transparent transparent;
    left: 50%;
    transform: translateX(-50%);
    border-width: 38px 35px 0 35px;
    top: 465px;
  }
  #online_menu .btn {
    margin-top: 24px;
  }
  #pricing .flex_box {
    display: flex;
    flex-wrap: wrap;
    align-items: start;
    justify-content: space-between;
    margin-bottom: 72px;
    gap: 24px;
  }
  #pricing .flex_box img {
    width: 210px;
    height: auto;
    border: solid 1px #efefef;
  }
  .LINE_txt {
    position: relative;
    margin: 109px auto 54px;
  }
  .LINE_txt::after {
    position: absolute;
    content: "";
    background: #f4e8ba;
    width: 100px;
    height: 2px;
    left: 50%;
    transform: translateX(-50%);
    top: 35px;
  }
  .LINE .txt {
    margin-top: 32px;
  }
  .LINE img {
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
  }
  .caption_txt {
    margin-bottom: 32px;
    text-align: center;
  }
}
#pricing {
  background-color: #fdfbf3;
}
#pricing .flex_container img {
  margin-bottom: 16px;
}
/* 吹き出し */
#pricing .sub_txt {
  position: relative;
  font-weight: bold;
  color: var(--blue_txt);
  display: inline-block;
  padding: 0 1.5em 0 2em;
  left: 50%;
  transform: translateX(-50%);
}
#pricing .sub_txt::before,
#pricing .sub_txt::after {
  content: "";
  position: absolute;
  top: 1em;
  width: 18px;
  height: 18px;
  border-top: 2px solid var(--blue_txt);
}
#pricing .sub_txt::before {
  left: 0;
  transform: translateY(-50%) rotate(61deg);
}
#pricing .sub_txt::after {
  right: 0;
  transform: translateY(-50%) rotate(-61deg);
}
/* カードデザイン */
.training-card {
  position: relative;
  width: 310px;
  box-sizing: border-box;
  border: 1px solid var(--blue);
  border-radius: 4px;
  background-color: #fff;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}
.card-header {
  background-color: var(--blue);
  color: #ffffff;
  text-align: center;
  padding: 24px 0;
  font-size: 20px;
  font-weight: bold;
}

/* カードの中身 */
.card-body {
  padding: 32px 16px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

@media screen and (min-width: 821px) {
  .card-body {
    height: 686px;
  }
  #plan_training .card-body {
    height: 740px;
  }
  #subscription_menu .card-body {
    height: 634px;
  }
  #online_menu .card-body {
    height: 350px;
  }
}

/* 人気No.1バッジ */
.times_info_wrap {
  height: 144px;
}
.times_info {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-bottom: 32px;
}
#subscription_menu .times_info {
  margin-bottom: 0;
}
#subscription_menu .training-card:first-child .times_info {
  margin-bottom: 70px;
}
.circle-badge {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #ffffff;
  border: 1px solid var(--black); /* 枠線 */
  border-radius: 50%;
  font-weight: bold;
  line-height: 1.3;
  min-width: 80px;
  min-height: 80px;
}
/* コース文字サイズ */
.times_info p {
  font-weight: bold;
  text-align: center;
}
.times_info .minutes {
  font-size: clamp(30px, 5vw, 40px);
}
.plan_times_txt {
  font-size: 32px;
  line-height: 1.2;
}
.times_info .times {
  font-size: 18px;
  line-height: 1.2;
}
.times_info .big_number {
  font-size: 24px;
}
.monthly {
  font-size: 20px;
  line-height: 1;
  margin-bottom: -8px;
}
.monthly .big_number {
  font-size: 26px;
}
.subscription_note {
  text-align: center;
  color: #959ca0;
  margin: 8px auto 16px;
}
/* 説明テキスト */
.description {
  color: var(--blue);
  font-weight: bold;
}
.description + .description {
  margin-top: 16px;
}
.consult {
  font-size: 14px;
  margin-top: 16px;
}
/* 価格表示 */
.price {
  font-size: 24px;
  font-weight: bold;
  text-align: center;
}
.session_list {
  margin: 40px auto;
  text-align: center;
}
.session_list li {
  max-width: 750px;
  padding-left: 194px;
  margin: 0 auto;
}
.session_youtube {
  text-align: center;
}
.session_youtube iframe {
  width: 700px;
  height: auto;
  margin: 0 auto;
  aspect-ratio: 16/9;
  margin-bottom: 16px;
}
.online_support {
  background-color: #f1f8ff;
  padding: 24px 24px 8px;
  border-radius: 8px;
  margin: 0 auto 8px;
  max-width: 500px;
}
.check_list {
  padding: 0;
  margin: 16px 0 0;
}
.check_list li {
  position: relative;
  padding-left: 28px;
  margin-bottom: 12px;
  font-size: 16px;
  line-height: 1.6;
}
.check_list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 3px;
  width: 20px;
  height: 20px;
  background-image: url("../img/check.png");
  background-size: contain;
  background-repeat: no-repeat;
}

/* 赤吹き出し */
@keyframes pulse {
  0%,
  100% {
    transform: translateX(-50%) scale(1);
  }
  50% {
    transform: translateX(-50%) scale(1.05); /* 少しだけ拡大 */
  }
}
.save_txt_box {
  position: absolute;
  bottom: -15px; /* カードより少し下にかぶせる */
  left: 50%;
  transform: translateX(-50%);
  background-color: #ff4444;
  color: #fff;
  padding: 6px 20px;
  border-radius: 50px;
  font-size: 16px;
  text-align: center;
  z-index: 10;
  white-space: nowrap;
  width: fit-content;
  animation: pulse 2s infinite ease-in-out;
}
.save_txt_box::before {
  content: "";
  position: absolute;
  top: -6px;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 8px solid transparent;
  border-right: 8px solid transparent;
  border-bottom: 8px solid #ff4444;
}

#pricing .circle_flex p + p {
  margin-top: 16px;
}

@media screen and (max-width: 820px) {
  #pricing .training-card {
    margin: 10vw auto;
    text-align: center;
    width: 100%;
  }
  #pricing .circle_flex {
    padding-top: 2.133vw;
  }
  #plan_training,
  #online_menu,
  #subscription_menu {
    margin-top: 20vw;
  }
  /* circle_flex */
  #pricing .circle_flex {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    align-items: start;
    gap: 4vw;
    padding-top: 2.133vw;
    margin: 10vw auto;
  }
  #pricing .contents_box {
    position: relative;
    margin-bottom: 2.133vw;
    text-align: center;
    width: 43vw;
  }
  #pricing .contents_box img {
    width: 34vw;
    height: 34vw;
    border-radius: 50%;
    margin: 4px auto 8px;
  }
  #pricing .contents_box .number {
    font-size: 40px;
    color: var(--blue);
    text-align: center;
    font-weight: bold;
    font-family: "Crimson Text", serif;
    font-weight: 700;
    font-style: italic;
    line-height: 1;
  }
  #pricing .contents_box .number span {
    font-size: 4vw;
    padding-right: 6px;
  }
  #pricing .contents_box .plan_txt {
    color: var(--blue);
    font-size: clamp(9px, 3.2vw, 16px);
    white-space: nowrap;
  }
  #pricing .circle_flex + .txt {
    margin-bottom: 8.533vw;
  }
  .LINE_txt {
    position: relative;
    margin: 15vw auto 5vw;
  }
  .LINE_txt::after {
    position: absolute;
    content: "";
    background: #f4e8ba;
    width: 13.333vw;
    height: 0.267vw;
    left: 50%;
    transform: translateX(-50%);
    top: 7.667vw;
  }
  .LINE .txt {
    margin-top: 8vw;
  }
  .LINE img {
    width: 70vw;
    margin-top: 5vw;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
  }
  .caption_txt {
    margin-bottom: 32px;
    text-align: center;
  }
  .session_youtube {
    width: 92vw;
    margin: 0 auto;
  }
  .session_youtube iframe {
    width: 100%;
  }
  .card-body,
  #plan_training .card-body,
  #online_menu .card-body {
    height: auto;
  }
  .session_list li {
    max-width: none;
    padding-left: 4vw;
  }
  .online_support {
    max-width: 360px;
    margin: 0 auto;
  }
}
/* ------------------------------
*  voice
------------------------------ */
#voice {
  background-color: #c5d4e3;
  /* background: url("../img/check_bg.jpg") repeat; */
}
.voice_flex {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 40px;
  margin-top: 72px;
}
.voice_flex img {
  width: 270px;
  height: auto;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
  border: solid 1px #c5d4e3;
}
figcaption {
  font-size: 14px;
  line-height: 1.6;
  margin-top: 8px;
  font-weight: bold;
}
#voice figure:nth-of-type(5) {
  margin-top: -223px;
}
#voice figure:nth-of-type(6) {
  margin-top: -223px;
}
@media screen and (max-width: 820px) {
  .voice_flex img {
    width: 70vw;
  }
  .voice_flex {
    margin-top: 8vw;
  }
  #voice figure:nth-of-type(5) {
    margin-top: 0;
  }
  #voice figure:nth-of-type(6) {
    margin-top: 0;
  }
}
/* ------------------------------
*  form
------------------------------ */
#form {
  background-color: #eef0f2;
}
#form .txt + .txt {
  margin-bottom: 72px;
}
.reservation-form {
  max-width: 650px;
  margin: 0 auto;
  /* background-color: #ffffff; */
  /* box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1); */
}

/* ラベルと入力フィールド */
.form-group {
  margin-bottom: 32px;
}
.form-group label {
  display: block;
  margin-bottom: 2px;
  cursor: pointer;
}
.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: 16px;
  background-color: #fff;
  border: 1px solid #ccc;
  border-radius: 8px;
  font-size: 16px;
  line-height: 1.5;
}
.form-group textarea {
  resize: vertical;
}
/* 必須ラベルのスタイル */
.label-group {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 16px; /* inputの上余白 */
}
.required {
  display: inline-block;
  border: 1px solid #ff6262;
  color: #ff6262;
  background: #fff;
  font-size: 12px;
  font-weight: bold;
  padding: 2px 6px;
  border-radius: 1px;
  text-align: center;
}
.optional {
  display: inline-block;
  border: 1px solid var(--blue);
  color: var(--blue);
  background: #fff;
  font-size: 12px;
  font-weight: bold;
  padding: 2px 6px;
  border-radius: 1px;
  text-align: center;
}

.menu-time-select {
  margin-top: -16px;
}
.menu-time-select .label-group {
  margin-bottom: 8px;
}
/* 日付と時間のレイアウト */
.time-group {
  margin-top: 12px; /* 時間選択との間に余白 */
}
.time-input {
  display: flex;
  align-items: center;
  gap: 8px;
}
.time-input .time-select {
  width: 150px; /* 時間選択の幅 */
  padding: 14px;
  border: 1px solid #ccc;
  border-radius: 8px;
  font-size: 16px;
  box-sizing: border-box;
}
.time-input span {
  font-size: 14px;
  color: #333;
}

/* 送信ボタン */
.form-submit {
  text-align: center;
}
/* ボタン内のテキストスタイル */
.btn button {
  all: unset; /* ボタンのデフォルトスタイルをリセット */
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff; /* テキストの色 */
  font-size: 16px;
  font-weight: inherit;
  width: 100%; /* ボタンの幅を親要素に合わせる */
  height: 100%; /* ボタンの高さを親要素に合わせる */
  text-align: center;
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, sans-serif !important;
}
/* 利用規約の横並び設定 */
.form-group.terms_txt label {
  display: flex; /* フレックスボックスを使用 */
  align-items: center; /* 垂直方向に中央揃え */
  justify-content: center;
  margin-left: -24px;
  gap: 8px; /* チェックボックスとテキストの間隔 */
}
.form-group .checkbox {
  width: 16px;
  height: 16px;
  cursor: pointer;
}
#form .message_txt {
  font-size: 12px;
  margin-bottom: 16px;
}
/* メディアクエリ（レスポンシブ対応） */
@media screen and (max-width: 820px) {
  #form .txt + .txt {
    margin-bottom: 10vw;
  }
  #form .txt {
    width: 100%;
  }
  .btn button {
    width: 100%;
    font-size: 16px;
  }
  .form-group input,
  .form-group select {
    height: 16vw;
  }
  .time-input .time-select {
    width: 30vw;
  }
}
/* ------------------------------
*  gym
------------------------------ */
@media screen and (max-width: 820px) {
  .google_map {
    height: 50vw;
    margin-bottom: 10vw;
  }
  #gym dl p,
  #gym dl a {
    font-size: 14px;
  }
  #gym dt {
    font-size: 18px;
    font-weight: bold;
    margin-bottom: 1vw;
  }
  #gym dl + dl {
    margin-top: 5vw;
  }
  #gym .bus {
    margin-top: 2vw;
  }
}
@media screen and (min-width: 821px) {
  #gym .flex_container {
    display: flex;
    align-items: start;
    justify-content: space-between;
  }
  #gym dl p,
  #gym dl a {
    font-size: 14px;
  }
  #gym dt {
    font-size: 18px;
    font-weight: bold;
  }
  #gym dl + dl {
    margin-top: 32px;
  }
  #gym .txt_box {
    width: 42%;
  }
  .google_map {
    width: 50%;
    height: 465px;
  }
  #gym .bus {
    margin-top: 8px;
  }
}

/* ------------------------------
*  footer
------------------------------ */
footer {
  position: relative;
  text-align: center;
  background-color: #0e2f4e;
  padding: 80px 0 32px;
  margin-left: 22%;
}
footer * {
  color: #fff;
}
footer ul li {
  position: relative;
  display: inline-block;
}
footer .nav_link li a {
  padding: 0 1.2em;
}
footer .sns li a {
  padding: 0 0.5em;
}
footer ul {
  text-align: center;
}
footer .nav_link li + li::before {
  position: absolute;
  content: "";
  background: #fff;
  width: 1px;
  height: 16px;
  top: 0.5em;
  left: -0.1em;
}
footer .sns img {
  width: 32px;
  height: auto;
}
footer .logo img {
  width: 100px;
  height: auto;
  margin-bottom: 72px;
}
footer .btn.pc {
  background: transparent;
  border: 1px solid #fff;
  margin: 32px auto;
}
footer .copy {
  margin-top: 32px;
}
@media screen and (min-width: 821px) {
  footer .sp {
    display: none;
  }
}
@media screen and (max-width: 820px) {
  footer {
    padding: 15vw 0 10vw;
  }
  footer .logo img {
    margin-bottom: 8vw;
    width: 20vw;
  }
  footer .sns {
    margin: 3vw auto 0;
  }
  footer .sns img {
    width: 26px;
    height: auto;
  }
  footer .sns li {
    padding: 0 2vw;
  }
  footer ul {
    margin: 3vw auto 4.6vw;
  }
  footer .nav_link {
    margin-bottom: 10vw;
  }
  footer .nav_link li {
    display: block;
    text-align: center;
    margin-top: 8px;
  }
  footer ul li::before {
    display: none;
  }
  footer .pc {
    display: none;
  }
  footer .btn {
    margin: 0 auto;
  }
  footer .white_btn {
    background: #fff;
  }
  footer .copy {
    font-size: 10px;
  }
  footer {
    margin-left: 0;
  }
  .btn_wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
  }
  .btn_wrap li {
    width: 86vw;
    height: 15vw;
  }
  .btn_wrap a {
    font-size: 14px;
  }
  .btn_wrap .line_icon {
    width: 10vw;
    height: 10vw;
    max-width: 40px;
    max-height: 40px;
    top: 8px;
    top: 50%;
    transform: translateY(-50%);
    left: 32px;
  }
}
@media screen and (max-width: 1100px) {
  footer {
    margin-left: 0;
  }
}

/* ------------------------------
*  利用規約
------------------------------ */
.terms {
  background-color: #f5f8fb;
  padding: 100px 20px 80px;
}
.terms .wrap {
  max-width: 800px;
  margin: 0 auto;
}
.terms-title {
  font-size: 24px;
  font-weight: bold;
  margin-bottom: 40px;
  text-align: center;
}
.terms-subtitle {
  font-size: 20px;
  font-weight: bold;
  margin: 80px 0 16px;
}
.terms p {
  font-size: 16px;
  margin-bottom: 24px;
}
.terms ul {
  margin: 0 0 16px 20px;
  padding: 0;
  list-style: disc;
}
.terms ol li {
  list-style-type: decimal;
}
.terms ul li {
  font-size: 16px;
  margin-bottom: 8px;
  list-style-type: disc;
}
.terms li + li {
  margin-top: 16px;
}

/* ------------------------------
*  subscription-plans
------------------------------ */

/* fv */
.subscription-plans_fv {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-evenly;
  width: 100%;
  height: 500px;
  padding-left: 10%;
  background: url("../img/subscription-plans_fv_img_pc.jpg") no-repeat top left 20% / cover;
}
.subscription-plans_fv h1 {
  width: 393px;
  height: auto;
}
.subscription-plans_fv p {
  color: #fff;
}
@media screen and (max-width: 820px) {
  .subscription-plans_fv {
    background: url("../img/subscription-plans_fv_img_sp.jpg") no-repeat top center / cover;
    padding: 0 4vw;
    align-items: center;
    justify-content: flex-start;
    padding-top: 100px;
    height: 80vh;
  }
  .subscription-plans_fv h1 {
    width: 92vw;
  }
  .subscription-plans_fv p {
    text-align: center;
  }
}

/* プラン比較表 */
#subscription-plans {
  background-color: #dff7ff;
  position: relative;
}
#subscription-plans .bonus_ttl {
  background-color: #005bac;
  color: #fff;
  font-weight: bold;
  font-size: 18px;
  padding: 10px;
  text-align: center;
  display: inline-block;
  width: 100%;
  clip-path: polygon(7% 0%, 100% 0%, 93% 100%, 0% 100%);
}
#subscription-plans .bonus_card {
  text-align: center;
}
#subscription-plans .sub_ttl {
  background-color: var(--blue);
  color: #fff;
  font-weight: bold;
  padding: 6px 32px;
  border-radius: 20px;
  display: inline-block;
  text-align: center;
}
#subscription-plans .bonus_list {
  background-color: #fff;
  border-radius: 4px;
  margin-top: -14px;
  padding: 26px 0 12px;
}
#subscription-plans .bonus_list li {
  display: flex;
  align-items: center;
  padding: 8px 12px 8px 24px;
  font-size: 16px;
  border-bottom: 1px dashed #ccc;
}
#subscription-plans .bonus_list li:last-child {
  border-bottom: none;
}
#subscription-plans .bonus_list .num {
  color: var(--blue_txt);
  font-weight: bold;
  font-size: 18px;
  display: inline-block;
  margin-right: 16px;
  flex-shrink: 0;
}
#subscription-plans .recommend_point_flex {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 24px;
  margin-top: 24px;
}
#subscription-plans .recommend_point_flex img {
  width: 78px;
}
/* table */
.plan_table_wrap {
  position: relative;
  padding: 55px 0 32px;
  overflow-x: auto;
}
.personal_plans_wrap .plan_table_wrap {
  padding: 22px 0 32px;
}
.subscription_plans_wrap .plan_table_wrap {
  padding: 55px 0;
}
.plan_table {
  width: 100%;
  border-collapse: collapse;
  background-color: #fff;
  border-radius: 12px;
  overflow: hidden;
}
/* ヘッダー */
.plan_table thead th {
  background-color: #99aab5;
  color: #fff;
  padding: 16px 12px;
  text-align: center;
}
/* グラデーションヘッダー（右カラム） */
.plan_table thead th.highlight_header {
  background: linear-gradient(to right, #85b3e1, #38628a);
  position: relative;
  color: #fff;
}
/* リボン画像配置 */
.ribbon_wrap {
  position: relative;
}
.ribbon_wrap img {
  position: absolute;
  top: -34px;
  right: 40px;
  width: 293px;
  z-index: 10;
}
.ribbon_wrap .ribbon_02 {
  right: 239px;
}
/* ラベル列 */
.plan_table tbody th {
  position: relative;
  background-color: #f7f7f7;
  text-align: left;
  padding: 16px;
  font-weight: normal;
  white-space: nowrap;
  text-align: center;
}
.plan_table td {
  padding: 16px;
  border: 1px solid #ddd;
  border-bottom: none;
  border-right: none;
  white-space: nowrap;
  text-align: center;
}
.plan_table th {
  border: 1px solid #ddd;
  border-bottom: none;
  border-left: none;
}
.plan_table tbody tr:first-child td,
.plan_table tbody tr:first-child th {
  border-top: none;
}
.plan_table .small_txt {
  margin-left: 4px;
}
.plan_table .note {
  vertical-align: super;
}
#subscription-plans .balloon_box {
  position: relative;
  display: inline-block;
  padding: 16px 30px;
  background-color: #a3d1f7;
  font-weight: bold;
  font-size: 20px;
  text-align: center;
  border-radius: 4px;
  z-index: 1;
}
#subscription-plans .balloon_box::after {
  content: "";
  position: absolute;
  bottom: -12px;
  left: 50%;
  transform: translateX(-50%);
  border-width: 12px 8px 0 8px;
  border-style: solid;
  border-color: #a3d1f7 transparent transparent transparent;
  display: block;
  width: 0;
}
#subscription-plans .balloon_box p {
  color: var(--blue_txt);
  font-weight: bold;
  text-align: center;
}

@media screen and (min-width: 821px) {
  #subscription-plans .flex_box {
    display: flex;
    align-items: stretch;
    justify-content: space-between;
  }
  .plan_training_wrap .flex_box {
    flex-direction: row-reverse;
  }
  #subscription-plans .plans_wrapper {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 46%;
  }
  .plans_wrapper .white_box {
    background-color: #fff;
    padding: 32px 24px;
  }
  .plans_wrapper .white_box .small_txt {
    margin-top: 24px;
  }
  #subscription-plans figure {
    width: 50%;
  }
  .subscription_plans_wrap {
    margin-top: 104px;
  }
  .personal_plans_wrap {
    margin-top: 56px;
    text-align: center;
  }
  .plan_table .save_txt_box {
    bottom: 14px;
  }
  .plan_table .save_txt_box_01 {
    left: 564px;
  }
  .plan_table .save_txt_box_02 {
    left: 820px;
  }
}

@media screen and (max-width: 820px) {
  .subscription_plans_wrap {
    margin-top: 60px;
    text-align: center;
  }
  .personal_plans_wrap {
    margin-top: 90px;
    text-align: center;
  }
  .personal_plans_wrap .white_btn a {
    font-size: 16px;
  }
  #subscription-plans .bonus_card {
    margin-top: 8px;
  }
  #subscription-plans .recommend_point_flex {
    gap: 8px;
  }
  #subscription-plans .plan_card {
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
    margin: 24px auto;
    overflow: visible;
  }
  #subscription-plans .plan_card_header {
    text-align: center;
    font-weight: bold;
    color: #fff;
    padding: 12px 0;
    font-size: 18px;
    border-radius: 12px 12px 0 0;
  }
  #subscription-plans .plan_card.plan_card_ribbon {
    margin-top: 50px;
  }
  /* 各プランのヘッダー色 */
  #subscription-plans .plan_card_header {
    background-color: #99aab5;
  }
  #subscription-plans .highlight_header {
    position: relative;
    background: linear-gradient(to right, #85b3e1, #38628a);
  }
  /* リボン画像の配置 */
  #subscription-plans .ribbon_img {
    position: absolute;
    top: -35px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 2;
    height: auto;
  }
  /* テーブルスタイル */
  #subscription-plans .plan_card_table {
    width: 100%;
    border-collapse: collapse;
  }
  #subscription-plans .plan_card_table th,
  #subscription-plans .plan_card_table td {
    padding: 12px 16px;
    border-top: 1px solid #eee;
    text-align: left;
    text-align: center;
  }
  #subscription-plans .plan_card_table th {
    font-weight: normal;
    color: #555;
    width: 35%;
    font-size: 14px;
    background-color: #f4f4f4;
  }
  #subscription-plans .small_txt + .flex_box {
    margin-top: 15vw;
  }
  #subscription-plans .plans_wrapper p {
    margin-top: 5vw;
  }
  .subscription_plans_wrap .plan_card_ribbon {
    position: relative;
  }
  #subscription-plans .plan_card:has(.save_txt_box_02) {
    position: relative;
    margin: 60px auto 0;
  }
  .save_txt_box_01 {
    bottom: -36px;
  }
  .save_txt_box_02 {
    bottom: -36px;
  }
}
/* ------------------------------
*  reCAPCHA
------------------------------ */
.g-recaptcha {
  margin-right: auto;
  margin-left: auto;
  text-align: center;
  width: 300px;
  margin-top: 32px;
  margin-bottom: 32px;
}

/* ipad用 */
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .fv_logo img {
    width: 60px;
  }
  .card-header {
    font-size: 16px;
  }
  .times_info .minutes {
    font-size: 26px;
  }
  section {
    padding: 0;
  }
}
/* ipad pro用 */
@media screen and (min-width: 1024px) and (max-width: 1366px) {
  .fv {
    padding: 320px 0 0 70px;
  }
  #navwrap .btn {
    max-width: 500px;
  }
  #navwrap .btn a {
    font-size: 12px;
  }
  #voice figure:nth-of-type(5) {
    margin-top: 0;
  }
  #voice figure:nth-of-type(6) {
    margin-top: 0;
  }
  .card-header {
    font-size: 16px;
  }
  .times_info .minutes {
    font-size: 26px;
  }
}
@media screen and (max-width: 1300px) {
  .ribbon_wrap .ribbon_02 {
    right: 202px;
  }
  .plan_table .save_txt_box_01 {
    left: 501px;
  }
  .plan_table .save_txt_box_02 {
    left: 730px;
  }
  .save_txt_box {
    font-size: 13px;
  }
}
@media screen and (max-width: 1200px) {
  .ribbon_wrap img {
    right: 18px;
  }
  .ribbon_wrap .ribbon_02 {
    right: 181px;
  }
  .plan_table .save_txt_box_01 {
    left: 464px;
  }
  .plan_table .save_txt_box_02 {
    left: 674px;
  }
}
@media screen and (max-width: 1100px) {
  .ribbon_wrap .ribbon_02 {
    right: 202px;
  }
  .plan_table .save_txt_box_01 {
    left: 510px;
  }
  .plan_table .save_txt_box_02 {
    left: 744px;
  }
  .save_txt_box {
    font-size: 16px;
  }
}
@media screen and (max-width: 900px) {
  .ribbon_wrap .ribbon_02 {
    right: 167px;
  }
  .plan_table .save_txt_box_01 {
    left: 450px;
  }
  .plan_table .save_txt_box_02 {
    left: 655px;
  }
  .save_txt_box {
    font-size: 13px;
  }
}
