@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&family=Zen+Kaku+Gothic+New:wght@300;400;500;700;900&display=swap');

/*
font-family: "Noto Sans JP", serif;
font-family: "Roboto", serif;
font-family: "Zen Kaku Gothic New", 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;
}

picture {
    display: block;
}

picture img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

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

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

    body {
        font-size: 15px;
        line-height: 1.86666666;
    }

}

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: 1224px;
    width: calc(100% - 160px);
    margin: 0 auto;
    box-sizing: border-box;
}

.inner1 {
    max-width: 1066px;
}

.innerPd {
    padding: 0 12px;
}

main.main {
    margin-top: 90px;
}

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

.sp {
    display: none;
}

.blue {
    color: #005EAD;
}

.red {
    color: #F26339;
}

.bold {
    font-weight: 700;
}

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

/*modBtn1*/
.modBtn1 {
    margin: 30px 27px 0 0;
    text-align: right;
}

.modBtn1 a {
    display: inline-block;
    position: relative;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.8125;
    padding-right: 60px;
}

.modBtn1 a .icon {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    margin: auto;
    width: 40px;
    height: 40px;
    border-radius: 40px;
}

.modBtn1 a .icon::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 50px;
    transition: .2s;
    z-index: -1;
    background: linear-gradient(to right, #4B97E0, #005EAD);
    transform: scale(1);
}

.modBtn1 a .icon::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: center;
    background-size: 8.66px;
    background-image: url(../img/common/icon-right-white.svg);
}

/*modBtn2*/
.modBtn2 a {
    position: relative;
    font-size: 18px;
    font-weight: 700;
    line-height: 1.8125;
    padding: 20px 80px 20px 20px;
}

.modBtn2 a .icon {
    position: absolute;
    top: 50%;
    right: 20px;
    transform: translateY(-50%);
    margin: auto;
    width: 30px;
    height: 30px;
    border-radius: 30px;
}

.modBtn2 a .icon::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 38.04px;
    transition: .2s;
    z-index: -1;
    background: linear-gradient(to right, #4B97E0, #005EAD);
    transform: scale(1);
}

.modBtn2 a .icon::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: center;
    background-size: 6.5px;
    background-image: url(../img/common/icon-right-white.svg);
}

/*modBtn3*/
.modBtn3 {
    position: relative;
    font-size: min(20px, 1.19vw);
    font-weight: 700;
    line-height: 1.8125;
    padding: 15px 60px 15px 20px;
    background-color: #fff;
    border-radius: 0 0 5px 5px;
}

.modBtn3 .icon {
    position: absolute;
    top: 50%;
    right: 20px;
    transform: translateY(-50%);
    margin: auto;
    width: min(40px, 2.857142857142857vw);
    height: min(40px, 2.857142857142857vw);
    border-radius: 40px;
}

.modBtn3 .icon::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 38.04px;
    transition: .2s;
    z-index: -1;
    background: linear-gradient(to right, #4B97E0, #005EAD);
    transform: scale(1);
}

.modBtn3 .icon::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: center;
    background-size: 8.66px;
    background-image: url(../img/common/icon-right-white.svg);
}

/*modBtn4*/
.modBtn4 {
    margin: 20px 0 0 0;
    text-align: right;
}

.modBtn4 a {
    position: relative;
    display: inline-block;
    font-size: 13px;
    font-weight: 500;
    line-height: 1.8125;
    padding: 10px 53px 10px 0;
    text-decoration: underline;
    text-underline-offset: 8px;
}

.modBtn4 a .icon {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    margin: auto;
    width: 40px;
    height: 40px;
    border-radius: 40px;
}

.modBtn4 a .icon::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 38.04px;
    transition: .2s;
    z-index: -1;
    background: linear-gradient(to right, #4B97E0, #005EAD);
    transform: scale(1);
}

.modBtn4 a .icon::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: center;
    background-size: 8.66px;
    background-image: url(../img/common/icon-right-white.svg);
}

/*modBtn5*/
.modBtn5 {
    margin: 65px auto 0 auto;
    text-align: center;
    max-width: 300px;
    height: 55px;
}

.modBtn5 a,
.modBtn5 button {
    display: block;
    position: relative;
    font-size: 18px;
    font-weight: 600;
    line-height: 1.66666666666;
    padding: 10px;
    background-color: #005EAD;
    border: 1px solid #005EAD;
    color: #fff;
    border-radius: 5px;
    height: 55px;
    width: 100%;
    cursor: pointer;
    transition: .2s;
}

.modBtn5 a .icon,
.modBtn5 button .icon {
    position: absolute;
    top: 50%;
    right: 17px;
    transform: translateY(-50%);
    margin: auto;
    width: 30px;
    height: 30px;
    border-radius: 30px;
}

.modBtn5 a .icon::before,
.modBtn5 button .icon::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 34px;
    transition: .2s;
    z-index: -1;
    background-color: #fff;
    transform: scale(1);
}

.modBtn5 a .icon::after,
.modBtn5 button .icon::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: center;
    background-size: 6.6px;
    background-image: url(../img/common/icon-right-blue.svg);
}

/*modBtn6*/
.modBtn6 {
    margin: 24px auto 0 auto;
    max-width: 515px;
    height: 120px;
}

.modBtn6 a {
    display: block;
    position: relative;
    padding: 29px 80px 29px 119px;
    border: 1px solid #005EAD;
    color: #fff;
    border-radius: 5px;
    width: 100%;
    cursor: pointer;
    background: url(../img/common/bn_icon_02.svg) no-repeat center left 26px;
    background-size: 67px;
    background-color: #005EAD;
    transition: .2s;
}

.modBtn6 a .bold {
    display: block;
    font-size: 22px;
    line-height: 1.454545454545;
    margin-bottom: 8px;
}

.modBtn6 a .icon {
    position: absolute;
    top: 50%;
    right: 22px;
    transform: translateY(-50%);
    margin: auto;
    width: 34px;
    height: 34px;
    border-radius: 34px;
}

.modBtn6 a .icon::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 46px;
    transition: .2s;
    z-index: -1;
    background-color: #fff;
    transform: scale(1);
}

.modBtn6 a .icon::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: center;
    background-size: 7.3px;
    background-image: url(../img/common/icon-right-blue.svg);
}

/*modBtn7*/
.modBtn7 {
    margin-bottom: 16px;
    max-width: 340.46px;
}

.modBtn7 a {
    display: inline-block;
    position: relative;
    font-weight: 700;
    line-height: 1.5;
    padding: 20px 40px 20px 53px;
    border: 1px solid #134671;
    color: #fff;
    border-radius: 5px;
    width: 100%;
    cursor: pointer;
    background-color: #134671;
    transition: .2s;
}

.modBtn7.xlsx a {
    background-image: url(../img/common/xlsx.png), url(../img/common/icon-right-white2.svg);
    background-repeat: no-repeat, no-repeat;
    background-position: center left 20px, center right 20px;
    background-size: 23.91px, 6.56px;
}

.modBtn7.docx a {
    background-image: url(../img/common/docx.png), url(../img/common/icon-right-white2.svg);
    background-repeat: no-repeat, no-repeat;
    background-position: center left 20px, center right 20px;
    background-size: 23.91px, 6.56px;
}

.modBtn7.pdf a {
    background-image: url(../img/common/pdf.png), url(../img/common/icon-right-white2.svg);
    background-repeat: no-repeat, no-repeat;
    background-position: center left 20px, center right 20px;
    background-size: 23.91px, 6.56px;
}

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

.sectionTitle1 {
    text-align: center;
    margin-bottom: 34px;
}

.sectionTitle .en {
    font-family: "Roboto", serif;
    font-size: 18px;
    font-weight: 700;
    line-height: 1.5;
    padding-left: 24px;
    background: url(../img/common/sectionTitle-en.svg) no-repeat top 7px left;
    background-size: 18px;
    color: #005EAD;
}

.sectionTitle1 .en {
    font-size: 30px;
    padding: 0 41px;
    background-image: url(../img/common/sectionTitle-en.svg), url(../img/common/sectionTitle-en2.svg);
    background-repeat: no-repeat, no-repeat;
    background-position: center left, center right;
    background-size: 26px, 26px;
    color: inherit;
    display: inline-block;
}

.sectionTitle .ja {
    font-size: 30px;
    font-weight: 700;
    line-height: 1.5;
}

.sectionTitle.border {
    padding-bottom: 15px;
    margin-bottom: 25px;
}

.sectionTitle.border::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 50px;
    height: 2px;
    background-color: #005EAD;
}

.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;
}

/*タイトル*/
.index .title {
    font-family: "Zen Kaku Gothic New", serif;
    font-size: 24px;
    font-weight: 700;
    line-height: 1.5;
    color: #005EAD;
    margin-bottom: 10px;
}

.content h2 {
    position: relative;
    font-size: 30px;
    font-weight: 700;
    padding-bottom: 18px;
    padding-left: 43px;
    margin-bottom: 45px;
    line-height: 1.4;
    background: url(../img/common/sectionTitle-en.svg) no-repeat top 14px left;
    background-size: 30px;
    margin-top: 70px;
    border-bottom: 2px solid #C8C8C8;
}

.content h2::before {
    content: "";
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 110px;
    height: 2px;
    background: #005EAD;
}

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

.content h3 {
    position: relative;
    display: inline-block;
    font-size: 22px;
    font-weight: 700;
    line-height: 1.4;
    padding-left: 22px;
    margin-bottom: 25px;
    margin-top: 60px;
    background-size: 8px;
}

.content h3::before {
    content: "";
    position: absolute;
    top: 3.5px;
    left: 0;
    width: 8px;
    height: calc(100% - 6px);
    border-radius: 4px;
    background-color: #3CA0EB;
}

.content h3::after {
    content: "";
    position: absolute;
    top: 3.5px;
    left: 0;
    width: 8px;
    height: 12px;
    border-radius: 4px 4px 0 0;
    background-color: #005EAD;
}

.content h4 {
    position: relative;
    font-size: 20px;
    font-weight: 700;
    line-height: 1.4;
    padding-left: 21px;
    padding-bottom: 12px;
    margin-bottom: 25px;
    margin-top: 55px;
    border-bottom: 2px solid #C8C8C8;
}

.content h4.no-border {
    border-bottom: none;
    padding-bottom: 0;
}

.content h4::before {
    content: "";
    position: absolute;
    top: 10px;
    left: 0;
    width: 10px;
    height: 10px;
    border-radius: 3px;
    background: #005EAD;
}

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

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

    .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;
}

.content ul li::before {
    content: "";
    position: absolute;
    top: 11px;
    left: 5px;
    width: 7px;
    height: 7px;
    border-radius: 7px;
    background-color: #005EAD;
}

.pageRecruit .content ul li::before {
    content: "・";
    top: 0;
    left: 0;
    width: auto;
    height: auto;
    border-radius: 0;
    background-color: inherit;
    font-weight: 700;
}

.content ul.cmList li::before {
    content: "※";
    top: 0;
    left: 0;
    width: auto;
    height: auto;
    border-radius: 0;
    background-color: inherit;
    font-weight: 700;
}

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

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

    .pageRecruit .content ul li {
        font-size: 15px;
    }

}

/*pageMv*/
.pageMv {
    position: relative;
    height: 195px;
    margin-bottom: 20px;
    background: linear-gradient(to bottom, #CEE9FF, #F4FAFF);
}

.pageMv::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 167px;
    height: 108.5px;
    background: url(../img/common/pageMv-1.svg) no-repeat;
    background-size: 167px;
    mix-blend-mode: multiply;
}

.pageMv::after {
    content: "";
    position: absolute;
    bottom: 0;
    right: 0;
    width: 167px;
    height: 107.6px;
    background: url(../img/common/pageMv-2.svg) no-repeat;
    background-size: 167px;
    mix-blend-mode: multiply;
}

.pageMv .inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    height: 100%;
}

.pageMv .text {
    position: relative;
    display: inline-block;
    font-size: 20px;
    font-weight: bold;
    color: #005EAD;
    padding: 0 38px;
    margin-bottom: 5px;
}

.pageMv .text::before,
.pageMv .text::after {
    content: "";
    position: absolute;
    top: 17px;
    width: 25.96px;
    height: 1px;
    background-color: #005EAD;
}

.pageMv .text::before {
    left: 0;
    transform: rotate(-60deg);
}

.pageMv .text::after {
    right: 0;
    transform: rotate(-60deg);
}

.pageMv .pageMvTitle {
    position: relative;
    font-size: 38px;
    font-weight: 700;
    line-height: 1.315789473;
}

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

    .pageMv {
        height: 188px;
        margin-bottom: 22px;
    }

    .pageMv::before,
    .pageMv::after {
        width: 67.28px;
        height: 43.71px;
        background-size: 67.28px;
    }

    .pageMv .text {
        font-size: 17px;
        padding: 0 35px;
    }

    .pageMv .text::before,
    .pageMv .text::after {
        top: 15px;
        width: 23.92px;
    }

    .pageMv .pageMvTitle {
        font-size: 30px;
        line-height: 1.4;
    }

}

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

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

.breadcrumb li:not(:last-of-type)::before {
    content: "";
    position: absolute;
    top: 10px;
    right: -17px;
    width: 5.01px;
    height: 6.68px;
    background: url(../img/common/icon-right-blue.svg) no-repeat;
    background-size: 5.01px;
}

.breadcrumb li a {
    opacity: .5;
}

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

    .breadcrumb li a:hover {
        color: #005EAD;
        opacity: 1;
    }

}

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

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

.table th,
.table td {
    padding: 27px 20px;
    border-bottom: 1px solid #707070;
    text-align: left;
    vertical-align: middle;
}

.table th {
    font-size: 17px;
    font-weight: bold;
    line-height: 1.505882352;
    background: #E6F4FF;
    width: 310px;
    color: #005EAD;
}

.table1 tr:first-child th {
    color: #fff;
    background-color: #005EAD;
    text-align: center;
    border-left: 1px solid #fff;
    padding: 15px 20px;
}

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

.table1 tr:first-child th:nth-child(2),
.table1 tr:first-child th:nth-child(3),
.table1 tr:first-child th:nth-child(4) {
    width: calc(100% - 310px / 3);
}

.table1 td {
    width: calc(100% - 310px / 3);
    text-align: right;
    border-left: 1px solid #707070;
}

.table1 .td1 {
    border-left: none;
}

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

    main.main {
        margin-top: 60px;
    }

}

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

    .modBtn1 a:hover .icon::before {
        background: linear-gradient(to right, #50B5FF, #005EAD);
        transform: scale(1.25);
    }

    .modBtn2 a:hover {
        color: #005EAD;
    }

    .modBtn2 a:hover .icon::before {
        background: #fff;
        border: 1px solid #005EAD;
        transform: scale(1.268);
    }

    .modBtn2 a:hover .icon::after {
        background-image: url(../img/common/icon-right-blue.svg);
    }

    .bannerLink .box:hover .modBtn3 {
        color: #005EAD;
    }

    .bannerLink .box:hover .modBtn3 .icon::before {
        background: #fff;
        border: 1px solid #005EAD;
        transform: scale(1.25);
    }

    .bannerLink .box:hover .modBtn3 .icon::after {
        background-image: url(../img/common/icon-right-blue.svg);
    }

    /*modBtn4*/
    .modBtn4 a:hover {
        color: #005EAD;
    }

    .modBtn4 a:hover .icon::before {
        background: #fff;
        border: 1px solid #005EAD;
        transform: scale(1.25);
    }

    .modBtn4 a:hover .icon::after {
        background-image: url(../img/common/icon-right-blue.svg);
    }

    /*modBtn5*/
    .modBtn5 a:hover,
    .modBtn5 button:hover {
        color: #005EAD;
        background-color: #E8F2FF;
    }

    .modBtn5 a:hover .icon::before,
    .modBtn5 button:hover .icon::before {
        background-color: #005EAD;
        transform: scale(1.133333333);
    }

    .modBtn5 a:hover .icon::after,
    .modBtn5 button:hover .icon::after {
        background-image: url(../img/common/icon-right-white.svg);
    }

    /*modBtn6*/
    .modBtn6 a:hover {
        color: #005EAD;
        background-color: #E8F2FF;
    }

    .modBtn6 a:hover .icon::before {
        background-color: #005EAD;
        transform: scale(1.352941176);
    }

    .modBtn6 a:hover .icon::after {
        background-image: url(../img/common/icon-right-white.svg);
    }

    /*modBtn7*/
    .modBtn7 a:hover {
        color: #134671;
        background-color: #E8F2FF;
    }

    .modBtn7.xlsx a:hover {
        background-image: url(../img/common/xlsx-hover.png), url(../img/common/icon-right-blue3.svg);
    }

    .modBtn7.docx a:hover {
        background-image: url(../img/common/docx-hover.png), url(../img/common/icon-right-blue3.svg);
    }

    .modBtn7.pdf a:hover {
        background-image: url(../img/common/pdf-hover.png), url(../img/common/icon-right-blue3.svg);
    }

}

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

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

    .innerPd {
        padding: 0 21px;
    }

    .innerPdSp0 {
        padding: 0;
    }

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

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

    /*modBtn1*/
    .modBtn1 {
        margin: 30px 0 0 0;
    }

    .modBtn1 a {
        font-size: 15px;
        line-height: 1.93333;
        padding-right: 50px;
    }

    /*modBtn2*/
    .modBtn2 a {
        font-size: 16px;
        padding: 16px 60px 16px 16px;
    }

    .modBtn2 a .icon {
        right: 16px;
        width: 26px;
        height: 26px;
    }

    .modBtn2 a .icon::after {
        background-size: 5.86px;
    }

    /*modBtn3*/
    .modBtn3 {
        font-size: 18px;
        line-height: 1.222222;
        padding: 19px 0 19px 19px;
    }

    .modBtn3 .icon {
        right: 20px;
        width: 40px;
        height: 40px;
    }

    /*modBtn4*/
    .modBtn4 {
        margin: 4px 0 0 0;
    }

    /*modBtn6*/
    .modBtn6 {
        max-width: 100%;
        height: 110px;
    }

    .modBtn6 a {
        font-size: 13px;
        line-height: 1.4;
        padding: 20px 70px 20px 76px;
        background: url(../img/common/bn_icon_02.svg) no-repeat center left 14px;
        background-size: 55px;
        background-color: #005EAD;
    }

    .modBtn6 a .bold {
        font-size: 18px;
        line-height: 1.333333333;
        margin-bottom: 7px;
    }

    .modBtn6 a .icon {
        right: 17px;
        width: 30px;
        height: 30px;
    }

    .modBtn6 a .icon::after {
        background-size: 6.6px;
    }

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

    .modBtn7 a {
        font-size: 16px;
        line-height: 1.5;
    }

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

    .sectionTitle1 {
        margin-bottom: 25px;
    }

    .sectionTitle.border {
        margin-bottom: 19px;
    }

    .sectionTitle .en {
        font-size: 16px;
        line-height: 1.3;
        padding-left: 23px;
        margin-left: 3px;
    }

    .sectionTitle1 .en {
        font-size: 28px;
        padding: 0 39px;
        background-size: 24px, 24px;
    }

    .sectionTitle .ja {
        font-size: 28px;
    }

    .pc {
        display: none;
    }

    .sp {
        display: block;
    }

    /*タイトル*/
    .index .title {
        font-size: 20px;
        line-height: 1.4;
        margin-bottom: 6px;
    }

    .content h2 {
        font-size: 24px;
        padding-bottom: 13px;
        padding-left: 34px;
        line-height: 1.3333333333;
        background: url(../img/common/sectionTitle-en.svg) no-repeat top 10px left;
        background-size: 26px;
        margin-top: 65px;
        margin-bottom: 30px;
    }

    .content h2::before {
        width: 93px;
    }

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

    .content h3 {
        font-size: 20px;
        margin-bottom: 24px;
        margin-top: 40px;
    }

    .content h4 {
        font-size: 18px;
        padding-bottom: 12px;
        margin-bottom: 15px;
        margin-top: 30px;
    }

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

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

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

    .table th {
        font-size: 16px;
        width: 100%;
        max-width: 100%;
    }

    .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: .2s;
    justify-content: flex-end;
}

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

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

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

.header .logo a img {
    width: 380px;
}

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

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

.navBtn a {
    font-size: 15px;
    font-weight: 500;
    border-radius: 5px;
    color: #fff;
    height: 34px;
    padding: 2px 20px;
    text-align: center;
    transition: .2s;
}

.navBtn:nth-child(1) a {
    background-color: #EA7654;
    border: 1px solid #EA7654;
}

.navBtn:nth-child(2) a {
    background-color: #3CA0EB;
    border: 1px solid #3CA0EB;
}

.navBtn:nth-child(3) a {
    background-color: #005EAD;
    border: 1px solid #005EAD;
}

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

    .navBtn:nth-child(1) a:hover {
        color: #EA7654;
        background-color: rgba(234, 118, 84, .05);
    }

    .navBtn:nth-child(2) a:hover {
        color: #3CA0EB;
        background-color: rgba(76, 151, 224, .05);
    }

    .navBtn:nth-child(3) a:hover {
        color: #005EAD;
        background-color: rgba(0, 94, 173, .05);
    }

}

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

.header .navListBox li {
    display: flex;
}

.header .navListBox li .main {
    font-size: 16px;
    font-weight: 500;
    line-height: 1.57;
    height: 100%;
    padding: 8px 0;
    margin: 0 13px;
    display: flex;
    align-items: center;
    z-index: 1;
    transition: .2s;
    border-bottom: 2px solid rgba(0, 94, 173, 0);
}

.header .navListBox li:last-child .main {
    margin: 0 0 0 13px;
}

.header .navListBox li:hover .main,
.header .navListBox li .subMenu:hover~.main {
    color: #005EAD;
    border-bottom: 2px solid rgba(0, 94, 173, 1);
}

.header .navListBox a {
    position: relative;
}

/*ドロップダウン*/
.header .nav .subMenu {
    width: 100%;
    position: absolute;
    top: 90px;
    left: 0;
    transition: .2s;
    background: #E6F4FF;
    height: auto;
    padding: 30px 0;
    opacity: 0;
    pointer-events: none;
    box-shadow: 0px 5px 10px 0px rgba(0, 94, 173, .1);
}

.header .nav .subMenu .inner {
    max-width: 994px;
    margin: 0 auto;
    row-gap: 20px;
}

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

.header .nav .subMenu li {
    display: block;
    width: calc(100% / 4);
}

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

.header .nav .subMenu li a {
    position: relative;
    display: inline-block;
    font-size: 15px;
    font-weight: 500;
    padding-left: 12px;
    background: url(../img/common/icon-right-blue.svg) no-repeat center left;
    background-size: 6.34px;
}

.header .nav .subMenu li a:hover {
    color: #005EAD;
}

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

    .header {
        height: 60px;
    }

    .header .nav {
        display: none;
    }

    .header .logo {
        top: 12px;
        left: 10px;
    }

    .header .logo a img {
        width: 254px;
    }

}

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

ハンバーガーメニュー

--------------------------------------------------------------------------------------------------------------------*/
.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;
    background-color: #005EAD;
    border-radius: 0 0 0 5px;
}

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

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

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

.hamburger .line span.line1:after {
    top: 8px;
    left: 0;
    width: 13px;
}

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

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

.hamburger .line.is-activeLine span.line1::after {
    top: 0;
    width: 26px;
    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: #E6F4FF;
    padding: 77px 16px 40px 16px;
}

.hamburger .menu .menuList {
    margin-bottom: 40px;
}

.hamburger .menu ul.menuList li {
    border-bottom: 1px solid #D2CFCF;
}

.hamburger .menu ul.menuList .main {
    font-size: 15px;
    font-weight: 700;
    line-height: 1.3;
    position: relative;
    width: 100%;
    padding: 15.5px 10px;
    color: #005EAD;
}

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

/* アニメーション後のメニューの状態 */
.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: 0;
    cursor: pointer;
    width: 11px;
    height: 11px;
    right: 10px;
    padding: 26px 0;
}

.hamburger .child {
    display: none;
}

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

.hamburger .toggleBtn:after {
    /* アイコン縦棒（閉じてるとき） */
    content: '';
    height: 11px;
    width: 1px;
    display: block;
    background: #005EAD;
    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 {
    padding: 15px 25px;
    border-top: 1px solid #D2CFCF;
    background-color: #fff;
}

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

.hamburger .menu ul.menuList .subMenu.child li a {
    position: relative;
    font-size: 13px;
    font-weight: 500;
    padding-left: 12px;
    background: url(../img/common/icon-right-blue.svg) no-repeat center left;
    background-size: 6.34px;
    margin-bottom: 8px;
}

.hamburger .menu ul.menuList .subMenu.child li:last-child a {
    margin-bottom: 0;
}

/*btn*/
.hamburger .navBtn {
    margin-bottom: 10px;
}

.hamburger .navBtn:last-child {
    margin-bottom: 0;
}

.hamburger .navBtn a {
    font-size: 17px;
    font-weight: 700;
    border-radius: 10px;
    height: 54px;
    padding: 11px 0;
}

.hamburger .navBtn a .btnInner {
    display: block;
    max-width: 315px;
    margin: 0 auto;
    background-position: center left;
    background-repeat: no-repeat;
    background-size: 30px;
}

.hamburger .navBtn:nth-child(1) a .btnInner {
    background-image: url(../img/common/bn_icon_01.svg);
    padding-left: 16px;
}

.hamburger .navBtn:nth-child(2) a .btnInner {
    background-image: url(../img/common/bn_icon_05.svg);
}

.hamburger .navBtn:nth-child(3) a .btnInner {
    background-image: url(../img/common/bn_icon_02.svg);
}


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

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

.fixed .fixedBtn1 {
    margin-bottom: 10px;
}

.fixed .fixedBtn a {
    position: relative;
    height: 210px;
    width: 61px;
    border-radius: 5px 0 0 5px;
    border-right: none;
    transition: .2s;
    padding: 10px 7px;
    background-repeat: no-repeat;
    background-position: center top 18px;
    background-size: 37.98px;
}

.fixed .fixedBtn1 a {
    border: 1px solid #EA7654;
    background-color: #EA7654;
    background-image: url(../img/common/fixedBtn1-pc.png);
}

.fixed .fixedBtn2 a {
    border: 1px solid #005EAD;
    background-color: #005EAD;
    background-image: url(../img/common/fixedBtn2-pc.png);
}

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

    .fixed .fixedBtn1 a:hover {
        color: #EA7654;
        background-color: #FEF8F7;
        background-image: url(../img/common/fixedBtn1-pc-hover.png);
    }

    .fixed .fixedBtn2 a:hover {
        color: #005EAD;
        background-color: #F4F7FB;
        background-image: url(../img/common/fixedBtn2-pc-hover.png);
    }

}

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

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

    .fixed .fixedBtn {
        width: calc(50% - 1.5px);
    }

    .fixed .fixedBtn1 {
        margin-bottom: 0;
    }

    .fixed .fixedBtn a {
        height: 54px;
        width: 100%;
        border-radius: 5px 5px 0 0;
        border: none;
        background-image: none;
    }

    .fixed .fixedBtn1 a {
        padding: 9px 10px 12px 10px;
    }

    .fixed .fixedBtn2 a {
        padding: 6px 0 9px 0;
    }

    .fixed .fixedBtn a img {
        margin: 0 auto;
        height: 100%;
        width: auto;
        object-fit: cover;
    }


}

/*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: .2s;
}

.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;
    margin-top: 132px;
}

/*footer-top*/
.footer .top {
    position: relative;
    padding-bottom: 50px;
}

.footer .top::before {
    content: "";
    position: absolute;
    top: 50px;
    left: 0;
    width: 100%;
    height: calc(100% - 50px);
    background-color: #E6F4FF;
}

.footer .top .inner {
    position: relative;
}

.footer .top .inner::before {
    content: "";
    position: absolute;
    top: 5px;
    right: 0;
    width: 106px;
    height: 67px;
    background: url(../img/common/illust-1.svg) no-repeat;
    background-size: 106px;
    mix-blend-mode: multiply;
}

.footer .top .sectionTitle {
    margin-bottom: 50px;
}

.linkList {
    column-gap: 36px;
    row-gap: 20px;
    justify-content: space-between;
}

.linkList .linkBtn {
    width: calc(50% - 18px);
}

.linkList .linkBtn a {
    position: relative;
    transition: .2s;
    border-radius: 5px;
    padding: 25px 30px;
    background-repeat: no-repeat;
    background-position: center left 30px;
    height: 120px;
}

.linkList .linkBtn1 a {
    border: 1px solid #3CA0EB;
    background-color: #3CA0EB;
    background-image: url(../img/common/linkBtn1-pc.png);
    background-size: min(312px, 28vw);
}

.linkList .linkBtn2 a {
    border: 1px solid #3CA0EB;
    background-color: #3CA0EB;
    background-image: url(../img/common/linkBtn2-pc.png);
    background-size: min(334px, 28vw);
}

.linkList .linkBtn3 a {
    border: 1px solid #EA7654;
    background-color: #EA7654;
    background-image: url(../img/common/linkBtn3-pc.png);
    background-size: min(353.54px, 30vw);
}

.linkList .linkBtn4 a {
    border: 1px solid #005EAD;
    background-color: #005EAD;
    background-image: url(../img/common/linkBtn4-pc.png);
    background-size: min(334px, 26vw);
}

.linkList .linkBtn a .icon {
    position: absolute;
    top: 50%;
    right: 28px;
    transform: translateY(-50%);
    margin: auto;
    width: 34px;
    height: 34px;
    border-radius: 34px;
    background-color: #fff;
}

.linkList .linkBtn a .icon::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 46px;
    transition: .2s;
    z-index: -1;
}

.linkList .linkBtn a .icon::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: center;
    background-size: 7.3px;
}

.linkList .linkBtn1 a .icon::after,
.linkList .linkBtn2 a .icon::after {
    background-image: url(../img/common/icon-right-blue2.svg);
}

.linkList .linkBtn3 a .icon::after {
    background-image: url(../img/common/icon-right-red.svg);
}

.linkList .linkBtn4 a .icon::after {
    background-image: url(../img/common/icon-right-blue.svg);
}

/*footer-bottom*/
.footer .bottom {
    position: relative;
    padding: 50px 0;
}

/*bottomTop*/
.footer .bottomTop .logo {
    transition: .2s;
    display: inline-block;
    vertical-align: top;
    margin: 0 23px 0 0;
}

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

.footer .bottomTop .text {
    display: inline-block;
    font-size: 15px;
    font-weight: 500;
}

.footer .bottomTop .text .address {
    margin: 0 1em 0 0;
}

.footer .bottomTop .text a {
    display: inline-block;
}

/*bottomMenu*/
.footer .bottomMenu {
    margin-top: 30px;
    padding-top: 50px;
    border-top: 1px solid #C8C8C8;
}

.footer .bottomMenu .menu .box {
    padding-left: 12px;
}

.footer .bottomMenu .menu .box1 {
    width: 23%;
}

.footer .bottomMenu .menu .box2,
.footer .bottomMenu .menu .box3 {
    width: 22%;
}

.footer .bottomMenu .menu .box4 {
    width: 33%;
}

.footer .menu .main {
    font-size: 15px;
    font-weight: 700;
    line-height: 1.5;
    margin-bottom: 20px;
    color: #005EAD;
}

.footer .menu .sub .main {
    position: relative;
    padding-bottom: 9px;
    margin-bottom: 14px;
}

.footer .menu .sub .main::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 30px;
    height: 1px;
    background-color: #005EAD;
}

.footer .menu .subMenu {
    margin-bottom: 20px;
}

.footer .menu li:last-child .subMenu,
.footer .menu li:last-child .subMenu li:last-child a {
    margin-bottom: 0;
}

.footer .menu .subMenu li a {
    position: relative;
    font-size: 13px;
    font-weight: 500;
    line-height: 1.5;
    margin-bottom: 5px;
    padding-left: 13px;
    background: url(../img/common/icon-right-blue.svg) no-repeat top 8px left;
    background-size: 6.34px;
}

/*box4*/
.footer .bottomMenu .menu .box4 .banner {
    margin-top: 136px;
}

.footer .bottomMenu .menu .box4 .banner a {
    transition: .2s;
}

/*copy*/
.footer .copy {
    font-family: "Roboto", serif;
    font-size: 12px;
    font-weight: 400;
    line-height: 1;
    color: rgba(0, 0, 0, .65);
}

.footer .copy .inner {
    display: block;
    text-align: center;
    padding: 21px 0;
    border-top: 1px solid #C8C8C8;
}

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

.footer .pageTop {
    position: absolute;
    bottom: 0;
    right: 0;
    width: 54px;
    height: 54px;
    background: url(../img/common/page-top.svg) no-repeat center;
    background-size: 25px;
    transition: .2s;
    cursor: pointer;
    text-align: center;
    border: 1px solid #005EAD;
    border-radius: 54px;
    background-color: #fff;
}

.footer .pageTop::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 54px;
    z-index: -1;
    transition: .2s;
}

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

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


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

    /*footer-top*/
    .linkList .linkBtn a:hover .icon::before {
        background-color: #3CA0EB;
        transform: scale(1.35294);
    }

    .linkList .linkBtn3 a:hover .icon::before {
        background-color: #EA7654;
    }

    .linkList .linkBtn4 a:hover .icon::before {
        background-color: #005EAD;
    }

    .linkList .linkBtn1 a:hover {
        background-image: url(../img/common/linkBtn1-pc-hover.png);
        background-color: #F4F7FB;
    }

    .linkList .linkBtn2 a:hover {
        background-image: url(../img/common/linkBtn2-pc-hover.png);
        background-color: #F4F7FB;
    }

    .linkList .linkBtn3 a:hover {
        background-image: url(../img/common/linkBtn3-pc-hover.png);
        background-color: #FEF8F7;
    }

    .linkList .linkBtn4 a:hover {
        background-image: url(../img/common/linkBtn4-pc-hover.png);
        background-color: #F4F7FB;
    }

    .linkList .linkBtn a:hover .icon::after {
        background-image: url(../img/common/icon-right-white.svg);
    }

    .footer .bottomTop .logo:hover {
        opacity: .5;
    }

    .footer .menu a.main:hover {
        color: #3CA0EB;
    }

    .footer .menu .subMenu li a:hover {
        color: #005EAD;
    }

    .footer .bottomMenu .menu .box4 .banner a:hover {
        opacity: .5;
    }

    .footer .pageTop:hover {
        background: url(../img/common/page-top-hover.svg) no-repeat center;

    }

    .footer .pageTop:hover::before {
        background-color: #005EAD;
        transform: scale(1.1859);
    }

}

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

    .footer {
        margin-top: 90px;
    }

    /*footer-top*/
    .footer .top {
        padding-bottom: 60px;
    }

    .footer .top::before {
        top: 45px;
        height: calc(100% - 45px);
    }

    .footer .top .inner::before {
        top: 7px;
        width: 81px;
        height: 53px;
        background-size: 81px;
    }

    .footer .top .sectionTitle {
        margin-bottom: 45px;
    }

    .linkList {
        row-gap: 13px;
    }

    .linkList .linkBtn {
        width: 100%;
    }

    .linkList .linkBtn a {
        position: relative;
        transition: .2s;
        border-radius: 5px;
        padding: 20px 14px;
        background: none;
        height: 96px;
    }

    .linkList .linkBtn1 a,
    .linkList .linkBtn2 a {
        background-color: #3CA0EB;
    }

    .linkList .linkBtn3 a {
        background-color: #EA7654;
        padding: 19px 14px;
    }

    .linkList .linkBtn4 a {
        background-color: #005EAD;
    }

    .linkList .linkBtn a .icon {
        right: 18px;
        width: 30px;
        height: 30px;
    }

    .linkList .linkBtn a .icon::after {
        background-size: 6.6px;
    }

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

    /*bottomTop*/
    .footer .bottomTop .logo {
        display: block;
        margin: 0;
    }

    .footer .bottomTop .logo img {
        width: 358px;
        margin: 0 auto 6px auto;
    }

    .footer .bottomTop .text {
        display: block;
        text-align: center;
        line-height: 1.3333;
    }

    .footer .bottomTop .text .address {
        display: block;
        margin: 6px 0 0 0;
    }

    .footer .bottomTop .text a {
        display: block;
    }

    /*bottomMenu*/
    .footer .bottomMenu {
        margin-top: 0;
        padding-top: 0;
        border-top: none;
    }

    .footer .bottomMenu .menu .box {
        padding-left: 0;
    }

    .footer .bottomMenu .menu .box1,
    .footer .bottomMenu .menu .box2,
    .footer .bottomMenu .menu .box3,
    .footer .bottomMenu .menu .box4 li:nth-child(1),
    .footer .bottomMenu .menu .box4 li:nth-child(2),
    .footer .bottomMenu .menu .box4 li:nth-child(3) {
        display: none;
    }

    .footer .bottomMenu .menu .box4 {
        width: 100%;
    }

    /*box4*/
    .footer .bottomMenu .menu .box4 .banner {
        margin-top: 30px;
    }

    .footer .bottomMenu .menu .box4 .banner a {
        transition: .2s;
    }

    .footer .bottomMenu .menu .box4 .banner a img {
        width: 207px;
        margin: 0 auto;
    }

    /*copy*/
    .footer .copy .inner {
        padding: 21px 0 74px 0;
    }

    /*pageTop*/
    .footer .pageTopInner {
        bottom: 98px;
        right: 16px;
    }

    .footer .pageTop {
        width: 44px;
        height: 44px;
        background-size: 19px;
    }

}

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

トップページ

--------------------------------------------------------------------------------------------------------------------*/
/*mv*/
.mv {
    position: relative;
    padding: 36px 0 88px 0;
    margin-bottom: 104px;
}

.mv::before {
    content: "";
    position: absolute;
    top: 526px;
    left: 0;
    background: linear-gradient(to bottom, #A2E6FF, #0F5ECC);
    width: calc(100% - 100px);
    height: 435px;
    z-index: -1;
}

/*textBox*/
.mv .textBox {
    position: absolute;
    top: 103px;
    left: 50%;
    transform: translateX(-50%);
    margin: auto;
    z-index: 2;
}

.mv .textBox::before {
    content: "";
    position: absolute;
    top: -23px;
    left: 295px;
    width: 94px;
    height: 61px;
    background: url(../img/common/illust-1.svg) no-repeat;
    background-size: 94px;
    mix-blend-mode: multiply;
}

.mv .textBox img {
    height: 317.47px;
    width: 304.59px;
}

/*スライド*/
.mv .mvSwiper {
    position: relative;
    padding-left: 40.7142858%;
    height: 586px;
    margin: 0 0 0 auto;
    box-sizing: border-box;
}

.mv .mvSwiper::before {
    content: "";
    position: absolute;
    bottom: -48px;
    left: 34.4285714%;
    width: 388px;
    height: 259px;
    background: url(../img/common/illust-3.svg) no-repeat;
    background-size: 388px;
    mix-blend-mode: multiply;
}

.mv .mvSwiper::after {
    content: "";
    position: absolute;
    bottom: -88px;
    left: 30%;
    width: 125px;
    height: 83px;
    background-color: #F4FAFF;
    opacity: .3;
    border-radius: 5px;
}

.mv .swiper-slide img {
    height: 100%;
    width: 100%;
    object-fit: cover;
    border-radius: 5px 0 0 5px;
}

.mv .mvSwiper .swiper-pagination {
    left: 50%;
    transform: translateX(-50%);
    margin: auto;
    right: auto;
    top: auto;
    bottom: -88px;
    text-align: left;
    width: calc(100% - 160px);
}

.mv .mvSwiper .swiper-pagination .swiper-pagination-bullet {
    width: 10px;
    height: 10px;
    background-color: #fff;
    border-radius: 10px;
    opacity: .3;
    margin: 0 7px;
    transition: .4s;
    vertical-align: bottom;
    display: inline-block;
}

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

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

    .mv {
        padding: 30px 0;
        margin-bottom: 90px;
    }

    .mv::before {
        top: 422px;
        width: calc(100% - 37px);
        min-height: 522px;
        height: 100vw;
    }

    /*textBox*/
    .mv .textBox {
        position: relative;
        top: 0;
        left: 0;
        transform: none;
        margin: 0 auto 53px auto;
    }

    .mv .textBox::before {
        top: 0;
        left: 241px;
        width: 72px;
        height: 46px;
        background-size: 72px;
    }

    .mv .textBox img {
        height: 252px;
        width: 239px;
    }

    /*スライド*/
    .mv .mvSwiper {
        padding-left: 36px;
        min-height: 296px;
        height: 78.93333333333334vw;
    }

    .mv .mvSwiper::before {
        content: "";
        position: absolute;
        bottom: -40px;
        left: 0;
        width: 121px;
        height: 81px;
        background-size: 121px;
    }

    .mv .mvSwiper::after {
        bottom: -52px;
        left: -15px;
        width: 39px;
        height: 26px;
        border-radius: 3px;
    }

    .mv .mvSwiper .swiper-pagination {
        left: 50%;
        transform: translateX(-50%);
        margin: auto;
        right: auto;
        top: auto;
        bottom: -30px;
        text-align: right;
        width: calc(100% - 72px);
    }

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

    .mv .mvSwiper .swiper-pagination .swiper-pagination-bullet:last-child {
        margin-right: 0;
    }

}

/*-----------------------------newsList*/
.newsTop {
    position: relative;
    padding: 50px 0;
    margin-bottom: 120px;
}

.newsTop::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    background-color: #fff;
    width: calc(100% - 40px);
    height: 100%;
    border-radius: 5px;
    box-shadow: rgba(0, 94, 173, 0.15) 0px 0px 15px 0px;
}

.newsTop .inner {
    row-gap: 20px;
}

.newsTop .left {
    position: relative;
    width: 242px;
    padding: 0 83px 0 0;
    margin-bottom: 0;
}

.newsTop .newsList.right {
    position: relative;
    width: calc(100% - 242px);
}

.newsList a {
    padding: 23.5px 60px 23.5px 10px;
    background: url(../img/common/icon-right-blue.svg) no-repeat center right 30px;
    background-size: 6.67px;
    border-bottom: 1px solid #C8C8C8;
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
}

.newsTop .newsList a {
    padding: 16px 40px 16px 12px;
    background: url(../img/common/icon-right-blue.svg) no-repeat center right 15px;
}

.newsList a:first-child {
    border-top: 1px solid #C8C8C8;
}

.newsList .date {
    font-family: "Roboto", serif;
    font-size: 15px;
    font-weight: 500;
    line-height: 1;
    display: inline-block;
    vertical-align: middle;
    opacity: .7;
    width: 107px;
    margin-top: 9px;
}

.pageTopicsDetail .newsList .date {
    margin-top: 0;
}

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

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

    .newsTop::before {
        content: "";
        position: absolute;
        top: 0;
        right: 0;
        background-color: #fff;
        width: calc(100% - 100px);
        height: 100%;
        border-radius: 5px;
        box-shadow: rgba(0, 94, 173, 0.15) 0px 0px 15px 0px;
    }

}

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

    .newsList a:hover .newsTitle {
        color: #005EAD;
    }

}

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

    .newsTop {
        padding: 30px 0;
        margin-bottom: 70px;
    }

    .newsTop .inner {
        padding: 0 21px;
    }

    .newsTop::before {
        right: 50%;
        left: 50%;
        transform: translateX(-50%);
        margin: auto;
        width: calc(100% - 32px);
    }

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

    .newsTop .left .modBtn4 {
        position: absolute;
        bottom: 0;
        right: 0;
    }

    .newsTop .newsList.right {
        width: 100%;
    }

    .newsList a {
        background-position: center right 24px;
        padding: 26px 40px 26px 12px;
    }

    .newsTop .newsList a {
        background-position: center right 15px;
        padding: 14px 40px 14px 12px;
    }

    .newsList .date {
        font-size: 14px;
        width: 100%;
        margin-top: 0;
        margin-bottom: 5px;
    }

    .pageTopicsDetail .newsList .date {
        margin-bottom: 0;
    }

    .newsList a .newsTitle {
        font-size: 15px;
        line-height: 1.46666666;
        width: 100%;
    }

}

/*messageTop*/
.messageTop {
    position: relative;
    margin-bottom: 120px;
}

.messageTop .img {
    width: 51.28%;
    height: 484px;
}

.messageTop .img img {
    border-radius: 0 5px 5px 0;
}

.messageTop .messageTopTitle {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    margin: auto;
    padding-left: min(655px, 46.785714285714285vw);
}

.messageTop .messageTopTitle::before {
    content: "";
    position: absolute;
    top: 0;
    right: -79px;
    width: 110px;
    height: 72px;
    background: url(../img/common/illust-1.svg) no-repeat;
    background-size: 110px;
    mix-blend-mode: multiply;
}

.messageTop .messageTopTitle .text {
    position: relative;
    font-family: "Zen Kaku Gothic New", serif;
    font-size: 22px;
    font-weight: 700;
    margin-bottom: 10px;
    color: #005EAD;
    display: inline-block;
    padding-right: 49px;
}

.messageTop .messageTopTitle .text::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    margin: auto;
    width: 41px;
    height: 2px;
    background-color: #005EAD;
}

.messageTop .messageTopTitle .textTitle {
    position: relative;
    font-family: "Zen Kaku Gothic New", serif;
    font-size: 32px;
    font-weight: 700;
    line-height: 1.5;
    padding-bottom: 20px;
    margin-bottom: 30px;
    border-bottom: 1px solid #C8C8C8;
}

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

    .messageTop {
        margin-bottom: 70px;
    }

    .messageTop .img {
        width: calc(100% - 16px);
        height: 61.33333333333333vw;
        min-height: 230px;
    }

    .messageTop .messageTopTitle {
        position: relative;
        top: auto;
        left: auto;
        transform: none;
        margin: 0 auto 30px auto;
        padding-left: 0;
    }

    .messageTop .messageTopTitle::before {
        right: -16px;
        width: 80px;
        height: 52px;
        background-size: 80px;
    }

    .messageTop .messageTopTitle .text {
        font-size: 18px;
        margin-bottom: 6px;
        padding-right: 32px;
    }

    .messageTop .messageTopTitle .text::before {
        width: 28.43px;
    }

    .messageTop .messageTopTitle .textTitle {
        font-size: 26px;
        line-height: 1.461538461;
        padding-bottom: 16px;
        margin-bottom: 21px;
    }

}

/*linkSection*/
.linkSection {
    position: relative;
    margin-bottom: 120px;
    padding-bottom: 70px;
}

.linkSection .inner {
    row-gap: 30px;
}

.linkSection::before {
    content: "";
    position: absolute;
    width: calc(100% - 40px);
    z-index: -1;
}

.linkSection1::before {
    top: 111px;
    height: calc(100% - 111px);
    right: 0;
    background-color: #E6F4FF;
    border-radius: 5px 0 0 5px;
}

.linkSection2::before {
    top: 84px;
    height: calc(100% - 84px);
    left: 0;
    background-color: #FAF8EF;
    border-radius: 0 5px 5px 0;
}

.linkSection .img {
    width: 57%;
    height: 360px;
}

.linkSection .img img {
    border-radius: 5px;
}

.linkSection .text {
    width: 43%;
}

.linkSection1 .text {
    padding: 62px 73px 0 30px;
}

.linkSection2 .text {
    padding: 34px 30px 0 70px;
}

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

    .linkSection {
        margin-bottom: 62px;
        padding-bottom: 50px;
    }

    .linkSection2 {
        margin-bottom: 96px;
    }

    .linkSection::before {
        top: 45px;
        width: 100%;
        height: calc(100% - 45px);
    }

    .linkSection1::before,
    .linkSection2::before {
        border-radius: 0;
    }

    .linkSection .img {
        width: 100%;
        height: 49.86666666666667vw;
        min-height: 187px;
    }

    .linkSection .text {
        width: 100%;
        padding: 0;
    }

    .linkSection2 .text {
        order: 1;
    }

    .linkSection2 .img {
        order: 2;
    }

}

/*workStyleTop*/
.workStyleTop {
    position: relative;
    padding-bottom: 140px;
}

.workStyleTop::before {
    content: "";
    position: absolute;
    top: 138px;
    left: 0;
    background-color: #E6F4FF;
    width: 100%;
    height: calc(100% - 138px);
    z-index: -1;
}

.workStyleTop .top {
    align-items: flex-end;
    row-gap: 30px;
    margin-bottom: 115px;
}

.workStyleTop .top .left {
    width: 412px;
    padding-right: 90px;
}

.workStyleTop .top .right {
    position: relative;
    width: calc(100% - 412px);
    height: 430px;
}

.workStyleTop .top .right::before {
    content: "";
    position: absolute;
    top: -30px;
    right: -60px;
    width: 139px;
    height: 90px;
    background: url(../img/common/illust-1.svg) no-repeat;
    background-size: 139px;
    mix-blend-mode: multiply;
}

.workStyleTop .top .right::after {
    content: "";
    position: absolute;
    bottom: -19px;
    left: -33px;
    width: 62px;
    height: 41px;
    background: url(../img/common/illust-2.svg) no-repeat;
    background-size: 62px;
    mix-blend-mode: multiply;
}

.workStyleTop .top .right img {
    border-radius: 5px;
    height: 100%;
    width: 100%;
    object-fit: cover;
}

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

    .workStyleTop {
        padding-bottom: 80px;
    }

    .workStyleTop::before {
        top: 110px;
        height: calc(100% - 110px);
    }

    .workStyleTop .top {
        margin-bottom: 50px;
    }

    .workStyleTop .top .left {
        width: 100%;
        padding-right: 0;
        order: 2;
    }

    .workStyleTop .top .right {
        width: 100%;
        height: 58.666666666666664vw;
        min-height: 220px;
        order: 1;
    }

    .workStyleTop .top .right::before {
        top: -20px;
        right: -16px;
        width: 89px;
        height: 58px;
        background-size: 89px;
    }

    .workStyleTop .top .right::after {
        bottom: -17px;
        left: -16px;
        width: 51px;
        height: 34px;
        background-size: 51px;
    }

}

.workStyleTop .bottom {
    row-gap: 30px;
}

.workStyleTop .bottom .left {
    width: calc(50% - 31px);
}

.workStyleTop .bottom .right {
    width: 50%;
    padding-left: 19px;
}

.workStyleTop .bottom .box {
    position: relative;
    padding: 0 40px 30px 40px;
}

.workStyleTop .bottom .box1 {
    margin: 0 19px 0 12px;
}

.workStyleTop .bottom .box2 {
    margin-bottom: 54px;
}

.workStyleTop .bottom .box::before {
    content: "";
    position: absolute;
    top: 50px;
    left: 0;
    background-color: #fff;
    width: 100%;
    height: calc(100% - 50px);
    z-index: -1;
    border-radius: 5px;
    box-shadow: rgba(0, 94, 173, 0.10) 0px 5px 10px 0px;
}

.workStyleTop .bottom .box1::before {
    top: 168px;
    height: calc(100% - 168px);
}

.workStyleTop .bottom .box .img {
    max-height: 207.88px;
    height: 14.848571428571427vw;
}

.workStyleTop .bottom .box1 .img {
    max-height: 337.88px;
    height: 24.134285714285713vw;
    margin-bottom: 28px;
}

.workStyleTop .bottom .right .box .img {
    width: 42.2%;
}

.workStyleTop .bottom .right .box .text {
    width: 57.8%;
    padding-left: 40px;
}

.workStyleTop .bottom .right .box2 .text {
    padding-top: 20px;
}

.workStyleTop .bottom .box .img img {
    border-radius: 5px;
}

.workStyleTop .bottom .box1 .text {
    align-items: flex-end;
}

.workStyleTop .bottom .box1 .text .textLeft {
    width: 56%;
}

.workStyleTop .bottom .box1 .text .textRight {
    width: 44%;
}

.workStyleTop .bottom .box2 .sectionTitle,
.workStyleTop .bottom .box3 .sectionTitle {
    margin-bottom: 8px;
}

.workStyleTop .bottom .box2 .modBtn4 {
    margin: 0;
}

.workStyleTop .bottom .box2 .modBtn4 a {
    padding-top: 0;
    padding-bottom: 0;
}

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

    .workStyleTop .bottom .left {
        width: 100%;
    }

    .workStyleTop .bottom .right {
        width: 100%;
        padding-left: 0;
    }

    .workStyleTop .bottom .box {
        padding: 0 22px 30px 22px;
    }

    .workStyleTop .bottom .box1 {
        margin: 0;
    }

    .workStyleTop .bottom .box2 {
        margin-bottom: 30px;
    }

    .workStyleTop .bottom .box::before,
    .workStyleTop .bottom .box1::before {
        top: 93px;
        height: calc(100% - 93px);
    }

    .workStyleTop .bottom .box .img,
    .workStyleTop .bottom .box1 .img {
        max-height: 100%;
        min-height: 186px;
        height: 49.6vw;
        margin-bottom: 20px;
    }

    .workStyleTop .bottom .right .box .img {
        width: 100%;
    }

    .workStyleTop .bottom .right .box .text {
        width: 100%;
        padding-left: 0;
    }

    .workStyleTop .bottom .right .box2 .text {
        padding-top: 0;
    }


    .workStyleTop .bottom .box1 .text .textLeft,
    .workStyleTop .bottom .box1 .text .textRight {
        width: 100%;
    }

    .workStyleTop .bottom .box .sectionTitle {
        margin-bottom: 9px;
    }

    .workStyleTop .bottom .box2 .modBtn4 {
        margin: 11px 0 0 0;
    }

    .workStyleTop .bottom .box2 .modBtn4 a {
        padding: 10px 53px 10px 0;
    }

}

/*bannerLink*/
.bannerLink {
    column-gap: 36px;
    row-gap: 30px;
    justify-content: space-between;
}

.bannerLink .box {
    position: relative;
    border-radius: 5px;
}

.environmentTop .bannerLink .box {
    width: calc(100% / 2 - 24px);
}

.pickUpTop .bannerLink .box {
    width: calc(100% / 3 - 24px);
    background-color: #fff;
}

.bannerLink .box .img {
    overflow: hidden;
}

.environmentTop .bannerLink .box .img {
    height: 240px;
    border-radius: 5px;
}

.pickUpTop .bannerLink .box .img {
    height: 182px;
    border-radius: 5px 5px 0 0;
}

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

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

    .bannerLink .box:hover .img img {
        transform: scale(1.09787234);
    }

}

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

    .environmentTop .bannerLink .box,
    .pickUpTop .bannerLink .box {
        width: 100%;
    }

    .environmentTop .bannerLink .box .img {
        height: 53.333333333333336vw;
        min-height: 200px;
    }

    .pickUpTop .bannerLink .box .img {
        height: 39.2vw;
        min-height: 147px;
    }

}

/*environmentTop*/
.environmentTop {
    position: relative;
    margin-bottom: 100px;
    background: url(../img/top/environmentTop-bg.webp) no-repeat top center;
    background-size: 100% auto;
    padding-top: 35.35714285714286vw;
}

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

.environmentTop .environmentTopInner {
    position: relative;
    align-items: flex-end;
    row-gap: 40px;
}

.environmentTop .left {
    width: 42.6%;
    padding-right: 65px;
    background: url(../img/common/illust-1.svg) no-repeat top left 165px;
    background-size: 96px;
}

.environmentTop .right {
    width: 57.4%;
}

.environmentTop .modBtn3 {
    position: absolute;
    bottom: 0;
    right: 0;
    border-radius: 5px 0 5px 0;
    padding: 16px 60px 3px 28px;
}

.environmentTop .modBtn3 .icon {
    top: auto;
    bottom: 0;
    right: 0;
    transform: none;
    margin: 0;
    z-index: 1;
}

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

    .environmentTop {
        background: url(../img/top/environmentTop-bg-sp.webp) no-repeat top center;
        background-size: 100% auto;
        margin-bottom: 70px;
        padding-top: 77.60000000000001vw;
    }

    .environmentTop::before {
        top: 64vw;
        width: calc(100% - 16px);
        height: calc(100% - 64vw);
    }

    .environmentTop .left {
        width: 100%;
        padding-right: 0;
        background: url(../img/common/illust-1.svg) no-repeat top 5px left 150px;
        background-size: 71px;
    }

    .environmentTop .right {
        width: 100%;
    }

    .environmentTop .modBtn3 {
        padding: 20px 55px 9px 30px;
    }

}

/*pickUpTop*/
.pickUpTop {
    background: linear-gradient(to bottom, #BEE4FF, #0F78D2);
    padding: 50px 0 64px 0;
    margin-bottom: 100px;
}

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

    .pickUpTop {
        padding: 38px 0 50px 0;
        margin-bottom: 70px;
    }

    .pickUpTop .bannerLink .box .modBtn3 {
        height: 60px;
    }

}

/*aboutTop*/
.aboutTop {
    row-gap: 30px;
}

.aboutTop .left.sectionTitle {
    margin-bottom: 0;
}

.aboutTop .left {
    width: 308px;
}

.aboutTop .right {
    width: calc(100% - 308px);
    column-gap: 57px;
    justify-content: space-between;
}

.aboutTop .right .box {
    width: calc(50% - 28.5px);
}

.aboutTop .right .box li a {
    border-bottom: 1px solid #E6E6E6;
}

.aboutTop .right .box li:first-child a {
    border-top: 1px solid #E6E6E6;
}

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

    /*aboutTop*/
    .aboutTop .left,
    .aboutTop .right,
    .aboutTop .right .box {
        width: 100%;
    }

    .aboutTop .right .box:last-child li:first-child a {
        border-top: none;
    }

}

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

下層ページ

--------------------------------------------------------------------------------------------------------------------*/
.mb1 {
    margin-bottom: 55px;
}

.mb2 {
    margin-bottom: 24px;
}

.mb3 {
    margin-bottom: 32px;
}

.content .h3Top {
    margin-top: 0;
}

.content .h4Top {
    margin-top: 10px;
}

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

    .mb1 {
        margin-bottom: 35px;
    }

}

/*flexBox*/
.flexBox {
    justify-content: space-between;
}

.flexBox1 {
    column-gap: 70px;
    row-gap: 30px;
}

.flexBox2 {
    column-gap: 36px;
    row-gap: 32px;
    margin-top: 32px;
}

.flexBox3 {
    column-gap: 35px;
    row-gap: 32px;
    margin-top: 7px;
}

.flexBox4 {
    column-gap: 48px;
    row-gap: 32px;
    margin-top: 7px;
}

.flexBox5 {
    column-gap: 36px;
    row-gap: 24px;
}

.flexBox6 {
    column-gap: 36px;
    row-gap: 19px;
}

.flexBox1 .box {
    width: calc(50% - 35px);
}

.flexBox2 .box {
    width: calc(50% - 18px);
}

.flexBox3 .box {
    width: calc(100% / 4 - 27.5px);
    padding: 0 20px 37px 20px;
    text-align: center;
}

.flexBox4 .box {
    width: calc(100% / 3 - 32px);
}

.flexBox5 .box {
    width: calc(100% / 3 - 24px);
    background-color: #E6F4FF;
    padding: 5px 30px 50px 30px;
    border-radius: 5px;
}

.flexBox6 .box {
    width: calc(50% - 24px);
    background-color: #F4FAFF;
    padding: 32px 23px;
    border-radius: 5px;
    text-align: center;
}

.flexBox1 .img {
    height: 321px;
}

.flexBox2 .img {
    height: 330px;
}

.flexBox4 .img {
    height: 238px;
}

.flexBox .img img {
    border-radius: 5px;
}

.flexBox h3,
.pageWalfare h3 {
    margin-top: 25px;
    margin-bottom: 15px;
}

.flexBox6 .box h4 {
    margin-top: 0;
    text-align: left;
}

.flexBox .box p {
    margin-top: 16px;
}

.flexBox5 .box p {
    margin-top: 9px;
}

.flexBox1 .box p,
.flexBox6 .box p {
    margin-top: 0;
}

.flexBox6 .box .tel {
    display: inline-block;
    margin-top: 0;
    padding-left: 60px;
    background: url(../img/common/icon-phone.svg) no-repeat center left;
    background-size: 41.37px;
}

.flexBox6 .box:first-child .tel {
    margin-top: 30px;
}

.flexBox6 .box .tel a {
    font-size: 45px;
    font-weight: 700;
    line-height: 1.4;
}

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

    .flexBox1 {
        row-gap: 25px;
    }

    .flexBox2 {
        row-gap: 24px;
        margin-top: 24px;
    }

    .flexBox3 {
        column-gap: 19px;
        margin-bottom: 40px;
    }

    .flexBox1-1 {
        row-gap: 40px;
    }

    .flexBox .box {
        width: 100%;
    }

    .flexBox3 .box {
        width: calc(50% - 9.5px);
        padding: 0;
    }

    .flexBox3 .box {
        padding: 0;
    }

    .flexBox1 .img {
        height: 58.666666666666664vw;
        min-height: 220px;
    }

    .flexBox2 .img {
        height: 59.199999999999996vw;
        min-height: 222px;
    }

    .flexBox4 .img {
        height: 67.2vw;
        min-height: 252px;
    }

    .flexBox3 .box p {
        margin-top: 8px;
    }

    .flexBox5 .box {
        padding: 5px 20px 30px 20px;
    }

    .flexBox6 .box {
        padding: 17px 19px;
    }

    .flexBox6 .box .tel {
        padding-left: 50px;
        background-size: 31.47px;
    }

    .flexBox6 .box:first-child .tel {
        margin-top: 0;
    }

    .flexBox6 .box .tel a {
        font-size: 35px;
    }

    .flexBox6 .box .cm {
        font-size: 14px;
        padding-left: 50px;
    }

}

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

.linkBox {
    padding: 0 66px 40px 60px;
    max-width: 1200px;
}

.linkBox1 {
    padding: 0;
    max-width: 1066px;
}

.linkBox::before {
    content: "";
    position: absolute;
    top: 26px;
    left: 0;
    width: 100%;
    height: calc(100% - 26px);
    background-color: #FAF8EF;
    border-radius: 5px;
    z-index: -1;
}

.linkBox1::before {
    display: none;
}

.linkBox .linkBoxTitle {
    position: relative;
    font-size: 30px;
    font-weight: 700;
    line-height: 1.315789473;
    padding-bottom: 17px;
    margin-bottom: 30px;
    color: #005EAD;
    text-align: center;
}

.linkBox .linkBoxTitle::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    margin: auto;
    background-color: #005EAD;
    width: 40px;
    height: 2px;
}

.linkBox .linkList {
    position: relative;
    column-gap: 20px;
    row-gap: 20px;
    justify-content: space-between;
}

.linkBox1 .linkList::after {
    content: "";
    display: block;
    width: calc(100% / 3 - 15px);
}

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

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

.linkBox .linkList li a {
    position: relative;
    font-size: 18px;
    font-weight: 700;
    line-height: 1.315789473;
    padding: 25px 70px 25px 30px;
    background-color: #fff;
    border-radius: 10px;
}

.linkBox1 .linkList li a {
    border: 1px solid #005EAD;
}

.linkBox1 .linkList li a:hover {
    background-color: #E8F2FF;
}

.linkBox .linkList li a .icon {
    position: absolute;
    top: 50%;
    right: 30px;
    transform: translateY(-50%);
    margin: auto;
    width: 30px;
    height: 30px;
    border-radius: 30px;
}

.linkBox .linkList li a .icon::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 38px;
    transition: .2s;
    z-index: -1;
    background: linear-gradient(to right, #4B97E0, #005EAD);
    transform: scale(1);
}

.linkBox .linkList li a .icon::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: center;
    background-size: 6.5px;
    background-image: url(../img/common/icon-right-white.svg);
}

.linkBox .linkList li a.current {
    color: #005EAD;
    pointer-events: none;
}

.linkBox .linkList li a.current .icon::before {
    background: #fff;
    border: 1px solid #005EAD;
    transform: scale(1.266666666);
}

.linkBox .linkList li a.current .icon::after {
    background-image: url(../img/common/icon-right-blue.svg);
}

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

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

    .linkBox1 .linkList li,
    .linkBox2 .linkList li {
        width: calc(100% / 3 - 15px);
    }

}

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

    .linkBox .linkList li a:hover {
        color: #005EAD;
    }

    .linkBox .linkList li a:hover .icon::before {
        background: #fff;
        border: 1px solid #005EAD;
        transform: scale(1.266666666);
    }

    .linkBox .linkList li a:hover .icon::after {
        background-image: url(../img/common/icon-right-blue.svg);
    }

}

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

    .linkBox {
        padding: 0 20px 30px 20px;
    }

    .linkBox1 {
        padding: 0 6px;
    }

    .linkBox1 .linkList::after {
        display: none;
    }

    .linkBox::before {
        top: 17px;
        height: calc(100% - 17px);
    }

    .linkBox .linkBoxTitle {
        font-size: 24px;
        padding-bottom: 12px;
    }

    .linkBox .linkList {
        row-gap: 12px;
    }

    .linkBox1 .linkList {
        row-gap: 10px;
    }

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

    .linkBox .linkList li a {
        font-size: 16px;
        padding: 19px 60px 19px 20px;
    }

    .linkBox1 .linkList li a {
        padding: 10px 60px 10px 16px;
        border-radius: 5px;
    }

    .linkBox .linkList li a .icon {
        right: 20px;
        width: 26px;
        height: 26px;
    }

    .linkBox1 .linkList li a .icon,
    .linkBox .linkList li a.current .icon::before {
        right: 15px;
        width: 26px;
        height: 26px;
    }

    .linkBox .linkList li a.current .icon::before {
        transform: none;
    }

    .linkBox .linkList li a .icon::after {
        background-size: 5.86px;
    }

}

/*faqList*/
.faqList {
    display: flex;
    flex-direction: column;
    row-gap: 32px;
    position: relative;
    border-radius: 5px;
    background-color: #FAF8EF;
    padding: 50px;
    margin-top: 48px;
}

.faqList .box {
    position: relative;
    background-color: #fff;
    border-radius: 5px;
}

.faqList .box .toggleBtn {
    position: relative;
    padding: 26px 103px 26px 50px;
    border-radius: 5px;
    background-color: #fff;
    cursor: pointer;
}

.faqList .box .toggleBtn .icon {
    position: absolute;
    top: 50%;
    right: 35px;
    transform: translateY(-50%);
    margin: auto;
    width: 35px;
    height: 35px;
    border-radius: 35px;
    background-color: #E8F2FF;
}

.faqList .box .toggleBtn .icon::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    margin: auto;
    width: 14px;
    height: 2px;
    background: #005EAD;
}

.faqList .box .toggleBtn .icon::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    margin: auto;
    height: 14px;
    width: 2px;
    background: #005EAD;
}

.faqList .box .toggleBtn.is-active .icon::after {
    display: none;
}

.faqList .qa {
    position: absolute;
    top: 50%;
    left: -27.5px;
    transform: translateY(-50%);
    margin: auto;
    width: 55px;
    height: 55px;
    border-radius: 55px;
    font-size: 27px;
    font-weight: 700;
    line-height: 50px;
    text-align: center;
    display: inline-block;
    background: linear-gradient(to bottom, #50B5FF, #005EAD);
    color: #fff;
}

.faqList .box .child {
    position: relative;
    display: none;
    padding: 0 35px 26px 50px;
    padding-top: 23px;
    overflow: visible;
}

.faqList .box .child::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50px;
    width: calc(100% - 85px);
    height: 2px;
    background-color: #C8C8C8;
}

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

    /*faqList*/
    .faqList {
        padding: 45px 18px 45px 35px;
        margin-top: 32px;
    }

    .faqList .box .toggleBtn {
        font-size: 16px;
        line-height: 1.75;
        padding: 23px 70px 23px 44px;
    }

    .faqList .box .toggleBtn .icon {
        right: 20px;
    }

    .faqList .box .child {
        font-size: 16px;
        line-height: 1.75;
        padding: 0 70px 32px 44px;
        padding-top: 28px;
    }

    .faqList .box .child::before {
        left: 44px;
        width: calc(100% - 114px);
    }

}

/*pageMessage*/
.pageMessage .content h2 {
    margin-bottom: 70px;
}

.pageMessage .top .topImg {
    position: relative;
    margin-bottom: 50px;
    padding: 0 37px 25px 37px;
}

.pageMessage .top .topImg .img {
    height: 460px;
}

.pageMessage .top .topImg .img img {
    border-radius: 5px;
}

.pageMessage .top .topImg .messageText {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 426px;
    height: 150px;
    padding: 28px 24px 25px 50px;
    border-radius: 5px;
    background-color: rgba(0, 133, 230, .8);
    color: #fff;
    font-family: "Zen Kaku Gothic New", serif;
    font-size: 32px;
    line-height: 1.5;
    font-weight: bold;
}

.pageMessage .top .text {
    max-width: 860px;
    margin: 0 auto;
}

.pageMessage .top .text .name {
    text-align: right;
    margin-top: 30px;
    vertical-align: middle;
}

.pageMessage .top .text .name .s {
    vertical-align: middle;
}

.pageMessage .top .text .name .b {
    font-size: 22px;
    margin-left: 20px;
    vertical-align: middle;
}

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

    .pageMessage .content h2 {
        margin-bottom: 40px;
    }

    .pageMessage .top .topImg {
        margin-bottom: 30px;
        padding: 0 0 54px 0;
    }

    .pageMessage .top .topImg .img {
        min-height: 472px;
        height: 125.86666666666666vw;
    }

    .pageMessage .top .topImg .messageText {
        left: -16px;
        width: 324px;
        height: 107px;
        padding: 16px 8px 16px 30px;
        font-size: 26px;
        line-height: 1.461538461;
    }

    .pageMessage .top .text {
        max-width: 100%;
    }

    .pageMessage .top .text .name {
        margin-top: 20px;
    }

    .pageMessage .top .text .name .b {
        font-size: 20px;
    }

}

/*pagePhilosophy*/
.pagePhilosophy .section1 .center {
    text-align: center;
}

.pagePhilosophy .section1 .philosophyText {
    font-family: "Zen Kaku Gothic New", serif;
    font-size: 34px;
    font-weight: 700;
    line-height: 1.647058823;
    display: inline-block;
    color: #005EAD;
    padding: 5px 77px 15px 77px;
    margin-bottom: 30px;
    background-image: url(../img/philosophy/philosophyText-1.svg), url(../img/philosophy/philosophyText-2.svg);
    background-repeat: no-repeat, no-repeat;
    background-position: top left 9px, bottom right;
    background-size: 75px, 57.5px;
}

.numBox {
    position: relative;
    padding: 0 36px 40px 36px;
    text-align: center;
}

.pagePhilosophy h3 {
    margin-top: 0;
}

.numBox::before {
    content: "";
    position: absolute;
    top: 16px;
    left: 0;
    width: 100%;
    height: calc(100% - 16px);
    background-color: #FAF8EF;
    border-radius: 5px;
    z-index: -1;
}

.numBoxList {
    position: relative;
    column-gap: 38px;
    row-gap: 17px;
    justify-content: space-between;
    text-align: left;
}

.pageTraining .numBoxList::before {
    content: "";
    position: absolute;
    top: 0;
    left: 77px;
    width: 3px;
    height: 100%;
    background-color: #50B5FF;
}

.numBoxList .box {
    position: relative;
}

.pagePhilosophy .numBoxList .box {
    width: calc(50% - 19px);
    padding: 12px 25px 12px 70px;
    min-height: 86px;
}

.pageTraining .numBoxList .box {
    padding: 25px 25px 25px 70px;
    margin-bottom: 24px;
}

.pageTraining .numBoxList .box:last-child {
    margin-bottom: 0;
}

.numBoxList .box::before {
    content: "";
    position: absolute;
    top: 0;
    left: 25px;
    width: calc(100% - 25px);
    height: 100%;
    background-color: #fff;
    border-radius: 5px;
}

.pagePhilosophy .numBoxList .box::before {
    left: 25px;
    width: calc(100% - 25px);
}

.pageTraining .numBoxList .box::before {
    left: 27px;
    width: calc(100% - 27px);
}

.numBoxList .box .num {
    position: absolute;
    top: 17px;
    left: 0;
    font-weight: 700;
    line-height: 1;
    background: linear-gradient(to bottom, #50B5FF, #005EAD);
    color: #fff;
    text-align: center;
    padding-top: 12px;
    border-radius: 100px;
    display: inline-block;
}

.pagePhilosophy .numBoxList .box .num {
    font-family: "Roboto", serif;
    font-size: 26px;
    width: 48px;
    height: 48px;
}

.pageTraining .numBoxList .box .num {
    top: 50%;
    transform: translateY(-50%);
    margin: auto;
    font-size: 13px;
    width: 55px;
    height: 55px;
}

.pageTraining .numBoxList .box:nth-child(6) .num,
.pageTraining .numBoxList .box:nth-child(7) .num,
.pageTraining .numBoxList .box:nth-child(8) .num {
    padding-top: 15px;
}


.pageTraining .numBoxList .box .num .big {
    font-size: 27px;
}

.pageTraining .numBoxList .box:nth-child(6) .num .big,
.pageTraining .numBoxList .box:nth-child(7) .num .big,
.pageTraining .numBoxList .box:nth-child(8) .num .big {
    font-size: 22px;
}

.numBoxList .box .text {
    position: relative;
    font-size: 18px;
    line-height: 1.555555;
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%;
}

.pagePhilosophy .section2 .text {
    font-size: 28px;
    font-weight: 700;
    line-height: 1.714285714;
}

.pageTraining .numBoxList .box:first-child ul {
    max-width: 520px;
    row-gap: 10px;
}

.pageTraining .numBoxList .box:first-child ul li {
    width: 50%;
}

.pageTraining .numBoxList .box ul li::before {
    width: 8px;
    height: 8px;
}

.pageTraining .numBoxList .box:last-child ul li {
    margin-right: 20px;
}

.pageTraining .videoWrap {
    margin: 45px auto 0;
    position: relative;
    padding-top: 56.25%;
    height: 0;
    overflow: hidden;
    max-width: 840px;
}

.pageTraining .videoWrap video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: auto
}

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

    .pagePhilosophy .section1 .philosophyText {
        font-size: 28px;
        line-height: 1.428571428;
        padding: 0 0 25px 0;
        background-position: top left, bottom right;
        background-size: 37.86px, 28.92px;
        margin-bottom: 15px;
    }

    .numBox {
        padding: 0 0 40px 0;
    }

    .numBox::before {
        top: 14px;
        left: -16px;
        width: calc(100% + 32px);
        height: calc(100% - 14px);
        border-radius: 0;
    }

    .numBoxList {
        row-gap: 15px;
    }

    .pageTraining .numBoxList::before {
        left: 50%;
        transform: translateX(-50%);
        margin: auto;
    }

    .pagePhilosophy .numBoxList .box {
        width: 100%;
        padding: 15px 28px 15px 60px;
        min-height: auto;
    }

    .pageTraining .numBoxList .box {
        padding: 60px 10px 20px 10px;
    }

    .numBoxList .box::before {
        left: 20px;
        width: calc(100% - 20px);
    }

    .pageTraining .numBoxList .box::before {
        left: 0;
        top: 25px;
        width: 100%;
        height: calc(100% - 25px);
    }

    .pagePhilosophy .numBoxList .box .num {
        top: 50%;
        transform: translateY(-50%);
        margin: auto;
        font-size: 23px;
        padding-top: 10px;
        width: 42px;
        height: 42px;
    }

    .pageTraining .numBoxList .box .num {
        top: 0;
        left: 50%;
        transform: translateX(-50%);
        width: 48px;
        height: 48px;
        padding-top: 10px;
    }

    .pageTraining .numBoxList .box:nth-child(6) .num,
    .pageTraining .numBoxList .box:nth-child(7) .num,
    .pageTraining .numBoxList .box:nth-child(8) .num {
        padding-top: 12px;
    }

    .numBoxList .box .text {
        font-size: 16px;
        line-height: 1.625;
    }

    .pagePhilosophy .section2 .text {
        font-size: 26px;
        line-height: 1.461538461;
    }

    .pageTraining .numBoxList .box:first-child ul,
    .pageTraining .numBoxList .box:first-child ul li {
        row-gap: 0;
        max-width: 100%;
        width: 100%;
    }

    .pageTraining .numBoxList .box:first-child ul li:nth-child(1) {
        order: 1;
    }

    .pageTraining .numBoxList .box:first-child ul li:nth-child(2) {
        order: 3;
    }

    .pageTraining .numBoxList .box:first-child ul li:nth-child(3) {
        order: 2;
    }

    .pageTraining .numBoxList .box:first-child ul li:nth-child(4) {
        order: 4;
    }

    .pageTraining .numBoxList .box:last-child ul li {
        margin-right: 0;
    }

}

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

.form .text {
    margin-bottom: 48px;
}

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

.form .box label {
    width: 260px;
    font-weight: 700;
    margin-right: 30px;
    background-color: #E6F4FF;
    border: 1px solid #E6F4FF;
    padding: 10px 24px;
}

.form .box label .red {
    font-family: "Zen Kaku Gothic New", sans-serif;
    font-size: 12px;
    font-weight: 500;
    text-align: center;
    width: 35px;
    height: 20px;
    border-radius: 3px;
    background-color: #EA7654;
    color: #fff;
    line-height: 1;
    padding-top: 4px;
    display: inline-block;
    margin: 5px 0 0 7px;
    vertical-align: top;
}

.form .box2 label .red,
.form .box4 label .red {
    margin-left: -1px;
}

.form .box input[type="text"],
.form .box input[type="email"],
.form .box textarea,
.form .box select {
    -webkit-appearance: none;
    appearance: none;
    width: calc(100% - 290px);
    border: 1px solid #D0CFCA;
    padding: 9px 12px;
    font-size: 15px;
}

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

.form .txt,
.form select {
    font-size: 15px;
}

.form select option:first-child,
.form textarea::placeholder {
    color: #D0CFCA;
    /* 通常の選択肢の色 */
}

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

.form .box1 input[type="text"],
.form .box2 input[type="text"] {
    width: calc(50% - 152px);
}

.form .box5 input[type="text"] {
    width: 380px;
    margin-left: 12px;
}

.form .box12 select {
    margin-right: 12px;
}

.form .box12 #birth1 {
    width: 16.428571428571427vw;
    max-width: 230px;
}

.form .box12 #birth2,
.form .box12 #birth3 {
    width: 14.6vw;
    max-width: 180px;
    margin-left: 12px;
}

.form .box1 input#name1,
.form .box2 input#namef1 {
    margin-right: 14px;
}

.form .box14 label {
    min-height: 81px;
    padding-top: 24px;
}

.form .box14 input {
    width: 100%;
}

.form .box14 input#file1 {
    margin-bottom: 20px;
}

.form .box14 input {
    color: #666666;
    font-weight: 400;
}

.form .box14 input::file-selector-button {
    margin-right: 12px;
}

.form .box14 .fileBox {
    width: calc(100% - 290px);
}

.form .box15 label {
    min-height: 200px;
    padding-top: 83px;
}

.form .box select {
    max-width: 380px;
    background: url(../img/contact/arrow.jpg) no-repeat top right;
    background-size: auto 100%;
    appearance: none;
    cursor: pointer;
    color: #666666;
    font-weight: 400;
}

.capture {
    margin: 48px auto 0;
    text-align: center;
}

.capture img {
    margin: 0 auto;
}

.capture input {
    border: 1px solid #ccc;
    height: 48px;
}

.capture span {
    font-weight: 400;
}

.submitBtnWrap {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 20px 40px;
    margin: 48px auto 0;
}

.submitBtnWrap .submitBtn {
    width: 100%;
    max-width: 300px;
    min-height: 55px;
    text-align: center;
    display: block;
    position: relative;
    font-size: 18px;
    font-weight: 600;
    line-height: 1.66666666666;
    padding: 10px;
    color: #fff;
    border-radius: 5px;
    height: 55px;
    width: 100%;
    cursor: pointer;
    transition: .2s;
}

.submitBtnWrap .submitBtn .icon {
    position: absolute;
    top: 50%;
    right: 17px;
    transform: translateY(-50%);
    margin: auto;
    width: 30px;
    height: 30px;
    border-radius: 30px;
}

.submitBtnWrap .backBtn .icon {
    left: 17px;
    right: unset;
    transform: translateY(-50%) rotate(180deg);
}

.submitBtnWrap .submitBtn .icon::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 34px;
    transition: .2s;
    z-index: -1;
    background-color: #fff;
    transform: scale(1);
}

.submitBtnWrap .submitBtn .icon::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: center;
    background-size: 6.6px;
    background-image: url(../img/common/icon-right-blue.svg);
}

.submitBtnWrap .submitBtn input {
    appearance: none;
    background: transparent;
    border: none;
    border-radius: 0;
    font: inherit;
    outline: none;
    padding: 0;
    opacity: 0 !important;
    display: block;
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
}

.submitBtnWrap .backBtn {
    background-color: #8b8a8a;
    border: 1px solid #8b8a8a;
}

.submitBtnWrap .backBtn:hover {
    background-color: #fff;
    border: 1px solid #8b8a8a;
    transition: .2s;
    color: #8b8a8a;
}

.submitBtnWrap .sendBtn {
    background-color: #005EAD;
    border: 1px solid #005EAD;
}

.submitBtnWrap .sendBtn:hover {
    color: #005EAD;
    background-color: #E8F2FF;
    transition: .2s;
}

.submitBtnWrap .backBtn:hover .icon::before {
    background-color: #8b8a8a;
    transform: scale(1.133333333);
}

.submitBtnWrap .sendBtn:hover .icon::before {
    background-color: #005EAD;
    transform: scale(1.133333333);
}

.submitBtnWrap .sendBtn:hover .icon::after,
.submitBtnWrap .backBtn:hover .icon::after {
    background-image: url(../img/common/icon-right-white.svg);
}

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

    .form .text {
        font-size: 16px;
        margin-bottom: 32px;
    }

    .form .box {
        margin-bottom: 20px;
    }

    .form .box label {
        font-size: 16px;
        width: 100%;
        margin-right: 0;
        margin-bottom: 14px;
        padding: 8px 10px;
    }

    .form .box input[type="text"],
    .form .box input[type="email"],
    .form .box textarea,
    .form .box select {
        width: 100%;
        padding: 10px 12px;
        margin: 0 10px;
    }

    .form .box1 input[type="text"],
    .form .box2 input[type="text"] {
        width: 100%;
    }

    .form .box1 input#name1,
    .form .box2 input#namef1 {
        margin-right: 10px;
        margin-bottom: 10px;
    }

    .form .box5 .txt {
        margin-left: 10px;
    }

    .form .box5 input[type="text"] {
        width: calc(100% - 45px);
    }

    .form .box12 select {
        margin-right: 12px;
    }

    .form .box12 #birth1,
    .form .box12 #birth2,
    .form .box12 #birth3 {
        width: calc(100% - 45px);
        max-width: 100%;
    }

    .form .box12 #birth2,
    .form .box12 #birth3 {
        margin-left: 10px;
        margin-top: 12px;
    }

    .form .box12 .txt2,
    .form .box12 .txt3 {
        margin-top: 12px;
    }

    .form .box14 label {
        min-height: 100%;
        padding-top: 8px;
    }

    .form .box14 input {
        width: 100%;
    }

    .form .box14 input#file1 {
        margin-bottom: 12px;
    }

    .form .box14 .fileBox {
        width: 100%;
        padding: 0 10px;
    }

    .form .box15 label {
        min-height: 100%;
        padding-top: 8px;
    }

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

}

/*pagePolicy*/
.pagePolicy .section {
    margin: 40px auto;
    padding: 40px 44px;
    background-color: #FAF8EF;
}

.pagePolicy .section .bold {
    margin-bottom: 40px;
    text-align: center;
}

.pagePolicy .section .box {
    margin-bottom: 32px;
}

.pagePolicy .section .box dt {
    font-size: 18px;
    font-weight: bold;
    line-height: 1.61111111;
    margin-bottom: 8px;
}

.pagePolicy .section .box dd,
.pagePolicy .section .name,
.pagePolicy .section .address {
    padding-left: 35px;
}

.pagePolicy .section .name {
    font-size: 20px;
    font-weight: 500;
    line-height: 1.45;
    margin-bottom: 12px;
}

.pagePolicy .center {
    text-align: center;
}

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

    .pagePolicy .section {
        margin: 24px auto 40px auto;
        padding: 40px 20px;
    }

    .pagePolicy .section .box dt {
        font-size: 18px;
        font-weight: bold;
        line-height: 1.61111111;
        margin-bottom: 8px;
    }

    .pagePolicy .section .box dd {
        padding-left: 37px;
    }

    .pagePolicy .section .name,
    .pagePolicy .section .address {
        padding-left: 0;
    }

    .pagePolicy .section .bold,
    .pagePolicy .section .box dd,
    .pagePolicy .section .address,
    .pagePolicy .center {
        font-size: 16px;
    }

    .pagePolicy .section .name {
        font-size: 18px;
        line-height: 1.61111111;
        margin-bottom: 15px;
    }

}

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

.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.svg) no-repeat center;
    background-size: 100% auto;
}

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

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

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

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

.pagination .num a:hover {
    background: #005EAD;
    color: #fff;
}

.pagination .num.active span {
    display: inline-block;
    width: 40px;
    height: 40px;
    text-align: center;
    border: 2px solid #005EAD;
    padding-top: 4px;
    color: #fff;
    background: #005EAD;
    font-weight: 700;
    line-height: 30px; /* 縦位置をaタグと合わせる */
}

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

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

    .pagination .button {
        width: 100%;
    }

}

/*pageTopicsDetail*/
.pageTopicsDetail .postTitle {
    margin-top: 16px;
}

.topicsContent {
    padding: 0 21px;
}

.topicsContent .img {
    max-width: 680px;
    height: 400px;
    margin: 0 auto 48px auto;
}

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

    .pageTopicsDetail .postTitle {
        margin-top: 8px;
        margin-bottom: 32px;
    }

    .topicsContent {
        padding: 0;
    }

    .topicsContent .img {
        max-width: 100%;
        height: 53.86666666666666vw;
        min-height: 202px;
        margin: 0 auto 40px auto;
    }

    .topicsContent p {
        font-size: 16px;
        line-height: 1.8125;
    }

}

/*pageFacility*/
.imgTop {
    max-width: 792px;
    margin: 40px auto 48px auto;
}

.pageCareer .imgTop {
    max-width: 900px;
}

.pageFacility .section {
    border-radius: 5px;
    background-color: #FAF8EF;
    padding: 30px 50px;
    margin-bottom: 56px;
}

.pageFacility .section h4 {
    margin-top: 0;
}

.pageFacility .content ul li {
    display: inline-block;
    margin-right: 29px;
}

.pageFacility .content ul li:first-child {
    display: block;
}

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

    .imgTop {
        max-width: 100%;
        margin: 32px auto;
    }

    .pageFacility .section {
        padding: 30px 20px;
        margin-bottom: 32px;
    }

    .pageFacility .content ul li {
        display: block;
        margin-right: 0;
    }

}

/*pageCareer*/
.pageCareer .cm {
    text-align: right;
    margin-top: 16px;
}

.pageCareer .cm cite {
    font-style: normal;
    all: unset;
}

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

    .pageCareer .cm {
        text-align: left;
    }

}

/*pageTraining*/
.pageTraining .section {
    position: relative;
    padding: 50px 28px 66px 28px;
    margin-bottom: 96px;
}

.pageTraining .section::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #FAF8EF;
    border-radius: 5px;
    z-index: -1;
}

.pageTraining .section .topTitle {
    font-size: 28px;
    font-weight: 700;
    line-height: 1.4;
    text-align: center;
    color: #005EAD;
}

.pageTraining .section .flexBox {
    margin: 32px auto;
    max-width: 850px;
    column-gap: 32px;
    row-gap: 15px;
}

.pageTraining .section .flexBox p {
    width: calc(100% / 3 - 22px);
    border-radius: 5px;
    font-size: 20px;
    font-weight: 700;
    line-height: 1.4;
    text-align: center;
    color: #fff;
    padding: 8px 16px;
}

.pageTraining .section .flexBox p:nth-child(1) {
    background-color: #50B5FF;
}

.pageTraining .section .flexBox p:nth-child(2) {
    background-color: #0082E1;
}

.pageTraining .section .flexBox p:nth-child(3) {
    background-color: #005EAD;
}

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

    .pageTraining .section {
        padding: 43px 7px 54px 7px;
        margin-bottom: 64px;
    }

    .pageTraining .section::before {
        content: "";
        position: absolute;
        top: 0;
        left: -16px;
        width: calc(100% + 32px);
    }

    .pageTraining .section .topTitle {
        font-size: 22px;
    }

    .pageTraining .section .flexBox {
        margin: 32px auto 24px auto;
        max-width: 100%;
    }

    .pageTraining .section .flexBox p {
        width: 100%;
        font-size: 18px;
    }

}

/*pageSupport*/
.pageSupport .section {
    padding: 0 0 0 175px;
    background: url(../img/support/support-4.webp) no-repeat top left;
    background-size: 130px;
}

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

    .pageSupport .section {
        padding: 125px 0 0 0;
        background: url(../img/support/support-4.webp) no-repeat top center;
        background-size: 130px;
    }

    .pageSupport .content p,
    .pageContact .content p {
        font-size: 16px;
    }

}

/*.pageContact*/
.pageContact .modBtn6 {
    margin-top: 7px;
    margin-bottom: 32px;
}

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

    .pageContact .modBtn6 {
        margin-top: 0;
        margin-bottom: 24px;
    }

}

/*pageRecruit*/
.pageRecruit .cm1 {
    text-align: right;
    margin-top: 16px;
}

.pageRecruit .cm2 {
    margin-top: 32px;
}

.pageRecruit .cm3 {
    position: relative;
    padding-left: 1em;
    margin-top: 32px;
}

.pageRecruit .cm3::before {
    content: "※";
    position: absolute;
    top: 0;
    left: 0;
}

.pageRecruit .section {
    border-radius: 5px;
    background-color: #FAF8EF;
    padding: 30px 50px;
    margin-top: 32px;
}

.pageRecruit .section h4 {
    margin-top: 0;
}

.pageRecruit .modBtn4 {
    margin-bottom: 48px;
}

.pageScholarship .modBtn7 {
    margin-top: 32px;
    margin-bottom: 48px;
}

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

    .pageRecruit .cm1 {
        font-size: 16px;
        margin-top: 12px;
    }

    .pageRecruit .cm2 {
        font-size: 16px;
    }

    .pageRecruit .cm3 {
        font-size: 16px;
        padding-left: 0;
    }

    .pageRecruit .cm3::before {
        content: "※";
        position: relative;
    }

    .pageRecruit .cm3 .sp {
        display: inline-block;
        width: 1em;
    }

    .pageRecruit .section {
        padding: 30px 27px;
        margin-top: 30px;
    }

    .pageRecruit .modBtn4 {
        margin-top: 16px;
        margin-bottom: 32px;
    }

    .pageScholarship .modBtn7 {
        margin-bottom: 32px;
    }

}

/*bannerDl*/
.bannerDl {
    position: relative;
    max-width: 740px;
    margin: 80px auto 0 auto;
    padding: 20px 0 30px;
    border-radius: 5px;
    height: 220px;
    overflow: hidden;
    transition: .2s;
    border: 1px solid #C8C8C8;
}

.bannerDl .imgBg {
    position: absolute;
    top: 0;
    left: 0;
    margin: auto;
    width: 100%;
    height: 100%;
    transition: .2s;
}

.bannerDl .imgText {
    position: relative;
    max-width: 430px;
    margin: 0 auto;
}

.bannerDl .icon {
    position: absolute;
    bottom: 15px;
    right: 22px;
    width: 28px;
    height: 28px;
    border-radius: 28px;
    background-color: #fff;
}

.bannerDl .icon::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 32px;
    transition: .2s;
    background-color: #fff;
}

.bannerDl .icon::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: center;
    background-size: 7.3px;
    background-image: url(../img/common/icon-right-blue2.svg);
}

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

    .bannerDl:hover .imgBg {
        transform: scale(1.05);
    }

    .bannerDl:hover .icon::before {
        transform: scale(1.142857142);
    }

}

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

    .bannerDl {
        max-width: 343px;
        margin: 48px auto 0 auto;
        padding: 42px 0 48px;
    }

    .bannerDl .imgText {
        max-width: 270px;
    }

    .bannerDl .icon {
        bottom: 12px;
        right: 17px;
    }

}

/*pageParticipants*/
.pageParticipants .flexBox {
    column-gap: 67px;
    row-gap: 16px;
}

.pageParticipants .flexBox .img {
    width: calc(50% - 33.5px);
}

.pageParticipants .flex2 .img {
    order: 2;
}

.pageParticipants .flexBox .img img {
    max-height: 321px;
    height: 22.928571428571427vw;
    width: 100%;
    border-radius: 5px;
    object-fit: cover;
}

.pageParticipants .flexBox .text {
    width: calc(50% - 33.5px);
}

.pageParticipants .flex2 .text {
    order: 1;
}

.pageParticipants .subject {
    background-color: #FAF8EF;
    padding: 13px 18px;
    border-radius: 5px;
    margin: 32px 0;
}

.pageParticipants .subject dt {
    color: #fff;
    background-color: #005EAD;
    border-radius: 5px;
    text-align: center;
    padding: 3px;
    margin-right: 18px;
    width: 60px;
    display: inline-block;
}

.pageParticipants .subject dd {
    width: calc(100% - 82px);
    display: inline-block;
}

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

    .pageParticipants .flexBox .img {
        width: 100%;
    }

    .pageParticipants .flex2 .img {
        order: 1;
    }

    .pageParticipants .flexBox .img img {
        max-height: 100%;
        height: 58.666666666666664vw;
        min-height: 220px;
        width: 100%;
    }

    .pageParticipants .flexBox .text {
        width: 100%;
    }

    .pageParticipants .flex2 .text {
        order: 2;
    }

    .pageParticipants .subject {
        margin: 16px 0;
    }

    .pageParticipants .subject dt {
        font-size: 16px;
    }

    .pageParticipants .subject dd {
        font-size: 16px;
    }

}

/*pageIntern*/
.pageIntern h2:not(:first-of-type) {
    margin-top: 96px;
}

.pageIntern .topImg {
    max-width: 720px;
    margin: 0 auto 72px auto;
}

.pageIntern .topImg img {
    max-height: 430px;
    height: 30.714285714285715vw;
    width: 100%;
    object-fit: cover;
}

.pageIntern .section {
    position: relative;
    border-radius: 5px;
    background-color: #FAF8EF;
    padding: 30px 50px;
    margin-top: 48px;
}

.pageIntern .modBtn5 {
    max-width: 341px;
}

.pageIntern .modBtn5 a {
    padding-right: 24px;
}

.pageIntern .modBtn5 a .icon {
    right: 11px;
}

.pageIntern .flexBox1 {
    column-gap: 67px;
    row-gap: 56px;
}

.pageIntern .flexBox1 .box {
    width: calc(50% - 33.5px);
}

.pageIntern .flexBox1 h3 {
    margin: 0;
}

.pageIntern .flexBox1 .img {
    margin-top: 32px;
    margin-bottom: 32px;
}

.pageIntern .flexBox1 .box.column2 {
    margin-top: 30px;
}

.pageIntern .section2 {
    padding: 55px 53px;
}

.pageIntern .section2::before {
    content: "";
    position: absolute;
    top: 55px;
    left: 107px;
    width: 3px;
    height: calc(100% - 172px);
    background-color: #50B5FF;
}

.pageIntern .section2 .box {
    position: relative;
    padding: 24px 30px;
    border-radius: 5px;
    background-color: #fff;
    margin-bottom: 24px;
}

.pageIntern .section2 .box:last-child {
    margin-bottom: 0;
}

.pageIntern .section2 .box h4 {
    margin: 0 0 24px 0;
}

.pageIntern .section2 .box ul {
    column-gap: 45px;
    row-gap: 24px;
}

.pageIntern .flexBox2 {
    column-gap: 47px;
}

.pageIntern .flexBox2 .box {
    width: calc(100% / 3 - 31.5px);
}

.pageIntern .flexBox2 .icon {
    width: 76px;
    margin: 0 auto;
    display: block;
}

.pageIntern .flexBox2 h4 {
    display: inline-block;
    width: calc(100% - 107px);
    margin: 18px 0 0 0;
}

.pageIntern .sectionContact {
    position: relative;
    background-color: #E6F4FF;
    padding: 30px;
    margin-top: 56px;
}

.pageIntern .sectionContact h3 {
    margin-top: 0;
}

.pageIntern .btn2 {
    margin-top: 46px;
}

.pageIntern .linkBox {
    margin-top: 96px;
    padding-bottom: 45px;
}

.pageIntern .linkBox h2 {
    margin-bottom: 60px;
}

.pageIntern .linkBox .bannerLink {
    column-gap: 60px;
    max-width: 860px;
    margin: 0 auto;
}

.pageIntern .linkBox .bannerLink .box {
    width: calc(50% - 30px);
    border-radius: 0;
}

.pageIntern .linkBox .bannerLink .box .img {
    height: 135px;
}

.pageIntern .linkBox .bannerLink .box .img img {
    transition: .3s;
}

.pageIntern .linkBox .bannerLink .box .modBtn3 {
    font-size: 18px;
    background-color: #005EAD;
    color: #fff;
    text-align: right;
    border-radius: 0;
    transition: .2s;
}

.pageIntern .linkBox .bannerLink .box .modBtn3 .btnInner {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    height: 100%;
}

.pageIntern .linkBox .bannerLink .box:hover .modBtn3 {
    background-color: #E8F2FF;
    color: #005EAD;
}

.pageIntern .linkBox .bannerLink .box .modBtn3 .icon {
    width: 28px;
    height: 28px;
}

.pageIntern .linkBox .bannerLink .box .modBtn3 .icon::before {
    background: #fff;
}

.pageIntern .linkBox .bannerLink .box:hover .modBtn3 .icon::before {
    background: #005EAD;
}

.pageIntern .linkBox .bannerLink .box .modBtn3 .icon::after {
    background: url(../img/common/icon-right-blue3.svg) no-repeat center;
    background-size: 7.3px;
}

.pageIntern .linkBox .bannerLink .box:hover .modBtn3 .icon::after {
    background-image: url(../img/common/icon-right-white2.svg);
}

.pageIntern .flexBox6 {
    max-width: 740px;
    margin: 56px auto 0 auto;
}

.pageIntern .flexBox6 .box {
    width: 100%;
}

.pageIntern .flexBox6 .box .tel {
    margin: 0;
}

.pageIntern .flexBox6 .box .cm3 {
    margin-top: 10px;
}

.pageIntern .flexBox3 {
    column-gap: 32px;
}

.pageIntern .flexBox3 .box {
    width: calc(100% / 4 - 24px);
    padding: 0;
    text-align: left;
}

.pageIntern .flexBox3 .box .img {
    border-radius: 5px;
    width: 100%;
}

.pageIntern .flexBox3 .box h4 {
    font-size: 18px;
    margin: 16px 0;
    border-bottom: none;
    background-image: repeating-linear-gradient(90deg, #005ead, #005ead 3px, transparent 3px, transparent 6px);
    background-position: left bottom;
    background-repeat: repeat-x;
    background-size: 100% 1px;
    padding-left: 0;
}

.pageIntern .flexBox3 .box h4::before {
    display: none;
}

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

    .pageIntern h2 {
        margin-top: 32px;
    }

    .pageIntern h2:not(:first-of-type) {
        margin-top: 56px;
    }

    .pageIntern .topImg {
        max-width: 100%;
        margin: 0 auto 32px auto;
    }

    .pageIntern .topImg img {
        max-height: 100%;
        min-height: 204px;
        height: 54.400000000000006vw;
    }

    .pageIntern .section {
        padding: 32px 27px;
        margin-top: 40px;
    }

    .pageIntern .modBtn4 {
        margin-top: 32px;
    }

    .pageIntern .modBtn5 {
        margin-top: 40px;
    }

    .pageIntern .modBtn5 a {
        padding-right: 40px;
    }

    .pageIntern .flexBox1 {
        row-gap: 32px;
    }

    .pageIntern .flexBox1 .box {
        width: 100%;
    }

    .pageIntern .flexBox1 .box.column2 {
        margin-top: -48px;
    }

    .pageIntern .flexBox1 .img {
        margin-top: 24px;
        margin-bottom: 16px;
    }

    .pageIntern .flexBox p {
        font-size: 16px;
    }

    .pageIntern .section2 {
        padding: 50px 20px;
    }

    .pageIntern .section2::before {
        top: 50px;
        left: 71px;
    }

    .pageIntern .section2 .box {
        padding: 19px 17px;
    }

    .pageIntern .section2 .box h4 {
        margin: 0 0 12px 0;
    }

    .pageIntern .section2 .box ul {
        flex-direction: column;
        row-gap: 6px;
    }

    .pageIntern .flexBox2 {
        row-gap: 32px;
    }

    .pageIntern .flexBox2 .box {
        width: 100%;
    }

    .pageIntern .sectionContact {
        padding: 30px;
        margin-top: 40px;
    }

    .pageIntern .btn2 {
        margin-top: 40px;
    }

    .pageIntern .linkBox {
        margin-top: 64px;
        padding-bottom: 38px;
    }

    .pageIntern .linkBox h2 {
        margin-bottom: 33px;
    }

    .pageIntern .linkBox .bannerLink {
        row-gap: 24px;
        max-width: 100%;
    }

    .pageIntern .linkBox .linkBoxTitle {
        white-space: nowrap;
    }

    .pageIntern .linkBox .bannerLink .box {
        width: 100%;
    }

    .pageIntern .linkBox .bannerLink .box .img {
        height: 36vw;
        min-height: 135px;
    }

    .pageIntern .linkBox .bannerLink .box .modBtn3 {
        padding: 19px 60px 19px 20px;
        line-height: 1.3333333;
    }

    .pageIntern .flexBox6 .box .cm {
        font-size: 14px;
        line-height: 1.8;
        padding: 0;
        margin-top: 8px;
    }

    .pageIntern .flexBox3 {
        column-gap: 32px;
    }

    .pageIntern .flexBox3 .box {
        width: calc(100% / 2 - 24px);
    }

}

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

    .pageIntern .flexBox2 .icon {
        width: 130px;
        height: 130px;
        margin: 0 auto;
        display: block;
    }

    .pageIntern .flexBox2 h4 {
        display: block;
        width: 100%;
        margin: 24px 0 0 0;
    }

    .pageIntern .flexBox3 .box {
        width: 100%;
    }

    .pageIntern .flexBox3 .box h4 {
        font-size: 16px;
        margin: 24px 0 16px 0;
    }

}

/*pageReal*/
.realVoice-mv {
    margin: 0 auto 64px;
}

.realVoice-mv img {
    margin: 0 auto;
}

.realVoice-mv p {
    margin: 10px auto 0;
    max-width: 600px;
}

.pageReal .flexBox4 {
    margin-top: 64px;
}

.pageReal .anchorList {
    margin: 96px 0;
}

.anchorList {
    padding: 0;
}

.anchorList::before,
.anchorList .linkList li::before,
.anchorList .toggleBtn {
    display: none;
}

.anchorList .linkList {
    column-gap: 36px;
    row-gap: 16px;
}

.anchorList .linkList li {
    width: calc(100% / 3 - 24px);
    padding: 0;
    border: 1px solid #005EAD;
    border-radius: 10px;
}

.anchorList .linkList::after {
    content: "";
    display: block;
    width: calc(100% / 3 - 24px);
}

.anchorList .linkList li a {
    height: 100%;
    min-height: 73px;
    padding: 10px 70px 10px 22px;
}

.anchorList .linkList li a .btnInner {
    height: 100%;
    display: flex;
    align-items: center;
}

.anchorList .linkList li a:hover {
    background-color: #E8F2FF;
}

.anchorList .linkList li a .icon::after {
    background-image: url(../img/common/icon-bottom-white.svg);
    background-size: 8.66px;
}

.anchorList1 .linkList li a .icon::after {
    background-image: url(../img/common/icon-right-white.svg);
}

.anchorList .linkList li a:hover .icon::after {
    background-image: url(../img/common/icon-bottom-blue.svg);
}

.anchorList1 .linkList li a:hover .icon::after {
    background-image: url(../img/common/icon-right-blue.svg);
}


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

    .pageReal .flexBox4 {
        margin-top: 40px;
        column-gap: 32px;
    }

    .pageReal .flexBox4 .box {
        width: calc(50% - 16px);
    }

    .flexBox4 .img {
        height: 238px;
    }

    .pageReal .anchorList {
        margin: 64px 0;
    }

    .anchorList .linkList {
        column-gap: 16px;
    }

    .anchorList .linkList li {
        width: calc(50% - 8px);
    }

    .anchorList .linkList::after {
        width: calc(50% - 8px);
    }

    .anchorList .linkList li a {
        min-height: 100%;
        padding: 19px 60px 19px 20px;
    }

    /* .pageReal .pageSupport .section h4 {
        margin-bottom: 25px;
        margin-top: 55px;
    } */

    .anchorList .linkList li a:hover {
        background-color: #fff;
    }

    .anchorList .linkList li a:hover .icon::after {
        background-image: url(../img/common/icon-bottom-white.svg);
    }

    .anchorList1 .linkList li a .icon::after,
    .anchorList1 .linkList li a:hover .icon::after {
        background-image: url(../img/common/icon-right-white.svg);
    }

}

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

    .pageReal .flexBox4 .box {
        width: 100%;
    }

    .pageReal .flexBox4 .img {
        height: 67.2vw;
        min-height: 252px;
    }

    .pageReal .anchorList {
        border: 1px solid #005EAD;
        border-radius: 5px;
    }

    .pageReal .anchorList {
        margin: 64px 0 40px 0;
    }

    .anchorList .toggleBtn {
        position: relative;
        display: block;
        font-size: 20px;
        font-weight: 700;
        color: #005EAD;
        padding: 21px 16px 21px 16px;
        cursor: pointer;
    }

    .anchorList .toggleBtn::before,
    .anchorList .toggleBtn::after {
        content: '';
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        margin: auto;
        background: #005EAD;
    }

    .anchorList .toggleBtn::before {
        height: 2px;
        width: 22px;
        right: 22px;
    }

    .anchorList .toggleBtn:after {
        height: 22px;
        width: 2px;
        right: 32px;
    }

    .anchorList .toggleBtn.is-active:after {
        height: 0;
        width: 0;
    }

    .anchorList .child {
        display: none;
        padding: 11px 22px 17px 22px;
    }

    .anchorList .linkList {
        row-gap: 12px;
    }

    .anchorList .linkList li {
        width: 100%;
        border-radius: 5px;
    }

    .anchorList .linkList::after {
        display: none;
    }

    .anchorList .linkList li a {
        padding: 9px 54px 9px 16px;
    }

    .linkBox .linkList li a .icon {
        right: 15px;
    }

    /* .pageReal .pageSupport .section h4 {
        margin-bottom: 15px;
        margin-top: 30px;
    } */

}

/*pageOrganization*/
.pageOrganization .img {
    margin: 80px auto 0 auto;
    max-width: 900px;
}

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

    .pageOrganization .img {
        margin: 32px auto 0 auto;
    }

}

/*pageStatistics*/
.pageStatistics .flexBox {
    column-gap: 36px;
    row-gap: 32px;
}

.pageStatistics .flexBox .box {
    width: calc(50% - 18px);
}

.pageStatistics .flexBox .box .bg {
    padding: 29px 25px 15px 25px;
    background-color: #FAF8EF;
    border-radius: 5px;
}

.pageStatistics .flexBox .box .bg h4 {
    margin-top: 0;
    margin-bottom: 10px;
}

.pageStatistics .flexBox .box .bg img {
    margin: 0 auto;
}

.pageStatistics .flexBox .box p {
    font-size: 16px;
}

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

    .pageStatistics .flexBox .box {
        width: 100%;
    }

    .pageStatistics .flexBox .box .bg {
        padding: 32px 23px 23px 23px;
    }

    .pageStatistics .flexBox .box .bg h4 {
        margin-bottom: 16px;
    }

}

/*pageWork*/
.flexBox7 {
    column-gap: 67px;
    row-gap: 24px;
}

.flexBox7 .img {
    width: calc(50% - 33.5px);
}

.flexBox7 .img img {
    border-radius: 5px;
    width: 100%;
    object-fit: unset;
    height: auto;
}

.flexBox7 .img img:nth-child(2) {
    margin-top: 16px;
}

.flexBox7 .text {
    width: calc(50% - 33.5px);
}

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

    .flexBox7 {
        column-gap: 24px;
    }

    .flexBox7 .img {
        width: calc(50% - 12px);
    }

    .flexBox7 .text {
        width: calc(50% - 12px);
    }

}

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

    .flexBox7 .img,
    .flexBox7 .text {
        width: 100%;
    }

}

/*pageOrigin*/
.pageOrigin .flexBox {
    column-gap: 27px;
    row-gap: 48px;
}

.pageOrigin .flexBox dl {
    width: calc(50% - 13.5px);
}

.pageOrigin .flexBox dl dt {
    font-size: 25px;
    font-weight: 700;
    text-align: center;
    padding: 8px;
    border-radius: 5px;
    background-color: #005EAD;
    color: #fff;
    margin-bottom: 24px;
}

.pageOrigin .flexBox dl dd ul li::before {
    content: "・";
    top: 0;
    left: 0;
    width: auto;
    height: auto;
    background-color: initial;
}

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

    .pageOrigin .flexBox {
        row-gap: 32px;
    }

    .pageOrigin .flexBox dl {
        width: 100%;
    }

    .pageOrigin .flexBox dl dt {
        font-size: 23px;
        margin-bottom: 17px;
    }

}

.dlList dl {
    margin-top: 7px;
}

.dlList dl {
    margin-bottom: 32px;
}

.dlList dl dt {
    position: relative;
    font-size: 21px;
    font-weight: 700;
    text-align: center;
    padding: 8px;
    border-radius: 5px;
    width: 130px;
    margin-right: 31px;
    display: inline-block;
    vertical-align: top;
    background-color: #E8F2FF;
    color: #134671;
}

.dlList dl dt::before {
    content: "";
    position: absolute;
    top: 4px;
    left: 4px;
    width: 100%;
    height: 100%;
    border-radius: 5px;
    background-color: #4C97E0;
    z-index: -1;
}

.dlList dl dd {
    width: calc(100% - 165px);
    display: inline-block;
}

.sectionMessage {
    border-radius: 5px;
    background-color: #FAF8EF;
    padding: 30px 50px;
    margin-top: 56px;
}

.sectionMessage h4 {
    font-size: 20px;
    margin-top: 0;
}

.sectionMessage p {
    font-size: 16px;
}

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

    .dlList dl {
        margin-top: 0;
    }

    .dlList dl {
        margin-bottom: 24px;
    }

    .dlList dl dt {
        font-size: 18px;
        padding: 5px;
        width: 95px;
        margin-right: 0;
        display: block;
        margin-bottom: 24px;
    }

    .dlList dl dd {
        width: 100%;
        display: block;
    }

    .sectionMessage {
        padding: 30px 27px;
        margin-top: 48px;
    }

    .sectionMessage h4 {
        margin-top: 0;
    }

}

/*pageSpecific*/
.pageSpecific .flexBox {
    column-gap: 44px;
    row-gap: 32px;
    margin: 40px 0 64px 0;
}

.pageSpecific .flexBox .box {
    width: calc(100% / 3 - 30.5px);
    position: relative;
    padding: 20px 10px;
    min-height: 97px;
    border-radius: 5px;
    background-color: #E8F2FF;
}

.pageSpecific .flexBox .box::before {
    content: "";
    position: absolute;
    top: 8px;
    left: 8px;
    width: 100%;
    height: 100%;
    border-radius: 5px;
    background-color: #4C97E0;
    z-index: -1;
}

.pageSpecific .flexBox .box p {
    font-size: 20px;
    font-weight: 700;
    line-height: 1.45;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #134671;
    margin: 0;
    height: 100%;
    text-align: center;
}

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

    .pageSpecific .flexBox {
        column-gap: 32px;
    }

    .pageSpecific .flexBox .box {
        width: calc(100% / 2 - 16.5px);
    }

}

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

    .pageSpecific .flexBox {
        row-gap: 16px;
        margin: 32px 0 40px 0;
    }

    .pageSpecific .flexBox .box {
        width: 100%;
        padding: 10px;
        min-height: auto;
    }

    .pageSpecific .flexBox .box::before {
        top: 6px;
        left: 6px;
    }

    .pageSpecific .flexBox .box p {
        line-height: 1.4;
    }

}

/*voiceList*/
.voiceList {
    column-gap: 22px;
    row-gap: 56px;
}

.linkBox .voiceList {
    max-width: 870px;
    margin: 47px auto 0 auto;
}

.voiceList .box {
    width: calc(100% / 4 - 16.5px);
}

.linkBox .voiceList .box {
    width: calc(100% / 3 - 15px);
}

.voiceList .box .img {
    max-height: 234px;
    height: 19vw;
    overflow: hidden;
    margin-bottom: 16px;
    border-radius: 5px;
}

.linkBox .voiceList .box .img {
    height: 21vw;
}

.voiceList .box .img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 5px;
    transition: .3s;
}

.voiceList .box:hover .img img {
    transform: scale(1.05);
}

.category {
    font-size: 14px;
    font-weight: 700;
    color: #005EAD;
}

.category .name {
    font-weight: 500;
    color: #000;
}

.voiceList .box .title {
    font-size: 18px;
    font-weight: 700;
    color: initial;
    padding: 0;
    margin: 3px 0 10px 0;
}

.voiceList .box .title::before,
.voiceList .box .title::after {
    display: none;
}

ul.tagList li {
    font-size: 13px;
    text-align: center;
    padding: 1px 6px 2px 6px;
    background-color: #005EAD;
    border-radius: 5px;
    color: #fff;
    display: inline-block;
    margin-right: 10px;
}

ul.tagList li::before {
    display: none;
}

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

    .voiceList .box {
        width: calc(100% / 3 - 16.5px);
    }

    .voiceList .box .img {
        max-height: 100%;
        height: 29vw;
    }

    .linkBox .voiceList .box .img {
        height: 27vw;
    }

}

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

    .voiceList {
        row-gap: 32px;
    }

    .linkBox .voiceList {
        width: calc(100% - 54px);
        margin-top: 56px;
    }

    .voiceList .box,
    .linkBox .voiceList .box {
        width: 100%;
    }

    .voiceList .box .img {
        height: 85vw;
    }

    .linkBox .voiceList .box .img {
        height: 63vw;
    }

    .category {
        font-size: 16px;
    }

    .linkBox .category {
        font-size: 14px;
    }

    .voiceList .box .title {
        font-size: 20px;
        margin: 8px 0 14px 0;
    }

    .linkBox .voiceList .box .title {
        font-size: 18px;
        margin: 3px 0 10px 0;
    }

}

/*voiceTop*/
.voiceTop {
    position: relative;
    margin-bottom: 24px;
}

.voiceTop::before {
    content: "";
    position: absolute;
    top: 20px;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #F4FAFF;
    border-radius: 5px;
    z-index: -1;
}

.voiceTop::after {
    content: "";
    position: absolute;
    top: 0;
    left: 18px;
    width: 77.99px;
    height: 50.12px;
    background: url(../img/common/pageMv-1.svg) no-repeat;
    background-size: 77.99px;
    mix-blend-mode: multiply;
}

.voiceTop .text {
    width: 50%;
    padding: 75px 47px 0 47px;
}

.voiceTop .text h2 {
    font-size: 23px;
    background: none;
    border: none;
    padding: 0;
    margin: 0 0 24px 0;
}

.voiceTop .text h2::before {
    display: none;
}

.voiceTop .text .category {
    font-size: 16px;
    margin-bottom: 5px;
}

.voiceTop .img {
    width: 50%;
    padding: 0 20px 0 13px;
    height: 250px;
}

.voiceTop .img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 5px;
}

.pageVoice .content p {
    font-size: 16px;
    line-height: 1.8125;
}

.pageVoice .modBtn4 {
    text-align: center;
    margin-top: 39px;
}

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

    .voiceTop {
        margin-bottom: 8px;
    }

    .voiceTop::before {
        top: 237px;
        left: -16px;
        width: calc(100% + 32px);
        height: calc(100% - 237px);
        background-color: #F4FAFF;
        border-radius: 0;
    }

    .voiceTop::after {
        display: none;
    }

    .voiceTop .text {
        width: 100%;
        padding: 26px 11px 32px 11px;
        order: 2;
    }

    .voiceTop .text h2 {
        font-size: 20px;
        margin: 0 0 12px 0;
    }

    .voiceTop .text h2::before {
        display: none;
    }

    .voiceTop .img {
        width: 100%;
        padding: 0;
        height: 280px;
        order: 1;
    }

}

/*sectionTalk*/
.sectionTalk {
    position: relative;
    margin-bottom: 64px;
    padding: 0 29px 30px 41px;
}

.sectionTalk::before {
    content: "";
    position: absolute;
    top: 20px;
    left: 0;
    width: 100%;
    height: calc(100% - 20px);
    background-color: #FAF8EF;
    border-radius: 5px;
    z-index: -1;
    box-shadow: rgba(0, 94, 173, 0.10) 0px 0px 8px 0px;
}

.sectionTalk.sectionTalk2::before {
    background-color: #E8F2FF;
}

.sectionTalk .text {
    width: 50%;
    padding-top: 67px;
}

.pageTalkDetail .sectionTalk .text {
    padding-top: 86px;
}

.sectionTalk .text h2 {
    font-size: 30px;
    background: none;
    border: none;
    padding: 0 0 15px 0;
    margin: 0;
}

.sectionTalk .text h2::before {
    width: 50px;
}

.sectionTalk .img {
    width: 50%;
    padding: 0 44px 0 0;
    min-height: 220px;
}

.sectionTalk .img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 5px;
}

.sectionTalk .modBtn4 {
    margin-top: 39px;
}

.talkIndex {
    margin-bottom: 56px;
}

@media screen and (max-width: 1023px) {
    .talkIndex {
        margin-bottom: 48px;
    }
}

.talkIndex a {
    text-decoration: underline;
    color: #005EAD;
    font-weight: bold;
    font-size: 16px;
    transition: all .3s;
    max-width: max-content;
    margin-bottom: 10px;
}

.talkIndex a:hover {
    text-decoration: none;
    color: #3CA0EB;
    transition: all .3s;
}

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

    .sectionTalk {
        padding: 0 21px 30px 21px;
    }

    .sectionTalk .img {
        width: 50%;
        padding: 0 21px 0 0;
        min-height: 220px;
    }

}

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

    .sectionTalk {
        margin-bottom: 45px;
        padding: 0 21px 19px 21px;
    }

    .pageTalkDetail .sectionTalk {
        padding: 0 21px 28px 21px;
    }

    .sectionTalk::before {
        top: 94px;
        height: calc(100% - 94px);
    }

    .sectionTalk .text {
        width: 100%;
        padding-top: 0;
    }

    .pageTalkDetail .sectionTalk .text {
        padding-top: 0;
    }

    .sectionTalk .text h2 {
        font-size: 28px;
        padding: 0;
    }

    .sectionTalk .text h2::before {
        display: none;
    }

    .sectionTalk .img {
        width: 100%;
        padding: 0 0 29px 0;
        height: 48vw;
        min-height: 186px;
    }

    .sectionTalk .modBtn4 {
        margin-top: 14px;
    }

}

.sectionMember {
    padding: 32px 46px 41px 46px;
    border-radius: 5px;
    background-color: #FAF8EF;
    margin: 48px 0 45px 0;
}

.sectionMember h4 {
    margin: 0 0 26px 0;
}

.sectionMember .flex {
    max-width: 800px;
    margin: 0 auto;
    column-gap: 50px;
    row-gap: 32px;
    justify-content: space-between;
}

.sectionMember.member5 .flex {
    max-width: unset;
    column-gap: 32px;
}

.sectionMember .flex .box {
    position: relative;
    width: calc(100% / 4 - 37.5px);
    text-align: center;
}

.sectionMember.member5 .flex .box {
    width: calc(100% / 5 - 37.5px);
}

.sectionMember .flex .box .img {
    width: 100%;
    aspect-ratio: 1;
    object-fit: cover;
    border-radius: 160px;
}

.sectionMember .flex .box .name {
    font-weight: 700;
    margin: 11px 0 5px 0;
}

.sectionMember .flex .box .text {
    font-size: 14px;
}

.sectionMember .flex .box .text .type {
    position: relative;
    display: inline-block;
    padding-right: 25px;
}

.sectionMember .flex .box .text .type::before {
    content: "/";
    position: absolute;
    top: -1px;
    right: 9px;
    color: #005EAD;
}

.sectionMember .flex .box .tagList {
    position: absolute;
    top: 4px;
    left: -3px;
}

.sectionMember .flex .box .tagList li {
    font-size: 15px;
}

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

    .sectionMember {
        padding: 32px 16px 46px 16px;
    }

    .sectionMember .flex {
        column-gap: 24px;
    }

    .sectionMember.member5 .flex {
        column-gap: 0px;
    }

    .sectionMember .flex .box {
        width: calc(100% / 4 - 18px);
    }

    .sectionMember.member5 .flex .box {
        width: calc(100% / 5 - 18px);
    }
}

@media screen and (max-width: 800px) {
    .sectionMember.member5 .flex {
        justify-content: flex-start;
        column-gap: 24px;
    }

    .sectionMember.member5 .flex .box {
        width: calc(100% / 3 - 18px);
    }
}

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

    .sectionMember {
        position: relative;
        padding: 32px 16px 46px 16px;
        border-radius: 0;
        background-color: none;
        margin: 48px 0 56px 0;
    }

    .sectionMember::before {
        content: "";
        position: absolute;
        top: 0;
        left: -16px;
        width: calc(100% + 32px);
        height: 100%;
        background-color: #FAF8EF;
        border-radius: 3px;
        z-index: -1;
    }

    .sectionMember h4 {
        margin: 0 0 38px 0;
    }

    .sectionMember .flex {
        column-gap: 24px;
    }

    .sectionMember .flex .box {
        width: calc(100% / 2 - 12px);
    }

    .sectionMember.member5 .flex .box {
        width: calc(100% / 2 - 12px);
    }

    .sectionMember .flex .box .name {
        margin: 12px 0 0 0;
    }

    .sectionMember .flex .box .text {
        font-size: 13px;
    }

    .sectionMember .flex .box .text .type {
        padding-right: 1em;
    }

    .sectionMember .flex .box .text .type::before {
        right: 3px;
    }

    .sectionMember .flex .box .tagList {
        top: 0;
    }

    .sectionMember .flex .box .tagList li {
        font-size: 13px;
    }

}

.sectionBlue {
    padding: 56px 59px;
    border-radius: 5px;
    background-color: #E8F2FF;
}

.sectionBlue .sectionTitle {
    margin-top: 56px;
}

.sectionBlue .sectionTitle.top {
    margin-top: 0;
}

.sectionBlue h2 {
    background-image: radial-gradient(circle, #005ead 1.5px, transparent 1.5px);
    background-position: left bottom;
    background-repeat: repeat-x;
    background-size: 13px 3px;
    border: none;
    padding: 0 0 11px 0;
    margin: 0 0 32px 0;
}

.sectionBlue h2::before {
    display: none;
}

.sectionBlue .bg {
    padding: 46px;
    border-radius: 5px;
    background-color: #fff;
}

.sectionBlue .bg .flex {
    margin-bottom: 32px;
}

.sectionBlue .bg .flex .img {
    width: 121px;
    padding-right: 21px;
    text-align: center;
}

.sectionBlue .bg .flex .img img {
    aspect-ratio: 1;
    object-fit: cover;
    border-radius: 100px;
}

.sectionBlue .bg .flex .img .name {
    font-size: 14px;
    font-weight: 700;
    margin-top: 12px;
}

.sectionBlue .bg .flex .text {
    width: calc(100% - 121px);
    padding: 20px;
    border-radius: 5px;
    box-shadow: rgba(0, 0, 0, 0.16) 0px 0px 6px 0px;
    max-height: max-content;
}

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

    .sectionBlue {
        padding: 39px 25px;
    }

    .sectionBlue .bg {
        padding: 46px 31px;
    }

}

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

    .sectionBlue .sectionTitle {
        margin-top: 46px;
    }

    .sectionBlue .sectionTitle h2 {
        font-size: 24px;
    }

    .sectionBlue .bg {
        padding: 20px;
    }

    .sectionBlue .bg .flex .img {
        width: 100%;
        padding-right: 0;
        margin-bottom: 21px;
    }

    .sectionBlue .bg .flex .img img {
        margin: 0 auto;
    }

    .sectionBlue .bg .flex .text {
        width: 100%;
        font-size: 16px;
    }

}

.pageTalkDetail .linkBox {
    padding-bottom: 71px;
}

.talkList {
    justify-content: space-between;
    column-gap: 66px;
    row-gap: 48px;
    margin-top: 39px;
}

.talkList .sectionTalk {
    width: calc(100% / 2 - 33px);
    margin-bottom: 0;
}

.talkList .sectionTalk .img,
.talkList .sectionTalk .text {
    width: 100%;
}

.talkList .sectionTalk .img {
    min-height: auto;
    max-height: 186px;
    height: 14vw;
    margin-bottom: 20px;
}

.talkList .sectionTalk .text {
    padding-top: 0;
}

.talkList .sectionTalk .text h2 {
    font-size: 26px;
    padding: 0;
}

.talkList .sectionTalk .modBtn4 {
    margin-top: 0;
}

.sectionBlue .bg .flex.figureImg {
    margin-bottom: 56px;
    column-gap: 6%;
    justify-content: center;
}

.sectionBlue .bg .flex.figureImg img {
    border-radius: 5px;
    width: 47%;
}

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

    .talkList {
        column-gap: 33px;
        row-gap: 48px;
    }

    .talkList .sectionTalk {
        width: calc(100% / 2 - 16.5px);
    }

    .talkList .sectionTalk .img {
        height: 19vw;
        padding-right: 0;
    }

}

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

    .talkList {
        row-gap: 32px;
    }

    .talkList .sectionTalk {
        width: 100%;
    }

    .talkList .sectionTalk .img {
        max-height: 100%;
        height: 42vw;
        min-height: 186px;
        padding: 0;
    }

    .talkList .sectionTalk .text h2 {
        font-size: 21px;
    }

    .talkList .sectionTitle .en {
        font-size: 14px;
        background-position: top 3px left;
    }

    .sectionBlue .bg .flex.figureImg {
        margin-bottom: 32px;
        row-gap: 24px;
    }

    .sectionBlue .bg .flex.figureImg img {
        width: 100%;
    }

}

.pageWorkstyle .sectionTop {
    position: relative;
    padding-bottom: 66px;
    margin-bottom: 80px;
}

.pageWorkstyle .sectionTop .img {
    width: 100%;
    max-width: 800px;
    margin: 0 auto;
}

.pageWorkstyle .sectionTop .img img {
    object-fit: unset;
    height: auto;
    border-radius: 5px;
}

.pageWorkstyle .sectionTop .text {
    position: absolute;
    top: 283px;
    right: 21px;
    padding: 26px;
    border-radius: 5px;
    background-color: #005EAD;
    color: #fff;
    width: 48.2328482%;
    max-width: 464px;
}

.pageWorkstyle .sectionTop .text::before {
    content: "";
    position: absolute;
    bottom: -13px;
    right: -21px;
    width: 98.91px;
    height: 66.11px;
    background: url(../img/common/illust-2.svg) no-repeat;
    background-size: 98.91px;
    z-index: -1;
}

.pageWorkstyle .sectionTop .text .type {
    font-weight: 600;
    line-height: 1.3;
}

.pageWorkstyle .sectionTop .text .name {
    font-size: 20px;
    border-bottom: 1px solid #fff;
    margin: 12px 0 16px 0;
    padding: 0 0 10px 0;
    background: none;
}

.pageWorkstyle .sectionTop .text .name::before {
    display: none;
}

.pageWorkstyle .lead {
    margin-bottom: 80px;
}

@media screen and (max-width: 799px) {
    .pageWorkstyle .sectionTop {
        margin-bottom: 20px;
        padding-bottom: 0;
    }

    .pageWorkstyle .sectionTop .text {
        position: relative;
        top: unset;
        right: unset;
        padding: 26px 16px;
        width: 100%;
        max-width: calc(100% - 22px);
        margin-top: 24px;
    }

    .pageWorkstyle .sectionTop .text::before {
        bottom: -18px;
        right: -22px;
    }
}

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

    .pageWorkstyle .sectionTop .text .type {
        font-size: 14px;
    }

    .pageWorkstyle .sectionTop .text .name {
        font-size: 20px;
        font-weight: 600;
        margin: 8px 0 16px 0;
    }

    .pageWorkstyle .lead {
        margin-bottom: 40px;
    }

}

.workFlow {
    margin-top: 80px;
}

.workFlow .flexBox {
    margin-bottom: 64px;
}

.workFlow .flex2 .img {
    order: 2;
}

.workFlow .flex2 .text {
    order: 1;
}

.workFlow .title {
    position: relative;
    padding: 0 17px 13px 17px;
    margin-bottom: 24px;
}

.workFlow .title::before {
    content: "";
    position: absolute;
    top: 8px;
    left: 0;
    width: 100%;
    height: calc(100% - 10px);
    border-radius: 5px;
    background-color: #E8F2FF;
    z-index: -1;
}

.workFlow .title img {
    display: inline-block;
    margin-right: 12px;
    vertical-align: bottom;
}

.workFlow .title .time {
    font-size: 22px;
    line-height: 1.3;
    color: #005EAD;
    display: inline-block;
    margin-right: 20px;
}

.workFlow .title .name {
    font-size: 25px;
    font-weight: 700;
    line-height: 1.16;
    display: inline-block;
    margin-top: 10px;
}

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

    .workFlow {
        margin-top: 56px;
    }

    .workFlow .flexBox {
        margin-bottom: 32px;
    }

    .workFlow .flex2 .img {
        order: 1;
    }

    .workFlow .flex2 .text {
        order: 2;
    }

    .workFlow .title {
        padding: 0 11px 10px 11px;
        margin-bottom: 16px;
    }

    .workFlow .title::before {
        top: 7px;
        height: calc(100% - 7px);
    }

    .workFlow .title img {
        margin-right: 10px;
    }

    .workFlow .title .time {
        font-size: 20px;
        margin-right: 10px;
    }

    .workFlow .title .name {
        font-size: 22px;
        line-height: 1.4;
    }

}

.pageFaq .section {
    margin-top: 56px;
}

.pageFaq #faq1 {
    margin-top: 80px;
}

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

    .pageFaq #faq1 {
        margin-top: 56px;
    }

}

/*確認用
body::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url(../img/pc.jpg) no-repeat top center;
    background-size: 100% auto;
    z-index: 10000;
    opacity: .8;
}*/