@charset "utf-8";

/* Contact */

.contactTextBox p {
    font-size: 1.4rem;
}
@media print, screen and (min-width: 770px) {
    .contactTextBox p {
        font-size: 1.6rem;
    }
}

/* 赤枠のお知らせBox（夏季休業など） */
.redLineBox {
    border: solid 1px #E20514;
    padding: 20px;
    margin-top: 30px;
}

.redLineBox .redLineBox_title {
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.5;
}
.redLineBox .redLineBox_title + p {
    margin-top: 10px;
}
@media print, screen and (min-width: 770px) {
    .redLineBox .redLineBox_title {
        font-size: 2.0rem;
    }
    .redLineBox {
        padding: 30px;
    }
}

.contactAnnounceTableText {
    margin-top: 20px;
}
@media print, screen and (min-width: 650px) {
    .contactAnnounceTableText{
        display: none;
    }    
}
.contactAnnounceTableText img {
    width: 19px;
    vertical-align: -3px;
    margin: 0 3px;
}

.contactAnnounceTableWrap {
    overflow-x: auto;
}
.contactAnnounceTableWrap .contactAnnounceTable {
    width: 1000px;
}

.contactAnnounceTable {
    box-sizing: border-box;
    font-size: 1.4rem;
    line-height: 1.2;
    margin: 20px 0 10px;
    width: 100%;
}

.contactAnnounceTable tr th,
.contactAnnounceTable tr td {
    box-sizing: border-box;
    border: solid 1px #000;
    font-weight: normal;
    text-align: center;
    vertical-align: middle;
    padding: 7px 2px;
}

.contactAnnounceTable tr th:nth-of-type(n+1),
.contactAnnounceTable tr td {
    width: 2.5em;
}

.contactAnnounceTable tr:nth-of-type(n+1) th:first-of-type {
    padding: 7px 2px;
}
@media print, screen and (min-width: 770px) {
    .contactAnnounceTableWrap .contactAnnounceTable {
        width: 100%;
    }

    .contactAnnounceTable {
        box-sizing: border-box;
        font-size: 1.4rem;
        line-height: 1.2;
        margin: 20px 0 5px;
    }

    .contactAnnounceTable tr th,
    .contactAnnounceTable tr td {
        padding: 10px px;
    }

    .contactAnnounceTable tr th:nth-of-type(n+1),
    .contactAnnounceTable tr td {
        width: 4em;
    }

    .contactAnnounceTable tr th:first-of-type {
        width: 9em;
    }

    .contactAnnounceTable tr:first-of-type th {
        letter-spacing: -0.05em;
        white-space: nowrap;
        padding: 6px 2px 7px;
    }
}

.contactCategory {
    display: flex;
    flex-direction: column;
    gap: 40px;
    margin-top: 40px;
}
.contTitle_h2 + .contactCategory_cont {
    margin-top: 20px;
}
@media print, screen and (min-width: 770px) {
    .contactCategory {
        flex-direction: row;
        gap: 60px;
        margin-top: 60px;
    }
    .contactCategory_item {
        width: 570px;
    }
    .contTitle_h2 + .contactCategory_cont {
        margin-top: 40px;
    }
    .contactCategory_cont {
        padding-left: 20px;
    }
}
.contactTitle_h3 {
    position: relative;
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 1.5;
    padding-left: 1em;
    margin-top: 30px;
}
.contactTitle_h3::before {
    content: "■";
    color: var(--main-blue);
    position: absolute;
    top: 0;
    left: 0;
}
.contactTitle_h3:first-child {
    margin-top: 0;
}
@media print, screen and (min-width: 770px) {
    .contactTitle_h3 {
        font-size: 2.0rem;
        margin-top: 40px;
    }
}


.contactBtnBox {
    border: solid 1px var(--main-blue);
    background-color: #fff;
}
.contactBtnBox:not(:first-child) {
    margin-top: 20px;
}
@media print, screen and (min-width: 770px) {
    .contactBtnBox:not(:first-child) {
        margin-top: 30px;
    }
}

.contactBtnBox_head {
    position: relative;
    display: flex;
    align-items: center;
    box-sizing: border-box;
    padding: 0 30px 0 12px;
    min-height: 64px;
}
a.contactBtnBox_head {
    color: #333;
}
.contactBtnBox_head::after {
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    font-family: "Font Awesome 5 Pro";
    font-weight: 900;
    color: var(--main-blue);
    position: absolute;
    top: 50%;
    right: 14px;
    transform: translateY(-50%);
}
p.contactBtnBox_head::after {
    content: "\f078";
}
p.contactBtnBox_head.active::after {
    content: "\f077";
}
a.contactBtnBox_head::after {
    content: "\f054";
}
.contactBtnBox_head_txt {
    font-weight: bold;
    line-height: 1.5;
}
@media print, screen and (min-width: 770px) {
    .contactBtnBox_head {
        padding: 0 45px 0 20px;
        transition: .3s;
        min-height: 80px;
    }
    .contactBtnBox_head::after {
        right: 20px;
        font-size: 2.0rem;
        transition: all .3s;
    }
    .contactBtnBox_head:hover {
        background-color: #EFF0F2;
        color: #0062B1;
        text-decoration: underline;
        cursor: pointer;
    }
    p.contactBtnBox_head:hover::after {
        top: calc(50% + 5px);
    }
    p.contactBtnBox_head.active:hover::after {
        top: calc(50% - 5px);
    }
    a.contactBtnBox_head:hover::after {
        right: 15px;
    }
    .contactBtnBox_head_txt {
        font-size: 2.0rem;
    }
}
.contactBtnBox_body {
    display: none;
    position: relative;
}
.contactBtnBox_body::before {
    content: "";
    width: calc(100% - 20px);
    height: 1px;
    background-color: var(--main-blue);
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
}
.contactBtnBox_body_inner {
    padding: 20px 10px;
}
.contactBtnBox_body_inner:nth-child(even) {
    background-color: #EFF0F2;
}
.contactBtnBox_body_inner p {
    font-size: 1.4rem;
}
@media print, screen and (min-width: 770px) {
    .contactBtnBox_body::before {
        width: calc(100% - 40px);
    }
    .contactBtnBox_body_inner {
        padding: 30px 20px;
    }
    .contactBtnBox_body_inner p {
        font-size: 1.6rem;
    }
}

.contactBtnBox_ttl {
    font-size: 1.6rem;
    font-weight: 500;
}
.contactBtnBox_ttl + * {
    margin-top: 8px;
}
.contactBtnBox_ttl_type {
    display: block;
    padding-bottom: .5em;
}
@media print, screen and (min-width: 770px) {
    .contactBtnBox_ttl {
        font-size: 2.0rem;
        line-height: 1.4;
    }
}

.contactBtnBox_redBox {
    display: block;
    border: solid 1px #E20514;
    padding: .6em .8em;
    font-size: 1.7rem;
    font-weight: bold;
    margin: 5px 0 15px;
}

.contactBtnBox_btn + .contactBtnBox_tel {
    margin-top: 16px;
}
.contactBtnBox_tel dt {
    font-size: 1.4rem;
    font-weight: 500;
}
.contactBtnBox_tel dd {
    font-size: 1.4rem;
    margin-top: .3em;
}
@media print, screen and (min-width: 770px) {
    .contactBtnBox_tel dt {
        font-size: 1.8rem;
    }
    .contactBtnBox_tel dd {
        font-size: 1.6rem;
    }
}

a.contactBtnBox_btn {
    position: relative;
    color: #fff;
    background-color: var(--main-blue);
    display: flex;
    align-items: center;
    box-sizing: border-box;
    padding: 0 30px 0 12px;
    min-height: 64px;
}
a.contactBtnBox_btn::after {
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    font-family: "Font Awesome 5 Pro";
    font-weight: 900;
    content: "\f054";
    color: #fff;
    position: absolute;
    top: 50%;
    right: 14px;
    transform: translateY(-50%);
}
* + a.contactBtnBox_btn {
    margin-top: 10px;
}
.contactBtnBox_btn_txt {
    font-weight: bold;
    line-height: 1.5;
}
@media print, screen and (min-width: 770px) {
    a.contactBtnBox_btn {
        padding: 0 45px 0 20px;
        transition: .3s;
        min-height: 80px;
    }
    a.contactBtnBox_btn::after {
        right: 20px;
        font-size: 2.0rem;
        transition: all .3s;
    }
    a.contactBtnBox_btn:hover::after {
        right: 15px;
    }
    * + a.contactBtnBox_btn {
        margin-top: 16px;
    }
    .contactBtnBox_btn_txt {
        font-size: 2.0rem;
    }
}

.contactNotesList {
    font-size: 1.4rem;
}
.contactNotesList_mt16 {
    margin-top: 16px;
}
.contactBtnBox + .contactNotesList {
    margin-top: 10px;
}
.contactNotesList li {
    position: relative;
    padding-left: 1.5em;
}
.contactNotesList li::before {
    content: "※";
    color: #D80616;
    position: absolute;
    top: 0;
    left: 0;
}
.contactNotesList li + li {
    margin-top: .5em;
}
