@charset "UTF-8";

/*——　全体　——*/
/* .full-width {
    margin-left: calc(-50vw + 50%);
    margin-right: calc(-50vw + 50%);
    font-family: "Sawarabi Gothic", sans-serif;
    font-weight: 400;
    font-style: normal;
    background: #000;
} */

a,
a:hover,
a:visited {
    /* color: white; */
    text-decoration: none;
}

section {
    padding: 150px 0 0;
}

/* ページ遷移表示 */
.breadcrumbs {
    display: none;
}

.columns .column.main {
    padding-bottom: 0;
}

.page-header {
    margin-bottom: 0;
}

/*position:stickey;を適用するために必須*/
.page-layout-1column,
.page-layout-2columns-left,
.page-layout-2columns-right,
.page-layout-1column-fullwidth {
    overflow-x: visible !important;
}

.pc-visible_md {
    display: inline-block;
}

.sp-visible_md {
    display: none;
}

@media screen and (max-width:768px) {

    .pc-visible_md {
        display: none;
    }

    .sp-visible_md {
        display: block;
    }

}

/* カテゴリメニュー */

.ctgmenu__box {
    max-width: 1200px;
    margin: auto;
    flex-wrap: nowrap;
    z-index: 99;
    -ms-flex-align: center;
    -ms-flex-pack: justify;
    -webkit-box-align: center;
    -webkit-box-pack: justify;
    align-items: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    justify-content: space-between;
}


.ctgmenu__btn {
    flex: 0 0 auto;
    width: calc(100% / 3);
    font-weight: bold;
    text-align: center;
    font-size: large;
}

@media screen and (max-width:767px) {

    section {
        padding: 100px 0 0;
    }

    .ctgmenu__box {
        display: flex;
        flex-wrap: wrap;
        max-width: 100%;
        padding: 0;
    }

    .ctgmenu__btn,
    .ctgmenu__btn--action {
        font-size: 15px;
        width: calc(100% / 2);
        margin: 0 auto;
    }

    .ctgmenu__btn:nth-of-type(n+3),
    .ctgmenu__btn--action:nth-of-type(n+3) {
        font-size: 15px;
        width: calc(100% / 2);
        margin: -10px auto 0;
    }

    .ctgmenu__btn a,
    .ctgmenu__btn--action a {
        padding: 7px 0;
    }

}

/* 背景 */
.voice--area {
    max-width: 1000px;
    margin: auto;
    padding: 15px 0;
}

.voice--area .col-md-6 {
    padding: 0 0 20px;
}

.model--area p {
    margin-bottom: 1.5rem;
    line-height: 2.5rem;
    font-size: x-large;
}

.model--area h3 {
    font-size: larger;
}

.model--area p.model,
.model--area span.model {
    font-size: medium;
}

.list--area ul {
    margin-bottom: 0;
    list-style: none;
    text-align: start;
}

.list--area.color--list {
    max-width: 340px;
}

.list--area ul.sale--detail li::before {
    content: "◆ ";
    margin-left: -15px;
}

.list--area ul li,
.list--area ul li.second {
    line-height: 3.5rem;
    font-size: large;
    margin-bottom: 0;
}

.list--area ul li.second::before {
    content: "";
}

.voice--area .list--area {
    background: transparent;
    padding: 0 10px;
}

.benefits--area p {
    text-align: center;
    margin-bottom: 0;
}

/* 各カテゴリ下の導入分 */
.ctg__ttl {
    max-width: 1200px;
    margin: auto;
    padding: 50px 0 30px;
}

.ctg__intro--area {
    text-align: start;
    margin: 30px auto;
    max-width: 800px;
    padding-left: 10px;
}

.ctg__intro--area p {
    font-size: large;
    line-height: 3.5rem;
    padding: 10px 0 10px 15px;
}

.ctg__intro--area p span.attention {
    font-size: small;
}

.ctg__detail {
    max-width: 1200px;
    padding: 30px 0;
    margin: auto;
}

.ctg__detail h3 {
    font-size: x-large;
    line-height: 3.5rem;
}

.ctg__detail h3 span.item__no {
    font-size: large;
}

.ctg__detail .item__detail p {
    font-size: large;
    line-height: 3.0rem;
    padding: 20px 0 10px;
}

.ctg__detail .item__detail p.reference {
    font-size: small;
    line-height: 2.25rem;
}

.ctg__detail .list--area.sale--list {
    max-width: 800px;
    margin: 0 0 15px;
    padding: 10px 0;
    background: transparent;
    border: none;
    box-shadow: none;
}

.ctg__detail .item__detail .allpresent__detail {
    margin: auto;
    padding: 20px 0;
    text-align: center;
}

.ctg__detail .item__detail .allpresent__detail img {
    width: 50%;
}

.project-details {
    font-size: large;
    line-height: 3.0rem;
}

.project-details a {
    text-decoration: underline;
    color: white;
}

/* 声優さん紹介 */
.actor-introduction__area .actor-introduction--txt {
    padding: 5px 0;
    text-align: center;
    line-height: 3.0rem;
    font-size: medium;
    letter-spacing: 1px;
}

.actor-introduction__area .actor-introduction--txt .awardhistory {
    padding-top: 20px;
}

.actor-introduction__area .actor-introduction--txt span {
    font-size: x-large;
    line-height: 4.75rem;
}

.lp-footer .footer__detail .ttl img {
    width: 70%;
}

.lp-footer .footer__detail .bnr {
    padding: 20px 0 40px;
}

.row.cocorovoice {
    max-width: 1000px;
    margin: auto;
}

.btn01.cocorovoice {
    margin: 65px auto auto;
}

@media screen and (max-width:768px) {

    .ctg__ttl {
        padding: 30px 0;
    }

    .ctg__btn--area {
        padding: 0;
    }

    .ctg__intro--area {
        margin: 15px;
    }

    .ctg__intro--area p {
        font-size: medium;
        padding: 10px 0;
        line-height: 2.5rem;
    }

    .ctg__detail .item__detail {
        margin: 20px;
    }

    .ctg__detail .item__detail p {
        padding: 10px 0;
    }

    .ctg__detail .item__detail .allpresent__detail img {
        width: 100%;
    }

    .ctg__detail .list--area.sale--list {
        padding: 0 0 15px;
    }

    .ctg__detail h3 {
        font-size: large;
        line-height: 3.0rem;
    }

    .ctg__detail h3 span.item__no {
        font-size: medium;
    }

    .list--area {
        padding: 15px 0;
    }

    .list--area ul {
        padding-left: 1.5rem;
    }

    /* .voice--area {
        padding: 15px 0;
    } */

    .model--area p {
        font-size: larger;
    }

    .model--area h3 {
        font-size: large;
    }

    .model--area p.model,
    .model--area span.model {
        font-size: small;
    }

    .project-details {
        font-size: medium;
        line-height: 2.5rem;
        padding: 15px 10px;
    }

    .sp-intro--txt {
        object-fit: cover;
        height: 600px;
    }

    .item__img--area {
        margin: 10px;
    }

    .actor-introduction__area {
        margin: 0 10px;
        padding: 0px
    }

    .actor-introduction__area img {
        border-right: none;
    }

    /* 対応機種一覧 */
    .model--area {
        margin: 10px 10px;
    }

    .lp-footer .footer__detail p {
        font-size: large;
    }

    .lp-footer .footer__detail .ttl {
        padding-bottom: 20px;
    }

    .lp-footer .footer__detail .ttl img {
        width: 100%;
    }

    .lp-footer .footer__detail .bnr {
        padding: 20px 0;
    }

}

@media screen and (max-width:767px) {

    .actor-introduction__area .actor-introduction--txt {
        font-size: small;
    }

    .actor-introduction__area .actor-introduction--txt span {
        font-size: large;
    }

    .list--area ul li,
    .list--area ul li.second {
        font-size: larger;
        line-height: 2.5rem;
        margin-bottom: 10px;
    }

    .list--area ul li.second {
        margin-bottom: 0 !important;
    }

    .btn01.cocorovoice {
        margin: auto;
    }

}

.form-check-input:focus {
    box-shadow: none;
}

@media screen and (max-width:768px) {

    .btn01 {
        max-width: 230px;
    }

}

/* スライダー */
#slide {
    margin: 0 auto;
}

.swiper.slider1,
.swiper.slider2,
.swiper.slider3,
.swiper.slider4,
.swiper.slider5,
.swiper.slider6 {
    width: 440px;
    height: 450px;
}

/* .swiper.slider5,
.swiper.slider6 {
    width: 400px;
    height: 450px;
} */

.swiper.slider7 {
    width: 410px;
    height: 450px;
    text-align: center;
}

.swiper.slider8 {
    width: 510px;
    height: 400px;
    text-align: center;
}

.swiper.slider9 {
    width: 610px;
    height: 340px;
    text-align: center;
}

.slider1 img,
.slider2 img,
.slider3 img,
.slider4 img,
.slider5 img,
.slider6 img {
    width: 400px;
    box-shadow: 10px 10px 1px #D3EFED;
}

/* .slider5 img,
.slider6 img {
    width: 400px;
    box-shadow: 0px 3px 5px #ccc;
} */

.slider7 img {
    width: 400px;
    box-shadow: 0px 3px 5px #666;
}

.slider8 img {
    width: 500px;
    box-shadow: 0px 3px 5px #666;
}

.slider9 img {
    width: 600px;
    box-shadow: 0px 3px 5px #666;
}

.swiper-pagination-bullet-active {
    background: #75CFB1 !important;
    opacity: 1 !important;
    transform: rotate(45deg) !important;
    width: 10px !important;
    height: 10px !important;
    border-radius: 0% !important;
}


@media screen and (max-width:768px) {

    .swiper.slider1,
    .swiper.slider2,
    .swiper.slider3,
    .swiper.slider4,
    .swiper.slider5,
    .swiper.slider6 {
        width: 320px;
        height: 340px;
        text-align: center;
    }

    .swiper.slider7 {
        width: 300px;
        height: 340px;
    }

    .swiper.slider8 {
        width: 310px;
        height: 250px;
    }

    .swiper.slider9 {
        width: 310px;
        height: 190px;
        text-align: center;
    }

    .slider1 img,
    .slider2 img,
    .slider3 img,
    .slider4 img,
    .slider5 img,
    .slider6 img {
        width: 300px;
        margin: auto;
        text-align: center;
    }

    .slider7 img,
    .slider8 img {
        width: 300px;
        margin: auto;
        text-align: center;
    }

    .slider9 img {
        width: 300px;
        margin: auto;
    }

}


/* voice */
audio {
    margin: auto;
}


/* キャンペーン */
.sp-center {
    text-align: start;
}

.sp-start {
    text-align: center !important;
}

.cp5__img img {
    width: 90%;
}

@media screen and (max-width:767px) {

    .sp-center {
        text-align: center;
        margin: auto;
    }

    .sp-start {
        text-align: start !important;
    }

    .sptxt-center {
        text-align: center;
    }

}

/* オーディオプレイヤーレイアウト */
.audio--wrap p {
    font-size: medium;
    text-align: center;
    margin-bottom: 0;
}

.audio-player {
    position: relative;
    width: 100%;
    max-width: 320px;
    margin: 5px auto 15px;
    padding: 7px;
    background-color: #fff;
    color: #454545;
    border-radius: 30px;
}

.audio-player .controls {
    display: flex;
    gap: 5px;
    flex-wrap: nowrap;
    align-items: center;
}

.audio-player .controls button {
    cursor: pointer;
    border: none;
    background-color: transparent;
}

.audio-player .controls button.play-btn {
    margin-right: -30px;
    margin-top: -2px;
    outline: none;
}

.audio-player .controls button.volume-btn {
    margin-right: -7px;
    outline: none;
}

.audio-player input[name="vol"] {
    display: none;
}

@media screen and (min-width: 480px) {
    .audio-player {
        padding: 10px 5px;
        max-width: 340px;
    }

    .audio-player .controls {
        gap: 10px;
    }

    .audio-player input[name="vol"] {
        display: none;
    }

    .audio--wrap p {
        font-size: large;
        text-align: start;
    }

}

/* レンジスライダー */
.audio-player input[type="range"] {
    -webkit-appearance: none;
    appearance: none;
    width: 80%;
    cursor: pointer;
    outline: none;
    border-radius: 15px;
    height: 6px;
    background: #454545;
}

.audio-player input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    height: 15px;
    width: 15px;
    background-color: #0AC4FF;
    border-radius: 50%;
    border: none;
    transition: .2s ease-in-out;
}

.audio-player input[type="range"]::-moz-range-thumb {
    height: 15px;
    width: 15px;
    background-color: #0AC4FF;
    border-radius: 50%;
    border: none;
    transition: .2s ease-in-out;
}

.audio-player input[type="range"]::-webkit-slider-thumb:hover {
    box-shadow: 0 0 0 8px rgba(1, 121, 172, .4)
}

.audio-player input[type="range"]:active::-webkit-slider-thumb {
    box-shadow: 0 0 0 5px rgba(1, 121, 172, .4)
}

.audio-player input[type="range"]:focus::-webkit-slider-thumb {
    box-shadow: 0 0 0 5px rgba(1, 121, 172, .4)
}

.audio-player input[type="range"]::-moz-range-thumb:hover {
    box-shadow: 0 0 0 8px rgba(1, 121, 172, .4)
}

.audio-player input[type="range"]:active::-moz-range-thumb {
    box-shadow: 0 0 0 5px rgba(1, 121, 172, .4)
}

.audio-player input[type="range"]:focus::-moz-range-thumb {
    box-shadow: 0 0 0 5px rgba(1, 121, 172, .4)
}

.audio-player .controls button::before {
    content: "";
    display: inline-block;
    height: 24px;
    width: 24px;
    vertical-align: -10px;
    margin-right: 8px;
    background-repeat: no-repeat;
}

.audio-player .controls .time {
    font-size: 15px;
    line-height: 36px;
}

.audio-player button.play-btn::before {
    background-image: url("../../../img/event/cp2409-voiceactor/icon_voice_stop.svg");
    background-size: contain;
}

.audio-player button.play-btn.playing::before {
    background-image: url("../../../img/event/cp2409-voiceactor/icon_voice_play.svg");
    background-size: contain;
}

.audio-player button.volume-btn.muted::before {
    background-image: url("../../../img/event/cp2409-voiceactor/icon_voice_mute.svg");
    background-size: contain;
}

.audio-player button.volume-btn.muted {
    transform: scale(1.0);
}

.audio-player button.volume-btn::before {
    background-image: url("../../../img/event/cp2409-voiceactor/icon_voice_sound.svg");
    background-size: contain;
}