@charset "UTF-8";
* {
  font-family: hiragino-kaku-gothic-pron, sans-serif;
  font-style: normal;
  font-weight: 300;
  color: #1a1a1a; }

li {
  list-style-type: none; }

a:hover {
  opacity: 0.7; }

:root {
  --gradient_color:linear-gradient(150deg, rgba(250, 144, 34, 1), rgba(249, 95, 23, 1) 66%, rgba(250, 70, 21, 1));
  --orange_color:#F94815;
  --mf_color:#D9CE62; }

/*scssにおけるメディアクエリの記述ルール*/
/*scssにおけるメディアクエリの記述ルール終わり*/
.bold {
  font-family: hiragino-kaku-gothic-pron, sans-serif;
  font-style: normal;
  font-weight: 600; }

.space1 {
  height: 2rem; }

@media screen and (min-width: 992px) {
  .section-item {
    height: 100vh; } }

main {
  scroll-snap-type: y mandatory; }

section {
  scroll-snap-stop: always; }

/* ヘッダー関連　*/
header {
  display: grid;
  grid-template-columns: 100px 1fr 240px;
  padding: 10px;
  height: 70px;
  background-image: var(--gradient_color);
}

.btnArea a {
  width: 240px;
  width: 240px;
  height: 50px;
  background: #24c1d6;
  display: block;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 25px;
  border: 1px solid #24c1d6;
  color: #fff; }
  .btnArea a p {
    color: #fff; }

/* メインビュー関連　*/
.mv {
  width: 100%; }
  .mv img {
    max-width: 100%; }

/*  見出し関連　*/
.midashi {
  background-color: var(--orange_color);
  padding: 1rem 0 1rem 0; }

h1 {
  width: 100%;
  background-color: var(--orange_color);
  color: #fff;
  text-align: center;
  padding-bottom: 1rem;
  font-size: 2rem; }
  h1 span {
    color: #FFFF00; }

.midashi_h2 {
  text-align: center;
  transform: skewX(-15deg); }

h2 {
  border: 1px solid #ffffff;
  background-color: #fff;
  padding: .5rem 1rem;
  text-align: center;
  display: inline-block;
  color: var(--orange_color);
  margin: 0 auto;
  font-size: 2rem; }
  h2 span {
    color: #1a1a1a;
    transform: skewX(15deg);
    display: inline-block;
    font-size: 1.3rem; }

@media screen and (min-width: 768px) {
  h1 {
    font-size: 3rem;
    padding: 2rem; }

  h2 {
    font-size: 3rem; }
    h2 span {
      font-size: 2rem;
      letter-spacing: .1rem; } }
@media screen and (max-width: 768px) {
  h1 {
    font-size: 2rem;
    padding: 0;
	margin: 0 auto;}
 }

/*  猫背のsection　*/
.nekoze,
.yugami {
  background-color: #FCF6BD;
  padding: 2rem 0; }
  .nekoze img,
  .yugami img {
    margin: 2rem auto;
    display: block;
    width: 40%; }
    @media screen and (min-width: 1200px) {
      .nekoze img,
      .yugami img {
        width: 40%; } }

@media screen and (min-width: 768px) {
  .nekoze img {
    margin: 3rem auto; } }
.h3_center {
  text-align: center;
  display: block; }

h3 {
  text-align: center;
  font-size: 1.5rem;
  border: 1px solid #FEDFC1;
  background-color: #FEDFC1;
  border-radius: 20px;
  display: inline-block;
  padding: .5rem 2rem;
  box-shadow: 4px 4px 2px #666666; }
  h3 .hatiwari {
    font-size: 2rem; }
    h3 .hatiwari .nekozedesu {
      margin-bottom: 4px;
      text-align: center;
      background: var(--orange_color);
      color: #fff;
      padding: 2px 6px;
      width: -moz-fit-content;
      width: fit-content; }

@media screen and (min-width: 768px) {
  .nekoze {
    padding: 5rem 0; }

  h3 {
    font-size: 2rem; }
    h3 .hatiwari {
      font-size: 3rem; } }
/*  ゆがみのsection　*/
.yugami {
  background-color: #DDF3F5;
  padding: 2rem 0; }
  .yugami img {
    width: 60%; }

/*  ながれのsection　*/
.nagare {
  width: 100%;
  background-color: #ffe0bc; }
  .nagare img {
    width: 50%;
    display: block;
    margin: 0 auto; }
    @media screen and (min-width: 1200px) {
      .nagare img {
        width: 50%; } }

/* cta section */
.orange2 {
  width: 100%;
  height: 2rem;
  background-image: linear-gradient(90deg, #fa4615, #fa9022 50%, #fa4615 100%);
  text-align: center;
  color: #fff; }

.orange {
  background-image: linear-gradient(90deg, #fa4615, #fa9022 50%, #fa4615 100%);
  width: 100%; }

.cta {
  width: 90%;
  margin: 0 auto;
  border: 3px solid var(--orange_color);
  background-color: #FFF5EB;
  border-radius: 20px;
  padding: 1rem;
  position: relative; }
  @media screen and (min-width: 768px) {
    .cta {
      width: 60%;
      max-width: 800px; } }
  .cta .imadake {
    border: 1px solid var(--mf_color);
    background-color: var(--mf_color);
    color: #fff;
    text-align: center;
    border-radius: 20px;
    font-size: 1.3rem;
    padding: .3rem 0;
    max-width: 500px;
    margin: 0 auto; }
  .cta p {
    text-align: center;
    font-weight: 600;
    margin: .5rem 0; }
  .cta img {
    max-width: 80%;
    display: block;
    margin: 0 auto; }
  .cta h4 {
    color: var(--orange_color);
    font-size: 1.5rem;
    text-align: center;
    margin: .5rem 0;
    letter-spacing: .1rem; }
    .cta h4 span {
      font-size: 2rem;
      font-weight: 600;
      color: var(--orange_color); }
  .cta .cta2 {
    text-align: center;
    font-weight: 600;
    margin: .5rem 0;
    font-size: 1.3rem; }
  .cta a {
    display: block;
    margin: 0 auto;
    border: 1px solid var(--orange_color);
    background-color: var(--orange_color);
    color: #fff;
    padding: 1rem 2rem;
    border-radius: 2rem;
    text-align: center;
    cursor: pointer;
    max-width: 500px; }
  .cta .cta3 {
    position: absolute;
    top: 5%;
    right: 5%;
    z-index: 100;
    background-image: url("images/gazou1.png") no-repeat; }
  .cta .sep_cp {
    width: 100%; }
  @media screen and (min-width: 768px) {
    .cta .sep_cp {
      width: 40%;
      display: block;
      margin: 0 auto; } }

.best3 {
  background-color: #FCF6BD;
  padding: 5rem 0 2rem 0;
  text-align: center; }
  .best3 h6 {
    font-size: 20px; }
  .best3 h5 {
    font-size: 2rem;
    color: #F55875;
    font-weight: 700; }
  .best3 .training3 {
    margin-top: 3rem; }
    .best3 .training3 .train3 {
      background-color: #fff;
      width: 90%;
      margin: 0 auto;
      max-width: 440px;
      border: 1px solid #fff;
      border-radius: 20px;
      margin-bottom: 1rem;
      list-style-type: none;
      padding: 1rem; }
      .best3 .training3 .train3 img {
        width: 100%;
        border-radius: 20px; }
      .best3 .training3 .train3 .sto-title {
        color: #1a1a1a;
        font-size: 1.5rem;
        margin: 1rem auto; }
      .best3 .training3 .train3 p {
        font-size: 1rem;
        font-weight: 400;
        letter-spacing: .1rem; }

@media screen and (min-width: 768px) {
  ul.training3 {
    display: flex;
    flex-wrap: wrap;
    max-width: 1400px;
    margin: 0 auto; } }
.goal {
  background-color: #F8E6E9;
  text-align: center;
  padding: 5rem 0; }
  .goal h6 {
    font-size: 20px; }
  .goal h5 {
    font-size: 2rem;
    color: #F55875; }
  .goal img {
    width: 100%;
    max-width: 800px;
    margin-top: 2rem; }

/* お客様の感想　　*/
.reaction {
  background-color: #E5F4E3;
  padding: 5rem 0; }
  .reaction h5 {
    font-size: 2rem;
    color: #F55875;
    text-align: center;
    margin-bottom: 2rem; }
  @media screen and (min-width: 992px) {
    .reaction ul {
      display: flex; } }
  .reaction ul .kansou {
    width: 80%;
    margin: 1rem auto;
    background-color: #fff;
    display: flex;
    padding: 2rem;
    align-items: center;
    font-size: 1.2rem;
    letter-spacing: .07rem; }
    @media screen and (min-width: 992px) {
      .reaction ul .kansou {
        width: 40%; } }
    .reaction ul .kansou img {
      width: 20%;
      margin-right: 3rem; }
    .reaction ul .kansou p {
      font-weight: 400;
      letter-spacing: .1rem;
      line-height: 2; }

/* お客様の疑問　*/
.gimon {
  background-color: #EDE7F6;
  text-align: center;
  padding: 5rem 0; }
  .gimon h6 {
    padding-top: 3rem;
    font-size: 20px; }
  .gimon h5 {
    font-size: 2rem;
    color: #F55875; }

/*アコーディオン　*/
/* アコーディオン外側 */
.index_accordion {
  margin: 0 auto;
  width: 80%;
  border: 1px solid #000; }
  @media screen and (min-width: 768px) {
    .index_accordion {
      width: 70%; } }

.index_accordion {
  margin-top: 1rem; }

/*質問*/
.accordion-header {
  padding: 1rem;
  cursor: pointer;
  outline: none;
  font-weight: bold;
  color: #000;
  position: relative;
  list-style: none;
  letter-spacing: .1rem;
  font-size: clamp(16px, 2vw, 20px);
  font-weight: 400;
  height: auto;
  line-height: 1.5;
  background-color: #fff; }

/* 答え。開いたら出てくる。 */
.accordion-content {
  padding: 1rem;
  line-height: 1.5;
  letter-spacing: .1rem;
  font-weight: 600;
  background-color: #fff;
  text-align: left; }

/* 質問横の三角の動き*/
.accordion-header::after {
  content: '▼';
  position: absolute;
  right: 10px;
  transition: transform 0.2s ease-in-out;
  color: #000; }

/* index_accordionが開いた時に、三角の動きが180度回転する。 */
.index_accordion[open] .accordion-header::after {
  transform: rotate(180deg); }

.index_accordion .accordion-header::-webkit-details-marker {
  display: none; }

/* エイムの紹介　*/
.service {
  background-color: #ffe0bc;
  padding: 5rem 0 2rem 0;
  text-align: center;
  margin: 0 auto; }
  .service h6 {
    font-size: 20px; }
  .service h5 {
    font-size: 2rem;
    color: #F55875;
    margin-bottom: 2rem; }
  .service .shop_info {
    border: 1px solid #fff;
    background: #fff;
    width: 80%;
    margin: 2rem auto 0 auto; }
    @media screen and (min-width: 1200px) {
      .service .shop_info {
        display: flex; } }

.shop_info img {
  width: 100%; }
  @media screen and (min-width: 1200px) {
    .shop_info img {
      max-width: 600px; } }

.info {
  padding: 2rem;
  text-align: left; }
  .info .club_title {
    color: #FFFFFF;
    width: -moz-fit-content;
    width: fit-content;
    background-color: var(--orange_color);
    font-weight: 600;
    font-size: 1.5rem;
    margin: .3rem 0; }
  .info p {
    letter-spacing: .1rem;
    line-height: 2;
    font-weight: 400; }

/* ムーンフォートの紹介　*/
.shop {
  background-color: #FCF6BD;
  padding: 5rem 0 2rem 0;
  text-align: center;
  margin: 0 auto; }
  .shop h6 {
    font-size: 20px; }
  .shop h5 {
    font-size: 2rem;
    color: #F55875;
    margin-bottom: 2rem; }
  .shop .shop_info {
    width: 80%;
    margin: 0 auto; }
    @media screen and (min-width: 1200px) {
      .shop .shop_info {
        display: flex; } }
    .shop .shop_info .shop_info img {
      width: 100%; }
    .shop .shop_info .info {
      text-align: center; }
      .shop .shop_info .info h2 {
        color: #FFFFFF;
        display: block;
        width: -moz-fit-content;
        width: fit-content;
        border-radius: 3px;
        background-color: var(--mf_color);
        font-weight: 600;
        font-size: 2rem; }
      .shop .shop_info .info .phone {
        color: #1a1a1a;
        font-size: 2rem;
        margin: 1rem 0; }
      .shop .shop_info .info p {
        font-size: 20px; }

.secService .commonWidth,
.secClose .commonWidth {
  margin: 0 auto; }
  .secService .commonWidth h6,
  .secClose .commonWidth h6 {
    font-size: 20px;
    text-align: center; }
  .secService .commonWidth h5,
  .secClose .commonWidth h5 {
    font-size: 2rem;
    color: #F55875;
    text-align: center; }
  .secService .commonWidth .content,
  .secClose .commonWidth .content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    background-color: #fff;
    border-radius: 20px;
    overflow: hidden;
    align-items: center;
    margin-bottom: 30px;
    width: 70%;
    margin: 0 auto 30px auto; }
    .secService .commonWidth .content img,
    .secClose .commonWidth .content img {
      display: block;
      width: 100%;
      object-fit: contain;
      transform: scale(1.1); }
    @media screen and (max-width: 767px) {
      .secService .commonWidth .content,
      .secClose .commonWidth .content {
        grid-template-columns: 1fr;
        border-radius: 15px;
        margin-bottom: 15px;
        max-width: 90%;
        display: block;
        margin: 0 auto 15px auto; }
        .secService .commonWidth .content img,
        .secClose .commonWidth .content img {
          transform: scale(1.2); } }

.txt {
  padding: 2rem; }
  @media screen and (min-width: 768px) {
    .txt {
      padding-left: 5rem; } }
  .txt .h3 {
    font-size: 1.5rem;
    text-align: left; }
    .txt .h3 span {
      background-color: var(--orange_color);
      color: #fff;
      width: -moz-fit-content;
      width: fit-content;
      padding: 2px; }
  .txt p {
    font-weight: 400;
    line-height: 1.75; }

.small {
  font-size: 1rem;
  margin-bottom: 1rem; }

/* --- 固定CTA --- */
.fixed-cta {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  background: rgba(255, 255, 255, 0.95);
  display: flex;
  justify-content: center;    /* 横中央に並べる */
  align-items: center;
  gap: 16px;                  /* ボタン間の余白 */
  padding: 14px 0;
  box-shadow: 0 -3px 10px rgba(0,0,0,0.15);
  z-index: 9999;
}

/* --- ボタンデザイン --- */
.fixed-cta .cta-btn {
  background: #ff5722;
  color: #fff;
  text-decoration: none;
  padding: 14px 80px;
  border-radius: 9999px;
  font-weight: 700;
  font-size: 16px;
  transition: all 0.2s ease;
  box-shadow: 0 3px 8px rgba(0,0,0,0.25);
}

.fixed-cta .cta-btn:hover {
  background: #e64a19;
  transform: translateY(-2px);
}

/* --- スマホ用微調整 --- */
@media (max-width: 600px) {
  .fixed-cta {
    gap: 8px;
    padding: 10px 0;
  }
  .fixed-cta .cta-btn {
    font-size: 14px;
    padding: 10px 100px;
  }
}
