@import url(https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@700&family=Red+Hat+Display:ital,wght@0,700;1,700&display=swap);

h3 {
    padding: 0.25em 0.5em;
    color: #252525;
    background: transparent;
    border-left: solid 5px #dfdfdf;
}

ul.kakomi_row li.kakomi_path {
    padding-top: 0.5em;
    padding-bottom: 0.5em;
}

ul.kakomi_row {
    margin-left: 2em;
    list-style-type: disclosure-closed;
}

span.underline {
    text-decoration: underline;
}

span.wave {
    text-decoration: wavy underline red;
}

img.center_yose {
    margin: 0 auto;
}

p {
    margin: 0.5em;
    font-size: 14px;
    color: #252525;
}

div.center_yose {
    font-size: 1.2em;
    color: #252525;
    margin-bottom: 0.5em;
    text-align: center;
}


.kakomi_red {
    position: relative;
    margin: 2em 0;
    padding: 25px 10px 7px;
    border: solid 2px #df3f3b;
}

.kakomi_red .box-title {
    position: absolute;
    display: inline-block;
    top: -2px;
    left: -2px;
    padding: 0 9px;
    height: 2em;
    line-height: 2em;
    font-size: 14px;
    background: #df3f3b;
    color: #fff;
    font-weight: bold;
}

.kakomi_red p {
    padding: 0;
}



.kakomi_blue {
    position: relative;
    margin: 2em 0;
    padding: 25px 10px 7px;
    border: solid 2px #169ed9;
}

.kakomi_blue .box-title {
    position: absolute;
    display: inline-block;
    top: -2px;
    left: -2px;
    padding: 0 9px;
    height: 2em;
    line-height: 2em;
    font-size: 14px;
    background: #169ed9;
    color: #fff;
    font-weight: bold;
}

.kakomi_blue p {
    padding: 0;
}

/* 追加CSS */


#lineup-list {
    display: flex;
    flex-wrap: wrap;
    gap: 48px;
    padding: 72px 0 0;
    width: 100%
}

#lineup-item {
    background-color: #fff;
    border-radius: 8px;
    box-shadow: 0 0 8px 0 rgba(0, 0, 0, .18);
    display: flex;
    flex-direction: column;
    position: relative;
    width: calc(33.33333% - 32px)
}

#lineup-item:before {
    border-radius: 50%;
    box-sizing: border-box;
    font-family: Red Hat Display, sans-serif;
    font-optical-sizing: auto;
    font-size: 48px;
    font-style: normal;
    height: 73px;
    left: -14px;
    top: -16px;
    width: 72px
}

#lineup-item:after,
#lineup-item:before {
    color: #fff;
    display: block;
    font-weight: 700;
    line-height: 73px;
    position: absolute
}

#lineup-item:after {
    content: "等";
    font-family: Red Hat Display;
    font-size: 24px
}

#lineup-item[data-number=tokusho]:before {
    background-color: #c9bb97;
    content: "特";
    font-size: 24px;
    padding: 0 11px
}

#lineup-item[data-number=tokusho]:after {
    left: 21px;
    top: -15px
}

#lineup-item[data-number="1"]:before {
    background-color: #c9bb97;
    content: "1";
    padding: 0 13px
}

#lineup-item[data-number="1"]:after {
    left: 21px;
    top: -8px
}

#lineup-item[data-number="2"]:before {
    background-color: #98bac9;
    content: "2";
    padding: 0 10px
}

#lineup-item[data-number="2"]:after {
    left: 27px;
    top: -8px
}

#lineup-item[data-number="3"]:before {
    background-color: #d9ac9e;
    content: "3";
    padding: 0 10px
}

#lineup-item[data-number="3"]:after {
    left: 27px;
    top: -8px
}

#lineup-item[data-number="4"]:before {
    background-color: #65bbe8;
    content: "4";
    padding: 0 8px
}

#lineup-item[data-number="4"]:after {
    left: 27px;
    top: -8px
}

#lineup-item[data-number="5"]:before {
    background-color: #65bbe8;
    content: "5";
    padding: 0 11px
}

#lineup-item[data-number="5"]:after {
    left: 27px;
    top: -8px
}

#lineup-item[data-number="6"]:before {
    background-color: #65bbe8;
    content: "6";
    padding: 0 11px
}

#lineup-item[data-number="6"]:after {
    left: 27px;
    top: -8px
}

#lineup-item2 {
    background-color: #fff;
    border-radius: 8px;
    box-shadow: 0 0 8px 0 rgba(0, 0, 0, .18);
    display: flex;
    flex-direction: column;
    position: relative;
    width: calc(33.33333% - 32px)
}

#lineup-item2:before {
    border-radius: 50%;
    box-sizing: border-box;
    font-family: Red Hat Display, sans-serif;
    font-optical-sizing: auto;
    font-size: 48px;
    font-style: normal;
    height: 73px;
    left: -14px;
    top: -16px;
    width: 72px
}

#lineup-item2:after,
#lineup-item2:before {
    color: #fff;
    display: block;
    font-weight: 700;
    line-height: 73px;
    position: absolute
}

#lineup-item2:after {
    content: "賞";
    font-family: Red Hat Display;
    font-size: 18px
}

#lineup-item2[data-number="S"]:before {
    background-color: #c9bb97;
    content: "S";
    padding: 0 10px
}

#lineup-item2[data-number="S"]:after {
    left: 27px;
    top: -3px
}


#lineup-item2[data-number="A"]:before {
    background-color: #c9bb97;
    content: "A";
    padding: 0 10px
}

#lineup-item2[data-number="A"]:after {
    left: 30px;
    top: -3px
}

#lineup-item2[data-number="B"]:before {
    background-color: #98bac9;
    content: "B";
    padding: 0 10px
}

#lineup-item2[data-number="B"]:after {
    left: 30px;
    top: -3px
}

#lineup-item2[data-number="C"]:before {
    background-color: #d9ac9e;
    content: "C";
    padding: 0 10px
}

#lineup-item2[data-number="C"]:after {
    left: 30px;
    top: -3px
}


#lineup-item2[data-number="D"]:before {
    background-color: #65bbe8;
    content: "D";
    padding: 0 11px
}

#lineup-item2[data-number="D"]:after {
    left: 31px;
    top: -3px
}

#lineup-item2[data-number="E"]:before {
    background-color: #65bbe8;
    content: "E";
    padding: 0 11px
}

#lineup-item2[data-number="E"]:after {
    left: 27px;
    top: -3px
}

#lineup-item2[data-number="F"]:before {
    background-color: #65bbe8;
    content: "F";
    padding: 0 11px
}

#lineup-item2[data-number="F"]:after {
    left: 27px;
    top: -8px
}

#lineup-item img {
    aspect-ratio: 3/2;
    border-radius: 8px 8px 0 0;
    max-width: 320px;
    -o-object-fit: contain;
    object-fit: contain;
    width: 100% !important
}

#lineup-item2 img {
    aspect-ratio: 3/2;
    border-radius: 8px 8px 0 0;
    max-width: 320px;
    -o-object-fit: contain;
    object-fit: contain;
    width: 100% !important
}

#lineup-data {
    background-image: linear-gradient(90deg, #e8e8e8, #e8e8e8 8px, transparent 0, transparent 8px);
    background-position: 0 0;
    background-repeat: repeat-x;
    background-size: 12px 2px;
    padding: 16px 25px
}

#lineup-title {
    font-size: 20px;
    font-weight: 700;
    font-family: "Noto Sans JP", sans-serif;
    text-align: left;
    margin: 0 0 8px 0;
    line-height: 120%;
}

#lineup-text {
    font-size: 12px;
    font-weight: 500;
    line-height: 16px;
    margin: 0
}

#lineup-text a {
    color: #169ed9;
    font-weight: 500
}

#lineup-text a:link {
    text-decoration: none
}

#lineup-rate {
    align-items: baseline;
    background-color: #e8e8e8;
    display: flex;
    font-family: Noto Sans JP, sans-serif;
    font-size: 16px;
    font-weight: 700;
    justify-content: center;
    margin: auto 0 0;
    padding: 6px 0
}

#lineup-rate span {
    font-family: Red Hat Display, sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 700
}

#lineup-textbox {
    margin: 72px 0 64px;
    text-align: center
}

#lineup-textbox #lineup-text {
    font-family: Noto Sans JP, sans-serif;
    font-weight: 500;
    margin: 0
}

#lineup-link {
    margin-bottom: 48px
}

#lineup-btn {
    background-color: #252525;
    border-radius: 100px;
    color: #fff !important;
    display: block;
    margin: 0 auto;
    max-width: 412px;
    padding: 17px 0;
    text-align: center;
    text-decoration: none;
    width: 100%
}

.text-small {
    margin-bottom: 0
}

#bonus {
    background-color: #169ed9;
    border-radius: 8px;
    margin-bottom: 10px;
    margin-top: 43px;
    padding: 27px 41px;
    width: 100%
}

#bonus p {
    color: #fff
}

#bonus-list {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
    margin: 0;
    padding: 0
}

#bonus-item {
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    position: relative;
    text-align: left;
    width: calc(25% - 18px)
}

#bonus-item img {
    aspect-ratio: 3/2;
    background: #fff;
    border-radius: 8px 8px 0 0;
    border-radius: 14.222px;
    max-width: 320px;
    -o-object-fit: contain;
    object-fit: contain;
    padding: 0 32px;
    position: relative;
    width: 100% !important
}

#bonus-imgbox {
    display: contents
}

#bonus-title {
    font-family: Noto Sans JP, sans-serif;
    font-size: 16px;
    font-weight: 700;
    margin: 8px 0
}

#bonus-catch {
    font-family: Red Hat Display, sans-serif;
    font-size: 12px;
    font-weight: 700;
    margin: 0 0 0 8px;
    text-align: center
}

#bonus-text {
    font-family: Noto Sans JP, sans-serif;
    font-weight: 500;
    margin: 0 0 8px;
    text-align: left
}

#bonus-text,
.text-small {
    font-size: 12px
}

#bonus-size {
    margin: auto 0;
    text-align: left
}

#bonus-number {
    color: #fcff66;
    font-family: Red Hat Display, sans-serif;
    font-size: 24px;
    font-weight: 900;
    padding: 0 2px
}

#link-inner {
    display: flex;
    gap: 24px
}

#link-btn {
    border: 1px solid #252525;
    border-radius: 100px;
    color: #252525;
    display: block;
    padding: 17px;
    text-align: center;
    text-decoration: none;
    width: calc(25% - 18px)
}

#notice {
    margin-bottom: 70px
}


#notice .product-description .product-description-body ul {
    padding-left: 30px
}


@media screen and (max-width:768px) {

    #bonus-item,
    #lineup-item,
    #lineup-item2 {
        width: calc(50% - 32px)
    }

    #link-inner {
        align-items: center;
        flex-flow: column
    }

    #link-btn {
        min-width: 186px
    }

    #notice .product-description .product-description-body ul {
        padding-left: 22px
    }
}

@media screen and (max-width:640px) {

    #lineup-item,
    #lineup-item2 {
        width: 100%
    }

    #lineup-item img {
        max-width: none
    }

    #lineup-item2 img {
        max-width: none
    }

    #bonus {
        padding: 32px
    }

    #bonus-item {
        width: 100%
    }

    #bonus-item img {
        max-width: none
    }
}

#edit-section {
    width: 100%
}

#edit-section section {
    margin: 0 0 48px;
    width: 100%
}

#edit-section section #text-link {
    color: #169ed9;
    font-weight: 400;
    text-decoration: none
}

#edit-section section #contents-inner {
    padding: 0 16px
}

#title {
    box-sizing: border-box;
    margin: 0;
    width: 100%
}

#edit-section section .description-title-h3 {
    background-color: #dfdfdf;
    display: block;
    font-family: Noto Sans JP, system-ui;
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 24px;
    padding: 4px 8px
}

#edit-section section .description-title-h4 {
    display: block;
    font-family: Noto Sans JP, system-ui;
    font-size: 16px;
    font-weight: 700;
    margin: 0;
    padding: 8px 0
}

.product-description .product-description-title {
    margin-bottom: 48px
}

#table-box {
    display: block;
    overflow-x: auto
}

#table-box table {
    border-collapse: collapse;
    max-width: 860px;
    min-width: 335px;
    width: 100%;
    table-layout: auto;
}

#table-box table td,
#table-box table th {
    border: 1px solid #b7b7b7;
    font-size: 12px;
    padding: 5px 0;
    text-align: center
}

#table-box table th {
    background-color: #e8e8e8
}

#table-box .twoColumns th {
    width: 30%;
    text-align: center;
}

#table-box .twoColumns td {
    margin: 0;
    padding: 10px 18px 10px 36px;
    text-align: left;
    width: 70%;
    line-height: 16px;
}

#table-box .twoColumns td ul,
#table-box table td ul {
    padding: 0;
    text-align: left;
}

#table-box .twoColumns td ul {
    list-style-type: disc;
    margin: 0;
    width: 100%;
}

#edit-section .text-box {
    line-height: 1.7
}

#edit-section .text-box p {
    font-size: 14px;
    font-weight: 500;
    margin: 0 0 24px
}

#edit-section .text-box .text-red {
    color: #df3f3b
}

.img {
    max-height: none !important;
    width: 100%
}

#edit-section .movie {
    margin: 0 0 24px
}

#edit-section .seiga {
    margin: 0 0 24px
}

#img-float {
    display: flex;
    gap: 27px
}

#img-float div {
    flex: 1;
    min-width: 0;
}

#img-float .seiga {
    flex: 3;
}

#img-float .seiga-text {
    flex: 7;
}

#img-box img {
    width: 100%
}

#img-group {
    display: flex;
    gap: 8px;
    margin-bottom: 16px;
    padding: 0
}

#img-group li {
    flex-flow: column;
    list-style: none;
    width: calc(25% - 6px)
}

#img-group li img {
    aspect-ratio: 240/240;
    border: 1px solid #dfdfdf;
    margin-bottom: 4px;
    -o-object-fit: cover;
    object-fit: cover;
    position: relative;
    width: 100%
}

#img-group li p {
    font-size: 12px;
    margin: 0 0 16px;
    text-align: center
}

#edit-section #img-group-title p {
    font-size: 12px;
    font-weight: 900;
    margin: 0 0 8px
}

#lineup-link {
    width: 100%
}

#edit-section .text-box .text-link {
    color: #169ed9;
    text-decoration: none
}

#edit-section .text-box .text-link:hover {
    opacity: .7
}

#link-outside {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    margin: 0 0 24px
}

#link-outside a {
    border: 1px solid #252525;
    border-radius: 100px;
    color: #252525;
    display: inline-block;
    font-size: 14px;
    min-width: -moz-fit-content;
    min-width: fit-content;
    padding: 10px 27px;
    text-decoration: none
}

#link-outside a:hover {
    opacity: .7
}

#banner .banner-inner {
    margin-bottom: 64px
}

#banner .banner-inner h2 {
    font-size: 20px
}

#banner .banner-inner {
    display: flex;
    flex-wrap: wrap;
    gap: 40px;
    justify-content: center
}

#banner .banner-inner a {
    height: 120px;
    max-width: 480px;
    width: 100%
}

#banner .banner-inner img {
    border-radius: 4px;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    transition: opacity .3s ease-in-out;
    width: 100%
}

#banner .banner-inner img:hover {
    opacity: .8
}

#list {
    margin-bottom: 70px
}

#list .product-description {
    margin-bottom: 64px
}

#list .product-description .product-description-body ul {
    font-size: 14px;
    list-style-type: disc;
    padding-left: 30px
}

#list .product-description .product-description-title {
    margin-bottom: 16px
}

#notice {
    margin-bottom: 70px
}

#banner .banner-inner {
    gap: 16px
}

#list .product-description {
    margin-bottom: 32px
}

#notice .product-description {
    margin-bottom: 64px
}

#notice .product-description .product-description-body ul {
    font-size: 14px;
    list-style-type: disc;
    padding-left: 30px
}

#notice .product-description .product-description-title {
    margin-bottom: 16px
}

.product-description .product-description-title {
    align-items: center;
    color: #252525;
    display: flex;
    font-size: 18px;
    gap: 0 24px;
    justify-content: space-between;
    margin: 0 0 16px
}

.product-description .product-description-title:after {
    background-color: #eee;
    content: "";
    display: block;
    flex: 1 0 0%;
    height: 1px
}

#buying-inner {
    margin-bottom: 24px
}

#buying-btn {
    background-color: #252525;
    border-radius: 100px;
    color: #fff !important;
    display: block;
    margin: 0 auto;
    max-width: 412px;
    padding: 17px 0;
    text-align: center;
    text-decoration: none;
    width: 100%
}

section {
    width: 100%
}

.temp-title {
    background-color: #169ed9;
    color: #fff;
    display: block;
    margin: 16px 0;
    padding: 8px 16px
}

.sample-box {
    margin: 0 0 40px;
    padding: 0
}

.sample-code {
    margin: 0 16px 24px;
    padding: 0 12px
}

.code-inner {
    border: 2px solid #dfdfdf;
    overflow-x: scroll
}

.code-title {
    font-weight: 700;
    margin: 0 0 12px
}

.sample-box-inner {
    margin: 0 16px;
    padding: 16px 0
}

.lo-Wrapper {
    background: #fff;
    min-width: 300px;
    width: 100%
}

.lo-Wrapper_Contner {
    align-items: flex-start;
    box-sizing: border-box;
    display: flex;
    flex-flow: column;
    margin-left: auto;
    margin-right: auto;
    padding-bottom: 64px;
    padding-top: 16px;
    width: 100%
}

.st-Header {
    margin: 0
}

.st-HeaderMain {
    background-color: #fff;
    border-bottom: 1px solid #e8e8e8;
    position: relative;
    width: 100%
}

.st-HeaderMain_Container {
    align-items: center;
    box-sizing: border-box;
    display: flex;
    flex-flow: row nowrap;
    margin-left: auto;
    margin-right: auto;
    width: 100%
}

.st-HeaderMain_Container img {
    height: 200px;
    margin: auto;
    max-width: 1000px;
    -o-object-fit: cover;
    object-fit: cover;
    width: 100%
}

.st-Footer {
    margin: 0
}

.st-FooterMain {
    background-color: #1b1b1b;
    color: #fff;
    position: relative;
    width: 100%
}

.st-FooterMain_Container {
    align-items: center;
    box-sizing: border-box;
    display: flex;
    flex-flow: row nowrap;
    height: 50px;
    margin-left: auto;
    margin-right: auto;
    width: 100%
}

#help-inner {
    display: flex;
    gap: 24px;
    margin-bottom: 64px
}

#help .help-btn {
    align-items: center;
    border: 1px solid #252525;
    border-radius: 100px;
    color: #252525;
    display: block;
    display: flex;
    font-size: 14px;
    justify-content: center;
    padding: 17px;
    text-align: center;
    text-decoration: none;
    width: calc(25% - 18px)
}

@media screen and (min-width:641px)and (max-width:899px) {
    .lo-Wrapper_Contner {
        padding-left: 16px;
        padding-right: 16px
    }
}

@media screen and (min-width:769px) {
    .st-FooterMain_Container {
        padding-left: 20px;
        padding-right: 20px
    }
}

@media screen and (min-width:900px) {
    .lo-Wrapper_Contner {
        max-width: 1120px;
        padding-left: 20px;
        padding-right: 20px
    }
}

@media screen and (max-width:768px) {
    #edit-section section #contents-inner {
        padding: 0
    }

    #edit-section section .description-title-h3 {
        margin-bottom: 16px
    }

    .product-description .product-description-title {
        margin-bottom: 10px
    }

    #edit-section .movie {
        margin: 0 0 16px;
        padding: 56.25% 0 0;
        position: relative;
        width: 100%
    }

    #edit-section .x_widget {
        margin: 0 0 16px;
        padding: 2% 0 0;
        position: relative;
        width: 100%
    }

    #edit-section .movie iframe {
        height: 100%;
        left: 0;
        position: absolute;
        top: 0;
        width: 100%
    }

    #img-float {
        flex-flow: column;
        gap: 16px
    }

    #img-float div {
        width: 100%
    }

    #img-group {
        flex-flow: column
    }

    #img-group li {
        width: 100%
    }

    #img-group li img {
        -o-object-fit: cover;
        object-fit: cover
    }

    #link-outside {
        justify-content: center
    }

    #notice .product-description {
        margin-bottom: 32px
    }

    #notice .product-description .product-description-body ul {
        padding-left: 22px
    }

    #buying-inner {
        margin-bottom: 32px
    }

    .sample-box-inner {
        margin: 0
    }

    .st-FooterMain_Container {
        padding-left: 10px;
        padding-right: 10px
    }

    #help-inner {
        align-items: center;
        flex-flow: column;
        margin-bottom: 42px
    }

    #help .help-btn {
        min-width: 186px
    }
}

@media screen and (max-width:640px) {
    .lo-Wrapper_Contner {
        padding-left: 10px;
        padding-right: 10px
    }
}

p.img-group-str {
    font-size: 12px;
    line-height: 18px;
    letter-spacing: 0.02rem;
    font-weight: 500;
}

p.img-group-str-blue {
    font-size: 12px;
    line-height: 18px;
    letter-spacing: 0.02rem;
    font-weight: 500;
    color: #089EDF;
}

#img-group li p.img-group-bold {
    font-size: 16px;
    line-height: 18px;
    font-weight: 700;
}

a#lineup-btn {
    background-color: #65BBE8;
}

#img-group li img {
    border: none;
}

#img-group {
    padding: 0 20px;
}

@media screen and (min-width: 861px) {
    .img-blue {
        margin-right: 24px;
    }
}

@media screen and (max-width: 768px) {
    .img-blue {
        padding: 0 80px;
        margin-bottom: 24px;
    }
}