/*-------------------- css --------------------*/
html, body{
    margin:0;
    padding:0;
    height:100%;
}
.mobile{
	display:none;
}

.mv_area{
    display: flex;
    justify-content: center;
    align-items: center;
    height:100%;

    img{
        width:150px;
    }
}


.zen-antique-soft-regular {
  font-family: "Zen Antique Soft", serif;
  font-weight: 400;
  font-style: normal;
}
.noto-sans-jp {
  font-family: "Noto Sans JP", sans-serif;
  font-style: normal;
}
.biz-udmincho-regular {
  font-family: "BIZ UDMincho", serif;
  font-weight: 400;
  font-style: normal;
}
body {
	font-size: 16px;
	font-family: "Noto Sans JP", sans-serif;
  	font-style: normal;
	font-weight: 300;
	color: black;
	background: white;
	line-height: 1.8;
/* 	max-width: 1440px;
	margin: 0 auto; */
}
body a {
	color: #000B46;
	text-decoration: none;
}
h1, h2, h3 {
	font-family: "Zen Antique Soft", serif;
	font-weight: 400;
	font-style: normal;
	margin: 0;
	color: #000B46;
}
h1 {
	font-size: 24px;
}
h2 {
	font-size: 20px;
}
h3 {
	font-size: 18px;
}
section {
/* 	padding: 50px 100px; */
}
img {
	display: block;
	width: auto;
	max-width: 100%;
}
/* ===== Header ===== */
#header {
	height:80px;
	background: #000B46;
	color: white;
}
#header .header-content {
	max-width: 1200px;
	height:100%;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0 20px;
}
#header .site-logo {
	width: 260px;
}
.fat-nav {
	display: none;
}



/* ===== Menu ===== */
#main-nav {
	display: flex;
	align-items: center;
	gap: 40px;
	margin: 0;
	padding: 0;
}
#main-nav .menu-item {
	font-size: 14px;
	color: white;
	padding: 0;
	margin: 0;
	display: block;
	font-weight: 400;
}
#main-nav .menu-item  a {
	color: white;
}



/* ===== Footer ===== */
#footer {
	position:relative;
	padding:50px 20px;
	color: white;
	
	&:before{
		content:'';
		position:absolute;
		top:0;
		left:0;
		width:50%;
		height:100%;
		background: #000B46;
		z-index:1;
	}
	&:after{
		content:'';
		position:absolute;
		top:0;
		right:0;
		width:50%;
		height:100%;
		background: rgb(0 11 70 / 80%) 50%;
		z-index:1;
	}
}
.footer_wrap{
	display:flex;
	position:relative;
	max-width:1200px;
	margin:0 auto;
	z-index:2;
}
#footer .footer-left {
	flex: 1;
/* 	background: #000B46; */
	padding-right:50px;
/* 	padding: 50px 50px 50px 175px; */
}
#footer .footer-right {
	flex: 1;
/* 	background: rgb(0 11 70 / 80%) 50%; */
	padding-left:50px;
/* 	padding: 50px 50px 50px 90px; */
}
.footer-logo {
	display: block;
	margin-bottom: 20px;
	
	img{
		width:260px;
	}
}
.footer-menu  {
/* 	margin-bottom: 250px; */
}
.footer-menu ul {
	padding: 0 125px 0 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
	gap: 4%;
}
.footer-menu ul li {
	display: block;
	width: 48%;
	background: url(../../uploads/arrow-white.png) no-repeat left top 4px;
	padding-left: 22px;
	margin: 0 0 30px;
	box-sizing: border-box;
}
.footer-menu ul li a {
	color: white;
}
.footer-info a{
	color:#ffffff;
}
.copyright {
	text-align: right;
}


/* ===== Home Page ===== */
.title-line {
	text-align: center;
	margin-bottom: 60px;
}
.title-line h2 {
	display: inline-block;
    border-bottom: 2px solid;
	font-size:30px;
    line-height: 1.4;
}
.row {
	display: flex;
	gap: 50px;
}
.row .column {
	.btn{
		font-size:16px;
	}
}
.main-section {
	background: url(../../uploads/home01.webp) no-repeat center center/cover;
	height: 500px;
}
.main-section .box{
	display: flex;
	align-items: center;
	height:100%;
	max-width:1200px;
	margin:0 auto;
	padding: 0 20px;
}
.main-section h1 {
	display: block;
    padding: 30px 50px;
    background: rgb(150 150 150 / 75%);
    border-radius: 30px;
    max-width: 500px;
	font-size:34px;
    box-sizing: border-box;
}
.news-section h2 {
	margin-bottom: 40px;
}
.btn {
	color: white;
	background: #000B46;
	font-weight: 400;
	padding: 8px 20px;
    display: inline-block;
}
.top_section{
	padding:100px 20px;
}
.top_wrap{
	max-width:1200px;
	margin:0 auto;
}

.news-list {
	flex: 1;
}
.news-list ul li {
	border-bottom: 3px solid #878787;
	display: flex;
	gap: 50px;
	padding: 45px 20px 45px 0;
	background: url(../../uploads/Icon-arrow-blue.png) no-repeat right;
}
.news-list ul li:first-child {
	border-top: 3px solid #878787;
}
.news-list ul li .wp-block-post-date {
	font-size: 14px;
	font-weight: 400;
	color: #404040;
	margin: 0;
}
.news-list ul li .taxonomy-category {
	font-size: 14px;
	font-weight: 300;
	background: rgb(217 217 217 / 50%);
    margin: 0;
    display: block;
    padding: 2px 15px;
}
.news-list ul li .wp-block-post-title {
	font-size: 16px;
	font-family: "Noto Sans JP", sans-serif;
  	font-style: normal;
	font-weight: 300;
	margin: 0;
}

.service-section {
	background: rgb(0 11 70 / 15%);
/* 	padding-left: 175px;
	padding-right: 175px; */
}
.banner-service {
	position: relative;
	margin-bottom: 100px;
	
	> img{
		width:100%;
	}
}
.banner-service .banner-content img {
	display: block;
	margin: 0 auto 5px;
}
.banner-service .banner-content {
	position: absolute;
	bottom: 0;
	right: 0;
	background: rgb(217 217 217 / 75%);
	padding: 50px 20px 85px;
	border-radius: 50px 0 0 0;
	text-align: center;
	max-width: 500px;
	overflow: hidden;
}
.banner-service .banner-content h3 {
	font-size: 16px;
	margin-bottom: 30px;
}
.banner-service .banner-content p  {
	font-family: "BIZ UDMincho", serif;
	  font-weight: 400;
	  font-style: normal;
}
.banner-service .banner-content a {
	display: block;
    position: absolute;
    width: 80px;
    height: 80px;
    right: -20px;
    bottom: -20px;
    background: #000B46;
    border-radius: 50%;
    padding: 24px 30px;
    box-sizing: border-box;
}
.banner-service.left .banner-content {
	right: auto;
	left: 0;
	border-radius: 0 50px 0 0;
}

.info-section {
/* 	padding-left: 175px;
	padding-right: 175px; */
}
.info-section img {
	display: block;
	text-align: center;
	margin: 0 auto 50px;
}
.company-info {
	max-width: 620px;
	margin: 0 auto;
	
	dl{
		display: grid;
		grid-template-columns:200px 1fr;
		margin:0;
		padding: 45px 0;
		border-bottom: 2px solid #878787;
		
		&:first-child{
			padding-top:0;
		}
		&:last-child{
			padding-bottom:0;
			border-bottom: none;
		}
		dt{
			font-weight: 400;
		}
		dd{
			margin:0;
		}
	}
}

.access-section  {
	background: rgb(0 11 70 / 15%);
/* 	padding-left: 175px;
	padding-right: 175px; */
	font-family: "BIZ UDMincho", serif;
	font-weight: 400;
	font-style: normal;
}
.access-section .column {
	flex: 1;
}
.access-section .column dl{
	margin:0;
}
.access-section .column dl dt{
	margin-bottom: 10px;
}
.access-section .column dl dd{
	margin:0 0 30px;
	padding-left: 18px;
	color: #000B46;
}

/* .access-section .column h3 {
	margin-bottom: 10px;
}
.access-section .column p {
	color: #000B46;
	padding-left: 18px;
	margin:0 0 30px;
} */


/* Category */
.news_main {
	padding: 50px 20px;
}
.news_wrap{
	max-width:1200px;
	margin:0 auto;
}
.category-page .category-title {
	text-align: center;
	margin-bottom: 30px;
}
.category-page .category-title h1 {
	display: inline-block;
	border-bottom: 2px solid;
}
.category-page .post-list {
	display: block;
	padding: 0;
	margin: 0;
}
.category-page .post-list .post-item {
	display: block;
	border-bottom: 3px solid #878787;
	padding: 45px 20px 45px 0;
	background: url(../../uploads/Icon-arrow-blue.png) no-repeat right;
}
.category-page .post-list .post-item:first-child {
	border-top: 3px solid #878787;
}
.category-page .post-list .post-item .post-content {
	display: flex;
	gap: 50px;
}

.category-page .post-list .post-item .post-content .post-date {
	font-size: 14px;
	font-weight: 400;
	color: #404040;
	margin: 0;
}
.category-page .post-list .post-item .post-content .post-cat{
	font-size: 14px;
	font-weight: 300;
	background: rgb(217 217 217 / 50%);
    margin: 0;
    display: block;
    padding: 2px 15px;
}
.category-page .post-list .post-item .post-content .post-title h2 {
	font-size: 16px;
	font-family: "Noto Sans JP", sans-serif;
  	font-style: normal;
	font-weight: 300;
	margin: 0;
}
.pagination {
	text-align: center;
	margin-top: 30px;
}
.pagination .nav-links .page-numbers {
	background: white;
	border: 1px solid #000B46;
	color: #000B46;
	padding: 2px 12px;
    display: inline-block;
}
.pagination .nav-links .page-numbers.current, .pagination .nav-links .page-numbers:hover {
	background: #000B46;
	color: white;
}


/* Post Detail */
.news_main .news_detail_head .date {
	display: flex;
	gap: 16px;
	align-items: center;
    margin: 0 0 10px;
}
.news_main .news_detail_head .date .category {
	font-size: 14px;
    font-weight: 300;
    background: rgb(217 217 217 / 50%);
    margin: 0;
    display: block;
    padding: 2px 15px;
}
.news_return{
	margin-top:50px;
	
	a{
		display:block;
		width:300px;
		margin:0 auto;
		padding:20px;
		font-size:16px;
		text-align:center;
		color:#ffffff;
		background-color:#000B46;
	}
}

/*-------------------- question ang answer --------------------*/
.que_ans_section{
/* 	padding-left: 175px;
    padding-right: 175px; */

	.section_contents{
		max-width: 1200px;
		margin: 0 auto;

		.que_ans_lists{
			display: grid;
			grid-gap: 20px;

			.que_ans_box{
				position: relative;
				cursor: pointer;
				transition: 0.3s;

				.que_box{
					position: relative;
					cursor: pointer;
					transition: 0.3s;
					border: 1px solid #c6c6c6;
				}
				.que_box:before {
					content: '';
					position: absolute;
					top: calc(45%);
					right: 20px;
					width: 10px;
					height: 10px;
					border-right: 2px solid #777777;
					border-bottom: 2px solid #777777;
					transform: translateY(-50%) rotate(45deg);
				}
				.que_box.active:before {
					top: calc(55%);
					transform: translateY(-50%) rotate(-135deg);
				}
				.ans_box{
					border: 1px solid #c6c6c6;
					background: #ededed;
					border-top: none;
				}
				dl{
					display: flex;
					justify-content: flex-start;
					align-items: center;
					grid-gap: 20px;
					margin: 0;
					padding: 10px 40px 10px 20px;
					font-size: 14px;
				}
				dt, dd{
					margin: 0;
				}
				dt{
					font-size: 28px;
					font-weight: bold;
				}
				.blue{
					color: #00539b;
				}
				.red{
					color: #c21f32;
				}
			}
		}
	}
}

.sub_container{
	padding:50px 20px;
}
.sub_section{
	max-width:1200px;
	margin:0 auto;
	
	.title{
		display:flex;
		justify-content:center;
		margin-bottom:50px;
		
		h1{
			font-size:30px;
			border-bottom:2px solid #000B46;
		}
	}
}

/*---------- service ----------*/
.service_container{
	display:grid;
	gap:50px;
}
.service_column{
	display:grid;
	grid-template-columns:repeat(2, 1fr);
	align-items:center;
	gap:50px;
	
	.box{
		h2{
			margin-bottom:20px;
			font-size:24px;
			border-bottom:1px solid #000B46;
		}
		p{
			font-size:16px;
		}
	}
	.img{
		height:400px;
		overflow:hidden;
		
		img{
			width:100%;
			height:100%;
			object-fit:cover;
		}
	}
}

/*---------- contact ----------*/
.wpcf7-form{
	max-width:800px;
	margin:0 auto;
}
.wpcf7-spinner{
	margin:20px auto 0;
}
.contact_container{
	display:grid;
	gap:20px;
	
	dl{
		display:grid;
		grid-template-columns:200px 1fr;
		align-items:center;
		gap:20px;
		margin:0;
		
		dt{
			p{
				display:flex;
				align-items:center;
				gap:10px;
				margin:0;
				font-size:16px;
				
				span{
					display:block;
					padding:5px;
					font-size:12px;
					line-height:1;
					color:#ffffff;
					background-color:#ef3737;
				}
			}
		}
		dd{
			margin:0;
			
			p{
				margin:0;
				
				input, textarea{
					display:block;
					width:100%;
					padding:15px;
					font-size:16px;
					border:1px solid #cccccc;
					box-sizing:border-box;
					resize:vertical;
				}	
			}
		}
	}
	> p{
		margin:30px 0 0;
		
		input[type="submit"]{
			display:block;
			width:100%;
			padding:20px;
			font-size:18px;
			color:#ffffff;
			background-color:#000b46;
			border:none;
			cursor:pointer;
			
			&:hover{
				opacity:0.8;
			}
		}
	}
}

@media screen and (max-width: 1024px) {
	#header .header-content {
/* 		padding: 30px 20px; */
	}
	.news_main {
		padding: 50px;
	}
	.main-section {
		padding: 20px 50px;
	}
	.service-section, .info-section, .access-section {
		padding-left: 50px;
		padding-right: 50px;
	}
	#footer .footer-left, #footer .footer-right {
		padding: 50px;
	}
}