@charset "UTF-8";
/* ========== 下層ページ共通 ========== */
.page-head__breadcrumb {
    background: linear-gradient(90deg, #49c5b1 0%, rgba(73, 197, 177, .5) 100%);
    padding: 0 clamp(20px, 2.77778vw, 40px);
    font-size: 1.4rem;
    font-weight: 500;
    color: #fff;
}
.page-head__breadcrumb ul {
    padding: 15px 0;
}
.page-head__breadcrumb a {
    color: #fff;
    letter-spacing: 0;
}
.page-head__breadcrumb a:after {
    content: "＞";
    display: inline-block;
    margin: 0 1em;
}

.page-head__txt {
    padding-top: 80px;
    padding-bottom: 80px;
    text-align: center;
}
.page-head__txt .page-ttl .en {
    display: block;
    font-size: 5.2rem;
    color: #49c5b1;
    font-family: "arboria", sans-serif;
    text-transform: uppercase;
    line-height: 1.1;
    letter-spacing: .2em;
}
.page-head__txt .page-ttl .ja {
    display: block;
    font-weight: 500;
    margin-top: 2em;
    letter-spacing: .2em;
}
.page-head__txt .page-lead {
    font-size: 2.4rem;
    line-height: 1.6;
    font-weight: 500;
    letter-spacing: .1em;
    margin-top: 40px;
}

@media only screen and (max-width: 767px) {
    .page-head__breadcrumb {
        padding: 0 clamp(10px, 4.54545vw, 20px);
        font-size: 1.2rem;
    }
    .page-head__txt {
        padding-top: 60px;
        padding-bottom: 60px;
    }
    .page-head__txt .page-ttl .en {
        font-size: clamp(2rem, 9.09091vw, 4rem);
    }
    .page-head__txt .page-ttl .ja {
        margin-top: 1.5em;
    }
    .page-head__txt .page-lead {
        font-size: clamp(1rem, 4.09091vw, 1.8rem);
    }
}

/* ========== ドクター紹介 ========== */
.doctor-search__contents--area {
    margin-top: 60px;
}
.doctor-search__contents--area .js-acTrigger span {
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 20px;
    height: 20px;
}
.doctor-search__contents--area .js-acTrigger span:before, .doctor-search__contents--area .js-acTrigger span:after {
    content: "";
    position: absolute;
    background: #49c5b1;
    transition: .3s;
}
.doctor-search__contents--area .js-acTrigger span:before {
    width: 100%;
    height: 1px;
    left: 0;
    top: 50%;
}
.doctor-search__contents--area .js-acTrigger span:after {
    width: 1px;
    height: 100%;
    left: 50%;
    top: 0;
}
.doctor-search__contents--area .js-acTrigger.is-open span:after {
    opacity: 0;
}

.doctor-search__contents--cat {
    margin-top: 30px;
}

.doctor-search .area-block {
    border-top: 1px solid #49c5b1;
}
.doctor-search .area-block:last-child {
    border-bottom: 1px solid #49c5b1;
}
.doctor-search .area-block__label {
    font-size: 2.6rem;
    font-weight: 500;
    letter-spacing: .1em;
    padding: .8em 0;
    position: relative;
}
.doctor-search .area-block__contents {
    border-top: 1px solid #49c5b1;
    padding-bottom: 80px;
}

.doctor-search .area-box {
    border-bottom: 1px solid #49c5b1;
}
.doctor-search .area-box__label {
    font-size: 2.2rem;
    font-weight: 500;
    letter-spacing: .1em;
    padding: .8em 0;
    position: relative;
}
.doctor-search .area-box__contents {
    padding-bottom: 80px;
}
.doctor-search .area-box .btn-access {
    text-align: center;
    margin: 70px 0 0;
}

.doctor-search .cat-label p {
    border-top: 1px solid #49c5b1;
    font-size: 2.2rem;
    font-weight: 500;
    letter-spacing: .1em;
    padding: .8em 0;
    position: relative;
    margin: 60px 0;
}

@media only screen and (max-width: 767px) {
    .doctor-search__contents--area {
        margin-top: 30px;
    }
    .doctor-search__contents--cat {
        margin-top: 30px;
    }
    .doctor-search .area-block__label {
        font-size: clamp(1.3rem, 5.90909vw, 2.6rem);
    }
    .doctor-search .area-block__contents {
        padding-bottom: 60px;
    }
    .doctor-search .area-box__label {
        font-size: clamp(1.1rem, 5vw, 2.2rem);
    }
    .doctor-search .area-box__contents {
        padding-bottom: 60px;
    }
    .doctor-search .area-box .btn-access {
        margin: 50px 0 0;
    }
    .doctor-search .cat-label p {
        font-size: clamp(1.1rem, 5vw, 2.2rem);
        margin: 30px 0 0;
    }
}

/* ========== 施術一覧 ========== */
.ct-search__nav {
    margin-bottom: 30px;
}

.ct-search .ct-contents {
    margin-top: 60px;
}
.ct-search .ct-contents__label {
    border-top: 1px solid #49c5b1;
    color: #49c5b1;
    font-weight: 500;
    font-size: 3rem;
    padding-top: .6em;
    margin-bottom: 1em;
}
.ct-search .ct-contents__block {
    margin-bottom: 40px;
}
.ct-search .ct-contents__block:last-child {
    margin-bottom: 0;
}
.ct-search .ct-contents__block .block-label {
    font-size: 2.4rem;
    font-weight: 500;
    margin-bottom: 1em;
}
.ct-search .ct-contents__block .block-txt {
    margin-bottom: 30px;
}

@media only screen and (max-width: 767px) {
    .ct-search .c-nav02 {
        gap: 0 6.666%;
    }
    .ct-search .c-nav02__item {
        width: 20%;
        height: 72px;
    }
    .ct-search .ct-contents {
        margin-top: 30px;
    }
    .ct-search .ct-contents__label {
        font-size: 2.8rem;
    }
    .ct-search .ct-contents__block .block-label {
        font-size: 2rem;
    }
    .ct-search .ct-contents__block .block-txt {
        margin-bottom: 20px;
    }
}





/* ========== クリニック一覧 ========== */
.clinic-search__contents--area { margin-top: 60px; }
.clinic-search__contents--cat { margin-top: 30px; }

.clinic-search .area-block__label { font-size: 2.6rem; font-weight: 500; letter-spacing: .1em; padding: .8em 0; position: relative;}
.clinic-search .area-block__contents { padding-bottom: 80px; }

.clinic-search .area-box { border: 1px solid #49c5b1; border-radius: 10px; padding: 20px; margin-bottom: 30px;}
.clinic-search .area-box__label { font-size: 3.2rem; font-weight: 500; letter-spacing: .1em; padding: .8em 0; text-align: center; color: #49c5b1; }
.clinic-search .area-box__contents {}

.clinic-search .area-box__label.cl_shinjuku::after { content: 'SHINJUKU'; display: block; font-size: 1.2rem; margin: 20px 0;}
.clinic-search .area-box__label.cl_ikebukuro::after { content: 'IKEBUKURO'; display: block; font-size: 1.2rem; margin: 20px 0;}
.clinic-search .area-box__label.cl_tachikawa::after { content: 'TACHIKAWA'; display: block; font-size: 1.2rem; margin: 20px 0;}
.clinic-search .area-box__label.cl_yokohama::after { content: 'YOKOHAMA'; display: block; font-size: 1.2rem; margin: 20px 0;}
.clinic-search .area-box__label.cl_omiya::after { content: 'OMIYA'; display: block; font-size: 1.2rem; margin: 20px 0;}
.clinic-search .area-box__label.cl_takasaki::after { content: 'TAKASAKI'; display: block; font-size: 1.2rem; margin: 20px 0;}
.clinic-search .area-box__label.cl_kashiwa::after { content: 'KASHIWA'; display: block; font-size: 1.2rem; margin: 20px 0;}
.clinic-search .area-box__label.cl_tsudanuma::after { content: 'TSUDANUMA'; display: block; font-size: 1.2rem; margin: 20px 0;}
.clinic-search .area-box__label.cl_mito::after { content: 'MITO'; display: block; font-size: 1.2rem; margin: 20px 0;}
.clinic-search .area-box__label.cl_kofu::after { content: 'KOFU'; display: block; font-size: 1.2rem; margin: 20px 0;}
.clinic-search .area-box__label.cl_nagano::after { content: 'NAGANO'; display: block; font-size: 1.2rem; margin: 20px 0;}
.clinic-search .area-box__label.cl_koriyama::after { content: 'KORIYAMA'; display: block; font-size: 1.2rem; margin: 20px 0;}
.clinic-search .area-box__label.cl_nagoya::after { content: 'NAOYA'; display: block; font-size: 1.2rem; margin: 20px 0;}
.clinic-search .area-box__label.cl_toyohashi::after { content: 'TOYOHASHI'; display: block; font-size: 1.2rem; margin: 20px 0;}
.clinic-search .area-box__label.cl_gifu::after { content: 'GIFU'; display: block; font-size: 1.2rem; margin: 20px 0;}
.clinic-search .area-box__label.cl_yokkaichi::after { content: 'YOKKAICHI'; display: block; font-size: 1.2rem; margin: 20px 0;}
.clinic-search .area-box__label.cl_shizuoka::after { content: 'SHIZUOKA'; display: block; font-size: 1.2rem; margin: 20px 0;}
.clinic-search .area-box__label.cl_osaka::after { content: 'OSAKA'; display: block; font-size: 1.2rem; margin: 20px 0;}
.clinic-search .area-box__label.cl_himeji::after { content: 'HIMEJI'; display: block; font-size: 1.2rem; margin: 20px 0;}
.clinic-search .area-box__label.cl_okayama::after { content: 'OKAYAMA'; display: block; font-size: 1.2rem; margin: 20px 0;}
.clinic-search .area-box__label.cl_matsuyama::after { content: 'MATSUYAMA'; display: block; font-size: 1.2rem; margin: 20px 0;}
.clinic-search .area-box__label.cl_fukuoka::after { content: 'FUKUOKA'; display: block; font-size: 1.2rem; margin: 20px 0;}
.clinic-search .area-box__label.cl_nagasaki::after { content: 'NAGASAKI'; display: block; font-size: 1.2rem; margin: 20px 0;}

.cliniclist_info { display: flex; flex-direction: row-reverse; justify-content:space-between; }
.cliniclist_map { width: 45%; }
.cliniclist_map iframe { height: 200px; }
.cliniclist_txt { justify-content: flex-start; }
.cliniclist_txt p { margin-bottom: 15px;}
.cliniclist_btn { display: flex; flex-wrap: wrap; justify-content:space-between; margin-top: 15px; }
.cliniclist_btn .c-btn01 span { padding-left: 60px; }
.cliniclist_btn li a.c-btn01 { width: 330px; margin: 10px 0; }
.cliniclist_btn li a.c-btn01 span { justify-content: flex-start; }
.cliniclist_btn .c-btn01:after {
    content: "";
    width: 21px;
    height: 28px;
    position: absolute;
    top: 50%;
    left: 20px;
    transform: translateY(-50%);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: 100%;
    transition: .3s;
}
.cliniclist_btn .c-btn01.btn01:after { background-image: url(../images/common/ico-tel-bl.svg); }
.cliniclist_btn .c-btn01.btn02:after { background-image: url(../images/common/ico-home.svg); }
.cliniclist_btn .c-btn01.btn03:after { background-image: url(../images/common/ico-list.svg); }
.cliniclist_btn .c-btn01.btn04:after { background-image: url(../images/common/ico-instagram-bl.svg); }


@media only screen and (max-width: 767px) {
    .clinic-search__contents--area { margin-top: 30px; }
    .clinic-search__contents--cat { margin-top: 30px; }
    .clinic-search .area-block__label { font-size: clamp(1.3rem, 5.90909vw, 2.6rem); }
    .clinic-search .area-block__contents { padding-bottom: 60px; }
    .clinic-search .area-box__label { font-size: clamp(1.1rem, 5vw, 2.2rem); }

    .cliniclist_info { display: block; }
    .cliniclist_map { width: 100%; }
    .cliniclist_txt { margin-top: 15px; }
    .cliniclist_btn { display: block; margin-top: 25px; }
	.cliniclist_btn li a.c-btn01 { width: 100%; margin: 8px 0; }
}

.c-nav03 {
    gap: 20px 4%;
}
.c-nav03__item {
    cursor: pointer;
	width: 30.668%;
    height: 52px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    color: #828282;
    border: 1px solid #828282;
    font-weight: 500;
    border-radius: 13px;
}
.c-nav03__item.is-active, .c-nav03__item.current {
    background: #49c5b1;
    color: #fff;
    border-color: #49c5b1;
}

@media only screen and (max-width: 767px) {
    .c-nav03 {
        gap: 15px 5%;
    }
    .c-nav03__item {
        width: 47.5%;
        height: 52px;
    }
}




/* ========== 料金一覧 ========== */
.area-menu { display: flex; flex-wrap: wrap; padding: 10px 15px; margin-bottom: 30px; background-color: rgba(73, 197, 177, .1); }
.area-menu li { margin-right: 20px; }
.area-menu li a { text-decoration: underline; }

.feeTab3 { margin: 25px 10px;}
.feeList3 h3 { font-size: 3.2rem; font-weight: 500; letter-spacing: 0; padding: .2em 0; text-align: center; color: #49c5b1; }

.feeTab3 section { margin: 40px 0 0; }
.feeList3 .itemBox { margin: 0; padding: 16px 0; border-bottom: 0.9px solid #000;  }
section .feeList3 .itemBox:last-child { border-bottom: none;  }
.feeList3 .itemBox h4 { font-size: 1.8rem; letter-spacing: 0px; font-weight: 500; line-height: 32px; }
.feeList3 .itemBox .img img { float: right; width: 70px; height: auto; background: #fff; padding: 0 0 6px 6px; }

.feeList3 h5 { font-family: var(--fontMin); font-size: 20px; line-height: 24px; font-weight: normal; letter-spacing: -1px; margin: 16px 0 0; }
.feeList3 h5 img { width: 20px; height: auto; padding-right: 6px; }

.feeList3 p  { color: #292929;  font-size: 16px; line-height: 24px; margin: 16px 0 0; }
.feeList3 p.note  { font-family: var(--fontMin); font-size: 16px; line-height: normal; margin: 16px 0;}
.feeList3 p.note img  { float: left; width: 60px; height: auto; padding: 0 6px 0 0; }
.feeList3 p.h5note  { font-size: 12px; border-left: none; margin: 0; padding: 6px 0; }

.feeList3 ul { margin-top: 16px; }
.feeList3 ul li { margin-top: 16px; font-size: 9px; line-height: 1.3; }
.feeList3 ul li img { width: 308px; margin-bottom: 6px; }
.feeList3 ul.bnr:empty { display: none; }

.feeList3 table  { border: none; clear:both; width: 100%; margin: 0; }
.feeList3 table th,
.feeList3 table td { text-align: left; letter-spacing: 0; vertical-align: top; color: #292929; font-size: 18px; line-height: 24px; font-weight: 400; letter-spacing: -1px; padding: 10px 0; }
.feeList3 table td.idt span::after { content: '～'; font-size: 12px; margin-right: -1em; }
.feeList3 table td { white-space: nowrap; }
.feeList3 table td.alignR { font-size: 3.2rem; font-weight: 500; padding: 10px 0; text-align: right; color: #49c5b1; }
.feeList3 table td.alignR span { font-size: 1.2rem; font-weight: 400; color: initial; }

.feeList3 table.table { width: 350px; table-layout: fixed; border: 0.9px solid #D9D9D9; margin: 16px 0 40px; }
.feeList3 table.table th, .feeList3 table.table td { font-size: 15px; text-align: center; border-left: 0.9px solid #D9D9D9; margin: 0; padding: 8px 0; border-bottom: none; }
.feeList3 table.table th { background: #f4f4f4; border-bottom: 0.9px solid #D9D9D9; }
.feeList3 table.table td { white-space: nowrap; }



/* ========== 症例写真一覧 ========== */
.photo-search__contents--area { margin-top: 60px; }
.photo-search__contents--area .js-acTrigger span {
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 20px;
    height: 20px;
}
.photo-search__contents--area .js-acTrigger span:before, .photo-search__contents--area .js-acTrigger span:after {
    content: "";
    position: absolute;
    background: #49c5b1;
    transition: .3s;
}
.photo-search__contents--area .js-acTrigger span:before { width: 100%; height: 1px; left: 0; top: 50%; }
.photo-search__contents--area .js-acTrigger span:after { width: 1px; height: 100%; left: 50%; top: 0; }
.photo-search__contents--area .js-acTrigger.is-open span:after { opacity: 0; }

.photo-search__contents--cat { margin-top: 30px; }

.photo-search .area-block { border-top: 1px solid #49c5b1; }
.photo-search .area-block:last-child { border-bottom: 1px solid #49c5b1; }
.photo-search .area-block__label {
    font-size: 2.6rem;
    font-weight: 500;
    letter-spacing: .1em;
    padding: .8em 0;
    position: relative;
}
.photo-search .area-block__contents { border-top: 1px solid #49c5b1; padding-bottom: 80px; }

.photo-search .area-box { border-bottom: 1px solid #49c5b1; }
.photo-search .area-box__label {
    font-size: 2.2rem;
    font-weight: 500;
    letter-spacing: .1em;
    padding: .8em 0;
    position: relative;
}
.photo-search .area-box__contents { padding-bottom: 80px; }
.photo-search .area-box .btn-access { text-align: center; margin: 70px 0 0; }

.photo-search .cat-label p {
    border-top: 1px solid #49c5b1;
    font-size: 2.2rem;
    font-weight: 500;
    letter-spacing: .1em;
    padding: .8em 0;
    position: relative;
    margin: 60px 0;
}

@media only screen and (max-width: 767px) {
    .photo-search__contents--area { margin-top: 30px; }
    .photo-search__contents--cat { margin-top: 30px; }
    .photo-search .area-block__label { font-size: clamp(1.3rem, 5.90909vw, 2.6rem); }
    .photo-search .area-block__contents { padding-bottom: 60px; }
    .photo-search .area-box__label { font-size: clamp(1.1rem, 5vw, 2.2rem); }
    .photo-search .area-box__contents { padding-bottom: 60px; }
    .photo-search .area-box .btn-access { margin: 50px 0 0; }
    .photo-search .cat-label p { font-size: clamp(1.1rem, 5vw, 2.2rem); margin: 30px 0 0; }
}




/* ========== メンズトップ ========== */
.mens__top { color: #000; padding: 0; }
.mens__top .c--btn { padding: 10px 0 35px; }
.mens__top .c--btn a { margin: 25px 35px 0; display: block; }
.mens__top .marker { background: #49c5b1; }

.page-img__txt.mens__top { position: relative; padding: 0; }
.page-img__txt.mens__top h1 { position: absolute; top: 15px; text-align: center; width: 100%; color: #fff; font-weight: 700; font-size: 20px; }
.page-img__txt.mens__top h1::after { content: '――'; display: block; text-align: center; font-size: 20px; font-weight: 400; letter-spacing: -2px; transform: rotate(90deg); padding-left: 40px; }
.page-img__txt.mens__top .box { position: relative; background: url(/ct/mens/img/top/bg_main_image.webp) no-repeat; background-size: 100% auto; padding: 50px 30px 30px; font-size: 13px; font-weight: 700; color: #fff; line-height: 1.6; letter-spacing: 0.1px; }
.page-img__txt.mens__top .box::before { position: absolute; top: -10px; left: 0; content: ""; display: inline-block; width: 100%; height: 50px; background-image: url(/ct/mens/img/top/mens_shiromoto.webp); background-repeat: no-repeat; background-position: top; background-size: contain; }
.page-img__txt.mens__top .box strong { display: inline-block; font-size: 26px; line-height: 1.3; font-weight: 900; color: #49c5b1; padding: 10px 0; }
.page-img__txt.mens__top .box .c--btn { overflow: hidden; padding: 10px 0 0; }
.page-img__txt.mens__top .box .c--btn a { margin: 20px 10px 0; display: block; }

.mens--shortcut { background: #000; border-top: 8px solid #49c5b1;}
.mens--shortcut ul { display:flex; flex-wrap: wrap; }
.mens--shortcut li { background: url(/ct/mens/img/top/shortcut_bg.webp) no-repeat; background-size: 100% auto; display: -moz-flex;display: -ms-flex;display: -o-flex; display: flex; min-height: 67px; flex-grow: 1; flex-basis: 50%; justify-content: center;align-items: center;text-align: center;position: relative; }
.mens--shortcut li a { display: flex; box-sizing: border-box; justify-content: center; align-items: center; width: 100%; height: 100%; color: #fff; font-size: 13px; line-height: 1.2; padding: 0 0 15px; }
.mens--shortcut li::after { font-size: 15px; line-height: 1; font-weight: 100; content: '＞'; display: block; position: absolute; left: 46%; bottom: 0; color: #49c5b1; transform: scale(2, 1) rotate(90deg) translate(-50%); }
.mens--shortcut li:last-child { margin-right: 50%; }

.mens--check { counter-reset: number 0; font-size: 13px; color: #fff; background: #000; padding: 35px 35px 10px; }
.mens--check h2 { position: relative; font-size: 20px; text-align: center; color: #fff; font-weight: 700; margin: 0 0 30px; padding-top: 60px; }
.mens--check h2::before { content: 'CHECK'; color: #49c5b1; font-size: 16px; letter-spacing: 0; font-weight: 900; position: absolute; left: 50%; top: 0; transform: translateX(-50%); padding: 0 10px 10px; border-bottom: 0.9px solid #fff; white-space: nowrap; }
.mens--check figure { margin: 30px -35px; }
.mens--check p { font-size: 18px; line-height: 1.5; letter-spacing: -1px; font-weight: 700; text-align: center; }
.mens--check span { background: linear-gradient(90deg, #3c998a, #2f6d63); display: inline-block; margin: 5px; padding: 0 8px; }
.mens--check .hyphen { padding-top: 40px; }
.mens--check .hyphen::before { content: '――'; display: block; text-align: center; font-size: 20px; font-weight: 400; letter-spacing: -2px; transform: rotate(90deg); padding-right: 40px; }
.mens--check ul { margin: 0 5px; background: url(/ct/mens/img/top/frame_white.webp) no-repeat; background-size: 100% 100%; padding: 30px 0 10px 20px; }
.mens--check ul li { font-size: 15px; letter-spacing: 0; font-weight: 700; padding: 0 0 24px 35px; background: url(/ct/mens/img/top/ico_check.webp) no-repeat; background-size: 25px auto; }

.mens--reasons { counter-reset: number 0; font-size: 13px; background: #f9f9f9; padding: 35px 35px 30px; }
.mens--reasons h2 { position: relative; font-size: 20px; text-align: center; color: #000; font-weight: 700; margin: 0 0 30px; padding-top: 60px; }
.mens--reasons h2::before { content: 'AGING'; color: #49c5b1; font-size: 16px; letter-spacing: 0; font-weight: 900; position: absolute; left: 50%; top: 0; transform: translateX(-50%); padding: 0 10px 10px; border-bottom: 0.9px solid #000; white-space: nowrap; }
.mens--reasons figure { margin: 30px 0; }
.mens--reasons p { line-height: 2; margin: 10px 0; }
.mens--reasons .hyphen { padding-bottom: 40px; }
.mens--reasons .hyphen::after { content: '――'; display: block; text-align: center; font-size: 20px; font-weight: 400; letter-spacing: -2px; transform: rotate(90deg); padding-left: 40px; }
.mens--reasons dl { position: relative; background: #2d2d2d; font-size: 13px; line-height: 1.4; letter-spacing: 0; padding: 15px 5px; margin: 10px 5px; }
.mens--reasons dl::after { content: ""; position: absolute; height: 100%; width: 100%; clip-path: polygon(0% 100%, 100% 0%, 0% 0%); background-color: #000; left: 0; top: 0; z-index: 0; }
.mens--reasons dt { position: relative; height: 55px; border-right: 2px solid #fff; font-size: 24px; font-weight: 900; color: #49c5b1; display: table-cell; width: 70px; vertical-align: middle; text-align: center; z-index: 1; }
.mens--reasons dd { position: relative; height: 55px; color: #fff; padding: 0 0 0  10px; vertical-align: middle; display: table-cell; z-index: 1; }
.mens--reasons div { height: 70px; background: url(/ct/mens/img/top/reasons_bg.webp) no-repeat; background-size: contain; text-align: center; color: #fff; font-size: 16px; letter-spacing: 0; font-weight: 700; line-height: 60px; margin: 45px -35px 25px; }
.mens--reasons div span { color: #49c5b1; }
.mens--reasons ul { margin: 0 5px; background: url(/ct/mens/img/top/frame_black.webp) no-repeat; background-size: 100% 100%; padding: 30px 0 30px 20px; }
.mens--reasons ul li { font-size: 15px; letter-spacing: 0; font-weight: 700; padding: 0 0 24px 35px; background: url(/ct/mens/img/top/ico_check.webp) no-repeat; background-size: 25px auto; }
.mens--reasons p:last-child { font-size: 18px; line-height: 1.6; letter-spacing: -1px; font-weight: 700; }

.mens--solution { position: relative; letter-spacing: 0; background: #49c5b1; text-align: center; color: #fff; padding: 100px 0 10px; }
.mens--solution::before { position: absolute; content: 'SOLUTION'; color: #fff; font-size: 20px; font-weight: 900; padding: 0 25px 10px; border-bottom: 0.1px solid #fff; top: 30px; left: 50%; transform: translateX(-50%); }
.mens--solution div { font-size: 22px; font-weight: 700; }
.mens--solution div.small { font-size: 16px; line-height: 1.8; font-weight: 700; }
.mens--solution figure { margin: 30px 0; }
.mens--solution figure:last-child { margin: 30px 35px; }
.mens--solution .equal::after { content: '＝'; display: block; font-size: 20px; font-weight: 400; transform: rotate(90deg); }
.mens--solution .hyphen { padding-bottom: 40px; }
.mens--solution .hyphen::after { content: '――'; display: block; font-size: 20px; font-weight: 400; transform: rotate(90deg); padding-left: 40px; }

.mens--menu--index { background: #000; }
.mens--menu--index ul { position: relative; padding: 130px 0 0 0; display: grid; gap: 0; grid-template-columns: 1fr 1fr; }
.mens--menu--index ul::before { position: absolute; content: 'MENU'; color: #49c5b1; font-size: 20px; font-weight: 900; padding: 0 25px 10px; border-bottom: 0.1px solid #fff; top: 50px; left: 50%; transform: translateX(-50%); }
.mens--menu--index ul li { background: url(/ct/mens/img/top/menu_bg.webp) no-repeat; background-size: cover; }
.mens--menu--index li a { position: relative; font-size: 12px; font-weight: 700; line-height: 1.3; display: block; color: #fff; padding: 15px 10px; }
.mens--menu--index li a img { float: left; width: auto; height: 40px; margin-right: 10px; display: table-cell; vertical-align: middle; }
.mens--menu--index li a span { display: table-cell; height: 40px; vertical-align: middle; }
.mens--menu--index li a::after { font-size: 15px; line-height: 1; font-weight: 100; content: '＞'; display: block; position: absolute; left: 85%; top: 50%; color: #49c5b1; transform: scale(2, 1) rotate(90deg) translate(-50%); }

.mens--menu .sec { font-size: 13px; line-height: 1.6; padding: 35px 35px 10px; }
.mens--menu .sec:nth-child(odd) { background: #f9f9f9; }
.mens--menu .sec:nth-child(even) { color: #fff; background: #000; }
.mens--menu h3 { position: relative; font-size: 20px; letter-spacing: 0; text-align: center; color: #000; font-weight: 700; margin: 0 0 30px; padding-top: 60px; }
.mens--menu h3::before { content: ''; color: #49c5b1; font-size: 16px; letter-spacing: 0; font-weight: 900; position: absolute; left: 50%; top: 0; transform: translateX(-50%); padding: 0 10px 10px; border-bottom: 0.9px solid #000; white-space: nowrap; }
.mens--menu .sec:nth-child(even) h3 { color: #fff; }
.mens--menu .sec:nth-child(even) h3:before { border-bottom: 0.9px solid #fff; }
.mens--menu .sec:nth-child(1) h3::before { content: 'HAIR REMOVAL'; }
.mens--menu .sec:nth-child(2) h3::before { content: 'PIGMENTS'; }
.mens--menu .sec:nth-child(3) h3::before { content: 'WRINKLES'; }
.mens--menu .sec:nth-child(4) h3::before { content: 'EYES'; }
.mens--menu .sec:nth-child(5) h3::before { content: 'ROUGH SKIN'; }
.mens--menu .sec:nth-child(6) h3::before { content: 'FACE LINE'; }
.mens--menu .sec:nth-child(7) h3::before { content: 'EYELID'; }
.mens--menu .sec:nth-child(8) h3::before { content: 'HAIR'; }
.mens--menu .sec:nth-child(9) h3::before { content: 'SWEAT'; }
.mens--menu .sec:nth-child(10) h3::before { content: 'MENS'; }
.mens--menu .sec figure { margin: 0 0 30px; }
.mens--menu .sec .c--btn { margin: -30px 0 0; }
.mens--menu .sec .c--btn a { margin: 30px 0 0; display: block; }
.mens--menu .pickup--photo { background: #fff; margin: 30px 0; padding: 20px; color: #000; }
.mens--menu .pickup--photo::before { content: 'PICK UP症例'; font-size: 22px; font-weight: 900; display: block; text-align: center; }
.mens--menu .pickup--photo p { margin: 15px 0;  }
.mens--menu .pickup--photo dl { font-size: 10px; line-height: 1.35; letter-spacing: -1.1px; }
.mens--menu .pickup--photo dt { font-weight: 700; padding-top: 5px; }

.mens--menu .menu--price { text-align: center; }
.mens--menu .menu--price h4 { font-weight: 900; display: inline-block; margin: 15px 0; padding: 0 10px; border-left: 2px solid #49c5b1; border-right: 2px solid #49c5b1; }
.mens--menu .menu--price h4 + div { margin: 0 0 15px; letter-spacing: 0; }
.mens--menu .menu--price table  { width: 100%; background: #fff; border-right: 0.9px solid #000; border-top: 0.9px solid #000; margin-bottom: 30px; }
.mens--menu .menu--price th, .mens--menu .menu--price td { font-size: 12px; color: #000; vertical-align: middle; padding: 5px 10px; border-left: 0.9px solid #000; border-bottom: 0.9px solid #000; }
.mens--menu .menu--price thead th { color: #fff; background: #49c5b1; }
.mens--menu .menu--price tbody { text-align: left; }
.mens--menu .menu--price tbody td:first-child { width: 99%; }
.mens--menu .menu--price tbody td:last-child { position: relative; font-size: 24px; letter-spacing: -0.5px; font-weight: 900; color: #49c5b1; text-align: right; white-space: nowrap; }
.mens--menu .menu--price tbody td:last-child span { color: #000; font-size: 11px; font-weight: normal; padding-right: 5px; }
.mens--menu .menu--price table + div { text-align: right; color: #49c5b1; margin: -20px 0 20px; }
.mens--menu .menu--price table + div a, .mens--menu .menu--price table + div a:visited { color: #49c5b1; }

.mens--reason { counter-reset: number 0; font-size: 13px; background: #49c5b1; padding: 35px 35px 10px; }
.mens--reason h2 { position: relative; font-size: 20px; text-align: center; color: #fff; font-weight: 700; margin: 0 0 30px; padding-top: 60px; }
.mens--reason h2::before { content: 'SELECTION'; color: #fff; font-size: 16px; letter-spacing: 0; font-weight: 900; position: absolute; left: 50%; top: 0; transform: translateX(-50%); padding: 0 10px 10px; border-bottom: 0.9px solid #fff; white-space: nowrap; }
.mens--reason p { margin: 10px 0; }
.mens--reason .reason--box { background: #fff; padding: 15px; margin: 30px 0; }
.mens--reason .reason--box:nth-child(even) h3 { position: relative; min-height: 80px; font-size: 17px; font-weight: 600; letter-spacing: -1px; padding: 20px 0 0 80px; }
.mens--reason .reason--box:nth-child(even) h3::before { font-family: var(--fontMin); font-style: italic; position: absolute; top: -3px; left: 0; font-size: 60px; font-weight: 500; counter-increment: number 1; content: counter(number, decimal-leading-zero); color: #49c5b1; }
.mens--reason .reason--box:nth-child(odd) h3 { position: relative; min-height: 80px; font-size: 17px; font-weight: 600; text-align: right; letter-spacing: -1px; padding: 20px 75px 0 0; }
.mens--reason .reason--box:nth-child(odd) h3::after { font-family: var(--fontMin); font-style: italic; position: absolute; top: -3px; right: 0; font-size: 60px; font-weight: 500; counter-increment: number 1; content: counter(number, decimal-leading-zero); color: #49c5b1; }
.mens--reason .reason--box h3:first-line { padding: 0; }
.mens--reason .reason--box:last-child h3::last-child { padding-right: 0; }
.mens--reason .reason--box h3 + div { letter-spacing: -1px; }
.mens--reason .reason--box h3 + div::before { content: 'ー'; }
.mens--reason .reason--box:nth-child(odd) h3 + div { text-align: right; }
.mens--reason .reason--box figure { margin: 20px 0;  }

.mens--flow { counter-reset: number 0; font-size: 13px; background: #f9f9f9; padding: 35px; }
.mens--flow h2 { position: relative; font-size: 20px; text-align: center; color: #000; font-weight: 700; margin: 0 0 30px; padding-top: 60px; }
.mens--flow h2::before { content: 'HOW TO'; color: #49c5b1; font-size: 16px; letter-spacing: 0; font-weight: 900; position: absolute; left: 50%; top: 0; transform: translateX(-50%); padding: 0 10px 10px; border-bottom: 0.9px solid #000; white-space: nowrap; }
.mens--flow p { margin: 10px 0; }
.mens--flow .flow--box { background: #fff; padding: 15px; margin: 30px 0; }
.mens--flow .flow--box:nth-child(even) h3 { position: relative; font-size: 17px; font-weight: 600; line-height: 60px; letter-spacing: -1px; text-indent: 75px; }
.mens--flow .flow--box:nth-child(even) h3::before { font-family: var(--fontMin); font-style: italic; position: absolute; top: -3px; left: -75px; font-size: 60px; font-weight: 500; counter-increment: number 1; content: counter(number, decimal-leading-zero); color: #49c5b1; }
.mens--flow .flow--box:nth-child(odd) h3 { position: relative; font-size: 17px; font-weight: 600; line-height: 60px; letter-spacing: -1px; text-align: right; padding-right: 75px; }
.mens--flow .flow--box:nth-child(odd) h3::after { font-family: var(--fontMin); font-style: italic; position: absolute; top: -3px; right: 0; font-size: 60px; font-weight: 500; counter-increment: number 1; content: counter(number, decimal-leading-zero); color: #49c5b1; }
.mens--flow .flow--box figure { margin: 20px 0;  }
.mens--flow table  { text-align: left; width: 100%; background: #fff; border-right: 0.9px solid #000; border-top: 0.9px solid #000; margin-bottom: 30px; }
.mens--flow th { width: 45%; background: #49c5b1; font-size: 12px; color: #fff; vertical-align: middle; padding: 5px 10px; border-left: 0.9px solid #000; border-bottom: 0.9px solid #000; }
.mens--flow td { font-size: 12px; color: #000; vertical-align: middle; padding: 5px 10px; border-left: 0.9px solid #000; border-bottom: 0.9px solid #000; }
.mens--flow .c--btn { padding: 10px 0 15px; }
.mens--flow .c--btn a { margin: 15px 5px 0; display: block; }

.mens--faq { font-size: 13px; background: #f9f9f9; padding: 35px 35px 10px; }
.mens--faq h2 { position: relative; font-size: 20px; text-align: center; color: #000; font-weight: 700; margin: 0 0 30px; padding-top: 60px; }
.mens--faq h2::before { content: 'Q & A'; color: #49c5b1; font-size: 16px; letter-spacing: 0; font-weight: 900; position: absolute; left: 50%; top: 0; transform: translateX(-50%); padding: 0 10px 10px; border-bottom: 0.9px solid #000; white-space: nowrap; }
.mens--faq dl { background: #fff; margin: 15px 0; padding: 10px; }
.mens--faq dt { position: relative; padding: 10px 20px 10px 35px; }
.mens--faq dt::before { position: absolute; left: 0; top: 2px; line-height: 30px; font-size: 24px; font-weight: 900; content: 'Q.'; color: #49c5b1; }
.mens--faq dd { position: relative; border-top: 0.9px solid #ccc; padding: 15px 20px 0 35px;}
.mens--faq dd::before { position: absolute; left: 0; top: 7px; line-height: 30px; font-size: 24px; font-weight: 900; content: 'A.'; color: #49c5b1; }
.mens--faq dt::after { font-size: 15px; line-height: 1; font-weight: 100; content: '＞'; display: block; position: absolute; left: 95%; top: 50%; color: #49c5b1; transform: scale(2, 1) rotate(90deg) translate(-50%); }


@media only screen and (min-width: 767px) {
    h2 { font-size: 30px !important; }
	.page-img__txt.mens__top { margin-top: 60px; }
	.mens__top * {}
	.mens__top { color: #000; padding: 0; width: 720px; }
    .mens__top .c--btn { padding: 30px 0 35px; }
    .mens__top .c--btn a { margin: 25px 80px 0; display: block; }

	.page-img__txt.mens__top h1 { font-size: 36px !important; }
    .page-img__txt.mens__top .box { padding: 80px 30px 80px; font-size: 150%; font-weight: 700; color: #fff; line-height: 1.6; letter-spacing: 0.1px; }
	.page-img__txt.mens__top .box strong { font-size: 42px !important; }
    .page-img__txt.mens__top .box .c--btn { overflow: hidden; padding: 30px 0 0; }
    .page-img__txt.mens__top .box .c--btn a { margin: 40px 80px 0; display: block; }

	.mens--shortcut { font-size: 130% !important; }
	.mens--shortcut li { min-height: 85px; flex-basis: 33.3%; }
	.mens--shortcut li a { font-size: 18px;}
	.mens--shortcut li:last-child { margin-right: calc(200% / 3); }
	
    .mens--check { padding: 35px 35px 10px; }
	.mens--check h2 { font-size: 20px;}
	.mens--check ul { padding: 50px 0 30px 50px; }
	.mens--check ul li { font-size: 25px; }
    .mens--check p { font-size: 26px; }
    .mens--check span { margin: 5px 20px; }

	.mens--reasons { font-size: 22px; }
	.mens--reasons dl { position: relative; background: #2d2d2d; font-size: 18px; line-height: 1.4; letter-spacing: 0; padding: 15px 5px; margin: 10px 5px; }
	.mens--reasons dt { font-size: 32px;width: 120px;  }
	.mens--reasons div { height: 120px; font-size: 28px; line-height: 120px; }
	.mens--reasons ul { padding: 50px 0 30px 50px; }
	.mens--reasons ul li { font-size: 25px; }
	.mens--reasons p:last-child { font-size: 26px; }

	.mens--solution div { font-size: 28px; }
	.mens--solution div.small { font-size: 20px;}
	.mens--solution .equal::after { font-size: 28px; }
	.mens--solution .hyphen::after { font-size: 28px; }

	.mens--menu--index li a { font-size: 20px; padding: 15px 30px; }
	.mens--menu--index li a img { height: 80px;  }
	.mens--menu--index li a span { height: 80px;  }
	
	.mens--menu .sec { font-size: 20px; }
	.mens--menu h3 { font-size: 30px;  }
	.mens--menu h3::before { font-size: 20px;  }
	.mens--menu .sec .c--btn { margin: -30px 0 0; }
	.mens--menu .sec .c--btn a { margin: 30px 80px 0; }
	.mens--menu .pickup--photo::before { font-size: 26px; }
    .mens--menu .pickup--photo dl { font-size: 16px; }
	
	.mens--menu .menu--price th, .mens--menu .menu--price td { font-size: 24px; padding: 5px 20px; }
	.mens--menu .menu--price tbody td:last-child { font-size: 36px; }
	.mens--menu .menu--price tbody td:last-child span { font-size: 14px; }

	.mens--reason .reason--box { font-size: 20px; background: #fff; padding: 15px; margin: 30px 0; }
	.mens--reason .reason--box:nth-child(even) h3 { font-size: 30px;  }
	.mens--reason .reason--box:nth-child(odd) h3 { font-size: 30px;  }
	.mens--reason .reason--box h3 + div::before { content: 'ー'; }
	.mens--reason .reason--box:nth-child(odd) div { text-align: right;  }

	.mens--flow { font-size: 20px;  }
	.mens--flow h2::before { font-size: 20px; }
	.mens--flow .flow--box { background: #fff; padding: 15px; margin: 30px 0; }
	.mens--flow .flow--box:nth-child(even) h3 { font-size: 30px; }
	.mens--flow .flow--box:nth-child(odd) h3 { font-size: 30px; }
	.mens--flow .flow--box .c--btn a:last-child { display: none; }
	.mens--flow th { font-size: 20px; }
	.mens--flow td { font-size: 18px; }

	.mens--faq { font-size: 20px; background: #f9f9f9; padding: 35px 35px 10px; }
	.mens--faq h2::before { font-size: 20px; }
	.mens--faq dl { padding: 10px 20px; }
	.mens--faq dt { padding: 10px 55px 10px 35px; }
	.mens--faq dt::before { top: 9px; font-size: 24px; }
	.mens--faq dd { padding: 15px 55px 0 35px;}
	.mens--faq dd::before { top: 15px; font-size: 24px; }
	.mens--faq dt::after { left: 97%; }
}
