@charset "utf-8";

.anchor {
    margin-top: -80px;
    padding-top: 80px;
}

/*================================================================
# 全ページ共通スタイル
================================================================ */
/* header
------------------------------------------------------ */
.header {
    width: 100%;
    height: 80px;
    background: #fff;
    box-shadow: 0 0 4px rgba(0, 0, 0, 0.1);
    position: fixed;
    z-index: 9999;
}

.box_head {
    width: 100%;
    height: 80px;
    margin: 0 auto;
}

.box_head .nav {
    height: 80px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.nav h1 {
    width: 160px;
    margin: 0 auto;
    padding: 0;
}

.nav ul {
    display: none;
}

.nav li {
    width: 33.3%;
    float: left;
}

.nav li a {
    display: block;
    font-size: 18px;
    font-weight: 600;
    line-height: 1;
    color: var(--black);
    text-align: center;
}

.nav li a span {
    padding: 10px 0 0;
    display: block;
    font-size: 12px;
    line-height: 1;
    color: var(--black);
}

.nav li a:hover {
    opacity: 0.7;
}

.zdo_drawer_menu .zdo_drawer_bg {
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.7);
    position: fixed;
    top: 0;
    left: 0;
    display: none;
    z-index: 999;
}

.zdo_drawer_menu .zdo_drawer_button {
    width: 35px;
    padding: 0;
    cursor: pointer;
    border: none;
    outline: none;
    background: none;
    position: absolute;
    top: 20px;
    right: 20px;
    display: block;
    text-align: center;
    z-index: 1001;
}

.zdo_drawer_menu .zdo_drawer_button.active {
    top: 20px;
    right: 250px;
    transition: all 0.2s;
}

.zdo_drawer_menu .zdo_drawer_bar {
    height: 3px;
    margin: 7px 0 0;
    background-color: var(--black);
    display: block;
    transition: all 0.2s;
    transform-origin: 0 0;
}

.zdo_drawer_menu .zdo_drawer_button.active .zdo_drawer_bar {
    width: 35px;
    height: 3px;
    margin: 0;
    background-color: var(--white);
}

.zdo_drawer_menu .zdo_drawer_button.active .zdo_drawer_bar1 {
    margin: 31px 0 0 !important;
    transform: rotate(-45deg);
}

.zdo_drawer_menu .zdo_drawer_button.active .zdo_drawer_bar2 {
    opacity: 0;
}

.zdo_drawer_menu .zdo_drawer_button.active .zdo_drawer_bar3 {
    margin: -31px 0 0 2.25px !important;
    transform: rotate(45deg);
}

.zdo_drawer_menu .zdo_drawer_button.active .zdo_drawer_close {
    display: block;
}

.zdo_drawer_menu .zdo_drawer_close {
    display: none;
}

.zdo_drawer_menu .zdo_drawer_nav_wrapper {
    width: 240px;
    height: 100%;
    padding: 80px 0 0;
    background: var(--primary);
    position: fixed;
    top: 0;
    right: 0;
    overflow: auto;
    z-index: 1000;
    transition: all 0.2s;
    transform: translate(240px);
    -webkit-overflow-scrolling: touch;
}

.zdo_drawer_menu .zdo_drawer_nav_wrapper.open {
    transform: translate(0);
}

.switch li a {
    padding: 20px 20px 20px 40px;
    position: relative;
    display: block;
    font-size: 16px;
    font-weight: 600;
    line-height: 1;
    color: var(--white);
}

.switch li a:before {
    width: 6px;
    height: 6px;
    margin-top: -4px;
    border: 0px;
    border-top: solid 2px #fff;
    border-right: solid 2px #fff;
    position: absolute;
    content: "";
    top: 50%;
    left: 20px;
    -ms-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

/* ページトップ
------------------------------------------------------ */
.scroll-to-top {
    width: 48px;
    height: 48px;
    cursor: pointer;
    position: fixed;
    right: 16px;
    bottom: 16px;
    z-index: 9;
}

.scroll-to-top a {
    width: 48px;
    height: 48px;
    border-radius: 9999px;
    background-color: var(--primary);
    display: flex;
    justify-content: center;
    align-items: center;
}

.scroll-to-top a img {
    width: 16px;
    display: block;
}

/* フッター
------------------------------------------------------ */
.footer {
    padding: 0 0 150px;
    background: url(../img/footer.png) repeat-x center bottom / auto 150px;
    background-color: var(--footer);
    position: relative;
}

.footer:before {
    width: 100%;
    height: 320px;
    background-color: var(--white);
    position: absolute;
    content: "";
    top: 0;
    left: 0;
}

.footer .contact-area {
    padding: 100px 0 0;
}

.footer .contact-area .contact__panel {
    margin: 0;
    padding: 64px 24px;
    border-radius: 30px;
    background: var(--bg03);
    position: relative;
    color: var(--white);
}

.footer .contact-area .heading01 .title-en {
    color: var(--white);
}

.footer .contact-area .contact__col {
    padding: 40px 0;
    text-align: center;
}

.footer .contact-area .contact__col:first-child {
    border-bottom: 4px dotted rgba(255, 255, 255, 0.9);
}

.footer .contact-area .contact__name {
    font-size: 18px;
    font-weight: 600;
    color: var(--white);
}

.footer .contact-area .contact__name small {
    display: block;
    font-size: 14px;
    font-weight: 600;
}

.footer .contact-area .contact__tel {
    font-size: 14px;
    letter-spacing: 0.06em;
}

.footer .contact-area .contact__tel a {
    display: inline-block;
    font-size: 32px;
    font-weight: 600;
    color: var(--white);
    text-decoration: none;
}

.footer .contact-area .btn01 {
    margin: 0;
}

.footer .contact-area .btn01 a {
    width: 100%;
    padding: 20px 20px 22px;
    border: 2px solid var(--secondary);
    display: flex;
    justify-content: center;
    align-items: center;
    color: var(--secondary);
}

.footer .contact-area .btn01 a::after {
    display: none;
}

.footer .contact-area .btn01 .icon {
    width: 24px;
    height: 17px;
    margin: 0 8px 0 0;
    background: url("../img/icon_contact.svg") no-repeat 50% 50% / contain;
    display: block;
}

.footer .contact-area .top_illust06,
.footer .contact-area .top_illust07 {
    user-select: none;
    pointer-events: none;
    position: absolute;
}

.footer .contact-area .top_illust06 {
    width: calc(396px / 2);
    top: -5px;
    left: -111px;
}

.footer .contact-area .top_illust07 {
    width: calc(369px / 2);
    top: -24px;
    right: -91px;
    transform: scale(-1, 1);
}

.footer .head {
    padding: 80px 0 0;
}

.footer .head .brand {
    margin: 0;
}

.footer .head .brand .logo a {
    display: flex;
    justify-content: center;
    align-items: center;
}

.footer .head .infos {
    margin: 64px 0 0;
}

.footer .head .info {
    margin: 40px 0 0;
    padding: 0;
}

.footer .head .info .ttl {
    margin: 0 0 8px;
    font-size: 18px;
    font-weight: 500;
    line-height: 1.5;
    color: var(--black);
}

.footer .head .info .ttl small {
    font-size: 13px;
    font-weight: 500;
    color: var(--black);
}

.footer .head .info .addr {
    margin: 0 0 6px;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.8;
    color: var(--black);
}

.footer .head .info .contact {
    margin: 0;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.8;
    color: var(--black);
}

.footer .foot {
    margin: 64px 0 0;
}

.footer .gnav_main li {
    width: 100%;
    display: block;
}

.footer .gnav_main li a {
    width: 100%;
    padding: 16px 16px 18px;
    border-bottom: 2px solid transparent;
    background: repeating-linear-gradient(to right, var(--border01) 0 2px, transparent 2px 6px) left bottom/auto 2px repeat-x;
    position: relative;
    display: block;
    font-weight: 500;
    transition: 0.3s;
}

.footer .gnav_main li a span {
    display: block;
    font-size: 14px;
    color: var(--primary);
    letter-spacing: 3px;
}

.footer .gnav_main li a::after {
    width: 0;
    height: 3px;
    margin: auto;
    background-color: var(--primary);
    position: absolute;
    content: "";
    right: 0;
    bottom: -8px;
    left: 0;
    transition: 0.3s;
}

.footer .gnav_main li a br {
    display: none;
}

.footer .gnav_sub {
    margin: 64px 0 0;
}

.footer .gnav_sub ul {
    margin: 0;
    display: grid;
    justify-content: center;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}

.footer .gnav_sub li {
    margin: 0;
    padding: 0;
    font-size: 13px;
    font-weight: 500;
}

.footer .gnav_sub li a {
    padding: 12px;
    border: 0;
    border-radius: 9999px;
    background-color: var(--gray01);
    display: flex;
    justify-content: center;
    align-items: center;
    transition: 0.25s;
    gap: 8px;
}

.footer .gnav_sub li a span {
    padding: 0 0 0 24px;
    position: relative;
}

.footer .gnav_sub li a span:before {
    width: 16px;
    height: 16px;
    margin: auto;
    background: no-repeat center / contain;
    position: absolute;
    content: "";
    inset: 0 auto 0 0;
}

.footer .gnav_sub .li_news a span:before {
    background-image: url("../img/icon_news.png");
}

.footer .gnav_sub .li_blog a span:before {
    background-image: url("../img/icon_blog.png");
}

.footer .gnav_sub .li_access a span:before {
    background-image: url("../img/icon_access.png");
}

.footer .gnav_sub .li_document a span:before {
    background-image: url("../img/icon_document.png");
}

.footer .gnav_sub .btn-pill {
    padding: 12px;
    border: 0;
    border-radius: 9999px;
    display: flex;
    align-items: center;
    color: var(--black);
    gap: 8px;
}

.footer .gnav_sub .btn-pill:hover {
    opacity: 0.8;
}

.footer .gnav_sub .li_recruit {
    margin: 24px 0 0;
}

.footer .gnav_sub .li_contact {
    margin: 8px 0 0;
}

.footer .gnav_sub .li_recruit,
.footer .gnav_sub .li_contact {
    width: 80%;
    font-size: 16px;
    grid-column: 1 / span 2;
    justify-self: center;
}

.footer .gnav_sub .li_recruit .btn-pill {
    background: var(--secondary);
    color: var(--white);
}

.footer .gnav_sub .li_contact .btn-pill {
    background: var(--primary);
    color: var(--white);
}

.footer .gnav_sub .li_recruit .btn-pill span,
.footer .gnav_sub .li_contact .btn-pill span {
    position: relative;
}

.footer .gnav_sub .li_recruit .btn-pill span {
    padding: 0 0 0 18px;
}

.footer .gnav_sub .li_contact .btn-pill span {
    padding: 0 0 0 24px;
}

.footer .gnav_sub .li_recruit .btn-pill span:before {
    width: 10px;
    height: 20px;
    margin: auto;
    background: url("../img/icon_recruit.png") no-repeat center / contain;
    position: absolute;
    content: "";
    inset: 0 auto 0 0;
}

.footer .gnav_sub .li_contact .btn-pill span:before {
    width: 17px;
    height: 12px;
    margin: auto;
    background: url("../img/icon_contact.png") no-repeat center / contain;
    position: absolute;
    content: "";
    inset: 0 auto 0 0;
}

.footer .copyright {
    margin: 64px 0 0;
    font-size: 10px;
    font-weight: 600;
    text-align: center;
}

/*================================================================
# 中面共通スタイル
================================================================ */
/* 中面ページタイトル
------------------------------------------------------ */
.page-title {
    padding: 32px 0 0;
    text-align: center;
    letter-spacing: 0.1em;
}

.page-title .title-en {
    font-size: 13px;
    font-weight: 600;
    color: var(--primary);
}

.page-title .title-en.purple {
    color: var(--secondary);
}

.page-title .title-jp {
    margin: 8px 0 0;
    font-size: 24px;
    font-weight: 600;
}

.page-title .img {
    margin: 32px 0 0;
}

.page-title .img img {
    width: 100%;
    min-height: 200px;
    object-fit: cover;
}

/* パンくず
------------------------------------------------------ */
.bread {
    width: 100%;
    margin: 0;
    padding: 10px 15px 0;
}

.bread p {
    font-size: 12px;
}

/* 背景
------------------------------------------------------ */
.bg01,
.bg02 {
    padding: 80px 0;
    position: relative;
}

.bg02 {
    background: var(--bg02);
}

/* レイアウト
------------------------------------------------------ */
.container {
    margin: 40px 0 0;
    font-size: 15px;
}

.container.top {
    margin: 0;
}

.container .img-area {
    margin: 24px 0 0;
}

.container .img-area img+img {
    margin: 16px 0 0;
}

.container .text-area {
    margin: 24px 0 0;
}

.container .text-area p+p {
    margin: 16px 0 0;
}

.container .img {
    margin: 16px 0 0;
}

/* ギャラリー
------------------------------------------------------ */
.img-row {
    margin: 24px 0 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

.img-row>img+img,
.img-row figure+figure {
    margin: 16px 0 0;
}

.img-row.col-2>img,
.img-row.col-2 figure {
    text-align: center;
}

.img-row.col-3>img,
.img-row.col-3 figure {
    text-align: center;
}

.img-row.col-2_sp img {
    width: calc(100% / 2 - 16px);
}

.img-row.col-3_sp img {
    width: calc(100% / 3 - 16px);
}

.img-row img {
    width: 100%;
}

.img-row figure figcaption {
    margin: 4px 0 0;
    font-size: 16px;
    font-weight: 600;
    text-align: center;
}

.table01 .img-row {
    margin: 0;
}

/* カード
------------------------------------------------------ */
.card01 {
    margin: 40px auto 0;
    padding: 0;
}

.card01 .card-item {
    margin: 40px 0 0;
    padding: 0;
}

.card01 .card-item__title {
    margin: 16px 0 0;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 18px;
    font-weight: 600;
    text-align: center;
}

.card01 .card-item__text {
    margin: 16px 0 0;
    padding: 0;
    font-size: 14px;
    line-height: 2;
}

/* 見出し
------------------------------------------------------ */
.heading01 {
    position: relative;
    font-size: 24px;
    font-weight: 500;
    text-align: center;
    letter-spacing: 0.1em;
}

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

.heading01 .title-en {
    font-size: 24px;
}

.heading01 .title-jp {
    margin: 16px 0 0;
    font-size: 13px;
}

.heading01 span {
    padding: 0;
    border-bottom: 4px dotted var(--primary);
    display: inline-block;
}

.heading01.purple span {
    border-bottom: 4px dotted var(--secondary);
}

.heading02 {
    margin: 40px 0 0;
    font-size: 20px;
    font-weight: 500;
    color: var(--primary);
}

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

.heading02.top {
    margin: 0;
}

.heading03 {
    margin: 40px 0 0;
    padding: 0 0 0 16px;
    position: relative;
    font-size: 20px;
    font-weight: 500;
    text-indent: 0;
}

.heading03::before {
    width: 6px;
    height: 6px;
    border-radius: 9999px;
    background-color: var(--primary);
    position: absolute;
    content: "";
    top: 15px;
    left: 0;
}

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

.heading03.top {
    margin: 0;
}

/* ボタン
------------------------------------------------------ */
.btn01 {
    margin: 40px 0 0;
    display: flex;
    justify-content: center;
    align-items: center;
}

.btn01 a,
.btn01 input {
    min-width: 260px;
    margin: 0 auto;
    padding: 20px 24px 22px 32px;
    cursor: pointer;
    border: 2px solid var(--primary);
    border-radius: 9999px;
    background: var(--btn);
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 16px;
    font-weight: 600;
    color: var(--primary);
    text-align: center;
    text-decoration: none;
    letter-spacing: 0.1em;
    -webkit-appearance: none;
    transition: 0.3s;
}

.btn01 a::after,
.btn01 input::after {
    width: 14px;
    height: 8px;
    margin: 0 0 0 12px;
    background-image: url("data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22UTF-8%22%3F%3E%3Csvg%20id%3D%22b%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC%202%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2212.98%22%20height%3D%227.47%22%20viewBox%3D%220%200%2012.98%207.47%22%3E%20%3Cg%20id%3D%22c%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC%201%22%3E%20%3Cg%3E%20%3Cline%20x1%3D%221%22%20y1%3D%223.73%22%20x2%3D%2211.34%22%20y2%3D%223.73%22%20fill%3D%22none%22%20stroke%3D%22%23f3a68c%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%222%22%2F%3E%20%3Cpolyline%20points%3D%229.25%201%2011.98%203.73%209.25%206.47%22%20fill%3D%22none%22%20stroke%3D%22%23f3a68c%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%222%22%2F%3E%20%3C%2Fg%3E%20%3C%2Fg%3E%3C%2Fsvg%3E");
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    display: block;
    transition: 0.3s;
}

.btn02 {
    margin: 40px 0 0;
    display: flex;
    justify-content: center;
    align-items: center;
}

.btn02 a,
.btn02 input {
    margin: 0 auto;
    padding: 20px 40px 22px;
    cursor: pointer;
    border: 2px solid var(--primary);
    border-radius: 9999px;
    background: var(--primary);
    position: relative;
    display: block;
    font-size: 18px;
    font-weight: 600;
    color: var(--white);
    text-align: center;
    text-decoration: none;
    letter-spacing: 0.1em;
    -webkit-appearance: none;
    transition: 0.3s;
}

.btn02 a:hover,
.btn02 input:hover {
    background: var(--white);
    color: var(--primary);
    transform: translate(0, -4px);
}

.btn02 a:hover::before,
.btn02 input:hover::before {
    transform: translate(8px, -50%);
}

.btn02.purple a,
.btn02.purple input {
    border: 2px solid var(--secondary);
    background: var(--secondary);
}

.btn02.purple a:hover,
.btn02.purple input:hover {
    background: var(--white);
    color: var(--secondary);
}

/* テーブル
------------------------------------------------------ */
.table01 {
    width: 100%;
    margin: 32px auto 0;
    table-layout: fixed;
    border-top: 1px solid var(--table);
    border-right: 1px solid var(--table);
    border-bottom: 1px solid var(--table);
    letter-spacing: 0;
}

.table01 tr {
    display: flex;
}

.table01 th {
    width: 22%;
    padding: 12px 11px;
    border-bottom: 1px solid var(--white);
    background: var(--table);
    flex: 0 0 auto;
    font-size: 13px;
    font-weight: 600;
    text-align: left;
    vertical-align: top;
}

.table01 thead th {
    padding: 12px;
    border-radius: 20px 20px 0 0;
    background: var(--table);
    position: relative;
    font-weight: 600;
    line-height: 1.4;
    text-align: center;
    vertical-align: top;
}

.table01 thead tr th:first-child {
    width: 22%;
}

.table01 thead tr th:not(:first-child) {
    flex: 1;
}

.table01 thead th:first-child {
    background-color: transparent;
}

.table01 thead th:not(:first-child) {
    width: auto;
}

.table01 thead th:last-child::before {
    width: 1px;
    height: 80%;
    background-color: var(--white);
    position: absolute;
    content: "";
    bottom: 0;
    left: -1px;
}

.table01 td {
    padding: 12px;
    border-bottom: 1px solid var(--table);
    border-left: 1px solid var(--table);
    background: var(--white);
    flex: 1;
    font-size: 13px;
    vertical-align: top;
    white-space: normal;
    word-wrap: break-word;
    overflow-wrap: anywhere;
}

.table01 tr:last-child th,
.table01 tr:last-child td {
    border-bottom: 0;
}

.table01 td .img-area {
    margin: 0;
}

.table01 td .img-area img {
    width: 100%;
    margin: 0;
}

.table01 td .img-row>img+img,
.table01 td .img-row figure+figure {
    margin: 8px 0 0;
}

.table01 td.center {
    text-align: center;
}

.table01 td .title {
    padding: 0 0 8px;
    border-bottom: 2px dotted var(--border01);
    font-size: 14px;
    text-align: center;
}

.table01 td .title02 {
    margin: 8px 0 0;
}

.table01 td .text {
    margin: 8px 0 0;
}

.table01 td p+p {
    margin: 8px 0 0;
}

.table01 td .note {
    margin: 4px 0 0;
    display: block;
    font-size: 10px;
    line-height: 1.4;
}

.table01 td .info {
    margin: 16px 0 0;
    font-size: 14px;
    font-weight: 600;
}

.table01 td a {
    font-size: 16px;
    font-weight: 600;
    color: var(--primary);
}

.table01 td a[href^="tel:"] {
    font-size: 16px;
}

.table01 td dl {
    margin: 8px 0 0;
    font-weight: 400;
}

.table01 td dl.top {
    margin: 0;
}

.table01 td .btn01 a {
    text-decoration: none;
}

/* リスト
------------------------------------------------------ */
.list01 {
    margin: 16px 0 0;
    list-style: none;
}

.list01.top {
    margin: 0;
}

.list01 li {
    margin: 0 0 0 1em;
    font-size: 20px;
    font-weight: 600;
    text-indent: -1em;
}

.list01 li:nth-child(n + 2) {
    margin: 24px 0 0 1em;
}

.list01 .text {
    margin: 8px 0 16px;
    font-size: 16px;
    font-weight: 400;
    text-indent: 0;
}

.ul-list01 {
    margin: 24px 0 0;
    padding: 0;
    list-style: none;
}

.ul-list01.top {
    margin: 0;
}

.ul-list01 li {
    padding: 0 0 0 16px;
    position: relative;
    font-size: 16px;
    font-weight: 600;
    text-indent: 0;
}

.ul-list01 li:nth-child(n + 2) {
    margin: 8px 0 0;
}

.ul-list01 li::before {
    width: 6px;
    height: 6px;
    border-radius: 9999px;
    background-color: var(--primary);
    position: absolute;
    content: "";
    top: 10px;
    left: 2px;
}

.ul-list01 li .text {
    margin: 8px 0 0;
    font-size: 16px;
    font-weight: 400;
}

.ul-list02 {
    margin: 16px 0 0;
    padding: 0;
    list-style: none;
}

.ul-list02.top {
    margin: 0;
}

.ul-list02 li {
    padding: 0 0 0 8px;
    position: relative;
    text-indent: 0;
}

.ul-list02 li:nth-child(n + 2) {
    margin: 5px 0 0;
}

.ul-list02 li::before {
    width: 4px;
    height: 4px;
    border-radius: 9999px;
    background-color: var(--black);
    position: absolute;
    content: "";
    top: 8px;
    left: 0;
}

.ul-list02 li .text {
    margin: 8px 0 0;
    font-size: 16px;
    font-weight: 400;
}

.ol-list01 {
    margin: 24px 0 0;
    padding: 0;
    list-style-type: none;
    counter-reset: item;
}

.ol-list01.top {
    margin: 0;
}

.ol-list01 li {
    padding: 0 0 0 20px;
    position: relative;
    font-size: 14px;
    font-weight: 600;
}

.ol-list01 li:before {
    width: 16px;
    height: 16px;
    counter-increment: item;
    position: absolute;
    content: counter(item);
    top: 3px;
    left: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 12px;
    font-weight: bold;
}

.ol-list01 li:after {
    width: 16px;
    height: 16px;
    border: 1px solid var(--black);
    border-radius: 9999px;
    position: absolute;
    content: "";
    top: 3px;
    left: 0;
}

.ol-list01 li+li {
    margin: 8px 0 0;
}

.ol-list01 li .text {
    margin: 4px 0 0 0;
    font-weight: 400;
}

/* テキスト
------------------------------------------------------ */
.lead01 {
    margin: 24px 0 0;
    font-size: 15px;
    line-height: 2;
}

.lead01 p+p {
    margin: 16px 0 0;
}

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

.text01 {
    margin: 24px 0 0;
    font-size: 15px;
    line-height: 2;
}

.text01.top {
    margin: 0;
}

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

.text01.right {
    text-align: right;
}

.text01 p+p {
    margin: 16px 0 0;
}

.text-link {
    position: relative;
    display: inline-block;
    font-weight: 600;
    color: var(--black);
}

.text-link:before {
    width: 100%;
    height: 2px;
    border-radius: 9999px;
    background-color: var(--primary);
    position: absolute;
    content: "";
    bottom: 0px;
    left: 0;
    transition: transform 0.3s ease;
    transform: scaleX(1);
    transform-origin: left center;
}

.note {
    margin: 8px 0 0;
    font-size: 12px;
}

.info {
    color: var(--primary);
}

/* セクション・ユニット
------------------------------------------------------ */
.section+.section {
    margin: 40px 0 0;
}

.unit+.unit {
    margin: 40px 0 0;
}

/* アコーディオン
------------------------------------------------------ */
.accordion-header {
    width: 200px;
    height: 48px;
    margin: 40px auto 0;
    padding: 0 0 2px;
    cursor: pointer;
    user-select: none;
    border-radius: 8px;
    background: var(--primary);
    display: flex;
    justify-content: center;
    align-items: center;
    font-weight: 600;
    color: var(--white);
    text-align: center;
    -webkit-appearance: none;
}

.accordion-content {
    max-height: 0;
    margin: 40px 0 -40px;
    padding: 0 10px;
    overflow: hidden;
    transition: 0.3s ease-out;
}

.accordion-content.open {
    max-height: 1000px;
    margin: 40px 0 0;
}

.accordion-content .section:first-child,
.accordion-content .section:first-child .heading02 {
    margin: 0;
}

/*================================================================
# トップページ
================================================================ */
/* mv
------------------------------------------------------ */
.mv {
    width: 100%;
    padding: 80px 0 0;
    background: var(--bg02);
}

.mv__inner {
    width: 100%;
    margin: 0 auto;
    padding: 16px 8px;
}

.js-mv-fade {
    width: 100%;
    margin: 0;
    padding: 0;
}

.js-mv-fade .splide__track {
    margin: 0;
    padding: 0;
}

.js-mv-fade .splide__slide {
    margin: 0;
    padding: 0;
}

.js-mv-fade .splide__slide img {
    width: 100%;
    display: block;
    object-fit: cover;
}

.js-mv-fade .splide__pagination {
    display: none;
}

/* よくあるご質問
------------------------------------------------------ */
.faq .text01 {
    margin: 8px 0 0 2.8em;
    font-weight: 500;
    line-height: 1.618;
    text-indent: -1.6em;
}

.faq .text01::first-letter {
    font-size: 24px;
}

/*================================================================
# お問い合わせ
================================================================ */
.contact .tel {
    margin: 8px 0 0;
    text-align: center;
}

.contact .tel a {
    display: inline-block;
    font-size: 32px;
    font-weight: 500;
    letter-spacing: 0;
}

.contact .tel a span {
    margin: 0 4px 0 0;
    font-size: 16px;
}

.contact .time {
    margin: 8px 0 0;
    text-align: center;
}

.contact-table {
    max-width: 559px;
    margin: 0 auto 30px;
}

.contact-table p {
    margin: 0 0 20px;
    font-size: 14px;
}

.contact-table .table01 th {
    position: relative;
}

.contact-table .table01 td ul {
    display: flex;
    flex-wrap: wrap;
}

.contact-table .icon_h {
    padding: 4px 8px;
    border-radius: 9999px;
    background: var(--primary);
    display: inline-block;
    font-size: 72%;
    line-height: 1;
    color: var(--white);
    align-self: start;
}

.contact-page .box_privacy {
    margin: 0 auto;
}

.contact-page .box_privacy p {
    margin: 0 0 16px;
    font-size: 108%;
}

.contact-page .section-privacy {
    margin: 64px auto 0;
}

.contact-page .section-privacy .privacy-box {
    margin: 24px 0 0;
    font-size: 12px;
}

.contact-page .section-privacy .privacy-box .title {
    margin: 24px 0 0;
    font-weight: 600;
}

.contact-page .section-privacy .privacy-box p {
    margin: 4px 0 0;
}

/*-----------
form
------------*/
::placeholder {
    color: var(--gray);
}

.contact-table select,
.contact-table input,
.contact-table textarea,
.contact-table button,
.contact-table option {
    font-family: "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", "Meiryo", sans-serif;
}

.contact-table input,
.contact-table textarea {
    width: 100%;
    padding: 12px;
    border: 1px solid var(--gray);
    border-radius: 8px;
    background: #f1f1f1;
    box-sizing: border-box;
    -webkit-appearance: none;
    transition: all 0.5s;
}

.contact-table input:focus,
.contact-table textarea:focus {
    border: 1px solid var(--gray);
    outline: 0;
    background: #f1f1f1;
}

.contact-table input:focus::placeholder,
.contact-table textarea:focus::placeholder {
    color: var(--gray);
}

.select-wrap {
    width: 100%;
    border: 1px solid var(--gray);
    border-radius: 8px;
    background: #f1f1f1;
    position: relative;
    overflow: hidden;
    box-sizing: border-box;
    -webkit-appearance: none;
    transition: all 0.5s;
}

.select-wrap::before {
    width: 6px;
    height: 6px;
    margin-top: -4px;
    border: 0;
    border-right: solid 2px #666;
    border-bottom: solid 2px #666;
    position: absolute;
    content: "";
    top: 50%;
    right: 15px;
    transform: rotate(45deg);
}

.select-wrap select {
    width: 100%;
    padding: 12px;
    cursor: pointer;
    border: none;
    outline: none;
    background: transparent;
    box-shadow: none;
    text-indent: 0.01px;
    text-overflow: ellipsis;
    -webkit-appearance: none;
    appearance: none;
}

.select-wrap select::-ms-expand {
    display: none;
}

/* チェックボックス */
input[type="checkbox"] {
    display: none;
}

.checkbox {
    width: auto;
    padding: 0.5rem 3rem;
    cursor: pointer;
    position: relative;
    display: inline-block;
    box-sizing: border-box;
}

.checkbox::before {
    width: 1.6rem;
    height: 1.6rem;
    margin-top: -0.8rem;
    border: 1px solid #ccc;
    border-radius: 0.3rem;
    background: #fff;
    position: absolute;
    content: "";
    top: 50%;
    left: 0.5rem;
    display: block;
}

.checkbox::after {
    width: 0.9rem;
    height: 2rem;
    margin-top: -1.6rem;
    opacity: 0;
    border-right: 0.4rem solid var(--blue);
    border-bottom: 0.4rem solid var(--blue);
    position: absolute;
    content: "";
    top: 50%;
    left: 1rem;
    display: block;
    transition: transform 0.2s ease-in-out, opacity 0.2s ease-in-out;
    transform: rotate(45deg) translate3d(0, 2px, 0) scale3d(0.7, 0.7, 1);
}

input[type="checkbox"]:checked+.checkbox::before {
    border-color: #666;
}

input[type="checkbox"]:checked+.checkbox::after {
    opacity: 1;
    transform: rotate(45deg) scale3d(1, 1, 1);
}

/* ラジオボタン */
input[type="radio"] {
    display: none;
}

.radio-btn {
    width: auto;
    padding: 5px 30px;
    cursor: pointer;
    position: relative;
    display: inline-block;
    box-sizing: border-box;
}

.radio-btn::before {
    width: 16px;
    height: 16px;
    margin-top: -8px;
    border: 1px solid #ccc;
    border-radius: 50%;
    background: #fff;
    position: absolute;
    content: "";
    top: 50%;
    left: 5px;
    display: block;
}

.radio-btn::after {
    width: 10px;
    height: 10px;
    margin-top: -4px;
    opacity: 0;
    border-radius: 50%;
    background: var(--black);
    position: absolute;
    content: "";
    top: calc(50% - 1px);
    left: 8px;
    display: block;
    transition: transform 0.2s ease-in-out, opacity 0.2s ease-in-out;
    transform: scale3d(0.3, 0.3, 1);
}

input[type="radio"]:checked+.radio-btn::before {
    border-color: #666;
}

input[type="radio"]:checked+.radio-btn::after {
    opacity: 1;
    transform: scale3d(1, 1, 1);
}

.kojin-checkbox {
    margin-top: 20px;
    font-weight: bold;
    text-align: center;
}

.kojin-checkbox label {
    padding: 0.5rem 4.4rem 0.5rem 3rem;
    font-size: 18px;
    font-weight: bold;
    text-align: center;
}

.kojin-checkbox input {
    margin: 0 10px 0 0;
}

.submit-btn {
    width: 100%;
    margin: 40px auto 0;
}

.submit-btn input {
    width: 80%;
    height: 64px;
    margin: auto;
    padding: 0 0 4px;
    border-radius: 9999px;
    background: var(--primary);
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 18px;
    font-weight: 600;
    color: var(--white);
    text-align: center;
    text-decoration: none;
    box-sizing: border-box;
    -webkit-appearance: none;
    transition: all 0.3s ease;
}

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

LINEトップ

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

.ban_line {
    width: 100%;
    background: #BBBCDE;
    position: fixed;
    right: 0;
    bottom: 0;
    z-index: 999;
}

.ban_line img {
    width: 100%;
    max-width: 280px;
    margin: 0 auto;
    padding: 5px 0;
    display: block;
}

