@charset "utf-8";

/*-----------------------------フォント*/
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Roboto:ital,wght@0,100..900;1,100..900&display=swap');

/*
font-family: "Noto Sans JP", serif;
font-family: "Roboto", serif;
*/

/*-----------------------------リセットCSS*/
html {
    box-sizing: border-box;
    -ms-overflow-style: scrollbar;
    overflow-x: hidden;
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

/* Remove default padding */

ul[class],
ol[class] {
    padding: 0;
}

/* Remove default margin */

body,
h1,
h2,
h3,
h4,
h5,
h6,
p,
ul[class],
ol[class],
figure,
blockquote,
dl,
dd {
    margin: 0;
}

/* Set core root defaults */

html {
    scroll-behavior: smooth;
}

/* Set core body defaults */

body {
    min-height: 100vh;
    text-rendering: optimizeSpeed;
    line-height: 100%;
}

/* Remove list styles on ul, ol elements with a class attribute */

ul[class],
ol[class] {
    list-style: none;
    padding: 0;
    margin: 0;
}

ul,
ol {
    list-style: none;
    padding: 0;
    margin: 0;
}

/* A elements that don't have a class get default styles */

a:not([class]) {
    -webkit-text-decoration-skip: ink;
    text-decoration-skip-ink: auto;
}

/* Make images easier to work with */

img {
    max-width: 100%;
    display: block;
}

/* Natural flow and rhythm in articles by default */

article>*+* {
    margin: 0;
}

/* Inherit fonts for inputs and buttons */

input,
button,
textarea,
select {
    font: inherit;
}

/* Blur images when they have no alt attribute */

/* Remove all animations and transitions for people that prefer not to see them */


img {
    height: auto;
}

address,
em {
    font-style: normal;
}

table {
    border-collapse: collapse;
}

input[type="text"],
input[type="tel"],
input[type="email"],
input[type="password"],
input[type="number"],
textarea {
    -webkit-appearance: none;
    border-radius: 0;
}

input[type="search"],
input[type="submit"],
input[type="button"] {
    -webkit-appearance: button;
    -moz-appearance: button;
    appearance: button;
    box-sizing: border-box;
    cursor: pointer;
}

input[type="search"]::-webkit-search-decoration,
input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
    display: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    clear: both;
    font-weight: normal;
}

/*-----------------------------初期値CSS*/
body {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.8;
    position: relative;
    background: #fff;
    color: #000;
    overflow-x: hidden;
}

a {
    text-decoration: none;
    color: #000;
    display: block;
    cursor: pointer;
    -webkit-text-decoration: none;
}

ul {
    margin: 0;
    padding: 0;
}

li {
    list-style: none;
}

.clearfix::after {
    content: "";
    display: block;
    clear: both;
}

/*スマホ時電話リンク*/
@media (min-width: 599px) {
    a[href*="tel:"] {
        pointer-events: none;
        cursor: default;
        text-decoration: none;
    }
}

/*iPhoneで画面サイズに合わせる*/
@supports (-webkit-touch-callout: none) {
    html {
        height: -webkit-fill-available;
    }

    body {
        min-height: 100vh;
        min-height: -webkit-fill-available;
    }
}

/*-----------------------------共通CSS*/
span.kai {
    display: inline-block;
}

.flex {
    display: flex;
    flex-wrap: wrap;
}

.inner {
    max-width: 1200px;
    width: calc(100% - 80px);
    margin: 0 auto;
    box-sizing: border-box;
}

.main.page .inner {
    max-width: 1105px;
}

.main.page .inner2 {
    max-width: 1200px;
}

a.anchor {
    display: block;
    padding-top: 85px;
    margin-top: -85px;
}

.sp {
    display: none;
}

.blue {
    color: #0E3B73;
}

.yellow {
    color: #FDD000;
}

.bold {
    font-weight: 700;
}

/*main*/
.pageSection {
    margin-top: 80px;
    margin-bottom: 120px;
}

/*modBtn1*/
.modBtn1 {
    width: 100%;
    max-width: 258px;
    margin: 0 0 0 auto;
}

.form .modBtn1 {
    margin: 0 auto;
}

.modBtn1 a,
.modBtn1 button,
.modBtn1 .a {
    position: relative;
    height: 54.08px;
    width: 100%;
    border-radius: 50px;
    overflow: hidden;
    background-color: #0E3B73;
    border: 1px solid rgba(255, 255, 255, 0);
    text-align: left;
    cursor: pointer;
}

.modBtn1 .a {
    display: block;
}

.modBtn1White a {
    background-color: #fff;
    border: 1px solid rgba(255, 255, 255, 0);
}

.caseTop .modBtn1 a {
    border: 1px solid #879DB9;
}

.modBtn1 a:hover,
.pageServiceDetail .flexBox5 .box:hover .modBtn1 .a {
    border: 1px solid rgba(255, 255, 255, 0);
}

.modBtn1White a:hover {
    border: 1px solid #879DB9;
}

.modBtn1 a .btnInner,
.modBtn1 .a .btnInner,
.modBtn1 button .btnInner {
    position: relative;
    font-size: 15px;
    font-weight: 700;
    color: #fff;
    padding: 12px 65px 12px 25px;
    display: block;
    background: url(../img/common/icon-right-white.svg) no-repeat center right 20px;
    background-size: 34.58px;
}

.modBtn1White a .btnInner {
    color: #0E3B73;
    background: url(../img/common/icon-right-blue.svg) no-repeat center right 20px;
    background-size: 34.58px;
}

.modBtn1 a:hover .btnInner,
.modBtn1 button:hover .btnInner,
.pageServiceDetail .flexBox5 .box:hover .modBtn1 .btnInner,
.modBtn1White a:hover .btnInner {
    color: #fff;
    background: url(../img/common/icon-right-hover.svg) no-repeat center right 20px;
    background-size: 34.58px;
}

.modBtn1 a::before,
.modBtn1 .a::before,
.modBtn1 button::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 100%;
    transition: all 0.2s ease 0s;
    background-color: #004EA2;
}

.modBtn1 a:hover::before,
.pageServiceDetail .flexBox5 .box:hover .a::before,
.modBtn1 button:hover::before {
    width: 100%;
}

/*modBtn2*/
.modBtn2 {
    width: 100%;
    max-width: 143px;
    margin: 0 0 0 auto;
}

.modBtn2 a {
    position: relative;
    height: 40px;
    width: 100%;
    border-radius: 50px;
    overflow: hidden;
    background-color: #F3F5F9;
    text-align: left;
    cursor: pointer;
}

.modBtn2 a .btnInner {
    position: relative;
    font-size: 14px;
    font-weight: 700;
    line-height: 1;
    color: #0E3B73;
    padding: 12px 55px 12px 15px;
    display: block;
    background: url(../img/common/icon-link-btn.svg) no-repeat center right 15px;
    background-size: 26px;
}

.modBtn2 a:hover .btnInner {
    color: #fff;
    background: url(../img/common/icon-link-btn-hover.svg) no-repeat center right 15px;
    background-size: 26px;
}

.modBtn2 a::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 100%;
    transition: all 0.2s ease 0s;
    background-color: #0E3B73;
}

.modBtn2 a:hover::before {
    width: 100%;
}

/*modBtn3*/
.modBtn3 {
    width: 100%;
    max-width: 339px;
}

.modBtn3 a {
    position: relative;
    height: 92.08px;
    border-radius: 50px;
    overflow: hidden;
    background-color: #F3F5F9;
    text-align: center;
    border: 1px solid rgba(255, 255, 255, 0);
}

.modBtn3 a:hover {
    border: 1px solid #879DB9;
}

.modBtn3 a .btnInner {
    position: relative;
    font-size: 22px;
    font-weight: 700;
    color: #0E3B73;
    padding: 26px 0 26px 51px;
    text-align: center;
    display: inline-block;
    background: url(../img/common/icon-mail.svg) no-repeat center left;
    background-size: 38.07px;
}

.modBtn3 a:hover .btnInner {
    color: #fff;
    background: url(../img/common/icon-mail-hover.svg) no-repeat center left;
    background-size: 38.07px;
}

.modBtn3 a::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 100%;
    transition: all 0.2s ease 0s;
    background-color: #0E3B73;
}

.modBtn3 a:hover::before {
    width: 100%;
}

/*sectionTitle*/
.sectionTitle {
    position: relative;
    margin-bottom: 37px;
}

.sectionTitle .en {
    font-family: "Roboto", serif;
    font-weight: bold;
    padding-left: 50px;
    background: url(../img/common/footerTitle.svg) no-repeat center left;
    background-size: 39.71px;
    color: #0E3B73;
}

.sectionTitleWhite .en {
    background: url(../img/common/footerTitleWhite.svg) no-repeat center left;
    background-size: 39.71px;
    color: #fff;
}

.sectionTitle .ja {
    font-size: 46px;
    font-weight: bold;
    line-height: 1.5;
}

.sectionTitleWhite .ja {
    color: #fff;
}

.sectionTitle .border {
    font-size: 15px;
    font-weight: 500;
    line-height: 1;
    padding: 5px 15px;
    border-radius: 50px;
    border: 1px solid #fff;
    margin: 0 0 15px 20px;
    display: inline-block;
    vertical-align: middle;
}

.sectionTitle .sub {
    position: relative;
    font-size: 24px;
    font-weight: bold;
    display: inline-block;
    padding-right: 64px;
}

.sectionTitle .sub::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    margin: auto;
    width: 55px;
    height: 2px;
    background-color: #000;
}

/*タイトル*/
.content h2 {
    position: relative;
    font-size: 32px;
    font-weight: 700;
    padding-left: 34px;
    margin-bottom: 40px;
    line-height: 1.4;
    background: url(../img/common/content-h2.svg) no-repeat top 13px left;
    background-size: 22px;
    margin-top: 70px;
}

.content h2:first-child {
    margin-top: 0;
}

.content h3 {
    position: relative;
    font-size: 26px;
    font-weight: 700;
    line-height: 1.4;
    padding-bottom: 15px;
    color: #0E3B75;
    margin-bottom: 40px;
    border-bottom: 2px solid #D6D6D6;
    margin-top: 40px;
}

.index .content h3 {
    font-size: 20px;
    line-height: 1.6;
    margin-bottom: 15px;
    margin-top: 0;
}

.content h3::before {
    content: "";
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 107px;
    height: 2px;
    background: #004EA2;
}

.content h4 {
    position: relative;
    font-size: 22px;
    font-weight: 700;
    line-height: 1.81;
    padding-left: 33px;
    margin-bottom: 18px;
    margin-top: 55px;
}

.content h4::before {
    content: "";
    position: absolute;
    top: 17px;
    left: 0;
    width: 23px;
    height: 6px;
    border-radius: 6px;
    background: #004EA2;
}

.content h5 {
    position: relative;
    font-size: 16px;
    font-weight: 700;
    padding-left: 17px;
    padding-bottom: 7px;
    margin-bottom: 5px;
    border-bottom: 1px solid #D6D6D6;
}

.content h5::before {
    content: "";
    position: absolute;
    top: 11px;
    left: 0;
    width: 8px;
    height: 8px;
    background: #004EA2;
}

/*link*/
.link {
    display: inline;
    color: #0E3B73;
    text-decoration: underline;
}

.link:hover {
    text-decoration: none;
}

/*ol*/
.content ol {
    counter-reset: item;
    margin: 14px 0 20px 0;
}

.content ol li {
    position: relative;
    text-indent: -1.0em;
    padding-left: 20px;
    margin-bottom: 3px;
}

.content ol li::before {
    counter-increment: item;
    content: counter(item)'.';
    padding-right: .5em;
}

/*ul*/
.content ul li {
    position: relative;
    padding-left: 22px;
    margin-bottom: 7px;
}

.content ul li::before {
    content: "・";
    position: absolute;
    top: 0;
    left: 0;
}

/*pageMv*/
.pageMv {
    padding-top: 156px;
    height: 285px;
    background: url(../img/common/page-bg-pc.webp) no-repeat bottom right;
    background-size: auto 100%;
    background-color: #F3F5F9;
    margin-bottom: 30px;
    border-radius: 0 0 80px 0;
}

.pageMv .en {
    font-weight: bold;
    padding-left: 32px;
    background: url(../img/common/footerTitle.svg) no-repeat center left;
    background-size: 26px;
    color: #0E3B73;
    margin-top: -14px;
}

.pageMv .title {
    position: relative;
    font-size: 46px;
    font-weight: 700;
    line-height: 1.413;
    color: #0E3B73;
}

/*パンくず*/
ul.breadcrumb {
    column-gap: 28px;
    margin: 0 auto;
}

.pageNewsSub ul.breadcrumb,
.pageCaseSub ul.breadcrumb {
    margin: 104px auto 0 auto;
}

.breadcrumb li {
    position: relative;
    font-size: 14px;
}

.breadcrumb li:not(:last-of-type)::before {
    content: "＞";
    font-size: 13px;
    position: absolute;
    top: 1px;
    right: -22px;
}

.breadcrumb li a {
    text-decoration: underline;
    transition: .3s;
}

.breadcrumb li a:hover {
    text-decoration: none;
    opacity: .7;
}

/*table*/
.table,
.table th,
.table td {
    border-collapse: collapse;
}

.table {
    width: 100%;
    border-top: 1px solid #D6D6D6;
}

.table th,
.table td {
    padding: 20px 35px;
    border-bottom: 1px solid #D6D6D6;
    text-align: left;
    vertical-align: top;
}

.table th {
    font-weight: bold;
    background: #F3F5F9;
    width: 223px;
    color: #0E3B73;
}

.table td {
    width: calc(100% - 223px);
}

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

    .inner {
        width: calc(100% - 32px);
    }

    a.anchor {
        display: block;
        padding-top: 60px;
        margin-top: -60px;
    }

    /*pageMv*/
    .pageMv {
        padding-top: 124px;
        height: 248px;
        background: url(../img/common/page-bg-sp.webp) no-repeat bottom right;
        background-size: auto 100%;
        background-color: #F3F5F9;
        margin-bottom: 22px;
        border-radius: 0 0 50px 0;
    }

    .pageMv .en {
        font-size: 14px;
        padding-left: 27px;
        background-size: 22.05px;
        margin-top: -8px;
    }

    .pageMv .title {
        font-size: 38px;
        line-height: 1.394;
    }

    .pageSection {
        margin-top: 55px;
        margin-bottom: 72px;
    }

    /*modBtn3*/
    .modBtn3 a .btnInner {
        font-size: 20px;
        padding: 26px 0 26px 42px;
        background: url(../img/common/icon-mail.svg) no-repeat center left;
        background-size: 33.3px;
    }

    .modBtn3 a:hover .btnInner {
        background: url(../img/common/icon-mail-hover.svg) no-repeat center left;
        background-size: 33.3px;
    }

    /*sectionTitle*/
    .sectionTitle {
        margin-bottom: 21px;
    }

    .sectionTitle .en {
        font-size: 14px;
        padding-left: 39px;
        background: url(../img/common/footerTitle.svg) no-repeat center left;
        background-size: 30px;
        margin-bottom: -13px;
    }

    .sectionTitleWhite .en {
        background: url(../img/common/footerTitleWhite.svg) no-repeat center left;
        background-size: 30px;
    }

    .sectionTitle .ja {
        font-size: 38px;
        line-height: 1.81;
    }

    .sectionTitleWhite .ja {
        color: #fff;
    }

    .sectionTitle .sub {
        font-size: 18px;
        padding-right: 48px;
        margin: 7px 0 0 0;
    }

    .sectionTitle .sub::before {
        width: 43.5px;
    }

    .pc {
        display: none;
    }

    .sp {
        display: block;
    }

    /*タイトル*/
    .content h2 {
        font-size: 28px;
        padding-left: 30px;
        margin-bottom: 40px;
        background: url(../img/common/content-h2.svg) no-repeat top 10px left;
        background-size: 20px;
        margin-top: 55px;
    }

    .content h3 {
        font-size: 22px;
        padding-bottom: 11px;
        margin-bottom: 32px;
        margin-top: 32px;
    }

    .index .content h3 {
        font-size: 18px;
    }

    .content h4 {
        font-size: 20px;
        line-height: 1.4;
        margin-bottom: 16px;
        margin-top: 30px;
    }

    .content h4::before {
        top: 12px;
    }

    /*table*/
    .table tr {
        border-bottom: 1px solid #D6D6D6;
    }

    .table th,
    .table td {
        font-size: 15px;
        display: block;
        border-bottom: none;
        padding: 11px 20px;
    }

    .table th {
        width: 100%;
        max-width: 100%;
        border-bottom: 1px solid #CFD8E3;
    }

    .table td {
        width: 100%;
    }

    .pageNewsSub ul.breadcrumb,
    .pageCaseSub ul.breadcrumb {
        margin: 73px auto 0 auto;
    }

}

/*--------------------------------------------------------------------------------------------------------------------

ヘッダー

--------------------------------------------------------------------------------------------------------------------*/
.header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    background: #fff;
    z-index: 500;
    height: 90px;
    width: 100%;
    transition: .3s;
    border-radius: 0 0 10px 10px;
    justify-content: flex-end;
}

/*-----------------------------左ロゴ*/
.header .logo {
    position: absolute;
    top: 18px;
    left: 40px;
}

.header .logo a {
    transition: .3s;
}

.header .logo a:hover {
    opacity: .5;
}

.header .logo a img {
    max-width: 315.21px;
    width: 22.515vw;
}

/*-----------------------------メニュー*/
.header .nav {
    padding: 14px 28px 0 0;
}

/*上段*/
.header .navBtnBox {
    justify-content: flex-end;
    column-gap: 10px;
}

.header .navBtnBox .navBtn a {
    position: relative;
    border-radius: 50px;
    overflow: hidden;
    background-color: #F3F5F9;
    height: 26px;
}

.header .navBtnBox .navBtn:first-child a {
    width: 141px;
}

.header .navBtnBox .navBtn:last-child a {
    width: 106px;
}

.header .navBtnBox .navBtn a::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 100%;
    transition: all 0.2s ease 0s;
    background-color: #0E3B73;
}

.header .navBtnBox .navBtn a:hover::before {
    width: 100%;
}

.header .navBtnBox .navBtn a .btnInner {
    position: relative;
    font-size: 14px;
    font-weight: 500;
    line-height: 1;
    color: #0E3B73;
    padding: 6px 11px 6px 32px;
    display: inline-block;
    vertical-align: top;
}

.header .navBtnBox .navBtn a:hover .btnInner {
    color: #fff;
}

.header .navBtnBox .navBtn:first-child a .btnInner {
    background: url(../img/common/icon-calendar.svg) no-repeat center left 11px;
    background-size: 16px;
}

.header .navBtnBox .navBtn:last-child a .btnInner {
    padding: 6px 11px 6px 36px;
    background: url(../img/common/icon-recruit.svg) no-repeat center left 13px;
    background-size: 18px;
}

.header .navBtnBox .navBtn:first-child a:hover .btnInner {
    background: url(../img/common/icon-calendar-white.svg) no-repeat center left 11px;
    background-size: 16px;
}

.header .navBtnBox .navBtn:last-child a:hover .btnInner {
    background: url(../img/common/icon-recruit-white.svg) no-repeat center left 13px;
    background-size: 18px;
}

/*下段*/
.header .navListBox {
    justify-content: flex-end;
}

.header .navListBox li {
    position: relative;
    display: flex;
}

.header .navListBox li::before {
    content: "";
    position: absolute;
    top: 11px;
    right: 0;
    width: 1px;
    height: calc(100% - 22px);
    background-color: #B9B9B9;
}

.header .navListBox li .main {
    position: relative;
    font-size: 16px;
    font-weight: 500;
    height: 100%;
    padding: 9px 20px;
    display: flex;
    align-items: center;
    z-index: 1;
}

.header .navListBox li:hover .main {
    color: #074A97;
}

.header .navListBox li.menu1 .main::before {
    content: "";
    position: absolute;
    top: 11px;
    left: 0;
    width: 1px;
    height: calc(100% - 22px);
    background-color: #B9B9B9;
}

.header .navListBox a {
    position: relative;
}

.header .navListBox li::after {
    content: '';
    position: absolute;
    bottom: 10px;
    left: 20px;
    width: 0;
    height: 1px;
    transition: all 0.2s ease 0s;
    background-color: #0E3B73;
}

.header .navListBox li:hover::after {
    width: calc(100% - 40px);
}

/*ドロップダウン*/
.header .nav .subMenu {
    width: 100%;
    position: absolute;
    top: 47px;
    left: 50%;
    transform: translateX(-50%);
    margin: auto;
    transition: .2s;
    background: #fff;
    height: auto;
    border-radius: 10px;
    padding: 13px 20px;
    opacity: 0;
    pointer-events: none;
    min-width: 158px;
    box-shadow: 0px 3px 3px 0px rgba(116, 95, 10, .16);
}

.header .navListBox li.sub:hover .subMenu {
    opacity: 1;
    z-index: 1;
    pointer-events: all;
}

.header .nav .subMenu li {
    display: block;
}

.header .nav .subMenu li::before {
    display: none;
}

.header .nav .subMenu li a {
    position: relative;
    font-size: 14px;
    font-weight: 500;
    padding: 5px 0 5px 18px;
}

.header .nav .subMenu li a::before {
    content: "";
    position: absolute;
    top: 17px;
    left: 0;
    width: 12px;
    height: 1px;
    background-color: #0E3B73;
}

.header .nav .subMenu li::after {
    display: none;
}

.header .nav .subMenu li a .btnInner {
    position: relative;
}

.header .nav .subMenu li a .btnInner::after {
    content: '';
    position: absolute;
    bottom: -3px;
    left: 0;
    width: 0;
    height: 1px;
    transition: all 0.2s ease 0s;
    background-color: #0E3B73;
}

.header .navListBox li a:hover .btnInner::after {
    width: 100%;
}

/*------------ボタン*/
.header .headerBtn {
    width: 134px;
}

.header .headerBtn a {
    position: relative;
    height: 90px;
    border-radius: 0 0 10px 10px;
    overflow: hidden;
    background-color: #004EA2;
}

.header .headerBtn a::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 100%;
    transition: all 0.2s ease 0s;
    background-color: #0E3B73;
}

.header .headerBtn a:hover::before {
    width: 100%;
}

.header .headerBtn a .btnInner {
    position: relative;
    font-weight: 700;
    color: #fff;
    padding-top: 42px;
    text-align: center;
    display: block;
}

.header .headerBtn a .btnInner {
    background: url(../img/common/icon-mail.svg) no-repeat center top 22px;
    background-size: 22px;
}

.header .headerBtn a:hover .btnInner {
    background: url(../img/common/icon-mail-hover.svg) no-repeat center top 22px;
    background-size: 22px;
}

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

    .header {
        height: 60px;
    }

    .header .nav,
    .header .headerBtn {
        display: none;
    }

    .header .logo {
        top: 11px;
        left: 16px;
    }

    .header .logo a img {
        max-width: 100%;
        width: 224.02px;
    }

}

/*--------------------------------------------------------------------------------------------------------------------

ハンバーガーメニュー

--------------------------------------------------------------------------------------------------------------------*/
.hamburger {
    display: none;
}

/*----------------------------------------------------------------------三本ライン*/
.hamburger .line {
    position: fixed;
    top: 0;
    right: 0;
    display: flex;
    height: 60px;
    width: 60px;
    justify-content: center;
    align-items: center;
    z-index: 999999;
    cursor: pointer;
    border-radius: 0 0 10px 10px;
    background-color: #0E3B73;
}

.hamburger .line span,
.hamburger .line span:before,
.hamburger .line span:after {
    content: '';
    display: block;
    height: 1px;
    width: 21px;
    background-color: #fff;
    position: absolute;
}

.hamburger .line span {
    right: 19px;
}

/*.line1*/
.hamburger .line span.line1:before {
    bottom: 6px;
    left: 0;
}

.hamburger .line span.line1:after {
    top: 6px;
    left: 0;
}

/*open*/
.hamburger .line.is-activeLine span.line1 {
    right: 17px;
    background-color: rgba(255, 255, 255, 0);
    /*メニューオープン時は真ん中の線を透明にする*/
}

.hamburger .line.is-activeLine span.line1::before {
    bottom: 0;
    width: 21px;
    transform: rotate(45deg);
}

.hamburger .line.is-activeLine span.line1::after {
    top: 0;
    width: 21px;
    transform: rotate(-45deg);
}

/* アニメーション前のメニューの状態 */
.hamburger .line.is-activeLine span.line1 {
    pointer-events: auto;
    opacity: 1;
}

/* アニメーション後のメニューの状態 */
.hamburger .line.is-activeLine span.line1 {
    pointer-events: none;
    opacity: 0;
}

.hamburger .line.is-activeLine span.line1 {
    pointer-events: none;
    opacity: 0;
}

/* アニメーション後のメニューの状態 */
.hamburger .line.is-activeLine span.line1 {
    pointer-events: auto;
    opacity: 1;
}

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

    .hamburger {
        display: block;
    }

}

/*-----------------------------------------------------------------------中のメニュー*/
.hamburger .menu {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: scroll;
    -webkit-overflow-scrolling: touch;
    box-sizing: border-box;
    /* 追加 */
    z-index: 80;
    background: #F3F5F9;
    padding: 61px 16px 20px 16px;
}

.hamburger .menu ul.menuList li {
    border-bottom: 1px solid rgba(14, 59, 115, .20);
}

.hamburger .menu ul.menuList .main {
    font-weight: 700;
    position: relative;
    width: 100%;
    padding: 15px 0;
}

.hamburger .menu ul.menuList .main.light {
    font-size: 14px;
    font-weight: 500;
    margin-bottom: 30px;
}

/*動き*/
/* アニメーション前のメニューの状態 */
.hamburger .menu {
    pointer-events: none;
    opacity: 0;
    transition: .3s;
}

/* アニメーション後のメニューの状態 */
.hamburger .menu.is-active {
    pointer-events: auto;
    opacity: 1;
}

/*---------------アコーディオン*/
.hamburger .menu ul.menuList li.sub {
    position: relative;
}

.hamburger .menu ul.menuList li .toggleBtn {
    display: block;
    position: absolute;
    top: 22px;
    cursor: pointer;
    width: 16px;
    height: 16px;
    right: 0;
}

.hamburger .child {
    display: none;
}

.hamburger .toggleBtn::before {
    /* アイコン横棒 */
    content: '';
    height: 2px;
    width: 16px;
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    margin: auto;
    background: #0E3B73;
}

.hamburger .toggleBtn:after {
    /* アイコン縦棒（閉じてるとき） */
    content: '';
    height: 16px;
    width: 2px;
    display: block;
    background: #0E3B73;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
}

.hamburger .toggleBtn.is-active:after {
    /* アイコン縦棒なし（開いてるとき） */
    height: 0;
    width: 0;
}

.hamburger .menu ul.menuList .subMenu.child {
    margin: 0 0 10px 15px;
}

.hamburger .menu ul.menuList .subMenu.child li {
    border-bottom: none;
}

.hamburger .menu ul.menuList .subMenu.child li a {
    position: relative;
    font-size: 14px;
    font-weight: 500;
    padding: 5px 18px;
}

.hamburger .menu ul.menuList .subMenu.child li a::before {
    content: "";
    position: absolute;
    top: 17px;
    left: 0;
    width: 12px;
    height: 1px;
    background-color: #0E3B73;
}

.hamburger .menu ul.menuList .subMenu.child li:first-child a {
    padding-top: 0;
}

.hamburger .menu ul.menuList .subMenu.child li:first-child a::before {
    top: 12px;
}

/*btnrecruitTop*/
.btnRecruit {
    margin-bottom: 12px;
}

.btnRecruit a {
    position: relative;
    height: 50px;
    border-radius: 10px;
    overflow: hidden;
    background-color: #81C026;
    text-align: center;
}

.btnRecruit a .btnInner {
    position: relative;
    font-size: 18px;
    font-weight: 700;
    padding-top: 10px;
    display: inline-block;
    padding: 8px 26px 0 36px;
}

.btnRecruit a .btnInner {
    background-image: url(../img/common/icon-recruit-1.svg), url(../img/common/icon-link.svg);
    background-repeat: no-repeat, no-repeat;
    background-position: top 10px left, top 17px right;
    background-size: 30.64px, 14px;
}

/*btnContact*/
.btnContact a {
    position: relative;
    height: 50px;
    border-radius: 10px;
    overflow: hidden;
    color: #fff;
    background-color: #0E3B73;
    text-align: center;
}

.btnContact a .btnInner {
    position: relative;
    font-size: 18px;
    font-weight: 700;
    padding-top: 10px;
    display: inline-block;
    padding: 8px 0 8px 36px;
}

.btnContact a .btnInner {
    background: url(../img/common/icon-mail.svg) no-repeat center left;
    background-size: 22.14px;
}

/*--------------------------------------------------------------------------------------------------------------------

固定要素
--------------------------------------------------------------------------------------------------------------------*/
.fixed {
    position: fixed;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    margin: auto;
    width: 53px;
    height: 411px;
    z-index: 11;
}

/*btnrecruitTop*/
.fixed .btnRecruit a {
    position: relative;
    height: 200px;
    width: 53px;
    border-radius: 10px 0 0 10px;
    overflow: hidden;
    background-color: #81C026;
    text-align: center;
    padding-top: 32px;
}

.fixed .btnRecruit a::before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 0;
    transition: all 0.2s ease 0s;
    background-color: #609A0B;
}

.fixed .btnRecruit a:hover::before {
    height: 100%;
}

.fixed .btnRecruit a .btnInner {
    position: relative;
    font-size: 18px;
    font-weight: 700;
    padding-top: 10px;
    text-align: center;
    display: inline-block;
    padding: 32px 5px 22px 5px;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    letter-spacing: .1em;
}

.fixed .btnRecruit a:hover .btnInner {
    color: #fff;
}

.fixed .btnRecruit a .btnInner {
    background-image: url(../img/common/icon-recruit-1.svg), url(../img/common/icon-link.svg);
    background-repeat: no-repeat, no-repeat;
    background-position: top left 8px, bottom center;
    background-size: 30.64px, 14px;
}

.fixed .btnRecruit a:hover .btnInner {
    background-image: url(../img/common/icon-recruit-1-hover.svg), url(../img/common/icon-link-hover.svg);
}

/*btnContact*/
.fixed .btnContact a {
    position: relative;
    height: 200px;
    width: 53px;
    border-radius: 10px 0 0 10px;
    overflow: hidden;
    background-color: #004EA2;
    text-align: center;
    padding-top: 30px;
}

.fixed .btnContact a::before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 0;
    transition: all 0.2s ease 0s;
    background-color: #0E3B73;
}

.fixed .btnContact a:hover::before {
    height: 100%;
}

.fixed .btnContact a .btnInner {
    position: relative;
    font-size: 18px;
    font-weight: 700;
    padding-top: 10px;
    text-align: center;
    display: inline-block;
    padding: 30px 5px 0 5px;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    letter-spacing: .1em;
}

.fixed .btnContact a:hover .btnInner {
    color: #fff;
}

.fixed .btnContact a .btnInner {
    background: url(../img/common/icon-mail.svg) no-repeat top center;
    background-size: 22.14px;
}

.fixed .btnContact a:hover .btnInner {
    background: url(../img/common/icon-mail-hover.svg) no-repeat top center;
    background-size: 22.14px;
}

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

    .fixed {
        top: auto;
        bottom: 0;
        transform: none;
        margin: 0;
        width: 100%;
        height: 50px;
        column-gap: 6px;
        justify-content: space-between;
    }

    .fixed .btnRecruit,
    .fixed .btnContact {
        width: calc(50% - 3px);
    }

    .fixed .btnRecruit a,
    .fixed .btnContact a {
        height: 50px;
        width: 100%;
        border-radius: 10px 10px 0 0;
        padding-top: 0;
    }

    .fixed .btnRecruit a::before,
    .fixed .btnContact a::before {
        bottom: auto;
        top: 0;
        width: 0;
        height: 100%;
    }

    .fixed .btnRecruit a:hover::before,
    .fixed .btnContact a:hover::before {
        width: 100%;
    }

    .fixed .btnRecruit a .btnInner,
    .fixed .btnContact a .btnInner {
        padding: 8px 26px 0 36px;
        -ms-writing-mode: inherit;
        writing-mode: inherit;
        letter-spacing: 0;
    }

    .fixed .btnContact a .btnInner {
        padding: 8px 0 8px 36px;
    }

    .fixed .btnRecruit a .btnInner {
        background-image: url(../img/common/icon-recruit-1.svg), url(../img/common/icon-link.svg);
        background-repeat: no-repeat, no-repeat;
        background-position: top 10px left, top 17px right;
        background-size: 30.64px, 14px;
    }

    .fixed .btnRecruit a:hover .btnInner {
        background-image: url(../img/common/icon-recruit-1-hover.svg), url(../img/common/icon-link-hover.svg);
    }

    .fixed .btnContact a .btnInner {
        background: url(../img/common/icon-mail.svg) no-repeat center left;
        background-size: 22.14px;
    }

    .fixed .btnContact a:hover .btnInner {
        background: url(../img/common/icon-mail-hover.svg) no-repeat center left;
        background-size: 22.14px;
    }

}

/*fixed-banner*/
.fixed-banner {
    position: fixed;
    bottom: 46px;
    right: 58px;
    z-index: 100;
}

.fixed-banner a {
    width: 220px;
    height: 183px;
    background: url(../img/common/banner-pc.jpg) no-repeat center;
    background-size: cover;
    border: 1px solid rgba(0, 0, 0, 0);
    box-shadow: 0px 0px 6px 3px rgba(116, 95, 10, .13);
    transition: .3s;
}

.fixed-banner a:hover {
    background: url(../img/common/banner-pc-hover.jpg) no-repeat center;
    background-size: cover;
    border: 1px solid #B3B3B3;
}

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

    .fixed-banner {
        position: fixed;
        flex-direction: column;
        bottom: 0;
        right: 0;
        z-index: 100;
        width: 100%;
    }

    .fixed-banner a {
        width: 100%;
        height: 100%;
        background: none;
        border: none;
        box-shadow: none;
    }

    .fixed-banner a:hover {
        background: none;
        border: none;
    }

}

/*--------------------------------------------------------------------------------------------------------------------

フッター
--------------------------------------------------------------------------------------------------------------------*/
.footer {
    position: relative;
}

.footerBg {
    background-color: #F3F5F9;
}

.footer .en-text {
    position: absolute;
    top: max(-115px, -8vw);
    left: 50%;
    transform: translateX(-50%);
    margin: auto;
    width: 100%;
    font-family: "Zen Kaku Gothic New", serif;
    font-size: min(116px, 8vw);
    font-weight: 900;
    line-height: 1.4;
    color: #FFF100;
    text-align: center;
}

/*footer-top*/
.footer .top {
    background: #0E3B73;
    border-radius: 80px 80px 0 0;
    min-height: 378.56px;
}

.footer .top .inner {
    max-width: 1320px;
    padding: 85px 60px;
    background: url(../img/common/footer-contact.png) no-repeat top 20px left;
    background-size: 486.7px;
    justify-content: space-between;
}

.footer .top .left {
    width: 300px;
}

.footer .top .right {
    min-width: 693.16px;
    align-items: center;
    justify-content: space-between;
    row-gap: 35px;
    column-gap: 35px;
    text-align: center;
    padding-top: 34px;
}

.footer .top .right .modBtn3 {
    margin-top: 12px;
}

.footer .top .right .telBox {
    max-width: 282px;
}

.footer .top .right .telBox .text {
    font-weight: bold;
    padding: 3px 22px 2px 22px;
    border-radius: 50px;
    color: #fff;
    border: 1px solid #879DB9;
    margin-bottom: 20px;
    display: inline-block;
}

.footer .top .right .telBox .num,
.footer .top .right .telBox .num a {
    font-family: "Roboto", serif;
    font-weight: bold;
    font-size: 36px;
    line-height: 1;
    color: #fff;
    margin-bottom: 5px;
    display: inline-block;
    text-align: left;
}

.footer .top .right .telBox .num .small {
    font-size: 22px;
    display: inline-block;
    width: 47px;
}

.footer .top .right .telBox .cm {
    font-size: 14px;
    font-weight: 500;
    color: #fff;
    margin-top: 5px;
    line-height: 1;
}

/*footer-bottom*/
.footer .bottom {
    position: relative;
    background: #F3F5F9;
    padding-bottom: 72px;
}

.footer .bottom .bottomInner {
    row-gap: 30px;
    max-width: 1320px;
    padding: 88px 60px 0px 60px;
    background: url(../img/common/footer-img.png) no-repeat bottom left;
    background-size: 395.5px;
    justify-content: space-between;
}

.footer .bottom .flex .box {
    margin-bottom: 0;
}

/*left*/
.footer .bottom .flex .left .logo {
    transition: .3s;
}

.footer .bottom .flex .left .logo:hover {
    opacity: .5;
}

.footer .bottom .flex .left .logo img {
    margin-bottom: 10px;
}

.footer .bottom .flex .left .text {
    font-size: 15px;
    padding-left: 7px;
    margin-bottom: 13px;
}

.footer .bottom .flex .left .text a {
    display: inline-block;
}

/*fotterTitle*/
.fotterTitle {
    font-weight: bold;
    padding-left: 30px;
    background: url(../img/common/footerTitle.svg) no-repeat center left;
    background-size: 23.39px;
    color: #0E3B73;
}

.footer .bottom .flex .left .fotterTitle {
    margin-left: 7px;
}

.fotterTitle a {
    display: inline-block;
    vertical-align: middle;
    margin-left: 15px;
}

.fotterTitle a:hover {
    opacity: .5;
}

/*right*/
.footer .bottom .flex .right {
    border-top: 1px solid rgba(14, 59, 115, .20);
    border-bottom: 1px solid rgba(14, 59, 115, .20);
    padding-right: 52px;
    column-gap: 36px;
    width: 685.5px;
    justify-content: space-between;
    padding-bottom: 8px;
}

.footer .menu li .main {
    position: relative;
    font-weight: 700;
    padding: 15px 21px;
    color: #0E3B73;
    border-bottom: 1px solid rgba(14, 59, 115, .20);
    height: 62px;
    min-width: 170px;
}

.footer .menu .box2 li:last-child .main {
    border-bottom: none;
}

.footer .menu .sub {
    border-bottom: 1px solid rgba(14, 59, 115, .20);
}

.footer .menu .sub1 {
    height: 186px;
}

.footer .menu .sub2 {
    height: 124px;
    border-bottom: none;
}

.footer .menu .sub .main {
    border-bottom: none;
    padding: 15px 21px 5px 21px;
    height: 50px;
}

.footer .menu .main img {
    display: inline-block;
    margin: 0 0 0 8px;
    width: 14px;
}

.footer .menu li:first-child .main {
    margin-top: 0;
}

.footer .menu li .main {
    color: #074A97;
    transition: .3s;
}

.footer .menu .subMenu {
    padding: 0 0 10px 21px;
}

.footer .menu .subMenu li a {
    position: relative;
    font-size: 14px;
    font-weight: 500;
    margin-bottom: 5px;
    transition: .3s;
    padding-left: 18px;
}

.footer .menu .subMenu li a::before {
    content: "";
    position: absolute;
    top: 15px;
    left: 0;
    width: 12px;
    height: 1px;
    background-color: #0E3B73;
}

.footer .menu li a .btnInner {
    position: relative;
}

.footer .menu li a .btnInner::after {
    content: '';
    position: absolute;
    bottom: -3px;
    left: 0;
    width: 0;
    height: 1px;
    transition: all 0.2s ease 0s;
    background-color: #0E3B73;
}

.footer .menu li a:hover .btnInner::after {
    width: 100%;
}

/*box3*/
.footer .box3 .fotterTitle {
    padding-top: 14px;
    padding-bottom: 14px;
}

.footer .banner a {
    width: 100%;
    background-color: #fff;
    transition: .3s;
    margin-bottom: 16px;
}

.footer .banner a:hover {
    opacity: 1;
    background-color: rgba(126, 206, 244, .5);
}

.footer .policy-wrap {
    position: absolute;
    bottom: 30px;
    left: calc(50% + 445px);
}

.footer .policy-wrap a {
    font-size: 14px;
    font-weight: 500;
    padding: 0;
    color: #676767;
    border-bottom: none;
    height: auto;
    min-width: auto;
}

.footer .policy-wrap a::after {
    content: '';
    position: absolute;
    bottom: -0px;
    left: 0;
    width: 0;
    height: 1px;
    transition: all 0.2s ease 0s;
    background-color: #787777;
}

.footer .policy-wrap a:hover::after {
    width: 100%;
}

/*bannerBox*/
.footer .bannerBox {
    background-color: #DEE8F5;
    padding: 33px 0;
}

.footer .bannerBox .flex {
    column-gap: 20px;
    row-gap: 16px;
    justify-content: space-between;
    max-width: 945px;
    margin: 0 auto;
}

.footer .bannerBox .flex a {
    transition: .3s;
}

.footer .bannerBox .flex a:hover {
    opacity: .5;
}

/*copy*/
.footer .copy {
    font-family: "Roboto", serif;
    font-size: 15px;
    font-weight: 400;
    background-color: #0E3B73;
    color: #fff;
    padding: 21px 0;
}

.footer .copy .inner {
    display: block;
}

/*pageTop*/
.footer .pageTopInner {
    position: fixed;
    bottom: 32px;
    right: 104px;
    z-index: 10;
}

.footer .pageTop {
    position: absolute;
    bottom: 0;
    right: 0;
    width: 62px;
    height: 79.75px;
    font-family: "Roboto", serif;
    font-size: 14px;
    font-weight: 700;
    color: #BCC8D6;
    padding-top: 55px;
    background: url(../img/common/page-top.svg) no-repeat top center;
    background-size: 61.79px;
    transition: .3s;
    cursor: pointer;
    text-align: center;
}

.pageTop {
    opacity: 0;
    visibility: hidden;
    /* 非表示時はフォーカスやクリックを無効化 */
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.pageTop.show {
    opacity: 1;
    visibility: visible;
    /* 表示時はクリック可能に */
}


.footer .pageTop:hover {
    padding-top: 65px;
    height: 89.75px;
}

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

    .footer .top {
        min-height: auto;
    }

    .footer .top .inner {
        display: block;
        background: url(../img/common/footer-contact.png) no-repeat top right -13px;
        background-size: 175.94px;
        width: 100%;
        padding: 85px 76px;
    }

    .footer .top .left {
        width: 100%;
    }

    .footer .top .right {
        width: 100%;
        min-width: auto;
        max-width: 341px;
        margin: 0 auto;
        padding-top: 0;
    }

    .footer .top .right .modBtn3 {
        margin-top: 0;
    }

    .footer .top .right .telBox {
        width: 100%;
        margin: 0 auto;
    }

    .footer .bottom .bottomInner {
        padding-bottom: 32px;
    }

    .footer .bottom .bottomInner {
        row-gap: 30px;
        max-width: 1320px;
        padding: 88px 0 230px 0;
        background: url(../img/common/footer-img.png) no-repeat bottom 30px center;
        background-size: 395.5px;
        justify-content: space-between;
    }

    .footer .bottom .flex .left,
    .footer .bottom .flex .right {
        width: 100%;
    }

    .footer .bottom .flex .right {
        max-width: 685.5px;
        margin: 0 auto;
    }

    .footer .bottom .flex .left .logo img {
        margin: 0 auto 15px auto;
    }

    .footer .bottom .flex .left .text {
        font-size: 15px;
        padding-left: 0;
        text-align: center;
    }

    .footer .bottom .flex .left .fotterTitle {
        margin: 0 auto;
        max-width: 200px;
        width: 100%;
    }

    .footer .policy-wrap {
        bottom: 260px;
        left: calc(50% + 220px);
    }
}

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

    /*top*/
    .footer .top {
        border-radius: 50px 50px 0 0;
    }

    .footer .top .inner {
        padding: 58px 16px;
    }

    .footer .top .right .telBox .text {
        margin-bottom: 20px;
    }

    /*bottom*/
    .footer .bottom {
        padding-bottom: 0;
    }

    .footer .bottom .bottomInner {
        padding: 30px 0 210px 0;
        background: url(../img/common/footer-img.png) no-repeat bottom 40px center;
        background-size: 324.58px;
    }

    .footer .bottom .flex .left .logo {
        margin: 0 auto 15px auto;
    }

    .footer .bottom .flex .right {
        max-width: 220px;
        border: none;
        padding-right: 0;
    }

    .footer .bottom .flex .box1,
    .footer .bottom .flex .box2 {
        display: none;
    }

    .footer .box3 .fotterTitle {
        margin: 0 auto 16px auto;
        max-width: 200px;
        width: 100%;
        padding-top: 0;
        padding-bottom: 0;
    }

    .footer .policy-wrap {
        bottom: 180px;
        left: 50%;
        transform: translate(-50%, 0);
    }

    .footer .bannerBox {
        padding: 50px 0;
    }

    .footer .bannerBox .flex {
        max-width: 220px;
        justify-content: center;
    }

    .footer .copy {
        padding: 23px 0 70px;
    }

    .footer .pageTopInner {
        bottom: 75px;
        right: 14px;
    }

    .footer .pageTop:hover {
        height: 79.75px;
        padding-top: 55px;
    }

}

/*--------------------------------------------------------------------------------------------------------------------

トップページ

--------------------------------------------------------------------------------------------------------------------*/
/*-----------------------------MV*/
.mv {
    position: relative;
    height: calc(var(--vh, 1vh) * 100);
    background: linear-gradient(#F9FBFC, #C4DBE6);
    margin-top: 40px;
}

.mv::before,
.mv .mvSwiper .swiper-slide2::before {
    content: "";
    position: absolute;
    top: 35%;
    left: 0;
    transform: translateY(-50%);
    margin: auto;
    width: calc(100% - 40px);
    height: calc(100% + 260px);
    background: url(../img/top/mv-en.png) no-repeat bottom left;
    background-size: 100% auto;
}

.mv::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url(../img/top/noise.png) no-repeat bottom center;
    background-size: 100% auto;
}

.mv .textBox {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    margin: auto;
    z-index: 10;
}

.animated {
    visibility: hidden;
    /* 初期状態で非表示 */
    opacity: 0;
    /* 初期状態で透明 */
}

.mv .textBox img {
    width: 551px;
}

.mv .textBox .ilust {
    position: absolute;
    top: -155px;
    /* 初期位置 */
    right: 55px;
    width: 170px;
    transition: top 2s ease;
    /* スライドの切り替えに合わせてスムーズに動かす */
}

.mv .mvSwiper {
    z-index: 9;
    height: 100%;
}

.mv .mvSwiper .swiper-slide img {
    height: 100%;
    width: 100%;
    object-fit: cover;
}

.mv .mvSwiper .swiper-pagination {
    margin-bottom: 272px;
    right: 40px;
    left: auto;
    text-align: right;
}

.mv .mvSwiper .swiper-pagination .swiper-pagination-bullet {
    width: 7px;
    height: 7px;
    background-color: #fff;
    border-radius: 7px;
    box-shadow: 0px 0px 6px 0px rgba(0, 0, 0, .16);
    opacity: 1;
    margin: 0 16.5px;
}

.mv .mvSwiper .swiper-pagination .swiper-pagination-bullet-active {
    position: relative;
}

.mv .mvSwiper .swiper-pagination .swiper-pagination-bullet-active::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    margin: auto;
    width: 38px;
    height: 38px;
    border-radius: 38px;
    background-color: #fff;
    box-shadow: 0px 0px 6px 0px rgba(0, 0, 0, .16);
    opacity: .4;
}

.mv .scroll {
    position: absolute;
    bottom: 273px;
    left: 40px;
    width: 101.5px;
    height: 65.74px;
    font-family: "Roboto", serif;
    font-weight: 500;
    color: #fff;
    padding: 46px 0 0 15px;
    text-shadow: 0px 0px 3px rgba(0, 0, 0, .16);
    z-index: 11;
}

.mv .scroll::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 3.5px;
    height: 60px;
    width: 1px;
    background-color: #fff;
    box-shadow: 0px 0px 3px 0px rgba(0, 0, 0, .16);
}

.mv .scroll .en {
    position: absolute;
    top: 0;
    left: 0;
    height: 8px;
    width: 8px;
    border-radius: 8px;
    background-color: #fff;
    box-shadow: 0px 0px 3px 0px rgba(0, 0, 0, .16);
    transition: top 2s ease;
    /* スライドの切り替えに合わせてスムーズに動かす */
}

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

    .mv .textBox img {
        max-width: 244px;
    }

    .mv .textBox .ilust {
        top: -18px;
        /* 初期位置 */
        right: -57px;
        width: 79px;
    }

    .mv .mvSwiper .swiper-pagination {
        margin-bottom: 74px;
        right: 25px;
    }

    .mv .mvSwiper .swiper-pagination .swiper-pagination-bullet {
        width: 5px;
        height: 5px;
        margin: 0 13.5px;
    }

    .mv .mvSwiper .swiper-pagination .swiper-pagination-bullet-active::before {
        width: 30px;
        height: 30px;
    }

    .mv .mvSwiper .swiper-slide img.pc {
        display: block;
    }

    .mv .mvSwiper .swiper-slide img.sp {
        display: none;
    }

    .mv .scroll {
        bottom: 81px;
        left: 50%;
        transform: translateX(-50%);
        margin: auto;
        width: 63px;
        height: 50.24px;
        font-size: 12px;
        padding: 37px 0 0 0;
    }

    .mv .scroll::before {
        left: 50%;
        transform: translateX(-50%);
        margin: auto;
        top: 0;
        bottom: auto;
        height: 31px;
    }

    .mv .scroll .en {
        top: 0;
        left: 50%;
        transform: translateX(-50%);
        margin: auto;
        height: 6px;
        width: 6px;
    }

}

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

    .mv::before,
    .mv .mvSwiper .swiper-slide2::before {
        width: 100%;
        height: 100%;
        background: url(../img/top/mv-en-sp.png) no-repeat top center;
        background-size: 100% auto;
    }

    .mv .mvSwiper .swiper-slide img.pc {
        display: none;
    }

    .mv .mvSwiper .swiper-slide img.sp {
        display: block;
    }

}

/*missionTop*/
.missionTop {
    position: relative;
    background: url(../img/top/back_gradation2.png) no-repeat top center;
    background-size: calc(100% + 520px) auto;
    padding: 553px 0 300px 0;
    margin-top: min(-240px, -17.142857142857142vw);
    z-index: 2;
}

.missionTop::before {
    content: "";
    position: absolute;
    top: 450px;
    right: 0;
    background-color: #fff;
    width: calc(100% - 40px);
    height: calc(100% - 270px);
    border-radius: 80px 0 0 0;
}

.missionTop::after {
    content: "";
    position: absolute;
    top: 389px;
    left: 50%;
    transform: translateX(-50%);
    margin: auto;
    width: 100%;
    height: 148px;
    background: url(../img/common/illust-3.png) no-repeat center left;
    background-size: auto 100%;
    z-index: 3;
    max-width: 1200px;
}

.missionTop .inner {
    position: relative;
    max-width: 1105px;
    width: calc(100% - 160px);
}

.missionTop .top {
    margin-bottom: 70px;
}

.missionTop .top .left {
    width: 43%;
    padding: 0 50px 0 0;
}

.missionTop .top .right {
    width: 57%;
    padding: 42px 0 0 0;
}

.missionTop .section {
    position: relative;
    padding: 0 22px 40px 22px;
    margin-bottom: 40px;
    row-gap: 25px;
}

.missionTop .section::before {
    content: "";
    position: absolute;
    top: 26px;
    left: 0;
    width: 100%;
    height: calc(100% - 26px);
    background-color: #F3F5F9;
    border-radius: 10px;
}

.missionTop .section1::after {
    content: "";
    position: absolute;
    top: -27px;
    right: -57px;
    width: 200px;
    height: 128.65px;
    background: url(../img/top/mission-illust-1.png) no-repeat center;
    background-size: 100% auto;
}

.missionTop .section2::after {
    content: "";
    position: absolute;
    bottom: -80px;
    left: -62px;
    width: 220px;
    height: 141.23px;
    background: url(../img/top/mission-illust-2.png) no-repeat center;
    background-size: 100% auto;
}

.missionTop .section .imgBox {
    position: relative;
    width: 50%;
    padding: 0 18px;
}

.missionTop .section .textBox {
    position: relative;
    width: 50%;
    padding: 65px 18px 0 85px;
}

.missionTop .section2 .imgBox {
    order: 2;
}

.missionTop .section2 .textBox {
    order: 1;
}

.missionTop .section .imgBox img {
    width: 100%;
    border-radius: 10px;
}

.missionTop .section .textBox .big {
    position: absolute;
    top: 0;
    left: 0;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    font-size: 28px;
    font-weight: bold;
    letter-spacing: .02em;
    line-height: 1.6;
}

.missionTop .section .textBox .big .blue {
    font-size: 54px;
}

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

    .missionTop {
        background-size: calc(100% + 140px) auto;
        padding: 240px 0 180px 0;
        margin-top: -81px;
    }

    .missionTop::before {
        top: 180px;
        width: 100%;
        height: 100%;
        border-radius: 50px 0 0 0;
    }

    .missionTop::after {
        top: 130px;
        height: 81px;
        left: 0;
        transform: none;
        margin: 0;
    }

    .missionTop .inner {
        width: calc(100% - 32px);
    }

    .missionTop .top {
        margin-bottom: 45px;
    }

    .missionTop .top .left {
        width: 100%;
        padding: 0;
    }

    .missionTop .top .right {
        width: 100%;
        padding: 0;
        font-size: 15px;
    }

    .missionTop .top .sectionTitle {
        margin-bottom: 5px;
    }

    .missionTop .top .sectionTitle .ja {
        margin-top: -15px;
    }

    .missionTop .section {
        position: relative;
        padding: 75px 20px 38px 70px;
        margin-bottom: 35px;
    }

    .missionTop .section::before {
        top: 37px;
        height: calc(100% - 37px);
    }

    .missionTop .section1::after {
        top: 0;
        right: 0;
        width: 114px;
        height: 73.15px;
    }

    .missionTop .section2::after {
        top: 0;
        right: 0;
        left: auto;
        width: 114px;
        height: 73.18px;
    }

    .missionTop .section .imgBox {
        width: 100%;
        padding: 0;
    }

    .missionTop .section .textBox {
        width: 100%;
        padding: 0;
    }

    .missionTop .section1 .imgBox {
        order: 2;
    }

    .missionTop .section1 .textBox {
        order: 1;
    }

    .missionTop .section .textBox .big {
        top: -60px;
        left: -86px;
        font-size: 24px;
    }

    .missionTop .section .textBox .big .blue {
        font-size: 50px;
    }

    .missionTop .section .textBox .text {
        font-size: 15px;
    }

}

/*photo*/
.photo {
    position: relative;
    background: url(../img/common/bg-wave.png) no-repeat bottom 50% center;
    background-size: 100% auto;
    margin-top: -180px;
    z-index: 2;
}

.photo::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 41%;
    background-color: #F3F5F9;
}

.photoSwiper .swiper-wrapper {
    transition-timing-function: linear;
}

.photoSwiper .swiper-slide {
    display: inline-block;
    /* 子要素の幅に基づいてサイズを調整 */
    width: auto !important;
    /* 自動で横幅を設定 */
}

.photoSwiper .swiper-slide img {
    height: 22.857142857142858vw;
    min-height: 160px;
    width: auto;
    object-fit: cover;
    border-radius: 10px;
}

.photoSwiper .swiper-slideDown {
    margin-top: 42px;
}

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

    .photo {
        background: url(../img/common/bg-wave-sp.png) no-repeat bottom 50% center;
        background-size: 100% auto;
        margin-top: -90px;
    }

    .photo::before {
        height: 50%;
    }

    .photoSwiper .swiper-wrapper {
        transition-timing-function: linear;
    }

    .photoSwiper .swiper-slide {
        display: inline-block;
        /* 子要素の幅に基づいてサイズを調整 */
        width: auto !important;
        /* 自動で横幅を設定 */
    }

    .photoSwiper .swiper-slideDown {
        margin-top: 20px;
    }

}

/*serviceTop*/
.serviceTop {
    position: relative;
    background-color: #F3F5F9;
    padding: 95px 0 0 0;
    z-index: 2;
}

.serviceTop .serviceInner {
    margin-bottom: 20px;
    max-width: 1224px;
    align-items: center;
    row-gap: 25px;
}

.serviceTop .left {
    width: 39.6%;
    padding: 0 50px 0 80px;
}

.serviceTop .right {
    width: 60.4%;
}

.serviceTop .left .sectionTitle {
    margin-bottom: 22px;
}

.serviceTop .left .text {
    font-size: 15px;
    font-weight: 500;
    margin-bottom: 30px;
}

.serviceTop .serviceText {
    max-width: 1400px;
    font-family: "Roboto", serif;
    font-weight: 400;
    font-size: min(134px, 9.6vw);
    line-height: .6;
    color: #0E3B73;
    opacity: .03;
    width: 100%;
}

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

    .serviceTop {
        padding: 70px 0 0 0;
    }

    .serviceTop .serviceInner {
        margin-bottom: 0;
    }

    .serviceTop .left {
        width: 100%;
        padding: 0;
    }

    .serviceTop .right {
        width: 100%;
    }

    .serviceTop .right img {
        width: 100%;
    }

    .serviceTop .left .sectionTitle {
        margin-bottom: 30px;
    }

    .serviceTop .serviceText {
        font-size: max(40px, 10.2vw);
        line-height: .9;
    }

    .serviceTop .serviceText .top {
        display: block;
    }

    .serviceTop .serviceText .bottom {
        display: block;
        text-align: right;
    }

}

/*sectionBlue*/
.sectionBlue {
    position: relative;
    background-color: #F3F5F9;
}

.productsTop.sectionBlue {
    padding: 53px 0 12px 0;
}

.sectionBlue::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to right, #7ECEF4, #0E3B75);
    border-radius: 80px 0 0 0;
}

.recruitTop.sectionBlue::before {
    top: 55px;
    border-radius: 0 80px 0 0;
}

.sectionBlue .inner {
    position: relative;
    align-items: center;
    justify-content: space-between;
    row-gap: 40px;
}

.recruitTop.sectionBlue .inner {
    align-items: flex-end;
    max-width: 1224px;
}

.sectionBlue .left {
    width: 55.5%;
}

.recruitTop.sectionBlue .left {
    width: 53%;
}

.sectionBlue .right {
    width: 44.5%;
    padding: 30px 3.83333% 60px 5.5%;
}

.recruitTop.sectionBlue .right {
    width: 47%;
    padding: 135px 8.9% 85px 6.5%;
    background: url(../img/top/recruit-illust.png) no-repeat top 135px right min(110px, 7.857142857142857vw);
    background-size: min(158px, 11.285714285714285vw);
}

.sectionBlue .right .sectionTitle {
    margin-bottom: 20px;
}

.sectionBlue .right .text {
    font-size: 15px;
    line-height: 1.8666;
    margin-bottom: 30px;
    color: #fff;
}

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

    .productsTop.sectionBlue {
        padding: 60px 0 45px 0;
    }

    .recruitTop.sectionBlue {
        padding: 0 0 120px 0;
        margin-bottom: -50px;
    }

    .sectionBlue::before {
        border-radius: 50px 0 0 0;
    }

    .recruitTop.sectionBlue::before {
        top: 0;
        border-radius: 0 50px 0 0;
    }

    .sectionBlue .inner {
        width: 100%;
    }

    .sectionBlue .left,
    .recruitTop.sectionBlue .left {
        width: 100%;
    }

    .sectionBlue .left {
        order: 2;
        padding-right: 16px;
    }

    .sectionBlue .left img {
        margin: 0 auto;
        width: 100%;
    }

    .sectionBlue .right {
        width: calc(100% - 32px);
        padding: 0;
        order: 1;
        margin: 0 auto;
    }

    .recruitTop.sectionBlue .right {
        width: calc(100% - 32px);
        padding: 60px 0 0 0;
        background: url(../img/top/recruit-illust.png) no-repeat top 30px right 0;
        background-size: 129.5px;
    }

}

/*caseTop*/
.caseTop {
    padding: 92px 0 0 0;
}

.caseTop .top-section-title {
    margin-bottom: 45px;
}

.caseTop .caseSwiper {
    position: relative;
    margin-left: auto;
    max-width: 1200px;
}

.caseTop .caseSwiper .swiper-wrapper {
    margin-bottom: 40px;
}

.caseTop .caseSwiper .swiper-wrapper,
.caseTop .caseSwiper .swiper-wrapper .swiper-slide {
    /* wrapperのサイズを調整 */
    width: 100%;
}

.caseTop .caseSwiper .swiper-button {
    position: absolute;
    left: 0;
    transform: translateX(-50%);
    margin: auto;
    top: auto;
    bottom: -40px;
    right: auto;
    z-index: 1;
}

.caseTop .caseSwiper .swiper-button .swiper-button-prev,
.caseTop .caseSwiper .swiper-button .swiper-button-next {
    margin-top: 0;
    top: 0;
    bottom: auto;
    left: auto;
    width: 32px;
    height: 32px;
    transition: .3s;
}

.caseTop .caseSwiper .swiper-button .swiper-button-prev {
    left: 0;
    background: url(../img/common/prev.svg) no-repeat center;
    background-size: 32px;
}

.caseTop .caseSwiper .swiper-button .swiper-button-prev:hover {
    background: url(../img/common/prev-hover.svg) no-repeat center;
    background-size: 32px;
}

.caseTop .caseSwiper .swiper-button .swiper-button-next {
    left: 43px;
    background: url(../img/common/next.svg) no-repeat center;
    background-size: 32px;
}

.caseTop .caseSwiper .swiper-button .swiper-button-next:hover {
    background: url(../img/common/icon-right-blue.svg) no-repeat center;
    background-size: 32px;
}

.caseTop .modBtn1 {
    position: relative;
    z-index: 1;
}

.caseList .box {
    width: calc(100% / 3);
    border-radius: 10px;
    background-color: #F3F5F9;
}

.pageCaseSub .caseList .box,
.pageServiceDetail .caseList .box {
    background-color: #fff;
}

.pageCase .caseList {
    column-gap: 36px;
    row-gap: 47px;
}

.pageCase .caseList .box {
    width: calc(100% / 3 - 24px);
}

.caseList .box .img {
    border-radius: 10px 10px 0 0;
    max-height: 236px;
    height: 16.857142857142858vw;
    overflow: hidden;
}

.pageCase .caseList .box .img {
    max-height: 224px;
    height: 18vw;
}

.caseList .box .img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: .3s;
}

.caseList .box:hover .img img {
    transform: scale(1.2);
}

.caseList .box .textBox {
    padding: 36px 30px;
}

.caseList .box .textBox p {
    font-size: 15px;
}

.caseList .category {
    font-size: 13px;
    font-weight: 500;
    line-height: 1.93;
    padding: 1px 22px;
    border-radius: 100px;
    color: #fff;
    display: inline-block;
    text-align: center;
    vertical-align: middle;
    margin-right: 15px;
}

.top.caseList .category {
    font-size: 16px;
}

.caseList .category1 {
    border: 1px solid #004EA2;
    background-color: #004EA2;
}

.caseList .category2 {
    border: 1px solid #0E3B73;
    background-color: #0E3B73;
}

.caseList .date {
    font-family: "Roboto", serif;
    font-size: 14px;
    font-weight: 400;
    line-height: 1;
    display: inline-block;
    vertical-align: middle;
    opacity: .5;
}

.caseList h3 {
    font-size: 20px;
    margin: 10px 0;
    padding-bottom: 9px;
}

.caseList .box1 h3::before {
    background-color: #004EA2;
}

.caseList p {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    /* 制限したい行数が3の場合 */
    overflow: hidden;
}

.pageCase .caseList p {
    -webkit-line-clamp: 3;
    /* 制限したい行数が3の場合 */
}

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

    .caseTop {
        margin-bottom: 50px;
        padding: 65px 0 0 0;
    }

    .caseTop .top-section-title {
        margin-bottom: 30px;
    }

    .caseTop .caseSwiper .swiper-wrapper {
        margin-bottom: 30px;
    }

    .caseTop .caseSwiper .swiper-button {
        left: auto;
        right: 0;
        top: -68px;
        bottom: auto;
        margin: 0;
        transform: none;
        width: 100%;
    }

    .caseTop .caseSwiper .swiper-button .swiper-button-prev,
    .caseTop .caseSwiper .swiper-button .swiper-button-next {
        margin-top: 0;
        top: 0;
        bottom: auto;
        left: auto;
        width: 32px;
        height: 32px;
        transition: .3s;
    }

    .caseTop .caseSwiper .swiper-button .swiper-button-prev {
        left: auto;
        right: 43px;
        background-size: 30.04px;
    }

    .caseTop .caseSwiper .swiper-button .swiper-button-prev:hover {
        background-size: 30.04px;
    }

    .caseTop .caseSwiper .swiper-button .swiper-button-next {
        right: 0;
        left: auto;
        background-size: 30.04px;
    }

    .caseTop .caseSwiper .swiper-button .swiper-button-next:hover {
        background-size: 30.04px;
    }

    .caseList .box,
    .pageCase .caseList .box {
        width: 100%;
    }

    .caseList .box .img,
    .pageCase .caseList .box .img {
        max-height: 100%;
        min-height: 226px;
        height: 60.266666666666666vw;
    }

    .caseList .box .textBox {
        padding: 34px 20px;
    }

    .pageCase .caseList {
        row-gap: 25px;
    }

    .caseList .category {
        font-size: 12px;
        line-height: 1.83;
        padding: 1px 19px;
    }

    .top.caseList .category {
        font-size: 15px;
    }

    .caseList .date {
        font-size: 13px;
    }

    .caseList h3 {
        font-size: 18px;
    }

    .pageCase .caseList p {
        -webkit-line-clamp: 2;
        /* 制限したい行数が3の場合 */
    }

}

/*aboutTop*/
.aboutTop {
    position: relative;
    background: url(../img/top/back_gradation.webp) no-repeat top center;
    background-size: calc(100% + 520px) auto;
    padding: 277px 0 205px 0;
    margin-top: -110px;
}

.aboutTop::before {
    content: "";
    position: absolute;
    top: 400px;
    left: 0;
    background-color: #fff;
    width: calc(100% - 40px);
    height: 100%;
    border-radius: 0 80px 0 0;
}

.aboutTop::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    background: url(../img/common/bg-wave.png) no-repeat center bottom;
    background-size: 100% auto;
    width: 100%;
    height: 107px;
}

.aboutTop .aboutInner {
    position: relative;
    padding-top: 140px;
    row-gap: 45px;
}

.aboutTop .left {
    position: relative;
    width: 50%;
    padding: 0 102px 0 38px;
}

.aboutTop .right {
    position: relative;
    width: 50%;
    padding: 0 130px 0 60px;
}

.aboutTop .left::before {
    content: "";
    position: absolute;
    width: 169px;
    height: 169px;
    top: -92px;
    right: 60px;
    background: url(../img/common/illust-2.png) no-repeat center;
    background-size: 100% auto;
    z-index: 3;
    transition: .2s;
}

.aboutTop .left:hover::before {
    right: 45px;
}

.aboutTop .left .imgBox {
    position: relative;
    margin-bottom: 42px;
}

.aboutTop .left .imgBox::before {
    content: "";
    position: absolute;
    top: 20px;
    left: -28px;
    width: 100%;
    height: 100%;
    border-radius: 10px;
    background: linear-gradient(#7ECEF4, #0E3B75);
    z-index: 1;
}

.aboutTop .left .imgBox::after {
    content: "";
    position: absolute;
    top: 115px;
    right: -42px;
    width: 100%;
    height: 100%;
    border-radius: 10px;
    background-color: #F3F5F9;
}

.aboutTop .left .imgBox .img {
    position: relative;
    overflow: hidden;
    border-radius: 10px;
    z-index: 2;
}

.aboutTop .left .imgBox .img img {
    width: 100%;
    transition: .3s;
}

.aboutTop .left:hover .imgBox .img img {
    transform: scale(1.2);
}

.aboutTop .left .title {
    position: relative;
    font-size: 24px;
    font-weight: bold;
    padding-left: 43px;
    background: url(../img/common/footerTitle.svg) no-repeat center left;
    background-size: 31.52px;
    color: #0E3B73;
}

.aboutTop .left .text {
    position: relative;
    font-weight: 500;
    background: url(../img/common/icon-right-blue.svg) no-repeat center right;
    background-size: 25.27px;
    padding-right: 44px;
    display: inline-block;
}

.aboutTop .left:hover .text {
    background: url(../img/common/icon-right-hover.svg) no-repeat center right;
    background-size: 25.27px;
}

/*wako*/
.wako {
    position: absolute;
    top: 322px;
    right: 0;
}

.wakoAbout {
    top: 215px;
    right: 40px;
    max-width: 1320px;
}

.wako img {
    margin-left: auto;
}

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

    .aboutTop {
        padding: 112px 0 130px 0;
        margin-top: 0;
        background-size: calc(100% + 140px) auto;
    }

    .aboutTop::before {
        top: 210px;
        width: 100%;
        border-radius: 0 50px 0 0;
    }

    .aboutTop .aboutInner {
        padding-top: 100px;
    }

    .aboutTop .left {
        width: 100%;
        padding: 0 20px 0 16px;
    }

    .aboutTop .right {
        width: 100%;
        padding: 0;
    }

    .aboutTop .left::before {
        content: "";
        position: absolute;
        width: 119px;
        height: 119px;
        top: -67px;
        right: 16px;
    }

    .aboutTop .left:hover::before {
        right: 1px;
    }

    .aboutTop .left .imgBox {
        margin-bottom: 30px;
    }

    .aboutTop .left .imgBox::before {
        top: 13px;
        left: -18px;
    }

    .aboutTop .left .imgBox::after {
        top: 70px;
        right: -24px;
    }

    .aboutTop .left .title {
        font-size: 18px;
        padding-left: 33px;
        background-size: 25.47px;
        margin-left: 10px;
    }

    .aboutTop .left .text {
        font-size: 15px;
        background: url(../img/common/icon-right-blue.svg) no-repeat center right;
        background-size: 22.04px;
        padding-right: 30px;
        margin-left: 10px;
    }

    .aboutTop .left:hover .text {
        background: url(../img/common/icon-right-blue.svg) no-repeat center right;
        background-size: 22.04px;
    }

    /*wako*/
    .wako {
        top: 140px;
        right: 0;
    }

    .wakoAbout {
        top: 158px;
        right: 16px;
    }

    .wako img {
        width: 270.68px;
    }

    .wakoAbout img {
        width: 235.36px;
    }

}

/*linkList*/
.linkList a {
    font-size: 20px;
    font-weight: bold;
    color: #0E3B73;
    padding: 25px 50px 25px 93px;
}

.linkBox .linkList a {
    font-size: min(20px, 1.4285714285714286vw);
}

.aboutTop .linkList a {
    border-bottom: 1px solid rgba(14, 59, 117, .2);
}

.aboutTop .linkList li:first-child a {
    border-top: 1px solid rgba(14, 59, 117, .2);
}

.linkList a.company {
    background-image: url(../img/common/icon-link-1.png), url(../img/common/icon-right-blue.svg);
    background-repeat: no-repeat, no-repeat;
    background-position: center left 20px, center right 17px;
    background-size: 55px, 22.04px;
}

.linkList a.company:hover {
    background-image: url(../img/common/icon-link-1.png), url(../img/common/icon-right-hover.svg);
}

.linkList a.access {
    background-image: url(../img/common/icon-link-2.png), url(../img/common/icon-right-blue.svg);
    background-repeat: no-repeat, no-repeat;
    background-position: center left 20px, center right 17px;
    background-size: 55px, 22.04px;
}

.linkList a.access:hover {
    background-image: url(../img/common/icon-link-2.png), url(../img/common/icon-right-hover.svg);
}

.linkList a.history {
    background-image: url(../img/common/icon-link-3.png), url(../img/common/icon-right-blue.svg);
    background-repeat: no-repeat, no-repeat;
    background-position: center left 20px, center right 17px;
    background-size: 55px, 22.04px;
}

.linkList a.history:hover {
    background-image: url(../img/common/icon-link-3.png), url(../img/common/icon-right-hover.svg);
}

.linkList a.qualification {
    background-image: url(../img/common/icon-link-4.png), url(../img/common/icon-right-blue.svg);
    background-repeat: no-repeat, no-repeat;
    background-position: center left 20px, center right 17px;
    background-size: 55px, 22.04px;
}

.linkList a.qualification:hover {
    background-image: url(../img/common/icon-link-4.png), url(../img/common/icon-right-hover.svg);
}

.linkList a.calendar {
    background-image: url(../img/common/icon-link-5.png), url(../img/common/icon-right-blue.svg);
    background-repeat: no-repeat, no-repeat;
    background-position: center left 20px, center right 17px;
    background-size: 55px, 22.04px;
}

.linkList a.calendar:hover {
    background-image: url(../img/common/icon-link-5.png), url(../img/common/icon-right-hover.svg);
}

.linkList a.message {
    background-image: url(../img/common/icon-link-6.png), url(../img/common/icon-right-blue.svg);
    background-repeat: no-repeat, no-repeat;
    background-position: center left 20px, center right 17px;
    background-size: 55px, 22.04px;
}

.linkList a.message:hover {
    background-image: url(../img/common/icon-link-6.png), url(../img/common/icon-right-hover.svg);
}

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

    .linkList a,
    .linkBox .linkList a {
        font-size: 18px;
        padding: 22px 50px 22px 87px;
        background-position: center left 20px, center right 21px;
    }

}

/*linkBox*/
.linkBox {
    position: relative;
    margin-top: 70px;
    padding-top: 30px;
}

.linkBox::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    margin: auto;
    height: 60px;
    width: 2px;
    background-color: #0E3B73;
}

.linkBox .linkList {
    padding: 60px 50px;
    border-radius: 10px;
    background-color: #F3F5F9;
    column-gap: 35px;
    row-gap: 20px;
    justify-content: space-between;
}

.linkBox .linkList li {
    width: calc(100% / 3 - 23.4px);
}

.linkBox .linkList a {
    background-color: #fff;
    border-radius: 10px;
}

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

    .linkBox {
        margin-top: 45px;
        padding-top: 25px;
    }

    .linkBox::before {
        height: 50px;
    }

    .linkBox .linkList {
        padding: 50px 20px;
        row-gap: 16px;
    }

    .linkBox .linkList li {
        width: 100%;
    }

}

/*-----------------------------newsList*/
.newsTop {
    position: relative;
    background-color: #F3F5F9;
    padding-top: 90px;
    z-index: 1;
    padding-bottom: 40px;
}

.newsTop .newsIlust {
    position: absolute;
    top: -148px;
    left: 50%;
    transform: translateX(-50%);
    margin: auto;
    max-width: 1224px;
}

.newsTop .newsIlust img {
    margin: 0 0 0 auto;
}

.newsTop .left {
    width: 19.5834%;
    padding-bottom: 141px;
    background: url(../img/common/illust-1.png) no-repeat bottom right;
    background-size: 133px;
    margin-right: 6.1666%;
}

.newsTop .newsList.right {
    width: 74.25%;
    padding: 24px 30px;
    margin-top: 25px;
    background-color: #fff;
    border-radius: 10px;
    margin-bottom: 35px;
}

.newsList a {
    padding: 20px 40px 20px 0;
    background: url(../img/common/icon-right-blue.svg) no-repeat bottom 20px right;
    background-size: 22.04px;
    border-bottom: 1px solid rgba(14, 59, 117, .2);
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
}

.newsTop .newsList a {
    padding: 17px 60px 17px 16px;
    background: url(../img/common/icon-right-blue.svg) no-repeat bottom 20px right 20px;
    background-size: 22.04px;
}

.newsList a:first-child {
    padding: 0 40px 17px 0;
}

.newsTop .newsList a:first-child {
    padding: 0 60px 17px 16px;
}

.newsList a:last-child,
.newsList a:hover:last-child {
    background-position: top 23px right 0;
}

.newsList a:first-child:last-child {
    background-position: bottom 20px right 20px;
}

.newsTop .newsList a:last-child {
    padding: 17px 60px 0 16px;
    border-bottom: none;
    background-position: top 23px right 20px;
}

.newsList a:hover {
    background: url(../img/common/icon-right-hover.svg) no-repeat bottom 20px right;
    background-size: 22.04px;
}

.newsTop .newsList a:hover {
    background: url(../img/common/icon-right-hover.svg) no-repeat bottom 20px right 20px;
    background-size: 22.04px;
}

.newsTop .newsList a:last-child:hover {
    background-position: top 23px right 20px;
}

.newsList .category {
    font-size: 13px;
    font-weight: 500;
    line-height: 1.93;
    padding: 1px 20px;
    border: 1px solid #0E3B73;
    border-radius: 100px;
    color: #0E3B73;
    display: inline-block;
    text-align: center;
    vertical-align: middle;
    min-width: 128px;
    margin-right: 15px;
}

.newsList .date {
    font-family: "Roboto", serif;
    font-size: 14px;
    font-weight: 400;
    line-height: 1;
    display: inline-block;
    vertical-align: middle;
    margin-right: 20px;
    opacity: .8;
    margin-top: 8px;
}

.pageNewsSub .newsList .date {
    margin-top: 3px;
}

.newsList a .title {
    display: inline-block;
    vertical-align: middle;
    font-weight: 500;
    font-size: 16px;
    width: calc(100% - 238px);
}

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

    .newsTop {
        background-color: #F3F5F9;
        padding-top: 80px;
        z-index: 1;
        padding-bottom: 65px;
    }

    .newsTop .newsIlust {
        top: -90px;
        width: calc(100% - 14px);
    }

    .newsTop .newsIlust img {
        width: 132.62px;
    }

    .newsTop .left {
        width: 50%;
        max-width: 290px;
        min-width: 254.81px;
        padding-bottom: 0;
        background: url(../img/common/illust-1.png) no-repeat center right;
        background-size: 93px;
        margin-right: 0;
    }

    .newsTop .newsList.right {
        width: 100%;
        padding: 24px 25px 24px 20px;
        margin-bottom: 30px;
        margin-top: 0;
    }

    .newsList a {
        padding: 13px 40px 13px 0;
        background: url(../img/common/icon-right-blue.svg) no-repeat top 55px right;
        background-size: 22.04px;
    }

    .newsTop .newsList a {
        padding: 13px 40px 13px 0;
        background: url(../img/common/icon-right-blue.svg) no-repeat top 57px right;
        background-size: 22.04px;
    }

    .newsList a:first-child,
    .newsTop .newsList a:first-child,
    .newsList a:first-child:hover,
    .newsTop .newsList a:first-child:hover {
        padding: 0 40px 13px 0;
        background-position: top 43px right;
    }

    .newsList a:last-child,
    .newsList a:hover:last-child {
        background-position: top 57px right 0;
    }

    .newsTop .newsList a:last-child {
        padding: 13px 40px 0 0;
        background-position: bottom 5px right;
    }

    .newsList a:hover {
        background: url(../img/common/icon-right-hover.svg) no-repeat top 55px right;
        background-size: 22.04px;
    }

    .newsTop .newsList a:hover {
        background: url(../img/common/icon-right-hover.svg) no-repeat top 57px right;
        background-size: 22.04px;
    }

    .newsTop .newsList a:last-child:hover {
        background-position: top 53px right;
    }

    .pageNewsSub .newsList .date {
        font-size: 16px;
    }

    .newsList .category {
        min-width: 126px;
    }

    .newsList a .title {
        display: block;
        font-size: 15px;
        line-height: 1.86666;
        margin-top: 10px;
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
        /* 制限したい行数が3の場合 */
        overflow: hidden;
        width: 100%;
    }

    .newsTop .newsList a .title {
        -webkit-line-clamp: 1;
        /* 制限したい行数が3の場合 */
    }

}

/*pagination*/
.pagination {
    margin-top: 70px;
}

.pagination .flex {
    justify-content: center;
    align-items: center;
    column-gap: 10px;
    row-gap: 10px;
}

.pagination .button a {
    width: 8.49px;
    height: 16.97px;
    margin: 0 auto;
}

.pagination .button.prev a {
    background: url(../img/common/prev.png) no-repeat center;
    background-size: 100% auto;
}

.pagination .button.prev a:hover {
    background: url(../img/common/prev-hover.png) no-repeat center;
    background-size: 100% auto;
}

.pagination .button.next a {
    background: url(../img/common/next.png) no-repeat center;
    background-size: 100% auto;
}

.pagination .button.next a:hover {
    background: url(../img/common/next-hover.png) no-repeat center;
    background-size: 100% auto;
}

.pagination .num a {
    font-weight: 400;
    width: 40px;
    height: 40px;
    text-align: center;
    border: 2px solid #0E3B73;
    padding-top: 4px;
    color: #333;
}

.pagination .num a:hover {
    background: #0E3B73;
    color: #fff;
}

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

    .main.page .pagination {
        margin-top: 30px;
        max-width: 240px;
    }

    .pagination .button {
        width: 100%;
    }

}

/*form*/
.form {
    max-width: 963px;
    margin: 0 auto;
}

.form .box {
    margin-bottom: 19px;
    align-items: center;
}

.form .box9 {
    align-items: flex-start;
}

.form .box label {
    width: 285px;
    font-size: 18px;
    font-weight: 700;
    margin-right: 19px;
}

.form .box label .small {
    font-size: 14px;
}

.form .box label .red {
    font-size: 13px;
    font-weight: 700;
    text-align: center;
    width: 50px;
    height: 25px;
    border-radius: 2px;
    background-color: #F4F4F4;
    color: #DB2356;
    line-height: 1;
    padding-top: 6px;
    display: inline-block;
    margin: 5px 0 0 10px;
    vertical-align: top;
}

.form .box input,
.form .box textarea,
.form .box select {
    -webkit-appearance: none;
    appearance: none;
    width: calc(100% - 304px);
    border: 1px solid #7C7C7C;
    padding: 10px 20px;
    font-weight: 400;
}

.form input::placeholder {
    color: #666;
    /* 好きな色に変更 */
    opacity: 1;
    /* 透明度を確保 */
}

.form select option:first-child {
    color: #666;
    /* 好きな色に変更 */
}

.form select {
    color: #666;
    /* 通常の選択肢の色 */
}

.form .box textarea {
    min-height: 180px;
}

.form .box2 input {
    max-width: 300px;
}

.form .box3 select {
    max-width: 340px;
    background: url(../img/contact/arrow.jpg) no-repeat top right;
    background-size: auto 100%;
    appearance: none;
    cursor: pointer;
}

.form .img {
    margin: 28px auto 48px auto;
    text-align: center;
}

.form .img img {
    width: 210px;
    margin: 0 auto 5px auto;
}

.form .img input {
    width: 220px;
    border: 1px solid #7C7C7C;
    padding: 9px;
    margin-bottom: 5px;
}

.form .policy {
    margin: 73px 0 46px;
    text-align: center;
}

.form .policy .scroll {
    max-width: 508px;
    height: 228px;
    overflow-y: scroll;
    margin: 0 auto 23px auto;
    border: 1px solid #808080;
    padding: 17px 34px 19px 34px;
    font-size: 15px;
    font-weight: 400;
    text-align: left;
}

.form .policy input[type="checkbox"] {
    display: none;
}

.form .policy label {
    display: flex;
    align-items: center;
    cursor: pointer;
    justify-content: center;
    font-weight: 400;
}

.form .policy .check-icon {
    width: 20px;
    height: 20px;
    background: url(../img/contact/check-no.jpg) no-repeat center left;
    background-size: auto 100%;
    margin-right: 10px;
}

.form .policy input[type="checkbox"]:checked+.check-icon {
    background: url(../img/contact/check.jpg) no-repeat center left;
    background-size: auto 100%;
}

/*policy*/
.policy .title {
    font-size: 18px;
}

.policy .bold {
    font-weight: bold;
}

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

    .form .box label {
        width: 100%;
        margin-bottom: 10px;
    }

    .form .box input,
    .form .box textarea,
    .form .box select {
        width: 100%;
        padding: 12px 18px;
    }

    .form .box2 {
        width: 100%;
        display: flex;
        flex-direction: column;
        justify-self: flex-start;
        align-items: flex-start;
    }

    .form .box3 select {
        max-width: 100%;
    }

    .form .policy {
        margin: 66px 0 45px;
    }

    .form .policy .scroll {
        max-width: 100%;
        height: 250px;
        margin: 0 auto 24px auto;
        padding: 17px 40px 19px 34px;
    }

    .policy .list li {
        margin-bottom: 5px;
    }

}

/*pageMessage*/
.pageMessage .top {
    margin-bottom: 80px;
}

.pageMessage .top .box {
    padding: 40px 20px;
    border-radius: 20px;
    background-color: #F3F5F9;
    text-align: center;
}

.pageMessage .top .box .bold {
    font-size: 43px;
    font-weight: bold;
    line-height: 1.5;
    color: #0E3B75;
    display: inline-block;
    background: linear-gradient(transparent 75%, rgba(207, 216, 227, .5) 75%);
    margin-bottom: 30px;
}

.pageMessage .section .text {
    max-width: 760px;
    text-align: left;
    margin: 0 auto;
}

.pageMessage .bottom .box {
    position: relative;
    border-radius: 10px;
    min-height: 400px;
    background: url(../img/message/message-bg.webp) no-repeat top center;
    background-size: auto 100%;
    margin-bottom: 118px;
}

.pageMessage .bottom .box .img {
    position: absolute;
    top: 25px;
    left: 47.5%;
}

.pageMessage .bottom .box .bold {
    font-size: 38px;
    font-weight: bold;
    line-height: 1.57;
    color: #0E3B75;
    padding: 123px 0 0 165px;
    background: url(../img/common/illust-2.png) no-repeat top 35px left 85px;
    background-size: 120px;
}

.pageMessage .ceoImg {
    max-width: 620px;
    margin: 48px auto;
}

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

    .pageMessage .top {
        margin-bottom: 65px;
    }

    .pageMessage .top .box {
        padding: 25px 20px;
    }

    .pageMessage .top .box .bold {
        font-size: 34px;
        font-weight: bold;
    }

    .pageMessage .bottom .box {
        min-height: 457px;
        background: url(../img/message/message-bg-sp.webp) no-repeat bottom center;
        background-size: cover;
        margin-bottom: 100px;
    }

    .pageMessage .bottom .box .img {
        top: 194px;
        left: auto;
        right: -16px;
    }

    .pageMessage .bottom .box .img img {
        width: 341px;
    }

    .pageMessage .bottom .box .bold {
        font-size: min(28px, 7.3vw);
        line-height: 1.5;
        padding: 105px 18px 0 18px;
        background: url(../img/common/illust-2.png) no-repeat top -4px left 13px;
        background-size: 120px;
    }

    .pageMessage .ceoImg {
        margin: 32px auto;
    }

}

/*pageCompany*/
.pageCompany .table .access {
    justify-content: space-between;
    column-gap: 43px;
    row-gap: 40px;
    width: 100%;
    padding: 30px 30px;
}

.pageCompany .table .access h5 {
    border-bottom: none;
}

.pageCompany .table .access .table_address th {
    color: #000;
    width: 97px;
    padding: 5px;
    background-color: #F5F5F5;
    text-align: center;
    vertical-align: middle;
}

.pageCompany .table .access .table_address td {
    padding: 15px 16px;
    width: calc(100% - 97px);
}

.pageCompany .table .access .table_address {
    border-top: 1px solid #D6D6D6;
    width: 100%;
}

.pageCompany .table .access .table_address .blue-txt {
    color: #0E3B73;
}

.pageCompany .table .access .table_address .modBtn2 {
    margin: 8px 0 0 0;
}

.pageCompany .table .access .box {
    width: calc(50% - 21.5px);
}

.pageCompany .table .access .box .img {
    margin-bottom: 16px;
}

.pageCompany .table .access .box .img img {
    width: 100%;
}

.pageCompany .table .access .box .text {
    font-size: 15px;
    line-height: 1.6;
    margin-bottom: 16px;
}

.pageCompany .table .member {
    width: 100%;
}

.pageCompany .table .member .left {
    width: 137px;
}

.pageCompany .table .member .right {
    width: calc(100% - 137px);
    vertical-align: top;
}

.pageCompany .table .patent .bold {
    position: relative;
    padding-left: 15px;
}

.pageCompany .table .patent .bold::before {
    content: "";
    position: absolute;
    top: 8px;
    left: 0;
    width: 8px;
    height: 8px;
    background: #004EA2;
}

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

    .pageCompany .table .access {
        display: flex;
        row-gap: 30px;
        padding: 20px 20px;
    }

    .pageCompany .table .access .table_address th,
    .pageCompany .table .access .table_address td {
        width: 100%;
    }

    .pageCompany .table .access .table_address th {
        text-align: left;
        padding: 5px 16px;
        border-bottom: none;
        align-content: center;
        height: 50px;
    }

    .pageCompany .table .access .box {
        width: 100%;
    }

    .pageCompany .table .access .box .img {
        margin-bottom: 10px;
    }

    .pageCompany .table .member .left {
        display: inline-block;
        width: 125px;
    }

    .pageCompany .table .member .right {
        display: inline-block;
        width: calc(100% - 125px);
    }

}

.pageCompany .bg {
    background-color: #fff;
    padding: 50px 45px;
    border-radius: 10px;
}

.pageCompany .bg .bgInner {
    max-width: 823px;
    margin: 0 auto;
    text-align: left;
}


.productsBoxList .listBox {
    padding: 0 10px;
}

.productsBoxList .squareList li {
    padding-right: 20px;
    margin-bottom: 12px;
}

.pageCompany .squareList1 {
    width: 30%;
}

.pageCompany .squareList2 {
    width: 21%;
}

.pageCompany .squareList3 {
    width: 33%;
}

.pageCompany .squareList4 {
    width: 16%;
}

.pageCompany .sectionBlue {
    margin-top: -80px;
}

.pageCompany .sectionBlue .content {
    text-align: center;
    padding: 70px 0 95px;
}

.pageCompany .sectionBlue .content h2 {
    color: #fff;
    background: url(../img/common/content-h2-white.svg) no-repeat top 13px left;
    background-size: 22px;
    display: inline-block;
}

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

    .pageCompany .bg {
        background-color: #fff;
        padding: 40px 20px;
        border-radius: 10px;
    }

    .pageCompany .bg .bgInner {
        max-width: 823px;
        margin: 0 auto;
        text-align: left;
    }

    .pageCompany .squareList {
        width: 50%;
    }

    .productsBoxList .squareList li {
        width: 100%;
        padding-right: 0;
    }

    .pageCompany .sectionBlue {
        margin-top: -51px;
    }

    .pageCompany .sectionBlue .content {
        padding: 60px 0 55px 0;
        width: calc(100% - 32px);
    }

    .pageCompany .sectionBlue .content h2 {
        background: url(../img/common/content-h2-white.svg) no-repeat top 11px left;
        background-size: 20px;
        margin-bottom: 20px;
    }

}

@media screen and (max-width: 600px) {
    .pageCompany .squareList {
        width: 100%;
    }

    .pageCompany .squareList li {
        width: 100%;
    }
}

/*topWave*/
.topWave {
    background: url(../img/common/topWave.webp) no-repeat top center;
    background-size: 100% auto;
    padding-top: 148px;
    background-color: #F3F5F9;
    margin-top: 100px;
    padding-bottom: 80px;
}

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

    .topWave {
        padding-top: 70px;
        margin-top: 70px;
        padding-bottom: 50px;
    }

}

/*bgWhiteLeft*/
.bgWhiteLeft {
    position: relative;
}

.bgWhiteLeft::before {
    content: "";
    position: absolute;
    top: 230px;
    left: 0;
    background-color: #fff;
    width: calc(100% - 40px);
    height: calc(100% - 450px);
    border-radius: 0 80px 80px 0;
}

.bgWhiteLeft .inner {
    position: relative;
}

.bgWhiteInner {
    margin: 150px 0 200px 0;
}

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

    .bgWhiteLeft {
        position: relative;
    }

    .bgWhiteLeft::before {
        top: 125px;
        width: 100%;
        height: calc(100% - 238px);
        border-radius: 0 50px 50px 0;
    }

    .bgWhiteLeft .inner {
        position: relative;
    }

    .bgWhiteInner {
        margin: 80px 0 120px 0;
    }

    .pageCompany .chart .img img {
        width: 100%;
    }

}

/*bgGrayLeft*/
.bgGrayLeft,
.bgGrayRight {
    position: relative;
    padding: 97px 0 90px 0;
}

.bgGrayLeft .inner,
.bgGrayRight .inner {
    width: calc(100% - 160px);
}

.bgGrayLeft::before,
.bgGrayRight::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    background-color: #F3F5F9;
    width: calc(100% - 40px);
    height: 100%;
    border-radius: 0 80px 80px 0;
    z-index: -1;
}

.bgGrayRight::before {
    left: auto;
    right: 0;
    border-radius: 80px 0 0 80px;
}

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

    .bgGrayLeft,
    .bgGrayRight {
        padding: 60px 0;
    }

    .bgGrayLeft .inner,
    .bgGrayRight .inner {
        width: calc(100% - 32px);
    }

    .bgGrayLeft::before,
    .bgGrayRight::before {
        width: 100%;
        border-radius: 0 50px 50px 0;
    }

    .bgGrayRight::before {
        border-radius: 50px 0 0 50px;
    }

}

/*squareList*/
.squareList {
    row-gap: 7px;
}

ul.squareList li {
    position: relative;
    padding-left: 17px;
    font-size: 18px;
    font-weight: 500;
    line-height: 1.45;
    margin-bottom: 0;
    min-width: 202px;
}

@media screen and (min-width: 1024px) {

    .productsBoxList ul.squareList li:nth-child(3n-1) {
        width: 47%;
    }
}

ul.squareList li::before {
    content: "";
    position: absolute;
    top: 12px;
    left: 0;
    width: 8px;
    height: 8px;
    background: #004EA2;
}

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

    .productsBoxList .listBox,
    .companyList {
        row-gap: 7px;
    }

    ul.squareList li {
        font-size: 16px;
    }

    ul.squareList li::before {
        top: 9px;
    }

}

/*pageHistory*/
.pageHistory .table th {
    text-align: center;
    vertical-align: middle;
}

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

    .pageHistory .table th {
        text-align: left;
    }

}

/*pageQualification*/
.pageQualification .text {
    font-size: 15px;
    margin-bottom: 25px;
}

.pageQualification .text2 {
    font-size: 15px;
    margin-top: 15px;
    text-align: right;
}

.pageQualification .table th {
    width: 330px;
}

.pageQualification .table td {
    width: calc(100% - 330px);
}

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

    .pageQualification .table th,
    .pageQualification .table td {
        width: 100%;
    }

}

/*pageCalendar*/
.pageCalendar .content.inner {
    max-width: 906px;
    margin-bottom: 128px;
}

.pageCalendar .img img {
    width: 100%;
}

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

    .pageCalendar .content.inner {
        margin-bottom: 0;
    }

}

/*pageNews*/
.pageCase .tabs {
    justify-content: center;
}

.tabs .tabItem {
    font-weight: 700;
    text-align: center;
    display: block;
    float: left;
    text-align: center;
    font-weight: bold;
    transition: all 0.2s ease;
}

.pageNewsList .tabs .tabItem {
    width: calc(100% / 5);
    background-color: #F3F5F9;
}

.tabs .tabItem.sp {
    display: none;
}

.pageNewsList .tabs .tabItem1 {
    padding-left: 12px;
    border-radius: 10px 0 0 10px;
}

.pageNewsList .tabs .tabItem5 {
    padding-right: 12px;
    border-radius: 0 10px 10px 0;
}

.tabs .tabInner {
    color: #fff;
    background-color: #fff;
    padding: 15px 5px;
    border-radius: 50px;
    text-align: center;
    display: block;
    margin: 0 16px;
    border: 1px solid #B9B9B9;
    color: #0E3B73;
    transition: .3s;
    cursor: pointer;
}

.pageNewsList .tabs .tabInner {
    border-radius: 5px;
    margin: 19px 12px;
}

.pageCase .tabs .tabInner {
    width: 258px;
    background: url(../img/common/icon-bottom-blue.svg) no-repeat center right 15px;
    background-size: 13.7px;
    background-color: #F3F5F9;
    border: 1px solid #0E3B73;
}

.tabs .tabItem:hover .tabInner {
    color: #fff;
    background-color: #0E3B73;
    border: 1px solid #0E3B73;
}

.pageCase .tabs .tabItem:hover .tabInner {
    background: url(../img/common/icon-bottom-white.svg) no-repeat center right 15px;
    background-size: 13.7px;
    background-color: #0E3B73;
    color: #fff;
}

/*ラジオボタンを全て消す*/
.tabs input[name="tabItem"] {
    display: none;
}

/*タブ切り替えの中身のスタイル*/
.tabs .tabContent {
    position: relative;
    display: none;
    padding: 65px 0 0 0;
    clear: both;
    overflow: hidden;
}

.pageCase .tabs .tabContent {
    width: 100%;
    padding: 75px 0 0 0;
}

/*選択されているタブのコンテンツのみを表示*/
#tabsA:checked~#tabsAContent,
#tabsB:checked~#tabsBContent,
#tabsC:checked~#tabsCContent,
#tabsD:checked~#tabsDContent,
#tabsE:checked~#tabsEContent {
    display: block;
}

/*選択されているタブのスタイルを変える*/
.tabs input:checked+.tabItem .tabInner {
    color: #fff;
    background-color: #0E3B73;
    border: 1px solid #0E3B73;
}

.pageCase .tabs input:checked+.tabItem .tabInner {
    background: url(../img/common/icon-bottom-white.svg) no-repeat center right 15px;
    background-size: 13.7px;
    background-color: #0E3B73;
}

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

    .tabs .tabItem,
    .pageNewsList .tabs .tabItem {
        width: calc(100% / 2);
    }

    .tabs .tabItem.sp {
        display: block;
        height: 86.8px;
        border-radius: 0 0 10px 0;
    }

    .pageNewsList .tabs .tabItem1 {
        padding-left: 2px;
        padding-top: 18px;
        border-radius: 10px 0 0 0;
    }

    .pageNewsList .tabs .tabItem2 {
        padding-right: 2px;
        padding-top: 18px;
        border-radius: 0 10px 0 0;
    }

    .pageNewsList .tabs .tabItem3 {
        padding-left: 2px;
    }

    .pageNewsList .tabs .tabItem4 {
        padding-right: 2px;
    }

    .pageNewsList .tabs .tabItem5 {
        padding-bottom: 18px;
        padding-left: 2px;
        padding-right: 0;
        border-radius: 0 0 0 10px;
    }

    .tabs .tabInner,
    .pageNewsList .tabs .tabInner {
        margin: 4px 5px;
    }

    .pageCase .tabs .tabItem,
    .pageCase .tabs .tabInner {
        width: 100%;
    }

    .tabWrapper{
        display: block;
        width: 100% !important;
    }

    /*タブ切り替えの中身のスタイル*/
    .tabs .tabContent,
    .pageCase .tabs .tabContent {
        padding: 42px 0 0 0;
    }

}

/*pageNewsSub*/
.pageNewsSub .content h2 {
    margin-top: 15px;
    border-bottom: 1px solid #B9B9B9;
    padding-bottom: 20px;
}

.pageCaseSub .content .title {
    margin-top: 15px;
}

.main.page.pageNewsSub .content {
    max-width: 960px;
}

.pageNewsSub .modBtn1 {
    margin: 70px auto 0 auto;
}

.pageCaseSub .modBtn1,
.pageServiceDetail .modBtn1 {
    margin: 40px auto 0 auto;
}

.newsContent .imgBox {
    max-width: 862px;
    margin: 45px auto 0 auto;
    row-gap: 15px;
}

.newsContent .imgBox img {
    margin: 0 15px;
    width: calc(50% - 30px);
}

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

    .pageNewsSub .content h2 {
        padding-bottom: 15px;
    }

    .pageNewsSub .modBtn1 {
        margin: 50px auto 0 auto;
    }

    .pageCaseSub .modBtn1,
    .pageServiceDetail .modBtn1 {
        margin: 30px auto 0 auto;
    }

    .newsContent .imgBox {
        margin: 30px auto 0 auto;
    }

    .newsContent .imgBox img {
        margin: 0;
        width: 100%;
    }

}

/*pageCaseSub*/
.fvImg {
    margin-bottom: 48px;
}

.fvImg img {
    border-radius: 10px;
    height: 400px;
    width: 100%;
    object-fit: cover;
}

.pageServiceDetail .fvImg img,
.pagePurpose .fvImg img {
    height: 320px;
}

.project {
    padding: 30px 40px;
    border-radius: 10px;
    background-color: #F3F5F9;
    margin-bottom: 70px;
}

.project h5 {
    font-size: 18px;
    margin-bottom: 24px;
}

.project h5::before,
.productsBox h5::before {
    top: 14px;
}

.project .flex {
    justify-content: space-between;
    column-gap: 60px;
    row-gap: 15px;
}

.project .flex .box {
    width: calc(50% - 30px);
}

.project .flex .box dt {
    color: #fff;
    background-color: #0E3B73;
    border-radius: 2px;
    text-align: center;
    padding: 3px;
    margin-right: 15px;
    width: 116px;
    display: inline-block;
    vertical-align: top;
}

.project .flex .box dd {
    width: calc(100% - 135px);
    display: inline-block;
}

/*flexBox*/
.flexBox {
    position: relative;
    justify-content: space-between;
    column-gap: 45px;
    row-gap: 10px;
    margin-bottom: 75px;
}

.pageServiceDetail .flexBox {
    row-gap: 20px;
}

.pageService .flexBox {
    align-items: center;
    margin-bottom: 0;
}

.flexBox2 {
    margin-bottom: 40px;
    row-gap: 15px;
}

.flexBox3 {
    margin-bottom: 30px;
    column-gap: 15px;
    row-gap: 12px;
}

.pageServiceDetail .flexBox3 {
    margin: 20px 0 0 0;
}

.flexBox4 {
    margin-bottom: 80px;
    row-gap: 20px;
}

.flexBox5 {
    margin-bottom: 55px;
    column-gap: 35px;
    row-gap: 40px;
}

.pageServiceDetail .flexBox5 {
    margin-bottom: 0;
    row-gap: 33px;
}

.flexBox3::before {
    content: "";
    display: block;
    width: calc(100% / 4 - 11.5px);
    order: 4;
}

.flexBox3::after {
    content: "";
    display: block;
    width: calc(100% / 4 - 11.5px);
}

/* 事例紹介 */
.flexBox.caseImg {
    column-gap: 27px;
    row-gap: 32px;
    justify-content: flex-start;
}

.flexBox.caseImg img {
    width: calc((100% - 54px)/3);
    height: 240px;
}

@media screen and (max-width: 1023px) {
    .flexBox.caseImg img {
        width: calc((100% - 27px)/2);
    }
}

@media screen and (max-width: 600px) {
    .flexBox.caseImg img {
        width: 100%;
        height: 235px;
    }
}

.flexBox .img,
.flexBox p,
.flexBox .text {
    width: calc(50% - 22.5px);
}

.pageService .flexBox p {
    width: 100%;
}

.pageService .flexBox .modBtn1 {
    margin: 50px 0 0 auto;
}

.pagePurpose .flexBox img {
    height: 25vw;
    max-height: 292px;
}

.flexBox3 .img {
    width: calc(100% / 4 - 11.5px);
}

.flexBox4 .img {
    width: 420px;
}

.flexBox4 .text {
    width: calc(100% - 465px);
}

.flexBox5 .box {
    width: calc(100% / 3 - 26.5px);
}

.flexBox5::after {
    content: "";
    display: block;
    width: calc(100% / 3 - 26.5px);
}

.flexBox5 .img {
    width: 100%;
    margin-bottom: 20px;
}

.flexBox5 .text {
    width: 100%;
    padding: 0 15px;
}

.flexBox5 .text h5 {
    margin-bottom: 10px;
    font-size: 18px;
}

.flexBox5 .text h5::before {
    top: 13px;
}

.flexBox5 p {
    font-size: 15px;
    width: 100%;
}

.flexBox img {
    border-radius: 10px;
    height: 300px;
    width: 100%;
    object-fit: cover;
}

.pageCaseSub .flexBox img,
.pageService .flexBox img {
    border-radius: 10px;
}

.flexBox5 img {
    height: 234px;
}

.pageServiceDetail .flexBox5 img,
.pagePurpose .flexBox5 img {
    max-height: 211px;
    height: 17vw;
}

.pageServiceDetail .flexBox5 .modBtn1 {
    margin: 15px 0 0 auto;
    max-width: 143px;
}

.pageServiceDetail .flexBox5 .modBtn1 .a {
    height: 40px;
}

.pageServiceDetail .flexBox5 .modBtn1 .a .btnInner,
.pageServiceDetail .flexBox5 .box:hover .modBtn1 .a .btnInner {
    font-size: 14px;
    padding: 6px 19px;
    background-size: 26px;
    background-position: center right 15px;
}

.flexBox3 img {
    height: 180px;
}

.pageServiceDetail .flexBox3 img {
    height: 150px;
    border-radius: 0;
}

.pageServiceDetail .flexBox5 a.box .img {
    overflow: hidden;
    border-radius: 10px;
}

.pageServiceDetail .flexBox5 a.box .img img {
    transition: .3s;
}

.pageServiceDetail .flexBox5 a.box:hover img {
    transform: scale(1.1);
}

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

    .fvImg {
        margin-bottom: 33px;
    }

    .fvImg img {
        min-height: 160px;
        height: 42.66666666666667vw;
    }

    .pageServiceDetail .fvImg img,
    .pagePurpose .fvImg img {
        min-height: 195px;
        height: 52vw;
    }

    .project {
        padding: 30px 22px;
        margin-bottom: 45px;
    }

    .project h5 {
        font-size: 16px;
        margin-bottom: 15px;
    }

    .project h5::before,
    .productsBox h5::before {
        top: 11px;
    }

    .project .flex {
        row-gap: 10px;
    }

    .project .flex .box {
        width: 100%;
    }

    .project .flex .box dt {
        font-size: 14px;
        border: 1px solid #CFD8E3;
        padding: 3px;
        margin-right: 0;
        width: 100px;
        display: block;
        margin-bottom: 3px;

    }

    .project .flex .box dd {
        font-size: 15px;
        width: 100%;
        display: block;
    }

    /*flexBox*/
    .flexBox,
    .flexBox2 {
        margin-bottom: 30px;
    }

    .flexBox3 {
        margin-bottom: 15px;
        column-gap: 5px;
    }

    .flexBox4 {
        margin-bottom: 50px;
    }

    .flexBox .img,
    .flexBox p,
    .flexBox .text {
        width: 100%;
    }

    .flexBox1 p {
        order: 1;
    }

    .pageService .flexBox .modBtn1 {
        margin: 30px 0 0 auto;
    }

    .flexBox1 .img {
        order: 2;
    }

    .flexBox img {
        min-height: 195px;
        height: 52vw;
    }

    .pagePurpose .flexBox img {
        min-height: 156px;
        max-height: 100%;
        height: 41.6vw;
    }

    .flexBox3::after,
    .flexBox3::before {
        width: calc(50% - 5.5px);
    }

    .flexBox3 .img {
        order: initial;
        width: calc(50% - 5.5px);
    }

    .pageServiceDetail .flexBox3 .img {
        width: 100%;
    }

    .flexBox3 img {
        min-height: 113px;
        height: 30.133333333333333vw;
    }

    .pageServiceDetail .flexBox3 img {
        min-height: 176px;
        height: 46.93333333333333vw;
    }

    .flexBox5 img {
        min-height: 232px;
        height: 61.86666666666667vw;
    }

    .pageServiceDetail .flexBox5 img,
    .pagePurpose .flexBox5 img {
        min-height: 210px;
        max-height: 100%;
        height: 56.00000000000001vw;
    }

    .flexBox5 {
        row-gap: 30px;
    }

    .flexBox5 .box {
        width: 100%;
    }

    .flexBox5 .text {
        width: 100%;
        padding: 0;
    }

    .flexBox5 .text h5 {
        font-size: 16px;
    }

    .flexBox5 .text h5::before {
        top: 11px;
    }

    .pageServiceDetail .flexBox5::after {
        display: none;
    }

}

/*productsLinks*/
.productsLinks {
    position: relative;
    column-gap: 15px;
    row-gap: 12px;
    margin-bottom: 72px;
}

.productsLinks::after {
    content: "";
    display: block;
    width: calc(100% / 4 - 11.5px);
}

.productsLinks .box {
    position: relative;
    width: calc(100% / 4 - 11.5px);
    background-color: #0E3B73;
    border: 1px solid #0E3B73;
    height: 112px;
    transition: .2s;
    overflow: hidden;
    min-width: 265px;
}

.productsLinks .box:hover {
    background-color: #004EA2;
    border: 1px solid #004EA2;
}

.productsLinks .box::before {
    content: "";
    position: absolute;
    bottom: 0;
    right: 0;
    width: 14.62px;
    height: 14.62px;
    background-image: linear-gradient(-45deg, #0E3B73 10px, transparent 0);
    z-index: 1;
}

.productsLinks .box:hover::before {
    background-image: linear-gradient(-45deg, #7ECEF4 10px, transparent 0);
}

.productsLinks .box .text {
    text-align: center;
    color: #fff;
    font-weight: bold;
    margin: auto 0;
    width: calc(100% - 115px);
    line-height: 1.5;
}

.productsLinks .box .img {
    width: 115px;
    overflow: hidden;
}

.productsLinks .box .img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: .2s;
}

.productsLinks .box:hover .img img {
    transform: scale(1.1);
}

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

    .productsLinks {
        margin-bottom: 50px;
    }

    .productsLinks::after {
        width: 100%;
    }

    .productsLinks .box {
        width: 100%;
        height: 83px;
    }

    .productsLinks .box .text {
        text-align: left;
        padding-left: 20px;
        width: calc(100% - 85px);
    }

    .productsLinks .box .img {
        width: 85px;
    }

}

/*pageProducts*/
.bgGrayRight .content h3:first-child {
    margin-top: 0;
}

/*productsBox*/
.productsBox {
    row-gap: 15px;
    background-color: #fff;
    border-radius: 10px;
    padding: 27px 30px;
    margin-bottom: 20px;
}

.productsBoxList {
    padding: 39px 28px;
    border: 1px solid rgba(14, 59, 115, .2);
    margin-top: 47px;
    margin-bottom: 70px;
}

.productsBox .img {
    width: 280px;
    height: 190px;
    margin-right: 25px;
    border: 1px solid #B9B9B9;
    border-radius: 5px;
}

.productsBox .img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 5px;
}

.productsBox .text {
    width: calc(100% - 305px);
}

.productsBox.noImg .text {
    width: 100%;
}

.productsBox .text h5 {
    font-size: 18px;
    margin-top: 15px;
    margin-bottom: 15px;
}

.productsBox .text h5:first-child {
    margin-top: 0;
}

.productsBoxList h4 {
    margin-top: 0;
    padding-bottom: 15px;
    border-bottom: 1px solid #D6D6D6;
}

.pageProducts .content h3.sec-products {
    margin-top: 80px;
}

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

    .productsBox {
        padding: 30px 20px;
    }

    .productsBoxList {
        padding: 30px 20px;
        margin-top: 30px;
        margin-bottom: 40px;
    }

    .productsBox .img {
        margin: 0 auto;
        max-width: 280px;
        width: calc(100% - 20px);
    }

    .productsBox .text {
        width: 100%;
    }

    .productsBox .text h5 {
        font-size: 16px;
    }

    .productsBoxList h4 {
        padding-bottom: 10px;
    }
}

/*bannerLink*/
.bannerLink {
    position: relative;
    margin-top: 50px;
    margin-bottom: 80px;
    border-radius: 10px;
}

.bannerLink::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: .6;
    background-color: #0E3B73;
    border-radius: 10px;
    z-index: 1;
}

.bannerLink .img {
    width: 100%;
    height: 200px;
    border-radius: 10px;
    overflow: hidden;
}

.bannerLink .img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 10px;
    transition: .2s;
}

.bannerLink:hover .img img {
    transform: scale(1.1);
}

.bannerLink .text {
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    margin: auto;
    width: 100%;
    font-size: 26px;
    font-weight: bold;
    padding-bottom: 15px;
    padding-left: 74px;
    color: #fff;
    z-index: 2;
    background: url(../img/common/icon-right-white.svg) no-repeat center right 70px;
    background-size: 34.58px;
}

.bannerLink:hover .text {
    background: url(../img/common/icon-right-hover.svg) no-repeat center right 70px;
}

.bannerLink .text::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 74px;
    width: 107px;
    height: 2px;
    background-color: #fff;
}

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

    .bannerLink {
        margin-top: 30px;
        margin-bottom: 50px;
    }

    .bannerLink .img {
        height: 180px;
    }

    .bannerLink .text {
        font-size: 22px;
        line-height: 1.36;
        padding-bottom: 10px;
        padding-left: 20px;
        background: url(../img/common/icon-right-white.svg) no-repeat center right 20px;
    }

    .bannerLink:hover .text {
        background: url(../img/common/icon-right-hover.svg) no-repeat center right 20px;
    }

    .bannerLink .text::before {
        content: "";
        position: absolute;
        bottom: 0;
        left: 20px;
        width: 107px;
        height: 2px;
        background-color: #fff;
    }

}

/*pageProductsDetail*/
.pageProductsDetail .modBtn1 {
    margin: 20px 0 55px auto;
}

.pageProductsDetail #category4 {
    margin-top: 80px;
}

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

    .pageProductsDetail .modBtn1 {
        margin: 20px auto 50px auto;
    }

    .pageProductsDetail .flexBox4 .modBtn1 {
        margin: 20px auto 0 auto;
    }

    .pageProductsDetail #category4 {
        margin-top: 50px;
    }

}

/*pageService*/
.pageService .bgGrayRight,
.pageServiceDetail .bgGrayRight,
.pagePurpose .bgGrayRight {
    margin-bottom: 100px;
}

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

    .pageService .bgGrayRight,
    .pageServiceDetail .bgGrayRight,
    .pagePurpose .bgGrayRight {
        margin-bottom: 60px;
    }

    .pageService .flexBox1 .img {
        order: 1;
    }

    .pageService .flexBox1 .text {
        order: 2;
    }

}

/*pageServiceDetail*/
.pageServiceDetail .bgGrayRight .content h3 {
    margin-top: 70px;
}

.serviceBox {
    position: relative;
    justify-content: space-between;
    column-gap: 30px;
    row-gap: 30px;
}

.serviceBox .box {
    width: calc(50% - 15px);
    background-color: #fff;
    border-radius: 10px;
    padding: 30px;
}

.serviceBox .box .img {
    width: 145px;
    padding-right: 25px;
}

.serviceBox .box .img img {
    width: 120px;
    height: 120px;
    object-fit: cover;
}

.serviceBox .box .text {
    width: calc(100% - 145px);
}

.serviceBox .box .text h5 {
    font-size: 18px;
    padding-bottom: 5px;
    margin-bottom: 10px;
}

.serviceBox .box .text h5::before {
    top: 13px;
}

.serviceBox .box .text p {
    font-size: 15px;
    line-height: 1.6;
}

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

    .pageServiceDetail .bgGrayRight .content h3 {
        margin-top: 45px;
    }

    .serviceBox {
        row-gap: 15px;
    }

    .serviceBox .box {
        width: 100%;
        padding: 40px 20px;
    }

    .serviceBox .box .img {
        width: 100%;
        padding-right: 0;
    }

    .serviceBox .box .img img {
        width: 100px;
        height: 100px;
        margin: 0 auto 20px auto;
    }

    .serviceBox .box .text {
        width: 100%;
    }

    .serviceBox .box .text h5 {
        font-size: 16px;
    }

    .serviceBox .box .text h5::before {
        top: 11px;
    }

}

.toggleSection {
    background-color: #fff;
    border-radius: 10px;
    border: 1px solid #B9B9B9;
    padding: 0 20px;
    margin-top: 25px;
}

.toggleSection .child {
    display: none;
    background-color: #F3F5F9;
    border-radius: 16px;
    padding: 20px 50px 50px 50px;
    margin: 20px 0 30px 0;
}

.toggleSection .child h4 {
    margin-top: 30px;
}

.pageServiceDetail #item3 {
    margin-top: 70px;
}

.pageServiceDetail .bgGrayRight .content .toggleSection .img.gmdss-img img {
    max-width: 800px;
    width: 100%;
}

.pageServiceDetail .bgGrayRight .content .toggleSection h3 {
    font-size: 23px;
    margin-top: 0;
    margin-bottom: 0;
    padding: 17px 20px;
    border-bottom: none;
    color: inherit;
    cursor: pointer;
}

.pageServiceDetail .bgGrayRight .content .toggleSection h3::before {
    width: 4px;
    height: 48px;
    top: 0;
    left: -5px;
}

.pageServiceDetail .bgGrayRight .content .toggleSection .toggleBtn .icon {
    display: block;
    position: absolute;
    top: 14px;
    cursor: pointer;
    width: 39px;
    height: 39px;
    border-radius: 39px;
    right: 0;
    background-color: #F3F5F9;
}

.pageServiceDetail .bgGrayRight .content .toggleSection .toggleBtn .icon::before {
    /* アイコン横棒 */
    content: '';
    height: 2px;
    width: 17px;
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    margin: auto;
    background: #0E3B73;
}

.pageServiceDetail .bgGrayRight .content .toggleSection .toggleBtn .icon:after {
    /* アイコン縦棒（閉じてるとき） */
    content: '';
    height: 17px;
    width: 2px;
    display: block;
    background: #0E3B73;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
}

.pageServiceDetail .bgGrayRight .content .toggleSection .toggleBtn.is-active .icon:after {
    /* アイコン縦棒なし（開いてるとき） */
    height: 0;
    width: 0;
}

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

    .toggleSection {
        border-radius: 5px;
    }

    .toggleSection .child {
        padding: 15px 15px 20px 15px;
        margin: 18px 0 40px 0;
    }

    .toggleSection .child h4 {
        margin-top: 25px;
    }

    .pageServiceDetail #item1 {
        margin-top: 45px;
    }

    .pageServiceDetail .bgGrayRight .content .toggleSection h3 {
        font-size: 20px;
        padding: 20px 40px 20px 20px;
    }

    .pageServiceDetail .bgGrayRight .content .toggleSection .toggleBtn .icon {
        top: 50%;
        transform: translateY(-50%);
    }

}

/*pagePurpose*/
.pagePurpose .pageSection {
    margin-bottom: 0;
}

.pagePurpose .topSection {
    position: relative;
    background: url(../img/common/bg-wave.png) no-repeat center bottom;
    background-size: 100% auto;
    padding-bottom: 165px;
}

.pagePurpose .topSection .flexBox .img:last-child {
    margin: 28px 0 0 0;
}

.pagePurpose .topSection .topText {
    max-width: 654px;
    margin: 0 auto;
}

.pagePurpose .bg {
    position: relative;
    background-color: #F3F5F9;
    padding-top: 90px;
    z-index: 1;
    padding-bottom: 120px;
}

.pagePurpose .bgGrayLeft::before,
.pagePurpose .bgGrayRight::before {
    background-color: #fff;
}

.pagePurpose .content h3 {
    margin-top: 70px;
    margin-bottom: 30px;
}

.pagePurpose .flexBox {
    row-gap: 17px;
}

.pagePurpose .flexBox5 {
    margin-top: 35px;
    margin-bottom: 30px;
    row-gap: 30px;
}

.pagePurpose .bannerLink {
    margin: 0;
}

.pagePurpose .ilust {
    position: absolute;
    top: -90px;
    left: 50%;
    transform: translateX(-50%);
    margin: auto;
}

.pagePurpose .ilust img {
    margin: 0 0 0 auto;
}

.pagePurpose .ilust1 img {
    width: 174px;
}

.pagePurpose .ilust2 img {
    width: 172px;
}

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

    .pagePurpose .topSection {
        padding-bottom: 65px;
    }

    .pagePurpose .topSection .flexBox .img:first-child {
        margin: 0 60px 0 0;
    }

    .pagePurpose .topSection .flexBox .img:last-child {
        margin: 0 0 0 60px;
    }

    .pagePurpose .bg {
        padding-top: 50px;
        padding-bottom: 72px;
    }

    .pagePurpose .content h3 {
        margin-top: 40px;
        margin-bottom: 25px;
    }

    .pagePurpose .flexBox5 {
        margin-top: 30px;
        margin-bottom: 40px;
    }

    .pagePurpose .ilust {
        top: -70px;
    }

    .pagePurpose .ilust1 img,
    .pagePurpose .ilust2 img {
        width: 131px;
    }

}

/*確認用
body::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url(../img/sp.jpg) no-repeat top center;
    background-size: 100% auto;
    z-index: 10000;
    opacity: .8;
}*/