.con1300 {
    width: 1300px;
    margin: 0 auto;
    padding: 0 17px;
}

#special_this_year p{
    font-size: 1.2rem;
    line-height: 2.4rem;
}

@media screen and (max-width:1300px){
    .con1300 {
        width: 100%;
    }

    #special_this_year p{
        font-size: 1rem;
        line-height: 2rem;
    }
}

/*-----------------------------
　　見出しタグ
  -----------------------------*/

#special_this_year h2{
    position: relative;
    font-size: 1.8em;
    display: block;
    text-align: center;
    margin-top: 30px;
    margin-bottom: 60px;
    border-bottom: none;
    color: #363636;
    padding: 0;
}

#special_this_year h2::before {
    content: '';
    position: absolute;
    bottom: -20px;
    display: inline-block;
    width: 60px;
    height: 1px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    background-color: #363636;
}

#special_this_year h3{
    font-size: 22px;
    padding-left: 0px;
    border-left: none;
    margin-block-start: 60px;
    margin-block-end: 20px;
    margin-inline-start: 0px;
    margin-inline-end: 0px;
}

#special_this_year h3::after {
    width: 0;
}

#special_this_year h3:first-child {
    margin-block-start: 0px;
}

.content_headline {
    display: flex;
    align-items: center;
    text-align: left;
    width: 100%;
}

.content_headline::after {
    content: "";
    flex: 1;
    height: 15px;
    margin-left: 10px;
    background-color: #C36068;
}

@media screen and (max-width:768px) {
    #special_this_year h2{
        font-size: 20px;
    }

    #special_this_year h3{
        font-size: 18px;
    }
}

/*-----------------------------
　　ボタン
  -----------------------------*/

.btnarrow{
	position: relative;
	border: 1px solid #363636;
    padding: 8px 30px;
    display: inline-block;
    text-align: left;
    text-decoration: none;
    color: #363636;
    background: #fff;
    outline: none;
    transition: all .2s linear;
}

.btnarrow:hover{
    opacity: 1;
	background:#363636;
	color:#fff;
}

.btnarrow::before{
    display: inline-block;
	content:"";
	position: absolute;
	top:50%;
	right:-26px;
	width:40px;
	height:1px;
	background:#363636;
    transition: all .2s linear;
}

.btnarrow::after{
    display: inline-block;
	content:"";
	position: absolute;
    top: 20%;
    right: -21px;
	width:1px;
	height:12px;
	background:#363636;
    transform:skewX(45deg);
    transition: all .2s linear;
}

.btnarrow:hover::before{
	right:-30px;
}

.btnarrow:hover::after{
	right:-25px;
}

@media screen and (max-width:768px){
    .btnarrow {
        padding: 8px 20px;
    }
    .btnarrow::before,
    .btnarrow::after {
        display: none;
    }
}

/*-----------------------------
　　box
  -----------------------------*/

.content01__text {
    margin-top: 80px;
    display: inline-block;
    box-sizing: border-box;
    width: calc(60% - 9px);
    margin-left: 8.5px;
}

.content01__img {
    margin-top: 80px;
    display: inline-block;
    box-sizing: border-box;
    width: calc(40% - 29px);
    padding-left: 20px;
    margin-right: 8.5px;
}

.content02__leftbox {
    display: inline-block;
    width: calc(50% - 9px);
    padding-left: 8.5px;
    padding-top: 168px;
}

.content02__rightbox {
    display: inline-block;
    width: calc(50% - 29px);
    padding-left: 20px;
    padding-right: 8.5px;
}

@media screen and (max-width:768px){
    .content01__text {
        width: 100%;
        order:2;
        padding: 0;
        margin: 20px auto 0 auto;
    }

    .content01__img {
        width: 100%;
        order:1;
        padding: 0;
        margin: 60px auto 0 auto;
    }

    .content02__leftbox {
        width: 100%;
        padding: 0;
        margin: 0 auto;
    }

    .content02__rightbox {
        width: 100%;
        padding: 0;
        margin: 0 auto;
    }
}

/*-----------------------------
　　content01
  -----------------------------*/
.bg-red {
    background:#FAEBD7;
    padding: 60px 20px 20px 20px;
    height: 100%;
    box-sizing: border-box;
}

.sticky {
    position: -webkit-sticky;
    position:sticky;
    top:0;
    padding: 20px 0;
    z-index: 100;
}

@media screen and (max-width:768px){
    .bg-red {
        background: none;
        padding: 0;
        height: auto;
    }

    .sticky {
        position: inherit;
        height: auto;
        padding: 0;
    }
}

/*-----------------------------
　　content02
  -----------------------------*/

.content02__bg {
    background:#FAEBD7;
    margin-top: 80px;
    padding: 5px 0 20px 0;
}

@media screen and (max-width:768px){
    .content02__bg {
        width: 100%;
        margin: 80px auto 0 auto;
    }
}

.content03__bg img,
.content04__bg img{
    max-width: 600px;
    max-height: 400px;
}

.cap {
    display: block;
    font-size: 14px;
    font-style: oblique;
}
@media screen and (max-width:768px){
    .cap {
        margin-bottom: 20px;
    }

    .content03__bg img,
    .content04__bg img{
    max-width: 100%;
    max-height: auto;
}
}
/*-----------------------------
　　content03
  -----------------------------*/

.content03__bg {
    display: inline-block;
    width: 50%;
    position: relative;
    height: 600px;
    background:#FAEBD7;
    margin-top: 80px;
}

.content03__bg div {
    width: 85%;
    position: absolute;
    top: 75px;
    right: 50px;
    padding:0;
}

.content03__text {
    display: inline-block;
    width: calc(50% - 50px);
    padding-right: 20px;
    padding-top: 75px;
    margin-left: 50px;
    margin-top: 80px;
}
.flex-side-column img {
    width: 100%;
}

@media screen and (max-width:768px){
    .content03__text{
        width: 100%;
        padding: 0 15px;
        margin: 80px auto 0 auto;
    }

    .content03__bg {
        position: inherit;
        width: 100%;
        height: 100%;
        margin: 0 auto;
    }

    .content03__bg div {
        position: inherit;
        margin: 0 auto;
        padding-top: 20px;
    }
}

/*-----------------------------
　　content04
  -----------------------------*/

.content04__bg {
    display: inline-block;
    width: 50%;
    position: relative;
    height: 600px;
    background:#FAEBD7;
    margin-top: 80px;
}

.content04__bg div {
    width: 85%;
    position: absolute;
    top: 75px;
    left: 50px;
}

.content04__text {
    display: inline-block;
    width: calc(50% - 50px);
    padding-left: 20px;
    padding-top: 75px;
    margin-right: 50px;
    margin-top: 80px;
}

@media screen and (max-width:768px){
    .content04__bg {
        order: 2;
        position: inherit;
        width: 100%;
        height: 100%;
        margin: 0 auto;
    }

    .content04__bg div {
        position: inherit;
        margin: 0 auto;
        padding-top: 20px;
    }

    .content04__bg img{
        top: 50px;
        left: 8%;
    }

    .content04__text{
        width: 95%;
        order: 1;
        padding: 0;
        margin: 80px auto 0 auto;
    }
}

/*-----------------------------
　　content05
  -----------------------------*/

.content05__text {
    display: inline-block;
    box-sizing: border-box;
    background:#FAEBD7;
    width: 50%;
    padding: 20px 20px 10px 50px;
    margin-top: 80px;
}

.content05__text p {
    padding: 0;
}

.content05__img {
    display: inline-block;
    box-sizing: border-box;
    width: 50%;
    margin-top: 80px;
}

.content05__img img {
    width: 100%;
}

@media screen and (max-width:768px){
    .content05__text {
        order: 1;
        width: 100%;
        padding: 20px 10px;
    }

    .content05__img {
        order: 2;
        width: 100%;
        margin-top: 20px;
    }
}

/*-----------------------------
　　animation
 -----------------------------*/
.bgextend{
	animation-name:bgextendAnimeBase;
	animation-duration:1s;
	animation-fill-mode:forwards;
	position: relative;
	overflow: hidden;/*　はみ出た色要素を隠す　*/
	opacity:0;
}

@keyframes bgextendAnimeBase{
  from {
    opacity:0;
  }

  to {
    opacity:1;  
}
}

.bgappear{
	animation-name:bgextendAnimeSecond;
	animation-duration:1s;
	animation-delay: 0.6s;
	animation-fill-mode:forwards;
	opacity: 0;
}

@keyframes bgextendAnimeSecond{
	0% {
	opacity: 0;
	}
	100% {
	opacity: 1;
}
}

.bgLRextend::before{
	animation-name:bgLRextendAnime;
	animation-duration:1s;
	animation-fill-mode:forwards;
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: #363636;/*伸びる背景色の設定*/
}

@keyframes bgLRextendAnime{
	0% {
		transform-origin:left;
		transform:scaleX(0);
	}
	50% {
		transform-origin:left;
		transform:scaleX(1);
	}
	50.001% {
		transform-origin:right;
	}
	100% {
		transform-origin:right;
		transform:scaleX(0);
	}
}

.bgappearTrigger02,
.bgLRextendTrigger02{
    opacity: 0;
}

.bgextend02{
	animation-name:bgextendAnimeBase02;
	animation-duration:1s;
	animation-fill-mode:forwards;
	position: relative;
	overflow: hidden;
	opacity:0;
}

@keyframes bgextendAnimeBase02{
  from {
    opacity:0;
  }

  to {
    opacity:1;  
}
}

/*中の要素*/
.bgappear02{
	animation-name:bgextendAnimeSecond02;
	animation-duration:1s;
	animation-delay: 0.6s;
	animation-fill-mode:forwards;
	opacity: 0;
}

@keyframes bgextendAnimeSecond02{
	0% {
	opacity: 0;
	}
	100% {
	opacity: 1;
}
}

/*左から右*/
.bgLRextend02::before{
	animation-name:bgLRextendAnime02;
	animation-duration:1s;
	animation-fill-mode:forwards;
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    background-color: #C36068;/*伸びる背景色の設定*/
}

@keyframes bgLRextendAnime02{
	0% {
		transform-origin:left;
		transform:scaleX(0);
	}
	50% {
		transform-origin:left;
		transform:scaleX(1);
	}
	50.001% {
		transform-origin:right;
	}
	100% {
		transform-origin:right;
		transform:scaleX(0);
	}
}

/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
.bgappearTrigger02,
.bgLRextendTrigger02{
    opacity: 0;
}

.w1300 {
    width: 100%;
    max-width: 1300px;
    margin: 0 auto 30px;
}
.refbtn {
    text-align: center;
}
.refbtn a {
    display: inline-block;
    padding: 5px 8px;
    font-size: 14px;
    line-height: 1;
    border-radius: 5px;
    background: #c73b3a;
    color: #fff;
}

#special_this_year .spcont h2 {
    font-size: 28px;
    border-bottom: 2px solid;
    padding: 0 0 12px 0;
    margin: 60px 0 40px 0;
    border-color: #0068B7;
    color: #0068B7;
    text-align: left;
}
#special_this_year .spcont h2::before {
    display: none;
}
#special_this_year .spcont img {
    border-radius: 0;
}

#special_this_year .spcont p {
    font-size: 1rem;
    line-height: 1rem;
}