/*
Theme Name: Gymgym Theme
Theme URI: https://gymgym.net/
Description: Gymgymサイト用WordPressテーマ
Text Domain: gymgym
*/
@charset "UTF-8";
html,body {
  overflow-x: hidden;
}
html,body,div,span,h1,h2,h3,h4,h5,h6,p,ul,ol,li,dl,dt,dd {
  margin: 0;
  padding: 0;
}
body {
  font-family: "Oswald", "Noto Sans JP", sans-serif;
  max-width: 470px;
  margin: 0 auto;
  background-color: #FFF;
}
section {
  background-color: #fff;
}
div,
span {
  margin: 0;
  padding: 0;
}
picture {
  display: block;
}
img {
  display: block;
  width: 100%;
  border: 0;
}
a {
  text-decoration: none;
  transition: transform 0.3s ease, opacity 0.3s ease;
}
li {
  list-style: none;
}

.yellow_font {
  color: #d8c55c;
  font-weight: 700;
}

.subtitle_white {
  color: #fff;
  text-align: center;
}
.subtitle_white_en {
  font-size: 25px;
  font-weight: bold;
}
.subtitle_white_jp {
  font-size: 22px;
  font-weight: 500;
}

.subtitle_blue {
  color: #1f2c5c;
  text-align: center;
}
.subtitle_blue_en {
  font-size: 25px;
  font-weight: bold;
}
.subtitle_blue_jp {
  font-size: 22px;
  font-weight: 500;
}

/* ボタン */
.detail_cta{
  text-align: center;
  margin-top: 5%;
}
.detail_btn{
  display: inline-flex;
  align-items: center;
  min-width: 240px;
  justify-content: center;
  gap: 10px;
  background: #fff;
  color: #1F2D5D;
  padding: 16px 36px;
  border-radius: 8px;
  font-size: 24px;
  font-weight: bold;
  transition: all .3s ease;
}
.detail_btn:hover{
  transform: translateY(-3px);
  box-shadow: 0 12px 28px rgba(0,0,0,.25);
}
.detail_plus{
  font-weight: 900;
  font-size: 20px;
}

/* FV */
.fv{
    width: 100%;
    overflow: hidden;
}
.fv picture,
.fv img{
    width: 100%;
    height: 100%;
    display: block;
}
.fv img{
    object-fit: cover;
}

.top_cta {
  position: relative;
}
.top_cta_button {
  position: absolute;
  margin: auto;
  bottom: 18%;
  width: 80%;
  left: 50%;
  border-radius: 12px;
  transform: translateX(-50%);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.top_cta_button:hover {
  transform: translateX(-50%) scale(1.05);
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.2);
}

.reviews {
  background-color: #1F2D5D;
  margin-top: -1px;
}
.reviews_inner {
  width: min(90%, 1200px);
  margin: 0 auto;
  padding: 40px 0;
}
.reviews picture {
  margin: 0 auto;
}

/* Program */
.program{
  position: relative;
  padding: 10% 0;
  color: #fff;
  background: url("../img/program/program_bg_sp.webp") center/cover no-repeat;
  overflow: hidden;
}
.program_inner{
  position: relative;
  z-index: 1;
  width: min(90%, 1200px);
  margin: 0 auto;
}
.program_cards{
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 18px;
  margin-top: 40px;
  padding-bottom: 5%;
}
.program_card a{
  display: flex;
  flex-direction: column;
  height: 100%;
  background: rgba(255,255,255,.95);
  color: #1f2c5c;
  text-decoration: none;
  overflow: hidden;
  border-radius: 2px;
  box-shadow: 0 10px 24px rgba(0,0,0,.2);
  transition: transform .4s ease, box-shadow .4s ease;
}
.program_card a:hover{
  transform: translateY(-8px);
  box-shadow: 0 18px 40px rgba(0,0,0,.25);
}
.program_img img{
  width: 100%;
  display: block;
}
.program_body{
  flex: 1;
  padding: 20px 18px 24px;
  text-align: center;
  display: block;
}
.program_ttl{
  font-size: 25px;
  font-weight: 700;
  color: #f2b705;
  margin-bottom: 8px;
}
.program_desc{
  font-size: 18px;
  color: #444;
  line-height: 1.6;
}

/* Reason */
.reason {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-image: url("../img/reason/reason_bg_sp.webp");
  padding: 10% 0;
}
.reason_inner {
  width: min(90%, 1200px);
  margin: 0 auto;
}
.reason_head {
  margin-bottom: 10%;
}
.reason_list {
  display: flex;
  flex-direction: column;
  margin-top: 40px;
  gap: 0;
}
.reason_row {
  position: relative;
}
.reason_box {
  background: #1F2D5D;
  color: #fff;
  position: relative;
  z-index: 1;
  padding: 20px 15px 30px;
}
.reason_box_head {
  display: flex;
  align-items: baseline;
  gap: 18px;
}
.reason_no {
  font-weight: 700;
  line-height: 1;
  font-size: 30px;
}
.reason_ttl {
  font-weight: 700;
  margin: 0 0 6px;
  text-align: justify;
  font-size: 30px;
}
.reason_sub {
  margin: 0;
  font-size: 18px;
  text-align: left;
}
.reason_line {
  height: 1px;
  background: rgba(255,255,255,.35);
  width: 100%;
  margin: 15px auto;
}
.reason_body {
  line-height: 2;
  font-size: 16px;
  text-align: left;
}
.reason_body p {
  margin: 0;
}
.reason_img {
  position: relative;
  right: 0;
  top: -40px;
  z-index: 2;
  width: 100%;
  margin-top: 20px;
  margin-left: -20px;
}
.reason_img img {
  width: 100%;
  display: block;
}
.reason_row.reverse .reason_box_head {
  justify-content: flex-start;
}
.reason_row.reverse .reason_img {
  left: auto;
  right: auto;
}
.reason_row.reverse .reason_box {
  margin-left: 0;
  text-align: left;
}
.reason_row.reverse .reason_line {
  height: 1px;
  background: rgba(255,255,255,.35);;
  width: 100%;
  margin: 15px auto;
}

/* steps */
.steps{
  background-image:url("../img/steps/steps_bg_sp.webp");
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  padding: 10% 0;
  color:#fff;
}
.steps_inner{
  width: min(90%, 1200px);
  margin:0 auto;
}
.steps_text{
  text-align: left;
  margin-top: 20px;
  margin-bottom: 20px;
  font-size: 16px;
  line-height: 1.8;
}
.steps_list{
  display:grid;
  grid-template-columns:1fr;
  gap:28px;
  margin-bottom:40px;
}
.steps_item{
  background:#fff;
  color:#333;
  border-radius:4px;
}
.steps_item img{
  width:100%;
  display:block;
}
.steps_body{
  padding:22px 18px 20px;
}
.steps_head{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:12px;
}
.steps_step{
  align-items: center;
  background: #e0b400;
  color: #fff;
  font-size: 22px;
  font-weight: 700;
  line-height: 1;
  padding: 6px 12px;
  letter-spacing: .05em;
  white-space: nowrap;
  margin: 0;
  flex-shrink: 0;
  margin-left: -10%;
}
.steps_title{
  font-size:22px;
  font-weight:700;
  line-height:1.4;
  margin:0;
  color:#CDA700;
}
.steps_desc{
  font-size:18px;
  line-height:1.8;
  color:#6F6F6F;
  font-weight: 500;
  margin:0;
}
.steps_cta{
  text-align:center;
  margin-bottom:40px;
}
.steps_btn{
  display:inline-block;
  background:#e0b400;
  color:#fff;
  padding:14px 20px;
  border-radius:4px;
  font-weight:700;
  text-decoration:none;
  transition:.3s;
}
.steps_btn:hover{
  opacity:.8;
}
.gymgym_cta_button{
  width: 100%;
  padding: 0 34px 30px;
}
.step_campaign {
  position: relative;
}
.gymgym_campaign_button {
  position: absolute;
  width: 90%;
  left: 50%;
  transform: translateX(-50%);
  bottom: 7%;
}

.trainer_container{
  width: min(90%, 1200px);
  margin: 0 auto;
  box-sizing: border-box;
}
.trainer_message,
.trainer_biography,
.trainer_qa{
  overflow: hidden;
}
.trainer_message{
  background: url("../img/lp01/trainer_bg.webp") center center / cover no-repeat;
  padding: 28px 0 40px;
}
.trainer_message_name{
  margin-top: 10px;
  font-size: 20px;
  font-weight: 500;
  color: #1f2c5c;
  text-align: center;
}
.trainer_message_name h2{
  margin: 0;
  color: #22356f;
  font-size: 22px;
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: 10px;
}
.trainer_message_name h2 span{
  margin-left: 8px;
  font-size: 22px;
  font-weight: 700;
}
.trainer_message_wrap{
  display: grid;
  grid-template-columns: 1fr;
  margin-top: 0;
  gap: 14px;
  align-items: end;
}
.trainer_message_left{
  width: 100%;
  display: flex;
  flex-direction: column;
  padding: 5% 0;
}
.trainer_message_main_image{
  width: 100%;
  margin-bottom: 6px;
}
.trainer_message_main_image img{
  width: 100%;
  display: block;
  object-fit: cover;
}
.trainer_message_sub_images{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
}
.trainer_message_sub_image img{
  width: 100%;
  display: block;
  object-fit: cover;
}
.trainer_message_right{
  margin-top: 10px;
}
.trainer_message_box{
  background-color: #1F2D5D;
  padding: 16px 14px 18px;
  box-sizing: border-box;
}
.trainer_message_explanation {
  font-size: 20px;
  font-weight: bold;
  color: #1f2c5c;
  text-align: center;
}
.trainer_message_box p{
  margin: 0 0 30px;
  color: #ffffff;
  font-size: 16px;
  line-height: 2;
  font-weight: 500;
}
.trainer_message_box p:last-child{
  margin-bottom: 0;
}
.trainer_message_box span{
  color: #FFDD44;
  font-weight: 700;
}
.trainer_biography_cards{
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}
.trainer_biography_card{
  background: #1F2D5D;
  margin-top: 20px;
  padding: 18px 16px 16px;
  box-sizing: border-box;
}
.trainer_biography_card {
  color: #ffffff;
  font-size: 16px;
  line-height: 1.9;
}
.trainer_biography_card h3{
  margin: 0 0 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid #ffffff;
  color: #d7a900;
  font-size: 18px;
  line-height: 1.4;
  font-weight: 700;
}
.trainer_biography_card ul{
  margin: 0;
  padding: 0;
  list-style: none;
}
.trainer_biography_card li{
  position: relative;
  padding-left: 0.9em;
  margin-bottom: 8px;
  color: #ffffff;
  font-size: 18px;
  line-height: 1.9;
}
.trainer_biography_card li:last-child{
  margin-bottom: 0;
}
.trainer_biography_card li::before{
  content: "・";
  position: absolute;
  left: 0;
  top: 0;
}

/* facility */
.facility_machine{
    background: url("../img/lp01/machine_bg.webp") center center / cover no-repeat;
    padding: 10% 0;
}
.facility_machine_inner{
    width: min(90%, 1200px);
    margin: 0 auto;
}
.facility_machine_wrap{
    margin-top: 24px;
    position: relative;
    display: block;
    align-items: stretch;
}
.facility_machine_image{
    width: 100%;
}
.facility_machine_image img{
    width: 100%;
    display: block;
}
.facility_machine_box{
    width: auto;
    background: #ffffff;
    color: #1F2D5D;
    margin-top: 20px;
    padding: 28px 24px;
    font-size: 18px;
    font-weight: bold;
    line-height: 2;
}
.facility_machine_box span{
    color: #CDA700;
    font-weight: 500;
}
.facility_machine_list{
    margin: 28px 0;
}
.facility_machine_list h3{
    color: #CDA700;
    font-size: 22px;
    margin: 0 0 18px;
    padding-bottom: 10px;
    border-bottom: 1px solid #1F2D5D;
}
.facility_machine_list li{
    margin-bottom: 8px;
}

/* PLAN */
.plan_price{
  position: relative;
  padding: 10% 0;
  color: #fff;
  background: url("../img/plan/plan_bg_sp.webp") center/cover no-repeat;
}
.plan_price_inner{
  position: relative;
  z-index: 1;
  width: min(90%, 1200px);
  margin: 0 auto;
}
.plan_price_tabs{
  display: flex;
  gap: 14px;
  margin-top: 26px;
  margin-bottom: 26px;
}
.plan_price_tab{
  flex: 1 1 0;
  height: 54px;
  border-radius: 8px;
  padding: 0;
  border: 1px solid rgb(0 0 0 / 0%);
  color: rgba(31, 44, 92, .45);
  font-weight: 500;
  font-size: 16px;
  cursor: pointer;
  transition: .25s ease;
}
.plan_price_tab.is_active{
  background: rgba(35, 54, 118, .95);
  color: #fff;
}
.plan_price_panel{
  width: 100%;
}
.plan_price_cards{
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  align-items: stretch;
}
.plan_price_card{
  position: relative;
  border-radius: 10px;
  box-shadow: 0 16px 40px rgba(0,0,0,.22);
  background: rgba(255,255,255,.10);
}
.plan_price_card_head{
  background: rgba(28, 44, 95, .95);
  text-align: center;
  padding: 18px 14px 16px;
}
.plan_price_card_en{
  margin: 0;
  font-size: 32px;
  font-weight: bold;
  letter-spacing: .02em;
}
.plan_price_card_jp{
  font-size: 24px;
  font-weight: bold;
}
.plan_price_card_body{
  grid-template-columns: 110px 1fr;
  background: rgba(255,255,255,.22);
  padding: 18px 16px 16px;
  display: grid;
  grid-template-rows: auto auto;
  row-gap: 10px;
  align-items: start;
}
.plan_price_tag{
  width: 90px;
  padding: 10px 2px;
  border-radius: 8px;
  background: #fff2b8;
  color: #1f2c5c;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.25;
  text-align: center;
}
.plan_price_price{
  grid-column: 2 / 3;
  color: #fff;
  text-align: center;
}
.plan_price_price_main{
  position: relative;
  display: inline-block;
  margin-top: -7%;
}
.plan_price_price_num{
  font-size: 43px;
  font-weight: bold;
  letter-spacing: .02em;
}
.plan_price_price_yen{
  position: relative;
  font-size: 18px;
  font-weight: 900;
  margin-left: 2px;
}
.plan_price_price_tax{
  position: absolute;
  right: 0;
  top: 23px;
  font-size: 9px;
  font-weight: 900;
}
.plan_price_price_sub{
  font-size: 18px;
  font-weight: bold;
}
.plan_price_limit{
  margin: 5px 0 0;
  font-size: 16px;
  font-weight: normal;
  grid-column: 1 / -1;
  text-align: center;
}
.plan_price_popularity{
  position: absolute;
  right: -25px;
  top: -15px;
  width: 90px;
  height: auto;
  z-index: 2;
}
.plan_price_note{
  margin: 18px 0 0;
  font-size: 11px;
  line-height: 1.7;
  opacity: .85;
}
.plan_price_coupons{
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 26px;
}
.plan_price_coupon{
  position: relative;
  background: rgba(255,255,255,.95);
  color: #1f2c5c;
  border-radius: 12px;
  padding: 18px 18px 16px;
  box-shadow: 0 16px 40px rgba(0,0,0,.22);
  overflow: hidden;
}
.plan_price_coupon_ribbon{
  position: absolute;
  left: -42px;
  top: 14px;
  transform: rotate(-45deg);
  width: 140px;
  text-align: center;
  background: #7fb7d8;
  color: #fff;
  font-weight: 900;
  font-size: 12px;
  padding: 6px 0;
  letter-spacing: 1.5px;
}
.plan_price_coupon_title{
  width: fit-content;
  margin: 0 auto 10px;
  position: relative;
  font-size: 20px;
  font-weight: bold;
  text-align: center;
  color: #1f2c5c;
  padding-bottom: 8px;
}
.plan_price_coupon_title::after{
  content:"";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 2px;
  background: #1f2c5c;
  border-radius: 2px;
}
.plan_price_coupon_list{
  margin: 0;
  font-size: 13px;
  font-weight: bold;
  line-height: 1.65;
}
.plan_price_coupon_big{
  margin: 5% 0 0;
  font-size: 20px;
  text-align: center;
  color: #caa400;
  font-weight: 900;
  line-height: 1.7;
}
.plan_price_campaign{
  display: grid;
  grid-template-columns: 2fr auto 0.8fr;
  align-items: end;
  margin-top: 10px;
}
.plan_price_campaign_label{
  margin: 0 0px -7px;
  font-size: 18px;
  font-weight: 900;
  color: #1f2c5c;
}
.plan_price_campaign_normal{
  position: relative;
  margin: 0;
  font-weight: 900;
  color: #6F6F6F;
  line-height: 1.2;
  display: inline-block;
}
.plan_price_campaign_normal_prefix{
  font-size: 24px;
  font-weight: 900;
}
.plan_price_campaign_normal_num{
  font-size: 36px;
  font-weight: 900;
  letter-spacing: .02em;
}
.plan_price_campaign_normal_yen{
  font-size: 25px;
  font-weight: 900;
  margin-left: 4px;
}
.plan_price_campaign_strike::after{
  content:"";
  position: absolute;
  left: 0px;
  top: 18%;
  width: 100%;
  height: 2px;
  background: #caa400;
  transform: translateY(-50%) rotate(10deg);
  transform-origin: left center;
}
.plan_price_campaign_arrow{
  font-weight: 900;
  color: #caa400;
}
.plan_price_campaign_right{
  position: relative;
  text-align: right;
  display: inline-block;
}
.plan_price_campaign_tax{
  position: absolute;
  right: 1px;
  top: 25px;
  font-size: 14px;
  font-weight: 900;
  color: #caa400;
}
.plan_price_campaign_zero{
  margin: 0;
  line-height: 1;
}
.plan_price_campaign_zero_num{
  font-size: 75px;
  font-weight: 900;
  color: #caa400;
}
.plan_price_campaign_zero_yen{
  font-size: 30px;
  font-weight: 900;
  color: #caa400;
  margin-left: 2px;
}
.plan_price_cta{
  margin-top: 28px;
}

/* FAQ */
.faq{
  background:#fff;
  padding:10% 0;
}
.faq_inner{
  width:min(90%,1200px);
  margin:0 auto;
}
.faq_list{
  margin-top:26px;
  border-top:none;
}
.faq_item{
  border-bottom:1px solid rgba(31,44,92,.18);
}
.faq_q{
  width:100%;
  display:grid;
  grid-template-columns:32px 1fr 26px;
  align-items:center;
  gap:14px;
  padding:16px 0;
  min-height:60px;
  background:transparent;
  border:0;
  cursor:pointer;
  text-align:left;
}
.faq_q_icon{
  width:28px;
  height:28px;
  display:block;
  object-fit:contain;
}
.faq_q_text{
  color:#1f2c5c;
  font-weight:900;
  line-height:1.5;
  font-size:15px;
}
.faq_toggle{
  width:24px;
  height:24px;
  position:relative;
  justify-self:end;
}
.faq_toggle::before{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  width:16px;
  height:2px;
  background:#1f2c5c;
  transform:translate(-50%,-50%);
  border-radius:2px;
}
.faq_toggle::after{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  width:2px;
  height:16px;
  background:#1f2c5c;
  transform:translate(-50%,-50%) rotate(0deg);
  border-radius:2px;
  transition:transform .3s ease,opacity .3s ease;
}
.faq_item.is_open .faq_toggle::after{
  transform:translate(-50%,-50%) rotate(90deg);
  opacity:0;
}
.faq_a{
  overflow:hidden;
  max-height:0;
  transition:max-height .35s ease;
  padding:0 6px;
}
.faq_item.is_open .faq_a{
  padding:0 6px 18px 6px;
}
.faq_a_inner{
  margin-left:46px;
  color:rgba(31,44,92,.75);
  font-size:12.5px;
  line-height:2;
}
.faq_cta .detail_btn{
  border:1px solid #7982A2;
}

/* Contact */
.contact{
  background: url("../img/contact/contact_bg_sp.webp") center/cover no-repeat;
  padding: 10% 0;
  position: relative;
  color: #fff;
}
.contact_inner{
  position: relative;
  z-index: 1;
  width: min(90%, 1200px);
  margin: 0 auto;
}
.contact_box{
  margin: 28px auto 0;
  max-width: 100%;
  border-radius: 6px;
}
.contact_iframe{
  width: 100%;
  height: 520px;
  border: 0;
  display: block;
  background: transparent;
}
.contact iframe {
  width: 100%;
  height: 620px;
  max-width: 1000px;
  padding-top: 10px;
  background-color: rgb(247, 249, 252);
}

/* ACCESS */
.access{
  background:url("../img/access/access_bg_sp.webp") center/cover no-repeat;
  padding:10% 0;
}
.access_inner{
  width:min(90%,1200px);
  margin:0 auto;
}
.access_content{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:20px;
  text-align:left;
}
.access_map{
  flex:1;
  display:flex;
  justify-content:center;
  padding-bottom:5%;
}
.access_map iframe{
  width:100%;
  max-width:100%;
  max-height:300px;
  aspect-ratio:16/10;
  border:0;
  display:block;
}
.access_right{
  display:block;
  flex:1;
  max-width:100%;
  color:#1f2c5c;
}
.access_block{
  padding-bottom:0;
}
.access_block + .access_block{
  margin-top:32px;
}
.access_head{
  position:relative;
  display:flex;
  align-items:baseline;
  gap:14px;
  padding-left:18px;
  margin-bottom:14px;
}
.access_head::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  width:3px;
  height:100%;
  background:#1f2c5c;
}
.access_en{
  font-size:35px;
  font-weight:900;
  letter-spacing:.05em;
}
.access_jp{
  font-size:25px;
  font-weight:700;
  letter-spacing:.06em;
}
.access_text p{
  margin:0;
  font-size:16px;
  line-height:1.6;
}
.access_address {
  font-size: 16px;
}
.access_zip{
  font-weight:800;
}