@charset "utf-8";

/*

home.css
Version: 2023.04.29

*/

/* --------------------------------------------------------
/* .page-home
/* .bgswitcher-visual（bgswitcher-visual.js）
/* .bgswitcher-conversion（bgswitcher-conversion.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
-------------------------------------------------------- */


/* .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 - 170px) !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: "© AKARITERRACE 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: #020202;
    text-align: center;
    /* text-shadow: 0 0 8px rgba(0, 0, 0, .2); */
    letter-spacing: .01em;
    font-weight: 600;
    font-size: 4.0rem;
    line-height: 1.16;
}
.bgswitcher-conversion-box-ttl span {
    display: inline-block;
}
.bgswitcher-conversion-box-ttl span .very {
    display: inline;
    margin: 0 .2em;
    background: linear-gradient(transparent 67%, #ffe653 67%, #ffe653);
    font-size: 130%;
}
.bgswitcher-conversion-box-ttl .ttl-01 {
    margin: 0 0 .6em;
    padding: .4em .4em .5em;
    background: #fff;
    font-size: 2.6rem;
}
.bgswitcher-conversion-box-ttl .ttl-02 {
    margin: 0;
    padding: .4em .4em .5em;
    background: #fff;
    font-size: 2.6rem;
}
.bgswitcher-conversion-box-label {
    display: flex;
    margin: 0 0 25px;

    flex-flow: row wrap;
    align-items: center;
    justify-content: center;
}
.bgswitcher-conversion-box-label li {
    margin-right: .5em;
    margin-bottom: .5em;
    padding: .2em 1em;
    /* text-shadow: 0 0 2px rgba(0, 0, 0, .2); */
    border-radius: 4px;
    background-color: #015cac;
    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.8rem;
    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: 2.2rem;
    line-height: 1.4;
    transform: translate(-50%, -50%);
}
.bgswitcher-conversion-point li .no {
    position: absolute;
    top: -3px;
    left: 50%;
    z-index: 3;
    display: flex;
    padding: .2em .8em;
    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;
    }
}

/* 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 6%;
        min-height: 760px;
        height: calc(100vh - 170px) !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 30px;
        text-align: left;
    }
    .bgswitcher-conversion-box-ttl .ttl-01 {
        font-size: 5.0rem;
    }
    .bgswitcher-conversion-box-ttl .ttl-02 {
        font-size: 5.0rem;
    }
    .bgswitcher-conversion-box-label {
        justify-content: flex-start;
        align-items: flex-start;
    }
    .bgswitcher-conversion-box-label li {
        margin-right: .8em;
        margin-bottom: .8em;
        font-size: 1.8rem;
    }
    .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.5%;
        width: 166px;
    }
    .bgswitcher-conversion-point li .circle .txt {
        font-size: 3.2rem;
    }
    .bgswitcher-conversion-point li .no {
        max-width: 120px;
        font-size: 1.5rem;
    }
}


/* .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;
    }
    .vide-visual-catch {
        pointer-events: none; /* iPhone低電力モード対策 */
    }
}

/* 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 - 172px) !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-02 {
    padding: 40px 0 40px;
    background-color: rgba(255, 255, 255, 1);
}
.top-sect-03 {
    padding: 0 0 30px;
    /* border-bottom: 1px solid #ededed;
    background-color: rgba(255, 255, 255, 1); */
}
.top-sect-04 {
    padding: 0 0 40px;
}
.top-sect-05 {
    padding: 110px 0 110px;
    background: #fff url(../../assets/img/common/bg_top-sect-05.jpg) no-repeat center top / cover;
}
.top-sect-06 {
    padding: 30px 0 30px;
    background: #fff url(../../assets/img/common/bg_top-sect-06.jpg) no-repeat center top / cover;
}
.top-sect-07 {
    position: relative;
    overflow: hidden;
    padding: 0 0 0;
    width: 100%;
    /* background: #fff url(../../assets/img/common/bg_top-sect-04.jpg) repeat-y center bottom; */
    background: linear-gradient(90deg, #f7f7f7 50%, #fff 50%);
}
.top-sect-08 {
    padding: 110px 0 0;
}
.top-sect-09 {
    padding: 110px 0 0;
    border-top: 1px solid #ededed;
    border-bottom: 1px solid #ededed;
    background-color: rgba(255, 255, 255, 1);
}
.top-sect-10 {
    padding: 110px 0 110px;
}
.top-sect-11 {
    padding: 110px 0 110px;
    background-image: url(../../assets/img/common/bg_overlay_23.png), url(../../assets/img/common/bg_top-job.jpg);
    background-attachment: scroll, scroll;
    background-position: center center, left center;
    background-size: auto, cover;
    background-repeat: repeat, no-repeat;
}
.top-sect-12 {
    padding: 110px 0 110px;
    border-top: 1px solid #ededed;
    border-bottom: 1px solid #ededed;
    background-color: rgba(255, 255, 255, 1);
}
.top-sect-13 {
    padding: 110px 0 110px;
    background: url(../../assets/img/common/bg_top-picky.jpg) no-repeat center center;
    background-size: cover;
}
.top-sect-14 {
    padding: 0;
}
.top-sect-15 {
    position: relative;
    padding: 0;
}
.top-sect-15::before {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    display: block;
    width: 65vw;
    height: 100%;
    background-color: #ececec;
    background-image: -webkit-gradient(linear, 0 0, 100% 100%, color-stop(.25, #f9f9f9), color-stop(.25, transparent), color-stop(.5, transparent), color-stop(.5, #f9f9f9), color-stop(.75, #f9f9f9), color-stop(.75, transparent), to(transparent));
    -webkit-background-size: 12px 12px;
    content: "";
}
.top-sect-17 {
    padding: 110px 0 110px;
    border-top: 1px solid #ededed;
    border-bottom: 1px solid #ededed;
    background-color: rgba(255, 255, 255, 1);
}
.top-sect-20 {
    padding: 0;
}

/* .top-sect-inner */
.top-sect-inner {
    margin: 0 auto;
    padding: 0 14px;
    max-width: 1520px;
    width: 100%;
}
.top-sect-02 .top-sect-inner {
    margin: 0 auto;
    padding: 14px 14px;
    max-width: 1420px;
    width: 100%;
}
.top-sect-17 .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-02 .top-sect-inner {
        padding: 14px 20px;
    }
    .top-sect-17 .top-sect-inner {
        padding: 40px 40px;
    }
}

/* .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: 50%;
    left: 50%;
    z-index: 1;
    overflow: hidden;
    color: #f8f8f8;
    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 0 0;
    letter-spacing: .05em;
    font-weight: 600;
    font-size: 2.6rem;
    font-family: "Noto Sans JP", sans-serif;
    line-height: 1.4;
}
.top-sect-ttl .catch {
    position: relative;
    z-index: 3;
    display: inline-block;
    margin: 0 auto 0;
    padding: 0 20px 10px;
    /* border-bottom: 4px solid #1972b5; */
    color: #1972b5;
    letter-spacing: .05em;
    font-weight: 600;
    font-size: 1.6rem;
    font-family: "Noto Sans JP", sans-serif;
}

/* .top-sect-ttl .catch::after {
    position: absolute;
    top: auto;
    bottom: 0;
    left: 50%;
    display: block;
    margin: auto;
    width: 40px;
    height: 3px;
    background: #1972b5;
    content: "";
    transform: translateX(-50%);
} */

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

/* .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: 1520px;
    width: 100%;
    text-align: center;
    letter-spacing: .075em;
    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.6rem;
    }
    .top-sect-body-txt {
        padding: 0 14px;
    }
}


/* .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: #1972b5;
    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: #1972b5;
    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(25, 114, 181, 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(25, 114, 181, 1);
    border-bottom: 2px solid rgba(25, 114, 181, 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: #1972b5;
        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(25, 114, 181, 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: 4.054054054054055%; /* 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: 1520px; */
    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: 45.94594594594595%; /* 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: #1972b5;
    /* 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: #fff;
}
.top-grid > div {
    z-index: 0 !important;
}
.top-grid-inner {
    position: relative;
    z-index: 0;
    margin: 0 auto;
    padding: 0 14px;
    max-width: 1520px;
    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: 1em 1.2em;
    background-color: rgba(249, 96, 94, .9);
    color: #fff;
    text-align: center;
    font-weight: 700;
    font-size: 1.2rem;
    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: transparent;
    color: #020202;
    font-weight: 400;
    font-size: 1.1rem;
    line-height: 1;
}
.top-grid-list-item .box-category .category.information {
    border: 1px solid #ededed;
    background: transparent;
    color: #020202;
}
.top-grid-list-item .box-category .category.blog {
    border: 1px solid #ededed;
    background: transparent;
    color: #ffab3c;
}
.top-grid-list-item .box-category .category.campaign {
    border: 1px solid #ededed;
    background: transparent;
    color: #87c040;
}
.top-grid-list-item .box-category .category.event {
    border: 1px solid #ededed;
    background: transparent;
    color: #db4a39;
}
.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: 2%;
        margin-right: 2%;
        width: 32%;
    }
    .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-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: .15em;
    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: 1520px;
}
.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: 1520px;
    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: #1972b5;
    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.64864864864865%; /* 720.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: #1972b5;
    /* 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: #1972b5;
    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: 1520px;
    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: 1520px;
    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: .15em;
    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: #1972b5;
    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: 1520px;
    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: 1520px;
    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: #1972b5;
    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: #1972b5;
    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: 1520px;
    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: 30px;
    background-color: #f6f4e8;
}
.top-oshirase-inner {
    margin: 0 auto;
    padding: 20px;
    max-width: 1100px;
    width: 100%;
    background-color: #fff;
    box-shadow: 0 2px 4px rgba(0, 0, 0, .2);
    /* background: #fff url(../../assets/img/common/bg_ptn_35.png); */
}
.top-oshirase .txt {
    margin-bottom: 7px;
    color: #cd162c;
    text-align: center;
    letter-spacing: .1em;
    font-weight: 600;
    font-size: 2.4rem;
    font-family: "Noto Sans JP", sans-serif;
}
.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: "";
}

/* pc（1200px以上の場合に適用） */
@media (min-width: 1200px) {
    .top-oshirase .link:hover {
        background-color: #cc070f;
        color: #fff;
        text-decoration: none;
    }
}
