@charset "UTF-8";

@media only screen and (max-width : 768px) {
	/*-----------------------
スマホ・タブレット用レイアウト（768px以下スクリーン）
----------------------*/

	/*------------------
共通設定(スマホ)
-------------------*/

	/* はみ出した領域は非表示にする*/
	html {
		overflow-y: scroll;
		overflow-x: hidden;
	}

	html,
	body {
		width: 100%;
		-webkit-text-size-adjust: 100%;
		-ms-text-size-adjust: 100%;
	}

	/*画像サイズの調整*/
	img {
		height: auto;
		max-width: 100%;
	}

	/*H2タグ*/
	h2 {
		margin: 0.5em 0 0.5em;
		font-size: 1.8em;
		font-weight: bold;
		text-align: center;
	}

	/*H3タグ*/
	h3 {
		margin: 0 0 0.5em;
		padding: 0.3em;
		font-size: 1.3em;
		/* border-left: 8px solid #ccc;
		border-bottom: 1px dotted #ccc;
		font-weight: bold; */
	}

	/*H4タグ*/
	h4 {
		margin: 0 0 0.5em;
		padding: 0.3em 0.6em;
		font-size: 1.4em;
		border: 1px solid #8e8e8e;
		font-weight: bold;
	}

	/*H5タグ*/
	h5 {
		margin: 0 0 0.5em;
		padding: 0.2em 0.4em;
		font-size: 1.2em;
		border-bottom: 2px solid #414141;
		font-weight: bold;
	}

	/*--------------------------------------------------------
全体レイアウト/背景設定(スマホ・タブレット)
--------------------------------------------------------*/

	/*全体エリア(全体背景の設定はここ)*/
	.main {
		background-color: #fff;
	}

	/*記事(ボディ)エリア*/
	.article {
		background-color: #fff;
		/*スマホの場合はカラムの線を消す*/
		border-left: none;
		border-right: none;
	}

	/*記事(ボディ)エリアの行間*/
	.article p {
		line-height: 1.8em;
	}

	/*記事(ボディ)エリアのフォントサイズ*/
	.article {
		font-size: 1.6em;
	}

	/*カラム全体の幅はスマホの場合固定*/
	.header_inr,
	.article,
	.top_image_in,
	.atcl_inr,
	.CTA_area {
		width: 100%;
		margin: 0 auto
	}

	/*PC画面とスマホ画面の切り替え*/

	.gamen_pc {
		display: none;
	}

	.gamen_rps {
		display: block;
	}

	/*--------------------------------------------------------
上部固定ヘッダー設定
--------------------------------------------------------*/

	/*上部固定ヘッダー全体*/
	.header {
		position: -webkit-sticky;
		top: 0;
		background-color: #fff;
		border-bottom: 1px;
		overflow: auto;
		position: static; 
		/* スマホ画面では通常のフローに戻す */
	}

	/*ヘッダーロゴ*/
	.header_logo {
		float: left;
		width: 35%;
		margin-top: 7px;
		margin-left: 0px;
	}

	/*ヘッダー 電話ボタン*/
	.header_tel {
		width: 30%;
		float: right;
		margin: 0.9em 0.5em 0em;
	}

	/*ヘッダー 問い合わせボタン*/
	.header_mail {
		width: 45%;
		float: right;
		margin: 0.8em 0.3em 0em;
	}

	/*ヘッダー内の画像はエリア幅に合わせる*/
	.header_logo img,
	.header_tel img,
	.header_mail img {
		width: 100%;
	}

	/*---------
ファーストビュー設定-----------------*/

	.top_image {
		/*スマホの際はファーストビューの背景を非表示*/
		background-image: none;
	}
	.top_image p {
		font-size: 1.8em;
	}

	/*-------------------------
※※※※※※※※※メイン部分(ボディ) ※ここに案件独自のcssを記述していく
--------------------------*/
.CTA_area_in{
	background-color: #25abee;
	text-align: center;
	margin: 1em ;
	padding: 1em ;
	border-radius: 10px;
	box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.1);
}

	.cta_plice_area{
		background-color: #fff;
		padding: 0em;
	}

.CTA_btn {
	flex-direction: column; 
	align-items: center; 
	gap: 1em; 
	margin: 0;
	padding: 0;
}
.cta_plice_area {
	text-align: center;
	padding: 0.5em 2em;
}
.CTA_btn img {
	max-width: 75%;
	height: auto;
}

/* -StepFitとは？-エリア- */

.ATEPFIT_kaisetu_text{
	padding: 0em 1em;
}
.ATEPFIT_kaisetu_merit{
	justify-content: space-around;
}

/* -3つのポイント-エリア- */
.point_mds {
	padding-left: 0.5em;
  }

.point_mds img {
	width: 85%;
	height: auto; 
  }
  .ATEPFIT_point_elt {
	margin: 1em ;
  }
  /* -料金
  プラン-エリア- */

  .ATEPFIT_price_service{
	display: flex;
	justify-content: space-between;
	flex-flow: row wrap;

  }
  .ATEPFIT_price_service img{
  width: 48%;
}

  /* -会員の声-エリア- */
  /* 画像のスタイル */
  .STEPFIT_koe_element {
	flex-direction: column; 
	align-items: center; 
	gap: 0px; 
	margin: 1em 2em;
  }
  .koe-text {
width: 100%;
padding: 1em 0.5em;

}
.koe-text::before,
	.koe-text::after {
		content: none; /* 矢印を非表示にする */
	}

	.koe-title {
		font-size: 1.4em;
	}
  /* -アクセス-エリア- */

	.access_table {
		padding: 0.5em 1em;
		text-align: center;
	}

	.map_wrapper {
		width: 100%; /* 幅を画面に合わせる */
		height: auto; /* 高さをアスペクト比で調整 */
		padding-top: 56.25%; /* 16:9アスペクト比 */
	  }
	
	  .iframe {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
	  }
	/*--------------------------------------------------------
段落・リスト・テーブル設定
--------------------------------------------------------*/

	/*チェックリスト（リストタグ）*/

	ul.checklist {
		background-color: #FEFFF5;
		margin: 0 0 1.5em;
		padding: 1em 1em 0em 1em;
		list-style: none;
		border: 1px solid #414141
	}

	.checklist li {
		margin-bottom: 0.8em;
	}

	.checklist li:before {
		font-family: "Font Awesome 5 Free";
		font-weight: 900;
		content: "\f14a";
		margin-right: 0.3em;
		color: red;
	}

	/*テーブルタグ*/
	table {
		width: 100%;
		border-collapse: collapse;
		margin: 1em 0.5em;
	}

	th,
	td {
		padding: 0.5em;
		border-right: 1px dotted #87ceeb;
		border-bottom: 1px dotted #87ceeb;
	}

	th {
		background-color: #eef6fb;
		font-weight: bold;
		text-align: left;
	}

	td {
		background-color: #fff;
		text-align: left;
	}

	table.table-style01 th,
	table.table-style01 td {
		text-align: left;
		vertical-align: middle;
	}

	/*テーブルをブロック表示に*/

	.table-style01,
	.table-style01 tr,
	.table-style01 th,
	.table-style01 td {
		display: block;
	}

	.table-style01 th,
	.table-style01 td {
		float: left;
		width: 100% !important;
		box-sizing: border-box;
	}

	.table-style01 {
		zoom: 1;
	}

	.table-style01:after {
		content: '';
		display: block;
		clear: both;
		height: 0;
	}

	/* 最下層の線を消す */
table tr:last-child td {
	border-bottom: none;
	/* 最後の行の下線を消去 */
}

	/*--------
テンプレート用のcss※必要に応じて使用する
-----------------------*/

	/*画像化したサブヘッドを横に広げる*/
	h2.subhead {
		margin: 0em -2em;
	}

	/*よくある質問(文章ver.)*/
	.box_qa {
		background-color: #efefef;
		padding: 1em;
	}

	.box_qa_q {
		background-color: #fff;
		padding: 0.2em 0.8em 0.5em 0.5em;
		border-bottom: 1px solid #ccc;
		font-size: 1em;
		font-weight: bold;
		color: #CD3B3E;
	}

	.box_qa_a {
		background-color: #fff;
		padding: 0.5em 1em;
		line-height: 1.8;
	}

	.box_qa_q p {
		text-indent: -2em;
		margin-left: 2.5em;
	}

	.box_qa_a p {
		text-indent: -2em;
		margin-left: 2.3em;
		line-height: 1.7em
	}

	/*よくある質問(アコーディオンver.)*/



	/*問い合わせエリア*/

	.box_entry {
		background-color: #125fa3;
		padding: 1em 1em;
	}

	.entry_inr {
		background-color: #fff;
		padding: 1em 1em;
	}

	.entry_tel {
		width: 100%;
		float: none;
		margin-top: 0.5em;
	}

	.entry_mail {
		width: 100%;
		float: none;
		margin-top: 0.5em;
	}

	/*フォームエリア*/

	/*全体*/
	.mailform {
		background-color: #fff;
		margin: 0em 0em 1em;
		padding: 1em 0em 1.5em;
		box-shadow: 0px 0px 1px #594a42;
	}

	.input {
		margin: 0em 0em 0em;
		padding: 0em 2em;
		color: #000;
	}

	.input_style {
		width: 100%;
		height: 60px;
		font-size: 100%;
		margin-bottom: 0.5em;
		text-align: center;
		color: #7b7b7b;
	}

	input[type="image"] {
		width: 100%;
		text-align: center;
		margin: 0em auto;
	}

	.caution {
		margin: 0em;
		padding: 0;
		font-size: 90%;
		color: #990000;
		text-align: center;
	}

	/* ------------------------------
   スライダー
------------------------------ */
.loopSliderWrap {
	top: 0;
	left: 0;
	height: 200px;
	overflow: hidden;
	position: absolute;
}
.loopSlider {
	background-color: #fff;
	margin: 0 auto;
	width: 100%;
	height: 100px;
	text-align: left;
	position: relative;
	overflow: hidden;
}
.loopSlider ul {
	height: 200px;
	float: left;
	overflow: hidden;
}
.loopSlider ul li {
	width: 150px;
	height: 150px;
	float: left;
	display: inline;
	overflow: hidden;
}
.loopSliderWrap ul li img {
	width: 100%;
}

	/*-----------------------------------------------------------------------------------------------------
フッター部分
-----------------------------------------------------------------------------------------------------*/

	.footer {
		padding: 2em 0em 8em;
		font-size: 1em;
	}

	/*スマホ用下部固定メニュー*/

	.fix_menu_smartphone {
		background-color: #fff;
		display: block;
		width: 100%;
		position: fixed;
		bottom: 0px;
		left: 0px;
		z-index: 10000;
		padding-top: 1.5em;
	}

	.fix_menu_smartphone img {
		width: 100%;
	}

	.tel_left {
		background-color: #fff;
		float: left;
		width: 50%;
		padding: 0em 0;
		border-right: 2px solid #ccc;
	}

	.tel_right {
		float: left;
		width: 50%;
		padding: 0em 0;
		margin-top: 9px;
	}

}