header #navi {
    margin-bottom: 134px;
}
header #key {
    min-height: 600px;
}
header #key:before {
    content: "";
    position: absolute;
    top: -134px;
    left: 0;
    background-image: url("../img/index/kv_bg.png");
    background-position: center top;
    background-repeat: no-repeat;
    width: 100%;
    height: 865px;
    z-index: 1;
}
#sec1 {
    background-image: url("../img/index/s1_bg.jpg");
    background-position: center top;
    background-repeat: no-repeat;
    background-size: cover;
    padding-bottom: 141px;
}
#sec1 h2 {
    margin: 239px 134px 0 0;
}
#sec1 .txt {
    width: 468px;
    height: 600px;
    margin: 313px 0 0 138px;
}
#sec2 {
    background-image: url("../img/index/s2_bgcircle.png");
    background-position: center top;
    background-repeat: no-repeat;
    position: relative;
    padding-bottom: 363px;
}
#sec2:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    background-image: url("../img/shared/sec_bg1.jpg");
    background-position: center top;
    background-repeat: repeat;
    width: 100%;
    height: 365px;
}
#sec2:after {
    content: "";
    position: absolute;
    top: 365px;
    left: 0;
    background-image: url("../img/index/s2_bg1.png");
    background-position: center top;
    background-repeat: no-repeat;
    width: 100%;
    height: 181px;
}
#sec2 .wrap {
    z-index: 1;
}
#sec2 h2 {
    padding: 60px 0 38px 0;
}

#sec2 .tab_btn li{
    float: left;
}
#sec2 .tab_btn li + li {
    margin-left: 16px;
}
#sec2 .tab_btn li.active:before{
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    background: url("../img/index/s2_navitab_on.png") no-repeat center top;
    z-index: 1;
}

#sec2 .s2Slider .slide_thm1{
	width: 606px;
	margin: 0 auto;
}
#sec2 .s2Slider .slide_thm1 li {
    float: left;
}
#sec2 .s2Slider .slide_thm1 li a{
    display: block;
    position: relative;
}
#sec2 .s2Slider .slide_thm1 li a.active:before{
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    background: url("../img/index/s2_navitab_on.png") no-repeat center top;
    z-index: 1;
}
#sec2 .s2Slider .slide_thm1 li + li {
    margin-left: 16px;
}
#sec2 .s2Slider .bx-viewport{
    overflow: inherit !important;
    z-index: 0;
}
#sec2 .tab_inner .fl {
    margin: 13px 0 0 -400px;
}
#sec2 .tab_inner .fr {
    width: 443px;
    margin: 95px 17px 0 0;
}
#sec2 .tab_inner .fr .logo {
    margin: 36px 0 0 -5px;
}
#sec2 .tab_inner .fr .txt {
    color: #111;
    margin-bottom: 35px;
}

#sec2 .slide_thm2 {
    text-align: center;
    position: absolute;
    bottom: 37px;
    left: 0;
    right: 0;
    z-index: 2;
}
#sec2 .slide_thm2 li{
    display: inline-block;
}
#sec2 .slide_thm2 li a{
    background: #b20a0a;
    width: 15px;
    height: 15px;
    border-radius: 50%;
    display: inline-block;
    margin: 0 10px;
    box-shadow: 4px 8px #999999;
}
#sec2 .slide_thm2 li a.active{
    background: #290c0c;
}
#sec3 {
    position: relative;
    border-bottom: 1px solid #000;
}
#sec3:before {
    content: "";
    position: absolute;
    bottom: -1px;
    left: 0;
    background-image: url("../img/index/s3_bg.png");
    background-position: center bottom;
    background-repeat: no-repeat;
    width: 100%;
    height: 1171px;
}
#sec3:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    background-image: url("../img/index/s3_bgimg.png");
    background-position: center bottom;
    background-repeat: no-repeat;
    width: 100%;
    height: 1066px;
}
#sec3 .box {
    background: #fff;
    color: #111;
    width: 375px;
    margin-left: 55px;
    padding: 0 81px 82px 72px;
    position: relative;
    z-index: 1;
}
#sec3 .box h2 {
    margin: -68px 0 0 -5px;
}
#sec3 .box .txt {
    clear: left;
    padding: 37px 0 42px 0;
}
#sec4 {
    margin: 81px 0 85px 0;
}
#sec4 h2 {
    margin-bottom: 53px;
}
#sec4 #feed {
    margin-bottom: 61px;
    font-size: 14px;
    line-height: 25px;
}
#sec4 #feed dl {
    width: 320px;
}
#sec4 #feed dl + dl {
    margin-left: 20px;
}
#sec4 #feed dl .photo {
    margin-bottom: 10px;
}
#sec4 #feed dl .photo span:hover {
    opacity: 0.8;
}
#sec4 #feed dl .date {
    padding-left: 15px;
}
#sec4 #feed dl .tit {
    font-weight: bold;
    border-bottom: 2px dotted #000;
    padding: 0 0 9px 15px;
    margin-bottom: 13px;
}
#sec4 #feed dl .txt {
    padding-left: 15px;
    word-break: break-all;
}


#top-slider {
	position: relative;
    z-index: 1;
}
#top-slider li {
	width: 100%;
	height: 100%;
	cursor: pointer;    
}
#top-slider li:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    z-index: 1;
	background: rgba(0,0,0,0.5);
}
#top-slider li.sp-selected:before {
	background: none;
}
#top-slider .sp-arrows {
	width: 100%;
	left: 0;
	top: 16%;
	margin-top: 0;
}
#top-slider .sp-arrow {
	width: calc(50% - 390px);
	height: 400px;
	-webkit-transition: 0.2s;
	-moz-transition: 0.2s;
	-ms-transition: 0.2s;
	-o-transition: 0.2s;
	transition: 0.2s;
}
#top-slider .sp-arrow:hover {
	opacity: 0.8;
}
#top-slider .sp-arrow:before {
	width: 48px;
	height: 100%;
	background: url("../img/index/icon.png") no-repeat 0 center;	
    left: calc(100% + -70px);
	top: 50%;
	margin-top: -200px;
	-webkit-transform: none;
	-moz-transform: none;
	-ms-transform: none;
	-o-transform: none;
	transform: none;
}
#top-slider .sp-arrow:after {
	display: none;
}
#top-slider a {
	-webkit-transition: 0.2s !important;
	-moz-transition: 0.2s !important;
	-ms-transition: 0.2s !important;
	-o-transition: 0.2s !important;
	transition: 0.2s !important;
}
#top-slider .sp-previous-arrow {
    left: 0;
}
#top-slider .sp-next-arrow {
    right: 0;
}
.sp-buttons {
	display: none;
}

#oshirase{
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "メイリオ", Meiryo, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	text-align:center;
	background:#530E00;
	box-shadow: 0px 0px 0 5px #530E00;
	border:1px solid #fff;
	color:#fff;
	font-size:14px;
	padding:10px 0;
	display:block;
	width:800px;
	margin:150px auto 0;
	z-index: 500;
	font-weight: normal;
	line-height: 1.8;
    position: absolute;
    left:0;
    right:0;
    top:-80px;
}
#oshirase p{
	margin-bottom: 1em;
}
#oshirase p:last-child{
	margin-bottom: 0em;
}
#oshirase .ttl{
	font-size:110%;
	font-weight: bold;
}


@media screen and (max-width: 979px) {
.prev, .next {
	position: absolute;
	top: 0;
	width: 32px;
	height: 100%;
	background-size: 10px 10px;
}
.prev:hover, .next:hover {
	opacity: 0.5;
	zoom: 1;
	cursor: pointer;
}
#top-slide .sp-mask {
	min-height: 560px!important;
}
#top-slider li {
	min-height: 560px!important;
	overflow: hidden;
}
}