@charset "utf-8";

/* ================================================================================
	Additional
================================================================================ */
.box {
	margin-bottom: 30px;
}
.box::after {
	content: '';
	display: block;
	clear: both;
}

.box_left {
	float: left;
	margin: 0 30px 30px 0;
}

.box_right {
	float: right;
	margin: 0 0 30px 30px;
}

.box_text {
	overflow: hidden;
}

.box_color {
	overflow: hidden;
	margin-bottom: 40px;
	padding: 25px 35px 30px;
	border-radius: 20px;
	background: #fff;
}
.box_color h4 {
	margin-bottom: 10px !important;
}

.box_color_success {
	overflow: hidden;
	margin-bottom: 40px;
	padding: 35px;
	border-radius: 20px;
	background: #d4edda;
}

.box_border {
	overflow: hidden;
	margin-bottom: 40px;
	padding: 35px;
	border: 3px solid #444;
	border-radius: 20px;
}

.color_green {
	color: #28a745;
}

.color_red {
	color: #dc3545;
}

.img_frame {
	overflow: hidden;
	padding: 2px;
	border: 2px solid #ddd;
	vertical-align: top;
}

.reset_ttl {
}


/* =============================================== */
/** Project */
/* =============================================== */

.map_wrap iframe {
	width: 100%;
	height: 450px;
	vertical-align: top;
}

.img_radius {
	border-radius: 20px;
}

.img_shadow img {
	box-shadow: 10px 10px #fafac5;
}

.pc_hide {
	display: none;
}

/* 見出し */
.box h2 {
	margin-bottom: 10px !important;
	padding: 0 !important;
	line-height: 1.785;
	color: #2a5ac2;
	font-weight: 900;
}
.box h2::before {
	display: none;
}

.box .box_text h4 {
	margin: 0 0 5px !important;
}

/* テーブル */
.tbl_underline th,
.tbl_underline td {
	padding: 30px 0 !important;
	border-top: 1px solid #bbb !important;
	border-bottom: 1px solid #bbb !important;
}
.tbl_underline th {
	color: #2a5ac2 !important;
	font-size: 20px;
}
.tbl_underline td {
	font-size: 16px;
}

.box.-expand {
	margin-bottom: 110px;
}
.box.-expand .box_right {
	margin: 0 -30px 0 60px !important;
}
.box.-expand .box_left {
	margin: 0 60px 0 -30px !important;
}
.box.-expand h2 {
	margin-bottom: 18px !important;
}
.box.-expand .box_text {
	padding-top: 120px;
	line-height: 2.266;
	font-size: 15px;
}

.list_flow {
	position: relative;
	margin: 60px 0 60px !important;
	padding-left: 120px;
}
.list_flow::before {
	content: '';
	display: block;
	position: absolute;
	top: 0;
	left: 120px;
	width: 14px;
	height: 100%;
	margin-left: -7px;
	background: #dfe2e4;
}
.bg_wrap .list_flow::before {
	background: #bbb;
}
.list_flow > li {
	position: relative;
	padding: 0 0 60px 0 !important;
	list-style: none !important;
}
.list_flow > li:last-child {
	padding-bottom: 30px;
}
.list_flow_icon {
	display: block;
	position: absolute;
	top: 0;
	left: -120px;
	z-index: 10;
	width: 100px;
	height: 36px;
	background: #bb91c5;
	line-height: 34px;
	color: #fff;
	font-size: 14px;
	font-weight: bold;
	text-align: center;
}
.list_flow_icon::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 100%;
	border-width: 5px 0 5px 10px;
	border-style: solid;
	border-color: transparent transparent transparent #bb91c5;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}
.list_flow .box {
	position: relative;
	padding-left: 70px;
}
.list_flow .box::before,
.list_flow .box::after {
	content: '';
	display: block;
	position: absolute;
	top: 15px;
}
.list_flow .box::before {
	top: 14px;
	left: -4px;
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: #bb91c5;
}
.list_flow .box::after {
	position: absolute;
	top: 17px;
	left: 5px;
	width: 50px;
	border-bottom: 1px dashed #999;
}
.list_flow .box_right {
	width: 300px;
}
.list_flow .box dt {
	margin: 4px 0 15px;
	line-height: 1.3;
	font-size: 22px;
	font-weight: bold;
}


/* =============================================== */
/** Page */
/* =============================================== */

/* =============================================== */
/** スマホアラート通知ファルネス */
/* =============================================== */
.page-falnes .box.-expand .box_text {
	padding-top: 100px;
}
.page-falnes .box.-expand {
	position: relative;
}
.page-falnes .box.-expand::before {
	content: '';
	position: absolute;
	top: 15px;
	right: 35px;
	width: 633px;
	height: 107px;
	z-index: -100;
	background: url(/shared/img/page/falnes/img04.png) no-repeat center center;
}


/* =============================================== */
/** ウェイブルのミッション */
/* =============================================== */
.page-mission .box.-expand {
	position: relative;
}
.page-mission .box.-expand::before {
	content: '';
	position: absolute;
	top: 5px;
	left: -50px;
	width: 610px;
	height: 154px;
	background: url(/shared/img/page/mission/img07.png) no-repeat center center;
}

.mis_problem {
	margin-bottom: 85px;
	text-align: center;
}
.mis_problem_ttl {
	margin-bottom: 40px !important;
	padding: 0 !important;
	font-weight: 900;
}
.mis_problem_ttl::before {
	display: none;
}
.mis_problem_list {
	display: -ms-flexbox;
	display: flex;
	margin: 0 -18px !important;
}
.mis_problem_list_item {
	-ms-flex: 0 0 20%;
	flex: 0 0 20%;
	width: 20%;
	max-width: 20%;
	padding: 0 18px !important;
}
.mis_problem_list_img {
	margin-bottom: 15px;
}
.mis_problem_list_txt {
	line-height: 1.733 !important;
	font-size: 15px;
}


/* =============================================== */
/** Wavlinkとは */
/* =============================================== */
.page-wavlink .box.-expand {
	position: relative;
}
.page-wavlink .box.-expand::before {
	content: '';
	position: absolute;
	top: 5px;
	right: -45px;
	width: 785px;
	height: 160px;
	z-index: -100;
	background: url(/shared/img/page/wavlink/img05.png) no-repeat center center;
}

.wav_feature_list {
	margin: 0 0 80px !important;
}
.wav_feature_list_item {
	position: relative;
	height: 100%;
	margin-bottom: 60px;
	border-radius: 20px;
	overflow: hidden;
}
.wav_feature_list_item:last-child {
	margin: 0;
}
.wav_feature_list_detail {
	float: left;
	width: 600px;
	background: #fff;
	padding: 40px 50px;
	min-height: 435px;
}
.wav_feature_list_detail h2 {
	margin-bottom: 10px !important;
	padding: 0 !important;
	line-height: 1.785;
	color: #2a5ac2;
	font-weight: 900;
}
.wav_feature_list_detail h2::before {
	display: none;
}
.wav_feature_list_detail strong {
	font-size: 19px !important;
}
.wav_feature_list_detail .list_check {
	margin: 0 0 10px !important;
}
.wav_feature_list_detail .list_check li {
	font-size: 15px !important;
}
.wav_feature_list_img {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	width: 600px;
	background: url(/shared/img/page/wavlink/img02.png) no-repeat center center / cover;
}
.wav_feature_list_item:nth-child(2) .wav_feature_list_img {
	background-image: url(/shared/img/page/wavlink/img03.png);
}
.wav_feature_list_item:nth-child(3) .wav_feature_list_img {
	background-image: url(/shared/img/page/wavlink/img04.png);
}
