@charset "UTF-8";
/* ============================== */
/*  FORUM SITE */
/* ============================== */ :root {
	--y-margin-tp: 80px;
}
@media screen and (min-width: 1232px), print {
	:root {
		--y-margin-tp: 100px;
	}
}
.mb-35 {
	margin-bottom: 35px;
}
.w-90p {
	width: 90%;
}
.w-300 {
	width: 300px;
}
.w-45p {
	width: 45%;
}
.ul_text {
	font-size: 14px;
}
@media screen and not (min-width: 768px) {
	.w-half-sp {
		width: 50%;
	}
	.pl-120-sp {
		padding-left: 10px;
	}
	.ul_text {
		font-size: 12px;
	}
}
/* FORUM TOP */
.forum-top-hero {
	font-size: 16px;
	background-color: var(--white);
	margin: 0;
	line-height: 1.8;
}
.forum-top-hero .caption {
	padding: 20px 5.4vw 40px;
	position: relative;
}
.forum-top-hero .facility-title {
	font-size: 2.3em;
	line-height: 1;
	height: 1em;
	margin: 0 0 0.5em;
}
.forum-top-hero .facility-title img {
	height: 100%;
	width: auto;
}
.forum-top-hero .catch-copy {
	font-feature-settings: 'palt';
}
.forum-top-hero .button-show-detail {
	margin-top: 2.4em;
}
@media screen and (min-width: 768px), print {
	.forum-top-hero {
		font-size: 18px;
	}
	.forum-top-hero .caption {
		padding: 20px calc(var(--x-margin) + 15px);
	}
}
@media screen and (min-width: 1232px), print {
	.forum-top-hero {
		font-size: min(calc(18px + 5 * ((100vw - 1232px) / 380)), 23px);
		width: calc(100% - 60px);
		max-width: 1580px;
		margin: 0 auto;
		border-radius: var(--rad-s);
		display: flex;
		flex-direction: row-reverse;
		margin-top: 60px;
		overflow: hidden;
		align-items: center;
		line-height: 2;
	}
	.forum-top-hero .caption {
		width: 42%;
		padding: 20px 2.9% 40px;
		flex: 0 0 auto;
	}
	.forum-top-hero .facility-image img {
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
	.forum-top-hero .button-show-detail {
		margin-top: 2.4em;
	}
}
@media screen and (min-width: 1612px) {
	.forum-top-hero .caption {
		padding: 55px;
	}
}
/* FORM TOP INDEX */
.forum-top-content-link {
	padding: var(--y-margin-tp) var(--x-margin);
}
.forum-top-content-link .content-list {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(min(300px, 100%), 1fr));
	gap: 40px 3%;
}
.forum-top-content-link .content-list + .content-list {
	margin-top: 40px;
}
.forum-top-content-link .content-list li {
	position: relative;
}
.forum-top-content-link .image {
	border-radius: var(--rad-s);
	overflow: hidden;
}
.forum-top-content-link a {
	color: var(--text-color);
	text-decoration: none;
	width: 100%;
}
.forum-top-content-link a .image img {
	transition: 400ms;
	aspect-ratio: 760 / 428;
	object-fit: cover;
}
.forum-top-content-link a .arrow {
	display: block;
	position: absolute;
	width: 40px;
	aspect-ratio: 1;
	bottom: -22px;
	right: 15px;
	border-radius: 50%;
	background: var(--theme-color) url("../../hall/images/common/arr_a-r.svg") center / 34% no-repeat;
	transition: 400ms;
}
@media (any-hover: hover) {
	.forum-top-content-link a:hover .image img {
		transform: scale(1.1);
		opacity: 0.7;
	}
	.forum-top-content-link a:hover .arrow {
		transform: scale(1.2);
	}
}
@media screen and (min-width: 768px), print {
	.forum-top-content-link .content-list.col-2 {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media screen and (min-width: 1012px), print {
	.forum-top-content-link .content-list.col-2 {
		row-gap: 40px;
	}
	.forum-top-content-link .content-list.col-2 img {
		aspect-ratio: 575 / 214;
	}
}
@media screen and (min-width: 1232px), print {
	.forum-top-content-link .content-list {
		gap: 80px 45px;
	}
	.forum-top-content-link a .arrow {
		width: 44px;
		bottom: -22px;
		right: 30px;
	}
	.forum-top-content-link .content-list + .content-list {
		margin-top: 80px;
	}
	.forum-top-content-link .content-list.col-2 {
		column-gap: 50px;
	}
}
.content-list-sub {
	display: flex;
	justify-content: center;
	margin: var(--y-margin-tp) auto 0;
	padding-inline: var(--x-margin);
	gap: 11%;
}
.content-list-sub li {
	display: flex;
	justify-content: center;
	text-align: center;
	width: 120px;
}
.content-list-sub .icon {
	width: 66.66666667%;
	aspect-ratio: 1;
	padding: 0px 9.09090909%;
	margin: 0 auto;
	display: flex;
	align-items: center;
	background-color: var(--theme-color);
	border-radius: 50%;
	transition: 200ms;
}
.content-list-sub h2 {
	font-size: 14px;
	margin: 0.75em 0 0;
	line-height: 1.4;
	font-weight: var(--font-medium);
}
@media (any-hover: hover) {
	.content-list-sub a:hover .icon{
		background-color: var(--theme-hover);
	}	
}
@media screen and (min-width: 768px), print {
	.content-list-sub li {
		width: 160px;
	}
	.content-list-sub h2 {
		font-size: 16px;
	}
}
@media screen and (min-width: 1232px), print {
	.content-list-sub {
		gap: 80px;
	}
	.content-list-sub li {
		width: 225px;
	}
	.content-list-sub h2 {
		font-size: 18px;
	}
}
/* FORUM TOP 施設情報 */
.foot-facility-info {
	padding: 30px var(--x-margin);
	background-color: var(--white);
}
.foot-facility-info > div {
	margin: 0 auto;
	gap: 30px;
}
.foot-facility-info .image {
	width: 100%;
	max-width: 300px;
	margin-bottom: 20px;
}
.foot-facility-info .text {
	font-size: 14px;
	line-height: 1.75;
	font-weight: var(--font-regular);
}
.foot-facility-info .text .facility-title {
	height: 2.29411765em;
	margin-bottom: 0.65em;
}
.foot-facility-info .text .facility-title img {
	height: 100%;
	width: auto;
}
@media screen and (min-width: 768px), print {
	.foot-facility-info {}
	.foot-facility-info > div {
		display: flex;
		justify-content: space-between;
		flex-direction: row-reverse;
		align-items: center;
		width: 90%;
		max-width: 758px;
		margin: 0 auto;
		gap: 30px;
	}
	.foot-facility-info .image {
		width: 45%;
		max-width: 325px;
		margin-bottom: 0;
	}
	.foot-facility-info .text {
		font-size: 15px;
	}
}
@media screen and (min-width: 1232px), print {
	.foot-facility-info > div {
		display: flex;
		justify-content: space-between;
		flex-direction: row-reverse;
		align-items: center;
		width: 825px;
		max-width: none;
	}
	.foot-facility-info .text {
		font-size: 17px;
	}
}
/* FORUM TOP FOOTER */
.page-forum-top .global-footer {
	margin-top: 0;
}
/* 日本ガイシフォーラム 施設概要・開館時間 */
.facility-detail-table > dl > dt {
	width: 12em;
}
.facility-detail-table > dl > dd {
	width: calc(100% - 12em);
}
@media screen and (min-width: 768px), print {
	.facility-detail-table > dl > dt {
		width: 12em;
	}
	.facility-detail-table > dl > dd {
		width: calc(100% - 12em);
	}
}
/* 日本ガイシフォーラム ご利用料金 */
.fee-table.forum2 tbody > tr:nth-child(2) td:first-child {
	width: 7em;
}
.fee-table.forum2 tbody > tr:nth-child(2) td:nth-child(2) {
	width: 12em;
}
/* 日本ガイシフォーラム トレーニング室 */
.fee-table.forum3 tbody > tr:first-child td:first-child {
	width: 11em;
}
/* 利用システム */
.course-wrapper {
	background-color: var(--white);
	border: 1px solid var(--theme-color);
	padding: 20px;
	border-radius: 6px;
	margin-top: 30px;
}
.courses .course-item:nth-child(n + 2) {
	border-top: 1px solid #ccc;
	margin-top: 20px;
	padding-top: 20px;
}
.course-item {
	display: flex;
	flex-direction: column;
	align-items: center;
}
.course-item dt {
	background-color: var(--theme-color);
	color: var(--white);
	font-size: 15px;
	font-size: 93.75%;
	text-align: center;
	padding: 0.2em 1em;
	min-width: 13em;
	display: inline;
	margin: 0 0 0.75em;
	font-weight: bold;
}
.course-item dd {
	text-align: center;
}
@media screen and (min-width: 768px), print {
	.course-wrapper {}
	.course-wrapper .courses {
		display: flex;
		margin-left: -20px;
		margin-right: -20px;
	}
	.course-wrapper .courses .course-item {
		width: 33.33333333%;
	}
	.courses .course-item:nth-child(n + 2) {
		border-top: none;
		border-left: 1px solid #ccc;
		margin-top: 0;
		padding-top: 0;
	}
}
@media screen and (min-width: 1232px), print {
	.course-wrapper {
		padding-block: 20px;
	}
	.course-item dt {
		font-size: 21px;
	}
	.course-item dd {
		font-size: 17px;
		font-size: 106.25%;
	}
}
.course-arrow {
	text-indent: -9999px;
	overflow: hidden;
	background-position: center;
	background-repeat: no-repeat;
	background-size: auto 2em;
	height: 2em;
	margin: 10px 0;
}
.course-arrow.ca1 {
	background-image: url("../images/ca1.svg");
}
.course-arrow.ca2 {
	background-image: url("../images/ca2.svg");
}
.course-arrow + .course-wrapper {
	margin-top: 0;
}
/* 日本ガイシフォーラム 施設概要 */
.space-list {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(min(300px, 100%), 1fr));
	gap: 70px 3%;
}
.space-photo {
	margin-top: 15px;
	margin-bottom: 20px;
	display: block;
}
.space-info-list dt {
	font-weight: 700;
	margin-top: 1.5em;
	margin-bottom: 0.3em;
	font-size: 95%;
	border-top: 1px solid rgb(0 0 0 / 0.2);
	padding-top: 1.25em;
}
.space-info-list + p {
	margin-top: 1.5em;
}
.modal-button {
	display: inline-block;
	margin-top: 1.5em;
	font-size: 15px;
	padding: 0.75em 2.5em 0.75em 1em;
	border: 1px solid var(--theme-color);
	border-radius: 5px;
	color: var(--theme-color);
	position: relative;
	text-decoration: none;
	text-align: left;
	line-height: 1;
	background: var(--white);
}
.modal-button::after {
	position: absolute;
	top: 50%;
	right: 0.75em;
	content: '';
	display: inline-block;
	width: calc(16 / 15 * 1em);
	aspect-ratio: 1;
	background: url(../images/icon_blank.svg) no-repeat top left / 100%;
	vertical-align: middle;
	transform: translateY(-50%);
}
@media (any-hover: hover) {
	.modal-button:hover {
		background-color: var(--theme-color);
		color: var(--white);
	}
	.modal-button:hover::after {
		background-position: bottom left;
	}
}
/*Modal*/
.modal_display {
	position: relative;
}
.modal_display::after {
	position: fixed;
	width: 100%;
	height: 100%;
	background: #000a;
	content: '';
	top: 0;
	left: 0;
	z-index: 120;
}
.modal {
	height: 100vh;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	display: none;
	z-index: 1000;
	font-size: 14px;
}
@media screen and (min-width: 768px), print {
	.modal {
		font-size: 16px;
	}
}
.modal_area {
	width: 670px;
	position: absolute;
	top: 30px;
	left: calc((100% - 670px) / 2);
}
.modal-header {
	width: calc(100% - 20px);
	max-width: 670px;
	margin: 0 auto 20px;
	display: flex;
	justify-content: flex-end;
}
.modal__close {
	width: 125px;
	height: 50px;
	display: flex;
	align-items: center;
	color: var(--white);
	position: relative;
	text-align: left;
	font-size: 18px;
	padding: 0;
	background: transparent;
}
.modal__close::after, .modal__close::before {
	position: absolute;
	content: '';
	top: calc(50% - 1px);
	right: 0;
	width: 63px;
	height: 2px;
	background-color: var(--white);
}
.modal__close::before {
	transform: rotate(45deg);
}
.modal__close::after {
	transform: rotate(-45deg);
}
.modal_content {
	background-color: var(--white);
	padding: 40px 45px;
	height: calc(100vh - 80px - 80px);
	height: calc(100svh - 80px - 80px);
	overflow-y: scroll;
	max-width: 670px;
	margin-left: auto;
	margin-right: auto;
}
.modal_content .modal_title {
	margin-bottom: 15px;
	font-size: 24px;
	margin: 0 0 0.6em;
	color: var(--theme-color);
	border-bottom: 2px solid;
}
.modal_content .modal_lead {
	margin-bottom: 40px;
}
.modal table {
	font-size: 14px;
}
.modal table.spec {
	margin-bottom: 35px;
}
.modal-h4 {
	width: 100%;
	background-color: var(--theme-color);
	font-weight: bold;
	color: var(--white);
	line-height: 1.2;
	padding: 0.25em 0.6em;
	margin: 0 0 0.5em;
	font-size: 15px;
}
@media screen and (min-width: 768px), print {
	.modal-h4 {
		font-size: 18px;
	}
}
.modal table th {
	background-color: transparent;
	vertical-align: top;
	border-left: none;
	border-right: none;
	font-weight: normal;
	position: relative;
	width: 180px;
	padding: 0.4em 1em;
}
.modal table th::before {
	position: absolute;
	content: '■';
	top: 0.4em;
	left: 0;
}
.modal table td {
	border-left: none;
	border-right: none;
}
.modal_flex {
	display: flex;
	justify-content: space-between;
}
.ul_text {
	font-size: 14px;
}
.ul_text ul li {
	position: relative;
	padding-left: 15px;
}
.ul_text ul li::before {
	position: absolute;
	top: 0;
	left: 0;
}
.ul_text .note li::before {
	content: '※';
}
.ul_text .disc li::before {
	content: '・';
}
.ul_text .diamond li::before {
	content: '◆';
}
@media screen and not (min-width: 768px) {
	.w-full-sp {
		width: 100%;
	}
	.box_31p.w-full-sp {
		margin-right: 0;
	}
	.w-half-sp {
		width: 50%;
	}
	.pl-120-sp {
		padding-left: 10px;
	}
	.mb-10-sp {
		margin-bottom: 10px;
	}
	.modal_area {
		top: 30px;
		width: calc(100% - 20px);
		left: 10px;
	}
	.modal_content {
		width: calc(100% - 20px);
		padding: 20px;
		height: calc(100vh - 80px - 80px);
		height: calc(100svh - 80px - 80px);
	}
	.modal-header {
		margin-bottom: 10px;
	}
	.ul_text {
		font-size: 12px;
	}
	.ul_text ul li {
		padding-left: 11px;
	}
}
.modal__overlay {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgb(0 0 0 / 0.6);
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
}
.modal__close {
	background: transparent;
	border: 0;
	cursor: pointer;
}
@keyframes mmfadeIn {
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}
@keyframes mmfadeOut {
	from {
		opacity: 1;
	}
	to {
		opacity: 0;
	}
}
@keyframes mmslideIn {
	from {
		transform: translateY(15%);
	}
	to {
		transform: translateY(0);
	}
}
@keyframes mmslideOut {
	from {
		transform: translateY(0);
	}
	to {
		transform: translateY(-10%);
	}
}
.micromodal-slide {
	display: none;
}
.micromodal-slide.is-open {
	display: block;
}
.micromodal-slide[aria-hidden=false] .modal__overlay {
	animation: mmfadeIn 0.3s cubic-bezier(0, 0, 0.2, 1);
	padding-bottom: 15px;
}
.micromodal-slide[aria-hidden=false] .modal__container {
	animation: mmslideIn 0.3s cubic-bezier(0, 0, 0.2, 1);
}
.micromodal-slide[aria-hidden=true] .modal__overlay {
	animation: mmfadeOut 0.3s cubic-bezier(0, 0, 0.2, 1);
}
.micromodal-slide[aria-hidden=true] .modal__container {
	animation: mmslideOut 0.3s cubic-bezier(0, 0, 0.2, 1);
}
.micromodal-slide .modal__container, .micromodal-slide .modal__overlay {
	will-change: transform;
}