body {
	color: #444;
	font-family: "Noto Serif JP", serif;
	font-weight: 500;
}

.u-desktop {
	display: block;
}

.u-mobile {
	display: none;
}

/* リキッドレイアウト */

html {
	font-size: 16px;
}

*,
*::before,
*::after {
	box-sizing: border-box;
}

/* Remove default padding */

ul,
ol {
	padding: 0;
}

/* Remove default margin */

body,
h1,
h2,
h3,
h4,
p,
ul,
ol,
figure,
blockquote,
dl,
dd {
	margin: 0;
}

/* Set core root defaults */

html {
	scroll-behavior: smooth;
}

/* Set core body defaults */

body {
	line-height: 1.5;
	min-height: 100vh;
	text-rendering: optimizeLegibility;
}

/* Remove list styles on ul, ol elements with a class attribute */

ul,
ol {
	list-style: none;
}

/* A elements that don't have a class get default styles */

a:not([class]) {
	-webkit-text-decoration-skip: ink;
	text-decoration-skip-ink: auto;
}

/* Make images easier to work with */

img {
	display: block;
	max-width: 100%;
	width: 100%;
}

/* Natural flow and rhythm in articles by default */

article > * + * {
	margin-top: 1em;
}

/* Inherit fonts for inputs and buttons */

input,
button,
textarea,
select {
	font: inherit;
}

/* Blur images when they have no alt attribute */

img:not([alt]) {
	filter: blur(10px);
}

/* フォ`ムリセット */

input,
button,
select,
textarea {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background: transparent;
	border: none;
	border-radius: 0;
	font: inherit;
	outline: none;
}

textarea {
	resize: vertical;
}

input[type=checkbox],
input[type=radio] {
	display: none;
}

input[type=submit],
input[type=button],
label,
button,
select {
	cursor: pointer;
}

select::-ms-expand {
	display: none;
}

/* ホバ` */

a {
	-webkit-text-decoration: none;
	color: inherit;
	text-decoration: none;
	transition: opacity 0.3s;
}

.about {
	padding: 8.75rem 0 8.125rem;
	position: relative;
}

.about .inner {
	position: relative;
}

.about__wrapper {
	margin: 0 auto;
	width: 90%;
}

.about__title img {
	margin: 0 auto;
	padding-left: 2%;
	width: 22.5rem;
}

.about__head {
	font-size: 2.375rem;
	font-weight: 700;
	letter-spacing: 3px;
	margin-top: 4.375rem;
	text-align: center;
}

.about__items {
	grid-gap: 0 9%;
	display: grid;
	gap: 0 9%;
	grid-template-columns: 41% 50%;
	margin: 3.4375rem auto 0;
}

.about__text {
	font-size: 1.375rem;
	line-height: 1.81818;
}

.access {
	padding: 5.4375rem 0 1.5625rem;
	position: relative;
}

.access::after {
	background: transparent url(../images/deco-l.png) no-repeat top left/contain;
	bottom: -2%;
	content: "";
	height: 19vw;
	left: 3.5%;
	position: absolute;
	width: 18vw;
}

.access .inner {
	position: relative;
}

.access__wrapper {
	margin: 0 auto;
	padding-right: 2%;
	width: 69%;
}

.access__items-t {
	grid-gap: 0 2%;
	align-items: center;
	display: grid;
	gap: 0 2%;
	grid-template-columns: 26% 72%;
	margin: 5.375rem auto 0;
}

.access__item1 {
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.875;
}

.access__item2 {
	font-size: 1rem;
	line-height: 1.75;
}

.access__items-b {
	grid-gap: 1.5625rem 0;
	display: grid;
	gap: 1.5625rem 0;
	grid-template-columns: 1fr;
	margin: 1.5625rem auto 0;
}

.access__item3 {
	font-size: 0.9375rem;
	line-height: 1.86666;
}

.access__item4 {
	aspect-ratio: 960/352;
	height: auto;
	width: 100%;
}

.access__item4 iframe {
	-o-object-fit: cover;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.access__bottom {
	margin: 2rem auto 0;
}

.access__bottom a {
	align-items: center;
	background-color: #004690;
	border-radius: 2.3125rem;
	display: flex;
	justify-content: center;
	margin: 0 auto;
	padding: 1.5% 0 2%;
	transition: all 0.3s;
	width: 17.375rem;
}

.access__bottom a:hover {
	opacity: 0.7;
}

.access__bottom a img {
	width: 62%;
}

.point2__attempt {
	padding: 10rem 0 0;
	position: relative;
}

.point2__attempt::before {
	background: transparent url(../images/deco-r.png) no-repeat top right/contain;
	bottom: -32%;
	content: "";
	height: 19vw;
	position: absolute;
	right: 3%;
	width: 18vw;
}

.attempt .swiper-container {
	margin: 4.375rem auto 0;
	padding: 4.6875rem 0 5.3125rem;
	position: relative; /* ペ`ジネ`ション喘*/
}

.attempt .swiper-container::before {
	border: 8px solid #ED9458;
	content: "";
	height: 100%;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 57%;
}

.attempt .swiper {
	background: #fff;
	overflow: visible;
}

.attempt .swiper-slide {
	height: 100%;
	width: 416px;
}

.attempt__img {
	aspect-ratio: 416/232;
	height: auto;
	width: 100%;
}

.attempt__img img {
	-o-object-fit: cover !important;
	height: 100% !important;
	object-fit: cover !important;
}

.attempt__img img {
	width: 100%;
}

.attempt__text {
	font-family: "Noto Sans JP", serif;
	font-size: 1.125rem;
	line-height: 1.55555;
	padding: 0.8125rem 0 1.75rem;
	text-align: center;
}

/* ペ`ジネ`ションの了崔 */

.attempt .swiper-pagination-horizontal {
	bottom: 3.375rem;
}

/* ペ`ジネ`ションの噫易 */

.attempt .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
	margin: 0 0.625rem !important;
}

/* ペ`ジネ`ションのサイズと弼 */

.attempt .swiper-pagination-bullet.swiper-pagination-bullet-active {
	background-color: #ED9458;
	height: 1.25rem;
	width: 1.25rem;
}

.attempt .swiper-pagination-bullet {
	background: #FADFCD;
	border-radius: 0.625rem;
	height: 1.25rem;
	opacity: 1;
	width: 1.25rem;
}

.attempt .swiper-area {
	position: relative;
}

/* 念への文咫カスタマイズ */

.attempt .swiper-button-prev::after {
	background-image: url(/extra/hyougen/assets/images/attempt-arrow.png);
}

/* 肝への文咫カスタマイズ */

.attempt .swiper-button-next::after {
	background-image: url(/extra/hyougen/assets/images/attempt-arrow.png);
	transform: rotate(180deg) translateY(28px);
}

/* 念へ肝への文咫カスタマイズ */

.attempt .swiper-button-prev,
.attempt .swiper-button-next {
	display: block;
	height: 2.5vw;
	top: 41%;
	width: 1.5vw;
}

.attempt .swiper-button-prev {
	left: 50%;
	transform: translateX(-256px);
}

.attempt .swiper-button-next {
	left: 50%;
	transform: translateX(230px);
}

/* 念へ肝への文咫カスタマイズ */

.attempt .swiper-button-prev::after,
.attempt .swiper-button-next::after {
	background-repeat: no-repeat;
	background-size: contain;
	color: #fff;
	content: "";
	display: block;
	height: max(2.5vw, 70px);
	margin: auto;
	width: max(1.5vw, 30px);
}

.wrapper {
	overflow: hidden;
}

.back-to-top {
	bottom: 80px; /* 兜豚: スマホ喘 */
	cursor: pointer;
	height: 50px;
	opacity: 0; /* 兜豚は邑苧 */
	position: fixed;
	right: 20px;
	transform: translateY(20px); /* 和からスライドイン */
	transition: opacity 0.5s ease, transform 0.5s ease, visibility 0.5s; /* なめらかな篁 */
	visibility: hidden; /* 兜豚は掲燕幣 */
	width: 50px;
	z-index: 1000;
}

.back-to-top.show {
	opacity: 1; /* 燕幣彜B */
	transform: translateY(0); /* 圷の了崔に */
	visibility: visible; /* 燕幣彜B */
}

.back-to-top.hidden {
	opacity: 0; /* 壅び邑苧に */
	transform: translateY(20px); /* 圷の了崔から和にる */
	visibility: hidden; /* 掲燕幣彜B */
}

.back-to-top img {
	-o-object-fit: contain;
	height: 100%;
	object-fit: contain;
	width: 100%;
}

.communication {
	background: transparent url(../images/communication-bg.png) no-repeat top center/cover;
	padding: 8.125rem 0 17.5rem;
	position: relative;
}

.communication::before {
	background: transparent url(../images/deco-r.png) no-repeat top right/contain;
	content: "";
	height: 19vw;
	position: absolute;
	right: 3%;
	top: -14%;
	width: 18vw;
}

.communication::after {
	background: transparent url(../images/deco-l.png) no-repeat top left/contain;
	bottom: 1%;
	content: "";
	height: 19vw;
	left: 3.5%;
	position: absolute;
	width: 18vw;
}

.communication .inner {
	position: relative;
}

.communication__wrapper {
	margin: 0 auto;
	width: 90%;
}

.communication__items {
	grid-gap: 0 2%;
	display: grid;
	gap: 0 2%;
	grid-template-columns: repeat(4, 1fr);
	margin: 6.25rem auto 0;
}

.communication__img {
	border-radius: 50%;
	box-shadow: 0 0 30px rgba(255, 148, 88, 0.3);
}

.communication__text {
	color: #003E5F;
	font-size: 2.5rem;
	font-weight: 700;
	line-height: 1.15384;
	margin-top: 1.875rem;
	text-align: center;
}

.communication__text span {
	display: block;
}

.communication__text span::first-letter {
	display: block;
	font-size: 3.25rem;
}

.communication__text .communication__text-color::first-letter {
	color: #ED9458;
	display: block;
}

.course {
	padding: 10.9375rem 0 0;
	position: relative;
}

.course::before {
	background: transparent url(../images/deco-r.png) no-repeat top right/contain;
	bottom: 24%;
	content: "";
	height: 19vw;
	position: absolute;
	right: 3%;
	width: 18vw;
	z-index: -1;
}

.course::after {
	background: transparent url(../images/deco-l.png) no-repeat top left/contain;
	content: "";
	height: 19vw;
	left: 3.5%;
	position: absolute;
	top: 27%;
	width: 18vw;
	z-index: -2;
}

.course__items {
	margin: 3.125rem auto 0;
	width: 90%;
}

.course__item + .course__item {
	margin-top: 5rem;
}

.course__item:nth-of-type(odd) {
	grid-gap: 0 5%;
	display: grid;
	gap: 0 5%;
	grid-template-columns: 48% 51%;
	grid-template-rows: 22%;
	padding: 5% 0 4% 5%;
}

.course__item:nth-of-type(even) {
	grid-gap: 0 0%;
	display: grid;
	gap: 0 0%;
	grid-template-columns: 51% 49%;
	grid-template-rows: 22%;
	padding: 4% 5% 4% 0;
}

.course__item:nth-of-type(even) .course__img {
	grid-area: 1/1/3/2;
}

.course__item:nth-of-type(odd) .course__img {
	grid-area: 1/2/3/3;
}

.course__item:nth-of-type(even) .course__head {
	grid-area: 1/2/2/3;
}

.course__item:nth-of-type(odd) .course__head {
	grid-area: 1/1/2/2;
}

.course__item {
	background: url(/extra/hyougen/assets/images/course-bg.png) no-repeat center;
	background-size: 100% auto; /* 嘘尚鮫颪魴80%で燕幣 */
	border-radius: 3.75rem;
	position: relative;
}

.course__item:first-of-type {
	background: url(/extra/hyougen/assets/images/course-bg.png) no-repeat center, #FAE3D7;
}

.course__item:nth-of-type(2) {
	background: url(/extra/hyougen/assets/images/course-bg.png) no-repeat center, #E8F9FD;
}

.course__item:last-of-type {
	background: url(/extra/hyougen/assets/images/course-bg.png) no-repeat center, #FDFCD0;
}

.course__item:nth-of-type(odd) .course__img img {
	margin-left: -2%;
}

.course__item:nth-of-type(even) .course__img img {
	margin-left: -6%;
}

.course__head {
	align-self: flex-start;
	position: relative;
}

.course__head span {
	background: #fff;
	border-radius: 2.5rem;
	color: #003E5F;
	display: inline-block;
	font-family: "Noto Sans JP", serif;
	font-size: 2.5rem;
	font-weight: 600;
	letter-spacing: 1px;
	line-height: 1;
	margin-top: 2%;
	padding: 3% 5%;
}

.course__item:nth-of-type(even) .course__detail {
	grid-area: 2/2/3/3;
}

.course__item:nth-of-type(odd) .course__detail {
	grid-area: 2/1/3/2;
}

.course__text {
	font-size: 1.125rem;
	letter-spacing: 0.5px;
	line-height: 1.77777;
	margin-top: 2.1875rem;
}

.course__text p:nth-of-type(2) {
	margin-top: 1.875rem;
}

.cta {
	background: transparent url(../images/common-bg.png) no-repeat top center/cover;
	padding: 9.375rem 0;
	position: relative;
}

.cta::before {
	background: transparent url(../images/deco-r.png) no-repeat top right/contain;
	bottom: -13vw;
	content: "";
	height: 19vw;
	position: absolute;
	right: 4%;
	width: 18vw;
}

.cta::after {
	background: transparent url(../images/deco-l.png) no-repeat top left/contain;
	content: "";
	height: 19vw;
	left: 3.5%;
	position: absolute;
	top: -13vw;
	width: 18vw;
}

.cta__items {
	grid-gap: 0 6%;
	align-items: center;
	display: grid;
	gap: 0 6%;
	grid-template-columns: 1fr 1fr;
	margin: 0 auto;
	width: max(63%, 650px);
}

.cta__button {
	border-radius: 6.1875rem;
	box-shadow: 0 0 20px rgba(230, 152, 50, 0.5);
	font-family: "Noto Sans JP", serif;
	font-size: 1.625rem;
	letter-spacing: -1px;
	padding: 5% 0;
	padding-right: 6%;
	position: relative;
	text-align: center;
	transition: all 0.3s;
}

.cta__button-siryou {
	background: #fff;
	color: #003E5F;
}

.cta__button-oc {
	background: #ED9458;
	color: #fff;
}

.cta__button svg {
	height: 1.5em;
	position: absolute;
	right: 8%;
	top: 50%;
	transform: translateY(-50%);
	transition: all 0.3s;
	width: 0.5em;
}

.cta__button:hover {
	opacity: 0.7;
}

.cta__button:hover svg {
	right: 6%;
}

.faq {
	padding: 5.9375rem 0 18.75rem;
	position: relative;
}

.faq::before {
	background: transparent url(../images/deco-r.png) no-repeat top right/contain;
	bottom: -6%;
	content: "";
	height: 19vw;
	position: absolute;
	right: 4%;
	width: 18vw;
	z-index: -1;
}

.faq::after {
	background: transparent url(../images/deco-l.png) no-repeat top left/contain;
	content: "";
	height: 19vw;
	left: 3.5%;
	position: absolute;
	top: -17%;
	width: 18vw;
	z-index: -2;
}

.faq .inner {
	position: relative;
}

.faq__wrapper {
	margin: 0 auto;
	width: 79%;
}

.faq__items {
	margin: 5.625rem auto 0;
}

.faq__item {
	border-top: 1px solid #707070;
}

.faq__items .faq__item:last-of-type {
	border-bottom: 1px solid #707070;
}

.faq__q {
	grid-gap: 0 1.5%;
	display: grid;
	gap: 0 1.5%;
	grid-template-columns: 3% 95.5%;
	padding: 2% 1% 2% 2.5%;
}

.faq__q:hover {
	cursor: pointer;
}

.faq__q-l {
	color: #003E5F;
	font-family: "Inter", sans-serif;
	font-size: 1.75rem;
	font-weight: 700;
	line-height: 1.42857;
}

.faq__q-r {
	grid-gap: 0 2%;
	color: #003E5F;
	display: grid;
	font-family: "Noto Sans JP", serif;
	gap: 0 2%;
	grid-template-columns: 93% 5%;
}

.faq__q-r-text {
	word-wrap: break-word; /* 個佩を弖紗 */
	align-items: center;
	display: flex;
	font-size: 1rem;
	line-height: 2.5;
	word-break: break-all; /* 駅勣に鬉犬gZを孵り卦す */
}

.faq__q-r-icon {
	position: relative;
}

.faq__q-r-icon::before,
.faq__q-r-icon::after {
	background: #003E5F;
	content: "";
	height: 2px;
	margin: auto;
	position: absolute;
	right: 20px;
	top: 1.2em;
	width: 20px;
}

.faq__q-r-icon::after {
	transform: rotate(-90deg);
	transition: transform 0.3s;
}

.faq__q-r-icon.open::after {
	transform: rotate(0deg);
}

.faq__content {
	display: none;
}

.faq__a {
	grid-gap: 0 1%;
	display: grid;
	gap: 0 1%;
	grid-template-columns: 2% 97%;
	padding: 0% 7% 3% 4%;
}

.faq__a-l {
	color: #003E5F;
	font-family: "Inter", sans-serif;
	font-size: 1rem;
	font-weight: 700;
	line-height: 2;
}

.faq__a-r {
	word-wrap: break-word; /* 個佩を弖紗 */
	align-items: center;
	display: flex;
	font-size: 1rem;
	line-height: 1.625;
	word-break: break-all; /* 駅勣に鬉犬gZを孵り卦す */
}

.footer {
	padding: 1.5625rem 0;
}

.footer__copyright {
	font-family: "Noto Sans JP", serif;
	font-size: 0.875rem;
	text-align: center;
}

.gallery {
	padding: 1.875rem 0 15.625rem;
	position: relative;
}

.gallery__top {
	margin: 6.25rem auto 0;
}

.gallery__bottom {
	margin: 10.625rem auto 0;
}

.gallery__head {
	font-size: 2.5rem;
	font-weight: 700;
	letter-spacing: 2px;
	text-align: center;
}

.gallery .swiper-container {
	padding: 3.125rem 0 5.3125rem;
	position: relative; /* ペ`ジネ`ション喘*/
}

.gallery .swiper {
	background: #fff;
	overflow: visible;
}

.gallery .swiper-slide {
	height: 100%;
	width: 416px;
}

.gallery__img {
	aspect-ratio: 416/232;
	height: auto;
	width: 100%;
}

.gallery__img img {
	-o-object-fit: cover !important;
	height: 100% !important;
	object-fit: cover !important;
}

.gallery__img img {
	width: 100%;
}

.gallery__text {
	font-family: "Noto Sans JP", serif;
	font-size: 1.125rem;
	line-height: 1.55555;
	padding: 0.8125rem 0 1.75rem;
	text-align: center;
}

/* ペ`ジネ`ションの了崔 */

.gallery .swiper-pagination-horizontal {
	bottom: 0.4375rem;
}

/* ペ`ジネ`ションの噫易 */

.gallery .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
	margin: 0 0.625rem !important;
}

/* ペ`ジネ`ションのサイズと弼 */

.gallery .swiper-pagination-bullet.swiper-pagination-bullet-active {
	background-color: #ED9458;
	height: 1.25rem;
	width: 1.25rem;
}

.gallery .swiper-pagination-bullet {
	background: #FADFCD;
	border-radius: 0.625rem;
	height: 1.25rem;
	opacity: 1;
	width: 1.25rem;
}

.gallery .swiper-area {
	position: relative;
}

/* 念への文咫カスタマイズ */

.gallery .swiper-button-prev::after {
	background-image: url(/extra/hyougen/assets/images/attempt-arrow.png);
}

/* 肝への文咫カスタマイズ */

.gallery .swiper-button-next::after {
	background-image: url(/extra/hyougen/assets/images/attempt-arrow.png);
	transform: rotate(180deg) translateY(28px);
}

/* 念へ肝への文咫カスタマイズ */

.gallery .swiper-button-prev,
.gallery .swiper-button-next {
	display: block;
	height: 2.5vw;
	top: 41%;
	width: 1.5vw;
}

.gallery .swiper-button-prev {
	left: 50%;
	transform: translateX(-256px);
}

.gallery .swiper-button-next {
	left: 50%;
	transform: translateX(230px);
}

/* 念へ肝への文咫カスタマイズ */

.gallery .swiper-button-prev::after,
.gallery .swiper-button-next::after {
	background-repeat: no-repeat;
	background-size: contain;
	color: #fff;
	content: "";
	display: block;
	height: max(2.5vw, 70px);
	margin: auto;
	width: max(1.5vw, 30px);
}

.header {
	background: transparent;
	height: 5vw;
	position: relative;
	z-index: 1;
}

.header__inner {
	display: flex;
	justify-content: space-between;
	margin: 0 auto;
	max-width: 102.5rem;
	padding: 1.875rem 1.25rem 1.875rem;
	position: relative;
	z-index: 0;
}

.header h1 {
	width: 15vw;
}

.header h1 a {
	transition: all 0.3s;
}

.header__menu {
	grid-gap: 0 6%;
	align-items: center;
	display: grid;
	gap: 0 6%;
	grid-template-columns: 1fr 1fr;
	width: 31vw;
}

.button {
	border-radius: 6.1875rem;
	box-shadow: 0 0 20px rgba(230, 152, 50, 0.5);
	font-family: "Noto Sans JP", serif;
	font-size: 1vw;
	font-weight: 600;
	letter-spacing: -1px;
	line-height: 1.7;
	padding: 4% 0;
	padding-right: 6%;
	position: relative;
	text-align: center;
	transition: all 0.3s;
}

.button-siryou {
	background: #fff;
	color: #003E5F;
}

.button-oc {
	background: #ED9458;
	color: #fff;
}

.button svg {
	height: 1.5em;
	position: absolute;
	right: 8%;
	top: 50%;
	transform: translateY(-50%);
	transition: all 0.3s;
	width: 0.5em;
}

.button:hover {
	opacity: 0.7;
}

.button:hover svg {
	right: 6%;
}

#fixed-header {
	background: #fff;
	box-sizing: border-box;
	height: 6.5625rem;
	position: fixed;
	text-align: center;
	top: -13vw;
	transition: 0.5s; /* アニメ`ションタイミング */
	width: 100%;
	z-index: 11;
}

#fixed-header .header__inner {
	background: #fff;
	padding: 0.9375rem 1.25rem;
}

#fixed-header.is-show {
	top: 0;
}

.inner {
	margin-left: auto;
	margin-right: auto;
	max-width: 1450px;
	padding-left: 25px;
	padding-right: 25px;
	width: 100%;
}

.learning {
	padding: 11.5625rem 0 0;
	position: relative;
}

.learning::before {
	background: transparent url(../images/deco-r.png) no-repeat top right/contain;
	bottom: 32%;
	content: "";
	height: 19vw;
	position: absolute;
	right: 3%;
	width: 18vw;
	z-index: -1;
}

.learning::after {
	background: transparent url(../images/deco-l.png) no-repeat top left/contain;
	content: "";
	height: 19vw;
	left: 3.5%;
	position: absolute;
	top: 0;
	width: 18vw;
	z-index: -2;
}

.learning__wrapper {
	margin: 6.25rem auto 0;
	max-width: 56.25rem;
}

.learning__item {
	grid-gap: 0 5%;
	display: grid;
	gap: 0 5%;
	grid-template-columns: 24% 71%;
	margin-bottom: 9%;
	padding-right: 3%;
}

.learning__q {
	background: #ED9458;
	color: #fff;
	display: grid;
	grid-template-columns: 1fr;
	padding: 15% 1%;
	position: relative;
	text-align: center;
}

.learning__q:after {
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	border: 1.625rem solid transparent;
	border-top: 1.75rem solid #ED9458;
	bottom: -3.25rem;
	content: "";
	left: 50%;
	position: absolute;
	transform: translateX(-50%);
	z-index: 1;
}

.learning__head {
	font-family: "Noto Sans JP", serif;
	font-size: 2.5rem;
	font-weight: 600;
	line-height: 1.275;
	order: 1;
}

.learning__icon {
	margin: 0.3125rem auto 0;
	order: 2;
	width: 38%;
}

.learning__arrow {
	display: none;
}

.learning__arrow::before,
.learning__arrow::after {
	background: #fff;
	content: "";
	height: 0.1875rem;
	margin: auto;
	position: absolute;
	position: absolute;
	right: 20px;
	top: 50%;
	transform: translateY(-50%);
	width: 1rem;
}

.learning__arrow::after {
	transform: rotate(-90deg);
	transition: transform 0.3s;
}

.learning__arrow.open::after {
	transform: rotate(0deg);
}

.learning__content-head {
	background: #FADFCD;
	font-size: 1.875rem;
	font-weight: 700;
	padding: 1% 1%;
}

.learning__content-detail {
	font-size: 1.5rem;
	line-height: 1.66666;
	margin-top: 0.9375rem;
}

.links {
	display: none;
}

.link__item a {
	color: #fff;
	display: block;
	font-family: "Noto Sans JP", serif;
	font-size: min(4.1vw, 20px);
	font-weight: 600;
	padding: min(9%, 20px) 0;
	text-align: center;
}

.link__item:first-of-type a {
	background: #003E5F;
}

.link__item:last-of-type a {
	background: #FF9000;
}

.link__item a svg {
	height: 0.8em;
	margin-left: 0.625rem;
	width: 0.5em;
}

.mv {
	margin-top: -5vw;
	position: relative;
}

.mv::before {
	animation: fade-in-opacity 2s ease forwards; /* ふんわり燕幣 */
	background: transparent url(../images/mv-text_bg.png) no-repeat top left/contain;
	content: "";
	height: 100%;
	left: 11vw;
	opacity: 0; /* 兜豚彜Bで掲燕幣 */
	position: absolute;
	top: 7.5vw;
	width: 77vw;
	z-index: 1;
}

:root {
	--sway-distance: 10px; /* デフォルトの貧和嫌 */
}

.mv__text {
	--sway-distance: 10px;
	animation: fade-in 2s ease forwards, sway 3s ease-in-out infinite; /* 竃F瘁ふわふわ咾 */
	opacity: 0; /* 兜豚彜Bで掲燕幣 */
	position: absolute;
	z-index: 1;
}

.mv__text00 {
	animation: fade-in-last 2s ease forwards;
	height: auto;
	left: 43%;
	opacity: 0; /* 兜豚彜Bで掲燕幣 */
	position: absolute;
	top: 12%;
	width: 12.5vw;
}

.mv__text01 {
	animation-delay: 0s;
	height: auto;
	left: 10vw;
	top: 15vw;
	width: 4.5vw;
}

.mv__text02 {
	animation-delay: 0.5s; /* 0.5昼Wれ */
	bottom: 11vw;
	height: auto;
	left: 25.5vw;
	width: 4.5vw;
}

.mv__text03 {
	animation-delay: 1s; /* 1昼Wれ */
	height: auto;
	left: 38.5vw;
	top: 15vw;
	width: 4.5vw;
}

.mv__text04 {
	animation-delay: 0s; /* 01と揖じタイミング */
	bottom: 10vw;
	height: auto;
	right: 33.5vw;
	width: 4.5vw;
}

.mv__text05 {
	animation-delay: 0.7s; /* 鏡徭のタイミング */
	height: auto;
	right: 18vw;
	top: 8vw;
	width: 4.5vw;
}

.mv__text06 {
	animation-delay: 0.7s; /* 鏡徭のタイミング */
	bottom: 7vw;
	height: auto;
	right: 20vw;
	width: 4.5vw;
}

.mv__img {
	animation: fade-in 2s ease forwards;
	opacity: 0; /* 兜豚彜Bで掲燕幣 */
	position: absolute;
	z-index: 0;
}

.mv__img01 {
	animation-delay: 0s;
	height: auto;
	left: 28vw;
	top: 9vw;
	width: 12vw;
}

.mv__img02 {
	animation-delay: 0.5s; /* 0.5昼Wれ */
	height: auto;
	left: 10.5vw;
	top: 19vw;
	width: 12vw;
}

.mv__img03 {
	animation-delay: 1s; /* 0.5昼Wれ */
	bottom: 9vw;
	height: auto;
	left: 30vw;
	width: 12vw;
}

.mv__img04 {
	animation-delay: 0.7s; /* 01と揖じタイミング */
	height: auto;
	right: 22.5vw;
	top: 7vw;
	width: 13vw;
}

.mv__img05 {
	animation-delay: 1.2s; /* 01と揖じタイミング */
	height: auto;
	right: 33.5vw;
	top: 22vw;
	width: 12vw;
}

.mv__img06 {
	animation-delay: 1.5s; /* 01と揖じタイミング */
	height: auto;
	right: 13.5vw;
	top: 18vw;
	width: 14vw;
}

.point1 {
	background: transparent url(../images/point-bg.png) no-repeat top center/cover;
	margin-top: -8%;
	padding: 15.3125rem 0 16.25rem;
	position: relative;
	z-index: -1;
}

.point1::before {
	background: transparent url(../images/deco-r.png) no-repeat top right/contain;
	content: "";
	height: 19vw;
	position: absolute;
	right: 3%;
	top: 32%;
	width: 18vw;
}

.point1::after {
	background: transparent url(../images/deco-l.png) no-repeat top left/contain;
	bottom: 26%;
	content: "";
	height: 19vw;
	left: 3.5%;
	position: absolute;
	width: 18vw;
	z-index: -1;
}

.point1 .inner {
	position: relative;
}

.point1__wrapper {
	margin: 0 auto;
	width: 90%;
}

.point1__items {
	margin: 7.8125rem auto 0;
}

.point1__item + .point1__item {
	margin-top: 7.5rem;
}

.point1__item:nth-of-type(odd) {
	grid-gap: 0 5.5%;
	display: grid;
	gap: 0 5.5%;
	grid-template-columns: 50% 44.5%;
}

.point1__item:nth-of-type(even) {
	grid-gap: 0 5.5%;
	display: grid;
	gap: 0 5.5%;
	grid-template-columns: 44.5% 50%;
}

.point1__item:nth-of-type(odd) .point1__img {
	grid-area: 1/1/3/2;
	position: relative;
}

.point1__item:nth-of-type(odd) .point1__img::before {
	background: transparent url(../images/deco2-l.png) no-repeat bottom left/contain;
	bottom: -19%;
	content: "";
	height: 39%;
	left: -24%;
	position: absolute;
	width: 35%;
	z-index: -1;
}

.point1__item:nth-of-type(even) .point1__img {
	grid-area: 1/2/3/3;
	position: relative;
}

.point1__item:nth-of-type(even) .point1__img::before {
	background: transparent url(../images/deco2-r.png) no-repeat bottom right/contain;
	bottom: -19%;
	content: "";
	height: 39%;
	position: absolute;
	right: -19%;
	width: 35%;
	z-index: -1;
}

.point1__item:nth-of-type(odd) .point1__head {
	grid-area: 1/2/2/3;
}

.point1__item:nth-of-type(even) .point1__head {
	grid-area: 1/1/2/2;
}

.point1__head {
	grid-gap: 0 5%;
	display: grid;
	font-weight: 700;
	gap: 0 5%;
	grid-template-columns: 20% 75%;
	position: relative;
}

.point1__head::before {
	background: transparent url(../images/point-head.png) no-repeat top left/contain;
	content: "";
	height: 48%;
	left: 0;
	position: absolute;
	top: -47%;
	width: 36%;
}

.point1__num span {
	align-items: center;
	aspect-ratio: 1/1;
	background: #fff;
	border-radius: 50%;
	box-shadow: 0 0 20px #fff;
	color: #ED9458;
	display: flex;
	font-size: 3.75rem;
	justify-content: center;
	padding-bottom: 8%;
}

.point1__head-text {
	font-size: 2.375rem;
	font-size: clamp(1.75rem, 1.3333rem + 0.8681vw, 2.375rem);
	letter-spacing: 3px;
	line-height: 1.42105;
}

.point1__item:nth-of-type(odd) .point1__detail {
	grid-area: 2/2/3/3;
}

.point1__item:nth-of-type(even) .point1__detail {
	grid-area: 2/1/3/2;
}

.point1__detail {
	font-size: 1.375rem;
	letter-spacing: 0.5px;
	line-height: 1.81818;
	margin-top: -9%;
}

.point2 {
	padding: 6.25rem 0 4.375rem;
}

.point2__head-wrapper img {
	margin: 0 auto;
	width: 27.8125rem;
}

.point2__head {
	font-size: 2.5rem;
	font-weight: 700;
	letter-spacing: 3px;
	margin-top: 1.25rem;
	text-align: center;
}

.qualifications {
	position: relative;
}

.qualifications::before {
	background: transparent url(../images/deco-r.png) no-repeat top right/contain;
	content: "";
	height: 19vw;
	position: absolute;
	right: 3%;
	top: -72%;
	width: 18vw;
}

.qualifications::after {
	background: transparent url(../images/deco-l.png) no-repeat top left/contain;
	bottom: 13%;
	content: "";
	height: 19vw;
	left: 3.5%;
	position: absolute;
	width: 18vw;
	z-index: -1;
}

.qualifications__items {
	margin: 2.5rem auto 0;
	max-width: 55.625rem;
}

.qualifications__items li {
	font-family: "Noto Sans JP", serif;
	font-size: 2.25rem;
	font-weight: 700;
	letter-spacing: 3px;
	line-height: 1.44444;
	padding-left: 4%;
	position: relative;
}

.qualifications__items li::before {
	background: #ED9458;
	border-radius: 50%;
	content: "";
	height: 0.65em;
	left: 0;
	position: absolute;
	top: 0.4em;
	width: 0.65em;
}

.section-title {
	font-size: 3.4375rem;
	font-weight: 700;
	letter-spacing: 2px;
	margin: 0 auto;
	position: relative;
	text-align: center;
	width: 27.5rem;
}

.about .section-title {
	padding-bottom: 1.5625rem;
}

.communication .section-title {
	padding-bottom: 0.5rem;
}

.point1 .section-title {
	padding-bottom: 0.3125rem;
}

.section-title::first-letter {
	color: #ED9458;
	font-size: 5.125rem;
}

.section-title::before {
	border-bottom: 5px solid #FADFCD;
	bottom: -5px;
	content: "";
	display: block;
	left: 50%;
	position: absolute;
	transform: translateX(-50%);
	width: 100%;
}

.point1 .section-title::before {
	border-bottom: 5px solid #fff;
}

.section-title::after {
	border-bottom: 5px solid #ED9458;
	bottom: -5px;
	content: "";
	display: block;
	left: 0;
	position: absolute;
	width: 50%;
}

.section-title-deco {
	color: #F6F8FB;
	display: block;
	font-family: "Crimson Text", serif;
	font-size: 11.25rem;
	font-weight: 400;
	position: absolute;
}

.section-title-deco::first-letter {
	color: #FADFCD;
}

.communication .section-title-deco::first-letter {
	color: #B2C5CF;
}

.point1 .section-title-deco::first-letter {
	color: #ED9458;
}

.about .section-title-deco {
	top: -30%;
}

.communication .section-title-deco {
	bottom: -37%;
	right: 2%;
}

.point1 .section-title-deco {
	top: -9%;
}

.voice .section-title-deco {
	bottom: -5%;
	right: 16%;
}

.faq .section-title-deco {
	bottom: -1.4em;
	font-size: 12.5rem;
	left: 1.5%;
}

.gallery .section-title-deco {
	bottom: -4%;
	font-size: 12.5rem;
	right: 14%;
}

.access .section-title-deco {
	top: -18%;
}

.sns {
	background: transparent url(../images/common-bg.png) no-repeat top center/cover;
	padding: 6.875rem 0 8.75rem;
	position: relative;
}

.sns::before {
	background: transparent url(../images/deco-r.png) no-repeat top right/contain;
	bottom: -11vw;
	content: "";
	height: 19vw;
	position: absolute;
	right: 4%;
	width: 18vw;
}

.sns::after {
	background: transparent url(../images/deco-l.png) no-repeat top left/contain;
	content: "";
	height: 19vw;
	left: 3.5%;
	position: absolute;
	top: -9vw;
	width: 18vw;
}

.sns__title {
	font-size: 3.4375rem;
	font-weight: 700;
	letter-spacing: 2px;
	margin: 0 auto;
	position: relative;
	text-align: center;
	width: 27.5rem;
}

.sns__title::before {
	border-bottom: 5px solid #FADFCD;
	bottom: -5px;
	content: "";
	display: block;
	left: 50%;
	position: absolute;
	transform: translateX(-50%);
	width: 100%;
}

.sns__title::after {
	border-bottom: 5px solid #ED9458;
	bottom: -5px;
	content: "";
	display: block;
	left: 0;
	position: absolute;
	width: 50%;
}

.sns__items {
	grid-gap: 0 6%;
	align-items: center;
	display: grid;
	gap: 0 6%;
	grid-template-columns: repeat(5, 1fr);
	margin: 7.1875rem auto 0;
	width: 41.25rem;
}

.sns__item a {
	transition: all 0.3s;
}

.sns__item a:hover {
	opacity: 0.7;
}

.voice {
	background: transparent url(../images/voice-bg.png) no-repeat top center/cover;
	padding: 12.5rem 0 13.125rem;
	position: relative;
}

/* Swiper */

.voice [class*=swiper]:focus {
	outline: none;
}

.voice .swiper__container {
	position: relative;
}

.voice .swiper__area {
	height: 100%;
	margin: 4.6875rem auto 0;
	position: relative;
}

.voice .voice__main .swiper {
	height: 100%;
	padding: 20px 0;
}

.voice .voice__main .swiper-slide {
	border-radius: 1.875rem;
	box-shadow: 0 0 20px rgba(0, 0, 0, 0.2);
	cursor: pointer;
	width: 375px;
	width: max(19.5vw, 250px);
}

.voice .voice__main .slide {
	display: flex;
	flex-direction: column;
	height: 100%;
}

.voice .voice__main .slide__img {
	aspect-ratio: 375/458;
	border-radius: 1.875rem 1.875rem 0 0;
	height: auto;
	overflow: hidden;
	width: 100%;
}

.voice .voice__main .slide__img img {
	-o-object-fit: cover;
	border-radius: 1.875rem 1.875rem 0 0;
	height: 100%;
	object-fit: cover;
	transition: transform 0.6s ease; /* ゆっくり篁させる */
	width: 100%;
}

.voice .voice__main .slide:hover img {
	transform: scale(1.1); /* 寄 */
}

.voice .voice__main .slide__text {
	background: #fff;
	border-radius: 0 0 1.875rem 1.875rem;
	display: flex;
	flex-direction: column;
	flex-grow: 1;
	font-family: "Noto Sans JP", serif;
	font-weight: 700;
	padding: 3% 4% 7%;
}

.voice .voice__main .slide__text-head {
	color: orange;
	flex-grow: 1;
	font-size: 1.125rem;
	font-size: max(1vw, 14px);
	line-height: 1.38888;
}

.voice .voice__main .slide__text-bottom {
	border-radius: 0 0 1.875rem 1.875rem;
	display: flex;
	justify-content: space-between;
	margin-top: 0.9375rem;
}

.voice .voice__main .slide__text-name {
	font-size: 1rem;
	font-size: max(0.85vw, 12px);
	margin-right: 1%;
}

.slide__text-btn {
	flex: 1;
}

.voice .voice__main .slide__text-btn span {
	align-items: center;
	border: 1px solid #003E5F;
	border-radius: 1.875rem;
	color: #003E5F;
	display: flex;
	font-size: 0.75rem;
	font-size: max(0.6vw, 10px);
	justify-content: center;
	margin-left: auto;
	padding: 3% 1%;
	white-space: nowrap;
	width: 80%;
}

.voice .voice__main .slide__text-btn span svg {
	height: 1em;
	margin-left: 1%;
	width: 1em;
}

.voice .slide__content {
	display: none;
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.3s ease;
}

.voice .slide__content.is-open {
	display: block;
	max-height: 1000px; /* コンテンツの恷寄互さに栽わせて{屁 */
}

.voice .slide__text-bottom {
	display: block;
}

.voice .slide__text-bottom.is-hidden {
	display: none;
}

.voice .slide__content-name {
	font-size: 1rem;
}

.voice .slide__content-office {
	font-size: 0.8125rem;
}

.voice .slide__content-detail {
	font-family: "Noto Serif JP", serif;
	font-size: 0.875rem;
	line-height: 1.714285;
	margin-top: 0.625rem;
}

.slide__content-bottom {
	font-size: 0.75rem;
	margin-top: 1.5625rem;
	text-align: right;
}

.slide__content-button {
	border: 1px solid #003E5F;
	border-radius: 2.5rem;
	color: #003E5F;
	font-size: 0.75rem;
	font-weight: 700;
	margin: 1.25rem auto 0;
	padding: 1% 3%;
	width: -moz-fit-content;
	width: fit-content;
}

.slide__content-button svg {
	height: 1em;
	transform: rotate(-90deg);
	width: 1em;
}

.voice__main .swiper__controls {
	align-items: center; /* 換岷圭鬚鰆佰Bえ */
	display: flex;
	gap: 20px; /* ボタンとペ`ジネ`ションのgの噫易 */
	justify-content: center; /* 邦峠圭鬚鰆佰Bえ */
	margin: 1% auto 0; /* 駅勣に鬉犬噸{屁 */
	max-width: 31.25rem;
	position: relative;
}

.voice__main .swiper__controls .swiper-button-prev,
.voice__main .swiper__controls .swiper-button-next {
	align-content: center;
	cursor: pointer;
	height: 3.75rem;
	justify-content: center;
	margin: auto;
	margin-top: 0;
	place-content: center;
	position: relative; /* absoluteではなくrelativeに */
	transition: 0.8s cubic-bezier(0.2, 1, 0.2, 1);
	width: 3.75rem;
	z-index: 20;
}

.voice .voice__main .swiper-button-prev {
	left: -1.25rem;
}

.voice .voice__main .swiper-button-next {
	right: -1.25rem;
}

.voice .voice__main .swiper-button-prev::after {
	background-image: url(/extra/hyougen/assets/images/voice-arrow.png);
}

/* 肝への文咫カスタマイズ */

.voice .voice__main .swiper-button-next::after {
	background-image: url(/extra/hyougen/assets/images/voice-arrow.png);
	transform: rotate(180deg);
}

/* 念へ肝への文咫カスタマイズ */

.voice .voice__main .swiper-button-prev::after,
.voice .voice__main .swiper-button-next::after {
	background-repeat: no-repeat;
	background-size: contain;
	color: #fff;
	content: "";
	display: block;
	height: 3.125rem;
	margin: auto;
	width: 3.125rem;
}

/* ペ`ジネ`ションの了崔 */

.voice .voice__main .swiper-pagination-horizontal {
	bottom: auto;
}

/* ペ`ジネ`ションの噫易 */

.voice .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
	margin: 0 0.4375rem;
}

/* ペ`ジネ`ションのサイズと弼 */

.voice .swiper-pagination-bullet.swiper-pagination-bullet-active {
	background-color: #003E5F;
	height: 0.625rem;
	width: 0.625rem;
}

.voice .swiper-pagination-bullet {
	background: #D1DDEA;
	border-radius: 0.625rem;
	height: 0.625rem;
	opacity: 1;
	width: 0.625rem;
}

.voice .modal .swiper-button-prev,
.voice .modal .swiper-button-next {
	align-content: center;
	background-color: #afafaf;
	border-radius: 50%;
	bottom: 0;
	cursor: pointer;
	display: grid;
	height: 60px;
	justify-content: center;
	margin: auto;
	place-content: center;
	position: absolute;
	top: 0;
	width: 60px;
	z-index: 1;
}

.voice .modal__content .swiper-button-prev {
	left: 0;
	transform: translateX(-50%);
}

.voice .modal__content .swiper-button-next {
	right: 0;
	transform: translateX(50%);
}

.voice .swiper-slide img {
	-o-object-fit: cover;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

/* モ`ダル */

.voice .modal {
	align-items: flex-start; /* 貧何から兵まる */
	background-color: rgba(120, 123, 131, 0.8);
	display: flex;
	height: 100vh;
	justify-content: center;
	left: 0;
	opacity: 0;
	overflow-y: auto; /* kスクロ`ルを嗤浸 */
	padding: 10% 0; /* モ`ダル畠悶に噫易を原けて嶄刹に塘崔 */
	pointer-events: none;
	position: fixed;
	top: 0;
	transition: opacity 0.3s;
	width: 100%;
	z-index: 100;
}

/* モ`ダルがactiveのr */

.voice .modal.is-active {
	opacity: 1;
	pointer-events: auto;
}

/* モ`ダル嘘尚のオ`バ`レイ何蛍 */

.voice .modal__overlay {
	cursor: pointer;
	height: 100%;
	position: absolute;
	width: 100%;
}

.modal__slider .modal__slide {
	display: flex;
	flex-direction: column;
	height: auto;
}

/* モ`ダルのコンテンツ */

.voice .modal__content {
	background-color: #fff;
	border-radius: 0.625rem;
	max-width: 830px;
	padding: 2% 2%;
	position: relative;
	width: 100%;
}

.modal__head {
	color: #ED9458;
	font-family: "Noto Sans JP", serif;
	font-size: 1.625rem;
	font-weight: 700;
	line-height: 1.38461;
	margin-top: 1.5625rem;
}

.modal__slide-name {
	align-items: center;
	display: flex;
	font-family: "Noto Sans JP", serif;
	margin-top: 0.3125rem;
}

.modal__slide-name span:first-of-type {
	font-size: 1.125rem;
	font-weight: 700;
	margin-right: 2%;
}

.modal__slide-name span:last-of-type {
	font-size: 1rem;
}

.modal__slide-text {
	font-size: 1rem;
	line-height: 1.875;
	margin-top: 1.5625rem;
}

.modal__slide-bottom {
	font-family: "Noto Sans JP", serif;
	font-size: 0.875rem;
	line-height: 1.71428;
	margin-top: 0.625rem;
	text-align: right;
}

.modal .swiper__controls {
	display: grid;
	grid-template-columns: 20% 60% 20%;
	margin: 3.125rem auto 0; /* 駅勣に鬉犬噸{屁 */
	position: relative;
}

/* モ`ダルを]じるボタン */

.voice .modal__close-btn {
	align-self: flex-start;
	background: #003E5F;
	border-radius: 2.5rem;
	color: #fff;
	cursor: pointer;
	font-family: "Noto Sans JP", serif;
	font-size: 0.9375rem;
	margin: 0 auto;
	padding: 1% 8% 1% 6%;
	width: -moz-fit-content;
	width: fit-content;
	z-index: 10;
}

.modal .swiper__controls .swiper-button-prev,
.modal .swiper__controls .swiper-button-next {
	align-content: center;
	background-color: transparent;
	cursor: pointer;
	height: 2.5rem;
	justify-content: center;
	margin-top: 0;
	place-content: center;
	position: relative; /* absoluteではなくrelativeに */
	transition: 0.8s cubic-bezier(0.2, 1, 0.2, 1);
	width: 2.5rem;
	z-index: 20;
}

.modal .swiper__controls .swiper-button-prev::after {
	background-image: url(/extra/hyougen/assets/images/voice-arrow.png);
}

/* 肝への文咫カスタマイズ */

.modal .swiper__controls .swiper-button-next::after {
	background-image: url(/extra/hyougen/assets/images/voice-arrow.png);
	transform: rotate(180deg);
}

/* 念へ肝への文咫カスタマイズ */

.modal .swiper__controls .swiper-button-prev::after,
.modal .swiper__controls .swiper-button-next::after {
	background-repeat: no-repeat;
	background-size: contain;
	color: #fff;
	content: "";
	display: block;
	height: 2.5rem;
	margin: 0 auto 15px;
	width: 2.5rem;
}

@media (min-width: 768px) {

a[href^="tel:"] {
	pointer-events: none;
}

}

@media (max-width: 1400px) {

html {
	font-size: 1.1428571429vw;
}

}

@media screen and (max-width: 767px) {

.u-desktop {
	display: none;
}

.u-mobile {
	display: block;
}

html {
	font-size: 16px;
}

.about {
	padding: 4.125rem 0 3.125rem;
}

.about::before {
	background: transparent url(../images/deco-l.png) no-repeat top left/contain;
	content: "";
	height: 21vw;
	left: 2%;
	position: absolute;
	top: -6%;
	width: 21vw;
}

.about .inner {
	max-width: 34.375rem;
}

.about__wrapper {
	width: 100%;
}

.about__title img {
	padding-left: 7%;
	width: 14.375rem;
}

.about__head {
	font-size: 1.25rem;
	letter-spacing: 0;
	line-height: 1.6;
	margin-top: 1.6875rem;
}

.about__items {
	gap: 1.0625rem 0;
	grid-template-columns: 1fr;
	margin: 1.25rem auto 0;
}

.about__text {
	font-size: 0.875rem;
	line-height: 1.71428;
	order: 2;
}

.about__img {
	order: 1;
}

.access {
	padding: 5.4375rem 0 1.25rem;
}

.access::after {
	display: none;
}

.access .inner {
	max-width: 34.375rem;
	padding: 0;
}

.access__wrapper {
	padding-right: 0;
	width: 100%;
}

.access__items-t {
	gap: 0.5rem 0;
	grid-template-columns: 1fr;
	margin: 1.25rem auto 0;
	padding: 0 1.25rem;
}

.access__item1 {
	font-size: 1.25rem;
	text-align: center;
}

.access__item2 {
	font-size: 0.875rem;
	line-height: 1.71428;
}

.access__items-b {
	gap: 0.3125rem 0;
	margin: 0.625rem auto 0;
}

.access__item3 {
	font-size: 0.75rem;
	line-height: 1.6666;
	order: 2;
	padding: 0 1.25rem;
}

.access__item4 {
	aspect-ratio: 390/280;
	order: 1;
}

.access__bottom a {
	border-radius: 2.8125rem;
	padding: 0.9375rem 0 1.25rem;
	width: 21.875rem;
}

.access__bottom a:hover {
	opacity: 1;
	opacity: initial;
}

.point2__attempt {
	padding-top: 3.4375rem;
}

.point2__attempt::before {
	display: none;
}

.attempt .swiper-container {
	margin: 3.9375rem auto 0;
	margin-top: 1.6875rem;
	padding: 0 0 1.25rem;
}

.attempt .swiper-container::before {
	display: none;
}

.attempt .swiper {
	overflow: hidden;
	width: 100%;
}

.attempt .swiper-slide {
	width: 310px;
}

.attempt__img {
	aspect-ratio: 310/180;
}

.attempt__text {
	font-size: 0.875rem;
	line-height: 1.6;
	padding: 0.4375rem 0 1.25rem;
}

.attempt .swiper-pagination-horizontal {
	bottom: 0.625rem;
}

.attempt .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
	margin: 0 0.3125rem !important;
}

.attempt .swiper-pagination-bullet.swiper-pagination-bullet-active {
	height: 0.625rem;
	width: 0.625rem;
}

.attempt .swiper-pagination-bullet {
	height: 0.625rem;
	width: 0.625rem;
}

.attempt .swiper-button-prev::after {
	background-image: url(/extra/hyougen/assets/images/attempt-arrow_sp.png);
}

.attempt .swiper-button-next::after {
	background-image: url(/extra/hyougen/assets/images/attempt-arrow_sp.png);
	transform: rotate(180deg) translateY(0);
}

.attempt .swiper-button-prev,
.attempt .swiper-button-next {
	height: 2.125rem;
	top: 38%;
	width: 2.125rem;
}

.attempt .swiper-button-prev {
	transform: translateX(-170px);
}

.attempt .swiper-button-next {
	transform: translateX(139px);
}

.attempt .swiper-button-prev::after,
.attempt .swiper-button-next::after {
	height: 2.125rem;
	width: 2.125rem;
}

.back-to-top {
	bottom: 80px;
}

.communication {
	background: transparent url(../images/communication-bg_sp.png) no-repeat top -28px center;
	background-size: 100% auto;
	padding: 3.125rem 0 2.5rem;
}

.communication::before {
	height: 21vw;
	top: -10%;
	width: 20vw;
}

.communication::after {
	bottom: -8%;
	height: 22vw;
	left: 2.5%;
	width: 21vw;
}

.communication .inner {
	max-width: 34.375rem;
}

.communication__items {
	gap: 1.4375rem 13%;
	grid-template-columns: repeat(2, 1fr);
	margin: 1.5625rem auto 0;
}

.communication__text {
	display: flex;
	font-size: 0.875rem;
	justify-content: center;
	letter-spacing: 1px;
	margin-top: 0.375rem;
}

.communication__text span::first-letter {
	font-size: 1.125rem;
}

.course {
	padding: 2.5rem 0 0;
}

.course::before {
	height: 21vw;
	top: 0.5%;
	width: 20vw;
}

.course::after {
	display: none;
}

.course__items {
	margin: 1.875rem auto 0;
	max-width: 31.25rem;
	width: 100%;
}

.course__item + .course__item {
	margin-top: 2.5rem;
}

.course__item:nth-of-type(odd) {
	gap: 0.9375rem 0;
	grid-template-columns: 1fr;
	grid-template-rows: auto;
	padding: 1.4375rem 6% 1.6875rem;
}

.course__item:nth-of-type(even) {
	gap: 0.9375rem 0;
	grid-template-columns: 1fr;
	grid-template-rows: auto;
	padding: 1.4375rem 6% 1.6875rem;
}

.course__item:nth-of-type(even) .course__img {
	grid-area: 2/1/3/2;
}

.course__item:nth-of-type(odd) .course__img {
	grid-area: 2/1/3/2;
}

.course__item:nth-of-type(even) .course__head {
	grid-area: 1/1/2/2;
}

.course__item:nth-of-type(odd) .course__head {
	grid-area: 1/1/2/2;
}

.course__item {
	background-size: 400% auto; /* 嘘尚鮫颪魴80%で燕幣 */
	border-radius: 1.25rem;
}

.course__item:nth-of-type(odd) .course__img img {
	margin-left: 0;
}

.course__item:nth-of-type(even) .course__img img {
	margin-left: 0;
}

.course__item::after {
	background: transparent url(../images/course-deco.png) no-repeat center center/contain;
	content: "";
	height: 115%;
	left: 50%;
	position: absolute;
	top: 48%;
	transform: translate(-50%, -50%);
	width: 115%;
	z-index: 5;
}

.course__item:nth-of-type(even):after {
	background: transparent url(../images/course-deco.png) no-repeat center center/contain;
	content: "";
	height: 105%;
	left: 50%;
	position: absolute;
	top: 48%;
	transform: translate(-50%, -50%);
	width: 105%;
	z-index: 5;
}

.course__head {
	text-align: center;
}

.course__head span {
	font-size: 1.25rem;
	line-height: 1.35;
	padding: 2% 5%;
}

.course__item:nth-of-type(even) .course__detail {
	grid-area: 3/1/4/2;
}

.course__item:nth-of-type(odd) .course__detail {
	grid-area: 3/1/4/2;
}

.course__text {
	font-size: 0.875rem;
	letter-spacing: 0;
	line-height: 1.71428;
	margin-top: 0;
}

.course__text p:nth-of-type(2) {
	margin-top: 1.5625rem;
}

.cta {
	background: transparent url(../images/common-bg_sp.png) no-repeat top center/cover;
	padding: 3.4375rem 0;
}

.cta::before {
	bottom: auto;
	height: 21vw;
	top: -14vw;
	width: 20vw;
}

.cta::after {
	bottom: -11vw;
	height: 21vw;
	top: auto;
	width: 20vw;
}

.cta__items {
	gap: 1.0625rem 0;
	grid-template-columns: 1fr;
	max-width: 34.375rem;
	width: 100%;
}

.cta__button {
	font-size: 1.25rem;
	letter-spacing: 0;
	padding: 6% 0;
}

.cta__button:hover {
	opacity: 1;
	opacity: initial;
}

.faq {
	padding: 6.875rem 0 2.5rem;
}

.faq::before {
	height: 21vw;
	top: 2%;
	width: 20vw;
}

.faq::after {
	bottom: -10%;
	height: 21vw;
	top: auto;
	width: 20vw;
}

.faq .inner {
	max-width: 34.375rem;
}

.faq__wrapper {
	width: 100%;
}

.faq__items {
	margin: 1.875rem auto 0;
}

.faq__q {
	gap: 0 2%;
	grid-template-columns: 9% 89%;
	padding: 3.9% 1%;
}

.faq__q-l {
	font-size: 1.25rem;
	line-height: 2;
}

.faq__q-r {
	gap: 0 3%;
	grid-template-columns: 90% 7%;
}

.faq__q-r-text {
	font-size: 0.875rem;
}

.faq__q-r-icon::before,
.faq__q-r-icon::after {
	height: 0.0625rem;
	right: 2px;
	width: 1.25rem;
}

.faq__a {
	gap: 0 2%;
	grid-template-columns: 6% 92%;
	padding: 0 10% 4% 5%;
}

.faq__a-l {
	font-size: 0.875rem;
}

.faq__a-r {
	font-size: 0.875rem;
	line-height: 1.71428;
}

.footer {
	padding: 1.25rem 0 5rem;
}

.footer__copyright {
	font-size: 0.75rem;
}

.gallery {
	padding: 2.625rem 0 2.8125rem;
}

.gallery::before {
	background: transparent url(../images/deco-r.png) no-repeat top right/contain;
	content: "";
	height: 21vw;
	position: absolute;
	right: 3%;
	top: 46%;
	width: 20vw;
	z-index: 1;
}

.gallery__top {
	margin: 1.6875rem auto 0;
}

.gallery__bottom {
	margin: 1.25rem auto 0;
}

.gallery__head {
	font-size: 1.25rem;
}

.gallery .swiper-container {
	padding: 0.625rem 0 1.25rem;
}

.gallery .swiper {
	overflow: hidden;
	width: 100%;
}

.gallery .swiper-slide {
	width: 310px;
}

.gallery__img {
	aspect-ratio: 310/180;
}

.gallery__text {
	font-size: 0.875rem;
	line-height: 1.6;
	padding: 0.4375rem 0 1.25rem;
}

.gallery .swiper-pagination-horizontal {
	bottom: 0.625rem;
}

.gallery .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
	margin: 0 0.3125rem !important;
}

.gallery .swiper-pagination-bullet.swiper-pagination-bullet-active {
	height: 0.625rem;
	width: 0.625rem;
}

.gallery .swiper-pagination-bullet {
	height: 0.625rem;
	width: 0.625rem;
}

.gallery .swiper-button-prev::after {
	background-image: url(/extra/hyougen/assets/images/attempt-arrow_sp.png);
}

.gallery .swiper-button-next::after {
	background-image: url(/extra/hyougen/assets/images/attempt-arrow_sp.png);
	transform: rotate(180deg) translateY(0);
}

.gallery .swiper-button-prev,
.gallery .swiper-button-next {
	height: 2.125rem;
	top: 38%;
	width: 2.125rem;
}

.gallery .swiper-button-prev {
	transform: translateX(-170px);
}

.gallery .swiper-button-next {
	transform: translateX(139px);
}

.gallery .swiper-button-prev::after,
.gallery .swiper-button-next::after {
	height: 2.125rem;
	width: 2.125rem;
}

.header__inner {
	padding: 1.125rem 1.3125rem 1.125rem;
}

.header h1 {
	width: 30vw;
}

.header h1 a:hover {
	opacity: 0.8;
}

.header__menu {
	display: none;
}

.button:hover {
	opacity: 1;
	opacity: initial;
}

#fixed-header {
	display: none;
}

.inner {
	padding-left: 20px;
	padding-right: 20px;
}

.learning {
	padding: 4rem 0 0;
}

.learning::before {
	display: none;
}

.learning::after {
	height: 21vw;
	top: 16%;
	width: 20vw;
}

.learning__wrapper {
	margin: 2.1875rem auto 0;
	max-width: 34.375rem;
	width: 100%;
}

.learning__item {
	grid-template-columns: 1fr;
	margin-bottom: 9.5%;
	padding-right: 0;
}

.learning__q {
	grid-gap: 0 0;
	align-items: center;
	display: grid;
	gap: 0 0;
	grid-template-columns: repeat(3, 1fr);
	padding: 1.125rem 1%;
}

.learning__q:after {
	border: 0.875rem solid transparent;
	border-top: 0.9375rem solid #ED9458;
	bottom: -1.6875rem;
}

.learning__head {
	font-size: 1.25rem;
	order: 2;
}

.learning__icon {
	margin: 0 auto;
	order: 1;
}

.learning__arrow {
	display: block;
	order: 3;
	position: relative;
}

.learning__content {
	display: none;
	margin-top: 7%;
}

.learning__content-head {
	font-size: 1.125rem;
	padding: 2.5% 0;
	text-align: center;
}

.learning__content-detail {
	font-size: 0.875rem;
	line-height: 1.71428;
}

.links {
	bottom: 0;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	left: 0;
	position: fixed;
	width: 100%;
	z-index: 10;
}

.mv::before {
	background: transparent url(../images/mv-text-bg_sp.png) no-repeat top left/contain;
	left: 13vw;
	top: 20vw;
	width: 87vw;
}

.mv__text {
	--sway-distance: 2px;
}

.mv__text00 {
	left: 35%;
	top: 10%;
	width: 31.5vw;
}

.mv__text01 {
	left: 1vw;
	top: 48vw;
	width: 10.5vw;
}

.mv__text02 {
	display: none;
}

.mv__text03 {
	left: 17.5vw;
	top: 39vw;
	width: 9vw;
}

.mv__text04 {
	bottom: 32vw;
	right: 13.5vw;
	width: 10vw;
}

.mv__text05 {
	display: none;
}

.mv__text06 {
	bottom: auto;
	height: auto;
	right: 12vw;
	top: 24vw;
	width: 9.5vw;
}

.mv__img01 {
	display: none;
}

.mv__img02 {
	left: auto;
	right: -7vw;
	top: -5vw;
	width: 33.5vw;
}

.mv__img03 {
	bottom: auto;
	left: -4vw;
	top: 13vw;
	width: 30vw;
}

.mv__img04 {
	right: -6.5vw;
	top: 38vw;
	width: 33vw;
}

.mv__img05 {
	bottom: 13vw;
	right: -6.5vw;
	top: auto;
	width: 30vw;
}

.mv__img06 {
	bottom: 17vw;
	left: -8vw;
	right: auto;
	top: auto;
	width: 32vw;
}

.point1 {
	background: transparent url(../images/point-bg_sp.png) no-repeat top center;
	background-size: 100% 100%;
	margin-top: 0;
	padding: 4.8125rem 0 5.625rem;
}

.point1::before {
	height: 21vw;
	top: 6%;
	width: 20vw;
}

.point1::after {
	background: transparent url(../images/deco-r.png) no-repeat top left/contain;
	bottom: 28%;
	height: 22vw;
	left: auto;
	right: 3%;
	width: 21vw;
}

.point1 .inner {
	max-width: 34.375rem;
}

.point1__wrapper {
	width: 100%;
}

.point1__items {
	margin: 2.1875rem auto 0;
}

.point1__item + .point1__item {
	margin-top: 2.25rem;
}

.point1__item:nth-of-type(odd) {
	gap: 0.9375rem 0;
	grid-template-columns: 1fr;
}

.point1__item:nth-of-type(even) {
	gap: 0.9375rem 0;
	grid-template-columns: 1fr;
}

.point1__item:nth-of-type(odd) .point1__img {
	grid-area: 2/1/3/2;
}

.point1__item:nth-of-type(odd) .point1__img::before {
	display: none;
}

.point1__item:nth-of-type(even) .point1__img {
	grid-area: 2/1/3/2;
}

.point1__item:nth-of-type(even) .point1__img::before {
	display: none;
}

.point1__item:nth-of-type(odd) .point1__head {
	grid-area: 1/1/2/2;
}

.point1__item:nth-of-type(even) .point1__head {
	grid-area: 1/1/2/2;
}

.point1__head {
	gap: 0 5%;
	grid-template-columns: 17% 78%;
}

.point1__head::before {
	display: none;
}

.point1__num span {
	font-size: 2.4375rem;
}

.point1__head-text {
	font-size: 1.25rem;
	letter-spacing: 2px;
	line-height: 1.4;
}

.point1__item:nth-of-type(odd) .point1__detail {
	grid-area: 3/1/4/2;
}

.point1__item:nth-of-type(even) .point1__detail {
	grid-area: 3/1/4/2;
}

.point1__detail {
	font-size: 0.875rem;
	letter-spacing: 0;
	line-height: 1.71428;
	margin-top: 0;
}

.point2 {
	padding: 3.125rem 0 2.5rem;
}

.point2__head-wrapper img {
	width: 15rem;
}

.point2__head {
	font-size: 1.25rem;
	letter-spacing: 2px;
	line-height: 1.6;
	margin-top: 0.75rem;
}

.qualifications::before {
	bottom: -3%;
	height: 21vw;
	top: auto;
	width: 20vw;
}

.qualifications::after {
	bottom: auto;
	height: 22vw;
	left: 2.5%;
	top: -34%;
	width: 21vw;
}

.qualifications__items {
	margin: 1.625rem auto 0;
	max-width: 28.125rem;
}

.qualifications__items li {
	font-size: 1.125rem;
	letter-spacing: 0;
	line-height: 1.77777;
	padding-left: 5%;
}

.qualifications__items li::before {
	top: 0.5em;
}

.section-title {
	font-size: 1.5rem;
	width: 14.75rem;
}

.about .section-title {
	padding-bottom: 0.4375rem;
}

.section-title::first-letter {
	font-size: 2.25rem;
}

.section-title::before {
	border-bottom: 3px solid #FADFCD;
}

.point1 .section-title::before {
	border-bottom: 3px solid #fff;
}

.section-title::after {
	border-bottom: 3px solid #ED9458;
}

.section-title-deco {
	font-size: 2rem;
}

.communication .section-title-deco::first-letter {
	color: #FADFCD;
}

.point1 .section-title-deco::first-letter {
	color: #fff;
}

.about .section-title-deco {
	color: #FADFCD;
	left: 50%;
	position: absolute;
	top: -7%;
	transform: translateX(-50%);
}

.communication .section-title-deco {
	bottom: auto;
	color: #FADFCD;
	left: 50%;
	right: auto;
	top: -7%;
	transform: translateX(-50%);
}

.point1 .section-title-deco {
	color: #fff;
	left: 50%;
	top: -1.5%;
	transform: translateX(-50%);
}

.voice .section-title-deco {
	bottom: auto;
	color: #FADFCD;
	left: 50%;
	right: auto;
	top: 1.5%;
	transform: translateX(-50%);
}

.faq .section-title-deco {
	bottom: auto;
	color: #FADFCD;
	font-size: 2rem;
	left: 50%;
	right: auto;
	top: -1.875rem;
	transform: translateX(-50%);
}

.gallery .section-title-deco {
	bottom: auto;
	color: #FADFCD;
	font-size: 2rem;
	left: 50%;
	right: auto;
	top: 1.5%;
	transform: translateX(-50%);
}

.access .section-title-deco {
	color: #FADFCD;
	left: 50%;
	top: -4.5%;
	transform: translateX(-50%);
}

.sns {
	background: transparent url(../images/common-bg_sp.png) no-repeat top center/cover;
	padding: 1.6875rem 0 2.5rem;
}

.sns::before {
	bottom: -11vw;
	height: 21vw;
	top: auto;
	width: 20vw;
}

.sns::after {
	bottom: auto;
	height: 21vw;
	top: -14vw;
	width: 20vw;
}

.sns__title {
	font-size: 1.5rem;
	width: 14.75rem;
}

.sns__title::before {
	border-bottom: 3px solid #FADFCD;
}

.sns__title::after {
	border-bottom: 3px solid #ED9458;
}

.sns__items {
	gap: 0 4%;
	margin: 2.1875rem auto 0;
	max-width: 34.375rem;
	width: 100%;
}

.sns__item a:hover {
	opacity: 1;
	opacity: initial;
}

.voice {
	padding: 2.6875rem 0;
}

.voice .swiper__area {
	margin: 0.9375rem auto 0;
}

.voice .voice__main .swiper-slide {
	height: 100%;
	min-height: 504px;
	width: 310px;
}

.voice .voice__main .slide__img {
	aspect-ratio: 310/352;
}

.voice .voice__main .slide__img img {
	transition: none;
}

.voice .voice__main .slide:hover img {
	transform: none;
}

.voice .voice__main .slide__text {
	padding: 5% 5% 7%;
}

.voice .voice__main .slide__text-head {
	font-size: 1.125rem;
	min-height: 86px;
}

.voice .voice__main .slide__text-bottom {
	grid-template-columns: 49% 51%;
	margin-top: 0;
}

.voice .voice__main .slide__text-name {
	font-size: 1rem;
}

.voice .voice__main .slide__text-btn span {
	font-size: 0.75rem;
}

.voice .voice__main .slide__text-btn span svg {
	height: 0.8em;
	margin-left: 2%;
	transform: rotate(90deg);
	width: 0.5em;
}

.voice__main .swiper__controls {
	height: 100%;
	max-width: none;
	position: absolute;
	top: 0;
	width: 100%;
}

.voice__main .swiper__controls .swiper-button-prev,
.voice__main .swiper__controls .swiper-button-next {
	height: 2.125rem;
	position: absolute;
	top: 250px;
	width: 2.125rem;
}

.voice .voice__main .swiper-button-prev {
	left: 50%;
	transform: translateX(-175px);
}

.voice .voice__main .swiper-button-next {
	right: 50%;
	transform: translateX(170px);
}

.voice .voice__main .swiper-button-prev::after {
	background-image: url(/extra/hyougen/assets/images/attempt-arrow_sp.png);
}

.voice .voice__main .swiper-button-next::after {
	background-image: url(/extra/hyougen/assets/images/attempt-arrow_sp.png);
}

.voice .voice__main .swiper-button-prev::after,
.voice .voice__main .swiper-button-next::after {
	height: 2.125rem;
	width: 2.125rem;
}

.voice .voice__main .swiper-pagination-horizontal {
	bottom: -1.0625rem;
}

.voice .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
	margin: 0 0.375rem;
}

.modal .swiper__controls .swiper-button-prev,
.modal .swiper__controls .swiper-button-next {
	height: 2.375rem;
	width: 2.375rem;
}

}

@media (max-width: 767px) {

:root {
	--sway-distance: 2px; /* 767px參和の貧和嫌 */
}

}

@media (max-width: 375px) {

html {
	font-size: 4.2666666667vw;
}

}

@keyframes fade-in-opacity {

from {
	opacity: 0; /* 頼畠に邑苧 */
}

to {
	opacity: 1; /* 頼畠に燕幣 */
}

}

@keyframes fade-in {

from {
	opacity: 0;
	transform: translateY(50px); /* 兜豚了崔 */
}

to {
	opacity: 1;
	transform: translateY(0);
}

}

@keyframes sway {

0%,100% {
	transform: translateY(0); /* 竃F瘁の了崔を児 */
}

50% {
	transform: translateY(calc(10px * -1));
	transform: translateY(calc(var(--sway-distance) * -1));
}

}

@keyframes fade-in-last {

from {
	opacity: 0;
	transform: translateY(50px); /* 兜豚了崔 */
}

to {
	opacity: 1;
	transform: translateY(0);
}

}


/*# sourceMappingURL=style.css.map */
