/* common
-------------------------------------------------------*/
:root {
	--color01: #406fb4;
	--color02: #00509a;
	--color-red: #c50606;
}
#wrapper {
	overflow: hidden;
}
.roboto {
	font-family: 'Roboto', sans-serif;
}
.sp {
	display: none!important;
}
.area {
	padding: 70px 20px;
	box-sizing: border-box;
}
.inner {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	box-sizing: border-box;
}
@media screen and (max-width:768px) {
	.pc {
		display: none!important;
	}
	.sp {
		display: block!important;
	}
	.area {
		padding: 30px 20px;
	}
	.inner {
		max-width: 100%;
		padding: 0 20px;
	}
}


/* header
-------------------------------------------------------*/
#header {
	background: #fff;
}
#header .inner {
	display: flex;
	flex-flow: row nowrap;
	align-items: center;
	justify-content: space-between;
	max-width: 1920px;
	padding: 22px 32px 25px;
}
#header .logo {
	width: 361px;
}
#header .logo img {
	display: block;
}
#header .header_info {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 24px;
}
#header .header_tel {
	display: grid;
	grid-template-columns: 32px auto;
	grid-template-rows: auto auto;
	align-items: center;
	color: var(--color-red);
	line-height: 1;
}
#header .header_tel .icon {
	grid-row: 1 / 3;
	display: block;
	width: 26px;
}
#header .header_tel .num {
	font-weight: 700;
	font-size: 4.0rem;
	letter-spacing: 0.01em;
}
#header .header_tel .note {
	color: #111;
	font-weight: 700;
	font-size: 1.0rem;
	letter-spacing: -0.04em;
	text-align: center;
}
#header .contact {
	display: flex;
	flex-flow: row nowrap;
	justify-content: flex-end;
	gap: 10px;
}
#header .contact .btn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 11px;
	min-width: 230px;
	height: 56px;
	padding: 0 22px;
	border-radius: 999px;
	color: #fff;
	font-weight: 700;
	font-size: 1.8rem;
	line-height: 1;
}
#header .contact .btn_mail {
	background: var(--color-red);
}
#header .contact .btn_line {
	background: #00b900;
}
#header .contact .btn em {
	color: #ffff00;
	font-style: normal;
}
#header .contact .btn_mail .icon {
	width: 33px;
}
#header .contact .btn_line .icon {
	width: 36px;
}
@media screen and (min-width:769px) and (max-width:1300px) {
	#header .inner {
		padding: 18px 20px;
	}
	#header .logo {
		width: 300px;
	}
	#header .header_info {
		gap: 12px;
	}
	#header .header_tel .num {
		font-size: 3.2rem;
	}
	#header .contact .btn {
		min-width: 190px;
		height: 50px;
		padding: 0 16px;
		font-size: 1.5rem;
	}
}
@media screen and (max-width:768px) {
	#header .inner {
		display: block;
		padding: 12px 15px;
	}
	#header .logo {
		width: min(280px, 74vw);
		margin: 0 auto;
	}
	#header .header_info {
		display: block;
	}
	#header .header_tel {
		display: none;
	}
	#header .contact {
		justify-content: center;
		position: fixed;
		left: 0;
		bottom: 0;
		z-index: 9;
		background: rgba(255, 255, 255, 0.95);
		padding: 8px 8px;
		width: 100%;
		box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.12);
	}
	#header .contact li {
		width: 50%;
	}
	#header .contact .btn {
		gap: 6px;
		min-width: 0;
		width: 100%;
		height: 48px;
		padding: 0 8px;
		font-size: 1.4rem;
	}
	#header .contact .btn_mail .icon {
		width: 24px;
	}
	#header .contact .btn_line .icon {
		width: 28px;
	}
}


/* visual
-------------------------------------------------------*/
#visual {
	padding: 0;
	box-sizing: border-box;
	background: url(../img/visual_bg.png) no-repeat center top / cover;
}
#visual .visual_lead {
	background: #406fb4;
	color: #fff;
	font-weight: 700;
	font-size: 2.2rem;
	line-height: 1.35;
}
#visual .visual_lead p {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	gap: 34px;
	min-height: 68px;
}
#visual .visual_lead span {
	display: inline-flex;
	align-items: center;
}
#visual .visual_lead span::before {
	content: "";
	display: inline-block;
	width: 30px;
	height: 26px;
	margin: 0 10px 0 0;
	background: url(../img/icon_check@2x.png) no-repeat center center / contain;
}
#visual .inner {
	max-width: 1200px;
}
#visual .txt {
	width: 1200px;
	max-width: 100%;
}
#visual .txt img {
	display: block;
}
@media screen and (min-width:769px) and (max-width:1300px) {
	#visual .visual_lead {
		font-size: 2.0rem;
	}
	#visual .visual_lead p {
		gap: 20px;
		min-height: 58px;
	}
	#visual .txt {
		padding: 0 20px;
	}
}
@media screen and (max-width:768px) {
	#visual {
		background-size: auto 100%;
	}
	#visual .inner {
		padding: 0;
	}
	#visual .visual_lead {
		font-size: 1.5rem;
	}
	#visual .visual_lead p {
		display: block;
		min-height: 0;
		padding: 9px 12px;
	}
	#visual .visual_lead span {
		display: flex;
		justify-content: flex-start;
	}
	#visual .visual_lead span + span {
		margin-top: 4px;
	}
	#visual .visual_lead span::before {
		width: 23px;
		height: 20px;
		margin: 0 7px 0 0;
	}
	#visual .txt {
		padding: 0;
		width: 100%;
		max-width: none;
		transform: translateX(0);
	}
}

/* cv_area
-------------------------------------------------------*/
.cv_area {
	padding: 58px 20px 60px;
	background: #fff;
	box-sizing: border-box;
}
.cv_area .cv_lead {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 46px;
	min-height: 124px;
	margin: 0 0 36px;
	padding: 0 38px;
	border-radius: 8px;
	background: var(--color01);
	color: #fff;
	font-weight: 700;
	box-sizing: border-box;
}
.cv_area .cv_lead::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: -21px;
	transform: translateX(-50%);
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 22px 20px 0 20px;
	border-color: var(--color01) transparent transparent transparent;
}
.cv_area .cv_lead > p:first-child {
	display: flex;
	align-items: center;
	gap: 24px;
	line-height: 1;
}
.cv_area .cv_lead .circle {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100px;
	height: 100px;
	border-radius: 50%;
	background: #ffff00;
	color: #0063b1;
	font-size: 2.8rem;
	line-height: 1.08;
	text-align: center;
}
.cv_area .cv_lead .time {
	color: #ffff00;
	font-size: 7.2rem;
	letter-spacing: -0.03em;
}
.cv_area .cv_lead .time span {
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 3.6rem;
}
.cv_area .cv_lead .txt {
	font-size: 2.6rem;
	line-height: 1.35;
	text-align: center;
}
.cv_area .cv_lead .txt strong {
	color: #ffff00;
	font-weight: 700;
}
.cv_area .cv_btns {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 60px;
	margin: 0 0 36px;
}
.cv_area .cv_btn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 26px;
	height: 118px;
	border-radius: 999px;
	color: #fff;
	font-weight: 700;
	line-height: 1;
	box-sizing: border-box;
}
.cv_area .cv_mail {
	background: var(--color-red);
	box-shadow: 0 7px 0 #740000;
}
.cv_area .cv_line {
	background: #00b900;
	box-shadow: 0 7px 0 #007800;
}
.cv_area .cv_btn .icon img {
	display: block;
}
.cv_area .cv_mail .icon {
	width: 55px;
}
.cv_area .cv_line .line_icon {
	width: 78px;
}
.cv_area .cv_line .line_icon img {
	display: block;
}
.cv_area .cv_btn .small {
	display: block;
	margin: 0 0 10px;
	font-size: 1.8rem;
}
.cv_area .cv_btn .text > span:nth-child(2) {
	display: block;
	font-size: 3.4rem;
}
.cv_area .cv_btn em {
	color: #ffff00;
	font-style: normal;
}
.cv_area .cv_line .note {
	display: block;
	margin: 9px 0 0;
	font-size: 1.4rem;
}
.cv_area .cv_tel {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 210px;
	padding: 22px 210px 20px;
	border-radius: 8px;
	background: #f4f8dc;
	box-sizing: border-box;
	text-align: center;
}
.cv_area .cv_tel .person {
	position: absolute;
	bottom: 0;
	line-height: 0;
}
.cv_area .cv_tel .person img {
	width: 100%;
	height: auto;
}
.cv_area .cv_tel .man {
	left: 70px;
	max-width: 182px;
}
.cv_area .cv_tel .woman {
	right: 74px;
	max-width: 178px;
}
.cv_area .cv_tel .lead {
	margin: 0 0 10px;
	font-size: 2.4rem;
	font-weight: 700;
	line-height: 1.3;
}
.cv_area .cv_tel .tel_num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 14px;
	color: var(--color-red);
	font-size: 6.8rem;
	font-weight: 700;
	line-height: 1;
}
.cv_area .cv_tel .tel_num .icon {
	width: 50px;
}
.cv_area .cv_tel .tel_num img {
	display: block;
}
.cv_area .cv_tel .note {
	margin: 8px 0 0;
	font-size: 1.8rem;
	line-height: 1.4;
}
@media screen and (max-width: 1080px) {
	.cv_area .cv_lead {
		gap: 24px;
		padding: 0 24px;
	}
	.cv_area .cv_lead .txt {
		font-size: 2.2rem;
	}
	.cv_area .cv_btns {
		gap: 24px;
	}
	.cv_area .cv_btn .text > span:nth-child(2) {
		font-size: 2.8rem;
	}
	.cv_area .cv_tel {
		padding: 22px 150px 20px;
	}
	.cv_area .cv_tel .man {
		left: 20px;
	}
	.cv_area .cv_tel .woman {
		right: 20px;
	}
}
@media screen and (max-width: 768px) {
	.cv_area {
		padding: 30px 0 35px;
	}
	.cv_area .cv_lead {
		display: block;
		min-height: 0;
		margin: 0 0 24px;
		padding: 16px 14px 18px;
	}
	.cv_area .cv_lead > p:first-child {
		justify-content: center;
		gap: 14px;
		margin: 0 0 10px;
	}
	.cv_area .cv_lead .circle {
		width: 60px;
		height: 60px;
		font-size: 1.6rem;
	}
	.cv_area .cv_lead .time {
		font-size: 5.0rem;
	}
	.cv_area .cv_lead .time span {
		font-size: 2.5rem;
	}
	.cv_area .cv_lead .txt {
		font-size: 1.6rem;
		line-height: 1.45;
	}
	.cv_area .cv_btns {
		display: block;
		margin: 0 0 24px;
	}
	.cv_area .cv_btns .cv_btn + .cv_btn {
		margin-top: 16px;
	}
	.cv_area .cv_btn {
		gap: 14px;
		height: 90px;
		box-shadow: 0 5px 0 rgba(0, 0, 0, 0.25);
	}
	.cv_area .cv_mail .icon {
		width: 42px;
	}
	.cv_area .cv_line .line_icon {
		width: 58px;
		height: 48px;
		font-size: 1.6rem;
	}
	.cv_area .cv_btn .small {
		margin: 0 0 6px;
		font-size: 1.2rem;
	}
	.cv_area .cv_btn .text > span:nth-child(2) {
		font-size: 2.1rem;
	}
	.cv_area .cv_line .note {
		margin-top: 6px;
		font-size: 1.1rem;
	}
	.cv_area .cv_tel {
		display: block;
		min-height: 0;
		padding: 18px 12px;
	}
	.cv_area .cv_tel .person img {
		width: auto;
		height: 88px;
	}
	.cv_area .cv_tel .man {
		left: 20px;
	}
	.cv_area .cv_tel .woman {
		right: 20px;
	}
	.cv_area .cv_tel .lead {
		font-size: 1.6rem;
	}
	.cv_area .cv_tel .tel_num {
		gap: 8px;
		font-size: 3.8rem;
	}
	.cv_area .cv_tel .tel_num .icon {
		width: 30px;
	}
	.cv_area .cv_tel .note {
		font-size: 1.2rem;
	}
}

/* about
-------------------------------------------------------*/
.about_area {
	padding: 0 0 64px;
	background: #eaf3ff;
}
.sec_ttl {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 128px;
	margin: 0 0 58px;
	background: var(--color01);
	color: #fff;
	font-size: 4.0rem;
	font-weight: 700;
	line-height: 1.3;
	text-align: center;
}
.sec_ttl em {
	color: #ffff00;
	font-style: normal;
}
.about_area .about_body {
	display: grid;
	grid-template-columns: 550px 1fr;
	gap: 50px;
	align-items: start;
	margin: 0 0 66px;
}
.about_area .about_body .photo img {
	display: block;
	width: 100%;
	height: auto;
}
.about_area .about_body .text {
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 2.0;
}
.about_area .about_body .text p + p {
	margin-top: 22px;
}
.about_area .about_body .text strong {
	color: var(--color-red);
	font-weight: 700;
}
.about_area .trouble_box {
	max-width: 1200px;
	margin: 0 auto;
	padding: 36px 45px 48px;
	border-radius: 18px;
	background: #1f5495;
	box-sizing: border-box;
	color: #fff;
}
.about_area .trouble_box h4 {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 18px;
	margin: 0 0 26px;
	font-size: 3.8rem;
	font-weight: 700;
	line-height: 1.25;
	text-align: center;
}
.about_area .trouble_box h4 .icon {
	width: 76px;
	line-height: 0;
}
.about_area .trouble_box h4 em {
	color: #ffff00;
	font-size: 5.0rem;
	font-style: normal;
}
.about_area .trouble_box ul {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 11px 10px;
}
.about_area .trouble_box li {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 50px;
	border-radius: 4px;
	background: #fff;
	color: #1f5495;
	font-size: 2.2rem;
	font-weight: 700;
	line-height: 1.2;
	text-align: center;
}
@media screen and (max-width: 768px) {

}

/* risk
-------------------------------------------------------*/
.risk_area {
	background: #f7f7f7;
}
.risk_area .risk_head {
	padding: 34px 20px 30px;
	background: var(--color01);
	text-align: center;
}
.risk_area .risk_head p {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 976px;
	min-height: 50px;
	margin: 0 0 14px;
	border-radius: 999px;
	background: #fff;
	color: #164682;
	font-size: 2.4rem;
	font-weight: 700;
	line-height: 1.35;
}
.risk_area .risk_head h3 {
	color: #fff;
	font-size: 4.2rem;
	font-weight: 700;
	line-height: 1.2;
}
.risk_area .risk_head h3 em {
	color: #ffff00;
	font-style: normal;
}
.risk_area .inner {
	max-width: 1120px;
	background: #fff;
	padding: 50px;
}
.risk_area .risk_list {
	padding: 64px 0 74px;
}
.risk_area .risk_item {
	display: grid;
	grid-template-columns: 200px 1fr;
	gap: 50px;
	align-items: center;
	min-height: 220px;
	padding: 28px 36px 28px 28px;
	border-radius: 14px;
	background: #fff;
	box-shadow: 0 0 28px rgba(0,0,0,0.08);
	box-sizing: border-box;
}
.risk_area .risk_item + .risk_item {
	margin-top: 32px;
}
.risk_area .risk_item .icon img {
	display: block;
	width: 200px;
	height: auto;
}
.risk_area .risk_item h4 {
	margin: 0 0 16px;
	color: #164682;
	font-size: 2.8rem;
	font-weight: 700;
	line-height: 1.3;
}
.risk_area .risk_item p {
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.8;
}
.risk_area .risk_note {
	padding: 68px 20px;
	background: #d7e3f1 url(../img/bg_crack.png) no-repeat right center / cover;
}
.risk_area .note_box {
	display: grid;
	grid-template-columns: 136px 1fr;
	gap: 54px;
	box-sizing: border-box;
}
.risk_area .note_box > .icon img {
	display: block;
	width: 136px;
	height: auto;
}
.risk_area .note_box .txt {
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.8;
}
.risk_area .alert {
	display: grid;
	grid-template-columns: 154px 1fr;
	gap: 46px;
	align-items: center;
	margin: 44px 0 0;
	padding: 26px 40px 24px;
	background: #ffe3e3;
	color: #111;
	font-size: 2.2rem;
	font-weight: 700;
	line-height: 1.55;
}
.risk_area .alert strong,
.risk_area .alert em {
	color: var(--color-red);
	font-style: normal;
}
.risk_area .alert .icon img {
	display: block;
	width: 154px;
	height: auto;
}

/* solution
-------------------------------------------------------*/
.solution_area {
	padding: 70px 20px 90px;
	background: url(../img/bg_solution.png) no-repeat center top / cover;
}
.solution_area .inner {
	max-width: 1175px;
	padding: 45px 40px 30px;
	border-radius: 18px 18px 0 0;
	background: #fff;
	box-sizing: border-box;
}
.solution_area .solution_ttl {
	position: relative;
	margin: 0 0 46px;
	font-weight: 700;
	line-height: 1.25;
	text-align: center;
}
.solution_area .solution_ttl::before,
.solution_area .solution_ttl::after {
	content: "";
	position: absolute;
	bottom: 0;
	width: 36%;
	height: 60px;
	background: url(../img/line_house@2x.png) no-repeat center bottom / contain;
	opacity: 0.75;
}
.solution_area .solution_ttl::before {
	left: 0;
}
.solution_area .solution_ttl::after {
	right: 0;
}
.solution_area .solution_ttl span {
	display: block;
	font-size: 2.8rem;
	color: #111;
}
.solution_area .solution_ttl em {
	display: block;
	color: var(--color01);
	font-size: 4.2rem;
	font-style: normal;
}
.solution_area .point_item {
	display: grid;
	grid-template-columns: 1fr 430px;
	gap: 58px;
	align-items: start;
	padding: 34px 0;
	border-bottom: 1px solid #b8c4d5;
}
.solution_area .point_item:last-child {
	border-bottom: none;
}
.solution_area .point_text {
	display: grid;
	grid-template-columns: 70px 1fr;
	gap: 24px;
	align-items: center;
}
.solution_area .point_text .num {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 70px;
	height: 70px;
	border-radius: 8px;
	background: var(--color01);
	color: #fff;
	font-size: 1.8rem;
	font-weight: 700;
	line-height: 0.9;
}
.solution_area .point_text .num span {
	font-size: 3.2rem;
}
.solution_area .point_text > div {
	display: contents;
}
.solution_area .point_text h4 {
	color: #164682;
	font-size: 2.8rem;
	font-weight: 700;
	line-height: 1.35;
}
.solution_area .point_text p:not(.num) {
	grid-column: 1 / -1;
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.85;
}
.solution_area .point_item .photo img {
	display: block;
	width: 430px;
	height: auto;
	border-radius: 7px;
}

@media screen and (max-width: 1080px) {
	.about_area .about_body {
		grid-template-columns: 45% 1fr;
		gap: 30px;
	}
	.about_area .trouble_box ul {
		grid-template-columns: repeat(4, 1fr);
	}
	.risk_area .risk_head p {
		min-width: 0;
		width: 100%;
	}
	.solution_area .point_item {
		grid-template-columns: 1fr 36%;
		gap: 30px;
	}
	.solution_area .point_item .photo img {
		width: 100%;
	}
}
@media screen and (max-width: 768px) {
	.sec_ttl {
		min-height: 80px;
		margin-bottom: 30px;
		font-size: 2.8rem;
	}
	.about_area {
		padding-bottom: 36px;
	}
	.about_area .about_body {
		display: block;
		margin-bottom: 34px;
	}
	.about_area .about_body .photo {
		margin-bottom: 20px;
	}
	.about_area .about_body .text {
		font-size: 1.4rem;
		line-height: 1.8;
	}
	.about_area .trouble_box {
		padding: 24px 16px 28px;
		border-radius: 12px;
	}
	.about_area .trouble_box h4 {
		flex-flow: column;
		gap: 5px;
		font-size: 2rem;
	}
	.about_area .trouble_box h4 em {
		font-size: 3.0rem;
	}
	.about_area .trouble_box h4 .icon {
		width: 52px;
	}
	.about_area .trouble_box ul {
		grid-template-columns: repeat(2, 1fr);
		gap: 8px;
	}
	.about_area .trouble_box li {
		min-height: 40px;
		font-size: 1.5rem;
	}
	.risk_area .inner {
		padding: 0 20px 20px;
	}
	.risk_area .risk_head {
		padding: 24px 15px 26px;
	}
	.risk_area .risk_head p {
		min-height: 0;
		padding: 8px 12px;
		font-size: 1.5rem;
	}
	.risk_area .risk_head h3 {
		font-size: 2.8rem;
	}
	.risk_area .risk_list {
		padding: 32px 0 40px;
	}
	.risk_area .risk_item {
		display: block;
		min-height: 0;
		padding: 24px 20px;
		text-align: center;
	}
	.risk_area .risk_item + .risk_item {
		margin-top: 20px;
	}
	.risk_area .risk_item .icon {
		margin-bottom: 16px;
	}
	.risk_area .risk_item .icon img {
		width: 140px;
		margin: 0 auto;
	}
	.risk_area .risk_item h4 {
		font-size: 2.2rem;
	}
	.risk_area .risk_item p {
		font-size: 1.4rem;
		text-align: left;
	}
	.risk_area .risk_note {
		padding: 36px 15px;
	}
	.risk_area .note_box {
		display: block;
		padding: 30px 0 0;
	}
	.risk_area .note_box > .icon {
		margin-bottom: 16px;
	}
	.risk_area .note_box > .icon img {
		width: 86px;
		margin: 0 auto;
	}
	.risk_area .note_box .txt {
		font-size: 1.4rem;
	}
	.risk_area .alert {
		display: flex;
		flex-flow: column;
		margin: 44px 0 0;
		padding: 20px;
		font-size: 1.6rem;
		gap: 20px;
	}
	.solution_area {
		padding: 38px 15px 48px;
	}
	.solution_area .inner {
		padding: 30px 20px 10px;
	}
	.solution_area .solution_ttl {
		margin-bottom: 24px;
		padding-bottom: 32px;
	}
	.solution_area .solution_ttl::before,
	.solution_area .solution_ttl::after {
		top: 52px;
		width: 42%;
		height: 36px;
	}
	.solution_area .solution_ttl span {
		font-size: 1.8rem;
	}
	.solution_area .solution_ttl em {
		font-size: 2.8rem;
	}
	.solution_area .point_item {
		display: block;
		padding: 26px 0;
	}
	.solution_area .point_text {
		grid-template-columns: 58px 1fr;
		gap: 14px;
		margin-bottom: 18px;
	}
	.solution_area .point_text .num {
		width: 58px;
		height: 58px;
		font-size: 1.4rem;
	}
	.solution_area .point_text .num span {
		font-size: 2.4rem;
	}
	.solution_area .point_text h4 {
		font-size: 1.8rem;
	}
	.solution_area .point_text p:not(.num) {
		font-size: 1.4rem;
	}
}

/* flow
-------------------------------------------------------*/
.flow_area {
	background: #fff;
}
.flow_area .flow_head {
	padding: 34px 20px 36px;
	background: var(--color01);
	box-sizing: border-box;
	text-align: center;
}
.flow_area .flow_head p {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 534px;
	height: 48px;
	margin: 0 0 14px;
	border-radius: 999px;
	background: #fff;
	color: var(--color01);
	font-size: 2.4rem;
	font-weight: 700;
	line-height: 1;
}
.flow_area .flow_head h3 {
	color: #fff;
	font-size: 4.0rem;
	font-weight: 700;
	line-height: 1.15;
}
.flow_area .flow_head h3 em,
.flow_area .flow_head h3 span {
	color: #ffff00;
	font-style: normal;
}
.flow_area .flow_head h3 em {
	font-size: 5.4rem;
}
.flow_area .flow_list {
	padding: 58px 0 0;
}
.flow_area .flow_item {
	display: grid;
	grid-template-columns: 260px 1fr;
	gap: 46px;
	align-items: center;
	margin: 0 0 30px;
}
.flow_area .flow_item .photo {
	position: relative;
}
.flow_area .flow_item .photo img {
	display: block;
	width: 260px;
	height: auto;
}
.flow_area .flow_item .text h4 {
	display: flex;
	align-items: center;
	min-height: 58px;
	margin: 0 0 18px;
	padding: 0 24px;
	background: #e4efff;
	color: #164682;
	font-size: 2.8rem;
	font-weight: 700;
	line-height: 1.3;
	box-sizing: border-box;
}
.flow_area .flow_item .text h4 span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	margin: 0 18px 0 0;
	border-radius: 50%;
	background: var(--color-red);
	color: #fff;
	font-size: 1.5rem;
	line-height: 1;
}
.flow_area .flow_item .text p {
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.85;
}
.flow_area .flow_item .text p em,
.flow_area .flow_item .text p strong {
	font-style: normal;
	font-weight: 700;
}
.flow_area .flow_item .text p em {
	color: var(--color-red);
}
.flow_area .flow_catch {
	margin: 18px 0 0;
	text-align: center;
}
.flow_area .flow_catch span {
	display: inline;
	background: linear-gradient(transparent 62%, #ffff00 62%);
	color: var(--color-red);
	font-size: 5.0rem;
	font-weight: 700;
	line-height: 1.2;
}

/* common blue section head
-------------------------------------------------------*/
.sec_head_blue {
	padding: 32px 20px 34px;
	background: var(--color01);
	box-sizing: border-box;
	text-align: center;
}
.sec_head_blue p {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 534px;
	height: 48px;
	margin: 0 0 15px;
	border-radius: 999px;
	background: #fff;
	color: var(--color01);
	font-size: 2.4rem;
	font-weight: 700;
	line-height: 1;
}
.sec_head_blue h3 {
	color: #ffff00;
	font-size: 4.0rem;
	font-weight: 700;
	line-height: 1.15;
}

/* case
-------------------------------------------------------*/
.case_area {
	padding: 0 0 82px;
	background: #fff;
}
.case_area .inner {
	padding: 64px 20px 0;
	max-width: 1590px;
}
.case_area .case_list {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 60px;
}
.case_area .case_item {
	padding: 30px;
	border: 1px solid #b7b7b7;
	box-shadow: 4px 4px 0 rgba(0, 0, 0, 0.12);
	box-sizing: border-box;
}
.case_area .case_item .photo {
	margin: 0 0 18px;
}
.case_area .case_item .photo img {
	display: block;
	width: 100%;
	height: auto;
}
.case_area .case_item .price {
	display: flex;
	align-items: center;
	gap: 14px;
	margin: 0 0 12px;
	color: var(--color-red);
	font-size: 2.6rem;
	font-weight: 700;
	line-height: 1;
}
.case_area .case_item .price span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 114px;
	height: 42px;
	background: #165bd6;
	color: #fff;
	font-size: 2.0rem;
}
.case_area .case_item .price em {
	font-size: 4.6rem;
	font-style: normal;
	letter-spacing: -0.02em;
}
.case_area .case_item h4 {
	margin: 0 0 24px;
	font-size: 1.9rem;
	font-weight: 700;
	line-height: 1.4;
}
.case_area .case_item .place {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 1.5rem;
	font-weight: 700;
}
.case_area .case_item .place span {
	display: inline-block;
	width: 16px;
	height: 22px;
	background: url(../img/icon_map.png) no-repeat center center / contain;
}

@media screen and (max-width: 1080px) {
	.flow_area .flow_item {
		gap: 30px;
	}
	.case_area .case_list {
		gap: 24px;
	}
	.case_area .case_item {
		padding: 18px;
	}
	.case_area .case_item .price {
		gap: 10px;
		font-size: 2.0rem;
	}
	.case_area .case_item .price span {
		min-width: 96px;
		font-size: 1.6rem;
	}
	.case_area .case_item .price em {
		font-size: 3.6rem;
	}
}
@media screen and (max-width: 768px) {
	.flow_area {
		padding-bottom: 36px;
	}
	.flow_area .flow_head,
	.sec_head_blue {
		padding: 26px 15px 28px;
	}
	.flow_area .flow_head p,
	.sec_head_blue p {
		min-width: 0;
		width: 100%;
		height: 38px;
		font-size: 1.7rem;
	}
	.flow_area .flow_head h3,
	.sec_head_blue h3 {
		font-size: 2.8rem;
	}
	.flow_area .flow_head h3 em {
		font-size: 3.8rem;
	}
	.flow_area .flow_list {
		padding-top: 34px;
	}
	.flow_area .flow_item {
		display: block;
		margin-bottom: 34px;
	}
	.flow_area .flow_item .photo {
		width: 180px;
		margin: 0 auto 16px;
	}
	.flow_area .flow_item .photo img {
		width: 180px;
	}
	.flow_area .flow_item .text h4 {
		min-height: 48px;
		padding: 0 14px;
		font-size: 2.0rem;
	}
	.flow_area .flow_item .text h4 span {
		width: 34px;
		height: 34px;
		margin-right: 10px;
		font-size: 1.2rem;
	}
	.flow_area .flow_item .text p {
		font-size: 1.4rem;
	}
	.flow_area .flow_catch span {
		font-size: 3.0rem;
	}
	.case_area {
		padding-bottom: 44px;
	}
	.case_area .inner {
		padding-top: 34px;
	}
	.case_area .case_list {
		display: block;
	}
	.case_area .case_item {
		padding: 16px;
	}
	.case_area .case_item + .case_item {
		margin-top: 24px;
	}
	.case_area .case_item .price {
		font-size: 1.8rem;
	}
	.case_area .case_item .price span {
		min-width: 86px;
		height: 34px;
		font-size: 1.4rem;
	}
	.case_area .case_item .price em {
		font-size: 3.2rem;
	}
}


/* voice
--------------------------------------------------------*/
.voice_area {
	padding: 0 0 78px;
	background: #fff;
}
.voice_area .inner {
	max-width: 1590px;
	padding: 78px 20px 0;
}
.voice_area .voice_list {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 30px;
}
.voice_area .voice_item {
	display: block;
	box-shadow: 0 0 28px rgba(0, 0, 0, 0.12);
	transition: opacity 0.3s ease;
}
.voice_area .voice_item:hover {
	opacity: 0.6;
}
.voice_area .voice_item img {
	display: block;
	width: 100%;
	height: auto;
}
.voice_modal {
	display: none;
	position: fixed;
	z-index: 10000;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	padding: 50px 20px;
	background: rgba(0, 0, 0, 0.78);
	box-sizing: border-box;
	overflow-y: auto;
}
.voice_modal.is_active {
	display: flex;
	align-items: flex-start;
	justify-content: center;
}
.voice_modal_body {
	max-width: 489px;
	width: 100%;
}
.voice_modal_body img {
	display: block;
	width: 100%;
	height: auto;
}
.voice_modal_close {
	position: fixed;
	top: 18px;
	right: 24px;
	width: 44px;
	height: 44px;
	border: none;
	border-radius: 50%;
	background: #fff;
	color: #333;
	font-size: 3.2rem;
	line-height: 1;
	cursor: pointer;
}

/* reason
--------------------------------------------------------*/
.reason_area {
	background: #fff;
}
.reason_area .reason_head {
	padding: 40px 20px 42px;
	background: var(--color01);
	text-align: center;
}
.reason_area .reason_head h3 {
	color: #fff;
	font-size: 4rem;
	font-weight: 700;
	line-height: 1.25;
}
.reason_area .reason_head h3 span {
	color: #ffff00;
}
.reason_area .inner {
	padding: 64px 20px 20px;
}
.reason_area .reason_item {
	display: grid;
	grid-template-columns: 480px 1fr;
	gap: 36px;
	align-items: start;
}
.reason_area .reason_item + .reason_item {
	margin-top: 30px;
}
.reason_area .reason_item .photo {
	position: relative;
}
.reason_area .reason_item .photo .num {
	position: absolute;
	top: 0;
	left: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 70px;
	height: 70px;
	background: var(--color01);
	color: #fff;
	font-size: 3.2rem;
	line-height: 1;
}
.reason_area .reason_item .photo img {
	display: block;
	width: 100%;
	height: auto;
}
.reason_area .reason_item .text {
	padding: 16px 0 0;
}
.reason_area .reason_item .text h4 {
	margin: 0 0 18px;
	padding: 0 0 18px;
	color: #244e8c;
	border-bottom: 1px solid var(--color01);
	font-size: 3.0rem;
	font-weight: 700;
	line-height: 1.35;
}
.reason_area .reason_item .text h4 small {
	font-size: 1.5rem;
}
.reason_area .reason_item .text p {
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 1.9;
}

@media screen and (max-width: 1080px) {
	.voice_area .voice_list {
		gap: 24px;
	}
	.reason_area .reason_item {
		grid-template-columns: 40% 1fr;
		gap: 26px;
	}
	.reason_area .reason_item .text h4 {
		font-size: 2.4rem;
	}
}
@media screen and (max-width: 768px) {
	.voice_area {
		padding-bottom: 44px;
	}
	.voice_area .inner {
		padding-top: 36px;
	}
	.voice_area .voice_list {
		display: block;
	}
	.voice_area .voice_item {
		max-width: 489px;
		margin: 0 auto;
	}
	.voice_area .voice_item + .voice_item {
		margin-top: 24px;
	}
	.voice_modal {
		padding: 64px 16px 30px;
	}
	.voice_modal_close {
		top: 12px;
		right: 12px;
	}
	.reason_area .reason_head {
		padding: 28px 15px;
	}
	.reason_area .reason_head h3 {
		font-size: 2.6rem;
	}
	.reason_area .inner {
		padding-top: 36px;
		padding-bottom: 46px;
	}
	.reason_area .reason_item {
		display: block;
	}
	.reason_area .reason_item + .reason_item {
		margin-top: 36px;
	}
	.reason_area .reason_item .photo {
		margin: 0 0 16px;
	}
	.reason_area .reason_item .photo .num {
		width: 56px;
		height: 56px;
		font-size: 2.6rem;
	}
	.reason_area .reason_item .text {
		padding: 0;
	}
	.reason_area .reason_item .text h4 {
		font-size: 2.2rem;
	}
	.reason_area .reason_item .text p {
		font-size: 1.5rem;
	}
}

/* qa
--------------------------------------------------------*/
.qa_area {
	background: #e8f1ff;
	padding-bottom: 70px;
}
.qa_area .inner {
	padding-top: 60px;
}
.qa_area h3 {
	color: #fff;
}
.qa_area .qa_item {
	background: #fff;
	border-radius: 8px;
	overflow: hidden;
}
.qa_area .qa_item + .qa_item {
	margin-top: 20px;
}
.qa_area .qa_q {
	position: relative;
	display: grid;
	grid-template-columns: 48px 1fr 26px;
	align-items: center;
	gap: 18px;
	width: 100%;
	padding: 20px 28px;
	border: 0;
	background: #fff;
	color: #111;
	font-family: inherit;
	font-size: 1.8rem;
	font-weight: 700;
	line-height: 1.5;
	text-align: left;
	cursor: pointer;
}
.qa_area .mark {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	border-radius: 50%;
	border: 2px solid var(--color01);
	background: #fff;
	color: var(--color01);
	font-family: Roboto, sans-serif;
	font-size: 2.4rem;
	font-weight: 500;
	line-height: 1;
}
.qa_area .qa_q .mark {
	background: var(--color01);
	color: #fff;
}
.qa_area .toggle {
	position: relative;
	display: block;
	width: 20px;
	height: 20px;
}
.qa_area .toggle::before,
.qa_area .toggle::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	width: 20px;
	height: 2px;
	background: var(--color01);
	transform: translate(-50%, -50%);
}
.qa_area .toggle::after {
	transform: translate(-50%, -50%) rotate(90deg);
}
.qa_area .qa_item.is_open .toggle::after {
	display: none;
}
.qa_area .qa_a {
	display: none;
	padding: 0 28px 22px;
}
.qa_area .qa_a p {
	display: grid;
	grid-template-columns: 48px 1fr;
	gap: 18px;
	align-items: start;
	font-size: 1.7rem;
	font-weight: 500;
	line-height: 1.75;
}

/* staff
--------------------------------------------------------*/
.staff_area {
	background: #fff;
}
.staff_area .inner {
	padding-top: 62px;
	padding-bottom: 86px;
}
.staff_area h3 {
	color: #fff;
}
.staff_area .staff_item {
	display: grid;
	grid-template-columns: 330px 1fr;
	gap: 32px;
	align-items: start;
}
.staff_area .staff_item + .staff_item {
	margin-top: 76px;
}
.staff_area .staff_item .photo img {
	display: block;
	width: 100%;
	height: auto;
}
.staff_area .staff_item .post {
	display: inline-block;
	min-width: 80px;
	margin-bottom: 6px;
	padding: 4px 14px;
	border-radius: 5px;
	background: #e8f5ff;
	font-size: 1.6rem;
	font-weight: 500;
	text-align: center;
}
.staff_area .staff_item h4 {
	margin-bottom: 16px;
	padding-bottom: 14px;
	border-bottom: 1px solid var(--color01);
	font-size: 2.0rem;
	font-weight: 700;
}
.staff_area .staff_item dl {
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.7;
}
.staff_area .staff_item dt {
	margin-top: 12px;
	color: var(--color01);
	font-size: 1.8rem;
	font-weight: 700;
}
.staff_area .staff_item .comment {
	margin-top: 16px;
	padding: 18px 22px;
	background: #e8f5ff;
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.7;
}

/* contact
--------------------------------------------------------*/
.contact_area {
	padding: 70px 0;
	background: #ffffef;
}
.contact_area .contact_box {
	border: 1px solid #aaa;
	background: #fff;
}
.contact_area h3 {
	padding: 18px 20px;
	background: var(--color01);
	color: #fff;
	font-size: 4.0rem;
	font-weight: 700;
	line-height: 1.3;
	text-align: center;
}
.contact_area .catch {
	margin-top: 26px;
	color: #ff6000;
	font-size: 3.8rem;
	font-weight: 700;
	line-height: 1.3;
	text-align: center;
}
.contact_area .lead {
	margin: 14px 0 28px;
	font-size: 1.5rem;
	text-align: center;
}
.contact_area .lead span {
	color: #c50606;
}
.contact_area .contact_table th span {
	display: block;
	margin: 0 6px;
	padding: 2px 7px;
	background: #c50606;
	color: #fff;
	font-size: 1.3rem;
	font-weight: 700;
	line-height: 1.2;
}
.contact_area form {
	padding: 0 48px 58px;
}
.contact_area .contact_table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0 18px;
}
.contact_area .contact_table th,
.contact_area .contact_table td {
	vertical-align: top;
}
.contact_area .contact_table td {
	width: 100%;
	padding-left: 20px;
}
.contact_area .contact_table th {
	width: 380px;
	padding-top: 11px;
	font-size: 1.7rem;
	font-weight: 700;
	text-align: left;
	display: flex;
	flex-flow: row nowrap;
	align-items: center;
	justify-content: space-between;
}
.contact_area .contact_table input,
.contact_area .contact_table select,
.contact_area .contact_table textarea {
	width: 100%;
	border: 1px solid #bbb;
	border-radius: 8px;
	background: #fff;
	font-size: 1.6rem;
	box-sizing: border-box;
	line-height: 1.4;
}
.contact_area .contact_table input,
.contact_area .contact_table select {
	height: 50px;
	padding: 0 18px;
}
.contact_area .contact_table textarea {
	height: 200px;
	padding: 18px;
	resize: vertical;
}
.contact_area .privacy_check {
	margin: 22px 0 40px;
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.8;
	text-align: center;
}
.contact_area .privacy_check label {
	display: inline-block;
	margin-top: 24px;
	cursor: pointer;
}
.contact_area .privacy_check input {
	margin-right: 14px;
}
.contact_area .form_btn {
	text-align: center;
}
.contact_area .form_btn01 {
	position: relative;
	width: 570px;
	max-width: 100%;
	height: 88px;
	border: 0;
	border-radius: 14px;
	background: #bfbfbf;
	box-shadow: 0 7px 0 #838383;
	color: #fff;
	font-family: inherit;
	font-size: 3.0rem;
	font-weight: 700;
	cursor: not-allowed;
}
.contact_area .form_btn01.is_active {
	background: #c50606;
	box-shadow: 0 7px 0 #740000;
	cursor: pointer;
}
.contact_area ::placeholder {
	color: #b5b5b5;
}

.contact_after{
	padding: 100px 0 120px;
	background: #fff;
}

.contact_after .inner{
	max-width: 800px;
	margin: 0 auto;
	padding: 0 20px;
}

.contact_after .txt_form{
	padding: 60px 30px;
	border: 4px solid #0055a2;
	background: #f8fbff;
	text-align: center;
	font-size: 2rem;
	font-weight: 500;
	line-height: 2;
	letter-spacing: 0.05em;
	border-radius: 20px;
}

.contact_after .txt_form .red{
	display: block;
	margin-bottom: 25px;
	font-size: 3rem;
	font-weight: 700;
	color: #c50606;
	line-height: 1.4;
}

.contact_after .form_btn{
	margin-top: 50px;
	text-align: center;
}
.contact_after .form_btn01 {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 400px;
	max-width: 100%;
	height: 70px;
	border: none;
	border-radius: 45px;
	background: #0055a2;
	color: #fff;
	font-size: 3rem;
	font-weight: 700;
	cursor: pointer;
	transition: opacity .3s;
	margin-bottom: 20px;
}
.contact_after .form_btn02 {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 400px;
	max-width: 100%;
	height: 70px;
	border: none;
	border-radius: 45px;
	border: 2px solid #0055a2;
	color: #0055a2;
	font-size: 3rem;
	font-weight: 700;
	cursor: pointer;
	transition: opacity .3s;
}

.contact_after .form_btn02:hover{
	opacity: .8;
}

.contact_after .txt_form_confirm {
	text-align: center;
	font-size: 2rem;
	font-weight: 700;
	margin-bottom: 50px;
}
.contact_after .table_temp {
	width: 100%;
}
.contact_after .table_temp tr {
	border-bottom: 1px solid #bbb;
}
.contact_after .table_temp th {
	font-weight: 700;
	text-align: left;
	padding: 10px;
	width: 300px;
}
.contact_after .table_temp td {
	padding: 10px;
}
@media screen and (max-width: 768px) {
	.contact_after {
		padding: 50px 0 60px;
	}
	.contact_after .txt_form_confirm {
		font-size: 1.6rem;
	}
	.contact_after .form_btn01 {
		height: 60px;
		font-size: 2rem;
	}
	.contact_after .form_btn02 {
		height: 60px;
		font-size: 2rem;
	}
	.contact_after .table_temp th {
		width: 120px;
	}
}

/* media
--------------------------------------------------------*/
.media_area {
	padding: 82px 0;
	background: #e8f1ff;
}
.media_area .media_box {
	padding: 48px 84px 40px;
	background: #fff;
}
.media_area .media_head {
	display: flex;
	align-items: center;
	gap: 34px;
	margin-bottom: 24px;
}
.media_area .media_head img {
	display: block;
	max-width: 229px;
}
.media_area .media_head h3 {
	color: var(--color01);
	font-size: 3.0rem;
	font-weight: 700;
	line-height: 1.45;
}
.media_area .media_photos {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 38px;
}
.media_area .media_photos img {
	display: block;
	width: 100%;
	height: auto;
}

/* company
--------------------------------------------------------*/
.company_area {
	background: #fff;
}
.company_area .company_head {
	padding: 30px 20px 28px;
	background: var(--color01);
	text-align: center;
}
.company_area .company_head p {
	display: inline-block;
	min-width: 540px;
	margin-bottom: 12px;
	padding: 7px 26px;
	border-radius: 999px;
	background: #fff;
	color: var(--color01);
	font-size: 2.8rem;
	font-weight: 700;
	line-height: 1.3;
}
.company_area .company_head h3 {
	color: #ffff00;
	font-size: 4.6rem;
	font-weight: 700;
	line-height: 1.2;
}
.company_area .inner {
	padding-top: 58px;
	padding-bottom: 74px;
}
.company_area .company_photo img {
	display: block;
	width: 100%;
	height: auto;
}
.company_area .company_table {
	width: 100%;
	margin-top: 44px;
	border-collapse: collapse;
	font-size: 1.6rem;
	font-weight: 500;
}
.company_area .company_table th,
.company_area .company_table td {
	border-top: 1px solid #d0d0d0;
	border-bottom: 1px solid #d0d0d0;
	padding: 18px 28px;
}
.company_area .company_table th {
	width: 190px;
	background: #f2f0f0;
	font-weight: 700;
	text-align: center;
}
#footer {
	padding: 44px 0 76px;
	background: #fff;
	text-align: center;
}
#footer .logo img {
	width: 361px;
	height: auto;
}
#footer .copy {
	margin-top: 22px;
	font-size: 1.3rem;
}

@media screen and (max-width: 768px) {
	.qa_area {
		padding-bottom: 42px;
	}
	.qa_area .inner {
		padding-top: 34px;
	}
	.qa_area .qa_q {
		grid-template-columns: 38px 1fr 20px;
		gap: 10px;
		padding: 16px 14px;
		font-size: 1.5rem;
	}
	.qa_area .mark {
		width: 34px;
		height: 34px;
		font-size: 2.0rem;
	}
	.qa_area .qa_a {
		padding: 0 14px 16px;
	}
	.qa_area .qa_a p {
		grid-template-columns: 38px 1fr;
		gap: 10px;
		font-size: 1.4rem;
	}
	.staff_area .inner {
		padding-top: 38px;
		padding-bottom: 46px;
	}
	.staff_area .staff_item {
		display: block;
	}
	.staff_area .staff_item + .staff_item {
		margin-top: 44px;
	}
	.staff_area .staff_item .photo {
		max-width: 330px;
		margin: 0 auto 18px;
	}
	.staff_area .staff_item h4 {
		font-size: 1.8rem;
	}
	.contact_area {
		padding: 42px 0;
	}
	.contact_area h3 {
		font-size: 2.6rem;
	}
	.contact_area .catch {
		font-size: 2rem;
	}
	.contact_area form {
		padding: 0 18px 40px;
	}
	.contact_area .contact_table,
	.contact_area .contact_table tbody,
	.contact_area .contact_table tr,
	.contact_area .contact_table th,
	.contact_area .contact_table td {
		display: block;
		width: 100%;
	}
	.contact_area .contact_table {
		border-spacing: 0;
	}
	.contact_area .contact_table tr + tr {
		margin-top: 16px;
	}
	.contact_area .contact_table th {
		padding: 0 0 8px;
		font-size: 1.5rem;
	}
	.contact_area .contact_table th span {
		display: inline-block;
	}
	.contact_area .contact_table td {
		padding-left: 0;
	}
	.contact_area .form_btn01 {
		height: 66px;
		font-size: 2.2rem;
	}
	.media_area {
		padding: 42px 0;
	}
	.media_area .media_box {
		padding: 26px 18px;
	}
	.media_area .media_head {
		display: block;
		text-align: center;
	}
	.media_area .media_head p {
		margin-bottom: 14px;
	}
	.media_area .media_head img {
		margin: 0 auto;
	}
	.media_area .media_head h3 {
		font-size: 2.2rem;
	}
	.media_area .media_photos {
		display: block;
	}
	.media_area .media_photos p + p {
		margin-top: 18px;
	}
	.company_area .company_head p {
		min-width: 0;
		font-size: 1.8rem;
	}
	.company_area .company_head h3 {
		font-size: 3.2rem;
	}
	.company_area .inner {
		padding-top: 36px;
		padding-bottom: 44px;
	}
	.company_area .company_table,
	.company_area .company_table tbody,
	.company_area .company_table tr,
	.company_area .company_table th,
	.company_area .company_table td {
		display: block;
		width: 100%;
	}
	.company_area .company_table td {
		border-bottom: none;
	}
	.company_area .company_table th,
	.company_area .company_table td {
		padding: 12px 14px;
		text-align: left;
	}
	.company_area .company_table td {
		border-top: 0;
	}
	#footer .logo img {
		width: 280px;
	}
}
