@charset "UTF-8";
.l-sec2 {
    background-color: rgb(225, 204, 82, 0.2)
}
.l-sec4 {
    background-color: #CF3A58;
}
.heading-2 {
    color: #013f6b;
    font-size: 50px;
    font-weight: 900;
}
.heading-2 span {
    display: block;
    font-size: 20px;
}

/* 全体レイアウト */
.ticket {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    justify-content: center;
    width: 70%;
    margin: auto;
    padding-top: 30px;
    padding-bottom: 30px;
}

.ticket p {
    margin: 0;
    width: calc(50% - 10px); /* 2カラム表示 */
    min-width: 300px;
}

/* ボタンの基本スタイル（チケットの外枠） */
.ticket button {
    position: relative;
    width: 100%;
    padding: 15px 40px;
    border: none;
    cursor: pointer;
    background: #333;
    border-radius: 4px;
    overflow: hidden;
    /* チケット特有の切り欠きデザイン */
    clip-path: polygon(
        15px 0%, calc(100% - 15px) 0%, 100% 15px, 
        100% calc(100% - 15px), calc(100% - 15px) 100%, 
        15px 100%, 0% calc(100% - 15px), 0% 15px
    );
}

/* チケット内部の共通装飾（メタリック感） */
.ticket button a {
    display: block;
    color: #fff;
    text-decoration: none;
    font-weight: bold;
    font-size: 22px;
    padding: 10px;
    border-radius: 50px; /* 内側の黒いカプセル部分 */
    background: rgba(0, 0, 0, 0.4);
    border: 1px solid rgba(255, 255, 255, 0.3);
    transition: 0.3s;
    position: relative;
    z-index: 2;
}

/* ホバー時の挙動 */
.ticket button:hover a {
    background: rgba(255, 255, 255, 0.1);
    color: #fff;
}

/* 左右の「TICKET」文字再現（擬似要素） */
.ticket button::before,
.ticket button::after {
    content: "TICKET";
    position: absolute;
    top: 50%;
    transform: translateY(-50%) rotate(-90deg);
    font-size: 10px;
    color: rgba(0, 0, 0, 0.5);
    font-weight: bold;
    letter-spacing: 2px;
}
.ticket button::before { left: 5px; }
.ticket button::after { right: 5px; transform: translateY(-50%) rotate(90deg); }

/* --- 個別カラー設定 --- */

/* 1つ目：ゴールド (RSA) */
.ticket p:nth-child(4) button {
    background: linear-gradient(135deg, #d4af37 0%, #fef1a2 50%, #af8f31 100%);
    box-shadow: 0 0 15px rgba(212, 175, 55, 0.4);
}

/* 2つ目：レッド (RSB) */
.ticket p:nth-child(3) button {
    background: linear-gradient(135deg, #8b0000 0%, #ff3333 50%, #5a0000 100%);
    box-shadow: 0 0 15px rgba(255, 0, 0, 0.4);
}

/* 3つ目：ブルー (RSC) */
.ticket p:nth-child(2) button {
    background: linear-gradient(135deg, #003366 0%, #0080ff 50%, #002244 100%);
    box-shadow: 0 0 15px rgba(0, 128, 255, 0.4);
}

/* 4つ目：グリーン (指定席A) */
.ticket p:nth-child(1) button {
    background: linear-gradient(135deg, #004d00 0%, #00a000 50%, #002600 100%);
    box-shadow: 0 0 15px rgba(0, 160, 0, 0.4);
}

/* スマホ対応 */
@media (max-width: 640px) {
    .ticket p { width: 100%; }
}

.booking {
    font-size: 30px;
    padding: 10px 0;
    text-align: center;
    background-image: linear-gradient(rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0.6)),url(../images/booking_bg.jpg);
    background-position: left 67%;
    padding: 30px 0;
}
.booking p {
    font-weight: 900;
    color: #FFFFFF;
    /* -webkit-text-stroke: 0.6px #ff8c00; */
}
.booking .ticket_group {
    border-top: 4px solid #D7BE66;
    border-bottom: 4px solid #D7BE66;
    margin-top: 20px;
    padding-bottom: 20px;
    background-image: linear-gradient(rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5))

}
.booking .mini_title {
    color: #D7BE66;
    padding-top: 25px;
}
.bounce-arrow {
  font-size: 24px;
  display: inline-block;
  color: #FFFFFF;
  animation: bounce 1.5s ease-in-out infinite;
  padding-right: 30px;
}
@keyframes bounce {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-10px);
  }
}
.airport-search {
    border: 6px solid red;
}
.box-thumbnail-sub .box-thumbnail-sub-item {
    width: calc(100% / 2 - 24px);
}
.box-thumbnail-sub-item-image img {
    height: initial;
}
.access_color {
    color: #FFFFFF;
}
.a_color {
    color: #16534C;
    text-align: center;
    padding-top: 30px;
    padding-bottom: 30px;
}
.a_color span {
    font-size: 30px;
    font-weight: 900;
    display: block;
    background-color: #FED23E;
    margin-top: 20px;
    margin-bottom: -20px;
    padding: 10px 0;
}
.access_bg {
    background-color: #FFFFFF;
    border-radius: 20px;
}
.access,.access_2,.access_3 {
    width: 90%;
    margin: auto;
    padding-top: 20px;
    padding-bottom: 20px;
}
.access p,.access_2 p {
    font-size: 20px;
    font-weight: 900;
    padding-bottom: 15px;
    width: 181px;
    background: linear-gradient(to right, #21ff00 0%, #ffff00 100%);
    background-repeat: no-repeat;
    background-position: center;
    background-size: 100% 30%;
}
.access ul li,.access_2 ul li {
    padding-top: 5px;
    padding-bottom: 5px;
}
.access_2 ul {
    padding-top: 15px;
    padding-bottom: 15px;
}
.access_2 ul li a {
    color: blue;
}
.access_2 ul li a:hover {
    color: red
}
.access_2 ul li:first-child {
    font-size: 18px;
    padding-bottom: 15px;
}
.access_bg .map {
    text-align: center;
    padding-bottom: 50px;
}
.map iframe {
    width: 90%;
    margin: auto;
}
.access_3 {
    color: #111111;
}
.access_3 a {
    color: blue;
}
.access_3 a:hover {
    color: red;
}
.event_bg {
    background-color: #0d0d0d;
    background-image: 
        radial-gradient(circle at center, rgba(40, 40, 40, 0.5) 0%, rgba(0, 0, 0, 0.8) 100%),
        url('https://www.transparenttextures.com/patterns/dark-leather.png'); /* 質感を出すためのテクスチャ */
    color: #ffffff;
    padding: 80px 20px;
    font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
}
.wrap-content-960.event_group {
    max-width: 960px;
    margin: 0 auto;
}

/* ヘッダー部分：赤い発光と上下のライン */
.event {
    position: relative;
    text-align: center;
    font-size: 36px;
    margin-bottom: 50px;
    padding: 20px 0;
    /* 中央の赤いグロー効果 */
    background: radial-gradient(ellipse at center, rgba(150, 0, 0, 0.6) 0%, rgba(0, 0, 0, 0) 75%);
    color: #FFFFFF;
}

/* ゴールドの上下線 */
.event::before,
.event::after {
    content: "";
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    width: 60%;
    height: 2px;
    background: linear-gradient(90deg, transparent, #d4af37 50%, transparent);
}

.event::before { top: 0; }
.event::after { bottom: 0; }

.event span {
    display: block;
    font-size: 14px;
    color: #00bfff; /* 水色のサブテキスト */
    font-weight: bold;
    margin-top: 8px;
    text-transform: uppercase;
}

/* テキストエリア */
.event_group > div:not(.venue) p {
    line-height: 1.8;
    margin-bottom: 30px;
    font-size: 16px;
    text-align: left;
    color: #FFFFFF;
}

/* 下部の詳細ボックス（金枠） */
.venue {
    border: 1px solid #91763d; /* ゴールド系の枠線 */
    padding: 30px;
    margin-top: 40px;
    position: relative;
    background-color: rgba(255, 255, 255, 0.02);
}

.venue p {
    margin: 0;
    font-weight: bold;
    font-size: 16px;
    line-height: 1.8;
    text-align: left;
    color: #FFFFFF;
}


/* スマホ対応 */
@media (max-width: 768px) {
    .event {
         font-size: 28px;
    }
    .event::before, .event::after {
         width: 90%;
    }
    .venue {
        padding: 20px;
    }
    .booking p {
        font-size: 20px;
    }
    .bounce-arrow {
        padding-right: 10px;
        font-size: 14px;
    }
    .heading-2 {
        font-size: 30px;
    }
    .box-thumbnail-sub .box-thumbnail-sub-item {
        width: 100%;
    }
    .access p, .access_2 p {
        width: 200px;
    }
    .a_color span {
        font-size: 21px;
    }
    .w90 {
        width: 90%;
        margin: auto;
        text-align: left;
    }
    .access_3 a {
        display: block;
    }
    .ticket {
        width: 90%;
    }
    .ticket button a {
        font-size: 17px;
    }
}
