@charset "UTF-8";

/* http://meyerweb.com/eric/tools/css/reset/
    v2.0 | 20110126
    License: none (public domain)
*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;
    box-sizing: border-box;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
    display: block;
}
body {
    line-height: 1;
}
ol, ul {
    list-style: none;
}
blockquote, q {
    quotes: none;
}
blockquote:before, blockquote:after, q:before, q:after {
    content: '';
    content: none;
}
table {
    border-collapse: collapse;
    border-spacing: 0;
}

/* CSS Document */

/*色関連----------------------------------------------------------- */
:root {
    --color_bk: #333333;
    --color_wt: #fff;
    --color1: #f1f4f6;
    --color2: #c4c4c4;
    --color3: #f2f2f2;
    --color4: #dedede;
    --color5: #f5f5f5;
    --color6: #666666;
}
.cl_01 {color: var(--color1);}
.bg_01 {background: var(--color1);}
.cl_02 {color: var(--color2);}
.cl_03 {color: var(--color3);}
.bg_03 {background: var(--color3);}
.cl_04 {color: var(--color4);}
.bg_04 {background-color: var(--color4);}
.bg_05 {background-color: var(--color5);}
.bg_06 {background-color: var(--color6);}
.cl_black {color: var(--color_bk);}
.bg_black {background: var(--color_bk);}
.cl_white {color: var(--color_wt);}
.bg_white {background: var(--color_wt);}

/*オリジナルリセットcss----------------------------------------------------------- */
p {margin-bottom: 0;line-height: 1.8;}
img {display: block;}
li {list-style: none;}

/*デバイス共通----------------------------------------------------------- */
html {
    font-size: 62.5%;
}
body {
    font-family: YuGothic, "YuGothic M", "游ゴシック体", "メイリオ", Meiryo, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", sans-serif;
    font-size: 1.6rem;
    line-height: 2;
    letter-spacing: .19em;
    color: #272727;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
    word-break: break-all;
}
@media (min-width: 768px) and (max-width: 1229px) {
    body {
        font-size: 1.4rem;
        line-height: 1.4;
        letter-spacing: .17em;
    }
}
@media screen and (max-width: 767px) {
    body {
        font-size: 1.4rem;
        line-height: 1.4;
        letter-spacing: .06em;
    }
}
a, a img {
    transition: all .3s;
}
.dib {display: inline-block;}
.m0a {margin: 0 auto;}
.mla {margin-left: auto;}
.posr {position: relative;}
.posa {position: absolute;}
.imgr {display: block; max-width: 100%; height: auto;}

@media screen and (max-width: 767px) {
    .sp_scroll {width: 100%; overflow-x: scroll;}
    .sp_scroll>* {min-width: 768px;}
}

/*テキスト関連----------------------------------------------------------- */
.fwb {font-weight: bold !important;}
.underline {text-decoration: underline;}
.font_xs {font-size: 1rem;}
.font_s {font-size: 1.2rem;}
.font_m {font-size: 1.8rem;}
.font_l {font-size: 2.4rem;}
.font_xl {font-size: 2.8rem;}
.font_xxl {font-size: 4rem;}
@media screen and (max-width: 767px) {
.font_xs {font-size: 8px;}
.font_s {font-size: 10px;}
.font_m {font-size: 12px;}
.font_l {font-size: 16px;}
.font_xl {font-size: 20px;}
.font_xxl {font-size: 35px;}
}
.lh1 {line-height: 1;}
.tac {text-align: center !important;}
.tal {text-align: left !important;}
.tar {text-align: right !important;}
.shadow {text-shadow: 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff;}
.font_min {font-family: "Shippori Mincho", "Yu Mincho", YuMincho, HG明朝B, "MS Mincho", serif;}
.font_go {font-family: "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ヒラギノ角ゴ Pro", "游ゴシック体", YuGothic, "YuGothic M", sans-serif;}
@import url('https://fonts.googleapis.com/css2?family=Lato&display=swap');
.font_lato {font-family: 'Lato', sans-serif;letter-spacing: 3px;}
@import url('https://fonts.googleapis.com/css2?family=Jost&family=Noto+Sans+JP:wght@100;400;700&display=swap');
.font_noto {font-family: 'Noto Sans JP', sans-serif,}
/* @import url('https://fonts.cdnfonts.com/css/din-2'); */
.font_din {font-family: din-2014, sans-serif;font-weight: 600;}

.indent {
    text-indent: -1em;
    padding-left: 1em;
}
.note {
    position: relative;
    font-size: 0.777em;
    padding-left: 1em;
}
.note:before {
    position: absolute;
    content: "※";
    top: 0;
    left: 0;
    font-size: 1em;
    line-height: 1.554em;
}
@media (min-width: 768px) and (max-width: 1229px) {
    .tab_shadow {
        text-shadow: 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff;
    }
}
@media screen and (max-width: 767px) {
    .sp_tal {
        text-align: left !important;
    }

    .sp_shadow {
        text-shadow: 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff;
    }
}

/*余白&幅調整----------------------------------------------------------- */
.mt0 {margin-top: 0;}.mt5 {margin-top: 5px;}.mt10 {margin-top: 10px;}.mt15 {margin-top: 15px;}.mt20 {margin-top: 20px;}.mt30 {margin-top: 30px;}.mt45 {margin-top: 45px;}.mt60 {margin-top: 60px;}.mt75 {margin-top: 75px;}.mt90 {margin-top: 90px;}.mt120 {margin-top: 120px;}.mb0 {margin-bottom: 0;}.mb5 {margin-bottom: 5px;}.mb10 {margin-bottom: 10px;}.mb15 {margin-bottom: 15px;}.mb20 {margin-bottom: 20px;}.mb30 {margin-bottom: 30px;}.mb45 {margin-bottom: 45px;}.mb60 {margin-bottom: 60px;}.mb75 {margin-bottom: 75px;}.mb90 {margin-bottom: 90px;}.mb120 {margin-bottom: 120px;}.pt0 {padding-top: 0;}.pt5 {padding-top: 5px;}.pt10 {padding-top: 10px;}.pt15 {padding-top: 15px;}.pt20 {padding-top: 20px;}.pt30 {padding-top: 30px;}.pt45 {padding-top: 45px;}.pt60 {padding-top: 60px;}.pt75 {padding-top: 75px;}.pt90 {padding-top: 90px;}.pt120 {padding-top: 120px;}.pb0 {padding-bottom: 0;}.pb5 {padding-bottom: 5px;}.pb10 {padding-bottom: 10px;}.pb15 {padding-bottom: 15px;}.pb20 {padding-bottom: 20px;}.pb30 {padding-bottom: 30px;}.pb45 {padding-bottom: 45px;}.pb60 {padding-bottom: 60px;}.pb75 {padding-bottom: 75px;}.pb90 {padding-bottom: 90px;}.pb120 {padding-bottom: 120px;}.pl0 {padding-left: 0;}.pr0 {padding-right: 0;}.ph0 {padding-left: 0; padding-right: 0;}.ph15 {padding-left: 15px; padding-right: 15px;}
@media screen and (max-width: 767px) {
    .spmt0 {margin-top: 0;}.spmt5 {margin-top: 5px;}.spmt10 {margin-top: 10px;}.spmt15 {margin-top: 15px;}.spmt20 {margin-top: 20px;}.spmt30 {margin-top: 30px;}.spmt45 {margin-top: 45px;}.spmt60 {margin-top: 60px;}.spmb0 {margin-bottom: 0;}.spmb5 {margin-bottom: 5px;}.spmb10 {margin-bottom: 10px;}.spmb15 {margin-bottom: 15px;}.spmb20 {margin-bottom: 20px;}.spmb30 {margin-bottom: 30px;}.spmb45 {margin-bottom: 45px;}.spmb60 {margin-bottom: 60px;}.sppt0 {padding-top: 0;}.sppt5 {padding-top: 5px;}.sppt10 {padding-top: 10px;}.sppt15 {padding-top: 15px;}.sppt20 {padding-top: 20px;}.sppt30 {padding-top: 30px;}.sppt45 {padding-top: 45px;}.sppt60 {padding-top: 60px;}.sppb0 {padding-bottom: 0;}.sppb5 {padding-bottom: 5px;}.sppb10 {padding-bottom: 10px;}.sppb15 {padding-bottom: 15px;}.sppb20 {padding-bottom: 20px;}.sppb30 {padding-bottom: 30px;}.sppb45 {padding-bottom: 45px;}.sppb60 {padding-bottom: 60px;}.sppl0 {padding-left: 0;}.sppr0 {padding-right: 0;}.spph0 {padding-left: 0; padding-right: 0;}
}
@media screen and (max-width: 767px) {
    .spwd50 {width: 50% !important;}
    .spwd60 {width: 60% !important;}
    .spwd70 {width: 70% !important;}
    .spwd80 {width: 80% !important;}
    .spwd90 {width: 90% !important;}
}

/*見出し----------------------------------------------------------- */
h1, h2, h3 {
    letter-spacing: 0.2em;
    line-height: 1.4;
}
h2 {
    margin: 0;
    padding: 0 0 30px;
    text-align: center;
}
h2 .font_lato,
h2.font_lato {
    letter-spacing: 0.2em;
}
h3 {
    margin: 0;
    padding: 0;
}
@media (min-width: 768px) and (max-width: 1229px) {
    h1, h2, h3 {
        letter-spacing: 0.07em;
    }

    h2 {
        padding: 0 0 45px;
    }
    h2 .font_lato,
    h2.font_lato {
        letter-spacing: 0.05em;
    }
}
@media screen and (max-width: 767px) {
    h1, h2, h3 {
        letter-spacing: .06em;
    }
    h2 {
        padding: 0 0 30px;
    }
}

/*はみ出し画像中央----------------------------------------------------------- */
.wic_wrap {
    overflow-x: hidden;
}
.wic img {
    width: auto;
    max-width: unset;
}
.wic1 {
    margin-left: calc(50% - 1000px);
}
.wic1 img {
    width: 2000px;
    max-width: 2000px;
}
.wic2 {
    margin-left: calc(50% - 670px);
}
.wic2 img {
    /* width: 1340px;
max-width: 1340px; */
}
@media screen and (max-width: 767px) {
    .wic1 img {
        width: 100%;
    }
    .wic1 {
        margin-left: 0;
        margin-right: 0;
    }
}

/*white-box----------------------------------------------------------- */
.white_box {
    padding: 45px;
    background-color: #fff;
    margin-bottom: 30px;
}
.white_box_xl {
    padding: 90px;
    background-color: #fff;
    margin-bottom: 30px;
}
.white_box_l {
    padding: 60px;
    background-color: #fff;
    margin-bottom: 30px;
}
.white_box_s {
    padding: 30px;
    background-color: #fff;
    margin-bottom: 30px;
}
.white_box_xs {
    padding: 15px;
    background-color: #fff;
    margin-bottom: 30px;
}
.white_box:last-of-type,
.white_box_xl:last-of-type,
.white_box_l:last-of-type,
.white_box_s:last-of-type,
.white_box_xs:last-of-type {
    margin-bottom: 0;
}
@media (min-width: 768px) and (max-width: 1229px) {
    .white_box {
        padding: 30px;
        margin-bottom: 15px;
    }
    .white_box_xl {
        padding: 45q;
        margin-bottom: 30px;
    }
    .white_box_l {
        padding: 45q;
        margin-bottom: 30px;
    }
    .white_box_s,
    .white_box_xs {
        padding: 15px;
        margin-bottom: 15px;
    }
}
@media screen and (max-width: 767px) {
    .white_box,
    .white_box_s,
    .white_box_xs {
        padding: 15px;
        margin-bottom: 15px;
    }
    .white_box_xl,
    .white_box_l {
        padding: 30px;
        margin-bottom: 15px;
    }
}

/* pagination */
.wp-pagenavi {
    padding-top: 60px;
    text-align: center;
}
.wp-pagenavi a,
.wp-pagenavi span {
    margin: 0;
    padding: 0;
    border: none;
    width: 30px;
    height: 30px;
    display: inline-block;
    text-align: center;
    line-height: 30px;
    margin-right: 10px;
}
.wp-pagenavi a:last-child,
.wp-pagenavi span:last-child {
    margin-right: 0;
}
.wp-pagenavi .current {
    background-color: var(--color1);
    color: var(--color_wt);
}
.wp-pagenavi .larger,
.wp-pagenavi .smaller {
    background-color: #ededed;
    color: var(--color_bk);
}
.wp-pagenavi .previouspostslink,
.wp-pagenavi .nextpostslink {
    background-color: #ededed;
    color: var(--color_bk);
}
/*背景左右はみだし----------------------------------------------------------- */
.white_box.bg_over_l,
.white_box.bg_over_r {
    margin-bottom: 60px;
}
@media (min-width: 768px) and (max-width: 1229px) {
    .white_box.bg_over_l,
    .white_box.bg_over_r {
        margin-bottom: 30px;
    }
}
@media screen and (max-width: 767px) {
    .white_box.bg_over_l,
    .white_box.bg_over_r {
        margin-bottom: 15px;
    }
}
.white_box.bg_over_l,
.white_box.bg_over_l>*,
.white_box.bg_over_r,
.white_box.bg_over_r>* {
    position: relative;
    z-index: 1;
}
.white_box.bg_over_l:before {
    position: absolute;
    display: block;
    content: "";
    height: 100%;
    width: 50vw;
    top: 0;
    left: 50%;
    transform: translateX(-50vw);
    background-color: #efefef;
    z-index: 0;
}
.white_box.bg_over_r:before {
    position: absolute;
    display: block;
    content: "";
    height: 100%;
    width: 50vw;
    top: 0;
    right: 0;
    transform: translateX(50vw);
    background-color: #efefef;
    z-index: 0;
}

/* 画像カバースライドイン */
.slidein {
    width: 100%;
    overflow: hidden;
}
.slidein .slidein_inner {
    width: inherit;
    height: inherit;
    opacity: 0;
}
.isPlay {
    animation-name: play;
    animation-duration: .5s;
    animation-fill-mode: forwards;
    animation-timing-function: cubic-bezier(.8, 0, .5, 1);
    position: relative;
    opacity: 1 !important;
}
.isPlay:before {
    animation-name: maskOut;
    animation-duration: .5s;
    animation-delay: .5s;
    animation-fill-mode: forwards;
    animation-timing-function: cubic-bezier(.8, 0, .5, 1);
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    width: 100%;
    height: 100%;
    background-image: linear-gradient(109.6deg, rgba(156, 252, 248, 1) 11.2%, rgba(110, 123, 251, 1) 91.1%);
}
@keyframes play {
    from {
        transform: translateX(-100%);
    }

    to {
        transform: translateX(0);
    }
}
@keyframes maskOut {
    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(100%);
    }
}

/* 画像フェードイン */
.fadein {
    width: 100%;
    overflow: hidden;
}
.fadein .fadein_inner {
    width: inherit;
    height: inherit;
    opacity: 0;
}
.isfadein {
    animation-name: fadein;
    animation-duration: .5s;
    animation-fill-mode: forwards;
    animation-timing-function: cubic-bezier(.8, 0, .5, 1);
    position: relative;
    opacity: 1;
}
@keyframes fadein {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

/*check_list----------------------------------------------------------- */
.check_list li {
    position: relative;
    padding-left: 1.5em;
    margin-bottom: 3px;
}
.check_list li:last-child {
    margin-bottom: 0;
}
.check_list li:before {
    position: absolute;
    content: "\f058";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    top: 0;
    left: 0;
    color: orange;
}
.list_border {
    border-bottom: 2px dashed #000;
}
.list_border_stop {
    border-bottom: 2px dashed #000;
    display: inline-block;
}


/*FOXcss追加スタイル----------------------------------------------------------- */
.fx-row-gutter-s {
    margin-left: -8px;
    margin-right: -8px;
}
.fx-row-gutter-s > li,
.fx-row-gutter-s > div {
    padding-left: 8px;
    padding-right: 8px;
}
.fx-row-gutter-xs {
    margin-left: -5px;
    margin-right: -5px;
}
.fx-row-gutter-xs > li,
.fx-row-gutter-xs > div {
    padding-left: 5px;
    padding-right: 5px;
}

/*Container / Break----------------------------------------------------------- */
@media (min-width: 1230px) {
    .container {
        width: 1230px;
        margin: 0 auto;
        position: relative;
        padding-left: 15px;
        padding-right: 15px;
        box-sizing: border-box;
    }
    .container_s {
        width: 960px;
        margin: 0 auto;
        position: relative;
        padding-left: 15px;
        padding-right: 15px;
        box-sizing: border-box;
    }
    .p_none {display: none;}
    .pt_none {display: none;}
    .ps_none {display: none;}
    .t_none {display: block;}
    .ts_none {display: block;}
    .s_none {display: block;}
}

@media (min-width: 768px) and (max-width: 1229px) {
    body {
        overflow-x: hidden;
    }
    .container {
        width: 768px;
        margin: 0 auto;
        position: relative;
        margin-right: auto;
        margin-left: auto;
        padding-left: 15px;
        padding-right: 15px;
        box-sizing: border-box;
    }
    .container_s {
        width: 768px;
        margin: 0 auto;
        position: relative;
        margin-right: auto;
        margin-left: auto;
        padding-left: 15px;
        padding-right: 15px;
        box-sizing: border-box;
    }
    .p_none {display: block;}
    .pt_none {display: none;}
    .ps_none {display: block;}
    .t_none {display: none;}
    .ts_none {display: none;}
    .s_none {display: block;}
}
@media screen and (max-width: 767px) {
    body {
        overflow-x: hidden;
        display: block;
        max-width: 767px;
    }
    .container,
    .container_s {
        margin-right: auto;
        margin-left: auto;
        padding-left: 15px;
        padding-right: 15px;
        box-sizing: border-box;
    }
    .p_none {display: block;}
    .pt_none {display: block;}
    .ps_none {display: none;}
    .t_none {display: block;}
    .ts_none {display: none;}
    .s_none {display: none;}
}

/*************************************************************/
/**********************     共通部分     **********************/
/*************************************************************/

/*セクション間余白----------------------------------------------------------- */
section {
    padding: 120px 0;
}
@media (min-width: 768px) and (max-width: 1229px) {
    section {
        padding: 90px 0;
    }
}
@media screen and (max-width: 767px) {
    section {
        padding: 45px 0;
    }

}

/*テキスト関連----------------------------------------------------------- */
.highlight {
    background: -webkit-linear-gradient(transparent 60%, #ffd200 50%);
    background: -o-linear-gradient(transparent 60%, #ffd200 50%);
    background: linear-gradient(transparent 60%, #ffd200 50%);
    font-weight: bold;
}

/*リンク色----------------------------------------------------------- */
a:link,
a:visited { text-decoration: none;}
/* a:hover {opacity: .8;} */
a { color: inherit; }

/*共通部分----------------------------------------------------------- */
.btn a,
.btn button {
    padding: 15px 0;
    position: relative;
    transition: all .4s;
    width: 100%;
    font-weight: bold;
    display: block;
    text-align: center;
}
.btn a:hover,
.btn button:hover {
}
.btn1 a,
.btn1 button {
    background-color: var(--color_bk);
    color: var(--color_wt);
    padding: 20px 0;
    font-size: 18px;
    border: 2px solid var(--color_bk);
    cursor: pointer;
}
.btn1 a::after,
.btn1 button::after {
    content: '\f078';
    font-family: "Font Awesome 5 Free";
    font-size: 20px;
    position: absolute;
    top: 50%;
    transform: rotate(0) translateY(-50%);
    right: 30px;
    transition: all .3s ease 0s;
}
.btn1 a:hover,
.btn1 button:hover {
    background-color: var(--color_wt);
    color: var(--color_bk);
    border: 2px solid var(--color_bk);
}
.btn2 a {
    color: var(--color6);
    background-color: var(--color_wt);
    padding-block: 20px;
    border: 1px solid var(--color6);
}
.btn2 a:hover {
    color: var(--color_wt);
    background-color: var(--color6);
}
.btn2 a::after {
    content: '\f054';
    position: absolute;
    font-family: "Font Awesome 5 Free";
    top: 50%;
    transform: translateY(-50%);
    right: 45px;
}
.btn3 a {
    color: var(--color_bk);
    background-color: var(--color_wt);
    padding-block: 20px;
}
.btn3 a:hover {
    color: var(--color_wt);
    background-color: var(--color_bk);
}
.btn3 a::after {
    content: '\f054';
    position: absolute;
    font-family: "Font Awesome 5 Free";
    top: 50%;
    transform: translateY(-50%);
    right: 45px;
}
.btn4 a,
.btn4 button {
    color: var(--color_wt);
    font-weight: bold;
    border: 2px solid var(--color_bk);
    background-color: var(--color_bk);
}
.btn4 a:hover,
.btn4 button:hover {
    border: 2px solid var(--color_bk);
    color: var(--color_bk);
    background-color: var(--color_wt);
}
.btn4 a::after,
.btn4 button::after {
    content: '';
    position: absolute;
    width: 43px;
    height: 2px;
    background-color: var(--color_wt);
    right: -2px;
    top: 50%;
    transform: translateY(-50%);
}
.btn4 a:hover::after,
.btn4 button:hover::after {
    content: none;
}
@media screen and (max-width: 1229px) {
    .btn3 a::after {
        right: 20px;
    }
}
@media screen and (max-width: 767px) {
    .btn1 a,
    .btn1 button {
        font-size: 16px;
    }
    .btn3 a::after {
        right: 20px;
    }
    .btn4 button,
    .btn4 a {
        width: 100%;
        padding: 15px 0;
    }
    .btn4 button::after,
    .btn4 a::after {
        width: 24px;
    }

}
/* section head  */
/* title + sub title */
.sec-head01 {
    letter-spacing: 0.2em;
    line-height: 1;
}
.sec-head01 h2 {
    padding-bottom: 0;
    line-height: 1;
    font-size: 50px;
}
.sec-head01 p {
    font-size: 20px;
}
@media screen and (max-width: 767px) {
    .sec-head01 h2 {
        font-size: 35px;
    }
    .sec-head01 p {
        font-size: 16px;
    }
}
/* title + 英語表記 */
.sec-head02 {
    font-weight: bold;
}
.sec-head02 p {
    letter-spacing: 0.04em;
    line-height: 1;
    font-size: 48px;
    font-weight: normal;
}
.sec-head02 h2 {
    text-align: left;
    line-height: 1;
}
/* title + 下線 */
.sec-head03 {
    position: relative;
	padding-bottom: 45px;
    margin-bottom: 45px;
	line-height: 1;
	font-size: 35px;
}
.sec-head03::after {
    content: '';
	position: absolute;
	width: 60px;
	height: 2px;
	background-color: var(--color_bk);
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);

}
@media screen and (max-width: 1229px) {
    .sec-head02 p {
        font-size: 30px;
    }
    .sec-head03 {
        line-height: 1.3;
    }
}
@media screen and (max-width: 767px) {
    .sec-head03 {
		padding-bottom: 20px;
        margin-bottom: 20px;
		line-height: 1.4;
		font-size: 20px;
	}
}
/* SLIDER */
/* 01 */
.slider01 {

}
.slider01 .slick-slide {
	margin-right: 60px;
}
@media screen and (max-width: 1229px) {
    .slider01 .slick-slide {
        margin-right: 20px;
    }
}
/* 02 */
.slider02 {
    overflow: hidden;
}
.slider02 h3 {
	position: relative;
	background-color: var(--color_wt);
	width: 80%;
	padding: 20px 0;
	margin-top: -30px;
    font-size: 20px;
    letter-spacing: 0.08em;
}
.slider02 p {
    letter-spacing: 0.08em;
}
.slider02 .slick-slide {
    margin-right: 0;
	max-width: 380px;
	width: 100%;
	margin-right: 30px;
}
.slider02 .slick-dots {
    bottom: 0;
}
.slider02 .slick-dots li button:before {
    font-size: 15px;
}
.slider02 .slick-dots li {
    margin: 0 4px;
}
@media screen and (max-width: 767px) {
    .slider02 .slick-slide {
        max-width: 250px;
        margin-right: 15px;
    }
    .slider02 h3 {
        margin-left: -1px;
        padding: 15px 0;
        font-size: 18px;
        width: 90%;
    }
    .slider02 p {
        letter-spacing: 0.06em;
    }
    .slider02 .slick-dots li button:before {
        font-size: 13px;
    }
}
/*Header----------------------------------------------------------- */
#header {
    position: fixed;
    z-index: 999999999;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
}
.header_wrap {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 10px;
}
.header_list {
    width: 46px;
    background-color: #000;
    padding: 20px 13px;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    line-height: 1;
    display: block;
    border: 2px solid #000;
    transition: all .3s ease 0s;
}
.header_list:not(.header_insta):hover {
    background-color: var(--color_wt);
    border: 2px solid #000;
    color: #000;
}
.header_insta {
    color: #000;
    display: flex;
    justify-content: space-between;
    align-items: center;
    background-color: unset;
    border: none;
}
.header_insta:hover {
    opacity: 0.6;
}
.header_bd {
    position: relative;
    width: 30px;
    height: 30px;
}
.header_bd::before {
    content: '';
    position: absolute;
    width: 1px;
    height: 20px;
    background-color: #000;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
.header_insta i {
    font-size: 32px;
}

/* DRAWER ------------------------- */
.header_drawer {
    position: absolute;
    width: 45px;
    height: 45px;
    border-radius: 50px;
    background-color: var(--color_bk);
    right: 15px;
    top: 15px;
    z-index: 999;
    cursor: pointer;
}
.header_drawer span {
    position: absolute;
    width: 25px;
    height: 2px;
    background-color: var(--color_wt);
    left: 50%;
    transform: translateX(-50%);
    transition: all .4s ease 0s;
}
.header_drawer.is-active span {
    background-color: var(--color_wt);
}
.header_drawer span:nth-child(1) {
    top: 14px;
}
.header_drawer.is-active span:nth-child(1) {
    top: 50%;
    transform: translate(-50%, -50%) rotate(-45deg);
}
.header_drawer span:nth-child(2) {
    top: 22px;
}
.header_drawer.is-active span:nth-child(2) {
    display: none;
}
.header_drawer span:nth-child(3) {
    top: 30px;
}
.header_drawer.is-active span:nth-child(3) {
    top: 50%;
    transform: translate(-50%, -50%) rotate(45deg);
}
.header_drawer-wrap {
    position: absolute;
    width: calc(100% - 30px);
    height: 100vh;
    background-color: var(--color_bk);
    top: 0;
    right: 0;
    padding: 45px 30px;
    color: var(--color_wt);
    transform: translateX(105%);
    transition: all .4s ease 0s;
    overflow-y: auto;
}
.header_drawer-wrap h2 {
    text-align: left;
}
.header_drawer-wrap h2 svg {
    filter: drop-shadow(0, 0, 5px #fff) ;
    width: 136px;
    height: 58px;
}
.header_drawer-wrap h2 g,
.header_drawer-wrap h2 path {
    fill: var(--color_wt);
}
.header_drawer-wrap.is-active {
    transform: translateX(0);
}
.header_drawer-head {
    text-align: left;
    font-size: 21px;

}
.header_drawer-menus {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}
.header_drawer-menus li {
    width: 100%;
}
.header_drawer-menus li:last-child a {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
}
.header_drawer-menus li:last-child a > i {
    font-size: 36px;
}
.header_drawer-menus a {
}
.header_drawer-menus a:hover {
    opacity: 0.6;
}
.header_drawer-list {
    position: relative;
    padding: 5px;
    display: inline-block;
    width: inherit;
    padding-left: 30px;
}
.header_drawer-list::before {
    content: '';
    position: absolute;
    width: 14px;
    height: 2px;
    background-color: var(--color_wt);
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}
.header_btn a {
    background-color: var(--color_wt);
    color: var(--color_bk);
    border-color: var(--color_wt);
    font-size: 16px;
}
.header_btn a::after {
    background-color: var(--color_bk);
}
.header_btn a:hover {
    background-color: var(--color_bk);
    color: var(--color_wt);
    border-color: var(--color_wt);
    opacity: 1;
}
.header_btn a:hover::after {
    background-color: var(--color_wt);
}

@media screen and (max-width: 1229px) {
}
@media screen and (max-width: 767px) {
    #header {
        width: 100%;
        height: 65px;
        top: 0;
        transform: none;
    }
    .header_wrap {
        display: none;
    }
}
/*breadclumb----------------------------------------------------------- */
.breadcrumb-area {
    padding: 5px 15px;
}
.bread_crumb .taxonomy,
.brea.entries__tagegory {
    color: var(--color1);
}
.archive {
    color: var(--color1);
}
.bread_icon {
    padding-inline: 15px;
}

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

@media screen and (max-width: 767px) {}

/* FOOTER
-----------------------------------------*/
.footer {
    background: url(../img/common/pc_footer_bg.png) no-repeat center center / cover;
    padding: 90px 0;
}
.footer a:hover {
    opacity: 0.7;
}
.footer_btn-wrap {
    width: 80%;
    display: flex;
    justify-content: space-between;
    gap: 45px;
}
.footer_btn {
    width: 50%;
}
.footer_btn a {
    font-size: 32px;
    padding: 45px 0;
}
.footer_btn a:hover {
    opacity: 1;
}
.footer_link-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
}
.footer_link {
    position: relative;
    color: var(--color_wt);
}
.footer_link:not(:last-child)::after {
    content: '';
    position: absolute;
    width: 1px;
    height: 15px;
    background-color: var(--color_wt);
    top: 50%;
    right: 0;
    transform: translateY(-50%);
}
.footer_link a {
    display: inline-block;
    padding: 15px;
}
.footer_insta a {
    display: inline-block;
    margin: 0 auto;
}
.footer_insta i {
    font-size: 4.6rem;
}
.footer h2 {
    letter-spacing: 0.1em;
}
.footer_contents {
    font-size: 1.4rem;
}
.footer_contents-links {
    display: flex;
    justify-content: center;
    gap: 15px;
}
.footer svg {
    width: 136px;
    height: 58px;
}
.footer svg g,
.footer svg path {
    fill: var(--color_wt);
}
.copy-right {
    background-color: #fff;
    font-size: 1.4rem;
    padding: 20px 0;
}
@media screen and (max-width: 1229px) {
    .footer_btn-wrap {
        gap: 15px;
    }
    .footer_btn {
        width: 50%;
    }
    .footer_btn a {
        font-size: 24px;
        padding: 45px 0;
        width: 100%;
    }
    .footer_link-wrap {
        flex-wrap: wrap;
        width: 75%;
        margin: 0 auto;
    }
    .footer_link:not(:last-child)::after {
        content: none;
    }
    .footer_link:not(:nth-child(5n),:last-child)::after {
        content: '';
        position: absolute;
        width: 1px;
        height: 15px;
        background-color: var(--color_wt);
        top: 50%;
        right: 0;
        transform: translateY(-50%);
    }
}
@media screen and (max-width: 767px) {
    .footer {
        background: url(../img/common/sp_footer_bg.png) no-repeat top center / cover;
        padding: 45px 0;
    }
    .footer_btn-wrap {
        flex-direction: column;
    }
    .footer_btn {
        width: 90%;
        margin: 0 auto;
    }
    .footer_btn a {
        font-size: 18px;
        padding: 30px 0;
    }
    .footer_link-wrap {
        width: 80%;
        row-gap: 5px;
    }
    .footer_link a {
        padding: 0 10px 5px;
    }
    .footer_link:not(:nth-child(5n),:last-child)::after {
        content: none;
    }
    .footer_link:not(:nth-child(3n))::after {
        content: '';
        position: absolute;
        width: 1px;
        height: 15px;
        background-color: var(--color_wt);
        top: 40%;
        right: 0;
        transform: translateY(-50%);
    }
    .footer_contents-links {
        flex-direction: column;
        gap: 0;
    }
    .footer_contents-links a {
        padding-bottom: 5px;
    }
}
/* contact form 共通
----------------------------------------- */
form > ul > li {
    padding: 15px 0;
}
form > ul > li.bb_none {
    border-bottom: none;
}
.form_head {
    text-align: right;
}
.form_head span {
    display: inline-block;
    font-weight: bold;
    font-size: 18px;
}
.form_head .haveto {
    background-color: var(--color_bk);
    color: #fff;
    padding: 1px 8px;
    font-weight: bold;
    margin-left: 10px;
    font-size: 16px;
}
.any {
    background-color: #81807f;
    color: #fff;
    padding: 1px 8px;
    font-weight: bold;
    font-size: 0.7em;
    margin-left: 10px;
}
.input_adjust {
    padding: 20px;
    border-radius: 3px;
    border: none;
    font-size: 18px;
    background-color: #f5f5f5;
}
.input_adjust::placeholder {
    font-family: YuGothic, "YuGothic M", "游ゴシック体", "メイリオ", Meiryo, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", sans-serif;
    color: #808080;
}
.input_2col {
    display: flex;
    justify-content: space-between;
    padding-right: 30px;
    width: 100%;
}
.input_2col input {
    width: calc(50% - 15px);
}
.input_1col {
    padding-right: 30px;
}
.input_1col input {
    width: 100%;
    box-sizing: border-box;
}
.input_zip_2col input {
    width: 30%;
}
.input_pref {
    width: 50%;
}
.input_select select {
    width: 80%;
    padding-right: 1em;
    cursor: pointer;
    text-overflow: ellipsis;
    border: none;
    outline: none;
    background: transparent;
    background-image: none;
    box-shadow: none;
    -webkit-appearance: none;
    appearance: none;
    padding: 12px 16px;
}
.input_select select::-ms-expand {
    display: none;
}
.input_select {
    position: relative;
    border: 2px solid #ccc;
    border-radius: 10px;
    background: #ffffff;
}
.input_select::before {
    position: absolute;
    top: calc(50% - 3px);
    right: 1em;
    width: 0;
    height: 0;
    padding: 0;
    content: "";
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 6px solid #000;
    pointer-events: none;
}
.input_tel_3col input {
    width: 30%;
}
.input_tel_3col input:first-child {
    width: 20%;
}
.radio_2col {
    display: flex;
}
.radio_2col label {
    display: flex;
    align-items: center;
    padding: 12px 0;
}
.radio_2col label:first-child {
    padding-right: 30px;
}
.radio_2col span {
    padding-left: 10px;
}
.radio_1col > label {
    width: 100%;
    display: flex;
    align-items: center;
    padding: 12px 0;
}
.radio_1col span {
    padding-left: 10px;
}
.date_2col {
    display: flex;
    justify-content: space-between;
    padding-right: 30px;
}
.date_2col > * {
    display: block;
    width: calc(50% - 15px);
}
.input_date {
    position: relative;
}
.input_date:before {
    position: absolute;
    content: "\f073";
    font-family: "Font Awesome 5 Free";
    right: 15px;
}
input[type="date"] {
    position: relative;
}
input[type="date"]::-webkit-calendar-picker-indicator {
    position: absolute;
    width: 100%;
    height: 100%;
    opacity: 0;
}
input[type="date"]::-webkit-inner-spin-button {
    -webkit-appearance: none;
}
input[type="date"]::-webkit-clear-button {
    -webkit-appearance: none;
}
.check_1col > label {
    width: 100%;
    display: flex;
    align-items: center;
    padding: 12px 0;
}
.check_1col span {
    padding-left: 10px;
}
.select_1col {
    padding-right: 30px;
}
.textarea {
    padding-right: 30px;
}
.textarea textarea {
    width: 100%;
    max-height: 160px;
    box-sizing: border-box;
}
.check_agree input {
    height: 20px;
    width: 20px;
}
.check_agree span {
    padding-top: 5px;
}
.sbm_wrap {
    padding: 30px 15px 0;
}
.sbm_wrap a {
    text-decoration: underline;
}
.btn button {
    position: relative;
}
@media screen and (max-width: 1229px) {
}
@media screen and (min-width: 768px) {
    .common_form .fx-col-16-s {
        -ms-flex-preferred-size: 16%;
        flex-basis: 16%;
        max-width: 16%;
        padding-top: 12px;
    }
    .common_form.fx-col-54-s {
        -ms-flex-preferred-size: 54%;
        flex-basis: 54%;
        max-width: 54%;
    }
    .input_select {
        margin-right: 30px;
    }
}
@media screen and (max-width: 767px) {
    .form_wrap {
        padding: 5px 0 0 ;
    }
    form > ul > li .fx-row > *:first-child {
        padding-top: 0;
    }
    form > ul > li {
        padding: 15px;
    }
    .form_head {
        text-align: left;
    }
    .form_head span {
        font-size: 16px;
    }
    .form_head .haveto {
        font-size: 14px;
    }
    .input_adjust {
        padding: 15px 12px;
    }
    .input_2col {
        padding-right: 0px;
    }
    .input_1col {
        padding-right: 0px;
    }
    .input_pref {
        width: 80%;
    }
    .input_select select {
        padding: 15px 12px;
    }
    .input_adjust {
        font-size: 14px;
    }
    .radio_2col label:first-child {
        padding-right: 0px;
    }
    .date_2col {
        padding-right: 0px;
    }
    .date_2col > * {
        width: calc(50% - 8px);
    }
    .select_1col {
        padding-right: 0px;
    }
    .textarea {
        padding-right: 0px;
    }
    .sbm_wrap {
        padding: 0;
    }
    .sbm {
        width: 100%;
    }
}
/*下層ページ共通----------------------------------------------------------- */
#register,
#register_ekyc,
#thanks,
#privacypolicy {
    background: url(../img/common/pc_page_bg.png) no-repeat center center / cover;
}
@media screen and (max-width: 767px) {
    #register,
    #register_ekyc,
    #thanks,
    #privacypolicy {
        background: url(../img/common/sp_page_bg.png) no-repeat center center / cover;
    }
}