/* Purged CSS - unused selectors removed */
/* Original: 102,634 bytes */

@charset "UTF-8";

/*! normalize.css v4.1.1 | MIT License | github.com/necolas/normalize.css */
html {
    font-family: sans-serif;
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%
}

body {
    margin: 0
}

article, aside, details, figcaption, figure, footer, header, main, menu, nav, section, summary {
    display: block
}

audio, canvas, progress, video {
    display: inline-block
}

audio:not([controls]) {
    display: none;
    height: 0
}

progress {
    vertical-align: baseline
}

template, [hidden] {
    display: none
}

a {
    background-color: transparent;
    -webkit-text-decoration-skip: objects;
    text-decoration: none;
}

a:active, a:hover {
    outline-width: 0
}

abbr[title] {
    border-bottom: none;
    text-decoration: underline;
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted
}

b, strong {
    font-weight: inherit
}

b, strong {
    font-weight: bolder
}

dfn {
    font-style: italic
}

h1 {
    font-size: 2rem;
    font-weight: 700;
    color:#fff;
}

mark {
    background-color: #ff0;
    color: #000
}

small {
    font-size: 80%
}

sub, sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline
}

sub {
    bottom: -.25em
}

sup {
    top: -.5em
}

img {
    border-style: none
}

svg:not(:root) {
    overflow: hidden
}

code, kbd, pre, samp {
    font-family: monospace, monospace;
    font-size: 1em
}

figure {
    margin: 1em 40px
}

hr {
    -webkit-box-sizing: content-box;
    box-sizing: content-box;
    height: 0;
    overflow: visible
}

button, input, select, textarea {
    font: inherit;
    margin: 0
}

optgroup {
    font-weight: 700
}

button, input {
    overflow: visible
}

button, select {
    text-transform: none
}

button, html [type="button"], [type="reset"], [type="submit"] {
    -webkit-appearance: button
}

button::-moz-focus-inner, [type="button"]::-moz-focus-inner, [type="reset"]::-moz-focus-inner, [type="submit"]::-moz-focus-inner {
    border-style: none;
    padding: 0
}

button:-moz-focusring, [type="button"]:-moz-focusring, [type="reset"]:-moz-focusring, [type="submit"]:-moz-focusring {
    outline: 1px dotted ButtonText
}

fieldset {
    border: 1px solid silver;
    margin: 0 2px;
    padding: .35em .625em .75em
}

legend {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    color: inherit;
    display: table;
    max-width: 100%;
    padding: 0;
    white-space: normal
}

textarea {
    overflow: auto
}

[type="checkbox"], [type="radio"] {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    padding: 0
}

[type="number"]::-webkit-inner-spin-button, [type="number"]::-webkit-outer-spin-button {
    height: auto
}

[type="search"] {
    -webkit-appearance: textfield;
    outline-offset: -2px
}

[type="search"]::-webkit-search-cancel-button, [type="search"]::-webkit-search-decoration {
    -webkit-appearance: none
}

::-webkit-input-placeholder {
    color: inherit;
    opacity: .54
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit
}

*, *::before, *::after {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    font-size: inherit;
    line-height: inherit;
    vertical-align: top;
    margin: 0;
    padding: 0
}

html {
    font-size: 62.5%;
    width: 100%;
    height: 100%
}

body {
    font-family: "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
    line-height: 1;
    color: #333;
    background: #fff;
    width: 100%;
    height: 100%;
    position: relative;
}

@media screen and (min-width:828px) {
    body {
            font-size: 2.6rem
        }
}

@media screen and (max-width:828px) {
    body {
            font-size: 3.5vw
        }
}

h1, h2, h3, h4, h5, h6 {
    font-weight: 400;
    margin: 0
}

p {
    line-height: 1.6
}

a:hover {
    text-decoration: underline
}

figure {
    margin: 0
}

img {
    width: auto;
    height: auto
}

ul, ol {
    list-style: none
}

table {
    border-spacing: 0;
    border-collapse: collapse
}

hr {
    border-color: #ccc;
    border-style: solid;
    border-width: 1px 0 0
}

@media screen and (min-width:828px) {
    hr {
            margin: 60px 0
        }
}

@media screen and (max-width:828px) {
    hr {
            margin: 24px 0
        }
}

button, input, select, textarea {
    font-family: sans-serif
}

::-moz-selection {
    color: #fff;
    background: #22b5e6
}

::selection {
    color: #fff;
    background: #22b5e6
}

::-moz-selection {
    color: #fff;
    background: #22b5e6
}

.contents-wrap {
    position: relative;
    overflow-x: hidden;

    max-width: 750px;
    margin: auto;
    background: url(./images/pattern.png) #f0fcff
}

.contents {
    position: relative;
    padding: 0 2%;
}

.footer {
    background: #fff;
    text-align: center;
    padding: 8%;
    margin-top: 8%
}

.footer-nav {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin-top: 2rem
}

.footer-nav-item {
    margin: 0 2%
}

.footer-nav-link {
    color: #999;
    line-height: 1;
    font-size: 1.3rem;
}

@media screen and (max-width:750px) {
    .footer-nav-link {
            font-size: 2.6vw
        }
}

.footer-copyright {
    margin-top: 4% ;
    text-align: center;
}

.footer-copyright small {
    line-height: 1.2;
    color: #999;
    font-size: 2rem;
    display: block
}

@media screen and (max-width:750px) {
    .footer-copyright small {
            font-size: 2.6vw
        }
}

.button {
    display: block;
    text-align: center;
    font-weight: 700;
    margin-top: 1%;
    padding: 1em;
    line-height: 1;
    color: #fff;
    border-radius: 100px;
    background: #f55677;
    border: 0;
    width: 100%;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    cursor: pointer;
    font-size: 2.8rem;
    -webkit-box-shadow: 0 10px 0 #d03455;
    box-shadow: 0 10px 0 #d03455
}

.button.--icon::after {
    content: "";
    width: 1.2em;
    height: 1em;
    display: inline-block;
    margin-left: 2%;
    background: url(./images/ic_link.png) center center no-repeat
}

.button.--icon.--small {
    -webkit-box-shadow: none;
    box-shadow: none
}

.button.--icon.--small::after {
    width: 1em;
    height: 1em;
    background-size: contain
}

.button.--gray {
    background: #f5f5f5;
    -webkit-box-shadow: 0 10px 0 #bfbfbf;
    box-shadow: 0 10px 0 #bfbfbf;
    color: #999
}

.button.--gray.--small {
    -webkit-box-shadow: none;
    box-shadow: none
}

.button.--small {
    -webkit-box-shadow: none;
    box-shadow: none;
    border-radius: 4px;
    font-size: 2rem;
    padding: .5em
}

@media screen and (max-width:750px) {
    .button {
            font-size: 3.7vw;
            -webkit-box-shadow: 0 1vw 0 #cc5266;
            box-shadow: 0 1vw 0 #cc5266
        }
    .button.--icon::after {
            background: url(./images/ic_link.png) center center/contain no-repeat
        }
    .button.--small {
            font-size: 2.6vw;
            -webkit-box-shadow: none;
            box-shadow: none;
            border-radius: 4px
        }
    .button.--gray {
            -webkit-box-shadow: 0 1vw 0 #bfbfbf;
            box-shadow: 0 1vw 0 #bfbfbf
        }
    .button.--gray.--small {
            -webkit-box-shadow: none;
            box-shadow: none
        }
}

.app-table-btn-item .button {
    margin-top: 0
}

.title {
    font-size: 3rem;
    font-weight: 700;
    line-height: 1;
    border-bottom: 4px solid #22b5e6;
    padding-bottom: 2%;
    margin-top: 8%;
}

@media screen and (max-width:750px) {
    .title {
            font-size: 4.2vw
        }
}

@-webkit-keyframes blink1 {
    0% {
        opacity: 0
    }

    100% {
        opacity: 1
    }
}

@keyframes blink1 {
    0% {
        opacity: 0
    }

    100% {
        opacity: 1
    }
}

.ranking-head {
    background: #22b5e6;
    padding: 1rem;
    color: #fff;
    text-align: center;
    font-weight: 700;
    font-size: 3rem;
    margin-top: 4%;
}

.ranking-head small {
    font-size: 2.2rem;
    display: block;
    margin-top: 1em
}

@media screen and (max-width:750px) {
    .ranking-head {
            font-size: 4vw
        }
    .ranking-head small {
            font-size: 3vw
        }
}

.section {
    margin-top: 4%
}

.app-catch {
    text-align: center;
    font-weight: 700;
    color: #f55677
}

.app-rank {
    font-size: 4rem;
    line-height: 1.5;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 4%;
    background: #22b5e6;
    font-weight: 700;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.app-rank a {
    position: relative;
    color: #fff;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.app-rank a::after {
    content: "";
    width: 35px;
    height: 35px;
    display: inline-block;
    margin-left: 10px;
    background: url(./images/ic_link.png) center center/contain no-repeat
}

.app-rank::before {
    width: 80px;
    height: 80px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    color: #22b5e6;
    margin-right: 4%;
    font-size: 4rem;
    font-weight: 700;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    background: #fff
}

@media screen and (max-width:750px) {
    .app-rank {
            font-size: 4.2vw
        }
    .app-rank a::after {
            width: 4.4vw;
            height: 4.4vw;
            margin-left: 1.2vw
        }
    .app-rank::before {
            width: 8.4vw;
            height: 8.4vw;
            font-size: 4.2vw
        }
}

.app-info {
    margin: 4% 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    color: #333
}

.app-info:hover {
    text-decoration: none
}

.app-info-icon {
    width: 120px
}

.app-info-icon img {
    border-radius: 10%
}

.app-info-icon.--border img {
    border: 2px solid #ddd
}

@media screen and (max-width:750px) {
    .app-info-icon {
            width: 16vw
        }
}

.app-info-detail {
    width: calc(100% - 135px)
}

@media screen and (max-width:750px) {
    .app-info-detail {
            width: calc(100% - 18vw)
        }
}

.app-type {
    margin-left: auto;
    width: 16%
}

.app-type span {
    display: block;
    font-size: 2.2rem;
    color: #fff;
    border: 2px solid #fff;
    padding: 4%;
    text-align: center
}

@media screen and (max-width:750px) {
    .app-type span {
            font-size: 3vw
        }
}

.app-body {
    background: #fff;
    padding: 6%;
    -webkit-box-shadow: 0 8px 8px rgba(0, 0, 0, .1);
    box-shadow: 0 8px 8px rgba(0, 0, 0, .1)
}

.app-img {
    margin-top: 4%
}

.app-img img {
    width: 100%
}

.app-text {
    margin: 2% 0;
    line-height: 1.8
}

.app-text span {
    color: #22b5e6
}

.app-dl-title-wrap {
    text-align: center
}

.app-dl-title {
    display: inline-block;
    vertical-align: bottom;
    font-weight: 700;
    position: relative;
    color: #f55677
}

.app-dl-title::before, .app-dl-title::after {
    content: "";
    display: block;
    width: .5%;
    height: 100%;
    background: #f55677;
    position: absolute;
    top: 0
}

.app-dl-title::before {
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    left: -8%
}

.app-dl-title::after {
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    right: -8%
}

.app-dl-title span {
    vertical-align: bottom
}

.app-dl-caption {
    color: #ccc;
    text-align: center;
    margin-top: 1em;
    font-size: 2rem
}

@media screen and (max-width:750px) {
    .app-dl-caption {
            font-size: 2.6vw
        }
}

.app-review-table {
    border: 2px solid #f2f2f2;
    width: 100%
}

.app-review-table tr:not(:last-of-type) th {
    border-bottom: 2px solid #fff
}

.app-review-table th, .app-review-table td {
    padding: 2%;
    font-size: 2.2rem
}

.app-review-table th {
    background: #f2f2f2;
    border-bottom: 2px solid #fff;
    font-weight: 400;
    text-align: left
}

.app-review-table td {
    border-bottom: 2px solid #f2f2f2
}

@media screen and (max-width:750px) {
    .app-review-table th, .app-review-table td {
            font-size: 3vw
        }
}

.app-review-table-rank {
    color: #f55677;
    display: block;
    font-weight: 700;
    margin-bottom: 5px;
    display: inline-block;
    margin-bottom: 0
}

.app-review-table-rank.--inline {
    display: inline-block;
    margin-bottom: 0
}

.app-review-table-star {
    color: #ffbf45;
    overflow: hidden
}

.modal-item .button {
    font-size: 20px;
    line-height: 1.5
}

@media screen and (max-width:750px) {
    .modal-item .button {
            font-size: 2.8vw
        }
}

.shindan-text {
    padding: 1em;
    text-align: center;
    line-height: 1.6;
    background: #f0fcff
}

.shindan-text span {
    font-size: 2rem;
    color: #22b5e6;
    font-weight: 700
}

.shindan-app-item {
    width: 27%;
    text-align: center
}

.shindan-app-icon img {
    border-radius: 10%;
    background: #fff;
}

.shindan-app-icon.--border img {
    border: 2px solid #ddd;
    max-width:100%;
}

.shindan-app-title {
    font-size: 1.12rem;
    padding-bottom: 0;
    background-position: center bottom;
    background-repeat: no-repeat
}

@media screen and (max-width:750px) {
    .shindan-app-title {
            padding-bottom: 0;
            background-size: 4.2vw
        }
}

.shindan-app-title span {
    font-weight: 700
}

.top-text {
    margin: 3%;
    padding-bottom: 15px
}

.top-text span {
    font-weight: 700;
    color: #f55677
}

.shindan-check {
    margin: 2% 4% 5% 4%;
}

.sf-head-check {
    display: none
}

.sf-head-check:checked+.sf-head:after {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg)
}

.sf-head-check:checked+.sf-head+.sf-body {
    display: none
}

.sf-head {
    background: #22b5e6;
    text-align: center;
    font-weight: 700;
    margin-top: 4%;
    padding: 2%;
    color: #fff;
    font-size: 2.8rem;
    cursor: pointer;
    width: 100%;
    display: block;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    position: relative;
}

.sf-head:after {
    content: "";
    display: block;
    width: 1em;
    height: 1em;
    background: url(./images/ic_arrow.webp) 50%/contain no-repeat;
    position: absolute;
    top: 50%;
    right: 4%;
    margin-top: -.5em;
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg)
}

@media screen and (max-width:750px) {
    .sf-head {
            font-size: 3.6vw
        }
}

.sf-body {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    padding: 4%;
    background: #FFF;
    border: 10px solid #22b5e6;
    border-top-width: 0
}

@media screen and (max-width:750px) {
    .sf-body {
            border-width: 0 5px 5px
        }
}

.searchfunction-head {
    text-align: center;
    font-weight: 700;
    margin-bottom: 2%
}

.searchfunction-head:not(:first-child) {
    margin-top: 4%
}

.searchfunction {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: left;
    -ms-flex-pack: left;
    justify-content: left;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.searchfunction-item {
    width: 48%;
    margin: 4% 0 0 4%
}

.searchfunction-item:nth-of-type(-n+2) {
    margin-top: 0
}

.searchfunction-item:nth-of-type(2n-1) {
    margin-left: 0
}

.searchfunction-item-wide {
    width: 100%
}

.searchfunction-item-wide:not(:first-child) {
    margin-top: 4%
}

.searchfunction-radio label {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    display: block;
    cursor: pointer;
    padding: 1em;
    position: relative;
    background: #ddf5f8;
    font-size: 1.4rem;
}

.searchfunction-radio label:before {
    content: "";
    display: inline-block;
    width: 1em;
    height: 1em;
    background: #fff;
    border-radius: 50%;
    margin-right: .5em
}

.searchfunction-radio input[type=radio] {
    display: none
}

.searchfunction-radio input[type=radio]:checked+label:before {
    background: #ff667f
}

.shindan-check-item {
    padding: 0 0 0 40px;
    background-position: left top;
    background-repeat: no-repeat;
    font-weight: 700
}

.shindan-check-item:not(:first-child) {
    margin-top: 1em
}

.--lover .shindan-check-item {
    background-image: url(./images/ic_check_lover.png)
}

.--play .shindan-check-item {
    background-image: url(./images/ic_check_play.png)
}

.--marriage .shindan-check-item {
    background-image: url(./images/ic_check_marriage.png)
}

@media screen and (max-width:750px) {
    .shindan-check-item {
            padding: 0 0 0 5.4vw;
            background-size: 3.3vw
        }
}

input[name="tab_item"] {
    display: none;
}

#all:checked~#all_content, #programming:checked~#programming_content, #design:checked~#design_content {
    display: block;
}

.sf-head-check:checked+.sf-head+.sf-body1 {
    display: block
}

input[name="tab_menu"] {
    display: none;
}

#menu01:checked~#menu01, #menu02:checked~#menu02, #menu03:checked~#menu03 {
    display: block;
}

.ribbon16-wrapper {
    display: block;
    position: relative;
    margin: 15px auto;
    background: #f1f1f1;
    box-sizing: border-box;
}

.ribbon16 {
    display: inline-block;
    position: absolute;
    top: -6px;
    right: 10px;
    margin: 0;
    padding: 10px 0 7px;
    z-index: 2;
    width: 40px;
    text-align: center;
    color: white;
    font-size: 15px;
    font-weight: 600;
    background: #f55677;
    border-radius: 2px 0 0 0;
}

.ribbon16:before {
    position: absolute;
    content: '';
    top: 0;
    right: -5px;
    border: none;
    border-bottom: solid 6px #f55677;
    border-right: solid 5px transparent;
}

.ribbon16:after {
    content: '';
    position: absolute;
    left: 0;
    top: 100%;
    height: 0;
    width: 0;
    border-left: 20px solid transparent;
    border-right: 20px solid transparent;
    border-top: 10px solid #f55677;
}

@keyframes fade-out {
    0% {
        visibility: visible;
        opacity: 1;
    }

    /* 最初は表示して、 */
    100% {
        visibility: hidden;
        opacity: 0;
    }

    /* フェードアウトする */
}

.contents2 {
    position: relative;
    padding: 0 0;
    width: 100%;
}

.contents-wrap1 {
    position: relative;
    overflow: hidden;
    max-width: 430px;
    margin: auto;
    background: #F1FBFB;
}

.ribbon16-wrapper1 {
    width: 100%;
    display: block;
    margin: auto;
    box-sizing: border-box;
    background: #DFFAFF;
}

.ribbon16_1 {
    display: inline-block;
    position: absolute;
    top: 6px;
    right: 6px;
    margin: 0;
    padding: 0.5% 0;
    z-index: 2;
    width: 30px;
    text-align: center;
    color: #929292;
    font-size: 1.2rem;
    font-weight: 700;
    border: 1px solid #929292;
    border-radius: 3px;
}

.sf-head1 {
    background: #fff;
    color: #929292;
    border: 2px solid #929292;
    text-align: center;
    font-weight: 700;
    padding: 2%;
    font-size: 1.3rem;
    cursor: pointer;
    width: 100%;
    display: block;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    position: relative;
    border-radius: 5px;
}

.sf-body2 {
    display: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    padding: 4%;
    background: #FFF;
    border: 2px solid #929292;
    border-top-width: 0;
    border-radius: 5px;
}

.sf-head-check:checked+.sf-head1+.sf-body2 {
    display: block
}

.sb-button {
    display: block;
    margin: 1.5rem auto 0 auto;
    padding: 1rem 3rem;
    border-radius: 1.5rem;
    background: #ff9f4a;
    font-weight: 700;
    line-height: 1;
    color: #fff;
    text-align: center
}

@media screen and (max-width:750px) {
    .ranking-head1 {
            font-size: 3vw
        }
    .ranking-head1 small {
            font-size: 3vw
        }
}

@keyframes shiny {
    0% {
        transform: scale(0) rotate(25deg);
        opacity: 0;
    }

    50% {
        transform: scale(1) rotate(25deg);
        opacity: 1;
    }

    100% {
        transform: scale(50) rotate(25deg);
        opacity: 0;
    }
}

.button1 {
    display: flex;
    text-align: center;
    font-weight: 700;
    padding: 2% 5%;
    justify-content: center;
    align-items: center;
    color: #fff;
    border-radius: 24px;
    background: #f55677;
    border: 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    cursor: pointer;
    font-size: 1.5rem;
    box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
    overflow: hidden;
    position: relative;
    flex-direction: column; /* 追加: 縦方向に要素を配置 */
    letter-spacing: 0.5px;
}

.button1::before {
    content: '';
    position: absolute;
    top: -100px;
    left: -100px;
    width: 50px;
    height: 50px;
    background-image: linear-gradient(100deg, rgba(255, 255, 255, 0) 10%, rgba(255, 255, 255, 1) 100%, rgba(255, 255, 255, 0) 0%);

    /* アニメーション */
    animation-name: shiny;
    animation-duration: 2.5s;
    animation-timing-function: ease-in-out;
    animation-iteration-count: infinite;
    
}

.button1.--icon::after {
    content: "18歳未満の方はご利用できません。";
    font-size: 0.8rem;
    position: relative;
    top: 4px;
    justify-content: center;
    font-weight: 100; /* 追加: 水平方向中央寄せ */
}

.button1.--icon.--small {
    -webkit-box-shadow: none;
    box-shadow: none
}

.button1.--icon.--small::after {
    width: 1em;
    height: 1em;
    background-size: contain
}

.button1.--gray {
    background: #f5f5f5;
    -webkit-box-shadow: 0 10px 0 #bfbfbf;
    box-shadow: 0 10px 0 #bfbfbf;
    color: #999
}

.button1.--gray.--small {
    -webkit-box-shadow: none;
    box-shadow: none
}

.button1.--small {
    -webkit-box-shadow: none;
    box-shadow: none;
    border-radius: 4px;
    font-size: 2rem;
    padding: .5em
}

@media screen and (max-width:750px) {
    .button1 {
            font-size: 1.4rem;
            box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
        }
    .button1.--small {
            font-size: 1.4rem;
            -webkit-box-shadow: none;
            box-shadow: none;
            border-radius: 4px
        }
    .button1.--gray {
            -webkit-box-shadow: 0 1vw 0 #bfbfbf;
            box-shadow: 0 1vw 0 #bfbfbf
        }
    .button1.--gray.--small {
            -webkit-box-shadow: none;
            box-shadow: none
        }
}

.tab_wrap {
    width: 100%;
    justify-content: center;
    margin: auto;
    padding-bottom: 5%;
}

.category-title {
    font-weight: 700;
    font-size: 1.7rem;
    padding: 2% 0;
}

.tab_panel {
    width: 100%;
}

.tab_panel p {
    text-align: center;
}

#panel1 .category-title {
    background-color: #57BED1;
    color: #FFF;
}

#panel1 {
    border: 2px solid #57bed1;
    background: #d8f9ff;
    margin-bottom: 3%;
    margin-top: 5%;
}

.shindan-app-lover {
    background: #d8f9ff;
    padding: 4%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between
}

#panel2 .category-title {
    background-color: #ff9900;
    color: #FFF;
}

#panel2 {
    border: 2px solid #ff9900;
    background: #fff6e9;
    margin-bottom: 3%;
}

.shindan-app-play {
    background: #fff6e9;
    padding: 4%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between
}

#panel3 .category-title {
    background-color: #e36179;
    color: #FFF;
}

#panel3 {
    border: 2px solid #e36179;
    background: #ffe9ed;
}

.shindan-app-marrige {
    background: #ffe9ed;
    padding: 4%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between
}

#panel2 .shindan-check-item {
    background-image: url(./images/ic_check_lover.png)
}

#panel3 .shindan-check-item {
    background-image: url(./images/ic_check_play.png)
}

#panel1 .shindan-check-item {
    background-image: url(./images/ic_check_marriage.png)
}

.kuchikomi {
    margin: 0 2%;
}

.accordion-001 {
    border-radius: 8px;
    background: #F7F7F7;
    padding-bottom: 2px;
}

.accordion-001:not([open]) {
    margin-bottom: 7px;
}

.accordion-001 summary {
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    padding: 1em 2em;
    border-radius: 8px;
    background: #F7F7F7;
    color: #000;
    cursor: pointer;
    font-size: 14px;
    font-weight: 700;
    line-height: 28px;
    /* 200% */
    letter-spacing: 0.42px;
}

.accordion-001 summary::-webkit-details-marker {
    display: none;
}

.accordion-001 summary::after {
    transform: translateY(-25%) rotate(45deg);
    width: 7px;
    height: 7px;
    margin-left: 10px;
    border-bottom: 3px solid #000;
    border-right: 3px solid #000;
    content: '';
    transition: transform .3s;
}

.accordion-001[open] summary::after {
    transform: rotate(225deg);
}

.accordion-001[open] p {
    transform: none;
    opacity: 1;
}

.category {
    width: 100%;
    flex-grow: 1;
}

.purpose span {
    margin-bottom: 2%;
    display: inline-flex;
    border: 1px solid #B0B0B0;
    color: #B0B0B0;
    width: 23%;
    justify-content: center;
    align-items: center;
    gap: 10px;
    border-radius: 17px;
    height: 22px;
    flex-direction: column;
    flex-shrink: 0;
    text-align: center;
    font-size: 12px;
    font-weight: 700;
    line-height: 28px;
    /* 233.333% */
    letter-spacing: 0.6px;
}

.purpose .love {
    border: 1px solid #57bed1;
    background-color: #57bed1;
    color: #fff;
    width: 23%;
    justify-content: center;
    align-items: center;
    gap: 10px;
    border-radius: 17px;
    height: 22px;
    flex-direction: column;
    flex-shrink: 0;
    text-align: center;
    font-size: 12px;
    font-weight: 700;
    line-height: 28px;
    /* 233.333% */
    letter-spacing: 0.6px;
}

.purpose .date {
    border: 1px solid #FF00C7;
    background-color: #FF00C7;
    color: #fff;
    width: 23%;
    justify-content: center;
    align-items: center;
    gap: 10px;
    border-radius: 17px;
    height: 22px;
    flex-direction: column;
    flex-shrink: 0;
    text-align: center;
    font-size: 12px;
    font-weight: 700;
    line-height: 28px;
    /* 233.333% */
    letter-spacing: 0.6px;
}

.purpose .play {
    border: 1px solid #ff9900;
    background-color: #ff9900;
    color: #fff;
    width: 23%;
    justify-content: center;
    align-items: center;
    gap: 10px;
    border-radius: 17px;
    height: 22px;
    flex-direction: column;
    flex-shrink: 0;
    text-align: center;
    font-size: 12px;
    font-weight: 700;
    line-height: 28px;
    /* 233.333% */
    letter-spacing: 0.6px;
}

.purpose .marriage {
    border: 1px solid #e36179;
    background-color: #e36179;
    color: #fff;
    width: 23%;
    justify-content: center;
    align-items: center;
    gap: 10px;
    border-radius: 17px;
    height: 22px;
    flex-direction: column;
    flex-shrink: 0;
    text-align: center;
    font-size: 12px;
    font-weight: 700;
    line-height: 28px;
    /* 233.333% */
    letter-spacing: 0.6px;
}

.generation span {
    margin-bottom: 2%;
    display: inline-flex;
    border: 1px solid #B0B0B0;
    color: #B0B0B0;
    width: 23%;
    justify-content: center;
    align-items: center;
    gap: 10px;
    border-radius: 17px;
    height: 22px;
    flex-direction: column;
    flex-shrink: 0;
    text-align: center;
    font-size: 12px;
    font-weight: 700;
    line-height: 28px;
    /* 233.333% */
    letter-spacing: 0.6px;
}

.generation .select {
    border: 1px solid #797979;
    color: #fff;
    background-color: #797979;
    width: 23%;
    justify-content: center;
    align-items: center;
    gap: 10px;
    border-radius: 17px;
    height: 22px;
    flex-direction: column;
    flex-shrink: 0;
    text-align: center;
    font-size: 12px;
    font-weight: 700;
    line-height: 28px;
    /* 233.333% */
    letter-spacing: 0.6px;
}

.ranking-head1 {
    display: flex;
    padding: 1%;
    flex-direction: column;
    vertical-align: middle;
    align-items: center;
    background: #57BED1;
}

.ranking-head1 span {
    color: #FFF;
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 116.667%;
    letter-spacing: -0.24px;
}

.ranking-head1 small {
    color: #FFF;
    font-size: 1.2rem;
    font-weight: 500;
    line-height: 175%;
    /* 175% */
    letter-spacing: 0.8px;
}

.ranking-body-new {
    margin-bottom: 3%;
    padding: 1% 2% 0% 2%;
    flex-direction: column;
    align-items: center;
}

.ranking-frame {
    border-radius: 10px;
    background: #fff;
    padding: 1% 1% 0% 1%;
    margin-bottom: 1%;
    box-shadow: 0px 1px 1px 1px rgba(0, 0, 0, 0.25);
}

.ranking-body-content {
    display: flex;
    border-radius: 10px;
}

.ranking-icon-new {
    width: 65px;
    margin: 4.6% 3.7% 5.5% 3.7%;
    justify-content: flex-start;
    align-items: center;
    border-radius: 6px;
    background: #ffffff;
}

.ranking-icon-new img {
    border: 1px solid #ddd;
    border-radius: 10%;
    background: #fff;
    width: 65px;
}

.name-and-review {
    display: flex;
    margin-left: 4%;
}

.ranking-content-name {
    flex-grow: 1;
}

.ranking-frame:nth-child(1) .top-ranking-number, .ranking-frame-5:nth-child(1) .top-ranking-number {
    width: 3rem;
    height: 3rem;
    background-color: #f2b50d;
    font-weight: 700;
    color: #FFF;
    text-align: center;
    border-radius: 100%;
    margin-right: 1.5%;
    font-size: 1.5rem;
    line-height: 3.1rem;
}

.ranking-frame:nth-child(2) .top-ranking-number, .ranking-frame-5:nth-child(2) .top-ranking-number {
    width: 3rem;
    height: 3rem;
    background-color: #738C8C;
    font-weight: 700;
    color: #FFF;
    text-align: center;
    border-radius: 100%;
    margin-right: 1.5%;
    font-size: 1.5rem;
    line-height: 3.1rem;
}

.ranking-frame:nth-child(3) .top-ranking-number, .ranking-frame-5:nth-child(3) .top-ranking-number {
    width: 3rem;
    height: 3rem;
    background-color: #B36B4D;
    font-weight: 700;
    color: #FFF;
    text-align: center;
    border-radius: 100%;
    margin-right: 1.5%;
    line-height: 3.1rem;
    font-size: 1.5rem;
}

.ranking-frame-5:nth-child(4) .top-ranking-number {
    width: 3rem;
    height: 3rem;
    background-color: #b34d76;
    font-weight: 700;
    color: #FFF;
    text-align: center;
    border-radius: 100%;
    margin-right: 1.5%;
    line-height: 3.1rem;
    font-size: 1.5rem;
}

.ranking-frame-5:nth-child(5) .top-ranking-number {
    width: 3rem;
    height: 3rem;
    background-color: #b34d4d;
    font-weight: 700;
    color: #FFF;
    text-align: center;
    border-radius: 100%;
    margin-right: 1.5%;
    line-height: 3.1rem;
    font-size: 1.5rem;
}

.top-app-star {
    color: #ffc700;
    margin-right: 2.3%;
}

.top-app-review-new {
    display: flex;
    color: #000;
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0.48px;
    margin: 0 0 0 auto;
    padding-right: 2%;
    line-height: 26px;
    font-size: 1.3rem;
}

.top-app-review-new-1 {
    margin-right: 2.3%;
}

.top-ranking-app {
    color: #000;
    font-size: 1.8rem;
    font-weight: 700;
    letter-spacing: 1px;
    line-height: 2.8rem;
    position: relative;
    display: inline-block;
}

.top-ranking-app a {
    color: #000;
    border-bottom: solid 1px #000;
}

.top-ranking-point {
    color: #000;
    font-size: 1.4rem;
    font-weight: 700;
    margin-left: 5%;
    margin-top: 0.5%;
}

.top-ranking-point-1 {
    color: #000;
    font-weight: 500;
    line-height: 1.3;
    font-size: 1.45rem;
    margin-left: 5%;
    text-align: justify;
    display: inline-table;
}

.ranking-frame:nth-child(n + 4) {
    display: none;
}

.SF {
    padding: 0 2%;
    padding-bottom: 2%;
}

.ranking-section {
    display: block;
    padding: 2%;
    border-radius: 10px;
    background: #FFF;
    width: 100%;
    margin-top: 2%;
    box-shadow: 0px 1px 1px 1px rgba(0, 0, 0, 0.25);
    /*各紹介ごとの余白*/
}

.ranking-section-top {
    display: flex;
    margin: 2% 0 0 0;
}

.app-icon {
    margin: 3% 0;
}

.app-icon img {
    border: 1px solid #ddd;
    border-radius: 10%;
    width: 70px;
    height: auto;
}

.section-line {
    border: 2px solid #D9D9D9;

}

.app-summary {
    margin: 3.5% 0 3% 0;
    font-weight: 700;
    flex-grow: 1;
}

.app-summary-top {
    display: flex;
    margin-left: 3%;
}

.ranking-section:nth-child(1) .app-rank {
    background-color: #f2b50d;
    width: 3rem;
    height: 3rem;
    font-weight: 700;
    color: #FFF;
    justify-content: center;
    font-size: 1.5rem;
    border-radius: 100%;
    margin-top: 1%;
}

.ranking-section:nth-child(2) .app-rank {
    background-color: #738C8C;
    width: 3rem;
    height: 3rem;
    font-weight: 700;
    color: #FFF;
    justify-content: center;
    font-size: 1.5rem;
    border-radius: 100%;
    margin-top: 1%;
}

.ranking-section:nth-child(3) .app-rank {
    background-color: #B36B4D;
    width: 3rem;
    height: 3rem;
    font-weight: 700;
    color: #FFF;
    justify-content: center;
    font-size: 1.5rem;
    border-radius: 100%;
    margin-top: 1%;
}

.ranking-section:nth-child(n+4) .app-rank {
    background-color: #b34d4d;
    width: 3rem;
    height: 3rem;
    font-weight: 700;
    color: #FFF;
    justify-content: center;
    font-size: 1.5rem;
    border-radius: 100%;
    margin-top: 1%;
}

.app-summary-top .app {
    font-size: 2rem;
    margin-left: 1.39%;
    line-height: 1.5;
}

.app-summary-top .app a {
    color: #000;
    border-bottom: solid 1px #000;
}

.app-summary-top .app-s {
    font-size: 1.8rem;
    margin-left: 1.39%;
    line-height: 1.5;
}

.app-summary-top .app-s a {
    color: #000;
    border-bottom: solid 1px #000;
}

.one-point {
    margin-left: 3%;
    font-size: 1.7rem;
    line-height: 2.5rem;
}

.ranking-section-second {
    display: flex;
    padding-top: 3%;
}

.purchase-type {
    border-radius: 6px;
    background: #DFFAFF;
    margin-bottom: 2.5%;
    width: 20%;
    height: 50px;
}

.purchase-type span {
    display: block;
    font-size: 1.2rem;
    color: #004652;
    font-weight: 700;
    letter-spacing: 0.6px;
    line-height: 50px;
    text-align: center;
}

.summary-table-frame {
    margin-bottom: 1%;
}

.summary-table {
    display: flex;
    height: 7vw;
}

.summary-1st {
    background: #EBEBEB;
    color: #404040;
    font-size: 1.1rem;
    font-weight: 500;
    width: 20%;
    border: 1px solid #DEDEDE;
    text-align: center;
    line-height: 7vw;
}

.summary-2nd {
    background: #FFF;
    color: #2F2F2F;
    font-size: 1.2rem;
    font-weight: 700;
    padding-left: 3%;
    border: 1px solid #DEDEDE;
    width: 30%;
    line-height: 7vw;
}

.summary-3rd {
    background: #FFF;
    color: #2F2F2F;
    font-size: 1.2rem;
    font-weight: 700;
    white-space: nowrap;
    padding-left: 3%;
    border: 1px solid #DEDEDE;
    width: 80%;
    line-height: 7vw;
}

@media screen and (min-width: 960px) {
    .summary-table {
            height: 1.5vw;
        }
    .summary-1st {
            line-height: 1.5vw;
        }
    .summary-2nd {
            line-height: 1.5vw;
        }
    .summary-3rd {
            line-height: 1.5vw;
        }
}

.summary-button-area {
    padding: 1% 0;
}

.ranking-section .app-img {
    margin: 2% 0;
}

.summary-text {
    font-size: 1.7rem;
    line-height: 150%;
    letter-spacing: 0.48px;
}

.summary-text span {
    font-weight: 700;
    background: linear-gradient(transparent 75%, #ffff7f 75%);
}

.sales-point {
    border-radius: 8px;
    border: 1px solid #5CC5D8;
    background: #F5FEFF;
    padding: 2% 3%;
    flex-direction: column;
    justify-content: center;
    margin-bottom: 4%;
    margin-top: 4%;
}

.sales-point span {
    display: inline-block;
    color: #2F2F2F;
    font-size: 20px;
    font-weight: 700;
    line-height: 28px;
    /* 140% */
    letter-spacing: 0.6px;
    gap: 10px;
    align-self: stretch;
}

.sales-point img {
    display: inline-block;
    width: 30px;
    height: 30px;
}

.sales-point li {
    color: #2F2F2F;
    font-size: 14px;
    font-weight: 700;
    line-height: 200%;
    letter-spacing: 0.42px;
    list-style: disc;
    margin-left: 8%;
}

.kuchikomi {
    border-radius: 8px;
    background: #FFF;
    padding: 6% 4%;
    margin-bottom: 2%;
}

.kuchikomi-top {
    display: flex;
    margin-bottom: 2%;
}

.kuchikomi-img img {
    width: 70px;
    height: 70px;
}

.kuchikomi-name {
    vertical-align: center;
    font-weight: 700;
    margin-top: 6%;
    margin-left: 7%;
    width: 100%;
    line-height: 140%;
    font-size: 1.7rem;
}

.kuchikomi-name span {
    font-weight: 500;
    font-size: 1.4rem;
}

.kuchikomi-review {
    font-weight: 700;
    font-size: 1.5rem;
    margin-left: 7%;
    width: 100%;
}

.kuchikomi-review span {
    color: #FFC700;
}

.shindan-body-new {
    padding: 3% 0;
}

.shindan-top {
    font-weight: 700;
    font-size: 1.4rem;
    color: #fff;
    background: #57BED1;
    border-radius: 25px;
    text-align: center;
    padding: 2%;
    width: 80%;
    margin: auto;
}

.shindan-head-text {
    color: #444;
    font-weight: 700;
    font-size: 1.7rem;
    text-align: center;
    margin-top: 2%;
}

.shindan-body-text {
    color: #444;
    font-weight: 700;
    font-size: 1.4rem;
    width: 80%;
    margin: auto;
    padding-top: 1%;
    text-align: justify;
}

.shindan-img-area {
    width: 100%;
    
}

.shindan-img-main02 {
    display: block;
    padding-top: 3%;
    margin: auto;
    width: 80%;
}

.shindan-body-app {
    padding: 2%;
}

.multi-use {
    display: block;
    padding-top: 3%;
    margin: auto;
    width: 90%;
}

.shousai {
    padding: 0% 2%;
    background: #F1FBFB;
}

.reference {
    font-size: 1rem;
    font-weight: 500;
}

.summary-text .reference {
    font-size: 1rem;
    font-weight: 500;
    border: none;
}

.ranking-section:nth-child(n + 11) {
    display: none;
}

.shindan-app-lover>.shindan-app-item:nth-child(n+5) {
    display: none;
}

.shindan-app-play>.shindan-app-item:nth-child(n+5) {
    display: none;
}

.shindan-app-marrige>.shindan-app-item:nth-child(n+5) {
    display: none;
}

.campaign {
    background-color: #fae1e8;
    border: 1px solid #E36179;
    border-radius: 8px;
    padding: 2% 4%;
    margin-top: 3%;
}

.campaign .head-title {
    font-weight: 700;
    font-size: 1.7rem;
    text-align: center;
}

.campaign p {
    font-weight: 500;
    font-size: 1.5rem;
}

.campaign p span {
    font-weight: 700;
    background: linear-gradient(transparent 75%, #ffff7f 75%);
}

.coupon {
    display: flex;
    justify-content: center;
    font-size: 1.5rem;
}

.coupon-code {
    background: #f0f0f0;
    font-weight: 700;
    border: solid 1px #cccccc;
    margin: 1% 2% 0 0;
    padding: 1% 3%;
    border-radius: 5px;
    width: 60%;
    text-align: center;
    font-size: 1.5rem;
}

.copy-button {
    color: #FFF;
    margin: 1% 2% 0 0;
    padding: 1% 3%;
    border-radius: 5px;
    background-color: #1d8258;
    font-weight: 700;
    border: solid 1px #1d8258;
    box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
    cursor: pointer;
    width: 25%;
    text-align: center;
    font-size: 1.5rem;
}

.top-coupon {
    display: flex;
    margin-left: 5%;
}

.shousai .section:nth-child(n+11) {
    display: none;
}

.shindan-app-item {
    display: none;
    /* 最初に全て非表示にする */
}

.shindan-app-item:nth-child(-n+3) {
    display: block;
    /* 最初から3つまでを表示 */
}

.fvtitle {
    position: relative;
    padding: 0.2em 0.5em;
    background:  #fff;
    color: #000;
    box-shadow: 0 0 4px rgba(0, 0, 0, 0.56);
    font-size: 1.7rem;
    font-weight: 700;
    text-align: center;
    margin: 2% 0;
}

.fvtitle .reference {
    display: block;
    height: 10%;
}

.summary-button-area p {
    font-size: 1rem;
    margin-top: 1%;
    text-align: center;
    color: #aaa;
}

.mid-table .purpose .love, .mid-table .purpose .marriage, .mid-table .purpose .play, .mid-table .purpose .date, .mid-table .purpose span {
    width: 60%;
}

.mid-table .generation .select-20, .mid-table .generation .select-30, .mid-table .generation .select-40, .mid-table .generation span {
    width: 60%;
}

.mid-table .generation .select-20 {
    background-color: #73AEFE;
    color:#fff;
    border: 1px solid #fff;
}

.mid-table .generation .select-30 {
    background-color: #5271fe;
    color:#fff;
    border: 1px solid #fff;
}

.mid-table .generation .select-40 {
    background-color: #3b52b7;
    color:#fff;
    border: 1px solid #fff;
}

.onepoint-label-1 {
    position: relative;
    padding: 0.6em;
    background: #2a59b8;
    display: inline-block;
    margin-bottom: 5px;
    font-size: 1.1rem;
    font-weight: 600;
    border-radius: 10px;
    color: #fff;
}

.onepoint-label-1:after {
    position: absolute;
    content: '';
    top: 70%;
    left: 37%;
    border: 10px solid transparent;
    border-top: 10px solid #2a59b8;
    width: 0;
    height: 0;
}

.onepoint-label-2 {
    position: relative;
    padding: 0.6em;
    background: #ff7b00;
    display: inline-block;
    margin-bottom: 5px;
    font-size: 1.1rem;
    font-weight: 600;
    border-radius: 10px;
    color: #fff;
    
}

.onepoint-label-2:after {
    position: absolute;
    content: '';
    top: 70%;
    left: 37%;
    border: 10px solid transparent;
    border-top: 10px solid #ff7b00;
    width: 0;
    height: 0;
}

.onepoint-label-3 {
    position: relative;
    padding: 0.6em;
    background: #d03455;
    display: inline-block;
    margin-bottom: 5px;
    font-size: 1.1rem;
    font-weight: 600;
    border-radius: 10px;
    color: #fff;
}

.onepoint-label-3:after {
    position: absolute;
    content: '';
    top: 70%;
    left: 37%;
    border: 10px solid transparent;
    border-top: 10px solid #d03455;
    width: 0;
    height: 0;
}

.shindan-hikaku-table {
    padding: 2% 0;
}

.age_table {
    width: 95%;
    text-align: center;
    background-color: #fff;
    margin: auto;
    
}

.age_table th {
    width: 10%;
    vertical-align: middle;
    font-size: 1.3rem;
}

.age_table tr {
    border-bottom: dotted 1px #999;
}

.age_table td {
    width: 30%;
    padding: 2%;
    font-size: 1.3rem;
    font-weight: 700;
}

.age_table img {
    width: 70%;
    background-color: #fff;
    border-radius: 5px;
    border: solid 1px #ccc;
}

.age_table p {
    font-size: 1rem;
}

.age_table .love {
    background-color: #ddf5f8;
}

.age_table .marriage {
    background-color: #ffe8ee;
}

.age_table .date {
    background-color: #fff4e0;
}

.shindan-check-item {
    display: none; /* 最初はすべて非表示にする */
  }

.shindan-check-item:nth-child(-n+3) {
    display: list-item; /* 上位3つを表示する */
  }

  .ranking-category-love {
    text-align: center;
    margin-top: 3%;
    border-radius: 4px;
    background: #57BED1;
    color: #FFF;
    font-size: 12px;
    font-weight: 600;
}

.ranking-category-marrige {
    text-align: center;
    margin-top: 3%;
    border-radius: 4px;
    background: #E36179;
    color: #FFF;
    font-size: 12px;
    font-weight: 600;
}

.ranking-category-play {
    text-align: center;
    margin-top: 3%;
    border-radius: 4px;
    background: #ff9900;
    color: #FFF;
    font-size: 12px;
    font-weight: 600;
}

.CTA-with::before {
    display: inline-block;
    content:"＼ 2024年主要5社比較 新規ダウンロード数No.1 ／";
    font-size: 1.2rem;
    font-weight: 700;
    color: #f55677;
    width: 100%;
    text-align: center;
    margin-top: 5px;
    margin-bottom: 2px;
}

.CTA-pairs::before {
    display: inline-block;
    content:"＼ 課金時にコード入力で最大3,000円分eギフトポイント ／";
    font-size: 1.2rem;
    font-weight: 700;
    color: #f55677;
    width: 100%;
    text-align: center;
    margin-top: 5px;
    margin-bottom: 2px;
}

.CTA-tapple::before {
    display: inline-block;
    content:"＼ 半額クーポン入力で ¥2,450 キャッシュバック ／";
    font-size: 1.2rem;
    font-weight: 700;
    color: #f55677;
    width: 100%;
    text-align: center;
    margin-top: 5px;
    margin-bottom: 2px;
}

.CTA-omiai::before {
    display: inline-block;
    content:"＼ 年末年始限定キャンペーンでお得に使える！ ／";
    font-size: 1.2rem;
    font-weight: 700;
    color: #f55677;
    width: 100%;
    text-align: center;
    margin-top: 5px;
    margin-bottom: 2px;
}

.CTA-wippy::before {
    display: inline-block;
    content:"＼ 日韓マッチングで数多くのユーザーと出会える ／";
    font-size: 1.2rem;
    font-weight: 700;
    color: #f55677;
    width: 100%;
    text-align: center;
    margin-top: 5px;
    margin-bottom: 2px;
}

.CTA-marrish::before {
    display: inline-block;
    content:"＼ 30代からの真剣な出会いを求める方におすすめ ／";
    font-size: 1.2rem;
    font-weight: 700;
    color: #f55677;
    width: 100%;
    text-align: center;
    margin-top: 5px;
    margin-bottom: 2px;
}