@charset "utf-8";
/*
Theme Name: res
Version: 1.2.4
Author: T8,Inc.
*/
@import url('https://fonts.googleapis.com/css?family=Noto+Sans+JP:300,400,700&display=swap');

:root {
    --break: 1920;
    --guideline-color: #30c9db;
    font-size: calc(16 / var(--break) * 100vw);
    --color01: #3B3B3B;
    --color02: #8FDD2A;
    --color03: #30C9DB;
    --color04: #9185CD;
    --color05: #825245;
    --color06: #F3F3F3;
    --color07: #F9F8EB;
    --color08: #FF8EAE;
    --color09: #FF9C27;
    --color10: #FFF958;

    --size5px: calc(5 / var(--break) * 100vw);
    --size10px: calc(10 / var(--break) * 100vw);
    --size15px: calc(15 / var(--break) * 100vw);
    --size20px: calc(20 / var(--break) * 100vw);
    --size25px: calc(25 / var(--break) * 100vw);
    --size30px: calc(30 / var(--break) * 100vw);
    --size35px: calc(35 / var(--break) * 100vw);
    --size40px: calc(40 / var(--break) * 100vw);
    --size45px: calc(45 / var(--break) * 100vw);
    --size50px: calc(50 / var(--break) * 100vw);
    --size55px: calc(55 / var(--break) * 100vw);
    --size60px: calc(60/ var(--break) * 100vw);
    --size65px: calc(65 / var(--break) * 100vw);
    --size70px: calc(70 / var(--break) * 100vw);
    --size75px: calc(75 / var(--break) * 100vw);
    --size80px: calc(80 / var(--break) * 100vw);
    --size85px: calc(85 / var(--break) * 100vw);
    --size90px: calc(90 / var(--break) * 100vw);
    --size95px: calc(95 / var(--break) * 100vw);
    --size100px: calc(100 / var(--break) * 100vw);
    --size105px: calc(105 / var(--break) * 100vw);
    --size110px: calc(110 / var(--break) * 100vw);
    --size115px: calc(115 / var(--break) * 100vw);
    --size120px: calc(120 / var(--break) * 100vw);
    --size125px: calc(125 / var(--break) * 100vw);
    --size130px: calc(130 / var(--break) * 100vw);
    --size135px: calc(135 / var(--break) * 100vw);
    --size140px: calc(140 / var(--break) * 100vw);
    --size145px: calc(145 / var(--break) * 100vw);
    --size150px: calc(150 / var(--break) * 100vw);
    --size160px: calc(160 / var(--break) * 100vw);
    --size170px: calc(170 / var(--break) * 100vw);
    --size180px: calc(180 / var(--break) * 100vw);
    --size190px: calc(190 / var(--break) * 100vw);
    --size200px: calc(200 / var(--break) * 100vw);
}

@media(min-width: 768px) and (max-width: 1599px) {
    :root {
        --break: 1599;
    }
}

@media(min-width: 768px) and (max-width: 1299px) {
    :root {
        --break: 1299;
    }
}

@media(max-width:767px) {
    :root {
        --break: 750;
    }
}

/*サイト別フォント・カラー設定*/
.txt_link {
    color: #333333;
    text-decoration: underline;
}

/*ここまで*/
html,
body {
    font-size: 1.125rem;
    font-weight: 300;
    line-height: 2;
    color: #333333;
    letter-spacing: .1em;
    font-family: "Noto Sans JP", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.fwn {
    font-weight: normal;
}

.fwb {
    font-weight: bold;
}

img {
    max-width: 100%;
    height: auto;
}

iframe {
    max-width: 100%;
}

video {
    max-width: 100%;
}

* {
    margin: 0;
    padding: 0;
}

li {
    list-style: none;
}

a {
    color: inherit;
    text-decoration: none;
}

#wrap {
    overflow-x: hidden;
}

.oh {
    overflow: hidden;
}

a:hover {
    opacity: .85;
    transition: .3s;
}

a.zoom {
    pointer-events: none;
}

.inner,
.inner1000,
.inner1140,
.inner1200,
.inner1340,
.inner1500 {
    max-width: 1240px;
    width: 90%;
    margin: 0 auto;
}

.inner1000 {
    max-width: 1000px;
}

.inner1140 {
    max-width: 1140px;
}

.inner1200 {
    max-width: 1200px;
}

.inner1340 {
    max-width: 1340px;
}

.inner1500 {
    max-width: 1500px;
}

.w100 {
    width: 100% !important;
}

table {
    table-layout: fixed;
}

td input {
    max-width: 100%;
}

a[href^="tel:"] {
    cursor: default;
}

a[href^="tel:"]:hover {
    opacity: 1;
}

.slick-slide {
    outline: none;
}

.adjust {
    display: none;
}

.tb_only {
    display: none;
}

.sp_only {
    display: none;
}

.tb_pc {
    display: inherit;
}

.sp_tb {
    display: none;
}

.flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-align-items: flex-start;
    align-items: flex-start;
}

.flex.start {
    -webkit-justify-content: flex-start;
    justify-content: flex-start;
}

.flex.end {
    -webkit-justify-content: flex-end;
    justify-content: flex-end;
}

.flex.center {
    -webkit-justify-content: center;
    justify-content: center;
}

.flex.around {
    -webkit-justify-content: space-around;
    justify-content: space-around;
}

.flex.between {
    -webkit-justify-content: space-between;
    justify-content: space-between;
}

.flex.stretch {
    -webkit-align-items: stretch;
    align-items: stretch;
}

.flex.ai_center {
    -webkit-align-items: center;
    align-items: center;
}

.flex.ai_start {
    -webkit-align-items: flex-start;
    align-items: flex-start;
}

.flex.ai_end {
    -webkit-align-items: flex-end;
    align-items: flex-end;
}

.flex.nowrap {
    -webkit-flex-wrap: nowrap;
    flex-wrap: nowrap;
}

.flex.column {
    -ms-flex-direction: column;
    -webkit-flex-direction: column;
    flex-direction: column;
}

.flex.row {
    -ms-flex-direction: row;
    -webkit-flex-direction: row;
    flex-direction: row;
}

.flex.c_reverse {
    -ms-flex-direction: column-reverse;
    -webkit-flex-direction: column-reverse;
    flex-direction: column-reverse;
}

.flex.r_reverse {
    -ms-flex-direction: row-reverse;
    -webkit-flex-direction: row-reverse;
    flex-direction: row-reverse;
}

.flex.cc {
    -webkit-align-items: center;
    align-items: center;
    -webkit-justify-content: center;
    justify-content: center;
}

.flex.ccc {
    -webkit-align-items: center;
    align-items: center;
    -webkit-justify-content: center;
    justify-content: center;
    text-align: center;
}

.flex.cccc {
    -webkit-align-items: center;
    align-items: center;
    -webkit-justify-content: center;
    justify-content: center;
    text-align: center;
    -webkit-flex-direction: column;
    flex-direction: column;
}

.noshrink {
    flex: 0 0 auto;
}

.grow {
    flex: 1 1 auto;
}

.ccl {
    border-radius: 100%;
}

.bdrd5 {
    border-radius: var(--size5px);
}

.bdrd10 {
    border-radius: var(--size10px);
}

.bdrd15 {
    border-radius: var(--size15px);
}

.bdrd20 {
    border-radius: var(--size20px);
}

.bdrd25 {
    border-radius: var(--size25px);
}

.bdrd30 {
    border-radius: var(--size30px);
}

.bdrd35 {
    border-radius: var(--size35px);
}

.bdrd40 {
    border-radius: var(--size40px);
}

.bdrd45 {
    border-radius: var(--size45px);
}

.bdrd50 {
    border-radius: var(--size50px);
}

.txt_center {
    text-align: center;
}

.txt_right {
    text-align: right;
}

.txt_rl {
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    text-orientation: upright;
}

.mgn_a {
    margin-left: auto;
    margin-right: auto;
}

.mgn_l {
    margin-left: auto;
}

.mgn_r {
    margin-right: auto;
}

.no_mgn {
    margin-bottom: 0 !important;
}

.mb5 {
    margin-bottom: var(--size5px);
}

.mb10 {
    margin-bottom: var(--size10px);
}

.mb15 {
    margin-bottom: var(--size15px);
}

.mb20 {
    margin-bottom: var(--size20px);
}

.mb25 {
    margin-bottom: var(--size25px);
}

.mb30 {
    margin-bottom: var(--size30px);
}

.mb35 {
    margin-bottom: var(--size35px);
}

.mb40 {
    margin-bottom: var(--size40px);
}

.mb45 {
    margin-bottom: var(--size45px);
}

.mb50 {
    margin-bottom: var(--size50px);
}

.mb55 {
    margin-bottom: var(--size55px);
}

.mb60 {
    margin-bottom: var(--size60px);
}

.mb65 {
    margin-bottom: var(--size65px);
}

.mb70 {
    margin-bottom: var(--size70px);
}

.mb75 {
    margin-bottom: var(--size75px);
}

.mb80 {
    margin-bottom: var(--size80px);
}

.mb85 {
    margin-bottom: var(--size85px);
}

.mb90 {
    margin-bottom: var(--size90px);
}

.mb95 {
    margin-bottom: var(--size95px);
}

.mb100 {
    margin-bottom: var(--size100px);
}

.mb105 {
    margin-bottom: var(--size105px);
}

.mb110 {
    margin-bottom: var(--size110px);
}

.mb115 {
    margin-bottom: var(--size115px);
}

.mb120 {
    margin-bottom: var(--size120px);
}

.mb125 {
    margin-bottom: var(--size125px);
}

.mb130 {
    margin-bottom: var(--size130px);
}

.mb135 {
    margin-bottom: var(--size135px);
}

.mb140 {
    margin-bottom: var(--size140px);
}

.mb145 {
    margin-bottom: var(--size145px);
}

.mb150 {
    margin-bottom: var(--size150px);
}

.mb05em {
    margin-bottom: 0.5em;
}

.mb10em {
    margin-bottom: 1.0em;
}

.mb15em {
    margin-bottom: 1.5em;
}

.mb20em {
    margin-bottom: 2.0em;
}

.mb25em {
    margin-bottom: 2.5em;
}

.mb30em {
    margin-bottom: 3.0em;
}

.mt5 {
    margin-top: var(--size5px);
}

.mt10 {
    margin-top: var(--size10px);
}

.mt15 {
    margin-top: var(--size15px);
}

.mt20 {
    margin-top: var(--size20px);
}

.mt25 {
    margin-top: var(--size25px);
}

.mt30 {
    margin-top: var(--size30px);
}

.mt35 {
    margin-top: var(--size35px);
}

.mt40 {
    margin-top: var(--size40px);
}

.mt45 {
    margin-top: var(--size45px);
}

.mt50 {
    margin-top: var(--size50px);
}

.mt55 {
    margin-top: var(--size55px);
}

.mt60 {
    margin-top: var(--size60px);
}

.mt65 {
    margin-top: var(--size65px);
}

.mt70 {
    margin-top: var(--size70px);
}

.mt75 {
    margin-top: var(--size75px);
}

.mt80 {
    margin-top: var(--size80px);
}

.mt85 {
    margin-top: var(--size85px);
}

.mt90 {
    margin-top: var(--size90px);
}

.mt95 {
    margin-top: var(--size95px);
}

.mt100 {
    margin-top: var(--size100px);
}

.mt105 {
    margin-top: var(--size105px);
}

.mt110 {
    margin-top: var(--size110px);
}

.mt115 {
    margin-top: var(--size115px);
}

.mt120 {
    margin-top: var(--size120px);
}

.mt125 {
    margin-top: var(--size125px);
}

.mt130 {
    margin-top: var(--size130px);
}

.mt135 {
    margin-top: var(--size135px);
}

.mt140 {
    margin-top: var(--size140px);
}

.mt145 {
    margin-top: var(--size145px);
}

.mt150 {
    margin-top: var(--size150px);
}

.mt05em {
    margin-top: 0.5em;
}

.mt10em {
    margin-top: 1.0em;
}

.mt15em {
    margin-top: 1.5em;
}

.mt20em {
    margin-top: 2.0em;
}

.mt25em {
    margin-top: 2.5em;
}

.mt30em {
    margin-top: 3.0em;
}

.mr5 {
    margin-right: var(--size5px);
}

.mr10 {
    margin-right: var(--size10px);
}

.mr15 {
    margin-right: var(--size15px);
}

.mr20 {
    margin-right: var(--size20px);
}

.mr25 {
    margin-right: var(--size25px);
}

.mr30 {
    margin-right: var(--size30px);
}

.mr35 {
    margin-right: var(--size35px);
}

.mr40 {
    margin-right: var(--size40px);
}

.mr45 {
    margin-right: var(--size45px);
}

.mr50 {
    margin-right: var(--size50px);
}

.ml5 {
    margin-left: var(--size5px);
}

.ml10 {
    margin-left: var(--size10px);
}

.ml15 {
    margin-left: var(--size15px);
}

.ml20 {
    margin-left: var(--size20px);
}

.ml25 {
    margin-left: var(--size25px);
}

.ml30 {
    margin-left: var(--size30px);
}

.ml35 {
    margin-left: var(--size35px);
}

.ml40 {
    margin-left: var(--size40px);
}

.ml45 {
    margin-left: var(--size45px);
}

.ml50 {
    margin-left: var(--size50px);
}

.db {
    display: block;
}

.dib {
    display: inline-block;
}

.por {
    position: relative;
    z-index: 1;
}

.poa {
    position: absolute;
}

.zi0 {
    z-index: 0;
}

.zi1 {
    z-index: 1;
}

.zi2 {
    z-index: 2;
}

.turn_up {
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
}

.lh1 {
    line-height: 1;
}

.lh11 {
    line-height: 1.1;
}

.lh12 {
    line-height: 1.2;
}

.lh13 {
    line-height: 1.3;
}

.lh14 {
    line-height: 1.4;
}

.lh15 {
    line-height: 1.5;
}

.lh16 {
    line-height: 1.6;
}

.lh17 {
    line-height: 1.7;
}

.lh18 {
    line-height: 1.8;
}

.lh19 {
    line-height: 1.9;
}

.lh2 {
    line-height: 2;
}

.lh22 {
    line-height: 2.2;
}

.lh25 {
    line-height: 2.5;
}

.pt0 {
    padding-top: 0;
}

.pt5 {
    padding-top: var(--size5px);
}

.pt10 {
    padding-top: var(--size10px);
}

.pt15 {
    padding-top: var(--size15px);
}

.pt20 {
    padding-top: var(--size20px);
}

.pt25 {
    padding-top: var(--size25px);
}

.pt30 {
    padding-top: var(--size30px);
}

.pt35 {
    padding-top: var(--size35px);
}

.pt40 {
    padding-top: var(--size40px);
}

.pt45 {
    padding-top: var(--size45px);
}

.pt50 {
    padding-top: var(--size50px);
}

.pt55 {
    padding-top: var(--size55px);
}

.pt60 {
    padding-top: var(--size60px);
}

.pt65 {
    padding-top: var(--size65px);
}

.pt70 {
    padding-top: var(--size70px);
}

.pt75 {
    padding-top: var(--size75px);
}

.pt80 {
    padding-top: var(--size80px);
}

.pt85 {
    padding-top: var(--size85px);
}

.pt90 {
    padding-top: var(--size90px);
}

.pt95 {
    padding-top: var(--size95px);
}

.pt100 {
    padding-top: var(--size100px);
}

.pt105 {
    padding-top: var(--size105px);
}

.pt110 {
    padding-top: var(--size110px);
}

.pt115 {
    padding-top: var(--size115px);
}

.pt120 {
    padding-top: var(--size120px);
}

.pt125 {
    padding-top: var(--size125px);
}

.pt130 {
    padding-top: var(--size130px);
}

.pt135 {
    padding-top: var(--size135px);
}

.pt140 {
    padding-top: var(--size140px);
}

.pt145 {
    padding-top: var(--size145px);
}

.pt150 {
    padding-top: var(--size150px);
}

.pt160 {
    padding-top: var(--size160px);
}

.pt170 {
    padding-top: var(--size170px);
}

.pt180 {
    padding-top: var(--size180px);
}

.pt190 {
    padding-top: var(--size190px);
}

.pt200 {
    padding-top: var(--size200px);
}

.pb0 {
    padding-bottom: 0;
}

.pb5 {
    padding-bottom: var(--size5px);
}

.pb10 {
    padding-bottom: var(--size10px);
}

.pb15 {
    padding-bottom: var(--size15px);
}

.pb20 {
    padding-bottom: var(--size20px);
}

.pb25 {
    padding-bottom: var(--size25px);
}

.pb30 {
    padding-bottom: var(--size30px);
}

.pb35 {
    padding-bottom: var(--size35px);
}

.pb40 {
    padding-bottom: var(--size40px);
}

.pb45 {
    padding-bottom: var(--size45px);
}

.pb50 {
    padding-bottom: var(--size50px);
}

.pb55 {
    padding-bottom: var(--size55px);
}

.pb60 {
    padding-bottom: var(--size60px);
}

.pb65 {
    padding-bottom: var(--size65px);
}

.pb70 {
    padding-bottom: var(--size70px);
}

.pb75 {
    padding-bottom: var(--size75px);
}

.pb80 {
    padding-bottom: var(--size80px);
}

.pb85 {
    padding-bottom: var(--size85px);
}

.pb90 {
    padding-bottom: var(--size90px);
}

.pb95 {
    padding-bottom: var(--size95px);
}

.pb100 {
    padding-bottom: var(--size100px);
}

.pb105 {
    padding-bottom: var(--size105px);
}

.pb110 {
    padding-bottom: var(--size110px);
}

.pb115 {
    padding-bottom: var(--size115px);
}

.pb120 {
    padding-bottom: var(--size120px);
}

.pb125 {
    padding-bottom: var(--size125px);
}

.pb130 {
    padding-bottom: var(--size130px);
}

.pb135 {
    padding-bottom: var(--size135px);
}

.pb140 {
    padding-bottom: var(--size140px);
}

.pb145 {
    padding-bottom: var(--size145px);
}

.pb150 {
    padding-bottom: var(--size150px);
}

.pb160 {
    padding-bottom: var(--size160px);
}

.pb170 {
    padding-bottom: var(--size170px);
}

.pb180 {
    padding-bottom: var(--size180px);
}

.pb190 {
    padding-bottom: var(--size190px);
}

.pb200 {
    padding-bottom: var(--size200px);
}

.pr5 {
    padding-right: var(--size5px);
}

.pr10 {
    padding-right: var(--size10px);
}

.pr15 {
    padding-right: var(--size15px);
}

.pr20 {
    padding-right: var(--size20px);
}

.pr25 {
    padding-right: var(--size25px);
}

.pr30 {
    padding-right: var(--size30px);
}

.pr35 {
    padding-right: var(--size35px);
}

.pr40 {
    padding-right: var(--size40px);
}

.pr45 {
    padding-right: var(--size45px);
}

.pr50 {
    padding-right: var(--size50px);
}

.pr55 {
    padding-right: var(--size55px);
}

.pr60 {
    padding-right: var(--size60px);
}

.pr65 {
    padding-right: var(--size65px);
}

.pr70 {
    padding-right: var(--size70px);
}

.pr75 {
    padding-right: var(--size75px);
}

.pr80 {
    padding-right: var(--size80px);
}

.pr85 {
    padding-right: var(--size85px);
}

.pr90 {
    padding-right: var(--size90px);
}

.pr95 {
    padding-right: var(--size95px);
}

.pr100 {
    padding-right: var(--size100px);
}

.pl5 {
    padding-left: var(--size5px);
}

.pl10 {
    padding-left: var(--size10px);
}

.pl15 {
    padding-left: var(--size15px);
}

.pl20 {
    padding-left: var(--size20px);
}

.pl25 {
    padding-left: var(--size25px);
}

.pl30 {
    padding-left: var(--size30px);
}

.pl35 {
    padding-left: var(--size35px);
}

.pl40 {
    padding-left: var(--size40px);
}

.pl45 {
    padding-left: var(--size45px);
}

.pl50 {
    padding-left: var(--size50px);
}

.pl55 {
    padding-left: var(--size55px);
}

.pl60 {
    padding-left: var(--size60px);
}

.pl65 {
    padding-left: var(--size65px);
}

.pl70 {
    padding-left: var(--size70px);
}

.pl75 {
    padding-left: var(--size75px);
}

.pl80 {
    padding-left: var(--size80px);
}

.pl85 {
    padding-left: var(--size85px);
}

.pl90 {
    padding-left: var(--size90px);
}

.pl95 {
    padding-left: var(--size95px);
}

.pl100 {
    padding-left: var(--size100px);
}

.prl5 {
    padding-right: var(--size5px);
    padding-left: var(--size5px);
}

.prl10 {
    padding-right: var(--size10px);
    padding-left: var(--size10px);
}

.prl15 {
    padding-right: var(--size15px);
    padding-left: var(--size15px);
}

.prl20 {
    padding-right: var(--size20px);
    padding-left: var(--size20px);
}

.prl25 {
    padding-right: var(--size25px);
    padding-left: var(--size25px);
}

.prl30 {
    padding-right: var(--size30px);
    padding-left: var(--size30px);
}

.prl35 {
    padding-right: var(--size35px);
    padding-left: var(--size35px);
}

.prl40 {
    padding-right: var(--size40px);
    padding-left: var(--size40px);
}

.prl45 {
    padding-right: var(--size45px);
    padding-left: var(--size45px);
}

.prl50 {
    padding-right: var(--size50px);
    padding-left: var(--size50px);
}

.prl55 {
    padding-right: var(--size55px);
    padding-left: var(--size55px);
}

.prl60 {
    padding-right: var(--size60px);
    padding-left: var(--size60px);
}

.prl65 {
    padding-right: var(--size65px);
    padding-left: var(--size65px);
}

.prl70 {
    padding-right: var(--size70px);
    padding-left: var(--size70px);
}

.prl75 {
    padding-right: var(--size75px);
    padding-left: var(--size75px);
}

.prl80 {
    padding-right: var(--size80px);
    padding-left: var(--size80px);
}

.prl85 {
    padding-right: var(--size85px);
    padding-left: var(--size85px);
}

.prl90 {
    padding-right: var(--size90px);
    padding-left: var(--size90px);
}

.prl95 {
    padding-right: var(--size95px);
    padding-left: var(--size95px);
}

.prl100 {
    padding-right: var(--size100px);
    padding-left: var(--size100px);
}

.fz10 {
    font-size: .625rem;
    letter-spacing: .1em;
}

.fz12 {
    font-size: .75rem;
    letter-spacing: .1em;
}

.fz13 {
    font-size: .8125rem;
    letter-spacing: .1em;
}

.fz14 {
    font-size: .875rem;
    letter-spacing: .1em;
}

.fz15 {
    font-size: .9375rem;
    letter-spacing: .1em;
}

.fz16 {
    font-size: 1rem;
    letter-spacing: .1em;
}

.fz18 {
    font-size: 1.125rem;
    letter-spacing: .1em;
}

.fz20 {
    font-size: 1.25rem;
    letter-spacing: .1em;
}

.fz22 {
    font-size: 1.375rem;
    letter-spacing: .1em;
}

.fz24 {
    font-size: 1.5rem;
    letter-spacing: .1em;
}

.fz25 {
    font-size: 1.5625rem;
    letter-spacing: .1em;
}

.fz26 {
    font-size: 1.625rem;
    letter-spacing: .1em;
}

.fz28 {
    font-size: 1.75rem;
    letter-spacing: .1em;
}

.fz30 {
    font-size: 1.875rem;
    letter-spacing: .1em;
}

.fz32 {
    font-size: 2rem;
    letter-spacing: .1em;
}

.fz34 {
    font-size: 2.125rem;
    letter-spacing: .1em;
}

.fz36 {
    font-size: 2.25rem;
    letter-spacing: .1em;
}

.fz38 {
    font-size: 2.375rem;
    letter-spacing: .1em;
}

.fz40 {
    font-size: 2.5rem;
    letter-spacing: .1em;
}

.fz42 {
    font-size: 2.625rem;
    letter-spacing: .1em;
}

.fz44 {
    font-size: 2.75rem;
    letter-spacing: .1em;
}

.fz46 {
    font-size: 2.875rem;
    letter-spacing: .1em;
}

.fz48 {
    font-size: 3rem;
    letter-spacing: .1em;
}

.fz50 {
    font-size: 3.125rem;
    letter-spacing: .1em;
}

.fz52 {
    font-size: 3.25rem;
    letter-spacing: .1em;
}

.fz54 {
    font-size: 3.375rem;
    letter-spacing: .1em;
}

.fz56 {
    font-size: 3.5rem;
    letter-spacing: .1em;
}

.fz58 {
    font-size: 3.625rem;
    letter-spacing: .1em;
}

.fz60 {
    font-size: 3.75rem;
    letter-spacing: .1em;
}

.fz62 {
    font-size: 3.875rem;
    letter-spacing: .1em;
}

.fz64 {
    font-size: 4rem;
    letter-spacing: .1em;
}

.fz66 {
    font-size: 4.125rem;
    letter-spacing: .1em;
}

.fz68 {
    font-size: 4.25rem;
    letter-spacing: .1em;
}

.fz70 {
    font-size: 4.375rem;
    letter-spacing: .1em;
}

.fz80 {
    font-size: 5rem;
    letter-spacing: .1em;
}

.fz84 {
    font-size: 5.25rem;
    letter-spacing: .1em;
}

.fz90 {
    font-size: 5.625rem;
    letter-spacing: .1em;
}

.fz96 {
    font-size: 6rem;
    letter-spacing: .1em;
}

.fz100 {
    font-size: 6.25rem;
    letter-spacing: .1em;
}

.fz110 {
    font-size: 6.875rem;
    letter-spacing: .1em;
}

.fz120 {
    font-size: 7.5rem;
    letter-spacing: .1em;
}

.fz130 {
    font-size: 8.125rem;
    letter-spacing: .1em;
}

.fz140 {
    font-size: 8.75rem;
    letter-spacing: .1em;
}

.fz150 {
    font-size: 9.375rem;
    letter-spacing: .1em;
}

.ls0 {
    letter-spacing: 0;
}

.ls05 {
    letter-spacing: .05em;
}

.ls1 {
    letter-spacing: .1em;
}

.ls15 {
    letter-spacing: .15em;
}

.ls2 {
    letter-spacing: .2em;
}

.txt_white {
    color: #fff !important;
}

.bg_white {
    background-color: #fff !important;
}

.shadow_w {
    text-shadow: 0px 0px 5px #fff, 0px 0px 5px #fff, 0px 0px 10px #fff, 0px 0px 10px #fff, 0px 0px 15px #fff, 0px 0px 15px #fff;
}

em {
    font-style: normal;
}


.txt_col01 {
    color: var(--color01) !important;
}

.txt_col02 {
    color: var(--color02) !important;
}

.txt_col03 {
    color: var(--color03) !important;
}

.txt_col04 {
    color: var(--color04) !important;
}

.txt_col05 {
    color: var(--color05) !important;
}

.txt_col06 {
    color: var(--color06) !important;
}

.txt_col07 {
    color: var(--color07) !important;
}

.txt_col08 {
    color: var(--color08) !important;
}

.txt_col09 {
    color: var(--color09) !important;
}

.txt_col10 {
    color: var(--color10) !important;
}

.txt_col11 {
    color: var(--color11) !important;
}

.txt_col12 {
    color: var(--color12) !important;
}

.txt_col13 {
    color: var(--color13) !important;
}

.txt_col14 {
    color: var(--color14) !important;
}

.txt_col15 {
    color: var(--color15) !important;
}

.txt_col16 {
    color: var(--color16) !important;
}

.txt_col17 {
    color: var(--color17) !important;
}

.txt_col18 {
    color: var(--color18) !important;
}

.txt_col19 {
    color: var(--color19) !important;
}

.txt_col20 {
    color: var(--color20) !important;
}

.txt_col21 {
    color: var(--color21) !important;
}

.txt_col22 {
    color: var(--color22) !important;
}

.txt_col23 {
    color: var(--color23) !important;
}

.txt_col24 {
    color: var(--color24) !important;
}

.txt_col25 {
    color: var(--color25) !important;
}

.txt_col_fl01::first-letter {
    color: var(--color01) !important;
}

.txt_col_fl02::first-letter {
    color: var(--color02) !important;
}

.txt_col_fl03::first-letter {
    color: var(--color03) !important;
}

.txt_col_fl04::first-letter {
    color: var(--color04) !important;
}

.txt_col_fl05::first-letter {
    color: var(--color05) !important;
}

.txt_col_fl06::first-letter {
    color: var(--color06) !important;
}

.txt_col_fl07::first-letter {
    color: var(--color07) !important;
}

.txt_col_fl08::first-letter {
    color: var(--color08) !important;
}

.txt_col_fl09::first-letter {
    color: var(--color09) !important;
}

.txt_col_fl10::first-letter {
    color: var(--color10) !important;
}

.txt_col_fl11::first-letter {
    color: var(--color11) !important;
}

.txt_col_fl12::first-letter {
    color: var(--color12) !important;
}

.txt_col_fl13::first-letter {
    color: var(--color13) !important;
}

.txt_col_fl14::first-letter {
    color: var(--color14) !important;
}

.txt_col_fl15::first-letter {
    color: var(--color15) !important;
}

.txt_col_fl16::first-letter {
    color: var(--color16) !important;
}

.txt_col_fl17::first-letter {
    color: var(--color17) !important;
}

.txt_col_fl18::first-letter {
    color: var(--color18) !important;
}

.txt_col_fl19::first-letter {
    color: var(--color19) !important;
}

.txt_col_fl20::first-letter {
    color: var(--color20) !important;
}

.txt_col_fl21::first-letter {
    color: var(--color21) !important;
}

.txt_col_fl22::first-letter {
    color: var(--color22) !important;
}

.txt_col_fl23::first-letter {
    color: var(--color23) !important;
}

.txt_col_fl24::first-letter {
    color: var(--color24) !important;
}

.txt_col_fl25::first-letter {
    color: var(--color25) !important;
}

.bg_col01 {
    background-color: var(--color01) !important;
}

.bg_col02 {
    background-color: var(--color02) !important;
}

.bg_col03 {
    background-color: var(--color03) !important;
}

.bg_col04 {
    background-color: var(--color04) !important;
}

.bg_col05 {
    background-color: var(--color05) !important;
}

.bg_col06 {
    background-color: var(--color06) !important;
}

.bg_col07 {
    background-color: var(--color07) !important;
}

.bg_col08 {
    background-color: var(--color08) !important;
}

.bg_col09 {
    background-color: var(--color09) !important;
}

.bg_col10 {
    background-color: var(--color10) !important;
}

.bg_col11 {
    background-color: var(--color11) !important;
}

.bg_col12 {
    background-color: var(--color12) !important;
}

.bg_col13 {
    background-color: var(--color13) !important;
}

.bg_col14 {
    background-color: var(--color14) !important;
}

.bg_col15 {
    background-color: var(--color15) !important;
}

.bg_col16 {
    background-color: var(--color16) !important;
}

.bg_col17 {
    background-color: var(--color17) !important;
}

.bg_col18 {
    background-color: var(--color18) !important;
}

.bg_col19 {
    background-color: var(--color19) !important;
}

.bg_col20 {
    background-color: var(--color20) !important;
}

.bg_col21 {
    background-color: var(--color21) !important;
}

.bg_col22 {
    background-color: var(--color22) !important;
}

.bg_col23 {
    background-color: var(--color23) !important;
}

.bg_col24 {
    background-color: var(--color24) !important;
}

.bg_col25 {
    background-color: var(--color25) !important;
}

.bdr_col01 {
    border-color: var(--color01) !important;
}

.bdr_col02 {
    border-color: var(--color02) !important;
}

.bdr_col03 {
    border-color: var(--color03) !important;
}

.bdr_col04 {
    border-color: var(--color04) !important;
}

.bdr_col05 {
    border-color: var(--color05) !important;
}

.bdr_col06 {
    border-color: var(--color06) !important;
}

.bdr_col07 {
    border-color: var(--color07) !important;
}

.bdr_col08 {
    border-color: var(--color08) !important;
}

.bdr_col09 {
    border-color: var(--color09) !important;
}

.bdr_col10 {
    border-color: var(--color10) !important;
}

.bdr_col11 {
    border-color: var(--color11) !important;
}

.bdr_col12 {
    border-color: var(--color12) !important;
}

.bdr_col13 {
    border-color: var(--color13) !important;
}

.bdr_col14 {
    border-color: var(--color14) !important;
}

.bdr_col15 {
    border-color: var(--color15) !important;
}

.bdr_col16 {
    border-color: var(--color16) !important;
}

.bdr_col17 {
    border-color: var(--color17) !important;
}

.bdr_col18 {
    border-color: var(--color18) !important;
}

.bdr_col19 {
    border-color: var(--color19) !important;
}

.bdr_col20 {
    border-color: var(--color20) !important;
}

.bdr_col21 {
    border-color: var(--color21) !important;
}

.bdr_col22 {
    border-color: var(--color22) !important;
}

.bdr_col23 {
    border-color: var(--color23) !important;
}

.bdr_col24 {
    border-color: var(--color24) !important;
}

.bdr_col25 {
    border-color: var(--color25) !important;
}

.bbw {
    border-bottom: 1px solid #fff;
}

.parallax {
    width: 100%;
    background-attachment: fixed !important;
}

.parallax.is_ios,
.tab.parallax {
    background-attachment: inherit !important;
}

.ready {
    position: relative;
}

.ready a {
    pointer-events: none;
}

.ready a:hover {
    opacity: 1;
    cursor: default;
}

.ready:before {
    content: "準備中";
    color: #fff;
    text-align: center;
    width: calc(100 / var(--break) * 100vw);
    height: calc(40 / var(--break) * 100vw);
    line-height: calc(40 / var(--break) * 100vw);
    background: rgba(51, 51, 51, .7);
    font-size: 1.125rem;
    letter-spacing: .1em;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    z-index: 2;
    position: absolute;
}

@media(max-width: 767px) {

    .parallax,
    .parallax.is_ios,
    .tab.parallax {
        width: 100%;
        background-attachment: inherit !important;
    }
}

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

    .slick-slide img,
    #sb_instagram .sbi_photo_wrap {
        backface-visibility: hidden;
        -webkit-backface-visibility: hidden;
    }
}

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

@media(min-width: 768px) and (max-width:1299px) {
    .pc_only {
        display: none;
    }

    .tb_only {
        display: inherit;
    }

    .sp_only {
        display: none;
    }

    .tb_pc {
        display: inherit;
    }

    .sp_tb {
        display: inherit;
    }
}

@media(max-width: 767px) {
    :root {
        font-size: 4.27vw;
    }

    html,
    body {
        font-size: 1rem;
        letter-spacing: 0;
    }

    .lum-lightbox {
        background-color: rgba(255, 255, 255, .9);
    }

    .lum-close-button:after,
    .lum-close-button:before {
        background-color: rgb(000, 000, 000);
    }

    .lum-gallery-button {
        display: none !important;
    }

    a.zoom {
        position: relative;
        display: block;
        pointer-events: auto;
    }

    a.zoom:before {
        content: "タップで拡大します";
        position: absolute;
        width: 100%;
        height: 4.27vw;
        left: 0;
        right: 0;
        top: 0;
        bottom: 0;
        margin: auto;
        letter-spacing: .1em;
        line-height: 4.27vw;
        text-shadow: 0 0 calc(5 / var(--break) * 100vw) #fff, 0 0 calc(5 / var(--break) * 100vw) #fff, 0 0 calc(10 / var(--break) * 100vw) #fff, 0 0 calc(10 / var(--break) * 100vw) #fff, 0 0 calc(15 / var(--break) * 100vw) #fff, 0 0 calc(15 / var(--break) * 100vw) #fff;
        text-align: center;
    }

    a.zoom:after {
        content: '';
        position: absolute;
        top: 0;
        right: 0;
        display: block;
        width: 1.5em;
        height: 1.5em;
        background-color: rgba(0, 0, 0, 0.5);
        background-image: url("images/page/icn_zoom.svg");
        background-size: 1em 1em;
        background-position: center center;
        background-repeat: no-repeat;
    }

    .lum-lightbox.lum-open {
        z-index: 10;
    }

    .lum-lightbox-image-wrapper {
        overflow-x: scroll;
    }

    .lum-lightbox-inner img {
        max-width: calc(1000 / var(--break) * 100vw);
    }

    .inner,
    .inner1000,
    .inner1140,
    .inner1200,
    .inner1340,
    .inner1500 {
        width: 100%;
        max-width: calc(702 / var(--break) * 100vw);
    }

    .pc_only {
        display: none;
    }

    .tb_only {
        display: none;
    }

    .sp_only {
        display: inherit;
    }

    .tb_pc {
        display: none;
    }

    .sp_tb {
        display: inherit;
    }

    .pt_1vw {
        padding-top: 1vw;
    }

    .pt_2vw {
        padding-top: 2vw;
    }

    .pt_3vw {
        padding-top: 3vw;
    }

    .pt_4vw {
        padding-top: 3vw;
    }

    .pt_5vw {
        padding-top: 5vw;
    }

    .pt_6vw {
        padding-top: 6vw;
    }

    .pt_7vw {
        padding-top: 7vw;
    }

    .pt_8vw {
        padding-top: 8vw;
    }

    .pt_9vw {
        padding-top: 9vw;
    }

    .pt_10vw {
        padding-top: 10vw;
    }

    .pt_11vw {
        padding-top: 11vw;
    }

    .pt_12vw {
        padding-top: 12vw;
    }

    .pt_13vw {
        padding-top: 13vw;
    }

    .pt_14vw {
        padding-top: 14vw;
    }

    .pt_15vw {
        padding-top: 15vw;
    }

    .pb_1vw {
        padding-bottom: 1vw;
    }

    .pb_2vw {
        padding-bottom: 2vw;
    }

    .pb_3vw {
        padding-bottom: 4vw;
    }

    .pb_5vw {
        padding-bottom: 5vw;
    }

    .pb_6vw {
        padding-bottom: 6vw;
    }

    .pb_7vw {
        padding-bottom: 7vw;
    }

    .pb_8vw {
        padding-bottom: 8vw;
    }

    .pb_9vw {
        padding-bottom: 9vw;
    }

    .pb_10vw {
        padding-bottom: 10vw;
    }

    .pb_11vw {
        padding-bottom: 11vw;
    }

    .pb_12vw {
        padding-bottom: 12vw;
    }

    .pb_13vw {
        padding-bottom: 13vw;
    }

    .pb_14vw {
        padding-bottom: 14vw;
    }

    .pb_15vw {
        padding-bottom: 15vw;
    }

    .ls0_sp {
        letter-spacing: 0 !important;
    }

    .ls05_sp {
        letter-spacing: .05em !important;
    }

    .ls15_sp {
        letter-spacing: .15em !important;
    }

    .ls2_sp {
        letter-spacing: .2em !important;
    }

    .txt_width {
        max-width: calc(646 / var(--break) * 100vw) !important;
        margin-left: auto;
        margin-right: auto;
    }

    .sp_left {
        text-align: left !important;
    }

    .shadow_w {
        text-shadow: 0 0 calc(5 / var(--break) * 100vw) #fff, 0 0 calc(5 / var(--break) * 100vw) #fff, 0 0 calc(10 / var(--break) * 100vw) #fff, 0 0 calc(10 / var(--break) * 100vw) #fff, 0 0 calc(15 / var(--break) * 100vw) #fff, 0 0 calc(15 / var(--break) * 100vw) #fff;
    }

    .txt_tb {
        writing-mode: horizontal-tb;
    }

    .ready:before {
        font-size: .75rem;
    }
}


/* ヘッダー header
------------------------------------------------------------------*/
header {
    width: 100%;
    padding: calc(18 / 1920 * 100vw) calc(110 / var(--break05)) 0;
    padding-right: calc(148 / var(--break04));
    z-index: 10;
}

header .col_hdg {
    padding: calc(22 / 1920 * 100vw) 0 0;
    width: calc(411 / var(--break04));
}

header .hdg1 {
    position: relative;
    z-index: 1;
}

.box_address_hdg {
    max-width: 300px;
    width: calc(300 / var(--break03));
    min-height: calc(90 / var(--break04));
    margin: calc(30 / var(--break04)) auto 0;
    padding: calc(10 / var(--break04));
    background: #fff;
    text-align: center;
    border-radius: calc(10 / var(--break04));
}

.box_address_hdg .copy {
    margin-bottom: calc(2 / var(--break04));
    line-height: 1.5;
    position: relative;
    z-index: 1;
}

.box_address_hdg .copy::before {
    content: "";
    width: 100%;
    height: 2px;
    margin: auto;
    background: #3B3B3B;
    position: absolute;
    inset: 0;
    z-index: 1;
}

.box_address_hdg .copy .bg {
    padding: 0 .5em;
    background: #fff;
    position: relative;
    z-index: 1;
}

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

@media(min-width: 768px) and (max-width:1299px) {
    header {
        padding-right: calc(148 / 1700 * 100vw);
    }
}

@media(max-width: 767px) {
    header {
        padding: 6vw 10vw;
        z-index: 10;
    }

    header .col_hdg {
        padding: 0;
        width: calc(411 / 750 * 100vw);
    }

    header .hdg1 {
        width: calc(411 / 750 * 100vw);
    }

    .box_address_hdg {
        display: none;
    }

    header .row_contact03 {
        display: none;
    }
}

/* グローバルナビゲーション gnav
------------------------------------------------------------------*/
.btn_gnav_sp {
    width: calc(108 / var(--break04));
    height: calc(108 / var(--break04));
    background: #8fdd2a;
    position: fixed;
    top: calc(20 / 1920 * 100vw);
    right: calc(18 / var(--break04));
    z-index: 10000;
    outline: none;
    cursor: pointer;
}

.btn_gnav_sp .txt_gnav {
    width: calc(54 / var(--break04));
    height: calc(15 / var(--break04));
    background: url(images/page/txt_gnav.svg)no-repeat center / contain;
    position: absolute;
    right: 0;
    left: 0;
    bottom: calc(18 / var(--break04));
    margin: auto;
}

.btn_gnav_sp .icn_gnav {
    width: calc(50 / var(--break04));
    height: calc(2 / var(--break04));
    margin: auto;
    background: #fff;
    position: absolute;
    top: calc(-25 / var(--break04));
    bottom: 0;
    left: 0;
    right: 0;
    transition: transform .3s ease-in-out;
}

.btn_gnav_sp .icn_gnav:before,
.btn_gnav_sp .icn_gnav:after {
    content: "";
    width: 100%;
    height: 2px;
    position: absolute;
    left: 0;
    background: #fff;
    transition: transform .3s ease-in-out;
}

.btn_gnav_sp .icn_gnav:before {
    top: calc(11 / var(--break04));
}

.btn_gnav_sp .icn_gnav:after {
    bottom: calc(11 / var(--break04));
}

.open .btn_gnav_sp .icn_gnav {
    background: none;
}

.open .btn_gnav_sp .icn_gnav:before,
.open .btn_gnav_sp .icn_gnav:after {
    background: #fff;
    transition: transform .3s ease-in-out;
}

.open .btn_gnav_sp .icn_gnav:before {
    transform: rotate(45deg);
    top: 0;
}

.open .btn_gnav_sp .icn_gnav:after {
    transform: rotate(-45deg);
    bottom: 0;
}

.gnav_sp {
    width: calc(600 / var(--break02));
    height: 100%;
    padding: 0;
    padding-top: 120px;
    line-height: 1.45;
    background: rgba(143, 221, 42, .9);
    position: fixed;
    top: 0;
    right: 0;
    z-index: 9999;
    overflow-y: auto;
    overflow-x: hidden;
    visibility: hidden;
    opacity: 0;
    transition: opacity .6s ease, visibility .6s ease;
    touch-action: auto !important;
}

.gnav_sp .nav_main {
    padding-bottom: 150px;
}

.bg_gnav {
    visibility: hidden;
    transition: .3s;
    opacity: 0;
}

.open .bg_gnav {
    width: 100%;
    height: 100%;
    position: fixed;
    z-index: 9998;
    background: rgba(0, 0, 0, 0);
    visibility: visible;
    opacity: 1;
    transition: .3s;
    left: 0;
    top: 0;
}

.gnav_sp .nav_main>ul {
    display: block;
    max-width: 580px;
    width: calc(580 / var(--break03));
    margin: auto;
}

.gnav_sp .nav_main>ul>li {
    opacity: 0;
    transform: translateX(50%);
}

.gnav_sp .nav_main>ul>li>a {
    display: block;
    padding: calc(13.5 / var(--break02)) 0;
    letter-spacing: 0;
    line-height: 1.6;
    font-size: calc(20 / var(--break02));
    font-family: "vdl-v7marugothic", sans-serif;
    font-weight: 700;
    font-style: normal;
    color: #fff;
    transition: transform .6s ease, opacity .2s ease;
    position: relative;
}

.gnav_sp .nav_main a>.arw {
    display: inline-block;
    width: 100%;
    padding-left: calc(60 / var(--break02));
    position: relative;
    z-index: 1;
}

.gnav_sp .nav_main a>.arw:after {
    content: "";
    width: calc(14 / var(--break02));
    height: calc(10 / var(--break02));
    margin: auto;
    background: #fff;
    clip-path: polygon(50% 100%, 0 0, 100% 0);
    position: absolute;
    top: 0;
    bottom: 0;
    left: calc(24 / var(--break03));
}

.gnav_sp .nav_main>ul>li.nav_drawer>a:after {
    transform: rotate(90deg);
}

.gnav_sp .nav_main>ul>li.nav_drawer>a.open:after {
    transform: rotate(-90deg);
}

.open .gnav_sp {
    visibility: visible;
    opacity: 1;
}

.open .gnav_sp .nav_main>ul>li {
    opacity: 1;
    transform: translateX(0);
    transition: transform 1s ease, opacity .9s ease;
}

@media(min-width: 768px) {
    .gnav_sp {
        overflow-y: scroll;
        -ms-overflow-style: none;
        scrollbar-width: none;
    }

    .gnav_sp::-webkit-scrollbar {
        display: none;
    }

    .gnav_sp .ps-container>.ps-scrollbar-y-rail>.ps-scrollbar-y {
        background-color: transparent !important;
    }
}

@media(min-width: 768px) and (max-width:1299px) {
    .btn_gnav_sp {
        width: calc(110 / var(--break04));
        height: calc(110 / var(--break04));
        right: calc(10 / 1700 * 100vw);
    }
}

@media only screen and (max-width: 767px) {
    .btn_gnav_sp {
        height: calc(100 / 750 * 100vw);
        width: calc(100 / 750 * 100vw);
        top: calc(20 / 750 * 100vw);
        right: calc(24 / 750 * 100vw);
    }

    .btn_gnav_sp .txt_gnav {
        width: calc(58 / 750 * 100vw);
        height: calc(15 / 750 * 100vw);
        bottom: 2.25vw;
    }

    .btn_gnav_sp .icn_gnav {
        width: calc(40 / 750 * 100vw);
        height: calc(4 / 750 * 100vw);
        top: -3vw;
    }

    .btn_gnav_sp .icn_gnav:before,
    .btn_gnav_sp .icn_gnav:after {
        height: calc(4 / 750 * 100vw);
    }

    .btn_gnav_sp .icn_gnav:before {
        top: -2vw;
    }

    .btn_gnav_sp .icn_gnav:after {
        bottom: -1.8vw;
    }

    .gnav_sp {
        max-width: calc(600 / 750 * 100vw);
        width: 80%;
        padding: calc(138 / 750 * 100vw) 0 0;
        line-height: 1.45;
    }

    .gnav_sp .nav_main {
        padding: 1.5vw 3vw 20vw;
    }

    .gnav_sp .nav_main>ul {
        width: 92%;
    }

    .gnav_sp .nav_main>ul>li {
        padding: 0;
    }

    .gnav_sp .nav_main>ul>li>a {
        display: flex;
        align-items: center;
        min-height: calc(82 / 750 * 100vw);
        padding: 3.4vw 1vw 3.3vw;
        line-height: 1.55;
        text-align: left;
        letter-spacing: 0;
        font-size: calc(32/ 750 * 100vw);
    }

    .gnav_sp .nav_main a>.arw {
        padding-left: 0;
    }

    .gnav_sp .nav_main a>.arw:after {
        width: calc(24 / 750 * 100vw);
        height: calc(14 / 750 * 100vw);
        left: -4.5vw;
    }
}


/* メインイメージ main_img
------------------------------------------------------------------*/
.main_img {
    margin-bottom: var(--size120px);
    position: relative;
}

.main_img .slide_main {
    opacity: 0;
    transition: opacity .3s linear;
    pointer-events: none;
}

.main_img .slide_main.slick-initialized {
    opacity: 1;
}

.main_img .slide_main li {
    min-height: 600px;
    height: 100vh;
}

.main_img.tab .slide_main li {
    height: auto;
}

.main01 {
    background: url(images/index/main01.jpg)no-repeat center / cover;
}

.main02 {
    background: url(images/index/main02.jpg)no-repeat center / cover;
}

.banner_main01 {
    width: calc(534 / var(--break04));
    margin: auto;
    position: absolute;
    bottom: calc(50 / 1920 * 100vw);
    left: calc(50 / 1920 * 100vw);
}

.ballon_main {
    width: calc(287/ 1920 * 100vw);
    height: calc(247 /1920 * 100vw);
}

.main01 .catch_main01 {
    width: calc(893/ var(--break04));
    height: calc(558.02 / var(--break04));
    margin: auto;
    position: absolute;
    inset: calc(-48 / var(--break04)) 0 0 0;
    z-index: 1;
}

.ballon_main01 {
    margin: auto;
    position: absolute;
    inset: calc(36 / var(--break04)) auto 0 94%;
    z-index: 1;
}

.cover_main_img01 {
    width: calc(401/ var(--break04));
    height: calc(447 / var(--break04));
    margin: auto;
    position: absolute;
    inset: auto calc(50 / 1920 * 100vw) calc(50 / var(--break04)) auto;
    z-index: 1;
}

.cover_main_img01 .ballon {
    width: calc(248 / var(--break04));
    height: calc(241 / var(--break04));
    margin: auto;
    line-height: 1.5;
    letter-spacing: .1em;
    color: #fff;
    position: absolute;
    z-index: 1;
}

.cover_main_img01 .ballon_main01_1 {
    padding-top: calc(70 / var(--break04));
    font-size: calc(24 / var(--break04));
    background: url(images/index/ballon_main01.png)no-repeat center / cover;
    top: 0;
    right: 0;
    z-index: 1;
}

.cover_main_img01 .ballon_main01_2 {
    line-height: 1.3;
    font-size: calc(20 / var(--break04));
    background: url(images/index/ballon_main01_2.png)no-repeat center / cover;
    bottom: 0;
    left: 0;
    z-index: 1;
}

.cover_main_img01 .s2 {
    font-size: calc(36 / var(--break04));
}

.cover_main_img01 .s3 {
    font-size: calc(30 / var(--break04));
}

.cover_main_img01 .s4 {
    font-size: calc(14 / var(--break04));
    font-family: "Noto Sans JP", sans-serif;
}

.main02 .catch_main02 {
    width: calc(737.15 / 1920 * 100vw);
    height: calc(293.11 / 1920 * 100vw);
    margin: auto;
    position: absolute;
    inset: calc(-55 / 1920 * 100vw) auto 0 calc(48 / 1920 * 100vw);
    z-index: 1;
}

.cover_main_img02 {
    width: calc(449 / var(--break04));
    height: calc(209 / var(--break04));
    position: absolute;
    inset: auto calc(30 / 1920 * 100vw) calc(30 / var(--break05)) auto;
}

.cover_main_img02 .ballon {
    width: calc(215 / var(--break04));
    height: calc(209 / var(--break04));
    padding-top: calc(48 / var(--break04));
    margin: auto;
    line-height: 1.5;
    letter-spacing: .1em;
    color: #fff;
    background: url(images/index/ballon_main02_1.png)no-repeat center / cover;
    position: absolute;
    top: 0;
    bottom: 0;
    z-index: 1;
}

.cover_main_img02 .ballon {
    font-size: calc(20 / var(--break04));
}

.cover_main_img02 .ballon .s {
    font-size: calc(28 / var(--break04));
}

.cover_main_img02 .ballon_main02_1 {
    background: url(images/index/ballon_main02_1.png)no-repeat center / cover;
    left: 0;
}

.cover_main_img02 .ballon_main02_2 {
    background: url(images/index/ballon_main02_2.png)no-repeat center / cover;
    right: 0;
}

.ballon_main02 {
    margin: auto;
    position: absolute;
    inset: calc(36 / var(--break04)) auto 0 94%;
    z-index: 1;
}

.ballon_main02_3 {
    width: calc(227 / var(--break04));
    height: calc(217 / var(--break04));
    margin: auto;
    font-size: calc(17 / var(--break04));
    background: url(images/index/ballon_main02_3.png)no-repeat center / cover;
    position: absolute;
    top: calc(-90 / 1920 * 100vw);
    right: calc(-40 / 1920 * 100vw);
}

.ballon_main02_3>.copy {
    line-height: 1.5;
    transform: rotate(16deg);
}

.ballon_main02_3 .s21 {
    font-size: calc(13 / var(--break04));
}

.box_main_img02 {
    width: calc(820 / var(--break04));
    padding: calc(30 / var(--break04)) calc(30 / var(--break04)) calc(20 / var(--break04));
    ;
    border-radius: calc(20 / var(--break04));
    background-color: #88d02a;
    position: absolute;
    bottom: calc(48 / 1920 * 100vw);
    left: calc(48 / 1920 * 100vw);
}

.deco_box_main_img02 {
    width: calc(81 / var(--break04));
    margin: auto;
    position: absolute;
    top: calc(-20 / 1920 * 100vw);
    left: 5%;
}

.copy_box_main_img02 {
    line-height: 1;
}

.copy_box_main_img02 .wrap {
    margin: 0 29% 0 auto;
    width: calc(435 / var(--break04));
    line-height: 1;
    position: relative;
    z-index: 1;
}

.copy_box_main_img02 .wrap::before {
    content: "";
    width: calc(52 / var(--break04));
    height: calc(2 / var(--break04));
    margin: auto;
    background: #fff;
    position: absolute;
    inset: 0 0 0 -7.5%;
}

.copy_box_main_img02 .s10 {
    line-height: 1;
    font-weight: 700;
    font-size: calc(36 / var(--break04));
    color: #fff;
}

.copy_box_main_img02 .s11 {
    width: calc(190 / var(--break04));
    height: calc(34 / var(--break04));
    line-height: 1;
    font-size: calc(18 / var(--break04));
    border-radius: calc(17 / var(--break04));
    color: #77421e;
    background: #fff;
}

.copy_box_main_img02 .wrap2 {
    display: block;
    width: 100%;
    margin-bottom: calc(18 / var(--break04));
    padding-right: calc(170 / var(--break04));
    padding-bottom: calc(20 / var(--break04));
    line-height: 1;
    font-weight: 700;
    color: #fff;
    border-bottom: 4px dotted #fff;
    position: relative;
    z-index: 1;
}

.copy_box_main_img02 .s1 {
    line-height: 1;
    font-size: calc(24 / var(--break04));
}

.copy_box_main_img02 .s2 {
    line-height: 1;
    padding: 0 calc(10 / var(--break04));
    font-size: calc(80 / var(--break04));
    color: #fff958;
}

.copy_box_main_img02 .s2_1 {
    line-height: 1;
    font-size: calc(50 / var(--break04));
}

.copy_box_main_img02 .s3 {
    line-height: 1;
    font-size: calc(36 / var(--break04));
    position: relative;
    z-index: 1;
}

.copy_box_main_img02 .s3_2 {
    width: 130%;
    font-size: calc(18 / var(--break04));
    text-align: left;
    position: absolute;
    left: 0;
    bottom: 100%;
}

.copy_box_main_img02 .s4 {
    width: calc(90 / var(--break04));
    height: calc(90 / var(--break04));
    margin: auto;
    color: #88d02a;
    background: #fff;
    font-size: calc(18 / var(--break04));
    border-radius: 100%;
    position: absolute;
    right: 0;
    left: calc(345 / var(--break04));
    bottom: calc(10 / var(--break04));
}

.copy_box_main_img02 .s4_3 {
    font-size: calc(36/ var(--break04));
}

.box_main_img02 .text {
    color: #fff;
    letter-spacing: 0;
    font-size: calc(16 / var(--break04));
}

@media(min-width: 768px) and (max-width:1899px) {
    .main_img .slide_main li {
        min-height: calc(920 / var(--break04));
        height: calc(920 / var(--break04));
    }

    .main_img .slide_main li {
        min-height: calc(920 / var(--break04));
        height: calc(920 / var(--break04));
    }
}

@media(min-width: 768px) and (max-width:1699px) {
    .cover_main_img01 {
        height: calc(500 / var(--break04));
    }

    .cover_main_img01 .ballon_main01_2 {
        left: auto;
        right: 0;
    }


    .box_main_img02 {
        width: calc(820 / 1700 * 100vw);
        padding: calc(30 / 1700 * 100vw)calc(30 / 1700 * 100vw) calc(20 / 1700 * 100vw);
        border-radius: calc(20 / 1700 * 100vw);
    }

    .deco_box_main_img02 {
        width: calc(81 / 1700 * 100vw);
        top: calc(-20 / 1700 * 100vw);
    }

    .copy_box_main_img02 .wrap {
        margin: 0 29% 0 auto;
        width: calc(435 / 1700 * 100vw);
    }

    .copy_box_main_img02 .wrap::before {
        width: calc(52 / 1700 * 100vw);
        height: calc(2 / 1700 * 100vw);
    }

    .copy_box_main_img02 .s10 {
        font-size: calc(36 / 1700 * 100vw);
    }

    .copy_box_main_img02 .s11 {
        width: calc(190 / 1700 * 100vw);
        height: calc(34 / 1700 * 100vw);
        font-size: calc(18 / 1700 * 100vw);
        border-radius: calc(17 /1700 * 100vw);
    }

    .copy_box_main_img02 .wrap2 {
        margin-bottom: calc(18 / 1700 * 100vw);
        padding-right: calc(170 / 1700 * 100vw);
        padding-bottom: calc(20 / 1700 * 100vw);
    }

    .copy_box_main_img02 .s1 {
        font-size: calc(24 / 1700 * 100vw);
    }

    .copy_box_main_img02 .s2 {
        padding: 0 calc(10 / 1700 * 100vw);
        font-size: calc(80 / 1700 * 100vw);
    }

    .copy_box_main_img02 .s2_1 {
        font-size: calc(50 / 1700 * 100vw);
    }

    .copy_box_main_img02 .s3 {
        font-size: calc(36 / 1700 * 100vw);
    }

    .copy_box_main_img02 .s3_2 {
        font-size: calc(18 / 1700 * 100vw);
    }

    .copy_box_main_img02 .s4 {
        width: calc(90 / 1700 * 100vw);
        height: calc(90 / 1700 * 100vw);
        font-size: calc(18 / 1700 * 100vw);
        left: calc(345 / 1700 * 100vw);
        bottom: calc(10 / 1700 * 100vw);
    }

    .copy_box_main_img02 .s4_3 {
        font-size: calc(36/ 1700 * 100vw);
    }

    .box_main_img02 .text {
        font-size: calc(16 / 1700 * 100vw);
    }
}

@media(min-width: 768px) and (max-width:1299px) {
    .main01 .catch_main01 {
        width: calc(893 / 1700 * 100vw);
        height: calc(558.02 / 1700 * 100vw);
    }

    .cover_main_img02 {
        width: calc(440 / 1700 * 100vw);
        height: calc(209 / 1700 * 100vw);
    }

    .cover_main_img02 .ballon {
        width: calc(215 / 1700 * 100vw);
        height: calc(209 / 1700 * 100vw);
        padding-top: calc(48 / 1700 * 100vw);
    }

    .cover_main_img02 .ballon {
        font-size: calc(20 / 1700 * 100vw);
    }

    .cover_main_img02 .ballon .s {
        font-size: calc(28 / 1700 * 100vw);
    }
}

@media only screen and (max-width: 767px) {
    .main_img {
        margin-bottom: 0;
    }

    .main_img .slide_main li {
        min-height: auto;
        border-radius: 0;
        height: calc(1080 / 750 * 100vw);
        height: calc(100svh - calc(122 / var(--break) * 100vw));
    }

    .main01 {
        background: url(images/index/main01_sp.jpg)no-repeat center top / cover;
    }

    .main02 {
        background: url(images/index/main02_sp.png)no-repeat center top / 100%;
    }

    .banner_main01 {
        width: calc(712 / 750 * 100vw);
        top: calc(714 / 750 * 100vw);
        bottom: auto;
        left: 0;
        right: 0;
    }

    .ballon_main {
        width: calc(226/ 750 * 100vw);
        height: calc(194 /750 * 100vw);
    }

    .main01 .catch_main01 {
        width: calc(702/ 750 * 100vw);
        height: calc(558.438 / 750 * 100vw);
        inset: calc(132 / var(--break04)) 0 auto;
        z-index: 1;
    }

    .ballon_main01 {
        inset: auto 0vw -6vw auto
    }

    .cover_main_img01 {
        width: calc(702/ 750 * 100vw);
        height: calc(102/ 750 * 100vw);
        inset: calc(952 / 750 * 100vw) 0 auto;
    }

    .cover_main_img01 .ballon {
        max-width: calc(342 / 750 * 100vw);
        width: 49.5%;
        height: calc(101 / var(--break04));
        border-radius: var(--size10px);
        letter-spacing: .1em;
    }

    .cover_main_img01 .ballon_main01_1 {
        padding: 0;
        letter-spacing: 0;
        font-size: calc(24 / var(--break04));
        background: #ff761a;
        top: 0;
        bottom: 0;
        right: 0;
        left: auto;
        z-index: 1;
    }

    .cover_main_img01 .ballon_main01_2 {
        letter-spacing: 0;
        background: #08cf9a;
        font-size: calc(24 / var(--break04));
        top: 0;
        bottom: 0;
        left: 0;
        right: auto;
    }

    .cover_main_img01 .s2 {
        font-size: calc(32 / var(--break04));
    }

    .cover_main_img01 .s3 {
        font-size: calc(24 / var(--break04));
    }

    .cover_main_img01 .s4 {
        font-size: calc(20 / var(--break04));
    }


    .main02 .catch_main02 {
        width: calc(664 / 750 * 100vw);
        height: calc(264 / 750 * 100vw);
        inset: calc(180 / 750 * 100vw) 0 auto 0;
    }

    .cover_main_img02 {
        width: calc(318 / var(--break04));
        height: calc(332 / var(--break04));
        background: url(images/index/ballon_main02_sp.png)no-repeat center / cover;
        top: calc(458 / 750 * 100vw);
        left: 3vw;
    }

    .cover_main_img02 .ballon {
        width: calc(200 / var(--break04));
        height: calc(200 / var(--break04));
        padding-top: calc(56 / var(--break04));
        letter-spacing: .1em;
    }

    .cover_main_img02 .ballon_main02_1 {
        background: none;
        left: -1vw;
        top: 0;
        bottom: auto;
    }

    .cover_main_img02 .ballon_main02_2 {
        background: none;
        top: auto;
        right: 1vw;
        bottom: -1vw;
    }

    .ballon_main02 {
        width: calc(172 / 750 * 100vw);
        inset: auto 0 calc(232 / 750 * 100vw) 17vw;
    }

    .ballon_main02_3 {
        width: calc(221 / var(--break04));
        height: calc(208 / var(--break04));
        padding-top: 2.5vw;
        letter-spacing: .1em;
        font-size: calc(20 / var(--break04));
        background: url(images/index/ballon_main02_3_sp.png)no-repeat center / cover;
        top: -8vw;
        right: 1vw;
    }

    .ballon_main02_3>.copy {
        line-height: 1.5;
        letter-spacing: .1em;
        transform: rotate(0deg);
    }

    .ballon_main02_3 .s21 {
        letter-spacing: .1em;
        font-size: calc(18 / var(--break04));
    }

    .box_main_img02 {
        width: 100%;
        min-height: calc(298 /750 * 100vw);
        padding: 3vw 3.5vw 2.5vw;
        border-radius: 0;
        bottom: 0;
        left: 0;
        right: 0;
    }

    .deco_box_main_img02 {
        display: none;
    }

    .copy_box_main_img02 .wrap {
        justify-content: flex-start;
        width: 100%;
        margin: 0 0 1vw;
        padding-left: 2vw;
    }

    .copy_box_main_img02 .wrap::before {
        content: none;
    }

    .copy_box_main_img02 .s10 {
        padding-right: 2.5vw;
        letter-spacing: .1em;
        font-size: calc(36 / var(--break04));
    }

    .copy_box_main_img02 .s11 {
        font-size: calc(20 / var(--break04));
    }

    .copy_box_main_img02 .wrap2 {
        margin-bottom: 2vw;
        padding-right: 0;
        padding-left: 2vw;
        padding-bottom: 2vw;
        text-align: left;
        border-bottom-width: 2px;
    }

    .copy_box_main_img02 .s1 {
        font-size: calc(32 / var(--break04));
    }

    .copy_box_main_img02 .s2 {
        padding: 0 1vw;
    }

    .copy_box_main_img02 .s3 {
        font-size: calc(32 / var(--break04));
    }

    .copy_box_main_img02 .s3_2 {
        width: 130%;
        font-size: calc(20 / var(--break04));
        bottom: 100%;
    }

    .copy_box_main_img02 .s4 {
        font-size: calc(20 / var(--break04));
        left: calc(214 / var(--break04));
        bottom: calc(10 / var(--break04));
    }

    .copy_box_main_img02 .s4_3 {
        font-size: calc(36/ var(--break04));
    }

    .box_main_img02 .text {
        line-height: 1.6;
        font-size: calc(22 / 750 * 100vw);
    }
}

/* prats_conversion
------------------------------------------------------------------*/
.prats_conversion {
    padding: calc(54 / var(--break03)) 0;
    position: relative;
    z-index: 100;
}

.prats_conversion::before {
    content: "";
    width: 100%;
    height: calc(100% + 104 / 1920 * 100vw);
    margin: auto;
    background: url(images/page/prats_conversion.png)no-repeat center top / 100%, url(images/page/prats_conversion.png)no-repeat center bottom / 100%;
    position: absolute;
    inset: calc(-50 / 1920 * 100vw) 0;
    z-index: -1;
}

.box_conversion {
    padding: calc(40 / var(--break03)) 4% calc(60 / var(--break03));
    background: #fff;
    border-radius: calc(50 / var(--break03));
    position: relative;
    z-index: 1;
}

.box_conversion::before {
    content: "";
    width: calc(100% + 100 / var(--break03));
    height: calc(100% - 100 / var(--break03));
    margin: auto;
    background: #ffffbc;
    border-radius: calc(50 / var(--break03));
    position: absolute;
    inset: 0 calc(-50 / var(--break03));
    z-index: -1;
}

.box_conversion::after {
    content: "";
    width: 100%;
    height: 100%;
    margin: auto;
    background: #fff;
    border-radius: calc(50 / var(--break03));
    position: absolute;
    inset: 0;
    z-index: -1;
}

.copy_conversion {
    max-width: 1100px;
    margin: 0 auto calc(18 / var(--break03));
    line-height: 1.5;
    letter-spacing: .1em;
    font-size: calc(36 / var(--break03));
    text-align: center;
    position: relative;
    z-index: 1;
}

.copy_conversion::before {
    content: "";
    width: calc(84 / var(--break03));
    height: calc(45 / var(--break03));
    margin: auto;
    background: url(images/page/deco_copy_conversion_l.png)no-repeat center / contain;
    position: absolute;
    inset: 0 auto 0 1%;
}

.copy_conversion::after {
    content: "";
    width: calc(86 / var(--break03));
    height: calc(40 / var(--break03));
    margin: auto;
    background: url(images/page/deco_copy_conversion_r.png)no-repeat center / contain;
    position: absolute;
    inset: 0 1% 0 auto;
}

.cover_row_conversion {
    margin-bottom: calc(30 / var(--break03));
    padding: calc(40 / var(--break03)) 0;
    position: relative;
    z-index: 1;
}

.cover_row_conversion::before,
.cover_row_conversion::after {
    content: "";
    width: 100%;
    height: calc(12 / var(--break03));
    margin: auto;
    background: url(images/page/line.png)repeat center / auto, #fff958;
    position: absolute;
}

.cover_row_conversion::before {
    top: 0;
}

.cover_row_conversion::after {
    bottom: 0;
}

.cover_row_conversion .ballon_conversion {
    width: calc(1217 / var(--break03));
    margin: auto;
    position: absolute;
    inset: auto 0 calc(32 / var(--break03));
}

.row_conversion {
    width: calc(890 / var(--break03));
}

.row_conversion>.circle {
    width: calc(200 / var(--break03));
    height: calc(200 / var(--break03));
    line-height: 1.5;
    letter-spacing: .1em;
    font-size: calc(24 / var(--break03));
    background: url(images/page/circle_conversion.png)no-repeat center / cover;
}

.row_conversion>.circle:nth-of-type(2n) {
    background: url(images/page/circle_conversion02.png)no-repeat center / cover;
}

.box_conversion .in_box {
    padding: calc(16 / var(--break03)) calc(50 / 1920 * 100vw) calc(30 / var(--break03));
    background: url(images/page/pattern_stripe_g.png)repeat center;
    position: relative;
    z-index: 1;
}

.in_box .ballon_conversion02 {
    width: calc(762 / var(--break03));
    margin: auto;
    position: absolute;
    inset: -5% 0 auto -2.5%;
    z-index: 2;
}

.in_box .ballon_conversion03 {
    width: calc(1140 / var(--break03));
    margin: auto;
    position: absolute;
    inset: 0 0 auto;
}

@media(max-width: 767px) {
    .prats_conversion {
        padding: var(--size60px) 0;
    }

    .prats_conversion::before {
        height: calc(100% + 50 / 750 * 100vw);
        background: url(images/page/prats_conversion_t_sp.png)no-repeat center top / 100%, url(images/page/prats_conversion_b_sp.png)no-repeat center bottom / 100%;
        inset: calc(-25 / 750 * 100vw) 0;
    }

    .box_conversion {
        padding: calc(60 / 750 * 100vw) 4% calc(80 / 750 * 100vw);
    }

    .box_conversion::before {
        content: none;
    }

    .box_conversion::after {
        content: none;
    }

    .copy_conversion {
        margin-bottom: calc(50/ 750 * 100vw);
        line-height: 1.6;
        letter-spacing: .1em;
        font-size: calc(36 / 750 * 100vw);
    }

    .copy_conversion::before {
        width: calc(67 / var(--break03));
        height: calc(100 / var(--break03));
        background: url(images/page/deco_copy_conversion_l_sp.png)no-repeat center / contain;
    }

    .copy_conversion::after {
        width: calc(71 / var(--break03));
        height: calc(100 / var(--break03));
        background: url(images/page/deco_copy_conversion_r_sp.png)no-repeat center / contain;
    }

    .copy_conversion02 {
        line-height: 1.6;
        letter-spacing: .1em;
        font-size: calc(32 / 750 * 100vw);
    }

    .copy_conversion02 .fz28 {
        letter-spacing: .1em;
        font-size: calc(36 / 750 * 100vw);
    }

    .cover_row_conversion {
        margin-bottom: calc(60 / 750 * 100vw);
        padding: calc(50 / 750 * 100vw) 0;
    }

    .cover_row_conversion::before,
    .cover_row_conversion::after {
        background: url(images/page/line.png)repeat center / calc(10 / 750 * 100vw), #fff958;
    }

    .cover_row_conversion .ballon_conversion {
        display: none;
    }

    .row_conversion {
        width: 100%;
    }

    .row_conversion>.circle {
        width: calc(158 / 750 * 100vw);
        height: calc(158 / 750 * 100vw);
        line-height: 1.5;
        letter-spacing: 0;
        font-size: calc(24 / 750 * 100vw);
    }

    .box_conversion .in_box {
        padding: calc(30 / 750 * 100vw) calc(40 / 750 * 100vw) calc(40 / 750 * 100vw);
        background: url(images/page/pattern_stripe_g.png)repeat center / calc(30 / 750 * 100vw);
    }

    .in_box .ballon_conversion02 {
        width: calc(670 / 750 * 100vw);
        inset: 15% 0 auto -2.5%;
        z-index: 2;
    }

    .in_box .ballon_conversion03 {
        width: calc(646 / 750 * 100vw);
        inset: 0 0 auto;
    }
}

/* areaTitle
------------------------------------------------------------------*/
.areaTitle {
    width: 100%;
    padding-bottom: calc(30 / var(--break04));
    text-align: center;
    position: relative;
    z-index: 9;
}

.areaTitle::before {
    content: "";
    width: calc(453/ var(--break04));
    height: calc(212/ var(--break04));
    margin: auto;
    background: url(images/page/dec_hdg3.png)no-repeat center / contain;
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: -1;
}

.areaTitle .ttl_jp {
    margin-bottom: calc(30 / var(--break04));
    letter-spacing: .1em;
    font-family: "vdl-v7marugothic", sans-serif;
    font-weight: 700;
    font-style: normal;
    font-size: calc(50 / var(--break04));
    color: #3b3b3b;
}

.areaTitle .ttl_en {
    line-height: 1;
    letter-spacing: .2em;
    font-family: "roboto-mono", monospace;
    font-weight: 400;
    font-style: normal;
    font-size: calc(36 / var(--break04));
    color: #ff8eae;
    text-align: center;
}

.areaTitle.txt_white::before {
    background: url(images/page/dec_white_hdg3.png)no-repeat center / contain;
}

@media(max-width: 767px) {
    .areaTitle {
        padding-bottom: 5vw;
    }

    .areaTitle::before {
        width: calc(292/ var(--break04));
        height: calc(213/ var(--break04));
        background: url(images/page/dec_hdg3_sp.png)no-repeat center / contain;
        bottom: 0;
        right: -3.2vw;
    }

    .areaTitle .ttl_jp {
        margin-bottom: calc(36 / var(--break04));
        line-height: 1.6;
        letter-spacing: .1em;
        font-family: "vdl-v7marugothic", sans-serif;
        font-weight: 700;
        font-style: normal;
        font-size: calc(50 / var(--break04));
        color: #3b3b3b;
    }

    .areaTitle .ttl_en {
        line-height: 1;
        letter-spacing: .2em;
        font-size: calc(36 / var(--break04));
    }

    .areaTitle.txt_white::before {
        background: url(images/page/dec_white_hdg3_sp.png)no-repeat center / contain;
    }
}

/* lp_feature
------------------------------------------------------------------*/
.lp_feature {
    padding: calc(90 / var(--break02)) 0 calc(100 / var(--break02));
}

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

@media(max-width: 767px) {
    .lp_feature {
        padding: calc(90 / var(--break02)) 0 0;
    }
}


/* lp_feature
------------------------------------------------------------------*/
.row_feature_common {
    max-width: 1640px;
    width: 96%;
}

.row_feature_common.right {
    margin-left: auto;
}

.row_feature_common.left {
    margin-right: auto;
}

.row_feature_common>.col_img {
    width: 55.9%;
    padding-bottom: calc(25 / var(--break04));
    position: relative;
    z-index: 1;
}

.row_feature_common>.col_txt {
    width: 42%;
}

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

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

@media(max-width: 767px) {
    .row_feature_common>.col_img {
        width: calc(728 / 750 * 100vw);
        margin-bottom: 5vw;
    }

    .row_feature_common>.col_txt {
        width: calc(642 / 750 * 100vw);
        margin: auto;
    }
}

/* row_feature_common02
------------------------------------------------------------------*/

.row_feature_common02 {
    max-width: 1460px;
}

@media(min-width: 768px) {
    .inner_feature {
        max-width: 1560px;
    }

    .row_feature_common02>.col_img {
        max-width: 728px;
        width: 50.5%;
    }

    .row_feature_common02>.col_txt {
        width: 47%;
    }
}

@media(max-width: 767px) {
    .row_feature_common02 {
        max-width: calc(702 / 750 * 100vw);
        margin-left: auto;
        margin-right: auto;
    }

    .row_feature_common02>.col_txt {
        width: calc(648 / 750 * 100vw);
        margin: 8vw auto 0;
    }
}

/* copy_feature_common
------------------------------------------------------------------*/
.copy_feature_common {
    font-size: calc(36 / var(--break04));
    position: relative;
    z-index: 1;
}

.copy_feature_common .num {
    line-height: 1;
    letter-spacing: 0;
    font-size: calc(120 / var(--break04));
    color: #fff958;
    position: absolute;
    top: calc(-44 / 1920 * 100vw);
    z-index: -1;
}

.copy_feature_common .num.left {
    left: calc(-42 / 1920 * 100vw);
}

.copy_feature_common .num.right {
    right: 0;
}

@media(min-width: 768px) and (max-width:1299px) {
    .copy_feature_common {
        letter-spacing: 0;
        font-size: calc(36 / 1700 * 100vw);
    }
}

@media(max-width: 767px) {
    .row_feature_common {
        width: 100%;
    }

    .copy_feature_common {
        font-size: calc(35 / var(--break04));
    }

    .copy_feature_common .num {
        top: -5vw;
    }

    .copy_feature_common .num.left {
        left: -5vw;
    }

    .copy_feature_common .num.right {
        right: -5vw;
    }
}


/* lp_feature
------------------------------------------------------------------*/
.feature01 {
    position: relative;
    z-index: 1;
}

.feature01::before {
    content: "";
    width: calc(329 / 1920 * 100vw);
    height: calc(615 / 1920 * 100vw);
    margin: auto;
    background: url(images/index/deco_feature01.png)no-repeat center / cover;
    position: absolute;
    inset: calc(-142 / 1920 * 100vw) auto auto calc(20 / 1920 * 100vw);
    z-index: -1;
}

.row_feature10 {
    width: calc(640 / var(--break03));
    margin: auto;
    position: absolute;
    left: calc(40 / var(--break03));
    right: 0;
    bottom: calc(-78 / var(--break03));
}

.row_feature10>.col {
    width: calc(201 / var(--break03));
    height: calc(201 / var(--break03));
    line-height: 1.6;
    letter-spacing: .1em;
    color: #fff;
    background: url(images/index/point_feature01.png)no-repeat center / cover;
    font-size: calc(28 / var(--break03));
}

.row_feature10>.col02 {
    background: url(images/index/point_feature02.png)no-repeat center / cover;
}

.row_feature10>.col03 {
    background: url(images/index/point_feature03.png)no-repeat center / cover;
}

.cover_feature10 {
    padding: calc(70 / var(--break03)) 0;
    position: relative;
    z-index: 1;
}

.cover_feature10::before {
    content: "";
    max-width: 1630px;
    width: 96%;
    height: 100%;
    border-radius: 0 calc(30 / var(--break03)) calc(30 / var(--break03)) 0;
    background: #f9f8eb;
    position: absolute;
    inset: 0 auto 0 0;
    z-index: -1;
}

.cover_feature10::after {
    content: "";
    width: calc(1117 / 1920 * 100vw);
    height: calc(390 / 1920 * 100vw);
    margin: auto;
    background: url(images/index/deco_feature02.png)no-repeat center / cover;
    position: absolute;
    inset: calc(-140 / 1920 * 100vw) calc(111 / 1920 * 100vw) auto auto;
    z-index: 1;
}

.cover_feature10 .ballon {
    width: calc(184 / var(--break03));
    height: calc(184 / var(--break03));
    margin: auto;
    letter-spacing: .1em;
    line-height: 1.3;
    font-size: calc(36 / var(--break03));
    background: url(images/index/point_feature04.png)no-repeat center / cover;
    position: absolute;
    left: 0;
    top: calc(-130 / var(--break03));
}

@media(min-width: 768px) and (max-width:1299px) {
    .cover_feature10::after {
        inset: calc(-140 / 1920 * 100vw) calc(20 / 1920 * 100vw) auto auto;
    }
}

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

@media(max-width: 767px) {
    .feature01::before {
        width: calc(213/ 750 * 100vw);
        height: calc(116 / 750 * 100vw);
        background: url(images/index/deco_feature01_sp.png)no-repeat center / 100%;
        inset: calc(68 / 750 * 100vw) auto auto calc(26 / 750 * 100vw);
    }

    .row_feature01.row_feature_common>.col_img {
        margin-bottom: 15vw;
    }

    .row_feature10 {
        left: calc(40 / var(--break03));
        right: 0;
        bottom: calc(-78 / var(--break03));
    }

    .cover_feature10 {
        padding: 7vw 0;
    }

    .cover_feature10::before {
        width: 100%;
        height: 100%;
        border-radius: 0;
    }

    .cover_feature10::after {
        width: calc(389 / var(--break04));
        height: calc(173 / var(--break04));
        background: url(images/index/deco_feature02_sp.png)no-repeat center / cover;
        inset: calc(-150 / 750 * 100vw) calc(124 / 1920 * 100vw) auto auto;
    }

    .cover_feature10 .copy_common01 {
        padding-left: calc(140 / var(--break04));
        padding-right: 0;
    }

    .cover_feature10 .ballon {
        width: calc(146 / var(--break03));
        height: calc(146 / var(--break03));
        letter-spacing: .1em;
        line-height: 1.3;
        font-size: calc(32 / var(--break03));
        left: 0vw;
        top: calc(-70 / var(--break03));
    }
}

/*  .row_feature20
------------------------------------------------------------------*/
.feature02 {
    margin-bottom: calc(-40 / var(--break04));
    position: relative;
    z-index: 1;
}

.feature02::before {
    content: "";
    width: calc(1790 / var(--break03));
    height: calc(666 / var(--break03));
    margin: auto;
    background: url(images/index/deco_feature03.png)no-repeat center / cover;
    position: absolute;
    inset: calc(48 / 1920 * 100vw) -50% auto;
    z-index: -2;
}

.row_feature20 {
    max-width: calc(980 / var(--break02));
}

.row_feature20>.circle {
    width: calc(300 / var(--break02));
    height: calc(300 / var(--break02));
    color: #fff;
    background: #ff8eae;
    position: relative;
    z-index: 1;
}

.row_feature20>.circle::before {
    content: "";
    width: calc(100% - 18 / var(--break02));
    height: calc(100% - 18 / var(--break02));
    margin: auto;
    border: 1px solid #fff;
    border-radius: 100%;
    position: absolute;
    inset: 0;
}

.row_feature20 .copy {
    margin-bottom: calc(18 / var(--break03));
    line-height: 1.3;
}

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

@media(max-width: 767px) {
    .feature02 {
        margin-bottom: 1vw;
    }

    .feature02::before {
        content: none;
    }

    .row_feature20 {
        width: calc(650 / 750 * 100vw);
        font-size: calc(20 / 750 * 100vw);
        position: relative;
        z-index: 1;
    }

    .row_feature20::before {
        content: "";
        width: calc(716 / 750 * 100vw);
        height: calc(270 / 750 * 100vw);
        margin: auto;
        background: url(images/index/deco_feature03_sp.png)no-repeat center / cover;
        position: absolute;
        top: -1vw;
        left: -5vw;
        right: 0;
    }

    .row_feature20>.circle01 {
        margin: 0 calc(175 / 750 * 100vw);
    }

    .row_feature20>.circle::before {
        width: calc(100% - 18 / var(--break02));
        height: calc(100% - 18 / var(--break02));
    }

    .row_feature20 .copy {
        font-size: calc(32 / 750 * 100vw);
        margin-bottom: 2vw;
    }

}

/* feature03
------------------------------------------------------------------*/
.feature03 {
    position: relative;
    z-index: 1;
}

.feature03::before {
    content: "";
    width: calc(1822 / var(--break03));
    height: calc(324 / var(--break03));
    margin: auto;
    background: url(images/index/deco_feature04.png)no-repeat center / cover;
    position: absolute;
    inset: auto -50% calc(20 / 1920 * 100vw);
    z-index: -1;
}

@media(min-width: 768px) {
    .feature03 .row_feature_common02>.col_txt {
        padding-top: calc(60 / 1920 * 100vw);
    }
}

@media(max-width: 767px) {
    .feature03::before {
        content: none;
    }
}

/* feature04
------------------------------------------------------------------*/
.feature04 {
    padding: calc(120 / var(--break02)) 0;
    background: #f3f3f3;
    position: relative;
    z-index: 1;
}

.feature04::before,
.feature04::after {
    content: "";
    width: 100%;
    height: calc(40 / 1920 * 100vw);
    margin: auto;
    background: url(images/page/bg_wave_common.png)repeat center bottom / 100%;
    position: absolute;
    inset: auto 0 -1px;
    z-index: -1;
}

.feature04::after {
    transform: scale(-1, -1);
    inset: -1px 0 auto;
}

.row_feature04>.col {
    max-width: 600px;
    width: 48.5%;
    position: relative;
    z-index: 1;
}

.row_feature04 .ballon {
    width: calc(241 / var(--break03));
    height: calc(241 / var(--break03));
    margin: auto;
    color: #fff;
    line-height: 1.85;
    letter-spacing: .1em;
    font-size: calc(20 / var(--break03));
    background: url(images/index/point_feature05.png)no-repeat center / cover;
    position: absolute;
    top: calc(-78 / 1920 * 100vw);
}

.row_feature04 .ballon01 {
    left: calc(-48 / 1920 * 100vw);
}

.row_feature04 .ballon02 {
    background: url(images/index/point_feature06.png)no-repeat center / cover;
    right: calc(-48 / 1920 * 100vw);
}

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

@media(max-width: 767px) {
    .feature04 {
        padding: 15vw 0;
    }

    .feature04::before,
    .feature04::after {
        height: calc(40 / 750 * 100vw);
        background: url(images/page/bg_wave_common_sp.png)repeat center bottom / calc(750/ 750 * 100vw);
    }

    .row_feature04>.col {
        max-width: calc(600 / 750 * 100vw);
        width: 100%;
        margin: 0 auto var(--size40px);
        position: relative;
    }

    .row_feature04 .ballon {
        width: calc(241 / 750 * 100vw);
        height: calc(241 / 750 * 100vw);
        line-height: 1.85;
        letter-spacing: .1em;
        font-size: calc(20 / 750 * 100vw);
        top: -6vw;
    }

    .row_feature04 .ballon01 {
        left: -7vw;
    }

    .row_feature04 .ballon02 {
        right: -7vw;
        top: -12vw;
    }
}

/* コンテンツ名 class
------------------------------------------------------------------*/
.feature05 {
    position: relative;
    z-index: 1;
}

.feature05::before {
    content: "";
    width: calc(1770 / var(--break04));
    height: calc(399 / var(--break04));
    margin: auto;
    background: url(images/index/deco_feature05.png)no-repeat center / contain;
    position: absolute;
    inset: auto 0 calc(-5 / 1920 * 100vw) calc(40 / var(--break02));
    z-index: -1;
}

.feature06 {
    position: relative;
    z-index: 1;
}

.feature06::before {
    content: "";
    width: calc(157 / 1920 * 100vw);
    height: calc(265 / 1920 * 100vw);
    margin: auto;
    background: url(images/index/deco_feature06.png)no-repeat center / contain;
    position: absolute;
    inset: calc(48 / 1920 * 100vw) auto 0 calc(38 / 1920 * 100vw);
    z-index: 2;
}

.lp_feature .coverFee {
    position: relative;
    z-index: 1;
}

.lp_feature .coverFee::before {
    content: "";
    width: calc(1708 / var(--break03));
    height: calc(1044 / var(--break03));
    margin: auto;
    background: url(images/index/deco_feature07.png)no-repeat center / contain;
    position: absolute;
    inset: auto 0 calc(80 / var(--break03)) calc(-200 / var(--break03));
    z-index: 2;
}

@media(min-width: 768px) and (max-width:1899px) {
    .feature05::before {
        inset: 0 -50%;
    }

    .feature06::before {
        inset: calc(48 / 1920 * 100vw) auto 0 calc(-60 / var(--break02));
    }
}

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

@media(max-width: 767px) {
    .feature05::before {
        width: calc(140 / 750*100vw);
        height: calc(194 / 750*100vw);
        background: url(images/index/deco_feature05_sp.png)no-repeat center / contain;
        inset: auto 4vw 100% auto;
    }

    .feature06::before {
        width: calc(157 / 750*100vw);
        height: calc(265 / 750*100vw);

        inset: calc(48 / 750 * 100vw) auto 0 calc(38 / 750 * 100vw);
    }

    .lp_feature .coverFee::before {
        content: none
    }
}

/* lp_trouble
------------------------------------------------------------------*/
.lp_trouble {
    position: relative;
    z-index: 1;
}

.lp_trouble::before {
    content: "";
    width: calc(1810 / 1920 * 100vw);
    height: calc(699 / 1920 * 100vw);
    margin: auto;
    background: url(images/index/deco_trouble.png)no-repeat center / cover;
    position: absolute;
    top: calc(48 / 1920 * 100vw);
    left: 0;
    right: 0;
    z-index: 2;
}

.lp_trouble::after {
    content: "";
    width: 100%;
    height: calc(190 / 1920 * 100vw);
    margin: auto;
    background: #fff;
    clip-path: polygon(50% 100%, 100% 0, 100% 100%, 0 100%, 0 0);
    position: absolute;
    inset: auto 0 -1px;
    z-index: 1;
}

.bg_trouble {
    padding: calc(70 / var(--break02)) 0 calc(148 / var(--break02));
    background: url(images/page/pattern_stripe_p.png)repeat center;
    position: relative;
    z-index: 1;
}

.bg_trouble::before,
.bg_trouble::after {
    content: "";
    width: calc(1130 / 1920 * 100vw);
    height: calc(420/ 1920 * 100vw);
    margin: auto;
    background: rgba(255, 255, 255, .15);
    clip-path: polygon(0 0, 0% 100%, 100% 0);
    position: absolute;
    top: 0;
}

.bg_trouble::before {
    left: 0;
}

.bg_trouble::after {
    right: 0;
    clip-path: polygon(0 0, 100% 100%, 100% 0);
}

.row_trouble>.circle {
    width: calc(220 / var(--break03));
    height: calc(208 / var(--break03));
    background: url(images/index/circle_trouble01.png)no-repeat center / cover;
}

.copy_trouble {
    letter-spacing: .1em;
    position: relative;
    z-index: 1;
}

.copy_trouble::before {
    content: "";
    width: calc(15 / var(--break02));
    height: calc(68 / var(--break02));
    margin: auto;
    background: url(images/index/illust_trouble01.png)no-repeat center /contain;
    position: absolute;
    top: 111%;
    left: 0;
    right: 0;
    z-index: -1;
}

.row_trouble {
    position: relative;
    z-index: 1;
}

.row_trouble::before {
    content: "";
    width: calc(1280 / var(--break03));
    height: calc(194 / var(--break03));
    margin: auto;
    background: url(images/index/illust_trouble02.png)no-repeat center /contain;
    position: absolute;
    inset: auto 0 calc(24 / 1920 * 100vw) calc(-14 / 1920 * 100vw);
    z-index: -1;
}

@media(min-width: 768px) {
    .row_trouble>.circle {
        margin-right: calc(30 / var(--break03));
    }

    .row_trouble>.circle:nth-of-type(5n),
    .row_trouble>.circle:last-child {
        margin-right: 0;
    }


    .row_trouble>.circle:nth-of-type(n + 6) {
        margin-top: calc(40 / var(--break03));
    }

    .ballon_trouble_sp {
        display: none;
    }
}

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

@media(max-width: 767px) {
    .lp_trouble::before {
        content: none;
    }

    .bg_trouble {
        padding: 10vw 0 20vw;
        background: url(images/page/pattern_stripe_p.png)repeat center / calc(30 / 750 * 100vw);
    }

    .bg_trouble::before,
    .bg_trouble::after {
        width: calc(545 / 750 * 100vw);
        height: calc(200 / 750 * 100vw);
    }

    .lp_trouble .areaTitle::before {
        bottom: 10vw;
    }

    .lp_trouble::after {
        height: calc(80 / 750 * 100vw);
    }

    .row_trouble {
        justify-content: space-between !important;
        position: static;
    }

    .row_trouble>.circle {
        width: calc(220 / var(--break03));
        height: calc(208 / var(--break03));
    }

    .row_trouble>.circle:nth-of-type(n + 4) {
        margin-top: calc(30 / 750 * 100vw);
    }

    .row_trouble>.circle .copy {
        line-height: 1.6;
        font-size: calc(24 / 750 * 100vw);
    }

    .copy_trouble {
        letter-spacing: .1em;
    }

    .copy_trouble::before {
        content: "";
        width: calc(15 / var(--break02));
        height: calc(68 / var(--break02));
        margin: auto;
        background: url(images/index/illust_trouble01.png)no-repeat center /contain;
        position: absolute;
        top: 111%;
        left: 0;
        right: 0;
        z-index: -1;
    }

    .row_trouble::before {
        content: none;
    }

    .ballon_trouble_sp {
        width: calc(702 / var(--break03));
        height: calc(194 / var(--break03));
        margin: auto;
        background: url(images/index/illust_trouble02_sp.png)no-repeat center /contain;
        position: absolute;
        inset: auto 0 0 -2vw;
        z-index: 100;
    }
}

/* lp_symptoms
------------------------------------------------------------------*/
.lp_symptoms {
    padding: calc(64 / var(--break02)) 0 calc(100 / var(--break02));
    background: url(images/index/bg_symptoms01.png)no-repeat center top calc(20 / 1920 * 100vw) / auto;
    position: relative;
    z-index: 1;
}

.lp_symptoms::before {
    content: "";
    width: calc(1800 / 1920 * 100vw);
    height: calc(1411 / 1920 * 100vw);
    margin: auto;
    position: absolute;
    background: url(images/index/deco_symptoms01.png)no-repeat center / contain;
    inset: calc(158 / var(--break04)) 0 auto calc(90 / 1920 * 100vw);
    z-index: -1;
}

.row_symptoms::after {
    content: "";
    width: calc(275 / var(--break04));
    height: calc(369 / var(--break04));
    margin: auto;
    background: url(images/index/illust_symptoms01.png)no-repeat center / contain;
    position: absolute;
    bottom: calc(-8 / var(--break04));
    right: calc(-170 / var(--break04));
}

.row_symptoms02::after {
    content: "";
    width: calc(144 / var(--break04));
    height: calc(136 / var(--break04));
    margin: auto;
    background: url(images/index/illust_symptoms02.png)no-repeat center / contain;
    position: absolute;
    bottom: calc(-92 / var(--break04));
    right: calc(96 / var(--break04));
}

@media(min-width: 768px) {
    .row_symptoms02>.col_img {
        max-width: 670px;
        width: 50%;
    }

    .row_symptoms02>.col_txt {
        width: 46%;
        padding: 0 2% 0 5%;
        height: calc(360 / var(--break03));
        position: relative;
    }

    .row_symptoms02>.col_txt::before {
        content: "";
        width: calc(683 / var(--break03));
        height: 100%;
        margin: auto;
        background: url(images/index/box_symptoms01.png)no-repeat center / 100%;
        position: absolute;
        inset: 0 auto 0 0;
    }
}

@media(min-width: 768px) and (max-width:1299px) {
    .row_symptoms02>.col_img {
        width: 47.5%;
    }

    .row_symptoms02>.col_txt {
        width: 48%;
        font-size: 98%;
        left: -2.5%;
    }
}

@media(max-width: 767px) {
    .lp_symptoms {
        padding-bottom: calc(100 / 750 * 100vw);
        background: url(images/index/bg_symptoms01_sp.png)no-repeat center top 92vw / calc(750 / 750 * 100vw);
    }

    .lp_symptoms::before {
        width: calc(706 / 750 * 100vw);
        height: calc(172 / 750 * 100vw);
        background: url(images/index/deco_symptoms01_sp.png)no-repeat center / contain;
        inset: 24vw 0 auto;
        z-index: -1;
    }

    .lp_symptoms .areaTitle::before {
        bottom: 10vw;
    }

    .row_symptoms::after {
        width: calc(199 / var(--break04));
        height: calc(209 / var(--break04));
        background: url(images/index/illust_symptoms01_sp.png)no-repeat center / contain;
        top: calc(292 / var(--break04));
        right: -0.5vw;
        bottom: auto;
    }

    .row_symptoms02 {
        width: calc(682 / 750 * 100vw);
        margin: 0 auto calc(80 / 750 * 100vw) !important;
    }

    .row_symptoms02::after {
        content: none;
    }

    .row_symptoms02>.col_txt {
        max-width: 100% !important;
        width: 100% !important;
        padding: 5vw 0;
        background: #f9f8eb;
        position: relative;
        z-index: 1;
    }

    .row_symptoms02>.col_txt::before {
        content: "";
        width: 99.999vw;
        height: 100%;
        margin: auto;
        background: #f9f8eb;
        position: absolute;
        inset: 0 -50%;
        z-index: -1;
    }

    .row_symptoms02::before {
        content: "";
        width: calc(138 / 750 * 100vw);
        height: calc(112 / 750 * 100vw);
        margin: auto;
        background: url(images/index/illust_symptoms04_sp.png)no-repeat center / contain;
        position: absolute;
        bottom: -8vw;
        right: calc(-16 / 750 * 100vw);
        z-index: 2;
    }

    .row_symptoms02>.col_txt::after {
        content: "";
        width: calc(83 / 750 * 100vw);
        height: calc(75 / 750 * 100vw);
        margin: auto;
        background: url(images/index/illust_symptoms03_sp.png)no-repeat center / contain;
        position: absolute;
        top: -5vw;
        left: calc(-6 / 750 * 100vw);
    }

    .lp_symptoms .copy_common04 {
        width: calc(646 / 750 * 100vw);
        margin: 0 auto var(--size60px);
        letter-spacing: 0;
        position: relative;
        z-index: 1;
    }

    .lp_symptoms .copy_common04::before {
        content: "";
        width: calc(144 / var(--break04));
        height: calc(136 / var(--break04));
        margin: auto;
        background: url(images/index/illust_symptoms02.png)no-repeat center / contain;
        position: absolute;
        bottom: -3vw;
        right: -4vw;
    }
}

/* bg_mft
------------------------------------------------------------------*/
.lp_mft {
    position: relative;
    z-index: 1;
}

.lp_mft::before {
    content: "";
    width: calc(1890 / var(--break03));
    height: calc(1890 / var(--break03));
    margin: auto;
    background: url(images/index/deco_mft01.png)no-repeat center / cover;
    position: absolute;
    inset: calc(-140 / 1920 * 100vw) auto 0 0;
    z-index: 2;
}

.bg_mft {
    padding: calc(70 / var(--break02)) 0 calc(138 / var(--break02));
    background: url(images/index/bg_mft01.png)no-repeat center top calc(698 / 1920 * 100vw) / auto, url(images/page/pattern_stripe_g.png)repeat center;
    position: relative;
    z-index: 1;
}

.bg_mft::before,
.bg_mft::after {
    content: "";
    width: calc(1180 / 1920 * 100vw);
    height: calc(420/ 1920 * 100vw);
    margin: auto;
    background: rgba(255, 255, 255, .15);
    clip-path: polygon(0 0, 0% 100%, 100% 0);
    position: absolute;
    top: 0;
}

.bg_mft::before {
    left: 0;
}

.bg_mft::after {
    right: 0;
    clip-path: polygon(0 0, 100% 100%, 100% 0);
}

.copy_mft {
    padding: var(--size35px);
    background: url(images/index/deco_copy_mft01.png)no-repeat left 3.5% center / calc(61 / var(--break03)), url(images/index/deco_copy_mft01_1.png)no-repeat right 3.5% center / calc(61 / var(--break03));
    text-align: center;
    position: relative;
    z-index: 1;
}

.copy_mft::before,
.copy_mft::after {
    content: "";
    width: 100%;
    height: calc(12 / var(--break03));
    margin: auto;
    background: url(images/page/line.png)repeat center;
    position: absolute;
    left: 0;
    right: 0;
}

.copy_mft::before {
    top: 0;
}

.copy_mft::after {
    bottom: 0;
}


.row_mft02::before {
    background: url(images/index/img_mft03.jpg)no-repeat center / cover;
}

.row_mft03::before {
    background: url(images/index/img_mft04.jpg)no-repeat center / cover;
}

.row_mft04::before {
    background: url(images/index/img_mft05.jpg)no-repeat center / cover;
}

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

@media(max-width: 767px) {
    .bg_mft {
        background: url(images/page/pattern_stripe_g.png)repeat center / calc(30 / 750 * 100vw);
    }

    .lp_mft::before {
        content: none;
    }

    .bg_mft::before,
    .bg_mft::after {
        width: calc(545 / 750 * 100vw);
        height: calc(200 / 750 * 100vw);
    }

    .copy_mft {
        padding: 5vw 0;
        line-height: 1.6;
        background: url(images/index/deco_copy_mft01.png)no-repeat left 8% top 6vw/ calc(61 / var(--break03)), url(images/index/deco_copy_mft01.png)no-repeat right 8% top 6vw/ calc(61 / var(--break03));
    }

    .copy_mft::before,
    .copy_mft::after {
        background: url(images/page/line.png)repeat center / calc(10 / 750 * 100vw);
    }
}

/* lp_type
------------------------------------------------------------------*/
.lp_type {
    padding: var(--size110px) 0 var(--size100px);
    background: url(images/index/bg_type.png)no-repeat center top calc(420 / 1920 * 100vw) / auto;
    position: relative;
    z-index: 1;
}

.lp_type::before {
    content: "";
    max-width: 1770px;
    max-height: 1287px;
    width: calc(1770/ 1840 * 100vw);
    height: calc(1287/ 1840 * 100vw);
    margin: auto;
    background: url(images/index/deco_type.png)no-repeat center / 100%;
    position: absolute;
    inset: calc(200 / 1920 * 100vw) 0 auto;
}

.copy_type {
    padding: var(--size35px);
    background: url(images/index/deco_copy_type01.png)no-repeat left 3.5% center / calc(61 / var(--break03)), url(images/index/deco_copy_type01_1.png)no-repeat right 3.5% center / calc(61 / var(--break03));
    text-align: center;
    position: relative;
    z-index: 1;
}

.copy_type::before,
.copy_type::after {
    content: "";
    width: 100%;
    height: calc(12 / var(--break03));
    margin: auto;
    background: url(images/page/line_lb.png)repeat center;
    position: absolute;
    left: 0;
    right: 0;
}

.copy_type::before {
    top: 0;
}

.copy_type::after {
    bottom: 0;
}

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

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

@media(max-width: 767px) {
    .lp_type {
        padding: 13vw 0 calc(100 / 750 * 100vw);
        background: url(images/index/bg_type.png)no-repeat center top calc(420 / 1920 * 100vw) / auto;
    }

    .lp_type::before {
        width: calc(213/ 750 * 100vw);
        height: calc(116 / 750 * 100vw);
        background: url(images/index/deco_type_sp.png)no-repeat center / 100%;
        inset: calc(68 / 750 * 100vw) auto auto calc(26 / 750 * 100vw);
    }

    .copy_type {
        padding: 5vw 0;
        line-height: 1.6;
        background: url(images/index/deco_copy_type01.png)no-repeat left 8% top 6vw/ calc(61 / var(--break03)), url(images/index/deco_copy_type01_1.png)no-repeat right 8% top 6vw/ calc(61 / var(--break03));
    }

    .copy_type::before,
    .copy_type::after {
        background: url(images/page/line_lb.png)repeat center / calc(10 / 750 * 100vw);
    }
}


/* lp_ortho
------------------------------------------------------------------*/
.bg_ortho {
    padding: var(--size70px) 0 var(--size100px);
    background: url(images/index/bg_orrho01.png)no-repeat center bottom calc(100 / 1920 * 100vw) / auto, url(images/page/pattern_stripe_p2.png)repeat center;
    position: relative;
    z-index: 1;
}

.bg_ortho::after {
    content: "";
    width: calc(189 / var(--break04));
    height: calc(170 / var(--break04));
    margin: auto;
    background: url(images/index/deco_ortho01.png)no-repeat center / contain;
    position: absolute;
    top: calc(110 / 1920 * 100vw);
    left: calc(440 / 1920 * 100vw);
}

.bg_ortho .bg::before,
.bg_ortho .bg::after {
    content: "";
    width: calc(1180 / 1920 * 100vw);
    height: calc(460/ 1920 * 100vw);
    margin: auto;
    background: rgba(255, 255, 255, .15);
    clip-path: polygon(0 0, 0% 100%, 100% 0);
    position: absolute;
    top: 0;
}

.bg_ortho .bg::before {
    left: 0;
}

.bg_ortho .bg::after {
    right: 0;
    clip-path: polygon(0 0, 100% 100%, 100% 0);
}

.illust_ortho01 {
    width: calc(1454 / var(--break04));
    margin: auto;
    position: absolute;
    bottom: calc(120 / var(--break04));
    left: 0;
    right: calc(40 / var(--break04));
    z-index: -1;
}

.bg_ortho02 {
    padding: var(--size30px) 0 var(--size140px);
}

.row_ortho02>.col {
    width: 30.8%;
    padding: var(--size30px);
    background: #fff;
    border-radius: var(--size10px);
}

.row_ortho02 .icon {
    width: calc(200 / var(--break03));
}

.row_ortho02 .copy {
    max-width: 252px;
    width: 100%;
    margin: calc(-28 / var(--break02)) auto auto;
    padding: calc(14 / var(--break02));
    line-height: 1.6;
    text-align: center;
    border-radius: var(--size5px);
    color: #fff;
    background: #8fdd2a;
}

@media(min-width: 768px) {
    .row_ortho02 {
        max-width: 1040px;
        width: 92%;
        margin-left: auto;
        margin-right: auto;
    }

    .row_ortho02>.col {
        margin-right: 3.7%;
    }

    .row_ortho02>.col:nth-of-type(3),
    .row_ortho02>.col:last-child {
        margin-right: 0;
    }

    .row_ortho02>.col:nth-of-type(n + 4) {
        margin-top: var(--size40px);
    }
}

@media(min-width: 768px) and (max-width:1299px) {
    .illust_ortho01 {
        width: calc(1454 / 1460 * 100vw);
        right: 0;
        z-index: -1;
    }
}

@media(max-width: 767px) {
    .bg_ortho {
        background: url(images/index/bg_ortho01_sp.png)no-repeat center bottom calc(80 / 750 * 100vw) / 100%, url(images/page/pattern_stripe_p2.png)repeat center/calc(30 / 750 * 100vw);
    }

    .bg_ortho::after {
        width: calc(100 / 750 * 100vw);
        height: calc(170 / 750 * 100vw);
        background: url(images/index/deco_ortho01_sp.png)no-repeat center / contain;
        top: calc(134 / 750 * 100vw);
        left: 0;
    }

    .bg_ortho .bg::before,
    .bg_ortho .bg::after {
        width: calc(545 / 750 * 100vw);
        height: calc(200 / 750 * 100vw);
    }

    .row_ortho02 {
        max-width: calc(680 / 750 * 100vw);
        margin-left: auto;
        margin-right: auto;
    }

    .row_ortho02>.col {
        width: 48.5%;
        margin-right: 3%;
        padding: calc(30 /750*100vw) calc(20 /750*100vw);
    }

    .row_ortho02>.col:nth-of-type(2n),
    .row_ortho02>.col:last-child {
        margin-right: 0;
    }

    .row_ortho02>.col:nth-of-type(n + 3) {
        margin-top: var(--size30px);
    }

    .row_ortho02 .copy {
        margin: calc(-28 / var(--break02)) auto auto;
        padding: calc(14 / var(--break02));
        font-size: calc(24 / var(--break02));
    }

    .illust_ortho01 {
        width: calc(662 / 750 * 100vw);
        margin-top: 5vw;
        position: relative;
        inset: 0;
        z-index: -1;
    }

    .bg_ortho02 {
        padding: 8vw 0 13vw;
    }
}

.tbl_ortho20 table {
    border: 2px solid #825245;
}

.tbl_ortho20 .copy {
    padding: calc(11.5 / var(--break03)) 1%;
    line-height: 1.5;
    letter-spacing: .1em;
    font-family: "zen-maru-gothic", sans-serif;
    font-weight: 700;
    font-style: normal;
    font-size: calc(24 / var(--break02));
    color: #fff;
    background: #8fdd2a;
    text-align: center;
    vertical-align: top;
}

.tbl_ortho20 tr:not(:last-child) td {
    border-bottom: 1px solid #825245;
}

.tbl_ortho20 td {
    width: 30%;
    padding: calc(16 / var(--break03)) 1.5%;
    line-height: 1.5;
    vertical-align: top;
    background: #fff;
}

.tbl_ortho20 .img {
    margin-top: var(--size20px);
}

.tbl_ortho20 .t01 {
    width: 21.5% !important;
    color: #fff;
    background: #825245 !important;
}

.tbl_ortho20 tr:not(:last-child) .t01 {
    border-bottom-color: #fff !important;
}

.tbl_ortho20 td.t03 {
    background: #f9f8eb !important;
}

@media(min-width: 768px) and (max-width:1599px) {
    .tbl_ortho20 table {
        font-size: 95%;
    }
}

@media(max-width: 767px) {
    .tbl_ortho20 table {
        width: calc(1500 / 750 * 100vw);
        font-size: 92%;
        border-width: 1px;
    }

    .tbl_ortho20 .copy {
        padding: 2vw;
        letter-spacing: .1em;
        font-size: 110%;
    }
}

/* lp_flow
------------------------------------------------------------------*/
.lp_flow {
    padding: var(--size110px) 0 var(--size100px);
    position: relative;
    z-index: 1;
}

.lp_flow::before {
    content: "";
    width: calc(1814 / 1920 * 100vw);
    height: calc(1802 / 1920 * 100vw);
    margin: auto;
    background: url(images/index/deco_flow01.png)no-repeat center / cover;
    position: absolute;
    inset: calc(100 / 1920 * 100vw) 0 0;
}

.box_common_flow01 {
    width: 100%;
    margin-bottom: calc(90 / var(--break03));
    padding: calc(28 / var(--break03));
    min-height: calc(240 / var(--break03));
    border: var(--size10px) solid #30c9db;
    border-radius: var(--size30px);
    background: #fff;
    position: relative;
    z-index: 1;
}

.box_common_flow01::before {
    content: "";
    width: calc(10 / var(--break02));
    height: calc(70 / var(--break02));
    margin: auto;
    border-left: dotted #30c9db calc(10 / var(--break02));
    position: absolute;
    top: calc(100% + 20 / var(--break02));
    left: 0;
    right: 0;
}

.fum_common_flow01 {
    width: calc(140 / var(--break02));
    margin: auto;
    position: absolute;
    inset: calc(-30 / var(--break02)) auto auto calc(55 / var(--break02));
    z-index: 1;
}

.box_common_flow01:nth-of-type(2)::before {
    border-color: #8fdd2a;
}

.box_common_flow01:nth-of-type(3)::before {
    border-color: #ff9c27;
}

.box_common_flow01:nth-of-type(4)::before {
    border-color: #ff8eae;
}

.box_common_flow01:nth-of-type(5)::before {
    border-color: #9185cd;
}

.box_common_flow01:last-child {
    margin-bottom: 0;
}

.box_common_flow01:last-child::before {
    content: none;
}

@media(min-width: 768px) {
    .row_common_flow01>.col_img {
        max-width: 345px;
        width: 31%;
    }

    .row_common_flow01>.col_txt {
        width: 65%;
    }
}

@media(max-width: 767px) {
    .bg_flow {
        padding: calc(220 / 750 * 100vw) 0 calc(100 / 750 * 100vw);
    }

    .lp_flow::before {
        width: calc(125 / 750 * 100vw);
        height: calc(112 / 750 * 100vw);
        background: url(images/index/deco_flow01_sp.png)no-repeat center / cover;
        inset: 23vw auto auto 3vw;
    }

    .box_common_flow01 {
        margin-bottom: calc(110 / 750 * 100vw);
        padding: calc(38 / 750 * 100vw) calc(39 / 750 * 100vw) calc(40 / 750 * 100vw);
    }

    .box_common_flow01::before {
        top: calc(100% + 30 / var(--break02));
    }

    .copy_common_flow01 {
        font-size: calc(36 / 750 * 100vw);
    }

    .fum_common_flow01 {
        inset: calc(-34 / var(--break02)) auto auto calc(-26 / var(--break02));
    }

}

/* lp_case
------------------------------------------------------------------*/
.lp_case {
    padding: var(--size90px) 0 var(--size100px);
    background: url(images/page/pattern_stripe_o.png)repeat center;
    position: relative;
    z-index: 1;
}

.lp_case::before,
.lp_case::after {
    content: "";
    width: calc(1180 / 1920 * 100vw);
    height: calc(460/ 1920 * 100vw);
    margin: auto;
    background: rgba(255, 255, 255, .15);
    clip-path: polygon(0 0, 0% 100%, 100% 0);
    position: absolute;
    top: 0;
}

.lp_case::before {
    left: 0;
}

.lp_case::after {
    right: 0;
    clip-path: polygon(0 0, 100% 100%, 100% 0);
}

.area_case_common01 .tbl_common02 {
    margin-top: var(--size30px);
}

.copy_case02 {
    margin-bottom: var(--size20px);
    height: var(--size50px);
    line-height: 1;
    color: #fff;
    background: #ff8eae;
    border-radius: var(--size5px);
    position: relative;
    z-index: 1;
}

.slider_case_img .slick-prev,
.slider_case_img .slick-next,
.slider_case_img .slick-prev:hover,
.slider_case_img .slick-next:hover,
.slider_case_img .slick-prev:focus,
.slider_case_img .slick-next:focus {
    width: calc(30 / var(--break02));
    height: calc(54 / var(--break02));
    background: url(images/index/arw.svg)no-repeat center / cover;
    z-index: 1;
    top: 0;
    bottom: 0;
    margin: auto;
    transform: none;
}

.slider_case_img .slick-prev:before,
.slider_case_img .slick-next:before {
    display: none;
}

.slider_case_img .slick-prev {
    left: calc(-100 / 1920 * 100vw);
}

.slider_case_img .slick-next {
    right: calc(-100 / 1920 * 100vw);
    transform: scaleX(-1) !important;
}

.slider_case_img.slick-dotted.slick-slider {
    margin-bottom: 0 !important;
}

.slider_case_img .slick-dots {
    margin-top: var(--size35px);
    position: relative;
    bottom: auto;
}

.slider_case_img li button:before {
    width: calc(11 / var(--break02));
    height: calc(11 / var(--break02));
    opacity: 1;
    background: #ff8eae;
    font-size: 0;
    border-radius: 100%;
}

.slider_case_img .slick-dots li.slick-active button:before {
    opacity: 1;
    background: #30c9db
}

@media(max-width: 767px) {
    .lp_case {
        padding: 10vw 0 var(--size100px);
        background: url(images/page/pattern_stripe_o.png)repeat center / calc(30 / 750 * 100vw);
    }

    .lp_case::before,
    .lp_case::after {
        width: calc(545 / 750 * 100vw);
        height: calc(200 / 750 * 100vw);
    }

    .copy_case01 {
        margin-bottom: 4vw !important;
    }

    .copy_case02 {
        margin-bottom: var(--size20px);
        height: var(--size50px);
        padding-top: 1.25vw;
        font-size: calc(24 /750*100vw);
    }

    .slider_case_img .slick-prev,
    .slider_case_img .slick-next,
    .slider_case_img .slick-prev:hover,
    .slider_case_img .slick-next:hover,
    .slider_case_img .slick-prev:focus,
    .slider_case_img .slick-next:focus {
        width: calc(30 / 750* 100vw);
        height: calc(54 / 750* 100vw);
        z-index: 1;
        top: 0;
        bottom: 0;
    }

    .slider_case_img .slick-prev,
    .slider_case_img .slick-next {
        top: -14vw;
    }

    .slider_case_img .slick-prev {
        left: 3.5%;
    }

    .slider_case_img .slick-next {
        right: 3.5%;
        transform: scaleX(-1) !important;
    }

    .slider_case_img li button:before {
        width: var(--size20px);
        height: var(--size20px);
    }

    .slider_case_img .slick-dots li {
        margin: 0;
    }
}

/* top_fee
------------------------------------------------------------------*/
.lp_fee {
    padding: var(--size65px) 0 var(--size100px);
    background: url(images/index/bg_fee.png)no-repeat center / auto;
    position: relative;
    z-index: 1;
}

.lp_fee::before {
    content: "";
    width: calc(1735 / var(--break04));
    height: calc(2167 / var(--break04));
    margin: auto;
    background: url(images/page/deco_pattern.png)no-repeat center / contain;
    position: absolute;
    inset: calc(140 / 1920 * 100vw) -50% auto;
    z-index: 9;
}

.lp_fee .shadow_w {
    position: relative;
    z-index: 100;
}

.copy_fee01 .s2 {
    padding: 0 .05em;
    letter-spacing: .1em;
}

.copy_fee01 .s4 {
    width: 200%;
    line-height: 1;
    letter-spacing: 0;
    font-size: calc(18 / var(--break03));
    position: absolute;
    bottom: 100%;
    left: -10%;
}

.copy_fee01 .s5 {
    font-size: calc(50 / var(--break03));
}

.illust_fee {
    width: calc(164 / var(--break04));
    position: absolute;
    bottom: calc(-30 / var(--break04));
    right: calc(60 / var(--break04));
}

.illust_fee02 {
    width: calc(148 / var(--break04));
    position: absolute;
    bottom: calc(-10 / var(--break04));
    right: calc(90 / var(--break04));
}

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

@media(max-width: 767px) {
    .lp_fee {
        padding: var(--size65px) 0 var(--size100px);
        background: none;
    }

    .lp_fee::before {
        width: calc(213 / 750 * 100vw);
        height: calc(116 / 750 * 100vw);
        background: url(images/page/deco_pattern_sp.png)no-repeat center / contain;
        inset: calc(134 / 750 * 100vw) auto auto 3vw;
    }

    .copy_fee01 {
        font-size: calc(32 / 750 * 100vw);
    }

    .copy_fee01 .s {
        font-size: calc(32 / 750 * 100vw);
    }

    .copy_fee01 .s2 {
        letter-spacing: 0.05em;
        font-size: calc(100 / 750 * 100vw);
    }

    .copy_fee01 .s4 {
        width: 200%;
        line-height: 1;
        letter-spacing: 0;
        font-size: calc(24 / var(--break03));
        position: absolute;
        bottom: 100%;
        left: -10%;
    }

    .coverFee .box_common02 {
        margin-left: -2vw;
        margin-right: -2vw;
        padding: 4vw 0;
        text-align: center;
    }

    .illust_fee {
        display: none;
    }

    .illust_fee02 {
        display: none;
    }

    .coverFee .box_common01 {
        margin-left: -3.2vw;
        margin-right: -3.2vw;
        padding-bottom: var(--size80px);
    }
}

/* row_fee_common
------------------------------------------------------------------*/
.row_fee_common>.col {
    width: 23%;
    padding: var(--size30px) var(--size10px);
    background: rgba(255, 255, 255, .6);
    overflow: hidden;
    position: relative;
    z-index: 1
}

.row_fee_common .icon {
    max-width: 176px;
    width: var(--size180px);
}

@media(min-width: 768px) {
    .row_fee_common>.col {
        margin-right: 2.65%;
    }

    .row_fee_common>.col:nth-of-type(4),
    .row_fee_common>.col:last-child {
        margin-right: 0;
    }
}

@media(min-width: 768px) and (max-width:1299px) {
    .row_fee_common .icon {
        width: var(--size170px)
    }

    .row_fee_common>.col {
        font-size: 92%
    }
}

@media(max-width: 767px) {
    .row_fee_common.flex {
        max-width: calc(650 / 750 * 100vw);
        justify-content: space-between;
    }

    .row_fee_common>.col {
        max-width: calc(310 / 750 * 100vw);
        width: 48.5%;
        padding: 5vw var(--size10px) 3vw;
        background: #fff;
    }

    .row_fee_common>.col:nth-of-type(n + 3) {
        margin-top: var(--size30px);
    }

    .row_fee_common .fz22 {
        letter-spacing: 0;
        font-size: calc(34 / 750 * 100vw);
    }

    .row_fee_common .icon {
        width: calc(176 / 750 * 100vw);
        margin-bottom: 3vw;
    }

    .row_fee_common .txt01 {
        font-size: calc(24 / 750 * 100vw);
    }
}

/* row_fee_common
------------------------------------------------------------------*/
.row_fee02 {
    max-width: 1040px;
    margin-left: auto;
    margin-right: auto;
}

.row_fee02>.col {
    width: 15.6%;
    position: relative;
    z-index: 100;
}

.row_fee02>.arw::before {
    content: "";
    width: calc(40/ var(--break04));
    height: calc(70/ var(--break04));
    margin: auto;
    background: url(images/index/arrow_fee.svg)no-repeat center / contain;
    position: absolute;
    top: 0;
    bottom: 0;
    left: calc(100% - .2px);
    z-index: 10;
}

.row_fee02>.col:nth-of-type(2) {
    z-index: 98;
}

.row_fee02>.col:nth-of-type(3) {
    z-index: 96;
}

.row_fee02>.col:nth-of-type(4) {
    z-index: 92;
}

.row_fee02>.col:nth-of-type(5) {
    z-index: 80;
}

.row_fee02>.col:nth-of-type(6) {
    z-index: 78;
}

.row_fee02>.box {
    padding: calc(28 / var(--break03)) 0;
    line-height: 1.5;
    letter-spacing: .1em;
    font-size: calc(28 / var(--break03));
    color: #30c9db;
    border: 2px solid #30c9db;
    background: #fff;
    border-radius: var(--size10px);
}

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

@media(max-width: 767px) {
    .row_fee02 {
        margin-left: -1vw;
        margin-right: -1vw;
    }

    .row_fee02>.box {
        width: calc(220 / 750 * 100vw);
        padding: 4vw 0;
        letter-spacing: .1em;
        font-size: calc(28 / 750 * 100vw);
        border-width: 1px;
    }

    .row_fee02>.col:nth-of-type(3)::before {
        content: none;
    }

    .row_fee02>.col:nth-of-type(n + 4) {
        margin-top: calc(20 / 750 * 100vw);
    }

    .row_fee02>.col:nth-of-type(5) {
        width: 13.5%;
        padding: 0 2.5vw 1vw 4vw;
    }

    .row_fee02>.col:nth-of-type(6) {
        width: calc(350 / 750 * 100vw);
    }
}

/* lp_greeting
------------------------------------------------------------------*/
.lp_greeting {
    padding: calc(110 / var(--break03)) 0 var(--size100px);
    position: relative;
    z-index: 1;
}

.lp_greeting::before {
    content: "";
    width: 100%;
    height: 100%;
    margin: auto;
    background: url(images/page/pattern_stripe_b.png)repeat center;
    position: absolute;
    inset: 0;
    z-index: -1;
}

.bg_greeting::before,
.bg_greeting::after {
    content: "";
    width: calc(1200 / 1920 * 100vw);
    height: calc(460/ 1920 * 100vw);
    margin: auto;
    background: rgba(255, 255, 255, .15);
    clip-path: polygon(0 0, 0% 100%, 100% 0);
    position: absolute;
    top: 0;
}

.bg_greeting::before {
    left: 0;
}

.bg_greeting::after {
    right: 0;
    clip-path: polygon(0 0, 100% 100%, 100% 0);
}

.bg_greeting {
    background: url(images/index/bg_greeting01.png)no-repeat center top calc(480 / var(--break04)) / 100%;
}

.row_greeting {
    max-width: 1640px;
    width: 96%;
}

.row_greeting>.col_img {
    width: 55.9%;
    padding-bottom: calc(25 / var(--break04));
    position: relative;
    z-index: 1;
}

.row_greeting>.col_txt {
    width: 42%;
}

.row_greeting .tagName {
    width: calc(540 / var(--break03));
    height: calc(80 / var(--break03));
    margin: auto;
    padding-left: calc(90 / var(--break03));
    ;
    font-size: calc(18 / var(--break03));
    background: #fff958;
    position: absolute;
    border-radius: var(--size5px);
    right: calc(80 / 1920 * 100vw);
    bottom: 0;
}

.row_greeting .tagName .tag {
    width: calc(124 / var(--break03));
    height: calc(124 / var(--break03));
    margin: auto;
    color: #fff;
    background: url(images/index/ballon_greeting01.png)no-repeat center / cover;
    position: absolute;
    left: calc(28 / var(--break03));
    bottom: calc(26 / var(--break03));
    z-index: 1;
}

.row_greeting .tagName .name_en {
    padding-left: calc(10 / var(--break03));
}

.row_greeting .tagName .fz28 {
    font-size: calc(28 / var(--break03));
}

.row_greeting .copy_common01 {
    font-size: calc(28 / var(--break04));
}

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

@media(max-width: 767px) {
    .lp_greeting {
        padding: calc(100 / var(--break03)) 0 var(--size100px);
    }

    .lp_greeting::before {
        background: url(images/page/pattern_stripe_b.png)repeat center / calc(28 / 750 * 100vw);
    }

    .bg_greeting::before,
    .bg_greeting::after {
        width: calc(570 / 750 * 100vw);
        height: calc(200 / 750 * 100vw);
    }

    .bg_greeting {
        background: url(images/index/bg_greeting01.png)no-repeat center top calc(480 / var(--break04)) / 100%;
    }

    .row_greeting {
        width: 100%;
    }

    .row_greeting>.col_img {
        width: calc(728 / 750 * 100vw);
        margin-bottom: 6vw;
        padding-bottom: 1vw;
    }

    .row_greeting>.col_txt {
        width: calc(642 / 750 * 100vw);
        margin: 0 auto 0;
    }

    .row_greeting .col_txt .text {
        padding: 0;
    }

    .row_greeting .tagName {
        width: calc(540 / var(--break03));
        height: calc(80 / var(--break03));
        padding-left: 18vw;
        padding-top: 1vw;
        right: calc(80 / 750 * 100vw);
    }

    .row_greeting .tagName .tag {
        font-size: calc(28 / 750 * 100vw);
        left: calc(43 / 750 * 100vw);
        z-index: 1;
    }

    .row_greeting .tagName .name_jp {
        font-size: calc(32 / 750 * 100vw);
    }

    .row_greeting .tagName .name_en {
        padding-left: calc(10 / var(--break03));
        font-size: calc(20 / var(--break03));
    }

    .row_greeting .copy_common01 {
        line-height: 1.75;
        font-size: calc(36 / 750 * 100vw);
    }

    .box_greeting {
        padding: calc(60 / 750 * 100vw) 4% 7vw !important;
    }
}

/* lp_clinics
------------------------------------------------------------------*/
.lp_clinic {
    padding: var(--size70px) 0 0;
    background: url(images/index/bg_clinic01.png)no-repeat center top / 100%;
}

.cover_clinic {
    position: relative;
    z-index: 1;
}

.cover_clinic::before {
    content: "";
    width: 50%;
    height: 100%;
    margin: auto;
    background: url(images/index/img_clinic.png)no-repeat center / cover;
    border-radius: 0 calc(500 / 1920 * 100vw) 0 0;
    position: absolute;
    inset: 0 0 0 auto;
}

.cover_clinic>.areaText {
    width: 50%;
    padding: calc(80 / var(--break04)) calc(70 / 1920 * 100vw) calc(80 / var(--break04));
    border-radius: calc(500 / 1920 * 100vw) 0 0 0;
    background: #f9f8eb;
}

.cover_clinic .areaText>.wrap {
    max-width: 530px;
    width: 100%;
    margin: 0 0 0 auto;
}

.cover_clinic .logo_clinic {
    width: calc(497 / var(--break04));
    margin: 0 auto calc(30 / var(--break04));
}

.cover_clinic .btn_tel_common02 {
    margin: 0 auto calc(30 / var(--break04));
}

.cover_clinic .tbl_time01 {
    margin-left: auto;
    margin-right: auto;
}

.cover_clinic .deco_clinic {
    width: calc(141 / 1920 * 100vw);
    height: calc(279 / 1920 * 100vw);
    margin: auto;
    position: absolute;
    inset: auto 0 0 calc(-50 / 1920 * 100vw);
    z-index: 1;
}

.cover_clinic .deco_clinic02 {
    width: calc(260 / 1920 * 100vw);
    height: calc(220 / 1920 * 100vw);
    margin: auto;
    position: absolute;
    inset: calc(-100 / 1920 * 100vw) auto auto 0;
    z-index: 1;
}

.ballon_clinic {
    width: calc(335 / var(--break04));
    margin: auto;
    position: absolute;
    inset: auto 0 calc(100% + calc(40 / var(--break04)));
}

@media(max-width: 767px) {
    .lp_clinic {
        padding: 11vw 0 0;
        background: url(images/index/bg_clinic01_sp.png)no-repeat left top / calc(294 / 750 * 100vw);
    }

    .top_clinic .areaTitle {
        margin-bottom: var(--size80px);
    }

    .cover_clinic {
        padding-top: calc(450 / 750 * 100vw);
        margin-bottom: var(--size60px);
    }

    .cover_clinic::before {
        width: 100%;
        height: calc(450 / 750 * 100vw);
        background: url(images/index/img_clinic_sp.jpg)no-repeat center / 100%;
        border-radius: 0;
        top: 0;
        bottom: auto;
    }

    .cover_clinic>.areaText {
        width: 100%;
        padding: calc(80 / 750 * 100vw) calc(25 / 750 * 100vw);
        border-radius: 0;
    }

    .cover_clinic .areaText>.wrap {
        width: 100%;
        position: static;
    }

    .cover_clinic .logo_clinic {
        margin: 0 auto 7vw;
    }

    .cover_clinic .text_address01 {
        letter-spacing: .1em;
    }

    .ballon_clinic {
        width: calc(201 / var(--break02));
        inset: auto auto calc(100% + calc(28 / var(--break04))) calc(48 / 750 * 100vw)
    }
}

/* lp_qa
------------------------------------------------------------------*/
.bg_qa {
    padding: calc(110 / var(--break03)) 0 calc(230 / var(--break03));
    background: #f9f8eb;
    position: relative;
    z-index: 1;
}

@media(max-width: 767px) {
    .bg_qa {
        padding: 12vw 0 18vw;
    }
}

/* .tbl_time table
------------------------------------------------------------------*/
.tbl_time table {
    border-color: #30c9db;
}

.tbl_time thead th {
    background: #30c9db;
}

.tbl_time tbody th,
.tbl_time tbody td {
    background: #fff;
}

.tbl_time tbody td span {
    color: #ff8eae;
}

.tbl_time tr:not(:last-child) th,
.tbl_time tr:not(:last-child) td {
    border-bottom-color: #30c9db;
}

.tbl_time .tbl_caption {
    margin-top: var(--size15px) !important;
}

@media(max-width: 767px) {
    .tbl_time .tbl_caption {
        text-align: center;
    }
}

/* フッター footer
------------------------------------------------------------------*/
.main_foot {
    padding: calc(60 / var(--break02)) 0 calc(60 / var(--break02));
}

.row_foot01>.col_l {
    width: 45%;
}

.row_foot01>.col_r {
    width: 52%;
}

.pagetop {
    position: fixed;
    right: calc(30 / var(--break) * 100vw);
    bottom: calc(30 / var(--break) * 100vw);
    z-index: 1000;
    width: calc(80 / var(--break) * 100vw);
}

.copyright {
    height: calc(80 / var(--break) * 100vw);
    color: #fff;
    background: var(--color09);
}

@media(max-width: 767px) {
    .main_foot {
        padding: calc(86 / 750 * 100vw) 0 calc(60 / 750 * 100vw);
    }

    .row_foot01 {
        display: block;
    }

    .row_foot01>.col_l {
        width: 100%;
        max-width: 100%;
        margin: 0 auto var(--size60px);
        text-align: center;
    }

    .row_foot01>.col_r {
        width: 100%;
        max-width: 100%;
        margin: 0 auto;
    }

    .row_foot01 .text_address01 {
        letter-spacing: .1em;
    }

    .copyright {
        font-size: 75%;
        letter-spacing: 0;
        padding: 4vw 0 20vw;
        height: auto;
    }

    .pagetop {
        display: none !important;
    }

    .fix {
        position: fixed;
        width: calc(730 / var(--break) * 100vw);
        margin: auto;
        right: 0;
        left: 0;
        bottom: 0;
        z-index: 999;
    }

    .fix_tel {
        width: calc(580 / var(--break) * 100vw);
    }

    .pagetop_sp {
        width: calc(140 / var(--break) * 100vw);
        position: absolute;
        inset: auto 0 0 auto;
    }

    .pagetop_sp a {
        width: 100%;
        padding: 0 calc(10 / var(--break) * 100vw);
    }

    .fix a {
        display: block;
    }
}

/* グーグルマップ
------------------------------------------------------------------*/
.map {
    position: relative;
    width: 100%;
    padding: calc(500 / var(--break) * 100vw) 0 0 0;
    overflow: hidden;
}

.map iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    margin-top: calc(-150 / var(--break) * 100vw);
    height: calc(100% + calc(150 / var(--break) * 100vw));
}

.btn_map {
    width: calc(300 / var(--break) * 100vw);
    font-weight: 400;
    font-size: 1.25rem;
    letter-spacing: .1em;
    left: calc(30 / var(--break) * 100vw);
    top: calc(30 / var(--break) * 100vw);
    z-index: 1;
}

.btn_map a {
    height: var(--size60px);
    letter-spacing: .1em;
    color: #30c9db;
    background: #fff;
    border: 1px solid #30c9db;
}

.btn_map a::before {
    content: "";
    max-width: 15px;
    max-height: 21px;
    width: calc(15 / var(--break02));
    height: calc(21 / var(--break02));
    margin: auto;
    background: url(images/page/icn_map.svg)no-repeat center / contain;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 10%;
}

.btn_map a::after {
    content: "";
    width: 0;
    height: 0;
    margin: auto;
    border-left: calc(8 / var(--break) * 100vw) solid #30c9db;
    border-top: calc(5 / var(--break) * 100vw) solid transparent;
    border-bottom: calc(5 / var(--break) * 100vw) solid transparent;
    position: absolute;
    top: 0;
    bottom: 0;
    right: calc(30 / var(--break) * 100vw);
}

@media(max-width: 767px) {
    .map iframe {
        margin-top: calc(-200 / var(--break) * 100vw);
        height: calc(100% + calc(200 / var(--break) * 100vw));
    }

    .btn_map {
        width: calc(600 / var(--break) * 100vw);
        margin: 0 auto calc(60 / var(--break) * 100vw);
        letter-spacing: .1em;
        font-size: calc(30 / var(--break) * 100vw);
        position: relative;
        left: auto;
        top: auto;
    }

    .btn_map a {
        height: calc(100 / var(--break) * 100vw);
        padding-left: 0;
        font-size: calc(34 / var(--break) * 100vw);
        border-radius: var(--size50px);
        color: #fff;
        background: #30C9DB;
    }

    .btn_map a::before {
        width: calc(41 / 750 * 100vw);
        height: calc(41 / 750 * 100vw);
        background: url(images/page/icn_map_sp.svg)no-repeat center / contain;
        left: 6%;
    }

    .btn_map a::after {
        border-left: calc(14 / var(--break) * 100vw) solid #fff;
        border-top: calc(10 / var(--break) * 100vw) solid transparent;
        border-bottom: calc(10 / var(--break) * 100vw) solid transparent;
        right: calc(30 / var(--break) * 100vw);
    }
}

@media(min-width: 768px) and (max-width:1024px) {
    .feature01::before,
    .feature02::before,
    .feature03::before,
    .feature05::before,
    .feature05::before,
    .feature06::before,
    .cover_feature10::after,
    .bg_ortho::after ,
    .lp_fee::before ,
    .lp_flow::before,
    .lp_type::before
    {content: none !important;}
}