@charset "UTF-8";
/*========================*/

/* Component */

/*========================*/
/*========================
SVG */
/* ---------
矢印 */
.arrow {
	fill:none;
	stroke: currentColor;
	stroke-width:2;
	stroke-linecap:round;
	stroke-linejoin:round;
}
/* ---------
丸矢印 */
.arrow-circle__circle {
    fill: #1f6c58;
    stroke-width: 0px;
}
.arrow-circle__arrow {
    fill: none;
    stroke: #ffffff;
    stroke-linecap: round;
    stroke-linejoin: round;
}

/*========================
hoerスタイル */
/* タッチデバイスでタップ時にhover.jsによりis-hoverクラスを付与するオブジェクトから、タップ時のハイライトを非表示にする */
@media (any-hover: none) {
	.is-hover,
	.tap-highlight-white.is-hover {
		cursor: pointer;

		-webkit-tap-highlight-color: rgba(255, 255, 255, 0);
	}
}
/* ------------------------
hover時の共通アニメーション */
/* arrow */
@-webkit-keyframes hover-arrow {
	0% {
		-webkit-transform: translateX(0);
		        transform: translateX(0);
		opacity: 1;
	}
	50% {
		-webkit-transform: translateX(100%);
		        transform: translateX(100%);
		opacity: 0;
	}
	51% {
		-webkit-transform: translateX(-100%);
		        transform: translateX(-100%);
		opacity: 0;
	}
	100% {
		-webkit-transform: translateX(0);
		        transform: translateX(0);
		opacity: 1;
	}
}
@keyframes hover-arrow {
	0% {
		-webkit-transform: translateX(0);
		        transform: translateX(0);
		opacity: 1;
	}
	50% {
		-webkit-transform: translateX(100%);
		        transform: translateX(100%);
		opacity: 0;
	}
	51% {
		-webkit-transform: translateX(-100%);
		        transform: translateX(-100%);
		opacity: 0;
	}
	100% {
		-webkit-transform: translateX(0);
		        transform: translateX(0);
		opacity: 1;
	}
}
@-webkit-keyframes hover-arrow-dlc {
	0% {
		-webkit-transform: rotate(90deg) translateX(0);
		        transform: rotate(90deg) translateX(0);
		opacity: 1;
	}
	50% {
		-webkit-transform: rotate(90deg) translateX(100%);
		        transform: rotate(90deg) translateX(100%);
		opacity: 0;
	}
	51% {
		-webkit-transform: rotate(90deg) translateX(-100%);
		        transform: rotate(90deg) translateX(-100%);
		opacity: 0;
	}
	100% {
		-webkit-transform: rotate(90deg) translateX(0);
		        transform: rotate(90deg) translateX(0);
		opacity: 1;
	}
}
@keyframes hover-arrow-dlc {
	0% {
		-webkit-transform: rotate(90deg) translateX(0);
		        transform: rotate(90deg) translateX(0);
		opacity: 1;
	}
	50% {
		-webkit-transform: rotate(90deg) translateX(100%);
		        transform: rotate(90deg) translateX(100%);
		opacity: 0;
	}
	51% {
		-webkit-transform: rotate(90deg) translateX(-100%);
		        transform: rotate(90deg) translateX(-100%);
		opacity: 0;
	}
	100% {
		-webkit-transform: rotate(90deg) translateX(0);
		        transform: rotate(90deg) translateX(0);
		opacity: 1;
	}
}
@-webkit-keyframes hover-arrow-back {
	0% {
		-webkit-transform: scaleX(-1) translateX(0);
		        transform: scaleX(-1) translateX(0);
		opacity: 1;
	}
	50% {
		-webkit-transform: scaleX(-1) translateX(100%);
		        transform: scaleX(-1) translateX(100%);
		opacity: 0;
	}
	51% {
		-webkit-transform: scaleX(-1) translateX(-100%);
		        transform: scaleX(-1) translateX(-100%);
		opacity: 0;
	}
	100% {
		-webkit-transform: scaleX(-1) translateX(0);
		        transform: scaleX(-1) translateX(0);
		opacity: 1;
	}
}
@keyframes hover-arrow-back {
	0% {
		-webkit-transform: scaleX(-1) translateX(0);
		        transform: scaleX(-1) translateX(0);
		opacity: 1;
	}
	50% {
		-webkit-transform: scaleX(-1) translateX(100%);
		        transform: scaleX(-1) translateX(100%);
		opacity: 0;
	}
	51% {
		-webkit-transform: scaleX(-1) translateX(-100%);
		        transform: scaleX(-1) translateX(-100%);
		opacity: 0;
	}
	100% {
		-webkit-transform: scaleX(-1) translateX(0);
		        transform: scaleX(-1) translateX(0);
		opacity: 1;
	}
}

/* ====================
/* ------------------
テキスト */
.txt {
	font-size: var(--txt-reg);
	font-weight: normal;
	letter-spacing: .06em;
	line-height: 2.25;
	line-height: 2;
	text-align: justify;
}
/* ------------------
リード */
.lead {
	font-size: var(--txt-4x);
	font-weight: 700;
	letter-spacing: .06em;
	line-height: 1.5;
	color: var(--color-main);
}
.lead--center {
	text-align: center;
}
/* ------------------
見出し */
.headline__alphabet {
	font-family: var(--alphabet);
	font-weight: 800;
	font-size: var(--txt-4x);
	letter-spacing: 0;
	line-height: 1.1;
	color: var(--color-main);
}
.headline__jp {
	font-size: var(--txt-md);
	font-weight: 700;
	line-height: 1.1;
	margin-top: 0.5em;
}
.headline--center {
	text-align: center;
}
/* ------------------
テキストリンク */
.txt--link {
	color: var(--color-link);
	text-decoration: underline;
}
@media (any-hover: hover) {
	.txt--link {
		-webkit-transition: color .2s ease-in-out;
		transition: color .2s ease-in-out;
	}
	.txt--link:hover,
	.txt--link:focus {
		color: var(--color-link--hover);
	}
}


/* ====================
ボタン */
.button__container {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: start;
	    -ms-flex-align: start;
	        align-items: flex-start;
	-webkit-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
}
.button {
	font-size: var(--txt-reg);
	line-height: 1.1;
	color: var(--color-white);
	text-align: center;

	display: -webkit-inline-box;

	display: -ms-inline-flexbox;

	display: inline-flex;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	-webkit-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;
	gap: 0 var(--button-gup);

	width: calc(336rem / 16);
	max-width: 100%;
	min-height: calc(60rem / 16);
	padding-block: 0.5em;
	padding-inline: calc(var(--button-gup) + var(--button-gup) + var(--button-arrow-size));

	border: 1px solid var(--color-main);
	border-radius: 8px;
	background-color: var(--color-main);

	--button-arrow-size: 1em;
	--button-gup: min(2.5vw, 1em);

	position: relative;
}
.button .arrow {
	width: var(--button-arrow-size);
	height: var(--button-arrow-size);

	position: absolute;
	right: var(--button-gup);
}
@media(any-hover: hover) {
	.button {
		-webkit-transition: background-color .2s var(--easeInQuad),
		border-color .2s var(--easeInQuad);
		transition: background-color .2s var(--easeInQuad),
		border-color .2s var(--easeInQuad);
	}
	.button:hover,
	.button:focus {
		background-color: var(--color-main-hover);
		border-color: var(--color-main-hover);
	}

	.button:hover .arrow ,
	.button:focus-visible .arrow {
		-webkit-animation-name: hover-arrow;
		        animation-name: hover-arrow;
		-webkit-animation-timing-function: var(--easeInExpo);
		        animation-timing-function: var(--easeInExpo);
		-webkit-animation-duration: .4s;
		        animation-duration: .4s;
		-webkit-animation-delay: .03s;
		        animation-delay: .03s;
		-webkit-animation-fill-mode: both;
		        animation-fill-mode: both;
	}
}
/* ------------------------
ダウンロードボタン */
.button.download .arrow {
	-webkit-transform: rotate(90deg);
	        transform: rotate(90deg);
}
@media (any-hover: hover) {
	.button.download:hover .arrow ,
	.button.download:focus-visible .arrow {
		-webkit-animation-name: hover-arrow-dlc;
		        animation-name: hover-arrow-dlc;
	}
}
/* ------------------------
シングルページ / フッターボタン */
.button.back-to-index {
	background-color: var(--color-main-pale);
	border-color: var(--color-main-pale);
}
.button.back-to-index .arrow {
	left: var(--button-gup);
	right: auto;
	-webkit-transform: scaleX(-1);
	        transform: scaleX(-1);
}
@media (any-hover: hover) {
	.back-to-index:hover,
	.back-to-index:focus {
		background-color: var(--color-main-hover);
		border-color: var(--color-main-hover);
	}
	.button.back-to-index:hover .arrow ,
	.button.back-to-index:focus-visible .arrow {
		-webkit-animation-name: hover-arrow-back;
		        animation-name: hover-arrow-back;
	}
}
/* ------------------------
大きいボタン */
.button--lg {
	font-family: var(--alphabet);
	font-size: var(--txt-sm);
	line-height: 1.35;
	color: var(--color-bk);
	text-align: center;

	display: -webkit-box;

	display: -ms-flexbox;

	display: flex;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	-webkit-box-pack: center;
	    -ms-flex-pack: center;
	        justify-content: center;

	width: auto;
	max-width: min(
	var(--max-width--sm),
	100%
	);
	padding: 1.5em var(--button-gup);

	border: 1px solid var(--color-white);
	background-color: var(--color-white);

	--button-gup: min(2.5vw, 1em);
}
@media(any-hover: hover) {
	.button--lg {
		-webkit-transition: color .2s var(--easeInSine),
		border-color .2s  var(--easeInSine);
		transition: color .2s var(--easeInSine),
		border-color .2s  var(--easeInSine);
	}
	.button--lg:hover,
	.button-.button--lg:hover {
		color: var(--color-main);

		border-color: var(--color-main);
	}
}


/* ====================
テーブル */
.table {
	width: 100%;
}
.table tr {
	font-size: var(--txt-reg);
	-webkit-font-feature-settings: "palt";
	        font-feature-settings: "palt";
	letter-spacing: .06em;
}
.table tr:not(:last-child) {
	border-bottom: 1px solid var(--color-main-pale);
}
.table tr:nth-child(odd) {
	background-color: var(--color-main-thin);
}
.table th,
.table td {
	padding: 1.1em min(1em , 5.5vw);
}
.table__slash-list {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	    flex-wrap: wrap;
}
.table__slash-list li:not(:last-child)::after {
	content: "／";
}
/* 個別設定 */
.table:is(.overview__table) th {
	width: max(8em , 140px);
	max-width: 100%;
}
@media (max-width: 559px) {
	.table tr {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		    -ms-flex-direction: column;
		        flex-direction: column;
	}
	.table th,
	.table:is(.overview__table) th {
		padding-bottom: 0;
		width: 100%;
	}
	.table td {
		padding-top: 0.5em;
	}
}


/* ====================
マップ */
.g-map {
	aspect-ratio: 16 / 9;
}
.g-map iframe {
	width: 100%;
	height: 100%;
}
.g-map__desc {
	margin-top: 1em;
}
@media (max-width: 959px) {
	.g-map {
		aspect-ratio: 3 / 2;
	}
}
@media (max-width: 559px) {
	.g-map {
		aspect-ratio: 1 / 1.3;
	}
}


/* ====================
下層イメージ */
#lower-hero {
	display: grid;

	height: max(
		560px,
		35vw
	);

	background-color: var(--color-main-pale);
	background-repeat: no-repeat;
	background-size: cover;

	place-items: center;
}
body:is(#member,#news-list,#report-list,#privacy) #lower-hero {
	height: max(
		460px,
		28.7vw
	);
	background-color: var(--color-main);
}
@media (max-width: 959px) {
	#lower-hero {
		height: max(
			336px,
			35vw
		);
		margin-top: var(--header-height);
	}
	body:is(#member,#news-list,#report-list,#privacy) #lower-hero {
		height: max(
			224px,
			28.7vw
		);
	}
}
/* 個別指定 */
#about #lower-hero {
	background-image: url(../../images/about/main_about.jpg);
	background-position: center center;
}
/* ページネーム */
.page-name {
	color: var(--color-white);
	text-align: center;

	margin-top: calc(var(--header-height) / 1.5);
	margin-inline: var(--gutter-var-8x);
}
.page-name__alphabet {
	font-family: var(--alphabet);
	font-weight: 800;
	text-transform: uppercase;
	/* min: 20px, max: 35px */
	font-size: clamp(1.25rem, calc(0.875rem + 1.875vw), 2.188rem);
	line-height: 1.1;
}
.page-name__jp {
	font-weight: 700;
	font-size: var(--txt-md);
	letter-spacing: 0.2em;
	line-height: 1.25;
	margin-top: 0.5em;
}
body:not(:is(#member,#news-list,#report-list,#privacy)) .page-name {
	text-shadow: 0px 0px 20px rgba(17, 46, 92, 0.7);
}
/* サファリ対応 */
_::-webkit-full-page-media, _:future, :root body:not(:is(#member,#news-list,#report-list,#privacy)) .page-name {
	text-shadow: none;
	-webkit-filter: drop-shadow(0px 0px 20px rgba(17, 46, 92, 0.7));
	filter: drop-shadow(0px 0px 20px rgba(17, 46, 92, 0.7));
}



/* ====================
PHPのindex.php用 */
.php-index__headline {
	font-size: var(--txt-md);
	font-weight: 700;
}
.php-index__headline::before {
	content: "";
	display: block;
	padding-top: var(--header-height);
}
.php-index__lead {
	margin-block: 1.5em;
}
.php-index__item {
	color: var(--color-main-soft);

	display: -webkit-box;

	display: -ms-flexbox;

	display: flex;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
}
.php-index__item::before {
	content: "・";
}
.php-index__item + .php-index__item {
	margin-top: 0.5em;
}
.php-index__item a {
	display: -webkit-inline-box;
	display: -ms-inline-flexbox;
	display: inline-flex;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
}
.php-index__item a[target="_blank"]::after {
    content: "";
    display: inline-block;
	line-height: 1;
    vertical-align: middle;
    margin-left: 0.3em;

	width: 0.7em;
	height: 0.7em;

	background-color: var(--color-main-soft);

	-webkit-mask-image: url(../../svg/icon_exlink.svg);
	        mask-image: url(../../svg/icon_exlink.svg);
	-webkit-mask-position: center;
	        mask-position: center;
	-webkit-mask-repeat: no-repeat;
	        mask-repeat: no-repeat;
	-webkit-mask-size: cover;
	        mask-size: cover;
}
@media (any-hover: hover) {
	.php-index__item a,
	.php-index__item a[target="_blank"]::after {
		-webkit-transition: color .2s ease-in-out, background-color .2s ease-in-out;
		transition: color .2s ease-in-out, background-color .2s ease-in-out;
	}
	.php-index__item a:hover,
	.php-index__item a:focus-visible {
		color: var(--color-accent);
	}
	.php-index__item a:hover[target="_blank"]::after,
	.php-index__item a:focus-visible[target="_blank"]::after {
		background-color: var(--color-accent);
	}
}