@charset "utf-8";
/*reset*/
body, h1, h2, h3, h4, h5, h6, h7, div, p, dl, dt, dd, ol, ul, li, table, th, td, fieldset, form, input[type="radio"], input[type="checkbox"] {
    margin: 0;
    padding: 0;
	box-sizing: border-box;
}
h1, h2, h3, h4, h5, h6, h7, dt, dd, th, td, em, address, label {
    font-weight: normal;
    font-style: normal;
    font-size: inherit;
}
ol, ul {
    list-style-type: none;
}
table {
    border-collapse: collapse;
    border-spacing: 0;
}
img, fieldset {
    border: 0;
}
img {
    display: block;
}
h1, h2, h3, h4, h5, h6, h7, p, dl, dt, dd, ol, ul, li, th, td {
    line-height: 1.8;
}
/*common*/
body {
    font-family: '游ゴシック', 'Yu Gothic', 'メイリオ', 'Meiryo', 'ＭＳ Ｐゴシック', sans-serif;
    line-height: 1.8;
    font-size: 4.5vw;
	color: #333;
	font-feature-settings: "palt";
}
a {
    color: #0066CC;
}
a.bluebtn,
a.whitebtn {
	position: relative;
	display: block;
	padding: 4vw 8vw 4vw 4vw;
	color: #FFF;
	line-height: 1;
	font-weight: bold;
	text-decoration: none;
	text-align: center;
	background: #0f476a;
	border-radius: 9999px;
	box-shadow: 0 2px 4px rgba(0,0,0,0.3);
  	transition: .3s;
}
a.whitebtn {
	background: #FFF;
	color: #0f476a;
	border: 1px solid #0f476a;
}
a.bluebtn:hover,
a.whitebtn:hover {
	box-shadow: 0 0 2px rgba(0,0,0,0.2);
	transform: translateY(2px);
  	transition: .3s;
}
a.bluebtn::after,
a.whitebtn::after {
	display: block;
	content: "";
	position: absolute;
	top: calc(50% - 1.25vw);
	right: 4vw;
	border-top: 2px solid #FFF;
	border-right: 2px solid #FFF;
	width: 2.5vw;
	height: 2.5vw;
	transform: rotate(45deg);
}
a.whitebtn::after {
	border-top: solid 2px #0f476a;
	border-right: solid 2px #0f476a;
}
.pc {
	display: none;
}
.inner {
	padding: 0 4vw;
}
section {
	margin-bottom: 12vw;
}
section h2 {
	margin-bottom: 8vw;
	font-size: 6.5vw;
	color: #0f476a;
	font-weight: bold;
	text-align: center;
	line-height: 1;
}
section h2::after {
    display: block;
    content: "";
    margin: 4vw auto 0;
    width: 20vw;
    height: 5px;
    background: #ffc600;
    background: -moz-linear-gradient(left, #ffc600 0%, #ff9c00 100%);
    background: -webkit-linear-gradient(left, #ffc600 0%, #ff9c00 100%);
    background: linear-gradient(left, #ffc600 0%, #ff9c00 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffc600', endColorstr='#ff9c00',GradientType=1 );
}

/*header*/
header .inner {
	padding: 0;
}
/*section#mv*/
section#mv {
	margin-bottom: 6vw;
}
section#mv .inner {
	padding: 0;
}
section#mv h1 img {
	width: 100%;
	height: auto;
}
/*section.cv*/
section.cv p.title {
	margin-bottom: 4vw;
	font-size: 6vw;
	font-weight: bold;
	text-align: center;
	line-height: 1.4;
}
section.cv .tel {
	margin-bottom: 3vw;
}
section.cv .tel a img {
	margin: 0 auto;
	width: 95%;
	height: auto;
}
section.cv .tel a p.openhour {
	margin-top: 1.5vw;
	text-align: center;
	font-size: 3.3vw;
}
section.cv .mail a.bluebtn {
	padding: 8vw 4vw;
	font-size: 6vw;
}
/*section#about*/
section#about .engagement {
	margin-bottom: 8vw;
}
section#about .engagement .image {
	margin-bottom: 6vw;
}
section#about .engagement .image img {
	width: 100%;
	height: auto;
}
section#about .engagement .text p {
	margin-bottom: 4vw;
}
section#about .engagement .text p:last-of-type {
	margin-bottom: 0;
}
section#about .vision {
	position : relative;
	padding: 8vw 4vw 6vw;
	border: 1px solid #0f476a;
	border-radius: 10px;
}
section#about .vision h3 {
	position: absolute;
	top: -2.5vw;
	left: calc(50% - 27.5vw);
	width: 55vw;
	line-height: 1;
	font-size: 5.5vw;
	font-weight: bold;
	color: #0f476a;
	text-align: center;
	background: #FFF;
}
section#about .vision .image {
	float: right;
	width: 40vw;
	margin-left: 3vw;
	margin-bottom: 3vw;
}
section#about .vision .image img {
	width: 100%;
	height: auto;
}
section#about .vision .text p {
	margin-bottom: 4vw;
}
section#about .vision .text a.bluebtn {
	padding: 6vw 4vw 6vw 2vw;
	font-size: 4.3vw;
	background: #3a8abc;
}
/*section#point*/
section#point .point_head {
    margin-bottom: 8vw;
}
section#point .point_head .inner {
    display: flex;
	flex-wrap: wrap;
	padding: 0;
}
section#point .point_head .title {
	order: 2;
	width: 100%;
	height: 35vw;
    display: flex;
	justify-content: center;
	align-items: center;
    background: #0f476a;
}
section#point .point_head .title h2 {
	margin-bottom: 0;
	color: #FFF;
}
section#point .point_head .image {
	width: 100%;
	height: 55vw;
	order: 1;
	background: url("/houjin/fpsoudan/image/bg_point.jpg") left center no-repeat;
	background-size: cover;
}
section#point .point_area {
	margin-bottom: 8vw;
}
section#point .point_area:last-of-type {
	margin-bottom: 0;
}
section#point .point_area h3 {
	margin-bottom: 6vw;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	color: #0f476a;
	font-size: 6vw;
	font-weight: bold;
	line-height: 1.4;
}
section#point .point_area h3 img {
	width: 13.4352vw;
	height: 16.308vw;
	margin-right: 4vw;
}
section#point .point_area p.explain {
	margin-bottom: 6vw;
}
section#point .point_area.point_01 ul.type {
	margin-bottom: 1vw;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
section#point .point_area.point_01 ul.type li {
	width: calc((100% - 3vw) / 2);
	margin-bottom: 3vw;
	padding: 3vw;
	background: #f2f2f2;
	border-radius: 10px;
}
section#point .point_area.point_01 ul.type li img {
	width: 100%;
	heigiht: auto;
	margin-bottom: 3vw;
}
section#point .point_area.point_01 ul.type li h4 {
	height: 12.6vw;
	margin-bottom: 2vw;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 4.5vw;
	font-weight: bold;
	text-align: center;
	color: #0f476a;
	line-height: 1.4;
}
section#point .point_area.point_01 ul.type li h4 span {
	margin-left: 2vw;
	font-size: 3.5vw;
}
section#point .point_area.point_01 p.disclaimer {
	padding-left: 1em;
	text-indent: -1em;
	font-size: 3.5vw;
}
section#point .point_area.point_02 ul.plan li {
	margin-bottom: 4vw;
	background: #f2f2f2;
	border-radius: 10px;
}
section#point .point_area.point_02 ul.plan li h4 {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 4vw 2vw;
	font-size: 5vw;
	font-weight: bold;
	color: #FFF;
	line-height: 1;
	border-radius: 10px 10px 0 0;
}
section#point .point_area.point_02 ul.plan li h4 span {
	margin-left: 1.5vw;
	padding: 1vw 1.5vw;
	font-size: 3vw;
	color: #FFF;
	border: 1px solid #FFF;
	border-radius: 999px;
}
section#point .point_area.point_02 ul.plan li.soudan h4 {
	background: #73b944;
}
section#point .point_area.point_02 ul.plan li.seminar h4 {
	background: #58a2b5;
}
section#point .point_area.point_02 ul.plan li img {
	width: 100%;
	heigiht: auto;
	margin-bottom: 4vw;
}
section#point .point_area.point_02 ul.plan li .plan_inner {
	padding: 4vw;
	border-radius: 0 0 10px 10px;
}
section#point .point_area.point_02 ul.plan li .plan_inner p {
	margin-bottom: 4vw;
}
section#point .point_area.point_02 ul.plan li .plan_inner p:last-of-type {
	margin-bottom: 0;
}
section#point .point_area.point_02 .online {
	padding: 4vw;
	border: 1px solid #0f476a;
	border-radius: 10px;
}
section#point .point_area.point_02 .online .text h4 {
	margin-bottom: 4vw;
	padding-left: 21vw;
	min-height: 14.5206vw;
	font-size: 5.5vw;
	font-weight: bold;
	color: #0f476a;
	line-height: 1.4;
	background: url("/houjin/fpsoudan/image/icon_online.png") left center no-repeat;
	background-size: 18vw 14.5206vw;
}
section#point .point_area.point_03 .jisseki .image {
	margin-bottom: 6vw;
}
section#point .point_area.point_03 .jisseki .image img {
	width: 100%;
	height: auto;
}
section#point .point_area.point_03 .jisseki .text p {
	margin-bottom: 4vw;
}
section#point .point_area.point_03 .jisseki .text p:last-of-type {
	margin-bottom: 0;
}
/*section#flow*/
section#flow .flow_head {
	height: 50vw;
	background: url("/houjin/fpsoudan/image/bg_flow.jpg") left center no-repeat;
    background-size: cover;
}
section#flow .flow_head .inner {
	padding-top: 16vw;
}
section#flow .flow_head h2 {
	color: #FFF;
}
section#flow ul.flow {
	margin-top: -10vw;
}
section#flow ul.flow li {
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	margin-bottom: 7.25vw;
	padding: 4vw;
	color: #FFF;
	background: #0f476a;
	border-radius: 10px;
}
section#flow ul.flow li::after {
	content: "";
	position: absolute;
	width: 6vw;
	height: 6vw;
	left: calc(50% - 3vw);
	bottom: -4.5vw;
	background: linear-gradient(45deg, transparent 50%, #ff9c00 50%, #ffc600);
	transform: rotate(135deg);
}
section#flow ul.flow li:last-child::after {
	display: none;
}
section#flow ul.flow li p.step {
	width: 100%;
	height: 8vw;
	margin-bottom: 4vw;
}
section#flow ul.flow li p.step img {
	width: auto;
	height: 8vw;
	margin: 0 auto;
}
section#flow ul.flow li .image {
	height: 8vw;
}
section#flow ul.flow li .image img {
	width: auto;
	height: 8vw;
	margin-right: 4vw;
}
section#flow ul.flow li h3 {
	font-size: 5.5vw;
	font-weight: bold;
	text-align: center;
	line-height: 1;
}
section#flow ul.flow li p.explain {
	width: 100%;
	margin-top: 4vw;
}
/*section#faq*/
section#faq {
	padding: 10vw 0;
	background: #0f476a;
	color: #FFF;
}
section#faq h2 {
	color: #FFF;
}
section#faq dl {
	margin-bottom: 8vw;
	line-height: 1.6;
	color: #FFF;
}
section#faq dl dt {
	position: relative;
	margin-bottom: 6vw;
	padding-left: 14vw;
	font-size: 5vw;
	font-weight: bold;
}
section#faq dl dt::before {
	position: absolute;
	top: -1vw;
	left: 0;
	content: "";
	width: 10vw;
	height: 10vw;
	background: url("/houjin/fpsoudan/image/txt_q.png") center center no-repeat;
    background-size: 100% 100%;
}
section#faq dl dt span {
	font-size: 80%;
}
section#faq dl dd {
	position: relative;
	padding-left: 14vw;
	font-size: 4.5vw;
}
section#faq dl dd::before {
	position: absolute;
	top: -2.0vw;
	left: 0;
	content: "";
	width: 10vw;
	height: 10vw;
	background: url("/houjin/fpsoudan/image/txt_a.png") center center no-repeat;
    background-size: 100% 100%;
}
section#faq p.disclaimer {
	padding-left: 1em;
	text-indent: -1em;
	font-size: 3.5vw;
}
section#faq p.disclaimer02 {
	font-size: 3.5vw;
}
/*section#company*/
section#company .information dl {
	margin-bottom: 6vw;
}
section#company .information dl dt {
	margin-bottom: 4vw;
	padding: 1vw 4vw;
	font-size: 5vw;
	font-weight: bold;
	text-align: center;
	background: #f2f2f2;
}
section#company .extra {
	padding: 6vw 4vw;
	border: 1px solid #0f476a;
	border-radius: 10px;
}
section#company .extra .extra_area .image {
	margin-bottom: 6vw;
}
section#company .extra .extra_area .image img {
	margin: 0 auto;
}
section#company .extra .extra_area.porter .image img {
	width: 26.88vw;
	height: auto;
}
section#company .extra .extra_area.isms .image img {
	width: 46.4vw;
	height: auto;
}
section#company .extra .extra_area .text h3 {
	margin-bottom: 4vw;
	font-size: 4vw;
	font-weight: bold;
	color: #0f476a;
	line-height: 1.4;
	text-align: center;
}
section#company .extra .extra_area .text h3 span {
	font-size: 5.5vw;
}
section#company .extra .porter {
	margin-bottom: 6vw;
	padding-bottom: 6vw;
	border-bottom: 1px solid#DDD;
}
section#company .extra .isms .image p.detail {
	margin-top: 4vw;
	font-size: 2.8vw;
	line-height: 1.4;
	text-align: center;
}