@charset "utf-8";

table {
    width: 100%;
    border-spacing: 0;
}

h2 {
    font-family: "Noto Sans JP Black";
    font-size: 40px;
    color: #1759A9;
    font-weight: 900;
    text-align: center;
    line-height: 1.4;
}

p {
    font-size: 15px;
}

section {
    padding-block: 28px 197px;
}

.flex {
    display: flex;
}
.flex-row {
    display: flex;
    flex-direction: column;
}

.wrapper {
    max-width: 1195px;
    margin: 0 auto;
}

@media screen and (max-width: 768px) {
    h2 {
        font-size: 30px;
    }
}

/* about us */
.about-us .wrapper {
    max-width: 1195px;
    padding-inline: 35px;
}

.about-us h2 {
    margin-bottom:30px;
}
.about-us #section02 h2,
.about-us .advantage h2 {
    font-size: 31px;
}
.about-us #section01 h2 {
    margin-bottom: 50px;
}
.about-us .advantage h2 {
    text-align: left;
}

.about-us #section01 table th,
.about-us #section01 table td {
    font-size: 17px;
    padding-bottom: 12px;
    line-height: 1.6;
}
.about-us #section01 table th {
    width: calc(100% - 76.6974%);
    text-align: left;
}
.about-us #section01 table td {
    width: 76.6974%;
    vertical-align: top;
}
.about-us #section01 table td a {
    text-decoration: underline;
}
.about-us #section01 table td a:hover {
    text-decoration: none;
    opacity: 0.7;
}

.about-us #section02 .comment {
    max-width: 775px;
    margin: 0 auto 45px;
}
.about-us #section02 .list {
    display: grid;
    grid-template-columns: 1fr;
    grid-auto-rows: 1fr;
    gap: 16px;
}
.about-us #section02 .list .list-item {
    color: #fff;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    border-radius: 15px 0 0 15px;
    padding: 35px;
    margin-left: -25px;
}
.about-us #section02 .list .item01 {
    background-image: url(../../image/contents/about-us_item01.webp);
}
.about-us #section02 .list .item02 {
    background-image: url(../../image/contents/about-us_item02.webp);
}
.about-us #section02 .list .item03 {
    background-image: url(../../image/contents/about-us_item03.webp);
}
.about-us #section02 .list .item04 {
    background-image: url(../../image/contents/about-us_item04.webp);
}
.about-us #section02 .list .list-item .text-group {
    width: calc(100% - 73.94%);
}
.about-us #section02 .list .list-item .text-group .text01 {
    font-size: 22px;
    font-weight: bold;
    margin-bottom: 13px;
}

.about-us .advantage .block01 {
    width: 55%;
}
.about-us .advantage .block01 a {
    display: inline-block;
    font-size: 20px;
    color: #1759A9;
    border: 1px solid #1759A9;
    padding: 12px 4em;
    transition: .3s;
    border-radius: 8px;
}
.about-us .advantage .block01 p {
    margin-bottom: 25px;
}
.about-us .advantage .block01 a:hover {
    color: #fff;
    background-color: #1759A9;
}
.about-us .advantage .block02 {
    width: 45%;
    text-align: center;
}
.about-us .advantage .block02 img {
    max-width: 314px;
}

.about-us .linkArea {
    display: flex;
    justify-content: center;
}
.about-us .linkArea a {
    display: flex;
    align-items: center;
    max-width: 722px;
    font-size: 32px;
    color: #fff;
    background-color: #1759A9;
    border: 3px solid #1759A9;
    font-weight: bold;
    padding-block: 42px;
    border-radius: 13px;
}

@media screen and (max-width: 768px) {
    .about-us #section01 table th, 
    .about-us #section01 table td {
        display: block;
    }
    .about-us #section01 table th {
        padding-bottom: 5px;
    }
}

/* function */
.function #section01 h2 {
    margin-bottom: 60px;
}

.function #section01 .list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-auto-rows: 1fr;
    gap: calc(90vw / 19.2);
    margin-bottom: 120px;
}
.function #section01 .list li .number,
.function #section01 .list li .title {
    font-weight: bold;
    color: #1759A9;
    text-align: center;
}
.function #section01 .list li .number {
    font-family: "Tw Cen MTB";
    font-size: 64px;
    margin-bottom: 30px;
}
.function #section01 .list li .title {
    font-size: 25px;
    margin-bottom: 15px;
}
.function #section01 .blockArea {
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.function #section01 .blockArea .item {
    background-color: #F2F5FA;
    padding: 16px;
    border-radius: 29px;
}
.function #section01 .blockArea .item .container {
    display: flex;
}
.function #section01 .blockArea .item .img {
    width: fit-content;
    aspect-ratio: 334 / 276;
    overflow: hidden;
    border-radius: 16px;
}
.function #section01 .blockArea .item .img img {
    width: 100%;
    object-fit: cover;
}
.function #section01 .blockArea .item .text {
    flex-grow: 1;
}
.function #section01 .blockArea .item .text .text01 {
    font-size: 21px;
    font-weight: bold;
    margin-bottom: 10px;
}

.function #section02 h2 {
    margin-bottom: 16px;
}
.function .comment {
    font-weight: bold;
    margin-bottom: 20px;
}
.function .comment,
.function #section02 a {
    text-align: center;
}
.function #section02 a {
    display: block;
    max-width: 515px;
    font-size: 26px;
    color: #1759A9;
    font-weight: bold;
    border: 3px solid #1759A9;
    border-radius: 16px;
    transition: .3s;
    padding: 1em 0;
    margin: 0 auto;
}
.function #section02 a:hover {
    color: #fff;
    background-color: #1759A9;
}
.function #section02 table {
    max-width: 1083px;
    margin: 50px auto 0;
}
.function #section02 table,
.function #section02 table th,
.function #section02 table td {
    border: 1px solid #ddd;
    border-collapse: collapse;
}
.function #section02 colgroup .col-menu {
    width: 27%;
}
.function #section02 colgroup .col-function01 {
    width: 31%;
}
.function #section02 colgroup .col-function02 {
    width: 42%;
}
.function #section02 table th,
.function #section02 table td {
    padding-block: 0.5em;
}
.function #section02 table thead th {
    font-size: 18px;
    color: #fff;
    font-weight: bold;
    text-align: center;
    background-color: #1759A9;
}
.function #section02 table tbody td {
    font-size: 15px;
    font-weight: 500;
    text-indent: 0.5em;
}