@charset "utf-8";
/*=============================
		common
===============================*/
/*nav*/
html.fixed, body.fixed {
	overflow: hidden;
	width: 100%;
}
body {
	position: relative;
}
/* wrap */
.wrap {
	position: relative;
	width: 1040px;
	margin: 0 auto;
	box-sizing: border-box;
	z-index: 1;
}
/* view */
.pc_view {
	display: block !important;
}
.sp_view {
	display: none !important;
}
/*=============================
		header
===============================*/
header {
	z-index: 999;
	min-width: 1200px;
	width: 100%;
	height: 80px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	position: absolute;
	margin-top: 60px;
	padding-left: 48px;
}
header .header_top {
	display: flex;
	justify-content: flex-start;
	align-items: center;
}
header .header_top_textbox {
	padding-left: 16px;
	font-weight: bold;
	line-height: 1.3;
	color: #353535;
	font-size: 14px;
}
header .header_bottom {
	padding-top: 16px;
}
header .header_bottom_text {
	font-size: 20px;
	font-weight: bold;
	display: block;
	line-height: 1;
}
header .header_bottom_text .name {
	font-size: 27px;
	display: block;
	padding-top: 8px;
}
/*=============================
		main
===============================*/
section {
	padding-top: 60px;
	margin: 0 auto;
}
.text {
	line-height: 1.8;
}
.marker {
	background: linear-gradient(transparent 75%, #fffd7a 60%);
}
.headline {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	margin-bottom: 72px;
}
.headline .headline_box {
	width: 100%;
	height: 125px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	background: rgb(0, 67, 124);
	background: -webkit-linear-gradient(350deg, rgba(0, 67, 124, 1) 50%, rgba(28, 102, 164, 1) 100%);
	background: -o-linear-gradient(350deg, rgba(0, 67, 124, 1) 50%, rgba(28, 102, 164, 1) 100%);
	background: linear-gradient(80deg, rgba(0, 67, 124, 1) 50%, rgba(28, 102, 164, 1) 100%);
}
.headline::after {
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 32px 56px 0 56px;
	border-color: rgb(0, 67, 124) transparent transparent transparent;
	margin-top: -1px;
}
.headline .headline_text {
	font-size: 46px;
	color: #fff;
	letter-spacing: 0.04em;
	margin-top: -8px;
	font-weight: 900;
}
.headline .headline_yellow {
	color: #fcff00;
}
.headline .text_bg {
	font-size: 60px;
	line-height: 1;
}
/*=============================
		mainvisual
===============================*/
#mainvisual {
	width: 100%;
	height: 100vh;
	background: url("../images/img_mainvisual.jpg") no-repeat;
	background-size: cover;
	display: flex;
	align-items: center;
}
#mainvisual .mainvisual_catch {
	padding: 0 75px;
}
/*=============================
		about
===============================*/
#about {
	max-width: 1140px;
}
#about .about_content-box {
	display: flex;
	justify-content: flex-start;
	position: relative;
}
#about .about_textbox {
	width: 500px;
	text-align: justify;
	margin-left: 50px;
	padding-top: 16px;
	padding-bottom: 62px;
}
#about .about_title_article {
    font-size: 46px;
    font-weight: 900;
    line-height: 1.3;
    margin-bottom: 35px;
    letter-spacing: 0.08em;
}
#about .about_textbox .text + .text {
	margin-top: 25px;
}
#about .about_img02 {
	position: absolute;
	top: 405px;
	left: 55px;
}
#about .about_img-box {
	display: flex;
	justify-content: flex-end;
	padding-bottom: 60px;
}
#about .about_img-box img + img {
	margin-left: 28px;
}
#about .about_catch {
    font-size: 46px;
    font-weight: 900;
    line-height: 1.3;
    margin-bottom: 25px;
    letter-spacing: 0.08em;
	text-align: center;
	color: #043864;
}
#about .about_catch .light {
	display: inline-block;
	background: linear-gradient(90deg, #02335c, #3672a1, #02335c);
	background: -webkit-linear-gradient(90deg, #02335c, #3672a1, #02335c);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}
/*============================
         works
============================*/
#works .wrap {
	width: 1140px;
	margin: 0 auto;
}
#works .works_item {
	display: flex;
	justify-content: flex-end;
}
#works .works_item + .works_item {
	padding-top: 190px;
}
#works .works_item:nth-child() {
	display: flex;
	justify-content: flex-start;
}
#works .works_item .textbox + .works_img, #works .works_item .works_img + .textbox {
	margin-left: 48px;
}
#works .works_item .textbox {
	width: 500px;
}
#works .works_item .title_article {
	padding-bottom: 25px;
	border-bottom: 4px double #bbbbbb;
}
#works .works_item .title_jp {
	font-size: 46px;
	font-weight: 700;
	letter-spacing: 0.04em;
}
#works .works_item .title_en {
	font-size: 16px;
	font-weight: 700;
	color: #0d538f;
}
#works .works_item .textbox_text {
	padding-top: 25px;
}
#works .works_item .textbox_text .text {
	text-align: justify;
	line-height: 2.4em;
}


#works .works_img_abu {
	position: absolute;
	display: block;
	top: 390px;
	right: 30px;
}
#works .works_img_abu li {
	float: left;
	width: 260px;
	margin: 0px 30px 0px 0px;
}
#works .works_img_abu li img {
	display: block;
	width: 100%;
	height: auto;
}



/*============================
         feature
============================*/
#feature .wrap {
	width: 1020px;
	padding-top: 40px;
	margin-top: -40px;
}
#feature .feature_item {
	display: flex;
	justify-content: space-between;
}
#feature .feature_item + .feature_item {
	padding-top: 88px;
}
#feature .feature_img {
	position: relative;
}
#feature .feature_img .feature_num {
	position: absolute;
	top: -40px;
	left: 10px;
	z-index: 2;
	width: 68px;
	height: 68px;
	font-size: 46px;
	text-align: center;
	color: #fff;
	background: #01428c;
	font-weight: 900;
    line-height: 1;
    padding: 8px 0;
}
#feature .textbox {
	width: 540px;
	height: auto;
	padding-top: 8px;
}
#feature .textbox_title_article {
	font-size: 38px;
	font-weight: 700;
	line-height: 1.3;
	letter-spacing: 0.04em;
}
#feature .textbox .text {
	text-align: justify;
	letter-spacing: 1.28px;
	margin-top: 25px;
	line-height: 2.0em;
}
/*============================
         voice
============================*/
#voice .voice_item {
	display: flex;
}
#voice .voice_item:nth-child(1), #voice .voice_item:nth-child(3) {
	justify-content: flex-end;
}
#voice .voice_item:nth-child(2), #voice .voice_item:nth-child(4) {
	justify-content: flex-start;
}
#voice .voice_item + .voice_item {
	padding-top: 40px;
}
#voice .voice_item .textbox {
	width: 540px;
	padding-top: 20px;
}
#voice .voice_item .textbox + .voice_img, #voice .voice_item .voice_img + .textbox {
	margin-left: 48px;
}
#voice .voice_title_article {
	display: flex;
	flex-direction: column;
}
#voice .voice_title_article::after {
	content: "";
	width: 130px;
	height: 6px;
	background: #faf3c2;
}
#voice .voice_item .textbox .voice_title_text01 {
	font-size: 38px;
	font-weight: 700;
	line-height: 1.3;
}
#voice .voice_item .textbox .voice_title_caption {
	font-size: 20px;
	font-weight: 700;
	padding-top: 24px;
	padding-bottom: 30px;
}
#voice .voice_item .textbox .voice_title_text02 {
	font-size: 26px;
	font-weight: bold;
	color: #1a63a1;
	padding-left: 32px;
}
#voice .voice_item .textbox .voice_title_text02::before {
    content: "";
    width: 20px;
    height: 20px;
    background: #1a63a1;
    margin-right: 12px;
    margin-top: -2px;
    position: absolute;
    left: 0;
    top: 13px;
}
#voice .voice_item .textbox .text.text01 {
	text-align: justify;
	padding-top: 30px;
	line-height: 2;
}
#voice .voice_item .textbox .text.text02 {
	text-align: justify;
	padding-top: 24px;
	line-height: 2;
}
#voice .voice_btn_area {
	padding-top: 68px;
}
#voice .voice_btn_title {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 55px;
	background: #ff9600;
	color: #fff;
	border-radius: 55px;
    letter-spacing: 0.06em;
    font-weight: 900;
	font-size: 22px;
}
#voice .voice_btn_title span {
	margin-top: -4px;
}
#voice .voice_btn_wrap {
	display: flex;
	justify-content: space-between;
	padding-top: 24px;
	width: 960px;
	height: auto;
	margin: 0 auto;
}
#voice .voice_btn_wrap .btn {
	width: 468px;
	height: 108px;
	border-radius: 54px;
}
#voice .voice_btn_wrap .btn a {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	width: 468px;
	height: 108px;
	border-radius: 54px;
	color: #fff;
	transition: 250ms all;
}
#voice .voice_btn_wrap .btn a:hover {
	opacity: 0.7;
}
#voice .voice_btn_wrap .btn .tel {
	background: rgb(31, 191, 144);
	background: linear-gradient(0deg, rgba(31, 191, 144, 1) 0%, rgba(88, 239, 195, 1) 100%);
}
#voice .voice_btn_wrap .btn .tel .number {
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 54px;
	line-height: 1;
}
#voice .voice_btn_wrap .btn .tel .number_caption {
	font-size: 13px;
	font-weight: bold;
	text-align: center;
}
#voice .voice_btn_wrap .btn .mail {
	background: rgb(213, 65, 49);
	background: linear-gradient(0deg, rgba(213, 65, 49, 1) 0%, rgba(239, 124, 105, 1) 100%);
}
#voice .voice_btn_wrap .btn .mail .mail_text {
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 28px;
	line-height: 1;
	margin-top: -8px;
}
#voice .voice_btn_wrap .btn .mail .mail_text::before {
	content: "";
	width: 42px;
    height: 39px;
	background: url("../images/ic_mail.svg") no-repeat;
	background-size: contain;
	margin-right: 12px;
	margin-top: 8px;
}
/*============================
         description
============================*/
.description_catch {
	text-align: center;
	color: #fe7800;
	margin-bottom: 28px;
	font-size: 42px;
	font-weight: 900;
}
#description .description_catch .text_bg {
	font-size: 52px;
}
#description .description_table {
	display: grid;
	width: 964px;
	grid-template-columns: 200px 764px;
	justify-content: center;
	font-weight: 500;
	border-top: 1px solid #bbbbbb;
	margin: 0 auto;
}
#description .table_title, .table_text {
	padding: 28px 0;
	border-bottom: 1px solid #bbbbbb;
}
#description .table_text {
	padding-left: 32px;
}
#description .table_title {
	background: #f1f1f1;
	text-align: center;
}
#description .table_text_list li {
	display: flex;
}
.table_text_list li::before {
	content: "●";
	padding-right: 4px;
}
#description .table_text_list.list2 {
	display: flex;
	width: 390px;
	flex-wrap: wrap;
}
#description .table_text_list.list2 li::before {
	content: "◆";
}
#description .table_text_list.list2 li:nth-child(1), #description .table_text_list.list2 li:nth-child(4), #description .table_text_list.list2 li:nth-child(6) {
	padding-right: 18px;
}
/*============================
         mailform
============================*/
#mailform {
	padding-top: 0;
	margin-top: 60px;
	background: url("../images/bg_mailfoam.jpg") no-repeat;
	background-size: cover;
	background-position-x: center;
	padding-bottom: 70px;
}
#mailform .headline::after {
	border-color: rgb(215, 70, 55) transparent transparent transparent;
}
#mailform .headline .headline_box {
	background: rgb(215, 70, 55);
	background: linear-gradient(0deg, rgba(215, 70, 55, 1) 0%, rgba(235, 114, 96, 1) 100%);
}
#mailform .headline .headline_text {
	display: flex;
	align-items: center;
	justify-content: center;
	margin-top: -10px;
}
#mailform .headline .headline_text::before {
	content: "";
	width: 54px;
	height: 46px;
	background: url("../images/ic_mail.svg") no-repeat;
	background-size: contain;
	margin-right: 15px;
	margin-bottom: -10px;
}
#mailform .wrap {
	background: #fff;
	width: 964px;
	height: auto;
	border-radius: 30px;
}
#mailform .wrap .table_wrap {
	padding-top: 80px;
	padding-bottom: 70px;
}
#mailform .wrap .table_mail {
	width: 792px;
	height: auto;
	margin: 0 auto;
}
#mailform form table td .mail_caption {
	display: flex;
	padding-top: 16px;
	font-size: 14px;
	letter-spacing: 1.6px;
}
#mailform form table td .mail_caption::before {
	content: "※";
	padding-right: 4px;
}
#mailform .th_small {
	/*display: flex;
	align-items: center;*/
}
#mailform .th_small span {
	display: inline-block;
	padding-left: 16px;
	font-weight: 500;
}
.checkbox span a {
	color: #233482;
	line-height: 1;
	border-bottom: 1px solid #233482;
	transition: 250ms all;
}
.checkbox span a:hover{
	opacity: 0.8;
}
/*============================
         profile
============================*/
#profile {
	background: #fbfbfb;
	padding-bottom: 52px;
}
#profile .wrap {
	display: flex;
	justify-content: space-between;
	width: 920px;
}
#profile .profile_left {
	width: 454px;
	height: auto;
	padding-top: 16px;
}
#profile .profile_left_title_article {
	display: flex;
	align-items: center;
	padding-bottom: 25px;
	border-bottom: 1px solid #e1e1e1;
}
#profile .profile_left_title_article .title_jp {
	display: flex;
	font-size: 32px;
	line-height: 1;
}
#profile .profile_left_title_article .title_jp::before {
	content: "";
	width: 8px;
	height: 44px;
	background: #01428c;
	margin-right: 20px;
}
#profile .profile_left_title_article .title_en {
	padding-left: 24px;
	font-size: 20px;
	color: #01428c;
}
#profile .profile_left .profile_name {
	padding: 16px 0 24px;
	border-bottom: 1px solid #e1e1e1;
}
#profile .profile_left .profile_name .profile_name_text {
	font-size: 22px;
	padding-bottom: 6px;
	font-weight: bold;
}
#profile .profile_left .profile_name .profile_name_nam {
	font-size: 14px;
	color: #353535;
	font-weight: 600;
}
#profile .profile_left .profile_address {
	display: flex;
	align-items: center;
	padding: 15px 0;
}
#profile .profile_left .address_icon {
	display: flex;
    justify-content: center;
    align-items: center;
    background: #939393;
    width: 80px;
    height: 60px;
    color: #fff;
    font-size: 16px;
    font-weight: bold;
    margin-right: 16px;
}
#profile .profile_left .address_list {
	font-size: 15px;
	font-weight: 500;
}
/*============================
         footer
============================*/
footer {
	padding-top: 80px;
}
footer .footer_tel .footer_tel_text {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 495px;
	height: 55px;
	color: #fff;
	border-radius: 28px;
	background: #ff9600;
	margin: 0 auto;
	font-size: 26px;
	font-weight: 900;
}
footer .footer_tel .footer_tel_text span {
	margin-top: -4px;
}
footer .footer_tel_btn {
	text-align: center;
	padding-top: 12px;
	padding-bottom: 28px;
}
footer .btn_number {
	display: inline-block;
	transition: opacity .3s ease;
}
footer .btn_number:hover {
	opacity: 0.7;
}

footer .footer_tel_caption {
	color: #686868;
	font-size: 14px;
	font-weight: bold;
}
footer .footer_nav {
	border-top: 1px solid #dadada;
	padding: 32px 0;
}
footer .footer_nav .nav_list {
	display: flex;
	justify-content: center;
}
footer .footer_nav .nav_list li {
	padding: 0 24px;
	border-right: 1px solid #a2a2a2;
	line-height: 1;
}
footer .footer_nav .nav_list li:first-child {
	padding-left: 0;
}
footer .footer_nav .nav_list li:last-child {
	padding-right: 0;
	border-right: none;
}
footer .footer_nav .nav_list li a {
	display: inline-block;
	font-weight: bold;
	font-size: 16px;
	padding-bottom: 4px;
	color: #353535;
	transition: color .3s ease;
}
footer .footer_nav .nav_list li a:hover {
	color: #ff9600;
}
footer .footer_nav .nav_list_bottom {
	display: flex;
	justify-content: center;
	padding-top: 15px;
	line-height: 1;
}
footer .footer_nav .nav_list_bottom li:first-child {
	padding-right: 20px;
	border-right: 1px solid #aaaaaa;
}
footer .footer_nav .nav_list_bottom li:last-child {
	padding-left: 20px;
}
footer .footer_nav .nav_list_bottom li a {
	display: inline-block;
	padding-bottom: 4px;
	justify-content: center;
	font-weight: 500;
	font-size: 16px;
	color: #565656;
	transition: opacity .3s ease;
}
footer .footer_nav .nav_list_bottom li a:hover{opacity: 0.7;}
.copyright {
	background: #00437c;
	width: 100%;
	height: 58px;
	color: #fff;
	text-align: center;
	display: flex;
	justify-content: center;
	align-items: center;
}
.copyright .text {
	text-align: center;
	font-size: 16px;
}
/*=============================
		contents page
===============================*/

.header_top_btn {
	line-height: 0;
}
.content_visual {
	width: 100%;
	height: 300px;
	background: url("../images/img_content_visual.jpg") no-repeat;
	background-size: cover;
	display: flex;
	align-items: center;
	justify-content: center;
}
.content_title {
	font-size: 44px;
	display: flex;
	justify-content: center;
	align-items: center;
	color: #fff;
	letter-spacing: 3px;
	line-height: 1;
	width: 500px;
	height: 100px;
	background: rgba(0, 67, 124, 0.9);
	margin-top: 90px;
	font-weight: 700;
}
.content_title span {
	margin-top: -5px;
}
.tree {
	display: flex;
	list-style-type: none;
	width: 1040px;
	margin: 0 auto;
	padding-top: 20px;
}
.tree li::after {
	content: "＞";
	margin: 0px 0px 0px 20px;
}
.tree li:last-child::after {
	content: none;
}
.tree li + li {
	padding-left: 20px;
}
/*=============================
		policy index
===============================*/
#policy {
	line-height: 1.5;
}
#policy p.txt {
	margin-bottom: 40px;
	text-align: justify;
	    line-height: 2;
}
#policy .txt span.txt_padding {
	display: inline-block;
	padding-top: 15px;
}
#policy dl {
	margin-bottom: 60px;
}
#policy dl:last-child {
	margin-bottom: 0;
}
#policy dl dt {
	padding-bottom: 20px;
	font-size: 24px;
	margin: 0 0 20px;
	font-weight: 500;
	position: relative;
	display: flex;
}
#policy dl dt .title_flex {
	font-weight: bold;
}
#policy dl dt .title_flex span {
	padding-right: 5px;
}
#policy dl dt::before {
	content: "";
	position: absolute;
	width: 100%;
	height: 3px;
	background: rgb(0, 67, 124);
	background: linear-gradient(0deg, rgba(0, 67, 124, 0.5) 50%, rgba(28, 102, 164, 0.5) 100%);
	bottom: 0;
}
#policy dl dd {
	font-size: 16px;
	padding: 0px 15px;
	 text-align: justify;
	    line-height: 2;
}
#policy dl dd ul {
	margin-top: 10px;
}
#policy dl dd ul li {
	position: relative;
	padding-left: 15px;
	margin-top: 2px;
}
#policy .address_box {
	display: inline-block;
	margin-top: 20px;
}
#policy .address_box .company_name {
	font-size: 18px;
	font-weight: bold;
}
#policy .company_address {
	line-height: 1.4em;
}
#policy ul.p_list {
	padding-bottom: 60px;
	line-height: 1.8;
}
#policy ul.p_list.top_list li {
	padding-bottom: 8px;
	    text-align: justify;
}
#policy dd ul.p_list {
	padding-bottom: 0;
}
#policy ul.p_list .p_list2 {
	padding-bottom: 0;
}
#policy ul.p_list li {
	display: flex;
}
#policy ul.p_list li span {
	padding-right: 5px;
}
#policy ul.p_list li.no_flex {
	display: block;
}
#policy ul.p_list li.in_list {
	display: block;
	padding-right: 0;
}
#policy ul.p_list li.in_list .in_list_box {
	display: flex;
}
#policy ul.p_list li.in_list .in_list_box span {
	display: flex;
	padding-right: 5px;
}
#policy dd.policy_right {
	text-align: right;
}
/*=============================
		thanks index
===============================*/
#thanks .textbox {
	padding-top: 80px;
	text-align: center;
}
#thanks .title_article {
	font-size: 32px;
	font-weight: 700;
}
#thanks .text {
	padding: 32px 0;
}
#thanks .btn1 {
	width: 300px;
	height: 60px;
	border-radius: 50px;
	transition: 250ms all;
	margin: 0 auto 40px;
}
#thanks .btn1:hover {
	opacity: 0.7;
}
#thanks .btn1 a {
	display: flex;
    justify-content: center;
    align-items: center;
    width: 300px;
    height: 65px;
    background: #df4436;
    border-radius: 65px;
    color: #fff;
    font-size: 20px;
    font-weight: bold;
    position: relative;
}



.mb40 {
	margin-bottom: 40px!important;
}
