@charset "utf-8";

/* =======================================

   BrowserReset

 ======================================= */
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,
font,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td {
    font-family: inherit;
    font-size: 100%;
    font-weight: inherit;
    font-style: inherit;
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    vertical-align: baseline;
    word-wrap: break-word;
    border: 0;
    outline: 0;
}

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

html {
    font-size: 62.5%;
    overflow-x: hidden;
    overflow-y: scroll;
    width: 100%;

    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
    -webkit-overflow-scrolling: touch;
}

body {

    font-family: '游ゴシック', 'YuGothic', 'メイリオ', 'Meiryo', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'Osaka', 'ＭＳ Ｐゴシック', 'MS P Gothic', Verdana, Arial, Helvetica, sans-serif;
    font-size: 1.8rem;
    font-weight: 400;
    position: relative;
    overflow: hidden;
    width: 100%;
    height: 100%;
    color: #222222;
    background: #ffffff;
    overflow-wrap: break-word;
    line-height: 1.75;
}

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

        font-size: 1.4rem;
    }
}

img {
    -ms-interpolation-mode: bicubic;
    vertical-align: bottom;
    -webkit-backface-visibility: hidden;

}

a {
    -webkit-transition: all .2s ease-in-out;
    -moz-transition: all .2s ease-in-out;
    -ms-transition: all .2s ease-in-out;
    transition: all .2s ease-in-out;
    text-decoration: none;
}

a:link,
a:visited,
a:active,
a:hover {
    -webkit-transition: all .2s ease-in-out;
    -moz-transition: all .2s ease-in-out;
    -ms-transition: all .2s ease-in-out;
    transition: all .2s ease-in-out;
    text-decoration: none;
    outline-width: 0;
    color: inherit;

}

a:focus {
    overflow: hidden;
}

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

canvas,
iframe,
video,
svg {
    max-width: 100%;
}

ol,
ul {
    list-style: none;
}

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

input,
button,
textarea,
select {
    font-family: '游ゴシック', 'YuGothic', 'メイリオ', 'Meiryo', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'Osaka', 'ＭＳ Ｐゴシック', 'MS P Gothic', Verdana, Arial, Helvetica, sans-serif;
    font-size: 100%;
    font-size: 16px;
    position: relative;
    top: -1px;
    margin: 0;
    margin: 0 4px 2px 0;
    padding: 0;
    vertical-align: middle;
    border: none;
    border-radius: 0;
    outline: none;
    background: none;

    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    *margin-right: 3px;
}


/*====================================

    font

====================================*/
@font-face {
    font-family: 'icon';
    src: url('../font/icon.eot?5n3q9r');
    src: url('../font/icon.eot?5n3q9r#iefix') format('embedded-opentype'),
        url('../font/icon.ttf?5n3q9r') format('truetype'),
        url('../font/icon.woff?5n3q9r') format('woff'),
        url('../font/icon.svg?5n3q9r#icon') format('svg');
    font-weight: normal;
    font-style: normal;
}

[class^="icon-"],
[class*=" icon-"] {
    font-family: 'icon';
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    position: relative;
}

.icon-serch:before {
    content: "\e90d";
}

.icon-mail:before {
    content: "\e90c";
}

.icon-pc:before {
    content: "\e90e";
}

.icon-arrow-left-thin:before {
    content: "\e906";
}

.icon-arrow-right-thin:before {
    content: "\e90b";
}

.icon-tab:before {
    content: "\e907";
}

.icon-tab-thin:before {
    content: "\e908";
}

.icon-download:before {
    content: "\e909";
}

.icon-download-thin:before {
    content: "\e90a";
}

.icon-arrow-down:before {
    content: "\e903";
}

.icon-arrow-left:before {
    content: "\e904";
}

.icon-arrow-top:before {
    content: "\e905";
}

.icon-arrow-right:before {
    content: "\e900";
}

.icon-page_top:before {
    content: "\e901";
}

.icon-tel:before {
    content: "\e902";
}

/* =======================================

   common

 ======================================= */


/* =====================
 cont
===================== */
.cont {
    position: relative;
    background: #042333;
    background-image: url(../img/bk01.webp);
    color: #fff;
    z-index: -1;
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
}

.cont_rea {
    background: linear-gradient(to bottom, #364F5C, #042333);
}

.cont_color {
    position: relative;
    background: #112D5C;
    color: #fff;
}

.cont-inner {
    position: relative;
    width: 100%;
    max-width: 1080px;
    margin: 0px auto;
}

.cont_w {
    background: #fff;
    color: #042333;
}


@media screen and (max-width: 1280px) {
    .cont-inner {
        padding: 0 20px;
    }
}

/* =====================
 section
===================== */
.secTop {
    padding-top: 96px;
}

.secBottom {
    padding-bottom: 96px;
}

.secBottom_S {
    padding-bottom: 40px;
}


.secTop_S {
    padding-top: 40px;
}

.secTB {
    padding: 96px 0;
    background-color: #fff;
}

.secTB_S {
    padding: 40px 0;
}

.secTB_SS {
    padding: 16px 0;
}


@media screen and (max-width: 767px) {
    .secTop {
        padding-top: 64px;
    }

    .secBottom {
        padding-bottom: 64px;
    }

    .secBottom_S {
        padding-bottom: 40px;
    }

    .secTop_S {
        padding-top: 40px;
    }

    .secTB {
        padding: 40px 0;
    }

    .secTB_S {
        padding: 16px 0;
    }

    .secTB_onlyH {
        padding-top: 16px;
        padding-bottom: 16px;
    }
}

@media screen and (max-width: 767px) {
    .txt {
        font-size: 1.6rem;
    }
}

/* =====================
 article
===================== */
.article p {
    margin-bottom: 18px;
    font-size: 1.8rem;
}

/* =====================
 img-fluid
===================== */
.img-fluid {
    width: 100%;
    height: auto;
    display: block;
}

.img-sm-fluid {
    max-width: 100%;
    height: auto;
    display: block;
    margin: 0 auto;
}

@media screen and (max-width: 767px) {
    .img-fluid_A {
        margin: 0 auto;
    }
}

/* =====================
  boxA
===================== */
.boxA {
    background: #fff;
    padding: 56px 40px;
    border: 10px solid #F0F3F5;
}

@media screen and (max-width: 767px) {
    .boxA {
        padding: 40px 8px;
    }
}

/* =====================
  boxB
===================== */
.boxB {
    background: #F0F3F5;
    padding: 32px 40px;
}

@media screen and (max-width: 767px) {
    .boxB {
        padding: 16px;
    }
}

/* =====================
  boxC
===================== */
.boxC {
    background: #fff;
    padding: 56px 32px;
}

@media screen and (max-width: 767px) {
    .boxC {
        padding: 24px 8px;
    }
}

/* =====================
 ついか　tuika
===================== */
.header-kv {
    position: relative;
    width: 100%;
    height: 400px;
    background-image: url(../img/kv_pc.webp);
    top: 0px;
    left: 0px;
    z-index: -1;
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
}

.rank_icon {
    position: absolute;
    z-index: 2;
    top: 20%;
    left: 2%;
    width: 80%;
}

.rank_icon a img {
    transition: .4s;
}

.rank_icon a:hover img {
    transform: translateY(-2px);
}

.mainVisual-pic {
    position: absolute;
    z-index: 2;
    width: 100%;
    max-width: 492px;
    margin-top: 180px;
}

.mainVisual-pic img {
    top: 40%;
    left: auto;
    width: 100%;
}

.mv-sp {
    display: none;
}

.mv-pc {
    display: block;
}


.secBottom_SS {
    padding-bottom: 0.3rem;
}

.secTop_SS {
    padding-top: 0.3rem;
}

.secBottom_margin {
    margin-bottom: 4rem;
}

.col,
.col-sm-4,
.col-sm-3 {
    position: relative;
    width: 33.3%;
    min-height: 1px;
    padding-right: 15px;
    padding-left: 15px;
}

.flowimg_wrap {
    display: block;
    width: 100%;
    margin-top: 6.5rem;
}

.flowimg_wrap img {
    display: block;
    width: 100%;
    height: auto;
}

.flowimg_wrap .flowimg_pc {
    display: block;
}

.flowimg_wrap .flowimg_sp {
    display: none;
}

/* =======================================
3つの理由
======================================= */
.rea_img_box {
    position: relative;
    font-family: 'Notoserif', 游明朝, 'Yu Mincho', YuMincho, 'メイリオ', 'Meiryo', 'ヒラギノ明朝 ProN W3', 'HiraMinProN-W3', 'HG明朝E', 'ＭＳ Ｐ明朝', 'MS PMincho', 'MS 明朝', serif;
    background-color: #112D5C;
    height: 70px;
}

.rea_ttl_box {
    position: relative;
    font-family: 'Notoserif', 游明朝, 'Yu Mincho', YuMincho, 'メイリオ', 'Meiryo', 'ヒラギノ明朝 ProN W3', 'HiraMinProN-W3', 'HG明朝E', 'ＭＳ Ｐ明朝', 'MS PMincho', 'MS 明朝', serif;
    color: #fff;
    width: 100%;
    max-width: 1080px;
    background-color: #112D5C;
    height: 70px;
    text-align: center;
}


.rea_Num {
    position: absolute;
    top: -5%;
    left: 5%;
    font-size: 5.0rem;
    font-weight: bold;
    font-style: oblique;
    color: #cad3e6;
}

.rea_ttl_box .rea_Num {
    position: absolute;
    top: -5%;
    left: 30%;
    font-size: 5.0rem;
    font-weight: bold;
    font-style: oblique;
    color: #cad3e6;
}

.rea_ttl {
    font-size: 2rem;
    position: absolute;
    top: 50%;
    left: 70%;
    -ms-transform: translate(-65%, -50%);
    transform: translate(-65%, -50%);
    max-width: 100%;
    width: 100%;
    color: #FFF;
    font-weight: 100;
    text-shadow: 3px 3px 3px #111213;
}

/* =====================
  ttl-baloonBottom
===================== */
.ttl-baloonBottom {
    position: relative;
    padding: 30px 20px 40px;
    letter-spacing: .5px;
    color: #fff;
    background: #1d2c5b;
    display: block;
}

.ttl-baloonBottom_inner {
    font-family: 'Notoserif', 游明朝, 'Yu Mincho', YuMincho, 'メイリオ', 'Meiryo', 'ヒラギノ明朝 ProN W3', 'HiraMinProN-W3', 'HG明朝E', 'ＭＳ Ｐ明朝', 'MS PMincho', 'MS 明朝', serif;
    width: 100%;
    max-width: 1140px;
    margin: 0 auto;
    text-align: center;
    font-weight: 500;
    position: relative;
}

.ttl-baloonBottom_inner.wide {
    padding: 30px 0;
}

.ttl-baloonBottom:after {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translate(-50%, 0);
    width: 0;
    height: 0;
    content: '';
    border-width: 16px 20px 0 20px;
    border-style: solid;
    border-color: #1d2c5b transparent transparent transparent;
    z-index: 3;
}

.ttl-baloonBottom.baloon-light {
    position: relative;
    width: 100%;
    max-width: 1140px;
    margin: 0px auto;
    color: #1d2c5b;
    background: #fff;
    border-bottom: 1px solid #ccc;
    padding: 0;
}

.ttl-baloonBottom.baloon-light:after {
    border-color: #fff transparent transparent transparent;
}

.ttl-baloonBottom.baloon-light:before {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translate(-50%, 0);
    width: 0;
    height: 0;
    content: '';
    border-width: 17px 21px 0 21px;
    border-style: solid;
    border-color: #ccc transparent transparent transparent;
    z-index: 2;
}

/* =====================
  ttl-baloonBottom light
===================== */
.ttl-baloonBottom.light {
    font-size: 1.5rem;
    font-weight: 700;
    display: block;
    min-height: 100px;
    padding: 20px;
    color: #1d2c5b;
    background: #eee;
}

.ttl-baloonBottom.light:after {
    border-color: #eee transparent transparent transparent;
    -webkit-transition: all .2s ease-in-out;
    -moz-transition: all .2s ease-in-out;
    -ms-transition: all .2s ease-in-out;
    transition: all .2s ease-in-out;
}

.hover .ttl-baloonBottom.light:hover {
    color: #1d2c5b;
    background: #ebf0ff;
}

.hover .ttl-baloonBottom.light:hover:after {
    border-color: #ebf0ff transparent transparent transparent;
}


/* =====================
  ttl-baloonBottom dark
===================== */
.ttl-baloonBottom.dark {
    font-size: 2.0rem;
    display: block;
    min-height: 140px;
    padding: 20px;
    letter-spacing: .5px;
    color: #1d2c5b;
    background: #eee;
}


@media screen and (max-width: 767px) {
    .mv-pc {
        display: none;
    }

    .mv-sp {
        display: block;
    }

    .header-kv {
        position: relative;
        width: 100%;
        height: 590px;
        background-image: url(../img/kv_sp.webp);
        top: 0px;
        left: 0px;
        z-index: -1;
        background-repeat: no-repeat;
        background-position: center;
        background-size: cover;
    }

    .rank_icon {
        position: absolute;
        top: 25%;
        left: 50%;
        transform: translate(-50%, -50%);
    }

    .rank_icon a img {
        transition: .4s;
    }

    .rank_icon a:hover img {
        transform: translateY(-2px);
    }

    .rank_icon img {
        width: 100%;
        max-width: 100%;
    }

    .mainVisual-pic {
        position: absolute;
        top: 10%;
        width: 45%;
        left: 5%;
    }

    .secBottom_SS {
        padding-bottom: 0.5rem;
    }

    .secTop_SS {
        padding-top: 0.5rem;
    }

    .secBottom_margin {
        margin-bottom: 4rem;
    }

    .rea_img_box {
        width: 33.333%;
        background-color: #112D5C;
    }

    .rea_Num {
        font-size: 5.0rem;
        font-weight: bold;
        font-style: oblique;
        color: #cad3e6;
    }

    .rea_ttl {
        font-size: 2.5rem;
        max-width: 100%;
        width: 100%;
        color: #FFF;
        font-weight: 100;
        margin-top: 3rem;
        text-shadow: 3px 3px 3px #111213;
    }

    .ttl-baloonBottom {
        font-size: 1.8rem;
        font-weight: 500;
        letter-spacing: 0.5px;
    }

    .ttl-baloonBottom.light {
        margin-bottom: 20px;
    }

    .flowimg_wrap {
        /*overflow: scroll hidden;*/
    }

    .flowimg_wrap img {
        /*width:initial;*/
    }

    .flowimg_wrap .flowimg_pc {
        display: none;
    }

    .flowimg_wrap .flowimg_sp {
        display: block;
    }

    .sp-telArea .telbtn  {
        width: 45px;
    }
}


/* =====================
  ttl-h2
===================== */
.ttl-h2 {
    font-family: 游明朝, 'Yu Mincho', YuMincho, 'メイリオ', 'Meiryo', 'ヒラギノ明朝 ProN W3', 'HiraMinProN-W3', 'HG明朝E', 'ＭＳ Ｐ明朝', 'MS PMincho', 'MS 明朝', serif;
    font-size: 3.8rem;
    line-height: 1.34;
    text-align: center;
    letter-spacing: 0.5px;
    position: relative;
    z-index: 3;
    font-weight: bold;
    color: #FFF;
}

.ttl-h2 .em {
    font-size: 4.6rem;
    color: #F2D980;
}

@media screen and (max-width: 767px) {
    .ttl-h2 {
        font-size: 2.4rem;
        line-height: 1.5;
    }

    .ttl-h2 .em {
        font-size: 2.8rem;
        line-height: 1.2;
    }
}

/* =====================
  ttl-h3
===================== */
.ttl-h3 {
    font-size: 2rem;
    font-weight: bold;
    color: #112D5C;
    background-color: #D4E3F6;
}

.ttl-h3_dark {
    color: #222222;
}

.ttl-h3_LightBlue {
    color: #004BB1;
}

.ttl-h3_green {
    color: #13756F;
}

@media screen and (max-width: 767px) {
    .ttl-h3 {
        font-size: 1.7rem;
        line-height: 1.5;
    }
}

/* =====================
  ttl-num
===================== */
.ttl-num {
    position: relative;
    text-align: center;
    margin-bottom: 40px;
}

.ttl-num:after {
    content: "";
    width: 100%;
    height: 1px;
    background: #98A6B5;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
}

.ttl-num .inner {
    background: #fff;
    display: inline-block;
    position: relative;
    z-index: 3;
    padding: 0 72px;
    font-weight: bold;
}

.ttl-num .inner .num {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: -1;
    color: #CDD6DD;
    font-family: 'Roboto', sans-serif;
    font-size: 8.0rem;
}

@media screen and (max-width: 767px) {
    .ttl-num {
        margin-top: 40px;
    }
}

/* =======================================

   ttl-pic

 ======================================= */
.ttl-pic {
    position: relative;
    width: 100%;
    overflow: hidden;
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    flex-direction: column;
    padding: 56px 0;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    background: url(../img/bk02.webp);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
}

.ttl-pic .ttl {
    position: relative;
    text-align: center;
    font-size: 4.8rem;
    color: #fff;
    font-weight: bold;
}

@media screen and (max-width: 767px) {
    .ttl-pic {
        padding: 24px 0 40px;
    }

    .ttl-pic .ttl {
        font-size: 2.8rem;
    }
}



/* =======================================

   navList

 ======================================= */
.navList {
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    color: #fff;
}

.navList>li {
    width: 33.3333%;
}

.navList>li:nth-child(2) {
    border-right: 1px solid #fff;
    border-left: 1px solid #fff;
}

.navList a.nav {
    color: #fff;
    font-weight: bold;
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    line-height: 1.2;
    position: relative;
}

.nav .num {
    font-size: 8.0rem;
    margin-right: 16px;
    font-family: 'Roboto', sans-serif;
}

.nav .txt {
    font-family: 游明朝, 'Yu Mincho', YuMincho, 'メイリオ', 'Meiryo', 'ヒラギノ明朝 ProN W3', 'HiraMinProN-W3', 'HG明朝E', 'ＭＳ Ｐ明朝', 'MS PMincho', 'MS 明朝', serif;
    font-size: 2.6rem;
}

.navList a.nav:after {
    -webkit-transition: all .1s ease-in-out;
    -moz-transition: all .1s ease-in-out;
    -ms-transition: all .1s ease-in-out;
    transition: all .1s ease-in-out;

    font-family: 'icon';
    content: '\e90b';
    position: absolute;
    bottom: -16px;
    left: 50%;
    transform: translate(-50%, 0) rotateZ(90deg);
    font-weight: normal;
}

.hover .navList a.nav:hover:after {
    transform: translate(-50%, 6px) rotateZ(90deg);
}




@media screen and (max-width: 929px) {
    .nav .num {
        font-size: 6.0rem;
    }

    .nav .txt {
        font-size: 2.0rem;
    }

    .navList a.nav:after {
        bottom: -24px;
    }
}


@media screen and (max-width: 767px) {
    .navList a.nav {

        flex-direction: column;

        -webkit-flex-direction: column;
        -ms-flex-direction: column;
        text-align: center;
    }

    .navList {
        margin: 0 -16px;
    }

    .navList>li {
        padding: 0 4px;
    }

    .navList>li:nth-child(2) {
        border-right: none;
        border-left: none;
    }



    .nav .num {
        font-size: 2.0rem;
        margin-right: 4px;
    }

    .nav .txt {
        font-size: 1.5rem;
    }

    .navList a.nav:after {
        bottom: -16px;
    }
}

@media screen and (max-width: 320px) {
    .nav .txt {
        font-size: 1.3rem;
    }
}

/* =====================
  ttl-common
===================== */

.ttl-common {
    font-size: 2.4rem;
    font-weight: bold;
}

.ttl-common_min {
    font-size: 2.4rem;
    font-weight: bold;
    font-family: 游明朝, 'Yu Mincho', YuMincho, 'メイリオ', 'Meiryo', 'ヒラギノ明朝 ProN W3', 'HiraMinProN-W3', 'HG明朝E', 'ＭＳ Ｐ明朝', 'MS PMincho', 'MS 明朝', serif;
}

.ttl-common_L {
    font-size: 2.6rem;
    font-weight: bold;
}

.ttl-common_LL {
    font-size: 4.8rem;
    font-weight: bold;

    line-height: 1.2;
}

.ttl-common .em {
    font-size: 3.0rem;
}



@media screen and (max-width: 767px) {
    .ttl-common {
        font-size: 2.0rem;
        line-height: 1.4;

    }

    .ttl-common_min {
        font-size: 1.6rem;
        line-height: 1.4;
    }

    .ttl-common_L {
        font-size: 2.2rem;
        line-height: 1.4;

    }

    .ttl-common_LL {
        font-size: 2.4rem;
        line-height: 1.4;

    }

    .ttl-common .em {
        font-size: 2.2rem;
        line-height: 1.4;

    }
}


/* =======================================

   l-Center

 ======================================= */

.l-Center {
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
}

/************** btn-inquiry **************/
.btn-inquiry,
.btn-urchase {
    position: relative;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: -webkit-inline-flex;
    display: inline-flex;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    text-align: center;
    color: #fff;
    border-radius: 8px;
    background: #00348A;
    box-shadow: 0 6px 0 #012561;
    text-shadow: 0 1px 1px rgba(0, 0, 0, .3);
    padding: 16px;
    min-width: 380px;
    letter-spacing: 1px;
    font-family: '游ゴシック', 'YuGothic', 'メイリオ', 'Meiryo', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'Osaka', 'ＭＳ Ｐゴシック', 'MS P Gothic', Verdana, Arial, Helvetica, sans-serif;
}

.btn-inquiry {
    background: #FD5004;
    box-shadow: 0 6px 0 #a33301;
}

.btn-urchase {
    background: #00348A;
    box-shadow: 0 6px 0 #012561;
}


a.btn-inquiry,
a.btn-urchase {
    color: #fff;
}

.hover .btn-inquiry:hover {
    background: #fb6d2e;
}

.hover .btn-urchase:hover {
    background: #1962dc;
}


.btn-inquiry:active,
.btn-urchase:active {
    top: 3px;
    box-shadow: none;
    -webkit-transition: .3s ease;
    -moz-transition: .3s ease;
    -ms-transition: .3s ease;
    transition: .3s ease;
}

.btn-inquiry:after,
.btn-urchase:after {
    font-family: 'icon';
    line-height: 0;
    content: '\e90b';
    color: #fff;
    position: absolute;
    top: 50%;
    right: 20px;
    transform: translate(0, -50%);
}

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

    .btn-inquiry,
    .btn-urchase {
        min-width: 100%;
    }

    .btn-inquiry:after,
    .btn-urchase:after {
        border-width: 4px 0 4px 7px;
    }
}

/*====================================

    header

====================================*/
.h-wrap {
    width: 100%;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 100;

    font-family: '游ゴシック', 'YuGothic', 'メイリオ', 'Meiryo', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'Osaka', 'ＭＳ Ｐゴシック', 'MS P Gothic', Verdana, Arial, Helvetica, sans-serif;
    -webkit-transform: translateZ(0);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

.h-inner {
    margin: 0 auto;
}

.h-logo {
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    margin-left: 18px;

    -js-display: flex;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    z-index: 5;
    position: relative;
    width: 100%;
    max-width: 328px;
}

.h-logo img {
    width: 100%;
    -webkit-backface-visibility: hidden;
}

.h-navArea {
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;

    -js-display: flex;
    position: relative;

}

.pc-telArea {
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    margin-left: auto;

    -js-display: flex;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
}

@media screen and (max-width: 1080px) {
    .h-logo {
        max-width: 240px;
    }
}


@media screen and (max-width: 767px) {
    .h-logo {
        max-width: 200px;
    }

    .pc-telArea {
        display: none;
    }
}

/* =====================
  telArea
===================== */
.telArea {
    text-align: center;
    padding: 10px;
    padding-right: 24px;
    font-size: 3.2rem;
    font-family: 游明朝, 'Yu Mincho', YuMincho, 'メイリオ', 'Meiryo', 'ヒラギノ明朝 ProN W3', 'HiraMinProN-W3', 'HG明朝E', 'ＭＳ Ｐ明朝', 'MS PMincho', 'MS 明朝', serif;
    color: #FFF;
}

.telArea .sub {
    font-size: 2.1rem;
}

@media screen and (max-width: 929px) {
    .telArea {
        font-size: 2.8rem;
        padding-right: 8px;
    }

    .telArea .sub {
        font-size: 1.8rem;
    }
}




@media all and (-ms-high-contrast: none) {
    .telArea {
        margin-top: 0px;
    }
}

/* =====================
  .h-icon
===================== */
.h-icon {
    margin-right: 8px;
    width: 100%;
    max-width: 30px;
}

.h-icon img {
    width: 100%;
}

@media screen and (max-width: 767px) {
    .h-icon {
        max-width: 20px;
    }
}

/* =====================
  btnContact
===================== */
.btnContact {
    color: #fff;
    font-size: 2.1rem;
    font-weight: bold;
    height: 100%;
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 0 24px;

    background: #DC2F02;
    position: relative;
    padding-right: 40px;
}

a.btnContact {
    color: #fff;
}

.btnContact:after {
    font-family: 'icon';
    font-size: 1.8rem;
    position: absolute;
    top: 50%;
    right: 4px;
    content: '\e90b';
    -webkit-transition: all .2s ease-in-out;
    -moz-transition: all .2s ease-in-out;
    -ms-transition: all .2s ease-in-out;
    transition: all .2s ease-in-out;
    transform: translate(-50%, -50%);
}

.hover .btnContact:hover {
    opacity: 0.8;
}

@media screen and (max-width: 929px) {
    .btnContact {
        font-size: 1.8rem;
    }

    .btnContact:after {
        font-size: 1.3rem;
    }
}

@media screen and (max-width: 1480px) {
    .h-inner {
        max-width: 100%;
        margin: 0 auto;
    }
}



@media screen and (max-width: 767px) {
    .h-navArea {
        padding: 8px 0 2px;
    }
}



@media all and (-ms-high-contrast: none) {
    a.btnContact {
        padding-top: 8px;
    }
}


/* =====================
  .sp-pc-telArea max-width: 767px
===================== */

@media screen and (min-width: 767px) {
    .sp-telArea {
        display: none;
    }
}

/* =====================
  h-gnav
===================== */
.h-gnav {
    display: none;
}

.h-gnav {}

.h-gnav-list {
    position: relative;
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    width: 100%;
    max-width: 1200px;

    -js-display: flex;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.h-gnav-list>li {
    position: relative;
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;

    text-align: center;

    -js-display: flex;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    cursor: pointer;
    width: 100%;
    letter-spacing: 0.8px;
}

li.gnav-list-onlySp {
    display: none;
}

.h-gnav-list .em-s {
    font-size: 1.2rem;
}

.menu-top-sp {
    display: none;
}

a.gnav-ttl {
    position: relative;
    padding: 20px;
    height: 100%;
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    -js-display: flex;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    width: 100%;
    flex-direction: column;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    text-align: center;
    -webkit-transition: all .2s ease-in-out;
    -moz-transition: all .2s ease-in-out;
    -ms-transition: all .2s ease-in-out;
    transition: all .2s ease-in-out;
}

a.gnav-ttl:after {
    -moz-transition: all .2s ease-in-out;
    -ms-transition: all .2s ease-in-out;
    transition: all .2s ease-in-out;

    content: "";
    position: absolute;
    top: 80%;
    left: 50%;
    transform: translate(-50%, 0);
    width: 16px;
    height: 2px;
    background: #fff;
}

.hover a.gnav-ttl:hover:after {
    background: #00348A;
}

@media screen and (max-width: 929px) {
    .h-gnav {




        width: 100%;
        border-top: 1px solid #B6BBCA;
        border-bottom: 1px solid #B6BBCA;
        font-size: 1.6rem;



        position: absolute;
        z-index: 19;
        top: 74px;
        display: block;
        padding: 0;
        transition: all 0.1s ease;
        -webkit-transform: translateX(100%);
        transform: translateX(100%);
        background: #f1f1f1;
    }

    .h-gnav-list {
        overflow: auto;
        overflow: auto;
        flex-direction: column;
        height: 100%;
        background: #1d2c5a;

        -webkit-overflow-scrolling: touch;
        -webkit-flex-direction: column;
        -ms-flex-direction: column;
    }

    .h-gnav-list .em-s {
        display: none;
    }

    .h-gnav-list>li {
        font-size: 2.0rem;
        flex-direction: column;
        padding: 0;
        cursor: pointer;
        text-align: left;
        color: #1d2c5a;
        border-bottom: 1px solid #fff;
        background: #f1f1f1;

        -webkit-flex-direction: column;
        -ms-flex-direction: column;
        -webkit-align-items: flex-start;
        -ms-flex-align: start;
        align-items: flex-start;
    }

    .h-gnav-list>li.active {
        padding-bottom: 0;
        color: #fff;
        border-top: 1px solid #434e6f;
        border-bottom: 0;
        background: #1d2c5b;
    }

    li.gnav-list-onlySp {
        display: block;
    }

    a.gnav-ttl {
        text-align: left;
        padding: 16px 0;
        padding-left: 20px;
    }

    a.gnav-ttl:after {
        content: none;
    }

    .hover a.gnav-ttl:hover:after {
        content: none;
    }

    .h-gnav-list>li>a {
        display: block;
        width: 100%;
        color: #1d2c5b;
        font-weight: bold;
    }

    .h-gnav-list>li>a .em {
        font-size: 2.8rem;
        line-height: 1.2;
    }

    .h-gnav-list>li .fwb {
        font-weight: 400;
    }

    .gnav-ttl {
        width: 100%;
        padding-left: 20px;
    }

    .active a.gnav-ttl {
        height: auto;
        color: #fff;
    }

    .hover .active a.gnav-ttl:hover {
        color: #fff;
    }

    .menu-top-sp {
        display: inline-block;
        margin-left: 10px;
    }

    .drawer-opened .h-wrap {
        position: fixed;
        z-index: 50;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        overflow-x: hidden;
        overflow-y: auto;
    }

    .drawer-opened .h-gnav {
        width: 100%;
        transition: all 0.1s ease;
        -webkit-transform: none;
        transform: none;
    }

    .drawer-opened #page {
        transition: all 0.1s ease;
        box-shadow: 1px 0 2px #000;
    }

    .drawer-opened #overlay {
        z-index: 10;
        transition: all 0.1s ease;
        -webkit-transform: none;
        transform: none;
        opacity: 0.3;
    }

    .gnav-ttl,
    .active .gnav-ttl {
        position: relative;
    }
}

@media screen and (max-width: 767px) {
    a.gnav-ttl {
        padding: 8px 0;
        padding-left: 16px;
    }

    .h-gnav {
        top: 78px;
    }

    .h-gnav-list>li {
        font-size: 1.6rem;

    }

    .h-gnav-list>li>a .em {
        font-size: 2.2rem;
    }

    .h-gnav-list>li:last-child {
        padding-bottom: 100px;

    }
}

/* =====================
 sp-h-btn
===================== */
.sp-h-btn {
    display: none;
}

@media screen and (max-width: 929px) {
    .sp-h-btn {
        display: flex;
        display: -ms-flexbox;
        display: -webkit-flex;

        -webkit-align-items: center;
        -ms-flex-align: center;
        align-items: center;
    }

    .sp-h-btn .btn {
        position: relative;
        display: flex;
        display: -ms-flexbox;
        display: -webkit-flex;
        flex-direction: column;
        text-align: center;

        -js-display: flex;
        -webkit-flex-direction: column;
        -ms-flex-direction: column;
        -webkit-align-items: center;
        -ms-flex-align: center;
        align-items: center;
        width: 10%;
        background: #fff;
    }

    .sp-telArea {
        cursor: pointer;
        width: 45px;
    }

    .sp-telArea img {
        display: block;
        width: 45px;
    }

    .sp-h-btn .btn p {
        font-size: 10px;
        margin-top: 2px;
        color: #00348A;
    }

    .sp-h-btn .btn-tel {
        display: block;
    }

    .sp-h-btn .icon-tel:before {
        font-size: 2.9rem;
        color: #1d2c5b;
    }

    .sp-h-btn .icon-bar {
        display: block;
        width: 32px;
        height: 3px;
        margin: 0 auto 8px;
        transition: all 0.3s ease;
        border-radius: 50px;
        background: #00348A;
    }

    body.drawer-opened .btn-menu {
        transition: all 0.1s ease;
    }

    body.drawer-opened .btn-menu .icon-bar {
        transition: all 0.1s ease;
    }

    body.drawer-opened .btn-menu .icon-bar:nth-child(1) {
        transition: all 0.1s ease;
        -ms-transform: translate(0, 14px) rotate(45deg);
        transform: translate(0, 14px) rotate(45deg);
    }

    body.drawer-opened .btn-menu .icon-bar:nth-child(2) {
        transition: all 0.1s ease;
        -ms-transform: translateX(200px);
        transform: translateX(200px);
    }

    body.drawer-opened .btn-menu .icon-bar:nth-child(3) {
        transition: all 0.1s ease;
        -ms-transform: translate(0, -7px) rotate(-45deg);
        transform: translate(0, -7px) rotate(-45deg);
    }
}

@media screen and (max-width: 767px) {
    .sp-h-btn {
        padding-right: 5px;
        margin-left: auto;
    }
}

/* =======================================
   btn-common

 ======================================= */
.btn-common {
    color: #fff;
    font-size: 2.8rem;
    min-width: 410px;
    border-radius: 100px;
    display: inline-block;
    padding: 12px 24px;
    text-align: center;
    position: relative;
    z-index: 1;
    background: linear-gradient(to right, #8E1C31, #000000);
    font-weight: bold;
    box-shadow: 0 4px 8px rgba(255, 255, 255, 0.5);
}

.btn-common .inner {
    position: relative;
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    padding-left: 16px;

}

a.btn-common {
    color: #fff;
}

.hover .btn-common:hover {
    opacity: 0.8;
}

.btn-common .icon-arrow-right-thin {
    font-size: 1.8rem;
    font-weight: bold;
    margin-left: 32px;
}

@media screen and (max-width: 767px) {
    .btn-common {
        min-width: calc(100% - 40px);
        font-size: 2.0rem;
        padding: 8px;
    }

    .btn-common .icon-arrow-right-thin {
        margin-left: 8px;
    }
}




@media all and (-ms-high-contrast: none) {
    .btn-common {
        padding: 16px 24px 8px 24px;
    }

    .btn-common .icon-arrow-right {
        margin-top: -8px;
    }
}

/* =======================================

   mainVisual

 ======================================= */
.mainVisual {
    position: relative;
    overflow: hidden;
    width: 100%;
    height: 582px;
    margin-top: 77px;
    background: url(../img/mv_bg.jpg);
    background-position: center center;
    background-size: cover;
    z-index: 1;
    background-repeat: no-repeat;
    line-height: 1.6;
}

.mainVisual:after {
    position: absolute;
    top: 0;
    left: 46%;
    content: "";
    background: url(../img/main_visual_bg.jpg);
    background-position: center center;
    background-size: cover;
    width: 100%;
    height: 640px;
    transform: skewX(-15deg);
    z-index: -1;
}

.mainVisual-inner {
    max-width: 1080px;
    margin: 0 auto;
    padding: 64px 16px;
    position: relative;
    height: 100%;
}

.mainVisual-cont {
    font-family: 游明朝, 'Yu Mincho', YuMincho, 'メイリオ', 'Meiryo', 'ヒラギノ明朝 ProN W3', 'HiraMinProN-W3', 'HG明朝E', 'ＭＳ Ｐ明朝', 'MS PMincho', 'MS 明朝', serif;
    position: relative;
    color: #fff;
    font-size: 4.8rem;
    text-shadow: 1px 1px 8px #111213;
    width: 100%;
}

.mv-catch {
    font-size: 7.0rem;
    margin-bottom: 30px;
    letter-spacing: .5px;
}

.lion {
    position: absolute;
    right: 0;
    bottom: 0;
    max-width: 550px;
}

.lion img {
    width: 100%;
}

.tvcm {
    position: absolute;
    bottom: 40px;
    right: 0;
    max-width: 148px;
    text-align: center;
    border: 1px solid #fff;
    border-radius: 50%;
    width: 148px;
    height: 148px;
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    flex-direction: column;

    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    font-size: 1.4rem;
    line-height: 1.2;
    margin-top: 8px;
    font-weight: bold;
}

a.tvcm {
    color: #fff;
}

.tvcm .em1 {
    font-size: 2.0rem;
    letter-spacing: 1px;
}

.tvcm .first {
    padding-top: 12px;
}

.tri {
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 10px 0 10px 20px;
    border-color: transparent transparent transparent #fff;
    margin-top: 6px;
}

.tvcm:hover {
    background: #fff;
    color: #003984;
}

a.tvcm:hover {
    color: #003984;
}

a.tvcm:hover .tri {
    border-color: transparent transparent transparent #003984;
}


.mainVisual-bnr {
    position: relative;
    display: block;
    max-width: 286px;
    text-align: center;
    font-weight: bold;
    border: 2px solid #fff;
    background: transparent;
    padding: 8px;
    text-align: center;
    color: #fff;
    border-radius: 4px;
    margin-top: 64px;
    font-size: 2.4rem;
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;

}

a.mainVisual-bnr {
    color: #fff;
}

.mainVisual-bnr:hover {
    border: 2px solid #DC2F02;
    background: #DC2F02;
}

.mainVisual-bnr_sp {
    display: none;
}


.mainVisual-bnr .icon-arrow-right-thin {
    font-size: 1.6rem;
    margin-left: 22px;
}


a.tvpr-bnr-pc {
    margin-top: 3rem;
    display: block;
}

a.tvpr-bnr-sp {
    display: none;
}

@media screen and (max-width: 1060px) {
    .mainVisual-cont {
        font-size: 4.0rem;
    }

    .mv-catch {
        font-size: 5.0rem;
    }

    .lion {
        max-width: 460px;
        right: 24px;
    }

    .tvcm {
        bottom: 24px;
        right: 16px;
    }
}

/*
@media screen and (max-width: 980px) {
    .mainVisual-pic {
        max-width: 480px;
    }
}
*/
@media screen and (max-width: 929px) {
    .mainVisual {
        margin-top: 70px;
    }
}

@media screen and (max-width: 900px) {
    .mainVisual-bnr {
        display: none;
    }

    .mainVisual {
        display: flex;
        display: -ms-flexbox;
        display: -webkit-flex;
        flex-direction: column;
        height: auto;
        margin-top: 64px;

        -js-display: flex;
        -webkit-justify-content: center;
        -ms-flex-pack: center;
        justify-content: center;
        -webkit-align-items: center;
        -ms-flex-align: center;
        align-items: center;
        -webkit-flex-direction: column;
        -ms-flex-direction: column;
    }

    .mainVisual:after {
        height: 100%;
    }

    .mainVisual-inner {
        padding-bottom: 0;
    }

    /*
    .mainVisual-pic {
        margin-top: 0;
        margin-bottom: 16px;
    }
    */

    .mv-catch {
        margin-bottom: 16px;
        text-align: center;
    }

    .mainVisual-cont {
        text-align: center;
    }

    .lion {
        position: static;
        max-width: 100%;
        max-width: 460px;
    }

    .mainVisual-bnr {
        display: none;
    }

    .mainVisual-bnr_sp {
        position: relative;
        display: block;
        color: #fff;
        background: #DC2F02;
        padding: 8px;
        text-align: center;
        font-size: 2.0rem;
        font-weight: bold;
    }

    .mainVisual-bnr_sp .txt {
        position: relative;
    }

    .mainVisual-bnr_sp .txt:after {
        font-family: 'icon';
        font-size: 1.8rem;
        position: absolute;
        top: 50%;
        right: -24px;
        content: '\e90b';
        -webkit-transition: all .2s ease-in-out;
        -moz-transition: all .2s ease-in-out;
        -ms-transition: all .2s ease-in-out;
        transition: all .2s ease-in-out;
        transform: translate(0, -50%);
    }

    a.mainVisual-bnr_sp {
        color: #fff;
    }

    a.tvpr-bnr-pc {
        display: none;
    }

    a.tvpr-bnr-sp {
        display: block;
        max-width: 460px;
        margin-bottom: 2rem;
        margin-left: 2px;
        text-align: center;
    }

    a.tvpr-bnr-sp img {
        width: 100%;
    }
}

@media screen and (max-width: 767px) {
    .mainVisual-inner {
        padding: 24px 8px 0 8px;
    }

    .mainVisual-cont {
        font-size: 2.3rem;
    }

    .mv-catch {
        font-size: 1.9rem;
    }

    .tvcm {
        width: 100px;
        height: 100px;
        font-size: 1.0rem;
    }

    .tvcm .em1 {
        font-size: 1.3rem;
    }

    .tri {
        border-width: 6px 0 6px 12px;
        margin-top: 3px;
    }

    /*
    .mainVisual-pic {
        width: calc(100% - 32px);
        margin: 0 auto;
        margin-bottom: 16px;
    } */
}

/* =======================================

  col3List

 ======================================= */
.col3List {
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;

}

.col3List>li {
    width: 30%;
}

@media screen and (max-width: 767px) {
    .col3List {
        flex-direction: column;

        -webkit-flex-direction: column;
        -ms-flex-direction: column;

    }

    .col3List>li {
        width: 100%;
        margin-bottom: 40px;
    }

    .col3List>li:last-child {
        margin-bottom: 0;
    }

    #reason02 .col3List>li {
        width: 100%;
        margin: 0 auto;
        margin-bottom: 40px;
    }

    #reason02 .col3List>li:last-child {
        margin-bottom: 0;
    }
}

/* =======================================

  col2List tukaimawasenai

 ======================================= */
.col2List {
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;

}

.col2List>li {
    width: 48%;
}

@media screen and (max-width: 929px) {
    .col2List {
        display: flex;
        flex-direction: column;

        -webkit-flex-direction: column;
        -ms-flex-direction: column;
        -webkit-align-items: center;
        -ms-flex-align: center;
        align-items: center;
    }

    .col2List>li {
        width: 100%;
        max-width: 400px;
        margin-bottom: 16px;
    }

    .col2List>li:last-child {
        margin-bottom: 0;
    }

}

@media screen and (max-width: 767px) {
    .col2List {
        margin-top: 32px;
    }

    .col2List>li {
        width: 100%;
        max-width: 400px;
        margin-bottom: 40px;
    }

    .col2List>li:last-child {
        margin-bottom: 0;
    }
}

/* =======================================

  cardA

 ======================================= */

.cardA .pic,
.cardA .ttl {
    text-align: center;
}

.cardA .ttl {
    font-size: 2.4rem;
    color: #FFF;
    font-weight: bold;
    padding-top: 8px;
    margin-bottom: 16px;
}

/* =======================================

  cardB

 ======================================= */
.cardB {
    border-top: 4px solid #003984;
    padding: 0 16px 16px 16px;
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0.2);
    flex-direction: column;

    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    height: 100%;
}

.cardB .ttl {
    font-size: 3.2rem;
    color: #003984;
    text-align: center;
    font-weight: bold;
    line-height: 1.2;
    border-bottom: 1px solid #CDD6DD;
    height: 111px;

    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 16px 0;
}

.cardB .ttl .num {
    font-size: 7.2rem;
    color: #003984;
}

.cardB .txt {
    padding: 32px 0 16px;
}

.cardB .pic {
    margin-top: auto;
}

.cardB .pic img {
    width: 100%;
}

@media screen and (max-width: 970px) {
    .cardB .ttl {
        font-size: 2.4rem;
    }

    .cardB .ttl .num {
        font-size: 4.8rem;
    }

    .cardB .pic {
        margin: 0 auto;
    }
}



@media all and (-ms-high-contrast: none) {

    .cardB {
        display: block;
    }

    .cardB .ttl {
        padding: 24px 0 16px 0;
    }


}


/* =======================================

  cardC

 ======================================= */
.cardC {
    background: #c9d3dd;
    display: block;
    width: 100%;
    position: relative;
    height: 100%;
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    flex-direction: column;

    -webkit-flex-direction: column;
    -ms-flex-direction: column;

}

.cardC .ttl {
    font-family: 游明朝, 'Yu Mincho', YuMincho, 'メイリオ', 'Meiryo', 'ヒラギノ明朝 ProN W3', 'HiraMinProN-W3', 'HG明朝E', 'ＭＳ Ｐ明朝', 'MS PMincho', 'MS 明朝', serif;
    font-weight: bold;
    font-size: 2.4rem;
    padding: 40px 4px 40px 0;
    padding-left: 46%;
    line-height: 1.6;
}

.cardC .pic {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 42%;
}

.cardC .pic img {
    width: 100%;
}

.cardC .pro {
    color: #fff;
    background: #98A6B5;
    padding: 16px 0;
    padding-left: 46%;
    margin-top: auto;
    -webkit-transition: all .2s ease-in-out;
    -moz-transition: all .2s ease-in-out;
    -ms-transition: all .2s ease-in-out;
    transition: all .2s ease-in-out;
    line-height: 1.2;
}

.cardC .posi {
    font-size: 2.0rem;
    padding-bottom: 8px;
}

.cardC .name {
    font-size: 2.7rem;
    font-weight: bold;
}

@media screen and (max-width: 767px) {
    .cardC .ttl {
        font-size: 1.6rem;
        padding: 16px 0 16px 0;
        padding-left: 46%;
    }

    .cardC .pro {
        padding: 8px 0;
        padding-left: 46%;
    }

    .cardC .posi {
        font-size: 1.4rem;
        padding-bottom: 4px;
    }

    .cardC .name {
        font-size: 2.0rem;
    }
}

/* =======================================

  ownerList

 ======================================= */
.ownerList {
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    -js-display: flex;
    width: 100%;
    margin: 0 auto;
}

.ownerList>li {
    position: relative;
    padding: 0 20px;
}

/* =======================================

  cardD

 ======================================= */
.ownerList .cardD {
    margin: 8px;
}

.cardD {
    padding: 16px;
    border: 1px solid #CDD6DD;
    display: block;
}

.cardD .name {
    font-weight: bold;
    margin-top: 8px;
}

.cardD .corp {
    font-size: 1.4rem;
    margin-bottom: 8px;
}

.cardD .ttl {
    line-height: 1.6;
}

.cardD .pic img {
    width: 100%;
}


@media screen and (max-width: 767px) {
    .ownerList .cardD {
        margin: 0;
    }
}

/* =======================================

  cont-02

 ======================================= */

.cont-02 {
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
}

.cont-02 .txt {
    width: 70%;
    padding-right: 72px;
}

.cont-02 .pic {
    width: 30%;
}

.cont-02 .pic img {
    width: 100%;
}

@media screen and (max-width: 767px) {
    .cont-02 {
        flex-direction: column;

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

    .cont-02 .txt {
        width: 100%;
        padding-right: 0;
        padding-bottom: 8px;
    }

    .cont-02 .pic {
        width: 100%;
        margin-top: 24px;
        margin: 0 auto;
        margin-top: 8px;
    }

}


@media screen and (max-width: 767px) {
    .txtBox {
        font-size: 1.6rem;
    }
}


/* =======================================

  label

 ======================================= */
.label {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: -webkit-inline-flex;
    display: inline-flex;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    background: #F0F3F5;
    padding: 2px 12px;
    border-radius: 4px;
    font-weight: bold;
}

.label.current {
    background: #004BB1;
    color: #fff;
}

a.label.current {
    background: #004BB1;
    color: #fff;
}

.hover .label:hover {
    background: #004BB1;
    color: #fff;
}

.hover a.label:hover {
    background: #004BB1;
    color: #fff;
}

@media screen and (max-width: 767px) {
    .label {
        padding: 2px 12px;
        font-size: 1.2rem
    }
}

/* =======================================

  labelList

 ======================================= */
.labelList {
    width: 100%;
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.labelList>li {
    padding: 8px;
}

@media screen and (max-width: 767px) {
    .labelList>li {
        padding: 4px;
    }

}

/* =======================================

  inquiry-box

 ======================================= */
.inquiry-box {
    position: relative;
    overflow: hidden;
    padding: 0 24px;

    background: url('../img/bg_contat.jpg');
    background-repeat: no-repeat;
    background-position: center bottom;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;

}

.inquiry-box .inner {
    width: 100%;
    max-width: 767px;
    margin: 0 auto;
    padding: 40px 24px;
}

.inquiry-box .tit {
    color: #fff;
    font-size: 2.8rem;
    font-weight: bold;
    text-align: center;
    line-height: 1.4;
    margin-bottom: 16px;
    line-height: 1.9;
    letter-spacing: 1px;
    line-height: 1.4;
}

.inquiry-box .inner .sub {
    font-size: 2.4rem;
    color: #fff;
    text-align: center;
    font-weight: bold;
}


.inquiry-box .tel {
    color: #fff;
    font-size: 2.4rem;
    font-weight: bold;
    text-align: center;
    line-height: 1;
    margin-top: 40px;
}

.inquiry-box .tel .num {
    font-size: 4.6rem;
    font-family: 游明朝, 'Yu Mincho', YuMincho, 'メイリオ', 'Meiryo', 'ヒラギノ明朝 ProN W3', 'HiraMinProN-W3', 'HG明朝E', 'ＭＳ Ｐ明朝', 'MS PMincho', 'MS 明朝', serif;
    padding-left: 16px;
    font-weight: normal;

}

@media screen and (max-width: 767px) {
    .inquiry-box .inner {
        max-width: 100%;
        padding: 40px 0;
    }

    .inquiry-box .tit {
        font-size: 2.0rem;
    }

    .inquiry-box .inner .sub {
        font-size: 1.6rem;
        line-height: 1.2;
    }

    .inquiry-box .tel .num {
        display: block;
        margin-top: 8px;
        font-size: 4.0rem;
        padding-left: 0;
    }

}




/* =======================================

   footer

 ======================================= */


/************** pageTop **************/
#pageTop {
    position: fixed;
    z-index: 10;
    right: 0;
    bottom: 0;
    width: 72px;
    height: 72px;
    cursor: pointer;
    text-align: center;
}

#pageTop .icon-page_top:before {
    color: #fff;
    font-size: 6.0rem;
    color: #ccc;
}

@media screen and (max-width: 767px) {
    #pageTop {
        right: 10px;
        bottom: 30px;
        width: 42px;
        height: 42px;
    }

    #pageTop .icon-page_top:before {
        font-size: 4.0rem;
    }
}



/* =====================
  slick
===================== */

.slick-slider {
    position: relative;
    display: block;
    box-sizing: border-box;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;

    -webkit-touch-callout: none;
    -khtml-user-select: none;
    -ms-touch-action: pan-y;
    touch-action: pan-y;
    -webkit-tap-highlight-color: transparent;
}

.slick-list {
    position: relative;
    display: block;
    overflow: hidden;
    margin: 0;
    padding: 0;
}

.slick-list:focus {
    outline: none;
}

.slick-list.dragging {
    cursor: pointer;
    cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
    -webkit-transform: translate3d(0, 0, 0);
    -moz-transform: translate3d(0, 0, 0);
    -ms-transform: translate3d(0, 0, 0);
    -o-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
}

.slick-track {
    position: relative;
    top: 0;
    left: 0;
    display: flex;
    display: -ms-flexbox;

    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.slick-slide {
    display: none;
    height: 100%;
    min-height: 1px;
}

.slick-slide.dragging img {
    pointer-events: none;
}

.slick-initialized .slick-slide {
    display: block;
}

.slick-vertical .slick-slide {
    display: block;
    height: auto;
    border: 1px solid transparent;
}

.slick-arrow.slick-hidden {
    display: none;
}

/* =====================
  prev next custom
===================== */
.slick-prev,
.slick-next {
    font-family: 'icon';
    font-size: 0;
    line-height: 0;
    position: absolute;
    top: 55%;
    display: block;
    height: 100%;
    padding: 0;
    cursor: pointer;
    -webkit-transform: translate(0, -50%);
    -ms-transform: translate(0, -50%);
    transform: translate(0, -50%);
    color: transparent;
    border: none;
    outline: none;
    background: transparent;
    z-index: 10;
}

.slick-prev:before,
.slick-next:before {
    font-size: 5.0rem;
    line-height: 1;
    color: #707F89;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.slick-prev {
    left: -72px;
}

.slick-next {
    right: -72px;
}

.slick-next:before {
    line-height: 0;
    content: '\e90b';
}

.slick-prev:before {
    line-height: 0;
    content: '\e906';
}

@media screen and (max-width: 1140px) {
    .slick-prev {
        left: -24px;
    }

    .slick-next {
        right: -24px;
    }
}

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

    .slick-prev:before,
    .slick-next:before {
        font-size: 3.0rem;
    }

    .slick-prev {
        left: -16px;
    }

    .slick-next {
        right: -16px;
    }
}


/* =====================
  copyright
===================== */
.copyright {
    padding: 24px 0;
    text-align: center;
    font-size: 2.0rem;
    background: #fff;
}

@media screen and (max-width: 767px) {
    .copyright {
        padding: 15px 0;
        font-size: 1.3rem;
    }
}


/************** bg **************/
.bg-gray {
    background: #F0F3F5;
}

.bg-blue {
    background: #1d2c5b;
}


.fwb {
    font-weight: bold;
}


.txt-blue {
    color: #003984;
}

a.txt-blue {
    color: #003984;
}

.txt-yellow {
    color: #F2D980;
}

.txt-syellow {
    color: #F2D980;
}


.tac {
    text-align: center;
}

.tac-only-pc {
    text-align: center;
}

@media screen and (max-width: 767px) {
    .tac-only-pc {
        text-align: left;
    }
}

/*  Responsive
------------------------*/
.only-sp {
    display: none;
}

@media screen and (max-width: 767px) {
    .only-sp {
        display: block;
    }

    .only-pc {
        display: none;
    }
}








/* =====================
  tbl-common
===================== */
.tbl-common {
    width: 100%;
    border-top: 1px solid #ccc;
    border-right: 1px solid #ccc;
    border-left: 1px solid #ccc;
}

.tbl-common tr {
    border-bottom: 1px solid #ccc;
}

.tbl-common th,
.tbl-common td {
    padding: 10px 20px;
    text-align: center;
    vertical-align: middle;
    word-wrap: break-word;
    /*20201022 追加*/
}

.tbl-common th {
    border-right: 1px solid #ccc;
    background: #e3e7f6;
}

.tbl-common td {
    border-right: 1px solid #ccc;
    background: #fff;
}

.tbl-common.tdLeft td {
    text-align: left;
}

.tbl-common.thLeft th {
    text-align: left;
}

.tbl-common th.thCenter {
    text-align: center;
}

.tbl-common.tdRight td {
    text-align: right;
}

.tbl-common.tdRight td:first-child {
    text-align: left;
}

.tbl-common th.br-none,
.tbl-common td.br-none {
    border-right: none;
}

.tbl-common th.bb-none,
.tbl-common td.bb-none {
    border-bottom: 1px solid #e3e7f6
}

.tbl-ttl {
    font-weight: bold;
    position: relative;
}

.tbl-ttl-tar {
    position: absolute;
    top: 0;
    right: 0;
}

.tbl-common.slim th,
.tbl-common.slim td {
    padding: 10px 5px;
}

.vertical {
    writing-mode: tb-lr;
    writing-mode: vertical-lr;
    -webkit-writing-mode: vertical-lr;
    letter-spacing: .2em;
    width: 2em;
    white-space: nowrap;
    text-orientation: upright;
    -webkit-text-orientation: upright;
}

_:-ms-lang(x),
.verticalIE {
    writing-mode: lr-tb;
}

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

    .tbl-sm th,
    .tbl-sm td {
        display: block;
        width: 100%;
        padding: 5px 10px;
    }

    .tbl-common.sm-slim th,
    .tbl-common.sm-slim td {
        padding: 10px 5px;
    }
}

/* =====================
  jissekiList
===================== */
/*.jissekiList{
        transition : 0.8s;
    -webkit-transform : translate(0,60px);
            transform : translate(0,60px);
    opacity : 0;
}*/
.jissekiList>li {
    position: relative;
    margin-bottom: 60px;
}

.jissekiList>li:last-child {
    margin-bottom: 0;
}

.jissekiList th,
.jissekiList td {
    text-align: left;
    line-height: 1.2;
}

.jissekiList th {
    background: #8c95b1;
    color: #fff;
}

.jissekiList .ttl {
    font-weight: bold;
}



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

    .tbl-common th,
    .tbl-common td {
        font-size: 1.2rem;
        padding: 10px 8px;
    }

    .jissekiList .ttl {
        font-weight: bold;
        font-size: 1.3rem;
        margin-bottom: 4px;
    }
}

/* =======================================

   contactStep-list

 ======================================= */

.contactStep-list {
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;

    -js-display: flex;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
}

.contactStep-list li {
    font-weight: 500;
    position: relative;
    width: 100%;
    height: 70px;
    padding: 20px 0;

    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    background: #F0F3F5;
    color: #1D2C5B;
    font-weight: bold;
}

.contactStep-list li.current {
    color: #fff;
    background: #003984;
}

.stepBg {
    position: absolute;
    z-index: 1;
    top: 0;
    left: 99%;
    width: 42.7px;
    height: 70px;
}

.stepBg img {
    width: 100%;
}


.contactStep-list .ttl {
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;

}


/* =======================================

   contactStep-list_green

 ======================================= */
.contactStep-list.contactStep-list_green li.current {
    color: #fff;
    background: #13756F;
}

.contactStep-list.contactStep-list_green li.current .stepBg {
    width: 43.7px;
}

.contactStep-list.contactStep-list_green li {
    color: #003A36;
}

@media screen and (max-width: 767px) {
    .contactStep-list li {
        font-size: 1.1rem;
        line-height: 1.2;
        height: 40px;
        padding: 0;
        padding-left: 14px;
        text-align: left;

    }

    .contactStep-list .ttl .num {
        margin-right: 4px;
    }

    .stepBg {
        width: 24px;
    }

    .contactStep-list.contactStep-list_green li.current .stepBg {
        width: 24px;
    }
}



/* =======================================

   form

 ======================================= */


/* =====================
  formArea
===================== */
#form {
    background: #fff;
    padding: 24px;
}

.formArea {
    font-size: 2.0rem;
    line-height: 1.2;
    padding: 10px 40px 45px;
    background: #f5f5f5;
    position: relative;
    width: 100%;
    max-width: 1140px;
    margin: 0px auto;
}

.formArea input[type="submit"] {
    cursor: pointer;
    width: 100%;
    padding: 10px 30px 10px 45px;
}

.formArea input[type="button"] {
    cursor: pointer;
    width: 100%;
    padding: 10px 30px 10px 45px;
}

.formArea-ttl {
    font-family: 'Notoserif', serif;
    font-size: 3.8rem;
    font-weight: 500;
    text-align: center;
    color: #1e2d5b;
}

.formArea-ttl-sub {
    font-size: 2.0rem;
    text-align: center;
    color: #1e2d5b;
    margin-top: 5px;

}

.formTxt-sub {
    margin-bottom: 10px;
}

.formTxt {
    margin-bottom: 15px;
}

.formArea .btn-common {
    cursor: pointer;
    -webkit-transition: all .2s ease-in-out;
    -moz-transition: all .2s ease-in-out;
    -ms-transition: all .2s ease-in-out;
    transition: all .2s ease-in-out;
}

.formArea .btn-sizeL {
    padding: 0;
}

.formArea .btn-common input[type="submit"] {
    color: #1e2d5b;
    font-size: 2.6rem;
}

.formArea .btn-common:hover input[type="submit"] {
    color: #fff;
}

.formArea .btn-em input[type="submit"] {
    color: #8e1c31;
    font-size: 2.6rem;
}

.formArea .btn-em:hover input[type="submit"] {
    color: #fff;
}

.formArea .btn-out input[type="submit"] {
    color: #ccc;
}

.formArea .btn-out:hover input[type="submit"] {
    color: #fff;
}


.formArea .btn-common input[type="button"] {
    color: #1e2d5b;
    font-size: 2.6rem;
}

.formArea .btn-common:hover input[type="button"] {
    color: #fff;
}

.formArea .btn-em input[type="button"] {
    color: #8e1c31;
    font-size: 2.6rem;
}

.formArea .btn-em:hover input[type="button"] {
    color: #fff;
}

.formArea .btn-out input[type="button"] {
    color: #ccc;
}

.formArea .btn-out:hover input[type="button"] {
    color: #fff;
}



@media screen and (max-width: 767px) {
    .formArea {
        font-size: 16px;
        margin-top: 0;
        padding: 30px 10px 20px;
    }

    .formArea-ttl {
        font-size: 2.4rem;
    }

    .formArea-ttl-sub {
        font-size: 1.4rem;
    }

    #form {
        margin-top: 0;
        padding: 24px 0;
    }
}

/* =====================
  formList
===================== */
.formList {
    padding: 20px 0 10px;
    font-size: 1.6rem;
    border-bottom: 1px solid #CDD6DD;
}

.formList>li {
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    padding: 20px 0;
    border-bottom: 1px solid #ccc;

    -js-display: flex;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
}

.formList>li:nth-child(n+4) {
    -webkit-align-items: flex-start;
    -ms-flex-align: start;
    align-items: flex-start;
}

.formList>li:nth-child(6) {
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
}

.formList>li:nth-child(n+7) {
    -webkit-align-items: flex-start;
    -ms-flex-align: start;
    align-items: flex-start;
}

.formList>li:first-child {
    border-top: 1px solid #ccc;
}

.formList>li:last-child {
    border-bottom: none;
}

.formTtl {
    position: relative;
    width: 24%;
    margin-right: 20px;
    line-height: 1.4;
    font-weight: bold;
}

.formTtl:after {
    font-size: 1.2rem;
    font-weight: bold;
    line-height: 1em;
    position: absolute;
    top: 0;
    right: 0;
    padding: 5px;
    content: '任意';
    color: #fff;
    background: #707F89;
}

.formTtl.required:after {
    content: '必須';
    background: #FF7F00;
}

.formItem {
    width: 76%;
    padding-left: 5px;
}

.formItem .row {
    margin: 0 auto;
}

.formBg {
    font-size: 16px;
    width: 100%;
    height: 50px;
    text-indent: 5px;
    border: 1px solid #ddd;
    background: #fff;
    border-radius: 4px;
}

input[type='text'],
input[type='password'] {
    font-size: 16px;
    width: 100%;
    height: 48px;
    margin-top: 1px;
    border-radius: 4px;
}

textarea {
    background: #fff;
    border: 1px solid #dddddd;
    border-radius: 4px;
    text-indent: 5px;
    font-size: 16px;
    height: 200px;
    width: 100%;
    padding: 10px 0;
}


@media screen and (min-width: 0\0) and (min-resolution: +72dpi) {
    .formTtl:after {
        padding: 6px 6px 2px;
    }
}


@media screen and (max-width: 767px) {
    .formList {
        padding-top: 0;
    }

    .formList>li {
        flex-direction: column;
        border-bottom: none;

        -webkit-flex-direction: column;
        -ms-flex-direction: column;
        -webkit-align-items: flex-start;
        -ms-flex-align: start;
        align-items: flex-start;
    }

    .formList>li:nth-child(6) {
        -webkit-align-items: flex-start;
        -ms-flex-align: start;
        align-items: flex-start;
    }

    .formTtl {
        width: auto;
        margin-right: 0;
        margin-bottom: 10px;
        padding-right: 45px;
    }

    .formItem {
        width: 100%;
        padding-left: 0;
        border-top: 1px solid #ccc;
        padding-top: 20px;
    }
}


/* =====================
  select
===================== */

select {
    font-size: inherit;
    font-size: 16px;
    box-sizing: content-box;
    width: 100%;
    height: 50px;
    margin: 0;
    padding: 0;
    cursor: pointer;
    vertical-align: middle;
    text-indent: 1.0rem;
    text-overflow: '';
    color: inherit;
    border: 0;
    border-radius: 0;
    background: none transparent;
    -moz-appearance: none;
    -webkit-appearance: none;
    appearance: none;
}

.formList select {
    font-size: 16px;
    width: 120%;
    height: 50px;
    cursor: pointer;
}

.selectBg-wrap {
    font-size: 16px;
    overflow: hidden;
    width: 100%;
    height: 50px;
    border: 1px solid #ddd;
    border-radius: 4px;
    background: #fff;
}

.selectBg {
    background: url(/img/formList-select.png) 50% no-repeat;
    background-position: center right;
    background-size: 23px, 4px;
}


/* =====================
  checkbox
===================== */
.checkbox input[type="checkbox"] {
    display: none;
}

.checkbox label {
    margin-right: 20px;
    display: inline-block;
    margin-bottom: 10px;
}

.checkbox01-input,
.radio-input {
    display: none;
}

.checkbox01-input:checked+.checkbox01-parts {
    color: #004BB1;
}

.checkbox01-parts::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 26px;
    height: 26px;
    border: 2px solid #DDD;
    border-radius: 6px;
    background: #fff;
}

.checkbox01-input:checked+.checkbox01-parts::after {
    content: "";
    display: block;
    position: absolute;
    top: 3px;
    left: 11px;
    width: 7px;
    height: 14px;
    transform: rotate(40deg);
    border-bottom: 3px solid #004BB1;
    border-right: 3px solid #004BB1;
}

.checkbox01-parts,
.radio-input+label {
    line-height: 1;
    position: relative;
    display: inline-block;
    padding-left: 36px;
    padding-top: 5px;
}

@media screen and (min-width: 0\0) and (min-resolution: +72dpi) {

    .checkbox01-parts,
    .radio-input+label {
        padding-top: 10px;
    }
}


/* =====================
  formMultiple
===================== */
.formMultiple li {
    margin-bottom: 10px;

    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.formMultiple-ttl {
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    -js-display: flex;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-justify-content: flex-start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    width: 100px;
    font-weight: bold;
}

.form-cap-wrap {
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    -js-display: flex;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-justify-content: flex-start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    font-size: 1.4rem;
}

.form-cap {
    margin-left: 10px;
}

.formMultiple li.only {
    margin-top: 15px;
}

.formMultiple li:last-child {
    margin-bottom: 0;
}

@media screen and (max-width: 767px) {
    .formMultiple li {
        flex-direction: column;

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

    .formMultiple-ttl {
        margin-bottom: 5px;
    }

    .form-cap-wrap {
        flex-direction: column;

        -webkit-flex-direction: column;
        -ms-flex-direction: column;
        -webkit-align-items: flex-start;
        -ms-flex-align: start;
        align-items: flex-start;
    }

    .form-cap {
        margin: 2px 0 10px;
    }
}

/* =====================
  formList-other
===================== */
.formList-other {
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;

    -js-display: flex;


}

.formList-other input[type='text'] {
    height: 40px;
}

.formList-other .formBg {
    height: 40px;
    margin-top: -7px;
    width: 80%;
}

@media screen and (max-width: 767px) {
    .formList-other {
        flex-direction: column;
        -webkit-flex-direction: column;
        -ms-flex-direction: column;
    }

    .formList-other .formBg {
        margin-top: 16px;
        width: 100%;
    }
}

/* =====================
  contactWay
===================== */
.contactWay-item {
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    margin-bottom: 20px;

    -js-display: flex;
}

@media screen and (max-width: 767px) {
    .contactWay-item {
        flex-direction: column;

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

    .contactWay-item li {
        margin-bottom: 20px;
    }
}

/* =====================
  checkboxList
===================== */
.checkboxList li {
    margin-bottom: 5px;
}

/* =====================
  triggerList
===================== */
.radioList li {
    margin-bottom: 15px;
}

/* =====================
  radio
===================== */
.radio-input {
    display: none;
}

.radio-input+label {
    position: relative;
    margin-right: 20px;
    padding-left: 36px;
}

.radio-input+label::before {
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 26px;
    height: 26px;
    content: '';
    border: 2px solid #DDDDDD;
    border-radius: 50%;
    background: #fff;
}

.radio-input:checked+label {
    color: #222;
    font-weight: bold;
}

.radio-input:checked+label::after {
    position: absolute;
    top: 5px;
    left: 5px;
    display: block;
    width: 20px;
    height: 20px;
    content: '';
    border-radius: 50%;
    background: #004BB1;
}

@media screen and (max-width: 767px) {
    .radio-input+label {
        position: relative;
        margin-right: 0;
        padding-left: 36px;
    }
}

/* =====================
  form-size
===================== */
.form-s {
    width: 180px;
}

.form-m {
    width: 220px;
}

.form-l {
    width: 350px;
}

@media screen and (max-width: 767px) {
    .form-s {
        width: 100%;
    }

    .form-m {
        width: 100%;
    }

    .form-l {
        width: 100%;
    }
}

/* =====================
  form-important
===================== */
.form-important {
    font-size: 1.6rem;
    border: 1px solid #ddd;
    border-radius: 6px;
    background: #fff;
    padding: 20px 24px;
}

.important-list li {
    margin-bottom: 18px;
}

.important-list li:last-child {
    margin-bottom: 0;
}

.important-ttl {
    font-size: 1.8rem;
    font-weight: 500;
    margin-bottom: 13px;
}

/* =====================
  agree-box
===================== */
.agree-box {
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;

    -js-display: flex;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    font-size: 1.6rem;
    margin: 33px auto;
    width: 440px;
}

.agree-box .checkbox {
    margin-top: -10px;
}

.agree-box .checkbox label {
    margin-right: 0;
}

@media screen and (max-width: 767px) {
    .agree-box {
        width: 100%;
    }
}





#form input[type="submit"] {
    color: #fff;
    font-weight: bold;
    font-size: 2.8rem;
    background: #3B4043;
    border-radius: 4px;
    padding: 16px;
    cursor: pointer;
    -webkit-transition: all .2s ease-in-out;
    -moz-transition: all .2s ease-in-out;
    -ms-transition: all .2s ease-in-out;
    transition: all .2s ease-in-out;
    width: 100%;
    max-width: 442px;
}

#form input[type="submit"]:hover {
    color: #fff;
    background: #003984;
}

@media screen and (max-width: 767px) {
    #form input[type="submit"] {
        font-size: 2.0rem;
        max-width: 100%;
    }
}

@media all and (-ms-high-contrast: none) {

    #form input[type="submit"] {
        padding: 18px 16px 8px 16px;
    }
}



.formError .formErrorContent {
    font-size: 1.3rem;
    position: relative;
    width: 100%;
    padding: 4px 10px;
    color: #fff;
    background: #8e001b;
}

/*====================================

    checkboxList

====================================*/
.checkboxList {
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    -js-display: flex;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.checkboxList>li {
    margin-bottom: 5px;
    width: 50%;
}

.checkboxList>li.full {
    width: 100%;
}

.checkboxList>li:last-child {
    margin-bottom: 0;
}

.checkboxList>li.flex {
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-bottom: 16px;
}

@media screen and (max-width: 980px) {
    .checkboxList>li {
        width: 100%;
        height: auto;
    }

    .checkboxList>li.flex {
        margin-bottom: 16px;
    }

    .checkboxList>li.flex .formItem {
        padding-top: 0;
        border: none;
        width: 100%;
        padding-left: 0;
    }
}

/* =====================
  checkbox
===================== */
.cbA input[type="checkbox"] {
    display: none;
}

.cbA label {
    margin-right: 20px;
    display: inline-block;
    margin-bottom: 10px;
    cursor: pointer;
}

.cbA-input,
.radio-input {
    display: none;
}

.cbA-input:checked+.cbA-parts {
    color: #1d2c5b;
}

.cbA-parts::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 16px;
    height: 16px;
    border: 2px solid #7d7c7c;
    background: #fff;
}

.cbA-input:checked+.cbA-parts::after {
    content: "";
    display: block;
    position: absolute;
    top: 0px;
    left: 6px;
    width: 6px;
    height: 12px;
    transform: rotate(40deg);
    border-bottom: 3px solid #1d2c5b;
    border-right: 3px solid #1d2c5b;
}

.cbA-parts {
    line-height: 1;
    position: relative;
    display: inline-block;
    padding-left: 24px;
    padding-top: 1px;
    font-size: 1.6rem;
}

@media screen and (min-width: 0\0) and (min-resolution: +72dpi) {

    .cbA-parts,
    .radio-input+label {
        padding-top: 10px;
    }
}


.brackets {
    margin-left: -16px;
}

/* =====================
  btn-wrap
===================== */

.btn-wrap {
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
}

/* =====================
  btn-check
===================== */
.btn-check {
    position: relative;
    cursor: pointer;
    display: flex;
    display: -ms-flexbox;
    display: -webkit-flex;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    font-size: 3.2rem;
    border: 2px solid #98a6b5;
    background: #fff;
    font-weight: bold;
    border-radius: 8px;
    padding: 8px 56px;
    padding-left: 112px;
    -webkit-transition: all .2s ease-in-out;
    -moz-transition: all .2s ease-in-out;
    -ms-transition: all .2s ease-in-out;
    transition: all .2s ease-in-out;

}

.btn-uri {
    color: #003984;
}

.btn-kai {
    color: #13756F;
}

.btn-uri,
.btn-kai {
    margin: 0 8px;
}

.hover .btn-uri:hover {
    background: #003984;
    border: 2px solid #003984;
    color: #fff;
}

.hover .btn-kai:hover {
    background: #13756F;
    border: 2px solid #13756F;

    color: #fff;
}

.active .btn-uri {
    background: #003984;
    border: 2px solid #003984;
    color: #fff;
}

.active .btn-kai {
    background: #13756F;
    border: 2px solid #13756F;
    color: #fff;
}

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

    .btn-uri,
    .btn-kai {
        margin: 0 4px;
    }
}

/* =====================
  btn-check
===================== */
.btn-check .mark {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    position: absolute;
    top: 50%;
    left: 16px;
    transform: translate(0, -50%);
    background: #cdd6dd;
}

.btn-check.btn-uri .mark:before,
.btn-check.btn-kai .mark:before {
    content: "";
    background: url(../img/mark_check.svg);
    background-repeat: no-repeat;
    background-size: contain;
    width: 25px;
    height: 19px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.hover .btn-check.btn-uri:hover .mark:before {
    background: url(../img/mark_check_blue.svg);
}

.hover .btn-check.btn-kai:hover .mark:before {
    background: url(../img/mark_check_green.svg);
}

.active .btn-check.btn-uri .mark:before {
    background: url(../img/mark_check_blue.svg);
}

.active .btn-check.btn-kai .mark:before {
    background: url(../img/mark_check_green.svg);
}


.hover .btn-check:hover .mark {
    background: #fff;
}

.active .btn-check .mark {
    background: #fff;
}

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

    .btn-check .mark {
        width: 24px;
        height: 24px;
        left: 8px;
    }

    .btn-check {
        font-size: 1.6rem;
        padding: 8px;
        padding-left: 40px;
    }

    .btn-check.btn-uri .mark:before,
    .btn-check.btn-kai .mark:before {
        width: 12px;
        height: 9px;
    }


}




.tab-form {
    display: none;
}

.tab-form.show {
    display: block;
}



/* =====================
 text-decoration
===================== */
.marker-ylw {
    background: linear-gradient(transparent 60%, #fcf300 60%);
}