/* --------------------
 Voice detail
-------------------- */
.layout {
    padding: 6.25rem 0 0;
}

@media (min-width: 768px) {
    .layout {
        padding: 10.625rem 0 0;
    }
}

.detail {
    margin: 0 0 2.5rem;
}

.detail-container {
    margin: 0 auto;
    max-width: 81.25rem;
    padding: 0 2.1875rem;
    position: relative;
    width: 100%;
}

@media (min-width: 768px) {
    .detail-container {
        align-items: stretch;
        display: flex;
        flex-flow: row nowrap;
        gap: 1.25rem 0;
        padding: 0;
    }
}

.detail__title {
    flex: 0 0 100%;
    left: 2.1875rem;
    position: absolute;
    top: 0;
}

@media (min-width: 768px) {
    .detail__title {
        flex: 0 0 6.25rem;
        inset: auto;
        position: static;
    }
}

.detail__title__ja {
    font-size: 0.875rem;
    font-weight: 700;
    line-height: 1;
    margin: 0 0 0.5rem;
    text-align: left;
}

.detail__title__en {
    color: var(--color-ruby-red);
    font-size: 1.1875rem;
    font-weight: 700;
    line-height: 1;
    margin: 0;
    text-align: left;
}

@media (min-width: 768px) {
    .detail__title__en {
        font-size: 1.1875rem;
    }
}

.detail__main {
    flex: 0 0 100%;
}

@media (min-width: 768px) {
    .detail__main {
        flex: 1 1 auto;
        max-width: 68.75rem;
    }
}

.detail__main__label {
    filter: drop-shadow(0.4375rem 0.4375rem 0.3125rem rgba(var(--color-black-rgb), 0.1));
    margin: 0 0 1.5625rem;
    padding: 0 0 0 5.625rem;
    width: -webkit-fit-content;
    width: fit-content;
}

@media (min-width: 768px) {
    .detail__main__label {
        padding: 0;
    }
}

.detail__main__label span {
    background: linear-gradient(to top, #84041a 0.625rem, #c30d23 0.625rem);
    background-color: #c30d23;
    -webkit-clip-path: polygon(0 0, 100% 0, calc(100% - 0.5rem) calc(50% - 0.3125rem), 100% calc(100% - 0.625rem), 0.625rem calc(100% - 0.625rem), 0.625rem 100%, 0 calc(100% - 0.625rem));
    clip-path: polygon(0 0, 100% 0, calc(100% - 0.5rem) calc(50% - 0.3125rem), 100% calc(100% - 0.625rem), 0.625rem calc(100% - 0.625rem), 0.625rem 100%, 0 calc(100% - 0.625rem));
    color: var(--color-white);
    display: block;
    font-size: 0.875rem;
    font-weight: 400;
    line-height: 1.2;
    padding: 0.625rem 1.5rem 1.25rem 0.75rem;
    text-box: trim-both cap alphabetic;
}

@media (min-width: 768px) {
    .detail__main__label span {
        background: linear-gradient(to top, #84041a 0.75rem, #c30d23 0.75rem);
        -webkit-clip-path: polygon(0 0, 100% 0, calc(100% - 0.5rem) calc(50% - 0.375rem), 100% calc(100% - 0.75rem), 0.75rem calc(100% - 0.75rem), 0.75rem 100%, 0 calc(100% - 0.75rem));
        clip-path: polygon(0 0, 100% 0, calc(100% - 0.5rem) calc(50% - 0.375rem), 100% calc(100% - 0.75rem), 0.75rem calc(100% - 0.75rem), 0.75rem 100%, 0 calc(100% - 0.75rem));
        font-size: 1rem;
        padding: 0.875rem 1.5rem 1.625rem;
    }
}

.detail__main__title {
    border-bottom: 0.0625rem solid var(--color-black);
    color: #000000;
    font-size: 1.1875rem;
    font-weight: 700;
    line-height: 1.52;
    margin: 0 0 1.25rem;
    padding: 0 0 1.25rem;
}

@media (min-width: 768px) {
    .detail__main__title {
        font-size: 2.25rem;
        line-height: 1.47;
        margin: 0 0 2.1875rem;
        padding: 0 0 2.1875rem;
    }
}

@media (min-width: 768px) {
    .detail__main__content {
        padding: 0 2.1875rem;
    }
}

.nav {
    background-color: var(--color-off-white-light);
    padding: 0.875rem 1.875rem;
}

@media (min-width: 768px) {
    .nav {
        padding: 2.5rem 0;
    }
}

.nav-container {
    align-items: center;
    display: flex;
    flex-flow: row wrap;
    justify-content: center;
    margin: 0 auto;
    max-width: 81.25rem;
    width: 100%;
}

@media (min-width: 768px) {
    .nav-container {
        flex-wrap: nowrap;
        justify-content: space-between;
    }
}

.nav__prev {
    flex: 0 0 50%;
    min-width: 0.0625rem;
}

@media (max-width: 767px) {
    .nav__prev {
        order: 2;
    }
}

@media (min-width: 768px) {
    .nav__prev {
        flex: 0 0 calc(50% - 165px);
        padding: 0 30px 0 0;
    }
}

.nav__prev__link {
    color: inherit;
    display: block;
    text-align: center;
    text-decoration: none;
    transition: color var(--duration) var(--cubic) 0s;
    width: -webkit-fit-content;
    width: fit-content;
}

.nav__prev__link__label {
    display: block;
    font-size: 0.9375rem;
    line-height: 1.4;
    margin: 0;
    padding: 0 0 0 1.875rem;
    position: relative;
}

@media (min-width: 768px) {
    .nav__prev__link__label {
        font-size: 1rem;
    }
}

.nav__prev__link__label:before {
    background-color: var(--color-black);
    content: "";
    display: block;
    height: 0.75rem;
    left: 0;
    -webkit-mask-image: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 10 12"><path d="M9.93,10.94c0,.14-.06.19-.21.13L.16,6.12c-.13-.08-.11-.21.02-.27L9.72.94c.13-.08.21-.02.21.13v.98c0,.11-.03.16-.13.21l-7.49,3.75,7.49,3.75c.1.05.13.11.13.21v.99Z"/></svg>');
    mask-image: url('data:image/svg+xml;charset=UTF-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 10 12"><path d="M9.93,10.94c0,.14-.06.19-.21.13L.16,6.12c-.13-.08-.11-.21.02-.27L9.72.94c.13-.08.21-.02.21.13v.98c0,.11-.03.16-.13.21l-7.49,3.75,7.49,3.75c.1.05.13.11.13.21v.99Z"/></svg>');
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-size: contain;
    mask-size: contain;
    position: absolute;
    right: auto;
    top: 0.25rem;
    transition: background-color var(--duration) var(--cubic) 0s;
    width: 0.625rem;
}

.nav__prev__link:focus {
    color: var(--color-crimson);
}

.nav__prev__link:focus .nav__prev__link__label {
    -webkit-text-decoration-color: color-mix(in srgb, currentColor, transparent 100%);
    text-decoration-color: color-mix(in srgb, currentColor, transparent 100%);
}

.nav__prev__link:focus .nav__prev__link__label:before {
    background-color: var(--color-crimson);
}

@media (hover: hover) and (pointer: fine) {
    .nav__prev__link:hover {
        color: var(--color-crimson);
    }

    .nav__prev__link:hover .nav__prev__link__label {
        -webkit-text-decoration-color: color-mix(in srgb, currentColor, transparent 100%);
        text-decoration-color: color-mix(in srgb, currentColor, transparent 100%);
    }

    .nav__prev__link:hover .nav__prev__link__label:before {
        background-color: var(--color-crimson);
    }
}

.nav__back {
    flex: 0 0 100%;
    margin: 0 0 1.5rem;
    min-width: 0.0625rem;
}

@media (max-width: 767px) {
    .nav__back {
        order: 1;
    }
}

@media (min-width: 768px) {
    .nav__back {
        flex: 0 0 20.625rem;
        margin: 0;
    }
}

.nav__back__button {
    color: var(--color-white);
    display: block;
    font-size: 1.3125rem;
    font-weight: 700;
    height: 5.875rem;
    letter-spacing: 0.24em;
    margin: 0 auto;
    position: relative;
    text-decoration: none;
    transform: translateX(-0.875rem);
    transition: color var(--duration) var(--cubic) 0s;
    width: 19.25rem;
}

@media (min-width: 768px) {
    .nav__back__button {
        height: 4.625rem;
        transform: translate(-0.9375rem, -0.75rem);
        width: 20.625rem;
    }
}

.nav__back__button svg {
    bottom: 0;
    display: block;
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 0;
}

.nav__back__button svg .-bg {
    transition: fill var(--duration) var(--cubic) 0s;
}

.nav__back__button__text {
    align-items: center;
    display: flex;
    flex-flow: row nowrap;
    height: 100%;
    justify-content: center;
    line-height: 1.2;
    margin: 0;
    padding: 1.25rem 0 0;
    position: relative;
    text-align: center;
    width: 100%;
    z-index: 1;
}

.nav__back__button:focus {
    color: var(--color-crimson);
}

.nav__back__button:focus .-bg {
    fill: var(--color-white) !important;
}

@media (hover: hover) and (pointer: fine) {
    .nav__back__button:hover {
        color: var(--color-crimson);
    }

    .nav__back__button:hover .-bg {
        fill: var(--color-white) !important;
    }
}

.nav__next {
    flex: 0 0 50%;
    min-width: 0.0625rem;
}

@media (max-width: 767px) {
    .nav__next {
        order: 3;
    }
}

@media (min-width: 768px) {
    .nav__next {
        flex: 0 0 calc(50% - 165px);
        padding: 0 0 0 1.875rem;
    }
}

.nav__next__link {
    color: inherit;
    display: block;
    margin: 0 0 0 auto;
    text-align: center;
    text-decoration: none;
    transition: color var(--duration) var(--cubic) 0s;
    width: -webkit-fit-content;
    width: fit-content;
}

.nav__next__link__label {
    display: block;
    font-size: 0.9375rem;
    line-height: 1.4;
    margin: 0;
    padding: 0 1.875rem 0 0;
    position: relative;
}

@media (min-width: 768px) {
    .nav__next__link__label {
        font-size: 1rem;
    }
}

.nav__next__link__label:before {
    background-color: var(--color-black);
    content: "";
    display: block;
    height: 0.75rem;
    left: auto;
    -webkit-mask-image: url('data:image/svg+xml;charset=UTF-8,<?xml version="1.0" encoding="UTF-8"?><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 10 12"><path d="M.07,1.06c0-.14.06-.19.21-.13l9.56,4.95c.13.08.11.21-.02.27L.28,11.06c-.13.08-.21.02-.21-.13v-.98c0-.11.03-.16.13-.21l7.49-3.75L.2,2.26c-.1-.05-.13-.11-.13-.21v-.99Z"/></svg>');
    mask-image: url('data:image/svg+xml;charset=UTF-8,<?xml version="1.0" encoding="UTF-8"?><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 10 12"><path d="M.07,1.06c0-.14.06-.19.21-.13l9.56,4.95c.13.08.11.21-.02.27L.28,11.06c-.13.08-.21.02-.21-.13v-.98c0-.11.03-.16.13-.21l7.49-3.75L.2,2.26c-.1-.05-.13-.11-.13-.21v-.99Z"/></svg>');
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-size: contain;
    mask-size: contain;
    position: absolute;
    right: 0;
    top: 0.25rem;
    transition: background-color var(--duration) var(--cubic) 0s;
    width: 0.625rem;
}

.nav__next__link:focus {
    color: var(--color-crimson);
}

.nav__next__link:focus .nav__next__link__label {
    -webkit-text-decoration-color: color-mix(in srgb, currentColor, transparent 100%);
    text-decoration-color: color-mix(in srgb, currentColor, transparent 100%);
}

.nav__next__link:focus .nav__next__link__label:before {
    background-color: var(--color-crimson);
}

@media (hover: hover) and (pointer: fine) {
    .nav__next__link:hover {
        color: var(--color-crimson);
    }

    .nav__next__link:hover .nav__next__link__label {
        -webkit-text-decoration-color: color-mix(in srgb, currentColor, transparent 100%);
        text-decoration-color: color-mix(in srgb, currentColor, transparent 100%);
    }

    .nav__next__link:hover .nav__next__link__label:before {
        background-color: var(--color-crimson);
    }
}