@charset "UTF-8";

/*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-

【色設定方法】

「デザイン基本設定」からサイトの色を設定できます。

--------------------------------------------------
ベースカラー（デフォルト：水色 #63C7E0）
--------------------------------------------------
リンク色、サイト名、ナビカレント時背景色

--------------------------------------------------
サブカラー１（デフォルト：濃いグレー #333333）
--------------------------------------------------
フッタ最下部背景色

--------------------------------------------------
サブカラー２（デフォルト：薄いグレー #666666）
--------------------------------------------------
フッタ背景色

--------------------------------------------------
サブカラー３（デフォルト：濃い水色 #36A9CF）
--------------------------------------------------
リンク マウスオーバー時時

--------------------------------------------------
アクセントカラー（デフォルト：#ffffff）
--------------------------------------------------
ナビ文字色、フッタ文字色


*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*/


/* -----------------------------------------------
	共通
------------------------------------------------- */
/* リンク */
a {
	color: #ffa828;
}
a:hover {
	color: #36A9CF;
}

.navbar-default .navbar-nav > li > a {
	color: #ffffff;
}
.navbar-default .navbar-nav > li > a.active,
.navbar-default .navbar-nav > li > a:hover,
.navbar-default .navbar-nav > li > a:focus {
	color: #ffa828;
}

/* ラベル */
.label {
	background-color: #ffa828;
}

/* 改行 */
.br-sp-on {
	display: none;
}

/* ブレークポイント追加 */
@media (min-width: 880px) and (max-width: 991px) {
	.container {
		width: 860px;
	}
}

/* -----------------------------------------------
	ヘッダー
------------------------------------------------- */
header {
	height: 81px;
}

.navbar {
	margin-bottom: 0;
}
.navbar-default {
	padding-top: 15px;
	padding-bottom: 15px;
	border-bottom: none;
	background: #252d44;
}
/* サイト名 ---------- */
.navbar-brand {
	margin: 0 26px;
}
nav a {
	font-weight: bold;
}
/* ナビゲーション部分 ---------- */
.navbar-default .navbar-nav {
		float: none;
}
.navbar-default .navbar-nav li a {
	padding-top: 15px;
	padding-bottom: 5px;
}
.navbar-default .navbar-nav li > a:hover,
.navbar-default .navbar-nav li > a:focus,
.navbar-default .navbar-nav .active > a,
.navbar-default .navbar-nav .active > a:hover {
	background: none;
}
.navbar-default .navbar-nav .active > a,
.navbar-default .navbar-nav .active > a:hover {
	padding: 13px 10px 2px;
	color: #ffffff;
}


.navbar-default .navbar-nav .active > a span,
.navbar-default .navbar-nav .active > a:hover span {
	padding: 2px 5px 3px;
	-moz-border-radius: 2px;
	-webkit-border-radius: 2px;
	border-radius: 2px;
	display: inline-block;
	background-color: #ffa828;
}


/* -----------------------------------------------
	フッター
------------------------------------------------- */
.footer_top {
	color: #bbb;
	padding: 30px 0;
	background-color: #666666;
}
.footer_top .sitemap li {
	padding: 0;
	line-height: 2.5;
}
.footer_top .sitemap li:after {
	content: "/";
}
.footer_top .sitemap li:last-child:after {
	content: none;
}
.footer_top .sitemap li a {
	margin: 0 10px 0 5px;
}
.footer_top h5 {
	margin-bottom: 20px;
	font-size: 16px;
	font-weight: bold;
	color: #ffffff;
}
.footer_top dl {
	margin: 0;
}
.footer_top dl dt {
	width: 1em;
	text-align: center;
}
.footer_top dl dd {
	margin-bottom: 10px;
	margin-left: 1.5em;
}

.footer_bottom {
	padding: 20px 0;
	font-size: 14px;
	color: #ffffff;
	text-align: center;
	background: #252d44;
}
.footer_bottom .sns {
	margin-bottom: 20px;
}
.footer_bottom .sns a {
	font-size: 30px;
	color: #ffffff;
	transition: all 0.3s ease 0s; 
}
.footer_bottom .sns a:hover {
	color: #36A9CF; 
}
.footer_bottom address {
	margin-bottom: 12px;
	font-size: 12px;
}
.footer_bottom p {
	font-size: 10px;
}

/* -----------------------------------------------
	sp時
------------------------------------------------- */
@media (max-width: 767px) {
	/* ヘッダー ---------- */
	.navbar-default {
		padding-top: 4px;
		padding-bottom: 4px;
	}
	.navbar-default h1 {
		margin: 0;
	}
	.navbar-default .container {
		padding: 0 15px;
	}
	.navbar-default .navbar-nav > li > a {
		color: #ffffff; }
	.navbar-default .navbar-collapse {
		border: none;
		-moz-box-shadow: none;
		-webkit-box-shadow: none;
		box-shadow: none;
	}
	.navbar-nav > .active > a,
	.navbar-nav > .active > a:hover,
	.navbar-nav > .active > a:focus {
		color: #ffa828;
		background: #e7e7e7;
	}
	/* フッター ---------- */
	.footer_top {
		padding: 15px 0;
	}
	.footer_top dl dt {
		float: left;
		clear: left;
	}
	.footer_top .sitemap {
		margin-bottom: 20px;
	}
	/* ほか レイアウトなど ---------- */
	.col-xs-10 {
		padding-right: 0;
		padding-left: 0; }
	.col-xs-10 .navbar-toggle {
		margin-right: 6px;
	}
	.br-sp-on {
		display: inline;
	}
	.br-sp-off {
		display: none;
	}
}



/* -----------------------------------------------
	共通 大枠
-------------------------------------------------- */
#main_contents .row {
	margin-right: 0;
	margin-left: 0;
}

/*************************
メインモジュール
*************************/
#main_module {
	padding-bottom: 40px;
}
#main_module .topics_link {
	margin-top: 1em;
}
#main_module .relation_link {
	padding: 10px 0 0;
	text-align: center;
	clear: both;
}

.list-group-item h3 {
	margin-top: 0;
}


/* -----------------------------------------------
	トップページ #page_top
-------------------------------------------------- */
/* #top_contents　メイン写真 ---------- */

#page_top #top_contents .head_image {
	height: 0;
	color: #fff;
	background-size: contain;
}
#page_top #top_contents .head_image .head_image_inner {
	height: 0;
	background-color: rgba(0, 0, 0, 0.3);
	position:relative;
}
#page_top #top_contents .head_image .head_image_text {
	text-align: center;
	position:absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%,-50%);
	transform: translate(-50%,-50%);
	width: 90%;
}
#page_top #top_contents h2 {
	margin: 0;
	font-size: 48px;
	font-weight: bold;
	color: #fff;
	border-bottom: none;
}
#page_top #top_contents p {
	margin-top: 20px;
	font-size: 18px;
	font-weight: bold;

}
#page_top #top_contents .button {
	margin-top: 20px;
	padding: 10px 20px;
	border: solid 2px #fff;
	border-radius: 3px;
	min-width: 360px;
	display: inline-block;
	font-size: 24px;
	font-weight: bold;
	color: #fff;
	text-decoration: none;
	transition: all 0.3s ease 0s;
}
#page_top #top_contents .button:hover {
	color: #fff;
	background: rgba(252, 252, 252, 0.4);
}

/* top_point3　ポイント ---------- */
#top_point3 {
	margin-right: 0;
	margin-left: 0;
}

#page_top #top_point3 > div {
	padding: 60px 20px 40px;
	text-align: center;
}
#page_top #top_point3 p {
	font-size: 16px;
	color: #666;
}
#page_top #top_point3 p.point {
	font-size: 22px;
	font-weight: bold;
}
#page_top #top_point3 i {
	margin: 0 auto 20px;
	padding: 26px 0;
	-moz-border-radius: 50%;
	-webkit-border-radius: 50%;
	border-radius: 50%;
	width: 100px;
	display: block;
	font-size: 48px;
	color: #fff;
	background: #ffa828;
}

/* メイン ---------- */
#page_top #main_module {
	padding: 60px 0;
}
#page_top .module_title {
	margin-top: 0;
	padding-bottom: 6px;
	border-bottom: 2px solid #999;
	font-size: 20px;
	font-weight: bold;
	color: #333;
}
#page_top .module_title small {
	float: right;
	font-size: 14px;
	line-height: 35px;
}
#page_top #main_right .module_title {
	margin-top: 3px;
	font-size: 18px;
}
#page_top #main_module li {
	border: none;
}
#page_top #main_module li .label {
	margin-left: 1em;
	background-color: #ffa828;
}

#page_top #main_right {
	padding-top: 60px;
	padding-bottom: 60px;
}

#page_top #main_bottom .topicsItem {
	padding: 20px 40px;
}
#page_top #main_bottom .topicsItem h3{
    font-size:16px;
}

/* sp時 */
@media (max-width: 767px) {
	/* #top_contents メイン写真 */
	#page_top #top_contents h2 {
		display: none;
	}
	#page_top #top_contents p {
		margin-top: 0;
		font-size: 14px;
	}
	#page_top #top_contents .button {
		margin-top: 0;
		min-width: 250px;
		font-size: 14px;
		padding: 3px 0;
	}

	/* top_point3　ポイント */
	#page_top #top_point3 > div {
		padding: 40px 20px 20px;
	}
	/* メインモジュール */
	#page_top #main_module {
		padding: 40px 0 20px;
	}
	#page_top #main_module li {
		line-height: 1.7;
	}
	/* サイドモジュール */
	#page_top #main_right {
		padding-top: 30px;
	}

    #page_top #main_bottom .topicsItem {
	    padding: 20px 20px;
    }
}


/* -----------------------------------------------
	セカンドページ
-------------------------------------------------- */
body:not(#page_top) .navbar-default {
	border-bottom: none;
}
body:not(#page_top) .breadcrumbs {
	position: relative;
	font-size: 12px;
	color: #ffffff;
	background-color: rgba(51, 51, 51, 0.65);
	z-index: 100;
}

body:not(#page_top) .breadcrumb {
	margin-bottom: 0;
	padding: 12px 0;
	background: none;
}

body:not(#page_top) #top_contents {
	margin: -41px 0 60px;
}
body:not(#page_top) #top_contents .head_image {
	height: 0;
}
body:not(#page_top) #top_contents .head_image_inner {
	height: 0;
	color: #fff;
	text-align: center;
	background: rgba(0, 0, 0, 0.3);
	position: relative;
}
body:not(#page_top) #top_contents .head_image_text {
	width: 90%;
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%,-50%);
	transform: translate(-50%,-50%);
}
body:not(#page_top) #top_contents .head_image_text h2 {
	font-size: 26px;
	font-weight: bold;
	margin: 41px 0 0;
}
body:not(#page_top) #top_contents .head_image_text h2 span {
	padding: 0 10px;
	border-bottom: 3px solid #ffa828;
}
body:not(#page_top) #top_contents .head_image_text p {
	padding: 15px 0 0 0;
}

/* sp時 */
@media (max-width: 767px) {
	body:not(#page_top) .breadcrumbs {
		display: none;
	}
	body:not(#page_top) #top_contents {
		margin: 0 0 20px;
	}
	body:not(#page_top) #top_contents .head_image_text h2 {
		font-size: 18px;
		margin: 0;
	}
}


/* セカンドページ詳細 ---------- */
body:not(#page_top) #main_module .module_title {
	margin: 0 0 15px;
	padding-bottom: 10px;
	border-bottom: 3px solid #ffa828;
	font-size: 26px;
}
body:not(#page_top) #main_bottom section {
	margin-bottom: 40px;
}
body:not(#page_top) #main_bottom h3 {
	padding-bottom: 3px;
	border-bottom: 2px solid #ddd;
}
body:not(#page_top) #main_contents h3.title {
    clear:both;
	padding-bottom: 3px;
	border-bottom: 2px solid #ddd;
	padding-top:40px;
}

/* セカンドサイド共通 */
body:not(#page_top) #main_right .module_title {
	margin: 7px 0 18px;
	padding-bottom: 10px;
	border-bottom: 2px solid #999;
	font-size: 18px;
	font-weight: bold;
	color: #333;
}
body:not(#page_top) #main_right section {
	margin-bottom: 40px;
}

/* セカンドサイドナビ ---------- */
.second_navi .list-group-item {
	padding: 0;
}
.second_navi .list-group-item a {
	font-weight: normal;
	color: #999;
}
.second_navi .list-group-item a:hover {
	color: #ffa828;
}
.second_navi .list-group-item.active {
	background: none;
	border-color: #ddd;
}
.second_navi .list-group-item.active a {
	color: #ffa828;
	background-color: #eee;
}
.second_navi .level2 a {
		padding-left: 25px;
		position: relative;
}
.second_navi .level2 a::before {
		position: absolute;
		left: 15px;
		content: "-";
}
.second_navi .list-group-item .badge {
		float: right;
}

/* sp時 */	
@media (max-width: 767px) {
	.second_navi {
		padding-bottom: 30px;
	}
}

/* バナーナビ ---------- */
.customize_navi {
	margin: 0;
	padding: 0;
}
.customize_navi li {
	margin: 20px 0;
	text-align: center;
	list-style: none;
}
.customize_navi li img {
	margin: 0 auto;
}


/* カード型一覧 ---------- */
#columns {
	padding-bottom: 45px;
}
#columns > div {
	padding: 0 8px;
}
#columns .cards .thumbnail {
	margin-bottom: 15px;
	-moz-box-shadow: 0 3px 4px #eee;
	-webkit-box-shadow: 0 3px 4px #eee;
	box-shadow: 0 3px 4px #eee;
}
#columns .cards .caption h3 {
	margin-top: 0;
	margin-bottom: 0;
	font-size: 20px;
	font-weight: normal;
}
#columns .cards .caption span {
	font-size: 12px;
}
#columns .cards .caption span.ymd {
	color: #999;
}
#columns .cards .caption span.label {
	font-weight: normal;
	font-size: 10px;
	background-color: #ffa828;
}
#columns .cards .caption div {
	padding-top: 10px;
	font-size: 14px;
	color: #666;
}

/* sp時 */
@media (max-width: 767px) {
	#columns > div {
		padding: 0 15px;
	}
}


/* 採用情報 ---------- */
#main_module dl dt,
#main_module dl dd {
	padding-bottom: 10px;
}

/* ブログ トップ ---------- */
#main_module #blog_new_item_list {
	margin-bottom: 20px;
}
#main_module #blog_new_item_list article {
	padding: 10px 0 0;
}
#main_module #blog_new_item_list .blog_relation_link {
	padding: 10px 0 20px;
	border-bottom: 1px solid #ddd;
}

/* お問い合わせ ---------- */
#main_module form[name="inquiry_form"] .label-danger {
	margin-left: 0.5em;
	background-color: #d9534f;
}
.form-group {
		margin-bottom: 25px;
}

/* 実績紹介 一覧 ---------- */
.portfolio-items .boxContent {
		margin-bottom: 20px;
}
.portfolio-items .boxContent h3 {
	font-size: 20px;
}

/* トピックス 一覧 ---------- */
.topicsItem h3 {
		margin-bottom: 5px;
		font-size: 20px;
		line-height: 1.4;
}
.topicsItem .ymd,
.topicsItem .label {
		margin-bottom: 5px;
		display: inline-block;
}

/* トピックス 詳細 ---------- */
.topics_contents {
	padding-bottom: 2em;
	border-bottom: 2px solid #eee;
}
.topics_contents .pdf_area {
		margin-top: 40px;
}
.topics_contents .pdf_area ul {
		padding: 0 0 0 20px;
}


/* サイトマップ ---------- */
.map-parent {
		margin-bottom: 15px;
		padding: 0;
		list-style: none outside;
}
.map-parent .fa {
		margin-right: 5px;
		display: inline-block;
		font-size: 18px;
		vertical-align: middle;
}
.map-child li {
		margin-top: 5px;
		list-style: disc outside;
}


iframe{
    max-width:100%;
}