@charset "UTF-8";
/* CSS Document */

/*
セクション間余白
----------------------------------------------------------- */
section {padding: 45px 0;}
.mv {padding: 0;}
.index .sec01 {padding: 45px 0 0;}
.index .sec02 {padding: 15px 0 45px;}
.index .sec03 {padding: 45px 0;}
.index .movie {padding: 45px 0 0;}
footer {padding: 45px 0;}
/*
news
----------------------------------------------------------- */
.news .sec01 {padding:0 0 45px}
/*
event
----------------------------------------------------------- */
.event .sec01 {padding:0}
.event .sec02 {padding: 45px 0 0;}
.event .sec03 {padding: 45px 0 0;}
.event .sec04 {padding: 45px 0 0;}
.event .sec05 {padding: 45px 0 0;}
.event .sec06 {padding: 45px 0 0;}
.event .sec07 {padding: 45px 0 0;}
.event .sec08 {padding: 45px 0 0;}
.event .sec09 {padding: 45px 0 0;}
.event .sec10 {padding: 45px 0 0;}
.event .sec11 {padding: 45px 0 0;}
.event .sec12 {padding: 45px 0 0;}
.event .sec13 {padding: 45px 0 0;}
.event .sec14 {padding: 45px 0;}
/*
sports
----------------------------------------------------------- */
.sports .sec01 {padding: 45px 0 0;}
.sports .sec02 {padding: 45px 0 0;}
.sports .sec03 {padding: 45px 0 0;}
.sports .sec04 {padding: 45px 0 0;}
.sports .sec05 {padding: 45px 0 0;}
.sports .sec06 {padding: 45px 0 0;}
.sports .sec07 {padding: 45px 0 0;}
.sports .sec08 {padding: 45px 0 0;}
.sports .sec09 {padding: 45px 0 0;}
.sports .sec10 {padding: 45px 0 0;}
.sports .sec11 {padding: 45px 0 0;}
.sports .sec12 {padding: 45px 0 0;}
.sports .sec13 {padding: 45px 0 0;}
.sports .sec14 {padding: 45px 0;}
/*
色関連
----------------------------------------------------------- */
.bg_cl1{background-color: #eeeef5;}
.bg_cl2{background-color: #f3f2f2;}
.cl_base{color: #fab300;}
.cl_main{color: #ef3300;}
.cl_accent{color: #4265a1;}
.cl_other1{color: #4265a1;}
.cl_other2{color: #4265a1;}

/*
テキスト関連
----------------------------------------------------------- */
.highlight {
    background: -webkit-linear-gradient(transparent 60%, #fff100 50%);
    background: -o-linear-gradient(transparent 60%, #fff100 50%);
    background: linear-gradient(transparent 60%, #fff100 50%);
    font-weight: bold;
}
.new {
    background: #fab300;
    color: #fff;
    margin-left: 10px;
    padding: 0 5px;
    border-radius: 5px;
}
.blink {
    -webkit-animation: blink 1.5s ease infinite;
    animation: blink 1.5s ease infinite;
}
@-webkit-keyframes blink {
    0% {opacity: 0;}
    100% {opacity: 1;}
}
@keyframes blink {
    0% {opacity: 0;}
    100% {opacity: 1;}
}
/*
リンク色
----------------------------------------------------------- */
a:link,
a:visited {
    color:#493310;
    text-decoration:none;
}
/*
はみ出し画像中央
----------------------------------------------------------- */
.wic {
    margin-left: calc(50% - 1000px);
}
.wic img {
    width: auto;
    max-width: unset;
}
.wic1 {
    margin-left: calc(50% - 1000px);
/*pxの部分を画像の半分の幅に変えてね！*/
}
.wic2 {
    margin-left: calc(50% - 600px);
}
.wic3 {
    margin-left: calc(50% - 800px);
}
main img {
    border-radius: 8px;
}

/*
loading
----------------------------------------------------------- */
.loader-container {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background-image: url(../img/loading-bg.webp);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 9999; /* 最前面に表示 */
    transition: opacity 0.8s ease, visibility 0.8s ease;
}
.loader-content {
    text-align: center;
}
.loader-logo {
    max-width: 300px;
    margin-bottom: 20px;
    animation: recordSpin 10s infinite;
}
.loader-text {
    font-size: 2.4rem;
    color: var(--color-primary-darkest);
    font-weight: bold;
    letter-spacing: 0.1em;
}
/* ロゴのアニメーション */
@keyframes recordSpin {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}
.loader-hidden {
opacity: 0;
visibility: hidden;
}

/*
swiper
----------------------------------------------------------- */

.swiper {
    overflow: hidden;
    position: relative;
}

.swiper-slide {
    transition: filter 0.3s ease, opacity 0.3s ease;
    border-radius: 8px;
}

.swiper-slide:hover {
    filter: brightness(1.05);
    opacity: 0.9;
}

/* カスタムナビゲーションボタン */
.swiper-button-next, 
.swiper-button-prev {
    color: #fab300;
}

.swiper-button-next:after, 
.swiper-button-prev:after {
    display: none;
}

.swiper-button-prev {
    background-image: url('../img/tsunopyon_l.png');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    width: 30px;
    height: 30px;
}

.swiper-button-next {
    background-image: url('../img/tsunopyon_r.png');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    width: 30px;
    height: 30px;
}

/* カスタムページネーション */
.swiper-pagination-bullet {
    background: #fab300;
    opacity: 0.5;
}

.swiper-pagination-bullet-active {
    opacity: 1;
    background: #fab300;
}

/* Header Adjustments */
header {
    position: relative; /* nav_toggle のfixed配置の基準にならないように */
    z-index: 999; /* 他の要素より手前に来るように調整 */
}

header .container {
    position: relative; /* nav_toggle が absolute の場合の基準 */
}

/* Hide original header SNS icons on PC, keep on SP if needed */
@media (min-width: 768px) {
    header .original_header_sns_icons {
        display: none;
    }
}
@media (max-width: 767px) {
    /* SPではナビゲーション内のSNSアイコンを非表示にする場合（重複を避けるため） */
    /* nav .nav_icon_list { display: none; } */
    /* もしSPでもナビゲーション内にSNSアイコンを表示するなら上記は不要 */
}

/* Navigation Toggle Button */
.nav_overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(65, 41, 6, 0.5); /* 半透明の黒 */
    z-index: 99; /* ナビゲーションより下、コンテンツより上 */
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.35s cubic-bezier(0.25, 0.46, 0.45, 0.94), 
                visibility 0.35s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* ナビゲーション開いた時のオーバーレイ表示 */
body.nav_open .nav_overlay {
    opacity: 1;
    visibility: visible;
}

/* Navigation Toggle Button */
#nav_toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    position: fixed;
    top: 15px;
    right: 15px;
    width: 50px;
    height: 50px;
    background-color: #fff;
    border-radius: 50%;
    box-shadow: 0 2px 4px rgba(0,0,0,0.15);
    z-index: 1001; /* オーバーレイより上 */
    cursor: pointer;
    transition: background-color 0.3s;
}

#nav_toggle div {
    position: relative;
    width: 24px;
    height: 24px;
}

#nav_toggle span {
    display: block;
    height: 3px;
    background: #fab300;
    position: absolute;
    width: 100%;
    left: 0;
    transition: all 0.3s ease-in-out;
    border-radius: 3px;
}

#nav_toggle span:nth-child(1) {
    top: 5px;
}

#nav_toggle span:nth-child(2) {
    top: 11px;
}

#nav_toggle span:nth-child(3) {
    top: 17px;
}

/* ナビゲーション開いた時のハンバーガーメニュー変化 */
header.open #nav_toggle span:nth-child(1) {
    top: 11px;
    transform: rotate(135deg);
}

header.open #nav_toggle span:nth-child(2) {
    opacity: 0;
    transform: translateX(-10px);
}

header.open #nav_toggle span:nth-child(3) {
    top: 11px;
    transform: rotate(-135deg);
}

/* Navigation Menu */
nav {
    position: fixed;
    top: 0;
    left: 0;
    width: 280px;
    max-width: 60%;
    height: 100vh;
    background-color: var(--color-primary-light);
    transform: translateX(-100%);
    transition: transform 0.35s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    z-index: 1000; /* オーバーレイより上、トグルボタンより下 */
    overflow-y: auto;
}

nav::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: url(../img/aside-bg.webp);
    background-size: cover;
    opacity: 0.9;
    z-index: -1;
}

.logo {
    padding: 15px;
}

nav.open_nav {
    transform: translateX(0);
    box-shadow: 4px 0px 10px rgba(0,0,0,0.2);
}

nav ul.nav_menu_container {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
}

nav ul.nav_menu_container > li {
    width: 100%;
    border-bottom: 1px solid #fff;
}

nav ul.nav_menu_container > li > a {
    display: block;
    padding: 18px 25px;
    color: #493310;
    text-decoration: none;
    font-weight: bold;
    font-size: 1.6rem;
    transition: background-color 0.2s, padding-left 0.2s;
}

nav ul.nav_menu_container > li > a:hover {
    background-color: #ffbd44b0;
    padding-left: 30px;
    opacity: 1;
}

nav .nav_jp {
    padding-bottom: 0;
}

/* Navigation SNS Icons */
nav .nav_icon_list {
    display: flex;
    justify-content: center;
    padding: 10px;
}

nav .nav_icon_list li {
    border-bottom: none;
    margin: 0 12px;
    width: auto;
}

nav .nav_icon_list li a {
    font-size: 2em;
    color: #493310;
    transition: all 0.2s ease-in-out;
}

nav .nav_icon_list li a:hover {
    background-color: transparent;
    color: #ff9d00;
    padding-left: 5px;
}

/*
left-area
----------------------------------------------------------- */
.left-area {
    position: fixed;
    top: 0;
    left: 0;
    width: 40%;
    height: 100%;
    z-index: -1;
}
.left-area-bg {
    width: 100%;
    height: 100%;
    background-image: url(../img/aside-bg.webp);
    background-size: cover;
    background-position: 0 0;
    background-repeat: no-repeat;
}

.left-area video {
    display: block;
    max-width: 100%;
    margin: 0 auto;
    height: 100vh;
}
.movie video {
    display: block;
    max-width: 100%;
    margin: 0 auto;
    height: auto;
}
.mv video {
    display: block;
    max-width: 100%;
    margin: 0 auto;
    height: auto;
}

/*
right-area
----------------------------------------------------------- */
.right-area {
    width: 60%;
    height: 100%;
    margin-left: auto;
}

/*
MV
----------------------------------------------------------- */
.mv {
    padding: 0;
}
.mv .container {
    padding: 0;
    position: relative;
}
.mv img {
    border-radius: 0;
}
.movie {
    padding: 0;
}
.icon_item{
    width: 130px;
    height: 130px;
    background-image: url(../img/left.gif);
    background-size: contain;
    display: block;
    filter: drop-shadow(2px 2px 2px rgba(61, 102, 85, 0.8));
}
.icon_wrap{
    display: block;
    position: absolute;
    bottom: -15px;
    animation-fill-mode: forwards;
    animation-timing-function: linear;
    animation-duration: 10s;
    animation-iteration-count: 1;
    margin-right: -80px;
    z-index: 2;
}
.icon_wrap[data-order="left"] {
    animation-name: GoLeft;
}
.icon_wrap[data-order="right"] {
    animation-name: GoRight;
}
[data-order="right"] > .icon_item {
    background-image: url(../img/right.gif);
}
@keyframes GoLeft {
    0% {
        right: 15%;
    }
    100% {
        right: 85%;
    }
}
@keyframes GoRight {
    0% {
        right: 85%;
    }
    100% {
        right: 15%;
    }
}
@media (min-width: 768px) and (max-width: 959px) {
    .icon_wrap{
        margin-right: -80px;
        animation-duration: 6s;
    }
}
@media screen and (max-width: 767px){
    .icon_wrap{
        margin-right: -70px;
        animation-duration: 4s;
    }
    .icon_item{
        width: 100px;
        height: 100px;
    }
}

/*
sec01
----------------------------------------------------------- */
.ovfhdn {
    overflow: hidden;
}
.head_ttl {
    background: #fffbea;
    padding: 45px 0 15px;
    margin-bottom: 45px;
}
.head_ttl .cmn_ttl_ja {
    margin-bottom: 30px;
}

/*
sec02
----------------------------------------------------------- */
.cmn_ttl_en {
    font-size: 4rem;
    font-weight: bold;
    text-align: center;
}
.cmn_ttl_ja {
    text-align: center;
    padding-bottom: 15px;
    position: relative;
    margin-bottom: 45px;
}
.cmn_ttl_ja:after {
    content: "";
    background: -webkit-linear-gradient(to right, #fab300, #ffea92);
    background: linear-gradient(to right, #fab300, #ffea92);
    position: absolute;
    left: 40%;
    bottom: 0;
    width: 20%;
    height: 3px;
}
.index .sec02 .sec02_ttl {
    border-top: 1px solid #ce9300;
    border-bottom: 1px solid #ce9300;
    color: #ce9300;
    text-align: center;
    padding: 5px 15px;
    z-index: 1;
    position: relative;
    margin: 30px 0;
    font-weight: bold;
    font-size: 1.2em;
}
.index .sec02 .sec02_ttl > span {
    position: relative; /* テキストを背景より手前にするため */
    z-index: 2;
}
.index .sec02 .sec02_ttl::before { 
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    width: 0;
    height: 100%;
    background-color: #fffbea;
    z-index: 0;
    transition: width 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.2s;
}
.index .sec02 .sec02_ttl.is-inview::before {
    width: 100%;
}

/* sec03
----------------------------------------------------------- */
.index .sec03 {
    position: relative;
}
.index .sec03::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
    background-image: url(../img/top-news-img01.webp);
    background-size: cover;
    background-position: center center;
    background-attachment: fixed;
    opacity: 0.2;
    background-color: rgba(255, 251, 234, 0.7);
}
.index .sec03::after { 
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%; 
    z-index: -1;
    /* 上から下への透過グラデーション（例：上部が濃い白で徐々に透明に） */
    background: linear-gradient(
        to bottom,
        rgba(255, 251, 234, 1) 0%,
        rgba(255, 251, 234, 0.8) 30%,
        rgba(255, 251, 234, 0.6) 60%,
        rgba(255, 251, 234, 0) 100%
    );
}
.index .sec03 img {
    border-radius: 0px;
}
.news_list {
    padding-bottom: 30px;
    max-width: 90%;
    margin: 0 auto;
}
.news_content {
    padding: 15px;
    border-bottom:  1px solid #ccc;
    transition: transform 0.3s ease-in-out, box-shadow 0.3s ease-in-out;
    position: relative;
}
.news_content:nth-child(1) {
    border-top: 1px solid #ccc;
}
.news_content:hover {
    transform: translateY(-5px); /* 少し上に浮き上がる */
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.1); /* 立体感を出す影 */
}
.news_content a {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    text-decoration: none;
    color: inherit; 
}
.news_date {
    padding-top: 2px;
    font-size: 90%;
    color: #666;
    flex: 0 0 130px;
    width: 130px;
    max-width: 130px;
}
.news_category {
    display: flex;
    justify-content: center;
    align-items: center;
    border: 1px solid #ce9300; /* メインカラー */
    height: 20px;
    line-height: 1;
    color: #ce9300; /* メインカラー */
    font-size: 1rem;
    margin-right: 15px;
    width: 130px;
    max-width: 130px;
}
.news_ttl {
    font-weight: bold;
    flex-grow: 1; /* 残りのスペースを埋めるように */
    transition: color 0.3s ease-in-out;
}
.news_content:hover a .news_ttl {
    color: #ce9300; /* メインカラー */
}
.news_btn {
    display: flex;
    justify-content: center;
}
.news_btn_inner {
    display: inline-flex; /* アイコンとテキストの整列のため */
    align-items: center;
    justify-content: center;
    font-size: 1.4rem; /* 既存 */
    font-weight: bold; /* 追加して少し強調 */
    text-decoration: none; /* 既存 */
    color: #ce9300; /* メインカラー */
    background-color: #ffffff; /* 背景は白 */
    border: 1px solid #ce9300; /* メインカラーのボーダー (太さを2pxに) */
    padding: 10px 30px; /* 上下は既存の15px、左右を広げてボタンらしさを強調 */
    border-radius: 5px; /* 角を丸くしておしゃれに */
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1); /* スムーズな変化 */
    position: relative; /* transformや疑似要素のため */
    overflow: hidden; /* はみ出し防止 */
}
.news_btn_inner .cl_base {
    margin-right: 10px; /* アイコンとテキストの間隔を少し広めに */
    display: inline-flex;
    align-items: center;
    color: #ce9300;
}
.news_btn_inner .cl_base i {
    transition: transform 0.3s ease-in-out;
}

/* ボタンホバー時のエフェクト */
.news_btn_inner:hover {
    background-color: #ce9300; /* メインカラーで塗りつぶし */
    color: #fff; /* 文字色を白に */
    transform: translateY(-3px) scale(1.03); /* 少し浮き上がり、わずかに拡大 */
    box-shadow: 0 6px 15px rgba(194, 145, 22, 0.35);
}
.news_btn_inner:hover .cl_base {
    color: #fff; /* アイコンの色も白に */
}
.news_btn_inner:hover .cl_base i {
    transform: translateX(5px); /* アイコンが少し右に動く */
}
.news_btn_inner:active {
    transform: translateY(-1px) scale(1.01); /* ホバーより少し控えめに */
    box-shadow: 0 3px 5px rgba(250, 179, 0, 0.25); /* 影も少し控えめに */
}
.sec03-pa-img {
    position: absolute;
    z-index: -1;
}
.pa-img-01 {
    bottom: 0;
    right: 15px;
    width: 20%;
}
.pa-img-02 {
    bottom: -30px;
    left: 15px;
    width: 20%;
}
/*
sec04
----------------------------------------------------------- */
.index .sec04{
    position: relative;
}
.index .sec04 .wave_bg {
    position: absolute;
    bottom: 0;
    z-index: -1;
    width: 100%;
}
.timelag > use {
    animation: wave 25s cubic-bezier(.55,.5,.45,.5) infinite;
}
.timelag > use:nth-child(1) {
    animation-delay: -2s;
    animation-duration: 7s;
}
.timelag > use:nth-child(2) {
    animation-delay: -3s;
    animation-duration: 10s;
}
.timelag > use:nth-child(3) {
    animation-delay: -4s;
    animation-duration: 13s;
}
.timelag > use:nth-child(4) {
    animation-delay: -5s;
    animation-duration: 20s;
}
@keyframes wave {
    0% {
        transform: translate3d(-90px,0,0);
    }
    100% { 
        transform: translate3d(85px,0,0);
    }
}

/*
sec05
----------------------------------------------------------- */


/*
Footer
----------------------------------------------------------- */
footer{
    color:#FFF;
    font-size:16px;
    background-color: #3b3b3b;
}
footer .copy {
    text-align: center;
}
footer a{
    color: #FFF;
}
footer a:hover, footer a:focus {
    color: #FFF;
}
footer ul li{
    display: inline-block;
    margin: 0 5px;
    white-space: nowrap;
}
footer .copy{
    font-size: 90%;
}

/*
qreはここから
----------------------------------------------------------- */

/*
sec01
----------------------------------------------------------- */
.qre .sec01 {
    padding: 0;
}
.qre .sec01 iframe {
    height: 1000px;
}
.qre .sec01 .qre_box {
    margin-bottom: 45px;
}
.qre .sec01 .top_btn {
    display: flex;
    justify-content: center;
    margin-bottom: 45px;
}
.qre .sec01 .top_btn_inner {
    font-size: 1.4rem;
    text-decoration: none;
    border: 1px solid #ccc;
    padding: 15px;
}

/*
postはここから
----------------------------------------------------------- */

/*
sec01
----------------------------------------------------------- */
.post .sec01 {
    padding: 0;
}
.post .sec01 iframe {
    height: 1000px;
}
.post .sec01 .post_box {
    margin-bottom: 45px;
}
.post .sec01 .top_btn {
    display: flex;
    justify-content: center;
    margin-bottom: 45px;
}
.post .sec01 .top_btn_inner {
    font-size: 1.4rem;
    text-decoration: none;
    border: 1px solid #ccc;
    padding: 15px;
}

/*
newsはここから
----------------------------------------------------------- */

/*
sec01
----------------------------------------------------------- */


/*
newslistはここから
----------------------------------------------------------- */

/*
sec01
----------------------------------------------------------- */
.newsitem .sec01 {
    padding: 0;
}
.newsitem .sec01 .newsitem_top_img{
    float: right;
    padding: 0 0 30px 30px;
}
.newsitem .sec01 h3 {
    font-size: 1.5em;
    font-weight: bold;
    border-left: 5px solid #fab300;
    padding-left: 15px;
    margin-bottom: 45px;
}
.newsitem .sec01 .newsitem_txt {
    padding-bottom: 45px;
}
.newsitem .sec01 .sec01_btn {
    display: flex;
    justify-content: center;
}
.newsitem .sec01 .newsitem_btn {
    background: #fab300;
    color: #FFF;
    border-radius: 30px;
    font-size: 1.2em;
    font-weight: bold;
    text-align: center;
    padding: 5px 0;
    position: relative;
    text-decoration: none;
    width: 290px;
}
.newsitem .sec01 .newsitem_btn::after {
    content: "\f138";
    font-family: "Font Awesome 6 Free";
    font-weight: bolder;
    color: #fff;
    position: absolute;
    right: 10px;
    top: 5px;
}
.newsitem .sec01 .news_btn {
    display: flex;
    justify-content: center;
    margin-bottom: 45px;
}
.newsitem .sec01 .news_btn_inner {
    font-size: 1.4rem;
    text-decoration: none;
    border: 1px solid #ccc;
    padding: 15px;
}

/*
eventはここから
----------------------------------------------------------- */
.event {
    position: relative;
}
.event .ev_btn {
    position: relative;
    text-align: center;
    padding: 5px 15px;
    border-radius: 5px;
    color: #fff;
    background-image: -webkit-gradient(
        linear,
        left top,
        right top,
        from(#fab300),
        to(#dbbf79)
    );
    background-image: -webkit-linear-gradient(left, #fab300 0%, #f9d423 100%);
    background-image: linear-gradient(to right, #fab300 0%, #f9d423 100%);
    box-shadow: 0 2px 5px #996e004f;
}
.event .ev_btn:before {
    position: absolute;
    top: 50%;
    right: -15px;
    width: 25px;
    height: 1px;
    content: "";
    transition: all 0.3s;
    background: #fab300;
}
.event .ev_btn:after {
    position: absolute;
    top: 41%;
    right: -15px;
    width: 9px;
    height: 1px;
    transform: rotate(35deg);
    content: "";
    transition: all 0.3s;
    background: #fab300;
}
.event .ev_btn:hover {
    scale: 1.05;
    -webkit-transition: all 0.2s;
    transition: all 0.2s;
    color: #996e00;
    background-image: linear-gradient(to right, #fff 0%, #fff 100%);
    box-shadow: 0 2px 5px #996e004f;
}
.event .ev_btn:hover:before {
    right: -30px;
    background: #fff;
}
.event .ev_btn:hover:after {
    right: -30px;
    background: #fff;
}
.event .event_bg_inner {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    clip-path: inset(0);
    z-index: -1;
}
.event .event_bg {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-image: url(../img/bg_ev_img01.webp);
    background-size: cover;
    background-position: center;
}

/*
sec01
----------------------------------------------------------- */
.event .sec01 a {
    opacity: 1;
}
.event .sec01 .sec01_btn {
    position: relative;
    text-align: center;
    font-weight: bold;
    font-size: 1.2em;
    padding: 5px 0;
    border-radius: 5px;
    color: #fff;
    background-image: -webkit-gradient(
        linear,
        left top,
        right top,
        from(#fab300),
        to(#dbbf79)
    );
    background-image: -webkit-linear-gradient(left, #fab300 0%, #f9d423 100%);
    background-image: linear-gradient(to right, #fab300 0%, #f9d423 100%);
    -webkit-box-shadow: 0 2px 5px #996e004f;
    box-shadow: 0 2px 5px #996e004f;
}
.event .sec01 .sec01_btn:before {
    position: absolute;
    top: 50%;
    right: -5px;
    width: 40px;
    height: 1px;
    content: "";
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    background: #fab300;
}
.event .sec01 .sec01_btn:after {
    position: absolute;
    top: 41%;
    right: -5px;
    width: 15px;
    height: 1px;
    transform: rotate(35deg);
    content: "";
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    background: #fab300;
}
.event .sec01 .sec01_btn:hover {
    scale: 1.05;
    -webkit-transition: all 0.2s;
    transition: all 0.2s;
    color: #fff;
    background-image: -webkit-linear-gradient(left, #fa8e00 0%, #ffad42 100%);
    background-image: linear-gradient(to right, #fa8e00 0%, #ffad42 100%);
    -webkit-box-shadow: 0 2px 5px #996e004f;
    box-shadow: 0 2px 5px #996e004f;
}
.event .sec01 .sec01_btn:hover:before {
    right: -15px;
    background: #cc7400;
}
.event .sec01 .sec01_btn:hover:after {
    right: -15px;
    background: #cc7400;
}

/*
sec02
----------------------------------------------------------- */
.event .sec_head_ttl {
    position: relative;
    padding: 20px 0;
    font-size: 2.5em;
    text-align: center;
    background: #cc7400;
    color: #fff;
    margin-bottom: 45px;
}
.event .sec_head_ttl::before {
    content: attr(data-en);
    position: absolute;
    top: -20px;
    right: 30px;
    color: rgba(255, 255, 255, 0.1);
    font-size: 2em;
    font-style: italic;
}
.event .ev_box {
    background: #fff;
    padding: 30px;
    border-radius: 10px;
    -webkit-box-shadow: 0 2px 5px #996e004f;
    box-shadow: 0 2px 5px #996e004f;
}
.event .pickup {
    background: #f9ff9f;
}
.event .pickup {
    position: relative;
}
.event .pickup::before {
    position: absolute;
    display: inline-block;
    content: 'PICK UP';
    font-size: 0.5em;
    bottom: 15px;
    right: 15px;
    line-height: 50px;
    text-align: center;
    font-weight: bold;
    background: #cc7400;
    color: #fff100;
    width: 50px;
    height: 50px;
    border-radius: 50%;
}
.event .pickup:hover::before {
    background: #fff100;
    color: #cc7400;
}
.event .ev_box:hover {
    background: #cc7400;
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
    color: #fff;
    scale: 1.02;
}
.event .ev_box:hover .ev_inner_day{
    color: #fff;
}
.event .ev_inner_item {
    display: flex;
    justify-content: space-between;
}
.event .ev_inner_day {
    font-size: 2.5em;
    color: #cc7400;
    font-weight: bold;
    line-height: 1;
}
.event .ev_inner_img {
    width: 100px;
    height: 100px;
    -webkit-box-shadow: 2px 2px 5px #996e004f;
    box-shadow: 2px 2px 5px #996e004f;
}
.event .ev_box:hover .ev_inner_img {
    -webkit-box-shadow: 2px 2px 5px #3325004f;
    box-shadow: 2px 2px 5px #3325004f;
}
.event .ev_inner_day_ja {
    font-size: 0.5em;
}
.event .ev_txt_area {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
.event .event_ttl {
    font-weight: bold;
    font-size: 1.2em;
    position: relative;
    border-bottom: solid 1px #b8b8b8;
    margin-bottom: 15px;
}
.event .event_ttl::after {
    content: " ";
    display: block;
    border-bottom: solid 1px #fab300;
    position: absolute;
    width: 50%;
}
.event .ev_cont_ttl {
    padding: 5px 15px;
    background: #fab300;
    margin-right: 15px;
}
.event .ev_box:hover .ev_cont_ttl {
    background: #fff100;
    color: #cc7400;
}
.event .cl_event {
    color: #4265a1;
}
.event .ev_box:hover .cl_event {
    color: #fff100;
}

/*
sportsはここから
----------------------------------------------------------- */

/*
sec01
----------------------------------------------------------- */
.sports .sec01 {
    padding: 0;
}
.sports .ctg_ttl {
    font-size: 1.3em;
    font-weight: bold;
    text-align: center;
    background: #cdffe6;
    padding: 5px 15px;
    border-top: dotted 1px #65d49d;
    border-bottom: dotted 1px #65d49d;
    color: #145334;
}
.sports .ctg_btn {
    background-image: url(../img/bg.png);
    border-radius: 30px;
    width: 100%;
    height: 40px;
    text-align: center;
    line-height: 40px;
    color: #58430b;
}
/*
sec02
----------------------------------------------------------- */
.sports .sec02 .sports_ttl {
    background-image: url(../img/pc_ttl_head01.webp);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    height: 250px;
}
.sports .top_box .top_box_ttl {
    width: 70%;
}
.sports .top_box .top_box_btn {
    width: 30%;
}
.sports .sports_target {
    font-weight: bold;
    font-size: 1.2em;
    position: relative;
    border-bottom: solid 1px #707070;
    margin-bottom: 15px;
}
.sports .sports_target::after {
    content: " ";
    display: block;
    border-bottom: solid 1px #fab300;
    position: absolute;
    width: 50%;
}
.sports .sports_inner {
    background: #e1fff0;
    padding: 15px;
}
.sports .sports_btn {
    padding: 5px 0;
    text-align: center;
    background: #58430b;
    color: #fff;
    font-size: 1.1em;
    border-radius: 30px;
}
.sports table {
    width: 100%;
    border-collapse: collapse;
}
.sports table tr {
    display: flex;
    flex-wrap: wrap;
    border-bottom: solid 2px white;
    margin-bottom: 5px;
}
.sports table tr:last-child {
    border-bottom: none;
    margin-bottom: 0px;
}
.sports table tr:nth-child(odd) td {
    background: #fff5cc;
}
.sports table th {
    position: relative;
    width: 30%;
    background-color: #fab300;
    color: #333;
    padding: 10px;
    display: flex;
    justify-content: flex-start;
    align-items: center;
}
.sports table th:after {
    display: block;
    content: "";
    width: 0px;
    height: 0px;
    position: absolute;
    top:calc(50% - 10px);
    right:-10px;
    border-left: 10px solid #fab300;
    border-top: 10px solid transparent;
    border-bottom: 10px solid transparent;
}
.sports table td {
    width: 70%;
    text-align: left;
    padding: 10px 30px;
}

/*
sec03
----------------------------------------------------------- */
.sports .sec03 .sports_ttl {
    background-image: url(../img/pc_ttl_head02.webp);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    height: 250px;
}

/*
sec04
----------------------------------------------------------- */
.sports .sec04 .sports_ttl {
    background-image: url(../img/pc_ttl_head03.webp);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    height: 250px;
}

/*
sec05
----------------------------------------------------------- */
.sports .sec05 .sports_ttl {
    background-image: url(../img/pc_ttl_head04.webp);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    height: 250px;
}
.sports .bg_orange {
    background: #fab300;
    font-weight: bold;
    padding: 5px 15px;
    margin-right: 15px;
}

/*
sec06
----------------------------------------------------------- */
.sports .sec06 .sports_ttl {
    background-image: url(../img/pc_ttl_head05.webp);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    height: 250px;
}

/*
sec07
----------------------------------------------------------- */
.sports .sec07 .sports_ttl {
    background-image: url(../img/pc_ttl_head06.webp);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    height: 250px;
}

/*
sec08
----------------------------------------------------------- */
.sports .sec08 .sports_ttl {
    background-image: url(../img/pc_ttl_head07.webp);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    height: 250px;
}

/*
sec09
----------------------------------------------------------- */
.sports .sec09 .sports_ttl {
    background-image: url(../img/pc_ttl_head08.webp);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    height: 250px;
}

/*
sec10
----------------------------------------------------------- */
.sports .sec10 .sports_ttl {
    background-image: url(../img/pc_ttl_head09.webp);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    height: 250px;
}

/*
sec11
----------------------------------------------------------- */
.sports .sec11 .sports_ttl {
    background-image: url(../img/pc_ttl_head10.webp);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    height: 250px;
}
.sports .sns_list {
    display: flex;
}
.sports .sns_icon {
    font-size: 2em;
    padding-left: 15px;
}
.sports .sns_icon:first-of-type {
    padding-left: 0px;
}
/*
sec12
----------------------------------------------------------- */
.sports .sec12 .sports_ttl {
    background-image: url(../img/pc_ttl_head11.webp);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    height: 250px;
}
/*
sec13
----------------------------------------------------------- */
.sports .sec13 .sports_ttl {
    background-image: url(../img/pc_ttl_head12.webp);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    height: 250px;
}
/*
sec14
----------------------------------------------------------- */
.sports .sec14 .sports_ttl {
    background-image: url(../img/pc_ttl_head13.webp);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    height: 250px;
}
.sports .other_sports .sports_target::after {
    border-bottom: solid 1px #1da767;
}
.sports .other_sports table tr:nth-child(odd) td {
    background: #ddffef;
}
.sports .other_sports table th {
    background-color: #1da767;
    color: #fff;
}
.sports .other_sports table th:after {
    border-left: 10px solid #1da767;
}
