/*
Theme Name: Infinity｜博愛会Study Group
Theme URI: 
Author: Wreath Enterprise co.,Ltd.
Author URI: https://wreath-ent.co.jp/
Description: Original Theme of Infinity｜博愛会Study Group
Version: 1.0
License: Wreath Enterprise co.,Ltd.
License URI: https://wreath-ent.co.jp/
Tags: 
Text Domain: 
*/
@charset "UTF-8";

*,
*::before,
*::after {
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
	margin: 0;
	padding: 0;
}

:where([hidden]:not([hidden=until-found])) {
	display: none !important;
}

:where(html) {
	-moz-tab-size: 2;
	  -o-tab-size: 2;
	     tab-size: 2;
	-webkit-text-size-adjust: none;
	color-scheme: dark light;
}

:where(body) {
	line-height: 1.5;
	-webkit-font-smoothing: antialiased;
}

:where(button) {
	all: unset;
}

:where(input,
button,
textarea,
select) {
	font: inherit;
	color: inherit;
}

:where(textarea) {
	resize: vertical;
}

:where(button,
label,
select,
summary,
[role=button],
[role=option]) {
	cursor: pointer;
}

:where(:disabled) {
	cursor: not-allowed;
}

:where(label:has(> input:disabled),
label:has(+ input:disabled)) {
	cursor: not-allowed;
}

:where(a) {
	color: inherit;
	text-underline-offset: 0.2ex;
}

:where(ul,
ol) {
	list-style: none;
}

:where(img,
svg,
video,
canvas,
audio,
iframe,
embed,
object) {
	display: block;
}

:where(img,
picture,
svg,
video) {
	max-inline-size: 100%;
	block-size: auto;
}

:where(p,
h1,
h2,
h3,
h4,
h5,
h6) {
	overflow-wrap: break-word;
}

:where(h1,
h2,
h3 h4) {
	line-height: 1.5;
}

:where(hr) {
	overflow: visible;
	border: none;
	color: inherit;
	-webkit-border-before: 1px solid;
	        border-block-start: 1px solid;
	block-size: 0;
}

:where(:focus-visible,
:target) {
	scroll-margin-block: 8vh;
}

:where(.visually-hidden:not(:focus-within,
:active)) {
	position: absolute !important;
	overflow: hidden !important;
	width: 1px !important;
	height: 1px !important;
	border: 0 !important;
	white-space: nowrap !important;
	-webkit-clip-path: inset(50%) !important;
	        clip-path: inset(50%) !important;
}

html,
body {
	overflow-x: hidden;
}

html {
	margin: 0;
	padding: 0;
	font-size: 62.5%;
	word-wrap: break-word;
}

body {
	position: relative;
	width: 100%;
	height: 100%;
	margin: 0 auto;
	padding-top: 90px;
	background-color: #fff;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 400;
	line-height: 1.5;
	color: #222;
	text-align: left;
	-webkit-text-size-adjust: 100%;
}

img {
	max-width: 100%;
	height: auto;
	background-repeat: no-repeat;
	background-size: cover;
	font-style: italic;
	vertical-align: middle;
	-webkit-shape-margin: 0.75rem;
	        shape-margin: 0.75rem;
}

a {
	color: #222;
	text-decoration: none;
}

.en {
	font-family: "Montserrat", sans-serif;
}

.c-btn--primary {
	position: relative;
	display: -ms-grid;
	display: grid;
	margin: 0 auto;
	border: 2px solid transparent;
	border-radius: 999px;
	background-color: #212121;
	color: #fff;
	-webkit-transition: background-color 0.4s ease, border-color 0.4s ease;
	-moz-transition: background-color 0.4s ease, border-color 0.4s ease;
	transition: background-color 0.4s ease, border-color 0.4s ease;
	place-items: center;
}

.c-btn--primary:hover {
	border-color: #212121;
	background-color: #fff;
	color: #212121;
}

.c-btn--primary:hover::after {
	background-color: #212121;
}

.c-btn--primary::after {
	position: absolute;
	top: 50%;
	display: inline-block;
	background-color: #fff;
	content: "";
	-webkit-transition: background-color 0.4s ease;
	-moz-transition: background-color 0.4s ease;
	transition: background-color 0.4s ease;
	-webkit-transform: translateY(-50%);
	   -moz-transform: translateY(-50%);
	    -ms-transform: translateY(-50%);
	        transform: translateY(-50%);
	aspect-ratio: 12/14;
	-webkit-mask: url("./images/common/btn_arrow.svg") center/contain no-repeat;
	        mask: url("./images/common/btn_arrow.svg") center/contain no-repeat;
}

.c-btn--primary .text {
	position: relative;
	font-weight: 500;
	-webkit-transition: color 0.4s ease;
	-moz-transition: color 0.4s ease;
	transition: color 0.4s ease;
}

.c-heading_section {
	text-align: center;
}

.c-heading_section .jpTitle {
	display: block;
	font-size: clamp(1.3rem, 0.8333333333vw, 1.6rem);
	font-weight: 700;
	color: #222;
}

.c-heading_section .title {
	display: inline-block;
	margin-top: 2px;
	background: -webkit-gradient(linear, left top, right top, color-stop(20%, #000000), color-stop(44%, #ee87b4), color-stop(71%, #000000));
	background: -webkit-linear-gradient(left, #000000 20%, #ee87b4 44%, #000000 71%);
	background: -moz-linear-gradient(left, #000000 20%, #ee87b4 44%, #000000 71%);
	background: linear-gradient(90deg, #000000 20%, #ee87b4 44%, #000000 71%);
	-webkit-background-clip: text;
	font-family: "Montserrat", sans-serif;
	font-size: clamp(2.8rem, 3.3333333333vw, 6.4rem);
	font-weight: 700;
	-webkit-text-fill-color: transparent;
}

.fade-appear {
	opacity: 0;
}

.fade-appear.fade-action {
	-webkit-animation-name: appear;
	   -moz-animation-name: appear;
	        animation-name: appear;
	-webkit-animation-duration: 0.8s;
	   -moz-animation-duration: 0.8s;
	        animation-duration: 0.8s;
	-webkit-animation-timing-function: ease;
	   -moz-animation-timing-function: ease;
	        animation-timing-function: ease;
	-webkit-animation-fill-mode: forwards;
	   -moz-animation-fill-mode: forwards;
	        animation-fill-mode: forwards;
}

.fade-in {
	opacity: 0;
}

.fade-in.fade-action {
	-webkit-animation-name: fade-in;
	   -moz-animation-name: fade-in;
	        animation-name: fade-in;
	-webkit-animation-duration: 0.8s;
	   -moz-animation-duration: 0.8s;
	        animation-duration: 0.8s;
	-webkit-animation-timing-function: ease;
	   -moz-animation-timing-function: ease;
	        animation-timing-function: ease;
	-webkit-animation-fill-mode: forwards;
	   -moz-animation-fill-mode: forwards;
	        animation-fill-mode: forwards;
}

.fade-up {
	opacity: 0;
}

.fade-up.fade-action {
	-webkit-animation-name: fade-up;
	   -moz-animation-name: fade-up;
	        animation-name: fade-up;
	-webkit-animation-duration: 0.8s;
	   -moz-animation-duration: 0.8s;
	        animation-duration: 0.8s;
	-webkit-animation-timing-function: ease;
	   -moz-animation-timing-function: ease;
	        animation-timing-function: ease;
	-webkit-animation-fill-mode: forwards;
	   -moz-animation-fill-mode: forwards;
	        animation-fill-mode: forwards;
}

.fade-right {
	opacity: 0;
}

.fade-right.fade-action {
	-webkit-animation-name: fade-right;
	   -moz-animation-name: fade-right;
	        animation-name: fade-right;
	-webkit-animation-duration: 0.8s;
	   -moz-animation-duration: 0.8s;
	        animation-duration: 0.8s;
	-webkit-animation-timing-function: ease;
	   -moz-animation-timing-function: ease;
	        animation-timing-function: ease;
	-webkit-animation-fill-mode: forwards;
	   -moz-animation-fill-mode: forwards;
	        animation-fill-mode: forwards;
}

.fade-left {
	opacity: 0;
}

.fade-left.fade-action {
	-webkit-animation-name: fade-left;
	   -moz-animation-name: fade-left;
	        animation-name: fade-left;
	-webkit-animation-duration: 0.8s;
	   -moz-animation-duration: 0.8s;
	        animation-duration: 0.8s;
	-webkit-animation-timing-function: ease;
	   -moz-animation-timing-function: ease;
	        animation-timing-function: ease;
	-webkit-animation-fill-mode: forwards;
	   -moz-animation-fill-mode: forwards;
	        animation-fill-mode: forwards;
}

.fade-bg .title {
	position: relative;
	color: transparent;
	-webkit-transition: color 0.1ms 0.35s;
	-moz-transition: color 0.1ms 0.35s;
	transition: color 0.1ms 0.35s;
}

.fade-bg .title::before {
	position: absolute;
	top: 50%;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: var(--c-primary);
	content: "";
	-webkit-transform: translate(101%, -50%);
	   -moz-transform: translate(101%, -50%);
	    -ms-transform: translate(101%, -50%);
	        transform: translate(101%, -50%);
}

.fade-bg.white .title::before {
	background-color: var(--c-white);
}

.fade-bg.fade-action .title {
	color: var(--c-primary);
}

.fade-bg.fade-action .title::before {
	-webkit-animation-name: fade-bg;
	   -moz-animation-name: fade-bg;
	        animation-name: fade-bg;
	-webkit-animation-duration: 1.25s;
	   -moz-animation-duration: 1.25s;
	        animation-duration: 1.25s;
	-webkit-animation-fill-mode: forwards;
	   -moz-animation-fill-mode: forwards;
	        animation-fill-mode: forwards;
}

.fade-bg.fade-action.white .title {
	color: var(--c-white);
}

.fade-cheese {
	opacity: 0;
}

.fade-cheese.fade-action {
	-webkit-animation-name: appear;
	   -moz-animation-name: appear;
	        animation-name: appear;
	-webkit-animation-duration: 0.8s;
	   -moz-animation-duration: 0.8s;
	        animation-duration: 0.8s;
	-webkit-animation-timing-function: ease;
	   -moz-animation-timing-function: ease;
	        animation-timing-function: ease;
	-webkit-animation-fill-mode: forwards;
	   -moz-animation-fill-mode: forwards;
	        animation-fill-mode: forwards;
}

.l-header {
	position: fixed;
	z-index: 200;
	top: 0;
	left: 0;
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	width: 100%;
	padding: 20px clamp(2rem, 2.0833333333vw, 4rem);
	-webkit-transition: background-color 0.3s ease, -webkit-backdrop-filter 0.3s ease;
	transition: background-color 0.3s ease, -webkit-backdrop-filter 0.3s ease;
	-moz-transition: background-color 0.3s ease, backdrop-filter 0.3s ease;
	transition: background-color 0.3s ease, backdrop-filter 0.3s ease;
	transition: background-color 0.3s ease, backdrop-filter 0.3s ease, -webkit-backdrop-filter 0.3s ease; /* ===== PCスクロール時 ===== */ /* ===== TB以下 ===== */
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	   -moz-box-pack: justify;
	    -ms-flex-pack: justify;
	        justify-content: space-between;
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
}

.l-header.is-scrolled {
	padding: 8px clamp(2rem, 2.0833333333vw, 4rem);
	background-color: rgba(255, 255, 255, 0.6);
	-webkit-backdrop-filter: blur(6px);
	        backdrop-filter: blur(6px);
}

.l-header_logo {
	width: clamp(20rem, 15.625vw, 30rem);
}

.l-header_list {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	   -moz-box-pack: justify;
	    -ms-flex-pack: justify;
	        justify-content: space-between;
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	gap: clamp(2rem, 2.6041666667vw, 5rem);
}

.l-header_list a {
	position: relative;
	display: inline-block;
	padding-bottom: 6px;
	font-size: clamp(1.5rem, 0.9375vw, 1.8rem);
	font-weight: 700;
	letter-spacing: 0.07em;
}

.l-header_list a::after {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 1px;
	background-color: currentColor;
	content: "";
	-webkit-transition: -webkit-transform 0.3s ease;
	transition: -webkit-transform 0.3s ease;
	-moz-transition: transform 0.3s ease, -moz-transform 0.3s ease;
	transition: transform 0.3s ease;
	transition: transform 0.3s ease, -webkit-transform 0.3s ease, -moz-transform 0.3s ease;
	-webkit-transform: scaleX(0);
	   -moz-transform: scaleX(0);
	    -ms-transform: scaleX(0);
	        transform: scaleX(0);
	-webkit-transform-origin: left;
	   -moz-transform-origin: left;
	    -ms-transform-origin: left;
	        transform-origin: left;
}

.l-header_list a:hover::after {
	-webkit-transform: scaleX(1);
	   -moz-transform: scaleX(1);
	    -ms-transform: scaleX(1);
	        transform: scaleX(1);
}

.l-header .is-instagram a {
	padding-bottom: 0;
}

.l-header .is-instagram a::after {
	display: none;
}

.l-header .is-instagram a:hover img {
	opacity: 0.6;
	-webkit-transition: opacity 0.3s ease;
	-moz-transition: opacity 0.3s ease;
	transition: opacity 0.3s ease;
}

.l-header .hamburger {
	position: fixed;
	z-index: 100;
	top: 0px;
	right: 0px;
}

.l-header .hamburger_btn {
	position: relative;
	z-index: 999;
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	overflow: hidden;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	   -moz-box-orient: vertical;
	   -moz-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	width: 90px;
	height: 90px;
	background: #2d2d2d;
	cursor: pointer;
	-webkit-transition: 0.3s;
	-moz-transition: 0.3s;
	transition: 0.3s;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	   -moz-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	gap: 8px;
}

.l-header .hamburger_btn span {
	width: 50px;
	height: 2px;
	border-radius: 2px;
	background: #fff;
	-webkit-transition: 0.3s;
	-moz-transition: 0.3s;
	transition: 0.3s;
	-webkit-transform: translateY(4px);
	   -moz-transform: translateY(4px);
	    -ms-transform: translateY(4px);
	        transform: translateY(4px);
}

.l-header .hamburger_btn p {
	margin-top: 2px;
	font-family: "Montserrat", sans-serif;
	font-size: clamp(1.7rem, 2.4390243902vw, 2rem);
	font-weight: 700;
	color: #fff;
}

.l-header .hamburger_btn.active span:nth-child(1) {
	-webkit-transform: rotate(23deg) translate(2px, 4px);
	   -moz-transform: rotate(23deg) translate(2px, 4px);
	    -ms-transform: rotate(23deg) translate(2px, 4px);
	        transform: rotate(23deg) translate(2px, 4px);
}

.l-header .hamburger_btn.active span:nth-child(2) {
	-webkit-transform: rotate(-23deg) translate(2px, -5px);
	   -moz-transform: rotate(-23deg) translate(2px, -5px);
	    -ms-transform: rotate(-23deg) translate(2px, -5px);
	        transform: rotate(-23deg) translate(2px, -5px);
}

.l-header .hamburger_menu {
	position: fixed;
	z-index: 90;
	display: none;
	overflow-y: auto;
	width: 100%;
	height: 100dvh;
	padding: 80px 20px 40px;
	background: #2d2d2d;
	inset: 0;
	-webkit-overflow-scrolling: touch;
}

.l-header .hamburger_menu.open {
	display: block;
	-webkit-animation: fadeIn 0.3s ease;
	   -moz-animation: fadeIn 0.3s ease;
	        animation: fadeIn 0.3s ease;
}

.l-header .hamburger_menu_list {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	   -moz-box-orient: vertical;
	   -moz-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	width: 90%;
	margin: 0 auto;
	margin-bottom: 40px;
	gap: 10%;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	   -moz-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
}

.l-header .hamburger_menu_list li a {
	position: relative;
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	   -moz-box-orient: vertical;
	   -moz-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	padding: 25px 0;
	border-bottom: 1px solid #f5f5f5;
	font-size: 18px;
	font-weight: 500;
	color: #fff;
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	gap: 12px;
}

.l-header .hamburger_menu_list li a::after {
	position: absolute;
	top: 50%;
	display: inline-block;
	background-color: #fff;
	content: "";
	-webkit-transition: background-color 0.4s ease;
	-moz-transition: background-color 0.4s ease;
	transition: background-color 0.4s ease;
	-webkit-transform: translateY(-50%);
	   -moz-transform: translateY(-50%);
	    -ms-transform: translateY(-50%);
	        transform: translateY(-50%);
	aspect-ratio: 12/14;
	-webkit-mask: url("./images/common/btn_arrow.svg") center/contain no-repeat;
	        mask: url("./images/common/btn_arrow.svg") center/contain no-repeat;
}

.l-footer {
	position: relative;
	z-index: 1;
	padding-top: 150px;
	padding-bottom: 20px;
	background-color: #f8f8f8;
}

.l-footer_inner {
	width: 90%;
	max-width: 1300px;
	margin: 0 auto;
}

.l-footer_top {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	   -moz-box-pack: justify;
	    -ms-flex-pack: justify;
	        justify-content: space-between;
	gap: 45px;
}

.l-footer_logo {
	width: 300px;
}

.l-footer_nav {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	   -moz-box-orient: vertical;
	   -moz-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	-webkit-box-align: end;
	-webkit-align-items: flex-end;
	   -moz-box-align: end;
	    -ms-flex-align: end;
	        align-items: flex-end;
}

.l-footer_list {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	margin-bottom: 10px;
	gap: clamp(2rem, 1.5625vw, 3rem);
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	   -moz-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
}

.l-footer_list li a {
	position: relative;
	display: inline-block;
	padding-bottom: 4px;
	font-size: clamp(1.6rem, 0.9375vw, 1.8rem);
	font-weight: 700;
	white-space: nowrap;
}

.l-footer_list li a::after {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 1px;
	background-color: currentColor;
	content: "";
	-webkit-transition: -webkit-transform 0.3s ease;
	transition: -webkit-transform 0.3s ease;
	-moz-transition: transform 0.3s ease, -moz-transform 0.3s ease;
	transition: transform 0.3s ease;
	transition: transform 0.3s ease, -webkit-transform 0.3s ease, -moz-transform 0.3s ease;
	-webkit-transform: scaleX(0);
	   -moz-transform: scaleX(0);
	    -ms-transform: scaleX(0);
	        transform: scaleX(0);
	-webkit-transform-origin: left;
	   -moz-transform-origin: left;
	    -ms-transform-origin: left;
	        transform-origin: left;
}

.l-footer_list li a:hover::after {
	-webkit-transform: scaleX(1);
	   -moz-transform: scaleX(1);
	    -ms-transform: scaleX(1);
	        transform: scaleX(1);
}

.l-footer_list li:last-child {
	-webkit-flex-shrink: 0;
	    -ms-flex-negative: 0;
	        flex-shrink: 0;
}

.l-footer_list img {
	display: block;
	width: 24px;
	height: auto;
}

.l-footer .is-instagram a {
	padding-bottom: 0;
}

.l-footer .is-instagram a::after {
	display: none;
}

.l-footer .is-instagram a:hover img {
	opacity: 0.6;
	-webkit-transition: opacity 0.3s ease;
	-moz-transition: opacity 0.3s ease;
	transition: opacity 0.3s ease;
}

.l-footer_privacy {
	position: relative;
	display: inline-block;
	margin-top: 15px;
	padding-bottom: 3px;
	font-size: 14px;
	font-weight: 500;
}

.l-footer_privacy::after {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 0.5px;
	background-color: currentColor;
	content: "";
	-webkit-transition: -webkit-transform 0.3s ease;
	transition: -webkit-transform 0.3s ease;
	-moz-transition: transform 0.3s ease, -moz-transform 0.3s ease;
	transition: transform 0.3s ease;
	transition: transform 0.3s ease, -webkit-transform 0.3s ease, -moz-transform 0.3s ease;
	-webkit-transform: scaleX(0);
	   -moz-transform: scaleX(0);
	    -ms-transform: scaleX(0);
	        transform: scaleX(0);
	-webkit-transform-origin: left;
	   -moz-transform-origin: left;
	    -ms-transform-origin: left;
	        transform-origin: left;
}

.l-footer_privacy:hover::after {
	-webkit-transform: scaleX(1);
	   -moz-transform: scaleX(1);
	    -ms-transform: scaleX(1);
	        transform: scaleX(1);
}

.l-footer_bottom {
	margin-top: 40px;
	text-align: center;
}

.l-footer_copy {
	font-size: 12px;
}

.cta {
	position: relative;
	height: 590px;
	padding: 80px 0 250px;
	background: url("./images/common/cta.jpg") center/cover no-repeat;
}

.cta_inner {
	position: relative;
	z-index: 2;
	margin: 0 auto;
	padding: 0 42px;
	color: #fff;
	text-align: center;
}

.cta_title {
	margin-bottom: 30px;
	font-size: clamp(3rem, 3.3333333333vw, 6.4rem);
	font-weight: 700;
}

.cta_text {
	font-size: clamp(1.6rem, 0.9375vw, 1.8rem);
	line-height: 2;
}

.cta_box {
	position: relative;
	position: relative;
	z-index: 3;
	z-index: 2;
	width: 90%;
	max-width: 1600px;
	margin: 0 auto;
	margin-top: 80px;
	padding: 50px 0 70px;
	background-color: #fff;
	text-align: center;
}

.cta_lead {
	width: 80%;
	margin: 0 auto;
	margin-bottom: 35px;
	font-size: clamp(1.6rem, 1.0416666667vw, 2rem);
	font-weight: 700;
}

.cta_btn {
	position: relative;
	display: -ms-grid;
	display: grid;
	margin: 0 auto;
	border: 2px solid transparent;
	border-radius: 999px;
	background-color: #212121;
	color: #fff;
	-webkit-transition: background-color 0.4s ease, border-color 0.4s ease;
	-moz-transition: background-color 0.4s ease, border-color 0.4s ease;
	transition: background-color 0.4s ease, border-color 0.4s ease;
	place-items: center;
}

.cta_btn:hover {
	border-color: #212121;
	background-color: #fff;
	color: #212121;
}

.cta_btn:hover::after {
	background-color: #212121;
}

.cta_btn::after {
	position: absolute;
	top: 50%;
	display: inline-block;
	background-color: #fff;
	content: "";
	-webkit-transition: background-color 0.4s ease;
	-moz-transition: background-color 0.4s ease;
	transition: background-color 0.4s ease;
	-webkit-transform: translateY(-50%);
	   -moz-transform: translateY(-50%);
	    -ms-transform: translateY(-50%);
	        transform: translateY(-50%);
	aspect-ratio: 12/14;
	-webkit-mask: url("./images/common/btn_arrow.svg") center/contain no-repeat;
	        mask: url("./images/common/btn_arrow.svg") center/contain no-repeat;
}

.cta_btn .text {
	position: relative;
	font-weight: 500;
	-webkit-transition: color 0.4s ease;
	-moz-transition: color 0.4s ease;
	transition: color 0.4s ease;
}

.home { /* ==============================================
  お知らせ
  ============================================== */ /* ==============================================
  infinityの理念
  ============================================== */ /* ==============================================
  講師紹介
  ============================================== */ /* ==============================================
  料金プラン
  ============================================== */ /* ==============================================
  スケジュール
  ============================================== */ /* ==============================================
  スポンサー
  ============================================== */
}

.home .wrapper {
	width: 90%;
	max-width: 1600px;
	margin: 0 auto;
}

.home .mv {
	position: relative;
	overflow: hidden;
	height: 90vh;
	min-height: 520px;
	background-image: url("./images/home/mv.jpg");
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}

.home .mv_copy {
	position: absolute;
	z-index: 2;
	top: 25%;
	left: 5%;
	color: #fff;
}

.home .mv_copy_main {
	font-family: "Montserrat", sans-serif;
	font-size: clamp(40px, 10vw, 148px);
	font-weight: 700;
	line-height: 1.05;
}

.home .mv_copy_sub {
	margin-top: 20px;
	font-size: clamp(18px, 4.5vw, 60px);
	font-weight: 700;
}

.home .banner {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	padding: 0 30px;
	padding-top: 80px;
	background-color: #f8f8f8;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	   -moz-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
}

.home .banner-link picture img {
	-webkit-transition: opacity 0.3s ease;
	-moz-transition: opacity 0.3s ease;
	transition: opacity 0.3s ease;
}

.home .banner-link picture img:hover {
	opacity: 0.7;
}

.home .news {
	padding: 80px 0 120px;
	background-color: #f8f8f8;
}

.home .news_inner {
	width: 90%;
	max-width: 1600px;
	margin: 0 auto;
	padding: 60px clamp(6rem, 6.25vw, 12rem);
	background-color: #fff;
}

.home .news_head {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	gap: 10px;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	   -moz-box-pack: justify;
	    -ms-flex-pack: justify;
	        justify-content: space-between;
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
}

.home .news_head_right {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-flex-wrap: wrap;
	    -ms-flex-wrap: wrap;
	        flex-wrap: wrap;
}

.home .news_head_right a {
	position: relative;
	display: inline-block;
	padding: 0 clamp(1rem, 0.78125vw, 1.5rem);
	font-size: clamp(1.4rem, 0.8333333333vw, 1.6rem);
	font-weight: 500;
	white-space: nowrap;
}

.home .news_head_right a:not(:last-child)::before {
	position: absolute;
	top: 50%;
	right: 0;
	width: 1px;
	height: 17px;
	background-color: #efefef;
	content: "";
	-webkit-transform: translateY(-50%);
	   -moz-transform: translateY(-50%);
	    -ms-transform: translateY(-50%);
	        transform: translateY(-50%);
}

.home .news_head_right a:hover {
	opacity: 0.6;
	-webkit-transition: opacity 0.3s ease;
	-moz-transition: opacity 0.3s ease;
	transition: opacity 0.3s ease;
}

.home .news_title {
	text-align: left;
}

.home .news_item {
	padding: 35px 0;
	border-bottom: 1px solid #e0e0e0;
	-webkit-transition: opacity 0.3s ease;
	-moz-transition: opacity 0.3s ease;
	transition: opacity 0.3s ease;
}

.home .news_item:hover {
	opacity: 0.7;
}

.home .news_item_inner {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	margin: 0 auto;
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	gap: 20px;
}

.home .news_item_info {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	width: clamp(25rem, 14.5833333333vw, 28rem);
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	gap: 20px;
}

.home .news_item_date {
	min-width: 90px;
	font-family: "Montserrat", sans-serif;
	font-size: clamp(1.6rem, 0.8854166667vw, 1.7rem);
	font-weight: 500;
}

.home .news_item_cat {
	min-width: 140px;
	padding: 4px 10px;
	background-color: #efefef;
	font-size: clamp(1.4rem, 0.78125vw, 1.5rem);
	font-weight: 500;
	text-align: center;
}

.home .news_item_right {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	width: 80%;
	gap: 10px;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	   -moz-box-pack: justify;
	    -ms-flex-pack: justify;
	        justify-content: space-between;
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
}

.home .news_item_text {
	font-size: clamp(1.6rem, 0.9375vw, 1.8rem);
	font-weight: 700;
}

.home .news_btn {
	margin-top: 50px;
}

.home .philosophy {
	height: 1234px;
	padding: clamp(10rem, 7.2916666667vw, 14rem) 0;
	background: url("./images/home/philosophy_back.jpg") center/cover no-repeat;
}

.home .philosophy_title {
	text-align: left;
}

.home .philosophy_inner {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	max-width: 1400px;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	   -moz-box-pack: justify;
	    -ms-flex-pack: justify;
	        justify-content: space-between;
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
}

.home .philosophy_inner .jpTitle {
	display: inline-block;
	background: -webkit-gradient(linear, left top, right top, color-stop(20%, #000000), color-stop(44%, #ee87b4), color-stop(71%, #000000));
	background: -webkit-linear-gradient(left, #000000 20%, #ee87b4 44%, #000000 71%);
	background: -moz-linear-gradient(left, #000000 20%, #ee87b4 44%, #000000 71%);
	background: linear-gradient(90deg, #000000 20%, #ee87b4 44%, #000000 71%);
	-webkit-background-clip: text;
	font-size: clamp(1.8rem, 1.5vw, 2.4rem);
	font-weight: 700;
	-webkit-text-fill-color: transparent;
}

.home .philosophy_inner .title {
	margin-top: 35px;
	background: none;
	-webkit-background-clip: initial;
	font-size: clamp(2.6rem, 3vw, 4.8rem);
	color: #222;
	-webkit-text-fill-color: initial;
}

.home .philosophy_left {
	width: 48%;
}

.home .philosophy_text {
	margin-top: clamp(4rem, 4.6875vw, 9rem);
	font-size: clamp(1.6rem, 0.9375vw, 1.8rem);
	line-height: 1.8;
}

.home .philosophy_text p + p {
	margin-top: 45px;
}

.home .philosophy_image {
	width: 45%;
}

.home .teachers {
	padding-top: clamp(20rem, 20.8333333333vw, 40rem);
	padding-bottom: 120px;
	background-color: #f8f8f8;
	scroll-margin-top: 120px;
}

.home .teachers_inner {
	position: relative;
	margin-top: -700px;
	padding: clamp(6rem, 7.8125vw, 15rem) clamp(4rem, 6.25vw, 12rem);
	background-color: #fff;
}

.home .teachers .c-heading {
	position: absolute;
	z-index: 2;
	top: clamp(-6rem, -4.375vw, -7rem);
	left: 50%;
	-webkit-transform: translateX(-50%);
	   -moz-transform: translateX(-50%);
	    -ms-transform: translateX(-50%);
	        transform: translateX(-50%);
}

.home .teachers_title {
	text-align: center;
}

.home .teachers .c-heading {
	margin-bottom: 100px;
}

.home .teachers_list {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	   -moz-box-orient: vertical;
	   -moz-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	gap: 120px;
}

.home .teachers_item {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	gap: clamp(2rem, 2.6041666667vw, 5rem);
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	   -moz-box-pack: justify;
	    -ms-flex-pack: justify;
	        justify-content: space-between;
}

.home .teachers_item_image {
	position: relative;
	width: 50%;
}

.home .teachers_item_body {
	width: 46%;
	max-width: 729px;
}

.home .teachers_item_role {
	font-size: clamp(1.6rem, 1.0416666667vw, 2rem);
	font-weight: 700;
}

.home .teachers_item_name {
	margin-top: 10px;
	font-size: clamp(3rem, 2.0833333333vw, 4rem);
	font-weight: 700;
}

.home .teachers_item_text {
	margin-top: 30px;
	padding: 15px clamp(1rem, 1.5625vw, 3rem);
	background-color: #f5f5f5;
	font-size: clamp(1.5rem, 0.8854166667vw, 1.7rem);
	line-height: 1.75;
}

.home .teachers_item.is-reverse {
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	-webkit-flex-direction: row-reverse;
	   -moz-box-orient: horizontal;
	   -moz-box-direction: reverse;
	    -ms-flex-direction: row-reverse;
	        flex-direction: row-reverse;
}

.home .teachers_btn {
	margin-top: 120px;
	text-align: center;
}

.home .plans {
	padding: 150px 0;
	background-color: #2b2b2b;
}

.home .plans_title {
	position: relative;
	margin-bottom: 100px;
	text-align: center;
	inset: 0;
}

.home .plans_title .jpTitle {
	position: relative;
	z-index: 2;
	font-size: clamp(2.8rem, 2.5vw, 4.8rem);
	font-weight: 700;
	color: #fff;
}

.home .plans_title .title {
	position: absolute;
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	font-family: "Montserrat", sans-serif;
	font-size: clamp(7rem, 9.1666666667vw, 17.6rem);
	font-weight: 700;
	color: rgba(255, 255, 255, 0.06);
	white-space: nowrap;
	inset: 0;
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	   -moz-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
}

.home .plans_list {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	   -moz-box-pack: justify;
	    -ms-flex-pack: justify;
	        justify-content: space-between;
	gap: clamp(3.5rem, 3.125vw, 6rem);
}

.home .plans_item {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	   -moz-box-orient: vertical;
	   -moz-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	width: 100%;
	padding: 40px clamp(2rem, 3.125vw, 6rem);
	background-color: #fff;
}

.home .plans_item_head {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	border-bottom: 1px solid #c7c7c7;
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	gap: clamp(1.5rem, 1.3020833333vw, 2.5rem);
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	   -moz-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
}

.home .plans_item_num {
	font-family: "Montserrat", sans-serif;
	font-size: clamp(3.5rem, 2.5vw, 4.8rem);
	font-weight: 700;
	color: #ee87b4;
}

.home .plans_item_title {
	padding-bottom: 8px;
	font-size: clamp(2.5rem, 2.0833333333vw, 4rem);
	font-weight: 700;
}

.home .plans_item_image {
	margin-top: 25px;
}

.home .plans_item_image img {
	margin: 0 auto;
}

.home .plans_item_text {
	margin-top: 30px;
	font-size: clamp(1.6rem, 0.9375vw, 1.8rem);
	line-height: 1.8;
}

.home .plans_item_price {
	margin-top: 30px;
	font-weight: 700;
}

.home .plans_item_price div {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	font-size: 16px;
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
}

.home .plans_item_price div + div {
	margin-top: 10px;
}

.home .plans_item_price dt {
	width: clamp(12rem, 7.2916666667vw, 14rem);
	font-size: clamp(1.6rem, 0.9375vw, 1.8rem);
}

.home .plans_item_price dd {
	letter-spacing: 0.05em;
}

.home .plans_item_price dd .num {
	font-size: clamp(2.2rem, 1.6666666667vw, 3.2rem);
}

.home .plans_item_price dd .comma {
	font-size: 20px;
}

.home .plans_item_price dd .num:last-of-type {
	margin-right: 0.08em;
}

.home .plans_item_condition {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	   -moz-box-orient: vertical;
	   -moz-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	height: 80px;
	margin-top: 30px;
	padding: 15px 10px;
	border-radius: 3px;
	background-color: #fae8f0;
	font-size: clamp(1.6rem, 1.0416666667vw, 2rem);
	font-weight: 700;
	text-align: center;
	text-align: left;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	   -moz-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
}

.home .plans_item_condition span {
	font-size: clamp(1.4rem, 0.8333333333vw, 1.6rem);
	font-weight: 400;
}

.home .plans_item_btn {
	width: 100%;
	margin-top: 40px;
}

.home .schedule {
	padding: clamp(8rem, 5.2083333333vw, 10rem) 0;
}

.home .schedule_inner {
	padding: clamp(3rem, 4.1666666667vw, 8rem) clamp(6rem, 6.25vw, 12rem) clamp(3rem, 5.2083333333vw, 10rem);
	border: 1px solid #cecece;
}

.home .schedule_inner h2 {
	margin-bottom: clamp(3rem, 2.34375vw, 4.5rem);
	font-size: clamp(2.8rem, 1.6666666667vw, 3.2rem);
	font-weight: 700;
	text-align: center;
}

.home .schedule_inner img {
	margin: 0 auto;
}

.home .sponsor_inner {
	margin-bottom: 140px;
	padding: clamp(4rem, 5.2083333333vw, 10rem) clamp(4rem, 6.25vw, 12rem);
	background-color: #f7f7f7;
	text-align: center;
}

.home .sponsor_list {
	display: -ms-grid;
	display: grid;
	max-width: 1200px;
	margin: 0 auto;
	margin-top: 45px;
	gap: 10px;
	-ms-grid-columns: (1fr)[4];
	grid-template-columns: repeat(4, 1fr);
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	   -moz-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
}

.home .sponsor_item {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	   -moz-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
}

.home .sponsor_item:nth-child(3n) {
	border-right: none;
}

.home .sponsor_item:nth-last-child(-n+3) {
	border-bottom: none;
}

.home .sponsor_btn {
	margin-top: 60px;
	text-align: center;
}

.p-notFound .error_content {
	max-width: 120rem;
	margin-inline: auto;
}

.p-notFound .error_content_text {
	font-size: clamp(2.2rem, 1.5625vw, 3rem);
	font-weight: 700;
	text-align: center;
	letter-spacing: 0.05em;
}

.p-notFound .error_content .c-btn--primary {
	margin-top: clamp(3.6rem, 9.6vw, 6.2rem);
	margin-inline: auto;
}

.p-privacy {
	padding: 80px 0 120px;
	background-color: #f8f8f8;
	line-height: 2;
}

.p-privacy_inner {
	width: 90%;
	max-width: 1600px;
	margin: 0 auto;
	padding: 60px clamp(6rem, 6.25vw, 12rem);
	background-color: #fff;
}

.p-privacy_title {
	text-align: left;
}

.p-privacy_head {
	margin-top: 30px;
	font-size: clamp(1.6rem, 0.9375vw, 1.8rem);
}

.p-privacy_bgTitle {
	margin-top: 50px;
	margin-bottom: 24px;
	padding-bottom: 12px;
	border-bottom: 1px solid #e0e0e0;
	background-repeat: repeat-x;
	background-position: bottom left;
	background-size: 8px 1px;
	font-size: clamp(2rem, 1.1458333333vw, 2.2rem);
}

.p-privacy_contents {
	margin-top: 40px;
}

.p-privacy_contents_head {
	margin-top: 10px;
	font-size: clamp(1.6rem, 0.9375vw, 1.8rem);
	font-weight: 700;
}

.p-privacy_contents_text {
	font-size: clamp(1.6rem, 0.9375vw, 1.8rem);
	font-weight: 500;
}

.p-privacy_contents_list {
	margin-top: 20px;
	padding-left: 0;
	list-style: none;
}

.p-privacy_contents_list li {
	position: relative;
	padding-left: 1em;
	font-size: clamp(1.6rem, 0.9375vw, 1.8rem);
}

.p-privacy_contents_list li::before {
	position: absolute;
	left: 0;
	content: "・";
}

.p-privacy_contents_list li span {
	display: block;
}

.p-privacy_contents .sub_title {
	margin-top: 20px;
	font-weight: 700;
}

.p-privacy_contents_contact {
	width: 400px;
	margin-top: 20px;
	padding: 25px;
	border: 1px solid #e0e0e0;
}

.p-sponsor {
	background-color: #efefef;
}

.p-sponsor_inner {
	width: 90%;
	max-width: 1300px;
	margin: 0 auto;
	padding: clamp(10rem, 8.3333333333vw, 16rem) 0;
}

.p-sponsor_inner_group {
	margin-top: clamp(6rem, 5.2083333333vw, 10rem);
}

.p-sponsor_inner_group + .p-sponsor_inner_group {
	margin-top: clamp(5rem, 7.2916666667vw, 14rem);
}

.p-sponsor_inner_logo {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	margin-top: 30px;
	-webkit-flex-wrap: wrap;
	    -ms-flex-wrap: wrap;
	        flex-wrap: wrap;
	gap: 10px;
}

.p-sponsor_inner_logo img {
	width: clamp(20rem, 16.4583333333vw, 31.6rem);
}

.p-sponsor_title {
	text-align: left;
}

.p-sponsor h3 {
	border-bottom: 1px solid #7b7b7b;
	font-family: "Montserrat", sans-serif;
	font-size: clamp(2rem, 2.0833333333vw, 4rem);
	font-weight: 700;
}

.news_archive .news {
	padding: 80px 0 120px;
	background-color: #f8f8f8;
}

.news_archive .news_inner {
	width: 90%;
	max-width: 1600px;
	margin: 0 auto;
	padding: 60px clamp(6rem, 6.25vw, 12rem);
	background-color: #fff;
}

.news_archive .news_head {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	gap: 10px;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	   -moz-box-pack: justify;
	    -ms-flex-pack: justify;
	        justify-content: space-between;
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
}

.news_archive .news_head_right {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-flex-wrap: wrap;
	    -ms-flex-wrap: wrap;
	        flex-wrap: wrap;
}

.news_archive .news_head_right a {
	position: relative;
	display: inline-block;
	padding: 0 clamp(1rem, 0.78125vw, 1.5rem);
	font-size: clamp(1.4rem, 0.8333333333vw, 1.6rem);
	font-weight: 500;
	white-space: nowrap;
}

.news_archive .news_head_right a:not(:last-child)::before {
	position: absolute;
	top: 50%;
	right: 0;
	width: 1px;
	height: 17px;
	background-color: #efefef;
	content: "";
	-webkit-transform: translateY(-50%);
	   -moz-transform: translateY(-50%);
	    -ms-transform: translateY(-50%);
	        transform: translateY(-50%);
}

.news_archive .news_head_right a:hover {
	opacity: 0.6;
	-webkit-transition: opacity 0.3s ease;
	-moz-transition: opacity 0.3s ease;
	transition: opacity 0.3s ease;
}

.news_archive .news_title {
	text-align: left;
}

.news_archive .news_item {
	padding: 35px 0;
	border-bottom: 1px solid #e0e0e0;
	-webkit-transition: opacity 0.3s ease;
	-moz-transition: opacity 0.3s ease;
	transition: opacity 0.3s ease;
}

.news_archive .news_item:hover {
	opacity: 0.7;
}

.news_archive .news_item_inner {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	margin: 0 auto;
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	gap: 20px;
}

.news_archive .news_item_info {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	width: clamp(25rem, 14.5833333333vw, 28rem);
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	gap: 20px;
}

.news_archive .news_item_date {
	min-width: 90px;
	font-family: "Montserrat", sans-serif;
	font-size: clamp(1.6rem, 0.8854166667vw, 1.7rem);
	font-weight: 500;
}

.news_archive .news_item_cat {
	min-width: 140px;
	padding: 4px 10px;
	background-color: #efefef;
	font-size: clamp(1.4rem, 0.78125vw, 1.5rem);
	font-weight: 500;
	text-align: center;
}

.news_archive .news_item_right {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	width: 80%;
	gap: 10px;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	   -moz-box-pack: justify;
	    -ms-flex-pack: justify;
	        justify-content: space-between;
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
}

.news_archive .news_item_text {
	font-size: clamp(1.6rem, 0.9375vw, 1.8rem);
	font-weight: 700;
}

.news_archive .news_btn {
	margin-top: 50px;
}

.news_archive_pagination {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	margin-top: 100px;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	   -moz-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
}

.news_archive_pagination .page-numbers {
	display: -webkit-inline-box;
	display: -webkit-inline-flex;
	display: -moz-inline-box;
	display: -ms-inline-flexbox;
	display: inline-flex;
	width: 50px;
	height: 50px;
	margin-right: 20px;
	border: 1px solid #212121;
	font-weight: 700;
	color: #212121;
	text-decoration: none;
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	   -moz-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
}

.news_archive_pagination .page-numbers.current {
	background: #212121;
	color: #fff;
}

.news_archive_pagination .prev,
.news_archive_pagination .next {
	display: none;
}

.news_archive .screen-reader-text {
	display: none;
}

body.news_archive .cta {
	margin-top: 0;
}

.news_detail {
	padding-top: clamp(8rem, 5.2083333333vw, 10rem);
	padding-bottom: 300px;
}

.news_detail_wrapper {
	width: 90%;
	max-width: 850px;
	margin: 0 auto;
}

.news_detail .news_content_ttlBox {
	margin-bottom: clamp(2rem, 2.0833333333vw, 4rem);
	padding: 10px 0;
	border-bottom: 2px solid #ee87b4;
}

.news_detail .news_content_ttlBox h1 {
	margin: 1rem 0;
	font-size: clamp(2.5rem, 2.34375vw, 4.5rem);
}

.news_detail .news_content_inner {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	gap: 1em;
}

.news_detail .news_content_inner .time {
	font-family: "Montserrat", sans-serif;
	font-size: clamp(1.5rem, 0.9375vw, 1.8rem);
	font-weight: 500;
}

.news_detail .news_content_inner .category {
	padding: 1px 12px;
	background: #f8f8f8;
	font-size: clamp(1.5rem, 0.8854166667vw, 1.7rem);
}

.news_detail .news_content_thumbnail {
	margin-bottom: 2rem;
}

.news_detail .news_content_thumbnail img {
	display: block;
	width: 100%;
	height: auto;
}

.news_detail .news_content .news_text {
	margin-top: 0;
	padding-top: 0;
	font-size: clamp(1.6rem, 0.9375vw, 1.8rem);
	font-weight: 500;
}

.news_detail .news_content .news_text h2 {
	padding: 7px 20px;
	background: #f8f8f8;
	font-size: clamp(2.2rem, 1.5625vw, 3rem);
}

.news_detail .news_content .news_text h2 + h2,
.news_detail .news_content .news_text h2 + h3,
.news_detail .news_content .news_text h2 + h4,
.news_detail .news_content .news_text h2 + p,
.news_detail .news_content .news_text h2 + ul,
.news_detail .news_content .news_text h2 + ol,
.news_detail .news_content .news_text h2 + .wp-block-image {
	margin-top: 40px;
}

.news_detail .news_content .news_text h3 {
	position: relative;
	padding: 15px 20px;
	border-bottom: solid 2px #dedede;
	font-size: 25px;
}

.news_detail .news_content .news_text h3::after {
	position: absolute;
	bottom: -3px;
	left: 0;
	display: block;
	width: 20%;
	border-bottom: solid 2px #ee87b4;
	content: " ";
}

.news_detail .news_content .news_text h3 + h2,
.news_detail .news_content .news_text h3 + h3,
.news_detail .news_content .news_text h3 + h4,
.news_detail .news_content .news_text h3 + p,
.news_detail .news_content .news_text h3 + ul,
.news_detail .news_content .news_text h3 + ol,
.news_detail .news_content .news_text h3 + .wp-block-image {
	margin-top: 4.8rem;
}

.news_detail .news_content .news_text h4 {
	padding: 0.4em 0.7em;
	border-left: solid 4px #ee87b4;
	border-radius: 5px;
	background: #fff8f8;
	font-size: 20px;
	line-height: 1.8;
}

.news_detail .news_content .news_text h4 + h2,
.news_detail .news_content .news_text h4 + h3,
.news_detail .news_content .news_text h4 + h4,
.news_detail .news_content .news_text h4 + p,
.news_detail .news_content .news_text h4 + ul,
.news_detail .news_content .news_text h4 + ol,
.news_detail .news_content .news_text h4 + .wp-block-image {
	margin-top: 4.8rem;
}

.news_detail .news_content .news_text p {
	font-weight: 500;
	line-height: 2;
}

.news_detail .news_content .news_text p + h2,
.news_detail .news_content .news_text p + h3,
.news_detail .news_content .news_text p + h4,
.news_detail .news_content .news_text p + p,
.news_detail .news_content .news_text p + ul,
.news_detail .news_content .news_text p + ol,
.news_detail .news_content .news_text p + .wp-block-image {
	margin-top: 40px;
}

.news_detail .news_content .news_text > ul + p,
.news_detail .news_content .news_text > ul + h2,
.news_detail .news_content .news_text > ul + h3,
.news_detail .news_content .news_text > ul + h4,
.news_detail .news_content .news_text > ul + ul,
.news_detail .news_content .news_text > ul + ol,
.news_detail .news_content .news_text > ul + .wp-block-image,
.news_detail .news_content .news_text > ol + p,
.news_detail .news_content .news_text > ol + h2,
.news_detail .news_content .news_text > ol + h3,
.news_detail .news_content .news_text > ol + h4,
.news_detail .news_content .news_text > ol + ul,
.news_detail .news_content .news_text > ol + ol,
.news_detail .news_content .news_text > ol + .wp-block-image {
	margin-top: 40px;
}

.news_detail .news_content .news_text > ul li {
	position: relative;
	padding-left: 1em;
	list-style: none;
	line-height: 2.2;
}

.news_detail .news_content .news_text > ul li::before {
	position: absolute;
	top: 0.8em;
	left: 0;
	width: 0.45em;
	height: 0.45em;
	border-radius: 50%;
	background-color: #ee87b4;
	content: "";
}

.news_detail .news_content .news_text > ol {
	position: relative;
	margin-left: 0;
	padding-left: 0;
	list-style: none;
	line-height: 2.2;
	counter-reset: num;
}

.news_detail .news_content .news_text > ol > li {
	position: relative;
	padding-left: 1.2em;
	counter-increment: num;
}

.news_detail .news_content .news_text > ol > li::before {
	position: absolute;
	top: 0;
	left: 0;
	font-size: 16px;
	font-weight: 700;
	line-height: inherit;
	color: #ee87b4;
	content: counter(num) ".";
}

.news_detail .news_content .news_text > .wp-block-image + h2,
.news_detail .news_content .news_text > .wp-block-image + h3,
.news_detail .news_content .news_text > .wp-block-image + h4,
.news_detail .news_content .news_text > .wp-block-image + p,
.news_detail .news_content .news_text > .wp-block-image + ul,
.news_detail .news_content .news_text > .wp-block-image + ol,
.news_detail .news_content .news_text > .wp-block-image + .wp-block-image {
	margin-top: 4.8rem;
}

.news_detail .news_content .news_text .wp-element-button {
	background-color: #ffe34d;
	font-weight: 700;
	color: #444;
}

.news_detail_btn {
	margin: 0 auto;
	margin-top: 100px;
}

.news_detail_btn a {
	color: #fff;
}

.news_detail_btn:hover {
	border-color: #212121;
	background-color: #fff;
	color: #212121;
}

.news_detail_btn:hover a {
	color: #212121;
}

.news_detail_btn:hover::after {
	background-color: #212121;
}

@media (prefers-reduced-motion: no-preference) {

:where(html:focus-within) {
	scroll-behavior: smooth;
}

}

@media screen and (min-width: 577px) {

body {
	font-size: 1.6rem;
}

.sp-only {
	display: none;
}

.sp-escape {
	display: block;
}

.p-notFound .error_content_text {
	line-height: 1.8;
}

}

@media screen and (max-width: 820px) and (min-width: 577px) {

.tab-only {
	display: block;
}

.tab-escape {
	display: none;
}

}

@media screen and (min-width: 821px) {

.pc-only {
	display: block;
}

.pc-escape {
	display: none;
}

.tab-only {
	display: none;
}

.tab-escape {
	display: block;
}

.c-btn--primary {
	width: clamp(26rem, 16.9270833333vw, 32.5rem);
	padding: 2.5rem 4.6rem;
}

.c-btn--primary::after {
	right: clamp(0rem, 2.0833333333vw, 3.2rem);
	width: clamp(1.2rem, 1.1727912432vw, 1.5rem);
}

.c-btn--primary .text {
	font-size: clamp(1.8rem, 1.5637216575vw, 2rem);
}

.cta_btn {
	width: clamp(50rem, 36.4583333333vw, 70rem);
	padding: 3rem 4.6rem;
}

.cta_btn::after {
	right: clamp(0rem, 2.0833333333vw, 3.2rem);
	width: clamp(1.2rem, 1.1727912432vw, 1.5rem);
}

.cta_btn .text {
	font-size: clamp(1.8rem, 1.5637216575vw, 2rem);
}

.p-notFound .error {
	padding: 15rem clamp(3.2rem, 3.7529319781vw, 4.8rem) clamp(10.4rem, 31.2744331509vw, 40rem);
}

}

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

.cta br {
	display: none;
}

.home .teachers {
	padding-top: 120px;
}

.home .teachers .c-heading {
	top: clamp(-5rem, -4.6875vw, -6rem);
}

}

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

.home .mv_copy {
	top: 35%;
}

.home .teachers_item {
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	   -moz-box-orient: vertical;
	   -moz-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
}

.home .teachers_item_image {
	width: 100%;
}

.home .teachers_item_image img {
	margin: 0 auto;
}

.home .teachers_item_body {
	width: 100%;
}

.home .teachers_item.is-reverse {
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	   -moz-box-orient: vertical;
	   -moz-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
}

.home .plans_list {
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	   -moz-box-orient: vertical;
	   -moz-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
}

.home .plans_item {
	padding: 40px;
}

.home .schedule_inner {
	padding: clamp(3rem, 4.1666666667vw, 8rem);
}

}

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

body {
	padding-top: 0;
}

.pc-only {
	display: none;
}

.pc-escape {
	display: block;
}

.c-btn--primary {
	width: clamp(26rem, 36.5853658537vw, 30rem);
	padding: clamp(1.5rem, 5.3333333333vw, 2rem) clamp(4rem, 10.6666666667vw, 7.4rem);
}

.c-btn--primary::after {
	right: clamp(0rem, 4.8vw, 5rem);
	width: clamp(1.6rem, 2.1951219512vw, 1.8rem);
}

.c-btn--primary .text {
	font-size: clamp(1.6rem, 1.9512195122vw, 1.6rem);
}

.l-header {
	position: relative;
	padding: 24px 0 24px 20px;
	background: transparent;
	-webkit-backdrop-filter: none;
	        backdrop-filter: none;
}

.l-header.is-scrolled {
	padding: 24px 0 24px 20px;
	background: transparent;
	-webkit-backdrop-filter: none;
	        backdrop-filter: none;
}

.l-header .hamburger_menu_list li a {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: normal;
	-webkit-flex-direction: row;
	   -moz-box-orient: horizontal;
	   -moz-box-direction: normal;
	    -ms-flex-direction: row;
	        flex-direction: row;
	-webkit-box-align: center;
	-webkit-align-items: center;
	   -moz-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	gap: 10px;
}

.l-header .hamburger_menu_list li a::after {
	right: clamp(0rem, 1.3333333333vw, 5rem);
	width: clamp(1.6rem, 2.1951219512vw, 1.8rem);
}

.l-footer_top {
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	   -moz-box-orient: vertical;
	   -moz-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
}

.cta {
	height: 600px;
	background: url("./images/common/cta_sp.jpg") center/cover no-repeat;
}

.cta_text {
	text-align: left;
}

.cta_btn {
	width: clamp(26rem, 36.5853658537vw, 30rem);
	padding: clamp(1.5rem, 5.3333333333vw, 2rem) clamp(2rem, 10.6666666667vw, 4rem);
}

.cta_btn::after {
	right: clamp(0rem, 4.8vw, 5rem);
	width: clamp(1.6rem, 2.1951219512vw, 1.8rem);
}

.cta_btn .text {
	font-size: clamp(1.6rem, 1.9512195122vw, 1.6rem);
}

.home .mv {
	height: 60vh;
	min-height: auto;
	background-image: url("./images/home/mv_sp.jpg");
	background-position: center;
}

.home .mv_copy {
	top: auto;
	bottom: 10%;
}

.home .news_head {
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	   -moz-box-orient: vertical;
	   -moz-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	gap: 40px;
}

.home .news_head_right {
	-webkit-flex-wrap: wrap;
	    -ms-flex-wrap: wrap;
	        flex-wrap: wrap;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	   -moz-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
	gap: 10px 0;
}

.home .news_title {
	text-align: center;
}

.home .news_item_inner {
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	   -moz-box-orient: vertical;
	   -moz-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	-webkit-box-align: baseline;
	-webkit-align-items: baseline;
	   -moz-box-align: baseline;
	    -ms-flex-align: baseline;
	        align-items: baseline;
}

.home .news_item_cat {
	min-width: auto;
}

.home .news_item_right {
	width: 100%;
}

.home .philosophy_title {
	text-align: center;
}

.home .philosophy_inner {
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	   -moz-box-orient: vertical;
	   -moz-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	gap: 30px;
}

.home .philosophy_inner .jpTitle {
	display: block;
}

.home .philosophy_inner .title {
	margin-top: 25px;
}

.home .philosophy_left {
	width: 100%;
}

.home .philosophy_text {
	margin-top: 45px;
}

.home .philosophy_text p + p {
	margin-top: 30px;
}

.home .philosophy_image {
	width: 100%;
}

.home .teachers_inner {
	margin-top: 0px;
	padding: 80px 40px 40px;
}

.home .teachers .c-heading {
	top: -40px;
}

.home .teachers_list {
	gap: 60px;
}

.home .plans {
	padding: 60px 0;
}

.home .plans_title {
	margin-bottom: 50px;
}

.home .plans_title .title {
	font-size: clamp(4rem, 12.1527777778vw, 7rem);
}

.home .schedule_inner_sp {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	   -moz-box-orient: vertical;
	   -moz-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	gap: 30px;
}

.home .sponsor_list {
	-ms-grid-columns: (1fr)[2];
	grid-template-columns: repeat(2, 1fr);
}

.p-notFound .error {
	padding: clamp(23rem, 36.5853658537vw, 40rem) clamp(2rem, 5.3333333333vw, 3.2rem) clamp(30rem, 12.8048780488vw, 10.5rem);
}

.p-privacy_title {
	text-align: center;
}

.p-privacy_head {
	font-size: clamp(1.4rem, 1.9512195122vw, 1.6rem);
}

.p-privacy_bgTitle {
	font-size: clamp(1.6rem, 2.4390243902vw, 2rem);
}

.p-privacy_contents_head {
	font-size: clamp(1.6rem, 2.4390243902vw, 2rem);
}

.p-privacy_contents_text {
	font-size: clamp(1.4rem, 1.9512195122vw, 1.6rem);
}

.p-privacy_contents_list li {
	font-size: clamp(1.4rem, 1.9512195122vw, 1.6rem);
}

.news_archive .news_head {
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	   -moz-box-orient: vertical;
	   -moz-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	gap: 40px;
}

.news_archive .news_head_right {
	-webkit-flex-wrap: wrap;
	    -ms-flex-wrap: wrap;
	        flex-wrap: wrap;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	   -moz-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
	gap: 10px 0;
}

.news_archive .news_title {
	text-align: center;
}

.news_archive .news_item_inner {
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	   -moz-box-orient: vertical;
	   -moz-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	-webkit-box-align: baseline;
	-webkit-align-items: baseline;
	   -moz-box-align: baseline;
	    -ms-flex-align: baseline;
	        align-items: baseline;
}

.news_archive .news_item_cat {
	min-width: auto;
}

.news_archive .news_item_right {
	width: 100%;
}

.news_detail {
	padding-top: clamp(4rem, 9.756097561vw, 8rem);
}

.news_detail .news_content_ttlBox h1 {
	font-size: clamp(1.6rem, 2.4390243902vw, 2rem);
}

.news_detail .news_content_inner .time {
	font-size: clamp(1.3rem, 1.8292682927vw, 1.5rem);
}

.news_detail .news_content_inner .category {
	font-size: clamp(1.3rem, 1.8292682927vw, 1.5rem);
}

.news_detail .news_content .news_text {
	font-size: clamp(1.4rem, 1.9512195122vw, 1.6rem);
}

.news_detail .news_content .news_text .has-fixed-layout td {
	font-size: clamp(1.2rem, 1.7073170732vw, 1.4rem);
}

.news_detail_btn {
	margin-top: clamp(4rem, 9.756097561vw, 8rem);
}

}

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

body {
	font-size: 1.4rem;
}

.tab-only {
	display: none;
}

.tab-escape {
	display: block;
}

.sp-only {
	display: block;
}

.sp-escape {
	display: none;
}

.l-header {
	padding: 18px 0 18px 20px;
}

.l-header_logo {
	width: 180px;
}

.l-header .hamburger_btn {
	width: 75px;
	height: 75px;
}

.l-header .hamburger_btn span {
	width: 42px;
}

.l-footer {
	padding-top: 80px;
}

.l-footer_list {
	-webkit-flex-wrap: wrap;
	    -ms-flex-wrap: wrap;
	        flex-wrap: wrap;
}

.l-footer_list li a {
	font-size: 14px;
}

.l-footer_privacy {
	font-size: 12px;
}

.cta {
	height: 500px;
	padding: 50px 0 250px;
}

.cta_title {
	font-size: 22px;
}

.cta_text {
	font-size: 14px;
}

.cta_box {
	margin-top: 50px;
	padding: 30px 0 30px;
}

.cta_lead {
	margin-bottom: 15px;
	font-size: 14px;
	text-align: left;
}

.home .mv_copy {
	top: auto;
	bottom: 8%;
	left: 7%;
}

.home .mv_copy_main {
	font-size: clamp(4rem, 12.1527777778vw, 7rem);
	line-height: 1.2;
}

.home .banner {
	padding-top: 40px;
}

.home .news {
	padding: 40px 0 40px;
}

.home .news_inner {
	padding: 30px;
}

.home .news_head_right {
	display: none;
}

.home .news_item {
	padding: 20px 0;
}

.home .news_item:first-child {
	padding-top: 40px;
}

.home .news_item_info {
	gap: 10px;
}

.home .news_item_date {
	min-width: 85px;
	font-size: 15px;
}

.home .news_item_cat {
	padding: 2px 5px;
	font-size: 13px;
}

.home .news_item_text {
	font-size: 14px;
}

.home .news_btn {
	margin-top: 30px;
}

.home .philosophy {
	padding: 50px 0;
}

.home .philosophy_inner .title {
	font-size: 24px;
}

.home .philosophy_text p + p {
	margin-top: 20px;
}

.home .teachers {
	padding-top: 90px;
	padding-bottom: 60px;
}

.home .teachers_inner {
	margin-top: -400px;
	padding: 60px 20px 40px;
}

.home .teachers_item_role {
	font-size: 14px;
}

.home .teachers_item_name {
	font-size: 22px;
}

.home .teachers_item_text {
	margin-top: 15px;
	font-size: 13px;
}

.home .plans_item {
	padding: 20px;
}

.home .plans_item_num {
	font-size: 25px;
}

.home .plans_item_title {
	padding-bottom: 5px;
	font-size: 20px;
}

.home .plans_item_text {
	font-size: 14px;
}

.home .plans_item_price div {
	font-size: 14px;
}

.home .plans_item_price dt {
	font-size: 14px;
}

.home .plans_item_condition {
	height: 90px;
	font-size: 14px;
}

.home .plans_item_condition span {
	font-size: 12px;
}

.home .plans_item_btn {
	width: clamp(26rem, 36.5853658537vw, 30rem);
}

.home .schedule {
	padding: 40px 0;
}

.home .schedule_inner h2 {
	margin-bottom: 25px;
	font-size: 22px;
}

.home .schedule_inner {
	padding: 20px;
}

.home .sponsor_inner {
	margin-bottom: 60px;
	padding: 60px 20px;
}

.home .sponsor_list {
	margin-top: 30px;
}

.home .sponsor_btn {
	margin-top: 30px;
}

.p-notFound .error_content_text {
	font-size: clamp(1.4rem, 3.7333333333vw, 1.8rem);
	line-height: 1.5;
}

.p-privacy {
	padding: 40px 0 40px;
	line-height: 1.6;
}

.p-privacy_inner {
	padding: 30px;
}

.p-privacy_bgTitle {
	margin-top: 30px;
}

.p-privacy_contents {
	margin-top: 30px;
}

.p-privacy_contents_contact {
	width: 100%;
	margin-right: auto;
	margin-left: auto;
	padding: 20px;
}

.p-sponsor_inner {
	padding: 40px 0;
}

.p-sponsor_inner_group {
	margin-top: 30px;
}

.p-sponsor_inner_logo {
	display: -ms-grid;
	display: grid;
	-webkit-flex-wrap: nowrap;
	    -ms-flex-wrap: nowrap;
	        flex-wrap: nowrap;
	-ms-grid-columns: (1fr)[2];
	grid-template-columns: repeat(2, 1fr);
}

.p-sponsor_inner_logo img {
	width: clamp(16rem, 10.4166666667vw, 20rem);
}

.news_archive .news {
	padding: 40px 0 40px;
}

.news_archive .news_inner {
	padding: 30px;
}

.news_archive .news_item {
	padding: 20px 0;
}

.news_archive .news_item:first-child {
	padding-top: 60px;
}

.news_archive .news_item_info {
	gap: 10px;
}

.news_archive .news_item_date {
	min-width: 85px;
	font-size: 15px;
}

.news_archive .news_item_cat {
	padding: 2px 5px;
	font-size: 13px;
}

.news_archive .news_item_text {
	font-size: 14px;
}

.news_archive .news_btn {
	margin-top: 30px;
}

.news_archive_pagination {
	margin-top: 50px;
}

.news_archive_pagination .page-numbers {
	width: 30px;
	height: 30px;
}

.news_detail {
	padding-top: 40px;
}

.news_detail .news_content .news_text h2 {
	padding: 7px;
	font-size: clamp(1.5rem, 3.125vw, 1.8rem);
}

.news_detail .news_content .news_text h2 + h2,
.news_detail .news_content .news_text h2 + h3,
.news_detail .news_content .news_text h2 + h4,
.news_detail .news_content .news_text h2 + p,
.news_detail .news_content .news_text h2 + ul,
.news_detail .news_content .news_text h2 + ol,
.news_detail .news_content .news_text h2 + .wp-block-image {
	margin-top: 2rem;
}

.news_detail .news_content .news_text h3 {
	padding: 7px;
	font-size: clamp(1.5rem, 3.125vw, 1.8rem);
}

.news_detail .news_content .news_text h3 + h2,
.news_detail .news_content .news_text h3 + h3,
.news_detail .news_content .news_text h3 + h4,
.news_detail .news_content .news_text h3 + p,
.news_detail .news_content .news_text h3 + ul,
.news_detail .news_content .news_text h3 + ol,
.news_detail .news_content .news_text h3 + .wp-block-image {
	margin-top: 2rem;
}

.news_detail .news_content .news_text h4 {
	padding: 7px;
	font-size: clamp(1.5rem, 3.125vw, 1.8rem);
}

.news_detail .news_content .news_text h4 + h2,
.news_detail .news_content .news_text h4 + h3,
.news_detail .news_content .news_text h4 + h4,
.news_detail .news_content .news_text h4 + p,
.news_detail .news_content .news_text h4 + ul,
.news_detail .news_content .news_text h4 + ol,
.news_detail .news_content .news_text h4 + .wp-block-image {
	margin-top: 2rem;
}

.news_detail .news_content .news_text p + h2,
.news_detail .news_content .news_text p + h3,
.news_detail .news_content .news_text p + h4,
.news_detail .news_content .news_text p + p,
.news_detail .news_content .news_text p + ul,
.news_detail .news_content .news_text p + ol,
.news_detail .news_content .news_text p + .wp-block-image {
	margin-top: 2rem;
	line-height: 1.6;
}

.news_detail .news_content .news_text > ul + p,
.news_detail .news_content .news_text > ul + h2,
.news_detail .news_content .news_text > ul + h3,
.news_detail .news_content .news_text > ul + h4,
.news_detail .news_content .news_text > ul + ul,
.news_detail .news_content .news_text > ul + ol,
.news_detail .news_content .news_text > ul + .wp-block-image,
.news_detail .news_content .news_text > ol + p,
.news_detail .news_content .news_text > ol + h2,
.news_detail .news_content .news_text > ol + h3,
.news_detail .news_content .news_text > ol + h4,
.news_detail .news_content .news_text > ol + ul,
.news_detail .news_content .news_text > ol + ol,
.news_detail .news_content .news_text > ol + .wp-block-image {
	margin-top: 2rem;
}

.news_detail .news_content .news_text > ul li {
	line-height: 2;
}

.news_detail .news_content .news_text > ol > li {
	line-height: 2;
}

.news_detail .news_content .news_text > ol > li::before {
	font-size: 14px;
}

.news_detail .news_content .news_text > .wp-block-image + h2,
.news_detail .news_content .news_text > .wp-block-image + h3,
.news_detail .news_content .news_text > .wp-block-image + h4,
.news_detail .news_content .news_text > .wp-block-image + p,
.news_detail .news_content .news_text > .wp-block-image + ul,
.news_detail .news_content .news_text > .wp-block-image + ol,
.news_detail .news_content .news_text > .wp-block-image + .wp-block-image {
	margin-top: 2rem;
}

.news_detail .news_content .news_text .wp-element-button {
	font-size: 15px;
}

.single .l-header .circle_image {
	display: none;
}

}

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

.l-footer {
	padding-top: 140px;
}

.home .plans_item_price div {
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-webkit-flex-direction: column;
	   -moz-box-orient: vertical;
	   -moz-box-direction: normal;
	    -ms-flex-direction: column;
	        flex-direction: column;
	-webkit-box-align: baseline;
	-webkit-align-items: baseline;
	   -moz-box-align: baseline;
	    -ms-flex-align: baseline;
	        align-items: baseline;
}

.home .plans_item_price div + div {
	margin-top: 20px;
}

}

@-webkit-keyframes fade-in {

0% {
	opacity: 0;
	-webkit-transform: translateY(25px);
	        transform: translateY(25px);
}

100% {
	opacity: 1;
	-webkit-transform: translateY(0);
	        transform: translateY(0);
}

}

@-moz-keyframes fade-in {

0% {
	opacity: 0;
	-moz-transform: translateY(25px);
	     transform: translateY(25px);
}

100% {
	opacity: 1;
	-moz-transform: translateY(0);
	     transform: translateY(0);
}

}

@keyframes fade-in {

0% {
	opacity: 0;
	-webkit-transform: translateY(25px);
	   -moz-transform: translateY(25px);
	        transform: translateY(25px);
}

100% {
	opacity: 1;
	-webkit-transform: translateY(0);
	   -moz-transform: translateY(0);
	        transform: translateY(0);
}

}

@-webkit-keyframes fade-up {

0% {
	opacity: 0;
	-webkit-transform: translateY(-25px);
	        transform: translateY(-25px);
}

100% {
	opacity: 1;
	-webkit-transform: translateY(0);
	        transform: translateY(0);
}

}

@-moz-keyframes fade-up {

0% {
	opacity: 0;
	-moz-transform: translateY(-25px);
	     transform: translateY(-25px);
}

100% {
	opacity: 1;
	-moz-transform: translateY(0);
	     transform: translateY(0);
}

}

@keyframes fade-up {

0% {
	opacity: 0;
	-webkit-transform: translateY(-25px);
	   -moz-transform: translateY(-25px);
	        transform: translateY(-25px);
}

100% {
	opacity: 1;
	-webkit-transform: translateY(0);
	   -moz-transform: translateY(0);
	        transform: translateY(0);
}

}

@-webkit-keyframes fade-right {

0% {
	opacity: 0;
	-webkit-transform: translateX(25px);
	        transform: translateX(25px);
}

100% {
	opacity: 1;
	-webkit-transform: translateX(0);
	        transform: translateX(0);
}

}

@-moz-keyframes fade-right {

0% {
	opacity: 0;
	-moz-transform: translateX(25px);
	     transform: translateX(25px);
}

100% {
	opacity: 1;
	-moz-transform: translateX(0);
	     transform: translateX(0);
}

}

@keyframes fade-right {

0% {
	opacity: 0;
	-webkit-transform: translateX(25px);
	   -moz-transform: translateX(25px);
	        transform: translateX(25px);
}

100% {
	opacity: 1;
	-webkit-transform: translateX(0);
	   -moz-transform: translateX(0);
	        transform: translateX(0);
}

}

@-webkit-keyframes fade-left {

0% {
	opacity: 0;
	-webkit-transform: translateX(-25px);
	        transform: translateX(-25px);
}

100% {
	opacity: 1;
	-webkit-transform: translateX(0);
	        transform: translateX(0);
}

}

@-moz-keyframes fade-left {

0% {
	opacity: 0;
	-moz-transform: translateX(-25px);
	     transform: translateX(-25px);
}

100% {
	opacity: 1;
	-moz-transform: translateX(0);
	     transform: translateX(0);
}

}

@keyframes fade-left {

0% {
	opacity: 0;
	-webkit-transform: translateX(-25px);
	   -moz-transform: translateX(-25px);
	        transform: translateX(-25px);
}

100% {
	opacity: 1;
	-webkit-transform: translateX(0);
	   -moz-transform: translateX(0);
	        transform: translateX(0);
}

}

@-webkit-keyframes fade-bg {

0% {
	-webkit-transform: translate(-101%, -50%);
	        transform: translate(-101%, -50%);
}

50% {
	-webkit-transform: translateX(0, -50%);
	        transform: translateX(0, -50%);
}

100% {
	-webkit-transform: translate(101%, -50%);
	        transform: translate(101%, -50%);
}

}

@-moz-keyframes fade-bg {

0% {
	-moz-transform: translate(-101%, -50%);
	     transform: translate(-101%, -50%);
}

50% {
	-moz-transform: translateX(0, -50%);
	     transform: translateX(0, -50%);
}

100% {
	-moz-transform: translate(101%, -50%);
	     transform: translate(101%, -50%);
}

}

@keyframes fade-bg {

0% {
	-webkit-transform: translate(-101%, -50%);
	   -moz-transform: translate(-101%, -50%);
	        transform: translate(-101%, -50%);
}

50% {
	-webkit-transform: translateX(0, -50%);
	   -moz-transform: translateX(0, -50%);
	        transform: translateX(0, -50%);
}

100% {
	-webkit-transform: translate(101%, -50%);
	   -moz-transform: translate(101%, -50%);
	        transform: translate(101%, -50%);
}

}

@-webkit-keyframes appear {

0% {
	opacity: 0;
}

100% {
	opacity: 1;
}

}

@-moz-keyframes appear {

0% {
	opacity: 0;
}

100% {
	opacity: 1;
}

}

@keyframes appear {

0% {
	opacity: 0;
}

100% {
	opacity: 1;
}

}

@-webkit-keyframes disappear {

0% {
	opacity: 1;
}

100% {
	opacity: 0;
}

}

@-moz-keyframes disappear {

0% {
	opacity: 1;
}

100% {
	opacity: 0;
}

}

@keyframes disappear {

0% {
	opacity: 1;
}

100% {
	opacity: 0;
}

}

@-webkit-keyframes sway {

0%,100% {
	-webkit-transform: rotate(10deg);
	        transform: rotate(10deg);
}

50% {
	-webkit-transform: rotate(-10deg);
	        transform: rotate(-10deg);
}

}

@-moz-keyframes sway {

0%,100% {
	-moz-transform: rotate(10deg);
	     transform: rotate(10deg);
}

50% {
	-moz-transform: rotate(-10deg);
	     transform: rotate(-10deg);
}

}

@keyframes sway {

0%,100% {
	-webkit-transform: rotate(10deg);
	   -moz-transform: rotate(10deg);
	        transform: rotate(10deg);
}

50% {
	-webkit-transform: rotate(-10deg);
	   -moz-transform: rotate(-10deg);
	        transform: rotate(-10deg);
}

}

@-webkit-keyframes ver-hol {

0% {
	-webkit-transform: translate(10px, 10px) rotate(4deg);
	        transform: translate(10px, 10px) rotate(4deg);
}

50% {
	-webkit-transform: translate(-10px, -10px) rotate(-8deg);
	        transform: translate(-10px, -10px) rotate(-8deg);
}

100% {
	-webkit-transform: translate(10px, 10px) rotate(4deg);
	        transform: translate(10px, 10px) rotate(4deg);
}

}

@-moz-keyframes ver-hol {

0% {
	-moz-transform: translate(10px, 10px) rotate(4deg);
	     transform: translate(10px, 10px) rotate(4deg);
}

50% {
	-moz-transform: translate(-10px, -10px) rotate(-8deg);
	     transform: translate(-10px, -10px) rotate(-8deg);
}

100% {
	-moz-transform: translate(10px, 10px) rotate(4deg);
	     transform: translate(10px, 10px) rotate(4deg);
}

}

@keyframes ver-hol {

0% {
	-webkit-transform: translate(10px, 10px) rotate(4deg);
	   -moz-transform: translate(10px, 10px) rotate(4deg);
	        transform: translate(10px, 10px) rotate(4deg);
}

50% {
	-webkit-transform: translate(-10px, -10px) rotate(-8deg);
	   -moz-transform: translate(-10px, -10px) rotate(-8deg);
	        transform: translate(-10px, -10px) rotate(-8deg);
}

100% {
	-webkit-transform: translate(10px, 10px) rotate(4deg);
	   -moz-transform: translate(10px, 10px) rotate(4deg);
	        transform: translate(10px, 10px) rotate(4deg);
}

}

@-webkit-keyframes hol-ver {

0% {
	-webkit-transform: translate(-10px, -10px) rotate(12deg);
	        transform: translate(-10px, -10px) rotate(12deg);
}

50% {
	-webkit-transform: translate(10px, 10px) rotate(-6deg);
	        transform: translate(10px, 10px) rotate(-6deg);
}

100% {
	-webkit-transform: translate(-10px, -10px) rotate(12deg);
	        transform: translate(-10px, -10px) rotate(12deg);
}

}

@-moz-keyframes hol-ver {

0% {
	-moz-transform: translate(-10px, -10px) rotate(12deg);
	     transform: translate(-10px, -10px) rotate(12deg);
}

50% {
	-moz-transform: translate(10px, 10px) rotate(-6deg);
	     transform: translate(10px, 10px) rotate(-6deg);
}

100% {
	-moz-transform: translate(-10px, -10px) rotate(12deg);
	     transform: translate(-10px, -10px) rotate(12deg);
}

}

@keyframes hol-ver {

0% {
	-webkit-transform: translate(-10px, -10px) rotate(12deg);
	   -moz-transform: translate(-10px, -10px) rotate(12deg);
	        transform: translate(-10px, -10px) rotate(12deg);
}

50% {
	-webkit-transform: translate(10px, 10px) rotate(-6deg);
	   -moz-transform: translate(10px, 10px) rotate(-6deg);
	        transform: translate(10px, 10px) rotate(-6deg);
}

100% {
	-webkit-transform: translate(-10px, -10px) rotate(12deg);
	   -moz-transform: translate(-10px, -10px) rotate(12deg);
	        transform: translate(-10px, -10px) rotate(12deg);
}

}

@-webkit-keyframes floating-right {

0% {
	-webkit-transform: translate(-10px, -5px) rotate(-6deg);
	        transform: translate(-10px, -5px) rotate(-6deg);
}

50% {
	-webkit-transform: translate(10px, 10px) rotate(6deg);
	        transform: translate(10px, 10px) rotate(6deg);
}

100% {
	-webkit-transform: translate(-10px, -5px) rotate(-6deg);
	        transform: translate(-10px, -5px) rotate(-6deg);
}

}

@-moz-keyframes floating-right {

0% {
	-moz-transform: translate(-10px, -5px) rotate(-6deg);
	     transform: translate(-10px, -5px) rotate(-6deg);
}

50% {
	-moz-transform: translate(10px, 10px) rotate(6deg);
	     transform: translate(10px, 10px) rotate(6deg);
}

100% {
	-moz-transform: translate(-10px, -5px) rotate(-6deg);
	     transform: translate(-10px, -5px) rotate(-6deg);
}

}

@keyframes floating-right {

0% {
	-webkit-transform: translate(-10px, -5px) rotate(-6deg);
	   -moz-transform: translate(-10px, -5px) rotate(-6deg);
	        transform: translate(-10px, -5px) rotate(-6deg);
}

50% {
	-webkit-transform: translate(10px, 10px) rotate(6deg);
	   -moz-transform: translate(10px, 10px) rotate(6deg);
	        transform: translate(10px, 10px) rotate(6deg);
}

100% {
	-webkit-transform: translate(-10px, -5px) rotate(-6deg);
	   -moz-transform: translate(-10px, -5px) rotate(-6deg);
	        transform: translate(-10px, -5px) rotate(-6deg);
}

}

@-webkit-keyframes floating-left {

0% {
	-webkit-transform: translate(10px, 10px) rotate(12deg);
	        transform: translate(10px, 10px) rotate(12deg);
}

50% {
	-webkit-transform: translate(-20px, -20px) rotate(-12deg);
	        transform: translate(-20px, -20px) rotate(-12deg);
}

100% {
	-webkit-transform: translate(10px, 10px) rotate(12deg);
	        transform: translate(10px, 10px) rotate(12deg);
}

}

@-moz-keyframes floating-left {

0% {
	-moz-transform: translate(10px, 10px) rotate(12deg);
	     transform: translate(10px, 10px) rotate(12deg);
}

50% {
	-moz-transform: translate(-20px, -20px) rotate(-12deg);
	     transform: translate(-20px, -20px) rotate(-12deg);
}

100% {
	-moz-transform: translate(10px, 10px) rotate(12deg);
	     transform: translate(10px, 10px) rotate(12deg);
}

}

@keyframes floating-left {

0% {
	-webkit-transform: translate(10px, 10px) rotate(12deg);
	   -moz-transform: translate(10px, 10px) rotate(12deg);
	        transform: translate(10px, 10px) rotate(12deg);
}

50% {
	-webkit-transform: translate(-20px, -20px) rotate(-12deg);
	   -moz-transform: translate(-20px, -20px) rotate(-12deg);
	        transform: translate(-20px, -20px) rotate(-12deg);
}

100% {
	-webkit-transform: translate(10px, 10px) rotate(12deg);
	   -moz-transform: translate(10px, 10px) rotate(12deg);
	        transform: translate(10px, 10px) rotate(12deg);
}

}

@-webkit-keyframes swiper-animation {

0% {
	-webkit-transform: translateX(0%);
	        transform: translateX(0%);
}

100% {
	-webkit-transform: translateX(-100%);
	        transform: translateX(-100%);
}

}

@-moz-keyframes swiper-animation {

0% {
	-moz-transform: translateX(0%);
	     transform: translateX(0%);
}

100% {
	-moz-transform: translateX(-100%);
	     transform: translateX(-100%);
}

}

@keyframes swiper-animation {

0% {
	-webkit-transform: translateX(0%);
	   -moz-transform: translateX(0%);
	        transform: translateX(0%);
}

100% {
	-webkit-transform: translateX(-100%);
	   -moz-transform: translateX(-100%);
	        transform: translateX(-100%);
}

}

