@charset "utf-8";

/*

home.css
Version: 2025.06.17

*/

/* --------------------------------------------------------
/* .page-home
/* .bgswitcher-visual（bgswitcher-visual.js）
/* .bgswitcher-conversion（bgswitcher-conversion.js）
/* .bgswitcher-switch（bgswitcher-switch.js）
/* .vide-visual（jquery.vide.ini.js）
/* .vide-movie（jquery.vide.ini.js）
/* .ytplayer-visual（jquery.mb.YTPlayer.js）
/* .top-sect
/* .top-important
/* .top-topics
/* .top-column
/* .top-trio
/* .top-grid
/* .top-about
/* .top-aboutus
/* .top-appeal
/* .top-access
/* .top-concept
/* .top-point
/* .top-picky
/* .top-worry
/* .top-job
/* .top-campaign
/* .top-business
/* .top-oshirase
/* .top-feature
/* .top-realestate
-------------------------------------------------------- */


/* .page-home
-------------------------------------------------------- */


/* .bgswitcher-visual（bgswitcher-visual.js）
-------------------------------------------------------- */
.bgswitcher-visual {
    position: relative;
    overflow: hidden;
    margin: 0;
    max-height: 840px;
    width: 100%;
    height: 550px;
    background: #1b0e0d url(../../assets/img/home/bg_bgswitcher-visual_01.jpg) no-repeat center center;
    background-size: cover;
    color: #fff;
    text-align: center;
}
/* .bgswitcher-visual > div {
    z-index: 0 !important;
} */
.bgswitcher-visual::before {
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 2;
    width: 100%;
    height: 240px;
    background: linear-gradient(0deg, #1b120f 0%, rgba(0, 0, 0, .6) 0%, rgba(0, 0, 0, 0) 100%);
    content: "";
}
.bgswitcher-visual::after {
    position: absolute;
    right: 0;
    bottom: 0;
    z-index: 3;
    padding: 10px;
    color: #fff;
    content: "© kumamoto-hp inc. All rights reserved.";
    letter-spacing: .25em;
    font-weight: 300;
    font-size: 1.3rem;
    font-family: "Cormorant Garamond", serif;
    line-height: 1.6;
}
.bgswitcher-visual-inner {
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 2;
    margin: 0;
    padding: 0;
    min-width: 320px;
    max-width: 760px;
    width: 90%;
    height: auto;
    border: 1px solid #fff;
    text-align: center;
    transform: translate(-50%, -50%);
}
.bgswitcher-visual-box {
    margin: 0 auto;
    padding: 20px 10px;
    /* background: rgba(0, 0, 0, .53); */
}
.bgswitcher-visual-box-ttl {
    margin: 0 auto 20px;
    padding: 0;
    color: #fff;
    text-shadow: 0 0 8px rgba(0, 0, 0, .2);
    letter-spacing: .01rem;
    font-weight: 400;
    font-size: 3.9rem;
    font-family: "Cormorant Garamond", serif;
    line-height: 1.16;
}
.bgswitcher-visual-box-ttl span {
    display: block;
}
.bgswitcher-visual-box-ttl .ttl-01 {
    font-size: 3.9rem;
}
.bgswitcher-visual-box-ttl .ttl-02 {
    font-size: 2.2rem;
}
.bgswitcher-visual-box-txt {
    margin: 0;
    color: #fff;
    text-shadow: 0 0 8px rgba(0, 0, 0, .2);
    font-weight: 700;
    font-size: 1.6rem;
    /* font-family: "Noto Serif JP", serif; */
    font-family: "Times New Roman", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
    line-height: 1.7;
}
.bgswitcher-visual-box-txt .ja {
    display: block;
    margin-bottom: 1em;
    color: #fff;
    text-align: center;
    text-shadow: 0 0 8px rgba(0, 0, 0, .2);
    letter-spacing: .1rem;
    font-weight: 400;
    font-size: 1.4rem;
    /* font-family: "Noto Serif JP", serif; */
    font-family: "Times New Roman", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
    line-height: 1.7;
}
.bgswitcher-visual-box-txt .en {
    display: block;
    margin-top: 1.2em;
    color: #fff;
    text-align: center;
    text-shadow: 0 0 8px rgba(0, 0, 0, .2);
    letter-spacing: .1rem;
    font-weight: 300;
    font-size: 2.0rem;
    font-family: "Mrs Saint Delafield", cursive;
    line-height: 1.2;
}
.bgswitcher-visual-box-btn {
    margin: 2.5em 0 0;
}
.bgswitcher-visual-box-btn a {
    margin: 0;
    padding: 13px 25px;
    max-width: 90%;
    width: 300px;
    border: 1px solid #fff;
    border-radius: 0;
    background-color: transparent;
    box-shadow: none;
    color: #fff;
    text-align: center;
    font-weight: 700;
    font-size: 1.6rem;
    /* font-family: "Noto Serif JP", serif; */
    font-family: "Times New Roman", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
    line-height: 27px;
}

/* .bgswitcher-visual-scroll */
.bgswitcher-visual-scroll {
    /* position: absolute;
    bottom: 30px;
    left: 50%;
    z-index: 2;
    display: inline-block; */
    text-align: center;
    /* transform: translateX(-50%); */
}
.bgswitcher-visual-scroll img {
    width: 50px;
}

/* sp（0px～768px未満の場合に適用） */
@media (min-width: 0) and (max-width: 767.98px) {
    .bgswitcher-visual {
        padding: 10% 0;
    }
    .bgswitcher-visual-box-txt {
        margin: 1em auto auto;
        max-width: 85%;
        text-align: left;
        font-size: 1.4rem;
        line-height: 1.7;
    }
}

/* tb（768px～1200px未満の場合に適用） */
@media (min-width: 768px) and (max-width: 1199.98px) {
    .bgswitcher-visual {
        padding: 2.5% 0;
        height: 730px;
    }
    .bgswitcher-visual-box {
        padding: 50px 40px;
    }
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    .bgswitcher-visual {
        padding: 2.5% 0;
        min-height: 450px;
        height: calc(100vh - 160px) !important;
    }
    .bgswitcher-visual-box {
        padding: 70px;
    }
    .bgswitcher-visual-box-ttl .ttl-01 {
        font-size: 11.0rem;
    }
    .bgswitcher-visual-box-ttl .ttl-02 {
        font-size: 3.2rem;
    }
    .bgswitcher-visual-box-txt .ja {
        font-size: 1.5rem;
    }
}


/* .bgswitcher-conversion（bgswitcher-conversion.js）
-------------------------------------------------------- */
.bgswitcher-conversion {
    position: relative;
    overflow: hidden;
    margin: 0;
    /* max-height: 840px; */
    width: 100%;
    height: auto;
    /* height: 550px; */
    background: #1b0e0d url(../../assets/img/home/bg_bgswitcher-conversion_01.jpg) no-repeat center center;
    background-size: cover;
    color: #fff;
    text-align: center;
}
/* .bgswitcher-conversion > div {
    z-index: 0 !important;
} */
/* .bgswitcher-conversion::before {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    display: block;
    overflow: hidden;
    width: 100%;
    height: 100%;
    background: rgba(0, 91, 172, .1);
    background: rgba(0, 91, 172, .1) url(../../assets/img/common/bg_overlay_24.png) repeat 0 0;
    content: "";
} */
.bgswitcher-conversion::after {
    position: absolute;
    bottom: 1em;
    left: 1em;
    z-index: 3;
    padding: .8em;
    color: #fff;
    content: "© SAGARA SIHOUSYOSI Inc. All rights reserved.";
    letter-spacing: .25em;
    font-weight: 300;
    font-size: 1.0rem;
    font-family: "Cormorant Garamond", serif;
    line-height: 1.6;
}
.bgswitcher-conversion-inner {
    position: relative;
    z-index: 2;
    display: grid;
    margin: 0 auto;
    padding: 0;
    max-width: 1920px;
    width: 100%;
    height: auto;

    grid-template-columns: 100%;
    grid-template-rows: 1fr auto auto auto;
    /* place-items: center center; */
    grid-template-areas: "item-a"
    "item-b"
    "item-c"
    "item-d";
}
.bgswitcher-conversion-inner .bgswitcher-conversion-box {
    grid-area: item-a;
}
.bgswitcher-conversion-inner .bgswitcher-conversion-txt {
    grid-area: item-b;
}
.bgswitcher-conversion-inner .bgswitcher-conversion-pr {
    grid-area: item-c;
}
.bgswitcher-conversion-inner .bgswitcher-conversion-point {
    grid-area: item-d;
}

/* .bgswitcher-conversion-box */
.bgswitcher-conversion-box {
    display: flex;
    flex-direction: column;
    margin: 0 auto;
    padding: 0;
    width: 100%;

    align-items: center;
    justify-content: flex-start;
}
.bgswitcher-conversion-box-ttl {
    margin: 0 auto 20px;
    padding: 0;
    color: rgba(255, 96, 16, 1);
    text-align: center;
    /* text-shadow: 0 0 8px rgba(0, 0, 0, .2); */
    letter-spacing: .01em;
    font-weight: 600;
    font-size: 3.8rem;
    line-height: 1.4;
}
.bgswitcher-conversion-box-ttl span {
    display: inline-block;
}
.bgswitcher-conversion-box-ttl span .very {
    display: inline;
    margin: 0 .1em;
    color: rgba(31, 150, 210, 1);
    /* background: linear-gradient(transparent 67%, #fdee21 67%, #fdee21); */
    font-size: 140%;
}
.bgswitcher-conversion-box-ttl .ttl-01 {
    margin: 0 0 0;
    padding: .2em .5em .3em;
    background: #fff;
    font-size: 1.8rem;
}
.bgswitcher-conversion-box-ttl .ttl-02 {
    margin: 0;
    padding: .2em .5em .3em;
    background: #fff;
    font-size: 1.8rem;
}
.bgswitcher-conversion-box-label {
    display: flex;
    margin: 0 0 2.2em;

    flex-flow: row wrap;
    align-items: center;
    justify-content: center;
}
.bgswitcher-conversion-box-label li {
    margin-right: .5em;
    margin-bottom: .5em;
    padding: .1em .5em;
    /* text-shadow: 0 0 2px rgba(0, 0, 0, .2); */
    border-radius: 4px;
    background-color: rgba(255, 96, 16, 1);
    color: #fff;
    letter-spacing: .1em;
    font-weight: 600;
    font-size: 1.0rem;
}
.bgswitcher-conversion-box-label li:last-child {
    margin-right: 0;
}
.bgswitcher-conversion-box-btn {
    margin: 2.5em 0 0;
}
.bgswitcher-conversion-box-btn a {
    margin: 0;
    padding: 13px 25px;
    max-width: 90%;
    width: 300px;
    border: 1px solid #fff;
    border-radius: 0;
    background-color: transparent;
    box-shadow: none;
    color: #fff;
    text-align: center;
    font-weight: 700;
    font-size: 1.6rem;
    /* font-family: "Noto Serif JP", serif; */
    /* font-family: "Times New Roman", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif; */
    line-height: 27px;
}

/* .bgswitcher-conversion-txt */
.bgswitcher-conversion-txt {
    margin: 0;
    color: #020202;
    text-align: center;
    font-weight: 700;
    /* text-shadow: 0 0 8px rgba(0, 0, 0, .2); */
    font-size: 1.6rem;
    /* font-family: "Noto Serif JP", serif; */
    /* font-family: "Times New Roman", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif; */
    line-height: 1.7;
}
.bgswitcher-conversion-txt .ja {
    display: block;
    margin-bottom: 1em;
    color: #020202;
    /* text-shadow: 0 0 8px rgba(0, 0, 0, .2); */
    letter-spacing: .1rem;
    font-weight: 700;
    font-size: 1.1rem;
    /* font-family: "Noto Serif JP", serif; */
    /* font-family: "Times New Roman", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif; */
    line-height: 2.0;
}
.bgswitcher-conversion-txt .en {
    display: block;
    margin-top: 1.2em;
    color: #020202;
    /* text-shadow: 0 0 8px rgba(0, 0, 0, .2); */
    letter-spacing: .1rem;
    font-weight: 700;
    font-size: 2.0rem;
    /* font-family: "Mrs Saint Delafield", cursive; */
    line-height: 1.2;
}

/* .bgswitcher-conversion-pr */
.bgswitcher-conversion-pr {
    display: flex;
    overflow-y: hidden;
    padding: 20px 0 0 0;
    width: 100%;
    height: 100%;

    align-items: center;
    justify-content: center;
}
.bgswitcher-conversion-pr a {
    background: #fff;
    box-shadow: 0 4px 5px rgba(0, 0, 0, .05);
}
.bgswitcher-conversion-pr a img {
    position: relative;
    bottom: 0;
    width: 100%;
    height: auto;
    border: 5px solid #fff;
}

/* .bgswitcher-conversion-point */
.bgswitcher-conversion-point {
    display: flex;
    margin-top: 1.4em;
    width: 100%;

    align-items: center;
    justify-content: center;
}
.bgswitcher-conversion-point li {
    position: relative;
    margin: 2%;
    width: 16rem;
    /* border: 1px dashed #fff; */
    border-radius: 50%;
    font-weight: 500;
}
.bgswitcher-conversion-point li .circle {
    position: relative;
    display: inline-block;
    overflow: hidden;
    padding-top: 100%;
    width: 100%;
    border-radius: 50%;
    background: rgba(205, 22, 44, 1);
    box-shadow: 0 4px 5px rgba(0, 0, 0, .05);
    vertical-align: top;
    text-align: center;
    line-height: 1.4;
}
.bgswitcher-conversion-point li .circle .txt {
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 2;
    width: 90%;
    color: #fff;
    text-align: center;
    text-shadow: 0 0 21px rgba(0, 0, 0, .24);
    font-size: 1.5rem;
    line-height: 1.2;
    transform: translate(-50%, -50%);
}
.bgswitcher-conversion-point li .no {
    position: absolute;
    top: -1px;
    left: 50%;
    z-index: 3;
    display: flex;
    padding: .5em .4em;
    width: 90%;
    border-radius: 12px;
    background-color: rgba(255, 255, 255, 1);
    color: rgba(205, 22, 44, 1);
    text-align: center;
    text-transform: uppercase;
    font-weight: 700;
    font-size: 1.0rem;
    line-height: 1.4;
    transform: translateX(-50%);

    flex-flow: row wrap;
    align-items: center;
    justify-content: center;
}

/* .bgswitcher-conversion-scroll */
.bgswitcher-conversion-scroll {
    position: absolute;
    bottom: 30px;
    left: 50%;
    z-index: 3;
    display: inline-block;
    width: 100%;
    text-align: center;
    transform: translateX(-50%);
}
.bgswitcher-conversion-scroll img {
    width: 50px;
}

/* sp（0px～768px未満の場合に適用） */
@media (min-width: 0) and (max-width: 767.98px) {
    .bgswitcher-conversion {
        padding: 10% 2.5% 18% 2.5%;
    }
    .bgswitcher-conversion-txt {
        margin: 1em auto auto;
        /* max-width: 85%; */
        text-align: left;
        font-size: 1.4rem;
        line-height: 1.7;
    }
    .bgswitcher-conversion-point li .no {
        display: none;
    }
}

/* tb（768px～1200px未満の場合に適用） */
@media (min-width: 768px) and (max-width: 1199.98px) {
    .bgswitcher-conversion {
        padding: 10% 2.5% 18% 2.5%;
    }
    .bgswitcher-conversion-box {
        padding: 20px 20px;
    }
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    .bgswitcher-conversion {
        display: grid;
        padding: 0 5%;
        min-height: 760px;
        height: calc(100vh - 160px) !important;

        place-items: center;
    }
    .bgswitcher-conversion::after {
        font-size: 1.3rem;
    }
    .bgswitcher-conversion-inner {
        display: grid;
        height: auto;

        grid-template-columns: repeat(3, 1fr);
        grid-template-rows: 1fr auto auto;
        grid-template-areas: "item-a item-a item-a"
        "item-b item-b item-c"
        "item-d item-d item-c";
    }
    .bgswitcher-conversion-box {
        align-items: flex-start;
    }
    .bgswitcher-conversion-box-ttl {
        margin: 0 auto 1em;
        text-align: left;
        line-height: 1.16;
    }
    .bgswitcher-conversion-box-ttl .ttl-01 {
        margin: 0 0 .6em;
        font-size: 5.2rem;
    }
    .bgswitcher-conversion-box-ttl .ttl-02 {
        font-size: 5.2rem;
    }
    .bgswitcher-conversion-box-label {
        justify-content: flex-start;
        align-items: flex-start;
    }
    .bgswitcher-conversion-box-label li {
        margin-right: .8em;
        margin-bottom: .8em;
        padding: .1em 1em;
        font-size: 1.9rem;
    }
    .bgswitcher-conversion-txt {
        text-align: left;
    }
    .bgswitcher-conversion-txt .ja {
        margin-right: 1em;
        font-size: 1.5rem;
    }
    .bgswitcher-conversion-pr {
        justify-content: flex-end;
        align-items: flex-end;
    }
    .bgswitcher-conversion-pr a img {
        width: 364px;
    }
    .bgswitcher-conversion-point {
        justify-content: flex-start;
    }
    .bgswitcher-conversion-point li {
        margin: 1% 1%;
        width: 170px;
    }
    .bgswitcher-conversion-point li .circle .txt {
        font-size: 3.0rem;
    }
    .bgswitcher-conversion-point li .no {
        display: block;
        max-width: 150px;
        font-size: 1.3rem;
    }
}


/* .bgswitcher-switch（bgswitcher-switch.js）
-------------------------------------------------------- */
.bgswitcher-switch {
    position: relative;
    overflow: hidden;
    margin: 0;
    /* max-height: 840px; */
    width: 100%;
    height: auto;
    /* height: 550px; */
    background: #fff url(../../assets/img/home/bg_bgswitcher-switch_01.jpg) no-repeat top right;
    background-size: cover;
    color: #fff;
    text-align: center;
}
.bgswitcher-switch > div {
    z-index: 0 !important;
}
.bgswitcher-switch::before {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
    display: block;
    overflow: hidden;
    width: 100%;
    height: 100%;
    background: rgba(1, 92, 172, .7);
    /* background: rgba(1, 92, 172, .7) url(../../assets/img/common/bg_overlay_24.png) repeat 0 0; */
    content: "";
}
.bgswitcher-switch::after {
    position: absolute;
    bottom: 1em;
    left: 1em;
    z-index: 3;
    padding: .8em;
    color: #fff;
    content: "© SAGARA SIHOUSYOSI Inc. All rights reserved.";
    letter-spacing: .25em;
    font-weight: 300;
    font-size: 1.0rem;
    font-family: "Cormorant Garamond", serif;
    line-height: 1.6;
}
.bgswitcher-switch-inner {
    position: relative;
    z-index: 2;
    display: grid;
    margin: 0 auto;
    padding: 0;
    max-width: 1920px;
    width: 100%;
    height: auto;

    grid-template-columns: 100%;
    grid-template-rows: 1fr auto auto auto;
    /* place-items: center center; */
    grid-template-areas: "item-a"
    "item-b"
    "item-c"
    "item-d";
}
.bgswitcher-switch-inner .bgswitcher-switch-box {
    grid-area: item-a;
}
.bgswitcher-switch-inner .bgswitcher-switch-txt {
    grid-area: item-b;
}
.bgswitcher-switch-inner .bgswitcher-switch-pr {
    grid-area: item-c;
}
.bgswitcher-switch-inner .bgswitcher-switch-point {
    grid-area: item-d;
}

/* .bgswitcher-switch-box */
.bgswitcher-switch-box {
    display: flex;
    flex-direction: column;
    margin: 0 auto;
    padding: 0;
    width: 100%;

    align-items: center;
    justify-content: flex-start;
}
.bgswitcher-switch-box-ttl {
    display: flex;
    margin: 0 auto 20px;
    padding: 0;
    color: rgba(10, 10, 10, 1);
    text-align: center;
    letter-spacing: .02em;
    /* font-weight: 600;
    font-size: 3.8rem;
    line-height: 1.4; */

    flex-flow: column;
    justify-content: center;
    align-items: center;
}
.bgswitcher-switch-box-ttl span {
    display: inline-block;
}
.bgswitcher-switch-box-ttl span .very {
    display: inline;
    margin: 0 .1em;
    color: rgba(255, 96, 16, 1);
    font-weight: 800;
    /* background: linear-gradient(transparent 67%, #fdee21 67%, #fdee21); */
    font-size: 137%;
}
.bgswitcher-switch-box-ttl .ttl-01 {
    margin: 0 0 .6em;
    padding: .08em .2em .2em .2em;
    border-radius: 6px;
    background: rgba(255, 255, 255, 1);
    font-size: 1.8rem;
}
.bgswitcher-switch-box-ttl .ttl-02 {
    margin: 0;
    padding: .08em .2em .2em .2em;
    border-radius: 6px;
    background: rgba(255, 255, 255, 1);
    font-size: 1.8rem;
}
/* .bgswitcher-switch-box-ttl .ttl-01 .marker,
.bgswitcher-switch-box-ttl .ttl-02 .marker {
    padding: 0 .2em 0 0;
    background: linear-gradient(transparent 58%, #fdee21 58%, #fdee21);
    font-weight: 800;
} */
.bgswitcher-switch-box-label {
    display: flex;
    margin: 0 0 1.2em;

    flex-flow: row wrap;
    align-items: center;
    justify-content: center;
}
.bgswitcher-switch-box-label li {
    margin-right: .5em;
    margin-bottom: .5em;
    padding: .1em .5em;
    /* text-shadow: 0 0 2px rgba(0, 0, 0, .2); */
    border-radius: 4px;
    background-color: rgba(1, 92, 172, 1);
    color: #fff;
    letter-spacing: .12em;
    font-weight: 600;
    font-size: 1.0rem;
    line-height: 1.8;
}
.bgswitcher-switch-box-label li:last-child {
    margin-right: 0;
}
.bgswitcher-switch-box-btn {
    margin: 2.5em 0 0;
}
.bgswitcher-switch-box-btn a {
    margin: 0;
    padding: 13px 25px;
    max-width: 90%;
    width: 300px;
    border: 1px solid #fff;
    border-radius: 0;
    background-color: transparent;
    box-shadow: none;
    color: #fff;
    text-align: center;
    font-weight: 700;
    font-size: 1.6rem;
    /* font-family: "Noto Serif JP", serif; */
    /* font-family: "Times New Roman", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif; */
    line-height: 27px;
}

/* .bgswitcher-switch-txt */
.bgswitcher-switch-txt {
    margin: 0;
    color: #fff;
    text-align: center;
    font-weight: 700;
    /* text-shadow: 0 0 8px rgba(0, 0, 0, .2); */
    font-size: 1.6rem;
    /* font-family: "Noto Serif JP", serif; */
    /* font-family: "Times New Roman", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif; */
    line-height: 1.7;
}
.bgswitcher-switch-txt .ja {
    display: block;
    margin-bottom: 1em;
    color: #fff;
    /* text-shadow: 0 0 8px rgba(0, 0, 0, .2); */
    letter-spacing: .1rem;
    font-weight: 700;
    font-size: 1.1rem;
    /* font-family: "Noto Serif JP", serif; */
    /* font-family: "Times New Roman", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif; */
    line-height: 2.0;
}
.bgswitcher-switch-txt .en {
    display: block;
    margin-top: 1.2em;
    color: #fff;
    /* text-shadow: 0 0 8px rgba(0, 0, 0, .2); */
    letter-spacing: .1rem;
    font-weight: 700;
    font-size: 2.0rem;
    /* font-family: "Mrs Saint Delafield", cursive; */
    line-height: 1.2;
}

/* .bgswitcher-switch-pr */
.bgswitcher-switch-pr {
    display: flex;
    overflow-y: hidden;
    padding: 20px 0 0 0;
    width: 100%;
    height: 100%;

    align-items: center;
    justify-content: center;
}
.bgswitcher-switch-pr a {
    background: #fff;
    box-shadow: 0 4px 5px rgba(0, 0, 0, .05);
}
.bgswitcher-switch-pr a img {
    position: relative;
    bottom: 0;
    width: 100%;
    height: auto;
    border: 5px solid #fff;
}

/* .bgswitcher-switch-point */
.bgswitcher-switch-point {
    display: flex;
    margin-top: .4em;
    width: 100%;

    align-items: center;
    justify-content: center;
}
.bgswitcher-switch-point li {
    position: relative;
    margin: 2%;
    width: 16rem;
    /* border: 1px dashed #fff; */
    border-radius: 50%;
    font-weight: 500;
}
.bgswitcher-switch-point li .circle {
    position: relative;
    display: inline-block;
    /* overflow: hidden; */
    padding-top: 100%;
    width: 100%;
    border-radius: 50%;
    background: rgba(205, 22, 44, 1);
    box-shadow: 0 4px 5px rgba(0, 0, 0, .05);
    vertical-align: top;
    text-align: center;
    line-height: 1.4;
}
.bgswitcher-switch-point li .circle .txt {
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 2;
    width: 90%;
    color: #fff;
    text-align: center;
    text-shadow: 0 0 21px rgba(0, 0, 0, .24);
    letter-spacing: .08em;
    font-weight: 600;
    font-size: 1.5rem;
    line-height: 1.3;
    transform: translate(-50%, -50%);
}
.bgswitcher-switch-point li .no {
    position: absolute;
    top: -1px;
    left: 50%;
    z-index: 3;
    display: flex;
    padding: .5em .4em;
    width: 90%;
    border-radius: 12px;
    background-color: rgba(255, 255, 255, 1);
    color: rgba(205, 22, 44, 1);
    text-align: center;
    text-transform: uppercase;
    font-weight: 900;
    font-size: 1.0rem;
    line-height: 1.4;
    transform: translateX(-50%);

    flex-flow: row wrap;
    align-items: center;
    justify-content: center;
}

/* .bgswitcher-switch-scroll */
.bgswitcher-switch-scroll {
    position: absolute;
    bottom: 30px;
    left: 50%;
    z-index: 3;
    display: inline-block;
    width: 100%;
    text-align: center;
    transform: translateX(-50%);
}
.bgswitcher-switch-scroll img {
    width: 50px;
}

/* sp（0px～768px未満の場合に適用） */
@media (min-width: 0) and (max-width: 767.98px) {
    .bgswitcher-switch {
        padding: 10% 2.5% 18% 2.5%;
    }
    .bgswitcher-switch-txt {
        margin: 0 auto auto;
        /* max-width: 85%; */
        text-align: left;
        font-size: 1.4rem;
        line-height: 1.7;
    }
    .bgswitcher-switch-point li .no {
        display: none;
    }
}

/* tb（768px～1200px未満の場合に適用） */
@media (min-width: 768px) and (max-width: 1199.98px) {
    .bgswitcher-switch {
        padding: 10% 2.5% 18% 2.5%;
    }
    .bgswitcher-switch-box {
        padding: 20px 20px;
    }
    .bgswitcher-switch-box-ttl .ttl-01 {
        margin: 0 0 .3em;
        font-size: 3.2rem;
    }
    .bgswitcher-switch-box-ttl .ttl-02 {
        font-size: 3.2rem;
    }
    .bgswitcher-switch-point li .circle .txt {
        font-size: 2.2rem;
    }
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    .bgswitcher-switch {
        display: grid;
        padding: 0 5.2%;
        min-height: 760px;
        height: calc(100vh - 160px) !important;

        place-items: center;
    }
    .bgswitcher-switch::before {
        position: absolute;
        top: -50%;
        left: -68%;
        width: 100%;
        height: 200%;
        /* background: linear-gradient(90deg, rgba(239, 241, 239, .92) 0%, rgba(239, 241, 239, .72) 70%, rgba(239, 241, 239, 0) 100%); */
        background: rgba(255, 255, 255, 0);
        content: "";
        transform: rotate(90deg);
    }
    /* .bgswitcher-switch::before {
        background: rgba(1, 92, 172, .25);
        content: none;
    } */
    .bgswitcher-switch::after {
        font-size: 1.3rem;
    }
    .bgswitcher-switch-inner {
        display: grid;
        height: auto;

        grid-template-columns: repeat(3, 1fr);
        grid-template-rows: 1fr auto auto;
        grid-template-areas: "item-a item-a item-a"
        "item-b item-b item-c"
        "item-d item-d item-c";
    }
    .bgswitcher-switch-box {
        align-items: flex-start;
    }
    .bgswitcher-switch-box-ttl {
        margin: 0 0 .6em;
        text-align: left;
        /* text-shadow: .07em .07em 0 rgba(255, 255, 255, 0), .11em .11em 0 rgba(0, 0, 0, .09); */
        line-height: 1.2;

        flex-flow: column;
        justify-content: center;
        align-items: flex-start;
    }
    .bgswitcher-switch-box-ttl .ttl-01,
    .bgswitcher-switch-box-ttl .ttl-02 {
        position: relative;
        border-radius: 0;
    }
    .bgswitcher-switch-box-ttl .ttl-01 {
        margin: 0 0 .15em;
        padding: .2em .3em .3em .3em;
        background: rgba(255, 255, 255, 1);
        letter-spacing: .06em;
        font-size: 3.8rem;
    }
    .bgswitcher-switch-box-ttl .ttl-02 {
        padding: .2em .3em .3em .3em;
        background: rgba(255, 255, 255, 1);
        letter-spacing: .06em;
        font-size: 3.8rem;
    }
    /* .bgswitcher-switch-box-ttl .ttl-01::after,
    .bgswitcher-switch-box-ttl .ttl-02::after {
        position: absolute;
        right: -14px;
        bottom: -14px;
        z-index: -2;
        width: 100%;
        height: 100%;
        border-radius: 10px;
        background: rgba(0, 0, 0, .05);
        content: "";
    } */
    .bgswitcher-switch-box-label {
        justify-content: flex-start;
        align-items: flex-start;
    }
    .bgswitcher-switch-box-label li {
        margin-right: .8em;
        margin-bottom: .8em;
        padding: 0 .6em;
        font-size: 2.0rem;
    }
    .bgswitcher-switch-txt {
        color: #020202;
        text-align: left;
    }
    .bgswitcher-switch-txt .ja {
        margin-right: 1em;
        color: #020202;
        text-shadow: 0 0 5px rgba(255, 255, 255, 1), 0 0 8px rgba(255, 255, 255, 1);
        font-size: 1.5rem;
    }
    .bgswitcher-switch-txt .en {
        color: #020202;
        text-shadow: 0 0 5px rgba(255, 255, 255, 1), 0 0 8px rgba(255, 255, 255, 1);
    }
    .bgswitcher-switch-pr {
        justify-content: flex-end;
        align-items: flex-end;
    }
    .bgswitcher-switch-pr a img {
        width: 422px;
    }
    .bgswitcher-switch-point {
        justify-content: flex-start;
    }
    .bgswitcher-switch-point li {
        margin: 1% 1%;
        width: 154px;
    }
    .bgswitcher-switch-point li .circle .txt {
        font-size: 2.3rem;
    }
    .bgswitcher-switch-point li .no {
        display: block;
        max-width: 150px;
        font-size: 1.4rem;
    }
}

/* pc（1400px以上の場合に適用） */
@media (min-width: 1400px) {
    .bgswitcher-switch-box-ttl .ttl-01 {
        margin: 0 0 .15em;
        font-size: 4.0rem;
    }
    .bgswitcher-switch-box-ttl .ttl-02 {
        font-size: 4.0rem;
    }
    .bgswitcher-switch-box-ttl span .very {
        font-size: 120%;
    }
}

/* pc（1600px以上の場合に適用） */
@media (min-width: 1600px) {
    .bgswitcher-switch-box-ttl .ttl-01 {
        margin: 0 0 .15em;
        font-size: 4.6rem;
    }
    .bgswitcher-switch-box-ttl .ttl-02 {
        font-size: 4.6rem;
    }
    .bgswitcher-switch-box-ttl span .very {
        font-size: 120%;
    }
}


/* .vide-visual（jquery.vide.ini.js）
-------------------------------------------------------- */
.vide-visual {
    position: relative;
    overflow: hidden;
    margin: 0 auto;
    padding: 0;
    width: 100%;
    height: 600px;
}
.vide-visual > div {
    z-index: 0 !important;
}
.vide-visual > div video {
    max-width: none;
}
.vide-visual-inner {
    position: relative;
    z-index: 0;
    margin: 0 auto;
    padding: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 1);
    /* background-position: top center;
    background-size: cover;
    background-repeat: no-repeat; */
}
.vide-visual-inner::before {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    display: block;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0) url(../../assets/img/common/bg_overlay_04.png) repeat 0 0;
    content: "";
    pointer-events: none; /* iPhone低電力モード対策 */
}

/* vide-visual-catch */
.vide-visual-catch {
    position: absolute;
    top: 0;
    left: 50%;
    z-index: 2;
    display: flex;
    flex-direction: column;
    margin: 0;
    padding: 0;
    width: 100%;
    height: 100%;
    transform: translateX(-50%);

    justify-content: center;
}
.vide-visual-catch-img {
    margin: 0 auto 40px;
    text-align: center;
}
.vide-visual-catch-img img {
    width: 320px;
}
.vide-visual-catch-ttl {
    margin: 0;
    padding: 14px;
    color: #fff;
    text-align: center;
    text-shadow: 1px 1px 1px rgba(0, 0, 0, .2);
    letter-spacing: .2em;
    font-weight: 700;
    font-size: 2.8rem;
    line-height: 1.5;
}
.vide-visual-catch-txt {
    margin: 0;
    padding: 14px;
    color: #fff;
    text-align: center;
    text-shadow: 1px 1px 1px rgba(0, 0, 0, .2);
    font-weight: 700;
    font-size: 1.6rem;
    line-height: 2.0;
}

/* .vide-visual-scroll */
.vide-visual-scroll {
    position: absolute;
    bottom: 30px;
    left: 50%;
    z-index: 2;
    display: inline-block;
    padding-top: 50px;
    color: #fff;
    letter-spacing: .1em;
    font-size: 1.2rem;
    font-family: "Noto Sans JP", sans-serif;
    transition: opacity .3s;
    transform: translateX(-50%);
}
.vide-visual-scroll:hover {
    color: #fff;
    text-decoration: none;
}
.vide-visual-scroll span {
    position: absolute;
    top: 0;
    left: 50%;
    margin-left: -12px;
    width: 24px;
    height: 24px;
    border-bottom: 1px solid #fff;
    border-left: 1px solid #fff;
    transform: rotate(-45deg);
    animation: vide-visual-scroll 1.5s infinite;
}
@keyframes vide-visual-scroll {
    0% {
        transform: rotate(-45deg) translate(0, 0);
    }
    20% {
        transform: rotate(-45deg) translate(-10px, 10px);
    }
    40% {
        transform: rotate(-45deg) translate(0, 0);
    }
}

/* sp（0px～768px未満の場合に適用） */
@media (min-width: 0) and (max-width: 767.98px) {
    /* vide-visual */
    .vide-visual {
        height: 600px;
    }
}

/* tb（768px～1200px未満の場合に適用） */
@media (min-width: 768px) and (max-width: 1199.98px) {
    /* vide-visual */
    .vide-visual {
        height: 600px;
    }
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    /* vide-visual */
    .vide-visual {
        min-width: 1120px;
        min-height: 450px;
        height: calc(100vh - 0px) !important;
    }
    /* vide-visual-catch */
    .vide-visual-catch-ttl {
        padding: 14px;
        font-size: 6.0rem;
    }
    /* #vide-visual-scroll */
    #vide-visual-scroll {
        margin-top: -94px;
        padding-top: 94px;
    }
}


/* .vide-movie（jquery.vide.ini.js）
-------------------------------------------------------- */
.vide-movie {
    position: relative;
    overflow: hidden;
    margin: 0 auto;
    padding: 0;
    width: 100%;
    height: 600px;
}
.vide-movie > div {
    z-index: 0 !important;
}
.vide-movie > div video {
    max-width: none;
}
.vide-movie-inner {
    position: relative;
    z-index: 0;
    margin: 0 auto;
    padding: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 1);
    /* background-position: top center;
    background-size: cover;
    background-repeat: no-repeat; */
}
.vide-movie-inner::before {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    display: block;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0) url(../../assets/img/common/bg_overlay_04.png) repeat 0 0;
    content: "";
    pointer-events: none; /* iPhone低電力モード対策 */
}

/* .vide-movie-area */
.vide-movie-area {
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 2;
    display: flex;
    flex-direction: column;
    margin: 0;
    padding: 0 14px;
    width: 100%;
    height: auto;
    transform: translate(-50%, -50%);

    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
}

/* .vide-movie-area-catch */
.vide-movie-area-catch {
    margin-bottom: 60px;
}
.vide-movie-area-catch .ttl {
    color: #fff;
    text-align: center;
    text-shadow: 0 0 10px rgba(0, 0, 0, .3);
    letter-spacing: .05em;
    font-size: 3.6rem;
    font-family: "Noto Sans JP", sans-serif;
    line-height: 1.4;
}
.vide-movie-area-catch .ttl span {
    display: block;
}
.vide-movie-area-catch .txt {
    margin-top: 40px;
    color: #fff;
    text-align: center;
    letter-spacing: .05em;
    font-size: 1.5rem;
    /* font-family: "Noto Sans JP", sans-serif; */
    font-family: "Times New Roman", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}

/* .vide-movie-area-bnr */
.vide-movie-area-bnr {
    position: relative;
    overflow: hidden;
    max-width: 403px;
    height: 124px;
}
.vide-movie-area-bnr a {
    text-decoration: none;
    transition: all .12s ease-in 0s;
}
.vide-movie-area-bnr a:hover {
    opacity: 1;
}
.vide-movie-area-bnr .img {
    position: relative;
    display: block;
    overflow: hidden;
    max-width: 403px;
    width: 100%;
    height: auto;
}
.vide-movie-area-bnr .img::after {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 3;
    display: block;
    width: 100%;
    height: 100%;
    background: linear-gradient(rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 40%, black 100%);
    content: "";
    opacity: .45;
    transition: all .5s ease-in 0s;
}
.vide-movie-area-bnr:hover .img::after {
    background: linear-gradient(rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 40%, black 100%);
    opacity: .65;
}
.vide-movie-area-bnr .box {
    position: absolute;
    bottom: 20px;
    left: 20px;
    z-index: 4;
}
.vide-movie-area-bnr .box-ttl {
    padding-bottom: 2px;
    color: #fff;
    font-weight: 700;
    font-size: 2.4rem;
    font-family: "Noto Sans JP", sans-serif;
    line-height: 120%;
}
.vide-movie-area-bnr .box-txt {
    color: #fff;
    letter-spacing: 1px;
    font-weight: 700;
    font-size: 1.2rem;
    line-height: 120%;
}
.vide-movie-area-bnr .btn {
    position: absolute;
    right: 65px;
    bottom: 60px;
    z-index: 4;
}
.vide-movie-area-bnr .btn .btn-inner {
    position: absolute;
    z-index: 1;
    display: block;
    width: 36px;
    height: 36px;
    border: 1px solid #fff;
    border-radius: 50%;
    transition: all .12s ease-in 0s;
}
.vide-movie-area-bnr:hover .btn .btn-inner {
    border: 1px solid #8fc31f;
    background-color: #8fc31f;
}
.vide-movie-area-bnr .btn .btn-inner::before {
    position: absolute;
    top: 15px;
    left: 15px;
    z-index: 2;
    display: block;
    margin: auto;
    width: 4px;
    height: 4px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    content: "";
    transition: all .12s ease-in 0s;
    transform: rotate(45deg);
}

/* .vide-movie-scroll */
.vide-movie-scroll {
    position: absolute;
    bottom: 30px;
    left: 50%;
    z-index: 2;
    display: inline-block;
    text-align: center;
    transform: translateX(-50%);
}
.vide-movie-scroll .scrolldown {
    margin: auto;
}
.vide-movie-scroll .scrolldown-img {
    width: 6px;
    height: 41px;
    animation: vide-movie-scroll 2s infinite;
}
@keyframes vide-movie-scroll {
    0% {
        opacity: 0;
        transform: translate(0, 0);
    }
    40% {
        opacity: 1;
    }
    80% {
        opacity: 0;
        transform: translate(0, 20px);
    }
    100% {
        opacity: 0;
    }
}
.vide-movie-scroll .scrolldown-txt {
    display: block;
    margin-top: 25px;
    color: #fff;
    font-size: 1.1rem;
    font-family: "Noto Sans JP", sans-serif;
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    .vide-movie {
        height: 810px;
    }
    .vide-movie-area {
        top: auto;
        bottom: 80px;
        flex-direction: row;
        padding: 0 60px;
        max-width: 1840px;
        width: 100%;
        transform: translate(-50%, 0);

        justify-content: space-between;
        align-items: flex-end;
    }

    /* .vide-movie-area.area-catch */
    .vide-movie-area-catch {
        margin-bottom: 100px;
    }
    .vide-movie-area-catch .ttl {
        text-align: left;
        font-size: 6.8rem;
    }
    .vide-movie-area-catch .txt {
        margin-top: 20px;
        text-align: left;
    }

    /* .vide-movie-area-bnr */
    .vide-movie-area-bnr {
        width: 403px;
        height: 201px;
    }
    .vide-movie-area-bnr .img img {
        transition: all 2.4s ease-in 0s;
    }
    .vide-movie-area-bnr:hover .img img {
        transform: scale(1.1);
    }
}


/* .ytplayer-visual（jquery.mb.YTPlayer.js）
-------------------------------------------------------- */
.ytplayer-visual {
    position: relative;
    overflow: hidden;
    margin: 0 auto;
    padding: 0;
    width: 100%;
    height: 600px;
}
.ytplayer-visual > div {
    z-index: 0 !important;
}
.ytplayer-visual-inner {
    position: relative;
    z-index: 0;
    margin: 0 auto;
    padding: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 1);
    /* background-position: top center;
    background-size: cover;
    background-repeat: no-repeat; */
}
.ytplayer-visual-inner::before {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    display: block;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, .2) url(../../assets/img/common/bg_overlay_20.png) repeat 0 0;
    content: "";
    pointer-events: none; /* iPhone低電力モード対策 */
}

/* .ytplayer-visual-area */
.ytplayer-visual-area {
    position: relative; /* 設定必須 */
    overflow: hidden;
    width: 100%; /* 設定必須 */
    height: 100%; /* 設定必須 */
}
.ytplayer-loading {
    position: absolute;
    top: 0;
    left: 0;
    display: flex;
    width: 100%;
    height: 100%;
    background: #333;
    color: #fff;
    font-size: 1.4rem;
    transition: all 1s ease;

    align-items: center;
    justify-content: center;
}

/* ytplayer-visual-catch */
.ytplayer-visual-catch {
    position: absolute;
    top: 0;
    left: 50%;
    z-index: 2;
    display: flex;
    flex-direction: column;
    margin: 0;
    padding: 0;
    width: 100%;
    height: 100%;
    transform: translateX(-50%);

    justify-content: center;
}
.ytplayer-visual-catch-ttl {
    margin: 0;
    padding: 14px;
    color: #fff;
    text-align: center;
    /* text-shadow: 1px 1px 1px rgba(0, 0, 0, .5); */
    font-weight: 700;
    font-size: 2.8rem;
    line-height: 1.5;
}
.ytplayer-visual-catch-txt {
    margin: 0;
    padding: 14px;
    color: #fff;
    text-align: center;
    /* text-shadow: 1px 1px 1px rgba(0, 0, 0, .5); */
    font-weight: 700;
    font-size: 1.8rem;
    line-height: 2.0;
}

/* .ytplayer-visual-scroll */
.ytplayer-visual-scroll img {
    width: 56px;
}

/* sp（0px～768px未満の場合に適用） */
@media (min-width: 0) and (max-width: 767.98px) {
    /* ytplayer-visual */
    .ytplayer-visual {
        height: 600px;
    }
}

/* tb（768px～1200px未満の場合に適用） */
@media (min-width: 768px) and (max-width: 1199.98px) {
    /* ytplayer-visual */
    .ytplayer-visual {
        height: 600px;
    }
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    /* ytplayer-visual */
    .ytplayer-visual {
        min-width: 1120px;
        min-height: 450px;
        height: calc(100vh - 160px) !important;
    }
    /* ytplayer-visual-catch */
    .ytplayer-visual-catch-ttl {
        padding: 14px;
        font-size: 8.8rem;
    }
    /* ytplayer-visual-scroll */
    .ytplayer-visual-scroll {
        position: absolute;
        bottom: 10%;
        z-index: 2;
        width: 100%;
        height: 39px;
        text-align: center;
    }
    .ytplayer-visual-scroll a:link,
    .ytplayer-visual-scroll a:visited {
        transition: opacity .3s ease-out;
    }
    .ytplayer-visual-scroll a:hover,
    .ytplayer-visual-scroll a:active {
        opacity: .6;
    }
    /* #ytplayer-visual-scroll */
    #ytplayer-visual-scroll {
        margin-top: -94px;
        padding-top: 94px;
    }
}


/* .top-sect
-------------------------------------------------------- */
.top-sect {
    position: relative;
    width: 100%;
}
.top-sect > div,
.top-sect > ul,
.top-sect > ol {
    z-index: 0 !important;
}
.top-sect-01,
.top-sect-02,
.top-sect-03,
.top-sect-04,
.top-sect-05,
.top-sect-06,
.top-sect-07,
.top-sect-08,
.top-sect-09,
.top-sect-10,
.top-sect-11,
.top-sect-12,
.top-sect-13,
.top-sect-14,
.top-sect-15,
.top-sect-16,
.top-sect-17,
.top-sect-18,
.top-sect-19,
.top-sect-20 {
    padding: 0;
}
.top-sect-01 {
    padding: 0;
}
.top-sect-02 {
    padding: 0;
    background: #fff url(../../assets/img/common/bg_ptn_47.png) repeat 0 0;
}
.top-sect-03 {
    padding: 60px 0 20px;
    background: #fff url(../../assets/img/common/bg_top-sect-03.jpg) no-repeat top right / cover;
}
.top-sect-04 {
    padding: 60px 0 20px;
    background: #fff url(../../assets/img/common/bg_top-sect-06.jpg) no-repeat top right / cover;
}
.top-sect-05 {
    padding: 60px 0 60px;
    background: #fff5f4 url(../../assets/img/common/bg_overlay_32.png) repeat top left / auto;
}
.top-sect-06 {
    padding: 60px 0 60px;
    background: #fff url(../../assets/img/common/bg_ptn_49.png) repeat 0 0;
}
.top-sect-07 {
    padding: 0;
}
.top-sect-08 {
    position: relative;
    margin: 0 0 120px;
    padding: 100px 0 160px 0;
    /* background: #fff url(../../assets/img/common/bg_top-sect-03.jpg) no-repeat center center / cover fixed; */
    background: #fff url(../../assets/img/common/bg_top-sect-03.jpg) no-repeat center center / cover;
}
.top-sect-08::after {
    position: absolute;
    bottom: -30px;
    left: 50%;
    margin: 0 0 0 -39px;
    width: 78px;
    height: 78px;
    border: 0;
    border-top: 1px solid #b00;
    border-right: 1px solid #b00;
    content: "";
    transform: rotate(135deg);
}
.top-sect-09 {
    padding: 0;
    background: #fff url(../../assets/img/common/bg_ptn_58.png) repeat 0 0;
}
.top-sect-10 {
    padding: 100px 0 100px;
    background: #fff;
}
.top-sect-11 {
    padding: 60px 0 60px;
    background: #fff url(../../assets/img/common/bg_ptn_51.png) repeat 0 0;
}
.top-sect-12 {
    padding: 60px 0 60px;
    background: #f9f2e6;
}
.top-sect-13 {
    padding: 60px 0 60px;
    background: #fff;
}
.top-sect-14 {
    padding: 60px 0 60px;
    background: #fff url(../../assets/img/common/bg_ptn_27.png) repeat 0 0;
}
.top-sect-15 {
    padding: 60px 0 60px;
    background: #fff5f4 url(../../assets/img/common/bg_overlay_31.png) repeat top left / auto;
}
.top-sect-16 {
    padding: 110px 0 110px;
    border-top: 1px solid #ededed;
    border-bottom: 1px solid #ededed;
    background-color: rgba(255, 255, 255, 1);
}
.top-sect-17 {
    padding: 60px 0 60px;
    background-image: url(../../assets/img/common/bg_overlay_00.png), url(../../assets/img/common/bg_ptn_47.png);
    background-attachment: scroll, scroll;
    background-position: center center, left center;
    background-size: auto, auto;
    background-repeat: repeat, repeat;
}
.top-sect-18 {
    padding: 110px 0 110px;
    background-image: url(../../assets/img/common/bg_overlay_23.png), url(../../assets/img/common/bg_top-sect-11.jpg);
    background-attachment: scroll, scroll;
    background-position: center center, left center;
    background-size: auto, cover;
    background-repeat: repeat, no-repeat;
}
.top-sect-19 {
    padding: 110px 0 110px;
    background: url(../../assets/img/common/bg_top-picky.jpg) no-repeat center center;
    background-size: cover;
}
.top-sect-20 {
    padding: 110px 0 110px;
    background-color: #f9f2e6;
}

/* .top-sect-inner */
.top-sect-inner {
    margin: 0 auto;
    padding: 0 14px;
    max-width: 1640px;
    width: 100%;
}
.top-sect-06 .top-sect-inner {
    margin: 0 auto;
    padding: 14px 14px;
    max-width: 1800px;
    width: 100%;
}
.top-sect-16 .top-sect-inner {
    margin: 0 auto;
    padding: 14px 14px;
    max-width: 1820px;
    width: 100%;
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    .top-sect-inner {
        padding: 0 20px;
    }
    .top-sect-03 {
        padding: 90px 0 90px;
    }
    .top-sect-04 {
        padding: 90px 0 90px;
    }
    .top-sect-05 {
        padding: 90px 0 90px;
    }
    .top-sect-06 {
        padding: 90px 0 90px;
    }
    .top-sect-06 .top-sect-inner {
        padding: 0 20px;
    }
    .top-sect-11 {
        padding: 90px 0 90px;
    }
    .top-sect-12 {
        padding: 90px 0 90px;
    }
    .top-sect-13 {
        padding: 90px 0 90px;
    }
    .top-sect-14 .top-sect-inner {
        padding: 40px 40px;
    }
    .top-sect-15 {
        padding: 60px 0 60px;
    }
}

/* .top-sect-ttl */
.top-sect-ttl {
    position: relative;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    margin: 0 auto 30px;
    padding: 40px 0 20px;
    text-align: center;

    justify-content: center;
}
.top-sect-ttl .bg {
    position: absolute;
    top: 40%;
    left: 50%;
    z-index: 1;
    overflow: hidden;
    color: rgba(255, 255, 255, .5);
    text-overflow: ellipsis;
    white-space: nowrap;
    font-weight: 600;
    font-size: 18rem;
    /* font-family: "Jost", sans-serif; */
    font-family: "Noto Sans JP", sans-serif;
    line-height: 1;
    transform: translate(-50%, -50%);
}
.top-sect-ttl .head {
    position: relative;
    z-index: 2;
    margin: 0 0 .4em 0;
    letter-spacing: .12em;
    font-weight: 800;
    font-size: 5.6rem;
    font-family: "Noto Sans JP", sans-serif;
    line-height: 1.4;
}
.top-sect-ttl .head span.color {
    color: rgba(255, 96, 16, 1);
}
.top-sect-ttl .catch {
    position: relative;
    z-index: 3;
    display: inline-block;
    overflow: hidden;
    margin: 0 auto 3em;
    padding: .2em 1.8em .3em;
    border-radius: 8em;
    background: rgba(255, 96, 16, 1);
    /* border-bottom: 4px solid #0070C0; */
    color: #fff;
    letter-spacing: .12em;
    font-weight: 600;
    font-size: 1.6rem;
    font-family: "Noto Sans JP", sans-serif;
}
.top-sect-ttl .catch::before {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    display: block;
    width: 60%;
    height: 100%;
    background: rgba(255, 149, 0, 1);
    content: "";
    transition: all .3s;

    clip-path: polygon(0% 0%, 65% 0%, 100% 100%, 0% 100%);
}
/* .top-sect-ttl .catch::before,
.top-sect-ttl .catch::after {
    position: absolute;
    top: auto;
    bottom: 0;
    display: block;
    margin: auto;
    width: 50%;
    height: auto;
    content: "";
}
.top-sect-ttl .catch::before {
    left: 0;
    border-bottom: 5px solid rgba(1, 92, 172, 1);
}
.top-sect-ttl .catch::after {
    right: 0;
    border-bottom: 5px solid rgba(255, 96, 16, 1);
} */

.top-sect-ttl .txt {
    position: relative;
    z-index: 4;
    text-align: center;
    font-weight: 600;
    font-size: 1.6rem;
    line-height: 1.7;
}
.top-sect-17 .top-sect-ttl .bg {
    color: rgba(255, 255, 255, .1);
}
.top-sect-17 .top-sect-ttl .head,
.top-sect-17 .top-sect-ttl .catch,
.top-sect-17 .top-sect-ttl .txt {
    color: #fff;
}
.top-sect-17 .top-sect-ttl .catch {
    border-bottom: 4px solid #fff;
}
.top-sect-18 .top-sect-ttl .head,
.top-sect-18 .top-sect-ttl .catch,
.top-sect-18 .top-sect-ttl .txt {
    color: #fff;
    text-shadow: 0 3px 15px rgba(0, 0, 0, 1);
}

/* .top-sect-body */
.top-sect-body {
    position: relative;
    margin: 0;
    padding: 0;
}
.top-sect-body-txt {
    margin: 0 auto 60px;
    padding: 0 20px;
    max-width: 1640px;
    width: 100%;
    text-align: center;
    letter-spacing: .075em;
    font-weight: 400;
    font-size: 1.8rem;
    line-height: 2;
}

/* .top-sect-btn */
.top-sect-btn {
    position: relative;
    display: flex;
    overflow: hidden;
    margin: 0 auto;
    padding: 5px 35px;
    max-width: 406px;
    width: 100%;
    height: 66px;
    background: #1c1c1c;
    box-shadow: 0 0 1px rgba(0, 0, 0, 0);
    color: #fff;
    text-align: center;
    letter-spacing: .08em;
    font-weight: 600;
    font-size: 1.6rem;
    line-height: 24px;
    opacity: 1 !important;
    transition: all .5s ease;
    transition-duration: .5s;
    transition-property: color;
    transform: perspective(1px) translateZ(0);

    align-items: center;
    justify-content: center;
}
.top-sect-btn::before {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: -1;
    border-radius: inherit;
    background: #0d529c;
    content: "";
    transition-timing-function: ease-out;
    transition-duration: .3s;
    transition-property: transform;
    transform: scaleX(0);
    transform-origin: 0 50%;
}
.top-sect-btn:hover {
    /* background: rgba(223, 0, 58, 1); */
    color: #fff;
}
.top-sect-btn:hover::before {
    transform: scaleX(1);
}

/* sp（0px～768px未満の場合に適用） */
@media (min-width: 0) and (max-width: 767.98px) {
    .top-sect-ttl {
        padding: 0 14px;
    }
    .top-sect-ttl .head {
        font-size: 2.3rem;
    }
    .top-sect-ttl .catch {
        font-size: 1.4rem;
    }
    .top-sect-body-txt {
        padding: 0 14px;
        font-size: 1.3rem;
    }
}

/* tb（768px～1200px未満の場合に適用） */
@media (min-width: 768px) and (max-width: 1199.98px) {
    .top-sect-ttl .head {
        font-size: 3.8rem;
    }
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    .top-sect-ttl .head {
        font-size: 5.6rem;
    }
}


/* .top-important
-------------------------------------------------------- */
.top-important-box {
    display: flex;
    width: 100%;
    /* border-bottom: 1px solid #e0dbdb; */
}

/* .top-important-box-hdr */
.top-important-box-hdr {
    display: flex;
    width: 224px;
    background-color: #0070c0;
    color: #fff;

    align-items: center;
    justify-content: center;
}
.top-important-box-hdr .ttl {
    color: #fff;
    font-size: 1.8rem;
}

/* .top-important-box-body */
.top-important-box-body {
    background: rgba(255, 255, 255, 1);

    flex: 1;
}

/* .top-important-box-list-item */
.top-important-box-list-item {
    flex: 1;
}
.top-important-box-list-item a {
    display: flex;
    padding: 20px 80px 20px 40px;
    min-height: 96px;
    color: #53565a;

    align-items: center;
}
.top-important-box-list-item a:hover {
    text-decoration: none;
}
.top-important-box-list-item a .date {
    width: 130px;
    font-size: 1.4rem;
}
.top-important-box-list-item a .ttl {
    font-weight: 600;
    font-size: 1.6rem;

    flex: 1;
}
.top-important-box-list-item a:hover .ttl {
    text-decoration: underline;
}

/* .top-important-box-ftr */
.top-important-box-ftr {
    display: flex;
    width: 100px;
    background-color: #fff;
    color: #004187;

    align-items: center;
    justify-content: center;
}
.top-important-box-ftr a {
    position: relative;
    display: block;
    overflow: hidden;
    padding: 0 20px 0 0;
    color: #0070c0;
    letter-spacing: -.02em;
    font-weight: 500;
    font-size: 1.6rem;
    font-family: "Noto Sans JP", sans-serif;
}
.top-important-box-ftr a::before,
.top-important-box-ftr a::after {
    position: absolute;
    display: block;
    content: "";
}
.top-important-box-ftr a::before {
    top: calc(50% - 1px);
    right: 1px;
    width: 14px;
    height: 2px;
    background-color: rgba(1, 92, 172, 1);
    transform-origin: left;
}
.top-important-box-ftr a::after {
    top: calc(50% - 4px);
    right: 2px;
    width: 8px;
    height: 8px;
    border-right: 2px solid rgba(1, 92, 172, 1);
    border-bottom: 2px solid rgba(1, 92, 172, 1);
    transform: rotate3d(0, 0, 1, -45deg);
}

/* sp（768px未満の場合に適用） */
@media (max-width: 767.98px) {
    .top-important-box-hdr {
        width: 100px;
    }
    .top-important-box-hdr .ttl {
        font-size: 1.5rem;
    }
    .top-important-box-list-item a .ttl {
        font-size: 1.3rem;
    }
    .top-important-box-list-item a.link {
        display: block;
        padding: 10px 20px 10px 16px;
        min-height: auto;
        background: none;
    }
    .top-important-box-ftr {
        width: 80px;
    }
    .top-important-box-ftr a {
        color: #0070c0;
        font-size: 1.4rem;
    }
}


/* .top-topics
-------------------------------------------------------- */
.top-topics {
    padding: 0;
    width: 100%;
}
.top-topics-inner {
    display: flex;
    flex-direction: column;

    flex-wrap: wrap;
}

/* .top-topics-head */
.top-topics-head {
    width: 100%;
}
.top-topics-head .en {
    display: block;
    margin-bottom: .5em;
    color: #f7674c;
    text-transform: uppercase;
    letter-spacing: .05rem;
    font-weight: 600;
    font-size: 1.4rem;
    /* font-family: "Noto Serif JP", serif; */
    font-family: "Times New Roman", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}
.top-topics-head .ja {
    margin-bottom: .5em;
    color: #020202;
    letter-spacing: .2rem;
    font-weight: 600;
    font-size: 4.0rem;
    /* font-family: "Noto Serif JP", serif; */
    font-family: "Times New Roman", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}
.top-topics-head .txt {
    margin-bottom: 2em;
    letter-spacing: .075rem;
    font-size: 1.4rem;
    line-height: 1.8;
}
.top-topics-head .more a {
    display: inline-block;
    overflow: hidden;
    margin-bottom: 2em;
    padding: 1.5em 1em;
    min-width: 170px;
    max-width: 264px;
    width: 100%;
    outline: none;
    border-radius: 36px;
    background: rgba(1, 92, 172, 1);
    color: #fff;
    vertical-align: middle;
    text-align: center;
    text-decoration: none;
    letter-spacing: .2em;
    font-weight: 600;
    line-height: 1;
    transition: background .4s;
}

/* .top-topics-body */
.top-topics-body {
    width: 100%;
}

/* .headline */
.top-topics-body .headline-body {
    overflow: visible;
    height: auto;
}
.top-topics-body .headline-body .body-box {
    border-bottom: 1px solid #ededed;
}
.top-topics-body .headline-body .body-box:hover {
    background: transparent;
}
.top-topics-body .headline-body .body-box a {
    flex-direction: column;
    padding: 20px 0 20px;

    align-items: stretch;
}
.top-topics-body .headline-body .body-box-date {
    margin-bottom: 5px;
    padding: 0;
    color: #020202;
    font-weight: 400;
}
.top-topics-body .headline-body .body-box-date .category {
    border: 1px solid #ededed;
    background: transparent;
    color: #020202;
}
.top-topics-body .headline-body .body-box a:hover .body-box-list .ttl {
    text-decoration: underline;
}
.top-topics-body .headline-ftr {
    text-align: right;
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    .top-topics-inner {
        flex-direction: row;
    }
    .top-topics-head {
        margin-right: 3.75%; /* 60.00px */
        width: 300px;

        flex-grow: 0;
        flex-shrink: 0;
    }
    .top-topics-head .ja {
        margin-bottom: 1em;
        font-size: 4.0rem;
    }
    .top-topics-head .txt {
        margin-bottom: 7em;
        font-size: 1.4rem;
    }
    .top-topics-body {
        width: calc(95.89041095890413% - 300px);
    }
}


/* .top-column
-------------------------------------------------------- */
.top-column {
    position: relative;
    padding: 100px 0;
    width: 100%;
}
.top-column-inner {
    display: flex;
    flex-direction: column;
    /* padding: 0 14px;
    max-width: 1640px; */
    width: 100%;

    justify-content: space-between;
    flex-wrap: wrap;
}
.top-column-box {
    width: 100%;
}
.top-column-box + .top-column-box {
    margin-top: 60px;
}

/* .headline-body */
.top-column-box .headline-body .body-box a {
    flex-direction: column;
    padding: 10px 16px 10px;
}
.top-column-box .headline-body .body-box-date {
    margin-bottom: 5px;
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    .top-column::before {
        position: absolute;
        top: 0;
        left: 50%;
        overflow: visible;
        width: 1px;
        height: 100%;
        background: #ededed;
        content: "";
        transform: translateX(-50%);
    }
    .top-column-inner {
        display: flex;
        flex-direction: row;
        padding: 0 0;
    }
    .top-column-box {
        margin-bottom: 0;
        width: 42.5%; /* 680.00px */
    }
    .top-column-box + .top-column-box {
        margin-top: 0;
    }
}


/* .top-trio
-------------------------------------------------------- */
.top-trio {
    margin: 0 auto;
    padding: 0;
    width: 100%;
}
.top-trio-inner {
    display: flex;
    margin: 0 auto;
    padding: 0;
    max-width: 1640px;
    width: calc(100% - 14px);

    flex-wrap: wrap;
    justify-content: space-between;
}

/* .top-trio-news */
.top-trio-news {
    width: 100%;
    /* background-color: #fff;
    box-shadow: 2px 2px 6px #ddd; */
}

/* .top-trio-news-ttl */
.top-trio-news-ttl {
    position: relative;
    display: flex;
    flex-direction: row;
    padding: 12px 0 12px 0;
    max-width: 100%;
    width: 100%;
    background: rgba(0, 0, 0, .0);
    /* line-height: 20px; */
    color: #fff;
    letter-spacing: 1.5px;
    /* text-shadow: 0 0 1px rgba(68, 119, 21, 1),
    0 0 10px rgba(68, 119, 21, 1),
    0 0 15px rgba(68, 119, 21, 1),
    0 0 20px rgba(68, 119, 21, 1); */
    font-size: 1.3rem;
    font-family: "Noto Sans JP", sans-serif;

    flex-wrap: nowrap;
    align-items: baseline;
    justify-content: flex-start;
}

/* .top-trio-news-ttl {
    background: #1972b5 url(../../assets/img/home/ttl_top-trio-news.png) no-repeat 15px 10px;
} */

.top-trio-news-ttl .en {
    padding-right: 20px;
    word-break: break-word;
    letter-spacing: -.02em;
    font-weight: 500;
    font-size: 3.4rem;
    font-family: "Barlow Semi Condensed", sans-serif;

    overflow-wrap: anywhere;
}
.top-trio-news-ttl .ja {
    word-break: break-word;
    font-weight: 500;
    font-size: 1.6rem;
    font-family: "Noto Sans JP", sans-serif;

    overflow-wrap: anywhere;
}

/* .top-trio-news-list */
.top-trio-news-list {
    /* height: 430px;
    overflow-y: scroll;
    padding: 0 0 5px 1px;
    background-color: #fff; */
    overflow: hidden;
}
.top-trio-news-list-item {
    display: block;
}
.top-trio-news-list-item:nth-child(odd) {
    background-color: #fff;
}
.top-trio-news-list-item:nth-child(even) {
    background-color: #fef7f8;
}
.top-trio-news-list-item > a {
    display: block;
    overflow: hidden;
    padding: 20px 20px;
    color: #020202;
    text-decoration: none;
    transition: all .3s ease;
}
.top-trio-news-list-item > a:hover {
    background: #f4f2eb;
}

/* .top-trio-news-list-item.thumbnail */
.top-trio-news-list-item.thumbnail a {
    display: flex;

    flex-wrap: wrap;
    justify-content: space-between;
}
.top-trio-news-list-item.thumbnail a .item-thumbnail {
    margin-right: 4%;
    width: 46%;
    /* width: 100%; */
}
.top-trio-news-list-item.thumbnail a .item-box {
    flex: 1;
}

/* .top-trio-news-list-item .item-box */
.top-trio-news-list-item .item-box {
    width: 100%;
}
.top-trio-news-list-item .item-box-label {
    display: flex;
    margin-bottom: 5px;
    font-size: 0;

    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-start;
}
.top-trio-news-list-item .item-box-label-time {
    display: inline-block;
    margin: .4em .4em .4em 0;
    color: #020202;
    font-weight: 400;
    font-size: 1.4rem;
    line-height: 1;
}
.top-trio-news-list-item .item-box-label-category {
    display: inline-block;
    overflow: hidden;
    margin-left: 5px;
    padding: 2px 5px;
    /* min-width: 30px; */
    border-radius: 3px;
    background: #ffab3c;
    color: #fff;
    vertical-align: middle;
    text-align: center;
    font-weight: 400;
    font-size: 1.2rem;
    line-height: 1.4;
}
.top-trio-news-list-item .item-box-label-category.blog {
    background: #dc1d1d;
}
.top-trio-news-list-item .item-box-label-category.event {
    background: #dc1d1d;
}
.top-trio-news-list-item .item-box-label-category.campaign {
    background: #db4a39;
}
.top-trio-news-list-item .item-box-label-category.recruit {
    background: #ff6f3c;
}
.top-trio-news-list-item .item-box-label-category.voice {
    background: #00acee;
}
.top-trio-news-list-item .item-box-label-category.works {
    background: #87c040;
}
.top-trio-news-list-item .item-box-ttl {
    margin-bottom: .3em;
    font-size: 1.8rem;
    line-height: 1.5;
}
.top-trio-news-list-item .item-box-txt {
    margin: 0;
    font-size: 1.4rem;
    line-height: 1.6;
}

/* .top-trio-news-more */
.top-trio-news-more {
    padding: 25px 0;
    text-align: right;
}
.top-trio-news-more .btn-top-trio {
    padding: 9px 16px;
    padding: 12px 22px;
    border-radius: 4px;
    background: #0070c0;
    /* box-shadow: 0 3px 0 #004981; */
    color: #fff !important;
    /* text-shadow: 0 1px 0 #fff; */
    font-weight: 700;
    font-size: 1.4rem;
}
.top-trio-news-more .btn-top-trio:hover {
    color: #fff;
}
.top-trio-news-more .btn-top-trio .ico {
    margin-left: 20px;
    color: #fff;
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    .top-trio-inner {
        width: calc(100% - 60px);
    }
    .top-trio-news-ttl .en {
        margin: 0 15px 0 0;
        padding: 0;
        text-align: left;
        font-size: 4.8rem;
        line-height: 1;
    }
    .top-trio-news-ttl .ja {
        text-align: left;
        font-weight: 500;
        font-size: 1.2rem;
        line-height: 2.2;
    }
    .top-trio-news {
        margin-right: 1%;
        width: 32.666666666666664%;
    }
    .top-trio-news:last-child {
        margin-right: 0;
    }
    .top-trio-news-list-item .item-box-ttl {
        font-size: 2.0rem;
    }
}


/* .top-grid
-------------------------------------------------------- */
.top-grid {
    margin: 0 auto;
    padding: 0;
    width: 100%;
    background: transparent;
}
.top-grid > div {
    z-index: 0 !important;
}
.top-grid-inner {
    position: relative;
    z-index: 0;
    margin: 0 auto;
    /* padding: 0 14px;
    max-width: 1640px; */
    width: 100%;
}
.top-grid-list {
    display: flex;
    width: 100%;
    transition: all .05s ease-in-out;

    flex-flow: column wrap;
    justify-content: flex-start;
    align-items: stretch;
}
.top-grid-list-item {
    width: 100%;
    /* border-bottom: 1px solid #e9e9e9; */
}
.top-grid-list-item a {
    position: relative;
    display: block;
    height: 100%;
    text-decoration: none;
    transition: all .3s ease-in-out;
}

/* .top-grid-list-item .img */
.top-grid-list-item .img {
    position: relative;
    /* box-shadow: 0 12px 12px rgba(0, 0, 0, .15); */
    overflow: hidden;
    width: 100%;
    height: auto;
    /* border: 1px solid #d0d0d0; */
    background-color: #fff;
}
.top-grid-list-item .img img {
    display: block;
    width: 100%;
    height: 100% !important;
    font-family: "object-fit: cover; object-position: 50% 50%;"; /* IE対策 */
    transition: all .3s ease-in-out;

    -o-object-position: 50% 50%;
       object-position: 50% 50%;
    -o-object-fit: cover;
       object-fit: cover;
}
.top-grid-list-item a:hover .img img {
    transform: scale(1.15);
}
.top-grid-list-item .img figcaption.img-txt {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
    display: flex;
    padding: .6em 1.2em;
    background-color: rgba(220, 0, 12, .9);
    color: #fff;
    text-align: center;
    font-weight: 500;
    font-size: 1.3rem;
    line-height: 1.4;

    flex-flow: row wrap;
    justify-content: center;
    align-items: center;
}

/* .top-grid-list-item .box */
.top-grid-list-item .box {
    padding: 1.2em 0 1.8em;
}
.top-grid-list-item .box-ttl {
    margin: 0 0 1.6em;
    font-size: 1.8rem;
}
.top-grid-list-item .box-date {
    display: block;
    margin-bottom: 5px;
    font-weight: 600;
    font-size: 1rem;
    line-height: 1;
}
.top-grid-list-item .box-category {
    display: inline-block;
    padding: 0 0 12px;
    font-size: 0;
}
.top-grid-list-item .box-category .date {
    display: inline-block;
    margin-right: .8em;
    color: #a2aeb6;
    font-weight: 400;
    font-size: 1.1rem;
    line-height: 1;
}
.top-grid-list-item .box-category .category {
    display: inline-block;
    padding: .4em 1.2em;
    width: auto;
    /* border: 1px solid #ededed; */
    background: rgba(255, 96, 16, 1);
    color: #fff;
    font-weight: 400;
    font-size: 1.1rem;
    line-height: 1;
}
.top-grid-list-item .box-category .category.information {
    /* border: 1px solid #ededed; */
    background: rgba(255, 96, 16, 1);
    color: #fff;
}
.top-grid-list-item .box-category .category.blog {
    /* border: 1px solid #ededed; */
    background: rgba(40, 167, 69, 1);
    color: #fff;
}
.top-grid-list-item .box-category .category.campaign {
    /* border: 1px solid #ededed; */
    background: rgba(23, 162, 184, 1);
    color: #fff;
}
.top-grid-list-item .box-category .category.event {
    /* border: 1px solid #ededed; */
    background: rgba(111, 66, 193, 1);
    color: #fff;
}
.top-grid-list-item .box-txt {
    color: #4f4f4f;
    word-break: break-all;
    line-height: 1.6;
}

/* .top-grid-ftr */
.top-grid-ftr {
    padding: 4em 0;
    text-align: center;
}
.top-grid-ftr .btn {
    margin: 1.5em 0 0 0;
}
.top-grid-ftr .btn:first-child {
    margin: 0;
}
.top-grid-ftr .btn-top-grid {
    padding: 16px 22px;
    width: 100%;
    border-radius: 4px;
    background: #1972b5;
    /* box-shadow: 0 3px 0 #004981; */
    color: #fff;
    font-weight: 700;
}
.top-grid-ftr .btn-top-grid .ico {
    position: relative;
    top: -2px;
    margin: 0 10px 0 0;
    color: #fff;
    font-size: 1.6rem;
}

/* sp（0px～768px未満の場合に適用） */
@media (min-width: 0) and (max-width: 767.98px) {
    /* .top-grid-list */
    .top-grid-list-item {
        margin-top: 6%;
        width: 100%;
    }
    .top-grid-list-item:nth-child(1) {
        margin-top: 0;
    }
}

/* tb（768px～1200px未満の場合に適用） */
@media (min-width: 768px) and (max-width: 1199.98px) {
    /* .top-grid-list */
    .top-grid-list {
        flex-flow: row wrap;
    }
    .top-grid-list-item {
        margin-top: 2%;
        margin-right: 2%;
        width: 49%;
    }
    .top-grid-list-item:nth-child(1),
    .top-grid-list-item:nth-child(2) {
        margin-top: 0;
    }
    .top-grid-list-item:nth-child(2n) {
        margin-right: 0;
    }
    .top-grid-list-item .img {
        height: 280px;
    }
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    /* .top-grid-inner {
        padding: 0 20px;
    } */
    .top-grid-list-item a:hover {
        opacity: .6;
    }
    /* .top-grid-list-item a::before {
        position: absolute;
        bottom: -1px;
        left: 0;
        z-index: 1;
        width: 0;
        height: 1px;
        background-color: #777;
        content: "";
        transition: all .3s ease-in-out;
    } */
    .top-grid-list-item a:hover::before {
        width: 100%;
    }

    /* .top-grid-list */
    .top-grid-list {
        flex-flow: row wrap;
    }
    .top-grid-list-item {
        margin-top: 3.75%; /* 60.00px */
        margin-right: 3.75%; /* 60.00px */
        width: 30.833333333333332%; /* 493.33px */
    }
    .top-grid-list-item:nth-child(1),
    .top-grid-list-item:nth-child(2),
    .top-grid-list-item:nth-child(3) {
        margin-top: 0;
    }
    .top-grid-list-item:nth-child(3n) {
        margin-right: 0;
    }
    .top-grid-list-item .img {
        height: 300px;
    }
    .top-grid-list-item .box-ttl {
        font-size: 2.2rem;
    }

    /* .top-grid-ftr */
    .top-grid-ftr {
        text-align: center;
    }
    .top-grid-ftr .btn {
        margin: 0 0 0 1.5em;
        padding: 18px 18px;
    }
    .top-grid-ftr .btn .ico {
        margin: 0 10px 0 0;
    }
    .top-grid-ftr .btn-top-grid {
        max-width: 320px;
        width: 40%;
    }
}


/* .top-about
-------------------------------------------------------- */
.top-about {
    position: relative;
    overflow: hidden;
    margin: 0 auto;
    padding: 0;
    width: 100%;
}
.top-about > div {
    z-index: 0 !important;
}
.top-about-inner {
    position: relative;
    z-index: 0;
    margin: 0 auto;
    padding: 80px 15px;
    max-width: 738px;
    width: 100%;
    background: #ff0064;
}
.top-about-hdr {
    color: #fff;
    text-align: center;
}
.top-about-hdr .ttl {
    color: #fff;
    letter-spacing: .12em;
    font-weight: 700;
    font-size: 3.2rem;
    font-family: "Montserrat", sans-serif;
    line-height: 1.4em;
}
.top-about-hdr .txt {
    display: inline-block;
    margin-bottom: 2.5em;
    padding-bottom: .8em;
    border-bottom: 1px solid #fff;
    letter-spacing: .2em;
    font-weight: 400;
    font-size: 1.4rem;
}
.top-about-hdr .copy {
    margin-bottom: 1em;
    color: #fff;
    letter-spacing: .08em;
    font-weight: 700;
    font-size: 2.4rem;
    line-height: 1.8em;
}
.top-about-body {
    padding: 0;
}
.top-about-body .txt {
    color: #fff;
    text-align: center;
    line-height: 2.2em;
}
.top-about-bg {
    height: 180px;
    background: url(../../assets/img/home/bg_top-about-bg.jpg) no-repeat;
    background-position: 50% 50%;
    background-size: cover;
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    .top-about-hdr .ttl {
        font-size: 6.4rem;
    }
    .top-about-hdr .txt {
        font-size: 1.4rem;
    }
    .top-about-hdr .copy {
        font-size: 3.4rem;
    }
    .top-about-bg {
        margin-top: -369px;
        height: 479px;
    }
}


/* .top-aboutus
-------------------------------------------------------- */
.top-aboutus {
    position: relative;
    overflow: hidden;
    padding: 20vw 0 90vw;
    /* background: linear-gradient(to bottom, #fff 0%, #f3f3f3 100%); */
}
.top-aboutus-ttl {
    position: absolute;
    top: 10vw;
    left: 0;
    z-index: 2;
    color: rgba(33, 67, 102, .1);
    letter-spacing: .1em;
    font-weight: 700;
    font-size: 8rem;
    font-family: "Poppins", sans-serif;
    line-height: 1;
}
.top-aboutus-box {
    position: relative;
    z-index: 3;
    margin: 0 auto;
    padding: 0 14px;
    max-width: 1640px;
}
.top-aboutus-box-inner {
    max-width: 100%;
}
.top-aboutus-box .box-lead {
    position: relative;
    z-index: 3;
    font-weight: 600;
    font-size: 2.6rem;
    line-height: 1.6;
}
.top-aboutus-box .box-txt {
    position: relative;
    z-index: 3;
    margin-top: 50px;
    font-weight: 500;
    font-size: 1.6rem;
    line-height: 1.8;
}
.top-aboutus-box .box-btn {
    position: relative;
    z-index: 3;
    margin-top: 50px;
}
.top-aboutus-box .box-btn a {
    position: relative;
    display: flex;
    padding: 1.4em .8em;
    max-width: 400px;
    width: 100%;
    height: 100%;
    background-image: linear-gradient(to right, #333 0%, #4e4e4e 51%, #333 100%);
    background-size: 200% auto;
    /* box-shadow: 0 0 20px rgba(0, 0, 0, .2); */
    color: #fff;
    font-weight: 500;
    font-size: 1.7rem;
    line-height: 1.4;
    transition: .3s;

    align-items: center;
    justify-content: center;
}
.top-aboutus-box .box-btn a:hover {
    background-position: right center;
}
.top-aboutus-img {
    position: absolute;
    right: -1vw;
    bottom: 7vw;
    z-index: 1;
    max-width: 100%;
    width: 90vw;
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    .top-aboutus {
        padding: 220px 0 150px;
    }
    .top-aboutus-ttl {
        top: 90px;
        left: calc(50% - 810px);
        font-size: 18rem;
    }
    .top-aboutus-box {
        padding: 0 20px;
    }
    .top-aboutus-box-inner {
        max-width: 60vw;
    }
    .top-aboutus-box .box-lead {
        font-size: 4.2rem;
    }
    .top-aboutus-box .box-txt {
        margin-top: 50px;
        text-shadow: -2px -2px 0 #fff, -1px -2px 0 #fff, 0 -2px 0 #fff, 1px -2px 0 #fff, 2px -2px 0 #fff, 2px -1px 0 #fff, 2px 0 0 #fff, 2px 1px 0 #fff, 2px 2px 0 #fff, 1px 2px 0 #fff, 0 2px 0 #fff, -1px 2px 0 #fff, -2px 2px 0 #fff, -2px 1px 0 #fff, -2px 0 0 #fff, -2px -1px 0 #fff;
        font-size: 1.8rem;
        line-height: 2.4;
    }
    .top-aboutus-box .box-btn {
        margin-top: 50px;
    }
    .top-aboutus-img {
        top: 120px;
        right: auto;
        bottom: auto;
        left: calc(50% + 200px);
        max-width: 40vw;
    }
}


/* .top-appeal
-------------------------------------------------------- */
.top-appeal {
    overflow: hidden;
    margin: 0 auto;
    padding: 0;
    width: 100%;
    background: #fff;
}
.top-appeal-inner {
    margin: 0 auto;
    padding: 30px 0;
    width: 100%;
}
/* .top-appeal-body */
.top-appeal-body {
    width: 100%;
}

/* .top-appeal-list */
.top-appeal-list {
    overflow: hidden;
    margin: 0 auto;
    width: 100%;
}
.top-appeal-list-item {
    position: relative;
    margin: 0 auto;
    padding: 0;
    width: 100%;
    /* border-bottom: 1px solid #e5e5e5; */
}
.top-appeal-list-item:nth-child(odd) {
    border-bottom: 1px solid #e5e5e5;
    background-color: #fff;
}
.top-appeal-list-item:nth-child(even) {
    background-color: #fafafa;
}
.top-appeal-list-item-inner {
    margin: 0 auto;
    padding: 0;
    max-width: 1640px;
    width: 100%;
}
.top-appeal-list-item .item-box {
    width: 100%;
}
.top-appeal-list-item .item-box-catch {
    text-align: center;
}
.top-appeal-list-item .item-box-catch-num {
    display: inline-block;
    margin: 0 0 32px 0;
    padding: 8px 18px 8px;
    background: #0070c0;
    color: #fff;
    font-size: 2.4rem;
}
.top-appeal-list-item .item-box-catch-ttl {
    margin: 0 0 30px 0;
    padding: 30px 0 0;
    color: #020202;
    text-align: center;
    font-size: 2.4rem;
    line-height: 1.4;
}
.top-appeal-list-item .item-box-catch-ttl .ja {
    position: relative;
    display: inline-block;
    margin-bottom: 0;
    padding: 0 55px;
    font-size: 2.8rem;
}
.top-appeal-list-item .item-box-catch-ttl .ja::before,
.top-appeal-list-item .item-box-catch-ttl .ja::after {
    position: absolute;
    top: 50%;
    display: inline-block;
    width: 90px;
    height: 2px;
    background-color: #333;
    content: "";
}
.top-appeal-list-item .item-box-catch-ttl .ja::before {
    left: -2em;
}
.top-appeal-list-item .item-box-catch-ttl .ja::after {
    right: -2em;
}
.top-appeal-list-item .item-box-img {
    position: relative;
    margin: 0 0 24px 0;
    width: 100%;
    height: 300px;
    background-position: center top;
    background-size: cover;
    background-repeat: no-repeat;
}
.top-appeal-list-item:nth-child(1) .item-box-img {
    background-image: url(../../assets/img/home/bg_top-appeal_01_sp.jpg);
}
.top-appeal-list-item:nth-child(2) .item-box-img {
    background-image: url(../../assets/img/home/bg_top-appeal_02_sp.jpg);
}
.top-appeal-list-item:nth-child(3) .item-box-img {
    background-image: url(../../assets/img/home/bg_top-appeal_03_sp.jpg);
}
.top-appeal-list-item .item-box-txt h4 {
    margin: 0 0 28px 0;
    text-align: center;
    font-weight: 400;
    font-size: 1.8rem;
}
.top-appeal-list-item .item-box-txt p {
    margin: 0 0 48px 0;
}
.top-appeal-list-item .item-box-txt .top-appeal-btn {
    margin: 0 auto;
    max-width: 320px;
    text-align: center;
}
.top-appeal-list-item .item-box-txt .top-appeal-btn .btn {
    display: block;
    margin: 15px 0 0 0;
    padding: 1em .5em;
    background: #2256a4;
    color: #fff;
    text-decoration: none;
}
.top-appeal-list-item .item-box-txt .top-appeal-btn .btn:first-child {
    margin: 0;
}
.top-appeal-list-item .item-box-txt .top-appeal-btn .btn .ico {
    margin-right: 1em;
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    .top-appeal-inner {
        padding: 0;
    }
    .top-appeal-list-item-inner {
        overflow: visible;
    }
    .top-appeal-list-item .item-box {
        padding: 140px 20px;
        width: 48.125%; /* 770.00px */
    }
    .top-appeal-list-item:nth-child(odd) .item-box {
        float: left;
    }
    .top-appeal-list-item:nth-child(even) .item-box {
        float: right;
    }
    .top-appeal-list-item .item-box-img {
        position: absolute;
        top: 0;
        margin: 0;
        width: 40%;
        height: 100%;
        background-position: center top;
        background-size: cover;
        background-repeat: no-repeat;
    }
    .top-appeal-list-item:nth-child(1) .item-box-img {
        background-image: url(../../assets/img/home/bg_top-appeal_01_pc.jpg);
    }
    .top-appeal-list-item:nth-child(2) .item-box-img {
        background-image: url(../../assets/img/home/bg_top-appeal_02_pc.jpg);
    }
    .top-appeal-list-item:nth-child(3) .item-box-img {
        background-image: url(../../assets/img/home/bg_top-appeal_03_pc.jpg);
    }
    .top-appeal-list-item:nth-child(odd) .item-box-img {
        right: 0;
    }
    .top-appeal-list-item:nth-child(even) .item-box-img {
        left: 0;
    }
    .top-appeal-list-item .item-box-catch {
        text-align: left;
    }
    .top-appeal-list-item .item-box-catch-ttl {
        font-size: 4.2rem;
    }
    .top-appeal-list-item .item-box-catch-ttl .ja {
        font-size: 4.0rem;
    }
}


/* .top-access
-------------------------------------------------------- */
.top-access {
    position: relative;
    margin: 0 auto;
    padding: 0;
    width: 100%;
}
.top-access-ttl {
    position: absolute;
    top: -20px;
    left: 5%;
    z-index: 0;
    display: block;
    margin: 0;
    padding: 0;
    width: auto;
    height: auto;
    color: #0070c0;
    /* letter-spacing: -.02em; */
    font-weight: 500;
    font-size: 3.4rem;
    font-family: "Barlow Semi Condensed", sans-serif;
    line-height: 1;
    transform: rotate(90deg);
    transform-origin: left bottom;

    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
}
.top-access-ttl::after {
    display: inline-block;
    margin: 0 0 10px 20px;
    width: 100px;
    height: 1px;
    background: #0070c0;
    content: "";
}
.top-access-map {
    position: relative;
    overflow: hidden;
    margin: 0 0 0 auto;
    padding: 0;
    width: 90%;
    height: 600px;
}
.top-access-map .info {
    position: absolute;
    top: 50%;
    right: 80px;
    z-index: 2;
    margin: 0;
    padding: 25px;
    max-width: 300px;
    width: 100%;
    background: rgba(255, 255, 255, .9);
    transform: translate(0, -50%);
}
.top-access-map .info figure {
    margin: 0 auto 10px;
    padding: 0;
    width: 100%;
}
.top-access-map .info figure img {
    margin: 0;
    padding: 0;
    width: 100%;
    height: auto;
}
.top-access-map .info h2 {
    margin: 0 auto 10px;
    padding: 0;
    color: #020202;
    font-weight: 400;
    font-size: 1.6rem;
    font-family: "Noto Sans JP", sans-serif;
    line-height: 1.4;

    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    -webkit-text-size-adjust: 100%;
        -ms-text-size-adjust: 100%;
       -moz-text-size-adjust: 100%;
            text-size-adjust: 100%;
}
.top-access-map .info p {
    margin: 0 auto 10px;
    padding: 0;
    font-weight: 400;
    font-style: normal;
    font-size: 1.2rem;
    line-height: 1.7em;

    -webkit-font-feature-settings: "palt" 1;
       -moz-font-feature-settings: "palt" 1;
        -ms-font-feature-settings: "palt" 1;
            font-feature-settings: "palt" 1;
}
.top-access-map .info .top-access-map-btn a {
    position: relative;
    /* display: block; */
    display: flex;
    margin: 0;
    padding: 10px;
    width: 100%;
    border-radius: 25px;
    background: #005491;
    color: #fff;
    text-align: center;
    font-size: 2.0rem;
    font-family: "Barlow Semi Condensed", sans-serif;
    line-height: 1;
    transition: all .2s ease-in;

    align-items: center;
    justify-content: center;
}
.top-access-map .info .top-access-map-btn a:hover {
    text-decoration: none;
}
.top-access-map .info .top-access-map-btn a .ico {
    margin-right: 0;
    font-size: 90%;
}

/* sp（768px未満の場合に適用） */
@media (max-width: 767.98px) {
    .top-access-ttl {
        display: none;
    }
    .top-access-map {
        width: 100%;
    }
    .top-access-map .info {
        display: none;
    }
}


/* .top-concept
-------------------------------------------------------- */
.top-concept {
    position: relative;
    overflow: hidden;
    margin: 0 auto;
    padding: 120px 0;
    width: 100%;
    /* border-top: 1px solid #ededed; */
    /* border-bottom: 1px solid #ededed; */
    /* background: #3263a6; */
    /* background: transparent; */
    background: url(../../assets/img/common/bg_top-concept.jpg) no-repeat bottom center;
    /* background-attachment: fixed; */
    background-size: cover;
}
.top-concept::after {
    position: absolute;
    bottom: -7%;
    left: 30%;
    color: rgba(255, 255, 255, .08);
    content: "Shikishima";
    text-transform: uppercase;
    white-space: nowrap;
    letter-spacing: -.1em;
    font-weight: 600;
    font-size: 28rem;
    font-family: "Noto Sans JP", sans-serif;
    line-height: 1;
}
.top-concept-inner {
    position: relative;
    margin: 0 auto;
    padding: 40px 14px;
    max-width: 1200px;
    width: 100%;
}

/* .concept-hdr */
.top-concept-hdr .ttl {
    margin: 0 0 10px 0;
    color: #fff;
    text-align: center;
    /* text-shadow: 0 0 25px rgba(0, 0, 0, .2); */
    letter-spacing: 2px;
    font-size: 2.8rem;
    line-height: 1.4;
}
.top-concept-hdr .txt {
    margin: 50px auto 50px;
    color: #fff;
    text-align: center;
    /* text-shadow: 0 0 25px rgba(0, 0, 0, .2); */
    letter-spacing: 2px;
    font-size: 1.4rem;
    line-height: 1.4;
}

/* .top-concept-body */
.top-concept-body .txt {
    margin: 0 0 30px;
    color: #fff;
    text-align: center;
    /* text-shadow: 0 0 25px rgba(0, 0, 0, .2); */
    font-weight: 600;
    font-size: 1.6rem;
    font-family: "Noto Sans JP", sans-serif;
    line-height: 2.4;
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    .top-concept::after {
        bottom: -8%;
        left: 30%;
        font-size: 28rem;
    }
    .top-concept-inner {
        padding: 60px 0;
    }
    .top-concept-hdr .ttl {
        font-size: 4.2rem;
    }
    .top-concept-hdr .txt {
        font-size: 1.6rem;
    }
    /* .top-concept-inner::before {
        position: absolute;
        bottom: 0;
        left: -410px;
        display: block;
        margin: auto;
        width: 370px;
        height: 357px;
        background: url(../../assets/img/home/img_top-concept_01.png);
        background-position: 0 0;
        background-size: 370px 357px;
        background-repeat: no-repeat;
        content: "";
    }
    .top-concept-inner::after {
        position: absolute;
        right: -370px;
        bottom: 0;
        display: block;
        margin: auto;
        width: 370px;
        height: 357px;
        background: url(../../assets/img/home/img_top-concept_02.png);
        background-position: 0 0;
        background-size: 370px 357px;
        background-repeat: no-repeat;
        content: "";
    } */
    .top-concept-body .txt {
        font-size: 1.8rem;
    }
}


/* .top-point
-------------------------------------------------------- */
.top-point {
    margin: 0 auto;
    padding: 0;
    width: 100%;
    background-color: #ccc;
}
.top-point > div {
    z-index: 0 !important;
}
.top-point-inner {
    position: relative;
    z-index: 0;
    overflow: hidden;
    margin: 0 auto;
    padding: 80px 0 80px;
    width: 100%;
}
.top-point-inner::before,
.top-point-inner::after {
    position: absolute;
    z-index: -1;
    width: 400px;
    height: 400px;
    background-repeat: no-repeat;
    content: "";
}
.top-point-inner::before {
    top: 0;
    left: 0;
    background-image: url(../../assets/img/common/bg_top-point_01.png);
    background-position: left top;
    background-size: 100%;
}
.top-point-inner::after {
    right: 0;
    bottom: 0;
    background-image: url(../../assets/img/common/bg_top-point_02.png);
    background-position: right bottom;
    background-size: 100%;
}
.top-point-body {
    margin: 0 auto;
    padding: 0 14px;
    max-width: 1640px;
    width: 100%;
}
.top-point-list {
    overflow: hidden;
}
.top-point-list-item {
    margin: 0 auto;
    padding: 0;
    width: 100%;
    text-align: center;
}
.top-point-list-item-img {
    margin: 0 0 20px 0;
}

/* .top-point-list-item-img img {
    border-radius: 5px;
} */

.top-point-list-item-ttl {
    position: relative;
    margin: 0 0 8px 0;
    padding: 0 0 8px 0;
    color: #020202;
    text-align: center;
    font-weight: 500;
    font-size: 2.2rem;
    font-family: "Noto Sans JP", sans-serif;
    line-height: 1.4;
}

/* .top-point-list-item-ttl::after {
    position: absolute;
    top: auto;
    bottom: 0;
    left: 50%;
    display: block;
    margin: auto;
    width: 100%;
    height: 1px;
    background: #333;
    content: "";
    transform: translateX(-50%);
} */

.top-point-list-item-txt {
    margin: 0;
    color: #020202;
    text-align: left;
    font-weight: 400;
    font-size: 1.6rem;
}

/* sp（0px～768px未満の場合に適用） */
@media (min-width: 0) and (max-width: 767.98px) {
    .top-point-inner::before {
        background-position: left top;
        background-size: 45%;
    }
    .top-point-inner::after {
        background-position: right bottom;
        background-size: 45%;
    }
}

/* tb（768px～1200px未満の場合に適用） */
@media (min-width: 768px) and (max-width: 1199.98px) {
    .top-point-inner::before {
        background-position: left top;
        background-size: 60%;
    }
    .top-point-inner::after {
        background-position: right bottom;
        background-size: 60%;
    }
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    .top-point-inner {
        padding: 120px 0 120px;
    }
    .top-point-body {
        padding: 0 20px;
    }
    .top-point-list-item-img {
        margin: 0 0 20px 0;
    }
    .top-point-list-item-ttl {
        font-size: 2.2rem;
    }
    .top-point-list-item-txt {
        font-size: 1.4rem;
    }
}


/* .top-picky
-------------------------------------------------------- */
.top-picky {
    overflow: hidden;
    padding: 0;
}
.top-picky-inner {
    margin: 0 auto;
    padding: 0 14px;
    max-width: 1640px;
    width: 100%;
}

/* .top-picky-ttl */
.top-picky-ttl {
    position: relative;
    margin: 0 auto 60px;
    padding: 0 0 20px;
    color: #fff;
    text-align: center;
    letter-spacing: 2px;
    line-height: 1.4;
}
.top-picky-ttl::after {
    position: absolute;
    top: auto;
    bottom: 0;
    left: 50%;
    display: block;
    margin: auto;
    width: 140px;
    height: 3px;
    background: #fff;
    content: "";
    transform: translateX(-50%);
}
.top-picky-ttl .ja {
    display: block;
    margin: 0 0 10px 0;
    color: #fff;
    letter-spacing: 1.5px;
    font-weight: 700;
    font-size: 1.8rem;
    font-family: "Noto Sans JP", sans-serif;
}
.top-picky-ttl .en {
    display: block;
    color: #fff;
    letter-spacing: 1.5px;
    font-weight: 400;
    font-size: 1.6rem;
    font-family: "Noto Sans JP", sans-serif;
}

/* .top-picky-list */
.top-picky-list {
    overflow: hidden;
}
.top-picky-list-item {
    margin: 0 auto;
    padding: 0;
    width: 100%;
}
.top-picky-list-item .dammy,
.top-picky-list-item a {
    display: block;
    padding: 30px 20px;
    border: 1px solid #fff;
    color: #fff;
    text-align: center;
    text-decoration: none;
    letter-spacing: .12em;
    transition: all .3s ease;

    -webkit-font-feature-settings: "palt" 1;
       -moz-font-feature-settings: "palt" 1;
        -ms-font-feature-settings: "palt" 1;
            font-feature-settings: "palt" 1;
}
.top-picky-list-item .dammy,
.top-picky-list-item a {
    position: relative;
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
    transition: all .5s ease;
}
.top-picky-list-item:nth-child(1) .dammy,
.top-picky-list-item:nth-child(1) a {
    background-image: url(../../assets/img/common/bg_top-picky-list-item_01.jpg);
}
.top-picky-list-item:nth-child(2) .dammy,
.top-picky-list-item:nth-child(2) a {
    background-image: url(../../assets/img/common/bg_top-picky-list-item_02.jpg);
}
.top-picky-list-item:nth-child(3) .dammy,
.top-picky-list-item:nth-child(3) a {
    background-image: url(../../assets/img/common/bg_top-picky-list-item_03.jpg);
}
.top-picky-list-item .dammy .ja,
.top-picky-list-item a .ja {
    display: block;
    margin-bottom: 5px;
    font-size: 1.6rem;
    font-family: "Noto Sans JP", sans-serif;
}
.top-picky-list-item .dammy .en,
.top-picky-list-item a .en {
    display: block;
    font-style: italic;
    font-size: 1.0rem;
    font-family: "din-demi";
    line-height: 1.3;
}
.top-picky-list-item a::after {
    position: absolute;
    top: 50%;
    right: 15px;
    display: inline-block;
    margin-top: 0;
    color: #fff;
    content: "\e848";
    font-weight: 700;
    font-size: 2.0rem;
    font-family: "webfont";
    transform: translate(0, -50%);
}
.top-picky-list-item a:hover {
    background: #fff;
    color: #0070c0;
    opacity: 1;
    /* opacity: .5; */
}
.top-picky-list-item .dammy::before {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 10;
    display: block;
    width: 100%;
    height: 100%;
    background: #000;
    content: "";
    opacity: .8;
}
.top-picky-list-item .dammy::after {
    position: absolute;
    top: 50%;
    right: auto;
    left: 50%;
    z-index: 11;
    display: inline-block;
    border-bottom: 2px solid #fff;
    color: #fff;
    content: "COMING SOON";
    letter-spacing: .08em;
    font-style: italic;
    font-size: 1.6rem;
    font-family: "Noto Sans JP", sans-serif;
    transform: translate(-50%, -50%);
}
.top-picky-list-item .dammy:hover {
    opacity: 1;
}

/* tb（768px以上の場合に適用） */
@media (min-width: 768px) {
    /* .top-picky-list-item */
    .top-picky-list-item .dammy,
    .top-picky-list-item a {
        padding: 16.5% 7%;
    }
    .top-picky-list-item .dammy .ja,
    .top-picky-list-item a .ja {
        margin-bottom: 10px;
        font-size: 2.0rem;
    }
    .top-picky-list-item .dammy .en,
    .top-picky-list-item a .en {
        font-size: 1.1rem;
    }
    .top-picky-list-item a::after {
        font-size: 3.0rem;
    }
    .top-picky-list-item .dammy::after {
        width: 145px;
        font-size: 1.8rem;
    }
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    .top-picky-inner {
        margin: 60px auto 0;
        padding: 0 20px 60px 20px;
    }

    /* .top-picky-ttl */
    .top-picky-ttl .ja {
        font-size: 3.6rem;
    }
    .top-picky-list-item .dammy .ja,
    .top-picky-list-item a .ja {
        font-size: 2.4rem;
    }
    .top-picky-list-item .dammy::after {
        font-size: 1.8rem;
    }
}


/* .top-worry
-------------------------------------------------------- */
.top-worry {
    position: relative;
    overflow: hidden;
    margin: 0 auto;
    padding: 0;
    width: 100%;
    /* background: url(../../assets/img/common/bg_top-worry.jpg) no-repeat bottom center; */
    /* background-attachment: fixed; */
    /* background-size: cover; */
    background: #f5ed6f;
}
.top-worry::after {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -2;
    width: 800%;
    height: 100%;
    background: url(../../assets/img/common/bg_top-worry.png) repeat-x center bottom;
    /* background-size: 1616px 836px; */
    background-size: contain;
    content: "";
    animation: infinitescroll 50s linear infinite;

    animation-fill-mode: both;
}
@keyframes infinitescroll {
    0% {
        transform: translate3d(0px, 0px, 0px);
    }
    100% {
        transform: translate3d(-1616px, 0px, 0px);
    }
}

.top-worry-inner {
    position: relative;
    margin: 0 auto;
    padding: 40px 14px;
    max-width: 1640px;
    width: 100%;
}

/* .top-worry-hdr */
.top-worry-hdr {
    margin-bottom: 50px;
    width: 100%;
}
.top-worry-hdr .txt {
    margin: 0 auto 10px;
    color: #020202;
    text-align: center;
    /* text-shadow: 0 0 25px rgba(0, 0, 0, .2); */
    letter-spacing: .1em;
    font-size: 1.4rem;
    line-height: 1.4;
}
.top-worry-hdr .ttl {
    margin: 0 0 80px 0;
    color: #020202;
    text-align: center;
    /* text-shadow: 0 0 25px rgba(0, 0, 0, .2); */
    letter-spacing: .1em;
    font-size: 2.8rem;
    line-height: 1.4;
}

/* .top-worry-body */
.top-worry-body .txt {
    margin: 0 0 30px;
    color: #020202;
    text-align: center;
    /* text-shadow: 0 0 25px rgba(0, 0, 0, .2); */
    font-weight: 600;
    font-size: 1.6rem;
    font-family: "Noto Sans JP", sans-serif;
    line-height: 2.4;
}

/* .top-worry-list */
.top-worry-list {
    margin: 0 auto;
    width: 100%;
}
.top-worry-list-fukidashi {
    color: #020202;
}
.top-worry-list-fukidashi .ttl {
    position: relative;
    text-align: center;
    letter-spacing: .05em;
    line-height: 1.6;
}
.top-worry-list-fukidashi .ttl::after {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    margin-top: -34px;
    width: 100%;
    height: 140px;
    background: url(../../assets/img/common/bg_ballon_03.svg) no-repeat center center / contain;
    content: "";
}
.top-worry-list-fukidashi .ttl span {
    font-weight: 600;
    font-size: 2rem;
}
.top-worry-list-fukidashi .txt {
    margin: 70px 0 30px;
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    .top-worry-inner {
        padding: 120px 20px;
    }
    .top-worry-hdr .txt {
        font-size: 2.4rem;
    }
    .top-worry-hdr .ttl {
        font-size: 4.2rem;
    }
    .top-worry-body .txt {
        font-size: 1.8rem;
    }
}


/* .top-job
-------------------------------------------------------- */
.top-job {
    width: 100%;
}
.top-job-inner {
    margin: 0 auto;
    padding: 0 4px;
    max-width: 1640px;
    width: 100%;
}

/* .top-job-list */
.top-job-list {
    display: flex;
    margin-bottom: 60px;

    flex-wrap: wrap;
    justify-content: center;
}
.top-job-list-item {
    position: relative;
    display: flex;
    padding: 10px;
    width: 50%;
    text-align: left;
}
.top-job-list-item::after {
    position: absolute;
    bottom: 30px;
    left: 50%;
    display: block;
    margin-left: -8px;
    width: 12px;
    height: 12px;
    border-top: 2px solid #111;
    border-right: 2px solid #111;
    content: "";
    transform: rotate(135deg);
}
.top-job-list-item a {
    display: block;
    width: 100%;
    background-color: #fff;
    box-shadow: 0 5px 10px 0 rgba(0, 0, 0, .15);
    text-decoration: none;
    transition: all .3s ease;
}
.top-job-list-item a:hover {
    box-shadow: 0 5px 10px 0 rgba(0, 0, 0, .5);
}

/* .top-job-list-item .item-img */
.top-job-list-item .item-img {
    position: relative;
    overflow: hidden;
    height: 200px;
}
.top-job-list-item .item-img img {
    width: 100%;
    height: 100%;
    font-family: "object-fit: cover; object-position: 0 100%;"; /* IE対策 */
    transition: all .5s ease-in-out 0s;

    -o-object-position: 0 100%;
       object-position: 0 100%;
    -o-object-fit: cover;
       object-fit: cover;
}
.top-job-list-item .item-img-area {
    position: absolute;
    top: 10px;
    left: 10px;
    padding-right: 10px;
}
.top-job-list-item .item-img-area ul {
    font-size: 0;
}
.top-job-list-item .item-img-area ul li {
    display: inline-block;
    margin: .2em;
    padding: 2px 6px;
    border-radius: 4px;
    background-color: rgba(255, 255, 255, 1);
    color: #005baa;
    font-weight: 700;
    font-size: 1.2rem;
}

/* .top-job-list-item .item-box */
.top-job-list-item .item-box {
    padding: 20px 20px 40px 20px;
}
.top-job-list-item .item-box-ttl {
    position: relative;
    margin: 0 0 12px 0;
    padding: 0 0 12px 0;
    border-bottom: 1px dotted #e5e5e5;
    color: #020202;
    text-align: left;
    font-weight: 700;
    font-size: 1.8rem;
    font-family: "Noto Sans JP", sans-serif;
    line-height: 1.6;
}
.top-job-list-item .item-box-place {
    margin: 0 0 8px 0;
    padding: 0 0 8px 0;
    border-bottom: 1px dotted #e5e5e5;
    font-size: 1.4rem;
}
.top-job-list-item .item-box-list {
    margin: 0 0 8px 0;
    padding: 0 0 8px 0;
    min-height: 58px;
    border-bottom: 1px dotted #e5e5e5;
    font-size: 0;
}
.top-job-list-item .item-box-list li {
    display: inline-block;
    margin: 0 .4em .4em 0;
    padding: 5px;
    border-radius: 3px;
    /* border: 1px solid #999; */
    background-color: #f5f5f5;
    font-size: 1.2rem;
    line-height: 1;
}
.top-job-list-item .item-box-list li.on {
    background-color: #005baa;
    color: #fff;
}
.top-job-list-item .item-box-salary {
    margin: 0 0 8px 0;
    padding: 0 0 8px 0;
    border-bottom: 1px dotted #e5e5e5;
    font-weight: 700;
    font-size: 1.6rem;
}
.top-job-list-item .item-box-txt {
    margin: 0 0 8px 0;
    padding: 0 0 8px 0;
    /* border-bottom: 1px dotted #e5e5e5; */
    color: #020202;
    text-align: left;
    font-weight: 400;
    font-size: 1.2rem;
    line-height: 1.6;
}
.top-job-list-item .item-box-category {
    display: inline-block;
    margin: 0 .3em .3em 0;
    padding: 2px 6px;
    border-radius: 3px;
    /* border: 1px solid #e5e5e5; */
    background: #0070c0;
    color: #fff;
    font-size: 1.3rem;
}

/* .top-job-btn */
.top-job-btn {
    margin: 0 auto;
    max-width: 320px;
    text-align: center;
}
.top-job-btn .btn {
    display: block;
    margin: 15px 0 0 0;
    padding: 1em .5em;
    background: #0070c0;
    color: #fff;
    text-decoration: none;
}
.top-job-btn .btn:first-child {
    margin: 0;
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    .top-job-inner {
        padding: 0 10px;
    }
    .top-job-list-item {
        padding: 10px;
        width: 25%;
        font-size: 1.6rem;
    }
    .top-job-list-item .item-img {
        height: auto;
    }
    .top-job-list-item .item-box-ttl {
        font-size: 2.2rem;
        line-height: 1.4;
    }
    .top-job-list-item .item-box-txt {
        font-size: 1.4rem;
    }
    .top-job-list-item:hover .item-img img {
        transform: scale(1.05);
    }
    .top-job-btn .btn {
        margin: 0 0 0 15px;
    }
    .top-job-btn .btn .ico {
        margin-right: 15px;
        margin-left: 0;
    }
}


/* .top-campaign
-------------------------------------------------------- */
.top-campaign {
    display: flex;
    overflow: hidden;

    flex-wrap: wrap;
}
.top-campaign-inner {
    position: relative;
}
.top-campaign > a {
    display: flex;
    overflow: hidden;
    padding: 60px 0;
    width: 100%;
    color: #352d2a;
    text-decoration: none;

    align-items: center;
    justify-content: center;
}

/* .top-campaign-bg */
.top-campaign-bg {
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: -1;
    display: flex;
    width: 100%;
    height: 100%;
    background-position: 50%;
    background-size: cover;
    background-repeat: no-repeat;
    transition: all .3s ease 0s;
    transform: translate(-50%, -50%) scale(1.1);

    align-items: center;
    justify-content: center;
}
.top-campaign-bg.top-campaign-bg_01 {
    background-image: url(../../assets/img/home/bg_top-campaign_01.png);
}
.top-campaign-bg.top-campaign-bg_02 {
    background-image: url(../../assets/img/home/bg_top-campaign_02.png);
}

/* .top-campaign-box */
.top-campaign-box {
    display: block;
    padding: 2em;
    max-width: 700px;
    width: 85%;
    border-radius: 0;
    background-color: #fff;
    box-shadow: 0 8px 16px rgba(0, 0, 0, .12);
    text-align: center;
}
.top-campaign-box .box-label {
    display: inline-block;
    margin: 0 0 .5em;
    padding: .6em .8em;
    background-color: #5f3fa1;
    color: #fff;
    letter-spacing: .1em;
    font-weight: 500;
    font-size: 1.6rem;
    line-height: 1;
}
.top-campaign-box .box-ttl {
    margin: 0 0 .6rem;
    letter-spacing: 1px;
    font-weight: 700;
    font-size: 2.4rem;
    line-height: 1.6;
}
.top-campaign-box .box-txt {
    letter-spacing: 0;
    font-size: 1.4rem;
    line-height: 2;
}
.top-campaign-box .box-more {
    display: flex;
    padding: .8em .5em;
    border: 2px solid #5f3fa1;
    border-radius: 4px;
    color: #5f3fa1;
    letter-spacing: .05em;
    font-weight: 700;
    font-size: 1.3rem;
    line-height: 1.8;

    align-items: center;
    justify-content: center;
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    .top-campaign > a {
        padding: 96px 0;
        width: 50%;
    }
    .top-campaign > a:hover .top-campaign-bg {
        transform: translate(-50%, -50%) scale(1.15);
    }
    .top-campaign-box {
        padding: 2em;
        max-width: 700px;
        width: 85%;
        text-align: left;
    }
    .top-campaign-box .box-label {
        padding: .6em .8em;
        font-size: 2.0rem;
        line-height: 1;
    }
    .top-campaign-box .box-ttl {
        font-size: 3.4rem;
        line-height: 1.6;
    }
    .top-campaign-box .box-txt {
        font-size: 1.5rem;
        line-height: 2;
    }
}


/* .top-business
-------------------------------------------------------- */
.top-business {
    position: relative;
    padding: 60px 0;
    height: auto;
}
.top-business::before {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    display: block;
    overflow: hidden;
    width: 100%;
    height: 100%;
    /* background: rgba(0, 91, 172, .2) url(../../assets/img/common/bg_overlay_25.png) repeat 0 0; */
    background: rgba(0, 0, 0, .2);
    content: "";
}
.top-business.top-business-01 {
    background: url(../../assets/img/home/bg_top-business_01.jpg) no-repeat center top;
    background-size: cover;
}
.top-business.top-business-02 {
    background: url(../../assets/img/home/bg_top-business_02.jpg) no-repeat center top;
    background-size: cover;
}
.top-business-inner {
    position: relative;
    z-index: 2;
    margin: 0 auto;
    padding: 0 14px;
    max-width: 1640px;
    width: 100%;
}
.top-business-ttl {
    margin-bottom: 15px;
}
.top-business-ttl .en {
    position: relative;
    display: block;
    overflow: hidden;
    color: #fff;
    letter-spacing: .12em;
    font-weight: 400;
    font-size: 5rem;
    font-family: "Roboto", sans-serif;
    line-height: 1;
}
.top-business-ttl .ja {
    position: relative;
    display: inline-block;
    color: #fff;
    letter-spacing: .2em;
    font-weight: 400;
    font-size: 2rem;
}
.top-business-txt {
    margin-bottom: 20px;
    color: #fff;
    letter-spacing: .2em;
    font-size: 1.5rem;
}
.top-business-more {
    margin: 0 auto;
    width: 100%;
}
.top-business-more a {
    position: relative;
    display: block;
    padding: 28px 0 26px;
    border: 3px solid #fff;
    color: #fff;
    text-align: center;
    text-decoration: none;
    letter-spacing: .2em;
    font-size: 2rem;
    font-family: "Roboto", sans-serif;
    transition: .3s ease;
}
.top-business-more a::after {
    position: absolute;
    top: 50%;
    right: 15px;
    z-index: 3;
    display: inline-block;
    margin-top: 0;
    color: #fff;
    content: "\e848";
    font-weight: 400;
    font-size: 2.0rem;
    font-family: "webfont";
    transform: translate(0, -50%);
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    .top-business {
        padding: 240px 0;
        min-height: 1000px;
    }
    .top-business-inner {
        padding: 0 20px;
    }
    .top-business-ttl {
        margin-bottom: 58px;
    }
    .top-business-ttl .en {
        color: #fff;
        font-weight: 400;
        font-size: 12rem;
    }
    .top-business-ttl .ja {
        color: #fff;
        font-weight: 400;
        font-size: 3rem;
    }
    .top-business-txt {
        margin-bottom: 100px;
        font-size: 1.8rem;
    }
    .top-business-more {
        margin: 0;
        max-width: 350px;
    }
    .top-business-more a:hover {
        background-color: #fff;
        color: #020202;
    }
    .top-business-more a:hover::after {
        color: #020202;
    }
}


/* .top-oshirase
-------------------------------------------------------- */
.top-oshirase {
    margin: 0;
    padding: 40px 14px 20px;
    /* background-color: #45a4dd; */
}
.top-oshirase-inner {
    display: flex;
    margin: 0 auto 20px;
    padding: 20px 10px 30px;
    max-width: 1100px;
    width: 100%;
    border: 3px solid #cd162c;
    background-color: #fff;
    box-shadow: 0 4px 5px rgba(0, 0, 0, .05);

    flex-flow: column;
    justify-content: center;
    align-items: center;
    /* background: #fff url(../../assets/img/common/bg_ptn_35.png); */
}
.top-oshirase .txt {
    display: inline-block;
    margin-bottom: .2em;
    padding: .1em .5em;
    border-bottom: 2px solid #cd162c;
    color: #cd162c;
    text-align: center;
    letter-spacing: .1em;
    font-weight: 600;
    font-size: 1.5rem;
    font-family: "Noto Sans JP", sans-serif;
    line-height: 1.6;
}
.top-oshirase .txt span {
    font-size: 110%;
}
.top-oshirase .box {
    width: 100%;
    text-align: center;
}
.top-oshirase .box-ttl {
    margin: 0 0 1em;
    font-weight: 600;
    font-size: 1.8rem;
}
.top-oshirase .box-txt {
    margin: 0 0 1em;
    font-size: 1.8rem;
}
.top-oshirase .box .font-s {
    margin: 0 0 1em;
}
.top-oshirase .link {
    position: relative;
    display: block;
    margin: 0 auto;
    padding: 8px;
    max-width: 350px;
    width: 100%;
    border-radius: 100px;
    background-color: #cd162c;
    color: #fff;
    text-align: center;
}
.top-oshirase .link::before {
    position: absolute;
    top: 50%;
    right: 15px;
    margin-top: -4px;
    border-width: 4px 6px;
    border-style: solid;
    border-color: transparent transparent transparent #fff;
    content: "";
}
.top-oshirase .phone {
    display: flex;
    margin: 0 auto;
    font-size: 0;

    flex-flow: column;
    align-items: center;
    justify-content: center;
}
.top-oshirase .phone li {
    display: inline-block;
    overflow: hidden;
    margin: 10px auto 0;
    vertical-align: top;
}
/* .top-oshirase .phone li:first-child {
    margin-left: 0;
}
.top-oshirase .phone li:nth-child(3) {
    margin-left: 10px;
} */
.top-oshirase .phone-info {
    /* margin: 17px 0 0 0; */
    /* padding: 0 15px 0 15px; */
    /* border-left: 1px solid #d0d2db; */
    text-align: right;
}
.top-oshirase .phone-info-time {
    display: block;
    margin-top: 0;
    color: #020202;
    font-size: 1.2rem;
    line-height: 1.2;
}
.top-oshirase .phone-info-tel {
    display: block;
    margin-bottom: .5em;
    color: #cd162c;
    text-align: center;
    text-decoration: none;
    letter-spacing: -.02em;
    font-weight: 500;
    font-size: 4.4rem;
    font-family: "Barlow Semi Condensed", sans-serif;
    line-height: 1;
}
.top-oshirase .phone-info-tel a {
    color: #cd162c;
}
.top-oshirase .phone-info-tel .ico {
    position: relative;
    top: 0;
    margin-right: 8px;
    color: #cd162c;
    font-size: 74%;
}
.top-oshirase .phone-contact {
    margin-top: 4px;
}
.top-oshirase .phone-contact:hover {
    /* padding-top: 3px; */
}
.top-oshirase .phone-contact a {
    display: block;
    padding: 0;
    width: 260px;
    height: 52px;
    color: #cd162c;
    color: #fff;
    text-align: center;
    text-decoration: none;
    font-weight: 700;
    line-height: 52px;
}
.top-oshirase .phone-contact-inner a {
    position: relative;
    border-radius: 100px;
    /* background: linear-gradient(45deg, rgba(108, 210, 153, 1), #1ab4b0); */
    background: #cd162c;
    /* border-bottom: 3px solid #8c4202; */
    /* box-shadow: 0 3px 0 #8c4202; */
}
/* .top-oshirase .phone-contact-inner a::before {
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 0;
    border-width: 52px 250px 0 0;
    border-style: solid;
    border-color: rgba(255, 255, 255, .1) transparent transparent transparent;
    content: "";
    transition: all .3s ease;
} */
.top-oshirase .phone-contact:hover .top-oshirase .phone-contact-inner a {
    /* border-bottom: none; */
    box-shadow: none;
}
.top-oshirase .phone-contact-ico {
    /* display: block; */
    margin-right: 7px;
    font-size: 2.0rem;
    line-height: 1;
}
.top-oshirase .phone-contact-txt {
    /* display: block; */
    font-size: 1.2rem;
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    .top-oshirase {
        padding: 50px 14px 30px;
    }
    .top-oshirase .txt {
        margin-bottom: .5em;
        font-size: 2.6rem;
    }
    .top-oshirase .link:hover {
        background-color: #cc070f;
        color: #fff;
        text-decoration: none;
    }
    .top-oshirase .phone {
        margin: 0 auto;

        flex-flow: wrap;
    }
    .top-oshirase .phone li {
        margin: 0;
    }
    .top-oshirase .phone li:last-child {
        margin-left: 50px;
    }
    .top-oshirase .phone-info-time {
        font-size: 1.6rem;
    }
    .top-oshirase .phone-info-tel {
        margin-bottom: .1em;
        font-size: 6.0rem;
    }
    .top-oshirase .phone-contact a {
        width: 420px;
        height: 76px;
        line-height: 76px;
    }
    .top-oshirase .phone-contact-ico {
        font-size: 3.2rem;
    }
    .top-oshirase .phone-contact-txt {
        font-size: 2.2rem;
    }
}


/* .top-feature
-------------------------------------------------------- */
.top-feature {
    margin: 0;
    padding: 0;
    /* background-color: #45a4dd; */
    /* background: #fff url(../../assets/img/common/bg_ptn_35.png); */
}
.top-feature-inner {
    margin: 0 auto;
    padding: 0 14px;
    max-width: 1640px;
    width: 100%;
}

/* .top-feature-ttl */
.top-feature-ttl {
    position: relative;
    display: table;
    margin: 0 auto 55px;
    padding: 0 30px;
    color: #262626;
    text-align: center;
    letter-spacing: .12em;
    font-weight: 800;
    font-size: 3.2rem;
    font-family: "Noto Sans JP", sans-serif;
    line-height: 1.4;
}
.top-feature-ttl::before,
.top-feature-ttl::after {
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    width: 24px;
    height: 130px;
    content: "";
}
.top-feature-ttl::before {
    left: 0;
    background: url(../../assets/img/common/bg_top-feature-ttl_01.png) no-repeat center / cover;
}
.top-feature-ttl::after {
    right: 0;
    background: url(../../assets/img/common/bg_top-feature-ttl_02.png) no-repeat center / cover;
}
.top-feature-ttl .num {
    padding: 0 .05em;
    color: rgba(255, 96, 16, 1);
    font-size: 120%;
}
.top-feature-ttl .sub {
    position: relative;
    z-index: 0;
    display: table;
    overflow: hidden;
    margin: 10px auto 0;
    padding: 5px 35px;
    border: 0;
    border-radius: 50px;
    background: rgba(38, 38, 38, 1);
    color: #fff;
    font-size: 1.2rem;
}
.top-feature-ttl .sub::before {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    display: block;
    width: 60%;
    height: 100%;
    background: rgba(38, 38, 38, 1);
    content: "";
    transition: all .3s;

    clip-path: polygon(0% 0%, 65% 0%, 100% 100%, 0% 100%);
}

/* .top-feature-list */
.top-feature-list {
    display: flex;
    width: 100%;
    counter-reset: number 0;

    flex-flow: column;
    justify-content: center;
    align-items: center;
}
.top-feature-list-item {
    position: relative;
    padding: 0 0 50px;
    width: 100%;
}
.top-feature-list-item::before {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 3;
    color: rgba(255, 96, 16, 1);
    content: counter(number, decimal-leading-zero);
    counter-increment: number 1;
    font-weight: 700;
    font-size: 5.2rem;
    line-height: 1;
}
.top-feature-list-item .item-box {
    position: relative;
    display: flex;
    flex-direction: column;
    margin: 0 auto 20px;
    width: 250px;
    height: 250px;
    border-radius: 50%;
    background: #fff;

    align-items: center;
    justify-content: center;
}
.top-feature-list-item .item-ttl {
    position: relative;
    padding-top: 15px;
    line-height: 1.4;
}
.top-feature-list-item .item-ttl-copy,
.top-feature-list-item .item-ttl-point,
.top-feature-list-item .item-ttl-data,
.top-feature-list-item .item-ttl-note {
    display: block;
    color: #0d0d0d;
    text-align: center;
    font-weight: 600;
    font-family: "Noto Sans JP", sans-serif;
}
.top-feature-list-item .item-ttl-copy {
    display: table;
    margin: 0 auto;
    padding-bottom: 10px;
    border-bottom: 3px solid #0d0d0d;
    font-size: 1.8rem;
}
.top-feature-list-item .item-ttl-point {
    font-size: 2.0rem;
}
.top-feature-list-item .item-ttl-data {
    font-size: 2.4rem;
}
.top-feature-list-item .item-ttl-note {
    font-size: 1.4rem;
}
.top-feature-list-item .item-txt {
    padding: 0 .5em .5em;
    text-align: center;
    font-size: 1.6rem;
}

/* sp（0px～768px未満の場合に適用） */
@media (min-width: 0) and (max-width: 767.98px) {
    .top-feature-list {
        flex-flow: wrap;
        justify-content: center;
        align-items: flex-start;
    }
    .top-feature-list-item {
        width: 49%;
    }
    .top-feature-list-item::before {
        top: -30px;
    }
    .top-feature-list-item .item-box {
        width: 150px;
        height: 150px;
    }
    .top-feature-list-item .item-ttl-copy {
        font-size: 1.8rem;
    }
    .top-feature-list-item .item-ttl-point {
        font-size: 2.0rem;
    }
    .top-feature-list-item .item-ttl-data {
        font-size: 2.4rem;
    }
    .top-feature-list-item .item-ttl-note {
        font-size: 1.4rem;
    }
}

/* tb（768px～1200px未満の場合に適用） */
@media (min-width: 768px) and (max-width: 1199.98px) {
    .top-feature-list {
        flex-flow: wrap;
        justify-content: center;
        align-items: flex-start;
    }
    .top-feature-list-item {
        width: 49%;
    }
    .top-feature-list-item::before {
        top: -30px;
    }
    .top-feature-list-item .item-box {
        width: 250px;
        height: 250px;
    }
    .top-feature-list-item .item-ttl-copy {
        font-size: 1.8rem;
    }
    .top-feature-list-item .item-ttl-point {
        font-size: 3.0rem;
    }
    .top-feature-list-item .item-ttl-data {
        font-size: 3.4rem;
    }
    .top-feature-list-item .item-ttl-note {
        font-size: 1.4rem;
    }
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    .top-feature-inner {
        padding: 0 20px;
    }
    .top-feature-ttl {
        margin: 0 auto 85px;
        padding: 0 75px;
        letter-spacing: .12em;
        font-size: 4.8rem;
    }
    .top-feature-ttl::before,
    .top-feature-ttl::after {
        width: 16px;
        height: 90px;
    }
    .top-feature-ttl .num {
        font-size: 180%;
    }
    .top-feature-ttl .sub {
        margin: 5px auto 0;
        padding: 3px 25px;
        font-size: 1.6rem;
    }
    .top-feature-list {
        flex-flow: wrap;
        justify-content: center;
        align-items: flex-start;
    }
    .top-feature-list-item {
        width: calc(100% / 3);
    }
    .top-feature-list-item::before {
        font-size: 6.2rem;
    }
    .top-feature-list-item .item-ttl-copy {
        font-size: 2.8rem;
    }
    .top-feature-list-item .item-ttl-point {
        font-size: 3.8rem;
    }
    .top-feature-list-item .item-ttl-data {
        font-size: 4.2rem;
    }
    .top-feature-list-item .item-ttl-note {
        font-size: 1.6rem;
    }
}

/* pc（1400px以上の場合に適用） */
@media (min-width: 1400px) {
    .top-feature-list-item {
        width: calc(100% / 5);
    }
}


/* .top-realestate
-------------------------------------------------------- */
.top-realestate {
    margin: 0;
    padding: 0;
    width: 100%;
    background: transparent;
}
.top-realestate > div {
    z-index: 0 !important;
}
.top-realestate-inner {
    position: relative;
    z-index: 0;
    margin: 0 auto;
    /* padding: 0 14px;
    max-width: 1640px; */
    width: 100%;
}

/* .top-realestate-body */
.top-realestate-body {
    margin: 0;
    padding: 0;
    width: 100%;
}

/* .top-realestate-body-unit */
.top-realestate-body-unit {
    margin: 0;
    padding: 0;
    width: 100%;
}
.top-realestate-body-unit .unit-list {
    display: flex;
    width: 100%;
    transition: all .05s ease-in-out;

    flex-flow: column wrap;
    justify-content: flex-start;
    align-items: stretch;
}
.top-realestate-body-unit .unit-list-item {
    width: 100%;
    background: #fff;
    /* border-bottom: 1px solid #e9e9e9; */
}
.top-realestate-body-unit .unit-list-item a {
    position: relative;
    display: block;
    height: 100%;
    text-decoration: none;
    transition: all .3s ease-in-out;
}

/* .top-realestate-body-unit .post-body-top-realestate */
.top-realestate-body-unit .post-body-top-realestate {
    display: flex;
    height: 100%;

    flex-flow: column;
    justify-content: flex-start;
    align-items: stretch;
}

/* .post-body-top-realestate-thumbnail */
.top-realestate-body-unit .post-body-top-realestate-thumbnail {
    position: relative;
    width: 100%;
    background: #fff;
}

/* .post-body-top-realestate-detail */
.top-realestate-body-unit .post-body-top-realestate-detail {
    padding: .5em .5em;
}

/* .detail-code */
.top-realestate-body-unit .post-body-top-realestate-detail .detail-code {
    display: flex;
    margin: 0 0 0 0;
    padding: 0 0;
    width: 100%;
    /* border: 1px solid #ebf1ff; */
    /* border-radius: 20px; */
    /* background: #ebf1ff; */
    color: #6a85cd;

    flex-flow: wrap;
    justify-content: flex-start;
    align-items: center;
}
.top-realestate-body-unit .post-body-top-realestate-detail .detail-code dt {
    /* color: rgba(0, 159, 232, 1); */
    font-weight: 500;
    font-size: 1.0rem;
}
.top-realestate-body-unit .post-body-top-realestate-detail .detail-code dd {
    font-weight: 400;
    font-size: 1.2rem;
}

/* .detail-ttl */
.top-realestate-body-unit .post-body-top-realestate-detail .detail-ttl {
    margin-bottom: 1em;
    font-size: 1.3rem;
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    .top-realestate-body-unit .post-body-top-realestate-detail .detail-ttl {
        font-size: 1.5rem;
    }
}

/* .detail-txt */
.top-realestate-body-unit .post-body-top-realestate-detail .detail-txt {
    margin: 0 0 0;
    font-size: 1.4rem;
    line-height: 1.6;
}
.top-realestate-body-unit .post-body-top-realestate-detail .detail-txt .price {
    padding: 0 5px 0 0;
    color: #dc000c;
    font-weight: 900;
    font-size: 150%;
}
.top-realestate-body-unit .post-body-top-realestate-detail .detail-txt .price small {
    font-size: 60%;
}
.top-realestate-body-unit .post-body-top-realestate-detail .detail-txt .layout {
    padding: 0 0 0 5px;
}

/* .detail-dl */
.top-realestate-body-unit .post-body-top-realestate-detail .detail-dl {
    display: flex;
    margin-bottom: 10px;
    padding: 0;
    font-size: 1.0rem;
    line-height: 1.5;

    flex-flow: wrap;
}
.top-realestate-body-unit .post-body-top-realestate-detail .detail-dl dt,
.top-realestate-body-unit .post-body-top-realestate-detail .detail-dl dt + dd {
    display: inline-block;
    vertical-align: top;
}
.top-realestate-body-unit .post-body-top-realestate-detail .detail-dl dt + dd {
    margin: 0 0 .3em 0;
    /* display: inline-flex; */
    padding: .35em .85em;
    /* width: 35%; */

    align-items: center;
}
.top-realestate-body-unit .post-body-top-realestate-detail .detail-dl dt {
    display: inline-flex;
    margin: 0 0 .3em 0;
    padding: .3em .5em;
    width: 25%;
    /* padding: 0; */
    border: 1px solid #f5f4f0;
    /* border-radius: 4px; */
    background-color: #f5f4f0;
    color: #666;
    font-weight: 600;

    align-items: center;
    justify-content: center;
}
.top-realestate-body-unit .post-body-top-realestate-detail .detail-dl dd {
    margin: .5em 0;
    padding: 0;
    width: 75%;
}
.top-realestate-body-unit .post-body-top-realestate-detail .detail-dl .land-area,
.top-realestate-body-unit .post-body-top-realestate-detail .detail-dl .land-tsubo,
.top-realestate-body-unit .post-body-top-realestate-detail .detail-dl .land-transaction {
    /* display: inline-flex;
    margin-right: .5em; */
    align-items: center;
}

/* sp（0px～768px未満の場合に適用） */
@media (min-width: 0) and (max-width: 767.98px) {
    .top-realestate-body-unit .post-body-top-realestate-detail .detail-dl {
        justify-content: flex-start;
    }
    /* .top-realestate-body-unit .post-body-top-realestate-detail .detail-dl dt,
    .top-realestate-body-unit .post-body-top-realestate-detail .detail-dl dd {
        text-align: center;

        flex: 0 0 100%;
    } */
}

/* detail-comment */
.top-realestate-body-unit .post-body-top-realestate-detail .detail-comment {
    display: flex;
    padding: 0 0 0 0;
    width: 100%;
    /* border-top: 1px solid #ccc; */

    flex-flow: wrap;
    justify-content: space-between;
    align-items: flex-start;
    gap: .85em;
}
.top-realestate-body-unit .post-body-top-realestate-detail .detail-comment .img {
    margin-bottom: 20px;
    padding: 0;
    width: 25%;
    background: transparent;
}
.top-realestate-body-unit .post-body-top-realestate-detail .detail-comment .img img {
    border-radius: 0;
}
.top-realestate-body-unit .post-body-top-realestate-detail .detail-comment .dl {
    margin: 0 0 1.5em;
    padding: 0;
    border: 0;
    background: #fff;

    flex: 1;
}
.top-realestate-body-unit .post-body-top-realestate-detail .detail-comment .dl dt {
    margin: 0;
    padding: 0;
    background: transparent;
    color: #020202;
    font-size: 1.5rem;
}
.top-realestate-body-unit .post-body-top-realestate-detail .detail-comment .dl dt span {
    display: inline-block;
    margin: 0 .5em 3px 0;
    padding: 3px;
    border: 1px solid #807d79;
    background: #807d79;
    color: #fff;
    font-size: .75em;
    line-height: 1;
}
.top-realestate-body-unit .post-body-top-realestate-detail .detail-comment .comment-archive {
    font-size: 1.4rem;
}

/* .post-body-top-realestate-more */
.top-realestate-body-unit .post-body-top-realestate-more {
    margin-top: auto;
}
.top-realestate-body-unit .post-body-top-realestate-more a {
    position: relative;
    display: block;
    margin: 0;
    padding: .5em .5em;
    /* max-width: 280px; */
    width: 100%;
    height: 100%;
    border-radius: 0;
    background: #111;
    color: #fff;
    text-align: center;
    text-decoration: none;
    font-weight: 600;
    font-size: 1.3rem;
    line-height: 1.5;
    transition: all .3s ease-in-out;
}

/* .top-realestate-ftr */
.top-realestate-ftr {
    padding: 4em 0;
    text-align: center;
}
.top-realestate-ftr .btn {
    margin: 1.5em 0 0 0;
}
.top-realestate-ftr .btn:first-child {
    margin: 0;
}
.top-realestate-ftr .btn-top-realestate {
    padding: 16px 22px;
    width: 100%;
    border-radius: 4px;
    background: #1972b5;
    /* box-shadow: 0 3px 0 #004981; */
    color: #fff;
    font-weight: 700;
}
.top-realestate-ftr .btn-top-realestate .ico {
    position: relative;
    top: -2px;
    margin: 0 10px 0 0;
    color: #fff;
    font-size: 1.6rem;
}

/* sp（0px～768px未満の場合に適用） */
@media (min-width: 0) and (max-width: 767.98px) {
    /* .top-realestate-body-unit .unit-list */
    .top-realestate-body-unit .unit-list {
        flex-flow: row wrap;
    }
    .top-realestate-body-unit .unit-list-item {
        margin-top: 1%;
        margin-right: 1%;
        width: 49.5%;
    }
    .top-realestate-body-unit .unit-list-item:nth-child(1),
    .top-realestate-body-unit .unit-list-item:nth-child(2) {
        margin-top: 0;
    }
    .top-realestate-body-unit .unit-list-item:nth-child(2n) {
        margin-right: 0;
    }
}

/* tb（768px～1200px未満の場合に適用） */
@media (min-width: 768px) and (max-width: 1199.98px) {
    /* .top-realestate-body-unit .unit-list */
    .top-realestate-body-unit .unit-list {
        flex-flow: row wrap;
    }
    .top-realestate-body-unit .unit-list-item {
        margin-top: 1%;
        margin-right: 1%;
        width: 32.666666666666664%;
    }
    .top-realestate-body-unit .unit-list-item:nth-child(1),
    .top-realestate-body-unit .unit-list-item:nth-child(2),
    .top-realestate-body-unit .unit-list-item:nth-child(3) {
        margin-top: 0;
    }
    .top-realestate-body-unit .unit-list-item:nth-child(3n) {
        margin-right: 0;
    }
    .top-realestate-body-unit .unit-list-item .img {
        height: 280px;
    }
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    /* .top-realestate-inner {
        padding: 0 20px;
    } */
    .top-realestate-body-unit .unit-list-item a:hover {
        opacity: .6;
    }
    /* .top-realestate-body-unit .unit-list-item a::before {
        position: absolute;
        bottom: -1px;
        left: 0;
        z-index: 1;
        width: 0;
        height: 1px;
        background-color: #777;
        content: "";
        transition: all .3s ease-in-out;
    } */
    .top-realestate-body-unit .unit-list-item a:hover::before {
        width: 100%;
    }

    /* .top-realestate-body-unit .unit-list */
    .top-realestate-body-unit .unit-list {
        flex-flow: row wrap;
    }
    .top-realestate-body-unit .unit-list-item {
        margin-top: 1%;
        margin-right: 1%;
        width: 15.833333333333334%;
    }
    .top-realestate-body-unit .unit-list-item:nth-child(1),
    .top-realestate-body-unit .unit-list-item:nth-child(2),
    .top-realestate-body-unit .unit-list-item:nth-child(3),
    .top-realestate-body-unit .unit-list-item:nth-child(4),
    .top-realestate-body-unit .unit-list-item:nth-child(5),
    .top-realestate-body-unit .unit-list-item:nth-child(6) {
        margin-top: 0;
    }
    .top-realestate-body-unit .unit-list-item:nth-child(6n) {
        margin-right: 0;
    }
    .top-realestate-body-unit .unit-list-item .img {
        height: 300px;
    }
    .top-realestate-body-unit .unit-list-item .box-ttl {
        font-size: 2.2rem;
    }

    /* .top-realestate-ftr */
    .top-realestate-ftr {
        text-align: center;
    }
    .top-realestate-ftr .btn {
        margin: 0 0 0 1.5em;
        padding: 18px 18px;
    }
    .top-realestate-ftr .btn .ico {
        margin: 0 10px 0 0;
    }
    .top-realestate-ftr .btn-top-realestate {
        max-width: 320px;
        width: 40%;
    }
}
