@charset "utf-8";
/*------------------------------------------------------------
Theme Name: スタジオミトー STUDIO MITOH
Theme URI: null
Description: Description
Author: 81bridge - LSZ
Version: 1.0
------------------------------------------------------------*/
.aligncenter {
	display: block;
	margin: 0 auto;
}
.alignright {
	float: right;
}
.alignleft {
	float: left;
}
img[class*="wp-image-"],
img[class*="attachment-"] {
	height: auto;
	max-width: 100%;
}
.wp-block-image figure,
.wp-block-image figcaption {
	display: block;
}
a.nolink,
a.nolink:hover {
	opacity: 1;
	cursor: default;
	pointer-events: none;
}
/*------------------------------------------------------------
	デフォルトスタイル
------------------------------------------------------------*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, figcaption, figure, section, footer, header, main, hgroup, menu, nav, summary {
	margin: 0;
	padding: 0;
	background: transparent;
	border: 0;
	outline: 0;
	font-size: 1em;	
	box-sizing: border-box;
}
html {
	font-size: 62.5%;
}
@media all and (max-width: 374px) {
	html {
		font-size: calc(1000vw / 375);
	}
}
@media all and (min-width: 897px) and (max-width: 1500px) {
	html {
		font-size: calc(1000vw / 1450);
	}
}
body, table, input, textarea, select, option {
	font-family: "M PLUS 1 Code", monospace;
	font-family: "M PLUS Rounded 1c", sans-serif;
}

.opensans {
	font-family: "Open Sans", sans-serif;
}
article, aside, canvas, details, figcaption, figure, footer, header, main, hgroup, menu, nav, section, summary {
	display: block;
}
ol, ul {
	list-style: none;
	box-sizing: border-box;
}
blockquote, q {
	quotes: none;
}
chrome_annotation {
	border: none !important;
}
:focus {
	outline: 0;
}
ins {
	text-decoration: none;
}
del {
	text-decoration: line-through;
}
img {
	vertical-align: top;
	max-width: 100%;
    height: auto;
}
address {
	font-style: normal;
}
a,
a:link {
	color: #000;
	text-decoration: none;
	transition: 0.3s;
}
a:visited {
	color: #000;
}
a:hover {
	color: #000;
}
a:active {
	color: #000;
}
/*------------------------------------------------------------
	レイアウト
------------------------------------------------------------*/
@media (prefers-reduced-motion: no-preference) {
	:root {
		scroll-behavior: inherit;
	}
}
body {
	color: #000;
	font-size: 1.6rem;
	line-height: 1.5;
	text-size-adjust: none;
	-webkit-text-size-adjust: none;
	background: url(img/common/bg_0928.png) repeat left top;
	background-size: 60rem auto;
}
/* .fixed {
	position: fixed;
	width: 100%;
	height: 100%;
} */
#container {
	overflow: hidden;
	text-align: left;
    word-break: break-word;
}
a[href^="tel:"] {
	cursor: default;
	pointer-events: none;
}
@media all and (min-width: 897px) {
	.sp {
		display: none !important;
	}
	.menuBox {
		display: block !important;
	}
}
@media all and (max-width: 896px) {
	body {
		min-width: inherit;
		font-size: 1.5rem;
	}
	a:hover,
	a:hover img {
		opacity: 1 !important;
	}
	.pc {
		display: none !important;
	}
	a[href^="tel:"] {
		cursor: pointer;
		pointer-events: auto;
	}
}
/*------------------------------------------------------------
	ヘッダー
------------------------------------------------------------*/
#gHeader {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 1000;
	background-color: #fff;
}
#gHeader .hInner {
	align-items: center;
	padding: 0 min(7.8vw,14.8rem);
	height: 9rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#gHeader h1 {
	width: 21.1rem;
}
#gHeader h1 img {
	margin-top: -0.9rem;
}
#gHeader .rBox {
	padding-top: 0.5rem;
	flex: 1;
	gap: 0 2.5rem;
	align-items: flex-start;
	display: flex;
	justify-content: flex-end;
}
#gNavi {
	margin: 1.2rem min(4.95vw,9.5rem) 0 0;
	font-size: 1.4rem;
	font-weight: 500;
	display: flex;
	flex-wrap: wrap;
	letter-spacing: 0.199em;
}
.hInner .tel {
	margin-top: -0.2rem;
	font-size: min(0.8vw,1.4rem);
	line-height: 1.2;
	font-weight: 500;
	align-self: center;
	letter-spacing: 0.199em;
}
.hInner .tel a {
	white-space: nowrap;
	line-height: 1;
	display: inline-block;
	font-size: min(1.25vw,2.4rem);
	font-weight: 500;
	letter-spacing: 0.199em;
}
.hInner .snsUl {
	display: flex;
	gap: 0 min(1.1vw,2rem);
}
.hInner .snsUl li {
	width: min(2.7vw,5rem);
}
#gHeader .rBox a:hover {
	opacity: 0.7;
}
#main {
	min-height: calc(100vh - 21.5rem);
	padding-top: 9rem;
}

@media all and (min-width: 897px) {
	
	#gNavi a {
		padding: 0.5rem min(1.0vw,1.9rem);	
	}
}
@media all and (max-width: 896px) {
	#gHeader .hInner {
		padding: 0 1rem;
		height: 6.55rem;
	}
	#gHeader h1 {
		width: 18.7rem;
		padding-top: 1.5rem;
	}
	.menuBox {
		display: none;
		position: absolute;
		top: 6.55rem;
		left: 0;
		width: 100%;
		height: calc(100vh - 6.55rem);
		z-index: 800;
		overflow-y: auto;
		background-color: #FEEEFF;
	}
	.menuBox .menuPhoto {
		width: 13.2rem;
		position: absolute;
		bottom: 1.1rem;
		right: 2.2rem;
	}
	.menuBox nav {
		min-height: 100%;
		position: relative;
	}
	#gNavi {
		padding: 2rem 3rem 15rem 4rem;
		font-size: 1.75rem;
		margin: 0;
		display: block;
	}
	#gNavi li {
		margin-bottom: 2.4rem;
	}
	#gNavi li:last-child {
		margin-bottom: 0;
	}
	.hInner .snsUl {
		gap: 0 1rem;
	}
	.hInner .snsUl li {
		width: 4.3rem;
	}
	#gHeader .rBox {
		padding-block: 0;
		padding-right: 6.7rem;
	}
	.menu {
		cursor: pointer;
		position: absolute;
		top: 0;
		right: 0;
		width: 6.55rem;
	}
	.menu.on {
		background: url(img/common/close.png) no-repeat center;
		background-size: 100% auto;
	}
	.menu.on img {
		visibility: hidden;
	}
	#main {
		min-height: calc(100vh - 6.55rem - 4.8rem);
		padding-top: 6.55rem;
	}
}
/*------------------------------------------------------------
	フッター
------------------------------------------------------------*/
#gFooter {
	margin-top: 12.38rem;
	padding: 3.2rem 2rem 3.1rem;
	background-color: #8D8986;
}
address {
	text-align: center;
	font-size: 1.898rem;
	color: #fff;
}
.pageTop {
	opacity: 0;
	visibility: hidden;
	position: fixed;
	bottom: 2rem;
	right: 2rem;
	z-index: 100;
	width: 12.9rem;
	transition: 0.3s;
}
.pageTop.on {
	opacity: 1;
	visibility: visible;
}
.pageTop a:hover {
	opacity: 0.7;
}
@media all and (min-width: 897px) {
	.pageTop {
		transform: scale(0.7);
		transform-origin: center;
	}
}

@media all and (max-width: 896px) {
	#gFooter {
		margin-top: 7rem;
		padding: 1.5rem 2rem 1.9rem;
	}
	address {
		font-size: 0.949rem;
	}
	.pageTop {
		bottom: 5rem;
		width: 4rem;
		right: 1rem;
	}
}

/*------------------------------------------------------------
	汎用スタイル
------------------------------------------------------------*/
/* 81-PSP */
/* clearfix */	
.clearfix:after {content: "";display: block;clear: both;}
/* flex */	
.flex,.flexA,.flexB,.flexC {display: flex;flex-wrap: wrap;}
.flexA {justify-content: space-around;}
.flexB {justify-content: space-between;}
.flexC {justify-content: center;}
/*------------------------------------------------------------
content
------------------------------------------------------------*/
.content {
	align-items: flex-start;
	margin: 0 auto;
	padding: 0 4rem;
	max-width: 144rem;
}
@media all and (min-width: 897px) {
}

@media all and (max-width: 896px) {
	.content {
		padding: 0 2rem;
		max-width: inherit;
	}
}

/*------------------------------------------------------------
headLine01
------------------------------------------------------------*/
.headLine01 {
	margin-bottom: 2.6rem;
	font-size: 3rem;
	font-weight: 500;
	text-align: center;
	letter-spacing: 0.199em;
}
.headLine01 > span {
	display: block;
}
@media all and (min-width: 897px) {
}

@media all and (max-width: 896px) {
	.headLine01 {
		letter-spacing: 0.1em;
		margin-bottom: 1.5rem !important;
		font-size: min(6.7vw,2.6rem) !important;
	}
}

/*------------------------------------------------------------
headLine02
------------------------------------------------------------*/
.headLine02 {
	margin-bottom: 7.6rem;
	font-size: 4.5rem;
	font-weight: 500;
	position: relative;
	letter-spacing: 0.199em;
	z-index: 1;
}
.headLine02 .txtSpan {
	position: absolute;
	top: -1.7rem;
	left: 0.5rem;
	width: 28.7rem;
	z-index: -1;
}
@media all and (min-width: 897px) {
}

@media all and (max-width: 896px) {
	.headLine02 {
		letter-spacing: 0.1em;
		font-size: 2.5rem;
		width: fit-content;
		margin: 0 auto 4rem;
	}
	.headLine02 .txtSpan {
		width: 100% !important;
		text-align: center;
	}
	.headLine02 .txtSpan img {
		max-width: inherit;
		height: 6.5rem;
		width: auto;
	}
	
}

/*------------------------------------------------------------
comLink
------------------------------------------------------------*/
.comLink {
	margin: 0 auto;
	width: 41.4rem;
}
.comLink a {
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 7.8rem;
	border-radius: 6rem;
	text-align: center;
	font-size: 1.952rem;
	font-weight: 500;
	letter-spacing: 0.05em;
	background-color: #D8A9DC;
}
.comLink a:hover {
	opacity: 0.7;
}
.comLink.small {
	width: 37.5rem;
}
.comLink.small a {
	min-height: 10rem;
	font-size: 2.747rem;
}
@media all and (min-width: 897px) {
	.comLink a {
		transform: scale(0.8);
		transform-origin: center;
	}
}

@media all and (max-width: 896px) {
	.comLink {
		width: auto;
		max-width: 32rem;
	}
	.comLink a {
		min-height: 5.5rem !important;
		font-size: 1.5rem !important;
	}
}

/*------------------------------------------------------------
comBox
------------------------------------------------------------*/
#main .comBox {
	margin-top: 27rem;
	padding-bottom: 8.3rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end !important;
	justify-content: space-between;
}
#main .comBox .photoBox {
	margin-right: -8rem;
	margin-left: 9.62rem;
	width: calc(50% + -6rem);
	order: 2;
}
#main .comBox .photoBox img {
	border-radius: 4.5rem;
	width: 100%;
}
#main .comBox .textBox {
	max-width: 75.3rem;
	padding-left: 4rem;
	margin-top: -0.4rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	flex: 1;
}
#main .comBox .textBox .sub {
	/* max-width: 85.4rem; */
	width: 100%;
}
#main .comBox .textBox p {
	margin-bottom: 2.5rem;
	line-height: 1.5;
}
#main .comBox .textBox .ttl {
	white-space: nowrap;
	margin: 0 -5rem 7.1rem 0;
	font-size: min(2.4vw,4.5rem);
	font-weight: 500;
	letter-spacing: 0.199em;
}
#main .comBox .textBox .photo {
	padding-top: 1rem;
	margin-bottom: 1.1rem;
	text-align: center;
	mix-blend-mode: multiply; 
}
#main .comBox .textBox .photo img {
	width: 25rem;
}
@media all and (min-width: 1601px) {
	#main .comBox .textBox {
		max-width: inherit;
		padding-left: min(8.7vw,16rem);
	}
}

@media all and (max-width: 896px) {
	#main .comBox {
		padding-bottom: 0rem;
		display: block;
		margin: 10rem 2rem 0;
	}
	#main .comBox .photoBox {
		display: none;
		width: auto;
		margin: 0 0 2rem;
	}
	#main .comBox .photoBox img {
		border-radius: 2rem;
	}
	#main .comBox .textBox {
		max-width: inherit !important;
		padding: 0 !important;
		margin: 0;
		display: block;
	}
	#main .comBox .textBox .sub {
		max-width: inherit;
	}
	#main .comBox .textBox .ttl {
		text-align: center;
		font-size: 2.25rem;
		margin: 0 0 5rem;
		line-height: 1.2;
		letter-spacing: 0;
	}
	#main .comBox .textBox p {
		margin-bottom: 1.5rem;
	}
	#main .comBox .textBox .photo img {
		width: 12.5rem;
	}
}

/*------------------------------------------------------------
	common//
------------------------------------------------------------*/

@media all and (min-width: 897px) {
}

@media all and (max-width: 896px) {
}

/*------------------------------------------------------------
blog
------------------------------------------------------------*/
#blog {
	padding-top: 6rem;
}
#sideBar {
	margin-right: 13.8rem;
	width: 22rem;
}
#sideBar .sideList > li {
	min-height: 26.6rem;
	margin-bottom: 5rem;
}
#sideBar .sideList > li:last-child {
	margin-bottom: 0;
}
#sideBar .ttl {
	margin-bottom: 2.2rem;
	font-size: 2.5rem;
	font-weight: 500;
	letter-spacing: 0.199em;
}
#sideBar .subList:not(.dateList) {
	border-top: 1px solid #ABA7A4;
}
#sideBar .subList li {
	border-bottom: 1px solid #ABA7A4;
}
#sideBar .subList a {
	padding: 0.8rem 0.5rem 0.6rem;
	display: flex;
	justify-content: space-between;
	font-weight: 500;
	letter-spacing: 0.199em;
}
#sideBar .subList a:hover {
	opacity: 0.7;
}
#sideBar .dateList .date {
	letter-spacing: 0.35em;
	background: url(img/common/icon01.png) no-repeat right 2.2rem center;
	background-size: 1.7rem auto;
}
#sideBar .dateList .date.on {
	background-image: url(img/common/icon02.png);
}
#sideBar .jsList {
	display: none;
	border-top: 1px solid #ABA7A4;
}
#sideBar .jsList li:last-child {
	border: none;
}
#sideBar .jsList li a {
	padding-inline: 2rem;
	letter-spacing: 0.45em;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#conts {
	order: 2;
	margin: -0.2rem 8rem 0 0;
	flex: 1;
}
#main .blogListBox {
	padding-bottom: 1.7rem;
	position: relative;
}
#main .blogListBox:after {
	display: none;
	width: 100%;  
	aspect-ratio: 1844 / 803;
	background: url(img/common/bg02.png) no-repeat center top;
	background-size: 100% auto;
	position: absolute;  
	bottom: -5rem;
	left: 0;
	content: ""; 
}
#main .blogListBox .comLink {
	display: none;
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
}
#main .blogListBox .noData {
	text-align: center;
	font-weight: 500;
}
#main .blogList {
	display: flex;
	flex-wrap: wrap;
	gap: 1.65rem 1.9rem;
}
#main .blogList li {
	width: calc((100% - (1.9rem * 2 + 0.1rem)) / 3);
}
#main .blogList li:nth-child(n+10) {
	display: none;
}
#main .blogList a {
	height: 100%;
	display: block;
	padding: 2.7rem 2.5rem 2.4rem;
	background-color: #fff;
	border: 1px solid #ABA7A4;
}
#main .blogList a:hover {
	opacity: 0.7;
}
#main .blogList:not(.show) li:nth-child(7) a,
#main .blogList:not(.show) li:nth-child(8) a,
#main .blogList:not(.show) li:nth-child(9) a {
	border-left: none;
	border-bottom: none;
	border-right: none;
	position: relative;
	background: linear-gradient(to bottom, rgba(255,255,255,0.7), transparent);
}
#main .blogList li:nth-child(7) a::before,
#main .blogList li:nth-child(8) a::before,
#main .blogList li:nth-child(9) a::before {
	width: 1px;  
	height: 75%;
	background: linear-gradient(to bottom, rgba(171,168,164,1), transparent);
	position: absolute;  
	top: 0;
	left: 0;
	content: ""; 
}
#main .blogList.show li:nth-child(7) a::before,
#main .blogList.show li:nth-child(8) a::before,
#main .blogList.show li:nth-child(9) a::before {
	display: none;
}
#main .blogList li:nth-child(7) a::after,
#main .blogList li:nth-child(8) a::after,
#main .blogList li:nth-child(9) a::after {
	width: 1px;  
	height: 75%;
	background: linear-gradient(to bottom, rgba(171,168,164,1), transparent);
	position: absolute;  
	top: 0;
	right: 0;
	content: ""; 
}
#main .blogList.show li:nth-child(7) a::after,
#main .blogList.show li:nth-child(8) a::after
#main .blogList.show li:nth-child(9) a::after {
	display: none;
}
#main .blogList li:nth-child(7) .txtBox,
#main .blogList li:nth-child(8) .txtBox,
#main .blogList li:nth-child(9) .txtBox {
	opacity: 0;
	visibility: hidden;
}
#main .blogList.show li:nth-child(7) .txtBox,
#main .blogList.show li:nth-child(8) .txtBox,
#main .blogList.show li:nth-child(9) .txtBox {
	opacity: 1;
	visibility: visible;
}
#main .blogList .photo {
	margin-bottom: 2rem;
	position: relative;
	aspect-ratio: 486 / 384;
}
#main .blogList .photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#main .blogList .date {
	margin-bottom: 1rem;
	font-size: 1.3rem;
}
#main .blogList p {
	font-size: 1.8rem;
	letter-spacing: 0.199em;
}
#main .blogList p:not(.ttl,.date) {
	line-height: 1.6;
}
#main .blogList .ttl {
	margin-bottom: 1rem;
	font-weight: 700;
}
#single #conts {
	margin-right: 9.6rem;
	padding: 4.9rem 5.3rem 7rem;
	border-radius: 4.5rem;
	background-color: #FFFFFF;
}
#single #conts h2 {
	margin: 0 0 0.7rem;
	text-align: left;
	letter-spacing: 0.036em;
}
#single #conts p {
	margin-bottom: 2.1rem;
	font-weight: 400;
	line-height: 1.875;
}
#single #conts p:last-child {
	margin-bottom: 0;
}
#single #conts p a {
	text-decoration: underline;
}
#single #conts p a:hover {
	opacity: 0.7;
}
#single #conts p strong {
	font-weight: 700;
}
#single #conts .date {
	margin: 0 0 2.4rem 0; 
	line-height: 1.5;
	letter-spacing: 0.199em;
}
.wp-block-image .aligncenter {
	margin-bottom: 2.9rem;
}
.wp-block-image .aligncenter .wp-element-caption {
	font-weight: 500;
	letter-spacing: -0.02em;
}
#single #conts h3 {
	font-size: 2.4rem;
	font-weight: 500;
	letter-spacing: 0.03em;
	margin-bottom: 0.5rem;
	padding-top: 2.3rem;
}
#single #conts .date + .wp-block-image .aligncenter {
	padding-top: 5rem;
}
#single #conts .date + h3 {
	padding-top: 0.3rem;
	margin-bottom: 1.2rem;
}
#single #conts p + .wp-block-columns {
	padding-top: 2.5rem;
}
#single #conts .wp-block-columns {
	margin-bottom: 4.2rem;
	align-items: flex-start !important;
}
#single #conts .wp-block-columns p {
	margin-bottom: 3rem;
}
#single :where(.wp-block-columns.is-layout-flex) {
    gap: 0;
}
#single #conts .wp-block-columns:last-child {
	margin-bottom: 0;
}
#single #conts .wp-block-column {
	margin-bottom: 4rem;
}
#single #conts .wp-block-column:has(.wp-block-image) {
	width: 20rem;
	flex: inherit !important;
	margin-right: 2.8rem;
	margin-top: 0.4rem;
}
#single #conts .wp-block-column:has(.wp-block-image) img {
	width: 100%;
}
#single #conts .wp-block-column:not(.wp-block-image) {
	flex: 1;
	margin-bottom: 0;
}
#single #conts .wp-block-column p:last-child {
	margin-bottom: 0 !important;
}
#main .pageList {
	padding-top: 5rem;
	gap: 1rem 12rem;
	font-weight: 500;
	display: flex;
	justify-content: center;
	text-align: center;
}
#main .pageList a:hover {
	opacity: 0.7;
}
#main .pageList .prev a {
	display: inline-block;
	padding-left: 2.5rem;
	background: url(img/common/icon05.png) no-repeat left center;
	background-size: 1.1rem auto;
}
#main .pageList .next a {
	display: inline-block;
	padding-right: 2.5rem;
	background: url(img/common/icon06.png) no-repeat right center;
	background-size: 1.1rem auto;
}
@media all and (min-width: 897px) {
	#blog #conts {
		margin-top: 0;
	}
}

@media all and (max-width: 896px) {
	#blog {
		padding-top: 3rem;
	}
	#blog .content {
		display: block;
	}
	#conts {
		margin: 0 0 5rem;
	}
	#sideBar {
		width: auto;
		margin: 0;
	}
	#main .blogListBox {
		padding-bottom: 0;
	}
	#main .blogList {
		display: block;
	}
	#main .blogList li {
		margin-bottom: 4rem;
		width: auto;
	}
	#main .blogList li:last-child {
		margin-bottom: 0;
	}
	#main .blogList a {
		padding: 2rem;
	}
	#main .blogList p {
		font-size: 1.6rem;
	}
	#main .blogList .no a {
		padding-bottom: 0;
	}
	#sideBar .ttl {
		margin-bottom: 1rem;
		font-size: 2rem;
	}
	#sideBar .sideList > li {
		min-height: inherit;
		margin-bottom: 5rem;
	}
	#single #conts {
		margin-right: 0;
		padding: 2.5rem 2rem 5rem;
	}
	#single #conts .wp-block-columns {
		margin-bottom: 2.8rem;
		display: block !important;
	}
	#single #conts .wp-block-column:has(.wp-block-image) {
		width: auto;
		margin: 0 0 2rem;
	}
	#single #conts h3 {
		font-size: 1.9rem;
	}
	#main .blogListBox .comLink {
		transform: none;
		left: auto;
		width: 20.6rem;
		margin-left: calc(50% - 10.3rem);
	}
	#main .blogList .no .txtBox {
		display: none;
	}
	#main .pageList {
		padding-top: 3rem;
		gap: 1rem 2rem;
	}
	#main .pageList .prev a {
		padding-left: 1.5rem;
		background-size: 0.8rem auto;
	}
	#main .pageList .next a {
		padding-right: 1.5rem;
		background-size: 0.8rem auto;
	}
}

/*------------------------------------------------------------
pw
------------------------------------------------------------*/
#pw {
	padding-top: 6rem;
}
#pw .photo {
	padding-top: 0.6rem;
	width: 28rem;
	margin: 0 auto 2.3rem;
}
#pw dl {
	margin-bottom: 4.2rem;
	text-align: center;
}
#pw dl dt {
	margin-bottom: 1.6rem;
	font-size: 2.5rem;
	font-weight: 500;
	letter-spacing: 0.199em;
}
#pw dl dd {
	margin: 0 auto;
	max-width: 40.8rem;
	font-size: 2rem;
}
input[type="email"],
input[type="tel"],
input[type="text"],
input[type="password"] {
    appearance:none;
    -moz-appearance:none;
    -webkit-appearance:none;
    border-radius: 0;
    height: 5.8rem;
	color: #000;
    border: 4px solid #000;
    box-sizing: border-box;
    font-size: 1.7rem;
    padding: 0 1rem;
    width: 100%;
    background-color: #fff;
}	
.submit {
	text-align: center;
}
.submit li {
	margin: 0 0.5rem;
	display: inline-block;
	position: relative;
}
.submit li input {
    appearance:none;
    -moz-appearance:none;
    -webkit-appearance:none;
    width: 41.2rem;
    height: 7.8rem;
    border-radius: 6rem;
    text-align: center;
    cursor: pointer;
    font-size: 1.952rem;
    font-weight: 500;
    color: #fff;
    border: none;
    background-color: #D8A9DC;
}
.submit li.disabled input {
	pointer-events: none;
	opacity: 0.7;
}
@media all and (min-width: 897px) {
	.submit li input:hover {
		opacity: 0.7;
	}
}

@media all and (max-width: 896px) {
	#pw {
		padding-top: 3rem;
	}
	#pw .photo {
		width: 20rem;
	}
	#pw dl {
		margin-bottom: 3.5rem;
	}
	#pw dl dt {
		font-size: 1.4rem;
	}
	input[type="email"], input[type="tel"], input[type="text"],input[type="password"] {
		height: 4rem;
		font-size: 1.4rem;
	}
	.submit li {
		max-width: 30rem;
		display: block;
		margin: 0 auto 1rem;
	}
	.submit li:last-child {
		margin-bottom: 0;
	}
	.submit li input {
		width: 100%;
		height: 5rem;
		font-size: 1.4rem;
	}
}

/*------------------------------------------------------------
faq
------------------------------------------------------------*/
#faq {
	padding-top: 6rem;
}
#main .faqList {
	margin: 0 auto;
	max-width: 120rem;
	border-top: 1px solid #ABA7A4;
}
#main .faqList li {
	border-bottom: 1px solid #ABA7A4;
}
#main .faqList dt {
	cursor: pointer;
	padding: 1.8rem 9rem;
	font-size: 2.3rem;
	font-weight: 500;
	letter-spacing: 0.199em;
	background: url(img/common/icon03.png) no-repeat right 5rem center;
	background-size: 2.1rem auto;
}
#main .faqList dt.on {
	background-image: url(img/common/icon04.png);
}
#main .faqList dd {
	font-size: 2rem;
	display: none;
	padding: 1.8rem 9rem;
}
#main .faqList dd p {
	margin-bottom: 3rem;
}
#main .faqList dd .comLink {
	margin-top: 3rem;
}
@media all and (min-width: 897px) {
}

@media all and (max-width: 896px) {
	#faq {
		padding-top: 3rem;
	}
	#main .faqList dt {
		line-height: 1.3;
		font-size: 1.5rem;
		letter-spacing: 0.05em;
		padding: 1.2rem 2rem 1.2rem 0;
		background-size: 1.5rem auto;
		background-position: right center;
	}
	#main .faqList dd {
		font-size: 1.4rem;
		padding: 0 3rem 2rem 0;
	}
	#main .faqList dd .comLink {
		margin: 3rem auto 0;
	}
}

/*------------------------------------------------------------
contact
------------------------------------------------------------*/
#contact {
	padding-top: 6.0rem;
}
#contact .content {
	max-width: 168rem;
}
#main .mailForm {
	max-width: 136rem;
	margin: 0 auto;
	padding: 0 0 0 8.5rem;
}
#contact p {
	margin-bottom: 6.2rem;
}
#main .contactDl {
	align-items: flex-start;
}
#main .contactDl dt {
	padding: 2.8rem 3.5rem 0 0;
	width: 23.5rem;
	font-weight: 400;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#main .contactDl dt .must {
	font-size: 2rem;
	color: #FF0000;
	font-weight: 700;
	font-family: Meiryo, "小塚ゴシック Pr6N", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", sans-serif;
}
#main .contactDl dd {
	padding: 1.1rem 8rem 1.2rem 0;
	width: calc(100% - 23.5rem);
}
#main .contactDl input[type="email"],
#main .contactDl input[type="tel"],
#main .contactDl input[type="text"] {
	border-radius: 6rem;
	border-width: 3px;
	height: 5.5rem;
	border-color: #707070;
}
#main .contactDl .dtStyle {
	width: 0;
	padding: 0;
}
#main .contactDl .ddStyle {
	width: 100%;
	padding-bottom: 2.5rem;
}
textarea {
	resize: vertical;
    appearance:none;
    -moz-appearance:none;
    -webkit-appearance:none;
    border-radius: 0;
    height: 42.1rem;
	color: #000;
    border: 3px solid #707070;
    box-sizing: border-box;
    font-size: 1.7rem;
    padding: 1rem;
    width: 100%;
	border-radius: 2.6rem;
    background-color: #fff;
}	
#main .checkList {
	padding: 1.9rem 2rem 4.6rem;
	display: flex;
	flex-wrap: wrap;
	gap: 0 1.6rem;
}
input[type="checkbox"] {
    display: none;
}
input[type="checkbox"] ~ span {
	background: url(img/common/check01.png) no-repeat left center;
	background-size: 1.2rem auto;
	border-radius: 0;
    display: inline-block;
    line-height: 2rem;
	cursor: pointer;
    padding: 0.4rem 0 0.4rem 1.4rem;
}
input[type="checkbox"]:checked ~ span {
	background-image: url("img/common/check02.png");
}
input[type="radio"] {
    display: none;
}
input[type="radio"] ~ span {
	background: url(img/common/radio01.png) no-repeat left center;
	background-size: 1.5rem auto;
	border-radius: 0;
    display: inline-block;
    line-height: 2rem;
	cursor: pointer;
    padding: 0.4rem 0 0.4rem 2rem;
}
input[type="radio"]:checked ~ span {
	background-image: url("img/common/radio02.png");
}
#contact .privacyBox {
	margin: 7rem 0 9.1rem;
	padding: 4.3rem 23rem;
	background-color: #DDD9D6;
}
#contact .privacyBox h3 {
	margin-bottom: 2.8rem;
	text-align: center;
	font-size: 3rem;
	font-weight: 500;
	letter-spacing: 0.199em;
}
#contact .privacyBox p {
	margin-bottom: 0.2rem;
	font-size: 2rem;
}
#contact .privacyBox .whiteBox {
	margin-right: -6rem;
	margin-block-end: 4.4rem;
	background-color: #fff;
	padding: 2.3rem 7rem 2.3rem 4rem;
	height: 24rem;
	overflow-y: auto;
}
#contact .privacyBox .whiteBox p {
	font-size: 1.6rem;
	margin-bottom: 2.5rem;
}
#contact .privacyBox .whiteBox p:last-child {
	margin-bottom: 0;
}
#contact .checkP {
	text-align: center;
}
#contact .checkP input[type="checkbox"] + span {
	font-size: 2rem;
	font-weight: 500;
	padding-left: 2rem;
	letter-spacing: 0.199em;
	background-size: 1.5rem auto;
}
#thanks p {
	line-height: 1.8;
	text-align: center;
}
#contact .wpcf7-spinner {
	position: absolute;
	bottom: -3rem;
	left: 42%;
}
@media all and (min-width: 897px) {
	#contact .headLine01 {
		margin-bottom: 4rem;
	}
	#contact .submit li input {
		width: 32.7rem;
	}
}

@media all and (max-width: 896px) {
	#contact {
		padding-top: 3rem;
	}
	#main .mailForm {
		padding: 0;
	}
	#contact p {
		margin-bottom: 3rem;
	}
	#main .contactDl{
		display: block;
	}
	#main .contactDl dt {
		width: auto;
		padding: 0;
		display: block;
	}
	#main .contactDl dt .must {
		font-size: 1.4rem;
		margin-left: 1rem;
	}
	#main .contactDl dd {
		padding: 0 0 2rem;
		width: auto !important;
	}
	#main .contactDl input[type="email"], #main .contactDl input[type="tel"], #main .contactDl input[type="text"] {
		height: 4rem;
		border-width: 2px;
	}
	textarea {
		border-width: 2px;
		height: 10rem;
		font-size: 1.4rem;
		border-radius: 1.3rem;
	}
	#main .checkList {
		padding: 0;
	}
	#contact .privacyBox {
		padding: 3rem 2rem;
		margin: 3rem 0 5rem;
	}
	#contact .privacyBox h3 {
		font-size: 1.7rem;
	}
	#contact .privacyBox p {
		font-size: 1.4rem;
	}
	#contact .privacyBox .whiteBox {
		margin: 0;
		padding: 2rem 1rem;
	}
	#contact .privacyBox .whiteBox p {
		font-size: 1.4rem;
	}
	#contact .checkP {
		margin-top: 1rem;
	}
	#contact .checkP input[type="checkbox"] + span {
		font-size: 1.4rem;
		letter-spacing: 0;
	}
}

/*------------------------------------------------------------
tuter
------------------------------------------------------------*/
#tuter {
	padding-top: 6rem;
}
#sideBar .sideList02 .subList:not(.dateList) {
	border: none;
}
#sideBar .sideList02 li {
	border: none;
}
#sideBar .sideList02 .subList li:not(:last-child) {
	margin-bottom: 1.8rem;
}
#sideBar .sideList02 a {
	padding: 0;
	font-size: 1.8rem;
	color: #C8C8C8;
}
#sideBar .sideList02 .current a {
	color: #000;
}
#tuter #conts {
	padding-top: 0.6rem;
}
#tuter #conts .headLine01 {
	margin-bottom: 3.2rem;
}
#tuter #conts .imgBox {
	margin-bottom: 8rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#tuter #conts .imgBox .photoBox {
	/* width: 48rem; */
	width: 52%;
	margin-right: 4.3rem;
}
#tuter #conts .imgBox .photoBox img {
	width: 100%;
	border-radius: 4.5rem;
}
#tuter #conts .imgBox .textBox {
	margin-top: -0.7rem;
	flex: 1;
}
#tuter #conts .imgBox .ttl {
	font-size: 2.5rem;
	font-weight: 700;
	margin-bottom: 3.1rem;
}
#tuter #conts .imgBox .smallTxt {
	font-size: 1.2rem;
	line-height: 1.33;
	margin-bottom: 2.2rem;
}
#tuter #conts .imgBox .comLink {
	margin-top: 3.6rem;
}
#tuter #conts .greeting {
	margin-bottom: 10.8rem;
}
#tuter #conts .greeting .headLine01 {
	margin-bottom: 2.2rem;
}
#tuter #conts .greeting p {
	margin-bottom: 2.5rem;
}
#tuter #conts .greeting p:last-child {
	margin-bottom: 0;
}
#tuter .awardsBox {
	border-radius: 3rem;
	margin: -0.8rem 1rem 0 0;
	padding: 0.7rem 0.8rem 0.7rem 1.2rem;
	background-color: #D8A9DC;
}
#tuter .awardsBox dl {
	border-radius: 2rem;
	overflow: hidden;
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	justify-content: space-between;
}
#tuter .awardsBox dt {
	padding: 0 2.8rem;
	display: flex;
	align-items: center;
	font-size: 2rem;
	font-weight: 400;
	width: calc(100% - 36rem);
	border-bottom: 3px solid #fff;
}
#tuter .awardsBox dt:last-of-type {
	border: none;
}
#tuter .awardsBox dd {
	padding: 1rem;
	text-align: center;
	font-size: 2rem;
	letter-spacing: 0.25em;
	width: 36rem;
	background-color: #fff;
	border-bottom: 3px solid #D8A9DC;
}
#tuter .awardsBox dd:last-child {
	border: none;
}
#tuter .awards {
	margin-bottom: 10.8rem;
}
#tuter .awards:last-child {
	margin-bottom: 0;
}
#tuter .achievements {
	margin-bottom: 2rem;
}
#tuter .achievements .awardsBox dt {
	justify-content: center;
}
#tuter #conts .txtSpan {
	display: block;
	font-size: 1.5rem;
	margin-left: 1rem;
}
#tuter #conts .txtSpan span {
	display: block;
}
#tuter .history {
	margin-top: 10.8rem;
}
#tuter .historyList {
	margin-right: 1.7rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 2rem 3.4rem;
}
#tuter .historyList li {
	padding: 3.2rem 2rem 2.3rem;
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	justify-content: space-between;
	border-top: 1px solid #8D8986;
	border-bottom: 1px solid #8D8986;
	width: calc((100% - 3.4rem) / 2);
}
#tuter .historyList li .photo {
	width: 11.7rem;
	margin-right: 2rem;
}
#tuter .historyList li .rBox {
	flex: 1;
}
#tuter .historyList dl {
	display: flex;
	flex-wrap: wrap;
}
#tuter .historyList dt {
	margin-right: 1rem;
	font-size: 1.5rem;
	font-weight: 700;
	margin-bottom: 0.4rem;
}
#tuter .historyList dd {
	font-size: 1.5rem;
	margin-bottom: 1.2rem;
}
#tuter .historyList dd:last-child {
	margin-bottom: 0;
}
#tuter .historyList .liStyle dl {
	display: block;
}
body:has(#sideBar) #container {
	overflow: inherit;
	overflow-x: clip;
}
@media all and (min-width: 897px) {
	#tuter #sideBar {
		position: sticky;
		top: 15rem;
		left: 0;
		margin-right: 13.5rem;
	}
	#sideBar .sideList02 a:hover {
		color: #000;
	}
	#tuter #conts .imgBox .comLink {
		width: 32.7rem;
	}
}

@media all and (max-width: 896px) {
	#tuter .content {
		display: block;
	}
	#tuter #conts {
		padding-top: 0;
	}
	#tuter #conts .imgBox {
		margin-bottom: 8rem;
		display: block;
	}
	#tuter #conts .headLine01 {
		margin-bottom: 1.5rem;
	}
	#tuter #conts .imgBox .photoBox {
		width: auto;
		margin: 0 0 2rem;
	}
	#tuter #conts .imgBox .photoBox img {
		width: 100%;
		border-radius: 2rem;
	}
	#tuter #conts .imgBox .textBox {
		margin: 0;
	}
	#tuter #conts .imgBox .ttl {
		font-size: 2rem;
	}
	#tuter #conts .greeting {
		margin-bottom: 8rem;
	}
	#tuter .awards:not(.achievements) {
		margin-bottom: 8.0rem;
	}
	#tuter .awardsBox {
		padding: 3rem 1rem;
		border-radius: 2rem;
	}
	#tuter .awardsBox dl {
		display: block;
		border-radius: 0;
	}
	#tuter .awardsBox dt {
		width: auto;
		font-size: 1.5rem;
		padding: 0 0 0.5rem;
	}
	#tuter .awardsBox dd {
		width: auto;
		margin-bottom: 2rem;
		font-size: 1.5rem;
		padding: 0.5rem 1rem;
	}
	#tuter .awardsBox dd:last-child {
		margin-bottom: 0;
	}
	#tuter .history {
		margin-top: 8rem;
	}
	#tuter .historyList {
		margin: 0;
		display: block;
	}
	#tuter .historyList li {
		width: auto;
		padding-top: 2rem;
		padding-inline: 1rem 0;
	}
	#tuter .historyList li:last-child {
		margin-bottom: 0;
	}
	#tuter .historyList li:not(:last-child) {
		border-bottom: none;
	}
	#tuter .historyList li .photo {
		width: 10rem;
		display: flex;
		align-items: center;
		border-radius: 100%;
		height: 10rem;
		justify-content: center;
		background-color: #FEEFFF;
		margin-right: 1rem;
	}
	#tuter .historyList li .photo img {
		width: 75%;
	}
	#tuter .historyList dl {
		display: block;
	}
	#tuter .historyList dt {
		margin: 0;
	}
	.sideList02 {
		overflow: hidden;
		z-index: 80;
		position: fixed;
		bottom: 0;
		left: 0;
		width: 100%;
		display: flex;
		background: #ffffff;
		box-shadow: 0 -0.9rem 1.2rem rgba(0, 0, 0, 0.05);
		overflow-x: auto;
	}
	.sideList02 > li {
		padding: 0 1rem;
		display: flex;
		min-height: inherit !important;
		width: 100%;
	}
	.sideList02 .ttl {
		display: none;
	}
	.sideList02 .subList {
		gap: 0 2rem;
		padding: 1rem 0;
		display: flex;
		justify-content: center;
		flex-shrink: 0;
	}
	.sideList02 .subList li {
		margin: 0 !important;
	}
	.sideList02 a {
		font-size: 1.3rem !important;
	}
	body:has(.sideList02) #gFooter {
		margin-bottom: 4rem;
	}
}

/*------------------------------------------------------------
pw/blog/detail.html
------------------------------------------------------------*/
#single.pw_detail #conts p + .wp-block-columns {
	padding-top: 0;
}
#single.pw_detail #conts p {
	line-height: 1.5;
	margin-bottom: 1.6rem;
}
#single.pw_detail #conts p:last-child {
	margin-bottom: 0;
}
#single.pw_detail .wp-block-columns {
	gap: 2.8rem 1rem;
}
#single.pw_detail #conts .wp-block-column:has(.wp-block-image) {
	margin: 0;
	width: calc((100% - 2.1rem) / 3);
}
#single.pw_detail .wp-block-image :where(figcaption) {
	text-align: center;
	font-weight: 500;
	margin: 0.5rem 0 0;
}
#single.pw_detail #conts .date + h3 {
	margin-bottom: 0.5rem;
}
#single.pw_detail #conts .date {
	margin-bottom: 3rem;
}
@media all and (min-width: 897px) {
	#single.pw_detail #conts h3 {
		font-size: 2.3rem;
		padding-bottom: 0.2rem;
	}
}

@media all and (max-width: 896px) {
	#single.pw_detail #conts .wp-block-columns {
		display: flex !important;
	}
	#single.pw_detail #conts .wp-block-column:has(.wp-block-image) {
		width: calc((100% - 1rem) / 2);
	}
	#single.pw_detail #conts .wp-container-core-columns-is-layout-3 {
		margin-bottom: 2.8rem;
	}
}

/*------------------------------------------------------------
lesson
------------------------------------------------------------*/
#lesson {
	padding-top: 6rem;
}
#lesson .headLine01 {
	margin-bottom: 3.3rem;
}
#lesson .tabList {
	margin-bottom: 2.7rem;
	display: flex;
	overflow: hidden;
	border-radius: 12rem;
	background-color: #EFEAF0;
}
#lesson .tabList li {
	width: calc(100% / 4);
	position: relative;
    z-index: 2;
}
#lesson .tabList .curBtn {
    position: absolute;
    left: 0;
    top: 0;
    width: calc(100% / 4);
    height: 100%;
    background-color: #D8A9DC;
    border-radius: 12rem;
    z-index: 1;
}
#lesson .tabList a {
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 6.5rem;
	text-align: center;
	border-radius: 12rem;
	font-size: 1.4rem;
	position: relative;
}
#lesson .tabList .on a {
	color: #fff;
	transition: all 0.01s 0.3s;
}
#lesson .tabInner {
	min-height: 36.6rem;
	margin-bottom: 9.5rem;
	padding: 3.3rem 5.5rem 4.5rem;
	background-color: #fff;
	border-radius: 3rem;
	border: 3px solid #D8A9DC;
}
#lesson .tabInner h3 {
	font-size: 2.5rem;
	letter-spacing: 0.2em;
	font-weight: 500;
	margin-bottom: 1rem;
	text-align: center;
}
#lesson .tabInner .list {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem 5rem;
}
#lesson .tabInner .list .txt {
	display: flex;
	font-size: 3rem;
	font-weight: 700;
	align-items: center;
}
#lesson .tabInner .list .txt .txtSpan {
	flex-shrink: 0;
	font-weight: 500;
	margin-right: 1rem;
	width: 6.7rem;
	text-align: center;
	border-radius: 1.2rem;
	text-align: center;
	color: #fff;
	font-size: 1.6rem;
	letter-spacing: 0.05em;
	padding: 0.3rem 0.2rem;
	background-color: #D8A9DC;
}
#lesson .tabInner .ttl {
	font-size: 2rem;
	font-weight: 700;
	margin-bottom: 1rem;
}
#lesson .tabInner .tabBox {
	display: none;
}
#lesson .tabInner .tabBox:nth-child(1) {
	display: block;
}
#lesson .tabInner p {
	margin-bottom: 2.4rem;
}
#lesson .tabInner p:last-child {
	margin-bottom: 0;
}
#lesson .lessonList {
	margin-top: -1.5rem;
	display: flex;
	flex-wrap: wrap;
	gap: 4.84rem;
}
#lesson .lessonList li {
	padding: 2rem 4rem 0.5rem;
	position: relative;
	background-color: #fff;
	min-height: 35rem;
	width: calc((100% - 4.84rem) / 2);
}
#lesson .lessonList li .pointTxt {
	position: absolute;
	top: 2rem;
	left: 3.5rem;
	width: 6rem;
	height: 6rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	font-size: 1.068rem;
	font-weight: 500;
	padding-bottom: 0.4rem;
	background: url(img/lesson/bg.png) no-repeat center;
	background-size: 100% auto;
}
#lesson .lessonList li .pointTxt .num {
	display: block;
	font-size: 2.45rem;
	line-height: 1;
	margin-top: -0.4rem;
}
#lesson .lessonList .photo {
	width: 20rem;
	margin: 0 auto -2.0rem;
}
#lesson .lessonList .ttl {
	font-weight: 700;
	line-height: 1.2;
	margin-bottom: 0.8rem;
}
#lesson .lessonSec {
	margin-bottom: 9.5rem;
}
#lesson .scheduleList {
	padding-top: 0.4rem;
	margin-left: 4.6rem;
}
#lesson .scheduleList > li {
	/* min-height: 24rem; */
	padding: 0 0 4rem 1.6rem;
	position: relative;
}
#lesson .scheduleList > li:last-child {
	padding-bottom: 0;
}
#lesson .scheduleList > li::before {
	width: 2px;  
	background-color: #8D8986;
	position: absolute;  
	top: 0.2rem;
	bottom: -2.5rem;
	left: -0.2rem;
	content: ""; 
}
#lesson .scheduleList > li:last-child::before {
	display: none;
}
#lesson .scheduleList li .ttl {
	padding-right: 4rem;
	margin: 0 1rem -0.5rem;
	font-size: 2.4rem;
	font-weight: 500;
	position: relative;
}
#lesson .scheduleList li:has(.text) .text{
	margin-top: 1.2rem;
}
#lesson .scheduleList li:has(.text) .ttl {
	cursor: pointer;
}
#lesson .scheduleList li:has(.text) .ttl:after {
	width: 2.1rem;  
	height: 2.1rem;
	background: url(img/common/icon03.png) no-repeat right center;
	background-size: 100% auto;
	position: absolute;  
	top: 50%;
	transform: translateY(-50%);
	right: 0;  
	content: ""; 
}
#lesson .scheduleList li:has(.text) .ttl.on:after {
	background-image: url(img/common/icon04.png);
}
#lesson .scheduleList li .text {
	background-color: #fff;
	border-radius: 2rem;
	padding: 2rem;
	display: none;
}
#lesson .scheduleList li .ttl::before {
	width: 3rem;  
	height: 3rem;
	border-radius: 100%;
	background-color: #D8A9DC;
	position: absolute;  
	top: 0.2rem;
	left: -4.2rem;
	content: ""; 
}
#lesson .scheduleList li .ttl:has(.bgSpan) {
	margin-bottom: 2.8rem;
}
#lesson .scheduleList li .ttl:has(.bgSpan)::before {
	width: 1.5rem;
	height: 1.5rem;
	left: -3.5rem;
	top: 1.2rem;
	background-color: #ECBDF0;
}
#lesson .scheduleList li .ttl .bgSpan {
	background: linear-gradient(transparent 0%, transparent 50%, #EBBDF0 50%, #EBBDF0 100%);
}
#lesson .comScrollBox {
	margin-right: -100%;
}
#lesson .scheduleList .comScrollBox {
	margin-left: 0.4rem;
}
#main .comScrollBox ul {
	display: flex;
}
#main .comScrollBox li {
	width: 30rem;
	margin-right: 1.9rem;
	position: relative;
	flex-shrink: 0;
}
#main .comScrollBox li img {
	width: 100%;
	height: 100%;
	aspect-ratio: 300 / 250;
	object-fit: cover;
	border-radius: 4rem;
}
#lesson .schedule {
	margin-bottom: 9.5rem;
}
#lesson .certification p {
	margin-bottom: 5rem;
}

@media all and (min-width: 897px) {
	#lesson #sideBar {
		position: sticky;
		top: 0;
		left: 0;
		top: 15rem;
		margin-right: 5.5rem;
		width: 30rem;
	}
	#lesson #conts {
		flex: inherit;
		width: calc(100% - 44.3rem);
		margin-right: 8.8rem;
		padding-top: 0.3rem;
	}
	/* #lesson .tabList a:hover {
		color: #fff;
		background-color: #D8A9DC;
	} */
	#lesson .scheduleList li .wpTag {
		max-width: 79rem;
	}
	#lesson .tabInner .list {
		margin-bottom: 1rem;
	}
	#lesson .lessonList .ttl {
		margin-bottom: 1.5rem;
	}
}

@media all and (max-width: 896px) {
	#lesson {
		padding-top: 3rem;
	}
	#lesson .content {
		display: block;
	}
	#lesson .tabList a {
		font-size: 1.0rem;
		line-height: 1.2;
		min-height: 4.5rem;
	}
	#lesson .headLine01 {
		margin-bottom: 1.5rem;
	}
	#lesson .tabInner {
		margin-bottom: 8rem;
		border-width: 3px;
		border-radius: 2rem;
		padding: 2rem;
	}
	#lesson .tabInner h3 {
		font-size: min(5.0vw,2rem);
		letter-spacing: 0;
	}
	#lesson .tabInner .list {
		display: block;
	}
	#lesson .tabInner .list li {
		margin-bottom: 0.5rem;
	}
	#lesson .tabInner .list:last-child {
		margin-bottom: 0;
	}
	#lesson .tabInner .list .txt {
		font-size: 1.8rem;
	}
	#lesson .tabInner .list .txt .txtSpan {
		font-size: 1.4rem;
	}
	#lesson .tabInner .ttl {
		font-size: min(4.1vw,1.6rem);
	}
	#lesson .lessonList {
		margin: 0;
		display: block;
	}
	#lesson .lessonList li {
		width: auto;
		min-height: inherit;
		padding: 0;
		margin-bottom: 3rem;
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		justify-content: space-between;
		background-color: transparent;
	}
	#lesson .lessonList li:last-child {
		margin-bottom: 0;
	}
	#lesson .lessonList .photo {
		width: 10rem;
		margin: 0 1rem 0 0;
	}
	#lesson .lessonList .textBox {
		flex: 1;
	}
	#lesson .lessonList li .pointTxt {
		width: 3.5rem;
		height: 3.5rem;
		top: -1rem;
		padding-bottom: 0;
		left: 0;
		font-size: 0.9rem;
	}
	#lesson .lessonList li .pointTxt .num {
		font-size: 1.3rem;
	}
	#lesson .lessonSec {
		margin-bottom: 8rem;
	}
	#lesson .scheduleList {
		margin-left: 0.8rem;
	}
	#lesson .scheduleList li .ttl {
		padding-right: 2rem;
		margin-inline: 0;
		font-size: 1.8rem;
		margin-bottom: -0.5rem;
	}
	#lesson .scheduleList li .ttl::before { 
		width: 2rem;
		height: 2rem;
		left: -2.7rem;
	}
	#lesson .scheduleList li .ttl:has(.bgSpan)::before {
		width: 1.2rem;
		height: 1.2rem;
		left: -2.3rem;
		top: 0.9rem;
	}
	#lesson .scheduleList li:has(.text) .ttl::after { 
		width: 1.5rem;
		height: 1.5rem;
	}
	#lesson .scheduleList li:has(.text) .text {
		margin-top: 1.2rem;
	}
	#main .comScrollBox li {
		width: 15rem;
		margin-right: 1.9rem;
	}
	#main .comScrollBox li {
		border-radius: 2rem;
		overflow: hidden;
	}
	#lesson .scheduleList li .ttl:has(.bgSpan) {
		margin-bottom: 1rem;
	}
	#lesson .scheduleList .comScrollBox {
		margin-left: 0;
	}
	#lesson .scheduleList > li::before { 
		bottom: -1.5rem;
	}
	#lesson .schedule {
		margin-bottom: 8rem;
	}
	#lesson .certification p {
		margin-bottom: 4rem;
	}
}

/*------------------------------------------------------------
about_class
------------------------------------------------------------*/
#about_class .mainVisual {
	min-height: 95rem;
	/* padding: 2rem 0; */
	position: relative;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	color: #fff;
}
#about_class .mainVisualPhoto {
	position: sticky;
    left: 0;
    top: 9rem;
    width: 100%;
    height: calc(100svh - 9rem);
    overflow: hidden;
}
#about_class .mainVisualPhoto img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: scale(1.2);
}
#about_class .mainVisualPhoto .bg {
    width: 100%;  
    height: 100%;
    background-color: rgba(0, 0, 0, 0.4);
    position: absolute;  
    top: 0;
    left: 0;
    opacity: 0;
}
#about_class .mainVisualPhoto .sub {
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background: url(img/about_class/main_img.jpg) no-repeat center;
	background-size: cover;
	-webkit-font-smoothing: antialiased;
	-webkit-transform: translateZ(0);
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	-webkit-transform-style: preserve-3d;
	-webkit-transform: translateZ(0);
	transform: translateZ(0);
	-webkit-overflow-scrolling: touch;
	will-change: transform;
}
#about_class .mainVisualPhoto .sub:after {
	width: 100%;  
	height: 100%;
	background-color: rgba(0, 0, 0, 0.4);
	position: absolute;  
	top: 0;
	left: 0;
	content: ""; 
	opacity: 0;
	transition: all 1s ease;
}
#about_class .mainVisual.active .sub::after {
	opacity: 1;
}
#about_class .mainVisual .content {
	padding: 5rem 4rem 10rem;
    width: 100%;
    position: relative;
    z-index: 1;
}
#about_class .mainVisual .content .textBox {
    opacity: 0;
}
#about_class .mainVisual.active .content {
	opacity: 1;
	visibility: visible;
}
#about_class .mainVisual p {
	/* font-size: 2rem; */
	margin-bottom: 3rem;
}
#about_class .mainVisual .list {
	margin-top: 14rem;
	display: flex;
	flex-wrap: wrap;
	/* gap: 0 16.4rem; */
	justify-content: center;
}
#about_class .mainVisual .list .comLink {
	width: 34.6rem;
	margin: 0;
}
#about_class .mainVisual .list .comLink a {
	min-height: 16.1rem;
	border-radius: 10rem;
	font-size: 2.51rem;
}
#about_class .introduction {
	padding: 16.5rem 0 26.5rem;
}
#about_class .introduction p {
	margin-bottom: 3.6rem;
}
#about_class p:last-child {
	margin-bottom: 0 !important; 
}
#about_class .introductionBox {
	margin-bottom: 9.8rem;
}
#about_class .introductionBox > ul {
	padding-bottom: 1px;
	display: flex;
	flex-wrap: wrap;
	gap: 0 5rem;
}
#about_class .introductionBox > ul > li {
	/* background-color: #fff; */
	margin-bottom: -1px;
	padding: 0.6rem 0 1rem;
	width: calc((100% - 5rem) / 2);
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	justify-content: space-between;
	border-top: 1px solid #8D8986;
	border-bottom: 1px solid #8D8986;
}
#about_class .introductionBox .photo {
	width: 15rem;
	margin-right: 2.3rem;
}
#about_class .introductionBox .textBox {
	flex: 1;
	padding-top: 3.3rem;
}
#about_class .introductionBox .textBox p {
	margin-bottom: 0;
	line-height: 1.6;
}
#about_class .introductionBox .textBox .ttl {
	font-weight: 700;
	line-height: 1.5;
	margin-bottom: -0.5rem;
}
#about_class .introductionBox .subUl {
	margin-top: 0.6rem;
}
#about_class .introductionBox .subUl li {
	line-height: 1.2;
	text-indent: -1em;
	padding-left: 1em;
}
#about_class .comScrollBox {
	margin-right: -100%;
	margin-top: 6.8rem;
}
#about_class .comScrollBox li {
	width: 55rem;
	margin-right: 5.5rem;
}
#about_class .comprehensive .headLine01 {
	margin-bottom: 2.1rem;
}
#about_class .comprehensive p {
	line-height: 1.25;
	margin-bottom: 4.1rem;
}
#about_class .comprehensiveList {
	margin-bottom: 8rem;
	display: flex;
	flex-wrap: wrap;
	gap: 4.3rem;
}
#about_class .comprehensiveList li {
	height: 100%;
	width: calc((100% - 4.3rem) / 2);
	background-color: #fff;
	padding: 2rem;
	border-radius: 2rem;
}
#about_class .comprehensiveList .photo {
	margin-bottom: 2rem;
}
#about_class .comprehensiveList .photo img {
	width: 100%;
}
#about_class .comprehensiveList .ttl {
	margin-bottom: 1.5rem;
	text-align: center;
	font-size: 1.8rem;
	font-weight: 700;
}
#about_class .comprehensiveList p {
	line-height: 1.25;
}
#about_class .comprehensive .comLink {
	width: 45.35rem;
}
#about_class .comprehensive {
	padding-bottom: 26.5rem;
}
#about_class .systemList {
	display: flex;
	flex-wrap: wrap;
	gap: 2rem 2.0rem;
}
#about_class .systemList li {
	width: calc((100% - 4.1rem) / 3);
	background-color: #fff;
	padding: 2rem;
	border-radius: 2rem;
}
#about_class .systemList .photo {
	margin: 0 auto 0.1rem;
	width: 20rem;
}
#about_class .systemList p {
	font-size: 1.6rem;
	line-height: 1.25;
}
#about_class .systemList .ttl {
	margin-bottom: 1.5rem;
	font-size: 1.8rem;
	font-weight: 700;
	line-height: 1.11;
	text-align: center;
}
#about_class .system .headLine01 {
	margin-bottom: 2.1rem;
}
#about_class .system .text {
	line-height: 1.25;
	margin-bottom: 4.1rem;
}
#about_class .system {
	padding-bottom: 20.5rem;
}
#about_class .access .headLine01 {
	margin-bottom: 4rem;
}
#about_class .access p {
	margin-bottom: 4rem;
	line-height: 1.25;
	text-align: center;
}
#about_class .access .map {
	height: 38.3rem;
}
#about_class .access .map iframe {
	width: 100%;
	height: 100%;
}
#about_class .comBox {
	padding: 8.8rem 0;
	background-color: #fff;
}
#main .comBox .textBox .ttl {
	position: relative;
	z-index: 1;
}
#main .comBox .textBox .ttl:after {
	width: 42rem;  
	height: 18.1rem;
	background: url(img/common/en.png) no-repeat;
	background-size: 100% auto;
	position: absolute;  
	top: -3rem;
	left: 0;
	z-index: -1;
	content: ""; 
}

@media all and (min-width: 897px) {
	#about_class #sideBar {
		position: sticky;
		top: 0;
		left: 0;
		margin-top: 16rem;
		top: 14rem;
		width: 30rem;
		margin-right: 5.5rem;
	}
	#about_class #conts {
		flex: inherit;
		width: calc(100% - 43.5rem);
	}
	body:has(#about_class) #gFooter {
		margin-top: 0;
	}
}

@media all and (max-width: 896px) {
	#about_class .mainVisual {
		/* padding: 4rem 2rem; */
		min-height: inherit;
		/* background-image: url(img/about_class/main_img_sp.jpg); */
	}
	#about_class .mainVisualPhoto {
        top: 6.6rem;
    }
    #about_class .mainVisual .content {
        padding: 4rem 2rem;
    }
	#about_class .mainVisual p {
		font-size: 1.5rem;
		margin-bottom: 2rem;
	}
	#about_class .mainVisual .list {
		margin-top: 4rem;
		display: block;
	}
	#about_class .mainVisual .list li {
		margin-bottom: 2rem;
	}
	#about_class .mainVisual .list li:last-child {
		margin-bottom: 0;
	}
	#about_class .mainVisual .list .comLink {
		max-width: 25rem;
		margin: 0 auto;
	}
	#about_class .mainVisual .list .comLink a {
		font-size: 1.5rem !important;
		min-height: 10rem !important;
	}
	#about_class .introduction {
		padding: 8rem 0 10rem;
	}
	#about_class .content {
		display: block;
	}
	#about_class .comScrollBox {
		margin-inline: -2rem;
	}
	#about_class .introductionBox {
		margin-bottom: 4rem;
		position: relative;
	}
	#about_class .introductionBox > ul {
		display: flex;
		flex-wrap: nowrap;
		gap: 0;
	}
	#about_class .introductionBox > ul > li {
		background-color: transparent;
		margin: 0;
		width: 100%;
		border: none;
	}
	#about_class .introductionBox .photo {
		background-color: #FEEFFF;
		height: 13rem;
		width: 13rem;
		display: flex;
		align-items: center;
		justify-content: center;
		border-radius: 100%;
		padding: 1rem;
		margin-right: 1rem;
	}
	#about_class .introductionBox .textBox {
		/* margin-right: -1rem; */
		padding-top: 2rem;
	}
	#about_class .introductionBox .iconBox {
		width: 11.5rem;
		margin: 1rem 5rem 0 auto;
		position: relative;
		z-index: 1;
	}
	/* #about_class .introductionBox .subUl {
		font-size: 1.2rem;
	} */
	#about_class .introductionBox .textBox p {
		/* font-size: 1.2rem; */
		line-height: 1.2;
	}
	#about_class .introductionBox .textBox .ttl {
		margin-bottom: 0;
	}
	#about_class .iconBox {
		gap: 0 5rem;
		display: flex;
		align-items: center;
	}
	#about_class .iconBox > div {
		width: 3.2rem;
		cursor: pointer;
	}
	#about_class .comScrollBox li {
		width: 21rem;
		margin-right: 2.1rem;
	}
	#main .comScrollBox li img {
		border-radius: 2.25rem;
	}
	#about_class .comprehensiveBox .swiper-scrollbar {
		width: 20rem;
		left: 13rem;
		bottom: 1.3rem;
		background-color: #FEEFFF;
	}
	#about_class .comprehensiveBox .swiper-scrollbar-drag {
		background-color: #D8A9DC;
		border-radius: 0;
	}
	#about_class .comprehensiveBox {
		margin-right: -2rem;
		margin-bottom: 5rem;
	}
	#about_class .comprehensiveList .photo {
		border-radius: 2rem 0 0 2rem;
		overflow: hidden;
	}
	#about_class .comprehensiveList {
		margin-bottom: 2rem;
		margin-right: -2rem;
		display: flex;
		flex-wrap: nowrap;
		gap: 0;
	}
	#about_class .comprehensiveList li {
		width: 100%;
	}
	#about_class .comprehensive {
		padding-bottom: 10rem;
	}
	#about_class .system .headLine01 {
		margin-bottom: 3rem;
	}
	#about_class .system .text {
		margin-bottom: 4.1rem;
	}
	#about_class .systemList {
		display: block;
	}
	#about_class .systemList li {
		padding-inline: 1rem;
		margin-bottom: 2rem;
		width: auto;
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	#about_class .systemList li:last-child {
		margin-bottom: 0;
	}
	#about_class .systemList .photo {
		width: 10rem;
		height: 10rem;
		display: flex;
		align-items: center;
		justify-content: center;
		border-radius: 100%;
		margin: 0 1rem 0 0;
		padding: 1rem;
		background-color: #FEEFFF;
	}
	#about_class .systemList .textBox {
		flex: 1;
	}
	#about_class .systemList p {
		font-size: 1.4rem;
	}
	#about_class .systemList .ttl {
		text-align: left;
		margin-bottom: 1rem;
		font-size: 1.6rem;
	}
	#about_class .system {
		padding-bottom: 10rem;
	}
	#about_class .access .headLine01 {
		margin-bottom: 2rem;
	}
	#about_class .access .map {
		margin-inline: -2rem;
		height: 80vw;
	}
	#about_class .comBox {
		padding: 0;
		background-color: transparent;
	}
	#about_class .comBox .textBox .ttl::after { 
		width: 15rem;
		top: -6rem;
		left: 50%;
		transform: translateX(-50%);
		display: block;
		height: 10rem;
	}
}

/*------------------------------------------------------------
	index
------------------------------------------------------------*/
#main .mainImg {
	padding: 2rem 0;
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	justify-content: flex-end;
	position: relative;
}
#main .mainImg .rBox {
	order: 2;
	position: relative;
	margin: 0 -0.8rem 0 13.5rem;
	width: calc(50% + 38.7rem);
}
#main .mainImg .fooList {
	overflow: hidden;
	border-radius: 4.5rem 0 0 4.5rem;
}
#main .mainImg .fooList li {
	/* aspect-ratio: 2697 / 1620; */
	height: 80.9rem;
	position: relative;
}
#main .mainImg .fooList li img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transform: scale(1.1);
}
#main .mainImg .fooList .swiper-slide.swiper-slide-prev img,
#main .mainImg .fooList .swiper-slide.swiper-slide-active img {
	transform: scale(1);
	transition: transform 1.4s cubic-bezier(0,.55,.45,1);
}
#main .mainImg .swiper-pagination {
	padding-left: 3.8rem;
	padding-bottom: 0.3rem;
	text-align: left;
}
#main .mainImg .swiper-pagination span {
	margin: 0 0.2rem;
	background: transparent;
	border: 1px solid #fff;
	width: 1.0rem;
	height: 1.0rem;
	opacity: 1;
}
#main .mainImg .swiper-pagination span.swiper-pagination-bullet-active {
	background: #fff;
}
#main .mainImg .lBox {
	padding: 1.4rem 0 0 2rem;
}
#main .mainImg .lBox .sub {
	max-width: 50rem;
	width: 100%;
}
#main .mainImg .lBox h2 img {
	width: 8.7rem;
}
#main .mainImg .list {
	display: flex;
	align-items: center;
	position: absolute;
	top: -1rem;
	right: 15.8rem;
	z-index: 1;
}
#main .mainImg .list li {
	width: 16rem;
	margin: 0 -1rem;
}
#main .mainImg .scroll {
	position: absolute;
	bottom: min(9.9vw,19rem);
	left: min(7.1vw,13.5rem);
}
#main .mainImg .scroll a {
	display: inline-block;
	font-size: 1.6rem;
	color: #B48CDC;
	-webkit-writing-mode : tb-rl;
	-webkit-writing-mode: vertical-rl;
	writing-mode: tb-rl;
	writing-mode: vertical-rl;
	width: 2.3rem;
	padding-bottom: 12rem;
	background: url(img/index/arrow.png) no-repeat left 0.5rem bottom;
	background-size: 1.6rem auto;
}
#main .mainImg .scroll a:hover {
	opacity: 0.7;
}
#main .aboutSec {
	padding: 25rem 0 16.5rem;
}
#index .content {
	max-width: 167.8rem;
	max-width: 171.8rem;
}
#main .aboutSec .lBox {
	margin-right: min(10.5vw,20rem);
	width: min(32.3vw,61.9rem);
}
#main .aboutSec .rBox {
	padding-top: 0.4rem;
	flex: 1;
}
#main .aboutSec .rBox p {
	margin-bottom: 2.4rem;
}
#main .aboutSec .rBox .comLinkUl {
	margin-top: 5rem;
}
#main .comLinkUl {
	margin: 0 -1rem;
	display: flex;
	flex-wrap: wrap;
	/* gap: 0 7rem; */
	justify-content: center;
}
#main .comLinkUl .comLink {
	width: 37.5rem; 
}
#main .comLinkUl .comLink a {
	min-height: 10rem;
	font-size: 2.75rem;
}
#main .strength {
	margin-bottom: 16.5rem;
}
#main .strength .headLine02 {
	margin: 0 auto 7.6rem;
	width: fit-content;
}
#main .strength .headLine02 .txtSpan{
	width: 54.6rem;
}
#main .strengthList {
	margin: -2.5rem 0 8.1rem;
	display: flex;
	flex-wrap: wrap;
	gap: 2rem 1.6rem;
}
#main .strengthList li {
	width: calc((100% - (1.6rem * 3 + 0.1rem)) / 4);
}
#main .strengthList .photo {
	width: 28rem;
	margin: 0 auto 1.9rem;
}
#main .strengthList p {
	line-height: 1.7;
}
#main .strengthList .ttl {
	margin-bottom: 1.2rem;
	font-size: 2rem;
	line-height: 1.75;
	text-align: center;
}
#main .strength .btmTxt {
	margin: -4rem 0 8rem;
}
#index .bigPhoto {
	height: 104.7rem;
	position: relative;
}
#index .bigPhoto .inner {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
    clip: rect(0, auto, auto, 0);
	-webkit-clip: rect(0, auto, auto, 0);
}
#index .bigPhoto .fixBox {
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	-webkit-font-smoothing: antialiased;
	-webkit-transform: translateZ(0);
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	-webkit-transform-style: preserve-3d;
	-webkit-transform: translateZ(0);
	transform: translateZ(0);
	-webkit-overflow-scrolling: touch;
	will-change: transform;
}
#index .bigPhoto img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center 9rem;
}
#index .bigPhoto img {
	transform: scale(1.1);
}
#index .bigPhoto.active img {
	transform: scale(1);
	transition: all 2s;
}
#index .lessonSec {
	padding: 13.5rem 0;
}
#index .lessonSec .headLine02 {
	text-align: center;
	width: fit-content;
	margin: 0 auto 10.5rem;
}
#index .lessonSec .headLine02 .txtSpan {
	width: 36.2rem;
	left: -2rem;
}
#main .lessonUl {
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 4.5rem;
	gap: 0 11.7rem;
}
#main .lessonUl li {
	padding: 3.5rem 2rem 2.7rem 8rem;
	width: calc((100% - 11.7rem) / 2);
	margin-bottom: -1px;
	border-top: 1px solid #8D8986;
	border-bottom: 1px solid #8D8986;
}
#main .lessonUl p {
	margin-bottom: 0.6rem;
}
#main .lessonUl p:last-child {
	margin-bottom: 0;
}
#main .lessonUl li .ttl {
	font-size: 2rem;
	margin-bottom: 0.8rem;
	font-weight: 700;
	letter-spacing: 0;
}
#main .lessonUl li .txt {
	display: flex;
	align-items: center;
	font-size: 2.8rem;
	font-weight: 700;
	letter-spacing: 0.025em;
}
#main .lessonUl li .txt + .txt {
	margin-top: -1rem;
}
#main .lessonUl li .txt .txtSpan {
	flex-shrink: 0;
	padding: 0.3rem 0.2rem;
	margin-right: 1rem;
	width: 6.7rem;
	border-radius: 1.2rem;
	text-align: center;
	font-size: 1.6rem;
	font-weight: 500;
	letter-spacing: 0.05em;
	color: #fff;
	background-color: #D8A9DC;
}
#index .lessonSec .textList {
	margin-bottom: 5.5rem;
	line-height: 1.6;
}
#index .lessonSec .textList li {
	text-indent: -1em;
	padding-left: 1em;
}
#main .voice .headLine02 {
	width: fit-content;
	margin: 0 auto 5rem;
}
#main .voice .headLine02 .txtSpan {
	width: 24rem;
	left: 50%;
	transform: translateX(-50%);
}
#main .voice {
	padding-bottom: 7.6rem;
}
#main .voiceList {
	position: relative;
	z-index: 1;
	margin-bottom: 5rem;
	padding-top: 1.6rem;
	display: flex;
	flex-wrap: wrap;
	gap: 10rem min(9vw,17.2rem);
}
#main .voiceList li {
	width: calc((100% - (min(9vw,17.2rem) * 2 + 0.1rem)) / 3);
}
#main .voiceList li .textBox {
	padding: 5.5rem 4rem 5rem 3rem;
	position: relative;
	min-height: 48.2rem;
	background: url(img/index/bg01.png) no-repeat center bottom;
	background-size: 100% 100%;
}
#main .voiceList li .textBox p {
	margin-bottom: 8rem;
	line-height: 1.2;
}
#main .voiceList li .textBox p .txtSpan {
	display: block;
	margin-top: 1rem;
}
#main .voiceList li .photo {
	width: min(13.1vw,25rem);
	margin: -6rem 0 0 3rem;
}
#index .scrollBox {
	padding-bottom: 32rem;
	padding-top: 32rem;
	position: relative;
	background-color: #fff;
}
#index .scrollBox .photo {
	width: 24.2rem;
	position: absolute;
	top: 8rem;
	right: 0;
	margin: 0 15.7rem 0rem auto;
}
#index .scrollBox ul {
	display: flex;
}
#index .scrollBox li {
	width: 55rem;
	border-radius: 4.5rem;
	overflow: hidden;
	position: relative;
	aspect-ratio: 550 / 450;
	margin-right: 5.4rem;
	flex-shrink: 0;
}
#index .scrollBox li img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#index .comBox {
	padding-bottom: 0;
	margin: 13rem 0;
}
#index .accessSec {
	text-align: center;
}
#index .accessSec .headLine02 {
	width: fit-content;
	margin: 0 auto 8.5rem;
}
#index .accessSec .map {
	height: 44.4rem;
}
#index .accessSec .map iframe {
	width: 100%;
	height: 100%;
}
#index .accessSec .headLine02 .txtSpan {
	left: 50%;
	transform: translateX(-50%);
	width: 34.5rem;
	top: -3.7rem;
}
#index .accessSec p {
	margin-bottom: 3rem;
	line-height: 1.2;
}
@media all and (min-width: 897px) {
	#main .aboutSec .rBox .comLinkUl {
		margin-inline: -3rem;
	}
}

@media all and (min-width: 897px) and (max-width: 1600px) {
	#index .aboutSec .content {
		max-width: 144rem;
	}
}

@media all and (max-width: 896px) {
	#main .mainImg {
		padding: 2rem 0 0;
		display: block;
	}
	#main .mainImg .rBox {
		margin: 0;
		width: auto;
		margin: 0 -2rem 0 4rem;
	}
	#main .mainImg .fooList {
		border-radius: 4rem 0 0 0;
	}
	#main .mainImg .fooList li {
		height: auto;
		aspect-ratio: 699 / 800;
	}
	#main .mainImg .list {
		justify-content: center;
		position: static;
		margin: 4rem 4.0rem 0 -1.3rem;
	}
	#main .mainImg .list li {
		margin: 0;
		width: 16.9rem;
	}
	#main .mainImg .list li img {
		width: 100%;
	}
	#main .mainImg .lBox {
		padding: 2rem 0 0;
	}
	#main .mainImg .lBox .sub {
		max-width: inherit;
	}
	#main .mainImg h2 {
		text-align: center;
		font-size: 1.75rem;
		line-height: 1.28;
		font-weight: 400;
	}
	#main .mainImg .scroll a {
		font-size: 1.2rem;
		padding-bottom: 6rem;
		width: 1.3rem;
		background-position: left 0.3rem bottom;
		background-size: auto 5.5rem;
	}
	#main .mainImg .spBox {
		position: relative;
	}
	#main .mainImg .scroll {
		left: -2rem;
		bottom: -0.5rem;
	}
	#main .mainImg .swiper-pagination {
		padding: 0;
		margin: 0;
		bottom: auto;
		left: -2rem;
		top: 28%;
		width: auto;
	}
	#main .mainImg .swiper-pagination span {
		display: block;
		border-color: #D8A9DC;
		width: 0.8rem;
		height: 0.8rem;
		margin-bottom: 0.3rem;
	}
	#main .mainImg .swiper-pagination span.swiper-pagination-bullet-active {
		background-color: #D8A9DC;
	}
	#main .aboutSec {
		padding: 3.6rem 0 10rem;
	}
	#main .aboutSec .content {
		display: block;
	}
	#main .aboutSec .lBox {
		margin: 0 2rem 2rem;
		width: auto;
	}
	#main .aboutSec .lBox img {
		width: 100%;
	}
	#main .aboutSec .rBox {
		padding-top: 2rem;
	}
	#main .aboutSec .rBox .comLinkUl {
		margin-top: 5rem;
	}
	#main .comLinkUl .comLink {
		width: 16rem;
	}
	#main .comLinkUl {
		gap: 0 2rem;
	}
	#main .strength {
		margin-bottom: 7rem;
	}
	#main .strength .headLine02 {
		margin-bottom: 6rem;
	}
	#main .strength .headLine02 .txtSpan {
		top: -1rem;
	}
	#main .strength .headLine02 .txtSpan img {
		height: 8rem;
	}
	#main .strengthList {
		margin: 0 0 6rem;
		display: block;
	}
	#main .strength .btmTxt {
		margin-bottom: 5rem;
	}
	#main .strengthList li {
		width: auto;
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		justify-content: space-between;
		margin-bottom: 2rem;
	}
	#main .strengthList li:last-child {
		margin-bottom: 0;
	}
	#main .strengthList .photo {
		width: 11rem;
		height: 11rem;
		border-radius: 100%;
		padding: 1.5rem;
		margin-bottom: 0;
		margin-right: 1rem;
		background-color: #FEEFFF;
	}
	#main .strengthList .textBox {
		flex: 1;
	}
	#main .strengthList .ttl {
		text-align: left;
		font-size: 2rem;
		line-height: 1.5;
		margin-bottom: 0.5rem;
	}
	#main .strengthList .ttl:last-child {
		margin-bottom: 0;
	}
	#main .strengthList p {
		font-size: 1.3rem;
	}
	#index .bigPhoto {
		height: 138.5vw;
	}
	#index .bigPhoto img {
		object-position: center 6.5rem;
	}
	#index .lessonSec {
		padding: 8rem 0 10rem;
	}
	#index .lessonSec .headLine02 {
		margin-bottom: 4rem;
	}
	#main .lessonUl {
		margin-bottom: 3rem;
		display: block;
	}
	#main .lessonUl li {
		width: auto;
		padding: 3rem 1rem;
	}
	#main .lessonUl li .ttl {
		font-size: 1.5rem;
	}
	/* #index .lessonSec .textList {
		font-size: 1.2rem;
	} */
	#index .lessonSec .textList {
		margin-bottom: 3rem;
	}
	#main .lessonUl li .txt {
		font-size: 2rem;
	}
	#main .lessonUl li .txt + .txt {
		margin-top: 0;
	}
	#index .lessonSec .comLinkUl .comLink {
		width: 20rem;
	}
	#index .lessonSec .headLine02 .txtSpan {
		left: 50%;
		transform: translateX(-50%);
	}
	#main .voice {
		padding-bottom: 5rem;
	}
	#main .voiceList {
		margin-bottom: 0;
		gap: 0;
		flex-wrap: nowrap;
	}
	#main .voiceList li {
		width: auto;
	}
	#main .voiceList li .textBox {
		min-height: 22rem;
		padding: 2rem 2rem 5rem;
		background-image: url(img/index/bg01_sp.png);
	}
	#main .voiceList li .textBox p {
		font-size: 1.3rem;
		margin-bottom: 2rem;
	}
	#main .voiceList li .photo {
		width: 13rem;
		margin: -3rem 0 0 5rem;
	}
	#main .voiceJsBox {
		max-width: 35rem;
		margin: 0 auto 5rem;
		position: relative;
	}
	#main .voiceJsBox .iconBox {
		position: absolute;
		bottom: 1rem;
		right: 3.5rem;
		z-index: 1;
		gap: 0 4rem;
		display: flex;
		align-items: center;
	}
	#index .voiceJsBox .iconBox > div {
		width: 3.2rem;
		cursor: pointer;
	}
	#main .voice .headLine02 .txtSpan {
		text-align: center;
	}
	#main .voice .headLine02 .txtSpan img {
		height: 8.5rem;
	}
	#main .voice .headLine02 {
		margin-bottom: 3rem;
	}
	#main .voice .comLink {
		width: 20rem;
	}
	#index .scrollBox .photo {
		width: 12.2rem;
		position: static;
		margin: 0 2rem -2rem auto;
	}
	#index .scrollBox {
		padding: 4rem 0 10rem;
	}
	#index .scrollBox li {
		width: 20rem;
		margin-right: 1.25rem;
		border-radius: 2.25rem;
	}
	#index .comBox {
		margin: 0;
		padding: 1rem 2rem 5rem;
		background-color: #fff;
	}
	#main .comBox .textBox .ttl::after {
		width: 21rem;
		height: 9rem;
		left: 50%;
		top: 1rem;
		transform: translateX(-50%);
	}
	#index .accessSec {
		background-color: #fff;
	}
	#index .accessSec .headLine02 .txtSpan img {
		height: 9.5rem;
	}
	#index .accessSec .headLine02 .txtSpan {
		width: 18rem !important;
		top: -2rem;
	}
	#index .accessSec {
		padding: 0 2rem 5rem;
	}
	#index .accessSec .headLine02 {
		margin-bottom: 4rem;
	}
	#index .accessSec p {
		margin-bottom: 2rem;
	}
	#index .accessSec .map {
		margin: 0 -2rem;
		height: 60vw;
	}
	body:has(#index) #gFooter {
		margin-top: 0;
	}
	
}


.fadeInUp {
    opacity: 0;
	transform: translate(0,50px);
    transition: all ease-in-out 0.8s;
}

.fadeInUp.on {
    opacity: 1;
	transform: translate(0, 0);
}

@media all and (min-width: 897px) and (max-width: 1850px) {
	/* #gHeader .hInner {
		padding: 0 min(5vw,14.8rem);
	} */
	#gNavi {
		margin-right: min(2vw,12rem);
		/* gap: 0 min(1.4vw,3.9rem); */
	}
	#gNavi a {
		padding-inline: min(1vw,1.4rem);
	}
	#main .mainImg .scroll {
		left: min(4vw,13.5rem);
	}
}

@media all and (min-width: 897px) and (max-width: 1600px) {
	#gHeader .hInner {
		padding: 0 5rem;
		margin: 0 auto;
		max-width: 144rem;
	}
	.content {
		padding: 0 5rem;
	}
	#gHeader h1 {
		margin-left: max(-0.7vw,-1.5rem);
	}
	#main .aboutSec .lBox {
		margin-right: min(8.5vw,20rem);
	}
	#gNavi a {
		margin-top: min(0.4vw,1.2rem);
		padding-inline: min(1vw,0.8rem);
	}
	.hInner .tel {
		margin-top: 0.5rem;
		white-space: nowrap;
		font-size: min(0.5vw,1.4rem);
	}
	.hInner .tel a {
		font-size: min(1.4vw,2.4rem);
	}
	#gHeader .rBox {
		gap: 0 2rem;
	}
	#gHeader h1 img {
		margin-top: 0;
	}
	/* #main .comBox .textBox {
		padding-left: 4.5rem;
	} */
}

.error {
	color: #FF0000;
}
.wpcf7-list-item:first-child {
	margin-left: 0;
}

@media all and (min-width: 1300px) and (max-width: 1650px) {
	#gHeader .hInner {
		padding: 0 7.5rem;
	}
	.content {
		padding: 0 7.5rem;
	}
	#main .comBox .textBox {
		padding-left: 7.5rem;
	}
	#about_class .mainVisual .content {
		padding-inline: 7.5rem;
	}
}