@charset "UTF-8";

/* ------------------------------------
  キレイライン矯正
  Date: 2021-03-08
------------------------------------ */


/* ------------------------------------
  Reset
------------------------------------ */

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
.footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    vertical-align: baseline;
}

article,
aside,
details,
figcaption,
figure,
.footer,
header,
hgroup,
menu,
nav,
section {
    display: block;
}

blockquote,
q {
    quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
    content: "";
    content: none;
}

input,
textarea {
    margin: 0;
    padding: 0;
}

ol,
ul {
    list-style: none;
}

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

h1,
h2,
h3,
h4 {
    font-weight: 500;
}


/* ------------------------------------
  Base
------------------------------------ */

html {
    font-size: 62.5%;
}

html.wf-active body {
    font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "ヒラギノ角ゴ W3", "メイリオ", "ＭＳ Ｐゴシック", sans-serif;
}

body {
    font-size: 1.4rem;
    line-height: 1;
    font-family: "ヒラギノ角ゴ Pro W3", "ヒラギノ角ゴ W3", "メイリオ", "ＭＳ Ｐゴシック", sans-serif;
    font-weight: 400;
    -webkit-text-size-adjust: none;
    color: #444;
    background: #fff;
}

img {
    border: 0;
    vertical-align: bottom;
    max-width: 100%;
    height: auto;
}

a {
    color: #444;
    text-decoration: none;
}

a:hover {
    color: #444;
    -webkit-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
}

a:visited {
    color: #444;
}

a:active,
a:focus {
    outline: none;
}

* {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.wrapper {
    overflow: hidden;
    width: 100%;
    margin: 0 auto;
    background: #f5f5f5;
}

.wrapper::after {
    z-index: 1000;
    /*content: "";*/
    display: block;
    width: 100%;
    height: 100vh;
    background: #f5f5f5;
    position: fixed;
    top: 0;
    left: 0;
    -webkit-animation-name: fadeOut;
    animation-name: fadeOut;
    -webkit-animation-duration: 2s;
    animation-duration: 2s;
    -webkit-animation-timing-function: ease;
    animation-timing-function: ease;
    -webkit-animation-delay: 1s;
    animation-delay: 1s;
    -webkit-animation-iteration-count: 1;
    animation-iteration-count: 1;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;
    -webkit-transition: all 0.6s ease 0;
    transition: all 0.6s ease 0;
}

.content {
    max-width: 640px;
    margin: 0 auto;
    background: #fff;
    overflow: hidden;
}

.taC {
    text-align: center;
}

.taR {
    text-align: right;
}

.sp-on {
    display: none;
}


/* ------------------------------------
  text
  background
------------------------------------ */

.txt_blue {
    color: #00a9e0;
}

.txt_size_01 {
    font-size: 120%;
}

.txt_maker {
    background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, #ffff00));
    background: linear-gradient(transparent 60%, #ffff00 60%);
    padding: 0 0.2rem;
}

.bg_stripe_01 {
    background: url(../img/bg_stripe_01.webp) center center/40px auto repeat;
}

.bg_stripe_02 {
    background: url(../img/bg_stripe_02.webp) center center/40px auto repeat;
}


/* ------------------------------------
  effect
------------------------------------ */

[data-scroll] {
    opacity: 0;
    -webkit-transition: all 0.4s ease 0s;
    transition: all 0.4s ease 0s;
}

[data-scroll].show[data-scroll] {
    opacity: 1;
}


/* ------------------------------------
  Slick Slider
------------------------------------ */

.slick-arr {
    position: absolute;
    top: 45%;
    width: 30px;
    height: 30px;
    line-height: 30px;
    z-index: 2;
    cursor: pointer;
    font-size: 1.4rem;
    text-align: center;
    background: rgba(170, 170, 170, 0.85);
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}

.slick-arr::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 25%;
    height: 25%;
    border-right: 2px solid #ffffff;
    border-bottom: 2px solid #ffffff;
}

.slick-arr.next {
    right: 3%;
}

.slick-arr.next::after {
    -webkit-transform: translate(-60%, -50%) rotate(-45deg);
    transform: translate(-60%, -50%) rotate(-45deg);
}

.slick-arr.prev {
    left: 0;
}

.slick-arr.prev::after {
    -webkit-transform: translate(-30%, -50%) rotate(135deg);
    transform: translate(-30%, -50%) rotate(135deg);
}

.js-slider-clinic {
    overflow: hidden;
    width: 110%;
    margin: 9.33333vw -8% 9.33333vw -2%;
}

.js-slider-clinic .slick-list {
    overflow: visible;
    padding-right: 8%;
    padding-left: 2%;
    z-index: 1;
}

.js-slider-clinic .slick-slide {
    margin-right: 3.33333vw;
}

.js-slider-clinic .slick-slide img {
    display: block;
    width: 100%;
}


/* ------------------------------------
  pagetop
------------------------------------ */

.pagetop_btn {
    cursor: pointer;
    position: fixed;
    bottom: 30px;
    right: 5px;
    z-index: 200;
    background: rgba(0, 169, 224, 0.75);
    width: 30px;
    height: 30px;
}

.pagetop_btn::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 30%;
    height: 30%;
    border-right: 1px solid #ffffff;
    border-bottom: 1px solid #ffffff;
    -webkit-transform: translate(-50%, -25%) rotate(-135deg);
    transform: translate(-50%, -25%) rotate(-135deg);
}

.pagetop_btn.on-footer {
    position: absolute;
    bottom: 100% !important;
}


/* ------------------------------------
  Fotoer
------------------------------------ */

.footer {
    position: relative;
    background-color: #00a9e0;
    padding: 1px 0;
    padding-bottom: 60px;
}

.footer_inner {
    padding: 5.33333vw 10px;
}

.footer_logo {
    display: block;
    text-align: center;
    margin: 0 0 4.6875vw;
}

.footer_copyright {
    display: block;
    color: #fff;
    margin: 0 0 3.125vw;
    font-size: 2.66667vw;
    text-align: center;
    line-height: 1.5;
}

.footer_nav {
    text-align: center;
}

.footer_nav li {
    display: inline-block;
    font-size: 2.4vw;
}

.footer_nav li::after {
    content: "　|　";
    color: #6dcdff;
}

.footer_nav li:last-child::after {
    display: none;
}

.footer_nav a {
    color: #fff;
    -webkit-transition: all 0.6s ease;
    transition: all 0.6s ease;
}


/* ------------------------------------
  Section：common
------------------------------------ */

.sec {
    position: relative;
    z-index: 20;
    background-color: #ffffff;
}

.sec_inner {
    margin: 0 auto;
    width: 88%;
    max-width: 650px;
}

.sec_head {
    position: relative;
    background: url(../img/bg_stripe_01.webp) center center/40px auto repeat;
    margin-bottom: 4.66667vw;
}

.sec_head::before,
.sec_head::after {
    content: "";
    width: 97.4%;
    height: 1px;
    position: absolute;
    background: #00a9e0;
}

.sec_head::before {
    top: 1.33333vw;
    left: 2.6%;
}

.sec_head::after {
    bottom: 1.33333vw;
    right: 2.6%;
}

.sec_head.blue {
    background-image: url(../img/bg_stripe_02.webp);
}

.sec_head.blue::before,
.sec_head.blue::after {
    background: #88dbf2;
}

.sec_head .head_tit {
    z-index: 2;
    position: relative;
}

.sec_head .head_pic {
    z-index: 1;
    position: absolute;
}

.sec_tit_stripe {
    background: url(../img/bg_stripe_01.webp) center center/40px auto repeat;
}

.sec_tit_fuki {
    background: #00a9e0;
    border-radius: 10px;
    position: relative;
    margin-bottom: 2.66667vw;
}

.sec_tit_fuki::after {
    content: "";
    position: absolute;
    bottom: -2.66667vw;
    left: 50%;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 2.66667vw 3.6vw 0 3.6vw;
    border-color: #00a9e0 transparent transparent transparent;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}

.sec_tit_fuki.white {
    background: #ffffff;
    border: 1px solid #00a9e0;
    text-align: center;
    margin-bottom: 5.33333vw;
}

.sec_tit_fuki.white::after {
    z-index: 1;
}

.sec_tit_fuki.white::before {
    content: "";
    position: absolute;
    bottom: calc(-2.66667vw + 1px);
    left: 50%;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 2.66667vw 3.6vw 0 3.6vw;
    border-color: #ffffff transparent transparent transparent;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    z-index: 2;
}

.sec p {
    font-size: 3.33333vw;
    line-height: 1.6;
    letter-spacing: -0.02em;
    line-break: strict;
    word-wrap: break-word;
    overflow-wrap: break-word;
    hanging-punctuation: allow-end;
}

.sec .txt_wrap p {
    margin: 5.33333vw 0;
}

.sec .txt_wrap p small.att {
    font-size: 75%;
    display: block;
    line-height: 1.5;
}

.att2 {
    font-size: 75% !important;
    line-height: 1.1 !important;
    text-align: left;
}

.sec .txt_wrap p b {
    /* font-weight: bold; */
}

.sec .img_round img {
    border-radius: 10px;
}

.sec .sorry_wrap {
    margin: 6.66667vw auto 8vw;
}

.sec .sorry_wrap .box {
    padding: 3.33333vw 4% 3.33333vw 22%;
    margin-bottom: 4vw;
    position: relative;
    background: #f8f8f8;
}

.sec .sorry_wrap .box_tit {
    text-align: center;
    padding-right: 22%;
}

.sec .sorry_wrap .box_img {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 22%;
}

.sec .sorry_wrap .box p {
    font-size: clamp(10px, 3.2vw, 20px);
    line-height: 1.7;
}

.sec .sorry_wrap li {
    font-size: clamp(9px, 2.66667vw, 14px);
    line-height: 1.7;
    line-break: strict;
    word-wrap: break-word;
    overflow-wrap: break-word;
    hanging-punctuation: allow-end;
}

.sec .sorry_wrap li::before {
    content: "・";
}

.sec .sorry_wrap li a {
    color: #00a9e0;
    text-decoration: underline;
}

.sec .check_list li {
    padding-left: 5.33333vw;
    background: url(../img/icon_chk_02.webp) left 1vw/14px auto no-repeat;
    font-size: clamp(9px, 3.46667vw, 22px);
    line-height: 1.5;
    margin: 2.66667vw 0;
    font-weight: 500;
}

.sec .box {
    position: relative;
}

.sec .box.box_round {
    border-radius: 10px;
}

.sec .box.box_blue_line {
    border: 1px solid #00a9e0;
}

.sec .box_img_tp,
.sec .box_img_tp img {
    border-radius: 10px 10px 0 0;
}

.sec .box_img_btm,
.sec .box_img_btm img {
    border-radius: 0 0 10px 10px;
}

.sec .box_inner {
    max-width: 550px;
    width: 84.8%;
    margin: 0 auto;
}

.sec .box.faq {
    margin-bottom: 4.66667vw;
}

.sec .box.faq .box_tit {
    position: relative;
    height: 16vw;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    font-size: 3.53333vw;
    line-height: 1.5;
    letter-spacing: -0.02em;
    color: #00a9e0;
    font-weight: 500;
    padding: 0 8.66667vw 0 10vw;
    line-break: strict;
    word-wrap: break-word;
    overflow-wrap: break-word;
    hanging-punctuation: allow-end;
}

.sec .box.faq .box_tit.lg {
    height: 21.33333vw;
}

.sec .box.faq .box_tit:not(.active) {
    border-radius: 10px;
}

.sec .box.faq .box_tit::before {
    content: "Q";
    font-size: 145%;
    font-weight: 700;
    line-height: 1;
    position: absolute;
    top: 50%;
    left: 4vw;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}

.sec .box.faq .box_tit::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 4vw;
    width: 2vw;
    height: 2vw;
    border-right: 1px solid #00a9e0;
    border-bottom: 1px solid #00a9e0;
    -webkit-transform: translateY(-50%) rotate(45deg);
    transform: translateY(-50%) rotate(45deg);
}


/* ------------------------------------
  section：movie
------------------------------------ */

.sec_movie {
    position: relative;
    background-color: #66ccff;
}

.sec_movie .sec_inner {
    /*padding: 11.33333vw 0 0;*/
    padding: 0 0 3.33333vw 0;
    width: 100%;
}

.sec_movie .sec_inner .inner {
    width: 80%;
    margin: auto;
}

.sec_movie .img01,
.sec_movie .img02 {
    margin: 1em 0;
}

.sec_movie .movie_cnt {
    position: relative;
}

.sec_movie .movie_cnt .movie {
    z-index: 1;
    position: relative;
    overflow: hidden;
    /*border: 1px solid #5fd6ff;*/
    padding-top: 56.25%;
    height: 0;
    width: 100%;
    background: url(../img/movie_thumb.webp) center center/cover no-repeat;
}

.sec_movie .movie_cnt .movie video {
    position: absolute;
    top: 50%;
    left: 50%;
    height: 100%;
    width: auto;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}


/* ------------------------------------
  section CTA まずは一度
------------------------------------ */

.cv_wrap {
    position: relative;
}

.cv_wrap .anim {
    -webkit-animation-iteration-count: infinite;
    animation-iteration-count: infinite;
    -webkit-animation-name: pulse;
    animation-name: pulse;
    -webkit-animation-duration: 1.5s;
    animation-duration: 1.5s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
}

.cv_wrap .cv_po {
    position: absolute;
    top: -6vw;
    width: 17.8%;
    z-index: 2;
}

.cv_wrap .cv_po.po_01 {
    left: -3.33333vw;
}

.cv_wrap .cv_po.po_02 {
    right: -3.33333vw;
}

.cv_wrap .cv_btn {
    position: relative;
    z-index: 1;
}

.cv_wrap .cv_btn a {
    display: block;
    background-color: #0081ab;
    border-radius: 10px;
    position: relative;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    border: 1px solid #0081ab;
}

.cv_wrap .cv_btn a::before {
    content: "";
    position: absolute;
    z-index: 1;
    width: calc(100% + 2px);
    height: 100%;
    top: -4px;
    left: -1px;
    background: #00a9e0;
    border-radius: 10px;
}

.cv_wrap .cv_btn a::after {
    z-index: 2;
    content: "";
    position: absolute;
    top: 50%;
    right: 4vw;
    width: 2.66667vw;
    height: 2.66667vw;
    border-right: 1px solid #ffffff;
    border-bottom: 1px solid #ffffff;
    -webkit-transform: translateY(-50%) rotate(-45deg);
    transform: translateY(-50%) rotate(-45deg);
}

.cv_wrap .cv_btn a img {
    z-index: 2;
    position: relative;
    border-radius: 10px;
}

.cv_wrap p {
    line-height: 1.5;
    margin-top: 2.66667vw;
}

.cv_wrap p small {
    font-size: 75%;
    display: block;
}


/* ------------------------------------
  section はじめに
------------------------------------ */

.sec_c0 {
    padding: 0 0 9.33333vw;
}

.attention_txt {
    color: #444;
    font-size: clamp(9px, 1.73333vw, 11px);
    font-weight: 300;
    letter-spacing: 0.02em;
    margin: 10px 10px 0 10px;
    line-height: 1.5;
}


/* ------------------------------------
  section ここがすごい
------------------------------------ */

.sec_c3 {
    padding-top: 10.66vw;
}

.sec_c3 .sec_head .head_pic {
    bottom: 0;
    left: 3.33333vw;
    width: 28.93%;
}

.sec_c3 .point_cnt {
    position: relative;
    margin-top: 8vw;
    padding: 0 0 5.33333vw;
    text-align: center;
}

.sec_c3 .point_cnt .icon {
    position: absolute;
    top: -4vw;
    left: -4vw;
    width: 21.53%;
}

.sec_c3 .point_cnt .tit {
    margin-bottom: 3.33333vw;
}

.sec_c3 .point_cnt p {
    margin: 3.33333vw 0 0;
}

.sec_c3 .point_cnt p small {
    font-size: 75%;
    display: inline-block;
}

.sec_c3 .point_cnt p small.att {
    display: block;
    line-height: 1.5;
}

.sec_c3 .point_cnt.point_02 .img {
    position: relative;
}

.sec_c3 .point_cnt.point_02 .img .fuki {
    position: absolute;
    display: block;
    width: 39.63%;
    top: 0;
    right: -4vw;
}

.sec_c3 .point_cnt.point_03 .img {
    position: relative;
}

.sec_c3 .point_cnt.point_03 .img .fuki {
    position: absolute;
    display: block;
    width: 38.54%;
    top: -2.4vw;
    left: -2.4vw;
}


/* ------------------------------------
  section 金額がたかいのでは？
------------------------------------ */

.sec_c4 {
    padding-top: 6.66667vw;
}

.sec_c4 .fuki_tit {
    text-align: center;
    margin-bottom: 2.66667vw;
}


/* ------------------------------------
  section ポイント
------------------------------------ */

.sec_c5 {
    position: relative;
    padding-top: 16.8vw;
}

.sec_c5 .taC {
    padding: 0 5%;
}

.sec_c5 .box {
    position: relative;
}

.sec_c5 .box>div {
    z-index: 1;
    position: relative;
}

.sec_c5 .att2 {
    margin-top: 4%;
}


/* ------------------------------------
  section お手頃プラン
------------------------------------ */

.sec_c6 {
    position: relative;
    padding: 8vw 0 0;
}

.sec_c6 .box.whitening {
    position: relative;
    margin-top: 8vw;
}

.sec_c6 .box.whitening .img_wrap {
    position: relative;
    margin: 4vw auto 5.33333vw;
}

.sec_c6 .box.whitening .img_wrap .fuki_01 {
    position: absolute;
    bottom: -2.66667vw;
    left: -5.33333vw;
    width: 31.45%;
}

.sec_c6 .box.whitening .img_wrap .fuki_02 {
    position: absolute;
    top: -2.66667vw;
    right: -2.66667vw;
    width: 29.45%;
}

.sec_c6 .box.whitening .txt_wrap.wrap_01 p {
    margin: 2.66667vw -5%;
}

.sec_c6 .box.whitening .txt_wrap.wrap_02 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.sec_c6 .box.whitening .txt_wrap.wrap_02>p {
    width: 56%;
    margin: 0;
}

.sec_c6 .box.whitening .txt_wrap.wrap_02>p+p {
    width: 40%;
}

.sec_c6 .box.whitening .txt_wrap.wrap_03 p {
    margin-right: -4%;
    margin-left: -4%;
}

.sec_c6 .box.whitening .toku_wrap {
    margin: 12vw 0 6.66667vw;
}

.sec_c6 .box.whitening .toku_wrap p {
    margin: 4vw 0;
    line-height: 1.5;
}

.sec_c6 .box.whitening .toku_wrap p small {
    margin: 0 -2%;
    text-align: left;
}

.sec_c6 .box.whitening .toku_wrap .box_po {
    position: absolute;
    top: -9.33333vw;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    width: 79.8%;
}


/* ------------------------------------
  section なぜ？
------------------------------------ */

.sec_c8 {
    position: relative;
    padding-top: 6.66667vw;
    padding-bottom: 2.66667vw;
}

.sec_c8 .fuki_tit {
    text-align: center;
    margin-bottom: 2.66667vw;
}

.sec_c8 .sec_head {
    margin-bottom: 0;
}

.sec_c8 .bg-white {
    background-color: #fff;
}

.sec_c8 .img_00 {
    margin: 1em 2em;
    text-align: center;
}

.sec_c8 .img_00+.att2 {
    padding: 0 5% 5%;
}

.sec_c8 .img_wrap.img_01 {
    position: relative;
    margin: 5.33333vw 0;
}

.sec_c8 .img_wrap.img_01 .att2 {
    margin: 5% 0 0;
}

.sec_c8 .img_wrap.img_02 {
    position: relative;
    /*padding-left: 21.5%;*/
    margin: 5.33333vw 0 10.66667vw;
}

.sec_c8 .box {
    position: relative;
    padding-top: 10px;
}

.sec_c8 .slide_wrap {
    margin-bottom: 1em;
}

.sec_c8 .box .box_left {
    width: 69%;
}

.sec_c8 .box .box_left p {
    font-size: 1.2rem;
}

.sec_c8 .box .box_left .img-s {
    width: 80%;
}

.sec_c8 .box .pic {
    width: 43%;
    position: absolute;
    bottom: 0;
    right: -7%;
}

.sec_c8 .txt_wrap p.txt {
    margin-bottom: 2.5%;
}

.sec_c8 .txt_wrap p.txt+p {
    margin-top: 0;
}

.sec_c8 .txt_wrap .txt_caption {
    font-size: 50% !important;
}

.sec_c8 .slide_wrap .tit {
    margin-bottom: 5.33333vw;
}


/* ------------------------------------
  section 10代～30代に支持
------------------------------------ */

.sec_c10 .sec_head {
    margin-bottom: 0;
}

.sec_c10 .head_img {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-bottom: 17.33333vw;
}

.sec_c10 .head_img .txt_att {
    position: absolute;
    bottom: -11.33333vw;
    max-width: 650px;
    width: 86.6%;
    left: 6.7%;
    line-height: 1.3;
}

.sec_c10 .head_img .txt_att small {
    font-size: 83.3%;
}


/* ------------------------------------
  section 何故はじめるの？
------------------------------------ */

.sec_c11 .txt_01 {
    margin-bottom: 18px;
}

.sec_c11 .sec_tit_fuki .pic {
    position: absolute;
    width: 24%;
    bottom: 0;
    right: 3.8%;
}

.sec_c11 .txt_wrap p small.att {
    display: block;
    margin-top: 2.66667vw;
}

.sec_c11 .txt_wrap .txt p {
    margin: 0;
}

.sec_c11 .txt_wrap .txt p+p {
    margin-top: 4vw;
}

.sec_c11 .cnt_01 .txt_wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    margin: 13.33333vw 0 6vw;
}

.sec_c11 .cnt_01 .txt_wrap .img {
    position: relative;
    width: 33%;
}

.sec_c11 .cnt_01 .txt_wrap .img .fuki {
    position: absolute;
    top: -10vw;
    left: -2.66667vw;
    width: 75.23%;
}

.sec_c11 .cnt_01 .txt_wrap .txt {
    padding-left: 3.33333vw;
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
}

.sec_c11 .cnt_02 .txt_wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    margin-bottom: 15.33333vw;
}

.sec_c11 .cnt_02 .txt_wrap .img {
    width: 33%;
    position: relative;
}

.sec_c11 .cnt_02 .txt_wrap .img .fuki {
    position: absolute;
    top: -12vw;
    right: -2.66667vw;
    width: 88.3%;
}

.sec_c11 .cnt_02 .txt_wrap .txt {
    padding-right: 3.33333vw;
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
}

.sec_c11 .cnt_02 .box_po {
    position: absolute;
    top: -6vw;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    width: 58.6%;
}

.sec_c11 .cnt_02 .box_inner {
    position: relative;
    width: 90%;
    margin: 6.66667vw auto;
}

.sec_c11 .cnt_02 .box_inner .pic {
    position: absolute;
    bottom: -10%;
    right: 0;
    width: 30%;
    z-index: 1;
    text-align: right;
}

.sec_c11 .cnt_02 .box_inner p {
    margin: 4vw 0;
    letter-spacing: -0.08em;
    z-index: 2;
    position: relative;
}

.sec_c11 .cnt_02 .box_inner p:first-of-type {
    margin-right: -5%;
}

.sec_c11 .cnt_03 {
    margin: 12vw auto 13.33333vw;
}

.sec_c11 .cnt_03 .txt_wrap {
    margin: 0 -8%;
}

.sec_c11 .cnt_03 .txt_wrap p {
    line-height: 2.2;
    letter-spacing: -0.06em;
    margin: 6.66667vw auto;
}


/* ------------------------------------
  section 本当にキレイになる？
------------------------------------ */

.sec_c13 {
    padding-top: 6.66667vw;
}

.c13_list {
    margin-top: 8%;
    border: 3px solid #33ccff;
}

.c13_list h3 {
    background-color: #33ccff;
    padding: 3em 0;
    text-align: center;
}

.c13_list h3 img {
    width: 80%;
}

.c13_list small {
    font-size: 0.8em;
}

.c13_list p {
    line-height: 1.5;
}

.c13_list .inner {
    width: 90%;
    margin: auto;
}

.c13_list p img {
    display: block;
    margin: auto;
}

.c13_list .box {
    position: relative;
}

.c13_list .box .box_left {
    width: 64%;
}

.c13_list .box .pic {
    width: 48%;
    position: absolute;
    bottom: 0;
    right: -8%;
}

.sec_c13 .sec_head {
    margin-bottom: 0;
}

.sec_c13 .img03 {
    width: 100%;
    margin: 2em auto 2.5em;
}

.sec_c13 .txt_wrap p small.att {
    display: block;
    line-height: 1.5;
    margin-top: -2.66667vw;
}


/* ------------------------------------
  section お越しください
------------------------------------ */

.sec_c15 {
    margin-bottom: 10.66667vw;
}

.sec_c15 .sec_head {
    margin-top: 25.33333vw;
}

.sec_c15 .sec_head .head_pic {
    top: -22.66667vw;
    left: 0;
}

.sec_c15 .clinic_map {
    margin: 8vw 0 6.66667vw;
    position: relative;
    padding-left: 24%;
}

.sec_c15 .clinic_map .fuki {
    position: absolute;
    top: -6%;
    left: 0;
    width: 57.5%;
}

.sec_c15 .clinic_list_01 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.sec_c15 .clinic_list_01>div {
    width: 30.7%;
}

.sec_c15 .clinic_cnt {
    background: #e4f8ff;
    border-radius: 10px;
}

.sec_c15 .clinic_cnt img {
    border-radius: 10px 10px 0 0;
}

.sec_c15 .clinic_cnt p {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    color: #00a9e0;
    font-weight: 700;
    text-align: center;
    font-size: 3.46667vw;
    height: 8vw;
}

.sec_c15 .txt_wrap .sec_tit_fuki {
    position: relative;
}

.sec_c15 .txt_wrap .sec_tit_fuki .pic {
    position: absolute;
    bottom: 0;
    left: -4vw;
    width: 36.3%;
    z-index: 2;
}


/* ------------------------------------
  section 初回検診の流れとメリット
------------------------------------ */

.sec_c16 .txt_wrap.wrap_01 {
    position: relative;
    padding-left: 36%;
}

.sec_c16 .txt_wrap.wrap_01 .img {
    position: absolute;
    bottom: 0;
    left: -3.2vw;
    width: 35.7%;
}

.sec_c16 .txt_wrap.wrap_01 p {
    margin: 4vw 0;
}

.sec_c16 .txt_wrap.wrap_02 {
    margin: 6.66667vw auto;
}

.sec_c16 .txt_wrap.wrap_02 p small.att {
    display: block;
    line-height: 1.5;
    margin-top: -2.66667vw;
}

.sec_c16 .cv_wrap {
    margin: 9.33333vw auto 8vw;
}

.sec_c16 .box {
    margin-top: 9.33333vw;
}

.sec_c16 .box_img {
    position: relative;
}

.sec_c16 .box_img .fuki {
    position: absolute;
}

.sec_c16 .box_tit {
    position: relative;
}

.sec_c16 .box_tit .num {
    position: absolute;
    width: 21.6%;
    top: -5.33333vw;
    left: -4vw;
}

.sec_c16 .box.step_01 .box_img .fuki {
    width: 39.5%;
    top: -4.6%;
    left: 7.7%;
}

.sec_c16 .box.step_02 .box_img .fuki {
    width: 39.3%;
    bottom: 10%;
    right: 50%;
}

.sec_c16 .box.step_03 .box_img .fuki {
    width: 39%;
    top: 43%;
    right: 1%;
}

.sec_c16 .box.step_04 .box_img .fuki {
    width: 46.45%;
    top: 45%;
    right: 44%;
}

.sec_c16 .box.step_05 .box_img .fuki {
    width: 39.5%;
    top: -9.8%;
    left: 2.3%;
}


/* ------------------------------------
  section 気持ちよくご利用
------------------------------------ */

.sec_c17 .sec_head {
    margin-top: 4vw;
}

.sec_c17 .txt_wrap.wrap_01 {
    position: relative;
    text-align: center;
    margin-bottom: 10.66667vw;
}

.sec_c17 .txt_wrap.wrap_01 p {
    margin-bottom: 0;
}


/* ------------------------------------
  section どの提携クリニックに行けばいいの？
------------------------------------ */

.sec_c18 .txt_wrap.wrap_01 {
    position: relative;
    padding-left: 43%;
}

.sec_c18 .txt_wrap.wrap_01 .img {
    position: absolute;
    width: 46%;
    left: -4.6%;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}

.sec_c18 .txt_wrap.wrap_01 p {
    margin: 2.66667vw -5% 2.66667vw 0;
}

.sec_c18 .txt_wrap p small.att {
    display: block;
    line-height: 1.5;
}


/* ------------------------------------
  section 料金プラン
------------------------------------ */

.sec_c19 {
    margin: 6.66667vw auto 10.66667vw;
}

.sec_c19 .toku_wrap p {
    margin: 4vw 0;
    line-height: 1.5;
}

.sec_c19 .toku_wrap.toku_02 {
    margin: 0 0 40px;
}

.sec_c19 .toku_wrap.toku_04 .txt_wrap {
    margin: 5.33333vw auto;
}

.sec_c19 .toku_wrap.toku_04 .txt_wrap .wrap_01 {
    position: relative;
    padding-right: 45%;
}

.sec_c19 .toku_wrap.toku_04 .txt_wrap .wrap_01 .pic {
    position: absolute;
    top: 0;
    right: -7%;
    width: 50%;
}


/* ------------------------------------
  section Q&A
------------------------------------ */

.sec_c20 {
    margin: 8vw auto 10.66667vw;
}

.sec_c20 .head_pic {
    bottom: 0;
    right: 3.2%;
    width: 28.9%;
}


/* ------------------------------------
  section 最後に
------------------------------------ */

.sec_c21 {
    margin: 9.33333vw auto;
}

.sec_c21 .head_pic {
    bottom: 0;
    right: 1%;
    width: 40.6%;
}

.sec_c21 .cv_wrap {
    margin-top: 10.66667vw;
}

@media not screen,
screen and (min-width: 768px) {
    .vsp767 {
        display: none;
    }
    .js-slider-doc .slick-slide {
        margin-right: 6.66667vw;
    }
}

@media screen and (min-width: 768px),
print {
    .bg_stripe_01 {
        background-size: 80px auto;
    }
    .bg_stripe_02 {
        background-size: 80px auto;
    }
    .js-slider-doc {
        margin-top: 40px;
    }
    .js-slider-doc .slick-slide {
        margin-right: 50px;
    }
    .js-slider-clinic {
        width: 112%;
        margin: 70px -8% 70px -4%;
    }
    .js-slider-clinic .slick-slide {
        margin-right: 25px;
    }
    .floating_bnr {
        width: 640px;
        left: 50%;
        -webkit-transform: translateX(-50%);
        transform: translateX(-50%);
    }
    .floating_bnr img {
        height: 60px;
        width: auto;
    }
    .pagetop_btn {
        bottom: 60px;
        right: 30px;
        width: 50px;
        height: 50px;
    }
    .footer_inner {
        padding: 40px 10px;
    }
    .footer_logo {
        margin: 0 0 30px;
    }
    .footer_copyright {
        margin: 0 0 20px;
        font-size: 19px;
    }
    .footer_nav li {
        font-size: 1.4rem;
    }
    .sec_head {
        margin-bottom: 35px;
        background-size: 80px auto;
    }
    .sec_head::before {
        top: 10px;
    }
    .sec_head::after {
        bottom: 10px;
    }
    .sec_tit_fuki {
        margin-bottom: 20px;
        border-radius: 20px;
    }
    .sec_tit_fuki::after {
        border-width: 20px 27px 0 27px;
        bottom: -20px;
    }
    .sec_tit_fuki.thin::after {
        border-width: 12px 22px 0 22px;
        bottom: -12px;
    }
    .sec_tit_fuki.white {
        margin-bottom: 35px;
    }
    .sec_tit_fuki.white::before {
        border-width: 20px 27px 0 27px;
        bottom: -19px;
    }
    .sec p {
        font-size: 2.2rem;
    }
    .sec .txt_wrap p {
        margin: 40px 0;
    }
    .sec .txt_wrap p small.att {
        font-size: 54.16%;
    }
    .att2 {
        margin-top: 4%;
        font-size: 54.16%;
        text-align: left;
        line-height: 1 !important;
    }
    .sec .img_round img {
        border-radius: 20px;
    }
    .sec .sorry_wrap {
        margin: 50px auto 60px;
    }
    .sec .sorry_wrap .box {
        padding: 25px 4% 25px 22%;
        margin-bottom: 30px;
    }
    .sec .check_list li {
        padding-left: 40px;
        background-position: left 5px;
        background-size: 28px auto;
        margin: 20px 0;
    }
    .sec .box.box_round {
        border-radius: 20px;
    }
    .sec .box_img_tp,
    .sec .box_img_tp img {
        border-radius: 20px 20px 0 0;
    }
    .sec .box_img_btm,
    .sec .box_img_btm img {
        border-radius: 0 0 20px 20px;
    }
    .sec .box.plan {
        margin-top: 100px;
    }
    .sec .box.plan .box_tit {
        top: -63px;
    }
    .sec .box.plan .fee {
        border-radius: 20px 20px 0 0;
    }
    .sec .box.plan_01 .pic {
        right: 5px;
        width: 47.5%;
    }
    .sec .box.plan_01 .txt_wrap {
        margin: 50px auto;
    }
    .sec .box.plan_02 .wrap_01 {
        margin-bottom: 0;
    }
    .sec .box.plan_02 .wrap_01 .box.txt {
        width: 52%;
        padding: 20px 10px 20px 15px;
    }
    .sec .box.plan_02 .wrap_01 .box.txt p {
        font-size: 2rem;
    }
    .sec .box.plan_02 .wrap_02 .txt+P {
        margin-top: 60px;
    }
    .sec .box.plan_03 .box_inner {
        padding-bottom: 20px;
    }
    .sec .box.plan_03 .txt_wrap .wrap_01 .pic {
        width: 36%;
        right: -5%;
    }
    .sec .box.plan_03 .txt_wrap .wrap_01 p {
        margin: 20px 0;
    }
    .sec .box.plan_04 .box_inner {
        padding: 50px 0 20px;
    }
    .sec .box.faq {
        margin-bottom: 35px;
    }
    .sec .box.faq .box_tit {
        font-size: 2.2rem;
        padding: 0 65px 0 75px;
        height: 110px;
    }
    .sec .box.faq .box_tit.lg {
        height: 155px;
    }
    .sec .box.faq .box_tit:not(.active) {
        border-radius: 20px;
    }
    .sec .box.faq .box_tit::before {
        left: 30px;
    }
    .sec .box.faq .box_tit::after {
        right: 30px;
        width: 20px;
        height: 20px;
    }
    .sec_movie .sec_inner {
        padding: 30px 0 40px 0;
    }
    .sec_movie .movie_cnt .movie {
        border-width: 2px;
    }
    .sec_movie .movie_cnt .txt_01 {
        top: -26px;
        left: -15px;
    }
    .sec_movie .movie_cnt .txt_02 {
        top: -26px;
        right: -15px;
    }
    .sec_movie .movie_cnt .txt_03 {
        bottom: -26px;
        left: -15px;
    }
    .sec_movie .movie_cnt .txt_04 {
        bottom: -26px;
        right: -15px;
    }
    .sec_movie .attention_txt {
        top: 10px;
        font-size: clamp(9px, 1.73333vw, 11px);
        letter-spacing: 0;
    }
    .cv_wrap .cv_po {
        top: -45px;
    }
    .cv_wrap .cv_po.po_01 {
        left: -25px;
    }
    .cv_wrap .cv_po.po_02 {
        right: -25px;
    }
    .cv_wrap .cv_btn a {
        border-radius: 20px;
    }
    .cv_wrap .cv_btn a::before {
        top: -5px;
        border-radius: 20px;
    }
    .cv_wrap .cv_btn a::after {
        right: 30px;
        width: 20px;
        height: 20px;
    }
    .cv_wrap .cv_btn a img {
        border-radius: 20px;
    }
    .cv_wrap p {
        margin-top: 15px;
    }
    .cv_wrap p small {
        font-size: 60%;
    }
    .sec_c0 {
        padding: 0 0 0px;
    }
    .attention_txt {
        letter-spacing: 0;
    }
    .sec_cta {
        padding-bottom: 40px;
    }
    .sec_c3 {
        padding-top: 40px;
    }
    .sec_c3 .sec_head .head_pic {
        left: 25px;
    }
    .sec_c3 .point_cnt {
        margin-top: 60px;
        padding-bottom: 40px;
    }
    .sec_c3 .point_cnt .icon {
        top: -30px;
        left: -30px;
    }
    .sec_c3 .point_cnt .tit {
        margin-bottom: 25px;
    }
    .sec_c3 .point_cnt p {
        margin-top: 25px;
    }
    .sec_c3 .point_cnt p small {
        font-size: 62.5%;
    }
    .sec_c3 .point_cnt.point_02 .img .fuki {
        right: -30px;
    }
    .sec_c3 .point_cnt.point_03 .img .fuki {
        top: -18px;
        left: -18px;
    }
    .sec_c4 {
        padding-top: 40px;
    }
    .sec_c4 .fuki_tit {
        margin-bottom: 15px;
    }
    .sec_c4 .txt_wrap p {
        margin-right: -6%;
        margin-left: -6%;
    }
    .sec_c5 {
        padding-top: 126px;
    }
    .sec_c5 .sec_head_ico {
        top: -28px;
    }
    .sec_c5 .sec_head_01 {
        margin-bottom: 40px;
    }
    .sec_c5 .sec_head_01 .head_pic {
        left: 15px;
    }
    .sec_c5 .box_tit {
        top: -46px;
    }
    .sec_c5 .box.box_01 {
        margin-top: 40px;
    }
    .sec_c5 .box.box_02 {
        margin-top: 0;
    }
    .sec_c6 {
        padding: 60px 0 0;
    }
    .sec_c6 .sec_head .head_pic {
        top: -35px;
        right: 5px;
    }
    .sec_c6 .box.whitening {
        margin-top: 60px;
    }
    .sec_c6 .box.whitening .img_wrap {
        margin: 30px auto 40px;
    }
    .sec_c6 .box.whitening .img_wrap .fuki_01 {
        bottom: -20px;
        left: -40px;
    }
    .sec_c6 .box.whitening .img_wrap .fuki_02 {
        top: -20px;
        right: -20px;
    }
    .sec_c6 .box.whitening .txt_wrap.wrap_01 p {
        margin: 20px -5%;
    }
    .sec_c6 .box.whitening .toku_wrap {
        margin: 80px 0 40px;
    }
    .sec_c6 .box.whitening .toku_wrap p {
        margin: 30px auto;
    }
    .sec_c6 .box.whitening .toku_wrap .box_po {
        top: -60px;
        width: 90%;
        text-align: center;
    }
    .sec_c6 .plan_01 .txt_wrap p:last-child {
        margin-bottom: 20px;
    }
    .sec_c6 .box.plan_01 .txt_wrap {
        margin-bottom: 20px;
    }
    .sec_c8 {
        padding-top: 50px;
        padding-bottom: 20px;
    }
    .sec_c8 .fuki_tit {
        margin-bottom: 15px;
    }
    .sec_c8 .img_00 {
        margin: 1em 2em;
    }
    .sec_c8 .img_wrap.img_01 {
        margin: 40px 0;
    }
    .sec_c8 .img_wrap.img_01 .fuki {
        bottom: 20px;
        left: 20px;
        font-size: 1.6rem;
    }
    .sec_c8 .img_wrap.img_02 {
        margin: 40px 0 60px;
    }
    .sec_c8 .img_wrap.img_02 .pic_03 {
        bottom: -30px;
        left: -40px;
    }
    .sec_c8 .box .box_left p {
        font-size: 1.9rem;
    }
    .sec_c8 .txt_wrap p .att {
        margin-top: 20px;
    }
    .sec_c8 .info_wrap {
        margin: 70px 0 50px;
    }
    .sec_c8 .info_wrap .img {
        margin: 0 0 30px 30px;
    }
    .sec_c8 .info_wrap .txt .name {
        font-size: 2.6rem;
        margin-bottom: 30px;
    }
    .sec_c8 .info_wrap .txt .name small {
        margin-top: 5px;
    }
    .sec_c8 .info_wrap .txt .name b {
        margin-top: 25px;
    }
    .sec_c8 .slide_wrap .tit {
        margin-bottom: 40px;
    }
    .sec_c8 .slide_wrap .slider p {
        font-size: 1.2rem;
    }
    .sec_c10 .sec_inner {
        margin-bottom: 65px;
    }
    .sec_c10 .head_img {
        margin-bottom: 130px;
    }
    .sec_c10 .head_img .txt_att {
        bottom: -85px;
    }
    .sec_c10 .sec_tit_fuki {
        margin-bottom: -20px;
    }
    .sec_c10 .sec_tit_fuki::after {
        border-width: 16px 16px 0 16px;
    }
    .sec_c11 .txt_wrap p small.att {
        margin-top: 20px;
    }
    .sec_c11 .txt_wrap .txt p+p {
        margin-top: 30px;
    }
    .sec_c11 .cnt_01 .txt_wrap {
        margin: 100px 0;
    }
    .sec_c11 .cnt_01 .txt_wrap .img .fuki {
        top: -75px;
        left: -20px;
    }
    .sec_c11 .cnt_01 .box_tit {
        top: -80px;
    }
    .sec_c11 .cnt_02 .txt_wrap {
        margin-bottom: 115px;
    }
    .sec_c11 .cnt_02 .txt_wrap .img .fuki {
        top: -90px;
        right: -20px;
    }
    .sec_c11 .cnt_02 .txt_wrap .txt {
        padding-right: 25px;
    }
    .sec_c11 .cnt_02 .box_po {
        top: -45px;
    }
    .sec_c11 .cnt_02 .box_inner {
        margin: 50px auto;
    }
    .sec_c11 .cnt_02 .box_inner .pic {
        width: 32%;
        bottom: -10%;
        right: 0;
    }
    .sec_c11 .cnt_02 .box_inner .pic img {
        width: 100%;
    }
    .sec_c11 .cnt_02 .box_inner p {
        margin: 30px 0;
    }
    .sec_c11 .cnt_02 .box_inner p:first-of-type {
        margin-right: -10%;
    }
    .sec_c11 .cnt_03 {
        margin: 90px auto 100px;
    }
    .sec_c11 .cnt_03 .txt_wrap p {
        margin: 50px auto;
    }
    .sec_c13 {
        padding-top: 50px;
    }
    .sec_c13 .head_pic {
        right: 25px;
    }
    .sec_c13 .txt_wrap p small.att {
        margin-top: -20px;
    }
    .sec_c15 {
        margin-bottom: 80px;
    }
    .sec_c15 .sec_head {
        margin-top: 190px;
    }
    .sec_c15 .sec_head .head_pic {
        top: -170px;
    }
    .sec_c15 .clinic_map {
        margin: 60px 0 50px;
    }
    .sec_c15 .clinic_cnt {
        border-radius: 20px;
    }
    .sec_c15 .clinic_cnt img {
        border-radius: 20px 20px 0 0;
    }
    .sec_c15 .clinic_cnt p {
        font-size: 2.6rem;
        height: 60px;
    }
    .sec_c15 .txt_wrap p small.att {
        margin-top: 20px;
    }
    .sec_c15 .txt_wrap .sec_tit_fuki .pic {
        left: -30px;
    }
    .sec_c16 .txt_wrap.wrap_01 .img {
        left: -24px;
    }
    .sec_c16 .txt_wrap.wrap_02 {
        margin: 50px auto;
    }
    .sec_c16 .txt_wrap.wrap_02 p small.att {
        margin-top: -20px;
    }
    .sec_c16 .cv_wrap {
        margin: 70px auto 60px;
    }
    .sec_c16 .box {
        margin-top: 70px;
    }
    .sec_c16 .box_tit .num {
        top: -40px;
        left: -30px;
    }
    .sec_c16 .box_att small {
        font-size: 54.16%;
        margin-top: 10px;
    }
    .sec_c17 .sec_head {
        margin-top: 30px;
    }
    .sec_c17 .txt_wrap.wrap_01 {
        margin-bottom: 80px;
    }
    .sec_c17 .box.box_01 {
        display: inline-block;
        margin-right: auto;
        margin-left: auto;
    }
    .sec_c17 .box.box_02 {
        margin-bottom: 90px;
    }
    .sec_c17 .box.box_02 .box_tit {
        top: -40px;
    }
    .sec_c17 .box.box_02 .box_inner {
        padding-top: 60px;
    }
    .sec_c18 .txt_wrap.wrap_01 p {
        margin: 20px 0;
        font-size: 2rem;
    }
    .sec_c19 {
        margin: 50px auto 80px;
    }
    .sec_c19 .toku_wrap p {
        margin: 30px auto;
    }
    .sec_c19 .toku_wrap.toku_01 .txt_wrap {
        margin: 50px auto;
    }
    .sec_c19 .toku_wrap.toku_03 {
        margin: 70px 0 50px;
    }
    .sec_c19 .toku_wrap.toku_03 .box_po {
        top: -70px;
    }
    .sec_c19 .toku_wrap.toku_03 .txt_wrap+.txt_wrap {
        margin-top: 40px;
    }
    .sec_c19 .toku_wrap.toku_04 .txt_wrap {
        margin: 40px auto;
    }
    .sec_c19 .cv_wrap {
        margin-top: 90px;
    }
    .sec_c20 {
        margin: 60px auto 80px;
    }
    .sec_c21 {
        margin: 60px auto;
    }
    .sec_c21 .cv_wrap {
        margin-top: 80px;
    }
    .type_line .cta_line .cv_btn a {
        border-radius: 20px;
    }
    .type_line .cta_line .cv_btn a::before {
        top: -5px;
        border-radius: 20px;
    }
    .type_line .cta_line .cv_btn a::after {
        right: 30px;
        width: 20px;
        height: 20px;
    }
    .type_line .cta_line .cv_btn a img {
        border-radius: 20px;
    }
    .type_line .cta_line .cv_btn+.att {
        margin-top: 20px;
    }
    .type_line .cta_line .cta_arr.arr_01 {
        height: 90px;
    }
    .type_line .cta_line .cta_arr.arr_02 {
        height: 70px;
    }
    .type_line .cta_line_01 {
        padding: 15px 0 30px;
    }
    .type_line .cta_line_01 .img_wrap .fuki {
        margin-right: -26px;
    }
    .type_line .cta_line_02 {
        padding: 50px 0 0;
    }
    .type_line .cta_line_02 .img_wrap .pic {
        margin-left: -20px;
    }
    .type_line .cta_line_02 .img_wrap .fuki {
        margin-right: -20px;
    }
}

@media not screen,
screen and (min-width: 1025px) {
    .vsp1024 {
        display: none;
    }
}

@media screen and (min-width: 1025px),
print {
    .slick-arr {
        font-size: 1.6rem;
        width: 50px;
        height: 50px;
        line-height: 50px;
    }
    .sec_tit_stripe {
        background-size: 80px auto;
    }
    .sec_tit_stripe2 {
        background-size: 80px auto;
    }
}

@media screen and (max-width: 1024px) {
    .vpc1024 {
        display: none;
    }
}

@media screen and (max-width: 813px) and (orientation: landscape) {
    .sec p {
        font-size: 2rem;
    }
    .sec .check_list li {
        font-size: 2rem;
    }
    .sec .box.faq .box_tit {
        font-size: 2rem;
    }
    .sec_hero {
        height: 150vw;
        min-height: 150vw;
    }
}

@media screen and (max-width: 767px) {
    .vpc767 {
        display: none;
    }
    .js-slider-clinic .slick-arr.next {
        right: 5%;
    }
    .sec_c6 .plan_01 .txt_wrap p:last-child {
        font-size: 2.8vw;
    }
}

@-webkit-keyframes flash {
    0% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}

@keyframes flash {
    0% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}

@-webkit-keyframes fadeOut {
    0% {
        opacity: 1;
    }
    100% {
        opacity: 0;
    }
}

@keyframes fadeOut {
    0% {
        opacity: 1;
    }
    100% {
        opacity: 0;
    }
}

@-webkit-keyframes pulse {
    from {
        -webkit-transform: scale3d(1.05, 1.05, 1.05);
        transform: scale3d(1.05, 1.05, 1.05);
    }
    50% {
        -webkit-transform: scale3d(1, 1, 1);
        transform: scale3d(1, 1, 1);
    }
    to {
        -webkit-transform: scale3d(1.05, 1.05, 1.05);
        transform: scale3d(1.05, 1.05, 1.05);
    }
}

@keyframes pulse {
    from {
        -webkit-transform: scale3d(1.05, 1.05, 1.05);
        transform: scale3d(1.05, 1.05, 1.05);
    }
    50% {
        -webkit-transform: scale3d(1, 1, 1);
        transform: scale3d(1, 1, 1);
    }
    to {
        -webkit-transform: scale3d(1.05, 1.05, 1.05);
        transform: scale3d(1.05, 1.05, 1.05);
    }
}

@-webkit-keyframes arrDown {
    0% {
        top: -5%;
        opacity: 0;
    }
    50% {
        opacity: 1;
    }
    100% {
        top: 18%;
        opacity: 0;
    }
}

@keyframes arrDown {
    0% {
        top: -5%;
        opacity: 0;
    }
    50% {
        opacity: 1;
    }
    100% {
        top: 18%;
        opacity: 0;
    }
}

@-webkit-keyframes arrUp {
    0% {
        top: 5%;
        opacity: 0;
    }
    50% {
        opacity: 1;
    }
    100% {
        top: -18%;
        opacity: 0;
    }
}

@keyframes arrUp {
    0% {
        top: 5%;
        opacity: 0;
    }
    50% {
        opacity: 1;
    }
    100% {
        top: -18%;
        opacity: 0;
    }
}


/*# sourceMappingURL=map/style.css.map */


/*----------------1126---------------*/


/*     top-menu 
--------------------------------------------------------------*/

.top-menu-sp {
    position: fixed;
    bottom: 0;
    z-index: 99998;
    width: 100%;
}

.top-menu-sp .nav-social {
    font-size: 0;
}

.top-menu-sp .nav-social .nav-item {
    display: inline-block;
    vertical-align: middle;
}

.top-menu-sp .nav-social .nav-item.link__contact {
    background-color: #32c332;
    width: 40%;
}

.top-menu-sp .nav-social .nav-item.link__reservation {
    background-image: -webkit-gradient(linear, left top, right top, from(#00b7ed), to(#53d3fa));
    background-image: -webkit-linear-gradient(left, #00b7ed, #53d3fa);
    background-image: -o-linear-gradient(left, #00b7ed, #53d3fa);
    background-image: linear-gradient(to right, #00b7ed, #53d3fa);
    width: 100%;
}

.top-menu-sp .nav-social .nav-item .nav-link {
    color: #fff;
    text-align: center;
    display: block;
    /* height: 60px; */
    height: auto;
    line-height: 60px;
    text-decoration: none;
    font-size: 2rem;
}

.top-menu-sp .nav-social .nav-item .nav-link span:before {
    content: "";
    display: inline-block;
    vertical-align: middle;
    width: 30px;
    height: 30px;
    margin-right: 0.5em;
}

.top-menu-sp .nav-social .nav-item .nav-link span.forLine:before {
    background: url(../img/kireilign-icon-line.webp) center no-repeat;
    background-size: 95% auto;
}

.top-menu-sp .nav-social .nav-item .nav-link span.forBook:before {
    background: url(../img/kirelign-icon-reservation.webp) center no-repeat;
    background-size: contain;
}

@media screen and (min-width: 768px) {}

@media screen and (max-width: 767px) {
    .sec_c15 .txt_wrap1 p {
        font-size: 3vw;
    }
    .sec_c0 {
        padding-bottom: 4vw;
    }
    .sec_c1 {
        margin-top: 8vw;
        margin-bottom: 8vw;
    }
    .top-menu {
        width: 100%;
        max-width: 640px;
    }
    .top-menu-sp .nav-social {
        font-size: 0;
    }
    .top-menu-sp .nav-social .nav-item {
        display: inline-block;
        vertical-align: middle;
    }
    .top-menu-sp .nav-social .nav-item.link__contact {
        background-color: #32c332;
        width: 40%;
    }
    .top-menu-sp .nav-social .nav-item.link__reservation {
        background-image: -webkit-gradient(linear, left top, right top, from(#00b7ed), to(#53d3fa));
        background-image: -webkit-linear-gradient(left, #00b7ed, #53d3fa);
        background-image: -o-linear-gradient(left, #00b7ed, #53d3fa);
        background-image: linear-gradient(to right, #00b7ed, #53d3fa);
        width: 100%;
    }
    .top-menu-sp .nav-social .nav-item .nav-link {
        color: #fff;
        text-align: center;
        display: block;
        height: 15vw;
        line-height: 15vw;
        text-decoration: none;
        font-size: 4.2vw;
    }
    .top-menu-sp .nav-social .nav-item .nav-link span:before {
        content: "";
        display: inline-block;
        vertical-align: middle;
        width: 7vw;
        height: 7vw;
        margin-right: 0.5em;
    }
    .top-menu-sp .nav-social .nav-item .nav-link span.forLine:before {
        background: url(../img/kireilign-icon-line.webp) center no-repeat;
        background-size: 95% auto;
    }
    .top-menu-sp .nav-social .nav-item .nav-link span.forBook:before {
        background: url(../img/kirelign-icon-reservation.webp) center no-repeat;
        background-size: contain;
    }
}


/* LP116パーツ  */

.mv {
    text-align: center;
}

.mv .box {
    background: #03a9e0;
    color: #fff;
    padding: calc(100vw / (750 / 20));
}

.mv .box ul {
    font-size: clamp(9px, 1.563vw, 10.2px);
    line-height: 1.4;
    margin-top: calc(100vw / (750 / 20));
    text-align: left;
}

.mv .box.white {
    background: #fff;
    color: #808080;
}

@media only screen and (min-width: 768px) {
    .mv .box {
        padding: calc(20px * 0.85333);
    }
    .mv .box ul {
        margin-top: calc(20px * 0.85333);
    }
}


/*     renewal
--------------------------------------------------------------*/

.renewal {
    padding-top: 50px;
}

.mv .renewal {
    padding-top: 0;
}

.renew_campaign {
    margin-top: min(4vw, 25.6px);
    background-color: #d5f2ff;
    padding-bottom: 40px;
}

.renew_campaign figure {
    margin: 0;
    position: relative;
    z-index: 1;
}

.renew_campaign .renew_campaign_img_03 {
    margin-top: max(-10.66vw, -68px);
}

.renew_campaign p {
    text-align: left;
    margin: 0 5%;
    padding: 20px 0;
    line-height: 1.4em;
    position: relative;
    z-index: 2;
}

.renew_campaign p small {
    font-size: clamp(10px, 1.2vw, 16px);
    letter-spacing: 0.06em;
    display: inline-block;
    line-height: 1.4;
}

.renew_campaign .campaign_cta {
    margin: 0 5%;
    padding: 20px 0;
}

.renew_campaign p+.campaign_cta {
    padding-top: 0;
}


/* update text coding date 2024-09-09
--------------------------------------------------------------*/

.poR {
    position: relative;
}

.renew_campaign_img_01 .text01 {
    position: absolute;
    top: 6.55%;
    left: 7.5%;
    display: flex;
    column-gap: 47px;
}

.renew_campaign_img_01 .text01 span {
    color: #fff;
    font-size: 17px;
    line-height: 1.7;
}

.renew_campaign_img_01 .text02 {
    color: #51ade5;
    font-size: 21px;
    line-height: 1.7;
    position: absolute;
    top: 9%;
    left: 0;
}

.bg_yellow {
    background-color: #fcf070;
    font-weight: bold;
}

.renew_campaign_img_01 .text03 {
    color: #51ade5;
    font-size: 19px;
    line-height: 1.5;
    position: absolute;
    top: 42.8%;
    left: 49%;
    transform: translateX(-50%);
    display: flex;
    justify-content: center;
    column-gap: 60px;
    width: 100%;
    text-align: center;
}

.renew_campaign_img_01 .text04 {
    color: #51ade5;
    font-size: 34px;
    line-height: 1.6;
    position: absolute;
    top: 62.8%;
    left: 37%;
}

.renew_campaign_img_01 .text05 {
    color: #fb827f;
    font-size: 23px;
    line-height: 1.5;
    position: absolute;
    top: 72%;
    left: 50%;
    transform: translateX(-50%);
    box-sizing: border-box;
    text-align: center;
    width: 100%;
    margin: 0;
    font-weight: bold;
}

.renew_campaign_img_02 .text01 {
    color: #51ade5;
    font-size: 34px;
    line-height: 1.6;
    position: absolute;
    top: 32%;
    left: 47%;
}

.renew_campaign_img_02 .text02 {
    color: #fb827f;
    font-size: 26px;
    line-height: 1.5;
    position: absolute;
    top: 63%;
    left: 50%;
    transform: translateX(-50%);
    box-sizing: border-box;
    text-align: center;
    width: 100%;
    margin: 0;
    letter-spacing: 2px;
    font-weight: bold;
}

.renew_campaign_img_02 .text02 .txtSmall {
    font-size: 25px;
}

.renew_campaign_img_02 .text02 .txtNum {
    font-size: 38px;
    line-height: 1;
}

.renew_campaign_img_02 .text02 sup {
    font-size: 10px;
    color: #000;
    position: relative;
    top: -15px;
}

.renew_campaign_img_03 .text01 {
    color: #51ade5;
    font-size: 34px;
    line-height: 1.6;
    position: absolute;
    top: 42%;
    left: 50%;
}

.renew_campaign_img_03 .text02 {
    color: #fb827f;
    font-size: 22px;
    line-height: 1.5;
    position: absolute;
    top: 70%;
    left: 50%;
    transform: translateX(-50%);
    box-sizing: border-box;
    text-align: center;
    width: 100%;
    margin: 0;
    font-weight: bold;
}

.renew_campaign_img_03 .text02 .larg {
    font-size: 28px;
}

.f-maru {
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: 300;
    font-style: normal;
}

.sec_c13 .c13_list>h3 {
    text-align: center;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: bold;
    font-style: normal;
    color: #fff;
    line-height: 1.5;
    font-size: 40px;
    padding: 20px 10px;
    letter-spacing: 2px;
}

.sec_c13_list {
    text-align: center;
}

.sec_c13_list_h3 {
    position: absolute;
    width: 80%;
    left: 50%;
    top: 4%;
    transform: translateX(-50%);
    text-align: center;
    font-size: 24px;
    line-height: 1.5;
}

.sec_c13_list ul {
    position: absolute;
    width: 80%;
    left: 62%;
    top: 52%;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    gap: 27px;
    text-align: left;
    font-size: 20px;
    font-weight: bold;
}

.sec_c13_list .note {
    position: absolute;
    width: 80%;
    left: 63%;
    top: 69%;
    transform: translateX(-50%);
    text-align: left;
    font-size: 14px;
    font-weight: bold;
    line-height: 1.3;
}

.yellow_line {
    background: rgba(0, 0, 0, 0) linear-gradient(transparent 60%, #ffff82 0%) repeat scroll 0 0;
}

.sec_c13 .sec_inner .heading {
    text-align: center;
    color: #51ade5;
    font-size: 26px;
    line-height: 1.8;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: 600;
    font-style: normal;
    letter-spacing: 2px;
}

.sec_c8 .box .box_left .img-s {
    margin: 40px 0;
}

.sec_c8_po1_box_02 {
    display: flex;
    justify-content: center;
    column-gap: 43px;
    color: #fff;
    text-align: center;
    font-size: 15px;
    line-height: 1.7;
    position: absolute;
    top: 19%;
    left: 4.5%;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: 500;
    font-style: normal;
}

.sec_tit_fuki-textBox {
    position: absolute;
    top: 7%;
    left: 7%;
}

.sec_tit_fuki-textBox h5 {
    text-align: center;
    color: #51ade5;
    font-size: 26px;
    line-height: 1.8;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: 600;
    font-style: normal;
    letter-spacing: 2px;
    width: 100%;
}

.sec_tit_fuki.box {
    margin: 40px 0;
}

.sec_tit_fuki-textBox .text01 {
    color: #000;
    font-size: 20px;
    line-height: 1.8;
    text-align: left;
    width: 70%;
    margin-left: auto !important;
}

.sec.sec_c18 .sec_tit_fuki {
    font-size: 28px;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: 400;
    font-style: normal;
    padding: 20px;
    line-height: 1.5;
}

.sec.sec_c18 .sec_c18_txt_02 {
    text-align: center;
    color: #00a9e0;
    font-size: 28px;
    line-height: 1.6;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: 600;
    font-style: normal;
    letter-spacing: 2px;
}

.sec.sec_c5 .sec_c5_txt_02 {
    text-align: center;
    color: #444;
    font-size: 28px;
    line-height: 1.6;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: 600;
    font-style: normal;
}

.sec.sec_c5 .sec_c5_txt_02>span {
    color: #00a9e0;
}

.sec.sec_c6 .sec_c6_toku_txt {
    color: #00a9e0;
    text-align: center;
    font-size: 24px;
    line-height: 1.6;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: 600;
    font-style: normal;
    padding: 30px 0;
    letter-spacing: 1px;
}

.sec_c6 .box.whitening .toku_wrap .box_po .txt01 {
    position: absolute;
    top: 42%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: #fff;
    text-align: center;
    font-size: 23px;
    line-height: 1.45;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: 600;
    font-style: normal;
    letter-spacing: 1px;
    width: 100%;
    margin: 0;
}

.sec_c6 .box.whitening .txt_wrap.wrap_03 .desc01 {
    color: #444;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: 600;
    font-style: normal;
    letter-spacing: 1px;
    text-align: center;
    line-height: 1.45;
    font-size: 25px;
}

.sec_c6 .box.whitening .txt_wrap.wrap_03 .desc01 .larg {
    color: #00a9e0;
    font-size: 29px;
}

.sec_c3 .sec_head .head_tit {
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: 33px;
    padding: 37px 0;
    width: 67%;
    margin-left: auto;
    color: #fff;
    line-height: 1.3;
}

.sec_c3 .sec_head .head_tit .clr-yellow {
    font-size: 38px;
}

.sec_c3 .point_cnt .box_img_tp {
    text-align: center;
    font-size: 29px;
    line-height: 1.3;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: 600;
    font-style: normal;
    padding: 20px 0;
}

.sec_c4 .sec_c4_txt_01 {
    text-align: center;
    font-size: 29px;
    line-height: 1.5;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: 600;
    font-style: normal;
    padding: 40px 0 60px;
}

.sec_c5 .box_txt_01 {
    text-align: center;
    font-size: 30px;
    line-height: 1.5;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: 600;
    font-style: normal;
    padding: 30px 0 40px;
}

.sec_c6 .box_img_tp {
    color: #fff;
    text-align: center;
    font-size: 35px;
    line-height: 1.4;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: 600;
    font-style: normal;
    padding: 25px 0;
}

.sec_c6 .toku_wrap .box_img_tp {
    padding: 45px 0 40px;
}

.sec_movie .sec_head>.sec_tit,
.sec_c13 .sec_head>.sec_tit {
    color: #fff;
    text-align: center;
    font-size: 35px;
    line-height: 1.4;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: 600;
    font-style: normal;
    padding: 25px 0;
}

.sec_movie .sec_head>.sec_tit {
    letter-spacing: 3px;
    font-size: 40px;
    padding: 35px 0;
}

.sec_c8 .sec_head>.head_tit {
    color: #fff;
    text-align: center;
    font-size: 38px;
    line-height: 1.4;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: 600;
    font-style: normal;
    padding: 25px 0;
}

.sec_c8 .sec_head>.head_tit .small {
    font-size: 32px;
}

.sec_c8 .sec_head>.head_tit .bigs {
    font-size: 44px;
}

.sec_c8 .point_tit {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 30px 0;
}

.sec_c8 .point_tit>span:nth-child(1) {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background-color: #00a9e0;
    border-radius: 30px;
    padding: 10px 40px;
    position: relative;
    color: #fff;
    text-align: center;
    font-size: 25px;
    line-height: 1.4;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: 600;
    font-style: normal;
    margin-bottom: 20px;
}

.sec_c8 .point_tit>span:nth-child(1)::before {
    content: "";
    position: absolute;
    width: 0;
    height: 0;
    border-left: 10px solid transparent;
    border-right: 10px solid transparent;
    border-top: 10px solid #00a9e0;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1;
}

.sec_c8 .point_tit>span:nth-child(2),
.sec_c8 .point_tit>span:nth-child(3) {
    text-align: center;
    font-size: 32px;
    line-height: 1.4;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: 600;
    font-style: normal;
}

.sec_c8 .point_tit>p {
    text-align: center;
    line-height: 1.5;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: 600;
    font-style: normal;
}

.sec_c8 .point_tit .text01 {
    font-size: 24px;
}

.sec_c8 .point_tit .text02 {
    font-size: 32px;
}

.sec_c18 .head_tit,
.sec_c16 .head_tit,
.sec_c15 .head_tit {
    color: #fff;
    text-align: center;
    font-size: 34px;
    line-height: 1.4;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: 600;
    font-style: normal;
    padding: 35px 0;
}

.sec_c15 .box_blue_line .box_tit {
    color: #00a9e0;
    text-align: center;
    font-size: 30px;
    line-height: 1.6;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: 600;
    font-style: normal;
    padding: 20px 0 25px;
    letter-spacing: 1px;
}

.sec_c16 .box_blue_line .box_img_btm {
    color: #00a9e0;
    text-align: left;
    font-size: 26px;
    line-height: 1.6;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: 600;
    font-style: normal;
    padding: 20px 0 25px;
    letter-spacing: 1px;
    padding-left: 115px;
}

.sec_c20 .head_tit {
    color: #00a9e0;
    text-align: left;
    font-size: 36px;
    line-height: 1.4;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: 600;
    font-style: normal;
    padding: 50px 40px;
    display: flex;
    align-items: flex-end;
}

.sec_c20 .head_tit .c-bigs {
    font-size: 60px;
    line-height: 1;
    margin-left: 15px;
}

.renew_campaign_img_01 .title-larg {
    font-family: "Oregon LDO Medium", sans-serif;
    position: absolute;
    top: 14.15%;
    left: 4.7%;
    font-size: 70px;
    letter-spacing: 15.9px;
    color: transparent;
}

.renew_campaign_img_01 .title-larg .ja {
    font-size: 52px;
    letter-spacing: 1px;
    transform: scale(1, 1.35);
    display: inline-block;
    margin-left: -8px;
}

sup {
    font-size: 10px;
}

.clr-yellow {
    color: #ff0;
}

.clr-blue {
    color: #00a9e0;
}

@media (max-width: 640px) {
    .renew_campaign_img_01 .text01 {
        column-gap: 7.34vw;
    }
    .renew_campaign_img_01 .text01 span {
        font-size: 2.66vw;
    }
    .renew_campaign_img_01 .text02 {
        font-size: 3.28vw;
    }
    .renew_campaign_img_01 .text03 {
        font-size: 2.97vw;
        column-gap: 9.38vw;
    }
    .renew_campaign_img_01 .text04 {
        font-size: 5.31vw;
    }
    .renew_campaign_img_01 .text05 {
        font-size: 3.59vw;
    }
    .renew_campaign_img_02 .text01 {
        font-size: 5.31vw;
    }
    .renew_campaign_img_02 .text02 {
        font-size: 4.06vw;
    }
    .renew_campaign_img_02 .text02 .txtSmall {
        font-size: 3.91vw;
    }
    .renew_campaign_img_02 .text02 .txtNum {
        font-size: 5.94vw;
    }
    .renew_campaign_img_02 sup {
        font-size: 1.56vw;
        top: -2.34vw;
    }
    .renew_campaign_img_03 .text01 {
        font-size: 5.31vw;
    }
    .renew_campaign_img_03 .text02 {
        font-size: 3.44vw;
    }
    .renew_campaign_img_03 .text02 .larg {
        font-size: 4.38vw;
    }
    .sec_c13 .c13_list>h3 {
        font-size: 6.25vw;
        padding: 3.13vw 1.56vw;
    }
    .sec_c13_list_h3 {
        font-size: 4.8vw;
        width: 100%;
    }
    .sec_c13_list ul {
        gap: 5.22vw;
        font-size: 3.9vw;
        left: 54%;
    }
    .sec_c13_list .note {
        font-size: 2.19vw;
        left: 55%;
        top: 74%;
    }
    .sec_c13 .sec_inner .heading {
        font-size: 3.9vw;
    }
    .sec_c8 .box .box_left .img-s {
        margin: 6.25vw;
    }
    .sec_c8_po1_box_02 {
        column-gap: 8vw;
        font-size: 2.54vw;
    }
    .sec_tit_fuki-textBox h5 {
        font-size: 3.26vw;
    }
    .sec_tit_fuki.box {
        margin: 6.25vw;
    }
    .sec_tit_fuki-textBox .text01 {
        font-size: 3.13vw;
    }
    .sec.sec_c18 .sec_tit_fuki {
        font-size: 4.38vw;
        padding: 3.13vw;
    }
    .sec.sec_c18 .sec_c18_txt_02 {
        font-size: 4.38vw;
    }
    .sec.sec_c5 .sec_c5_txt_02 {
        font-size: 4.38vw;
    }
    .sec.sec_c6 .sec_c6_toku_txt {
        font-size: 3.75vw;
        padding: 4.69vw 0;
    }
    .sec_c6 .box.whitening .toku_wrap .box_po .txt01 {
        font-size: 3.59vw;
    }
    .sec_c6 .box.whitening .txt_wrap.wrap_03 .desc01 {
        font-size: 3.91vw;
    }
    .sec_c6 .box.whitening .txt_wrap.wrap_03 .desc01 .larg {
        font-size: 4.4vw;
    }
    .sec_c3 .sec_head .head_tit {
        font-size: 5.16vw;
        padding: 5.78vw 0;
    }
    .sec_c3 .sec_head .head_tit .clr-yellow {
        font-size: 5.94vw;
    }
    .sec_c3 .point_cnt .box_img_tp {
        font-size: 4.53vw;
        padding: 3.13vw 0;
    }
    .sec_c4 .sec_c4_txt_01 {
        font-size: 4.53vw;
        padding: 6.25vw 0 9.38vw;
    }
    .sec_c5 .box_txt_01 {
        font-size: 4.69vw;
        padding: 4.69vw 0 6.25vw;
    }
    .sec_c6 .box_img_tp {
        font-size: 5.47vw;
        padding: 3.91vw 0;
    }
    .sec_c6 .toku_wrap .box_img_tp {
        padding: 7.03vw 0 6.25vw;
    }
    .sec_movie .sec_head>.sec_tit {
        font-size: 6.25vw;
        padding: 5.46875vw 0;
    }
    .sec_c13 .sec_head>.sec_tit {
        font-size: 5.47vw;
        padding: 3.91vw 0;
    }
    .sec_c8 .sec_head>.head_tit {
        font-size: 5.94vw;
        padding: 3.91vw 0;
    }
    .sec_c8 .sec_head>.head_tit .small {
        font-size: 5vw;
    }
    .sec_c8 .sec_head>.head_tit .bigs {
        font-size: 6.88vw;
    }
    .sec_c8 .point_tit {
        padding: 4.69vw 0;
    }
    .sec_c8 .point_tit>span:nth-child(1) {
        border-radius: 4.69vw;
        padding: 1.56vw 6.25vw;
        font-size: 3.91vw;
        margin-bottom: 3.13vw;
    }
    .sec_c8 .point_tit>span:nth-child(1)::before {
        border-left: 1.56vw solid transparent;
        border-right: 1.56vw solid transparent;
        border-top: 1.56vw solid #00a9e0;
    }
    .sec_c8 .point_tit>span:nth-child(2),
    .sec_c8 .point_tit>span:nth-child(3) {
        font-size: 5vw;
    }
    .sec_c8 .point_tit .text01 {
        font-size: 3.75vw;
    }
    .sec_c8 .point_tit .text02 {
        font-size: 5vw;
    }
    .sec_c18 .head_tit,
    .sec_c16 .head_tit,
    .sec_c15 .head_tit {
        font-size: 5.31vw;
        padding: 5.47vw 0;
    }
    .sec_c15 .box_blue_line .box_tit {
        font-size: 4.69vw;
        padding: 3.13vw 0 3.91vw;
    }
    .sec_c16 .box_blue_line .box_img_btm {
        font-size: 4.06vw;
        padding: 3.13vw 0 3.91vw;
        padding-left: 17.97vw;
    }
    .sec_c20 .head_tit {
        font-size: 5.625vw;
        padding: 7.8125vw 6.25vw;
    }
    .sec_c20 .head_tit .c-bigs {
        font-size: 9.375vw;
        margin-left: 2.34375vw;
    }
    .renew_campaign_img_01 .title-larg {
        font-size: 10.9375vw;
        letter-spacing: 2.484375vw;
    }
    .renew_campaign_img_01 .title-larg .ja {
        font-size: 8.125vw;
        margin-left: -1.25vw;
    }
}


/* ADD SLIDER */

.sec_movie .sec_head {
    margin-bottom: 0 !important;
    margin-top: 30px;
}

.sec_movie .box-slider {
    /* max-width: 80%; */
    background-color: #fff;
    margin: 0 auto;
    padding: 30px 0;
}

.sec_movie .box-slider .slider {
    max-width: 80%;
    margin: 0 auto;
}

.sec_movie .box-slider .slick-list {
    border-radius: 18px;
}

.sec_movie .slick-dots {
    display: flex;
    justify-content: center;
    margin-top: 15px;
}

.sec_movie .slick-dots li {
    position: relative;
    display: inline-block;
    width: 20px;
    height: 20px;
    margin: 0 5px;
    padding: 0;
    cursor: pointer;
}

.sec_movie .slick-dots li button {
    font-size: 0;
    line-height: 0;
    display: block;
    width: 20px;
    height: 20px;
    padding: 5px;
    cursor: pointer;
    color: transparent;
    border: 0;
    outline: 0;
    background: 0 0;
}

.sec_movie .slick-dots li button:before {
    font-size: 28px;
    line-height: 20px;
    position: absolute;
    top: 0;
    left: 0;
    width: 20px;
    height: 20px;
    content: "•";
    text-align: center;
    opacity: 0.25;
    color: #000;
}

.sec_movie .slick-dots li.slick-active button:before {
    opacity: 1;
}

@media not screen,
screen and (min-width: 768px) {
    .sec_movie .sec_inner {
        padding: 0px 0 40px 0;
    }
}

.sec_movie {
    background-color: #d6f2ff;
}

.sec_movie .sec_inner .inner {
    padding-top: 30px;
}

.sec_movie .txt_note {
    text-align: right;
    font-size: clamp(9px, 1.73333vw, 12px);
    color: #3d3d3d;
    line-height: 1.6;
    padding: 0 5.5% 30px;
}


/* 24-10-11 */

.renewal-list .heading {
    background-color: #00a9e0;
    padding: 20px;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    text-align: center;
    font-size: 35px;
    color: #fff;
    line-height: 1.5;
    letter-spacing: 0.1em;
    font-weight: bold;
}

.renewal-list ul {
    position: absolute;
    display: flex;
    flex-wrap: wrap;
    gap: 157px 25px;
    left: 50%;
    top: 26%;
    justify-content: center;
    width: 85%;
    transform: translateX(-50%);
}

.renewal-list ul li {
    width: calc(100% / 2 - 80px);
}

.renewal-list ul li span {
    display: block;
}

.clr-yellow-light {
    color: #fff4a3;
}

.renewal-list ul li span:nth-child(1) {
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    text-align: center;
    font-size: 20px;
    color: #444;
    line-height: 1.5;
}

.renewal-list ul li span:nth-child(2) {
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    text-align: center;
    font-size: 14px;
    color: #444;
    line-height: 1.5;
}

.renewal-list_note {
    text-align: left;
    font-size: 12px;
    line-height: 1.7;
    padding: 0 4% 5%;
}

video.vcl02 {
    max-width: 100%;
    width: 100%;
    margin: 0 auto;
    display: block;
}

.sec_treatment {
    padding-bottom: 40px;
    font-size: 16px;
}

.sec_treatment_pic {
    max-width: 85%;
    margin: 0 auto;
}

.sec_treatment .sec_head {
    padding: 30px 0;
}

.sec_treatment .sec_head .head_tit {
    font-size: 35px;
    text-align: center;
    line-height: 1.6;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: bold;
    letter-spacing: 3px;
}

.sec_treatment .text_treatment {
    text-align: center;
    padding: 30px 0 50px;
    font-size: 30px;
    line-height: 1.6;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: bold;
    letter-spacing: 2px;
}

.sec_c5 .att2 {
    line-height: 1.8 !important;
}

.fv_tit {
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    text-align: center;
    font-size: 37px;
    line-height: 1.5;
    position: absolute;
    color: #fff4a3;
    font-weight: bold;
    top: 1.5%;
    right: 3.5%;
    z-index: 1;
}

.fv_text01 {
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    text-align: center;
    font-size: 25px;
    line-height: 1.5;
    position: absolute;
    color: #fff;
    font-weight: bold;
    top: 38%;
    left: 6.7%;
    z-index: 1;
}

.fv_text01 .small {
    font-size: 18px;
}

@media (max-width: 640px) {
    .fv_tit {
        font-size: 5.781vw;
    }
    .renewal-list .heading {
        padding: 3.125vw;
        font-size: 5.469vw;
    }
    .renewal-list ul {
        gap: 24.531vw 3.906vw;
    }
    .renewal-list ul li {
        width: 34%;
    }
    .renewal-list ul li span:nth-child(1) {
        font-size: 3.125vw;
    }
    .renewal-list ul li span:nth-child(2) {
        font-size: 2.188vw;
    }
    .renewal-list_note {
        font-size: 1.875vw;
    }
    .fv_text01 {
        font-size: 3.906vw;
    }
    .fv_text01 .small {
        font-size: 2.813vw;
    }
    .sec_treatment .sec_head .head_tit {
        font-size: 5.46875vw;
    }
    .sec_treatment {
        padding-bottom: 6.25vw;
        font-size: 2.5vw;
    }
    .sec_treatment .sec_head {
        padding: 4.6875vw 0;
    }
    .sec_treatment .sec_head .head_tit {
        font-size: 5.46875vw;
    }
    .sec_treatment .text_treatment {
        padding: 4.6875vw 0 7.8125vw;
        font-size: 4.6875vw;
    }
}

.top-menu-sp .nav-social .nav-item .nav-link {
    max-width: 750px;
    margin: 0 auto;
    width: 80%;
    height: auto;
}

.top-menu-sp .nav-social .nav-item .nav-link img {
    width: 75%;
}


/* Custom 241211 */

.btnLink {
    position: relative;
}

.btnLink h3 {
    position: absolute;
    top: 12.5%;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    text-align: center;
    z-index: 1;
    font-size: 32px;
    color: #fcf4a4;
    font-family: "a-otf-ud-shin-maru-go-pr6n", sans-serif;
    font-weight: bold;
    letter-spacing: 0.1em;
}

.btnLink>a {
    position: absolute;
    bottom: 17%;
    left: 10%;
    width: 80%;
    z-index: 1;
    -webkit-animation-iteration-count: infinite;
    animation-iteration-count: infinite;
    -webkit-animation-name: pulse;
    animation-name: pulse;
    -webkit-animation-duration: 1.5s;
    animation-duration: 1.5s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
}

@media screen and (max-width: 640px) {
    .btnLink h3 {
        font-size: 5vw;
    }
}

.mv-btn {
    position: absolute;
    bottom: 25px;
    left: 0;
    width: 86%;
    right: 0;
    margin: auto;
    animation-iteration-count: infinite;
    animation-name: pulse;
    animation-duration: 1.5s;
    animation-fill-mode: both;
}

@media (max-width: 767px) {
    .mv-btn {
        bottom: 4vw;
    }
}

.notes {
    position: absolute;
    width: 100%;
    left: 0;
    padding: 0 8%;
    top: 78%;
    text-align: right;
    font-size: min(calc(14 / 750 * 100vw), 14px);
}


/* add case */

.case {
    color: #333333
}

.bg_blue {
    background-color: #00a9e0;
}

.txt_white {
    color: #fff;
}

.poA {
    position: absolute;
    width: 100%;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1;
}

.case .title {
    font-family: "Noto Serif JP", serif;
    font-size: 30px;
    font-weight: 500;
    line-height: 1.8;
    text-align: center;
}

.case .titSub {
    font-family: "Noto Serif JP", serif;
    text-align: center;
    font-size: 44px;
    font-weight: 500;
    line-height: 1.6;
}

.case .titSub>span {
    font-family: "Noto Serif JP", serif;
    line-height: 1.2;
    display: inline-block;
}

.case .price {
    padding: 0 80px;
    text-align: center;
}

.case .price .head {
    font-family: "Noto Serif JP", serif;
    font-size: 28px;
    line-height: 1.7;
    color: #00a9e0;
    font-weight: 500;
}

.case .price .head>span {
    font-size: 32px;
    display: inline-block;
    line-height: 1;
}

.case .price ul {
    margin-top: 20px;
    list-style: none;
}

.case .price ul li {
    font-family: "Noto Serif JP", serif;
    font-size: 22px;
    line-height: 1.7;
    color: #00a9e0;
    font-weight: 500;
    margin-top: 5px;
}

.case .price ul li {
    font-family: "Noto Serif JP", serif;
    font-size: 22px;
    line-height: 1.7;
    color: #00a9e0;
    font-weight: 500;
    margin-top: 5px;
}

.case .price ul li>span {
    font-size: 28px;
    display: inline-block;
    line-height: 1;
}

.case .price ul li .font-myriad {
    font-size: 34px;
    line-height: 1;
    display: inline-block;
    transform: translateY(0.2rem);
}

.case .price .txt_note {
    font-size: 16px;
    padding-right: 90px;
    text-align: right;
    margin-top: 5px;
    line-height: 1.8;
}

.case .text {
    padding: 0 70px;
}

.case .text li {
    display: flex;
    gap: 10px;
}

.case .text li>span {
    font-size: 22px;
    font-weight: 500;
    text-align: left;
    line-height: 1.7;
}

.case01 .text li>span:nth-child(1) {
    width: 24%;
}

.case01 .text li>span:nth-child(2) {
    width: 76%;
}

.case .note {
    padding: 0 55px;
    font-size: 16px;
    text-align: left;
    line-height: 1.7;
}


/* case01 */

.case01 .title {
    top: 8.5%;
}

.case01 .titSub {
    top: 16.5%;
}

.case01 .price {
    top: 39%;
    right: 0;
}

.case01 .text {
    top: 78.1%;
}

.case01 .note {
    top: 89%;
}


/* case 02 */

.case02 .price {
    top: 10.5%;
    right: 0;
}

.case02 .text {
    top: 68.5%;
}

.case02 .note {
    top: 84.5%;
}


/* case 3 */

.case03 .price {
    top: 8.2%;
    right: 0;
}

.case03 .text {
    top: 53.5%;
}

.case03 .note {
    top: 67%;
}

.case03 .btn-modal {
    bottom: 9.5%;
    text-align: center;
    transition: opacity 0.3s ease;
}

.case03 .btn-modal:hover {
    opacity: 0.7;
}

.case03 .btn-modal>button {
    width: 90%;
    margin: 0 auto;
    border: none;
    outline: none;
    background-color: transparent;
    cursor: pointer;
}

@media (max-width: 639px) {
    .case .title {
        font-size: 4.688vw;
    }
    .case .titSub {
        font-size: 6.875vw;
    }
    .case .price {
        padding: 0 12.5vw;
    }
    .case .price .head {
        font-size: 4.375vw;
    }
    .case .price .head>span {
        font-size: 5vw;
    }
    .case .price ul {
        margin-top: 3.125vw;
    }
    .case .price ul li {
        font-size: 3.438vw;
        margin-top: 0.781vw;
    }
    .case .price ul li {
        font-size: 3.438vw;
        margin-top: 0.781vw;
    }
    .case .price ul li>span {
        font-size: 4.375vw;
    }
    .case .price ul li .font-myriad {
        font-size: 5.313vw;
    }
    .case .price .txt_note {
        font-size: 2.5vw;
        padding-right: 14.063vw;
        margin-top: 0.781vw;
    }
    .case .text {
        padding: 0 10.938vw;
    }
    .case .text li {
        gap: 1.563vw;
    }
    .case .text li>span {
        font-size: 3.438vw;
    }
    .case .note {
        padding: 0 8.594vw;
        font-size: 2.5vw;
    }
}


/* Modal styles */

.modal {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 99999;
    justify-content: center;
    align-items: center;
    padding: 4rem;
}

.modal-inner {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 100%;
}

.modal-content {
    background-color: white;
    width: 100%;
    max-width: 640px;
    max-height: 80vh;
    display: flex;
    flex-direction: column;
    position: relative;
    padding: 15px 0 15px 15px;
}

.close-modal {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    position: absolute;
    background-color: #00A9E0;
    top: -40px;
    right: -40px;
    cursor: pointer;
}

.close-modal::before,
.close-modal::after {
    content: "";
    position: absolute;
    background-color: #fff;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(45deg);
    z-index: 1;
}

.close-modal::before {
    width: 20px;
    height: 2px;
}

.close-modal::after {
    height: 20px;
    width: 2px;
}

.modal-body {
    overflow-y: auto;
    height: 100%;
    padding-right: 13px;
}

.sample-content .boxIn+.boxIn {
    margin-top: 40px;
}

.sample-content .price {
    margin-top: 20px;
    background-color: rgba(0, 169, 224, 0.15);
    padding: 20px 30px;
}

.sample-content .price ul {
    list-style: none;
    border-bottom: 1px dashed #333333;
    padding: 15px 0;
}

.sample-content .price ul:first-child {
    padding: 0 0 15px;
}

.sample-content .price ul:last-child {
    border: none;
    padding: 15px 0 0;
}

.sample-content .price ul>li {
    display: flex;
    font-size: 18px;
    line-height: 1.6;
    color: #333;
}

.sample-content .price ul>li>span:nth-child(1) {
    width: 150px;
    display: block;
}

.sample-content .price ul>li>span:nth-child(2) {
    width: calc(100% - 150px);
    display: block;
}

.modal-body::-webkit-scrollbar {
    width: 6px;
}

.modal-body::-webkit-scrollbar-track {
    background: #f1f1f1;
    border-radius: 4px;
}

.modal-body::-webkit-scrollbar-thumb {
    background: #afafaf;
    border-radius: 4px;
}

@media screen and (max-width: 639px) {
    .modal {
        padding: 6.25vw;
    }
    .modal-content {
        padding: 2.344vw 0 2.344vw 2.344vw;
    }
    .close-modal {
        width: 6.25vw;
        height: 6.25vw;
        top: -6.25vw;
        right: -5.25vw;
    }
    .close-modal::before {
        width: 3.125vw;
        height: 0.313vw;
    }
    .close-modal::after {
        height: 3.125vw;
        width: 0.313vw;
    }
    .modal-body {
        padding-right: 2.031vw;
    }
    .sample-content .boxIn+.boxIn {
        margin-top: 6.25vw;
    }
    .sample-content .price {
        margin-top: 3.125vw;
        padding: 3.125vw 4.688vw;
    }
    .sample-content .price ul {
        padding: 2.344vw 0;
    }
    .sample-content .price ul:first-child {
        padding: 0 0 2.344vw;
    }
    .sample-content .price ul:last-child {
        padding: 2.344vw 0 0;
    }
    .sample-content .price ul>li {
        font-size: 2.813vw;
    }
    .sample-content .price ul>li>span:nth-child(1) {
        width: 23.438vw;
    }
    .sample-content .price ul>li>span:nth-child(2) {
        width: calc(100% - 23.438vw);
    }
    .modal-body::-webkit-scrollbar {
        width: 0.938vw;
    }
    .modal-body::-webkit-scrollbar-track {
        border-radius: 0.625vw;
    }
    .modal-body::-webkit-scrollbar-thumb {
        border-radius: 0.625vw;
    }
    body.modal-open {
        overflow: hidden;
    }
}