@charset "utf-8";

/*================================================================
# 全ページ共通スタイル
================================================================ */
/* ヘッダー
------------------------------------------------------ */
.header {
    width: 100%;
    height: 56px;
    margin: 0 auto;
    padding: 0 12px;
    background: var(--footer);
    display: flex;
    align-items: flex-end;
}

.header .container {
    margin: 0;
}

.header .left h1 {
    margin: 0;
    padding: 0;
}

.header .left h1 a {
    display: block;
}

.header .left h1 a img {
    width: auto;
    height: 48px;
    object-fit: contain;
}

.header .right {
    display: none;
}

.header .gnav_main {
    display: none;
}

.nav-toggle {
    width: 56px;
    height: 56px;
    cursor: pointer;
    background-color: var(--primary);
    position: fixed;
    top: 0;
    right: 0;
    z-index: 9999;
}

.nav-toggle:before {
    width: 100%;
    height: 1em;
    margin: auto;
    position: absolute;
    content: "MENU";
    right: 0;
    bottom: 12px;
    left: 0;
    font-size: 10px;
    color: var(--white);
    text-align: center;
    letter-spacing: 0;
}

.nav-toggle span {
    width: 50%;
    height: 2px;
    background-color: var(--white);
    position: absolute;
    left: 13px;
    display: inline-block;
    transition: all 0.4s;
}

.nav-toggle span:nth-of-type(1) {
    top: 14px;
}

.nav-toggle span:nth-of-type(2) {
    top: 22px;
}

.nav-toggle span:nth-of-type(3) {
    top: 30px;
}

.nav-toggle.active:before {
    content: "CLOSE";
}

.nav-toggle.active span:nth-of-type(1) {
    width: 50%;
    top: 14px;
    left: 13px;
    transform: translateY(6px) rotate(-45deg);
}

.nav-toggle.active span:nth-of-type(2) {
    opacity: 0;
}

.nav-toggle.active span:nth-of-type(3) {
    width: 50%;
    top: 26px;
    left: 13px;
    transform: translateY(-6px) rotate(45deg);
}

/* gnav_sp
------------------------------------------------------ */
.gnav_sp {
    width: 100%;
    height: 100dvh;
    opacity: 0;
    background: var(--white);
    position: fixed;
    top: 0;
    right: -100%;
    bottom: 0;
    overflow-y: scroll;
    z-index: 9;
    transition: all 0.5s;
    -webkit-overflow-scrolling: touch;
}

.gnav_sp.panelactive {
    opacity: 1;
    right: 0;
    z-index: 999;
}

.gnav_sp.panelactive .gnav-list_sp {
    width: 100%;
    height: 100%;
    padding: 56px 0;
    position: fixed;
    overflow: auto;
    z-index: 999;
    -webkit-overflow-scrolling: touch;
}

.gnav_sp .primary {
    padding: 0 24px;
}

.gnav_sp .primary li a {
    width: 100%;
    padding: 16px 24px 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;
}

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

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

.gnav_sp .primary li a br {
    display: none;
}

.gnav_sp .secondary {
    margin: 40px 0 0;
    padding: 0 24px;
    display: grid;
    justify-content: center;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}

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

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

.gnav_sp .secondary li a span {
    padding: 0 0 0 24px;
    position: relative;
}

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

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

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

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

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

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

.gnav_sp .secondary .btn-pill:hover {
    opacity: 0.8;
}

.gnav_sp .secondary .li_recruit,
.gnav_sp .secondary .li_contact {
    width: 50%;
    margin: 24px 0 0;
    font-size: 16px;
    grid-column: 1 / span 2;
    justify-self: center;
}

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

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

.gnav_sp .secondary .li_recruit .btn-pill span,
.gnav_sp .secondary .li_contact .btn-pill span {
    position: relative;
}

.gnav_sp .secondary .li_recruit .btn-pill span {
    padding: 0 0 0 18px;
}

.gnav_sp .secondary .li_contact .btn-pill span {
    padding: 0 0 0 24px;
}

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

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

.gnav-footer_sp {
    margin: 64px 0 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    font-size: 14px;
    text-align: center;
}

.gnav-footer_sp h1 {
    margin: auto;
}

.gnav-footer_sp h1 a {
    display: block;
}

.gnav-footer_sp h1 img {
    width: 120px;
}

.gnav-footer_sp .address {
    width: 100%;
    margin: 16px 0 0;
}

.gnav-footer_sp .tel {
    width: 220px;
    margin: 16px auto 0;
}

.gnav-footer_sp .contact {
    width: 100%;
    margin: 16px auto 0;
}

.gnav-footer_sp .contact a {
    width: 240px;
    margin: auto;
    display: block;
    text-align: center;
}

.gnav-footer_sp .contact img {
    width: 240px;
}

.gnav-footer_sp .copyright {
    width: 100%;
    margin: 40px 0 0;
    opacity: 0.7;
    font-size: 10px;
}

/* ページトップ
------------------------------------------------------ */
.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: 500;
}

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

/* 背景
------------------------------------------------------ */
.contents-wrap>div:first-child {
    padding: 40px 0 80px;
}

.contents-wrap>div:last-child {
    padding: 80px 0 0;
}

.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: 500;
    text-align: center;
}

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

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

.card01 .card-item {
    margin: 0 0 28px;
    padding: 0;
    border-radius: 16px;
    background: var(--bg04);
}

.card01 .card-inner {
    margin: 0;
    padding: 36px;
}

.card01 .card-title {
    margin: 0;
    padding: 0;
    position: relative;
    display: inline-block;
    font-size: 20px;
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.02em;
}

.card01 .card-title .dot {
    width: 8px;
    height: 8px;
    margin: 0 10px 0 0;
    padding: 0;
    border-radius: 9999px;
    background: var(--primary);
    display: inline-block;
    transform: translateY(-4px);
}

.card01 .card-body {
    margin: 0;
    padding: 0;
    letter-spacing: 0;
}

.card01 .info {
    margin: 24px 0 0;
    padding: 0;
    display: flex;
}

.card01 .info:nth-child(n + 2) {
    margin: 8px 0 0;
}

.card01 .info dt {
    margin: 0;
    padding: 0;
    flex: 0 0 auto;
    font-size: 16px;
    font-weight: 500;
}

.card01 .info dd {
    margin: 0;
    padding: 0;
    font-size: 16px;
    font-weight: 500;
}

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

/* 見出し
------------------------------------------------------ */
.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: 13px;
    color: var(--primary);
}

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

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

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

.heading02 {
    margin: 40px 0 0;
    font-size: 22px;
    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: 500;
    text-align: left;
    vertical-align: top;
}

.table01 thead th {
    padding: 12px;
    border-radius: 20px 20px 0 0;
    background: var(--table);
    position: relative;
    font-weight: 500;
    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: 500;
}

.table01 td a {
    font-weight: 500;
    color: var(--primary);
    text-decoration: underline;
}

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

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

.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: 500;
    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 {
    font-weight: 500;
    color: var(--black);
    text-decoration: underline;
}

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

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

/* セクション・ユニット
------------------------------------------------------ */
.section+.section {
    margin: 64px 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 {
    margin: 0;
    padding: 0;
    background: var(--bg02);
}

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

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

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

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

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

/* お知らせ
------------------------------------------------------ */
.top-page .news {
    padding: 0 0 80px;
}

.top-page .news .wrap {
    max-width: 840px;
    position: relative;
}

.top-page .news .wrap:before {
    width: calc(248px / 2);
    height: calc(239px / 2);
    background: url(../img/top_illust01.png) no-repeat center top / contain;
    position: absolute;
    content: "";
    top: -64px;
    left: -40px;
}

.top-page .news .container {
    margin: 0;
}

.top-page .news h1 {
    font-size: 24px;
    color: var(--primary);
    text-align: center;
}

.top-page .news .news-list {
    margin: 24px 0 0;
    padding: 0;
}

.top-page .news .news-list .list-item {
    margin: 0;
    border-bottom: 2px dotted var(--white);
}

.top-page .news .news-list .link {
    width: 100%;
    padding: 16px 0;
    display: flex;
    font-weight: 500;
}

.top-page .news .news-list .day {
    margin: 0 24px 0 0;
    display: block;
    font-size: 14px;
}

.top-page .news .news-list .text {
    font-size: 14px;
    color: var(--primary);
}

/* ご紹介
------------------------------------------------------ */
.top-page .introduction .top_illust02 {
    width: calc(311px / 2);
    position: absolute;
    top: -20px;
    left: -40px;
}

.top-page .introduction .top_illust03 {
    width: calc(311px / 2);
    position: absolute;
    top: -56px;
    right: -40px;
}

.top-page .introduction .introduction-list {
    margin: 40px 0 0;
    padding: 0;
    list-style: none;
}

.top-page .introduction .introduction-list .list-item {
    margin: 40px 0 0;
}

.top-page .introduction .introduction-list .link {
    margin: 0;
    padding: 0;
    display: block;
    transition: 0.3s;
}

.top-page .introduction .introduction-list .link__text {
    width: 232px;
    height: 56px;
    margin: 0;
    border-radius: 0 9999px 9999px 0;
    background-color: var(--primary);
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    font-size: 18px;
    font-weight: 600;
    line-height: 1.2;
    color: var(--white);
    text-align: center;
}

.top-page .introduction .introduction-list .link__text small {
    display: block;
    font-size: 13px;
}

.top-page .introduction .introduction-list .link__img {
    margin: -30px 0 0;
}

.top-page .introduction .introduction-list .link__img img {
    width: 100%;
    height: 280px;
    border-radius: 20px;
    display: block;
    object-fit: cover;
    transition: 0.3s;
}

.top-page .introduction .introduction-list .link__btn {
    width: 180px;
    height: 56px;
    margin: -56px 0 0 auto;
    padding: 0;
    border: 0;
    border-radius: 20px 0 20px 0;
    background: var(--white);
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 14px;
    font-weight: 600;
    transition: 0.3s;
    gap: 8px;
}

.top-page .introduction .introduction-list .link__btn:after {
    width: 14px;
    height: 8px;
    background: url("../img/icon_arrow.png") no-repeat 50% 50% / contain;
    content: "";
}

/* 採用バナー
------------------------------------------------------ */
.top-page .recruit {
    padding: 40px 0 0;
}

.top-page .recruit__panel {
    margin: 0;
    padding: 64px 24px;
    border-radius: 28px;
    background: var(--primary);
    position: relative;
    display: grid;
    align-items: center;
    color: var(--white);
}

.top-page .recruit__left {
    margin: 0;
    padding: 0;
    position: relative;
    display: flex;
}

.top-page .recruit__ph {
    margin: 0;
    padding: 0;
}

.top-page .recruit__ph--main {
    width: 55%;
    margin: 0 0 16px;
}

.top-page .recruit__ph--sub {
    width: 45%;
    margin: auto 0 0 8px;
}

.top-page .recruit__right {
    margin: 0;
    padding: 0;
}

.top-page .recruit .heading01 {
    text-align: left;
}

.top-page .recruit .heading01 .title-en {
    color: var(--white);
}

.top-page .recruit .heading01 span {
    border-bottom: 4px dotted var(--white);
}

.top-page .recruit__lead {
    margin: 20px 0 32px;
    padding: 0;
    font-size: 16px;
    font-weight: 600;
    line-height: 2;
    color: var(--white);
    letter-spacing: 0.03em;
}

.top-page .recruit .btn01 a {
    margin: 0;
}

.top-page .recruit__illust {
    position: absolute;
}

.top-page .top_illust04 {
    width: calc(282px / 2);
    bottom: -15px;
    left: -33px;
}

.top-page .top_illust05 {
    width: calc(305px / 2);
    top: -63px;
    right: -7px;
}

/* バナー
------------------------------------------------------ */
.top-page .ban {
    padding: 80px 0 0;
}

.top-page .ban-list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0;
}

.top-page .ban-list .list-item {
    display: flex;
    justify-content: center;
    align-items: center;
}

.top-page .ban-list .list-item:first-child {
    grid-column: 1 / span 2;
    justify-self: center;
}

.top-page .ban-list .link {
    width: 160px;
    height: 160px;
    margin: 0;
    padding: 24px 16px;
    border: 3px solid var(--primary);
    border-radius: 9999px;
    background: var(--white);
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    font-size: 15px;
    font-weight: 600;
    color: var(--black);
    text-align: center;
    letter-spacing: 0;
    transition: background-color 0.3s ease, transform 0.3s ease;
    gap: 12px;
}

.top-page .ban-list .text {
    font-size: 18px;
}

.top-page .ban-list .icon img {
    width: 36px;
    height: 36px;
    object-fit: contain;
}

/*================================================================
# 園の紹介
================================================================ */
.about-page .about_img09 {
    width: 80%;
    margin: auto;
    text-align: center;
}

/*================================================================
# はすがおか幼稚園（幼児部）
================================================================ */
.kindergarten-page .azukari .table01 .dl01 dt {
    font-weight: 600;
}

.kindergarten-page .azukari .table01 .dl02 dt {
    font-weight: 600;
}

/*================================================================
# 一日の流れ
================================================================ */
.schedule-page .schedule {
    padding: 80px 0 100px;
    overflow: hidden;
}

.schedule-page .schedule .list {
    position: relative;
}

.schedule-page .schedule .list::before {
    width: 2px;
    padding-bottom: 5px;
    background-image: linear-gradient(to top, var(--border01) 4px, transparent 4px);
    background-repeat: repeat-y;
    background-position: left bottom;
    background-size: 2px 10px;
    position: absolute;
    content: "";
    top: 30px;
    bottom: 30px;
    left: 36px;
}

.schedule-page .schedule .item {
    min-height: 80px;
    margin: 24px 0 0;
    padding: 0 0 0 88px;
    position: relative;
    display: block;
    z-index: 0;
}

.schedule-page .schedule .time {
    width: 72px;
    height: 72px;
    background: url(../img/schedule_time.png) no-repeat center top / contain;
    position: absolute;
    top: 0;
    left: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    font-weight: 600;
    color: var(--white);
}

.schedule-page .schedule .title {
    padding: 20px 0 0;
    font-size: 18px;
    font-weight: 500;
    letter-spacing: 0.08em;
}

.schedule-page .schedule .text {
    margin: 16px 0 0;
    font-size: 15px;
    line-height: 2;
    letter-spacing: 0.03em;
}

.schedule-page .schedule .box {
    margin: 16px 0 0;
    padding: 24px;
    background-color: var(--bg04);
    position: relative;
    z-index: 0;
}

.schedule-page .schedule .img-area {
    width: 100%;
}

.schedule-page .schedule .text-area {
    width: 100%;
    margin: 16px 0 0;
}

.schedule-page .schedule .box-title {
    margin: 16px 0 0;
    font-size: 20px;
    font-weight: 500;
    color: var(--primary);
    letter-spacing: 0.04em;
}

.schedule-page .schedule .box-text {
    margin: 5px 0 0;
    font-size: 15px;
    font-weight: 500;
    line-height: 27px;
    letter-spacing: 0.03em;
}

.schedule-page .schedule .img {
    margin: 24px 0 0;
}

.schedule-page .schedule .item:last-child .img {
    display: flex;
    justify-content: flex-end;
}

.schedule-page .schedule .img img {
    width: 60%;
    border-radius: 9999px;
    object-fit: cover;
}

/*================================================================
# 年間行事
================================================================ */
.event-page .calendar {
    padding: 0 0 64px;
}

.event-page .cards {
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

.event-page .cards .card-item {
    width: 100%;
    margin: 40px 0 0;
    border-radius: 10px;
    background-color: var(--bg04);
}

.event-page .cards .card-item .img-area {
    margin: 0;
}

.event-slider .splide__slide img,
.event-slider__static img {
    width: 100%;
    height: auto;
    display: block;
}

.event-slider:not(.is-initialized) .splide__track {
    overflow: visible;
}

.event-slider:not(.is-initialized) .splide__list {
    display: block;
}

.event-slider:not(.is-initialized) .splide__slide {
    width: auto;
}

.event-page .cards .card-item .text-area {
    margin: 0;
    padding: 32px;
    position: relative;
}

.event-page .cards .card-item .text-area:before {
    width: 100px;
    height: 100px;
    margin: auto;
    border-radius: 9999px;
    background-color: var(--bg04);
    position: absolute;
    content: "";
    top: -32px;
    right: 0;
    left: 0;
    display: block;
    z-index: 0;
}

.event-page .cards .card-item .text-area .card__title {
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    font-size: 32px;
    font-weight: 600;
    text-align: center;
}

.event-page .cards .card-item .text-area .card__title span {
    margin: 0 0 0 4px;
    font-size: 16px;
}

.event-page .cards .card-item .text-area .card__text {
    margin: 24px 0 0;
}

.event-page .cards .card-item .text-area .card__text ul li {
    padding: 0 0 0 13px;
    list-style: none;
    position: relative;
    font-weight: bold;
}

.event-page .cards .card-item .text-area .card__text ul li+li {
    margin: 4px 0 0;
}

.event-page .cards .card-item .text-area .card__text ul li:before {
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: var(--primary);
    position: absolute;
    content: "";
    top: 0.7em;
    left: 0;
    display: inline-block;
}

.event-page .cards .card-item .text-area .card__text ul li span {
    margin: 4px 0 8px;
    font-size: 12px;
    font-weight: 400;
}

/* ticker
------------------------------------------------------ */
.ticker {
    margin: 40px 0 0;
    overflow: hidden;
}

.ticker-splide .splide__list {
    will-change: transform;
}

.ticker-splide .splide__slide {
    width: auto;
}

.ticker-splide img {
    width: 320px;
    height: auto;
    display: block;
}

.ticker-splide .splide__arrows,
.ticker-splide .splide__pagination {
    display: none;
}

/*================================================================
# プティ・エコール（乳児部）
================================================================ */
.nursery-page .facility-introduction .container {
    margin: 0;
}

.nursery-page .facility-introduction .container .img-area {
    margin: 16px 0 0;
}

/*================================================================
# 入園案内・子育て支援
================================================================ */
.guide-page div.anchor-button {
    padding: 32px 0 0;
}

.guide-page .anchor-button .btn02 a {
    width: 100%;
}

.guide-page .admission-information .contact__panel {
    margin: 40px 0 0;
    padding: 0 24px;
    border-radius: 20px;
    background: var(--bg04);
}

.guide-page .admission-information .contact__panel .contact__cols {
    width: 100%;
    margin: 0 auto;
    padding: 0;
    position: relative;
}

.guide-page .admission-information .contact__panel .contact__cols::before {
    width: 100%;
    height: 4px;
    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: absolute;
    content: "";
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.guide-page .admission-information .contact__panel .contact__col {
    padding: 40px 0;
    text-align: center;
}

.guide-page .admission-information .contact__panel .contact__name {
    font-size: 20px;
    font-weight: 500;
}

.guide-page .admission-information .contact__panel .contact__name small {
    display: block;
    font-size: 16px;
    font-weight: 500;
}

.guide-page .admission-information .contact__panel .contact__tel {
    font-size: 16px;
    letter-spacing: 0.06em;
}

.guide-page .admission-information .contact__panel .contact__tel a {
    display: inline-block;
    font-size: 32px;
    font-weight: 500;
    text-decoration: none;
}

.guide-page .child-rearing-support .anchor-button .container {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}

.guide-page .child-rearing-support .anchor-button .container .btn02 {
    margin: 0;
}

.guide-page .child-rearing-support .anchor-button .container .btn02 a {
    width: 100%;
    height: 64px;
    padding: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 14px;
}

.guide-page .kindergarten {
    padding: 0 0 100px;
}

#anchor01,
#anchor02,
#anchor03,
#anchor04,
#anchor05,
#anchor06 {
    padding: 0;
}

.temporary-care {
    padding: 80px 0 0;
}

/*================================================================
# お知らせ
================================================================ */
.news-page .news,
.blog-page .blog {
    margin: 0 auto;
    position: relative;
}

.news-page .news .news-list,
.blog-page .blog .blog-list {
    margin: 40px 0 0;
    padding: 0;
}

.news-page .news .news-list .list-item,
.blog-page .blog .blog-list .list-item {
    margin: 0;
    border-bottom: 2px dotted var(--border01);
}

.news-page .news .news-list .link,
.blog-page .blog .blog-list .link {
    width: 100%;
    padding: 24px 0;
    display: flex;
    flex-wrap: wrap;
}

.news-page .news .news-list .day,
.blog-page .blog .blog-list .day {
    width: 100%;
    margin: 0;
    font-size: 14px;
    font-weight: 500;
}

.news-page .news .news-list .text,
.blog-page .blog .blog-list .text {
    width: 100%;
    margin: 8px 0 0;
    font-size: 14px;
    font-weight: 500;
    color: var(--primary);
}

.wp-pagenavi {
    margin: 40px 0 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

.wp-pagenavi .pages {
    height: 33px;
    margin: 2px;
    padding: 3px 24px;
    border-radius: 9999px;
    background-color: var(--bg04);
    display: flex;
    justify-content: center;
    align-items: center;
    text-decoration: none;
}

.wp-pagenavi a {
    width: 33px;
    height: 33px;
    margin: 2px;
    padding: 3px 5px;
    border: 1px solid var(--primary);
    border-radius: 9999px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-weight: 600;
    color: var(--primary);
    text-decoration: none;
}

.wp-pagenavi .current {
    width: 33px;
    height: 33px;
    margin: 2px;
    padding: 3px 5px;
    border: 0;
    border-radius: 9999px;
    background: var(--primary);
    display: flex;
    justify-content: center;
    align-items: center;
    color: var(--white);
    text-decoration: none;
}

.wp-pagenavi a:hover {
    background: var(--btn-hover);
}

/*================================================================
# お知らせ - 詳細
================================================================ */
.post {
    margin: 0 auto;
    position: relative;
}

.post .post__title {
    margin: 0;
    padding: 16px 24px;
    border-left: 4px solid var(--primary);
    background-color: var(--gray01);
    font-size: 24px;
    font-weight: 600;
}

.post .post__text {
    margin: 40px 0 0;
}

/*================================================================
# 交通案内
================================================================ */
.gmap {
    margin: 24px 0 0;
    padding-bottom: 120%;
    border: 10px solid var(--primary);
}

/*================================================================
# お問い合わせ
================================================================ */
.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;
}

