/* --------------------------------------------------------------------------------
misc
-------------------------------------------------------------------------------- */

br.small {
	display: inline;
}
br.large {
	display: none;
}
img.small {
	display: block;
}
img.large {
	display: none;
}
span.no-small {
	display: none;
}



/* --------------------------------------------------------------------------------
page
-------------------------------------------------------------------------------- */

body:not(.home) div#page {
	padding-top: 0px;
}
div.grecaptcha-badge {
	bottom: 100px !important;
}



/* --------------------------------------------------------------------------------
header
-------------------------------------------------------------------------------- */

header#header :where(*#logo, p#button-menu) {
	transition: 0.25s transform ease;
}
div.scroll header#header :where(*#logo, p#button-menu) {
	transform: translateY(-60px);
}
div.scroll-up header#header :where(*#logo, p#button-menu),
div.menu-header header#header :where(*#logo, p#button-menu) {
	transform: translateY(0px);
}
header#header *#logo {
	height: 60px;
	z-index: 10;
	padding: 0px 0px 2.5px 15px;
}
body.admin-bar header#header *#logo {
	top: 0px;
}
header#header *#logo img {
	width: calc(362px * 0.475);
}
header#header :where(p#button-menu, div#menu) {
	position: fixed;
}
header#header p#button-menu {
	width: 60px;
	height: 60px;
	right: 0px;
	top: 0px;
	z-index: 30;
	cursor: pointer;
}
header#header p#button-menu i {
	display: block;
	position: absolute;
	width: 30px;
	height: 0px;
	left: calc(50% - 15px);
	top: calc(50% - 1px);
	border-bottom: 2px solid #9d9d9d;
	transition: 0.25s all ease;
}
header#header p#button-menu i:nth-child(1) {
	transform: translateY(-8px);
}
header#header p#button-menu i:nth-child(2) {
	transform: translateY(8px);
}
div.menu-header header#header p#button-menu i:nth-child(-n+3) {
	width: 0px;
	left: 50%;
	opacity: 0;
	transform: translateY(0px);
}
div.menu-header header#header p#button-menu i:nth-child(4) {
	transform: rotate(30deg);
}
div.menu-header header#header p#button-menu i:nth-child(5) {
	transform: rotate(-30deg);
}
header#header div#menu {
	width: 100%;
	height: 100%;
	right: 0px;
	top: 0px;
	overflow: auto;
	z-index: 10;
	background-color: #ffffff;
	transform: translateX(100%);
	transition: 0.25s transform ease;
	-webkit-overflow-scrolling: touch;
}
div.menu-header header#header div#menu {
	transform: translateX(0%);
}
header#header div#menu::-webkit-scrollbar {
	display: none;
}
header#header div#menu div.inner-menu {
	padding: 40px 30px;
}
header#header nav#navi {
	position: static;
	width: 280px;
	right: auto;
	top: auto;
	margin: 0px auto 20px auto;
}
body.admin-bar header#header nav#navi {
	top: auto;
}
header#header nav#navi > ul {
	display: block;
	padding-left: 20px;
}
header#header nav#navi > ul > li:not(:last-child) {
	margin-right: 0px;
}
header#header nav#navi > ul > li:not(.recruit) {
	margin-bottom: 10px;
}
header#header nav#navi > ul > li:where(.home, .news, .document, .recruit) {
	display: block;
}
header#header nav#navi > ul > li.contact {
	display: none;
}
header#header nav#navi > ul > li > a {
	display: flex;
	flex-wrap: wrap;
}
header#header nav#navi > ul > li span.illust {
	display: none;
}
header#header nav#navi > ul > li div.nest {
	display: block;
	padding-left: 20px;
}
header#header nav#navi > ul > li div.nest ul {
	display: flex;
	flex-wrap: wrap;
	margin-bottom: -5px;
}
header#header nav#navi > ul > li div.nest ul li {
	position: relative;
	font-size: 0.875rem;
	font-weight: 400;
	line-height: 1.5rem;
	margin-bottom: 5px;
	padding-left: 15px;
}
header#header nav#navi > ul > li div.nest ul li:not(:last-child) {
	margin-right: 30px;
}
header#header nav#navi > ul > li div.nest ul li::before {
	position: absolute;
	width: 5px;
	height: 7px;
	left: 0px;
	top: 9.5px;
	background-color: #555555;
	content: "";
	clip-path: polygon(0% 0%, 100% 50%, 0% 100%);
}
header#header div.button-wrapper {
	display: block;
}
header#header p.button-default {
	font-size: 1rem;
}
header#header p.button-default:not(:last-child) {
	margin-bottom: 20px;
}
header#header p.button-default a {
	width: 280px;
	height: 65px;
	color: #555555;
	border-color: #9d9d9d;
	border-radius: 32.5px;
}
header#header p.button-default a:hover {
	background-color: #efefef;
}

/* home
-------------------------------------------------------------------------------- */

body.home header#header *#logo {
	transition: 0.25s background-color ease, 1.25s opacity ease-in-out, 0.25s transform ease;
}
body.home header#header p#button-menu {
	opacity: 0;
	transition: 1.25s opacity ease-in-out, 0.25s transform ease;
}
body.home div.cover-02 header#header p#button-menu {
	opacity: 1;
}
body.home header#header nav#navi {
	pointer-events: auto;
	opacity: 1;
	transition: none;
}



/* --------------------------------------------------------------------------------
cover
-------------------------------------------------------------------------------- */

div#cover {
	min-height: 0px;
}
body.admin-bar #cover {
	height: 100svh;
}
body.admin-bar div#cover div.main-wrapper {
	padding-top: 0px;
}
div#cover div.main {
	position: relative;
	aspect-ratio: 0.5;
	width: auto;
	height: 50%;
}
@media (min-aspect-ratio:1.5) {
div#cover div.main {
	width: auto;
	height: 50%;
}
}
@media (min-aspect-ratio:0.5) {
div#cover div.main {
	width: 50%;
	height: auto;
}
}
div#cover div.main p.illust-01 {
	width: calc(60% * 1.375);
	right: 60%;
	bottom: 40%;
}
div#cover div.main p.illust-02 {
	width: calc(64% * 1.375);
	left: 12%;
	bottom: 40%;
}
div#cover div.main p.illust-03 {
	width: calc(43% * 1.375);
	left: 60%;
	bottom: 36%;
}
div#cover div.main p.illust-04 {
	width: calc(67% * 1.375);
	left: -35%;
	top: 54%;
}
div#cover div.main p.illust-05 {
	width: calc(121% * 2.5);
	min-width: 0px;
	left: auto;
	right: -20%;
	top: 54%;
}
div#cover div.main p.illust-06 {
	width: calc(92% * 1.625);
	left: -52%;
	top: 73%;
}
div#cover div.main p.illust-07 {
	width: calc(40% * 1.875);
	left: 37%;
	top: 83%;
}
div#cover div.main p.illust-07 img {
	transform: rotate(-10deg);
}
div#cover div.main h1 {
	top: 27.5%;
	font-size: 1.5rem;
	line-height: 2.5rem;
}
div#cover div.sub {
	height: 90px;
}
div#cover div.sub::before {
	mask-position: 75% top;
	mask-size: 137.5% 100%;
}
div#cover div.sub p.illust-01 {
	width: calc(43% * 1.75);
	left: -21%;
	bottom: 15%;
}
div#cover div.sub p.illust-02 {
	width: calc(12% * 1.5);
	right: 15%;
	top: -25%;
}
@media (orientation:landscape) {
div#cover div.main p.illust-01 {
	bottom: 23%;
}
div#cover div.main p.illust-02 {
	bottom: 21%;
}
div#cover div.main p.illust-03 {
	bottom: 12.5%;
}
div#cover div.main h1 {
	top: 15%;
}
}
div#cover div.sub p#button-scroll {
	display: none;
}



/* --------------------------------------------------------------------------------
title
-------------------------------------------------------------------------------- */

body:has(div#space-title) div#title,
div#space-title {
	height: 760px;
}
body:has(div#space-title) div#title {
	top: 0px;
}
body:has(div#space-title).admin-bar div#title {
	top: 0px;
}
body:has(div#space-title) div#title p.image {
	height: 500px;
	top: auto;
	bottom: 0px;
	transition-delay: 0.5s;
}
body:not(:has(div#space-title)) div#title h1 {
	padding-top: 100px;
}
body:has(div#space-title) div#title h1 {
	display: block;
	position: static;
	width: auto;
	height: 260px;
	left: auto;
	top: auto;
	padding-top: 100px;
	background-color: transparent;
	border-radius: 0px;
}



/* --------------------------------------------------------------------------------
main
-------------------------------------------------------------------------------- */

body:has(div#space-title) main section:first-child::before,
main section.cloud::before {
	height: 90px;
	top: -88px;
	mask-position: 75% top;
	mask-size: 137.5% 100%;
}
main section div.inner-section {
	width: auto;
	padding: 80px 30px;
}
main section.cloud div.inner-section {
	padding-top: 40px;
}
main section:where(:last-child, .cloud-top) div.inner-section {
	padding-bottom: 170px;
}
body.single main section div.inner-section {
	width: auto;
}
main nav#navi-sub ul {
	display: block;
}
main nav#navi-sub ul li {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
main nav#navi-sub ul li:not(:last-child) {
	margin: 0px 0px 20px 0px;
}
main div.block:not(:last-child) {
	margin-bottom: 80px;
}
main div.slide:has(div.caption) {
	display: block;
}
main div.banner-wrapper {
	padding: 60px 0px 110px 0px;
}
main div.banner {
	width: 240px;
}
main div.banner p.image {
	width: auto;
}
main div.banner div.text {
	width: 100%;
	padding: 20px 0px;
}
main article.common header {
	margin-bottom: 40px;
}
main article.common header h1 {
	margin-bottom: 20px;
}
main :where(div#pager, nav#navi-article) {
	margin-top: 60px;
}
main nav#navi-article ul {
	width: 240px;
}
main nav#navi-article ul:has(li.prev),
main nav#navi-article ul:has(li.next) {
	padding-top: 70px;
}
main nav#navi-article ul li.next a::after {
	margin-left: 10px;
}

/* home
-------------------------------------------------------------------------------- */

main section#home-misc div.inner-section {
	padding-left: 0px;
	padding-right: 0px;
	padding-top: 40px;
}
main section#home-misc div.block {
	display: block;
	margin-left: -40px;
	margin-right: -40px;
	padding-top: 40px;
}
main section#home-misc div.block:not(:last-child) {
	margin-bottom: 80px;
}
main section#home-misc div.block div.text {
	width: auto;
	margin-bottom: 60px;
	padding-top: 0px;
}
main section#home-misc div.block div.text div.headline-description {
	margin-bottom: 40px;
}
main section#home-misc div.block div.text div.headline-description h2.headline {
	transition-delay: 0s;
}
main section#home-misc div.block div.text div.headline-description p.description {
	transition-delay: 0.25s;
}
main section#home-misc div.block div.text p.button-default {
	transition-delay: 0.5s;
}
main section#home-misc div.block:not(.block-scene) div.slide {
	width: calc(100vw + 80px);
	max-width: 480px;
	margin: 0px auto;
	transition-delay: 0.75s;
}
main section#home-misc div.block-about p.illust {
	width: calc(118px * 0.75);
	left: auto;
	right: calc(50% + 80px);
	top: 200px;
	bottom: auto;
}
main section#home-misc div.block-feature p.illust {
	width: calc(117px * 0.75);
	left: calc(50% + 50px);
	right: auto;
	top: 340px;
	bottom: auto;
}
main section#home-misc div.block-class p.illust {
	width: calc(68px * 0.75);
	left: calc(50% - 20px);
	top: 350px;
}
main section#home-misc div.block-class div.text div.headline-description {
	margin-bottom: 120px;
}
main section#home-letter-news div.block-wrapper {
	display: block;
	margin-right: 0px;
}
main section#home-letter-news div.block-letter {
	width: auto;
	margin-bottom: 80px;
}
main section#home-letter-news div.block-letter p.illust {
	left: calc(50% - 130px);
	top: -20px;
}
main section#home-letter-news div.block-letter div.header {
	width: auto;
}
main section#home-letter-news div.block-letter div.slide div.list {
	margin-right: -30px;
	padding-bottom: 40px;
}
main section#home-letter-news div.block-letter div.slide.active-alternate p.line {
	display: none;
}
main section#home-letter-news div.block-letter div.slide.active-alternate p.number {
	display: flex;
	position: absolute;
	left: 110px;
	bottom: -45px;
}
main section#home-letter-news p.more {
	width: auto;
	transform: translateY(12.5px);
}
main section#home-letter-news div.block-news {
	width: auto;
	margin-top: 0px;
	padding-top: 0px;
	padding-bottom: 80px;
	transform: translateX(0px);
}
main section#home-letter-news div.block-news p.illust-01 {
	width: calc(50px * 0.75);
	left: calc(50% - 20px);
	bottom: 20px;
}
main section#home-letter-news div.block-news p.illust-02 {
	width: calc(183px * 0.75);
	left: calc(50% - 100px);
	bottom: -60px;
}

/* about
-------------------------------------------------------------------------------- */

main section:where(#concept, #outline) div.inner-section {
	width: auto;
}
main section#concept div.inner-section {
	padding-top: 40px;
}
main section#concept div:where(.block-basic, .block-childcare) p.description {
	margin-left: -30px;
	margin-right: -30px;
}
main section#concept div.inner-section > p.illust {
	right: 30px;
}
main section#concept div:where(.block-basic, .block-childcare) {
	padding-bottom: 120px;
}
main section#concept div.block-basic p.illust {
	width: calc(118px * 0.875);
	left: calc(50% - 50px);
	top: 220px;
}
main section#concept div.block-childcare p.illust-01 {
	width: calc(87px * 0.46875);
	right: calc(50% + 112.5px);
	top: 180px;
}
main section#concept div.block-childcare p.illust-02 {
	width: calc(87px * 0.75);
	right: calc(50% + 30px);
	top: 205px;
}
main section#concept div.block-goal {
	margin-left: 0px;
	margin-right: 0px;
}
main section#concept div.block-goal div.list {
	display: block;
	margin-right: 0px;
}
main section#concept div.block-goal div.list div.row {
	aspect-ratio: auto;
	width: auto;
	margin-right: 0px;
	padding: 40px 20px;
	border-radius: 20px;
}
main section#concept div.block-goal div.list div.row:not(:last-child) {
	margin-bottom: 20px;
}
main section#outline div.list div.row {
	display: block;
	padding: 20px 0px;
	text-align: center;
}
main section#outline div.list div.row p.label {
	width: auto;
	margin-bottom: 10px;
}
main section#outline div.list div.row p.body {
	width: auto;
}
main section#access div.column {
	display: block;
}
main section#access div.column div:where(.left, .right) {
	width: auto;
}
main section#access div.column div.left {
	margin-bottom: 60px;
}

/* feature
-------------------------------------------------------------------------------- */

main section#initiative div.inner-section {
	padding-top: 40px;
}
main section#initiative div.inner-section > p.illust {
	right: 30px;
}
main section#initiative div.block {
	display: block;
}
main section#initiative div.block div.body div.text :where(p.number, h3, p.sub) {
	text-align: center;
}
main section#initiative div.block div.body div.text p.number {
	font-size: 2rem;
	line-height: 2.75rem;
}
main section#initiative div.block-01 {
	margin-left: 0px;
	padding-bottom: 80px;
}
main section#initiative div.block-01 div.body {
	width: auto;
}
main section#initiative div.block-01 p.image {
	width: auto;
	margin-bottom: 30px;
}
main section#initiative div.block-01 p.illust {
	width: calc(113px * 0.75);
	left: auto;
	right: 10px;
	top: auto;
	bottom: -20px;
}
main section#initiative div.block-01 div.body {
	margin-top: 0px;
}
main section#initiative div.block-02 {
	margin-right: 0px;
}
main section#initiative div:where(.block-02, .block-03) p.image {
	aspect-ratio: 585 / 405;
	width: auto;
}
main section#initiative div:where(.block-02, .block-03) p.image img {
	object-fit: cover;
	width: 100%;
	height: 100%;
}
main section#initiative div.block-02 p.image {
	margin: 0px 0px 30px 0px;
}
main section#initiative div:where(.block-02, .block-03) div.body {
	width: auto;
}
main section#initiative div.block-02 div.body {
	margin-top: 0px;
}
main section#initiative div.block-03 {
	margin-left: 0px;
}
main section#initiative div.block-03 p.image {
	margin: 0px 0px 30px 0px;
}
main section#initiative div.block-03 div.body div.text {
	margin-bottom: 40px;
}
main section#initiative div.block-03 div.body p.image-01 {
	position: static;
	width: calc(100% - 80px);
	left: auto;
	top: auto;
	margin-bottom: 20px;
}
main section#initiative div.block-03 div.body p.image-02 {
	width: calc(100% - 80px);
	margin-right: 0px;
}
main section:where(#initiative-alternate, #support) div.inner-section {
	width: auto;
}
main section:where(#initiative-alternate, #support) div.list {
	margin: 0px 0px -40px 0px;
}
main section:where(#initiative-alternate, #support) div.list div.row {
	width: 100%;
	margin: 0px 0px 40px 0px;
}

/* class
-------------------------------------------------------------------------------- */

main section#class div.inner-section {
	width: auto;
	padding-top: 40px;
}
main section#class header {
	margin-bottom: 80px;
}
main section#class header p.illust {
	right: 30px;
	top: -90px;
}
main section#class h2.headline {
	margin-bottom: 40px;
}
main section#class div.block {
	display: block;
}
main section#class div.block div:where(.text, .slide) {
	margin-bottom: 40px;
}
main section#class div.block div.text {
	width: auto;
}
main section#class div.block div.text div.list {
	margin-bottom: 0px;
}
main section#class div.block div.text p.description {
	display: none;
}
main section#class div.block div.slide {
	width: auto;
}
main section#class div.block div.text-alternate {
	display: block;
}
main section#facility div.inner-section {
	padding-bottom: 180px;
}
main section#facility p.illust-01 {
	right: 110px;
	top: auto;
	bottom: 80px;
}
main section#facility p.illust-02 {
	right: 30px;
	top: auto;
	bottom: 20px;
}
main section#facility p.map {
	margin-bottom: 60px;
	padding: 40px 0px;
}
main section#facility p.map img {
	width: 100%;
	max-width: 256px;
}
main section#facility div.slide div.image {
	aspect-ratio: 1;
	width: auto;
	margin-bottom: 20px;
}
main section#facility div.slide div.caption {
	width: auto;
}
main section#facility div.slide div.caption p.row span.place {
	margin-bottom: 20px;
}
main section#facility div.slide :where(div.pager, p.number) {
	top: calc(calc(100vw - 60px) + 20px);
	bottom: auto;
}
main section#facility div.slide div.pager {
	left: auto;
	right: 60px;
}
main section#facility div.slide div.pager p.button {
	top: 0px;
	bottom: auto;
}
main section#facility div.slide p.number {
	left: auto;
	right: 0px;
}

/* schedule
-------------------------------------------------------------------------------- */

main section#day div.inner-section {
	width: auto;
	padding-top: 40px;
}
main section#day header {
	margin-bottom: 80px;
}
main section#day header p.illust {
	right: 30px;
	top: -90px;
}
main section#day div.block {
	margin-left: -30px;
	margin-right: -30px;
	padding: 60px 30px;
	border-radius: 0px;
}
main section#day div.block:not(:last-child) {
	margin-bottom: 0px;
}
main section#day div.block-02:not(:last-child) {
	margin-bottom: 80px;
}
main section#day div.block-03 {
	padding: 0px 30px;
}
main section#day div.block p.description {
	text-align: justify;
}
main section#day div.block div.slide div.image {
	width: auto;
	margin-bottom: 20px;
}
main section#day div.block div.slide div.caption {
	width: auto;
	padding-top: 0px;
}
main section#day div.block div.slide div.caption-alternate {
	width: auto;
}
main section#day div.block div.slide div.caption-alternate p.row {
	padding: 0px;
}
main section#day div.block div.slide :where(div.pager, p.number) {
	top: calc(calc(calc(100vw - 60px) * calc(315 / 520)) + 20px);
	bottom: auto;
}
main section#day div.block div.slide div.pager {
	left: auto;
	right: 60px;
}
main section#day div.block div.slide p.number {
	left: auto;
	right: 0px;
}
main section#day div.block-01 p.illust-01 {
	left: 50px;
	right: auto;
	top: 70px;
}
main section#day div.block-01 p.illust-02 {
	left: 90px;
	right: auto;
	top: -30px;
}
main section#day div.block-01 p.illust-03 {
	right: 40px;
	left: auto;
	top: auto;
	bottom: 10px;
}
main section#day div.block-02 p.illust-01 {
	left: 30px;
	right: auto;
	top: 40px;
}
main section#day div.block-02 p.illust-02 {
	left: auto;
	right: 30px;
	top: auto;
	bottom: 0px;
}
main section#day div.block-02 p.illust-03 {
	left: auto;
	right: 110px;
	top: auto;
	bottom: -30px;
}
main section#event p.description {
	margin-bottom: 40px;
}
main section#event div.block div.image {
	margin: 0px -30px 40px -30px;
}
main section#event div.block:nth-child(2n) div.image div.inner-image {
	margin-left: 0px;
}
main section#event div.block div.image-01 div.inner-image {
	animation: event-01 calc(12.5s * 1) linear infinite forwards;
}
main section#event div.block div.image-02 div.inner-image {
	animation: event-02 calc(12.5s * 2) linear infinite forwards;
}
main section#event div.block div.image-03 div.inner-image {
	animation: event-03 calc(12.5s * 3) linear infinite forwards;
}
main section#event div.block div.image-04 div.inner-image {
	animation: event-04 calc(12.5s * 4) linear infinite forwards;
}
main section#event div.block div.image-05 div.inner-image {
	animation: event-05 calc(12.5s * 5) linear infinite forwards;
}
main section#event div.block div.image-06 div.inner-image {
	animation: event-06 calc(12.5s * 6) linear infinite forwards;
}
main section#event div.block div.image-07 div.inner-image {
	animation: event-07 calc(12.5s * 7) linear infinite forwards;
}
main section#event div.block div.image-08 div.inner-image {
	animation: event-08 calc(12.5s * 8) linear infinite forwards;
}
main section#event div.block div.image-09 div.inner-image {
	animation: event-09 calc(12.5s * 9) linear infinite forwards;
}
main section#event div.block div.image-10 div.inner-image {
	animation: event-10 calc(12.5s * 10) linear infinite forwards;
}
main section#event div.block div.image-11 div.inner-image {
	animation: event-11 calc(12.5s * 11) linear infinite forwards;
}
main section#event div.block div.image-12 div.inner-image {
	animation: event-12 calc(12.5s * 12) linear infinite forwards;
}
main section#event div.block div.image-13 div.inner-image {
	animation: event-13 calc(12.5s * 13) linear infinite forwards;
}
main section#event div.block div.image-14 div.inner-image {
	animation: event-14 calc(12.5s * 14) linear infinite forwards;
}
main section#event div.block div.image-15 div.inner-image {
	animation: event-15 calc(12.5s * 15) linear infinite forwards;
}
@keyframes event-01 {
	0% { transform: translateX(0px); }
	100% { transform: translateX(calc(-310px * 1)); }
}
@keyframes event-02 {
	0% { transform: translateX(0px); }
	100% { transform: translateX(calc(-310px * 2)); }
}
@keyframes event-03 {
	0% { transform: translateX(0px); }
	100% { transform: translateX(calc(-310px * 3)); }
}
@keyframes event-04 {
	0% { transform: translateX(0px); }
	100% { transform: translateX(calc(-310px * 4)); }
}
@keyframes event-05 {
	0% { transform: translateX(0px); }
	100% { transform: translateX(calc(-310px * 5)); }
}
@keyframes event-06 {
	0% { transform: translateX(0px); }
	100% { transform: translateX(calc(-310px * 6)); }
}
@keyframes event-07 {
	0% { transform: translateX(0px); }
	100% { transform: translateX(calc(-310px * 7)); }
}
@keyframes event-08 {
	0% { transform: translateX(0px); }
	100% { transform: translateX(calc(-310px * 8)); }
}
@keyframes event-09 {
	0% { transform: translateX(0px); }
	100% { transform: translateX(calc(-310px * 9)); }
}
@keyframes event-10 {
	0% { transform: translateX(0px); }
	100% { transform: translateX(calc(-310px * 10)); }
}
@keyframes event-11 {
	0% { transform: translateX(0px); }
	100% { transform: translateX(calc(-310px * 11)); }
}
@keyframes event-12 {
	0% { transform: translateX(0px); }
	100% { transform: translateX(calc(-410px * 12)); }
}
@keyframes event-13 {
	0% { transform: translateX(0px); }
	100% { transform: translateX(calc(-410px * 13)); }
}
@keyframes event-14 {
	0% { transform: translateX(0px); }
	100% { transform: translateX(calc(-410px * 14)); }
}
@keyframes event-15 {
	0% { transform: translateX(0px); }
	100% { transform: translateX(calc(-410px * 15)); }
}
main section#event div.block div.image p.row {
	width: 305px;
}
main section#event div.block div.text,
main section#event div.block div.text div.list:has(div.row:nth-child(2)) {
	display: block;
}
main section#event div.block div.text {
	margin-right: 0px;
}
main section#event div.block div.text h3 {
	width: auto;
	font-size: 2.5rem;
	line-height: 2.5rem;
	margin-bottom: 20px;
}
main section#event div.block div.text div.list {
	width: auto;
}
main section#event div.block div.text div.list:has(div.row:nth-child(2)) div.row {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: flex-start;
	width: auto;
	margin-right: 0px;
}
main section#event div.block div.text div.list div.row:not(:last-child) {
	margin-bottom: 20px;
}
main section#event div.block div.text div.list div.row p.month {
	margin-bottom: 0px;
}
main section#event div.block div.text div.list:has(div.row:nth-child(2)) div.row ul {
	width: calc(100% - 85px);
}

/* admission
-------------------------------------------------------------------------------- */

main section:where(#admission, #admission-alternate) div.inner-section {
	width: auto;
}
main section#admission div.inner-section {
	padding: 40px 30px 170px 30px;
}
main section#admission p.illust {
	right: 30px;
}
main section#admission p.description {
	text-align: justify;
	margin-bottom: 80px;
}
main section#admission div.table-wrapper:not(:last-child) {
	margin-bottom: 40px;
}
main section#admission table :where(caption, th) {
	padding: 10px 0px;
}
main section#admission table :where(th, td:not(:last-child)) {
	width: 100px;
}
main section#admission table td {
	padding: 10px;
}
main section#admission-alternate div.list div.row p.label {
	width: 130px;
}
main section#admission-alternate div.list div.row p.body {
	width: calc(100% - 130px);
}
main section#admission-alternate p.description {
	margin-bottom: 40px;
}
main section#admission-alternate div.button-wrapper {
	display: block;
	margin: 0px;
}
main section#admission-alternate div.button-wrapper p.button-default {
	margin: 0px;
}
main section#admission-alternate div.button-wrapper p.button-default:not(:last-child) {
	margin-bottom: 20px;
}
main section#admission-alternate div.block-schedule p.description {
	text-align: justify;
}

/* letter
-------------------------------------------------------------------------------- */

main div.list-letter {
	display: block;
	margin: 0px;
}
main div.list-letter div.row {
	width: auto;
	margin: 0px;
}
main div.list-letter div.row:not(:last-child) {
	margin-bottom: 40px;
}

/* document
-------------------------------------------------------------------------------- */

main section#document p.description {
	text-align: justify;
	margin-bottom: 80px;
}
main section#document div.button-wrapper {
	display: block;
}
main section#document p.button-default:not(:last-child) {
	margin: 0px 0px 20px 0px;
}

/* recruit
-------------------------------------------------------------------------------- */

main section#recruit p.description {
	text-align: justify;
	margin-bottom: 80px;
}
main section#recruit p.summary {
	margin-bottom: 40px;
}

/* form
-------------------------------------------------------------------------------- */

main section.form div.inner-section {
	width: auto;
}
main section.form div.header {
	margin-bottom: 60px;
	padding-bottom: 60px;
}
main section.form div.mw_wp_form_preview div.form div.component-wrapper {
	margin-bottom: 60px;
}
main section.form div.form div.agreement {
	justify-content: space-between;
	align-items: flex-start;
}
main section.form div.form div.agreement span.mwform-checkbox-field {
	margin-right: 0px;
}
main section.form div.form div.agreement p {
	width: calc(100% - 35px);
}
main section.form div.form div.agreement span.error {
	text-align: left;
	padding-left: 35px;
}
main section.form div.form div.action {
	display: block;
	margin-right: 0px;
}
main section.form div.form div.action :where(input:where([type=button], [type=submit]), button) {
	width: 100%;
}
main section.form div.form div.action:has(*:nth-child(2)) :where(input:where([type=button], [type=submit]), button) {
	width: 100%;
}
main section.form div.form div.action :where(input:where([type=button], [type=submit]), button):not(:last-child) {
	margin: 0px 0px 20px 0px;
}



/* --------------------------------------------------------------------------------
footer
-------------------------------------------------------------------------------- */

footer#footer p#button-admission {
	right: 10px;
	bottom: 10px;
	font-size: 0.8125rem;
	line-height: 1.125rem;
}
footer#footer p#button-admission a {
	width: 80px;
	height: 80px;
}
footer#footer p#button-page-top {
	right: 15px;
	bottom: 140px;
}
footer#footer div.contact {
	padding-bottom: 80px;
}
footer#footer div.contact::before {
	height: 90px;
	top: -88px;
	mask-position: 75% top;
	mask-size: 137.5% 100%;
}
footer#footer div.contact p.description {
	margin-bottom: 40px;
}
footer#footer div.contact div.button-wrapper {
	display: block;
}
footer#footer div.contact p.button-default:not(:last-child) {
	margin: 0px 0px 20px 0px;
}
footer#footer div.fix {
	height: 400px;
}
footer#footer div.information-navi-footer {
	padding: 40px 0px;
}
footer#footer div.information-navi-footer::before {
	height: 30px;
	top: -28px;
}
footer#footer div.information-navi-footer div.inner-information-navi-footer {
	display: block;
	width: auto;
}
footer#footer div.information-navi-footer div.information {
	width: auto;
}
footer#footer div.information-navi-footer div.information h3 img {
	width: calc(362px * 0.75);
}
footer#footer div.information-navi-footer div.information div.button-wrapper {
	display: block;
	margin: 0px 0px 40px 0px;
}
footer#footer div.information-navi-footer div.information p.button-default:not(:last-child) {
	margin: 0px 0px 20px 0px;
}
footer#footer div.information-navi-footer div.information p.privacy-policy {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	font-size: 0.875rem;
	line-height: 1.5rem;
}
footer#footer div.information-navi-footer nav#navi-footer {
	display: none;
}
footer#footer p.illust {
	width: 366px;
}
