@charset 'utf-8';
/* adiva-template v4.0.2 | (c) adiva | adiva.jp | MIT licensed */

/*	Color
/* -------------------------------------------------------------------------------- */
:root {
  --color-theme1: #27b5e9;
  --color-theme2: #e64f27;
  --color-theme3: #834192;
  --color-theme4: #38b2ac;
  --color-theme5: #5fdc9f;
  --color-theme6: #f4f6f8;

  --bgColor: var(--color-white);
  --fgColor: #313030;

  --headerFgColor: var(--color-fff);
/*  --headerBgColor: var(--color-black50);*/
  --headerBgColor: rgba(30,50,60,0.5);
  --footerFgColor: var(--color-fff);
  --footerBgColor: var(--color-theme1);
  --contentsColor: var(--color-fff);
  --navFgColor: var(--color-white);
  --navBgColor: transparent;
}

/*	Font Color
	------------------ */
.fc-alert {
  color: var(--color-alert);
}

/*	Bg Color
	------------------ */
.bg-contents {
	background:var(--contentsColor);
}



/*	Framework
/* -------------------------------------------------------------------------------- */
:root {
	--baseFontSize: 70%;
	--headerHeight: 100px;
	--maxContentsWidth: 1512px;

	--wrapperPadding: 6.76%;
/*	--wrapperPadding: 0;*/
	--innerPaddingWidth: 60px;
	--innerPaddingHeight: 80px;

	--boxPaddingWidth: calc(var(--gridSize) * 5);
}
@media only screen and (max-width: 1512px) {
	:root {
	}
}
@media only screen and (max-width: 1280px) {
	:root {
		--innerPaddingWidth: 3.7vw;
		--innerPaddingHeight: 3.7vw;
		--baseFontSize: 62.5%;
		--headerHeight: 80px;
	}
}
@media only screen and (max-width: 960px) {
	:root {
		--baseFontSize: 62.5%;
		--headerHeight: 70px;

/*		--wrapperPadding: 4%;*/
		--wrapperPadding: 0;
		--innerPaddingWidth: 4.35vw;
		--innerPaddingHeight: 4.35vw;
	}
}
@media only screen and (max-width: 430px) {
	:root {
		--baseFontSize: 62.5%;
		--headerHeight: 60px;

		--wrapperPadding: 0;
		--innerPaddingWidth: 20px;
		--innerPaddingHeight: 30px;
	}
}

/*
 * Global
 * ================================================================================
 */
img.square {
  width: 100%;
  aspect-ratio: 1 / 1; 
  object-fit: cover;
  clip-path: inset(0);
}
img.square.top {
  object-position: top;
}
img.square.bottom {
  object-position: bottom;
}

/*	Font
/* -------------------------------------------------------------------------------- */
html {
	font-size: var(--baseFontSize);
/*font-size:62.5%;*/
}
body,
button,
input,
select,
textarea {
/*	font-family: Arial, Helvetica, 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, sans-serif;*/
/*  font-family: 'Noto Sans JP', sans-serif;*/
	font-family: "Noto Sans", sans-serif;
}



/*
 * Layout
 * ================================================================================
 */
html {
	overflow-y:scroll;
}

#container {
	display:grid;
	grid-template-columns: 1fr;
	grid-template-rows: 1fr auto;
	padding-top:var(--headerHeight);
	overflow:hidden;
	min-height: 100dvh;
}

.wrapper {
	max-width:var(--maxContentsWidth);
	width:100%;
	margin:0 auto;
	padding:0 var(--wrapperPadding);
}

.inner {
	padding:var(--innerPaddingHeight) var(--innerPaddingWidth);
}

.paddingbox {
	padding-left: var(--boxPaddingWidth);
	padding-right: var(--boxPaddingWidth);
}
@media only screen and (max-width: 960px) {
	.paddingbox {
		padding-left: 0;
		padding-right: 0;
	}
}


/*	Header
	------------------ */
#header {
	display:flex;
	align-items:center;
	position:fixed;
	left:0;
	top:0;
	width:100%;
	height:var(--headerHeight);
	z-index:1000;
	transition: all 0.2s 0s ease;
}
@media only screen and (min-width: 961px) {
/*	#header.resize {
		height:calc(var(--headerHeight) * 0.8);
	}*/
}

#header > .wrapper {
/*	display:flex;
	align-items: center;
	justify-content: flex-start;
	flex-direction:column;*/

/*	display:grid;
	grid-template-rows: 55% 45%;*/

	height:100%;
}
@media only screen and (max-width: 960px) {
	#header > .wrapper {
		display:grid;
		grid-template-columns: 1fr auto;
		grid-template-rows: 100%;
		height:100%;
		padding:0;
	}
}

#header .inner {
	display:flex;
	align-items: center;
	justify-content: space-between;
	width:100%;
	height:100%;
	padding-top:0;
	padding-bottom:0;

	padding-left:4%;
	padding-right:4%;
}
@media only screen and (min-width: 961px) {
	#header .inner {
		padding-left:2%;
		padding-right:2%;
	}
}

#header .inner > h1 {
	display:flex;
	align-items: center;
	margin-top:0;
	margin-bottom:0;
	height:100%;
/*	margin-right:4%;*/
	padding-right:12px;
	padding-top:16px;
	padding-bottom:16px;
}
@media only screen and (max-width: 960px) {
	#header .inner > h1 {
		padding-right:8px;
		padding-top:12px;
		padding-bottom:12px;
	}
}
#header .inner > h1 > a {
	display:flex;
	align-items: center;
	margin-top:0;
	margin-bottom:0;
	height:100%;
}
#header-logo {
	display:block;
	max-height:100%;
}


/*	Main
	------------------ */
#main {
/*  display: flex;
  align-items: stretch;
  flex-direction: column;*/
}

#main .wrapper {
/*	display:grid;*/
/*	grid-template-columns: 33.33% 1fr;*/
/*	grid-template-columns: 30% 1fr;*/
/*	height:100%;*/
}
#contents-top {
/*	min-height: calc(100vh - var(--headerHeight));*/
/*		height: 40vw;
		max-height: 420px;*/
}
@media only screen and (max-width: 960px) {
/*	#main .wrapper {
	  display: flex;
	  align-items: stretch;
	  justify-content: flex-start;
	  flex-direction: column;
	}
	#contents-top {
		height: auto;
		min-height: 56.25vw;
	}*/
}


/*	Footer
	------------------ */
#footer .inner {
	padding-top:40px;
	padding-bottom:40px;

	grid-template-columns: 1fr 40%;
}

#copyright {
	margin-top:20px;
/*	text-align:center;*/
}





/*
 * Style
 * ================================================================================
 */
html {
	background-color: var(--footerFgColor);
}

#bg {
	position:fixed;
	width:100vw;
	height:100vh;
/*	background-image:url(../../images/bg.jpg);*/
	background-repeat:no-repeat;
	background-position:center top;
	background-size:cover;
	background-color:var(--bgColor);
	color:var(--fgColor);
}


/*	Header
	------------------ */
#header {
	color:var(--headerFgColor);
	background-color:var(--headerBgColor);
	backdrop-filter: blur(15px);
	-webkit-backdrop-filter: blur(15px);
/*	border-top:var(--color-blue) solid 6px;*/
/*	border-bottom:#c4c4c4 solid 1px;*/
}

/*	Main
	------------------ */


/*	Footer
	------------------ */
#footer {
	color: var(--footerFgColor);
	background-color:var(--footerBgColor);
}


/*	Nav
	------------------ */
#nav {
	height:100%;
}
#nav > ul {
	display: flex;
	align-items:stretch;
/*	justify-content:flex-end;*/
	width:100%;
	height:100%;
/*	gap:2%;*/
}
#nav li {
/*position:relative;*/
	height:100%;
}
/*#nav li:before {
	content:"";
	display:block;
	position:absolute;
	left:0;
	top:50%;
	margin-top:-0.5em;
	width:1px;
	height:1em;
	background-color:currentcolor;
}
#nav li:last-child:after {
	content:"";
	display:block;
	position:absolute;
	right:0;
	top:50%;
	margin-top:-0.5em;
	width:1px;
	height:1em;
	background-color:currentcolor;
}*/
#nav a {
	box-sizing:border-box;
	display: flex;
	align-items:center;
	justify-content:center;
	text-decoration: none;
	padding-left: 12px;
	padding-right: 12px;
/*	border-left: currentcolor solid 1px;*/
	border-bottom: transparent solid 3px;
	text-align:right;
/*font-weight:500;*/
	height:100%;
	color:var(--navFgColor);
	background-color:var(--navBgColor);
	white-space:nowrap;
/*font-size: clamp(1.2rem, -0.004rem + 2vw, 1.8rem);*/
}
#nav a:hover {
	border-bottom: currentcolor solid 3px;
/*opacity:1;*/
}
/*#nav a:after {
	font:var(--fa-font-solid);
	content: "\f107";
	margin-left:0.5em;
}*/

@media only screen and (max-width: 1280px) {
	#nav a {
		padding-left: 8px;
		padding-right: 8px;
		font-size:14px;
	}
}
@media only screen and (max-width: 960px) {
	#nav {
		display:block;
		position:fixed;
		top:0;
		left:0;
		width:100%;
		height:100vh;
		height:100dvh;
/*padding-left:0;
padding-right:0;*/

		padding-top:calc(var(--headerHeight) + var(--innerPaddingHeight));
/*		padding-top:var(--headerHeight);*/
		background-color:var(--color-theme1);
		overflow-y:scroll;
		z-index:-1;
	}
	#nav > ul {
		display: block;
	}
	#nav li {
		height:auto;
	}
	#nav li:before,
	#nav li:after {
		display:none !important;
	}
	#nav a {
		justify-content: flex-end;
		padding: 0.25em 2rem;
		margin-bottom: 0;
		font-size:2.4rem;
	}
}


/*	Nav Button
	------------------ */
#nav-btn {
	flex-shrink:0;
	margin-right:-7px;
	width:50px;
	height:50px;
	cursor:pointer;
display:none;
	z-index:1000;
}
#nav-icon {
	display:block;
	position:absolute;
	top:50%;
	left:50%;
	width:36px;
	height:2px;
	margin:-1px 0 0 -18px;
	transition: 0.2s;
	background:var(--color-white);
}
#nav-icon:before,
#nav-icon:after {
	display:block;
	content:'';
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
	transition: 0.3s;
	background:var(--color-white);
}
#nav-icon:before {
	margin-top:-10px;
}
#nav-icon:after {
	margin-top:10px;
}
#nav-icon.close {
	background:transparent;
}
#nav-icon.close:before,
#nav-icon.close:after {
	margin-top:0;
}
#nav-icon.close:before {
	transform:rotate(-45deg);
	-webkit-transform:rotate(-45deg);
}
#nav-icon.close:after {
	transform:rotate(-135deg);
	-webkit-transform:rotate(-135deg);
}












/*
 * Compornent
 * ================================================================================
 */
ul.disc {
  list-style-type: disc;
  margin: 0;
  padding-left: 1em;
}

.bg-blur {
	backdrop-filter: blur(15px);
	-webkit-backdrop-filter: blur(15px);
}

#contents a, 
a.sitelink {
/*  filter: hue-rotate(180deg);*/
	text-decoration:underline;
}


/*	Line
	------------------ */
.line.dashed {
	height:1px;
  background-image : linear-gradient(to right, #999, #999 4px, transparent 4px, transparent 8px);
  background-size: 8px 1px;
  background-position: left bottom;
  background-repeat: repeat-x;
}


/*	Label
	------------------ */
h2, h3, h4, h5, h6 {
	margin:0;
	font-size: 100%;
	font-weight:normal;
	line-height:normal;
}

h1, h2, h3, h4, h5, h6 {
  margin: 1.5rem 0 0.5rem;
}

h1 {
  font-size: 4rem;
  font-weight: 700;
  color: currentcolor;
  text-shadow: 0 0 10px currentcolor;
}

h2 {
  font-size: 3.0rem;
  font-weight: 700;
}

h3 {
	font-size: 2.2rem;
	margin-bottom: 0.9em;
	padding-bottom: 0.9em;
	border-bottom: 1.5px solid currentcolor;
}

h4 {
  font-size: 2.0rem;
  opacity: 0.85;
  font-weight: 400;
}

h5 {
  font-size: 1.6rem;
	margin-bottom:0.5em;
	padding:0.5em calc(var(--boxPaddingWidth) - 1.5px);
	border-left:currentcolor solid 1.5px;
	font-weight:400;
  opacity: 0.75;
/*	color:var(--color-black60);*/
}

h6 {
  font-size: 1.4rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight:700;
  opacity: 0.6;
}

h2 + p, 
h3 + p, 
h4 + p, 
h5 + p, 
h6 + p, 
p:first-child {
	margin-top:0;
}

/* スマホ用調整 */
@media only screen and (max-width: 430px) {
	h2 {

	}
	h3 {

	}
	h4 {

	}
	h5 {

	}
	h6 {

	}
}


/* Table
	------------------ */
table {
	border-collapse: collapse;
}
th,td {
	padding:0.5em 2em;
	border:var(--color-bbb) solid 1px;
}
th {
	background-color:var(--color-black50);
	color:var(--color-white);
	font-weight:500;
}
td {
	background-color:var(--color-white60);
}
/*.table-wrapper {
	min-width:0;
	max-width:100%;
}
.table-wrapper > table {
	min-width:100%;
}*/
@media only screen and (max-width: 960px) {
	.table-wrapper {
		overflow-x:auto;
	}
	.table-wrapper > table {
		white-space: nowrap;
	}
}









/*	List Table
	------------------ */
.listtable {
	display:grid;
	grid-template-columns: auto auto;
	margin-top:1.6rem;
/*	place-items: center;*/
}
.listtable.left {
	place-content:start start;
}
.listtable.center {
	place-content: start center;
}
.listtable.right {
	place-content:start end;
}
.listtable.col2 {
	grid-template-columns: auto auto;
}
.listtable.col3 {
	grid-template-columns: auto auto auto;
}
.listtable.col4 {
	grid-template-columns: auto auto auto auto;
}

.listtable dt,
.listtable dd {
  display: flex;
  align-items: center;
  justify-content: center;
/*	min-height:3em;*/
	padding:0.5em 2em;
	margin-bottom:-1px;
	margin-right:-1px;
	border:var(--color-bbb) solid 1px;
	line-height:1.1;
/*place-self: center;*/
}
.listtable dt {
	background-color:var(--color-black50);
	color:var(--color-white);
}
.listtable dd {
	background-color:var(--color-white60);
}
.listtable .left {
  justify-content: flex-start;
}
.listtable .center {
  justify-content: center;
}
.listtable .right {
  justify-content: flex-end;
}

@media only screen and (max-width: 960px) {
	.listtable.responsible {
		grid-template-columns: 1fr !important;
	}
}
@media only screen and (max-width: 430px) {

}


/*	Link Button
	------------------ */
.linkbtn {
  position: relative;
	display:inline-flex;
	align-items:center;
	justify-content:center;
	margin:1.6rem 0;
	padding:0 2.8em;
	height:3em;
	border-radius:1.5em;
	background-color:var(--color-theme1);
	text-decoration:none !important;
	color:#fff;
	font-weight:500;
	line-height:1.1;
}
.linkbtn::before {
	font:var(--fa-font-solid);
  position: absolute;
  top:50%;
  transform:translatey(-50%);
}
.linkbtn.arrow-right::before {
	content: "\f105";
  left:auto;
  right:1.2em;
}
.linkbtn.arrow-down::before {
	content: "\f063";
  left:auto;
  right:1.2em;
}
.linkbtn.file::before {
	font:var(--fa-font-regular);
	content: "\f15b";
  left:1.2em;
  right:auto;
}
.linkbtn.site::before {
	content: "\f0c1";
  right:1.2em;
  left:auto;
}


/*	To Top
	------------------ */
.totop {
	display:flex;
	align-items:center;
	justify-content:center;
	position:fixed;
	bottom:20px;
	right:20px;
	width:44px;
	height:44px;
	background:var(--color-black30);
	border-radius:4px;
	color:var(--color-white);
	font-size:20px;
	z-index: 100;
}
.totop:before {
	font:var(--fa-font-solid);
	content: "\f106";
}

/*	Form
	------------------ */





/*
 * Responsive
 * ================================================================================
 */
@media only screen and (max-width: 960px) {
	.mobile-w-full {
		width:100%;
	}

}




/*	
/* -------------------------------------------------------------------------------- */
.readmore {
	display:inline-block;
	padding:0.75em;
	font-size:1.4rem;
	color:var(--fgColor);
	border:1.5px solid currentcolor;
/*	font-weight:300;*/
}

#footer-nav ul {
  display: flex;
	flex-wrap:wrap
}
#footer-nav a {
  white-space:nowrap;
	margin-right:1em;
	text-decoration:underline;
	font-size:110%;
	line-height:2;
}





.bg-img2 {
	background-image: url(../../images/circle_2.svg);
	background-position:center;
	background-repeat:no-repeat;
	background-size:90%;
}
.bg-img3 {
	background-image: url(../../images/circle_3.svg);
	background-position:center;
	background-repeat:no-repeat;
	background-size:90%;
}








.accordion-content {
	display:none;
}


