@charset "utf-8";
img{
    vertical-align: top;
}
body{
    background-color: #000000;
}
.top div{
    max-width:1200px;
    width:100%;
    margin:0 auto;
}
.top div img{
    width:100%;
}
.common-width{
    max-width:800px;
    width:90%;
    margin:0 auto;
}
.accordion-group{
    margin-top:60px;
    display:flex;
    flex-direction: column;
    gap:50px;
}
/* ======アコーディオン共通====== */
.kv-accordion__trigger {
    cursor: pointer;
    background: none;
    border: 0;
    position: relative;
}
.accordion-btn{
    position: absolute;
    right: 30px;
    bottom: 10px;
    width: 35px;
    transition: .3s;
}
.kv-accordion[data-open="true"] .accordion-btn {
  transform: rotate(180deg);
}
.kv-accordion__img{
    width:100%;
}
.kv-accordion__panel {
  overflow: hidden;
  max-height: 0;
  transition: max-height .5s ease, opacity .3s ease;
}
.kv-accordion[data-open="true"] .kv-accordion__panel {
    opacity: 1;
}
.kv-accordion__inner {
    margin-top:40px;
    margin-bottom:40px;
    border-bottom:2px #FF6E00 solid;
    padding-bottom:50px;
}
.kv-accordion__lead {
    font-size:16px;
    font-weight:600;
    letter-spacing: 0.08em;
    line-height: 2.2;
    color:white;
    margin:4px 0;
}
.kv-accordion__btn{
    width:215px;
    margin:40px auto 0 auto;
}
.kv-accordion__play{
    cursor: pointer;
    background: none;
    border: 0;
}
.kv-accordion__play img{
    width:100%;
}
.kv-accordion__close{
  width:100%;
  cursor: pointer;
  background: none;
  border: 0;
  margin:30px 0 0 0;
  text-align: center;
}
.kv-accordion__close img{
    width:90px;
}
.kv-accordion__inner .sub-span{
    display:block;
    font-size:10px;
    color:white;
    margin-top:10px;
}
.ob-img img{
    width:100%;
}
.ob-img-1{
    width:360px;
    margin:15px 0;
}
.ob-img-2{
    width:242px;
    margin:15px 0 0 0;
}
.ob-img-3{
    width:360px;
    margin:15px 0;
}
.ob-img-4{
    width:595px;
    margin:15px auto 0 auto;
}
.ob-img-5{
    width:100%;
    margin:55px auto 30px auto;
}
.ob-img-flex{
    display:grid;
    grid-template-columns: repeat(2, 1fr);
    gap:10px;
}
.car-padding{
    padding:0 40px 50px 40px;
}
.car-title{
    border-left:#FF6E00 10px solid;
    padding:0 0 0 20px;
    margin:40px 0 20px 0;
}
.car-title h3{
    color:#FF6E00;
    font-size:30px;
    font-weight:600;
}
.car-title p{
    color:#FF6E00;
    font-size:16px;
    font-weight:600;
}
.car-p{
    color:white;
    font-size:18px;
    font-weight:500;
}
.car-p-flex{
    display:flex;
}
.car-sub-title{
    border-left:#FF6E00 10px solid;
    padding:0 0 0 20px;
    margin:40px 0 20px 0;
    color:#FF6E00;
    font-size:20px;
    font-weight:600;
}
.car-p-title{
    color:white;
    font-size:22px;
    font-weight: 600;
    margin:0 0 20px 0;
}
.car-info-group{
    display:flex;
    flex-direction: column;
    gap:20px;
}
.car-info-detail .no{
    color:white;
    font-size:18px;
    font-weight: 600;
}
.car-info-detail .days{
    color:white;
    font-size:16px;
    font-weight: 600;
    padding:0 0 0 22px;
    margin:5px 0 0 0;
}
@media (prefers-reduced-motion: reduce) {
  .kv-accordion__panel { transition: none; }
}
.ac-h3{
    font-size:20px;
    font-weight:600;
    line-height: 1.8;
    color:white;
    text-align: center;
    margin-top:20px;
}
.ac-p{
    font-size:16px;
    font-weight:500;
    line-height: 1.8;
    color:white;
    text-align: left;
}
.ac-link{
    margin:30px auto 0 auto;
    background-color: #FF6E00;
    border-radius: 40px;
    padding:15px 20px;
    display:flex;
    gap:10px;
    align-items: center;
    justify-content: center;
    width:50%;
}
.ac-link-txt{
    color:black;
    font-size:20px;
    font-weight:700;
    font-family: "Noto Sans JP", sans-serif;
}
.b-btn{
    width:15px;
}
.sns-group{
    margin-top:60px;
    display:flex;
    justify-content: center;
    align-items: center;
    gap:20px;
}
.sns-group p{
    color:white;
}
.sns-link{
    display:flex;
    gap:5px
}
.sns-link a{
    display:block;
    width:60px;
}
.sns-link a img{
    width:100%;
}
small{
    font-size:12px;
    color:#9F9F9F;
    text-align: center;
    display:block;
    margin:0 auto;
    padding:60px 0 80px;
}


/* 動画モーダル */
#openBtn{
    background-color:transparent;
    border: none;
    padding:0;
    display:flex;
    align-items: center;
    gap:11px;
}
#openBtn .icon{
    width:44px;
}
#openBtn .txt{
    color:#FF6E00;
    font-size:18px;
    font-weight:700;
    letter-spacing: 0.06em;
    font-family: "Noto Sans JP", sans-serif;
}
#openBtn .icon img{
    width:100%;
}
.modal{
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.8);
    justify-content: center;
    align-items: center;
    z-index: 900;
}
.modal iframe{
    width:100%;
    aspect-ratio: 16 / 9;
}
.modal.is-open{
    display: flex;
}
.modal-content{
    position: relative;
    width:800px;
}
.modal-content video{
    width: 100%;
}
.close{
    position: absolute;
    top:-65px;
    right:0;
    width:72px;
}
.close img{
    width:100%;
}
.pc{
    display:none;
}
.qr{
    width:250px;
    margin:40px auto 0 auto;
}
.qr img{
    width:100%;
}
/* ライトボックス */
.fullscreen-img {
  max-width: 100%;
  cursor: pointer;
  transition: transform 0.2s ease;
}

.fullscreen-view {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: rgba(0,0,0,0.9);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 9999;
}

.fullscreen-view img {
  max-width: 90%;
  max-height: 90%;
}
.noteTx01{
    font-size:11px;
    color:#aaa;
    margin:15px 10px 10px 0;
    text-align:right;
}

/* --- SP --- */
@media only screen and (max-width:999px) {
    .sp{
        display:none;
    }
    .common-width {
        width: 86%;
        margin: 0 auto;
    }
    .kv-accordion__trigger{
        padding:0;
    }
    .accordion-group{
    margin-top:40px;
    display:flex;
    flex-direction: column;
    gap:20px;
    }
    .kv-accordion__lead {
    font-size:14px;
    font-weight:600;
    letter-spacing: 0.08em;
    line-height: 2.2;
    color:white;
    margin:4px 0;
    text-align: left;
    }
    .accordion-btn{
    position: absolute;
    right: 20px;
    bottom: 5px;
    width: 5%;
    transition: .3s;
    }
    
    .accordion-btn.ex{
        bottom: 10px;
    }
    
    .ac-h3{
    font-size:16px;
    font-weight:600;
    line-height: 1.8;
    color:white;
    text-align: left;
    margin-top:20px;
    }
    .ac-p{
        font-size:14px;
        font-weight:500;
        line-height: 1.8;
        color:white;
        text-align: left;
    }
    .ac-link{
    margin:30px auto 0 auto;
    background-color: #FF6E00;
    border-radius: 40px;
    padding:15px 20px;
    display:flex;
    gap:10px;
    align-items: center;
    justify-content: center;
    width:auto;
    }
    .ac-link-txt{
        color:black;
        font-size:14px;
        font-weight:700;
        font-family: "Noto Sans JP", sans-serif;
    }
    .b-btn{
        width:25px;
    }
    .b-btn img{
        width:100%;
        vertical-align: middle;
    }
    .kv-accordion__inner .sub-span{
        text-align: center;
    }
    .ob-img-1{
        width:100%;
        margin:15px 0;
    }
    .ob-img-2{
        width:200px;
        margin:15px 0 0 0;
    }
    .ob-img-3{
        width:100%;
        margin:15px 0;
    }
    .ob-img-4{
        width:100%;
        margin:15px auto 0 auto;
    }
    .ob-img-5{
        width:100%;
        margin:55px auto 30px auto;
    }
    .ob-img-6{
        width:100%;
        margin:15px 0 0 0;
    }
    .ob-img-flex{
        display:grid;
        grid-template-columns: repeat(1, 1fr);
        gap:10px;
    }
    .car-padding{
        padding:0 0 60px 0;
    }
    .car-title h3{
        color:#FF6E00;
        font-size:21px;
        font-weight:600;
    }
    .car-title p{
        color:#FF6E00;
        font-size:14px;
        font-weight:600;
    }
    .car-p{
        font-size:14px;
    }
    .car-p-title{
        font-size:19px;
    }
    .car-info-detail .no{
        font-size:16px;
    }
    .car-info-detail .days{
        font-size:14px;
    }
    .car-sub-title{
        font-size:16px;
    }
    
    .noteTx01{
        font-size:2.75vw;
        color:#aaa;
        margin:1em 0;
        text-align:center;
    }
}