/*-------------------------------------------------
base 
-------------------------------------------------*/

body {
	font-family: YakuHanJP,'source-han-sans-japanese', sans-serif;
	font-size:1.4rem;
	line-height:1.6;
	color:#111;
	-webkit-text-size-adjust:100%;
	letter-spacing:0.1em;
}
a img {
	border-style: none;
}
a {
 color: inherit;
 text-decoration: none;
}
a:link, a:visited {
text-decoration: none;
}
.clear  {
	clear: both;
	visibility: hidden;
	height: 0px;
}
.line_effect {
text-decoration: none;
}
.u_line_wht,
.u_line_blk {
position: relative;
z-index: 1;
}
.u_line_wht:after {
content: '';
position: absolute;
left: 0;
bottom: -8px;/*テキストからの距離*/
width: 0%;/*初期状態では下線非表示*/
height: 1px;/*下線の高さ*/
background: #ccc;/*下線の色*/
z-index: -1;
transition: all 0.3s;/*アニメーション速度*/
}
.u_line_blk:after {
content: '';
position: absolute;
left: 0;
bottom: -8px;/*テキストからの距離*/
width: 0%;/*初期状態では下線非表示*/
height: 1px;/*下線の高さ*/
background: #222;/*下線の色*/
z-index: -1;
transition: all 0.3s;/*アニメーション速度*/
}

.line_effect:hover .u_line_wht:after,
.line_effect:hover .u_line_blk:after{
width: 100%;/*hover時に表示*/
}

::selection {
background: #FFEF00;
color: #111;
}

/*Firefox*/
::-moz-selection {
background: #FFEF00;
color: #111;
}

/*-------------------------------------------------
	padding margin font-size
-------------------------------------------------*/

.p-0{padding: 0px !important;}
.p-5{padding: 5px !important;}
.p-10{padding: 10px !important;}
.p-15{padding: 15px !important;}
.p-20{padding: 20px !important;}
.p-25{padding: 25px !important;}
.p-30{padding: 30px !important;}
.p-35{padding: 35px !important;}
.p-40{padding: 40px !important;}
.p-45{padding: 45px !important;}
.p-50{padding: 50px !important;}

.pt-0 {padding-top: 0 !important;}
.pt-5 {padding-top: 5px !important;}
.pt-10 {padding-top: 10px !important;}
.pt-15 {padding-top: 15px !important;}
.pt-20 {padding-top: 20px !important;}
.pt-25 {padding-top: 25px !important;}
.pt-30 {padding-top: 30px !important;}
.pt-35 {padding-top: 35px !important;}
.pt-40 {padding-top: 40px !important;}
.pt-45 {padding-top: 45px !important;}
.pt-50 {padding-top: 50px !important;}

.pr-0 {padding-right: 0 !important;}
.pr-5 {padding-right: 5px !important;}
.pr-10 {padding-right: 10px !important;}
.pr-15 {padding-right: 15px !important;}
.pr-20 {padding-right: 20px !important;}
.pr-25 {padding-right: 25px !important;}
.pr-30 {padding-right: 30px !important;}
.pr-35 {padding-right: 35px !important;}
.pr-40 {padding-right: 40px !important;}
.pr-45 {padding-right: 45px !important;}
.pr-50 {padding-right: 50px !important;}

.pb-0 {padding-bottom: 0 !important;}
.pb-5 {padding-bottom: 5px !important;}
.pb-10 {padding-bottom: 10px !important;}
.pb-15 {padding-bottom: 15px !important;}
.pb-20 {padding-bottom: 20px !important;}
.pb-25 {padding-bottom: 25px !important;}
.pb-30 {padding-bottom: 30px !important;}
.pb-35 {padding-bottom: 35px !important;}
.pb-40 {padding-bottom: 40px !important;}
.pb-45 {padding-bottom: 45px !important;}
.pb-50 {padding-bottom: 50px !important;}

.pl-0 {padding-left: 0 !important;}
.pl-5 {padding-left: 5px !important;}
.pl-10 {padding-left: 10px !important;}
.pl-15 {padding-left: 15px !important;}
.pl-20 {padding-left: 20px !important;}
.pl-25 {padding-left: 25px !important;}
.pl-30 {padding-left: 30px !important;}
.pl-35 {padding-left: 35px !important;}
.pl-40 {padding-left: 40px !important;}
.pl-45 {padding-left: 45px !important;}
.pl-50 {padding-left: 50px !important;}

.m-0{margin: 0px !important;}
.m-5{margin: 5px !important;}
.m-10{margin: 10px !important;}
.m-15{margin: 15px !important;}
.m-20{margin: 20px !important;}
.m-25{margin: 25px !important;}
.m-30{margin: 30px !important;}
.m-35{margin: 35px !important;}
.m-40{margin: 40px !important;}
.m-45{margin: 45px !important;}
.m-50{margin: 50px !important;}

.mt-0{margin-top: 0px !important;}
.mt-5{margin-top: 5px !important;}
.mt-10{margin-top: 10px !important;}
.mt-15{margin-top: 15px !important;}
.mt-20{margin-top: 20px !important;}
.mt-25{margin-top: 25px !important;}
.mt-30{margin-top: 30px !important;}
.mt-35{margin-top: 35px !important;}
.mt-40{margin-top: 40px !important;}
.mt-45{margin-top: 45px !important;}
.mt-50{margin-top: 50px !important;}

.mr-0{margin-right: 0px !important;}
.mr-5{margin-right: 5px !important;}
.mr-10{margin-right: 10px !important;}
.mr-15{margin-right: 15px !important;}
.mr-20{margin-right: 20px !important;}
.mr-25{margin-right: 25px !important;}
.mr-30{margin-right: 30px !important;}
.mr-35{margin-right: 35px !important;}
.mr-40{margin-right: 40px !important;}
.mr-45{margin-right: 45px !important;}
.mr-50{margin-right: 50px !important;}

.mb-0{margin-bottom: 0px !important;}
.mb-5{margin-bottom: 5px !important;}
.mb-10{margin-bottom: 10px !important;}
.mb-15{margin-bottom: 15px !important;}
.mb-20{margin-bottom: 20px !important;}
.mb-25{margin-bottom: 25px !important;}
.mb-30{margin-bottom: 30px !important;}
.mb-35{margin-bottom: 35px !important;}
.mb-40{margin-bottom: 40px !important;}
.mb-45{margin-bottom: 45px !important;}
.mb-50{margin-bottom: 50px !important;}
.mb-60{margin-bottom: 60px !important;}
.mb-70{margin-bottom: 70px !important;}
.mb-80{margin-bottom: 80px !important;}
.mb-90{margin-bottom: 90px !important;}
.mb-100{margin-bottom: 100px !important;}
.mb-110{margin-bottom: 110px !important;}
.mb-120{margin-bottom: 120px !important;}

.ml-0{margin-left: 0px !important;}
.ml-5{margin-left: 5px !important;}
.ml-10{margin-left: 10px !important;}
.ml-15{margin-left: 15px !important;}
.ml-20{margin-left: 20px !important;}
.ml-25{margin-left: 25px !important;}
.ml-30{margin-left: 30px !important;}
.ml-35{margin-left: 35px !important;}
.ml-40{margin-left: 40px !important;}
.ml-45{margin-left: 45px !important;}
.ml-50{margin-left: 50px !important;}

.fs-1 {font-size:.1rem !important;}
.fs-2 {font-size:.2rem !important;}
.fs-3 {font-size:.3rem !important;}
.fs-4 {font-size:.4rem !important;}
.fs-5 {font-size:.5rem !important;}
.fs-6 {font-size:.6rem !important;}
.fs-7 {font-size:.7rem !important;}
.fs-8 {font-size:.8rem !important;}
.fs-9 {font-size:.9rem !important;}
.fs-10{font-size:1rem !important;}
.fs-11{font-size:1.1rem !important;}
.fs-12{font-size:1.2rem !important;}
.fs-13{font-size:1.3rem !important;}
.fs-14{font-size:1.4rem !important;}
.fs-15{font-size:1.5rem !important;}
.fs-16{font-size:1.6rem !important;}
.fs-17{font-size:1.7rem !important;}
.fs-18{font-size:1.8rem !important;}
.fs-19{font-size:1.9rem !important;}
.fs-20{font-size:2rem !important;}
.fs-21{font-size:2.1rem !important;}
.fs-22{font-size:2.2rem !important;}
.fs-23{font-size:2.3rem !important;}
.fs-24{font-size:2.4rem !important;}
.fs-25{font-size:2.5rem !important;}
.fs-26{font-size:2.6rem !important;}
.fs-27{font-size:2.7rem !important;}
.fs-28{font-size:2.8rem !important;}
.fs-29{font-size:2.9rem !important;}
.fs-30{font-size:3.0rem !important;}
.fs-31{font-size:3.1rem !important;}
.fs-32{font-size:3.2rem !important;}
.fs-33{font-size:3.3rem !important;}
.fs-34{font-size:3.4rem !important;}
.fs-35{font-size:3.5rem !important;}
.fs-36{font-size:3.6rem !important;}
.fs-37{font-size:3.7rem !important;}
.fs-38{font-size:3.8rem !important;}
.fs-39{font-size:3.9rem !important;}
.fs-40{font-size:4rem !important;}
.fs-41{font-size:4.1rem !important;}
.fs-42{font-size:4.2rem !important;}
.fs-43{font-size:4.3rem !important;}
.fs-44{font-size:4.4rem !important;}
.fs-45{font-size:4.5rem !important;}
.fs-46{font-size:4.6rem !important;}
.fs-47{font-size:4.7rem !important;}
.fs-48{font-size:4.8rem !important;}
.fs-49{font-size:4.9rem !important;}
.fs-50{font-size:5rem !important;}


/*-------------------------------------------------
改 行
-------------------------------------------------*/

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

.pc-hidden{
	display:none;
}

}

@media screen and (max-width : 480px ){

.sp-hidden{
	display:none;
}

}



/*-------------------------------------------------
basic layout 
-------------------------------------------------*/

main {
width: 100%;
}
.box {
margin: 150px 0 90px;
}
.box_s {
max-width: 980px;
margin: 0 auto;
}
.box_m {
max-width: 1260px;
margin: 0 auto;
}
.box_l {
width: 100%;
}


/*-------------------------------------------------
グローバルナビ
-------------------------------------------------*/

.head-bar {
position: fixed;
left: 0;
top:0;
z-index: 11;
display: block;
width: 100%;
height: 100px;
background-color: rgba(255,255,255,0.9);
display: flex;
justify-content: space-between;
align-items: center;
box-shadow: 0 1px 1px rgba(0, 0, 0, 0.05);
}
.head_logo {
max-width: 130px;
height: auto;
margin-left: 30px;
}
@media screen and (max-width: 979px) {
.head-bar {
height: 60px;
}
.head_logo {
max-width: 100px;
height: auto;
margin-left: 0px;
margin: 0 auto;
}
}

.head_logo img {
width: 100%;
}
.head-bar .menu {
position: relative;
display: flex;
justify-content: flex-start;
align-items: center;
}

@media screen and (max-width: 979px) {
.head-bar .menu {
display: none;
}
}
.head-bar .menu .list {
display: flex;
}
.head-bar .menu .list .li {
font-family: fot-tsukuardgothic-std, sans-serif;
font-weight: 700;
font-size: 1.6rem;
font-weight: bold;
letter-spacing: 0.2em;
line-height: 100%;
}
.head-bar .menu .list .u_arrow {
background-image: url("../img/common/arrow_under_icon.svg");
background-repeat: no-repeat;
background-position: center 68px;
}
.head-bar .menu .list .li a {
position: relative;
display: flex;
align-items: center;
height: 100px;
padding: 0 30px;
color: #000;
transition: all .1s;
}

.head-bar .menu .list .li a.is-on {
/*background-color: #f5f3ef;*/
/*background-image: url("../img/common/arrow_under_icon.svg");
background-repeat: no-repeat;
background-position: center 71px;
transition:none;*/
}
.lang_box {
width: 110px;
height: 100px;
background-color: #FFEF00;
margin-left: 27px;
}
.lang_box a {
width: 100%;
height: 100%;
display: flex;
align-items: center;
justify-content: center;
}
.lang_box:hover {
background-color: #FFDC2E;
}

/*マウスオーバーメニュー*/

.head-menu-sub {
position: absolute;
left: 0;
top: 100px;
width: 100%;
z-index: 3;
/*background-color: #f5f3ef;*/
background-color: rgba(0,0,0,0.7);
opacity: 0;
visibility: hidden;
transition: all .3s;
}
.head-menu-sub.is-on {
opacity: 1;
visibility: visible;
position: fixed;
z-index: 9999;
}
.head-menu-sub img {
max-width: 100%;
height: auto;
}
.head-menu-sub .container {
display: flex;
justify-content: flex-end;
width: 100%;
padding: 32px 0 26px;
}
.head-menu-sub .item {
position: relative;
display: block;
width: 175px;
margin: 0 22px;
line-height: 1.4;
}
.head-menu-sub .item:hover .fig {
display: block
}
.head-menu-sub .item:hover .fig img {
transform: scale(1.2, 1.2)
}
/*.head-menu-sub .item:hover .fig:after {
display: block;
z-index: 1;
opacity: 0;
}*/
.head-menu-sub .item:hover .label {
opacity: .5;
}
.head-menu-sub .item .fig {
position: relative;
overflow: hidden;
z-index: 1
}
.head-menu-sub .item .fig img {
transition: transform .6s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.head-menu-sub .item .fig:after {
content: "";
position: absolute;
left: 0;
top: 0;
width: 100%;
height: 100%;
background-color: #000;
opacity: .8;
z-index: -1;
transition: opacity 1.3s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.head-menu-sub .item .label {
position: relative;
font-family: fot-tsukuardgothic-std, sans-serif;
font-weight: 700;
color: #fff;
margin-top: .75em;
font-size: 1.4rem;
transition: all .2s;
z-index: 1;
}



/*-------------------------------------------------
	 pager
-------------------------------------------------*/

.pager {
 display: flex;
 align-items: center;
 justify-content: center;
 margin-top: 60px;
 text-align: center;
}
.pager > * {
 margin: 0 5px;
 padding: 8px 14px;
 font-family: 'Barlow', sans-serif;
	font-weight: 400;
 color: #333;
 text-align: center;
}
.pager a {
 background-color: #fff;
 border: 1px solid #ddd;
}
.pager a:hover, .pager span {
 background-color: #111;
 color: #fff !important;
}
.pager span {
 display: flex;
 align-items: center;
}
.pager span.pn, .pager span.previous, .pager > span.next {
 padding: 0 2px;
 background: transparent !important;
 border: none;
 color: #333 !important;
}
.pager span.previous a:hover, .pager span.next a:hover {
 color: #5F5C07 !important;
}
.pager span.pn a, .pager span.previous a, .pager span.next a {
 position: static;
 display: inline-block;
 padding: 5px 0;
 color: #333 !important;
 background: transparent !important;
 border: none;
 font-size: 1.2rem;
}
@media screen and (max-width:767px) {
 .pager {
  margin-top: 30px;
 }
 .pager > * {
  margin: 0 2px 0;
  padding: 4px 10px;
 }
 .pager a, .pager span {
  font-size: 1.2rem;
 }
 .pager span.pn a, .pager span.previous a, .pager span.next a {
  display: inline-block;
  padding: 10px 0;
  position: static;
  border: none;
  background: transparent !important;
 }
}


/*-------------------------------------------------
page top
-------------------------------------------------*/

.page_top {
width: 45px;
height: 45px;
position: fixed;
right: 20px;
bottom: 80px;
background: #777D85;
opacity: 0.9;
z-index: 999;
}
.page_top a{
position: relative;
display: block;
width: 45px;
height: 45px;
text-decoration: none;
}
.page_top a::before{
font-family: 'Font Awesome 5 Free';
font-weight: 700;
content: '\f106';
font-size: 17px;
color: #fff;
position: absolute;
width: 30px;
height: 30px;
top: 0px;
bottom: 0;
right: 0;
left: 0;
margin: auto;
text-align: center;
}


/*-------------------------------------------------
btn
-------------------------------------------------*/

/* ボタン共通設定 */
.link_btn {  
position: relative; /*矢印の基点とするためrelativeを指定*/
font-family: fot-tsukuardgothic-std, sans-serif;
font-size: 1.6rem;
font-weight: 700;
text-decoration: none; /*ボタンの形状*/
display: inline-block;
color:#111;
padding: 20px 100px 20px 100px;
border: 1px solid #45403f;
border-radius:50px;
text-align: center;
outline: none;
transition: ease .3s; /*アニメーションの指定*/
}
.link_btn_s {  
position: relative; /*矢印の基点とするためrelativeを指定*/
font-family: fot-tsukuardgothic-std, sans-serif;
font-size: 1.3rem;
font-weight: 700;
text-decoration: none; /*ボタンの形状*/
display: inline-block;
color:#111;
padding: 10px 50px 10px 50px;
border: 1px solid #45403f;
border-radius:50px;
text-align: center;
outline: none;
transition: ease .3s; /*アニメーションの指定*/
}
.link_btn:hover {
background:#FFEF00;
border: 1px solid #FFEF00;
transition: ease .3s;
}
.btn_arrow::after{ /* 矢印が右に移動して現在地に戻る */
content: '';
position: absolute;/*絶対配置で矢印の位置を決める*/
top:42%;
right: 20px;
width: 8px; /*矢印の形状*/
height: 8px;
border-top: 1px solid #000;
border-right: 1px solid #000;
transform: rotate(45deg);
transition: ease .3s;
}
.btn_arrow_s::after { /* 矢印が右に移動して現在地に戻る */
content: '';
position: absolute;/*絶対配置で矢印の位置を決める*/
top:42%;
right: 20px;
width: 6px; /*矢印の形状*/
height: 6px;
border-top: 1px solid #000;
border-right: 1px solid #000;
transform: rotate(45deg);
transition: ease .3s;
}
.btn_arrow:hover::after,
.btn_arrow_s:hover::after { /*hoverした際のアニメーション*/
right: 15px;
transition: .3s;
}
.link_btn_box {
display: flex;
justify-content: center;
}


/*-------------------------------------------------
モジュールパーツ
-------------------------------------------------*/

/*ボタンマウスオーバー*/

.pic {
overflow: hidden;	/*拡大時にはみ出た部分を隠す*/
background: #000;
}
.pic img {
width: 100%;
height: auto;
display: block;
transition-duration: 0.5s;	/*変化に掛かる時間*/
}
.pic img:hover {
transform: scale(1.05);	/*画像の拡大率*/
transition-duration: 0.5s;	/*変化に掛かる時間*/
opacity: 0.7;	/* 小さくするほど暗くなります */
}

/*-------------------------------------------------
Footer
-------------------------------------------------*/

footer {
background-color: #3B4043;
}
.sponsor_sec {
width: 100%;
padding: 30px 0 60px;
background-color: #F7F7F7;
}
.sponsor_sec_inner {
max-width: 1200px;
margin: 0 auto;
}
.sponsor_title {
font-family: fot-tsukuardgothic-std, sans-serif;
font-weight: 700;
font-size: 1.8rem;
line-height: 100%;
margin: 0 0 25px 0px;
}
.swiper_sponsor {
width: 100%;
position: relative;
}

.swiper_sponsor .swiper-wrapper .swiper-slide {
max-width: 170px;
max-height: 170px;

}
.swiper_sponsor .sponsor_img {
border: 1px solid #ddd;
}
.swiper_sponsor .swiper-wrapper .swiper-slide a:hover {
opacity: 0.8;
}
.foot_info_sec {
max-width: 1260px;
padding: 70px 0 20px;
margin: 0 auto;
}
.foot_banner {
max-width: 1180px;
margin: 0 auto 50px;
display: flex;
flex-wrap: wrap;
}
.foot_banner li {
width: calc(25% - 60px / 4);
margin-right: 20px;
}
.foot_banner li:nth-child(4) {
margin-right: 0px;
}
.foot_banner li a:hover {
opacity: 0.8;
}
.foot_credit_sec {
max-width: 1260px;
padding: 40px 20px 0 30px;
border-top: solid 1px #525C61;
color: #fff;
display: flex;
justify-content: space-between;
}
.foot_logo {
max-width: 290px;
height: auto;
margin-bottom: 30px;
}
.foot_logo img {
width: 100%;
}
.foot_contact_title {
font-size: 1.0rem;
font-family: quicksand, sans-serif;
font-weight: 700;
letter-spacing: 0.2em;
line-height: 100%;
display: block;
margin-bottom: 15px;
}
.foot_address {
font-size: 1.2rem;
margin-bottom: 40px;
letter-spacing: 0.2em;
display: block;
}
.foot_address a {
text-decoration: underline;
}
.foot_address a:hover {
text-decoration: none;
}
.copyright {
font-size: 1.0rem;
font-family: quicksand, sans-serif;
font-weight: 400;
}
.sns_wrap {
display: flex;
align-items: center;
margin-top: 20px;
}
.sns_title {
font-size: 1.0rem;
font-family: quicksand, sans-serif;
font-weight: 400;
}
.sns_icon {
display: flex;
align-items: center;
}
.sns_icon li {
margin-left:20px; 
height: 22px;
}

/*-------------------------------------------------
ページトップ
-------------------------------------------------*/

.page_top {
width: 50px;
height: 50px;
position: fixed;
right: 20px;
bottom: 80px;
background: #FFEF00;
opacity: 0.9;
border-radius: 50%;
z-index: 999;
}
.page_top a{
position: relative;
display: block;
width: 50px;
height: 50px;
text-decoration: none;
}
.page_top a::before{
font-family: 'Font Awesome 5 Free';
font-weight: 700;
content: '\f106';
font-size: 16px;
color: #000;
position: absolute;
width: 30px;
height: 30px;
top: 0px;
bottom: 0;
right: 0;
left: 0;
margin: auto;
text-align: center;
}


/*-------------------------------------------------
タブレット(768px ～横幅 1024pxまで)
-------------------------------------------------*/

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

.sponsor_title {
font-size: 1.6rem;
margin: 0 0 25px 20px;
}
.swiper_sponsor {
width: 95%;
}
.swiper_sponsor .swiper-wrapper .swiper-slide {
max-width: 150px;
max-height: 150px;

}
.foot_banner {
padding: 0 20px;
}
}


/*-------------------------------------------------
Footer切り替えポイント
-------------------------------------------------*/

@media all and (max-width : 896px ){

}

/*-------------------------------------------------
スマートフォン
-------------------------------------------------*/

@media all and (max-width : 767px ){

/*-------------------------------------------------
basic layout 
-------------------------------------------------*/

main {
width: 100%;
}
.box {
margin: 50px 0 30px;
}
.box_s {
max-width: 980px;
margin: 0 auto;
}
.box_m {
max-width: 1260px;
margin: 0 auto;
}
.box_l {
width: 100%;
}


/*-------------------------------------------------
btn
-------------------------------------------------*/

.link_btn {  
font-size: 1.2rem;
font-weight: 700;
padding: 10px 40px 10px 40px;
}
.btn_arrow::after{ 
top:45%;
right: 20px;
width: 6px; /*矢印の形状*/
height: 6px;
}

.head_logo {
max-width: 90px;
}

/*-------------------------------------------------
Footer
-------------------------------------------------*/


.sponsor_sec {
padding: 20px 0 30px;
}
.sponsor_title {
font-size: 1.4rem;
margin: 0 0 20px 10px;
}
.swiper_sponsor {
width: 95%;
}
.swiper_sponsor .swiper-wrapper .swiper-slide {
max-width: 140px;
max-height: 140px;
}
.foot_info_sec {
padding: 20px 20px 15px 20px;
}
.foot_banner {
margin: 0 auto 20px;
}
.foot_banner li {
width: calc(50% - 10px / 2);
margin-right: 10px;
margin-bottom: 10px;
}
.foot_banner li:nth-child(2n) {
margin-right: 0px;
}

.foot_credit_sec {
padding: 20px 0px 0 0px;
display: flex;
flex-direction: column;
align-items: center;
}
.foot_credit_left {
width: 100%;
display: flex;
flex-direction: column;
align-items: center;
}
.foot_logo {
max-width: 180px;
height: auto;
margin-bottom: 20px;
}

.foot_contact_title {
font-size: 1.0rem;
margin-bottom: 15px;
}
.foot_address {
font-size: 1.0rem;
margin-bottom: 20px;
line-height: 200%;
text-align: center;
}

.sns_wrap {
display: none;
}


/*-------------------------------------------------
ページトップ
-------------------------------------------------*/

.page_top {
width: 40px;
height: 40px;
position: fixed;
right: 10px;
bottom: 60px;
}
.page_top a{
width: 40px;
height: 40px;
}
.page_top a::before{
top: 1px;
}




}