@charset "utf-8";

/* ========== 変数 ========== */
:root {
    --_color-text: #202124;
    --font-family: sans-serif;
    --_global--background-color: #ffffff;
    --_global--transition-duration: .4s;
    --font-size_m: 1.125rem;
    --font-size_l: 1.5rem;
    --font-size_xl: clamp(1.375rem, calc(1.0535714285714286rem + 1.607142857142857vw), 2.5rem);
}

/* ========== 基本設定 ========== */
ul {
    padding-left: 0;
}

li {
    list-style: none;
}

.p_rel {
    position: relative;
}

.inline_b {
    display: inline-block;
}

.pc_none {
    display: none;
}

h3:where(.wp-block-heading) {
    font-size: var(--font-size_l);
}

/* ========== 共通設定 ========== */
body {
    font-feature-settings: "palt";
}

/* 見出し */
.section_heading {
    gap: 0.25rem;
}

.section_heading__sub {
    color: var(--accent-color);
    font-size: 0.875rem;
    font-weight: 700;
    padding-inline: 0.5rem;
    border: solid 2px currentColor;
    border-radius: 1000px;
    background-color: var(--_global--background-color);
}

.section_heading__main {
    font-size: 2.5rem;
}

/* テーブル */
table,
tbody {
    display: block;
    width: 100%;
}

.wp-block-table tr {
    display: flex;
    flex-wrap: wrap;
}

.wp-block-table tr td {
    display: block;
    padding-block: var(--_padding1);
    padding-inline: var(--_padding-1);
}

.wp-block-table tr td:first-child {
    width: 30%;
    font-weight: 500;
    vertical-align: middle;
    background-color: var(--sub-accent-color);
}

.wp-block-table tr td:last-child {
    width: 70%;
}

.wp-block-table a[href^="tel:"] {
    color: inherit;
    text-decoration: none;
    pointer-events: none;
}

/* 投稿 */
.c-meta__item--author,
.c-meta__item--modified {
    display: none;
}

.c-entry-summary__term {
    font-size: 0.875rem !important;
}

.c-entries--simple,
.c-entries--text,
.c-entries--text2 {
    border-color: var(--light-accent-color);
}

.c-entries--simple .c-entries__item,
.c-entries--text .c-entries__item,
.c-entries--text2 .c-entries__item {
    border-color: var(--light-accent-color);
}

/* ヘッダー */
/* ロゴ */
header .l-1row-header__branding {
    padding-block: 0;
}

header .c-site-branding__title {
    line-height: 1;
}

header .c-site-branding__title>a.custom-logo-link {
    display: block;
    width: clamp(172px, calc(129.71428571428572px + 13.214285714285715vw), 320px);
}

header .c-site-branding__title>a.custom-logo-link>img {
    width: 100%;
}

/* グローバルナビ */
.p-global-nav {
    background-color: #ffffff7d;
    backdrop-filter: blur(10px);
    border-radius: 1000px;
    padding-inline: 1.25rem;
    margin-top: 12px;
}

.p-global-nav .c-navbar__item>a {
    color: var(--accent-color);
    padding-inline: var(--_padding-2);
}

.p-global-nav .c-navbar__item>a>span {
    gap: 0.25rem;
}

/* ハンバーガーボタン */
.c-hamburger-btn {
    background-color: #ffffff7d;
    backdrop-filter: blur(10px);
    width: 3rem;
    aspect-ratio: 1;
    border-radius: 50%;
}

.l-header .c-hamburger-btn__bar {
    background-color: var(--accent-color);
    height: 2px;
    border-radius: 100px;
}

.c-hamburger-btn__label {
    color: var(--accent-color);
    font-family: inherit;
    font-weight: 500;
}

/* ドロワー */
#drawer-nav {
    padding-top: 64px;
    font-weight: 500;
}

.sp_nav__cta a {
    color: var(--accent-color);
    background-color: #fff;
    padding-block: var(--_padding-2);
    padding-inline: var(--_padding-2);
    border-radius: 4px;
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

/* フッター */
.l-footer {
    color: #fff;
    background-color: var(--accent-color);
    border: none;
}

[data-is-slim-widget-area=true] .c-widget {
    font-size: inherit;
    font-weight: 700;
}

.l-footer .c-row>.c-row__col {
    margin-bottom: 0;
}

#menu-footer {
    display: flex;
    flex-wrap: wrap;
    gap: var(--_padding-1) var(--_margin1);
}

#menu-footer li+li {
    margin-top: 0;
}

.footer_sns .wp-social-link-instagram {
    background-color: transparent;
}

.footer_sns .wp-block-social-link-anchor {
    padding: 0;
}

.c-copyright--inverse {
    font-size: 0.625rem;
    background-color: transparent;
    padding-block: 10px;
}

/* ========== アニメーション ========== */
.LoopText {
    overflow: hidden;
}

.LoopText__wrap {
    animation: LoopText var(--LoopText-duration) linear infinite;
}

.LoopText p {
    display: inline-block;
    white-space: nowrap;
}

@keyframes LoopText {
    0% {
        transform: translateX(0%);
    }

    100% {
        transform: translateX(-100%);
    }
}

/* ========== パターン ========== */
/* pattern_cta */
.pattern_cta {
    color: #fff;
    background-color: var(--accent-color);
    border-radius: 40px 40px 0 0;
}

.pattern_cta__column {
    max-width: 960px;
}

.pattern_cta__btns .smb-btn {
    font-size: var(--font-size_m);
    font-weight: 700;
    color: var(--accent-color);
    background-color: #fff;
    padding-block: var(--_padding-1);
}

/* pattern_message */
.pattern_message__copy {
    font-size: var(--font-size_l);
    font-weight: 700;
}

.pattern_message__image img {
    border-radius: 4px;
}

/* ========== HOME ========== */
/* home_hero */
.home_hero {
    padding-top: 0;
}

.home_hero__image img {
    aspect-ratio: 16 / 9;
    object-fit: cover;
    max-height: 100svh;
    border-radius: 0 0 40px 40px;
}

.home_hero__copy {
    color: #fff;
    font-weight: 700;
    text-shadow: 0 0 10px rgb(0 0 0 / 25%);
    position: absolute;
    left: 5%;
    bottom: 5%;
}

.home_hero__main-copy {
    font-size: clamp(2.75rem, calc(1.8214285714285714rem + 4.642857142857143vw), 6rem);
    letter-spacing: 0.1em;
    line-height: 1.25;
}

.home_hero__main-copy>span {
    display: inline-block;
}

.home_hero__main-copy .is-style-small {
    font-size: 0.375em;
    letter-spacing: 0.1em;
    margin-right: 0.5rem;
}

.home_hero__sub-copy {
    font-size: clamp(0.875rem, calc(0.7321428571428572rem + 0.7142857142857143vw), 1.375rem);
}

.home_hero__sub-copy-text {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.home_hero__sub-copy-text::before {
    content: "";
    display: block;
    width: 0.375em;
    aspect-ratio: 1;
    border-radius: 50%;
    background-color: currentColor;
}

/* home_about */
.home_about__heading--main {
    font-size: var(--font-size_xl);
}

.home_about__text-cover {
    margin-left: 35vw !important;
}

/* home_loop */
.home_loop {
    --LoopText-duration: 40s;
    color: var(--sub-accent-color);
    font-size: 8.75rem;
    font-weight: 700;
    line-height: 1.5;
    letter-spacing: -0.03em;
    position: absolute;
    bottom: 64px;
    z-index: -1;
}

/* home_service */
.home_service__grid-item {
    padding-block: var(--_padding1);
    padding-inline: var(--_padding-1);
    background-color: var(--lightest-accent-color);
    border-radius: 3px;
    grid-template-rows: subgrid;
    grid-row: span 2;
}

.home_service__title {
    color: var(--accent-color);
    font-size: var(--font-size_m);
    font-weight: 700;
    padding-inline: 0.5em;
    background-color: #fff;
    border: solid 2px currentColor;
    border-radius: 1000px;
    width: fit-content;
}

.home_service__text {
    font-size: 0.875rem;
    font-weight: 500;
}

/* home_area */
.home_area {
    margin-top: var(--_margin3);
}

.home_area__content {
    color: #fff;
    font-weight: 500;
    padding-block: var(--_padding2);
    padding-right: var(--_padding1);
    position: relative;
}

.home_area__content::before {
    content: "";
    display: block;
    width: 100vw;
    height: 100%;
    background-color: var(--accent-color);
    position: absolute;
    top: 0;
    right: 0;
    border-radius: 0 20px 20px 0;
}

.home_area__lists {
    display: flex;
    flex-wrap: wrap;
    gap: calc(var(--_margin1) / 2) var(--_margin1);
}

.home_area__lists li {
    margin-top: 0;
    list-style: disc;
    margin-left: 1.5em;
}

.home_area__map {
    padding-left: var(--_padding1);
}

/* home_feature */
.home_feature {
    background-color: var(--sub-accent-color);
    border-radius: 40px 40px 0 0;
    padding-top: calc(var(--smb-section--padding) * 1.5);
    padding-bottom: calc(var(--smb-section--padding) + 40px);
}

.home_feature__column {
    padding-bottom: var(--_padding2);
    border-bottom: solid 1px var(--light-accent-color);
}

.home_feature__column:nth-child(n+2) {
    padding-top: var(--_padding2);
}

.home_feature__copy {
    gap: 0;
}

.home_feature__sub-copy {
    color: var(--accent-color);
    font-weight: 500;
}

.home_feature__image img {
    border-radius: 4px;
}

.home_feature__num {
    color: #fff;
    font-size: 8.75rem;
    line-height: 1;
    position: absolute;
    top: 0;
}

:where(.home_feature__column:nth-child(odd)) .home_feature__num {
    right: 0;
}

:where(.home_feature__column:nth-child(even)) .home_feature__num {
    left: 0;
}

:where(.home_feature__column:nth-child(n+2)) .home_feature__num {
    top: var(--_padding2);
}

/* home_message */
.home_feature+.home_message {
    background-color: var(--_global--background-color);
    padding-top: calc(var(--smb-section--padding) * 1.5);
    border-radius: 40px 40px 0 0;
    margin-top: -40px !important;
}

/* ========== 下層ページ ========== */
body.page .l-contents__inner {
    padding-bottom: 0;
    margin-top: 0;
}

/* 下層ページヘッダー */
.c-page-header {
    color: var(--accent-color);
    background-color: var(--sub-accent-color);
    padding-block: 144px 72px;
    border-radius: 0 0 40px 40px;
}

.c-page-header[data-has-image=true] {
    height: unset;
}

.c-page-header[data-has-image=true] .c-page-header__content {
    color: unset;
}

.c-page-header__bgimage>img,
.c-page-header__bgimage>picture>img {
    display: none;
}

/* パンくずリスト */
.l-contents__container>.p-breadcrumbs-wrapper:first-child {
    padding-block: var(--_padding-1);
}

/* ========== サービス内容 ========== */
/* service_intro */
.service_intro__copy {
    font-size: 2rem;
}

/* service_services */
.service_services__block {
    font-weight: 500;
    background-color: var(--lightest-accent-color);
    padding-inline: var(--_padding1);
    padding-block: var(--_padding2);
    border-radius: 20px;
}

.service_services__header {
    padding-bottom: var(--_padding2);
    border-bottom: solid 2px #fff;
}

.service_services__item img {
    border-radius: 4px;
}

.service_services__inner {
    padding-top: var(--_padding2);
    margin-top: 0;
    gap: var(--_padding2);
}

.service_services__title {
    color: var(--accent-color);
    background: #fff;
    width: fit-content;
    padding-inline: var(--_padding-2);
    margin-left: 0 !important;
    border: solid 2px currentColor;
    border-radius: 1000px;
}

.service_services__text {
    margin-top: var(--_padding-1);
}

/* ========== お問い合わせ ========== */
.contact_form__heading-main {
    font-size: clamp(1.125rem, calc(0.9464285714285714rem + 0.8928571428571428vw), 1.75rem);
}

/* お問い合わせフォーム */
#autozip {
    display: none !important;
}

.smf-control-description a[href^="tel:"] {
    color: inherit;
    text-decoration: none;
    pointer-events: none;
}

.smf-item__description {
    color: var(--accent-color);
    font-weight: 500;
}

/* プログレスバー */
[data-screen=back] .smf-progress-tracker__item--input .smf-progress-tracker__item__number,
[data-screen=complete] .smf-progress-tracker__item--complete .smf-progress-tracker__item__number,
[data-screen=confirm] .smf-progress-tracker__item--confirm .smf-progress-tracker__item__number,
[data-screen=input] .smf-progress-tracker__item--input .smf-progress-tracker__item__number,
[data-screen=invalid] .smf-progress-tracker__item--input .smf-progress-tracker__item__number {
    background-color: var(--accent-color);
}

/* 送信ボタン */
.smf-action .smf-button-control__control {
    background-color: var(--accent-color);
    border: 2px solid var(--accent-color);
    font-family: inherit;
    color: white;
    width: 100%;
    max-width: 400px;
    padding-block: 1rem;
    background-image: none;
}

/* 戻るボタン */
.smf-action .smf-button-control__control[data-action="back"] {
    background-color: white;
    color: var(--accent-color);
}

.smf-button-control {
    margin-left: 0 !important;
}

.smf-action .smf-button-control__control {
    margin-top: 24px;
}

/* ========== プライバシーポリシー ========== */
.privacy-policy li {
    list-style: inherit;
}


/* ~~~~~~~~~~~~~~~~~~~~ large-size ~~~~~~~~~~~~~~~~~~~~ */
@media screen and (max-width: 1023px) {

    /* ヘッダー */
    .l-header {
        background-color: transparent;
        box-shadow: none;
    }

    /* ========== HOME ========== */
    /* home_hero */
    .home_hero {
        padding-top: 72px;
    }

    .home_hero__image {
        padding-inline: 3%;
    }

    .home_hero__image img {
        border-radius: 20px;
    }
}

/* ~~~~~~~~~~~~~~~~~~~~ medium-size ~~~~~~~~~~~~~~~~~~~~ */
@media screen and (max-width: 781px) {

    /* ========== パターン ========== */
    /* pattern_message */
    .pattern_message__column {
        flex-direction: column-reverse;
    }

    .pattern_message__image {
        max-width: 480px;
    }

    /* ========== HOME ========== */
    /* home_hero */
    .home_hero__copy {
        color: var(--accent-color);
        text-shadow: none;
        padding-top: var(--_padding-1);
        padding-inline: 3%;
        position: relative;
        inset: auto;
    }

    /* home_feature */
    .home_feature__column:nth-child(odd) {
        flex-direction: column-reverse;
    }
}

/* ~~~~~~~~~~~~~~~~~~~~ small-size ~~~~~~~~~~~~~~~~~~~~ */
@media screen and (max-width: 639px) {

    /* ========== 共通設定 ========== */
    /* テーブル */
    .wp-block-table tr td:is(:first-child, :last-child) {
        box-sizing: border-box;
        width: 100%;
    }

    .wp-block-table tr td:first-child {
        text-align: left;
    }


    /* 投稿(シンプル)*/
    .c-entries--simple .c-entry-summary__content {
        display: block;
    }

    .c-entries--simple .c-entry-summary__figure {
        float: inherit;
        width: 100%;
        margin-bottom: 20px;
    }

    /* ========== HOME ========== */
    .home_loop {
        --LoopText-duration: 70s;
    }

    /* home_about */
    .home_about__text-cover {
        margin-left: auto !important;
    }

    /* ========== お問い合わせ ========== */
    .form_thanks__text p {
        text-align: left;
    }
}