@charset "utf-8";

/* ========== 変数 ========== */
:root {
    --_color-text: #202124;
    --font-family: "Zen Maru Gothic", sans-serif;
    --_global--background-color: #fffaeb;
    --_global--transition-duration: .4s;
    --font-size_l: clamp(1.375rem, calc(0.7807750759878419rem + 1.21580547112462vw), 1.875rem);
    --color_white: #fff;
}

/* ========== 基本設定 ========== */
ul {
    padding-left: 0;
}

li {
    list-style: none;
}

.p_rel {
    position: relative;
}

.inline_b {
    display: inline-block;
}

.pc_none {
    display: none;
}

/* ========== 共通設定 ========== */
body {
    font-size: clamp(0.875rem, calc(0.7264437689969605rem + 0.303951367781155vw), 1rem);
    font-weight: 500;
}

.wp-block-columns {
    column-gap: min(64px, 4.44%);
}

/* 見出し */
.section_heading {
    color: var(--accent-color);
    font-size: clamp(1.5rem, calc(1.2142857142857144rem + 1.4285714285714286vw), 2.5rem);
    margin-bottom: var(--_margin3);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
}

.section_heading::before {
    content: "";
    display: block;
    width: 100px;
    aspect-ratio: 2/1;
    background: url("/wp-content/uploads/2026/01/heading-deco.png") no-repeat center center / cover;
}

.section_heading.is-white {
    color: var(--color_white);
}

.section_heading.is-white::before {
    background: url("/wp-content/uploads/2026/01/heading-deco-white.png") no-repeat center center / cover;
}

.home_heading {
    color: var(--accent-color);
    display: flex;
    align-items: center;
    gap: 0.5em;
}

.home_heading::before {
    content: "";
    display: block;
    width: 0.5em;
    aspect-ratio: 1;
    border-radius: 50%;
    background-color: currentColor;
}

/* ボタン */
.smb-buttons {
    margin-top: var(--_margin2);
}

.smb-btn:is(:active, :focus, :hover) {
    filter: brightness(1.0);
}

.smb-btn {
    --smb-btn--color: var(--accent-color);
    font-weight: 700;
    border-radius: 1000px;
    border: solid 2px currentColor;
    background-color: var(--color_white);
    min-width: 280px;
}

.smb-btn__label {
    display: flex;
    align-items: center;
    gap: 0.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: 2rem;
    padding-inline: 1.25rem;
    border: none;
}

.wp-block-table tr td:first-child {
    width: 30%;
    vertical-align: middle;
    color: var(--dark-accent-color);
    font-weight: 700;
    border-bottom: solid 2px var(--accent-color);
}

.wp-block-table tr td:last-child {
    width: 70%;
    border-bottom: solid 2px var(--lighter-accent-color);
}

.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;
    border-radius: 0 20px;
}

.c-entry-summary__figure {
    border-radius: 20px;
}

/* ヘッダー */
/* ロゴ */
header .l-1row-header__branding {
    padding-block: 0;
}

header .c-site-branding__title {
    line-height: 1;
}

header .c-site-branding__title {
    position: absolute;
    top: 0;
    left: 0;
}

header .c-site-branding__title>a.custom-logo-link {
    display: block;
    width: clamp(96px, calc(73.14285714285714px + 7.142857142857142vw), 176px);
    background-color: var(--color_white);
    padding: 15%;
    border-radius: 0 0 10px 0;
}

header .c-site-branding__title>a.custom-logo-link>img {
    width: 100%;
}

/* グローバルナビ */
.p-global-nav {
    margin-top: 20px;
}

#menu-g_nav .c-navbar__item {
    color: var(--accent-color);
    background-color: var(--color_white);
}

#menu-g_nav .c-navbar__item:nth-child(1) {
    border-radius: 100px 0 0 100px;
}

#menu-g_nav .c-navbar__item:nth-last-child(2) {
    border-radius: 0 100px 100px 0;
}

#menu-g_nav .c-navbar__item:last-child {
    color: var(--color_white);
    background-color: var(--accent-color);
    border-radius: 100px;
    margin-left: var(--_margin-1);
}

.p-global-nav .c-navbar__item>a>span {
    gap: 0.25rem;
}

/* ハンバーガーメニュー */
.c-hamburger-btn {
    background-color: var(--accent-color);
    width: 56px;
    aspect-ratio: 1;
    border-radius: 50%;
    border: solid 1px var(--_global--background-color);
}

/* フッター */
.l-footer {
    background-color: var(--lightest-accent-color);
    padding-top: var(--_padding2);
}

.footer_logo {
    width: 148px;
}

#menu-footer {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 2rem;
    font-weight: 500;
}

#menu-footer li {
    margin-top: 0;
}

.c-copyright--inverse {
    background-color: transparent;
}

/* ========== pattern ========== */
.pattern_cta__inner {
    padding-inline: min(var(--_padding1), 5%);
    padding-block: var(--_padding2);
    background-color: var(--color_white);
    border-radius: 40px;
    border: dotted 5px var(--accent-color);
}

.pattern_cta__heading-cover {
    gap: var(--_padding-2);
}

.pattern_cta__copy {
    color: var(--accent-color);
    display: inline-block;
    padding-inline: 1em;
    position: relative;
}

.pattern_cta__copy::before,
.pattern_cta__copy::after {
    content: "";
    display: block;
    width: 2px;
    height: 1.25em;
    background-color: currentColor;
    position: absolute;
    bottom: 0;
}

.pattern_cta__copy::before {
    left: 0;
    rotate: -25deg;
}

.pattern_cta__copy::after {
    right: 0;
    rotate: 25deg;
}

.pattern_cta__btn .smb-btn {
    color: var(--color_white);
    padding-block: 1.125rem;
    background-color: var(--accent-color);
    min-width: auto;
}

/* ========== HOME ========== */
/* home_hero */
.home_hero .smb-section__dividers {
    z-index: 1;
}

.home_hero__slider {
    z-index: -1;
}

.home_hero__slider .spider__slide::after {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    background-color: #000;
    opacity: 0.25;
    position: absolute;
    inset: 0;
    mix-blend-mode: multiply;
}

.home_hero__copy {
    color: var(--color_white);
    font-size: clamp(1.75rem, calc(0.4129939209726443rem + 2.735562310030395vw), 2.875rem);
    font-weight: 700;
    line-height: 1.5;
    position: absolute;
    left: 3%;
    top: 57%;
    translate: 0 -50%;
    margin-top: 0;
}

.home_hero__copy>span {
    display: inline-block;
}

.home_hero__copy>span:nth-child(n+2) {
    margin-top: 0.5rem;
}

/* home_feature */
.home_feature {
    color: var(--_global--background-color);
    padding-block: calc(var(--smb-section--padding) * 2);
}

.home_feature .smb-section__fixed-background::before {
    content: "";
    display: block;
    width: 15%;
    aspect-ratio: 1;
    background: url("/wp-content/uploads/2026/01/deco_sun.png") no-repeat center center / cover;
    position: absolute;
    right: 2%;
    top: 2%;
    opacity: 0.75;
}

.home_feature__image-cover {
    margin-left: calc(50% - 50vw) !important;
}

.home_feature__main .home_feature__image img {
    border-radius: 0 40px 40px 0;
}

.home_feature__main-content {
    flex-grow: 1 !important;
}

.home_feature__sub {
    margin-top: var(--_margin3);
}

.home_feature__sub .home_feature__image img {
    border-radius: 40px;
}

.home_feature__copy {
    font-size: var(--font-size_l);
    font-weight: 700;
}

.home_feature__text {
    line-height: 2;
    margin-top: var(--_margin2);
}

/* home_service */
.home_service {
    padding-top: calc(var(--smb-section--padding) * 2);
}

.home_service__list {
    color: var(--accent-color);
    text-align: center;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--_margin-1);
    margin-top: var(--_margin1);
}

.home_service__list li {
    display: grid;
    place-items: center;
    flex-basis: 20%;
    min-width: 108px;
    aspect-ratio: 1;
    border-radius: 50%;
    padding: 2%;
    border: solid 2px currentColor;
    margin-top: 0;
}

/* home_lineup */
.home_lineup__posts .c-entries-carousel .spider__slide {
    max-width: 100%;
}

.home_lineup__posts .c-entry-summary__figure {
    border-radius: 50%;
}

.home_lineup__posts .c-entry-summary__figure:before {
    padding-top: 100%;
}

.home_lineup__posts .c-entry-summary__body {
    position: absolute;
    left: 0;
    bottom: 8%;
}

.home_lineup__posts .c-entries-carousel .spider__dots {
    margin-top: 0;
}

.home_lineup__posts .c-entry-summary__title {
    background: var(--color_white);
    width: fit-content;
    padding-inline: 0.5rem;
}

/* home_about */
.home_about__sub-heading {
    color: var(--accent-color);
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    display: flex;
    align-items: center;
    gap: 0.5em;
}

.home_about__sub-heading::before {
    content: "";
    display: block;
    width: 0.5em;
    aspect-ratio: 1;
    border-radius: 50%;
    background-color: currentColor;
}

/* home_farmer */
.home_farmer__copy {
    font-size: 1.5rem;
    font-weight: 700;
}

.home_farmer__image img {
    border-radius: 40px;
}

/* home_farm */
.home_farm {
    margin-top: var(--_margin3);
}

.home_farmer__column:nth-child(n+2) {
    margin-top: var(--_margin2);
}

.home_farm__copy {
    font-size: var(--font-size_l);
    font-weight: 700;
}

.home_farm__text {
    line-height: 2;
}

.home_farm__image-cover {
    margin-right: calc(50% - 50vw) !important;
}

.home_farm__content {
    position: relative;
}

.home_farm__content::before {
    content: "";
    display: block;
    width: 75%;
    aspect-ratio: 35/39;
    background: url("/wp-content/uploads/2026/01/map.png") no-repeat center center / cover;
    position: absolute;
    left: 50%;
    top: 50%;
    translate: -50% -50%;
    opacity: 0.4;
    z-index: -1;
}

.home_farm__image img {
    border-radius: 40px 0 0 40px;
}

/* home_outsourcing */
.home_outsourcing__image img {
    border-radius: 40px;
}

.home_outsourcing__heading {
    font-size: var(--font-size_l);
    color: var(--accent-color);
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    display: flex;
    align-items: center;
    gap: 0.5em;
}

.home_outsourcing__heading::before {
    content: "";
    display: block;
    width: 0.5em;
    aspect-ratio: 1;
    border-radius: 50%;
    background-color: currentColor;
}

.home_outsourcing__copy {
    color: var(--_global--background-color);
    font-weight: 700;
    background-color: var(--sub-accent-color);
    margin-top: var(--_margin3);
}

.home_outsourcing__list {
    color: var(--sub-accent-color);
    display: flex;
    flex-wrap: wrap;
    gap: 0 var(--_margin1);
    align-items: center;
    justify-content: center;
}

.home_outsourcing__list li {
    display: grid;
    place-items: center;
    text-align: center;
    margin-top: 0;
    flex-basis: 20%;
    min-width: 220px;
    aspect-ratio: 1;
    padding: 3%;
    border-radius: 50%;
    border: solid 2px currentColor;
}

/* home_activity */
.home_activity__content {
    color: var(--_global--background-color);
    padding-inline: 7% 2%;
    padding-block: var(--_padding3);
    position: relative;
    flex-grow: 1 !important;
    min-width: 440px;
}

.home_activity__content::before {
    content: "";
    display: block;
    width: 125%;
    height: 100%;
    background-color: var(--sub-accent-color);
    border-radius: 0 1000px 1000px 0;
    position: absolute;
    inset: 0;
}

.home_activity__image-cover {
    /* max-width: 580px; */
}

.home_activity__slider {
    padding-inline: var(--smb-spider-slider--gap);
    margin-top: var(--_margin3);
}

.home_activity__slider .spider__canvas {
    align-items: flex-start;
}

.home_activity__slider .spider__slide:nth-child(even) {
    margin-top: var(--_margin2);
}

.home_activity__slider .spider__figure {
    border-radius: 20px;
}

/* ========== 下層ページ ========== */
body.page .l-contents__inner {
    padding-bottom: 0;
    margin-top: 0;
}

/* 下層ページヘッダー */
.c-page-header {
    padding-top: 144px;
    background-color: var(--_global--background-color);
}

.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;
}

/* ========== 会社概要 ========== */
.company_message__items:nth-child(n+2) {
    margin-top: var(--_margin3);
}

/* ========== 農作業受託 ========== */
.outsourcing_intro__image-cover {
    margin-right: calc(50% - 50vw) !important;
}

.outsourcing_intro__image img {
    border-radius: 40px 0 0 40px;
}

.outsourcing_price__table tr td:first-child {
    width: 25%;
}

.outsourcing_price__table tr td:nth-child(2) {
    width: 25%;
    border-bottom: solid 2px var(--lighter-accent-color);
}

.outsourcing_price__table tr td:last-child {
    width: 50%;
}

/* ========== 作っているもの ========== */
.service_intro__image-cover {
    margin-right: calc(50% - 50vw) !important;
}

.service_intro__image img {
    border-radius: 40px 0 0 40px;
}

.service_rice__column {
    background-color: #ffffffbf;
    border-radius: 40px;
    padding-block: var(--_padding2);
    padding-inline: var(--_padding-1);
}

.service_rice__column:nth-child(n+2) {
    margin-top: var(--_margin3);
}

.service_rice__sub-heading {
    color: var(--accent-color);
    gap: 0;
}

.service_rice__sub-heading-copy {
    font-size: 1.125em;
    font-weight: 700;
    position: relative;
    padding-left: 1.25em;
}

.service_rice__sub-heading-copy::before {
    content: "";
    display: block;
    width: 0.375em;
    aspect-ratio: 1;
    border-radius: 50%;
    background-color: currentColor;
    position: absolute;
    left: 0;
    top: calc(1em * 0.5 * 1.75);
    translate: 0 -50%;
}

.service_rice__sub-heading-title {
    font-size: var(--font-size_l);
}

.service_rice__recommendation {
    margin-top: var(--_margin2);
}

.service_rice__recommendation-title {
    font-weight: 700;
}

.service_rice__recommendation-title .svg-inline--fa {
    margin-right: 0.5em;
}

.service_rice__recommendation-text {
    margin-top: var(--_margin-1);
}

.service_rice__recommendation-image-cover {
    padding-right: 50%;
}

.service_rice__recommendation-image img {
    border-radius: 20px;
}

/* ========== ラインナップ ========== */
.lineup_intro__image img {
    border-radius: 40px;
}

.lineup_intro__text {
    font-size: 1.125em;
    line-height: 2;
    margin-top: var(--_margin2);
}

.lineup_wrap {
    margin-top: var(--_margin4);
}

.lineup_item:nth-child(n+2) {
    margin-top: var(--_margin3);
}

:is(.tax-products-cat, .post-type-archive-products) .c-entry-summary__meta {
    display: none;
}

.single-products .c-prev-next-nav__item-label {
    display: none;
}

/* ========== お問い合わせ ========== */
/* お問い合わせフォーム */
#autozip {
    display: none !important;
}

.smf-control-description a[href^="tel:"] {
    color: inherit;
    text-decoration: none;
    pointer-events: none;
}

.smf-form--letter .smf-item {
    padding-block: var(--_padding2);
    border-bottom: solid 2px var(--lightest-accent-color);
}

.smf-item__label {
    color: var(--accent-color);
    font-size: 1.125em;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.smf-item__label::before {
    content: "";
    display: block;
    width: 0.5rem;
    aspect-ratio: 1;
    border-radius: 50%;
    background-color: currentColor;
}

.smf-item__description {
    color: var(--sub-accent-color);
    font-weight: 700;
}

/* プログレスバー */
[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;
    font-weight: 700;
    color: white;
    width: 100%;
    max-width: 400px;
    padding-block: 1rem;
    background-image: none;
    border-radius: 1000px;
}

/* 戻るボタン */
.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 {
        overflow: visible;
    }

    /* ========== HOME ========== */
    .home_activity__column {
        flex-direction: column-reverse;
        row-gap: 0 !important;
    }

    .home_activity__content {
        min-width: auto;
        margin-top: -48px !important;
    }
}

/* ~~~~~~~~~~~~~~~~~~~~ medium-size ~~~~~~~~~~~~~~~~~~~~ */
@media screen and (max-width: 781px) {

    /* ========== HOME ========== */
    .home_hero__slider.smb-spider-slider--16x9 .smb-spider-slider__figure-wrapper:before {
        padding-top: calc(4/3 * 100%);
    }

    .home_hero__copy {
        font-size: clamp(1.5rem, calc(0.5476190476190477rem + 4.761904761904762vw), 2.875rem);
    }

    .home_service__content {
        display: contents;
    }

    .home_service__heading {
        order: 1;
        margin-bottom: 0;
        width: 100%;
    }

    .home_service__text {
        order: 2;
    }

    .home_service__image-cover {
        order: 3;
    }

    .home_service__btns {
        order: 4;
        margin-top: 0;
    }

    .home_limeup__content {
        display: contents;
    }

    .home_limeup__heading {
        order: 1;
        margin-bottom: 0;
        width: 100%;
    }

    .home_limeup__text {
        order: 2;
    }

    .home_limeup__post-cover {
        order: 3;
    }

    .home_limeup__btns {
        order: 4;
    }

    .home_outsourcing__header {
        flex-direction: column-reverse;
    }

    .home_outsourcing__heading {
        -ms-writing-mode: inherit;
        writing-mode: initial;
    }

    .home_outsourcing__list li {
        min-width: 280px;
        max-width: 100%;
        aspect-ratio: initial;
        border: none;
        margin-left: 1.5em;
        list-style: disc;
    }

    /* ========== 作っているもの ========== */
    .service_rice__recommendation-image-cover {
        padding-right: 0;
    }
}

/* ~~~~~~~~~~~~~~~~~~~~ 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 {
        border-bottom: none;
        padding-bottom: 1rem;
    }

    .wp-block-table tr td:last-child {
        padding-top: 1rem;
    }


    /* 投稿(シンプル)*/
    .c-entries--simple .c-entry-summary__content {
        display: block;
    }

    .c-entries--simple .c-entry-summary__figure {
        float: inherit;
        width: 100%;
        margin-bottom: 20px;
    }

    /* ========== 農作業委託 ========== */
    .outsourcing_price__table tr td:nth-child(2) {
        text-align: left;
        width: 100%;
        padding-top: 1rem;
        padding-bottom: 0;
        border-bottom: none;
    }

    .wp-block-table tr td:last-child {
        border-bottom-color: var(--accent-color);
    }

    /* ========== お問い合わせ ========== */
    .form_thanks__text p {
        text-align: left;
    }
}