@charset "utf-8";
.w_type_middle {
    width: 87.5%;
    margin: 0 auto
}
.w_type_full {
    width: 100%
}
.circle_list li:before,
.point_string {
    color: #c88f73
}
main .info {
    font-size: 1.3rem;
    line-height: 2.4rem;
    letter-spacing: 0;
    text-align: justify;
    margin-bottom: 19px
}
main .more_info {
    border: solid 1px #c88f73;
    padding: 16px;
    font-family: 'Noto Sans JP';
    font-size: 1.1rem;
    line-height: 1.7rem;
    letter-spacing: 0.16em;
    width: 100%;
    max-width: 375px;
    margin: 0 auto
}
main .more_info.asterisk_list {
    border: none;
    line-height: 1;
    padding: 9px 1.5rem 0
}
main .more_info.asterisk_list li:before {
    color: #000
}
#mv {
    background-color: #000;
    /*margin-bottom: 8px*/
}
#mv > h1 {
    width: 100%;
    margin: 0 auto;
    opacity: 0
}
#lead h2,
#system h2 {
    font-size: 1.7rem;
    line-height: 2.8rem;
    letter-spacing: 0.17em;
    font-weight: 500;
    color: #c88f73;
    text-align: center;
    margin-bottom: 25px;
    opacity: 0
}
#lead {
    padding-bottom: 20px
}
#lead #img_skin52 {
    width: 100%;
    max-width: 479px;
    margin: 0 auto;
    display: block
}
#lead #outer_lead_info {
    width: 100%;
    max-width: 479px;
    margin: 0 auto
}
#lead #outer_lead_info .more_info p {
    letter-spacing: 0.06em
}
main .more_info .more_info_title {
    font-size: 1.3rem;
    line-height: 1;
    color: #c88f73;
    margin-bottom: 6px
}
#lead .circle_list li {
    border-bottom: dotted 1px #c88f73;
    padding-bottom: 6px;
    margin-bottom: 6px
}
#system {
    background-color: #f9f4f1;
    padding-top: 20px
}
#system #img_stp {
    width: 279px
}
#system .info:first-of-type {
    margin-bottom: 0
}
#system #img_before-after {
    width: 100%;
    max-width: 458px;
    margin: 0 auto 40px;
    display: block
}
#system #outer_system_info {
    width: 100%;
    max-width: 520px;
    margin: 0 auto
}
#system h3 {
    width: 82.38px;
    margin: 0 auto 4px
}
#system #row_system_02 {
    margin-bottom: 0
}
#system #row_system_03 {
    margin-bottom: 0
}
#system #row_system_02 .col-12 > div,
#system #row_system_03 .col-12 > div {
    margin-bottom: 4px
}
#system .view_more {
    cursor: pointer;
    margin: 5px auto 32px;
    max-width: 213px;
    width: 67.5%
}
#system .view_more svg {
    width: 100%
}
#system .view_more svg path,
#system .view_more svg rect {
    transition: fill 0.6s ease
}
#system .view_more:hover svg rect {
    fill: #fff
}
#system .view_more:hover svg path {
    fill: #c88f73
}
#system .view_more[aria-expanded=true] {
    margin: 0 auto 32px
}
#system .view_more[aria-expanded=true] svg {
    display: none
}
#system .cmn_img_case {
    width: 100%;
    max-width: 416px;
    margin: 0 auto;
    display: block
}
#tool {
    background-color: #fff;
    padding-top: 17px
}
#tool #col_tool_detail_01,
#tool #col_tool_detail_02,
#tool #col_tool_detail_03,
#tool #col_tool_detail_04 {
    position: relative;
    background-position: center;
    background-size: cover
}
#tool #col_tool_detail_01 {
    background-image: url('../../img/skin52/tool_bg_01_sp.jpg');
    height: calc(647px + 54px)
}
#tool #col_tool_detail_02 {
    background-image: url('../../img/skin52/tool_bg_02_sp.jpg');
    height: calc(500px + 37px)
}
#tool #col_tool_detail_03 {
    background-image: url('../../img/skin52/tool_bg_03_sp.jpg');
    height: 711px
}
#tool #col_tool_detail_04 {
    background-image: url('../../img/skin52/tool_bg_04_sp.jpg');
    height: 543px
}
#tool .tool_detail,
#tool .tool_detail .more_info .circle_list li:before,
#tool .tool_detail .more_info .more_info_title {
    color: #fff
}
#tool .tool_detail {
    width: 87.5%;
    max-width: 350px;
    margin: 0 auto;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%)
}
#tool .tool_detail h4 {
    font-size: 4.3rem;
    line-height: 1;
    letter-spacing: 0.08em;
    width: 100%;
    margin-bottom: 17px
}
#tool .tool_detail h4 img {
    display: block;
    min-height: 1%
}
#tool #tool_detail_01 h4 img {
    width: 146.84px
}
#tool #tool_detail_02 h4 img {
    width: 139.907px
}
#tool #tool_detail_03 h4 img {
    width: 58.97px
}
#tool #tool_detail_04 h4 img {
    width: 51.61px
}
#tool #tool_detail_01 h4 p,
#tool #tool_detail_02 h4 p,
#tool #tool_detail_04 h4 p {
    margin-bottom: 10px
}
#tool #tool_detail_03 h4 p {
    margin-right: 10px
}
#tool .outer_tool_detail {
    margin-bottom: 10px
}
#tool .outer_tool_detail:last-of-type {
    margin-bottom: 0
}
#tool .tool_detail .tool_lead {
    font-size: 1.5rem;
    line-height: 2.7rem;
    letter-spacing: 0.01em;
    font-weight: 500;
    margin-bottom: 15px;
    text-align: justify
}
#tool .tool_detail .info {
    line-height: 2.1rem;
    margin-bottom: 13px
}
#tool .tool_detail .info:last-of-type {
    margin-bottom: 0
}
#tool .tool_detail .more_info {
    border: solid 1px #fff;
    margin-bottom: 11px;
    padding: 10px
}
#tool .tool_detail .more_info .more_info_title {
    font-size: 1.6rem;
    letter-spacing: 0.04em
}
#tool .tool_detail .more_info table {
    letter-spacing: 0.12em
}
#tool .tool_detail .more_info table th {
    white-space: nowrap;
    vertical-align: top
}
#tool .tool_detail dl dt {
    font-size: 2.1rem;
    line-height: 3.2rem;
    letter-spacing: 0.04em;
    font-weight: 500;
    margin-left: -1rem
}
#tool .tool_detail dl dt:before {
    content: "【"
}
#tool .tool_detail dl dt:after {
    content: "】"
}
#tool .tool_detail dl dd {
    font-size: 1.3rem;
    line-height: 2.1rem;
    letter-spacing: 0.05em;
    font-weight: 300;
    text-align: justify
}
#salons {
    padding: 34px 0 22px
}
#salons h2 {
    margin-bottom: 40px;
    text-align: center;
    font-size: 1.6rem;
}
#salons h2:after {
    content: "";
    width: 33.6px;
    height: 1px;
    background-color: #000;
    margin: 8px auto 0;
    display: block
}
#salons ul {
    columns:  2;
}
#salons ul li {
    margin-bottom: 2em;
    padding-right: 2em;
    list-style: none;
    line-height: 1.3;
}
#profile {
    padding: 34px 0 22px
}
#profile .profile_detail {
    margin: 0 auto 60px
}
#profile .profile_detail h2,
#profile .profile_detail h3 {
    font-size: 1.6rem;
    line-height: 1;
    letter-spacing: 0.08em;
    font-weight: 300;
    text-align: center;
    margin-bottom: 11px
}
#profile .profile_detail h2 p:last-of-type {
    font-size: 0.98rem;
    line-height: 1.61rem
}
#profile .profile_detail h2:after {
    content: "";
    width: 33.6px;
    height: 1px;
    background-color: #000;
    margin: 8px auto 0;
    display: block
}
#profile .profile_detail h3 p:last-of-type {
    font-size: 0.84rem;
    line-height: 1.61rem
}
#profile .profile_detail img {
    width: 200px;
    display: block;
    margin: 0 auto 17px
}
#profile .profile_detail .circle_list {
    font-size: 1.1rem;
    line-height: 1.84rem;
    letter-spacing: 0.08em;
    width: 290px;
    margin: 0 auto
}
#profile .profile_detail .circle_list li:before {
    color: #000
}
#profile .profile_detail .outer_profile_detail_info {
    width: 100%;
    max-width: 520px;
    margin: 0 auto
}
#profile .profile_detail .lead {
    font-size: 1.4rem;
    line-height: 2.7rem;
    letter-spacing: 0;
    font-weight: 500;
    margin-bottom: 12px;
    text-align: justify
}
#profile .profile_detail .info {
    font-size: 1.4rem;
    line-height: 2.1rem
}


#topics {
	margin-bottom: 3em;
	padding: 34px 0;
}
#topics h2 {
    font-size: 1.6rem;
    line-height: 1;
    letter-spacing: 0.08em;
    font-weight: 300;
    text-align: center;
    margin-bottom: 11px
}
#topics h2:after {
    content: "";
    width: 33.6px;
    height: 1px;
    background-color: #000;
    margin: 8px auto 0;
    display: block
}
#topics ul {
	margin-top: 2em;
	padding-left: 0;
}
#topics ul li {
	margin-bottom: 1em;
	list-style: none;
	border-bottom: 1px solid #ddd;
	font-size: 1.4rem;
}
#topics ul li .meta {
	font-size: 1.0rem;
}
#topics ul li .category {
	display: inline-block;
	margin-right: 1em;
	padding: 0.1em 0.5em;
	background: #000;
	color: #fff;
	font-size: 1.0rem;
}
#topics ul li a {
	display: block;
	padding: 1em 0;
	color: #000;
}
#topics .morelink {
	text-align: right;
	font-size: 1.2rem;
}
#topics .morelink a {
	color: #000;
}


#faq {
	padding: 34px 0;
}
#faq h2 {
    font-size: 1.6rem;
    line-height: 1;
    letter-spacing: 0.08em;
    font-weight: 300;
    text-align: center;
    margin-bottom: 11px
}
#faq h2:after {
    content: "";
    width: 33.6px;
    height: 1px;
    background-color: #000;
    margin: 8px auto 0;
    display: block
}
#faq .inner {
	margin: 3em 0;
}
#faq .inner dt {
	margin-bottom: 1em;
	color: #c88f73;
	font-size: 1.6rem;
}
#faq .inner dt:before {
	content: "Q.";
	font-size: 2.0rem;
}
#faq .inner dd {
	margin-bottom: 2em;
	padding-left: 2em;
}
#faq .inner dd p {
	margin-bottom: 0.6em;
	font-size: 1.4rem;
	line-height: 2.1rem;
}

footer {
    background-color: #000;
    padding: 40px 0 20px
}
.footer_inquiry {
    color: #cd9a81;
    font-family: 'Noto Sans JP';
    font-size: 1rem;
    line-height: 1.8rem;
    margin: 0 auto 25px;
    padding: 0
}
.footer_inquiry .footer_inquiry_label {
    /*font-size: 1.4rem;*/
    font-size: 1.8rem;
    line-height: 2.5rem
}
.footer_inquiry .corp_name {
    /*font-size: 1rem;*/
    font-size: 1.4rem;
    line-height: 1.8rem;
    margin: 0 auto
}
.footer_inquiry .corp_mail {
    color: #fff;
    font-size: 1.3rem;
    line-height: 2.3rem
}
#footer_sns {
    border-top: 1px solid #c88f73;
    margin: 40px auto 0;
    padding: 16px 0 0;
    width: 100%
}
#footer_sns a {
    height: 44px;
    margin: 0 14px
}
#footer_sns a.logo {
    height: 60px
}
#page_top {
    height: 30px;
    width: 30px
}

.inquiry_info {
    color: #cd9a81;
    font-family: 'Noto Sans JP';
    font-size: 1rem;
    line-height: 1.8rem;
    margin: 0 auto 25px;
    padding: 3em 0;
    text-align: center;
    background-color: #000;
}
.inquiry_info .box {
	margin: 0 auto;
	padding: 2em;
	border: 10px solid #58443d;
}
.inquiry_info .inquiry {
	margin-bottom: 1em;
}
.inquiry_info .inquiry .footer_inquiry_label {
    font-size: 1.9rem;
    line-height: 2.5rem
}
.inquiry_info .inquiry .corp_name {
    font-size: 1.5rem;
    line-height: 1.8rem;
    margin: 0.3em auto
}
.inquiry_info .inquiry .corp_mail {
    color: #fff;
    font-size: 1.3rem;
    line-height: 2.3rem
}

@media(min-width:768px) {
    #lead #outer_lead_info .more_info p {
        letter-spacing: 0.16em
    }
    #tool .tool_detail h4 {
        letter-spacing: 0.01em
    }
    #system #row_system_02 .order-md-1 > div,
    #system #row_system_02 .order-md-3 > div {
        margin-right: 2px
    }
    #system #row_system_02 .order-md-2 > div,
    #system #row_system_02 .order-md-4 > div {
        margin-left: 2px
    }
    #system #row_system_03 div:nth-of-type(odd) > div {
        margin-right: 2px
    }
    #system #row_system_03 div:nth-of-type(even) > div {
        margin-left: 2px
    }
    #system .view_more {
        margin: 10px auto 52px
    }
    #system .view_more[aria-expanded=true] {
        margin: 0 auto 52px
    }
    #system .cmn_img_case {
        max-width: none;
        width: 100%
    }
    #page_top {
        height: 52px;
        width: 52px
    }
}
@media(min-width:992px) {
    .w_type_middle {
        width: 870px
    }
    main .info {
        font-size: 1.4rem;
        line-height: 2.8rem;
        margin-bottom: 19px
    }
    main .more_info {
        max-width: initial
    }
    #mv {
        /*margin-bottom: 64px*/
    }
    #lead h2,
    #system h2 {
        letter-spacing: 0.24em;
        font-size: 2.5rem;
        line-height: 4.7rem;
        margin-bottom: 25px
    }
    #mv {
        background-color: #000
    }
    #mv > h1 {
        width: 100%;
        max-width: 992px;
        margin: 0 auto
    }
    #lead {
        padding-bottom: 0
    }
    #lead h2 {
        margin-bottom: 0
    }
    #lead #outer_lead_info {
        width: 378px;
        margin: 0 auto 0 0
    }
    #lead #outer_lead_img {
        height: 563px;
        position: relative
    }
    #lead #img_skin52 {
        top: 0;
        left: -14px;
        position: absolute;
        width: 479px;
        z-index: 10
    }
    #system {
        padding-top: 68px
    }
    #system #row_system_01 {
        margin-bottom: 32px
    }
    #system #outer_system_img {
        position: relative;
        height: 433px
    }
    #system #img_before-after {
        position: absolute;
        width: 458px;
        top: 0.5em;
        left: 0;
        margin: auto
    }
    #system #outer_system_info {
        width: 375px;
        margin: 0 0 0 auto
    }
    #system #img_stp {
        width: 294px
    }
    #system h3 {
        width: 117.21px;
        margin-bottom: 10px
    }
    #system #row_system_02 {
        margin-bottom: 0
    }
    #system #row_system_03 {
        margin-bottom: 0
    }
    #system #row_system_02 .col-12 > div,
    #system #row_system_03 .col-12 > div {
        margin-bottom: 10px
    }
    #system #row_system_02 .order-md-1 > div,
    #system #row_system_02 .order-md-3 > div {
        margin-right: 5px
    }
    #system #row_system_02 .order-md-2 > div,
    #system #row_system_02 .order-md-4 > div {
        margin-left: 5px
    }
    #system #row_system_03 div:nth-of-type(odd) > div {
        margin-right: 5px
    }
    #system #row_system_03 div:nth-of-type(even) > div {
        margin-left: 5px
    }
    #tool {
        padding-top: 23px
    }
    #tool .tool_detail {
        max-width: initial;
        width: 365px
    }
    #tool .tool_detail h4 {
        font-size: 4.5rem;
        margin-bottom: 19px
    }
    #tool #tool_detail_01 h4 p,
    #tool #tool_detail_04 h4 p {
        margin-bottom: 0;
        margin-right: 10px
    }
    #tool .outer_tool_detail {
        max-width: 2000px;
        margin: 0 auto
    }
    #tool .outer_tool_detail > .row {
        max-width: 1000px;
        margin: 0 auto
    }
    #tool #outer_tool_detail_01 {
        background-image: url('../../img/skin52/tool_bg_01_pc.jpg');
        background-position: center;
        background-size: cover
    }
    #tool #outer_tool_detail_02 {
        background-image: url('../../img/skin52/tool_bg_02_pc.jpg');
        background-position: center;
        background-size: cover
    }
    #tool #outer_tool_detail_03 {
        background-image: url('../../img/skin52/tool_bg_03_pc.jpg');
        background-position: center;
        background-size: cover
    }
    #tool #outer_tool_detail_04 {
        background-image: url('../../img/skin52/tool_bg_04_pc.jpg');
        background-position: center;
        background-size: cover
    }
    #tool #col_tool_detail_01,
    #tool #col_tool_detail_02,
    #tool #col_tool_detail_03,
    #tool #col_tool_detail_04 {
        background-image: none;
        height: auto
    }
    #tool .tool_detail .tool_lead {
        font-size: 1.8rem;
        line-height: 2.9rem;
        letter-spacing: 0.04em;
        margin-bottom: 30px
    }
    #tool .tool_detail .info {
        line-height: 2.3rem
    }
    #tool .tool_detail .more_info {
        font-size: 1.2rem;
        line-height: 1.6rem
    }
    #tool .tool_detail dl dd {
        font-size: 1.4rem;
        line-height: 2.3rem;
        letter-spacing: 0.08em
    }
    #salons {
        padding: 91px 0 50px
    }
    #salons h2 {
        font-size: 2.3rem;
        line-height: 1
    }
    #salons h2:after {
        margin-top: 20px;
        width: 48px
    }
    #profile {
        padding: 91px 0 79px
    }
    #profile .profile_detail {
        margin-bottom: 104px
    }
    #profile .profile_detail:last-of-type {
        margin-bottom: 0
    }
    #profile .profile_detail img {
        width: 395px;
        margin: 0.5rem 0 0 auto
    }
    #profile .profile_detail h2,
    #profile .profile_detail h3 {
        font-size: 2.3rem;
        line-height: 1
    }
    #profile .profile_detail h3 {
        margin-bottom: 32px
    }
    #profile .profile_detail h2 p:first-of-type {
        margin-bottom: 15px
    }
    #profile .profile_detail h3 p:first-of-type {
        margin-bottom: 13px
    }
    #profile .profile_detail h2 p:last-of-type {
        font-size: 1.4rem
    }
    #profile .profile_detail h2:after {
        margin-top: 20px;
        width: 48px
    }
    #profile .profile_detail h3 p:last-of-type {
        font-size: 1.2rem
    }
    #profile .profile_detail .circle_list {
        font-size: 1.4rem;
        line-height: 2.3rem;
        width: auto;
        margin-left: 3.35em
    }
    #profile .profile_detail .lead {
        font-size: 1.6rem;
        line-height: 3.2rem;
        letter-spacing: 0.04rem
    }
    #profile .profile_detail .info {
        line-height: 2.8rem
    }
    #profile .profile_detail .outer_profile_detail_info {
        width: 365px;
        max-width: initial
    }
    #topics h2,
    #faq h2 {
    	font-size: 2.3rem;
    	line-height: 1;
    }
    #topics h2:after,
    #faq h2:after {
        margin-top: 20px;
        width: 48px
    }

}