/*!
 * Start Bootstrap - Business Casual Bootstrap Theme (http://startbootstrap.com)
 * Code licensed under the Apache License v2.0.
 * For details, see http://www.apache.org/licenses/LICENSE-2.0.
 */

html{overflow-y:scroll;}body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,textarea,p,blockquote,{margin:0;padding:0;font-size: 62.5%;}address,caption,cite,code,dfn,em,strong,th,var{font-style:normal;}table{border-collapse:collapse;border-spacing:0;}caption,th{text-align:left;}q:before,q:after{content:'';}object,embed{vertical-align:top;}legend{display:none;}h1,h2,h3,h4,h5,h6{font-size:100%;}img,abbr,acronym,fieldset{border:0;}ul li{list-style-type:none;}a,label{cursor:pointer;}img{vertical-align:bottom;margin:0;padding:0;}
/*----------------------------------------------------
	BODY
----------------------------------------------------*/
* {
		margin: 0;
		padding: 0px;
	}
body {
	font-family: "HelveticaNeueW01-45Ligh", "Noto Sans Japanese", "Noto Sans SC", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	background-color: white;
	color: black;
	text-align: justify;
	font-size: 1.6rem;

}

h1,
h2,
h3,
h4,
h5,
h6 {
	margin: 0;
}

p {
	margin: 5px 0;
	font-size: 1.6rem;
	letter-spacing: 0;
	line-height: 3.5rem;
}

hr {
	border-color: #c9c9c9;
	margin: 20px 0 ;
}

li {
left:0;
list-style-type: none;
}

a:hover img {
	filter: alpha(opacity=50);
	-moz-opacity: 0.50;
	opacity: 0.50;
	-webkit-transition-duration: 100ms;
	-webkit-transition-property: opacity;
	-webkit-transition-timing-function: linear;
	-moz-transition-duration: 100ms;
	-moz-transition-property: -moz-opacity;
	-moz-transition-timing-function: linear;
	-o-transition-duration: 100ms;
	-o-transition-property: -o-opacity;
	-o-transition-timing-function: linear;
}


.xs { font-size: xx-small } /* 小2 */
.xm { font-size: x-small }  /* 小1 */
.sm { font-size: small }    /* 小 */
.md { font-size: medium }   /* 標準 */
.la { font-size: 2.5rem; font-weight: bold; line-height: 1.2em; letter-spacing: 0;}    /* 大 */
.xr { font-size: 3.0rem; font-weight: bold; line-height: 1.2em; letter-spacing: 0;}  /* 大1 */
.sr { font-size: smaller }  /* 一段階小さい */
.red { color:#FF0004; }
.blue{color:#092f55;}
.white{color:#FFF;}
.em{font-weight: bold;}
.mt30{margin-top: 30px;}
.mb5{margin-bottom: 5px;}
.mb10{margin-bottom: 10px;}
.mb20{margin-bottom: 20px;}
.mt60{margin-top: 60px;}
.mb40{margin-bottom: 40px;}
.mb60{margin-bottom: 60px;}
.gray{color: #888;}


/*----------------------------------------------------
    .TOP BOX
----------------------------------------------------*/
/*追記20200615*/

.box26 {
    position: relative;
    margin: 0.5em 0 2em 0;
    padding: 1.5em 1em;
    border: solid 3px #000;
    border-radius: 8px;
}
.box26 .box-title {
    position: absolute;
    display: inline-block;
    top: -13px;
    left: 10px;
    padding: 0 9px;
    line-height: 1;
    font-size: 19px;
    background: #FFF;
    color: #000;
    font-weight: bold;
}
.box26 p {
    margin: 0;
    padding: 0;
}
.box_title h3{
	font-size: 18px;
	text-align: center;
	padding: 0.5em 0;
	background-color: #0d4278;
	color: #FFF;
}
.box_title h4{
	font-size: 14px;
	text-align: center;
	padding: 0.5em 0;
	background-color: #0d4278;
	color: #FFF;
}

/* 点滅 */
.blinking{
	-webkit-animation:blink 0.5s ease-in-out infinite alternate;
    -moz-animation:blink 0.5s ease-in-out infinite alternate;
    animation:blink 0.5s ease-in-out infinite alternate;
}
@-webkit-keyframes blink{
    0% {opacity:0;}
    100% {opacity:1;}
}
@-moz-keyframes blink{
    0% {opacity:0;}
    100% {opacity:1;}
}
@keyframes blink{
    0% {opacity:0;}
    100% {opacity:1;}
}


/*----------------------------------------------------
    .navigation
----------------------------------------------------*/

.brand,
.address-bar {
	display: none;
}
.navbar {
	margin-bottom: 0;
}
.navbar-brand {
	text-transform: uppercase;
	font-weight: 900;
	letter-spacing: 2px;
}
.navbar-nav {
	text-transform: uppercase;
	font-weight: 400;
	letter-spacing: 3px;
}


/*----------------------------------------------------
    .demo01
----------------------------------------------------*/

section table   { width: 100%; }
section th, section td  { padding: 15px; border: 1px solid #ddd; }
section th  { background: #f4f4f4; }
.demo01 th  { width: 30%; text-align: left; background-color: #f9f9f9;}

@media only screen and (max-width:767px){
    .demo01 { margin: 0 0px; }
    .demo01 th,
    .demo01 td{
        width: 100%;
        display: block;
        border-top: none;
    }
    .demo01 tr:first-child th   { border-top: 1px solid #ddd; }
}

.about_container{
	padding: 0 15px;
	width: 100%;
}
.waku
{ border-top: 1px solid #ddd; }
/*----------------------------------------------------
   Common　min-width:768px
----------------------------------------------------*/

@media screen and (min-width:768px) {

	.sp{
		display: none;
	}

	.container3{
		margin: 0 auto;
		width: 1500px;
	}

	.brand {
		display: inherit;
		margin: 0;
		padding: 10px 0;
		text-align: center;
		background-color: #092f55;
		height: 100px;
	}
	.brand ul li{
		float: left;
		padding: 0 20px;
	}

	.top-divider {
		margin-top: 0;
	}
	.navbar {
		border-radius: 0;
		padding-bottom: 5px;
	}
	.navbar-header {
		display: none;
	}
	.navbar {
		min-height: 0;

	}
	.navbar-default {
		border: none;
		background: linear-gradient(#0A2E55, #0C4176);

	}
	.nav>li>a {
		padding: 10px 20px;
		font-size: 14px;
		 font-family: 'Montserrat', sans-serif;
		 font-weight: 700;
		 letter-spacing: 0;
		 text-align: center;
	}
	.navbar-default .navbar-nav > li > a {
		color: #FFF;
	}
	.navbar-default .navbar-nav > li > a:hover,
	.navbar-default .navbar-nav > li > a:focus {
		color: #555;

	}
	.navbar-default .navbar-nav > .active > a,
	.navbar-default .navbar-nav > .active > a:hover,
	.navbar-default .navbar-nav > .active > a:focus {
		color: #FFF;
		background-color: transparent;
	}
	.navbar-nav>li>a {
		line-height: normal;
	}
	.navbar-nav {
		display: table;
		float: none;
		margin: 0 auto;
		table-layout: fixed;
		font-size: 1.25em;
		color: black;
	}

}

/*----------------------------------------------------
    COMMON
----------------------------------------------------*/
.bar_white{
	background-color: #FFF;
	padding: 0 3px;
	color: #555
}

.bg_gray{
	background-color: #ececec;
	padding: 15px 30px;
	margin: 30px 0;
}

.bg_gray a{
	color: #333;
	text-decoration: underline;
}

.bg_lightgray{
	background-color: #F4F4F4;
	padding: 30px 0;
	margin: 30px 0;
	}

.bg_blue{
	background-color: #092f55;
	color: #FFF;
	padding: 10px 15px;
	font-size: 24px;
	text-align: center;
}


.title_bar_blue{
	padding: 30px 0 15px 0;
	margin-top: 30px;
}

.title_bar_blue h2{
	color: #000;
	font-size: 30px;
	font-weight: bold;
	margin-bottom: 30px;

	padding: 0.25em 0.5em;/*上下 左右の余白*/
	background: transparent;/*背景透明に*/
	border-left: solid 5px #092f55;/*左線*/

}



.title_bar_green{
	background-color: #accc42;
	color: #FFFFFF;
	padding: 10px 15px 10px 15px;
	margin-bottom: 30px;
	border-radius: 10px;
	text-align: center;
}

.narabi ul{
	padding: 0 15px 0 0;
}

.narabi li{
	float: left;
	padding: 0 5px 5px 0 ;
}
.mt30{
		margin-top: 30px;
	}
@media(max-width:767px) {
.bg_gray{
	padding: 15px 15px;
	font-size: 10px;
	}
.title_bar_blue{
	margin-bottom: 15px;
	}
}

.video-wrap {
  position: relative;
  margin-top: 1.2em;
  margin-bottom: 1.2em;
  padding-top: 69px;
  padding-bottom: 50%;
  overflow: hidden;
}
.video-wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
}

/*----------------------------------------------------
    TOP NEWS
----------------------------------------------------*/
.news{
	margin-top: 30px;
}
.news h2{
	font-size: 2.4rem;
	color: #092f55;
}
  @media(max-width:767px) {
 	  .mm{
 	min-height: 40px;
 	}
 	.top_news h2 {
	font-size: 16px;
	}
}

/*----------------------------------------------------
    NEWS 下層
----------------------------------------------------*/
#news h2 {
	font-size: 24px;
	font-weight: bold;
	color: #092f55;
 }
#news h3 {
	font-size: 18px;
 }
#news a:hover, a:focus {
	text-decoration: underline;
 }
 .tate{
 	border-left: 2px #ddd;
 	height: 50px;
 }
 .waku{
 	padding: 15px 15px;
 	border-bottom: solid 1px #ddd ;
 	border-right: solid 1px #ddd;
 	border-left: solid 1px #ddd;
 }
   .waku_white{
  	background-color: #fdfdfd;
 	padding: 15px 15px;
 	border-bottom: solid 1px #ddd ;
 	border-right: solid 1px #ddd;
 	border-left: solid 1px #ddd;
 }
  .waku_green{
  	background-color: #f2fbfc;
 	padding: 15px 15px;
 	border-bottom: solid 1px #ddd ;
 	border-right: solid 1px #ddd;
 	border-left: solid 1px #ddd;
 }
  .waku_red{
  	background-color: #fef7f6;
 	padding: 15px 15px;
 	border-bottom: solid 1px #ddd ;
 	border-right: solid 1px #ddd;
 	border-left: solid 1px #ddd;
 }
 .title{
	background-color: #092f55;
	color: #FFFFFF;
	padding: 10px 15px 10px 15px;
}
 .title_green{
	background-color: #35be82;
	color: #FFFFFF;
	padding: 10px 15px 10px 15px;
}
 .title_red{
	background-color: #e9614b;
	color: #FFFFFF;
	padding: 10px 15px 10px 15px;
}

.clearleft{
	clear: left;
}

  @media(max-width:767px) {
 	  .mm{
 	min-height: 40px;
 	}
 	#news h2 {
	font-size: 16px;
	}
}

/*----------------------------------------------------
	ABOUT
----------------------------------------------------*/
 #about {
 	margin:0;
 	background-image: url(../../assets/img/header01.jpg);
 	background-repeat: no-repeat;
 	background-size: cover;
 	padding: 100px; 0;
 	background-position:top;
 	 }
 #about h2 {
 	font-size: 48px;
 	font-weight: bold;
 	line-height: 1.2em;
 	letter-spacing: 0;
 	color: #FFFFFF;
 }
  #about p {
 	font-size: 14px;
 	line-height: 1.2em;
 	letter-spacing: 0;
 	color: #FFFFFF;
 }
/*----------------------------------------------------
	PHILOSOPHY
----------------------------------------------------*/
  #philosophy {
 	margin:0;
 	background-image: url(../../assets/img/header01.jpg);
 	background-repeat: no-repeat;
 	background-size: cover;
 	padding: 100px; 0;
 	background-position:top;
 	 }
  #philosophy h2 {
 	font-size: 48px;
 	font-weight: bold;
 	line-height: 1.2em;
 	letter-spacing: 0;
 	color: #FFFFFF;
 }
   #philosophy p {
 	font-size: 14px;
 	line-height: 1.2em;
 	letter-spacing: 0;
 	color: #FFFFFF;
 }
 .emc a{
 	color: red;
 	font-size: 36px;
 }
 @media(max-width:767px) {
 	  #philosophy h2 {
 	font-size: 30px;
	}
}

/*------------------------------------------------
	History
------------------------------------------------*/
.timeline {
	list-style: none;
	padding: 20px 0 0;
	position: relative;
	margin-bottom: 10px;
}

.timeline:before {
	top: 0;
	bottom: 0;
	position: absolute;
	content: " ";
	width: 1px;
	background-color: #eeeeee;
	left: 50%;
	margin-left: -1.5px;
}



.timeline p {
	color: #0d0d0d;
}
/*追記*/

.timeline > li {
	margin-bottom: 40px;
	position: relative;
}

.timeline > li:before,
.timeline > li:after {
	content: " ";
	display: table;
}

.timeline > li:after {
	clear: both;
}

.timeline > li:before,
.timeline > li:after {
	content: " ";
	display: table;
}

.timeline > li:after {
	clear: both;
}

.timeline > li > .timeline-panel {
	width: 46%;
	float: left;
	/*
	border: 1px solid #d4d4d4;
	border-radius: 2px;
	*/
	padding: 0 20px 20px 20px;
	position: relative;
	/*
	-webkit-box-shadow: 0 1px 6px rgba(0, 0, 0, 0.175);
	box-shadow: 0 1px 6px rgba(0, 0, 0, 0.175);
	*/

	/*追記*/
	text-align: right;
	/*追記*/
}

.timeline > li > .timeline-panel:before {
	position: absolute;
	top: 26px;
	right: -15px;
	display: inline-block;
	/*
	border-top: 15px solid transparent;
	border-left: 15px solid #ccc;
	border-right: 0 solid #ccc;
	border-bottom: 15px solid transparent;
	*/
	content: " ";
}

.timeline > li > .timeline-panel:after {
	position: absolute;
	top: 27px;
	right: -14px;
	display: inline-block;
	/*
	border-top: 14px solid transparent;
	border-left: 14px solid #fff;
	border-right: 0 solid #fff;
	border-bottom: 14px solid transparent;
	*/
	content: " ";
}

.timeline > li > .timeline-badge {
	color: #fff;
	width: 10px;
	height: 10px;
	line-height: 20px;
	font-size: 1.4em;
	text-align: center;
	position: absolute;
	top: 16px;
	left: 50%;
	margin-left: -7px;
	background-color: #092f55;
	z-index: 100;
	border-top-right-radius: 50%;
	border-top-left-radius: 50%;
	border-bottom-right-radius: 50%;
	border-bottom-left-radius: 50%;
}

/*追記*/
.timeline-photo {
	position: absolute;
	right: 30%;

}

.timeline > li.timeline-inverted > .timeline-photo {
	position: absolute;
	left: 30%;

}

.timeline-center-text {
	text-align: center;
}

.timeline-center {
	position: relative;
	width: 200px;
	margin-left: 470px;
	margin-top: -20px;
}



/*追記*/

.timeline > li.timeline-inverted > .timeline-panel {
	float: right;

	/*追記*/
	text-align: left;
	/*追記*/
}

.timeline > li.timeline-inverted > .timeline-panel:before {
	border-left-width: 0;
	border-right-width: 15px;
	left: -15px;
	right: auto;
}

.timeline > li.timeline-inverted > .timeline-panel:after {
	border-left-width: 0;
	border-right-width: 14px;
	left: -14px;
	right: auto;
}

.timeline-badge.primary {
	background-color: #2e6da4 !important;
}

.timeline-badge.success {
	background-color: #3f903f !important;
}

.timeline-badge.warning {
	background-color: #f0ad4e !important;
}

.timeline-badge.danger {
	background-color: #d9534f !important;
}

.timeline-badge.info {
	background-color: #5bc0de !important;
}

.timeline-title {
	margin-top: 0;
	color: inherit;
}

.timeline-body > p,
.timeline-body > ul {
	margin-bottom: 0;
}

.timeline-body > p + p {
	margin-top: 5px;
}





@media (max-width: 1200px) {
/*@media (max-width: 767px) {*/
	ul.timeline:before {
		left: 40px;
	}

	ul.timeline > li > .timeline-panel {
		width: calc(100% - 90px);
		width: -moz-calc(100% - 90px);
		width: -webkit-calc(100% - 90px);
	}

	ul.timeline > li > .timeline-badge {
		left: 29px;
		margin-left: 6px;
		top: 16px;
	}

	ul.timeline > li > .timeline-panel {
		float: right;
		/*追記*/
		text-align: left;
		/*追記*/
	}

	/*追記*/
	.timeline > li.timeline-inverted > .timeline-panel {
		float: right;
		text-align: left;
	}
	/*追記*/

	ul.timeline > li > .timeline-panel:before {
		border-left-width: 0;
		border-right-width: 15px;
		left: -15px;
		right: auto;
	}

	ul.timeline > li > .timeline-panel:after {
		border-left-width: 0;
		border-right-width: 14px;
		left: -14px;
		right: auto;
	}

	/*追記*/
	.timeline-photo,
	.timeline > li.timeline-inverted > .timeline-photo {
		display: block;
		position: relative;
		left: 0;
		top: 0;
		margin-left: 110px;
		padding-bottom: 20px;
	}

	.timeline-center-text {
		position: relative;
		text-align: left;

}

.timeline-center {
	position: relative;
	width: 80px;
	margin-left: 1px;
	margin-top: -20px;
}
}
/*----------------------------------------------------
	gallery
----------------------------------------------------*/
.gallery {
	min-height: 180px;
}

/*----------------------------------------------------
	SCHEDULE
----------------------------------------------------*/
 #schedule {
 	margin:0;
 	background-image: url(../../assets/img/header02.jpg);
 	background-repeat: no-repeat;
 	background-size: cover;
 	padding: 100px 0;
 	background-position:top;
 	 }
 #schedule h1 {
 	font-size: 48px;
 	font-weight: bold;
 	line-height: 1.2em;
 	letter-spacing: 0;
 	color: #FFFFFF;
 }
  #schedule p {
 	font-size: 18px;
 	line-height: 1.2em;
 	letter-spacing: 0;
 	color: #FFFFFF;
 }


.gc_wrapper {
  max-width: 1000px;
  min-width: 300px;
  margin: 2.0833% auto;
}

.responsive-iframe-container {
    position: relative;
    padding-bottom: 56.25%;
    padding-top: 30px;
    height: 0;
    overflow: hidden;
}
.responsive-iframe-container iframe,
.responsive-iframe-container object,
.responsive-iframe-container embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

@media (max-width: 767px) {
    .big-container {
        display: none;
    }

    .small-container {
       padding-bottom: 150%;   /* 高さ */
    }
}
@media (min-width: 768px) {
    .small-container {
        display: none;
    }
}

/*----------------------------------------------------
	QA
----------------------------------------------------*/
 #qa {
 	margin:0;
 	background-image: url(../../assets/img/header03.jpg);
 	background-repeat: no-repeat;
 	background-size: cover;
 	padding: 100px; 0;
 	background-position: top;
 	 }
 #qa h2 {
 	font-size: 48px;
 	font-weight: bold;
 	line-height: 1.2em;
 	letter-spacing: 0;
 	color: #FFFFFF;
 }
  #qa p {
 	font-size: 14px;
 	line-height: 1.2em;
 	letter-spacing: 0;
 	color: #FFFFFF;
 }

 .qa_q {
		font-size: 24px;
		color: #092f55;
		font-weight: bold;
		line-height: 1.5em;
	}
.qa_a {
		font-size: 24px;
		color: #eb8100;
		font-weight: bold;
	}
.bg_gray2{
	background-color: #ececec;
	padding: 15px 30px;
	margin: 30px 0;
}
/*----------------------------------------------------
	WORK
----------------------------------------------------*/
 #work {
 	margin:0;
 	background-image: url(../../assets/img/header04.jpg);
 	background-repeat: no-repeat;
 	background-size: cover;
 	padding: 100px 0;
 	background-position:top;
 	 }
 #work h2 {
 	font-size: 48px;
 	font-weight: bold;
 	line-height: 1.2em;
 	letter-spacing: 0;
 	color: #FFFFFF;
 }
  #work p {
 	font-size: 24px;
 	line-height: 1.2em;
 	letter-spacing: 0;
 	color: #FFFFFF;
 }

 .work_title{
 	background-color: #46c2f0;
 	color: #FFFFFF;
 	font-weight: bold;
 	padding: 5px 15px;
 	margin-bottom: 15px;
 }

/*----------------------------------------------------
	東海追記
----------------------------------------------------*/
.bg_white_cover{
	background-color: white;
	padding: 30px 0;
	margin:30px 0 ;
}

.bg_white_cover h2{
	font-size: 3.0rem;
	font-weight: bold;
	margin-bottom: 30px;
	color: #092f55;
	border-bottom: dashed 1px #092f55;
}


.bg_blue_cover{
	background: linear-gradient(#0A2E55, #0C4176);
	padding: 50px 0;
	margin-bottom: 30px;
}

.bg_blue_cover h2{
	font-size: 3.0rem;
	font-weight: bold;
	margin-bottom: 30px;
	color: white;
	padding: 0.25em 0.5em;/*上下 左右の余白*/
	background: transparent;/*背景透明に*/
	border-left: solid 5px #FFF;/*左線*/
}

.bg_blue_cover h3{
	font-size: 2.4rem;
	font-weight: bold;
	margin-bottom: 30px;
	color: white;
	border-bottom: dashed 1px #FFF;
}

.bg_gray_cover{
	background-color: #f9f9f9;
	padding: 50px 0;
	margin-top: 60px;
}
/*----------------------------------------------------
	FOOTER
----------------------------------------------------*/
footer {
	background: #0B3058;
	padding: 60px 0;
}


footer p {

	margin: 0;
	color: #FFF;
	font-size: 1.4rem;
	line-height: 2.5rem;
}



footer  a {
	color: #FFF;
	font-size: 1.4rem;
}

footer hr {
	border-color: #888;
}

footer a:hover,
footer  a:focus {
	color: #ddd;
	background-color: transparent !important;
}

footer ul.social-buttons{
	margin-top: 20px;
}

footer ul.social-buttons li a {
	display: block;
	width: 40px;
	height: 40px;
	border-radius: 100%;
	font-size: 20px;
	line-height: 40px;
	outline: 0;
	color: #fff;
	background-color: #222;
	-webkit-transition: all .3s;
	-moz-transition: all .3s;
	transition: all .3s;
}

footer ul.social-buttons li a:hover,
footer ul.social-buttons li a:focus,
footer ul.social-buttons li a:active {
	background-color: #9d7d44;
}




.copyright {
	color: #555;
	padding: 15px;
	text-align: center;
	background-color: #FFF;
	margin-top: 15px;
	font-size: 10px;
}

/*----------------------------------------------------
	SP
----------------------------------------------------*/

@media screen and (max-width:767px) {
	hr {
	margin: 15px 0 ;
	}
	.mt30{
		margin-top: 10px;
	}
	.pc {
		display: none;
	}

	.qa_q {
		font-size: 18px;
		color: #46c2f0;
		font-weight: bold;
		line-height: 1.3em;
	}

	.qa_a {
		font-size: 18px;
		color: #eb8100;
		font-weight: bold;
	}
	.qa_area{
		background-color: #f5f5f5;
		padding: 15px 15px;
		margin-bottom: 15px;
	}
	.xr { font-size: 1.8rem; font-weight: bold; line-height: 1.2em; letter-spacing: 0;}  /* 大1 */
}




