
/* CSS Document */

/*==================================================

メインイメージ

=================================================*/
.main-image,
.top-image{
	margin: 100px auto 0;
	position: relative;
	text-align: center;
	z-index: 1;
}.top-image{
	padding: 20px 10px 3%;
}
.top-image::after{
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 40%;
	background: #e5eba2;
	z-index: -1;
}
.top-image .n2-section-smartslider{
	text-align: center;
	margin: 0 auto;
}
.main-image::after{
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
   animation: Grad 50s infinite;
  opacity: 0.4;
  background: linear-gradient(150deg, #a6d900 0%, #ff4454 100%);
}
@keyframes Grad {
  0% {
    -webkit-filter: hue-rotate(0deg);
    filter: hue-rotate(0deg);
  }

  100% {
    -webkit-filter: hue-rotate(360deg);
    filter: hue-rotate(360deg);
  }
}


.main-image .Title{
	padding: 5% 0;
}
.main-image .Title h2{
	color: #fff;
	padding: 5px 10px;
	font-weight: 700;
	line-height: 1.5em;
	position: relative;
	text-shadow: 1px 1px 2px #999;
	text-align: center;
	margin: auto;
}

@media print , screen and (min-width:1px) and (max-width: 960px) {
.main-image,
.top-image{
	margin: 90px auto 0;
	position: relative;
	text-align: center;
	z-index: 1;
}
}
@media print , screen and (min-width:1px) and (max-width: 768px) {
.main-image,
.top-image{
	margin: 80px auto 0;
	position: relative;
	text-align: center;
	z-index: 1;
}
}
.main{
	margin: 5% auto 8%;
}

#content{
	width: 100%;
	position: relative;
	z-index: 20 !important;
}
#content p{
	padding: 20px 0;
}
#content h3{
	text-align: left;
	margin: 5% auto 3%;
}


/*共通*/


.main h2 {
	text-align: left;
    position: relative;
    padding: 5px 10px;
	font-weight: bold;
	margin-bottom: 5%;
	border-bottom: 3px solid #cccccc;
}
.main h2::after{
	width: 22%;
	height: 3px;
	background: #69b0be;
	position: absolute;
	bottom: -3px;
	left: 0;
	content: "";
}

.main h2:not(:first-child) {
  margin-top: 1.5em;
}
.main h3{
	font-weight: 500;
	position: relative;
	margin: 5% auto 1%;
	border-bottom:4px solid #69b0be;
	border-bottom:4px solid #dfdfdf;
	padding: 5px 15px;
	position: relative;
}
.main h3::after{
	content: "";
	position: absolute;
	left: 0;
	bottom: -4px;
	width: 120px;
	border-bottom:4px solid #c0e7e1;
	padding: 12px;
}
.main h4{
	background: #c0e7e1;
	color: #000;
	padding: 8px 15px;
	margin: 5% auto;
}
.main h5 {
  padding: 5px 15px ;
  margin-bottom: 1.5em;
  position: relative;
	color: #69b0be;
	background: #f8f4ea;
	border-bottom:1px solid #c0e7e1;
}
.main h6 {
  padding: 5px 15px ;
  margin-bottom: 1.5em;
  position: relative;
	color: #69b0be;
}
.main ul.wp-block-list{
	margin: 20px 20px;
}
.main ul li{
	text-align: left;
	margin: 0 10px;
}
.main ul li::before{
	content: "● ";
	font-size: 0.6em;
	color: #e3eb98;
}



/*News*/

.news{
	margin: 6% auto 3%;
	position: relative;
}
.news h3{
	display: flex;
	justify-content: flex-start;
	align-items: center;
}
.news h3 .ico{
	width: 60px;
	margin-right: 10px;
}
.news .btn{
	position: absolute;
	right: 10px;
	top: 10px;
}
.news .btn a{
	font-size: 0.9em;
	display: inline-block;
	width: 180px;
	background: #83ccd2;
	color: #fff;
	border-radius: 40px;
	padding: 10px 20px 10px 10px;
	position: relative;
	-webkit-transition: all 0.3s;
	transition: all 0.3s;
}
.news .btn a::after{
	content: "";
	position: absolute;
	right: 10px;
	top:40% ;
	display: inline-block;
	width: 11px;
	height: 11px;
	margin: 0 10px;
	border-top: 1px solid #fff;
	border-right: 1px solid #fff;
	transform: rotate(45deg);
}
.news .btn a:hover{
	background: #fff;
	color: #83ccd2;
	border: 1px solid #83ccd2;
}
.news .btn a:hover::after{
	border-top: 1px solid #83ccd2;
	border-right: 1px solid #83ccd2;
}
.news .news_area {
	margin: 3% auto;
	border-top: 1px solid #bfc0c0;
}
.news .news_area dl{
	border-bottom: 1px solid #bfc0c0;
}
.news .news_area dl a{
	display: flex;
	flex-wrap: wrap;
	padding: 0 20px 0 10px;
	-webkit-transition: all 0.3s;
	transition: all 0.3s;
}
.news .news_area dl:hover a{
	padding: 0 10px 0 20px;
/*	color: #83ccd2;*/
}
.news .news_area dl a dt{
	width: 300px;
	margin-bottom: 10px;
	padding: 25px 10px;
}
.news .news_area dl a dt .cat,
.news .news_area dl a dt .cat.cat-com{
	font-size: 1.4rem;
	background: #ffe893;
	padding: 5px 10px;
	line-height: 1.2em;
	border-radius: 15px;
	width: 120px;
	text-align: center;
	display: inline-block;
}
.news .news_area dl a dt .cat.cat-event{
	background: #fce6e6;
}
.news .news_area dl a dt .cat.cat-ir{
	background: #dcf0f4;
}
.news .news_area dl a dd{
	width: calc(100% - 320px);
	text-align: left;
	display: block;
	background: url("../img/common/news_arrow.svg") right center no-repeat;
	background-size: 35px;
	padding: 25px 60px 25px 10px;
}
.news .news_area dl a:hover,
.news .news_area dl dt:hover,
.news .news_area dl dd:hover{
	color: #777;
}
.sns{
	margin: 3% auto 8%;
}
@media print , screen and (min-width:1px) and (max-width: 768px) {
	
.news .btn{
	position: relative;
	right: inherit;
	top: inherit;
	text-align: center;
	margin: 20px auto;
}
.news .news_area dl a dt{
	width: 100%;
	margin-bottom: 10px;
	padding: 20px 10px 0;
	text-align: left;
	position: relative;
}
.news .news_area dl a dt .cat,
.news .news_area dl a dt .cat.cat-com,
.news .news_area dl a dt .cat.cat-event,
.news .news_area dl a dt .cat.cat-ir{
	display: block;
	position: absolute;
	right: 0;
	top: 20px;
	width: 100px;
	padding: 5px 10px;
	text-align: center;
	font-size: 1.3rem;
	line-height: 1.2em;
}
.news .news_area dl a dd{
	width: 100%;
	background-size: 25px;
	padding: 5px 40px 25px 10px;
}
	
}