@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
#gHeader {
	margin-bottom: -8.9rem;
	background: none;
}
#gHeader h1 a {
	display: block;
	position: relative;
}
#gHeader h1 a::after {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background: url(../img/common/logo_white.png) no-repeat left top/100%;
	z-index: 1;
	opacity: 0;
}
#gHeader.white:after {
	position: absolute;
	left: 0;
	top: 0;
	width: calc(100% - 17rem);
	height: 100%;
	z-index: -1;
	background: rgba(255, 255, 255, 0.7);
	content: "";
	opacity: 0;
}
#gHeader.white:not(.fix) h1 img {
	opacity: 0;
}
#gHeader.white:not(.fix) h1 a::after {
	opacity: 1;
}
#gHeader.white:not(.fix) #gNavi .menuList > li > a,#gHeader.white:not(.fix) #gNavi .menuList > li > .ttl {
	color: #fff;
}
#gHeader.fix {
	background: #D9ECF4;
}
#gHeader.fix h1 {
	opacity: 1;
}
#gHeader.fix:after {
	display: none;
}
#main .content {
	max-width: 109.6rem;
}
#main .mainVisual {
	margin-bottom: 3.8rem;
	width: calc(100% - 17rem);
	position: relative;
}
#main .mainVisual .movie {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	aspect-ratio: 1110/610;
	border-radius: 0 0 3rem 0;
	overflow: hidden;
	z-index: 10;
	display: none;
}
#main .mainVisual .movie video {
	width: 100%;
	width: calc(100% + 1px);
	height: 100%;
	object-fit: cover;
	display: block;
}
#main .mainVisual .movie .btn {
	position: absolute;
	right: 4rem;
	bottom: 4rem;
	width: 5.1rem;
}
#main .mainVisual .movie .btn .close {
	display: none;
}
#main .mainVisual .movie .btn.on img {
	display: none;
}
#main .mainVisual .movie .btn.on img.close {
	display: block;
}
#main .mainVisual .mainImg {
	min-height: 61rem;
	padding: 0 0 0 6rem;
	background: #D9ECF4;
	border-radius: 0 0 3rem 0;
	display: flex;
	align-items: flex-end;
	overflow: hidden;
}
#main .mainVisual .mainImg .content {
	align-items: center;
	width: 100%;
}
#main .mainVisual .mainImg .txtBox {
	margin: 3.6rem 0.6rem 0 0;
	width: 44rem;
}
#main .mainVisual .mainImg .title {
	margin-bottom: 10rem;
	width: 42.9rem;
}
#main .mainVisual .pickTtl {
	margin: 0 0 0.7rem 0.3rem;
	display: flex;
	align-items: center;
	color: #0080B5;
	font-size: 1.9rem;
}
#main .mainVisual .pickTtl:after {
	margin-left: 1.3rem;
	flex: 1;
	height: 1px;
	background-color: #0080B5;
	display: inline-block;
	content: "";
}
#main .mainVisual .pick a {
	display: flex;
	align-items: flex-start;
}
#main .mainVisual .pick a:hover {
	opacity: 0.7;
}
#main .mainVisual .pick .pho {
	width: 15.1rem;
	border-radius: 0.6rem;
	aspect-ratio: 150/89;
	overflow: hidden;
}
#main .mainVisual .pick .pho img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#main .mainVisual .pick .rBox {
	margin: 0.2rem 0 0 1.4rem;
	flex: 1;
}
#main .mainVisual .pick .rBox .date {
	margin-bottom: 0.6rem;
	color: #0075B3;
	font-size: 1.2rem;
	letter-spacing: 0.14em;
}
#main .mainVisual .pick .rBox .txt {
	font-size: 1.4rem;
	line-height: 1.86;
	letter-spacing: 0.04em;
	text-align: justify;
}
#main .mainVisual .mainImg .phoBox {
	width: 58.3rem;
}
#main .topNews {
	margin-bottom: 6.5rem;
	padding: 1rem 0 0.9rem;
	position: relative;
}
#main .topNews:after {
	position: absolute;
	left: 0;
	top: 0;
	width: calc(50% + 20rem);
	height: 100%;
	z-index: -1;
	background: #E6F0F7;
	border-radius: 0rem 0.5rem 0.5rem 0rem;
	content: "";
}
#main .topNews .content {
	max-width: 114.6rem;
	align-items: flex-start;
}
#main .topNews h2 {
	margin: -0.2rem 1.2rem 0 0;
	color: #0075B3;
	font-size: 1.9rem;
	line-height: 1.4;
	font-weight: 400;
	letter-spacing: 0.16em;
}
#main .topNews dl {
	flex: 1;
	max-width: 66rem;
}
#main .topNews dt {
	float: left;
	font-size: 1.5rem;
}
#main .topNews dt .tag {
	margin-right: 1rem;
}
#main .topNews dt .tag span {
	padding: 0.1rem 0.5rem 0.2rem;
	display: inline-block;
	min-width: 12.3rem;
	color: #fff;
	text-align: center;
	background: #007F47;
	border-radius: 1.2rem;
}
#main .topNews dt .tag .bgColor01 {
	background: #0080B5;
}
#main .topNews dt .tag .bgColor02 {
	background: #007F47;
}
#main .topNews dt .tag .bgColor03 {
	background: #BC771A;
}
#main .topNews dd {
	padding: 0.1rem 0 0 14.6em;
	font-size: 1.5rem;
}
#main .topNews dd a:hover {
	opacity: 0.7;
}
#main .emergency {
	margin: 0 auto 2.5rem;
	padding: 1.5rem 2rem 2rem 12rem;
	max-width: 96.2rem;
	background: url(../img/common/icon15.png) no-repeat 3.8rem center/4.1rem;
	border: 1px solid #485E91;
}
#main .emergency p {
	line-height: 1.75;
	font-feature-settings: normal;
}
#main .emergency p:hover {
	opacity: 0.7;
}
#main .topSlide {
	padding: 4rem 0;
}
#main .topSlide .slick-slide {
	margin: 0 0.5rem;
	width: 25.5rem;
}
#main .topSlide a {
	display: block;
	padding: 0 1rem 1rem;
	background: #D9ECF4;
	border-radius: 1rem;
	overflow: hidden;
}
#main .topSlide a p {
	margin: 0 -1rem 1rem;
	padding: 1.3rem 1.8rem;
	min-height: 10.8rem;
	color: #fff;
	font-size: 2.1rem;
	background: #64B2D2;
	transition: .3s;
}
#main .topSlide .slick-current p {
	background: #0080B5;
}
#main .topSlide a img {
	width: 100%;
	border-radius: 0.6rem;
}
#main .slick-dots {
	margin-top: 2.7rem;
	display: flex;
	justify-content: center;
}
#main .slick-dots li {
	margin: 0 0.65rem;
	width: 4.7rem;
	height: 1.1rem;
	cursor: pointer;
	border-radius: 0.4rem;
	background-color: #64B2D2;
}
#main .slick-dots li button {
	display: none;
}
#main .slick-dots li.slick-active {
	background-color: #0080B5;
}
#main .news {
	padding: 4rem 0;
}
#main .news .content {
	position: relative;
}
#main .news .comNewsList {
	margin-left: auto;
	max-width: 97rem;
}
#main .btnMore {
	position: absolute;
	right: 0.7rem;
	top: 7.3rem;
}
#main .btnMore a {
	color: #004098;
}
#main .btnMore a:hover {
	opacity: 0.7;
}
#main .works {
	padding: 3.3rem 0;
	position: relative;
	overflow: hidden;
}
#main .works:after {
	position: absolute;
	left: 0;
	top: 18rem;
	width: 100%;
	height: calc(100% - 31.5rem);
	background: #D9ECF4;
	z-index: -1;
	content: "";
}
#main .works .ttlBox {
	margin: 0 0 2rem auto;
	max-width: 61.5rem;
}
#main .works .ttlBox h2 {
	margin-bottom: 2.3rem;
}
#main .works .ttlBox p {
	margin-left: 0.6rem;
	color: #0080B5;
	font-size: 1.4rem;
	line-height: 1.7;
	font-weight: 500;
	letter-spacing: 0.04em;
}
#main .works .rBox {
	margin-left: auto;
	max-width: 97.4rem;
}
#main .works .slideBox {
	margin-bottom: 4.7rem;
	align-items: flex-start;
}
#main .works .phoList {
	margin-top: -6.1rem;
	width: 30.2rem;
	background-color: #fff;
	border-radius: 1rem;
	overflow: hidden;
	position: relative;
	z-index: 1;
}
#main .works .phoList li {
	position: relative;
	border-radius: 1rem;
	overflow: hidden;
}
#main .works .phoList .slick-slide {
	line-height: 0;
}
#main .works .phoList p {
	position: absolute;
	left: 3.6rem;
	top: 2.2rem;
	color: #0080B5;
	font-size: 2.1rem;
	line-height: 1.5;
	letter-spacing: 0.03em;
}
#main .works .phoList img {
	width: 100%;
}
#main .works .txtList {
	margin-left: -0.5rem;
	flex: 1;
}
#main .works .txtList li {
	border-bottom: 1px solid #0080B5;
}
#main .works .txtList a {
	display: block;
	position: relative;
	padding: 1.3rem 7rem 1.2rem 13rem;
	font-size: 1.2rem;
	letter-spacing: 0.04em;
	line-height: 1.75;
	word-wrap: break-word;
}
#main .works .txtList a .txt {
	position: relative;
	z-index: 1;
}
#main .works .txtList a .ttl {
	margin-bottom: 0.2rem;
	display: block;
	font-size: 2rem;
	color: #0080B5;
	line-height: 1.4;
	transition: .3s;
}
#main .works .txtList a:before {
	position: absolute;
	left: 0;
	top: -1px;
	width: 999rem;
	height: calc(100% + 2px);
	opacity: 0;
	transition: .3s;
	background: #0080B5;
	content: "";
}
#main .works .txtList a:after {
	position: absolute;
	right: 4.5rem;
	top: 50%;
	transform: translateY(-50%);
	width: 1.9rem;
	height: 1.9rem;
	z-index: 1;
	background: url(../img/common/icon01.png) no-repeat left top/100%;
	content: "";
}
#main .works .txtList .on a {
	color: #fff;
}
#main .works .txtList .on .ttl {
	color: #fff;
}
#main .works .txtList .on a:before {
	opacity: 1;
}
#main .works .txtList .on a:after {
	background-image: url(../img/common/icon02.png);
}
#main .works .comSearchBox {
	margin-top: 0;
}
#main .pickup {
	padding-top: 5.7rem;
}
#main .pickup .content {
	position: relative;
}
#main .pickup h2 {
	width: 27.3rem;
}
#main .pickup h2 .en {
	line-height: 1.2;
}
#main .pickup .pickList {
	flex: 1;
	gap: 1.9rem;
}
#main .pickup .pickList > li {
	width: calc((100% - 3.8rem)/3);
}
#main .pickup .pickList a {
	display: block;
	padding: 1.1rem 1.1rem 3.4rem;
	background: #D9ECF4;
	border-radius: 0.5rem;
	min-height: 100%;
}
#main .pickup .pickList img {
	width: 100%;
	border-radius: 0.5rem;
	margin-bottom: 2.6rem;
}
#main .pickup .pickList p {
	font-size: 1.3rem;
	line-height: 2;
	letter-spacing: 0.04em;
}
#main .pickup .btnMore {
	top: -3.2rem;
	right: 0;
}
#main {
	margin-bottom: 10.2rem;
}
@media all and (min-width: 739px) {
	#main .topSlide a:hover p {
		background: #0080B5;
	}
	#main .works .txtList a:hover {
		color: #fff;
	}
	#main .works .txtList a:hover .ttl {
		color: #fff;
	}
	#main .works .txtList a:hover:before {
		opacity: 1;
	}
	#main .works .txtList a:hover:after {
		background-image: url(../img/common/icon02.png);
	}
	#main .pickList a:hover {
		color: #fff;
		background: #0080B5;
	}
}
@media all and (max-width: 738px) {
	#container:after {
		display: block;
		width: 17.8rem;
		height: 42.7rem;
		border-radius: 0 0 0 1.6rem;
	}
	#gHeader {
		margin-bottom: 0;
		position: fixed;
		justify-content: flex-end;
		background: none !important;
	}
	#gHeader h1 {
		display: none;
	}
	#main .content {
		margin: 0 1.5rem;
	}
	#main .mainVisual {
		margin-bottom: 1.6rem;
		width: calc(100% - 6.7rem);
	}
	#main .mainVisual .movie {
		height: auto;
		aspect-ratio: 616/772;
		border-radius: 0 0 1rem 0;
	}
	#main .mainVisual .movie .btn {
		right: 2rem;
		bottom: 2rem;
		width: 4.7rem;
	}
	#main .mainVisual .mainImg {
		margin-bottom: 5.2rem;
		min-height: inherit;
		padding: 0;
		border-radius: 0 0 1rem 0;
		display: block;
		overflow: hidden;
		position: relative;
	}
	#main .mainVisual .mainImg .content {
		display: block;
		margin: 0;
		height: 100%;
	}
	#main .mainVisual .mainImg .txtBox {
		margin: 0;
		width: auto;
	}
	#main .mainVisual .mainImg .title {
		margin-bottom: 2.9rem;
		width: 21.4rem;
	}
	#main .mainVisual .pick {
		margin: 0 -4rem 0 1.9rem;
	}
	#main .mainVisual .pick a {
		display: block;
	}
	#main .mainVisual .pick .pho {
		width: auto;
		margin-bottom: 0.8rem;
		border-radius: 0;
		display: flex;
		align-items: center;
		aspect-ratio: inherit;
	}
	#main .mainVisual .pick .pho img {
		margin-right: 1.3rem;
		width: 14.8rem;
		height: 10.4rem;
		border-radius: 0.5rem;
	}
	#main .mainVisual .pick .phoTxt {
		margin-top: 0.5rem;
		flex: 1;
	}
	#main .mainVisual .pick .pho .ttl {
		margin-bottom: 0.5rem;
		color : #0080B5;
		font-size: 2rem;
	}
	#main .mainVisual .pick .rBox {
		margin: 0 0.3rem;
	}
	#main .mainVisual .pick .date {
		margin-bottom: 0.5rem;
		color: #0075B3;
		font-size: 1.5rem;
		letter-spacing: 0.04em;
	}
	#main .mainVisual .pick .rBox .txt {
		font-size: 1.65rem;
		line-height: 1.5;
		letter-spacing: 0.04em;
	}
	#main .mainVisual .mainImg .phoBox {
		width: auto;
		position: relative;
	}
	#main .mainVisual .mainImg .phoBox .logo {
		position: absolute;
		left: 1.1rem;
		top: 1.1rem;
		width: 21.4rem;
		z-index: 101;
	}
	#main .topNews {
		margin-bottom: 2rem;
	}
	#main .topNews:after {
		width: 100%;
		border-radius: 0;
	}
	#main .topNews .content {
		margin: 0;
		flex-wrap: nowrap;
	}
	#main .topNews h2 {
		margin: -0.4rem 1rem 0 1.7rem;
		font-size: 1.85rem;
		white-space: nowrap;
	}
	#main .topNews dl {
		max-width: inherit;
	}
	#main .topNews dt {
		font-size: 1.45rem;
	}
	#main .topNews dt .tag span {
		min-width: 11.9rem;
	}
	#main .topNews dd {
		padding-left: 14.6em;
		font-size: 1.45rem;
		white-space: nowrap;
	}
	#main .emergency {
		margin: 0 1.2rem;
		padding: 8.9rem 1.5rem 1.5rem;
		background-size: 5.1rem;
		background-position: center top 2.4rem;
		border-color: #0080B5;
	}
	#main .emergency p {
		font-size: 1.65rem;
		line-height: 1.58;
		letter-spacing: 0.04em;
		font-feature-settings: "palt";
		text-align: justify;
	}
	#main .topSlide {
		padding-bottom: 2rem;
	}
	#main .topSlide .slick-slide {
		margin: 0 0.4rem;
		width: 21.5rem;
	}
	#main .topSlide a {
		padding: 0 0.9rem 0.9rem;
		border-radius: 0.9rem;
	}
	#main .topSlide a p {
		margin: 0 -0.9rem 0.9rem;
		padding: 1rem 1.5rem;
		min-height: 9rem;
		font-size: 1.8rem;
	}
	#main .topSlide a img {
		border-radius: 0.4rem;
	}
	#main .slick-dots {
		margin-top: 2.5rem;
	}
	#main .slick-dots li {
		margin: 0 0.65rem;
		width: 4.2rem;
		height: 1rem;
		border-radius: 0.6rem;
	}
	#main .news {
		padding: 1.9rem 0 1.4rem;
	}
	#main .news .comNewsList {
		max-width: inherit;
	}
	#main .btnMore {
		margin-top: 0.8rem;
		position: static;
		text-align: right;
	}
	#main .btnMore a {
		font-size: 2rem;
		text-transform: uppercase;
	}
	#main .works {
		padding: 1.5rem 0;
	}
	#main .works:after {
		display: none;
	}
	#main .works .ttlBox {
		margin: 0 0 1.2rem auto;
		max-width: inherit;
	}
	#main .works .ttlBox h2 {
		margin-bottom: 1rem;
	}
	#main .works .ttlBox p {
		margin-left: 0.6rem;
		font-size: 1.7rem;
		line-height: 1.76;
	}
	#main .works .rBox {
		max-width: inherit;
	}
	#main .works .slideBox {
		margin: 0 -1.5rem -13rem;
		padding-bottom: 16.5rem;
		display: block;
		background : #D9ECF4;
	}
	#main .works .phoList {
		display: none;
	}
	#main .works .txtList {
		margin-left: 0;
		flex: 1;
		border-bottom: 1px solid #0080B5;
	}
	#main .works .txtList li {
		border-bottom: none;
	}
	#main .works .txtList a {
		padding: 1.5rem 6.3rem 1.2rem 2rem;
		font-size: 1.65rem;
		line-height: 1.64;
		text-align: justify;
	}
	#main .works .txtList a .ttl {
		margin-bottom: 0.8rem;
		font-size: 2.5rem;
		line-height: 1;
		letter-spacing: 0;
	}
	#main .works .txtList a:before {
		display: none;
	}
	#main .works .txtList a:after {
		right: 2.1rem;
		width: 2.5rem;
		height: 2.5rem;
	}
	#main .works .txtList li:nth-child(2n-1) a {
		background : #0080B5;
	}
	#main .works .txtList li:nth-child(2n-1) a {
		color: #fff;
	}
	#main .works .txtList li:nth-child(2n-1) a .ttl {
		color: #fff;
	}
	#main .works .txtList li:nth-child(2n-1) a:after {
		background-image: url(../img/common/icon02.png);
	}
	#main .pickup {
		padding-top: 2.5rem;
	}
	#main .pickup .content {
		display: block;
	}
	#main .pickup h2 {
		margin: 0 0 2rem 0.8rem;
		width: auto;
	}
	#main .pickup h2 .en {
		line-height: 1;
	}
	#main .pickup .pickList {
		margin: 0 -1.5rem;
		display: block;
	}
	#main .pickup .pickList .slick-slide {
		margin: 0 1rem;
		width: 26.8rem;
	}
	#main .pickup .pickList a {
		padding: 1.2rem 1.2rem 1.8rem;
	}
	#main .pickup .pickList img {
		margin-bottom: 1.5rem;
	}
	#main .pickup .pickList p {
		font-size: 1.75rem;
		line-height: 1.57;
	}
	#main .pickup .slick-current a {
		color: #fff;
		background: #0080B5;
	}
	#main .pickup .slick-dots {
		margin-top: 3.3rem;
	}
	#main .pickup .btnMore {
		margin-bottom: 1rem;
	}
	#main {
		margin-bottom: 6.8rem;
	}
}
