@import"https://fonts.googleapis.com/css?family=Roboto:400,700";
@import"https://fonts.googleapis.com/css?family=Noto+Sans+JP:400,700&display=swap&subset=japanese";
@charset "UTF-8";
@font-face {
    font-family: aderans_mens-fonts;
    src: url('/mens/common/rn-font//aderans_mens-fonts.eot');
    src: url('/mens/common/rn-font//aderans_mens-fonts.eot?#iefix') format("eot"), url('/mens/common/rn-font//aderans_mens-fonts.woff') format("woff"), url('/mens/common/rn-font//aderans_mens-fonts.ttf') format("truetype"), url('/mens/common/rn-font//aderans_mens-fonts.svg#aderans_mens-fonts') format("svg")
}
@media print {
	body { display: none; }
}
.overlay {
    /* position: absolute; */
    /* top: 0; */
    /* left: 0; */
    width: 100%;
    height: 100%;
    background: url("../images/clear.png") no-repeat;
    z-index: 10;
}

/* ====================================== */
/* common */

a:hover {
	opacity: 0.7;
}

main {
	position: relative;
	padding-top: 0 !important;
    font-family: 'Noto Sans JP', sans-serif;
}

img {
	transition:all 0.3s ease;
    pointer-events: none;
}

.pc {
    display: block;
}
.ipad {
    display: none;
} 
.sp {
    display: none;
}
p.note {
    font-size: 1.2rem;
}
section img {
  opacity: 0;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
section img.lazyloaded {
  opacity: 1;
}
p {
 visibility: hidden;
}
.wf-active p {
 visibility: visible;
}

/* ====================================== */
/* fv */

.fv {
    width: 100%;
    position: relative;
    padding: 50px 0 10px 0;
    background: #42b1eb url("../images/fv_bg.png") center / auto 100% no-repeat;
}
.fv h1 {
    display: table;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}
.fv h1 img {
    margin: 0 auto;
}
.fv .blur img {
    position: absolute;
    display: table;
    bottom: 0;
    transform: translate(-50%, 0px);
    -webkit-transform: translate(-50%, 0px);
    -ms-transform: translate(-50%, 0px); 
    left: 50%;
    right: 0;
}
.cvbtn-fv {
    position: relative;
    z-index: 1;
    display: table;
    margin: 0 auto;
}
.cvbtn-fv img {
    max-width: 740px;
    height: auto;
    margin: 0 auto;
    transition: all 0.3s;
}
.cvbtn-fv a:hover,
.cvbtn-fv a img:hover,
.cvbtn-common a:hover,
.cvbtn-common a img:hover,
section.cvbtm .cvbtn a:hover {
    opacity: 1 !important;
    transform: scale(1.05);
}

/* ====================================== */
/* cv */

.cvbtn {
    display: table;
    margin: 0 auto 5em auto;
    text-align: center;
}
.cvbtn p {
    color: #81640d;
    font-size: 3.2rem;
    font-weight: 700;
    position: absolute;
    margin: 0 auto 0.5em auto;
    z-index: 1;
    transform: translate(-50%, 0px);
    -webkit-transform: translate(-50%, 0px);
    -ms-transform: translate(-50%, 0px);
    left: 50%;
    right: 0;
    top: -1em;
}
.arrow-wrap {
    z-index: 2;
    bottom: -20px;
    display: table;
    position: relative;
    margin: 0 auto !important;
}
.arrow {
    width:0;
    height:0;
    border-style:solid;
    border-width: 70px 300px 0 300px;
    border-color: #a58411 transparent transparent transparent;
    position:absolute;
    top:0;
    left:0;
    right: 0;
    margin: 0 auto;
}
.arrow-bg {
    background: -webkit-linear-gradient(rgba(255,255,255,1) 0%, rgba(255,255,255,0.5) 50%, rgba(255,255,255,0) 100%);
    background: -o-linear-gradient(rgba(255,255,255,1) 0%, rgba(255,255,255,0.5) 50%, rgba(255,255,255,0) 100%);
    background: linear-gradient(rgba(255,255,255,1) 0%, rgba(255,255,255,0.5) 50%, rgba(255,255,255,0) 100%);
    width: 754px;
    height: 70px;
    display:block;
    position:absolute;
    top:0;
    left:0;
    right: 0;
    margin: 0 auto;
}
.pinpamph {
    position: relative;
    transition: all 0.3s ease;
    margin-bottom: 50px;
}
.pinpamph img {
    position: absolute;
    left: -55px;
    top: 50%;
    transform: translateY(-50%);
    padding-bottom: 7em;
}
.cvbtn a {
    display: table;
    margin: 0 auto;
    width: 850px;
    height: 154px;
    text-indent: -999em;
    background: url(../images/cv.png) no-repeat;
    z-index: 1;
}
.cvbtn a:hover {
    opacity: 1 !important;  
}
section.cvbtm .cvbtn {
    margin: 0 auto 0 auto;
}
section.cvbtm .cvbtn a {
    background: url(../images/cv_btm.png) no-repeat;
    width: 888px;
    height: 113px;
}
.cvbtn .mazu {
    position: relative;
    display: table;
    margin: 0 auto .5em auto;
}
.cvbtn .mazu:before,
.cvbtn .mazu:after {
    content: "";
    display: block;
    position: absolute;
    bottom: 0;
    background-repeat: no-repeat;
    width: 60px;
    height: 75px;
}
.cvbtn .mazu:before {
    left: -65px;
    background-image: url(../images/mazu_left.png);
}
.cvbtn .mazu:after {
    right: -65px;
    background-image: url(../images/mazu_right.png);
}

/* ====================================== */
/* section common */

section {
    padding: 5em 0;
}

/* ====================================== */
/* section kininari */

section.kininari {
    background: #6b6b6b url(../images/kininari_bg.png) repeat center;
    background-size: cover;
    position: relative;
    z-index: 1;
}
section.kininari .catch {
    display: table;
    margin: 0 auto 2em auto;
}
section.kininari .catch img {
    margin: 0 auto;
}
section.kininari ul {
    padding: 1.2em 2em;
    box-sizing: border-box;
    background: rgba(0,0,0,0.75);
    max-width: 1000px;
    margin: 0 auto;
    line-height: 2.4em;
    font-weight: 700;
    font-size: 3.5rem;
    color: white;
    font-style: italic;
    position: relative;
}
section.kininari ul:after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 96%;
    height: 94%;
    border: 1px solid rgba(255,255,255,0.50);
}
section.kininari ul li {
    background: url("../images/check.png") no-repeat left;
    background-size: 45px 41px;
    padding-left: 60px;
}

/* ====================================== */
/* section okotae */

section.okotae {
    padding: 5em 0 8em 0;
}
section.okotae .catch1,
section.okotae .catch2 {
    display: table;
    text-align: center;
}
section.okotae .catch1 {
    margin: 0 auto;
}
section.okotae .catch2 {
    margin: 0 auto 50px auto;
}
section.okotae .catch1 p.first-text {
    font-weight: 800;
    position: relative;
    font-size: 3rem;
    margin-bottom: 20px;
    line-height: 1;
}
section.okotae .catch1 p.first-text:before,
section.okotae .catch1 p.first-text:after {
    content: "";
    background: #1a1a1a;
    width: 2px;
    height: 45px;
    display: inline-block;
    position: relative;
    bottom: -0.3em;
}
section.okotae .catch1 p.first-text:before {
    transform: rotate(-40deg);
    left: -0.8em;
}
section.okotae .catch1 p.first-text:after {
    transform: rotate(40deg);
    right: -0.8em;
}
section.okotae .catch1 p.first-text span {
    color: #24508f;
}
section.okotae .catch1 p.second-text {
    font-weight: 600;
    line-height: 1.5;
    border-top: 1px dashed #1a1a1a;
    border-bottom: 1px dashed #1a1a1a;
    padding: 0.3em 0.3em;
    margin-bottom: 30px;
    font-size: 2rem;
    font-feature-settings: "palt";
}
section.okotae .catch2 p.first-text {
    font-weight: 900;
    font-size: 4.5rem;
    background: linear-gradient(transparent 60%, #f4da1f 30%);
    line-height: 1.5;
    margin-bottom: 10px;
}
section.okotae .catch2 p.second-text {
    font-weight: 900;
    font-size: 2.6rem;
    line-height: 1;
}
section.okotae .hajimeru-pamph {
    max-width: 1000px;
    margin: 0 auto 80px auto;
}
section.okotae .hajimeru-pamph picture img {
    border: 1px solid #b2b2b2;
}

/* ====================================== */
/* section kaiketsutitle */

section.kaiketsutitle {
    transform: skewY(-5deg);
    background: #245090;
    color: white;
    font-weight: 900;
    font-style: italic;
    line-height: 1.5;
    padding: 1em 0;
    position: relative;
    z-index: 2;
}
section.kaiketsutitle .title {
    max-width: 1000px;
    margin: 0 auto;
    font-size: 6.5rem;
    line-height: 0;
    padding: 10px 0;
}
section.kaiketsutitle .title p {
    line-height: 1.3;
    letter-spacing: 0.02em;
    text-align: right;
}
section.kaiketsutitle .title p.small {
    font-size: 60%;
    text-align: left;
}
section.kaiketsutitle .subtitle {
    color: #245090;
    font-size: 4rem;
    font-weight: 700;
    position: absolute;
    left: 0;
    right: 0;
    margin: 1em auto 0 auto;
    max-width: 1000px;
}

/* ====================================== */
/* section kaiketsu */

section.kaiketsu {
    position: relative;
    padding: 6em 0 0.5em 0;
    background: #bfe3f1 url(../images/kaiketsu_bg.png) no-repeat left top;
}
section.kaiketsu .zomo-lineup p {
    text-align: center;
    font-weight: 600;
    font-size: 2.5rem;
    margin: 0 auto 0.8em auto;
    line-height: 1;
}
section.kaiketsu:before {
    width: 0px;
    height: 0px;
    border-style: solid;
    border-width: 0 0 168px 100vw;
    border-color: transparent transparent #bfe3f1 transparent;
    transform: rotate(0deg);
    content: "";
    position: absolute;
    top: -168px;
}
section.kaiketsu ul li .frame {
    position: relative;
    max-width: 1000px;
    margin: 0 auto 5em auto;
    padding: 6em 3em;
    box-sizing: border-box;
    transform: skewY(-4deg);
    display: flex;
    justify-content: space-between;
}
section.kaiketsu ul li .frame.w {
    background: rgba(255,255,255,0.8);
}
section.kaiketsu ul li .frame.b {
    background: #5abee6;
}
section.kaiketsu .product {
    max-width: 1000px;
    margin: 0 auto;
    background: #bfe3f1;
    transform: skewY(-4deg);
}
section.kaiketsu .product p {
    background: #245090;
    color: white;
    font-size: 3rem;
    text-align: center;
    font-weight: 700;
    position: relative;
    z-index: -1;
    top: 0;
    display: table;
    padding: 0.5em 0;
    margin: 0 0 0 0;
    width: 13em;
    letter-spacing: 0.05em;
    line-height: 1;
}
section.kaiketsu .lead {
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    font-size: 3rem;
    font-weight: 700;
    line-height: 1.4;
    z-index: 2;
}
section.kaiketsu ul li .frame.w .lead {
    position: absolute;
    right: 1em;
}
section.kaiketsu ul li .frame.b .lead {
}
section.kaiketsu .image {
    display: table;
    text-align: center;
    position: relative;
    z-index: 2;
    transform: skewY(4deg);
    width: 85%;
}
section.kaiketsu .image-inner {
    width: 100%;
}
section.kaiketsu .image-inner img {
    max-width: 100%;
}
section.kaiketsu .image.b {
    left: 20%;
}
section.kaiketsu .image-last {
    transform: skewY(4deg);
    width: 85%;
}
section.kaiketsu .image p {
    font-size: 2.6rem;
    font-weight: 700;
    margin-top: 0.3em;
}
section.kaiketsu .osusume {
    display: table;
    position: relative;
    z-index: 2;
    transform: skewY(4deg);
}
section.kaiketsu li:nth-child(2) .osusume {
    margin: -8em auto 0 auto;
    left: -7%;
}
section.kaiketsu li:nth-child(3) .osusume {
    margin: -5em 0 0 auto;
    right: 15%;
}
section.kaiketsu .osusume.b {
}
section.kaiketsu .osusume p {
    color: #245090;
    padding: 0.5em 1.5em;
    background: #fff;
    text-align: center;
    position: relative;
    display: table;
    font-size: 2.7rem;
    font-weight: 900;
    z-index: 1;
    margin: 0 auto;
    line-height: 2.7rem;
    border: 1px solid #245090;
}
section.kaiketsu .osusume p:before,
section.kaiketsu .osusume p:after {
    content: "";
    display: block;
    width: 0;
    height: 0;
    border-style: solid;
    position: absolute;
    top: 0;
}
section.kaiketsu .osusume p:before {
    border-width: 0 0 1em 1em;
    border-color: transparent transparent #245090 transparent;
    left: -1em;
}
section.kaiketsu .osusume :after {
    border-width: 1em 0 0 1em;
    border-color: transparent transparent transparent #245090;
    right: -1em;
}
section.kaiketsu .osusume ul {
    font-weight: 700;
    font-size: 2.7rem;
    color: white;
    padding: 2em 1.5em 1em 1.5em;
    background: rgba(0,0,0,0.75);
    position: relative;
    display: table;
    margin: -2.8rem 0 0 0;
}
section.kaiketsu li:first-child .osusume {
    margin: 0 auto 40px auto;
}
section.kaiketsu .osusume ul:after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 98%;
    height: 94%;
    border: 1px solid rgba(255,255,255,0.50);
}
section.kaiketsu .osusume ul li {
    line-height: 2;
    padding-left: 40px;
    letter-spacing: 0.05em;
    background: url(../images/check.png) no-repeat left;
    background-size: 33px auto;
}
section.kaiketsu .hairrepro {
    transform: skewY(4deg);
    display: table;
    margin: 50px auto 0 auto;
    background: white;
    width: 100%;
    padding: 3em;
}
section.kaiketsu .hairrepro img {
    margin: 0 auto;
}
section.kaiketsu .hairrepro .hr-maintitle {
    margin: 0 auto 30px auto;
}
section.kaiketsu .hairrepro .hr-subtitle {
    margin: 0 auto 10px auto;
}
section.kaiketsu .hairrepro .hr-hairsupport {
    margin: 0 auto 25px auto;
}
section.kaiketsu .hairrepro p {
    text-align: center;
    margin: 0 auto 25px auto;
    font-size: 1.7rem;
    font-weight: 600;
    line-height: 1.5;
}
section.kaiketsu .before .text {
    background: #9f9a09;
    display: block;
    padding: 2.5em 5.5em 5em 1.5em;
    position: relative;
    left: 4em;
    top: 3em;
    width: calc(100%);
}
section.kaiketsu .before .text p {
    color: white;
    font-size: 1.5rem;
    line-height: 1.6;
}
section.kaiketsu .b-a {
    transform: skewY(4deg);
    width: 85%;
    margin: 0 auto 85px 0;
    padding: 0 0 0 0;
    position: relative;
    z-index: 1;
    display: flex;
}
section.kaiketsu .after picture {
    background: #aaaaaa;
    margin-left: 1px;
}
section.kaiketsu .after {
    width: 60%;
}
section.kaiketsu .before {
    width: 40%;
    flex-shrink: 2;
}
section.kaiketsu .before picture {
    display: table;
    position: relative;
    top: -0.8em;
    width: 247px;
}
.slider{
  display: none;
}
.slider.slick-initialized{
  display: block;
}
section.kaiketsu .slick-dots li {
    margin: 0 5px;
}
section.kaiketsu .slick-dots li button:before {
    font-size: 15px !important;
    color: white !important;
    border-radius: 1em;
    text-indent: -999em;
    background: white !important;
    border: 2px solid black;
    opacity: 1 !important;
    width: 16px !important;
    height: 16px !important;
}
section.kaiketsu .slick-dots li.slick-active button:before {
    background: black !important;
}
section.kaiketsu .slick-dots {
    bottom: -8%;
}
section.kaiketsu .slick-dots li.slick-active button {
    background: transparent !important;
}
section.kaiketsu .after:after {
    content: "";
    background: url(../images/style_after_after.png) no-repeat;
    background-size: contain;
    display: table;
    position: absolute;
    background-position: top right;
    width: calc(100% - 60%);
    height: calc(100% - 80%);
    z-index: 2;
    bottom: 3em;
    right: 2em;
}
section.kaiketsu .zomo-lineup {
    transform: skewY(4deg);
    margin: 0 auto 40px auto;
}
section.kaiketsu .pinpoint {
    width: 100%;
    margin: 0 auto 0 auto;
    border: 4px solid #d3d3d3;
    padding: 30px;
    background: white;
    transform: skewY(4deg);
}
section.kaiketsu .pinpoint h2 {
    margin: 0 auto 20px auto;
    display: table;
}
section.kaiketsu .pinpoint .flexbox {
    display: flex;
    align-items: center;
    width: 100%;
    justify-content: space-between;
    margin: 0 auto 40px auto;
}
section.kaiketsu .pinpoint .flexbox .youtube {
    width: 40%;
    border: 1px solid #d3d3d3;
}
section.kaiketsu .pinpoint .flexbox .sentence {
    padding-left: 30px;
    width: 60%;
}
section.kaiketsu .pinpoint .flexbox .sentence .pin-title {
    font-weight: 900;
    font-size: 2.2rem;
    font-feature-settings: "palt";
    padding-bottom: 0.5em;
    border-bottom: 1px solid #000;
    margin-bottom: 0.5em;
    letter-spacing: 0.03em;
    font-family: 'Noto Sans JP', sans-serif;
    line-height: 1.5;
}
section.kaiketsu .pinpoint .flexbox .sentence .pin-title span {
    font-size: 70%;
}
section.kaiketsu .pinpoint .flexbox .sentence p {
    font-weight: 600;
    line-height: 1.8;
}
section.kaiketsu .secret .acc-inner.one {
    display: block;
}
section.kaiketsu .secret .acc-inner.four .movie p {
    padding-top: 2em;
}
section.kaiketsu .secret .wrap {
    background: #313131 url(../images/dot.png) repeat-y;
    background-size: 18%;
    color: white;
    padding: 1.5em;
    position: relative;
    display: block;
    height: 100px;
}
section.kaiketsu .secret .wrap .catch {
    font-size: 1.3rem;
    font-weight: 500;
    line-height: 1em;
    margin-bottom: 0.5em;
}
section.kaiketsu .secret .wrap h2 {
    font-size: 2rem;
    line-height: 1.3em;
    font-feature-settings: "palt";
}
section.kaiketsu .secret .title.one h2 {
    margin: 0 0 1em 0;
    font-size: 2rem;
}
section.kaiketsu .secret .title.three h2 {
    margin: 0 0 0 0;
}
section.kaiketsu .secret .wrap .catch p,
section.kaiketsu .secret .wrap h2 {
    font-family: 'Noto Sans JP', sans-serif;
    letter-spacing: 0.1em;
}
section.kaiketsu .secret .wrap h2 span {
    font-size: 60%;
    line-height: 0;
}
section.kaiketsu .secret p.note {
    position: absolute;
    bottom: 0.5em;
    right: 1em;
    font-size: 1.15rem;
}
section.kaiketsu .secret .title.one .wrap:after,
section.kaiketsu .secret .title.four .wrap:after {
    content: "";
    width: 80px;
    height: 89px;
    display: table;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;    
}
section.kaiketsu .secret .title.one .wrap:after {
    background: url(../images/tech1_list_balloon.png) no-repeat;
    top: -35px;
    right: 1em;
}
section.kaiketsu .secret .title.four .wrap:after {
    background: url(../images/tech4_list_balloon.png) no-repeat;
    right: 10px;
    top: -55px;
}
section.kaiketsu .secret .acc-inner {
    display: none;
    transition: none;
}
section.kaiketsu .secret ul.ok {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 5em;
}
section.kaiketsu .secret ul.ok li {
    border: 1px solid #313131;
    position: relative;
    width: calc(100% / 3 - 20px);
}
section.kaiketsu .secret ul.ok li img {
    width: 100%;
}
section.kaiketsu .secret ul.ok li p {
    display: table;
    background: #313131;
    line-height: 1em;
    color: white;
    text-align: center;
    padding: 0.5em 1em;
    position: absolute;
    bottom: -1em;
    transform: translate(-50%, 0px);
    -webkit-transform: translate(-50%, 0px);
    -ms-transform: translate(-50%, 0px); 
    left: 50%;
    right: 0;
    font-size: 1.5rem;
    white-space: nowrap;
}
section.kaiketsu .secret .secret-series ul {
    width: 100%;
    margin: 0 auto;
}
section.kaiketsu .secret .secret-series li {
    background: #dde9f4;
    padding: 1.5em;
    margin-bottom: 3em;
    width: 100% !important;
    min-height: 260px;
}
section.kaiketsu .secret .secret-series li .inner {
    display: block;
}
section.kaiketsu .secret .secret-series li .inner picture {
    display: table;
    margin: 0 auto;
}
section.kaiketsu .secret .secret-series li .inner dl {
    text-align: center;
    margin-bottom: 1em;
    line-height: 1.6;
}
section.kaiketsu .secret .secret-series li .inner dd {
    font-size: 1.4rem;
    font-weight: 500;
    font-feature-settings: "palt";
}
section.kaiketsu .secret ul.wrap-secret-series {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    max-width: 1000px;
    margin: 0 auto;
}
section.kaiketsu .secret ul.wrap-secret-series li {
    width: calc(100% / 2 - 5px);
}
section.kaiketsu .secret ul.wrap-secret-series li:nth-child(3) img {
    margin-top: 30px;
}
section.kaiketsu .secret ul.wrap-secret-series li:nth-child(3) .secret-series ul li,
section.kaiketsu .secret ul.wrap-secret-series li:nth-child(4) .secret-series ul li {
    margin-bottom: 0;
}
section.kaiketsu .image-last img {
    position: relative;
    display: table;
}
section.kaiketsu .image-last img:first-of-type {
    margin: 0 0 0 auto;
    z-index: 1;
}
section.kaiketsu .image-last img:last-of-type {
    margin: -150px 0 0 0;
}
section.kaiketsu ul li:nth-child(3) .frame {
    flex-wrap: wrap;
    background: rgba(255,255,255,0.8) url("../images/freedom_bg.png") no-repeat bottom;
    margin-bottom: 0;
    padding: 6em 3em 0 3em;
}
section.kaiketsu .freedom-wrap {
    transform: skewY(4deg);
    padding-top: 50px;
}
section.kaiketsu .freedom-slide {
    transform: skewY(4deg);
    display: flex;    
}
section.kaiketsu .freedom-slide picture {
    width: calc(100% / 4);
    display: table;
}
section.kaiketsu .freedom-slide picture img {
    width: 100%;
}
section.kaiketsu ul li .frame.f-slide {
    display: block;
    padding: 3em 0 6em 0;
}

/* ====================================== */
/* section salon */

section.salon {
    position: relative;
    padding: 0 0 0 0;
}
section.salon:after {
    content: "";
    display: block;
    position: absolute;
    width: 100%;
    min-height: 50%;
    top: 0;
}
section.salon .title {
    text-align: center;
    font-size: 4.5rem;
    font-weight: 900;
    line-height: 1.5;
    font-style: italic;
    padding: 1em 0 0 0;
    position: relative;
}
section.salon .title p {
    position: relative;
    z-index: 2;
    letter-spacing: 0.05em;
    line-height: 1.3;
}
section.salon .title p span {
    font-size: 130%;
    color: #026ca3;
}
section.salon .bg {
    position: absolute;
    top: 0;
    right: 0;
    z-index: 1;
    width: 100%;
}
section.salon ul.main,
section.salon ul.sub {
    position: relative;
    z-index: 2;
}
section.salon ul.main {
    display: flex;
    align-items: center;
    width: 1000px;
    margin: 4em auto 2em auto;
}
section.salon ul.main li:first-child {
    flex-shrink: 0;
}
section.salon ul.main li .pic img {
    border: 10px solid #245090;
}
section.salon ul.main li .pic p {
    padding: 0.3em 2em 0.3em 1em;    
    letter-spacing: 0.05em;
    background: #245090;
    color: white;
    font-weight: 700;
    font-style: italic;
    font-size: 2.5rem;
    line-height: 2.5rem;
    display: table;
    position: relative;
    margin-left: auto;
}
section.salon ul.main li .pic p:before {
    content: "";
    display: block;
    position: absolute;
    left: -25px;
    transform: skewX(-30deg);
    background: #244f90;
    top: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
}
section.salon ul.main li .free {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 2rem;
    font-weight: 700;
    background: #ED2953;
    background: -webkit-linear-gradient(to bottom left, #ED2953 48%, #D4284C 53%);
    background: -moz-linear-gradient(to bottom left, #ED2953 48%, #D4284C 53%);
    background: linear-gradient(to bottom left, #ED2953 48%, #D4284C 53%);
    position: absolute;
    left: -1em;
    top: 1em;
}
section.salon ul.main li:nth-child(2) p {
    font-size: 2.5rem;
    font-weight: 700;
    line-height: 1.5;
    padding-left: 1.5em;
    letter-spacing: 0.05em;
}
section.salon ul.main li:nth-child(2) p span {
    color: #eb1744;
}
section.salon ul.sub {
    display: flex;
    width: 1000px;
    margin: 0 auto 2em auto;
    justify-content: space-between;
}
section.salon ul.sub li {
    position: relative;
    flex-shrink: 0;
}
section.salon ul.sub li div {
    position: relative;
}
section.salon ul.sub li div:after {
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 77.5px 0 77.5px 1em;
    border-color: transparent transparent transparent #0da1dc;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    right: -1em;
}
section.salon ul.sub li:last-child div:after {
    content: none;
}
section.salon ul.sub li dl {
    display: flex;
    font-size: 2rem;
    font-weight: 700;
    align-items: center;
}
section.salon ul.sub li dl dt {
    width: 22px;
    height: 22px;
    background: #eb1744;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1.2rem;
}
section.salon ul.sub li dl dt p {

}
section.salon ul.sub li dl dd {
    font-style: italic;
}
section.salon ul.sub li dl dd span {
        color: #eb1744;
}
section.salon p.note {
    width: 1000px;
    margin: 0 auto;
    line-height: 1.8;
    letter-spacing: 0.03em;
}


/* ====================================== */
/* section salon-eisei */

section.salon-eisei {
    position: relative;
    padding: 3em 0 80px 0;
}
section.salon-eisei .bg1,
section.salon-eisei .bg2 {
    position: absolute;
    z-index: -1;
}
section.salon-eisei .bg1 {
    top: 0;
    left: 0;
}
section.salon-eisei .bg2 {
    bottom: 0;
    right: 0;
}
section.salon-eisei .box1,
section.salon .box2 {
    display: table;
    margin: 0 auto;
}
section.salon-eisei .box1 {
    margin: 0 auto 0 auto;
    width: 95%;
}
section.salon-eisei .box1 img:hover,
section.salon-eisei .box1 a:hover {
    opacity: 0.9 !important;
}
section.salon-eisei .box2 {
    width: 1000px;
    padding: 3em;
    min-height: 482px;
    background: #f1f3f0 url(../images/eisei_bg.png) no-repeat right;
    background-size: auto 100%;
    margin: 0 auto;
}
section.salon-eisei .box1 img {
    margin: 0 auto;
}
section.salon-eisei .box2 .title {
    font-size: 3rem;
    font-weight: 900;
    display: table;
    padding: 0 0 0 0;
    margin: 0 0 0.5em 0;
    border-bottom: 7px solid rgba(11,108,190,0.3);
    text-shadow    : 
       2px  2px 1px #ffffff,
      -2px  2px 1px #ffffff,
       2px -2px 1px #ffffff,
      -2px -2px 1px #ffffff,
       2px  0px 1px #ffffff,
       0px  2px 1px #ffffff,
      -2px  0px 1px #ffffff,
       0px -2px 1px #ffffff; 
}
section.salon-eisei .box2 .title span {
    color: #002859;
}
section.salon-eisei .box2 .lead {
    font-size: 1.5rem;
    text-shadow:
        2px 2px 1px #ffffff,
        -2px 2px 1px #ffffff,
        2px -2px 1px #ffffff,
        -2px -2px 1px #ffffff,
        2px 0px 1px #ffffff,
        0px 2px 1px #ffffff,
        -2px 0px 1px #ffffff,
        0px -2px 1px #ffffff;
    margin-bottom: 1.5em;
    font-weight: 600;
    width: 45%;
    text-align: center;
    line-height: 1.6;
}
section.salon-eisei .box2 ul {
    display: flex;
    justify-content: center;
    width: 45%;
    flex-wrap: wrap;
}
section.salon-eisei .box2 ul li {
    flex-shrink: 0;
}
section.salon-eisei .box2 ul li:first-child,
section.salon-eisei .box2 ul li:nth-child(2),
section.salon-eisei .box2 ul li:nth-child(3) {
    margin-bottom: 15px;
}
section.salon-eisei .box2 ul li:first-child,
section.salon-eisei .box2 ul li:nth-child(2),
section.salon-eisei .box2 ul li:nth-child(4) {
    margin-right: 15px;
}


/* ====================================== */
/* section map */

section.map {
   background: #e1f7fd url(../images/salon_bg.png) no-repeat top center;
   background-size: cover;
   width: 100%; 
   padding: 0 0 8em 0;
}
section.map .salontitle {
    position: relative;
    top: -2em;
    display: table;
    margin: 0 auto;
    width: 50em;
}
section.map .salontitle:before,
section.map .salontitle:after {
    position: absolute;
    display: block;
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
}
section.map .salontitle:before {
    border-width: 0 0 2em 1em;
    border-color: transparent transparent #002c5e transparent;
    left: -1em;
}
section.map .salontitle:after {
    border-width: 2em 0 0 1em;
    border-color: transparent transparent transparent #002c5e;
    right: -1em;
}
section.map .salontitle p {
    color: white;
    font-size: 3.5rem;
    font-weight: 900;
    font-style: italic;
    letter-spacing: 0.1em;
    background: #245090;
    display: table;
    margin: auto;
    padding: 0.8em 0 0.5em 0;
    width: 20em;
    text-align: center;
    line-height: 3.5rem;
    position: absolute;
    left: 0;
    right: 0;
}
section.map .salontitle p:after {
    content: "";
    display: block;
    width: 0;
    height: 0;
    position: absolute;
    left: 0;
    bottom: -2em;
    border-style: solid;
    border-width: 2em 10em 0 10em;
    border-color: #244f90 transparent transparent transparent;
}
section.map .salontitle p span {
    font-size: 80%;
}
section.map .box {
    display: table;
    margin: 0 auto;
    padding: 5em 0 0 0;
}

/* ====================================== */
/* section cvbtm */

section.cvbtm {
    background: -webkit-linear-gradient(bottom, #DDD468 0%, #FFFFFF 50%);
    background: -o-linear-gradient(bottom, #DDD468 0%, #FFFFFF 50%);
    background: linear-gradient(to top, #DDD468 0%, #FFFFFF 50%);
    position: relative;
    padding: 8em 0;
}
section.cvbtm:after {
    content: "";
    display: block;
    top: 0;
    left: 0;
    right: 0;
    margin: auto;
    position: absolute;
    width: 100%;
    height: 100%;
    background: url(../images/cv_bg.png) no-repeat 0 0;
    background-size: cover;
}
section.cvbtm .inner {
    max-width: 1000px;
    background: rgba(255,255,255,0.9);
    display: table;
    margin: 0 auto;
    padding: 2.5em 2.5em 8em 2.5em;
    box-sizing: border-box;
    position: relative;
    z-index: 2;
}
section.cvbtm .inner img {
    position: relative;
}
section.cvbtm img.pamph {
    position: absolute;
    z-index: 3;
    right: 3em;
}
section.cvbtm .inner .sentence {
    display: none;
    border-bottom: 1px solid #245090;
    padding: 0 0 0.5em 0;
    font-style: italic;
    font-weight: 700;
    line-height: 1.8;
}

/* ====================================== */
/* section info */

section.info {
    padding: 5em 0 0 0;
}
section.info .box {
    max-width: 800px;
    padding: 2.5em 5em;
    box-sizing: border-box;
    display: table;
    margin: 0 auto 5% auto;
    background: #245090;
    position: relative;
    color: white;
    font-weight: 900;
    text-align: center;
}
section.info .box:after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 98%;
    height: 94%;
    border: 1px solid #ceaf47;
}
section.info .box .title {
    font-size: 4rem;
    margin-bottom: 0.5em;
}
section.info .box .lead {
    font-size: 2.3rem;
    line-height: 1.6;
}
section.info .box .lead span {
    color: #d9a800;
}
section.info h3 {
    color: #245090;
    font-weight: 900;
    font-size: 3.5rem;
    margin: 0 auto 2% auto;
    text-align: center;
}
section.info .eisei {
    margin: 0 auto 5% auto;
    display: table;
}
section.info .exp {
    text-align: center;
    font-weight: 900;
    font-size: 2.5rem;
    line-height: 1.7;
    margin-bottom: 4%;
}
section.info ul {
    display: flex;
    justify-content: center;
    width: 748px;
    margin: 0 auto;
    flex-wrap: wrap;
}
section.info ul li {
    text-indent: -999em;
    background-repeat: no-repeat;
    background-size: 214px 214px;
    width: 214px;
    height: 214px;
    display: block;
    margin: 0 2% 7% 2%;
}
section.info ul li:first-child {
    background-image: url(../images/icon_eisei_1.jpg);
}
section.info ul li:nth-child(2) {
    background-image: url(../images/icon_eisei_2.jpg);
}
section.info ul li:nth-child(3) {
    background-image: url(../images/icon_eisei_3.jpg);
}
section.info ul li:nth-child(4) {
    background-image: url(../images/icon_eisei_4.jpg);
}
section.info ul li:nth-child(5) {
    background-image: url(../images/icon_eisei_5.jpg);
}

/* ====================================== */
/* cvbtn-common */

.cvbtn-common {
    max-width: 900px;
    display: table;
    margin: 0 auto;
}
.cvbtn-common,
.cvbtn-common img {
    transition: all 0.3s;
}

/* ====================================== */
/* media query */

@media screen and (max-width : 64em) {
	
    /* common */
    section {
        padding: 3em 0;
    }
    
    /* fv */
    .fv {
        padding: 30px 0 10px 0;
    }
    .fv h1 img {
        max-width: 95%;
    }
    .cvbtn-fv img {
        max-width: 70%;
    }
    
    /* section.kininaru */    
    section.kininari ul {
        width: 95%;
        font-size: 2.5rem;
    }
    section.kininari ul li {
        background-size: 35px;
        padding-left: 45px;
    }
    section.kininari .catch img {
        width: 70%;
    }
    
    /* okotae */
    section.okotae {
        padding: 3em 0 2em 0;
    }
    section.okotae .hajimeru-pamph {
        max-width: 95%;
        margin: 0 auto 5em auto;
    }
    section.okotae .catch1 p.first-text {
        font-size: 2.5rem;
    }
    section.okotae .catch1 p.second-text {
        font-size: 1.8rem;
    }
    section.okotae .catch2 p.first-text {
        font-size: 3.5rem;
    }  
    section.okotae .catch2 p.second-text {
        font-size: 2rem;
    }
    
    /* section kaiketsutitle */
    
    section.kaiketsutitle {
    }
    section.kaiketsutitle .title p {
        margin: 0 auto;
        display: table;
    }
    section.kaiketsutitle .subtitle {
        display: table;
    }
    
    /* cvbtn-common */

    .cvbtn-common {
        max-width: 90%;
    }
    
    /* section kaiketsu */
    
    section.kaiketsu ul li .frame {
        max-width: 95%;
        padding: 4em 2em;
    }
    section.kaiketsu ul li:nth-child(3) .frame {
        padding: 4em 1em 0 1em;
    }
    section.kaiketsutitle .title {
        font-size: 6vw;
    }
    section.kaiketsu .product {
        max-width: 95%;
    }
    section.kaiketsu .image-inner {
        max-width: 100%;
    }
    section.kaiketsu .osusume {
        transform: skewY(4deg);
        transform-origin: top center;
    }
    section.kaiketsu .osusume ul {
        font-size: 2rem;
    }
    section.kaiketsu .osusume ul li {
        background-size: 22px auto;
        padding-left: 30px;
    }    
    section.kaiketsu .osusume p {
        font-size: 2.5rem;
    }
    section.kaiketsu .lead {
        font-size: 2.25rem;
    }
    section.kaiketsu .before .text {
        padding: 2em 2em 5em 1em;
        left: 1em;
    }
    section.kaiketsu .before .text p {
        font-size: 1.4rem;
    }    
    section.kaiketsu .before picture {
        width: 75%;
    }
    section.kaiketsu .pinpoint .flexbox .sentence .pin-title {
        font-size: 2rem;
    }
    section.kaiketsu {
        max-width: 100%;
        background-size: 50%;
        margin: 0 auto 0 auto;
    }
    section.kaiketsu .secret .secret-series ul {
        width: 100%;
    }   
    section.kaiketsu .secret ul.wrap-secret-series {
        max-width: 100%;
        display: block;
        width: 100%;
    }    
    section.kaiketsu .secret ul.wrap-secret-series li {
        min-height: initial;
        width: 100%;
        margin-bottom: 2em;
    } 
    section.kaiketsu .secret ul.wrap-secret-series li:last-child {
        margin-bottom: 0;
    }
    section.kaiketsu .secret ul.wrap-secret-series li:nth-child(3) .secret-series ul li {
        margin-bottom: 4em;
    }
    section.kaiketsu .secret .wrap {
        background: #313131 url(../images/dot_sp.png) repeat-y;
        background-size: 10%;
        height: auto;
    }    
    section.kaiketsu .secret .title.one .wrap:after {
    }
    section.kaiketsu .secret .wrap .catch {
    }   
    section.kaiketsu .secret .wrap h2 {
        font-size: 2.5rem;
    }
    section.kaiketsu .secret .secret-series li .inner dd {
        letter-spacing: 0.05em;
    } 
    section.kaiketsu .secret p.note {
    }
    section.kaiketsu .secret .secret-series li {
        padding: 1em;
    }
    section.kaiketsu .pinpoint .flexbox {
        display: block;
    }
    section.kaiketsu .pinpoint .flexbox .youtube {
        width: 100%;
        margin-bottom: 1em;
    }
    section.kaiketsu .pinpoint .flexbox .sentence {
        padding-left: 0;
        width: 100%;
    } 
    section.kaiketsu .image-last img:first-of-type {
        width: 38vw;
    }
    section.kaiketsu .image-last img:last-of-type {
        width: 50vw;
        margin: -10em 0 0 0;
    }
    section.kaiketsu li:nth-child(3) .osusume {
        margin: -6em 0 0 auto;
    }
    
    /* section salon */
    section.salon ul.main {
        width: 95%;
    }
    section.salon ul.main li .free {
        width: 60px;
        height: 60px;
    }
    section.salon ul.main li:nth-child(2) p {
        font-size: 2rem;
    }
    section.salon .salon-inner {
        width: 95%;
        margin: 0 auto;
        overflow-x: scroll;
    }  
    section.salon p.note {
        width: 95%;
    }
    
    /* section salon-eisei */
    section.salon-eisei .box1 {
        width: 95%;
    } 
    section.salon-eisei .box2 {
        width: 95%;
        padding: 2em;
        min-height: initial;
        background-size: cover;
        background-position: center;
    } 
    section.salon-eisei .box2 .title {
        margin: 0 auto 0.5em auto;
    }   
    section.salon-eisei .box2 .lead {
        width: auto;
    }
    section.salon-eisei .box2 ul {
        width: auto;
    } 
    section.salon-eisei .box2 ul li {
        margin: 0.5em;
        width: 7em;
    } 
    
    /* section cvbtm */
    section.cvbtm {
        padding: 5em 0;
    }
    section.cvbtm .inner {
        max-width: 95%;
        padding: 2em;
    }
    section.cvbtm .cvbtn {
        display: block;
    }
    section.cvbtm .cvbtn a {
        width: 100%;
        background-size: contain;
    }
    section.cvbtm img.pamph {
        width: 20%;
    }
    section.cvbtm .cvbtn p {
        font-size: 2.5rem;
    }
    .youtube {
		position: relative;
		width: 100%;
		padding-top: 56.25%;
        max-width: initial;
        margin: 0 auto 0 auto;
	}
	
	.youtube iframe {
		position: absolute;
		top: 0;
		right: 0;
		max-width: 100% !important;
		width: 100% !important;
		height: 100% !important;
	} 
    
}

@media screen and (max-width : 42em) {
	
    /* common */
    
    body {
        min-width: 100%;
    }
    .pc {
        display: none;
    }
	.sp {
		display: block;
	}
    .ipad {
        display: none;
    }
    body {
        min-width: 100%;
    }
    section {
        padding: 2em 0;
    }
    p.note {
        font-size: 3vw;
    }   
    
    /* fv */
    
    .fv {
        padding: 15px 0 10px 0;
        background: #42b1eb url("../images/fv_bg_sp.png") no-repeat center;
        background-size: cover;
    }
    .fv h1 {
        display: table;
        margin: 0 auto 10px auto;
        background: url(../images/fv_title_sp.png) center / 95% auto no-repeat;
        width: 100%;
        height: 0;
        padding-top: 56.6831683168%;
        aspect-ratio: 404 / 229;
    }
    .cvbtn-fv img {
        max-width: 90%;
    }

    p.note.pin {
        width: 100%;
        margin: 1em auto 3em auto;
        text-align: center;
    }
    .pinpamph {
        margin-bottom: 2em;
    }    
    .pinpamph img {
        zoom: 0.5;
        left: 1em;
    }    
    .cvbtn {
        display: block;
        margin: 0 auto;
    }
    .cvbtn .mazu {
        left: 1em;
    }
    .cvbtn p {
        font-size: 4.5vw;
        line-height: 1;
        z-index: 1;
        margin: 0 auto;
    }
    .cvbtn .mazu:before,
    .cvbtn .mazu:after {
        width: 1.5em;
        background-size: contain;
        background-position: bottom;
    }
    .cvbtn .mazu:before {
        left: -2em;
    }
    .cvbtn .mazu:after {
        right: -2em;
    }
    .cvbtn a {
        width: 90%;
        height: 0;
        padding-top: 13.2208157525%;
        background: url(../images/cv_sp.png) no-repeat;
        background-size: contain;
        background-repeat: no-repeat;
        border-color: #777777 transparent transparent transparent;
    }
    .arrow {
        border-width: 2em 40vw 0 40vw;
    }
    .arrow-wrap {
        width: 60vw;
        height: 2em;
        bottom: -1em;
    }
    .arrow-bg {
        width: 100vw;
        height: 2em; 
    } 
    
    /* section.kininari */
    
    section.kininari .catch {
        margin: 0 auto 1em auto;
    }
    section.kininari {
    }
    section.kininari ul {
        width: 95%;
        padding: 1em;
        font-size: 4vw;
    }
    section.kininari ul li {
        background-size: 1.5em;
        padding-left: 2.2em;
    }
    
    /* okotae */
    
    section.okotae .catch1 p.first-text {
        font-size: 4vw;
    }
    section.okotae .catch1 p.first-text:before,
    section.okotae .catch1 p.first-text:after {
        height: 30px;
    }
    section.okotae .catch1 p.second-text {
        font-size: 3vw;
    }
    section.okotae .catch2 {
        margin: 0 auto 20px auto;
    }
    section.okotae .catch2 p.first-text {
        font-size: 5.85vw;
        font-feature-settings: "palt";
    }
    section.okotae .catch1 p.second-text {
        font-size: 3vw;
        margin-bottom: 20px;
    } 
    
    /* section kaiketsutitle */
    
    section.kaiketsutitle {
        padding: 1em 0;
    }
    section.kaiketsutitle .title {
        max-width: 90%;
        font-size: 7vw;
    }
    section.kaiketsutitle .subtitle {
        font-size: 4vw;
        max-width: 90%;
        margin: 1.2em auto 0 auto;
    }
    
    /* section kaiketsu */
    
    section.kaiketsu:before {
        border-width: 0 0 100px 100vw;
        top: -100px;
    }
    section.kaiketsu ul {
        margin: 0 auto;
        width: 100%;
    }
    section.kaiketsu {
        padding: 60px 0 0.5em 0;
        background-size: contain;
    }
    section.kaiketsu ul li .frame {
        min-height: initial;
        width: 100%;
        padding: 4em 1em;
        top: 0;
        margin: 0 auto 2em auto;
    }
    section.kaiketsu .osusume ul {
        padding: 2.5em 1em 1em 1em;
        font-size: 3vw;
        width: 100%;
    }
    section.kaiketsu .osusume ul li {
        background-size: 1.2em;
        padding-left: 1.5em; 
        line-height: 2;
    }
    section.kaiketsu .image,
    section.kaiketsu .osusume {
    }
    section.kaiketsu .osusume.b,
    section.kaiketsu .image.b {
        left: 20%;
    }
    section.kaiketsu .osusume p {
        font-size: 3.5vw;
        line-height: 1.3;
    }
    section.kaiketsu .image p {
        font-size: 4vw;
    }
    section.kaiketsu .lead {
        font-size: 3.6vw;
        line-height: 1.3;
    }
    section.kaiketsu .product {
        width: 100%;
    }
    section.kaiketsu .product p {
        font-size: 4vw;
        padding: 0.5em 0;
    }
    section.kaiketsu li:nth-child(2) .osusume {
        margin: -3em auto 0 auto;
    }
    section.kaiketsu .hairrepro {
        margin: 60px auto 0 auto;
        padding: 1em;
    }
    section.kaiketsu .hairrepro .hr-subtitle {
        padding: 0 20px;
    }
    section.kaiketsu .hairrepro .hr-maintitle {
        margin: 0 auto 20px auto;
    }
    section.kaiketsu .hairrepro p {
        font-size: 3vw;
        margin: 0 auto 10px auto;
    }
    section.kaiketsu .hairrepro .hr-hairsupport {
        padding: 0 20px;
    }
    section.kaiketsu .b-a {
        width: 100%;
        margin: 0 auto 3em 0;
        padding: 0 0 0 0;
        flex-flow: column;
    }
    section.kaiketsu .before {
        width: 100%;
        display: flex;
        margin-top: 50px;
    }
    section.kaiketsu .before .text {
        padding: 1em 1.5em 1em 1em;
        left: initial;
        right: 0;
        top: 0;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    section.kaiketsu .before picture {
        top: 0;
    }
    section.kaiketsu .before .text p {
        font-size: 3vw;
    }
    section.kaiketsu .before picture {
    }
    section.kaiketsu .slick-dots li button:before {
        width: 10px !important;
        height: 10px !important;
    }
    section.kaiketsu .before {
        width: 100%;
        order: 1;
        flex-direction: row-reverse;
    }
    section.kaiketsu .after,
    section.kaiketsu .image-last {
        width: 85%;
    }
    section.kaiketsu .after:after {
        bottom: 2em;
    }    
    section.kaiketsu .zomo-lineup p {
        font-size: 4vw;
    } 
    section.kaiketsu .slick-dots {
        bottom: -3em;
    }
    section.kaiketsu .pinpoint {
        width: 100%;
        padding: 1em;
        background-size: 100%;
    }
    section.kaiketsu .pinpoint h2 {
        width: 100%;
        padding: 0 0.5em;
        margin: 0 auto 1em auto;
        line-height: 0;
    }
    section.kaiketsu .pinpoint .flexbox {
        flex-flow: column;
        width: 100%;
    }
    section.kaiketsu .pinpoint .flexbox .youtube {
        width: 100%;
        margin: 0 auto 1em auto;
    }
    section.kaiketsu .pinpoint .flexbox .sentence {
        padding-left: 0;
        width: 100%;
    }
    section.kaiketsu .pinpoint .flexbox .sentence .pin-title {
        font-size: 3.5vw;
        text-align: center;
    }    
    section.kaiketsu .pinpoint .flexbox .sentence p {
        font-size: 3vw;
    } 
    section.kaiketsu .secret .wrap .catch {
        font-size: 2.5vw;
    }   
    section.kaiketsu .secret .title h2 {
        font-size: 3.25vw !important;
        padding: 0 0 0 0;
    }
    section.kaiketsu .secret .title.one .wrap:after {
        background-size: 70px;
        background-position: right;
    }
    section.kaiketsu .secret .secret-series li .inner dd {
        font-size: 2.6vw;
    }
    section.kaiketsu .secret .wrap {
        padding: 1em;
    }
    section.kaiketsu .image-last img:last-of-type {
        margin: -5em 0 0 0;
    }
    section.kaiketsu li:nth-child(3) .osusume {
        margin: -3em 0 0 auto;
    }
    
    /* section salon */
    
    section.salon {
        top: 0;
    }
    section.salon ul.main {
        display: table;
        margin: 2em auto 2em auto;
    }
    section.salon .title {
        font-size: 5vw;
        padding: 1em 0 0 0;
    }
    section.salon ul.main li .free {
        font-size: 5vw;
        left: 1em;
        width: 16vw;
        height: 16vw;
        z-index: 2;
    }
    section.salon ul.main li .pic p {
        font-size: 4vw;
        padding: 0.5em 2em 0.5em 1em;
    }
    section.salon ul.main li .pic img {
        width: 100%;
    }
    section.salon ul.main li:nth-child(2) p {
        padding-left: 0;
        padding-top: 0.5em;
        font-size: 4vw;
    }
    section.salon ul.sub {
        margin: 0 auto;
        width: 100%;
        flex-direction: column;
    }
    section.salon ul.sub li {
        display: flex;
        -webkit-flex-flow: column;
        flex-flow: column;
        justify-content: center;
    }
    section.salon ul.sub li div {
        width: 80%;
        margin: 0 auto;
        order: 2;
    }
    section.salon ul.sub li div img {
        width: 100%;
        position: relative;
    }
    section.salon ul.sub li div:after {
        border-width: 1.5em 30vw 0 30vw;
        border-color: #0da1dc transparent transparent transparent;
        left: 0;
        right: 0;
        top: initial;
        bottom: -1.5em;  
    }
    section.salon ul.sub li dl {
        order: 1;
        width: 70%;
        margin: 2em auto 0.5em auto;
        font-size: 4vw;
        text-align: center;
        justify-content: center;    
    }
    section.salon ul.sub li dl dt {
        width: 5vw;
        height: 5vw;
        font-size: 3vw;
    }
    section.salon p.note {
        width: 90%;
        margin: 1.5em auto 0 auto;
    }
    section.salon .salon-inner {
        overflow-x: hidden;
        width: 100%;
    }
    
    /* section salon-eisei */
    
    section.salon-eisei {
        padding: 2em 0;
        width: 95%;
        margin: 0 auto;
    }
    section.salon-eisei .box1 {
        margin: 0 auto 0 auto;
        width: 100%;
    }
    section.salon-eisei .box2 {
        background: #f1f3f0;
        min-height: initial;
        padding: 0 0 5% 0;
        width: 100%;
    } 
    section.salon-eisei .box2 .title {
        font-size: 6vw;
        text-align: center;
        margin: 1em auto 0.5em auto;
    }
    section.salon-eisei .box2 .lead {
        width: 100%;
        margin: 0 auto 1.5em auto;
    }
    section.salon-eisei .box2 ul {
        width: 100%;
        margin: 0 auto;
    }
    section.salon-eisei .box2 ul li {
        width: 25%;
        margin: 0.5em !important;
    }
    
    /* map */
    
    section.map .salontitle {
        width: 80%;
        z-index: 1;
    }
    section.map .salontitle p {
        width: 100%;
        font-size: 4vw;
    }
    section.map .salontitle p:after {
        bottom: -0.9em;
        border-width: 1em 40vw 0 40vw;
    }
    section.map .box {
        width: 90%;
        padding: 2em 0 0 0;
    }
    section.map {
        padding: 0 0 5em 0;
    }
    
    /* section cvbtm */
    
    section.cvbtm {
        padding: 3em 0;
    }
    section.cvbtm .inner{
        zoom: 0.9;
        min-width: 100%;    
    }
    section.cvbtm .inner img {
        margin-top: 0;
    }     
    section.cvbtm .cvbtn {
        display: block;
        position: relative;
    }
    section.cvbtm .inner {
        min-width: initial;
        width: 90%;
        margin: 0 auto;
        padding: 1em;
        display: block;
        padding-bottom: 1em;
    }
    section.cvbtm .cvbtn a {
        width: 90%;
        height: auto;
        position: relative;
        background-size: contain;
        padding-top: 12.7252252252%;
        line-height: 1;
    }
    section.cvbtm img.pamph {
        width: calc(100% - 80%);
        right: 1.5em;
        bottom: 0;
    }
    section.cvbtm .cvbtn p {
        font-size: 3vw;
        top: -0.5em;
    }
    
    /* section info */
    
    section.info {
        padding: 3em 0 0 0;
    }
    section.info .box {
        width: 90%;
        font-weight: 700;
        padding: 1.5em 2em;
    }
    section.info .box .title {
        font-size: 4vw;
    }
    section.info .box .lead {
        font-size: 3vw;
    }
    section.info h3 {
        font-size: 4vw;
    }
    section.info .exp {
        font-size: 4vw;
        font-weight: 600;
    }
    section.info ul {
        width: 100%;
    }
    section.info ul li {
        width: 40vw;
        height: 40vw;
        background-size: contain;
    }
        
}