need@charset "UTF-8";


/*
	Theme Name: Make Smile パーソナルジム
	Description: Make Smile パーソナルジム
	Theme URI: https://makesmile-personalgym.jp/
	Author: オフィス谷口
	Author URI: https://www.officetaniguchi.com
	Version: 0.0.5
*/



/* 共通設定 */

* {
	box-sizing: border-box;
}
body {
	color: #777;
	font-family: "Noto Sans JP", sans-serif;
	font-size: 100%;
	letter-spacing: 0.1em;
	line-height: 1.5em;
	margin: 0;
	padding: 0;
}
aside, header, nav, footer {
	display: block;
}
header > div, footer > div, #breadcrumb {
	clear: both;
	overflow: auto;
	margin: 0 auto;
	padding: 0;
	width: 1200px;
}
hr {
	background-color: #499bea;
	border-style: none;
	height: 7px;
	margin: 0;
	padding: 0;
}
img {
	border: 0;
	margin: 0;
	max-width: 100%;
	vertical-align: bottom;
}
table {
	border-collapse: collapse;
}
.boldfont {
	font-weight: bold;
}
.caption {
	padding-left: 1.1em;
	text-indent: -1.1em;
}
.disable-auto-tel a[href^="tel:"] {
	color: inherit;
	text-decoration: none;
	pointer-events: none;
}
.redfont {
	color: #f00;
}
.smallfont {
	font-size: 80%;
	font-weight: normal;
	letter-spacing: 0.1em;
	line-height: 1.5em;
}
.textcenter {
	text-align: center;
}
@media screen and (min-width: 751px) {	 /* PCは電話リンクをなくす */
	a[href*="tel:"] {
		pointer-events: none;
		cursor: default;
		text-decoration: none;
	}
}




/* ヘッダー */

header {
	background-color: #fff;
	border-bottom: 2px solid #ccc;
	padding-bottom: 5px;
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 9999;
}
header > div {
	display: grid;
	grid-template-columns: 1fr 1fr;
	margin-left: auto;
	margin-right: auto;
	width: 90%;
}
header#faq_header > div {
	display: block;
}
header > div > div {
	display: grid;
	grid-template-columns: 1fr;
}
header > div > div p {
	grid-row: 1/2;
}
header > div > div p a {
	background-color: #ffa500;
	border-radius: 5px;
	color: #fff;
	display: block;
	font-size: 1.2rem;
	font-weight: bold;
	letter-spacing: 0.1em;
	line-height: 1em;
	margin: 0 auto;
	padding: 0.7em 0;
	text-align: center;
	text-decoration: none;
	transition: all 0.5s ease;
	width: 50%;
}
header > div > div p a:hover {
	background-color: #008000;
}
header > div > div nav {
	grid-row: 2/3;
}
header h1 {
	align-items: center;
	display: flex;
	margin: 0;
	padding: 0;
	text-align: center;
}
header h1 a {
	text-decoration: none;
}
header h1 img {
	height: 75px;
	width: auto;
}
header h1 a:hover {
	filter: alpha(opacity=70);
	-ms-filter: "alpha(opacity=70)";
	opacity: 0.7;
}
header#faq_header > div {
	display: block;
	padding: 7px 0 4px;
	overflow: hidden;
}
header#faq_header h1 {
	display: block;
}
nav ul {
	display: flex;
	justify-content: flex-start;
	list-style: none;
	margin: 0 auto;
	padding: 0;
}
nav li {
	flex-grow: 1;
	padding: 0;
	position: relative;
	margin: 0;
}
nav li a {
	display: block;
	color: #777;
	font-size: 0.9rem;
	font-weight: bold;
	letter-spacing: 0.1em;
	line-height: 40px;
	padding: 0;
	text-align: center;
	text-decoration: none;
}
nav li.active {
	border-bottom: 3px solid #0000cd;
}
nav li:not(.active)::after {
	background-color: #0000cd;
	bottom: 0;
	content: '';
	height: 3px;
	left: 0;
	position: absolute;
	transform: scale(0, 1);
	transform-origin: center top;
	transition: transform 0.75s;
	width: 100%;
}
nav li:not(.active):hover::after {
	transform: scale(1, 1);
}
nav input, nav label {
	display: none;
}



/* フッター */

footer {
	background: #f4f5f6;
	border-top: #eee;
	color: #aaa;
	font-size: 0.8em;
	letter-spacing: 0.1em;
	line-height: 1.5em;
	padding: 2rem 0;
	text-align: center;
	width: 100%;
}
footer > div {
	background-color: transparent;
	display: grid;
	grid-template-columns: 40% 1fr;
	margin: 0 auto;
}
footer ul {
	display: flex;
	justify-content: space-around;
	list-style-type: none;
	margin: 0;
	padding: 1em 0 40px;
}
footer p {
	margin-top: 5px;
}
#tel a {
	color: #ff8c00;
	font-size: 2rem;
	font-weight: bold;
	letter-spacing: 0.1em;
	line-height: 1.5em;
}
#tel a::before {
	content: '\f095';
	display: inline-block;
	font: var(--fa-font-solid);
	font-family: "Font Awesome 6 Free";
	font-weight: 900;
	padding-right: 0.3em;
	vertical-align: middle;
}



/* メインコンテンツ */

body {
	margin-top: 180px;
}
article {
	padding-bottom: 4rem;
}
article section, #notice {
	margin: 8rem auto;
	width: 1200px;
}
article section:nth-of-type(1) {
	1margin-top: 0;
}
section h2 {
	font-size: 1.8rem;
	letter-spacing: 0.1em;
	line-height: 1.5em;
	margin: 1rem auto 2em;
	pading: 0;
	text-align: center;
	width: 90%;
}
#breadcrumb {
	background-color: #000;
	display: flex;
	flex-wrap: wrap;
	list-style-type: none;
	margin: 1rem auto;
	padding: 0.4em 15px 0.6em;
	row-gap: 0.7em;
}
#breadcrumb li {
	color: #fff;
	margin: 0;
	padding: 0;
	width: auto;
}
#breadcrumb li a {
	color: #fff;
}
#breadcrumb li:first-child::before {
	content: '\f015';
	font: var(--fa-font-solid);
	font-family: "Font Awesome 6 Free";
	font-weight: 900;
	padding-right: 0.5em;
}
#breadcrumb li:not(:last-child)::after {
	content: '\f054';
	font: var(--fa-font-solid);
	font-family: "Font Awesome 6 Free";
	font-weight: 900;
	padding: 0 0.4em 0 0.7em;
}
#catch {
	display: grid;
	grid-template-columns: 1fr 1fr;
}
#catch > div {
	order: 2;
}
#catch > div h2 {
	margin-top: 0;
}
#catch > div ul {
	list-style-type: none;
	margin: 0 auto;
	padding: 0;
	width: 90%;
}
#catch > div ul li {
	display: flex;
	margin: 0.7em 0;
}
#catch > div ul li::before {
	color: #f00;
	content: '\f00c';
	font: var(--fa-font-solid);
	font-family: "Font Awesome 6 Free";
	font-size: 1.2em;
	font-weight: 900;
	letter-spacing: 0.1em;
	line-height: 1.5em;
	padding-right: 0.5em;
}
#catch > p {
	margin: 0;
	order: 1;
	padding: 0;
}
#catch > p img {
	object-fit: contain;
}
#cat_list, #infoarea, #rssarea, #to_newslist {
	margin: 0 auto;
	width: 60%;
}
#cat_list tr > *, #infoarea tr > * {
	border-bottom: 1px dashed #ccc;
	padding: 0.3em 1em;
}
#cat_list tr th, #infoarea tr th {
	width: 20%;
}
#course {
	display: grid;
	grid-template-columns: 45% 45%;
	justify-content: space-around;
}
#course > div:nth-child(1) {
	border: 5px solid #ffa500;
	border-radius: 7px;
}
#course > div:nth-child(2) {
	border: 5px solid #008000;
	border-radius: 7px;
}
#course > div > div {
	background-color: #f0f8ff;
	overflow: hidden;
	padding-left: 1rem;
	padding-right: 1rem;
	text-align: center;
}
#course > div h3 {
	font-size: 1.5rem;
	letter-spacing: 0.1em;
	line-height: 1.5em;
	text-align: center;
}
#course > div h4 {
	font-size: 1.3rem;
	letter-spacing: 0.1em;
	line-height: 1.5em;
	text-align: center;
}
#course > div ul {
	margin-left: auto;
	margin-right: auto;
	width: fit-content;
}
#results_desc {
	margin-bottom: 6rem;
	margin-top: 3rem;
	text-align: center;
}
#experience_flow {
	align-item: center;
	display: flex;
	justify-content: center;
}
#experience_flow > ul {
	list-style-type: none;
	padding-left: 0;
}
#experience_flow > ul > li {
	display: flex;
}
#experience_flow > ul > li:not(:last-child) {
	margin: 0 0 50px;
}
#experience_flow > ul > li > dl {
	padding: 0 0 0 30px;
	width: calc(100% - 115px);
}
#experience_flow > ul > li > dl dd {
	display: grid;
	grid-template-columns: 20% 1fr;
	margin: 0;
}
#experience_flow > ul > li > dl dd > div {
	order: 2;
}
#experience_flow > ul > li > dl dd > p {
	align-item: center;
	display: flex;
	justify-content: center;
	margin: 0;
}
#experience_flow > ul > li > dl dd > p img {
	border-radius: 50%;
	display: block;
	height: auto;
	width: 80%;
}
#experience_flow > ul > li > dl dt {
	border-bottom: 4px solid #ccc;
	font-size: 1.2em;
	font-weight: bold;
	margin: 0 0 15px;
	padding: 0 0 5px;
	position: relative;
}
#experience_flow > ul > li > dl dt::after {
	background-color: #b058d6;
	bottom: -4px;
	content: '';
	height: 4px;
	left: 0;
	position: absolute;
	width: 20%;
}
#experience_flow > ul > li > p {
	background: #b058d6;
	border-radius: 5px 5px 0 0;
	box-sizing: border-box;
	color: #fff;
	font-weight: bold;
	line-height: 125%;
	margin: 0;
	padding: 20px 10px 10px;
	position: relative;
	text-align: center;
	width: 90px;
}
#experience_flow > ul > li:last-child > p {
	border-radius: 5px;
}
#experience_flow > ul > li:not(:last-child) > p::after {
	border-left: 45px solid transparent;
	border-right: 45px solid transparent;
	border-top: 20px solid #B058D6;
	content: ' ';
	height: 0;
	left: 0;
	position: absolute;
	bottom: -20px;
	width: 0;
}
#faq_caption dl, #mail_form .mw_wp_form_complete {
	text-align: center;
}
#faq_caption dl, #mail_form .mw_wp_form_complete dl {
	margin: 3rem auto 0;
	width: 60%;
}
#faq_caption dd, #mail_form .mw_wp_form_complete dd {
	margin: 1rem;
}
#faq_caption dt, #mail_form .mw_wp_form_complete dt {
	background-color: #eee;
	font-weight: bold;
	margin-bottom: 1rem;
	padding: 0.7em 0;
}
#faq_caption dt:not(:first-child), #mail_form .mw_wp_form_complete dt:not(:first-child) {
	margin-top: 2rem;
}
#faq_caption, #personal_info {
	text-align: center;
}
#faq_caption ul {
	font-size: 1.5rem;
	font-weight: bold;
	letter-spacing: 0.1em;
	line-height: 1.5em;
	margin: 2rem auto;
	text-align: left;
	width: fit-content;
}
#faq_caption ul li {
	margin-bottom: 1em;
	margin-top: 1em;
}
#faq_caption ul li:last-child a {
	color: #777;
}
#faq_caption ul li:last-child span {
	font-size: 0.7em;
	font-weight: normal;
	letter-spacing: 0.1em;
	line-height: 1.5em;
}
#faq_list {
	list-style-type: none;
	margin: 0 auto;
	padding: 0;
	width: fit-content;
}
#faq_list li {
	align-items: center;
	margin: 1rem 0;
	display: flex;
}
#faq_list li > span {
	background-color: #f00;
	border-radius: 50%;
	display: inline-block;
	height: 2rem;
	margin-right: 0.5rem;
	text-align: center;
	width: 2rem;
}
#faq_list li > span::before {
	color: #fff;
	content: 'Q';
	display: inline-block;
	font-size: 1.2em;
	font-weight: bold;
	letter-spacing: 0.1em;
	line-height: 1em;
	margin-top: 0.3rem;
}
#faq_step {
	margin: 7rem auto;
	width: 45%;
}
#faq_step ol {
	display: flex;
	justify-content: space-between;
	margin: 0;
	padding: 0;
	position: relative;
}
#faq_step ol li {
	color: #c7c7c7;
	position: relative;
	z-index: 1;
}
#faq_step ol li:before {
	background: #c7c7c7;
	border-radius: 100%;
	content: "";
	display: block;
	height: 1.5em;
	margin: 0 auto 1em;
	width: 1.5em;
}
#faq_step ol li#on_state, #faq_step ol li.complete {
	color: #4b4b4b;
}
#faq_step ol li#on_state::before, #faq_step ol li.complete::before {
	background: #4b4b4b;
}
#faq_step ol::before {
	background: #c7c7c7;
	content: "";
	height: 1px;
	left: 2%;
	position: absolute;
	top: 11px;
	width: 95%;
	z-index: 1;
}
#mail_form table {
	margin: 0 auto;
	width: 80%;
}
#mail_form table td, #mail_form table th {
	border: 1px solid #ccc;
	padding: 0.7em 1em;
	text-align: left;
}
#mail_form table td span {
	font-size: 0.9em;
	color: #ccc;
	letter-spacing: 0.1em;
	line-height: 1.5em;
}
#mail_form table td span.error {
	color: #f00;
	font-weight: bold;

}
#mail_form table td p {
	margin: 1em;
}
#mail_form table th {
	background-color: #fbfbfb;
}
#mail_form #buttom_area input {
	background-color: #6fa1ff;
	border: 0;
	border-radius: 100vh;
	color: #fff;
	cursor: pointer;
	display: block;
	font-size: 1.2rem;
	font-weight: bold;
	letter-spacing: 0.1em;
	line-height: 1em;
	margin: 3rem auto;
	padding: 15px;
	text-align: center;
	width: 300px;
}
#mail_form .need {
	background-color: #f00;
	color: #fff;
	font-size: 0.8rem;
	letter-spacing: 0.1em;
	line-height: 1em;
	margin-left: 1em;
	padding: 0.2em 0.7em;
}
#map iframe {
	margin: 5rem 0 0;
	width: 100%;
}
#notice {
	display: grid;
	grid-template-columns: 70% 25%;
	justify-content: space-around;
}
#notice > div section {
	border: 1px solid #ccc;
	border-radius: 5px;
}
#notice > div section h2 {
	font-size: 1.5rem;
	letter-spacing: 0.1em;
	line-height: 1.5em;
}
#notice > div section ul {
	list-style-type: none;
	margin: 1rem auto;
	padding: 0;
	width: 85%;
}
#notice > div section ul li {
	display: grid;
	grid-template-columns: 10px 1fr;
	margin: 1rem 0;
}
#notice > div section ul li span:first-child {
	background-color: #c70026;
	display: block;
	grid-row: 1 / 3;
	width: 10px;
}
#notice > div section ul li a, #notice > div section ul li span:not(:nth-of-type(1)) {
	padding: 0.4em 0 0.5em 0.5em;
}
#notice > div section ul li span:nth-of-type(2) {
	padding-top: 0;
}
#notice section {
	margin: 0;
	width: auto;
}
#notice > section h2 > span {
	background-color: #f00;
	border-radius: 50%;
	display: inline-block;
	height: 2em;
	margin-right: 0.5rem;
	text-align: center;
	width: 2em;
}
#notice > section h2 > span::before {
	color: #fff;
	content: 'Q';
	display: inline-block;
	font-size: 1.2em;
	font-weight: bold;
	letter-spacing: 0.1em;
	line-height: 1em;
	margin-top: 0.4rem;
}
#pagination ul {
	list-style-type: none;
	margin:  3rem 0;
	padding: 0;
	text-align: center;
}
#pagination ul li {
	display: inline-block;
	height: 50px;
	margin: 0 2px;
	padding: 0;
	position: relative;
	width: 50px;
}
#pagination ul li a {
	background-color: #f5deb3;
	border-radius: 50px;
	color: #fff;
	display: block;
	left: 0;
	line-height: 50px;
	position: absolute;
	text-align: center;
	text-decoration: none;
	top: 0;
	transition: all 0.3s ease;
	width: 100%;
}
#pagination ul li a:hover {
	background-color: #8b0000;
	color: #fff;
}
#pagination ul li span {
	background-color: #8b0000;
	border-radius: 50px;
	color: #fff;
	display: block;
	left: 0;
	line-height: 50px;
	position: absolute;
	text-align: center;
	text-decoration: none;
	top: 0;
	transition: all 0.3s ease;
	width: 100%;
}
#payment_method {
	display: grid;
	grid-template-columns: 40% 1fr;
	margin: 0 auto;
	width: 80%;
}
#payment_method > div {
	order: 2;
}
#payment_method > div ul {
	margin-left: auto;
	margin-right: auto;
	width: fit-content;
}
#payment_method > div p {
	text-align: center;
}
#payment_method > p {
	order: 1;
	text-align: center;
}
#payment_method > p img {
	display: block;
	height: auto;
	margin: 0 auto;
	width: 300px;
}
#post {
	margin: 0 auto;
	width: 90%;
}
#post h2 {
	border-bottom: double 5px #ffc778;
	margin-top: 5rem;
}

#post p {
	text-align: left;
}
#privacy {
	margin: 5rem auto 2rem;
	width: 90%;
}
#privacy dd, #privacy dt {
	margin: 0;
	padding: 0;
}
#privacy dd {
	margin-left: 2em;
	margin-right: 2em;
}
#privacy dt {
	font-weight: bold;
	margin: 2em 1em 1em;
}
#privacy dt:not(:first-child) {
	margin-top: 4em;
}
#privacy dt span {
	margin-left: 1em;
}
#question-cat {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
	list-style-type: none;
	margin: 5rem auto;
	padding: 0;
	row-gap: 10px;
	width: 90%;
}
#question-cat li {
	align-items: center;
	border-radius: 10px;
	display: flex;
	height: 300px;
	justify-content: center;
	width: 300px;
}
#question-cat li:nth-child(1) {
	border: 5px solid #0000cd;
}
#question-cat li:nth-child(2) {
	border: 5px solid #008000;
}
#question-cat li:nth-child(3) {
	border: 5px solid #ffa500;
}
#question-cat li a {
	align-items: center;
	display: flex;
	font-size: 1.2em;
	font-weight: bold;
	height: 100%;
	justify-content: center;
	letter-spacing: 0.1em;
	line-height: 1.5em;
	text-decoration: none;
	width: 100%;
}
#question_post {
	background: url(img/anser_back.png) center top no-repeat;
	background-color:rgba(255,255,255,0.8);
	background-size: 70%;
	margin: 2rem auto;
	min-height: 800px;
	overflow: hidden;
	text-align: center;
	width: 90%;
}
#question_post p:first-child {
	margin-top: 3rem;
}
#result_list {
	margin: 0 auto;
	width: 90%;
}
#result_list ul {
	display: grid;
	grid-row-gap: 2rem;
	grid-template-columns: 30% 30% 30%;
	justify-content: space-around;
	list-style-type: none;
	margin: 0;
	padding: 0;
}
#result_list ul li a {
	display: block;
	height: auto;
	text-align: center;
	width: auto;
}
#rssarea {
	align-items: center;
	display: flex;
	flex-direction: column;
	justify-content: center;
	text-align: left;
}
#rssarea ul {
	list-style-type: none;
	margin: 0;
	padding: 0;
}
#rssarea ul li {
	display: flex;
}
#rssarea ul li:not(:first-child) {
	margin: 1.5em 0;
}
#rssarea ul li > span {
	margin-right: 0.7em;
}
#rssarea ul li > span::after {
	color:  #ff8c00;
	content: '\f31c';
	font: var(--fa-font-solid);
	font-family: "Font Awesome 6 Free";
	font-size: 1.5rem;
	font-weight: 900;
	letter-spacing: 0.1em;
	line-height: 1em;
}
#shopinfo {
	display: grid;
	grid-template-columns: 30% 1fr;
	margin: 0 auto;
	width: 90%;
}
#shopinfo > div {
	order: 2;
}
#shopinfo > div table {
	margin: 0 auto;
	width: 90%;
}
#shopinfo > div table tr > * {
	border-bottom: 1px solid #ccc;
	padding: 1em;
}
#shopinfo > div table tr:first-child > * {
	border-top: 1px solid #ccc;
}
#shopinfo > div table tr > th {
	background-color: #eee;
	width: 30%;
}
#shopinfo > p {
	margin: 0;
	order: 1;
}
#shopinfo > p img {
	border-radius: 50%;
	display: block;
	height: auto;
	margin: 0 auto;
	width: 90%;
}
#strong_point {
	display: grid;
	grid-row-gap: 2rem;
	grid-template-columns: 47% 47%;
	justify-content: space-around;
}
#strong_point > div {
	border: 1px solid #ddd;
	border-radius: 7px;
}
#strong_point > div > div {
	display: grid;
	grid-template-columns: 1fr;
	margin: 2rem auto;
	width: 90%;
}
#strong_point > div > div > div {
	order: 2;
}
#strong_point > div > div > p {
	margin: 0;
	order: 1;
	padding: 0;
	text-align: center;
}
#strong_point > div > div > p img {
	height: auto;
	width: 70%;
}
#strong_point h3 {
	background-color: #f0ffff;
	border-radius: 7px 7px 0 0;
	1display: grid;
	1grid-template-columns: 20% 1fr;
	font-size: 1.5rem;
	letter-spacing: 0.1em;
	line-height: 1.5em;
	margin: 0;
	padding: 1rem;
	text-align: center
}
#ticket {
	display: grid;
	grid-template-columns: 30% 30% 30%;
	justify-content: space-around;
	margin: 0 auto;
	width: 90%;
}
#ticket > div {
	border-radius: 7px;
}
#ticket > div:nth-child(1) {
	border: 5px solid #0000cd;
}
#ticket > div:nth-child(2) {
	border: 5px solid #008000;
}
#ticket > div:nth-child(3) {
	border: 5px solid #ffa500;
}
#ticket > div > div {
	background-color: #f0f6da;
	overflow: hidden;
	text-align: center;
}
#ticket > div > div p {
	margin: 1em;
}
#ticket > div h3 {
	font-size: 1.5rem;
	letter-spacing: 0.1em;
	line-height: 1.5em;
	text-align: center;
}
#ticket > div h4 {
	font-size: 1.3rem;
	letter-spacing: 0.1em;
	line-height: 1.5em;
	text-align: center;
}
#tofaq {
	display: grid;
	grid-template-columns: 45% 45%;
	justify-content: space-around;
}
#tofaq > div > a {
	color: #fff;
	text-decoration: none;
}
#tofaq > div:nth-of-type(1) > a {
	background: linear-gradient(to bottom,  #7abcff 0%,#60abf8 44%,#4096ee 100%);
	display: block;
	height: 100%;
	width: 100%;
}
#tofaq > div:nth-of-type(1) > a:hover {
	background: linear-gradient(to bottom,  #0fb4e7 0%,#a9e4f7 100%);
}
#tofaq > div:nth-of-type(2) > a {
	background-color: #06c755;
	display: grid;
	grid-template-columns: 1fr 40%;
}
#tofaq > div > a > div {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	height: 100%;
	justify-content: center;
	width: 100%;
}
#tofaq > div:nth-of-type(2) > a > p {
	align-items: center;
	display: flex;
	justify-content: center;
}
#tofaq > div:nth-of-type(2) > a > p img {
	display: block;
	height: auto;
	width: 80%;
}
#tofaq > div h2 {
	font-size: 5rem;
	letter-spacing: 0.1em;
	line-height: 1.5em;
	margin: 0;
	padding: 0;
}
#tofaq > div h2 span {
	display: block;
	font-size: 1.3rem;
	letter-spacing: 0.1em;
	line-height: 1.5em;
}
#to_newslist {
	margin-top: 1em;
	text-align: right;
}
#to_newslist a::before {
	color: #c70026;
	content: '\f138';
	display: inline-block;
	font: var(--fa-font-solid);
	font-family: "Font Awesome 6 Free";
	font-size: 1.2em;
	font-weight: 900;
	margin-right: 5px;
	vertical-align: middle;
}
#trial_plan {
	display: grid;
	grid-template-columns: 30% 30% 30%;
	justify-content: space-around;
	margin: 0 auto;
	width: 90%;
}
#trial_plan > div {
	border: 3px solid #ccc;
	border-radius: 7px;
}
#trial_plan > div > div > p:first-child {
	align-items: center;
	display: flex;
	justify-content: center;
	margin: 0;
	margin: 0;
}
#trial_plan > div > div > p:first-child img {
	border-radius: 50%;
	display: block;
	height; auto;
	width: 90%;
}
#trial_plan > div > div > p:nth-child(2) {
	color: #f00;
	font-size: 1.2rem;
	font-weight: bold;
	letter-spacing: 0.1em;
	line-height: 1.5em;
	text-align: center;
}
#trial_plan > div > div > p:nth-child(3) {
	margin: 1em auto;
	width: 80%;
}
#trial_plan > div > h3 {
	font-size: 1.5rem;
	letter-spacing: 0.1em;
	line-height: 1.5em;
	text-align: center;
}
.layout {
	display: grid;
	grid-template-columns: 1fr 1fr;
}
.layout > div > div {
	margin: 1em auto;
	width: 90%;
}
.layout > p {
	margin: 0;
	padding: 0;
}
.layout > p img {
	object-fit: contain;
}
.layout:nth-of-type(even) > div {
	order: 2;
}
.layout:nth-of-type(even) > p {
	order: 1;
}
.shop_access {
	border: 2px solid #f88400;
	border-radius: 10px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
	width: 90%;
}
.shop_access:not(:last-of-type) {
	margin-bottom: 50px;
}
.shop_access:not(:last-of-type) > div::after, .shop_access:not(:last-of-type) > div::before {
	border: solid transparent;
	content: '';
	left: 50%;
	position: absolute;
	top: 100%;
	transform: translateX(-50%);
}
.shop_access:not(:last-of-type) > div::before {
	border-top-color: #f88400;
	border-width: 42px;
}
.shop_access:not(:last-of-type) > div::after {
	border-top-color: #fff;
	border-width: 40px;
}
.shop_access > div {
	display: grid;
	grid-template-columns: 30% 1fr;
	margin: 0 auto;
	padding: 2rem 0;
	position: relative;
	width: 90%;
}
.shop_access > div > div {
	order: 2;
}
.shop_access > div > div p {
	margin: 1em;
}
.shop_access > div > p {
	margin: 0;
	order: 1;
}
.shop_access > div > p img {
	border-radius: 50%;
	display: block;
	margin: 0 auto;
	width: 90%;
}
.slider {
	margin: 0;
	padding: 0;
}
.slider2 {
	list-style-type: none;
	margin: 0;
	padding: 0;
}
.trainer_info {
	display: grid;
	grid-template-columns: 30% 1fr;
	margin: 0 auto;
	width: 80%;
}
.trainer_info > div {
	order: 2;
}
.trainer_info h3 {
	text-align: center;
}
.trainer_info > p {
	margin: 0;
	order: 1;
}
.trainer_info > p img {
	border-radius: 50%;
	display: block;
	height: auto;
	margin: 2rem auto 0;
	width: 90%;
}
.trainer_info:nth-of-type(1) h3 span {
	display: block;
	font-size: 0.8em;
	font-weight: normal;
	letter-spacing: 0,1em;
	line-height: 1.5em;
}
.trainer_info:nth-of-type(1) > div > p {
	text-align: center;
}
.trainer_info:nth-of-type(1) > div > table {
	margin: 1em auto;
	width: 90%;
}
.trainer_info:nth-of-type(1) > div > table tr > * {
	border-bottom: 1px solid #ccc;
	padding: 1em;
}
.trainer_info:nth-of-type(1) > div > table tr > th {
	background-color: #eee;
	width: 30%;
}
.trainer_info:nth-of-type(1) > div ul {
	list-style-type: none;
	margin: 0;
	padding: 0;
}
.trainer_info:nth-of-type(1) > div ul li {
	display: flex;
}
.trainer_info:nth-of-type(1) > div ul li::before {
	content: '\f111';
	font: var(--fa-font-solid);
	font-family: "Font Awesome 6 Free";
	font-size: 1.2em;
	font-weight: 900;
	letter-spacing: 0.1em;
	line-height: 1.5em;
	padding-right: 0.3em;
}
.trainer_info:nth-of-type(2) {
	margin-top: 2rem;
}
.trainer_info:nth-of-type(2) > div > div p {
	margin: 1em;
}
.w-1 {
	margin-left: auto;
	margin-right: auto;
	width: 90%;
}






/* 画面サイズ 1200px用 */
@media screen and (max-width: 1200px) {
	article section, header > div, footer > div, #notice {
		width: 100%;
	}
	header h1 a {
		margin-left: 1rem;
	}
	#breadcrumb, #catch, #experience_flow, #faq_caption, #map, #personal_info, #strong_point, .layout, .slider, .trainer_info {
		margin-left: auto;
		margin-right: auto;
		width: 95%;
	}
	#infoarea, #rssarea {
		width: 70%;
	}
}

/* 画面サイズ 1080px用 */
@media screen and (max-width: 1080px) {
	#mail_form table {
		width: 95%;
	}
}
/* 画面サイズ 960px用 */
@media screen and (max-width: 960px) {
	footer ul {
		flex-wrap: wrap;
		margin-left: auto;
		margin-right: auto;
		width: 70%;
	}
	footer ul li {
		width: 25%;
	}
	footer ul li:nth-of-type(n+5) {
		margin-top: 2em;
	}
	#question-cat li {
		height: 250px;
		width: 250px;
	}
	#tofaq > div h2 {
		font-size: 3rem;
		letter-spacing: 0.1em;
		line-height: 1.5em;
	}
}

/* 画面サイズ 896px用 */
@media screen and (max-width: 896px) {
	footer ul {
		align-items: flex-start;
		flex-wrap: nowrap;
		margin: 3rem auto;
		width: 95%;
	}
	footer ul li {
		width: auto;
	}
	footer ul li:nth-of-type(n+5) {
		margin-top: 0;
	}
	footer > div {
		display: block;
	}
	section h2 {
		font-size: 1.5rem;
		letter-spacing: 0.1em;
		line-height: 1.5em;
	}
	#mail_form table th {
		text-align: center;
	}
	#mail_form .need {
		display: block;
		margin: 1em 0;
		padding: 0.3em 0 0.5em;
	}
	#strong_point h3 {
		display: block;
		overflow: hidden;
		1padding: 1em 0;
		text-align: center;
	}
}

/* 画面サイズ 854px用 */
@media screen and (max-width: 854px) {
	#faq_caption dl, #mail_form .mw_wp_form_complete dl {
		width: 80%;
	}
	#catch {
		grid-template-columns: 1fr;
	}
	#catch > div ul {
		margin-top: 3rem;
		width: fit-content;
	}
	#experience_flow > ul > li > dl dd {
		grid-template-columns: 40% 1fr;
	}
	#mail_form table td, #mail_form table th, #mail_form table tr {
		display: block;
	}
	#mail_form table td {
		padding: 2rem 0 3rem;
		text-align: center;
	}
	#mail_form table th {
		padding-bottom: 1em;
	}
	#mail_form .need {
		display: inline;
		margin: 0 0 0 0.7em;
		padding: 0.3em 0.7em 0.5em;
	}
	#ticket {
		display: block;
		width: 70%;
	}
	#ticket > div:not(:first-child) {
		margin-top: 2rem;
	}
	#ticket > div ul {
		margin-left: auto;
		margin-right: auto;
		width: fit-content;
	}
}

/* 画面サイズ 810px用 */
@media screen and (max-width: 810px) {
	#course, #notice, #trial_plan {
		display: block;
	}
	#course > div, #trial_plan > div {
		margin-left: auto;
		margin-right: auto;
		width: 70%;
	}
	#course > div:not(:first-child), #trial_plan > div:not(:first-child) {
		margin-top: 2rem;
	}
	#notice > div section {
		margin: 5rem auto 0;
		width: 90%;
	}
	#payment_method, #shopinfo, .trainer_info {
		grid-template-columns: 1fr;
	}
	#result_list ul {
		grid-template-columns: 47% 47%;
	}
	#shopinfo > div table {
		margin-top: 2rem;
	}
	#shopinfo > p img, .trainer_info > p img {
		width: 50%;
	}
	#strong_point {
		display: block;
	}
	#strong_point > div:not(:first-child) {
		margin-top: 2rem;
	}
	#strong_point h3 {
		1display: grid;
		1grid-template-columns: 20% 1fr;
	}
}

/* 画面サイズ 800px用 */
@media screen and (max-width: 800px) {
	header {
		padding: 10px 0;
		overflow: hidden;
		top: 50px;
	}
	header#faq_header {
		top: 0;
	}
	header > div > * {
		height: 100%;
		width: 100%;
	}
	header > div > div {
		display: block;
		width: 100%;
	}
	header > div > div p, header h1 {
		align-items: center;
		display: flex;
		height: 100%;
		justify-content: center;
		margin: 0;
	}
	header h1 a {
		margin: 0;
	}
	header nav {
		background-color: #4169e1;
		height: 50px;
		overflow: visible;
		position: fixed;
		right: 0;
		top: 0;
		width: 100%;
		z-index: 99999;
	}
	header nav > label {
		cursor: pointer;
		display: block;
		float: right;
		height: 30px;
		margin-right: 15px;
		margin-top: 7px;
		position: relative;
		width: 30px;
		z-index: 11;
	}
	header nav > label::before {
		box-shadow: #fff 0 12px 0;
		-webkit-box-shadow: #fff 0 12px 0;
	}
	header nav > label::after {
		bottom: 0;
	}
	header nav > label::before, nav label::after {
		background: #fff;
		content: '';
		display: block;
		height: 6px;
		position: absolute;
		transition: box-shadow 0.2s linear, transform 0.2s 0.2s;
		-webkit-transition: -webkit-box-shadow 0.2s linear, -webkit-transform 0.2s 0.2s;
		width: 30px;
	}
	header nav > input:checked ~ label::before {
		-webkit-box-shadow: transparent 0 0 0;
		box-shadow: transparent 0 0 0;
		-webkit-transform: rotate(45deg) translate3d(6px, 11px, 0);
		transform: rotate(45deg) translate3d(6px, 11px, 0);
	}
	header nav > input:checked ~ label::after {
		-webkit-transform: rotate(-45deg) translate3d(6px, -11px, 0);
		transform: rotate(-45deg) translate3d(6px, -11px, 0);
	}
	header nav > input:checked ~ ul {
		right: 0;
	}
	header nav > ul {
		background-color: #00f;
		box-shadow: 8px 0px 8px -1px rgba(0,0,0,0.31);
		-webkit-box-shadow: 8px 0px 8px -1px rgba(0,0,0,0.31);
		-moz-box-shadow: 8px 0px 8px -1px rgba(0,0,0,0.31);
		display: block;
		height: auto;
		right: -230px;
		margin-top: 45px;
		position: absolute;
		top: 0;
		transition: left 0.4s;
		-webkit-transition: left 0.4s;
		width : 230px;
		z-index: 99999;
	}
	header nav > ul li {
		border: 0;
		display: block;
		height: auto;
	}
	header nav > ul li a {
		border-top: 1px solid #fff;
		color: #fff;
		font-size: 1rem;
		letter-spacing: 0.1em;
		line-height: 1em;
		padding: 1em 0;
		text-align: center;
	}
	header nav > ul li a::before {
		background-color: transparent;
	}
}

/* 画面サイズ 768px用 */
@media screen and (max-width: 768px) {
	#experience_flow > ul > li > dl dd > p img {
		height: 200px;
		width: 200px;
	}
	#tofaq {
		grid-row-gap: 1rem;
		grid-template-columns: 90%;
	}
	.layout {
		grid-template-columns: 1fr;
	}
	.layout > div {
		order: 2;
	}
	.layout > p {
		order: 1;
	}
}

/* 画面サイズ 736px用 */
@media screen and (max-width: 736px) {
	header > div {
		grid-template-columns: 60% 1fr;
	}
}

/* 画面サイズ 667px用 */
@media screen and (max-width: 667px) {
	header > div > div p a {
		width: 80%;
	}
	#cat_list, #faq_list, #infoarea,, #rssarea, #to_newslist {
		width: 90%;
	}
}

/* 画面サイズ 640px用 */
@media screen and (max-width: 640px) {
	#experience_flow > ul > li > dl dd {
		grid-template-columns: 90%;
	}
	#faq_caption dl, #mail_form .mw_wp_form_complete dl {
		width: 95%;
	}
	#faq_step {
		width: 70%;
	}
}

/* 画面サイズ 600px用 */
@media screen and (max-width: 600px) {
	body {
		margin-top: 300px;
	}
	header > div {
		display: block;
	}
	header > div > div {
		margin-top: 2rem;
	}
	header > div > div p a {
		width: 60%;
	}
}

/* 画面サイズ 428px用 */
@media screen and (max-width: 428px) {
	footer ul {
		flex-wrap: wrap;
		gap: 1.5em 1em;
	}
	#course > div, #faq_list li a, #mail_form table tr:not(:nth-child(2)) td input, #mail_form table td textarea, #ticket, #trial_plan > div {
		width: 90%;
	}
	#infoarea tr > * {
		display: block;
	}
	#infoarea tr th {
		border: 0;
	}
	#infoarea tr:not(:first-child) th {
		margin-top: 1em;
	}
	#map iframe {
		height: 400px;
	}
	#result_list ul {
		grid-template-columns: 90%;
	}
	.shop_access > div {
		grid-template-columns: 1fr;
	}
}

/* 画面サイズ 400px用 */
@media screen and (max-width: 400px) {
	header h1 img {
		height: auto;
		width: 85%;;
	}
	#shopinfo > p img, .trainer_info > p img {
		width: 80%;
	}
	#tofaq > div:nth-of-type(2) > a {
		grid-template-columns: 1fr;
	}
	#tofaq > div > a > div {
		order: 2;
	}
	#tofaq > div:nth-of-type(2) > a > p {
		oeder: 1;
	}
	#tofaq > div:nth-of-type(2) > a > p img {
		width: 50%;
	}
}
