/* mobile.css - スマートフォン向けスタイル */

@media (max-width: 768px) {
    .spinner,
    .spinner-small {
        width: 120px;
        height: 120px;
    }

    .record-center-hole {
        width: 60px;
        height: 60px;
    }

    .counter {
        font-size: 20px;
        bottom: 14px;
    }

    .progress-container {
        bottom: 20px;
        width: 90vw;
    }

    .news-section h2 {
        font-size: 24px;
    }

    .news-section ul {
        padding: 0 10px;
    }

    .news-section li {
        font-size: 14px;
    }

    .loop__text {
        font-size: 2.5rem;
    }

    .concept-title {
        font-size: 24px;
    }

    .concept-line {
        font-size: 16px;
        line-height: 1.8;
    }

    footer img.logo {
        width: 235px;
    }

    footer .sns-icons img {
        width: 40px;
    }

    .nav-links a {
        font-size: 16px;
    }
    .navbar .nav-links a {
        font-size: 16px !important;
    }
    .logo {
        font-size: 20px;
    }
    .sek_taitol {
        width: 95%;
    }
    table.soldoutbox.section-fade.visible {
        font-size: 8px;
        line-height: 11px;
    }
    #topw {
        margin-bottom: 75% !important;
    }
    section.tikes_box {
        margin-bottom: 21% !important;
    }
    .etbox {
        width: 100%;
    }
    .titol h2 {
        width: 100%;
    }
    img.taitol2 {
        width: 70%;
    }
    a.seat-link.link1 {
        width: 33%;
        height: 6%;
    }
    a.seat-link.link2 {
        width: 46%;
        height: 11%;
    }
    .link2 {
        top: 83%;
        left: 44%;
    }
    .fixed-banner {
        position: absolute;
        right: 60px;
        bottom: -183px;
        z-index: 1;
        display: block;
        width: 301px;
        height: auto;
        transition: opacity 0.3s ease;
    }
    .fixed-banner2 {
        position: absolute;
        right: 60px;
        bottom: -286px;
        z-index: 1;
        display: block;
        width: 301px;
        height: auto;
        transition: opacity 0.3s ease;
    }
    /* ハンバーガーメニュー表示 */
    .hamburger {
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        width: 25px;
        height: 18px;
        cursor: pointer;
        z-index: 20;
    }

    .hamburger span {
        height: 3px;
        width: 100%;
        background-color: rgb(203, 163, 115);
        border-radius: 2px;
        transition: all 0.3s ease;
    }

    .hamburger.active span:nth-child(1) {
        transform: rotate(45deg) translate(5px, 5px);
    }

    .hamburger.active span:nth-child(2) {
        opacity: 0;
    }

    .hamburger.active span:nth-child(3) {
        transform: rotate(-45deg) translate(5px, -5px);
    }

    /* ナビゲーションメニュー */
    .nav-links {
        position: absolute;
        top: 60px;
        right: 30px;
        flex-direction: column;
        background: #fff;
        border: 1px solid #ccc;
        border-radius: 6px;
        padding: 10px 15px;
        display: none;
        width: 150px;
        box-shadow: 0 4px 10px rgba(0,0,0,0.1);
        transition: all 0.3s ease;
    }

    .nav-links.active {
        display: flex;
        animation: slideFadeIn 0.4s ease forwards;
    }

    @keyframes slideFadeIn {
        from {
            opacity: 0;
            transform: translateY(-10px);
        }
        to {
            opacity: 1;
            transform: translateY(0);
        }
    }
}
.concept-stars {
    display: none;
}
section#hanbabox img {
    width: 100%;
}
@media (max-width: 480px) {
    .loop__text {
        font-size: 2rem;
    }

    .concept-line {
        font-size: 14px;
    }

    .news-section h2 {
        font-size: 20px;
    }

    .nav-links {
        width: 100%;
        right: 0;
    }

    .nav-links a {
        padding: 8px 0;
    }
}
@media screen and (max-width: 768px) {
    html, body {
        font-size: 14px;
        padding: 0;
    }

    .wf, .wf2, .livese {
        width: 100%;
        padding: 20px;
    }
    .tyuuibox {
        background-color: #fff;
        padding: 22px;
        border-radius: 10px;
    }
    .news_tex {
        padding: 1.5rem 1rem;
    }

    .btn a {
        width: 90%;
        font-size: 16px;
        height: auto;
        padding: 20px;
        margin: 14px auto;
    }

    table {
        width: 398px;
    }

    .tikes_box h2 img {
        width: 80%;
    }

    .concept-title {
        font-size: 32px;
    }
    .ttai_1 {
        margin-top: 22%;
        margin-bottom: -6%;
    }
    .loop__text, .loop__text2 {
        font-size: 2rem;
    }

    .scroll-down {
        right: 5px;
        bottom: 20px;
        font-size: 14px;
    }

    .scroll-down span {
        margin-bottom: 4px;
    }

    .navbar {
        padding: 15px;
        flex-direction: row;
        justify-content: space-between;
    }
    nav.nav-links.active {
        width: 175px;
        top: 1px;
    }
    .navbar .logo-img {
        height: 30px;
        left: 10px;
    }
    .ttai_1 {
        margin-top: 20%;
        margin-bottom: 1%;
    }
    .nav-links {
        width: 80%;
        padding: 60px 10px 10px 20px;
    }

    .hero {
        margin-bottom: 20px;
    }

    .ttai_1 img {
        width: 74%;
    }

    .news-section h2 {
        font-size: 24px;
    }

    .news-section li {
        font-size: 14px;
        padding: 20px 0;
    }

    .parallax-layer svg {
        width: 70%;
    }

    .live-concept {
        padding: 40px 10px;
    }

    .concept-line {
        font-size: 12px;
        line-height: 1.7;
    }

    .btn.btn003 {
        flex-direction: column;
    }
}
