@charset "utf-8";
/* CSS Document */
/* ##################################################################### */
/*	モバイルレ : 480 px およびそれ以下
/* ##################################################################### */
/* ===================================================================== */
/*	基本設定
/* ===================================================================== */
/* animate */
@keyframes animate__fadeInUp1 {
  from {
    opacity: 0;
    transform: translateY(200px);
  }
  to {
    opacity: 1;
    transform: translateX(0px);
  }
}
.fadeInUp1 {
  animation-name: animate__fadeInUp1;
  animation-duration: 2s;
}
@keyframes animate__fadeInUp2 {
  from {
    opacity: 0;
    transform: translateY(300px);
  }
  to {
    opacity: 1;
    transform: translateX(0px);
  }
}
.fadeInUp2 {
  animation-name: animate__fadeInUp2;
  animation-duration: 2s;
}
@keyframes animate__fadeInUp3 {
  from {
    opacity: 0;
    transform: translateY(400px);
  }
  to {
    opacity: 1;
    transform: translateX(0px);
  }
}
.fadeInUp3 {
  animation-name: animate__fadeInUp3;
  animation-duration: 2s;
}
@keyframes animate__fadeInUp4 {
  from {
    opacity: 0;
    transform: translateY(500px);
  }
  to {
    opacity: 1;
    transform: translateX(0px);
  }
}
.fadeInUp4 {
  animation-name: animate__fadeInUp4;
  animation-duration: 2s;
}
/* ===================================================================== */
/*	見出し　リボン
/* ===================================================================== */
/*	見出し　リボン h1 */
.h_ribon{
	margin-bottom: 3em;
}
.h_ribon h1 {
	position: relative;
	padding: .10em 1em;
	margin-bottom:15px;
}
.h_ribon h1::before,
.h_ribon h1::after {
	content: '';
	position: absolute;
	border-style: solid;
	border-color: transparent;
}
.h_ribon h1::before {
	top: 100%;
	left: 0;
	border-width: 0 15px 15px 0;
	border-right-color: #ccc;
}

/*	見出し　リボン h2 */
.h_ribon h2 {
	position: relative;
	padding: .40em 1em;
	margin-bottom:15px;
	font-size: 150%;
}
.h_ribon h2::before,
.h_ribon h2::after {
	content: '';
	position: absolute;
	border-style: solid;
	border-color: transparent;
}
.h_ribon h2::before {
	top: 100%;
	left: 0;
	border-width: 0 15px 15px 0;
	border-right-color: #ccc;
}

/*	見出し　リボン h3 */
.h_ribon h3 {
	position: relative;
	padding: .40em 1em;
	margin-bottom:15px;
	font-size: 130%;
}
.h_ribon h3::before,
.h_ribon h3::after {
	content: '';
	position: absolute;
	border-style: solid;
	border-color: transparent;
}
.h_ribon h3::before {
	top: 100%;
	left: 0;
	border-width: 0 15px 15px 0;
	border-right-color: #ccc;
}

/*	見出し　リボン p */
.localTitle .h_ribon{
	margin-bottom: 15px;
	font-size: 110%;
}

.localTitle .h_ribon p {
	position: relative;
	padding: .30em 1em;
	margin-bottom:0px;
	font-size: 120%;
}
.localTitle .h_ribon p::before,
.localTitle .h_ribon p::after {
	content: '';
	position: absolute;
	border-style: solid;
	border-color: transparent;
}
.localTitle .h_ribon p::before {
	top: 100%;
	left: 0;
	border-width: 0 15px 15px 0;
	border-right-color: #ccc;
}


/* ===================================================================== */
/*	見出し　フラット
/* ===================================================================== */
.h_flat{
	margin-bottom: 3em;
}

.h_flat h1{
	padding-bottom: 10px;
	padding-top: 10px;
	padding-left:15px;
}

.h_flat h2{
	padding-bottom: 10px;
	padding-top: 10px;
	padding-left:15px;
}

.h_flat h3{
	padding-bottom: 10px;
	padding-top: 10px;
	padding-left:15px;
}
.newsLists dl.row {
	margin-left: 0;
	margin-right: 0;
}

.newsLists dl {
    width: 100%;
    margin-top: 0px;
    padding-top: 0px;
}
.newsLists dt .date {
    padding-top: 5px;
    font-size: 80%;
}
.newsLists dd {
    width: 100%!important;
    text-indent: 0px;
    line-height: 1.5em;
    padding-top: 5px;
    padding-left: 0px;
    padding-right: 0px;
    border-bottom-width: 1px;
    border-bottom-style: solid;
    border-bottom-color: #CCC;
}
.cat {
    display: inline-block;
    width: 100px;
    color: #ffffff;
    text-decoration: none;
    text-align: center;
    margin-top: 0px;
    padding-top: 0.6em;
    padding-bottom: 0.5em;
    height: 25px;
    line-height: 1.0em;
    font-size: 75%;
    font-weight: bold;
}

.item2 {
	border-radius: 0px; 
}
.number {
    line-height: 1.0em;
    padding-top: 5px;
    padding-bottom: 5px;
    padding-right: 10px;
    padding-left: 10px;
    background-color: #ffffff;
    display: block;
    color: #D90003!important;
    font-size: 200%;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
    width: 40px;
}
.point_number {
    text-align: center;
    font-weight: bolder;
    font-size: 300%;
    line-height: 1.0em;
    margin-bottom: 0px;
    padding-bottom: 0px;
}
.point {
    text-align: center;
}

label.control-label{
	margin-bottom: 2px;
	color: #000000;
	font-weight: bold;
}


/* --------------------------------------------------------------------- */
/*	共通設定 定義リスト  dl dt dd　FAQ
/* --------------------------------------------------------------------- */
.qanda {
	float: left;
	width: 100%;
}
.qanda dl {
	font-size: 100%;
}
.qanda dl dt {
	background-color: #F2F2F2;
	border: 1px solid #CCCCCC;
	margin-top: 0px;
	margin-right: 0px;
	margin-bottom: 5px;
	margin-left: 0px;
	padding-top: 8px;
	padding-bottom: 8px;
	width: 100%;
	line-height: 1.4em;
	font-weight: normal;
	color: #006;
	padding-left: 50px!important;
	text-indent: -25px;

}
.qanda dl dt:before {
	content: "Q";
	padding-left: 0px!important;
	margin-right: 10px;
	font-family: 'Orbitron', sans-serif;
	font-size: 160%;
	color: #d90003;
	    margin-left: -3px;
}

.qanda dd {
	background-color: #FFFFFF;
	border: 1px solid #CCCCCC;
	margin-top: 0px;
	margin-right: 5px;
	margin-bottom: 20px;
	padding-top: 5px;
	padding-bottom: 8px;
	width: 100%;
	line-height: 1.8em;
	color: #333;
	padding-right: 10px!important;
	padding-left: 50px!important;
	text-indent: -20px;
}
.qanda dl dd:before {
	content: "A";
	padding-left: 0px!important;
	margin-right: 5px;
	font-family: 'Orbitron', sans-serif;
	font-size: 160%;
	color: #00AB38;
    margin-left: -3px;

}



.basic dl{}

.basic dl dt{}

.basic dl dd{
	padding-left: 20px;
}


.frame{
	background-color: rgba(0,0,0,1.00);	
}

.bg_color{
	background-color: rgba(0,0,0,1.00);	
}

.jumbotron{
	padding-top: 1em;
	padding-bottom: 0.5em;
}


.bnrArea{
	margin-bottom: 30px;
}	
.bnrArea ul{
	list-style-type: none!important;
	margin-left: 0px;
	margin-right: 0px;
	padding-left: 0px;
	padding-right: 0px;
	margin: 0px;
	}	
.bnrArea li{
	list-style-type: none!important;
	display: inline-block;
	width: 48.0%;
	padding-left: 0px;
	padding-right: 0px;
	margin-left: 1px!important;
	margin-right: 2px!important;
	margin-bottom: 15px;
}
.bnrArea li:nth-child(4n){
	margin-right: 0px!important;
}

/* ===================================================================== */
/*	モバイル　フレックスボックス
/* ===================================================================== */
.flexbox {
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	margin-bottom: 25px;
	width: 100%;
	flex-direction:column-reverse;
}

.flexbox .item {
	margin-bottom: 25px;
	width: 100.0%;
	text-align: left;
	border: 0px solid #7A7A7A;
	margin: 1%;
}

.flexbox .item p.caption {
	margin-top: 0px;
	font-size: 84%;
	padding-top: 10px;
	padding-bottom: 10px;
	padding-left: 10px;
	padding-right: 10px;
	text-align: left;
	line-height: 1.4em;
}

.flexbox02 {
	padding-left: 25px;
	padding-right: 10px;
	text-align: left;

}
/*
.tea h1 {
  position: relative;
  padding: 0.25em 1em;
  border-top: solid 2px #245411;
  border-bottom: solid 2px #245411;
  color: #245411!important;
  margin-bottom: 30px;
  font-size: 150%;
}

/*
.tea h1:before, .tea h1:after {
  content: '';
  position: absolute;
  top: -7px;
  width: 10px;
  height: -webkit-calc(100% + 14px);
  height: calc(100% + 14px);
  background-color: #245411;
}
.tea h1:before {
  left: 7px;
}
.tea h1:after {
  right: 7px;
}



.tea h2{
	background-image: url(../images/h2_icon.png);
	background-repeat: no-repeat;
	background-position: 5px;
	padding-left: 65px;
	/*height: 56px;*/
/*
color: #fff;
	line-height: 1.9em;
	background-color: #245411;
    font-size: 160%;
}
*/

.tea h1 {
  position: relative;
text-align: center;
  padding: 0.5em 0.75em;
  border-top: solid 2px #0B0B0B;
  border-bottom: solid 2px #0B0B0B;
    color: #B91E23!important;
	margin-top: 30px;
    margin-bottom: 30px;
    font-size: 150%;
}

.tea h1:before {
	content: "";
	position: absolute;
	top: -18px;
	left: 50%;
	width: 200px;
	height: 80px;
	/*
	border-radius: 80%;
	border-left: 5px solid transparent;
	border-right: 5px solid transparent;
	border-bottom: 5px solid #B91E23;
	border-top: 5px solid #B91E23;*/
	border-left-color: transparent;
	border-right-color: transparent;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
}

.tea h2{
/*	background-image: url(../images/h2_icon.png);　*/
	background-repeat: no-repeat;
	background-position: 5px;
	padding-left: 25px;
	/*height: 56px;*/
	color: #0B0B0B;
	line-height: 1.9em;
	border-bottom: 3px dotted #9B9898;
    font-size: 160%;
}


.tea h3{
	background-image: url(../images/h3_icon.png);　
	background-repeat: no-repeat;
	background-position: 5px;
	padding-left: 65px;
	height: auto;
	color: #0B0B0B;
	line-height: 1.9em;
	border-bottom: 3px dotted #0B0B0B;
	font-size: 140%;
}

.ty h3{
	background-repeat: no-repeat;
	line-height: 1.2em;
	color: #C9C0C0;
	border-bottom: 3px dotted #C9C0C0;
	font-size: 120%;
	font-weight: bold;
}

.tea small{
	font-size: 90%;
	margin-bottom: 25px!important;
	display: inline-block;
}

.t_icon h1 {
  text-align: center !important;
}
.t_icon.fff h2, .t_icon.fff h3 {
  color: #fff;
}
.t_icon.bbb h2, .t_icon.bbb h3 {
  color: #000;
}
.t_icon {
  text-align: center;

}
.t_icon_left {
  text-align: left;

}

/* ##################################################################### */
/*	タブレット小
/* ##################################################################### */
@media (min-width: 480px) {
/* ===================================================================== */
/*	タブレット小　共通基本設定
/* ===================================================================== */
.tea h1 {
    font-size: 180%;
}
.newsLists dt .date {
    margin-right: 16px;
/*    display: block;
    float: left;*/
}
.newsLists dt {
    padding: 0px;
    margin-top: 0px;
    margin-right: 0px;
    margin-bottom: 0px!important;
    font-weight: normal;
}
.point_number {
    text-align: center;
    font-weight: bolder;
    font-size: 600%!important;
    line-height: 1.0em;
}	
.bnrArea li{
	width: 23.0%;
	margin-bottom: 25px;

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

/* ##################################################################### */
/*	タブレット大
/* ##################################################################### */
@media (min-width: 768px) {
/* ===================================================================== */
/*	タブレット大　共通基本設定
/* ===================================================================== */
.bnrArea li{
	width: 23.45%;
	margin-bottom: 25px;
	
}

/* ===================================================================== */
/*	モバイル横　フレックスボックス
/* ===================================================================== */	
.flexbox {
	display: -webkit-flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	flex-direction:row;
}
.flexbox .item {
	width: 40.0%;
}
.flexbox .item.list01{
		flex-grow: 2;
	}
	
}

/* ##################################################################### */
/*	タブレット大
/* ##################################################################### */
@media (min-width: 993px) {
/* ===================================================================== */
/*	タブレット大　共通基本設定
/* ===================================================================== */
.bnrArea li{
	width: 24.5%;
	margin-bottom: 25px;

}
	
}
/* ##################################################################### */
/*	PC
/* ##################################################################### */
@media (min-width: 1200px) {
/* ===================================================================== */
/*	PC　　共通基本設定
/* ===================================================================== */
.newsLists dt{
    border-bottom-width: 1px;
    border-bottom-style: dotted;
    border-bottom-color: #CCC;
	padding-bottom: 10px;
	margin-bottom: 10px!important;

}
.newsLists dd {
    border-bottom-width: 1px;
    border-bottom-style: dotted;
    border-bottom-color: #CCC;
    padding-bottom: 10px;
    margin-bottom: 10px;
	line-height: 1.5em;
    font-size: 110%;
}
	
}
