@charset "UTF-8";

/* /////////////////////////////////////////////// */

/* テンプレート用CSS */

/* /////////////////////////////////////////////// */
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	background-repeat: no-repeat;
	font-feature-settings : "palt";
}
html,
body {
	width: 100%;
	height: 100%;
}
body {
	font-family: "游ゴシック", YuGothic, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "メイリオ", "ＭＳ Ｐゴシック", "MS PGothic", Meiryo, sans-serif;
	color: #333;
	font-size: 1em;
	line-height: 180%;
	background-color: #FFF;
}

a {
	color: #08C;
}
a:hover {
	text-decoration: none;
}

img {
	vertical-align: bottom;
}

.fix::after {
	content: "";
	height: 0;
	display: block;
	clear: both;
}

.btn {
	min-height: 40px;
	padding: 0 1em;
	display: inline-block;
	line-height: 40px;
	color: #FFF;
	text-align: center;
	text-decoration: none;
	background-color: #5EA6DD;
	box-shadow: 2px 2px 0 0 rgba(0,0,0,0.1);
	border-radius: 3px;
}

.w_max {
	width: 100% !important;
}

.news-list::after {
	content: "";
	height: 0;
	display: block;
	clear: both;
}
.news-list dt {
	width: 6em;
	margin-right: -6em;
	padding: 0.5em 0;
	float: left;
	clear: both;
}
.news-list dd {
	padding: 0.5em 0 0.5em 6em;
	border-bottom: 1px dashed #CCC;
}
.date-list > li {
	padding: 0.5em 0;
	display: flex;
	justify-content: left;
	align-items: start;
	list-style: none;
	line-height: 140%;
	border-bottom: 1px dashed #CCC;
}
.date-list > li > * {
	margin-right: 1em;
	padding: 0.5em 0;
}
.date-list > li > *:last-child {
	margin-right: 0;
}
.date-list > li > time {
	width: 5em;
}
.date-list > li > a::before {
	display: none !important;
}

a {
	display: inline-block;
	position: relative;
}
.mincho {
	font-family: "Times New Roman", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "メイリオ", "ＭＳ Ｐ明朝", "MS PMincho", Meiryo, serif;
}



/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
/* header */
/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
header {
	max-width: 1012px;
	margin: 0 auto;
	padding: 15px 0;
	position: relative;
}
header form {
	position: absolute;
	top: 30px;
	right: 0;
}
header form input[type="keyword"] {
	width: 300px;
	height: 40px;
	background-color: #EEE;
	border: none;
	border-radius: 3px;
	box-shadow: 2px 2px 0 0 rgba(0,0,0,0.15) inset;
}
header form button {
	width: 40px;
	height: 38px;
	margin: 0;
	padding: 0;
	position: absolute;
	top: 2px;
	right: 0;
	background-color: #EEE;
	border: none;
	box-shadow: none;
}
header form button i {
	margin: -1px 0 1px;
	font-size: 20px;
	color: #555;
}
#sp_menu {
	display: none;
}



/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
/* nav */
/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
nav {
	width: 100%;
	display: flex;
	justify-content: center;
	align-items: stretch;
	position: relative;
	background-color: #79BFF3;
}
nav > a,
nav > div > span {
	width: 202px;
	width: calc(1012px / 6);
	display: block;
	position: relative;
	line-height: 60px;
	text-align: center;
	color: #333;
	color: #FFF;
	background-color: #5EA6DD;
	cursor: pointer;
	transition: 0.3s;
}
nav > a.current {
	pointer-events: none;
}
nav > a.current::before,
nav > div.current > span::before {
	content: "";
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	background-color: rgba(255,255,255,0.15);
}
nav > a:hover,
nav > div > span:hover {
	background-color: #182A37;
}
nav > div > span::after {
	content: "";
	width: 0;
	height: 0;
	margin: 0.3em 0 -0.3em 0.4em;
	margin-left: 0.5em;
	display: inline-block;
	border: 0.45em solid transparent;
	border-top: 0.6em solid rgba(255,255,255,0.25);
}
nav i {
	margin-right: 0.35em;
	font-size: 1.2em;
}
nav a {
	text-decoration: none;
}
nav span + div {
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	color: #FFF;
	text-align: left;
	background-color: rgba(0,0,0,0.85);
	z-index: 11;
	opacity: 0;
	pointer-events: none;
	transition: 0.3s;
}
nav > div:hover > span + div,
nav > div > span + div:hover {
	opacity: 1;
	pointer-events: all;
}
nav span + div > div {
	width: 1012px;
	margin: 0 auto;
	padding: 20px;
	display: flex;
	justify-content: space-between;
	align-items: start;
}
nav span + div > div::after {
	display: none;
}
nav span + div > div dl {
}
nav span + div > div dl dt {
	margin-bottom: 0.5em;
	padding-bottom: 0.5em;
	font-size: 1.3em;
	font-weight: bold;
	white-space: nowrap;
	border-bottom: 1px solid #FFF;
}
nav span + div > div dl dt small {
	font-size: 1rem;
}
nav span + div > div dl dt span {
	font-size: 2rem;
	vertical-align: middle;
}
nav span + div > div dl ul {
	padding-left: 1em;
}
nav span + div > div dl ul li {
	padding: 0.5em 0;
	line-height: 100%;
}
nav div.fix a {
	height: auto;
	line-height: 140%;
	color: #FFF;
	text-decoration: underline;
}
nav .japanmap {
	width: 700px;
	padding: 0 30px;
	background-color: #FFF;
	border-radius: 4px;
}
nav .japanmap svg {
	width: 100%;
}
nav .japanmap text {
	font-size: 9px;
	font-weight: bolder;
}



/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
/* bc_list */
/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
#bc-list {
	background-color: #EEE;
}
#bc-list ol {
	width: 1012px;
	margin: 0 auto;
	padding: 0;
}
#bc-list ol li {
	margin: 0;
	padding: 0;
	display: inline-block;
	list-style: none;
	line-height: 40px;
}
#bc-list ol li:not(:last-child)::after {
	content: " ＞ ";
	opacity: 0.5;
}



/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
/* article */
/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
article {
	width: 1012px;
	margin: 0 auto;
}

article > section {
	padding: 20px 0;
}

.about #page-title,
.project #page-title,
.member #page-title,
.faq #page-title {
	height: 350px;
	margin-bottom: 20px;
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: #79BFF3;
	background-color: #CEF;
	background-blend-mode: multiply;
	background-size: cover;
	background-position: center;
	border-radius: 3px;
}
.about #page-title { background-image: url(../img/pt1.jpg); }
.project #page-title { background-image: url(../img/pt2.jpg); }
.member #page-title { height: 220px; background-image: url(../img/pt3.jpg); }
.faq #page-title { background-image: url(../img/pt4.jpg); }

#page-title h2 {
	margin-bottom: 20px;
	padding: 1em;
	position: relative;
	color: #FFF;
	font-size: 1.8em;
	text-shadow: 1px 2px 0 rgba(0,0,0,0.5);
	background-color: #5EA6DD;
	background-image: url(../img/h2.png);
	background-position: right center;
}
.about #page-title h2,
.project #page-title h2,
.member #page-title h2,
.faq #page-title h2 {
	margin-bottom: 0;
	padding: 0;
	line-height: 120%;
	font-size: 52px;
	font-weight: normal;
	text-align: center;
	text-shadow: 0 2px 15px rgba(0,0,0,1), 0 1px 3px #000, 0 1px 3px #000;
	background-color: transparent;
	background-image: none;
}

table {
	margin: 0 auto 12px;
	border-collapse: collapse;
	border-top: 1px solid #CCC;
}
table.bl2em {
	border-left: 2em solid transparent;
}
caption {
	color: #5EA6DD;
	font-weight: bold;
	text-align: left;
}
thead {
	background-color: #F9F9F9;
}
thead th {
	padding: 0.5em 0;
}
th,
td {
	padding: 0.5em 1em;
	border-bottom: 1px solid #CCC;
}
th {
	padding-right: 1em;
	white-space: nowrap;
}
table.plain {
	margin: 0;
	border-collapse: collapse;
	border-top: none;
}
table.plain th,
table.plain td {
	padding: 0.2em 1em 0.2em 0;
	border-bottom: none;
}
table.plain th {
	white-space: normal;
}

.select_wrapper {
	padding: 0;
	overflow: hidden;
	position: relative;
	line-height: 100%;
	font-size: 1em;
	background-image: linear-gradient(#FFF 50%, #DDD 100%);
	border: 1px solid #06C;
	border: 1px solid rgba(0,0,0,0.5);
	border-radius: 3px;
	display: inline-block;
	vertical-align: bottom;
	box-shadow: 0 0 0 2px #FFF inset;
}
.select_wrapper:after {
	content: "";
	width: 0;
	height: 0;
	margin-top: -0.2em;
	display: block;
	position: absolute;
	top: 50%;
	right: 0.7em;
	border: 0.4em solid transparent;
	border-top: 0.5em solid #06C;
}
.select_wrapper select {
	width: 150%;
	height: 2.4em;
	padding: 0 1.5em 0 0.5em;
	background-color: transparent;
	border: none;
	font-size: 1em;
}

input,
button,
textarea {
	height: 2.4em;
	padding: 0.7em;
	line-height: 100%;
	font-size: 1em;
	background-color: #F9F9F9;
	border: 1px solid rgba(0,0,0,0.3);
	border-right-color: rgba(0,0,0,0.15);
	border-bottom-color: rgba(0,0,0,0.15);
	box-shadow: 2px 2px 0 0 rgba(0,0,0,0.1) inset;
	border-radius: 3px;
}
br + .select_wrapper,
br + input {
	margin-top: 0.5em;
}
textarea {
	height: 8.4em !important;
}
.center {
	text-align: center;
}
input[type="reset"],
input[type="submit"],
button {
	width: 8em;
	margin: 0 0.5em;
	background-color: #DDD;
	border-top-color: transparent;
	border-left-color: transparent;
	box-shadow: 2px 2px 0 0 rgba(0,0,0,0.2);
}
input[type="submit"],
#mfp_button_send {
	color: #FFF;
	background-color: #06C;
}
.p-postal-code,
#zip-code {
    width: auto !important;
}
.p-country-name {
	display: none;
}

.flex {
	max-width: 1012px;
	margin: 0 auto 5vh;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
.top .flex {
	margin-bottom: 12px;
}
.flex.nowrap {
	flex-wrap: nowrap;
}
.flex.center > * {
	margin-left: 1em;
	margin-right: 1em;
	margin-bottom: 1em;
}
.flex.col2 {
	justify-content: space-between;
}
.flex.col2 > * {
	width: calc(50% - 10px);
	margin-bottom: 1em;
}
.flex img {
	max-width: 100%;
}

.right {
	text-align: right;
}
.center {
	text-align: center;
}
.fl {
	float: left;
}
.fr {
	float: right;
}
#tinymce .caution,
#contents-body .caution {
	color: #C00;
}

.one_list li {
	position: relative;
	list-style: none;
}
.one_list li::before {
	content: "1.";
	position: absolute;
	top: 0.3em;
	left: -1.5em;
}

.gallery dl {
	margin-bottom: 0.7em;
}
.gallery dt a::before {
	display: none !important;
}
.gallery img {
	height: auto !important;
	margin-bottom: 0.3em;
	border: none !important;
}
.gallery dd {
	line-height: 120%;
}



/*--------------------------------------------------------- top ---------------------------------------------------------*/
#new {
	width: 262px;
	padding: 12px;
	background-color: #79BFF3;
}
#new h2 {
	height: 50px;
	margin: -12px -12px 0;
	overflow: hidden;
	line-height: 47px;
	font-size: 1.15em;
	text-align: center;
	background-color: #FFF;
	background-image: url(../img/slash.png);
	background-repeat: repeat;
	border-bottom: 3px solid #5EA6DD;
}
#new h2 strong {
	font-size: 30px;
}
#new p {
	height: 45px;
	overflow: hidden;
	line-height: 45px;
	color: #FFF;
	font-size: 1.15em;
	text-align: center;
}
#new ol {
	height: 241px;
	margin-bottom: 12px;
	padding: 0 12px;
	overflow: auto;
	background-color: #FFF;
}
#new ol li {
	padding: 15px 0;
	display: flex;
	overflow: hidden;
	border-top: 1px solid #999;
}
#new ol li:first-child {
	border-top: none;
}
#new ol li span {
	width: 5em;
	font-size: 14px;
	line-height: 120%;
	text-align: center;
	white-space: nowrap;
}
#new ol li a {
	padding-left: 12px;
	font-size: 22px;
	text-decoration: underline;
	white-space: nowrap;
}
#new > a {
	width: 100%;
	padding-left: 0;
	padding-right: 0;
	color: #5EA6DD;
	display: block;
	background-color: #FFF;
}

#slide {
	width: 750px;
	height: 400px;
	position: relative;
}
#slide li {
	width: 100%;
	height: 100%;
	overflow: hidden;
	position: absolute;
	top: 0;
	left: 0;
	opacity: 0;
	pointer-events: none;
	transition: 1s linear opacity;
}
#slide li.current {
	position: static;
	opacity: 1;
	pointer-events: all;
}
#slide li a {
	display: block;
	position: static;
}
#slide li img {
	width: 100%;
}
#slide li p {
	padding: 0.5em;
	position: absolute;
	bottom: 5px;
	right: 5px;
	line-height: 100%;
	color: #FFF;
	font-size: 1em;
	text-align: right;
	background-color: rgba(0,0,0,0.65);
	border-radius: 3px;
}

#peace80 {
	height: 400px;
	margin-bottom: 12px;
	padding-right: 340px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	position: relative;
	overflow: hidden;
	background-image: url(../img/peace_bg.jpg);
	background-size: cover;
	background-position: bottom;
}
#peace80 a {
	width: 440px;
	padding: 20px;
	color: #FFF;
	font-size: 28px;
	font-weight: 700;
	text-align: center;
	text-decoration: none;
	text-shadow: 0 2px 3px rgba(0,0,0,.5);
	background-color: rgba(255,255,255,.1);
	border: 1px solid #FFF;
	border-radius: 100em;
	transition: .3s;
}
#peace80 a:hover {
	color: #000;
	text-shadow: none;
	background-color: rgba(255,255,255,.9);
	box-shadow: 0 2px 3px 0 rgba(0,0,0,.5),
				0 4px 12px 0 rgba(0,0,0,.25);
}
#peace80 > div {
	position: absolute;
	top: -50px;
	right: -60px;
	transform: rotate(-12deg);
}
#peace80 > div img {
	animation: film 15s linear infinite;
}
@keyframes film {
	0% {
		transform: translate(0, 0);
	}
	100% {
		transform: translate(0, -656px);
	}
}

#news {
	width: 738px;
	padding-top: 42px;
	position: relative;
}
#news input {
	position: absolute;
	visibility: hidden;
}
#news label {
	width: 50%;
	height: 42px;
	display: block;
	overflow: hidden;
	position: absolute;
	top: 0;
	left: 0;
	line-height: 45px;
	color: #000;
	font-size: 18px;
	font-weight: bold;
	text-align: center;
	background-image: url(../img/slash.png);
	background-repeat: repeat;
}
#news #tab2 + label {
	left: 50%;
}
#news :checked + label {
	color: #FFF;
	background-color: #5EA6DD;
	background-image: none;
}
#news ol {
	margin-bottom: 1.2em;
	display: none;
	border-top: 3px solid #5EA6DD;
}
#news :checked + label + ol {
	display: block;
}
#news ol li {
	padding: 1.2em 0 1.2em 6em;
	position: relative;
	line-height: 120%;
	border-bottom: 1px dashed #999;
}
#news ol li.new a::after {
	content: "New";
	margin-left: 5px;
	padding: 0.333em 0.5em;
	display: inline-block;
	font-size: 0.6em;
	color: #FFF;
	background-color: #C00;
	vertical-align: middle;
	line-height: 100%;
	border-radius: 3px;
}
#news ol li time {
	position: absolute;
	top: 1.2em;
	left: 0;
}
#news a.btn {
	width: 500px;
	margin: 0 auto;
	display: block;
}

#fb {
	width: 274px;
	min-height: 550px;
	padding-left: 24px;
	position: relative;
}
#fb::before {
	content: "";
	width: 1px;
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 12px;
	background-color: #999;
}
#fb iframe {
	height: 100%;
}

#link {
	padding: 12px 0;
	position: relative;
}
#link h2 {
	width: 250px;
	height: calc(195px + 1.8em);
	padding-top: calc((195px - 1.4em) / 2);
	position: absolute;
	top: 12px;
	left: 0;
	color: #FFF;
	text-align: center;
	background-color: #5EA6DD;
}
#link h2 i {
	margin-bottom: 5px;
	display: block;
	font-size: 2em;
}
#link ul {
	display: flex;
	justify-content: left;
	align-items: flex-start;
	flex-wrap: wrap;
}
#link ul:before {
	content: "";
	width: 250px;
	height: 100%;
	margin: 0 4px 10px 0;
	display: block;
	background-color: #5EA6DD;
}
#link ul li {
	width: 250px;
	margin: 0 4px 10px 0;
	line-height: 120%;
	text-align: center;
	font-size: 0.9em;
}
#link ul li:nth-of-type(4n - 1) {
	margin-right: 0;
}
#link ul li img {
	margin-bottom: 4px;
	border: 1px solid #CCC;
}



/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
/* contents-body */
/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
#tinymce h2,
#contents-body h2 {
	padding: 1em;
	position: relative;
	color: #FFF;
	font-size: 1.8em;
	text-shadow: 1px 2px 0 rgba(0,0,0,0.5);
	background-color: #5EA6DD;
	background-image: url(../img/h2.png);
	background-position: right center;
}
#tinymce h3,
#contents-body h3 {
	margin: 30px 0 12px;
	padding: 0 0 8px 1.7em;
	position: relative;
	line-height: 100%;
	font-size: 1.6em;
	border-bottom: 3px solid #5EA6DD;
}
#tinymce h3::before,
#contents-body h3::before {
	content: "\f56b";
	margin: -0.05em 0.3em 0.05em 0;
	display: block;
	position: absolute;
	top: -0.1em;
	left: 0;
	line-height: 1;
	color: #5EA6DD;
	font-family: "Font Awesome 5 Free";
	font-size: 1.3em;
	font-weight: 900;
	font-style: normal;
	font-variant: normal;
	-moz-osx-font-smoothing: grayscale;
	-webkit-font-smoothing: antialiased;
	text-rendering: auto;
}
#tinymce h4,
#contents-body h4 {
	margin-bottom: 12px;
	padding: 0.5em 1em;
	font-size: 1.2em;
	background: linear-gradient(90deg, #CEF, #79BFF3);
	border-radius: 3px;
}
#tinymce h5,
#contents-body h5 {
	margin-bottom: 12px;
	padding: 0.5em;
	position: relative;
	line-height: 120%;
	font-size: 1.2em;
	border: 4px solid #5EA6DD;
	border: 4px solid #CEF;
	border: 4px solid #AADBFA;
	border-radius: 6px;
}
#tinymce h5::after,
#contents-body h5::after {
	content: "";
	display: block;
	position: absolute;
	top: -1px;
	left: -1px;
	right: -1px;
	bottom: -1px;
	border-right: 1px solid rgba(0,0,0,0.3);
	border-bottom: 1px solid rgba(0,0,0,0.3);
	pointer-events: none;
}
#tinymce h6,
#contents-body h6 {
	width: 100%;
	margin-bottom: 12px;
	overflow: hidden;
	white-space: nowrap;
	color: #5EA6DD;
	font-size: 1.2em;
	font-weight: bold;
}
#tinymce h6::after,
#contents-body h6::after {
	content: "";
	width: 100%;
	height: 2px;
	margin-left: 0.3em;
	display: inline-block;
	vertical-align: middle;
	background-color: #DDD;
}
#tinymce strong,
#contents-body strong {
	color: #000;
}
#tinymce del,
#contents-body del {
	opacity: 0.5;
}
#tinymce code,
#contents-body code {
	padding: 0 0.5em;
	display: inline-block;
	color: #0F9;
	background-color: #333;
	border-radius: 2px;
}
#tinymce a::before,
#contents-body a::before {
	content: "\f0c1";
	width: 1em;
	text-align: center;
	margin-right: 0.3em;
	display: inline-block;
	font-family: "Font Awesome 5 Free";
	font-style: normal;
	font-variant: normal;
	font-weight: 900;
	-moz-osx-font-smoothing: grayscale;
	-webkit-font-smoothing: antialiased;
	text-rendering: auto;
}
#tinymce a.no-icon::before,
#contents-body a.no-icon::before {
	display: none;
}
#tinymce a[href$=".pdf"]::before,
#contents-body a[href$=".pdf"]::before {
	content: "\f1c1";
}
#tinymce a[href$=".doc"]::before,
#contents-body a[href$=".doc"]::before {
	content: "\f1c2";
}
#tinymce a[href$=".xls"]::before,
#contents-body a[href$=".xls"]::before {
	content: "\f1c3";
}
#tinymce a[href^="mailto"]::before,
#contents-body a[href^="mailto"]::before {
	content: "\f0e0";
}
#tinymce a[target="_blank"]::before,
#contents-body a[target="_blank"]::before {
	content: "\f35d";
}
#tinymce p,
#contents-body p {
	margin-bottom: 12px;
	padding: 0 20px;
}

.no_list,
.no_list > li {
	margin: 0;
	padding: 0;
	list-style: none;
}
#tinymce ul:not(.no_list),
#tinymce ol:not(.no_list),
#contents-body ul:not(.no_list),
#contents-body ol:not(.no_list) {
	margin-bottom: 12px;
	padding-left: calc(2em + 20px);
}
#tinymce ul:not(.no_list) li,
#tinymce ol:not(.no_list) li,
#contents-body ul:not(.no_list) li,
#contents-body ol:not(.no_list) li {
	padding: 0.3em 0;
	line-height: 130%;
}
#tinymce ol.kanji li,
#contents-body ol.kanji li {
	padding-left: 0.7em;
	position: relative;
	list-style: none;
}
#tinymce ol.kanji li::before,
#contents-body ol.kanji li::before {
	width: 1em;
	display: block;
	position: absolute;
	top: 0.3em;
	left: -1.3em;
	text-align: center;
}
ol.kanji li:nth-of-type(1)::before,
ol.kanji.single li::before { content: "一、" !important; }
ol.kanji li:nth-of-type(2)::before { content: "二、"; }
ol.kanji li:nth-of-type(3)::before { content: "三、"; }
ol.kanji li:nth-of-type(4)::before { content: "四、"; }
ol.kanji li:nth-of-type(5)::before { content: "五、"; }
ol.kanji li:nth-of-type(6)::before { content: "六、"; }
ol.kanji li:nth-of-type(7)::before { content: "七、"; }
ol.kanji li:nth-of-type(8)::before { content: "八、"; }
ol.kanji li:nth-of-type(9)::before { content: "九、"; }
ol.kanji li:nth-of-type(10)::before { content: "十、"; }
#contents-body .free-style:not(.no_list) > li {
	padding-left: 0.7em;
	position: relative;
	list-style: none;
}
#contents-body ol.free-style:not(.no_list) > li > i {
	position: absolute;
	top: 0.3em;
	right: 100%;
	font-style: normal;
}
#tinymce blockquote,
#contents-body blockquote {
	padding: 1em 2em;
	position: relative;
	background-color: #EEE;
	border-radius: 4px;
}
#tinymce blockquote::before,
#tinymce blockquote::after,
#contents-body blockquote::before,
#contents-body blockquote::after {
	content: "“";
	position: absolute;
	font-size: 80px;
	line-height: 100%;
	opacity: 0.25;
}
#tinymce blockquote::before,
#contents-body blockquote::before {
	top: 0.5rem;
	left: 0.5rem;
}
#tinymce blockquote::after,
#contents-body blockquote::after {
	bottom: 0.5rem;
	right: 0.5rem;
	transform: rotate(180deg);
}



/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
/* member */
/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */

/*--------------------------------------------------------- index ---------------------------------------------------------*/
table.member-table {
	width: calc(100% - 40px);
	margin: 0 20px 40px;
}
.member-table tfoot tr {
	background-color: #F9F9F9;
}
.member-table th,
.member-table td {
	padding: 0.5em 1em;
	border: 1px solid #CCC;
}
.member-table tbody th {
	width: 6em;
}
.member-table tbody th + td,
.member-table tbody th + td + td + td {
	width: 50%;
}
.member-table tbody th + td + td,
.member-table tbody th + td + td + td + td,
.member-table tbody th + td + td + td + td + td {
	width: 3em;
	text-align: center;
}
.category-check ~ .member-table tbody th + td,
.category-check ~ .member-table tbody th + td + td {
	width: 50%;
	text-align: left;
}
.member-table td a::before {
	display: none !important;
}
#total thead tr {
	background-color: #79BFF3;
	background-color: #CEF;
}
#total tbody tr {
	text-align: center;
	font-weight: bold;
	background-color: #FFF;
}

.category-check {
	padding: 10px 0 30px;
	display: flex;
	justify-content: center;
}
.category-check div {
	padding: 15px 15px 10px;
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: #EEE;
	border: 1px solid #CCC;
	border-radius: 3px;
}
.category-check div div {
	padding: 0;
	flex-wrap: wrap;
	justify-content: flex-start;
	border: none;
}
#contents-body .category-check p {
	margin: 0 10px 0 0;
	padding: 0;
	flex-shrink: 0;
}
.category-check .btn {
	margin-right: 5px;
	margin-bottom: 5px;
	padding-left: 2.5em;
	position: relative;
	cursor: pointer;
}
.category-check .btn.deactive {
	color: #333;
	background-color: #FFF;
}
.category-check .btn::before,
.category-check .btn::after {
	content: "";
	display: block;
	position: absolute;
	top: 50%;
	left: 1.2em;
	transform: translate(-50%, -50%);
}
.category-check .btn::before {
	width: 1.2em;
	height: 1.2em;
	background-color: #FFF;
	border-radius: 2px;
	box-shadow: 1px 1px 2px 0 rgba(0,0,0,.2) inset;
}
.category-check .btn.deactive::before {
	background-color: #EEE;
}
.category-check .btn::after {
	width: .3em;
	height: .7em;
	border: 3px solid #79BFF3;
	border: 3px solid #F90;
	border-top: none;
	border-left: none;
	transform: translate(-50%, -65%) rotate(45deg);
}
.category-check .btn.deactive::after {
	display: none;
}
.category-check ~ table a[class],
.category-check ~ table a[class] + span {
	display: none;
}


/*--------------------------------------------------------- map ---------------------------------------------------------*/
#member-map {
	min-height: 19em;
}
#member-map + table {
	margin-top: -19em;
	float: right;
}
.japanmap [hover="true"] {
	opacity: 0.7;
}
.japanmap svg,
.japanmap text {
	cursor: pointer;
}
.japanmap path[pref-id="01-1"],
.japanmap path[pref-id="01-2"],
.japanmap path[pref-id="01-3"],
.japanmap path[pref-id="01-4"] { fill: #B39DDB; }
.japanmap path[pref-id="02"],
.japanmap path[pref-id="03"],
.japanmap path[pref-id="04"],
.japanmap path[pref-id="05"],
.japanmap path[pref-id="06"],
.japanmap path[pref-id="07"] { fill: #90CAF9; }
.japanmap path[pref-id="08"],
.japanmap path[pref-id="09"],
.japanmap path[pref-id="10"],
.japanmap path[pref-id="11"],
.japanmap path[pref-id="12"],
.japanmap path[pref-id="13"],
.japanmap path[pref-id="14"] { fill: #80DEEA; }
.japanmap path[pref-id="15"],
.japanmap path[pref-id="16"],
.japanmap path[pref-id="17"],
.japanmap path[pref-id="18"],
.japanmap path[pref-id="19"],
.japanmap path[pref-id="20"],
.japanmap path[pref-id="21"],
.japanmap path[pref-id="22"],
.japanmap path[pref-id="23"],
.japanmap path[pref-id="24"] { fill: #A5D6A7; }
.japanmap path[pref-id="25"],
.japanmap path[pref-id="26"],
.japanmap path[pref-id="27"],
.japanmap path[pref-id="28"],
.japanmap path[pref-id="29"],
.japanmap path[pref-id="30"],
.japanmap path[pref-id="30"] { fill: #E6EE9C; }
.japanmap path[pref-id="31"],
.japanmap path[pref-id="32"],
.japanmap path[pref-id="33"],
.japanmap path[pref-id="34"],
.japanmap path[pref-id="35"] { fill: #FFE082; }
.japanmap path[pref-id="36"],
.japanmap path[pref-id="37"],
.japanmap path[pref-id="38"],
.japanmap path[pref-id="39"] { fill: #FFCC80; }
.japanmap path[pref-id="40"],
.japanmap path[pref-id="41"],
.japanmap path[pref-id="42"],
.japanmap path[pref-id="43"],
.japanmap path[pref-id="44"],
.japanmap path[pref-id="45"],
.japanmap path[pref-id="46"],
.japanmap path[pref-id="47"] { fill: #EF9A9A; }



/*--------------------------------------------------------- pref ---------------------------------------------------------*/
#member-data,
#member-data .flex {
	margin-bottom: 0;
}
#member-data > :last-child,
#member-data section table + table {
	margin-left: 12px;
}
#member-data a::before {
	display: none;
}
#pref-map {
	overflow: hidden;
}
#pref-map svg {
	width: 100%;
	cursor: default;
}
#pref-map path {
	fill: #EEE;
	cursor: default;
	pointer-events: none;
}
#pref-map path[div="join"] {
	fill: #C9E5FA;
}
#pref-map path[div="error"] {
	fill: #FF0000;
	fill-opacity: 0.4;
}
#pref-map path[div="member"] {
	fill: #79BFF3;
	pointer-events: all;
}
#pref-map path[div="hidden"] {
}
#pref-map path.city04101,
#pref-map path.city11101,
#pref-map path.city12101,
#pref-map path.city14101,
#pref-map path.city14131,
#pref-map path.city14151,
#pref-map path.city15101,
#pref-map path.city22101,
#pref-map path.city22131,
#pref-map path.city23101,
#pref-map path.city26101,
#pref-map path.city27102,
#pref-map path.city27141,
#pref-map path.city28101,
#pref-map path.city33101,
#pref-map path.city34101,
#pref-map path.city40101,
#pref-map path.city40131,
#pref-map path.city43101 {
	stroke: none !important;
}
#pref-map path[div="member"][hover="true"] {
	fill: #FC6;
	cursor: pointer;
}
#pref-map text {
	pointer-events: none;
}
#pref-map text.hidden {
	display: none;
}
#member-data th,
#member-data td {
	padding: 0.5em 0.5em;
	white-space: nowrap;
	text-align: center;
}

#pref-text {
	margin-bottom: 15px;
	justify-content: space-between;
}
.example {
	flex-shrink: 0;
}
.example li {
	padding: 0.3em 0.5em !important;
	text-align: center;
	background-color:  #EEE;
}
.example li.member {
	background-color:  #79BFF3;
}
.example li.join {
	background-color:  #C9E5FA;
}


/*--------------------------------------------------------- detail ---------------------------------------------------------*/
#member-detail #contents-body {
	padding-left: 262px;
}
#member-nav {
	width: 250px;
	margin-top: -3px;
	margin-left: -262px;
	position: -webkit-sticky;
	position: sticky;
	top: 12px;
	float: left;
	color: #FFF;
	font-weight: bold;
	background-color: #79BFF3;
	border-radius: 3px;
}
#member-nav h3 {
	margin: 0;
	padding: 15px 12px;
	font-size: 1.3em;
	background-color: rgba(0,0,0,0.1);
	border-bottom: 1px solid rgba(255,255,255,1);
	border-radius: 3px 3px 0 0;
}
#contents-body #member-nav h3::before {
	display: none;
}
#member-nav a {
	padding: 15px 12px;
	display: block;
	line-height: 100%;
	color: #FFF;
	text-decoration: none;
	transition: 0.3s;
}
#member-nav a:hover {
	background-color: rgba(255,255,255,0.15);
}
#member-nav a::before {
	display: none;
}
#member-nav > a + a {
	border-top: 1px dashed rgba(255,255,255,1);
}
#member-nav ul {
	margin: 0 !important;
	padding: 0 !important;
	border-top: 1px solid rgba(0,0,0,0.15);
	background-color: rgba(0,0,0,0.1);
}
#member-nav ul li {
	margin: 0;
	padding: 0;
	list-style: none;
}
#member-nav ul li a {
	padding-left: 2.2em;
	position: relative;
}
#member-nav ul li a::before {
	content: "";
	width: 0;
	height: 0;
	display: block;
	position: absolute;
	top: 50%;
	left: 1.5em;
	border: 4px solid transparent;
	border-left: 5px solid #FFF;
	transform: translate(0, -50%);
}

.img-box {
	padding: 0 20px 10px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	align-items: flex-start;
}
.img-box::after {
	content: "";
	flex-grow: 9;
}
.img-box > * {
	width: calc((100% - 20px) / 3);
	margin-right: 10px;
	margin-bottom: 10px
}
.img-box > *:nth-child(3n) {
	margin-right: 0;
}
.img-box img {
max-width: 100%;
}
#contents-body h4:has(+ .author) {
	border-radius: 3px 3px 0 0;
}
#contents-body h4 + .author {
	margin-top: -12px;
	padding: 5px 10px;
	text-align: right;
	background-color: #EEE;
}



/*--------------------------------------------------------- faq ---------------------------------------------------------*/
#faq dt,
#faq dd {
	padding: 1em 1em 1em 4em;
	position: relative;
	border-radius: 3px;
}
#faq dt {
	margin: 0 50px 10px 0;
	color: #FFF;
	font-weight: bold;
	background-color: #79BFF3;
	background-color: #5EA6DD;
}
#faq dd {
	margin: 0 0 30px 50px;
	background-color: #EEE;
}
#faq dt::before,
#faq dd::before {
	content: "Q";
	position: absolute;
	top: 0.25em;
	left: 0.3em;
	font-size: 3em;
	font-weight: bold;
	opacity: 0.25;
}
#faq dt::before {
	content: "Q";
}
#faq dd::before {
	content: "A";
	top: 0.4em;
	left: 0.4em;
}
#faq table {
	background-color: #FFF;
}
#faq table th {
	text-align: left;
	background-color: #F9F9F9;
}
#faq ul {
	padding: 0.5em 0 0 2em;
}



/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
/* login */
/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
#login {
	min-height: calc(100vh - 614px);
	padding: 50px 0;
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
}
#login > section {
	padding: 50px 100px;
	display: inline-block;
	color: #FFF;
	background-color: #79BFF3;
	border-radius: 3px;
	box-shadow: 6px 6px 6px 0 rgba(0,0,0,0.1);
}
#login #page-title {
	height: auto;
	margin-bottom: 30px;
	background-color: transparent;
}
#login #page-title h2 {
	padding: 0;
	font-size: 2em;
	font-weight: bold;
	text-shadow: none;
	background-color: transparent;
	background-image: none;
}
#login #page-title h2 i {
	margin-bottom: 5px;
	font-size: 100px;
	opacity: 0.3;
}
#login p.center {
	width: 20em;
	margin-bottom: 30px;
	padding: 0;
	color: #FFF;
}
#login form {
	text-align: center;
}
#login .news-list {
	display: inline-block;
	text-align: left;
	border-top: 1px dashed rgba(255,255,255,0.5);
}
#login .news-list dt,
#login .news-list dd {
	padding-top: 1em;
	padding-bottom: 1em;
}
#login .news-list dt {
	line-height: 240%;
	font-weight: bold;
}
#login .news-list dd {
	border-bottom-color: rgba(255,255,255,0.5);
}
#login input {
	width: 15em;
}
#login input[type="text"],
#login input[type="password"] {
	border: none;
	box-shadow: -1px -1px 0 0 rgba(0,0,0,0.2), 3px 3px 0 0 rgba(0,0,0,0.1) inset;
}
#onetime {
	margin-bottom: -20px;
}
#onetime strong {
	margin-bottom: 0.3em;
	display: block;
	font-size: 1.1em;
	color: #FFF;
}
#login input[type="submit"] {
	margin: 0;
	color: #333;
	font-weight: bold;
	background-color: #FFF;
	border: none;
}



/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
/* footer */
/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
footer {
	color: #FFF;
	text-align: center;
	background-color: #79BFF3;
}
footer a {
	color: #FFF;
}
footer .sp {
	display: none;
}
footer > div {
	width: auto;
	margin: 0 auto;
	display: inline-block;
	padding: 20px 0;
	text-align: left;
}
footer h2 {
	margin: 0 0 10px;
	padding: 0 0 10px;
	font-size: 1.25em;
	text-align: center;
	line-height: 100%;
	border-bottom: 1px solid #FFF;
}
footer dl {
	line-height: 140%;
}
footer dl dt,
footer dl dd {
	margin-bottom: 0.2em;
}
footer dl dt {
	width: 5em;
	margin-right: -5em;
	float: left;
	clear: both;
}
footer dl dd {
	padding-left: 4em;
}
footer dl a {
	color: #FFF;
}
footer h3 {
	padding-top: 0.5em;
	font-size: 1rem;
	font-weight: bold;
}
footer iframe {
	width: calc(100% - 20px - 22.5em);
}
footer > p {
	line-height: 50px;
	text-align: center;
	background-color: #5EA6DD;
}
















/* /////////////////////////////////////////////////////////////////////////////////////// */
/* スマホ */
/* /////////////////////////////////////////////////////////////////////////////////////// */
@media screen and (max-width: 641px) {
body {
	font-size: 3.6vw;
}

img {
	max-width: 100%;
}

h2 {
	padding-top: 90px;
}

th {
	padding-left: 0;
	padding-right: 0;
	white-space: normal;
}
td {
	white-space: normal;
	word-break: break-all;
}



/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
/* header */
/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
header {
	width: 100%;
	padding: 1vh;
}
header.min {
	padding: 1vh 0;
}
header h1 {
	max-width: calc(100% - 60px + 1vh);
	height: calc(60px - 2vh);
	vertical-align: bottom;
}
header h1 img {
	max-width: 100%;
	height: auto;
	max-height: 100%;
}
header form {
	width: calc(100% - 60px);
	position: fixed;
	top: auto;
	bottom: 0;
	right: auto;
	left: -100%;
	z-index: 11;
	transition: 0.3s;
}
.scroll-prevent header form {
	left: 0;
}
header form input[type="keyword"] {
	width: 100%;
	height: 7vh;
	color: #FFF;
	font-size: 1rem;
	background-color: rgba(0,0,0,0.35);
	border-radius: 0;
	box-shadow: none;
}
header form button {
	width: 7vh;
	height: 7vh;
	top: 0;
	background-color: transparent;
}
header form button .fas {
	color: #FFF;
}
header form input::-webkit-input-placeholder {
	color:#FFF;
}
header form input:-ms-input-placeholder {
	color:#FFF;
}
header form input::placeholder{
	color:#FFF;
}



/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
/* nav */
/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
.scroll-prevent {
	width: 100%;
	height: 100%;
	position: fixed;
	z-index: -1;
}
#gb {
	width: 100%;
	position: fixed;
	top: 0;
	bottom: 0;
	left: -100%;
	background-color: rgba(0,0,0,0.85);
	z-index: 9;
	transition: 0.3s;
}
#gb.active {
	left: 0;
}
nav {
	width: calc(100% - 60px);
	padding: 0 0 7vh;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	position: fixed;
	top: 0;
	bottom: 0;
	left: -100%;
	pointer-events: none;
	z-index: 10;
	transition: 0.3s;
}
nav.active {
	left: 0;
	pointer-events: all;
}
nav > a,
nav > div > span {
	width: 100%;
	height: 7vh;
	margin-right: 0;
	padding: 0 1.5em;
	display: block;
	line-height: 7vh;
	text-align: left;
	font-size: 4vw;
	color: #FFF;
}
nav > a {
	border-bottom: 1px dashed rgba(255,255,255,0.5);
}
nav > div {
	width: 100%;
	border-bottom: 1px dashed rgba(255,255,255,0.5);
}
nav > div > span::after {
	position: absolute;
	top: 50%;
	right: 1.5em;
	margin-top: -0.2em;
}
nav > div > span.active::after {
	margin-top: -0.85em;
	transition: 0.3s;
	transform: rotate(180deg);
}
nav > :last-child {
	border-bottom: none !important;
}
nav > div > span + * {
	max-height: 0;
	display: block;
	overflow: hidden;
	position: static;
	background-color: #5EA6DD;
	box-shadow: 1px 1px 0 0 rgba(0,0,0,0.2) inset;
	opacity: 1;
	transition: 0.3s;
}
nav > div > span.active + * {
	height: auto;
	max-height: 51vh;
	overflow: auto;
}
nav span + div > div {
	width: 100%;
	padding-top: 0;
	display: block;
	background-color: rgba(0,0,0,0.1);
}
nav span + div > div dl {
	margin-bottom: 1.5em;
}
nav span + div > div dl dt {
	margin: 0 -20px 0.5em;
	padding: 0.5em 20px;
	border: none;
	background-color: rgba(255,255,255,0.1);
	box-shadow: 0 1px 0 0 rgba(0,0,0,0.2);
}
nav span + div > div dl ul li {
	padding: 0;
}
nav div.fix a {
	padding: 0.7em 0;
	text-decoration: none;
	font-size: 1.1em;
	display: inline-block;
}
nav .japanmap {
	display: none;
}
nav span + div > div dl dt span {
	font-size: 1.5rem;
	vertical-align: top:
}

#sp_menu {
	width: 60px;
	height: 60px;
	display: block;
	position: absolute;
	top: 0;
	right: 0;
	cursor: pointer;
	z-index: 10;
	transition: 0.5s;
}
#sp_menu span {
	width: 40%;
	height: 2px;
	margin-top: -1px;
	display: block;
	position: absolute;
	top: 50%;
	left: 30%;
	background-color: #999;
	transition: 0.4s;
}
#sp_menu:before,
#sp_menu:after {
	content: "";
	width: 40%;
	height: 2px;
	margin-top: -16%;
	display: block;
	position: absolute;
	top: 50%;
	left: 30%;
	background-color: #999;
	transition: 0.4s;
}
#sp_menu:after {
	margin-top: calc(16% - 2px);
}
#sp_menu.active span {
	opacity: 0;
}
#sp_menu.active:before,
#sp_menu.active:after {
	width: 50%;
	margin-top: -1px;
	left: 25%;
	background-color: #FFF;
	transform: rotate(225deg);
}
#sp_menu.active:after {
	transform: rotate(315deg);
}



/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
/* bc-list */
/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
#bc-list ol {
	width: 100%;
	padding: 0 1em;
	overflow: auto;
	white-space: nowrap;
	border-top: 1px solid rgba(0,0,0,0.1);
}



/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
/* article */
/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
article {
	width: 100%;
}

article > section {
	padding: 0 0 20px;
}

.about #page-title,
.project #page-title,
.member #page-title,
.faq #page-title {
	height: 30vh;
	margin-bottom: 3vw;
	border-radius: 0;
}
.member #page-title {
	background-position: right;
}

#contents-body {
	padding-left: 3vw;
	padding-right: 3vw;
}

.flex {
	max-width: auto;
	margin: 0 auto 5vh;
	padding: 0;
}
.top .flex {
	margin-bottom: 12px;
}

.about #page-title h2, .project #page-title h2, .member #page-title h2, .faq #page-title h2 {
	font-size: 3em;
}

#contents-body p {
	padding-left: 0;
	padding-right: 0;
}
#contents-body ul,
#contents-body ol {
	padding-left: 1.6em;
}
#contents-body ul.date-list,
#contents-body ol.date-list {
	padding-left: 0;
}

#contents-body .gallery .gallery-item {
	width: 80%;
	margin: 0 auto 1em;
	float: none;
}
#contents-body .gallery img {
	width: 100%;
}



/*--------------------------------------------------------- top ---------------------------------------------------------*/
.top > .flex:first-child {
	margin-bottom: 0;
	flex-direction: column-reverse;
}
#new {
	width: 100%;
	position: relative;
	z-index: 1;
}
#new h2 {
	height: 7vh;
	margin-bottom: calc(3vw - 3px);
	padding-top: 0;
	line-height: 7vh;
	font-size: 1.5em;
}
#new p {
	height: auto;
	padding: 2vw 0 3vw;
	line-height: 120%;
	font-size: 5vw;
}
#new p {
	width: 7em;
	padding: 0;
	position: absolute;
	top: calc(7vh + 3vw);
	right: 3vw;
	line-height: 120%;
	font-size: 5vw;
	text-align: center;
}
#new p strong {
	font-size: 10vw;
	line-height: 100%;
}
#new ol {
	height: calc(6vw + 13vw + 48px + 1.2em + 2.4em);
	margin-bottom: 0;
	margin-right: calc(3vw + 35vw);
	padding: 0 3vw;
}
#new ol li span {
	font-size: 3.5vw;
}
#new ol li a {
	padding-left: 3vw;
	font-size: 5.5vw;
	line-height: 7vw;
}
#new > a {
	width: calc(33vw - 24px);
	height: calc(6vw + 13vw + 48px + 1.2em + 2.4em);
	width: 35vw;
	height: calc(6vw + 13vw + 48px + 1.2em + 2.4em - 16vw);
	padding: 15px 0 10px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	position: absolute;
	bottom: 3vw;
	right: 12px;
	line-height: 120%;
}
#new > a i {
	margin-bottom: 10px;
	display: block;
	font-size: 2em;
}

#slide {
	width: 100%;
	height: calc(100vw * 400 / 750);
}

#peace80 {
	height: 100vmin;
	padding-right: 0;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	position: relative;
	overflow: hidden;
	background-image: url(../img/peace_bg.jpg);
	background-size: cover;
	background-position: left bottom;
}
#peace80 h2 {
	width: 95%;
	margin-bottom: 5vmin;
	padding-top: 0;
}
#peace80 a {
	width: 80%;
	padding: 15px;
	position: static;
	font-size: 5.5vmin;
	box-shadow: 0 2px 3px 0 rgba(0,0,0,.5),
				0 4px 12px 0 rgba(0,0,0,.25);
}
#peace80 a::before {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
}
#peace80 > div {
	display: none;
}

#news {
	width: 100%;
	padding-top: 7vh;
	padding-bottom: 12px;
}
#news label {
	height: 7vh;
	line-height: calc(7vh - 3px);
	line-height: 7vh;
}
#news ol {
	margin-bottom: 1.2em;
}
#news ol li {
	padding: 1.2em 12px 1.2em 6em;
	padding-left: calc(12px + 6em);
}
#news ol li time {
	left: 12px;
}
#news a.btn {
	width: calc(100% - 24px);
	line-height: 6vh;
	font-size: 1.15em;
	margin: 0 auto;
	display: block;
}

#fb {
	height: 50vh;
	min-height: auto;
	margin: 0 auto;
	padding: 0 12px;
}
#fb::before {
	display: none;
}
#fb iframe {
	width: 100%;
	height: 100%;
}

#link {
	padding: 0;
}
#link h2 {
	width: 100%;
	height: 7vh;
	padding-top: 0;
	position: static;
	line-height: 7vh;
}
#link h2 i {
	margin-bottom: 0;
	margin-right: 0.3em;
	display: inline-block;
	font-size: 1em;
}
#link ul {
	padding: 12px;
	justify-content: left;
	justify-content: space-between;
	align-items: flex-start;
}
#link ul:before {
	display: none;
}
#link ul li {
	width: calc(50% - 6px);
	margin: 0 0 12px 0;
	font-size: 2.5vw;
}
#link ul li img {
	width: 100%;
}



/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
/* member */
/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
#member-data {
	padding: 0 3vw;
}
#member-data > section,
#member-data > section table {
	width: 100%;
	margin-left: 0 !important;
}
#member-data > section:last-child table + table {
	margin-top: -13px;
}

#member-map + table {
	width: calc(100% - 6vw);
	margin: 20px auto;
	float: none;
}
#member-map + table caption {
	text-align: center;
}

#member-detail #contents-body {
	padding: 0 3vw;
	display: block;
}
#member-nav {
	width: auto;
	margin: -20px -3vw 3vw;
	position: static;
	float: none;
	border-radius: 0;
}
#member-nav li {
	display: inline-block;
}
#member-detail th {
	min-width: 7em;
}

#pref-text p br {
	display: none;
}
#pref-text .example {
	padding-left: 1em;
}

.img-box {
	padding: 0 0 10px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.img-box > * {
	width: calc((100% - 10px) / 2);
	margin-right: 10px;
	margin-bottom: 10px
}
.img-box > *:nth-child(3n) {
	margin-right: 10px;
}
.img-box > *:nth-child(2n) {
	margin-right: 0;
}


.category-check {
	padding: 10px 0 30px;
	display: flex;
	justify-content: center;
}
.category-check div {
	width: 100%;
}
.category-check > div {
	display: block;
}
.category-check > div div::after {
	content: "";
	width: 10%;
	height: 0;
	display: block;
	flex-grow: 10;
}
#contents-body .category-check p {
	padding: 0;
}
.category-check .btn {
	padding: .5em;
	padding-top: 2.5em;
	white-space: nowrap;
	line-height: 1;
	flex-grow: 1;
}
.category-check .btn::before,
.category-check .btn::after {
	top: 1.2em;
	left: 50%;
}



/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
/* faq */
/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
#faq dt {
	margin: 0;
	border-radius: 3px 3px 0 0;
}
#faq dd {
	margin: 0 0 3vw;
	border-radius: 0 0 3px 3px;
}
#faq dt::before,
#faq dd::before {
	top: 0.333em;
}
#faq table th {
	min-width: 6em;
	padding-left: 1em;
	padding-right: 1em;
}



/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
/* login */
/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
#login {
	padding: 10vw 0;
}
#login > section {
	width: calc(100% - 20vw);
	padding: 6vw;
}
#login #page-title {
	margin-bottom: 6vw;
}



/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
/* footer */
/* ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////// */
footer {
	color: #FFF;
	background-color: #79BFF3;
}
footer .sp {
	display: block;
}
footer > div {
	width: 100%;
	padding: 12px;
	display: block;
}
footer > div > div {
	width: 100%;
}
footer h2 {
	margin: 0 0 12px;
	padding: 0 0 12px;
	font-size: 1.5em;
	text-align: center;
}
footer iframe {
	width: calc(100% + 24px);
	margin: -12px;
	vertical-align: bottom;
}
footer > p {
	height: 5vh;
	line-height: 5vh;
	font-size: 3vw;
}


}


