@charset "UTF-8";
/* CSS Document */

/*==============================
		 mainimage設定
==============================*/



#contents {
  margin: 0 0 10px;
	padding-top:100px;
}


 .mainimg {
	 background-image:url(./img/title_pc.jpg);
	 background-position: right;
	 width: 100%;
	 background-size: cover;
	 height:348px;
	 position: relative;
	 margin-bottom:80px;
 }


.mainimg p {
	color:#4d4d4d;
	font-size:24px;
	position: absolute;
	top:40%;
	left:80px;
}

.mainimg span {
	font-size:60px;
	font-family: 'Josefin Sans', sans-serif;
    font-style: italic;
	color: #3b0056;
	margin-right:16px;
}

/*-----メインコピー-----*/

#contents .copy h2{
	text-align: center;
	font-weight: bold;
}


/*ごあいさつ*/

#main_area {
	width: 980px;
	margin: 80px auto 0;
	display:flex;
	justify-content:space-between;
	flex-direction: row-reverse;
}

.message_box p{
	margin: 0 100px 0 0;
	line-height: 28px;
	overflow: hidden;
	min-height: 400px;
	position: relative;
}

.message_box p>span {
	position: absolute;
	bottom: 130;
	right: 0;
}

.message_box p span span.ceo_name {
	margin: 0 0 0 10px;
}

.title {
	margin-bottom: 40px;
	font-size: 12px;
	text-align: center;
	font-weight: bold;
}
.title span {
	display: block;
	font-size: 22px;
	color: #3b0056;
	font-style: normal;
}

.prof_list li {
	display: flex;
	padding: 0 0 15px 0;
	margin: 0 0 15px 0;
	border-bottom: 1px dotted #898989;
}
.prof_list li p{
	margin:  0 0 0 15px;
}

.bd_box {
	width: 980px;
	height: 20px;
	margin: 0 auto;
	position: relative;
}

.bd_box #breadcrumb{
	position:absolute;
	right: -140px;
	bottom: 90px;
}

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

#contents .info {
	background: #F2F2F2;
	padding: 60px 0;
}

#contents .info ul{
	margin-bottom: 40px;
}

#contents .info ul li .news_box{
	justify-content: left;
	margin-bottom: 20px;
	padding-bottom: 20px;
	border-bottom: 1px dotted #858585;
}

#contents .info ul li .news_box .date{
	flex:0 0 10%;
	-ms-flex:0 0 10%;
}

#contents .info ul li .news_box .txt{
	flex:0 0 80%;
	-ms-flex:0 0 80%;
	margin:0 2%;
}

#contents .info ul li .news_box .btn_more{
	flex:0 0 6%;
	-ms-flex:0 0 6%;
	font-weight: bold;
}

#contents .info ul li .news_box .btn_more:hover{
	color: #3b0056;
}

#contents .info ul li .news_box .btn_more:after{
	font-family: "Font Awesome\ 5 Free";
	content: "\f105";
    padding-left: 10px;
    line-height: 1.5em;
}


/* ステート設定
   ========================================================================== */
.stateBox {
  padding: 10px;
  margin-bottom: 10px; }
  .stateBox p {
    padding: 5px 0;
    color: #333;
    text-align: center;
    border-width: 2px;
    border-style: solid;
    border-color: #ccc; }
    .stateBox p.green {
      color: #fff;
      border-color: #9FC569;
      background-color: #9FC569; }
    .stateBox p.red {
      color: #fff;
      border-color: #ED7A53;
      border-color: #d9534f;
      background-color: #ED7A53;
      background-color: #d9534f; }

/* フォーム設定
   ========================================================================== */
#contact {
  margin-bottom: 30px;
	width: 100%;}
  #contact h2 {
    border-bottom: 2px solid #000; }

#form {
  display: table;
  width: 100%;
	margin: 0 auto;
  font-size: 14px;
  text-align: left;
  /*border: 1px solid #ccc;*/
  border-bottom: none; }
  #form .group {
    display: table-row;
    padding: 15px 12px; }
	#form .group:nth-child(odd){
		background: #f2f2f2;}
    #form .group:after {
      content: ".";
      display: block;
      height: 0;
      font-size: 0;
      clear: both;
      visibility: hidden; }
    #form .group .gLeft {
      display: table-cell;
      width: 34%;
      padding:100px 20px;
			font-size: 13px;
      vertical-align: top;
      /*background-color: #fafafa;*/
      /*border-right: 1px solid #ccc;*/
      /*border-bottom: 1px solid #ccc; */}
		#form .group .gLeft p{
			border-left: 4px solid #3b0056;
			padding-left: 10px;
			font-weight: bold;
			font-size: 16px;
		}
		#form .group .gLeft p span{
			margin-left: 10px;
		}
    #form .group .gRight {
      display: table-cell;
      padding: 10px;
      vertical-align: top;
      /*border-right: 1px solid #ccc;*/
      /*border-bottom: 1px solid #ccc;*/ }
			#form .group .gRight p{
				padding: 30px 20px;
			}
		#form .group .gRight label {
			display: inline-block;
			width: 160px;
			margin:50px 20px 0 0;
		}
		#form .group .gRight label input {

		}
    #form .group .gCenter {
      display: block;
      width: 100%;
      float: none;
      margin-bottom: 10px;
      font-weight: bold; }
  #form .typeBox {
    color: #555;
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 4px;
    box-shadow: 0 0 2px 1px rgba(0, 0, 0, 0.075) inset;
    display: block;
    font-size: 14px;
    width: 100%;
    *width: 280px;
    /*height: 34px;*/
		height: 60px;
    *height: auto;
    line-height: 1.42857;
    *line-height: 1;
    padding: 6px 10px;
    box-sizing: border-box;
    -moz-box-sizing: border-box; }
    #form .typeBox:focus {
      border-color: #66afe9;
      outline: 0;
      -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 8px rgba(102, 175, 233, 0.6);
      box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 8px rgba(102, 175, 233, 0.6); }
	#form input[type="text"],
	#form input[type="mail"],
	#form input[type="num"]{
		margin: 75px 0 0;
	}
#form input#zip{
	height: 20px;
	margin-bottom: 10px;
}
	#form input#zip+input {
		margin: 0;
	}
  #form textarea.typeBox {
		min-height: 220px;
		 }
  #form .notes {
    /*border-radius: 0.25em;*/
    color: #fff;
    display: inline;
    font-size: 75%;
    /*font-weight: 700;*/
    line-height: 1;
    padding: 0.4em 0.6em;
    text-align: center;
    vertical-align: baseline;
    white-space: nowrap; }
  #form .nRed {
    background-color: #bb0d23; }
  #form .nGray {
    background-color: #777; }
  #form .help {
    color: #737373;
    padding-top: 5px;
    margin: 0; }
  #form .floatBox {
    float: left;
    *float: none;
    padding: 0 30px 10px 0; }
  #form .error {
    background-color: #FFEEEE!important; }
#form + p{
	text-align: center;
}
/* ボタン設定
   ========================================================================== */
.btnBox {
  text-align: center;
  padding: 20px 0 10px; }
  .btnBox .comment {
    margin: 10px 0; }
  .btnBox a {
    text-decoration: none; }
  .btnBox .rBtn {
    background: #bb0d23;
    color: #FFF;
    border: 2px solid #bb0d23;
    /*border-radius: 4px;*/
		font-weight: normal!important;
		font-size: 16px!important;
    cursor: pointer;
    display: inline-block;
    font-size: 16px;
    font-weight: bold;
    letter-spacing: 0.2em;
    padding: 15px 80px;
    text-align: center;
    vertical-align: middle;
    margin: 0 5px; }
		.btnBox .rBtn:hover {
      background: #fff;
      color: #bb0d23; }
    .btnBox .rBtn.active {
      background: #000;
      color: #fff; }
  .btnBox .gBtn {
    background: #FFF;
    color: #666;
    border: 2px solid #CCC;
    border-radius: 4px;
    cursor: pointer;
    display: inline-block;
    font-size: 16px;
    letter-spacing: 0.2em;
    padding: 6px 15px;
    text-align: center;
    vertical-align: middle;
    margin: 0 5px; }

.btnBox div {
	margin: 10px auto;
}
button {
	position: relative;
}

button i {
	position:absolute;
	right: 5px;
	bottom: 19px;
}
/* プライバシーポリシー設定
   ========================================================================== */
.privacy {
	width: 80%;
  height: 200px;
  padding: 20px;
	margin: 30px auto 10px;
  background-color: #fff;
  border: 1px solid #999;
  overflow: scroll; }
  .privacy h3 {
    font-size: 24px;
    text-align: center; }
  .privacy p {
    margin-bottom: 20px; }
  .privacy dl {
    margin-bottom: 20px; }
    .privacy dl dt {
      font-weight: 600;
      margin-bottom: 5px; }
    .privacy dl dd {
      padding-left: 20px;
      margin-bottom: 10px; }

/* 完了画面設定
   ========================================================================== */
.competionBox {
	width: 960px;
  margin: 20px auto; }
  .competionBox p {
    margin: 15px 0;
    text-align: left; }
  .competionBox .image {
    text-align: center; }
  .competionBox .subject {
    padding: 15px 0;
    text-align: center;
    border: 2px solid #ccc; }

/*///////////////////////////////////////////////////////
	home.css
	
	Author　mukai
	Date　2015.08.26
///////////////////////////////////////////////////////*/
/*css設定の読み込み
------------------------------*/
/*///////////////////////////////////////////////////////
	config.css
	
	Author　mukai
	Date　2015.08.26
	
///////////////////////////////////////////////////////*/
/*ブレイクポイントの設定
------------------------------*/
/*スマホ縦*/
/*タブレット縦*/
/*デスクトップ縦*/
/*カラー設定
------------------------------*/
/*汎用カラー*/
/*スマホの設定
------------------------------*/
@media (max-width: 992px) {
  #container .concept p {
    font-size: 16px; } }
/*///////////////////////////////////////////////////////
	home.css
	
	Author　mukai
	Date　2015.08.26
///////////////////////////////////////////////////////*/
/*css設定の読み込み
------------------------------*/
/*///////////////////////////////////////////////////////
	config.css
	
	Author　mukai
	Date　2015.08.26
	
///////////////////////////////////////////////////////*/
/*ブレイクポイントの設定
------------------------------*/
/*スマホ縦*/
/*タブレット縦*/
/*デスクトップ縦*/
/*カラー設定
------------------------------*/
/*汎用カラー*/
/*スマホの設定
------------------------------*/
@media (max-width: 768px) {
  .news {
    height: 260px !important; }

  .company {
    height: 280px; }

  .access {
    height: 260px !important; }
    .access .map {
      display: none; }
      .access .map #map_canvas {
        float: none;
        width: 100%;
        height: 100px; }
    .access address {
      float: none;
      width: 100%; } }





/*==============================
		tablet設定
==============================*/

@media screen and (max-width:960px) {
	#contents .info ul li .news_box .txt{
		flex:0 0 77%;
		-ms-flex:0 0 77%;
	}
	
	#contents .point {
		margin-bottom: 120px;
	}
	
	#contents .point #line{
		display: none;
	}

	#contents .point #circle{
		display: none;
	}
	#contents .point .point_box {
		margin-bottom: 60px;
	}
	#contents .point .point_box:first-child {
		padding-top: 80px;
	}
}

@media screen and (min-width:640px) and ( max-width:960px) {
	.message_box {
		width: 100%;
		margin: 80px auto 0;
		display:block;
		justify-content:space-between;
	}
	.bd_box {
		width: 100%;
		height: 20px;
		margin: 0 auto;
		position: relative;
	}
	.bd_box #breadcrumb{
		position:absolute;
		right:  10px;
		bottom: 90px;
	}
}

/*==============================
		SP設定
==============================*/

@media screen and (max-width:640px){
	#movie{
		background: url(/img/home/nonemovie_sp.jpg) no-repeat center / cover;
		height: 250px;
	}
	.mainimg video{
		display: none;
	}
	/*-----ポイント-----*/
	#contents .point .point_box{
		display:block;
		margin-bottom: 60px;
	}
	#contents .point .point_box .img_box{
		margin-bottom: 20px;
	}
	/*-----メインコンテンツ-----*/
	#contents .main ul{
		display: block;
	}
	
	#contents .main ul li{
		margin-bottom: 15px;
	}
	/*-----お知らせ-----*/
	#contents .info ul li .news_box{
		display: block;
	}
	#contents .info ul li .news_box .txt{
		margin: 0;
	}
	#contents .info ul li .news_box .btn_more {
		text-align: right;
		display: inherit;
	}
	
	#contents .copy h2{
		font-size: 18px;
	}
	
	#contents {
		padding: 100px 10px 0 10px;
	}
	
	
	#main_area {
		width: 100%;
		margin: 80px auto 0;
		display:flex;
		justify-content:space-between;
		flex-direction: row-reverse;
	}
	
	.mainimg {
	 background-image:url(./img/title_sp.jpg);
	 width: 100%;
	 height:120px;
	 background-size: cover;
	 position: relative;
	 margin-bottom:20px;
 }
	.mainimg>p {
		display: none;
	}
	.message_box {
		width: 100%;
		margin: 80px auto 0;
		display:block;
		justify-content:space-between;
	}
	.message_box p{
		margin: 20px auto 0;
		line-height: 28px;
		overflow:auto;
		min-height: 400px;
		position: relative;
	}

	.message_box p>span {
		position: absolute;
		bottom: 130;
		right: 0;
	}
	.prof_list li p{
		margin:  0 0 0 15px;
	}
	.bd_box {
		width: 100%;
		height: 20px;
		margin: 0 auto;
		position: relative;
	}
	.bd_box #breadcrumb{
		position:absolute;
		right:  10px;
		bottom: 0;
	}
	
	/* ステート設定
   ========================================================================== */
.stateBox {
  padding: 10px;
  margin-bottom: 10px; }
  .stateBox p {
    padding: 5px 0;
    color: #333;
    text-align: center;
    border-width: 2px;
    border-style: solid;
    border-color: #ccc; }
    .stateBox p.green {
      color: #fff;
      border-color: #9FC569;
      background-color: #9FC569; }
    .stateBox p.red {
      color: #fff;
      border-color: #ED7A53;
      border-color: #d9534f;
      background-color: #ED7A53;
      background-color: #d9534f; }

/* フォーム設定
   ========================================================================== */
#contact {
  margin-bottom: 30px; }
  #contact h2 {
    border-bottom: 2px solid #000; }
	#contact p {
    font-size: 12px;}

#form {
  width: 100%;
	margin: 0 auto;
  font-size: 14px;
  text-align: left;
  /*border: 1px solid #ccc;*/
  border-bottom: none; }
  #form .group {
    padding: 15px 12px; }
    #form .group:after {
      content: ".";
      display: block;
      height: 0;
      font-size: 0;
      clear: both;
      visibility: hidden; }
    #form .group .gLeft {
      display:inline-block;
      width: 95%;
      padding: 10px;
      font-weight: bold;
      vertical-align: top;
      background:none;
      /*border-right: 1px solid #ccc;*/
      border-bottom:none; }
    #form .group .gRight {
			width: 95%;
      display: inline-block;
      padding: 10px;
      vertical-align: top;
      /*border-right: 1px solid #ccc;*/
      border-bottom:none;}
    #form .group .gCenter {
      display: block;
      width: 100%;
      float: none;
      margin-bottom: 10px;
      font-weight: bold; }
	#form input[type="text"],
	#form input[type="mail"],
	#form input[type="num"]{
		margin: 10px 0 0;
	}
	#form .group .gRight label {
		display: inline-block;
		width: 200px;
		margin:15px 20px 0 0;
	}
  #form .typeBox {
    color: #555;
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 4px;
    box-shadow: 0 0 2px 1px rgba(0, 0, 0, 0.075) inset;
    display: block;
    font-size: 14px;
    width: 100%;
    *width: 280px;
    height: 34px;
    *height: auto;
    line-height: 1.42857;
    *line-height: 1;
    padding: 10px;
    box-sizing: border-box;
    -moz-box-sizing: border-box; }
    #form .typeBox:focus {
      border-color: #66afe9;
      outline: 0;
      -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 8px rgba(102, 175, 233, 0.6);
      box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 8px rgba(102, 175, 233, 0.6); }
  #form textarea.typeBox {
    height: auto; }
  #form .notes {
    border-radius: 0.25em;
    color: #fff;
    display: inline;
    font-size: 75%;
    font-weight: 700;
    line-height: 1;
    padding: 0.2em 0.6em;
    text-align: center;
    vertical-align: baseline;
    white-space: nowrap; }
  #form .nRed {
    background-color: #d9534f; }
  #form .nGray {
    background-color: #777; }
  #form .help {
    color: #737373;
    padding-top: 5px;
    margin: 0; }
  #form .floatBox {
    float: left;
    *float: none;
    padding: 0 30px 10px 0; }
  #form .error {
    background-color: #FFEEEE; }

/* ボタン設定
   ========================================================================== */
.btnBox {
	display: flex;
	flex-direction:column-reverse;
  text-align: center;
  padding: 20px 0 10px; }
  .btnBox .comment {
    margin: 10px 0; }
  .btnBox a {
    text-decoration: none; }
  .btnBox .rBtn {
    color: #FFF;
    cursor: pointer;
    display: inline-block;
    font-size: 16px;
    font-weight: bold;
    letter-spacing: 0.2em;
    text-align: center;
    vertical-align: middle;
    margin: 0 5px 20px; }
		.btnBox .rBtn:hover {
      background: #fff;
      color: #2a274d; }
    .btnBox .rBtn.active {
      background: #000;
      color: #fff; }
  .btnBox .gBtn {
    background: #FFF;
    color: #666;
    border: 2px solid #CCC;
    border-radius: 4px;
    cursor: pointer;
    display: inline-block;
    font-size: 16px;
    letter-spacing: 0.2em;
    padding: 6px 15px;
    text-align: center;
    vertical-align: middle;
    margin: 0 5px; }
.btnBox div {
	margin: 10px auto;
}
/* プライバシーポリシー設定
   ========================================================================== */
.privacy {
	width: 80%;
  height: 200px;
  padding: 20px;
	margin: 30px auto 10px;
  background-color: #fff;
  border: 1px solid #999;
  overflow: scroll; }
  .privacy h3 {
    font-size: 24px;
    text-align: center; }
  .privacy p {
    margin-bottom: 20px; }
  .privacy dl {
    margin-bottom: 20px; }
    .privacy dl dt {
      font-weight: 600;
      margin-bottom: 5px; }
    .privacy dl dd {
      padding-left: 20px;
      margin-bottom: 10px; }

/* 完了画面設定
   ========================================================================== */
.competionBox {
	width: 100%;
  margin: 20px auto; }
  .competionBox p {
    margin: 15px 0;
    text-align: left; }
  .competionBox .image {
    text-align: center; }
  .competionBox .subject {
    padding: 15px 0;
    text-align: center;
    border: 2px solid #ccc; }

/*///////////////////////////////////////////////////////
	home.css
	
	Author　mukai
	Date　2015.08.26
///////////////////////////////////////////////////////*/
/*css設定の読み込み
------------------------------*/
/*///////////////////////////////////////////////////////
	config.css
	
	Author　mukai
	Date　2015.08.26
	
///////////////////////////////////////////////////////*/
/*ブレイクポイントの設定
------------------------------*/
/*スマホ縦*/
/*タブレット縦*/
/*デスクトップ縦*/
/*カラー設定
------------------------------*/
/*汎用カラー*/
/*スマホの設定
------------------------------*/
@media (max-width: 992px) {
  #container .concept p {
    font-size: 16px; } }
/*///////////////////////////////////////////////////////
	home.css
	
	Author　mukai
	Date　2015.08.26
///////////////////////////////////////////////////////*/
/*css設定の読み込み
------------------------------*/
/*///////////////////////////////////////////////////////
	config.css
	
	Author　mukai
	Date　2015.08.26
	
///////////////////////////////////////////////////////*/
/*ブレイクポイントの設定
------------------------------*/
/*スマホ縦*/
/*タブレット縦*/
/*デスクトップ縦*/
/*カラー設定
------------------------------*/
/*汎用カラー*/
/*スマホの設定
------------------------------*/
@media (max-width: 768px) {
  .news {
    height: 260px !important; }

  .company {
    height: 100px; }

  .access {
    height: 260px !important; }
    .access .map {
      display: none; }
      .access .map #map_canvas {
        float: none;
        width: 100%;
        height: 100px; }
    .access address {
      float: none;
      width: 100%; } }

}


