@charset "utf-8";

/*--------------------------------------------------------------【サンプルコメント】*/
/* サンプルコメント（example）
----------------------------------------------- */

/* ================================================================================ */
/*                                                                                  */
/*      スタイル                                                                    */
/*                                                                                  */
/* ================================================================================ */

/* 
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com 
Twitter: @rich_clark
*/

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
	margin:0;
	padding:0;
	border:0;
	outline:0;
	font-size:100%;
	vertical-align:baseline;
	background:transparent;
}

body {
	line-height:1;
}

article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section { 
	display:block;
}

nav ul {
	list-style:none;
}

blockquote, q {
	quotes:none;
}

blockquote:before, blockquote:after,
q:before, q:after {
	content:'';
	content:none;
}

a {
	margin:0;
	padding:0;
	font-size:100%;
	vertical-align:baseline;
	background:transparent;
}

/* change colours to suit your needs */
ins {
	background-color:#ff9;
	color:#000;
	text-decoration:none;
}

/* change colours to suit your needs */
mark {
	background-color:#ff9;
	color:#000; 
	font-style:italic;
	font-weight:bold;
}

del {
	text-decoration: line-through;
}

abbr[title], dfn[title] {
	border-bottom:1px dotted;
	cursor:help;
}

table {
	border-collapse:collapse;
	border-spacing:0;
}

/* change border colour to suit your needs */
hr {
	display:block;
	height:1px;
	border:0;   
	border-top:1px solid #cccccc;
	margin:1em 0;
	padding:0;
}

input, select {
	vertical-align:middle;
}

/* ベース
----------------------------------------------- */

*	{
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}

.clearfix:after	{
	content: '';
	display: block;
	clear: both;
}

body	{
	font-size: 12px;
	font-family: Verdana,Arial,"メイリオ",Meiryo,"ヒラギノ角ゴPro W3","Hiragino Kaku Gothic Pro","ＭＳ Ｐゴシック",sans-serif;
	color: #212121;
}

a	{
	color: #333;
}

a:hover	{
	color: #424242;
	text-decoration: none;
}

.copy	{ color: #757575; padding: 20px 0; }
.copy a	{ color: inherit; }


/* ================================================================================ */
/*                                                                                  */
/*      レイアウト                                                                  */
/*                                                                                  */
/* ================================================================================ */

.wrapper {
}

.container {
	background: #FFEFD4;
}

.contents {
	width: 960px;
	margin: 0 auto;
	padding: 20px 10px 30px;
}

.indexLayer {}

.mainContents {
	width: 620px;
	float: right;
}

.sideContents {
	width: 300px;
	float: left;
}

/* ヘッダー
----------------------------------------------- */

.header {
	width: 960px;
	padding: 15px 0;
	margin: 0 auto;
}

.header__logo {
}

.header__logo a {}

.header__logo a img {
	height: 60px;
}

/* フッター
----------------------------------------------- */

.footer {
	background:#390000;
}

.footer__ {
	width: 960px;
	margin: 0 auto;
	padding: 40px 0;
}

.footer__logo {
	display: inline-block;
	margin: 0 20px 0 10px;
	vertical-align: top;
}

.footer__logo a {
	font-size: 16px;
	font-weight: bold;
	text-decoration: none;
	color: #CCC;
}

.footerNav {
}

.footerNav__list {
	overflow: hidden;
	list-style: none;
	margin: 10px 0;
}

.footerNav__list__item {
	float: left;
}

.footerNav__list__item a {
	display: block;
	padding: 5px 10px;
	text-decoration: none;
	color: #CCC;
}

.footerNav__list__item a:hover {
	text-decoration: underline;
}

.siteCopy {
	background: #000;
	padding: 20px 0;
}

.siteCopy__text {
	width: 960px;
	margin: 0 auto;
	text-align: center;
	font-size: 10px;
	color: #666;
}


/* ================================================================================ */
/*                                                                                  */
/*      モジュール＆ステート                                                        */
/*                                                                                  */
/* ================================================================================ */

/* 汎用リスト
----------------------------------------------- */

.commonList {
	padding: 0 20px;
}

.commonList__item {}


/* ナビゲーション
----------------------------------------------- */

.navBg {
	background: #FFF;
	border-top: 1px solid #EEE;
	border-bottom: 1px solid #EEE;
	box-shadow: 0 2px rgba(0,0,0,0.05);
	margin:  0 0 2px;
}

.globalNav {
}

.globalNav__list {
	overflow: hidden;
	width: 960px;
	margin: 0 auto;
	border-left: 1px solid #EEE;
}

.globalNav__list__item {
	float: left;
	border-right: 1px solid #EEE;
	padding: 0 1px;
}

.globalNav__list__item a {
	display: block;
	width: 154px;
	height: 60px;
	padding-top: 15px;
	text-align: center;
	font-size: 13px;
	text-decoration: none;
	position: relative;
	color: #666;
	position: relative;
	overflow: hidden;
}

.globalNav__list__item a strong {
	display: block;
	font-size: 14px;
	font-weight: bold;
	line-height: 1.3;
}

.globalNav__list__item a strong:hover {
	color: #0b2c79;
}


.globalNav__list__item a span {
	display: block;
	margin: 3px 0 0 0;
	color: #AAA;
	text-transform: uppercase;
	font-size: 80%;
	letter-spacing: 1px;
}

.globalNav__list__item--active {}


/* サイドメニュー
----------------------------------------------- */

.sideContents__title {
	padding: 0.6em 0.6em 0.6em 1.6em;
	margin: 0 0 10px;
	background:#F8C5C7;
	border-bottom: 2px solid rgba(255,255,255,1);
	font-weight: normal;
	font-size: 16px;
	position: relative;
	color: #0b2c79;
}

.sideContents__title:before {
	content: "";
	position: absolute;
	left: 10px;
	top: 50%;
	transform: translateY(-25%);
	border-top: 5px solid #333;
	border-right: 5px solid transparent;
	border-bottom: 5px solid transparent;
	border-left: 5px solid transparent;
}

.sideContents__list {
	margin: 0 0 20px;
	list-style: none;
}

.sideContents__list li {
	border-bottom: 1px solid #DDD;
	font-size: 13px;
}

.sideContents__list li a {
	display: block;
	padding: 15px 10px 15px 35px;
	text-decoration: none;
	position: relative;
}

.sideContents__list li a:before {
	content: "";
	position: absolute;
	left: 15px;
	top: 50%;
	transform: translateY(-50%);
	width: 4px;
	height: 4px;
	border-radius: 50%;
	background: #333;
}

.sideContents__list li a:hover {
	text-decoration: underline;
}


/* トップイメージ
----------------------------------------------- */

.indexFech {
	height: 400px;
    text-align: center;
    background-image: url(images/main6.jpg);
}

.indexFech__title {
	color: #FF6A6E;
	font-size:25px;
	padding: 50px 0 30px;
	line-height:normal
}

.indecFech__text {
	color: rgba(255,255,255,0.9);
	font-size: 15px;
	line-height: normal
}

.indecFech__text--target {
	color: rgba(255,255,255,0.9);
	font-size: 15px;
	padding: 30px 0 25px 0;
}

.indecFech__text--desc {
	color: rgba(255,255,255,0.9);
	font-size: 15px;
	padding: 30px 0 25px 0;
	line-height: normal
}

.indecFech__text--description span:first-child {
	padding: 20px 0 10px 0;
}

.topImage {
	padding: 20px 0 0;
}

.topImage__ {
	position: relative;
	margin: 0 auto;
	width: 940px;
}

.topImage img {
	display: block;
	margin: 0 auto;
	height: auto;
	max-width: 100%;
}

.topImage__title {
	font-size: 15px;
	color: #666;
}

.slogan	{
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	background:#FF6A6E;
	color: #FFF;
	line-height: 1.4;
	padding: 5px 10px;
}

.slogan__title	{
	font-weight: normal;
}

.slogan__text	{}


/* 記事
----------------------------------------------- */

.promotionCase {
    padding: 10px;
    font-weight: normal;
    font-size: 16px;
	color: #0b2c79;
}

.indexLayer {
	overflow: hidden;
	margin: 0 0 10px;
}

.articlePart {
	float: left;
	width: 32%;
	min-height: 165px;
	margin: 0 0 15px 2%;
	padding: 15px;
	border: 1px solid #eee;
	border-radius: 3px;
	background: #FFE1AA;
	box-shadow: 2px 2px rgba(0,0,0,0.05);
}

.articlePart:nth-child(3n+1) {
	margin: 0 0 15px 0;
}

.articlePart__title {
	margin: -10px -10px 15px;
	padding: 15px 10px 15px 25px;
	background: #FFEFD4;
	border-bottom: 1px solid rgba(0,0,0,0.1);
	position: relative;
}

.articlePart__title:before {
	content: "";
	position: absolute;
	left: 10px;
	top: 50%;
	transform: translateY(-50%);
	border: 4px solid #333;
	border-radius: 50%;
}

.articlePart p {
	line-height: 1.6;
	font-size: 11px;
}

.articlePart__more {
	text-align: right;
}

.articlePart__more a {
	padding: 3px 12px;
	display: inline-block;
	border: 1px solid #666;
	border-radius: 2px;
}

.articlePart__more a:hover {
}

.articlePart--index {}


/* お知らせ
----------------------------------------------- */

.articleNews {
	margin: 0 0 20px;
	box-shadow: 2px 2px rgba(0,0,0,0.05);
}

.articleNews__title {
	padding: 10px;
	background: #FFE1AA;
	border-bottom: 1px solid rgba(0,0,0,0.1);
	font-weight: normal;
	font-size: 16px;
	color: #0b2c79;
}

.articleNews__body {
	padding: 20px;
	font-size: 13px;
	background: rgba(255,255,255,0.95);
}

.articleNews__body p {
	line-height: 1.6;
	overflow: hidden;
}

.articleNews__body p img {
	float: right;
	height: auto;
	margin: 10px;
}

.newsInfo .mainContents {
	width: 100%;
	float: none;
}

.newsInfo .articleNewsInfo {
	border: 1px solid #DDD;
	margin: 0 0 20px;
	box-shadow: 2px 2px rgba(0,0,0,0.05);
}

.newsInfo .articleNewsInfo__body {
	padding: 60px 80px 40px;
	font-size: 14px;
	background: rgba(255,255,255,1);
}

.newsInfo .articleNewsInfo__body p {
	line-height: 1.6;
	font-size: 15px;
	margin: 0 0 10px;
	overflow: hidden;
}

.newsInfo .articleNewsInfo__body ol {
	margin: 0 30px;
	line-height: 1.5;
	font-size: 15px;
}

.newsInfo .articleNewsInfo__body ol li {
	margin: 0 0 10px;
}

.newsInfo .articleNewsInfo__body table.articleTable th,
.newsInfo .articleNewsInfo__body table.articleTable td {
	padding: 4px 8px;
	font-size: 13px;
}

.newsInfo .articleNewsInfo__body table.articleTable th {
	width: 200px;
}

.newsInfo p.articleNewsInfo__auth {
	text-align: right;
	font-size: 13px;
}

.newsInfo .articleNewsInfo__title {
	text-align: center;
	font-size: 24px;
	line-height: 1.3;
	margin: 20px 0;
}

.newsInfo .articleNewsInfo__title--lv2 {
	font-size: 16px;
	text-align: left;
}


/* ページ(汎用)
----------------------------------------------- */

.articleBase {
	border: 1px solid #EEE;
	margin: 0 0 20px;
	box-shadow: 2px 2px rgba(0,0,0,0.05);
}

.articleBase__title {
	padding: 0.6em;
	background: #F5F5F5;
	font-weight: normal;
	font-size: 16px;
}

.articleBase__body {
	padding: 1em 2em;
	line-height: 1.6;
	font-size: 13px;
	background: rgba(255,255,255,0.95)
}

.articleBase__body__title {
	font-size: 16px;
	padding: 0.6em 0;
	margin: 1em 0;
}

.articleBase__body > .articleBase__body__title {
	margin: 0 0 1em;
}

.articleBase__body__title strong {
	font-size: 75%;
	font-weight: normal;
	letter-spacing: 2px;
	display: block;
}

.articleBase__body__title span {
	font-weight: normal;
	font-size: 75%;
	padding: 0 10px;
}

.articleBase__body p {
	margin: 1em 0;
}

.articleThumbBg {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	margin: 0 0 20px;
}

.articleThumbBg__list {
	list-style: none;
	width: 25%;
	height: 94px;
	background-size: cover;
	background-position: center;
	font-size: 10px;
	text-align: right;
	padding: 0 5px 0 0;
}



/* 会社概要
----------------------------------------------- */

.articleCompany {
	border: 1px solid #EEE;
	margin: 0 0 20px;
	box-shadow: 2px 2px rgba(0,0,0,0.05);
}

.articleCompany__title {
	padding: 0.6em;
	background: #F5F5F5;
	font-weight: normal;
	font-size: 16px;
	color: #0b2c79;
}

.articleCompany__body {
	padding: 1em 2em;
	background: rgba(255,255,255,0.95);
}

.articleTable {
	width: 100%;
	margin: 1em 0;
}

.articleTable td,
.articleTable th,
.articleTable {
	border-collapse: collapse;
	border-bottom: 1px solid #EEE;
}

.articleTable th,
.articleTable td {
	padding: 8px;
	line-height: 20px;
}

.articleTable th {
	white-space: nowrap;
	text-align: right;
	font-weight: normal;
}

.articleTable td {
	
}

.articleTable td a {
}


/* ================================================================================ */
/*                                                                                  */
/*      レスポンシブ対応(PCファースト)                                              */
/*                                                                                  */
/* ================================================================================ */

@media only screen and (max-width:960px)	{}

/* iPad縦(portrait) */
@media only screen and (max-width:768px)	{}

/* smartphone横(landscape) */
@media only screen and (max-width:640px)	{

	.header {
		width: 100%;
		padding: 5px 0;
		position: fixed;
		z-index: 9999;
		background: #fff;
	}

	.header__logo {
	}

	.header__logo a img {
		margin: 0 0 0 10px;
		height: 44px;
	}

	.globalNav {
		position: fixed;
		z-index: 9999;
		/* 開いてないときは画面外に配置 */
		top: -500px;
		background: #333;
		width: 100%;
		text-align: center;
		-webkit-transition: .5s ease-in-out;
		-moz-transition: .5s ease-in-out;
		transition: .5s ease-in-out;
	}

	.globalNav__list {
		list-style: none;
		position: static;
		right: 0;
		bottom: 0;
		font-size: 11px;
		width: 100%;
	}

	.globalNav__list__item {
		border-bottom: 1px solid #999;
		float: none;
	}
	
	.globalNav__list__item a {
		width: 100%;
		display: block;
		color: #fff;
		padding: 18px 0;
		text-decoration: none;
	}
	
	.navToggle {
		position: absolute;
    	right: 10px;
		top: 16px;
		width: 34px;
		height: 36px;
		cursor: pointer;
		z-index: 101;
	}

	.navToggle__icon {
		position: relative;
	}
	
	.navToggle__icon__item {
		display: block;
		position: absolute;
		height: 4px;
		width: 100%;
		background: #0b2c79;
		left: 0;
		-webkit-transition: .35s ease-in-out;
		-moz-transition: .35s ease-in-out;
		transition: .35s ease-in-out;
	}
	
	.navToggle__icon__item:nth-child(1) {
		top: 0;
	}

	.navToggle__icon__item:nth-child(2) {
		top: 10px;
	}
	
	.navToggle__icon__item:nth-child(3) {
		top: 20px;
	}

	/* navToggle 切り替えアニメーション */
	.open .navToggle__icon__item:nth-child(1) {
		top: 11px;
		-webkit-transform: rotate(315deg);
		-moz-transform: rotate(315deg);
		transform: rotate(315deg);
	}
	
	.open .navToggle__icon__item:nth-child(2) {
		width: 0;
		left: 50%;
	}

	.open .navToggle__icon__item:nth-child(3) {
		top: 11px;
		-webkit-transform: rotate(-315deg);
		-moz-transform: rotate(-315deg);
		transform: rotate(-315deg);
	}

	/* globalNav スライドアニメーション */
	.open .globalNav {
		-moz-transform: translateY(556px);
		-webkit-transform: translateY(556px);
		transform: translateY(555px);
	}
	
	.topBg {
    	display: table;
    	width: 100%;
		margin: 50px 0 0 0;
	}
	
	.indexFech {
		height: 300px;
		text-align: center;
		background-image: url(images/main6_2.jpg);
		background-size: cover;
		display: table-cell;
    	vertical-align: middle;
	}
	
	.indexFech__title {
    	padding: 10;
	}
	
	.indecFech__text {
		color: rgba(255,255,255,0.9);
		font-size: 12px;
	}
	
	.indecFech__text--target,
	.indecFech__text--desc{
		font-size: 10px;
	}
 
	.topImage {
		padding: 0;
	}

	.topImage__ {
		width: auto;
		padding: 0 5px;
	}

	.topImage__title {
		padding: 24px 0 0;
		font-size: 13px;
	}

	.slogan{
		padding: 5px;
		right: 5px;
	}

	.slogan__title {
		font-size: 11px;
	}

	.contents {
		width: auto;
		padding: 30px 5px;
	}

	.articlePart {
		float: none;
		width: auto;
		margin: 0 0 10px;
	}

	.articlePart:nth-child(3n+1) {
		margin: 0 0 10px;
	}

	.sideContents,
	.mainContents {
		width: auto;
		float: none;
	}

	.sideContents {
		display: none;
	}

	.articleNews {
		margin: 0 0 10px;
	}

	.articleBase__title,
	.articleNews__title {
		font-size: 13px;
	}

	.articleNews__body {
		padding: 5px 10px;
	}

	.articleBase__body,
	.articleCompany__body {
		padding: 5px 10px;
	}

	.articleTable tr {
		display: block;
		width: 100%;
	}

	.articleTable th {
		display: block;
		text-align: left;
		padding: 0;
		border: none;
		font-weight: bold;
	}

	.articleTable td {
		display: block;
		text-align: left;
		background: transparent;
		padding: 5px;
		border: none;
		margin: 0 0 10px;
	}

	.articleThumbBg__list {
		width: 50%;
		height: 120px;
	}

	.newsInfo .articleNewsInfo {
		border: 1px solid #DDD;
		margin: 0 0 20px;
		box-shadow: 2px 2px rgba(0,0,0,0.05);
	}

	.newsInfo .articleNewsInfo__body {
		padding: 20px;
		font-size: 13px;
		background: rgba(255,255,255,1);
	}

	.newsInfo .articleNewsInfo__body p {
		font-size: 12px;
	}

	.newsInfo .articleNewsInfo__body ol {
		font-size: 13px;
	}

	.newsInfo .articleNewsInfo__body ol li {
	}

	.newsInfo .articleNewsInfo__body table.articleTable th,
	.newsInfo .articleNewsInfo__body table.articleTable td {
		font-size: 13px;
	}

	.newsInfo .articleNewsInfo__body table.articleTable th {
		width: auto;
	}

	.newsInfo p.articleNewsInfo__auth {
		text-align: right;
		font-size: 10px;
	}

	.newsInfo .articleNewsInfo__title {
		text-align: left;
		font-size: 14px;
	}

	.newsInfo .articleNewsInfo__title--lv2 {
		font-size: 13px;
	}


	.footer__ {
		width: auto;
	}

	.footer__logo a {
		font-size: 14px;
	}

	.footerNav__list {
		border-bottom: 1px solid #CCC;
	}

	.footerNav__list__item {
		width: 50%;
		border-top: 1px solid #CCC;
		border-bottom: 1px solid #CCC;
		margin: 0 0 -1px;
	}

	.footerNav__list__item:nth-child(2n+1) {
		border-right: 1px solid #CCC;
	}

	.footerNav__list__item a {
		padding: 10px;
		border-right: none;
		position: relative;
	}

	.footerNav__list__item a:after {
		content: "";
		position: absolute;
		right: 5px;
		top: 50%;
		transform: translateY(-50%);
		width: 0;
		height: 0;
		border-top: 5px solid transparent;
		border-right: 5px solid transparent;
		border-bottom: 5px solid transparent;
		border-left: 5px solid #fff;

	}

	.siteCopy__text {
		width: auto;
		text-align: left;
		padding: 0 10px;
	}

}

/* iPhone横(landscape) */
@media only screen and (max-width:480px)	{}

/* smartphone縦(portrait) */
@media only screen and (max-width:360px)	{}

/* iPhone縦(portrait) */
@media only screen and (max-width:320px)	{}

/* viewportの仕様上、指定可能な最小幅 */
@media only screen and (max-width:200px)	{}

/* ================================================================================ */
/*                                                                                  */
/*      デザインテーマ                                                              */
/*                                                                                  */
/* ================================================================================ */






