@charset "UTF-8";
.d-block {
    display: block !important;
}

.d-inline-block {
    display: inline-block !important;
}

.text-center {
    text-align: center !important;
}

.container {
    width: 100%;
    padding-right: 25px;
    padding-left: 25px;
    margin-right: auto;
    margin-left: auto;
}

.mr-auto,
.mx-auto {
    margin-right: auto !important;
}

.ml-auto,
.mx-auto {
    margin-left: auto !important;
}

.row {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-right: -15px;
    margin-left: -15px;
}

.row img {
    max-width: 100%;
    vertical-align: middle;
    border-style: none;
}

.col-12 {
    -ms-flex: 0 0 100%;
    flex: 0 0 100%;
    max-width: 100%;
    position: relative;
    width: 100%;
    padding-right: 30px;
    padding-left: 30px;
}

figure {
    margin: 0 0 1rem;
}

.mb-5,
.my-5 {
    margin-bottom: 3rem !important;
}

.mb-3,
.my-3 {
    margin-bottom: 1rem !important;
}

.align-items-center {
    -ms-flex-align: center !important;
    align-items: center !important;
}

.justify-content-center {
    -ms-flex-pack: center !important;
    justify-content: center !important;
}

.d-flex {
    display: -ms-flexbox !important;
    display: flex !important;
}

.pb-3,
.py-3 {
    padding-bottom: 1rem !important;
}

.mb-0,
.my-0 {
    margin-bottom: 0 !important;
}

.pb-4,
.py-4 {
    padding-bottom: 1.5rem !important;
}

.pt-4,
.py-4 {
    padding-top: 1.5rem !important;
}

.col-6 {
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
    max-width: 50%;
    position: relative;
    width: 100%;
    padding-right: 15px;
    padding-left: 15px;
}

.mb-4,
.my-4 {
    margin-bottom: 1.5rem !important;
}

.list-unstyled {
    padding-left: 0;
    list-style: none;
}

@media(min-width: 576px) {
    .container {
        max-width: 540px;
    }
}

@media(min-width: 768px) {
    .container {
        max-width: 720px;
    }
    .mb-md-5,
    .my-md-5 {
        margin-bottom: 3rem !important;
    }
    .col-md-6 {
        -ms-flex: 0 0 50%;
        flex: 0 0 50%;
        max-width: 50%;
        position: relative;
        width: 100%;
        padding-right: 15px;
        padding-left: 15px;
    }
    .col-md-4 {
        -ms-flex: 0 0 33.333333%;
        flex: 0 0 33.333333%;
        max-width: 33.333333%;
    }
    .d-md-flex {
        display: -ms-flexbox !important;
        display: flex !important;
    }
    .order-md-2 {
        -ms-flex-order: 2;
        order: 2;
    }
    .col-12 {
        padding-right: 15px;
        padding-left: 15px;
    }
}

@media(min-width: 992px) {
    .container {
        max-width: 960px;
    }
}

@media(min-width: 1200px) {
    .container {
        max-width: 1140px;
    }
}


/*
span,
ul,
ol,
dl,
table {
    font-size: 1.4rem;
    line-height: 1.6
}

@media(min-width: 768px) {
    span,
    ul,
    ol,
    dl,
    table {
        font-size: 1.6rem
    }
}
*/

img {
    max-width: 100%
}

.page-title,
.sub-title,
.normal-title {
    font-weight: bold
}

.page-title {
    margin-bottom: 60px;
    padding: 30px 0;
    text-align: center;
    color: #c70067;
    background: url(../common/images/hybrid/hybrid-header.jpg);
    background-size: cover
}

@media(min-width: 992px) {
    .page-title {
        padding: 100px 0
    }
}

.page-title span {
    font-size: 2.4rem;
    display: block;
    background: rgba(255, 255, 255, .8);
    padding: 8px;
    width: 90%;
    font-family: 'Kaisei Tokumin', serif;
}

@media(min-width: 992px) {
    .page-title span {
        width: 100%;
        font-size: 3.2rem
    }
}

.sub-title {
    background: #ea3a99;
    width: 100%;
    text-align: center;
    color: #fff;
    font-size: 1.8rem;
    padding: .5em 0
}

@media(min-width: 992px) {
    .sub-title {
        margin-bottom: 60px;
        font-size: 2.5rem
    }
}

.normal-title {
    color: #ea3a99;
    border-bottom: 1px solid;
    padding-bottom: .8em;
    margin-bottom: 20px;
    font-size: 1.8rem
}

@media(min-width: 992px) {
    .normal-title {
        font-size: 2.4rem
    }
}

@media(min-width: 768px) {
    a[href^="tel:"] {
        pointer-events: none
    }
}

.total-parts {
    margin-bottom: 30px
}

@media(min-width: 992px) {
    .total-parts {
        margin-bottom: 60px
    }
}

.total-parts-about {
    font-size: 1.15rem;
    font-weight: bold;
    margin-bottom: 30px;
    font-family: 'Kiwi Maru', serif;
}

@media(min-width: 992px) {
    .total-parts-about {
        font-size: 1.65rem;
        margin-bottom: 60px
    }
}

@media(max-width: 320px) {
    .total-parts-about {
        font-size: 1.5rem
    }
}

.total-parts-title {
    font-size: 1.4rem;
    border: 1px solid #ea3a99;
    line-height: 1;
    padding: 1.5rem 2.5rem;
    font-family: 'Kaisei Opti', serif;
}

.total-parts-title::before {
    content: "●";
    margin-right: 5px;
    color: #ea3a99;
    width: 1em;
    height: 1em
}

.total-parts-text dt {
    background: #f19ca7;
    color: #fff;
    width: 260px;
    padding: 15px 1em;
    font-size: 1.4rem;
    font-family: 'Kiwi Maru', serif;
    border-radius: 10px;
}

.total-parts-text dd {
    font-size: 1.15rem;
    font-weight: normal;
    font-family: 'Kiwi Maru', serif;
    letter-spacing: .2em;
}

@media(min-width: 768px) {
    .total-parts-text dt {
        width: 100%;
        font-size: 1.8rem
    }
    .total-parts-text dd {
        font-size: 1.2rem;
    }
}

@media(min-width: 992px) {
    .total-parts-text dt {
        font-size: 1.6rem
    }
}

.total-model {
    max-width: 100%
}

@media(min-width: 768px) {
    .total-model {
        max-width: 1000px;
    }
}

.model-front,
.model-back {
    width: 100%;
    height: auto;
}

.total-points {
    background: #fdf0f5;
    padding: 60px 0 75px 0;
    /*
    padding: 60px 0 30px 0;
    margin-bottom: 60px;
    */
    margin-bottom: auto;
}

@media(min-width: 768px) {
    .total-points {
        padding: 90px 0;
        /*
        margin-bottom: 90px;
        */
        margin-bottom: 0;
    }
}

.total-points-title {
    font-size: 1.8rem;
    color: #ea3a99;
    font-weight: bold;
    font-family: 'Kaisei Decol', serif;
}

@media(min-width: 768px) {
    .total-points-title {
        font-size: 2.8rem
    }
}

.total-point-lists ol>li:not(:last-child) {
    margin-bottom: 60px
}

@media(min-width: 768px) {
    .total-point-lists ol>li:not(:last-child) {
        margin-bottom: 90px
    }
}

.total-point-box {
    width: 100%;
    margin: 0 auto;
}

@media(min-width: 768px) {
    .total-point-box-img-l {
        margin-left: 0;
        padding-left: 0;
    }
    .total-point-box-img-r {
        margin-right: 0;
        padding-right: 0;
    }
}

.total-lists-title {
    color: #fff;
    font-size: 1.6rem;
    font-weight: bold;
    width: 8em;
    margin: 0 auto;
    width: 100%
}

.total-point-box .col-md-6 .total_totalcompbox .total_top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}

.total-point-box .col-md-6 .total_totalcompbox .total_top .name {
    width: 25%;
    font-weight: bold;
    font-size: 2.4rem;
    color: #ea3a99;
    margin-bottom: 0;
}

.total-point-box .col-md-6 .total_totalcompbox .total_top .count {
    width: 75%;
    font-size: 2.4rem;
    font-weight: bold;
    color: #ea3a99;
    background-color: #fff;
    border: 5px solid #ea3a99;
    text-align: center;
}

.total-point-box .col-md-6 .total_totalcompbox .total_top .count p {
    font-size: 2.4rem;
    font-weight: bold;
    margin-bottom: 0;
}

.total-point-box .col-md-6 .total_totalcompbox .total_btm {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.total-point-box .col-md-6 .total_totalcompbox .total_btm .name {
    width: 25%;
    font-size: 2.4rem;
    font-weight: bold;
    margin-bottom: 0;
}

.total-point-box .col-md-6 .total_totalcompbox .total_btm .count {
    width: 75%;
    font-size: 2.4rem;
    font-weight: bold;
}

.total-point-box .col-md-6 .total_totalcompbox .total_btm .count ul {
    display: flex;
    border: 5px solid #333;
    background-color: #fff;
}

.total-point-box .col-md-6 .total_totalcompbox .total_btm .count li {
    list-style: none;
    font-size: 2.4rem;
    width: 25%;
    text-align: center;
    border-right: 2px solid #333;
}

.total-point-box .col-md-6 .total_totalcompbox .total_btm .count li:last-child {
    border-right: none;
}

@media(max-width: 768px) {
    .total-point-box .col-md-6 .total_totalcompbox .total_top .name {
        font-size: 1.8rem;
    }
    .total-point-box .col-md-6 .total_totalcompbox .total_top .count p {
        font-size: 1.8rem;
    }
    .total-point-box .col-md-6 .total_totalcompbox .total_btm .name {
        font-size: 1.8rem;
    }
    .total-point-box .col-md-6 .total_totalcompbox .total_btm .count li {
        font-size: 1.8rem;
    }
}

@media(min-width: 768px) {
    .total-lists-title {
        background: #e8383d;
    }
}

.total-lists-number {
    letter-spacing: 1px;
    background: #f39800;
    padding: 8px;
    width: 110px;
    margin: 0 auto;
    font-family: 'Stick No Bills', sans-serif;
    font-weight: 700;
    border-radius: 50%;
    position: relative;
    top: -10px;
    font-size: 1.8rem;
}

@media(min-width: 768px) {
    .total-lists-number {
        width: auto;
        margin: 0 1em 0 0;
        padding-left: 1em;
        padding-right: 1em;
        font-size: 2.5rem;
    }
}

@media(min-width: 992px) {
    .total-lists-number {
        /*
        padding: 10px 1.8em;
        top: -20px;
        left: 30px;
        font-size: 1.85rem;
        */
        padding: 5px .5em;
        top: -20px;
        left: 30px;
        font-size: 3rem;
    }
}

.total-lists-name {
    padding: 10px 0;
    background: #e8383d;
    position: relative;
    font-family: 'Shippori Mincho B1', serif;
    font-size: 1.3rem;
}

@media(min-width: 768px) {
    .total-lists-name {
        background: transparent;
        position: absolute;
        left: 50%;
        transform: translateX(-50%);
        font-size: 2.3rem;
    }
}


/*
.total-lists-name,
.total-lists-number {
    font-size: 1.3rem;
    font-family: 'Kiwi Maru', serif;
}

@media(min-width: 768px) {
    .total-lists-name,
    .total-lists-number {
        font-size: 1.6rem
    }
}
*/

.total-lists-text-1 {
    /*
    font-weight: bold;
    */
    font-weight: normal;
    text-align: center;
    font-family: 'Kiwi Maru', serif;
    font-size: 1.05rem;
}

@media(min-width: 768px) {
    .total-lists-text-1 {
        text-align: left;
        font-size: 1.3rem
    }
}

@media(min-width: 992px) {
    .total-lists-text-1 {
        text-align: left;
        font-size: 1.2rem;
        font-weight: normal;
    }
}


/*
@media(min-width: 992px) {
    .total-lists-text-1 {
        text-align: left;
        font-size: 1.25rem;
    }
}
*/

@media(min-width: 768px) {
    .total-lists-text-2 {
        font-size: 1.5rem;
        text-align: left;
        width: calc(100% - 6em)
    }
}

@media(min-width: 992px) {
    .total-lists-text-2 {
        font-size: 1.35rem
    }
}

.total-lists-text-3 {
    border-top: 1px solid #ea3a99;
    text-align: center;
    font-size: 2rem
}

@media(min-width: 992px) {
    .total-lists-text-3 {
        font-size: 2.4rem
    }
}

.total-lists-text-2,
.total-lists-text-3 {
    color: #915da3;
    font-weight: bold;
    /*
    text-align: center;
    */
    text-align: center;
    font-family: 'Kaisei Opti', serif;
    font-size: 1.25rem;
}


/*
.total-more {
    background: #e95464;
    color: #fff;
    margin: 0 auto;
    width: 4em;
    height: 4em
}
*/

.total-more {
    background: #915da3;
    color: #fff;
    margin: 0 auto;
    width: 3em;
    height: 3em;
    top: 5px;
    position: relative;
}

@media(min-width: 768px) {
    .total-more {
        margin: 0 1em 0 0;
        font-size: 1.6rem;
    }
    .total-lists-text-2,
    .total-lists-text-3 {
        text-align: left;
    }
}

.comparison-times {
    background: #fff;
    font-weight: bold;
    font-size: 2.2rem;
    width: 2em;
    height: 2em
}

@media(max-width: 320px) {
    .comparison-times {
        width: 1.5em;
        height: 1.5em
    }
}

@media(min-width: 768px) {
    .comparison-times {
        font-size: 2rem
    }
}

@media(min-width: 992px) {
    .comparison-times {
        width: 2.8em;
        height: 2.8em
    }
}

@media(min-width: 992px) {
    .comparison-times span {
        font-size: 2.4rem
    }
}

.total-more,
.comparison-times {
    border-radius: 50px;
    text-align: center
}

.total-more span,
.comparison-times span {
    line-height: 1;
    font-family: 'Kaisei Opti', serif;
}

.total-comparison {
    font-weight: bold;
    width: 95%;
    margin: 0 auto;
}

@media(min-width: 768px) {
    .total-comparison {
        width: 100%;
    }
}

.total-comparison-border {
    margin: 20px 0 0 0;
    padding: 30px 0 0 0;
    border-top: 1px solid #f19ca7;
    font-family: 'Kiwi Maru', serif;
}

@media(min-width: 992px) {
    .total-comparison-border {
        margin: 30px 0 0 0
    }
}

.comparison-sum {
    margin-left: 3px;
    margin-right: 3px;
    width: 1em;
    line-height: 1.3
}

@media(max-width: 375px) {
    .comparison-sum {
        margin-bottom: 0
    }
}

@media(max-width: 320px) {
    .comparison-sum {
        font-size: 1.1rem
    }
}

@media(min-width: 768px) {
    .comparison-sum {
        margin-bottom: 0;
        font-size: 1.2rem
    }
}

@media(min-width: 992px) {
    .comparison-sum {
        margin-left: 10px;
        margin-right: 10px;
        font-size: 1.8rem
    }
}

.comparison-minute {
    margin-top: 2rem
}

.comparison-length {
    font-size: 4.5rem;
    line-height: 1 !important
}

@media(max-width: 375px) {
    .comparison-length {
        font-size: 3.5rem
    }
}

@media(max-width: 320px) {
    .comparison-length {
        font-size: 3.2rem
    }
}

@media(min-width: 768px) {
    .comparison-length {
        font-size: 3.6rem
    }
}

@media(min-width: 992px) {
    .comparison-length {
        font-size: 4rem
    }
}

@media(min-width: 1200px) {
    .comparison-length {
        font-size: 6rem
    }
}

.other-salon dt {
    border: 1px solid #222
}

.kbl-salon {
    color: #ea3a99
}

.kbl-salon dt {
    color: #fff;
    background: #ea3a99;
    border: 1px solid #ea3a99
}

.other-salon dt,
.kbl-salon dt {
    width: 100%;
    padding: 3px
}

@media(min-width: 992px) {
    .other-salon dt,
    .kbl-salon dt {
        padding: 8px
    }
}

.other-salon p,
.kbl-salon p {
    line-height: 1.4
}

@media(max-width: 320px) {
    .other-salon .unshaved,
    .kbl-salon .unshaved {
        font-size: 1.2rem
    }
}

@media(min-width: 768px) {
    .other-salon .unshaved,
    .kbl-salon .unshaved {
        font-size: 1.4rem
    }
}

.total-comparison-p1 dl {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.total-comparison-p1-child {
    width: 100%;
}

.kbl-salon-p1 {
    color: #ea3a99;
    font-weight: bold;
}

.kbl-salon-p1 dt {
    font-size: 3.2rem;
}

.kbl-salon-p1 dd {
    border: 3px solid #ea3a99;
    background: #fff;
    font-size: 3.2rem;
    height: 50px;
}

.other-salon-p1 {
    font-size: 1.8rem;
}

.other-salon-p1 dd {
    margin: 0;
    padding: 0;
}

.other-salon-p1-list {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    font-size: 1.8rem;
}

.other-salon-p1-list li {
    width: 25%!important;
    height: 44px;
    padding: 0;
    background: #fff;
    border-top: 1px solid #000;
    border-left: 1px solid #000;
    border-bottom: 1px solid #000;
    display: flex;
    justify-content: center;
    align-items: center;
}

.other-salon-p1-list li:last-child {
    border-right: 1px solid #000;
}

@media(min-width: 768px) {
    .kbl-salon-p1 dt {
        font-size: 2.6rem;
    }
    .kbl-salon-p1 dd {
        font-size: 2.6rem;
        height: 50px;
    }
    .other-salon-p1 {
        font-size: 1.4rem;
    }
    .other-salon-p1 dd {
        margin: 0;
        padding: 0;
    }
    .other-salon-p1-list {
        font-size: 1.8rem;
    }
}

@media(min-width: 992px) {
    .kbl-salon-p1 dt {
        font-size: 2.6rem;
    }
    .kbl-salon-p1 dd {
        font-size: 2.6rem;
        height: 50px;
    }
    .other-salon-p1 {
        font-size: 1.5rem;
    }
    .other-salon-p1 dd {
        margin: 0;
        padding: 0;
    }
    .other-salon-p1-list {
        font-size: 1.8rem;
    }
}

.all-free,
.other-pain,
.kbl-pain {
    font-size: 2.8rem !important;
    line-height: 1 !important
}

@media(min-width: 992px) {
    .all-free,
    .other-pain,
    .kbl-pain {
        font-size: 3.8rem !important
    }
}

.costs-everytime {
    line-height: 1.2;
    font-size: 1.6rem
}

@media(min-width: 1200px) {
    .costs-everytime {
        font-size: 1.8rem
    }
}

.model-back {
    width: 67%;
    margin: 0 auto;
    display: block;
}

.total-salon {
    max-width: 227px;
    padding-left: 4%;
}

.total-kbl {
    max-width: 192px;
    padding-left: 4%;
}

.others {
    padding-bottom: 140px;
}

.others .counseling_link {
    margin: 0 auto;
    max-width: 480px;
    height: 80px;
    display: flex;
    align-items: center;
    padding-left: 80px;
    color: #fff;
    text-decoration: none;
    background: #EA3A99;
    border-radius: 10px;
    font-weight: bold;
    transition: .5s;
    -webkit-transition: .5s;
}

.others .counseling_link .counseling_link_text {
    font-size: 24px;
    color: #FFF;
    margin-top: 8px;
    letter-spacing: 0.1em;
    font-weight: bold;
}

.others .counseling_link .arrow {
    display: inline-block;
    width: 14px;
    margin-left: 60px;
    transition: .5s;
    -webkit-transition: .5s;
}

.others .counseling_link:hover .arrow {
    margin-left: 70px;
}

.others .counseling_link:hover {
    opacity: .7;
}

@media(max-width: 768px) {
    .others {
        padding-bottom: 100px;
    }
    .others .counseling_link {
        max-width: unset;
        margin: 0 auto;
        width: 100%;
        height: calc(100 * (100vw / 750));
        padding-left: calc(135 * (100vw / 750));
        position: relative;
    }
    .others .counseling_link .counseling_link_text {
        font-size: calc(32 * (100vw / 750));
    }
    .others .counseling_link .arrow {
        display: inline-block;
        width: calc(18 * (100vw / 750));
        margin-left: calc(80 * (100vw / 750));
        transition: .5s;
        -webkit-transition: .5s;
    }
}

.total_totalcompbox {
    width: 100%;
    margin-top: 15px;
}

.total_totalcompbox>img {
    width: 100%;
    max-width: 500px;
}

.contents_text {
    padding-bottom: 30px;
    margin-top: 20px;
}

.contents_text .img03 {
    text-align: center
}

.contents_text .img03 img {
    display: inline-block;
    width: 100%;
    max-width: 100%;
}

@media(min-width: 768px) {
    .contents_text {
        padding-bottom: 26px
    }
    .contents_text .img03 {
        text-align: center
    }
    .contents_text .img03 img {
        display: inline-block
    }
}

@media screen and (min-width: 981px) {
    .pc_only {
        display: block
    }
    .sp_only {
        display: none!important
    }
}

@media screen and (max-width: 980px) {
    .pc_only {
        display: none!important
    }
    .sp_only {
        display: block
    }
}