@charset "UTF-8";
/* 奈多写真 CSS Document */
/* 共通部分 */
body {
    background: #fff;
    color: #000;
    overflow: hidden;
    font-size: 14px;
    font-size: clamp(15px, 0.75vw, 20px);
    letter-spacing: .08em;
    counter-reset: number 0 counter-reset1 counter-reset2;
}
a, .post-content a {
    color: #000;
}
.font-type2, .headline-font-type {
    font-family: "Noto Sans JP", "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
}
p, .post-content p {
    font-size: 0.9em;
    font-weight: 400;
    line-height: 2;
}
.post-content ul {
    font-size: 0.9em;
    list-style: disc;
}
.breadcrumb-wrapper {
    background: none;
    color: #fff;
}
.breadcrumb-wrapper a{
    color: #fff;
}
.breadcrumb.inner {
    font-size: 0.8em;
    letter-spacing: .06em;
    width: fit-content;
    display: block;
    height: 35px;
    line-height: 35px;
}
.signage {
    width: calc(100% - 50px);
    margin: auto;
    height: 280px;
    position: relative;
    z-index: 0;
}
.signage:after{
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.3);
    content: "";
    z-index: -1;
}
.signage-title.headline-font-type, .signage-title-sub {
    text-align: center;
    text-shadow: none;
}
.signage-title.headline-font-type {
    letter-spacing: .1em;
    margin-bottom: 15px;
    font-size: 2.5em !important;
    font-weight: 700;
    font-family: "Lato", sans-serif;
    color: #fff !important;
}
.signage-title-sub {
    font-size: 0.95em !important;
    letter-spacing: .08em;
    line-height: 1;
    font-weight: 500;
    color: #fff !important;
}
@media only screen and (max-width: 768px) {
    .signage {
        width: calc(100% - 30px);
        height: 170px;
    }
    .signage-title.headline-font-type {
        font-size: 1.8em !important;
    }
    .signage-title-sub {
        font-size: 0.75em !important;
    }
}
/* 共通部分 END */
/* ナビ */
.home .header::before {
    content: '';
    position: absolute;
    background: #000;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    opacity: 0.5;
    z-index: 1;
}
.header-bar {
    z-index: 50;
    box-shadow: none;
}
.logo-image {
    top: 5px;
    width: 200px;
    height: auto;
    left: 30px;
    position: absolute;
}
img.h_logo {
    width: 100%;
}
.global-nav {
    padding-right: 25px;
}
.header-bar-inner {
    width: 100%;
    max-width: unset;
    z-index: 100;
}
.global-nav > ul > li > a {
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.15em;
    line-height: 90px;
    padding: 0px 22px;
    position: relative;
    text-align: center;
    transition: all 0.5s;
    color: #000;
    font-family: "Lato", sans-serif;
}
.global-nav > ul > li > a::before, .global-nav .current-menu-item > a::before {
    content: "";
    left: 48%;
    width: 1px;
    height: 10px;
    background: #000;
    top: 20px;
    position: absolute;
    transform: rotate(20deg);
    transition: all 0.8s;
    z-index: 1;
}
.global-nav > ul > li > a:hover::before, .global-nav .current-menu-item > a::before {
    background: #7d6ca0;
    transform: rotate(0deg);
}
.global-nav > ul > li > a::after {
    position: relative;
    text-align: center;
    display: block;
    bottom: 27px;
    line-height: 1;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: .05em;
    color: #646464;
    font-family: "Noto Sans JP", "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
}
.global-nav > ul > li > a span {
    position: relative;
    text-align: center;
    display: block;
    bottom: 27px;
    line-height: 1;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: .05em;
    color: #646464;
    font-family: "Noto Sans JP", "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
}
.global-nav > ul > li.global-menu-home > a::after {
    content: "ホーム";
}
.global-nav > ul > li.global-menu-price > a::after {
    content: "撮影料金";
}
.global-nav > ul > li.global-menu-greeting > a::after {
    content: "ご挨拶";
}
.global-nav > ul > li.global-menu-company > a::after {
    content: "運営概要";
}
.global-nav > ul > li.global-menu-contact > a::after {
    content: "お問い合わせ";
}
.global-nav .sub-menu {
    left: auto;
    right: 0px !important;
}
.global-nav .sub-menu a {
    font-size: 12px;
    font-weight: 400;
    color: #000;
    background: #fff !important;
}
.global-nav .sub-menu a:hover {
    color: #7d6ca0 !important;
    background: #fff !important;
}
.global-nav .sub-menu .current-menu-item > a::before, .global-nav .sub-menu a:hover::before {
    content: none;
}
@media only screen and (max-width: 1200px) {
    .logo-image {
        top: 2px;
        left: 5px;
        width: 180px;
    }
    .header-bar {
        border-bottom: 1px solid #fff;
    }
    .global-nav-button {
        border-left: 0px;
        background: none;
    }
    .global-nav-button:before {
        color: #000;
    }
    .global-nav-button:hover:before {
        color: #7d6ca0;
    }
    .global-nav > ul > li > a {
        font-size: 12px;
        letter-spacing: 1px;
        text-shadow: none;
        text-align: center;
        padding: 0px;
        line-height: 40px;
    }
    .global-nav > ul > li > a span{
        position: absolute;
        left: 50%;
        bottom: 10px;
        transform: translateX(-50%);
    }
    .global-nav > ul > li > a::after {
        /*        text-align: left;
                line-height: 0;
                bottom: 25px;
                padding-left: 120px;*/
        position: absolute;
        left: 50%;
        bottom: 10px;
        transform: translateX(-50%);
    }
    .global-nav a {
        background: #fff;
        color: #000 !important;
    }
    .global-nav .sub-menu a {
        font-size: 11px;
        letter-spacing: .05em;
        background: #fff !important;
        color: #000 !important;
    }
    .global-nav a:hover, .global-nav .sub-menu a:hover {
        background: #fff !important;
        color: #7d6ca0 !important;
    }
    .global-nav > ul > li > a::before, .global-nav .current-menu-item > a::before {
        content: none !important;
    }
    .global-nav .menu-item-has-children > a:before {
        content: none !important;
    }
    .global-nav .menu-item-has-children > a span::before {
        color: #000;
    }
}
@media only screen and (max-width: 820px) {
    img.s_logo {
        width: 100%;
    }
}
@media only screen and (max-width: 768px) {
    .home .header::before {
        width: calc(100% - 30px);
        left: 15px;
    }
}
/* ナビ END */
/* YouTube コントロールバー非表示 */
.mb_YTPBar {
    display: none !important;
}
/* YouTube コントロールバー非表示 */
/* トップ・フッター */
.header-youtube-overlay {
    background: linear-gradient(-70deg, #ffffff 0%, #a88a79 59%);
    opacity: 0.45;
}
.top-slider-content {
    border-radius: 0;
    flex-direction: column;
    justify-content: center;
    display: -webkit-flex;
    display: flex;
    width: 100% !important;
    height: 100% !important;
}
.top-slider-content-inner, .top-slider-content-inner:hover {
    background: none;
}
.top-slider-content-inner {
    width: 100% !important;
    height: 100% !important;
    box-sizing: border-box;
    margin: 0 auto;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    display: -webkit-flex;
    display: flex;
}
.top-slider-content-inner p, .top-slider-nav {
    display: none;
}
.top-slider-content-inner:after {
    content: none;
}
.front-slider-box {
    width: 86%;
    margin: 0 auto;
}
.front-copy-img {
    width: 50%;
    max-width: 300px;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    display: -webkit-flex;
    display: flex;
}
.top-slider-wrapper {
    width: calc(100% - 50px);
    margin: 0 auto;
}
.top-slider-wrapper::before {
    content: '';
    position: absolute;
    width: 1px;
    height: 40px;
    background: #fff;
    bottom: 0;
    left: 10%;
    z-index: 10;
}
.top-slider-wrapper::after {
    content: 'SCROLL';
    position: absolute;
    color: #fff;
    text-align: center;
    width: 20%;
    left: 0;
    bottom: 50px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.15em;
    line-height: 1;
    z-index: 2;
    font-family: "Lato", sans-serif;
}
/* ============================================
   吉粋工業 | フロント & フッター スタイル
   テーマカラー: 上品なシック紫
   - メイン:   #6b5b8e
   - サブ:     #7d6ca0
   - ライト:   #a99bc4
   - 背景:     #f5f2f8
   - アクセント金: #c8a96a
   ============================================ */

/* ---- 共通アニメーション定義 ---- */
@keyframes yoshisuiFadeUp {
    0% { opacity: 0; transform: translateY(40px); }
    100% { opacity: 1; transform: translateY(0); }
}
@keyframes yoshisuiFloat {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-8px); }
}
@keyframes yoshisuiShine {
    0% { background-position: -200% center; }
    100% { background-position: 200% center; }
}
@keyframes yoshisuiPulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.7; transform: scale(1.05); }
}

/* フェードイン制御は親テーマ（TCD STORY）の挙動に任せる
   ※ 独自に .fade01 { opacity:0 } を仕込むと親テーマのトリガークラスと
   　 不一致になり要素が永久に透明になる事故が起きるため、ここでは触らない */

/* ============================================
   ABOUT セクション (front_original01)
   ============================================ */
.front_original01 {
    padding: 8em 0 7em;
    position: relative;
    background: linear-gradient(180deg, #ffffff 0%, #faf8fc 100%);
    overflow: hidden;
}
.front_original01::before {
    content: '';
    position: absolute;
    width: 360px;
    height: 360px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(169,155,196,0.18) 0%, rgba(169,155,196,0) 70%);
    top: -120px;
    right: -120px;
    z-index: 0;
    animation: yoshisuiFloat 8s ease-in-out infinite;
}
.front_original01::after {
    content: '';
    position: absolute;
    width: 240px;
    height: 240px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(200,169,106,0.12) 0%, rgba(200,169,106,0) 70%);
    bottom: -60px;
    left: -60px;
    z-index: 0;
    animation: yoshisuiFloat 10s ease-in-out infinite reverse;
}
.front-original01-inner {
    width: 86%;
    max-width: 1150px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}
.front-original01__title {
    width: 32%;
    box-sizing: border-box;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    display: flex;
    padding-right: 1em;
}
.front-original01__text {
    width: 68%;
    padding-left: 5em;
    box-sizing: border-box;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    display: flex;
    border-left: 1px solid rgba(125,108,160,0.25);
}
.front-original01__title h2 {
    font-size: 1.1em;
    font-weight: 500;
    font-family: "Lato", sans-serif;
    letter-spacing: .35em;
    margin-bottom: 24px;
    width: 100%;
    color: #6b5b8e;
    position: relative;
    padding-left: 48px;
}
.front-original01__title h2::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    width: 36px;
    height: 1px;
    background: linear-gradient(90deg, #6b5b8e, #a99bc4);
    transform: translateY(-50%);
}
.front-original01__title h3 {
    font-size: 1.85em;
    font-weight: 600;
    letter-spacing: .06em;
    line-height: 1.7;
    width: 100%;
    color: #2d2438;
    font-family: "Noto Serif JP", "游明朝", YuMincho, "Hiragino Mincho Pro", serif;
}
.front-original01__title h3 br + br { display: none; }
.front-original01__text p {
    margin-bottom: 22px;
    width: 100%;
    line-height: 2.1;
    color: #3d3548;
}
.front-original01__text p:last-of-type {
    margin-bottom: 0;
}

/* ============================================
   SERVICE セクション (content02)
   ============================================ */
.content02 {
    padding: 7em 0 6em;
    width: calc(100% - 50px);
    margin: 0 auto;
    background: linear-gradient(135deg, #f5f2f8 0%, #ece5f2 100%);
    border-radius: 32px;
    position: relative;
    overflow: hidden;
}
.content02::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        radial-gradient(circle at 20% 30%, rgba(255,255,255,0.6) 0, transparent 40%),
        radial-gradient(circle at 80% 70%, rgba(200,169,106,0.08) 0, transparent 40%);
    pointer-events: none;
}
h2.content02_title {
    width: 86%;
    margin: 0 auto;
    font-size: 2.4em;
    font-weight: 500;
    font-family: "Lato", sans-serif;
    letter-spacing: .25em;
    text-align: center;
    color: #4a3f6b;
    position: relative;
    z-index: 1;
}
h2.content02_title::before {
    content: 'サービス案内';
    display: block;
    font-family: "Noto Serif JP", serif;
    font-size: 0.42em;
    font-weight: 400;
    letter-spacing: .35em;
    color: #c8a96a;
    margin-bottom: 12px;
    letter-spacing: .4em;
}
h2.content02_title::after {
    content: '';
    display: block;
    width: 48px;
    height: 2px;
    background: linear-gradient(90deg, #6b5b8e, #c8a96a);
    margin: 22px auto 0;
    border-radius: 2px;
    transform: none;
}
.content02-inner {
    width: 88%;
    max-width: 1180px;
    margin: 0 auto;
    padding: 0;
    padding-top: 70px;
    position: relative;
    z-index: 1;
    gap: 36px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}
.content02-item {
    width: calc((100% - 72px) / 3);
    margin-left: 0;
    padding: 28px 24px 32px;
    box-sizing: border-box;
    background: #ffffff;
    border-radius: 22px;
    box-shadow:
        0 1px 2px rgba(74,63,107,0.04),
        0 8px 24px rgba(74,63,107,0.08);
    transition: transform 0.5s cubic-bezier(.2,.7,.2,1), box-shadow 0.5s cubic-bezier(.2,.7,.2,1);
    position: relative;
    overflow: hidden;
}
.content02-item::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, #6b5b8e, #a99bc4, #c8a96a);
    border-radius: 22px 22px 0 0;
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.6s cubic-bezier(.2,.7,.2,1);
}
.content02-item:hover {
    transform: translateY(-8px);
    box-shadow:
        0 4px 8px rgba(74,63,107,0.06),
        0 24px 48px rgba(74,63,107,0.16);
}
.content02-item:hover::before {
    transform: scaleX(1);
}
.content02-img {
    width: 100%;
    height: auto;
    margin: 0 auto 26px;
    overflow: hidden;
    position: relative;
    transition: all .5s;
    z-index: 0;
    border-radius: 14px;
    aspect-ratio: 4 / 3;
}
.content02-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.8s cubic-bezier(.2,.7,.2,1);
}
.content02-img:hover img {
    transform: scale(1.08);
}
.content02-img::before {
    position: absolute;
    content: 'BENRIYA';
    display: inline-flex;
    align-items: center;
    left: 14px;
    top: 14px;
    bottom: auto;
    border: 0;
    padding: 7px 14px;
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: .15em;
    text-align: center;
    font-family: "Lato", sans-serif;
    color: #ffffff;
    background: rgba(107,91,142,0.92);
    backdrop-filter: blur(6px);
    box-sizing: border-box;
    z-index: 2;
    border-radius: 100px;
    box-shadow: 0 4px 12px rgba(74,63,107,0.22);
}
.content02-item:nth-of-type(2) .content02-img::before {
    content: 'KUSAKARI';
    background: rgba(125,108,160,0.92);
}
.content02-item:nth-of-type(3) .content02-img::before {
    content: 'KAJI';
    background: rgba(169,155,196,0.95);
}
.content02-img-inner {
    width: 100%;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    position: absolute;
    text-align: center;
    color: #fff;
    z-index: 2;
}
h2.content02-img_title {
    font-size: 1.7em;
    font-weight: 500;
    letter-spacing: .15em;
    margin: 0;
    font-family: "Lato", "Noto Sans JP", "游ゴシック", YuGothic, sans-serif;
    text-shadow: 0 2px 12px rgba(0,0,0,0.4);
}
h2.content02-img_title span {
    font-size: 0.45em;
    font-weight: 500;
    margin-top: 10px;
    letter-spacing: .15em;
    display: block;
    font-family: "Noto Serif JP", serif;
}
.content02-img .mask {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    background: linear-gradient(135deg, rgba(74,63,107,0.55), rgba(107,91,142,0.7));
    -webkit-transition: all 0.6s ease;
    transition: all 0.6s ease;
    z-index: 1;
}
.content02-img:hover .mask {
    opacity: 1;
}
.content02-item .headline-font-type {
    font-size: 1.18em;
    font-weight: 600;
    line-height: 1.6;
    margin-bottom: 16px;
    letter-spacing: .04em;
    color: #2d2438;
    font-family: "Noto Serif JP", "游明朝", YuMincho, serif;
    padding-bottom: 14px;
    position: relative;
}
.content02-item .headline-font-type::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 32px;
    height: 2px;
    background: #c8a96a;
    border-radius: 2px;
}
.content02-text {
    line-height: 2;
    color: #3d3548;
    font-size: 0.92em;
}
.content02-button {
    font-size: 0.85em;
    font-weight: 500;
    overflow: hidden;
    text-align: left;
    width: 100%;
    max-width: 100%;
    height: 56px;
    line-height: 56px;
    position: relative;
    margin: 24px auto 0;
    color: #ffffff;
    background: #6b5b8e;
    border: none;
    border-radius: 100px;
    padding: 0 28px;
    box-sizing: border-box;
    transition: all 0.5s cubic-bezier(.2,.7,.2,1);
    z-index: 1;
    display: block;
    letter-spacing: .08em;
    box-shadow: 0 6px 18px rgba(107,91,142,0.28);
}
.content02-button::after {
    content: '→';
    position: absolute;
    font-size: 1.1em;
    right: 24px;
    top: 50%;
    transform: translateY(-50%);
    font-family: "Lato", sans-serif;
    transition: transform 0.5s cubic-bezier(.2,.7,.2,1);
    color: #ffffff;
}
.content02-button::before {
    width: 100%;
    height: 100%;
    position: absolute;
    content: '';
    background: linear-gradient(90deg, #6b5b8e, #7d6ca0, #a99bc4);
    background-size: 200% 100%;
    background-position: 100% 0;
    left: 0;
    top: 0;
    z-index: -1;
    transition: background-position 0.6s cubic-bezier(.2,.7,.2,1);
    border-radius: 100px;
}
.content02-button:hover {
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 10px 24px rgba(107,91,142,0.4);
}
.content02-button:hover::before {
    background-position: 0 0;
}
.content02-button:hover::after {
    transform: translateY(-50%) translateX(6px);
}

/* ============================================
   代表挨拶 (front_original02)
   ============================================ */
.front_original02 {
    position: relative;
    z-index: 0;
    padding: 8em 0;
}
.front_original02::before {
    content: '';
    position: absolute;
    display: block;
    background: linear-gradient(135deg, #f5f2f8 0%, #efe7f5 100%);
    width: calc(100% - 50px);
    height: 70%;
    left: 25px;
    top: 15%;
    z-index: -1;
    border-radius: 32px;
}
.front_original02::after {
    content: '吉';
    position: absolute;
    font-family: "Noto Serif JP", serif;
    font-size: 22em;
    font-weight: 700;
    color: rgba(107,91,142,0.05);
    top: 50%;
    right: 4%;
    transform: translateY(-50%);
    z-index: -1;
    line-height: 1;
    pointer-events: none;
}
.front-original02-inner {
    width: 86%;
    max-width: 1200px;
    margin: 0 auto;
    align-items: center;
}
.front-original02__text {
    width: 42%;
    height: fit-content;
    border: none;
    margin-top: 4em;
    padding: 44px 40px;
    background: #ffffff;
    box-sizing: border-box;
    border-radius: 22px;
    box-shadow:
        0 4px 12px rgba(74,63,107,0.06),
        0 24px 56px rgba(74,63,107,0.12);
    position: relative;
    z-index: 2;
}
/*.front-original02__text::before {
    content: 'GREETING';
    position: absolute;
    top: -16px;
    left: 40px;
    background: #6b5b8e;
    color: #ffffff;
    padding: 7px 18px;
    border-radius: 100px;
    font-family: "Lato", sans-serif;
    font-size: 0.7em;
    letter-spacing: .25em;
    font-weight: 500;
    box-shadow: 0 6px 16px rgba(107,91,142,0.3);
}*/
.front-original02__img {
    width: 65%;
    margin-left: -7%;
    box-sizing: border-box;
    z-index: 1;
    border-radius: 22px;
    overflow: hidden;
    box-shadow: 0 30px 60px rgba(74,63,107,0.18);
    position: relative;
}
.front-original02__img img {
    width: 100%;
    height: auto;
    display: block;
    transition: transform 1.2s cubic-bezier(.2,.7,.2,1);
}
.front-original02__img:hover img {
    transform: scale(1.04);
}
.front-original02__text h2 {
    font-size: 1.6em;
    font-weight: 600;
    margin-bottom: 22px;
    line-height: 1.7;
    width: 100%;
    color: #2d2438;
    font-family: "Noto Serif JP", "游明朝", YuMincho, serif;
    letter-spacing: .04em;
}
.front-original02__text p {
    width: 100%;
    line-height: 2.1;
    color: #3d3548;
    font-size: 0.92em;
}

/* ============================================
   選ばれる理由 / POINT (front_original03)
   ============================================ */
.front_original03 {
    padding: 9em 0 8em;
    background: linear-gradient(180deg, #ffffff 0%, #faf8fc 100%);
    position: relative;
}
.front_original03::before {
    content: 'POINT';
    position: absolute;
    top: 60px;
    left: 50%;
    transform: translateX(-50%);
    font-family: "Lato", sans-serif;
    font-size: 0.85em;
    font-weight: 600;
    letter-spacing: .5em;
    color: #6b5b8e;
}
.front_original03::after {
    content: '選ばれる理由';
    position: absolute;
    top: 92px;
    left: 50%;
    transform: translateX(-50%);
    font-family: "Noto Serif JP", serif;
    font-size: 1.8em;
    font-weight: 600;
    letter-spacing: .15em;
    color: #2d2438;
}
.front-original03-inner {
    width: 86%;
    max-width: 1180px;
    margin: 0 auto;
    padding-top: 100px;
}
.third-box {
    margin-bottom: 80px;
    position: relative;
}
.third-box:last-of-type {
    margin-bottom: 0;
}
.third-inner {
    align-items: center;
}
.front-third-text {
    width: 48%;
    box-sizing: border-box;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    display: flex;
    position: relative;
}
.front-third-text::before {
    counter-increment: number 1;
    content: "0"counter(number) "";
    width: auto;
    font-size: 4.5em;
    font-weight: 700;
    margin-bottom: 8px;
    font-family: "Lato", sans-serif;
    color: transparent;
    -webkit-text-stroke: 1.5px #a99bc4;
    line-height: 1;
    letter-spacing: -0.04em;
    background: linear-gradient(135deg, #6b5b8e 0%, #c8a96a 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    -webkit-text-stroke: 0;
}
.third-box:nth-of-type(odd) .front-third-text {
    padding-left: 4em;
    margin-left: 52%;
}
.third-box:nth-of-type(even) .front-third-text {
    padding-right: 4em;
}
.front-third-img {
    width: 52%;
    box-sizing: border-box;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    display: flex;
    position: relative;
    border-radius: 22px;
    overflow: hidden;
    box-shadow: 0 24px 48px rgba(74,63,107,0.15);
    transition: transform 0.6s cubic-bezier(.2,.7,.2,1);
}
.front-third-img:hover {
    transform: translateY(-6px);
}
.front-third-img img {
    width: 100%;
    height: auto;
    display: block;
    transition: transform 1.2s cubic-bezier(.2,.7,.2,1);
}
.front-third-img:hover img {
    transform: scale(1.06);
}
.third-box:nth-of-type(odd) .front-third-img {
    margin-left: -100%;
}
.front-third-text p {
    width: 100%;
    line-height: 2.1;
    color: #3d3548;
    font-size: 0.92em;
}
h3.third_title {
    font-size: 1.45em;
    font-weight: 600;
    line-height: 1.6;
    margin-bottom: 20px;
    width: 100%;
    color: #2d2438;
    font-family: "Noto Serif JP", "游明朝", YuMincho, serif;
    letter-spacing: .04em;
    position: relative;
    padding-bottom: 18px;
}
h3.third_title::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 40px;
    height: 2px;
    background: linear-gradient(90deg, #6b5b8e, #c8a96a);
    border-radius: 2px;
}

/* ============================================
   トピックス (front_topics)
   ============================================ */
.front_topics {
    padding: 7em 0 6em;
    width: calc(100% - 50px);
    margin: 0 auto 4em;
    background: linear-gradient(135deg, #f5f2f8 0%, #ece5f2 100%);
    border-radius: 32px;
    position: relative;
    overflow: hidden;
}
.front_topics::before {
    content: '';
    position: absolute;
    width: 320px;
    height: 320px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(200,169,106,0.1) 0%, rgba(200,169,106,0) 70%);
    top: -80px;
    left: -80px;
    pointer-events: none;
}
.front-topics-inner {
    width: 86%;
    max-width: 1180px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}
h2.front_topics_title {
    font-size: 2.4em;
    margin-bottom: 50px;
    font-family: "Lato", sans-serif;
    font-weight: 500;
    letter-spacing: .25em;
    text-align: center;
    color: #4a3f6b;
}
h2.front_topics_title::before {
    content: 'お知らせ';
    display: block;
    font-family: "Noto Serif JP", serif;
    font-size: 0.42em;
    font-weight: 400;
    letter-spacing: .4em;
    color: #c8a96a;
    margin-bottom: 12px;
}
h2.front_topics_title::after {
    content: '';
    display: block;
    width: 48px;
    height: 2px;
    background: linear-gradient(90deg, #6b5b8e, #c8a96a);
    margin: 22px auto 0;
    border-radius: 2px;
    transform: none;
}
h2.headline-primary {
    display: none;
}
.footer-gallery-title, .align1 {
    display: none;
}
.footer {
    margin-top: 0;
    background: #faf8fc;
}

/* ============================================
   フッター連絡先 (footer_contact_sec)
   ============================================ */
.footer_contact_sec {
    padding: 5em 0 4em;
    background: linear-gradient(180deg, #faf8fc 0%, #ece5f2 100%);
    position: relative;
}
/*.footer_contact_sec::before {
    content: 'CONTACT';
    position: absolute;
    top: 50px;
    left: 50%;
    transform: translateX(-50%);
    font-family: "Lato", sans-serif;
    font-size: 0.78em;
    font-weight: 600;
    letter-spacing: .5em;
    color: #6b5b8e;
}
.footer_contact_sec::after {
    content: 'お問い合わせ';
    position: absolute;
    top: 78px;
    left: 50%;
    transform: translateX(-50%);
    font-family: "Noto Serif JP", serif;
    font-size: 1.6em;
    font-weight: 600;
    letter-spacing: .15em;
    color: #2d2438;
}*/
.footer_contact_inner {
    width: 86%;
    max-width: 1180px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    gap: 40px;
    align-items: flex-start;
}
.footer_contact_bg {
    width: calc(72% - 20px);
    box-sizing: border-box;
    background: #ffffff;
    padding: 44px 48px;
    border-radius: 22px;
    box-shadow:
        0 4px 12px rgba(74,63,107,0.06),
        0 16px 40px rgba(74,63,107,0.1);
    position: relative;
}
.footer_menu_bg {
    width: calc(28% - 20px);
    padding-left: 0;
    box-sizing: border-box;
    background: #ffffff;
    padding: 44px 32px;
    border-radius: 22px;
    box-shadow:
        0 4px 12px rgba(74,63,107,0.06),
        0 16px 40px rgba(74,63,107,0.1);
}
h2.footer-logo-name {
    font-size: 1.7em;
    font-weight: 600;
    margin-bottom: 0;
    letter-spacing: .12em;
    float: left;
    color: #2d2438;
    font-family: "Noto Serif JP", "游明朝", YuMincho, serif;
}
h3.footer-holiday {
    font-size: 0.78em;
    width: fit-content;
    padding: 6px 14px;
    letter-spacing: .15em;
    color: #ffffff;
    background: linear-gradient(135deg, #6b5b8e, #a99bc4);
    margin-left: 16px;
    margin-top: 8px;
    display: inline-block;
    border-radius: 100px;
    font-weight: 500;
    box-shadow: 0 4px 12px rgba(107,91,142,0.25);
}
dl.address_body {
    width: 100%;
    font-size: 0.85em;
    line-height: 1.7;
    display: flex;
    margin-bottom: 14px;
    clear: both;
    align-items: flex-start;
}
dl.address_body:first-of-type {
    margin-top: 28px;
    padding-top: 24px;
    border-top: 1px solid rgba(125,108,160,0.18);
}
dl.address_body:last-of-type {
    margin-bottom: 24px;
}
dt.address_title {
    width: 90px;
    font-weight: 600;
    color: #6b5b8e;
    letter-spacing: .08em;
    flex-shrink: 0;
}
dd.address_text {
    width: calc(100% - 90px);
    color: #3d3548;
}
.address_note {
    display: inline-block;
    font-size: 0.85em;
    color: #7d6ca0;
    margin-top: 4px;
}
address.footer_tel {
    font-size: 1.7em;
    font-weight: 700;
    font-style: normal;
    margin-bottom: 8px;
    font-family: "Lato", sans-serif;
    color: #2d2438;
    display: flex;
    align-items: baseline;
    gap: 8px;
    letter-spacing: .04em;
}
address.footer_tel::before {
    content: '☎';
    font-size: 0.7em;
    color: #6b5b8e;
}
span.footer_tel_sub {
    font-size: 0.5em;
    margin-right: 4px;
    letter-spacing: .15em;
    color: #6b5b8e;
    font-weight: 500;
}
p.footer-con-caution {
    font-size: 0.78em;
    letter-spacing: .04em;
    position: relative;
    line-height: 1.6;
    padding-left: 16px;
    margin-bottom: 6px;
    box-sizing: border-box;
    color: #5a4f6b;
}
p.footer-con-caution:last-of-type {
    margin-bottom: 0;
}
p.footer-con-caution::before {
    content: '※';
    position: absolute;
    left: 0;
    color: #c8a96a;
    font-weight: 700;
}
ul.sns__links {
    width: 100%;
    max-width: 100%;
    display: flex;
    margin-top: 28px;
    gap: 12px;
    flex-wrap: wrap;
}
li.sns__links-item {
    width: auto;
    margin-right: 0;
}
li.sns__links-item:last-child {
    margin-right: 0;
}
a.footer_sns {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    text-align: center;
    padding: 14px 28px;
    border-radius: 100px;
    font-size: 0.85em;
    font-weight: 600;
    letter-spacing: .12em;
    color: #ffffff;
    transition: all 0.5s cubic-bezier(.2,.7,.2,1);
    text-decoration: none;
    position: relative;
    overflow: hidden;
}
a.footer_sns::before {
    content: "";
    font-family: design_plus;
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin: 0;
    color: #ffffff;
    font-size: 14px;
    width: auto;
    height: auto;
    border-radius: 0;
    transition: none;
    z-index: 1;
    background: none !important;
}
a.footer_line_but {
    background: linear-gradient(135deg, #06c755, #00b900);
    box-shadow: 0 8px 20px rgba(0,185,0,0.3);
}
a.footer_line_but::before {
    content: '\f1d7';
    font-family: "Font Awesome 6 Brands", "Font Awesome 5 Brands", design_plus;
}
a.footer_mail_but {
    background: linear-gradient(135deg, #6b5b8e, #7d6ca0);
    box-shadow: 0 8px 20px rgba(107,91,142,0.3);
}
a.footer_mail_but::before {
    content: '\f0e0';
}
a.footer_sns:hover {
    background: linear-gradient(135deg, #4a3f6b, #6b5b8e);
    transform: translateY(-3px);
    box-shadow: 0 12px 28px rgba(107,91,142,0.42);
}
a.footer_line_but:hover {
    background: linear-gradient(135deg, #00b900, #06c755);
    box-shadow: 0 12px 28px rgba(0,185,0,0.45);
}
a.footer_sns:hover::before {
    opacity: 1;
}
a.footer_sns span {
    margin-top: 0;
    text-align: center;
    display: inline-block;
    font-size: 1em;
    font-weight: 600;
    font-family: "Lato", sans-serif;
    color: #ffffff;
    letter-spacing: .15em;
}
ul.footer-content-list-outer {
    width: 100%;
    margin-bottom: 14px;
    box-sizing: border-box;
}
ul.footer-content-list-outer:last-child {
    padding-right: 0;
    margin-bottom: 0;
}
ul.footer-content-list-outer li {
    font-size: 0.82em;
    font-weight: 600;
    font-family: "Noto Sans JP", sans-serif;
    letter-spacing: .12em;
    line-height: 1.5;
    padding-left: 18px;
    margin-bottom: 14px;
    position: relative;
    transition: padding-left 0.4s cubic-bezier(.2,.7,.2,1);
}
ul.footer-content-list-outer li:last-of-type {
    margin-bottom: 0;
}
ul.footer-content-list-outer li:before {
    content: '';
    position: absolute;
    width: 8px;
    height: 1px;
    background: #6b5b8e;
    top: 11px;
    left: 0;
    transition: all 0.4s cubic-bezier(.2,.7,.2,1);
    transform: none;
}
ul.footer-content-list-outer li:hover {
    padding-left: 24px;
}
ul.footer-content-list-outer li:hover::before {
    width: 14px;
    background: #c8a96a;
}
ul.footer-content-list-outer li a {
    color: #2d2438;
    transition: color 0.4s ease;
    text-decoration: none;
}
ul.footer-content-list-outer li a span{
    display: none;
}
ul.footer-content-list-outer li a:hover {
    color: #6b5b8e;
}
.footer-content {
    display: none;
}

/* ============================================
   ページトップ・コピーライト
   ============================================ */
.pagetop {
    right: 24px;
    bottom: 28px;
}
.pagetop a {
    background: none;
    color: transparent;
    position: relative;
    width: 52px;
    height: 52px;
    font-size: 0;
    font-weight: 400;
    line-height: 1;
    font-family: "Lato", sans-serif;
    display: block;
}
.pagetop a::before {
    position: absolute;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    background: linear-gradient(135deg, #6b5b8e, #a99bc4);
    width: 52px;
    height: 52px;
    line-height: 52px;
    font-size: 14px;
    text-align: center;
    border-radius: 50%;
    right: 0;
    top: 0;
    bottom: auto;
    z-index: 1;
    transition: all 0.5s cubic-bezier(.2,.7,.2,1);
    content: '↑';
    box-shadow: 0 8px 20px rgba(107,91,142,0.35);
}
.pagetop a:hover {
    color: transparent;
    background: none;
}
.pagetop a:hover::before {
    bottom: auto;
    top: -4px;
    background: linear-gradient(135deg, #4a3f6b, #6b5b8e);
    box-shadow: 0 12px 28px rgba(107,91,142,0.5);
}
.copyright {
    font-size: 11px;
    color: #5a4f6b;
    letter-spacing: .1em;
}
.footer-bar01, .footer-bar01-inner, .copyright {
    background: none;
}
.footer-bar01 {
    padding: 18px 0;
    border-top: 1px solid rgba(125,108,160,0.15);
    background: #faf8fc;
}

/* ============================================
   レスポンシブ
   ============================================ */
@media only screen and (max-width: 1200px) {
    .header-youtube, .header-video, .top-slider {
        height: calc(80vh - 80px);
    }
    .content02-item {
        width: calc((100% - 36px) / 3);
    }
}
@media only screen and (max-width: 970px) {
    .header-youtube, .header-video, .top-slider {
        height: calc(60vh - 55px);
    }
    .front_original01 {
        padding: 5em 0;
    }
    .front-original01__title {
        width: 100%;
        margin-bottom: 1.8em;
        padding-right: 0;
    }
    .front-original01__text {
        width: 100%;
        padding-left: 0;
        border-left: none;
        border-top: 1px solid rgba(125,108,160,0.25);
        padding-top: 1.8em;
    }
    .front-original01__title h3 {
        line-height: 1.7;
        font-size: 1.55em;
    }
    .content02 {
        padding: 5em 0 4em;
    }
    .content02-inner {
        display: flex;
        padding-top: 50px;
        padding-bottom: 0;
        gap: 28px;
    }
    .content02-item {
        width: 100%;
        margin-left: 0;
    }
    .content02-item:nth-of-type(2) {
        top: 0;
    }
    .content02-item:nth-of-type(3) {
        top: 0;
    }
    .front_original02 {
        padding: 5em 0;
    }
    .front-original02-inner {
        flex-wrap: wrap;
    }
    .front-original02__text {
        width: 100%;
        margin-top: 0;
        order: 2;
    }
    .front-original02__img {
        width: 100%;
        margin-left: 0;
        order: 1;
        margin-bottom: 2em;
    }
    .front_original02::after {
        font-size: 14em;
        right: -20px;
    }
    .front_original03 {
        padding: 6em 0 5em;
    }
    .third-box {
        margin-bottom: 50px;
    }
    .front-third-text {
        width: 100%;
        padding-bottom: 1.5em;
        padding-top: 1.5em;
    }
    .third-box:nth-of-type(odd) .front-third-text {
        padding-left: 0;
        margin-left: 0;
    }
    .third-box:nth-of-type(even) .front-third-text {
        padding-right: 0;
    }
    .front-third-img {
        width: 100%;
    }
    .third-box:nth-of-type(odd) .front-third-img {
        margin-left: 0;
    }
    .footer_contact_inner {
        gap: 24px;
        padding-top: 100px;
    }
    .footer_contact_bg {
        width: 100%;
        padding: 32px 28px;
    }
    .footer_menu_bg {
        width: 100%;
        padding: 32px 28px;
    }
    .dp-footer-bar {
        background: #6b5b8e !important;
        border-top: 1px solid #6b5b8e !important;
    }
    .dp-footer-bar-item + .dp-footer-bar-item {
        border-left: 1px solid rgba(255,255,255,0.4) !important;
    }
    .dp-footer-bar a {
        color: #fff;
    }
    .dp-footer-bar-item {
        font-size: 11px;
    }
    .dp-footer-bar-icon:before {
        font-weight: 500;
    }
}
@media only screen and (max-width: 768px) {
    .header-youtube, .header-video, .top-slider {
        height: calc(100vh - 55px);
    }
    .top-slider-wrapper {
        width: calc(100% - 30px);
    }
    .top-slider-wrapper::before {
        height: 20px;
    }
    .top-slider-wrapper::after {
        bottom: 30px;
    }
    .front_original01 {
        padding: 3.5em 0;
    }
    .front-original01__title h2 {
        margin-bottom: 16px;
        font-size: 1em;
    }
    .front-original01__title h3 {
        font-size: 1.35em;
    }
    .front-original01__text p {
        margin-bottom: 14px;
    }
    .content02 {
        width: calc(100% - 24px);
        padding: 3.5em 0 3em;
        border-radius: 22px;
    }
    .content02-inner {
        padding-top: 30px;
    }
    h2.content02_title {
        font-size: 1.7em;
    }
    h2.content02_title::after {
        margin-top: 18px;
    }
    .content02-item {
        padding: 22px 20px 26px;
        border-radius: 18px;
    }
    .front_original02 {
        padding: 3.5em 0;
    }
    .front_original02::before {
        width: calc(100% - 24px);
        left: 12px;
        border-radius: 22px;
    }
    .front_original02::after {
        font-size: 10em;
    }
    .front-original02__text {
        padding: 32px 24px;
    }
    .front-original02__text h2 {
        font-size: 1.3em;
        margin-bottom: 14px;
    }
    .front_original03 {
        padding: 4em 0 3em;
    }
    .front_original03::before {
        top: 30px;
    }
    .front_original03::after {
        font-size: 1.5em;
        top: 58px;
    }
    .front-original03-inner {
        padding-top: 70px;
    }
    .front-third-text::before {
        font-size: 3.6em;
    }
    h3.third_title {
        font-size: 1.25em;
    }
    .front_topics {
        padding: 3.5em 0 3em;
        width: calc(100% - 24px);
        border-radius: 22px;
    }
    h2.front_topics_title {
        font-size: 1.7em;
        margin-bottom: 30px;
    }
    h2.front_topics_title::after {
        margin-top: 18px;
    }
    .footer_contact_sec {
        padding: 3.5em 0 2.5em;
    }
    .footer_contact_sec::after {
        font-size: 1.35em;
    }
    .footer_contact_inner {
        padding-top: 90px;
    }
    .footer_contact_bg, .footer_menu_bg {
        width: 100%;
    }
    .footer_menu_bg {
        padding-left: 28px;
        margin-top: 0;
    }
    address.footer_tel {
        font-size: 1.5em;
    }
    ul.footer-content-list-outer {
        width: 50%;
        margin-bottom: 0;
    }
    .social-nav {
        width: 90%;
        margin: auto;
    }
    .pagetop {
        bottom: 80px !important;
        right: 14px;
    }
    .pagetop a, .pagetop a::before {
        width: 44px;
        height: 44px;
        line-height: 44px;
    }
    a.footer_sns {
        padding: 12px 22px;
        font-size: 0.8em;
    }
}
@media only screen and (max-width: 500px) {
    .header-youtube, .header-video, .top-slider {
        height: calc(60vh - 60px);
    }
    .front-copy-img {
        width: 90%;
    }
    ul.footer-content-list-outer {
        width: 100%;
        margin-bottom: 14px;
    }
    ul.footer-content-list-outer:last-child {
        margin-bottom: 0;
    }
    .footer-original02__text::before, .front-original02__text::before {
        font-size: 0.62em;
    }
    .front_original02::after {
        font-size: 8em;
    }
    dt.address_title {
        width: 80px;
    }
    dd.address_text {
        width: calc(100% - 80px);
    }
}
@media only screen and (max-height: 400px) {
    .top-slider {
        height: 100vh;
    }
}

/* ============================================
   吉粋工業 FV (ファーストビュー)
   - 背景: 草刈り職人の写真をKen Burnsアニメ
   - キャッチコピー: 行ごとの時差スライドアップ
   - レイアウト: デスクトップは右寄せ、モバイルは下寄せ
   ============================================ */

/* --- 既存の SCROLL 表記を非表示化（新FVスクロール表示と競合するため） --- */
.top-slider-wrapper::before,
.top-slider-wrapper::after {
    content: none !important;
}

/* --- スライダーラッパー全体 --- */
.top-slider-wrapper {
    width: 100% !important;
    margin: 0 !important;
    position: relative;
    overflow: hidden;
    background: #1a1326;
}

/* --- 背景画像エリア (Ken Burnsズームアニメ) --- */
.top-slider,
.top-slider-item,
.top-slider-item span,
.header-video,
.header-youtube {
    width: 100% !important;
    height: 100% !important;
}

.top-slider {
    height: 100vh !important;
}

/* 子テーマで直接画像指定する場合のフォールバック背景
   ※ 子テーマのimg/フォルダに「fv-main.jpg」を配置すれば
   　 親テーマでスライダー画像を未設定でもこの画像がFVに表示される */
.top-slider-wrapper {
    background-image: url('img/fv-main.jpg');
    background-size: cover;
    background-position: center 30%;
    background-repeat: no-repeat;
}

/* スライダーが空の時の保険レイヤー（Ken Burnsズーム適用） */
.top-slider-wrapper::before {
    content: '' !important;
    position: absolute !important;
    inset: 0 !important;
    width: auto !important;
    height: auto !important;
    background-image: url('img/fv-main.jpg');
    background-size: cover;
    background-position: center 30%;
    background-repeat: no-repeat;
    background-color: transparent !important;
    z-index: 0;
    animation: yoshisuiKenBurns 24s ease-in-out infinite alternate;
    transform-origin: center center;
}

/* 親テーマがスライダー画像を表示する場合、その画像にもKen Burnsを適用 */
.top-slider-item span,
.header-video,
.header-youtube.bg-image {
    animation: yoshisuiKenBurns 24s ease-in-out infinite alternate;
    transform-origin: center center;
}

@keyframes yoshisuiKenBurns {
    0% {
        transform: scale(1.0) translate(0, 0);
    }
    50% {
        transform: scale(1.08) translate(-1.5%, -0.5%);
    }
    100% {
        transform: scale(1.15) translate(1%, 0.5%);
    }
}

/* --- 紫グラデーションオーバーレイ（右寄せ用：右側を濃くして可読性確保） --- */
.yoshisui-fv-overlay {
    position: absolute;
    inset: 0;
    z-index: 5;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    padding: 0 6% 0 8%;
    background:
        linear-gradient(
        -75deg,
        rgba(28, 20, 50, 0.78) 0%,
        rgba(45, 30, 70, 0.62) 25%,
        rgba(74, 63, 107, 0.38) 50%,
        rgba(74, 63, 107, 0.18) 75%,
        rgba(74, 63, 107, 0.05) 100%
        ),
        linear-gradient(
        180deg,
        rgba(0, 0, 0, 0.22) 0%,
        transparent 25%,
        transparent 75%,
        rgba(0, 0, 0, 0.32) 100%
        );
    pointer-events: none;
}
.yoshisui-fv-overlay::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(rgba(255,255,255,0.04) 1px, transparent 1px);
    background-size: 3px 3px;
    pointer-events: none;
    opacity: 0.5;
    mix-blend-mode: overlay;
}

/* --- インナー（テキスト群、右寄せ） --- */
.yoshisui-fv-inner {
    position: relative;
    z-index: 2;
    max-width: 640px;
    width: 100%;
    color: #ffffff;
    pointer-events: auto;
    text-align: left;
}

/* --- アイブロウ（YOSHISUI KOGYO 英字） --- */
.yoshisui-fv-eyebrow {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 32px;
    opacity: 0;
    animation: yoshisuiFvFadeDown 1s cubic-bezier(.2,.7,.2,1) 0.4s forwards;
}
.yoshisui-fv-eyebrow-line {
    display: block;
    width: 56px;
    height: 1px;
    background: linear-gradient(90deg, #c8a96a, rgba(200,169,106,0.2));
    transform: scaleX(0);
    transform-origin: left;
    animation: yoshisuiFvLineGrow 1.2s cubic-bezier(.2,.7,.2,1) 0.6s forwards;
}
.yoshisui-fv-eyebrow-text {
    font-family: "Lato", sans-serif;
    font-size: 0.85em;
    font-weight: 600;
    letter-spacing: 0.4em;
    color: #d4b87f;
    text-transform: uppercase;
}

/* --- メインヘッドライン --- */
.yoshisui-fv-headline {
    font-family: "Noto Serif JP", "游明朝", YuMincho, "Hiragino Mincho ProN", serif;
    font-size: clamp(24px, 3.2vw, 46px);
    font-weight: 600;
    line-height: 1.6;
    letter-spacing: 0.04em;
    margin: 0 0 28px;
    color: #ffffff;
    text-shadow: 0 4px 24px rgba(0, 0, 0, 0.5);
}
.yoshisui-fv-headline-row {
    display: block;
    overflow: hidden;
    line-height: 1.55;
    white-space: nowrap;
}
.yoshisui-fv-headline-inner {
    display: inline-block;
    transform: translateY(110%);
    opacity: 0;
}
.yoshisui-fv-headline-row:nth-child(1) .yoshisui-fv-headline-inner {
    animation: yoshisuiFvSlideUp 1.1s cubic-bezier(.2,.7,.2,1) 0.9s forwards;
}
.yoshisui-fv-headline-row:nth-child(2) .yoshisui-fv-headline-inner {
    animation: yoshisuiFvSlideUp 1.1s cubic-bezier(.2,.7,.2,1) 1.15s forwards;
}

/* --- サブライン --- */
.yoshisui-fv-subline {
    font-family: "Noto Sans JP", sans-serif;
    font-size: clamp(13px, 1.05vw, 16px);
    font-weight: 500;
    letter-spacing: 0.18em;
    color: rgba(255, 255, 255, 0.92);
    margin: 0;
    display: flex;
    align-items: center;
    gap: 14px;
    opacity: 0;
    animation: yoshisuiFvFadeIn 1.2s cubic-bezier(.2,.7,.2,1) 1.7s forwards;
    text-shadow: 0 2px 12px rgba(0,0,0,0.4);
}
.yoshisui-fv-subline-mark {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #c8a96a;
    box-shadow: 0 0 0 4px rgba(200,169,106,0.2);
    animation: yoshisuiFvPulse 2.4s ease-in-out infinite;
    flex-shrink: 0;
}

/* --- スクロールインジケーター（デスクトップは左下、モバイルは下中央） --- */
.yoshisui-fv-scroll {
    position: absolute;
    bottom: 40px;
    left: 5%;
    transform: none;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    z-index: 10;
    opacity: 0;
    animation: yoshisuiFvFadeIn 1s cubic-bezier(.2,.7,.2,1) 2.4s forwards;
}
.yoshisui-fv-scroll-text {
    font-family: "Lato", sans-serif;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.4em;
    color: rgba(255, 255, 255, 0.85);
}
.yoshisui-fv-scroll-line {
    display: block;
    width: 1px;
    height: 56px;
    background: linear-gradient(180deg, rgba(255,255,255,0.8), rgba(255,255,255,0));
    position: relative;
    overflow: hidden;
}
.yoshisui-fv-scroll-line::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 30%;
    background: linear-gradient(180deg, transparent, #c8a96a);
    animation: yoshisuiFvScrollDown 2.2s cubic-bezier(.6,0,.4,1) infinite;
}

/* --- アニメーション定義 --- */
@keyframes yoshisuiFvFadeDown {
    0% { opacity: 0; transform: translateY(-12px); }
    100% { opacity: 1; transform: translateY(0); }
}
@keyframes yoshisuiFvLineGrow {
    0% { transform: scaleX(0); }
    100% { transform: scaleX(1); }
}
@keyframes yoshisuiFvSlideUp {
    0% { transform: translateY(110%); opacity: 0; }
    100% { transform: translateY(0); opacity: 1; }
}
@keyframes yoshisuiFvFadeIn {
    0% { opacity: 0; transform: translateY(8px); }
    100% { opacity: 1; transform: translateY(0); }
}
@keyframes yoshisuiFvPulse {
    0%, 100% {
        box-shadow: 0 0 0 4px rgba(200,169,106,0.2);
        transform: scale(1);
    }
    50% {
        box-shadow: 0 0 0 8px rgba(200,169,106,0);
        transform: scale(1.15);
    }
}
@keyframes yoshisuiFvScrollDown {
    0% { top: -30%; }
    100% { top: 130%; }
}

/* --- 既存の丸ボタン(top-slider-content)と被らないよう調整 --- */
#top-slider-content {
    z-index: 8;
}

/* --- レスポンシブ --- */
@media only screen and (max-width: 1100px) {
    .yoshisui-fv-overlay {
        padding: 0 5% 0 8%;
    }
    .yoshisui-fv-inner {
        max-width: 540px;
    }
}
@media only screen and (max-width: 970px) {
    .yoshisui-fv-overlay {
        justify-content: flex-start;
        padding: 0 6%;
        background:
            linear-gradient(
            100deg,
            rgba(28, 20, 50, 0.72) 0%,
            rgba(45, 30, 70, 0.55) 40%,
            rgba(74, 63, 107, 0.3) 80%,
            rgba(74, 63, 107, 0.2) 100%
            ),
            linear-gradient(
            180deg,
            rgba(0, 0, 0, 0.2) 0%,
            transparent 30%,
            transparent 70%,
            rgba(0, 0, 0, 0.3) 100%
            );
    }
    .yoshisui-fv-inner {
        max-width: 100%;
    }
    .yoshisui-fv-eyebrow {
        margin-bottom: 24px;
    }
    .yoshisui-fv-eyebrow-line {
        width: 40px;
    }
}
@media only screen and (max-width: 768px) {
    /* === スマホ FV: 横長帯レイアウト（B案: 16:13画像 + 下部テキスト重ね）=== */
    /* 親テーマの 100vh 高さ指定を上書きし、画像のアスペクト比でFV高さを決める */
    .top-slider-wrapper {
        height: auto !important;
        aspect-ratio: 16 / 13;
        background-position: 42% center;
        background-size: cover;
    }
    .top-slider-wrapper::before {
        background-position: 42% center;
    }
    /* 親テーマのスライダー要素の高さ強制リセット */
    .header-youtube,
    .header-video,
    .top-slider,
    .top-slider-item,
    .top-slider-item span {
        height: 100% !important;
    }

    /* オーバーレイ：画像下半分にだけ紫グラデを重ねる */
    .yoshisui-fv-overlay {
        justify-content: flex-start;
        align-items: flex-end;
        padding: 0 22px;
        padding-bottom: 22px;
        background:
            linear-gradient(
            180deg,
            rgba(20, 14, 36, 0) 0%,
            rgba(20, 14, 36, 0) 35%,
            rgba(28, 20, 50, 0.4) 60%,
            rgba(45, 30, 70, 0.78) 90%,
            rgba(74, 63, 107, 0.88) 100%
            );
    }
    .yoshisui-fv-overlay::after {
        opacity: 0.3;
    }

    /* テキスト群はコンパクトに */
    .yoshisui-fv-inner {
        max-width: 100%;
    }
    .yoshisui-fv-eyebrow {
        margin-bottom: 10px;
        gap: 10px;
    }
    .yoshisui-fv-eyebrow-line {
        width: 28px;
    }
    .yoshisui-fv-eyebrow-text {
        font-size: 0.62em;
        letter-spacing: 0.28em;
    }
    .yoshisui-fv-headline {
        font-size: 19px;
        margin-bottom: 10px;
        line-height: 1.55;
        letter-spacing: 0.02em;
    }
    .yoshisui-fv-headline-row {
        white-space: normal;
    }
    .yoshisui-fv-subline {
        font-size: 10.5px;
        letter-spacing: 0.08em;
        gap: 8px;
    }
    .yoshisui-fv-subline-mark {
        width: 6px;
        height: 6px;
    }

    /* スクロールインジケータは画像の右上に小さく配置 */
    .yoshisui-fv-scroll {
        bottom: auto;
        top: 18px;
        left: auto;
        right: 18px;
        transform: none;
        gap: 6px;
    }
    .yoshisui-fv-scroll-text {
        font-size: 8px;
        letter-spacing: 0.3em;
    }
    .yoshisui-fv-scroll-line {
        height: 28px;
    }
}
@media only screen and (max-width: 500px) {
    .top-slider-wrapper {
        aspect-ratio: 16 / 13;
    }
    .yoshisui-fv-headline {
        font-size: 18px;
        line-height: 1.6;
    }
    .yoshisui-fv-subline {
        font-size: 10px;
    }
}
/* === 吉粋工業 FV END === */

/* トップ・フッター END */
/* 固定ページ */
.page .post-header {
    margin: 0px;
}
.content_inner {
    width: 86%;
    max-width: 1150px;
    margin: 0px auto;
    padding: 100px 0;
    box-sizing: border-box;
    position: relative;
}
.post-content h2 {
    font-size: 1.6em;
    letter-spacing: .03em;
    line-height: 1.8;
    margin-bottom: 30px;
    padding-top: 0;
    font-weight: 600;
    text-align: center;
}
.post-content h2::after {
    content: "";
    display: block;
    background: #7d6ca0;
    width: 20px;
    height: 2px;
    margin: 20px auto 0;
    transform: rotate(-50deg);
    z-index: 1;
}
.post-content h3 {
    font-size: 1.3em;
    font-weight: 600;
    padding: 0;
    margin-bottom: 15px;
    line-height: 1.5;
    color: #7d6ca0;
}
.post-content h4 {
    font-size: 1.2em;
    margin-bottom: 15px;
    line-height: 1.5;
    font-weight: 600;
    padding: 0;
}
.post-content table {
    margin: 0;
}
.post-content th, .post-content td {
    font-size: 0.95em;
    font-weight: 400;
    vertical-align: middle;
    line-height: 1.8;
    padding: 22px 2px 18px;
    background: none;
    border: 0;
    border-bottom: 1px #d6d6d6 solid;
}
.post-content th {
    width: 20%;
    text-align: left;
    border-right: none;
}
.post-content td {
    border-left: none;
}
@media only screen and (max-width: 1200px) {
    .content_inner {
        padding: 80px 0;
    }
}
@media only screen and (max-width: 970px) {
    .post-content th, .post-content td {
        padding: 14px 4px 10px;
        line-height: 1.5;
        display: block;
        box-sizing: border-box;
        margin-top: -1px;
        width: 100% !important;
    }
    .post-content th {
        border-bottom: none;
        padding-bottom: 0;
    }
    .post-content td {
        border-top: none;
    }
}
@media only screen and (max-width: 768px) {
    .content_inner {
        padding: 50px 0;
    }
    .post-content h2 {
        font-size: 1.3em;
        line-height: 1.5;
        margin-bottom: 20px;
    }
    .post-content h2::after {
        width: 15px;
    }
    .post-content h3 {
        font-size: 1.1em;
        margin-bottom: 10px;
    }
}
/* 固定ページ END */
/* お知らせ */
.archive.category .main, .post-template-default .main, .blog .main {
    padding-bottom: 100px;
}
h2.archive-title {
    font-weight: 600;
    color: #000;
}
.archive-header {
    margin: 90px 0px 40px;
}
.article03 {
    background: #fff;
    box-sizing: border-box;
    border: 1px solid #cae1e6;
}
.article03-content {
    padding: 15px;
}
.article03-title {
    font-size: 0.85em;
    font-weight: 400;
    line-height: 1.5;
    color: #000;
}
.article03-category-item:hover, .article03 a:hover .article03-title {
    text-decoration: none;
}
.post-title, .post-meta {
    color: #000;
    font-weight: 600;
}
.nav-links01 {
    border-top: 1px solid #d6d6d6;
    border-bottom: 1px solid #d6d6d6;
}
.nav-links01-previous + .nav-links01-next {
    border-left: 1px solid #d6d6d6;
}
.article01-title a {
    font-size: 0.9em;
    font-weight: 600;
    color: #000;
}
.nav-links01-previous a::before, .nav-links01-next a::after {
    font-size: 15px;
    font-weight: 600;
}
.post-meta-box {
    background: #f5f2f8;
}
.post-meta-box-item::before {
    color: #000;
}
.primary {
    width: 100%;
}
.headline-bar {
    color: #000;
    font-weight: 600;
    background: #f5f2f8;
}
@media only screen and (max-width: 1200px) {
    .archive.category .main, .post-template-default .main {
        padding-bottom: 80px;
    }
    .article03-title {
        margin: 0;
        overflow: hidden;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        line-clamp: 2;
        -webkit-box-orient: vertical;
        height: auto;
    }
}
@media only screen and (max-width: 970px) {
    .post-meta-box-item {
        padding: 8px 0px 8px 20px;
        margin-left: 15px;
    }
}
@media only screen and (max-width: 768px) {
    .archive.category .main, .post-template-default .main {
        padding-bottom: 30px;
    }
    .archive-header {
        margin: 50px 0px 30px;
    }
    h2.archive-title {
        font-size: 25px !important;
    }
    h1.post-title {
        font-size: 1.2em !important;
    }
    .nav-links01-previous a::before, .nav-links01-next a::after {
        color: #000;
    }
    .article04-title {
        font-size: 15px;
    }
    .nav-links01 {
        border: 1px solid #d6d6d6;
    }
}
@media only screen and (max-width: 500px) {
    .post-title, .post-meta {
        text-align: left;
    }
    .article03-title {
        font-size: 10px;
        margin-top: 0;
    }
}
/* お知らせ END */
/* コンテンツ 共通 */
.flex-inner {
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
}
p.caution {
    line-height: 1.5;
    margin-bottom: 5px;
    padding-left: 15px;
    position: relative;
    box-sizing: border-box;
}
p.caution:last-of-type {
    margin-bottom: 0;
}
p.caution::before {
    content: '※';
    position: absolute;
    left: 0;
    color: #f35d63;
}
span.caution {
    position: relative;
    padding-left: 17px;
    line-height: 1.8;
    box-sizing: border-box;
    display: inline-block;
}
span.caution::before {
    content: '※';
    position: absolute;
    left: 0;
    top: 0;
    color: #ff5353;
}
ul.list {
    margin: 0;
    list-style: none;
}
ul.list li {
    padding-left: 18px;
    line-height: 2;
    margin-bottom: 10px;
    box-sizing: border-box;
    position: relative;
}
ul.list li:last-child {
    margin-bottom: 0;
}
ul.list li::before {
    content: '';
    position: absolute;
    background: #7d6ca0;
    width: 7px;
    height: 7px;
    top: 11px;
    left: 0;
}
ul.list.caution_list li::before {
    content: '※';
    background: none;
    top: 0;
}
/* コンテンツ 共通 END */
/* 撮影料金 */
.price_sec .content_inner {
    max-width: 900px;
}
.menu_box {
    margin-bottom: 80px;
}
.menu_box:last-of-type {
    margin-bottom: 0;
}
.menu_box h2 {
    font-size: 1.3em;
    margin-bottom: 10px;
    line-height: 1.5;
    text-align: left;
}
.menu_box h2::before {
    counter-increment: number 1;
    content: "MENU."counter(number) "";
    width: 100%;
    font-size: 0.85em;
    font-weight: 700;
    font-family: "Lato", sans-serif;
    margin-bottom: 10px;
    color: #7d6ca0;
    display: block;
}
.menu_box h2::after {
    content: none;
}
.menu_box p {
    margin-bottom: 10px;
}
.menu_box p:last-child {
    margin-bottom: 0;
}
.menu_text {
    width: 55%;
    padding-right: 2.5em;
    box-sizing: border-box;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    display: -webkit-flex;
    display: flex;
}
.menu_img {
    width: 45%;
    box-sizing: border-box;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    display: -webkit-flex;
    display: flex;
}
.menu_text h2, .menu_text p {
    width: 100%;
}
a.menu_con_but {
    width: 100%;
    max-width: 250px;
    margin-top: 12px;
    padding: 10px 18px;
    font-size: 0.9em;
    font-weight: 600;
    letter-spacing: .05em;
    display: block;
    color: #fff;
    background: #7d6ca0;
    border-radius: 100px;
    box-sizing: border-box;
    position: relative;
}
a.menu_con_but::after {
    content: '\ea3c';
    font-family: "design_plus";
    position: absolute;
    display: block;
    right: 17px;
    top: 11px;
    font-weight: 400;
}
a.menu_con_but:hover {
    background: #a99bc4;
    color: #fff;
}
table.price_tbl th {
    width: 55%;
}
span.price_caution {
    font-size: 0.9em;
    letter-spacing: .05em;
}
span.option {
    padding: 2px 5px;
    margin-bottom: 5px;
    font-size: 0.8em;
    font-weight: 500;
    letter-spacing: 0;
    color: #fff;
    background: #000;
    display: inline-block;
}
@media only screen and (max-width: 768px) {
    .menu_box {
        margin-bottom: 40px;
    }
    .menu_text {
        width: 100%;
        padding-right: 0;
        margin-bottom: 1.5em;
    }
    .menu_img {
        width: 100%;
    }
}
/* 撮影料金 END */
/* ポートフォリオ*/
.portfolio_sec .content_inner {
    max-width: 900px;
}
.portfolio {
    border-bottom: 1px solid #d6d6d6;
    padding-bottom: 60px;
    margin-bottom: 50px;
}
.portfolio:last-of-type {
    border-bottom: 0;
    padding-bottom: 0;
    margin-bottom: 0;
}
@media only screen and (max-width: 768px) {
    .portfolio {
        padding-bottom: 30px;
        margin-bottom: 25px;
    }
}
/* ポートフォリオ END */
/* 撮影の流れ */
.flow_sec .content_inner {
    max-width: 900px;
}
.flow {
    padding-left: 70px;
    padding-top: 10px;
    padding-bottom: 40px;
    position: relative;
    box-sizing: border-box;
    z-index: 0;
}
.flow:last-of-type {
    padding-bottom: 0;
}
.flow::before {
    counter-increment: number 1;
    content: counter(number)"";
    position: absolute;
    text-align: center;
    width: 45px;
    height: 55px;
    line-height: 52px;
    border-top: 1px solid;
    border-bottom: 1px solid;
    font-size: 35px;
    font-weight: 400;
    font-family: "Lato", sans-serif;
    color: #7d6ca0;
    background: #fff;
    box-sizing: border-box;
    top: 0;
    left: 0;
    z-index: 0;
}
.flow::after {
    content: '';
    position: absolute;
    top: 0;
    left: 22px;
    width: 1px;
    height: 100%;
    background: #7d6ca0;
    z-index: -1;
}
.flow:last-of-type::after {
    display: none;
}
.flow h2 {
    font-size: 1.3em;
    font-weight: 600;
    line-height: 1.5;
    margin-bottom: 15px;
    text-align: left;
}
.flow h2::after {
    content: none;
}
.flow p {
    margin-bottom: 0;
}
a.flow_con_but {
    width: 100%;
    max-width: 300px;
    margin-top: 15px;
    padding: 12px 20px;
    font-weight: 600;
    letter-spacing: .05em;
    display: block;
    color: #fff;
    background: #7d6ca0;
    border-radius: 100px;
    box-sizing: border-box;
    position: relative;
}
a.flow_con_but::after {
    content: '\ea3c';
    font-family: "design_plus";
    position: absolute;
    display: block;
    right: 20px;
    top: 13px;
    font-weight: 400;
}
a.flow_con_but:hover {
    background: #a99bc4;
    color: #fff;
}
@media only screen and (max-width: 768px) {
    .flow {
        padding-top: 7px;
        padding-left: 55px;
        padding-bottom: 25px;
    }
    .flow::before {
        width: 35px;
        height: 45px;
        line-height: 40px;
        font-size: 30px;
    }
    .flow::after {
        left: 17px;
    }
}
/* 撮影の流れ END */
/* ご挨拶 */
.greeting__img {
    width: 30%;
    box-sizing: border-box;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    display: -webkit-flex;
    display: flex;
    z-index: -1;
}
.greeting__text {
    width: 70%;
    padding-left: 2.5em;
    box-sizing: border-box;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    display: -webkit-flex;
    display: flex;
}
.greeting__text h2, .greeting__text p {
    width: 100%;
}
.greeting__text h2 {
    padding-left: 30px;
    text-align: left;
    position: relative;
    box-sizing: border-box;
}
.greeting__text h2::after {
    position: absolute;
    display: inline-block;
    left: 0;
    top: 3px;
    transform: rotate(0deg);
}
.greeting__text p {
    margin-bottom: 20px;
}
.greeting__text p:last-of-type {
    margin-bottom: 0;
}
@media only screen and (max-width: 768px) {
    .greeting__img {
        width: 100%;
        max-width: 330px;
        padding-right: 0;
    }
    .greeting__text {
        width: 100%;
        padding-left: 0;
        margin-top: 2em;
    }
    .greeting__text h2::after {
        top: -4px;
    }
}
/* ご挨拶 END */
/* 運営概要 */
.company_sec .content_inner {
    max-width: 800px;
}
table.company_tbl th {
    width: 28%;
}
span.company_holiday {
    padding: 2px 5px;
    margin-bottom: 10px;
    font-weight: 600;
    background: #000;
    color: #fff;
    display: inline-block;
    box-sizing: border-box;
}
span.caution.company-caution {
    font-size: 0.8em;
    letter-spacing: .05em;
    display: block;
}
/* 運営概要 END */
/* ----------------------------------------------------------------------
 Contactform - お問い合わせフォーム
---------------------------------------------------------------------- */
.wpcf7 {
    width: 100%;
    border: 1px solid #ddd;
    background: #fafafa;
    padding: 0;
    margin: 0 0 2.5em !important;
    font-size: 14px;
}

.wpcf7 form {
    margin: 1.5em 1.5em 0;
}

.wpcf7 p {
    margin-bottom: 1em;
    font-size: 12px;
}

.wpcf7 input, .wpcf7 textarea {
    width: auto;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    width: 100%;
    border: 1px solid #ccc;
    line-height: 1.2;
    padding: 8px;
}

.wpcf7 select, .wpcf7 input[type=checkbox], .wpcf7 input[type=radio] {
    width: auto;
    max-width: 97%;
    border: 1px solid #ccc;
    padding: 8px;
}

.wpcf7 select, .wpcf7 .wpcf7-list-item-label {
    line-height: 1.2;
    font-size: 14px;
}

.wpcf7-list-item {
    display: block;
}

.wpcf7 textarea {
    height: 300px;
}

.wpcf7 input:focus, .wpcf7 textarea:focus {
    outline: none;
    border: 1px solid #bbb;
    -webkit-box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.2);
    box-shadow: inner 0 0 5px rgba(0, 0, 0, 0.5);
}

.wpcf7 input.wpcf7-submit, .wpcf7 .wpcf7-previous {
    position: relative;
    display: block;
    width: 225px;
    height: 48px;
    margin: 30px auto 0;
    background-color: #333333;
    cursor: pointer;
    border: none !important;
    color: #fff;
    text-align: center;
    text-decoration: none;
    font-size: 14px;
    line-height: 1.5;
    outline: none;
    -webkit-transition: all .3s;
    transition: all .3s;
}

.wpcf7 input.wpcf7-submit, .wpcf7 input.wpcf7-submit::before, .wpcf7 input.wpcf7-submit::after {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

.wpcf7 input.wpcf7-submit:hover, .wpcf7 .wpcf7-previous:hover {
    background-color: #666666;
}

.wpcf7 .wpcf7-not-valid {
    background: pink;
}

.wpcf7 .wpcf7-response-output {
    margin: 10px 0 0;
    padding: 8px 35px 8px 14px;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    border-radius: 4px;
}

.wpcf7 .wpcf7-validation-errors {
    color: #B94A48;
    background-color: #F2DEDE;
    border: 1px solid #EED3D7;
}

.wpcf7 .wpcf7-mail-sent-ok {
    color: #3A87AD;
    background-color: #D9EDF7;
    border: 1px solid #BCE8F1;
}

.wpcf7 .wpcf7-previous + br {
    display: none;
}

.wpcf7 form .wpcf7-response-output{
    margin: 2em 0.5em 2em; padding:0; border: none; text-align:center;
}

.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output{
    color:#dc3232; font-size: 1em;
}

/* ----------------------------------------------------------------------
 font-size - フォントサイズ
---------------------------------------------------------------------- */
/* お問い合わせ */
.contact_sec .content_inner, .mail_sec .content_inner {
    max-width: 1000px;
}
.contact_sec .content_inner {
    padding-bottom: 0;
}
.con__inner {
    margin-bottom: 40px;
}
.con__inner:last-of-type {
    margin-bottom: 0;
}
.con__inner p {
    margin-bottom: 0;
}
address.con_tel {
    font-size: 2.5em;
    font-style: normal;
    letter-spacing: .05em;
    font-weight: 700;
    margin-bottom: 15px;
    line-height: 1;
    color: #3eb926;
    text-align: center;
}
address.con_tel a {
    color: #3eb926;
}
span.con_tel_sub {
    font-size: 0.5em;
    letter-spacing: 1px;
    margin-right: 5px;
    color: #151515;
}
p.con-time {
    width: fit-content;
    margin: auto;
    margin-bottom: 10px;
    line-height: 1.5;
    font-weight: 600;
}
p.con_time:last-of-type {
    margin-bottom: 0;
}
p.con-time span {
    display: inline-block;
    margin-right: 10px;
    color: #ff870b;
}
p.con_caution {
    font-size: 0.85em;
    width: fit-content;
    margin: 0 auto 10px;
}
.mail_info_box {
    margin-bottom: 30px;
}
.mail_info_box p {
    font-size: 0.9em;
    line-height: 2;
    margin-bottom: 0;
}
@media only screen and (max-width: 768px) {
    address.con_tel {
        font-size: 1.8em;
    }
}
/* お問い合わせ END */
/* お問い合わせフォーム */
span.required {
    font-size: 0.7em;
    line-height: 1.5;
    letter-spacing: 0;
    display: inline-block;
    margin-left: 8px;
    margin-bottom: 8px;
    padding: 3px 5px;
    border-radius: 2px;
    color: #fff;
    background: #ff5353;
}
.wpcf7 {
    border: none;
    background: none;
    margin-bottom: 0 !important;
}
.wpcf7 input, .wpcf7 textarea {
    background: #efefef;
    border: 0;
    padding: 18px;
    box-sizing: border-box;
}
.wpcf7 form {
    margin: 0;
}
.wpcf7 form p {
    font-size: 15px;
    font-weight: 700;
    line-height: 2.5;
    margin-bottom: 22px;
}
.wpcf7 form p:last-of-type {
    margin-bottom: 0;
}
.wpcf7-list-item {
    margin-left: 0;
    margin-top: 8px;
    line-height: 1.5;
    font-weight: 500;
}
.wpcf7 select {
    background: #fff;
}
.wpcf7 input.wpcf7-submit {
    margin-top: 30px;
    width: 100%;
    max-width: 400px;
    margin-left: auto;
    font-size: 1.2em;
    font-weight: 700;
    height: 75px;
    color: #fff;
    background: #3eb926;
    border-radius: 100px;
    transition: all .5s;
    font-family: 'Quicksand', 'Noto Sans JP', "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
}
.wpcf7 input.wpcf7-submit:hover {
    color: #3eb926;
    background: #e0f6dd;
    transform: translateY(8px);
}
.wpcf7 input:focus, .wpcf7 textarea:focus {
    box-shadow: none !important;
}
.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output {
    border: none;
    background: #ffd8df;
    line-height: 1.8;
    padding: 15px 20px;
}
@media only screen and (max-width: 767px) {
    .wpcf7 input.wpcf7-submit {
        margin-top: 20px;
    }
}
/* お問い合わせフォーム END */
/* ブログ記事の画像 */
.single .post-content img {
    width: auto;
}
/* ブログ記事の画像 END */
/* ã‚µãƒ¼ãƒ“ã‚¹æ¡ˆå†… */
.service_sec h2 {
    text-align: left;
}
.service_sec h2::after {
    margin-left: 0;
}
.service_thought {
    padding: 30px 35px;
    margin-bottom: 80px;
    border-radius: 20px;
    background: #f6f6f6;
    box-sizing: border-box;
}
.service_thought p, .service_text p {
    margin-bottom: 0;
}
.service_box {
    margin-top: 50px;
}
.service_img {
    width: 50%;
    text-align: center;
    box-sizing: border-box;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    display: -webkit-flex;
    display: flex;
}
.service_text {
    width: 50%;
    box-sizing: border-box;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    display: -webkit-flex;
    display: flex;
}
.service_box:nth-of-type(odd) .service_img {
    margin-left: 50%;
    padding-left: 2.5em;
}
.service_box:nth-of-type(odd) .service_text {
    margin-left: -100%;
}
.service_box:nth-of-type(even) .service_img {
    padding-right: 2.5em;
}
.service_text h3, .service_text p {
    width: 100%;
}
.service_img img {
    border-radius: 10px;
}
@media only screen and (max-width: 768px) {
    .service_thought {
        padding: 20px 25px;
        margin-bottom: 40px;
    }
    .service_box {
        margin-top: 30px;
    }
    .service_img, .service_text {
        width: 100%;
    }
    .service_img {
        margin-bottom: 1em;
    }
    .service_box:nth-of-type(odd) .service_img {
        margin-left: 0;
        padding-left: 0;
    }
    .service_box:nth-of-type(even) .service_img {
        padding-right: 0;
    }
    .service_box:nth-of-type(odd) .service_text {
        margin-left: 0;
    }
}
/* ã‚µãƒ¼ãƒ“ã‚¹æ¡ˆå†… END */
.service_sec {
    padding: 100px 30px;
    background: #f8f6f0;
    position: relative;
    margin-top: 25px;
}

.service_inner {
    max-width: 1100px;
    margin: 0 auto;
}

/* ----- ã‚»ã‚¯ã‚·ãƒ§ãƒ³ãƒ˜ãƒƒãƒ€ãƒ¼ ----- */
.service_header {
    text-align: center;
    margin-bottom: 60px;
}

.service_label {
    display: inline-block;
    font-family: "Zen Kaku Gothic Antique", sans-serif;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: #5c8a4a;
    margin: 0 0 10px;
    line-height: 1;
    position: relative;
    padding: 0 30px;
}

.service_label::before,
.service_label::after {
    content: "";
    position: absolute;
    top: 50%;
    width: 22px;
    height: 1px;
    background: #5c8a4a;
}

.service_label::before { right: 100%; margin-right: -26px; }
.service_label::after  { left: 100%;  margin-left: -26px;  }

.service_title {
    font-family: "Zen Old Mincho", serif;
    font-size: 38px;
    font-weight: 900;
    color: #222;
    margin: 0;
    line-height: 1.3;
}

/* ----- ã‚«ãƒ¼ãƒ‰ã‚°ãƒªãƒƒãƒ‰ ----- */
.service_grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
}

/* 4ãƒ»5æžšç›®ã‚’ä¸­å¤®å¯„ã› */
.service_grid:has(.service_card:nth-child(5):last-child) {
    /* 5æžšã®ã¨ãã€4ãƒ»5æžšç›®ã‚’2åˆ—ã§ä¸­å¤®ã«æƒãˆã‚‹ */
}

/* 5ã‚«ãƒ¼ãƒ‰æ™‚: 4ãƒ»5ã‚’ä¸­å¤®2åˆ—ã« */
.service_grid {
    grid-template-columns: repeat(6, 1fr);
}

.service_card {
    grid-column: span 2;
}

.service_card:nth-child(4) {
    grid-column: 2 / span 2;
}

.service_card:nth-child(5) {
    grid-column: 4 / span 2;
}

/* ----- ã‚«ãƒ¼ãƒ‰æœ¬ä½“ ----- */
.service_card {
    background: #fff;
    border-radius: 12px;
    padding: 40px 30px 36px;
    text-align: center;
    box-shadow: 0 2px 16px rgba(0,0,0,0.06);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    position: relative;
    overflow: hidden;
}

.service_card::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: #5c8a4a;
    transform: scaleX(0);
    transform-origin: center;
    transition: transform 0.3s ease;
}

.service_card:hover {
    transform: translateY(-6px);
    box-shadow: 0 8px 30px rgba(92,138,74,0.16);
}

.service_card:hover::after {
    transform: scaleX(1);
}

/* ----- ã‚¢ã‚¤ã‚³ãƒ³ ----- */
.service_icon {
    width: 100px;
    height: 100px;
    margin: 0 auto 24px;
}

.service_icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    transition: transform 0.3s ease;
}

.service_card:hover .service_icon img {
    transform: scale(1.08);
}

/* ----- ãƒ†ã‚­ã‚¹ãƒˆ ----- */
.service_name {
    font-family: "Zen Old Mincho", serif;
    font-size: 20px;
    font-weight: 700;
    color: #2d4d22;
    margin: 0 0 14px;
    padding-bottom: 14px;
    position: relative;
}

/*.service_name::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 32px;
    height: 2px;
    background: #8ab874;
    border-radius: 1px;
}*/

.service_desc {
    font-family: "Zen Kaku Gothic Antique", sans-serif;
    font-size: 14px;
    line-height: 1.9;
    color: #555;
    margin: 0;
    text-align: left;
}

/* =====================================================
   ãƒ¬ã‚¹ãƒãƒ³ã‚·ãƒ–
   ===================================================== */
@media (max-width: 1024px) {
    .service_grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .service_card {
        grid-column: span 1 !important;
    }

    .service_card:nth-child(5):last-child {
        grid-column: 1 / span 2 !important;
        max-width: 380px;
        margin: 0 auto;
        width: 100%;
    }
}

@media (max-width: 640px) {
    .service_sec {
        padding: 70px 20px;
    }

    .service_title {
        font-size: 28px;
    }

    .service_grid {
        grid-template-columns: 1fr;
    }

    .service_card {
        grid-column: span 1 !important;
    }

    .service_card:nth-child(5):last-child {
        max-width: 100%;
    }

    .service_card {
        padding: 30px 20px;
    }
}
.price_sec {
    background: #f9f7f4;
    padding: 64px 0;
    font-family: 'Noto Sans JP', sans-serif;
}
.price_sec .content_inner {
    max-width: 900px;
    margin: 0 auto;
    padding: 0 24px;
}
.price_sec h2 {
    font-size: 2rem;
    font-weight: 700;
    color: #1a2e1a;
    text-align: center;
    margin-bottom: 12px;
}
.price_sec > .content_inner > p {
    text-align: center;
    color: #555;
    font-size: 0.95rem;
    line-height: 1.8;
    margin-bottom: 48px;
}
.price_category {
    margin-bottom: 40px;
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 2px 12px rgba(0,0,0,0.07);
}
.price_category_header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 24px;
    background: #2d5a27;
    color: #fff;
}
.price_category_header .cat_icon {
    font-size: 1.4rem;
    line-height: 1;
}
.price_category_header h3 {
    font-size: 1.1rem;
    font-weight: 700;
    margin: 0;
    letter-spacing: 0.05em;
    color: #fff;
    padding: 0;
    border: none;
}

/* ãƒ†ãƒ¼ãƒ–ãƒ« */
.price_table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.95rem;
}
.price_table thead tr {
    background: #eef4ec;
}
.price_table thead th {
    padding: 10px 20px;
    text-align: left;
    color: #2d5a27;
    font-weight: 700;
    font-size: 0.85rem;
    letter-spacing: 0.05em;
    background: #eef4ec;
    width: auto;
}
.price_table tr td{
    text-align: left;
}
.price_table tbody tr {
    border-bottom: 1px solid #f0ede8;
}
.price_table tbody tr:last-child {
    border-bottom: none;
}
.price_table tbody tr:hover {
    background: #fafdf9;
}
.price_table td {
    padding: 14px 20px;
    color: #333;
    vertical-align: middle;
}
.price_table td.item_name {
    font-weight: 600;
    color: #1a2e1a;
    width: 34%;
}
.price_table td.item_sub {
    color: #666;
    font-size: 0.9rem;
    width: 33%;
}
.price_table td.item_price {
    font-weight: 700;
    color: #2d5a27;
    text-align: right;
    width: 33%;
    font-size: 1rem;
}
.price_table td.item_price .unit {
    font-size: 0.78rem;
    font-weight: 400;
    color: #888;
    margin-left: 2px;
}
.post-content .price_note {
    padding: 0;
    background: transparent;
    border-top: none;
    font-size: 0.82em;
    color: #8a7fa0;
    line-height: 1.8;
    margin: 16px 0 0;
}

/* ãŠåº­é€ ã‚Šç³»ï¼šè¦‹ç©ã‚‚ã‚Šã®ã¿ */
.price_estimate_list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding: 20px 24px;
}
.price_estimate_list li {
    list-style: none;
    background: #eef4ec;
    color: #2d5a27;
    padding: 8px 16px;
    border-radius: 20px;
    font-size: 0.9rem;
    font-weight: 600;
}
.estimate_note {
    padding: 0 24px 20px;
    font-size: 0.85rem;
    color: #888;
}
.price_footer_note {
    margin-top: 40px;
    padding: 20px 28px;
    background: #fff8e8;
    border-left: 4px solid #c8a94a;
    border-radius: 0 8px 8px 0;
    font-size: 0.88rem;
    color: #5a4a1a;
    line-height: 1.9;
}
.price_footer_note strong {
    color: #a07820;
}

@media (max-width: 600px) {
    .price_table thead { display: none; }
    .price_table tbody tr {
        display: grid;
        grid-template-columns: 1fr 1fr;
        padding: 12px 16px;
        gap: 2px 8px;
    }
    .price_table td { padding: 2px 0; width: auto !important; }
    .price_table td.item_name { grid-column: 1 / -1; font-size: 0.95rem; }
    .price_table td.item_sub { color: #888; font-size: 0.83rem; }
    .price_table td.item_price { text-align: left; }

}
/* kozen-style-concept */
.concept-intro-text {
    width: 60%;
    background: #ffffff;
    box-sizing: border-box;
    position: relative;
    z-index: 1;
    margin-top: 5em;
    padding: 0 3em 0 0;
}
.concept-intro-img {
    width: 50%;
    margin-left: -10%;
    position: relative;
    z-index: 0;
}
.concept-intro-text p {
    margin-bottom: 1em;
}
.concept-contents-text {
    width: 60%;
    margin-left: 40%;
    box-sizing: border-box;
    position: relative;
    z-index: 1;
}
.concept-contents-img {
    width: 40%;
    box-sizing: border-box;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    display: -webkit-flex;
    display: flex;
    position: relative;
    z-index: 0;
    margin-left: -100%;
}
.concept-contents-text.contents01-text {
    padding-left: 3em;
    font-size: 0.9em;
}
.concept-contents-img img {
    display: block;
    width: 100%;
}
.concept-intro-img img {
    display: block;
    width: 100%;
}
.concept-contents-text.contents02-text {
    margin-left: 0;
    font-size: 0.9em;
    padding-right: 3em;
}
.concept-contents {
    margin-top: 5em;
}
.concept-contents-text.contents03-text {
    padding: 3em 0em 0 3em;
    background: #ffffff;
    margin-top: 5em;
}
.concept-contents-img.contents03-img {
    justify-content: flex-end;
    width: 60%;
}
.concept-contents-img.contents02-img {
    margin-left: 0;
}
@media only screen and (max-width: 970px) {
    .concept-intro-text {
        background: none;
        padding: 0;
        margin: 0 auto 3em;
        width: 100%;
    }
    .concept-intro-img {
        width: 110%;
    }
    .concept-contents-img {
        width: 100% !important;
        margin: 0 auto !important;
    }
    .concept-contents-text {
        width: 100% !important;
        margin: 0 auto 2em !important;
        padding: 0 !important;
    }
}
@media only screen and (max-width: 485px) {
    .concept-contents {
        margin-top: 4em;
    }
}
/* kozen-style-concept END */
section.kp-main-content {
    padding: 100px 0 100px;
    position: relative;
}
.kp-content_inner {
    max-width: 1150px;
    width: 86%;
    margin: 0 auto;
}
.wp-block-columns {
    display: flex;
    margin-bottom: 1.75em;
    box-sizing: border-box;
    flex-wrap: wrap;
}
@media (min-width: 782px) {
    .wp-block-columns {
        flex-wrap: nowrap;
    }
}
.wp-block-columns:where(.has-background) {
    padding: 1.25em 2.375em;
}
.wp-block-columns.are-vertically-aligned-top {
    align-items: flex-start;
}
.wp-block-columns.are-vertically-aligned-center {
    align-items: center;
}
.wp-block-columns.are-vertically-aligned-bottom {
    align-items: flex-end;
}
@media (max-width: 599px) {
    .wp-block-columns:not(.is-not-stacked-on-mobile) > .wp-block-column {
        flex-basis: 100% !important;
    }
}
@media (min-width: 600px) and (max-width: 781px) {
    .wp-block-columns:not(.is-not-stacked-on-mobile) > .wp-block-column:not(:only-child) {
        flex-basis: calc(50% - var(--wp--style--block-gap, 2em) / 2) !important;
        flex-grow: 0;
    }
    .wp-block-columns:not(.is-not-stacked-on-mobile) > .wp-block-column:nth-child(2n) {
        margin-left: var(--wp--style--block-gap, 2em);
    }
}
@media (min-width: 782px) {
    .wp-block-columns:not(.is-not-stacked-on-mobile) > .wp-block-column {
        flex-basis: 0;
        flex-grow: 1;
    }
    .wp-block-columns:not(.is-not-stacked-on-mobile) > .wp-block-column[style*="flex-basis"] {
        flex-grow: 0;
    }
    .wp-block-columns:not(.is-not-stacked-on-mobile) > .wp-block-column:not(:first-child) {
        margin-left: var(--wp--style--block-gap, 2em);
    }
}
.wp-block-columns.is-not-stacked-on-mobile {
    flex-wrap: nowrap;
}
.wp-block-columns.is-not-stacked-on-mobile > .wp-block-column {
    flex-basis: 0;
    flex-grow: 1;
}
.wp-block-columns.is-not-stacked-on-mobile > .wp-block-column[style*="flex-basis"] {
    flex-grow: 0;
}
.wp-block-columns.is-not-stacked-on-mobile > .wp-block-column:not(:first-child) {
    margin-left: var(--wp--style--block-gap, 2em);
}
.wp-block-text-columns .wp-block-column {
    margin: 0 1em;
    padding: 0;
}
.wp-block-text-columns .wp-block-column:first-child {
    margin-left: 0;
}
.wp-block-text-columns .wp-block-column:last-child {
    margin-right: 0;
}
.wp-block-text-columns.columns-2 .wp-block-column {
    width: 50%;
}
.wp-block-text-columns.columns-3 .wp-block-column {
    width: 33.33333%;
}
.wp-block-text-columns.columns-4 .wp-block-column {
    width: 25%;
}
.wp-block-image figcaption {
    margin-top: .5em;
    margin-bottom: 1em;
    text-align: center;
}
.post-content .wp-block-column ul {
    padding-left: 0;
    background-color: #f9eaf985;
    padding: 25px 15px 15px 15px;
    border-radius: 3px;
    position: relative;
    margin-bottom: 25px;
    margin-left: 0px;
}
.post-content .wp-block-column li {
    font-size: 18px;
    font-weight: bold;
    list-style-type: none !important;
    line-height: 1.6em;
    padding: 4px 0 4px 40px;
    margin-bottom: 10px;
}
.post-content .wp-block-column li:before {
    font-family: "Font Awesome 5 Free";
    content: '\f559';
    position: absolute;
    left: 1.5em;
    color: #de1218;
}
/* qa */
.faq-sec h2 {
    padding-left: 35px;
    margin-bottom: 0.5em;
    position: relative;
    text-align: left;
}
.faq-sec h2::before {
    content: 'Q.';
    font-family: 'Poppins','Noto Sans JP', Verdana, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
    font-weight: 700;
    position: absolute;
    left: 0;
    color: #333;
    top: 0;
}
.faq-sec h2::after {
    display: none;
}
.faq-sec p {
    padding-left: 35px;
    margin-top: 0.3em;
    margin-bottom: 3em;
    padding-bottom: 3em;
    border-bottom: 1px solid #ddd;
}
.faq-sec p:last-of-type {
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
}
/* qa END */

/* =====================================================================
   ▼ CONTACT PAGE（ツナグのトンマナを移植）___ START
   ===================================================================== */
.contact-section {
    padding: 6em 0 7em;
    background: linear-gradient(180deg, #ffffff 0%, #faf8fc 100%);
}
.contact-section * { box-sizing: border-box; }
.contact-inner {
    width: 88%;
    max-width: 820px;
    margin: 0 auto;
}
.contact-pagetitle {
    text-align: center;
    font-family: "Noto Serif JP", "游明朝", YuMincho, serif;
    color: #2d2438;
    font-size: 2em;
    font-weight: 600;
    letter-spacing: .08em;
    line-height: 1.4;
    margin: 0 0 1.2em;
    position: relative;
}
.contact-pagetitle span {
    display: block;
    font-family: "Lato", sans-serif;
    font-size: .4em;
    letter-spacing: .4em;
    color: #6b5b8e;
    margin-top: .9em;
    font-weight: 600;
}
.post-content h2.contact-pagetitle::after {
    display: none;
}
.contact-lead {
    text-align: center;
    color: #3d3548;
    font-size: 0.95em;
    line-height: 2;
    margin: 0 auto 3em;
    max-width: 680px;
}
.contact-grid {
    margin: 0 auto 3em;
}
.contact-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    background: #fff;
    border: 1px solid rgba(125,108,160,0.10);
    border-radius: 22px;
    box-shadow:
        0 4px 12px rgba(74,63,107,0.06),
        0 24px 56px rgba(74,63,107,0.10);
    padding: 3em 2.6em;
}
.contact-card__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: linear-gradient(135deg, #6b5b8e, #7d6ca0);
    color: #fff;
    margin-bottom: 1.2em;
    box-shadow: 0 12px 26px rgba(107,91,142,0.3);
}
.contact-card__title {
    font-family: "Noto Serif JP", "游明朝", YuMincho, serif;
    color: #2d2438;
    font-size: 1.25em;
    font-weight: 600;
    letter-spacing: .04em;
    margin: 0 0 1em;
}
.contact-tel {
    font-style: normal;
    display: flex;
    align-items: baseline;
    justify-content: center;
    gap: .4em;
    margin-bottom: 1em;
}
.contact-tel__sub {
    font-family: "Lato", sans-serif;
    color: #c8a96a;
    font-size: 1.1em;
    font-weight: 700;
}
.contact-tel .tel-link {
    color: #4a3f6b;
    font-family: "Lato", sans-serif;
    font-size: 2.2em;
    font-weight: 800;
    letter-spacing: .02em;
    text-decoration: none;
    line-height: 1;
}
.contact-meta {
    list-style: none;
    margin: 0 0 1.4em;
    padding: 0;
}
.contact-meta li {
    font-size: 0.92em;
    color: #3d3548;
    margin-bottom: .4em;
}
.contact-meta li span {
    display: inline-block;
    color: #6b5b8e;
    font-weight: 700;
    margin-right: .6em;
}
.contact-note {
    font-size: 0.82em;
    color: #8a7fa0;
    line-height: 1.8;
    text-align: left;
    margin: .5em 0 0;
    width: 100%;
}
.contact-mail {
    background: #fff;
    border: 1px solid rgba(125,108,160,0.10);
    border-radius: 22px;
    box-shadow:
        0 4px 12px rgba(74,63,107,0.06),
        0 24px 56px rgba(74,63,107,0.10);
    padding: 3em 2.8em;
}
.contact-mail__title {
    text-align: center;
    font-family: "Noto Serif JP", "游明朝", YuMincho, serif;
    color: #2d2438;
    font-size: 1.35em;
    font-weight: 600;
    letter-spacing: .04em;
    margin: 0 0 1.6em;
}
.contact-notice {
    background: linear-gradient(135deg, #f5f2f8 0%, #ece5f2 100%);
    border-radius: 14px;
    padding: 1.6em 1.8em;
    margin-bottom: 2.4em;
}
.contact-notice h4 {
    display: flex;
    align-items: center;
    gap: .6em;
    color: #4a3f6b;
    font-size: 1.02em;
    font-weight: 700;
    margin: 0 0 .7em;
}
.contact-notice h4::before {
    content: "!";
    flex-shrink: 0;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: linear-gradient(135deg, #6b5b8e, #c8a96a);
    color: #fff;
    font-family: "Lato", sans-serif;
    font-size: 0.9em;
    font-weight: 800;
    display: flex;
    align-items: center;
    justify-content: center;
}
.contact-notice p {
    color: #3d3548;
    font-size: 0.9em;
    line-height: 1.9;
    margin: 0;
}
.contact-mail .wpcf7-form p { margin: 0 0 1.4em; }
.contact-mail label {
    display: block;
    font-size: 0.92em;
    font-weight: 700;
    color: #4a3f6b;
    margin-bottom: .5em;
}
.contact-mail input[type="text"],
.contact-mail input[type="email"],
.contact-mail input[type="tel"],
.contact-mail input[type="url"],
.contact-mail input[type="number"],
.contact-mail input[type="date"],
.contact-mail textarea,
.contact-mail select {
    width: 100%;
    box-sizing: border-box;
    border: 1px solid rgba(125,108,160,0.25);
    border-radius: 12px;
    background: #faf8fc;
    padding: .9em 1em;
    font-size: 0.95em;
    color: #2d2438;
    font-family: inherit;
    transition: border-color .3s, box-shadow .3s, background .3s;
}
.contact-mail input:focus,
.contact-mail textarea:focus,
.contact-mail select:focus {
    outline: none;
    border-color: #6b5b8e;
    box-shadow: 0 0 0 3px rgba(107,91,142,0.15);
    background: #fff;
}
.contact-mail textarea {
    min-height: 11em;
    resize: vertical;
}
.contact-mail .wpcf7-submit {
    display: block;
    margin: .6em auto 0;
    cursor: pointer;
    background: linear-gradient(120deg, #6b5b8e, #7d6ca0);
    color: #fff;
    border: none;
    border-radius: 999px;
    font-size: 1em;
    font-weight: 700;
    letter-spacing: .12em;
    padding: 1em 3em;
    box-shadow: 0 14px 30px rgba(107,91,142,0.3);
    transition: transform .3s cubic-bezier(.22,1,.36,1), box-shadow .3s cubic-bezier(.22,1,.36,1);
}
.contact-mail .wpcf7-submit:hover {
    transform: translateY(-3px);
    box-shadow: 0 20px 38px rgba(107,91,142,0.4);
}
@media screen and (max-width: 768px) {
    .contact-section { padding: 4em 0 4.5em; }
    .contact-inner { width: 92%; }
    .contact-pagetitle { font-size: 1.6em; }
    .contact-lead { margin-bottom: 2.4em; }
    .contact-card { padding: 2.4em 1.6em; }
    .contact-tel .tel-link { font-size: 1.8em; }
    .contact-mail { padding: 2.4em 1.4em; }
    .contact-mail__title { font-size: 1.2em; }
}
/* =====================================================================
   ▼ CONTACT PAGE ___ END
   ===================================================================== */

/* =====================================================================
   ▼ 会社概要 / 店舗概要ページ (yoshisui-store)
   ===================================================================== */
.yoshisui-store {
    width: 88%;
    max-width: 980px;
    margin: 0 auto;
    padding: 1em 0 2em;
}
.yoshisui-store__head {
    text-align: center;
    margin-bottom: 2.6em;
}
.yoshisui-store__head .sub {
    display: block;
    font-family: "Noto Serif JP", serif;
    font-size: 0.95em;
    font-weight: 400;
    letter-spacing: .4em;
    color: #c8a96a;
    margin-bottom: 14px;
}
.yoshisui-store__head .main {
    display: block;
    font-family: "Lato", sans-serif;
    font-size: 2.4em;
    font-weight: 500;
    letter-spacing: .25em;
    color: #4a3f6b;
    line-height: 1.2;
}
.yoshisui-store__head .line {
    display: block;
    width: 48px;
    height: 2px;
    background: linear-gradient(90deg, #6b5b8e, #c8a96a);
    border-radius: 2px;
    margin: 22px auto 0;
}
.yoshisui-store__card {
    background: #ffffff;
    /*border-radius: 22px;*/
    box-shadow:
        0 4px 12px rgba(74,63,107,0.06),
        0 24px 56px rgba(74,63,107,0.10);
    overflow: hidden;
    border: 1px solid rgba(125,108,160,0.10);
}
.yoshisui-store table {
    width: 100%;
    border-collapse: collapse;
    margin: 0;
}
.yoshisui-store th,
.yoshisui-store td {
    text-align: left;
    vertical-align: top;
    padding: 24px 32px;
    border-bottom: 1px solid rgba(125,108,160,0.14);
    line-height: 1.9;
}
.yoshisui-store tr:last-child th,
.yoshisui-store tr:last-child td {
    border-bottom: none;
}
.yoshisui-store th {
    width: 220px;
    background: linear-gradient(135deg, #f5f2f8 0%, #ece5f2 100%);
    color: #4a3f6b;
    font-weight: 600;
    font-size: 0.95em;
    letter-spacing: .08em;
    font-family: "Noto Sans JP", sans-serif;
    white-space: nowrap;
    position: relative;
}
/*.yoshisui-store th::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 3px;
    height: 22px;
    background: linear-gradient(180deg, #6b5b8e, #c8a96a);
    border-radius: 0 2px 2px 0;
}*/
.yoshisui-store td {
    color: #3d3548;
    font-size: 0.95em;
    background: #fff;
}
.yoshisui-store td .note {
    display: block;
    margin-top: 6px;
    font-size: 0.82em;
    line-height: 1.7;
    color: #8a7fa0;
}
.yoshisui-store td a {
    color: #6b5b8e;
    font-weight: 600;
}
.yoshisui-map {
    width: 88%;
    max-width: 980px;
    margin: 2.6em auto 0;
    height: 420px;
    border-radius: 22px;
    overflow: hidden;
    box-shadow: 0 24px 48px rgba(74,63,107,0.15);
    position: relative;
}
.yoshisui-map iframe {
    width: 100%;
    height: 100%;
    display: block;
    border: 0;
}
@media only screen and (max-width: 768px) {
    .yoshisui-store { width: 100%; }
    .yoshisui-store__head { margin-bottom: 2em; }
    .yoshisui-store__head .main { font-size: 1.8em; }
    .yoshisui-store table,
    .yoshisui-store tbody,
    .yoshisui-store tr,
    .yoshisui-store th,
    .yoshisui-store td {
        display: block;
        width: 100%;
        box-sizing: border-box;
    }
    .yoshisui-store th {
        width: 100%;
        white-space: normal;
        padding: 14px 20px;
        border-bottom: none;
    }
    .yoshisui-store td {
        padding: 14px 20px 22px;
        border-bottom: 1px solid rgba(125,108,160,0.14);
    }
    .yoshisui-store tr:last-child td { border-bottom: none; }
    .yoshisui-map { width: 92%; height: 300px; margin-top: 2em; }
    
    .post-content .s_table{
        white-space: normal;
    }
}
/* =====================================================================
   ▲ 会社概要 / 店舗概要ページ ___ END
   ===================================================================== */

/* =====================================================================
   ▼ よくある質問ページ (yoshisui-faq)
   ===================================================================== */
.yoshisui-faq {
    width: 88%;
    max-width: 920px;
    margin: 0 auto;
    padding: 1em 0 2em;
}
.yoshisui-faq__head {
    text-align: center;
    margin-bottom: 2.6em;
}
.yoshisui-faq__head .sub {
    display: block;
    font-family: "Noto Serif JP", serif;
    font-size: 0.95em;
    font-weight: 400;
    letter-spacing: .4em;
    color: #c8a96a;
    margin-bottom: 14px;
}
.yoshisui-faq__head .main {
    display: block;
    font-family: "Lato", sans-serif;
    font-size: 2.4em;
    font-weight: 500;
    letter-spacing: .25em;
    color: #4a3f6b;
    line-height: 1.2;
}
.yoshisui-faq__head .line {
    display: block;
    width: 48px;
    height: 2px;
    background: linear-gradient(90deg, #6b5b8e, #c8a96a);
    border-radius: 2px;
    margin: 22px auto 0;
}
.yoshisui-faq__item {
    background: #ffffff;
    border-radius: 22px;
    box-shadow:
        0 4px 12px rgba(74,63,107,0.06),
        0 24px 56px rgba(74,63,107,0.10);
    border: 1px solid rgba(125,108,160,0.10);
    overflow: hidden;
    margin-bottom: 24px;
    position: relative;
}
.yoshisui-faq__item::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 4px;
    height: 100%;
    background: linear-gradient(180deg, #6b5b8e, #a99bc4, #c8a96a);
}
.yoshisui-faq__q,
.yoshisui-faq__a {
    display: flex;
    align-items: flex-start;
    gap: 18px;
    padding: 26px 32px;
    margin: 0;
}
.yoshisui-faq__q {
    border-bottom: 1px solid rgba(125,108,160,0.14);
    align-items: center;
}
.yoshisui-faq__q::before,
.yoshisui-faq__a::before {
    flex: 0 0 auto;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: "Lato", sans-serif;
    font-weight: 700;
    font-size: 1.05em;
    color: #ffffff;
    line-height: 1;
}
.yoshisui-faq__q::before {
    content: 'Q';
    background: linear-gradient(135deg, #6b5b8e, #7d6ca0);
    box-shadow: 0 6px 16px rgba(107,91,142,0.3);
}
.yoshisui-faq__a::before {
    content: 'A';
    background: linear-gradient(135deg, #c8a96a, #d8bd86);
    box-shadow: 0 6px 16px rgba(200,169,106,0.3);
}
.yoshisui-faq__q-text {
    font-family: "Noto Serif JP", "游明朝", YuMincho, serif;
    font-size: 1.12em;
    font-weight: 600;
    line-height: 1.6;
    color: #2d2438;
    letter-spacing: .03em;
}
.yoshisui-faq__a-text {
    font-size: 0.95em;
    line-height: 2.0;
    color: #3d3548;
    padding-top: 4px;
}
@media only screen and (max-width: 768px) {
    .yoshisui-faq { width: 92%; }
    .yoshisui-faq__head { margin-bottom: 2em; }
    .yoshisui-faq__head .main { font-size: 1.8em; }
    .yoshisui-faq__q,
    .yoshisui-faq__a {
        gap: 12px;
        padding: 18px 18px;
    }
    .yoshisui-faq__q::before,
    .yoshisui-faq__a::before {
        width: 32px;
        height: 32px;
        font-size: 0.95em;
    }
    .yoshisui-faq__q-text { font-size: 1.02em; }
    .yoshisui-faq__a-text { font-size: 0.92em; line-height: 1.9; }
}
/* =====================================================================
   ▲ よくある質問ページ ___ END
   ===================================================================== */

/* =====================================================================
   ▼ サービス・料金ページ (service_sec / price_sec)
   ===================================================================== */
/* --- 対応サービス --- */
.service_sec {
    padding: 6em 0 5em;
    background: linear-gradient(180deg, #ffffff 0%, #faf8fc 100%);
}
.service_inner {
    width: 88%;
    max-width: 1180px;
    margin: 0 auto;
}
.service_header {
    text-align: center;
    margin-bottom: 3em;
}
.service_label {
    font-family: "Lato", sans-serif;
    font-size: 0.95em;
    font-weight: 600;
    letter-spacing: .4em;
    color: #6b5b8e;
    margin: 0 0 12px;
}
h2.service_title {
    font-family: "Noto Serif JP", "游明朝", YuMincho, serif;
    font-size: 2em;
    font-weight: 600;
    letter-spacing: .08em;
    color: #2d2438;
    position: relative;
    padding-bottom: 22px;
    margin: 0;
    text-align: center;
}
h2.service_title::after {
    content: '';
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    width: 48px;
    height: 2px;
    background: linear-gradient(90deg, #6b5b8e, #c8a96a);
    border-radius: 2px;
}
.service_grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 36px;
}
.service_card {
    width: calc((100% - 72px) / 3);
    box-sizing: border-box;
    background: #ffffff;
    border-radius: 22px;
    padding: 36px 28px 34px;
    text-align: center;
    box-shadow:
        0 1px 2px rgba(74,63,107,0.04),
        0 8px 24px rgba(74,63,107,0.08);
    border: 1px solid rgba(125,108,160,0.10);
    cursor: pointer;
    position: relative;
    overflow: hidden;
}
/* ホバー効果は無効化（旧テンプレート由来の効果も含めて打ち消し） */
.service_card,
.service_card:hover {
    transform: none;
    box-shadow:
        0 1px 2px rgba(74,63,107,0.04),
        0 8px 24px rgba(74,63,107,0.08);
    transition: none;
}
.service_card::before,
.service_card::after {
    display: none;
}
.service_card:hover .service_icon img {
    transform: none;
}
/* 上部・全幅の実写バナー（左右・上は余白なし） */
.service_photo {
    margin: -36px -28px 24px;
    line-height: 0;
}
.service_photo img {
    width: 100%;
    height: auto;
    display: block;
    aspect-ratio: 3 / 2;
    object-fit: cover;
}
.service_icon {
    width: 120px;
    height: 120px;
    margin: 0 auto 22px;
    border-radius: 50%;
    background: linear-gradient(135deg, #f5f2f8 0%, #ece5f2 100%);
    display: flex;
    align-items: center;
    justify-content: center;
}
.service_icon img {
    width: 72px;
    height: auto;
}
h3.service_name {
    font-family: "Noto Serif JP", "游明朝", YuMincho, serif;
    font-size: 1.25em;
    font-weight: 600;
    color: #2d2438;
    letter-spacing: .04em;
    margin: 0 0 16px;
    padding-bottom: 14px;
    position: relative;
}
h3.service_name::after {
    content: '';
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    width: 32px;
    height: 2px;
    background: #c8a96a;
    border-radius: 2px;
}
.service_desc {
    font-size: 0.92em;
    line-height: 2;
    color: #3d3548;
    text-align: left;
    margin: 0;
}

/* --- 料金プラン --- */
.price_sec {
    padding: 6em 0 6em;
    background: linear-gradient(180deg, #faf8fc 0%, #ffffff 100%);
}
.price_sec .content_inner {
    width: 88%;
    max-width: 900px;
    margin: 0 auto;
}
.price_sec > .content_inner > h2 {
    text-align: center;
    font-family: "Noto Serif JP", "游明朝", YuMincho, serif;
    font-size: 2em;
    font-weight: 600;
    letter-spacing: .08em;
    color: #2d2438;
    position: relative;
    padding-bottom: 22px;
    margin: 0 0 1.4em;
}
.price_sec > .content_inner > h2::after {
    content: '';
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    width: 48px;
    height: 2px;
    background: linear-gradient(90deg, #6b5b8e, #c8a96a);
    border-radius: 2px;
}
.price_lead {
    text-align: center;
    font-size: 0.95em;
    line-height: 2.1;
    color: #3d3548;
    margin: 0 auto 3em;
    max-width: 760px;
}
.price_lead strong {
    color: #6b5b8e;
    font-weight: 700;
}
.price_category {
    background: #ffffff;
    border-radius: 22px;
    box-shadow:
        0 4px 12px rgba(74,63,107,0.06),
        0 24px 56px rgba(74,63,107,0.10);
    border: 1px solid rgba(125,108,160,0.10);
    padding: 28px 34px 28px;
    margin-bottom: 36px;
    scroll-margin-top: 110px;
}
.price_category_header {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 22px 0 20px;
    margin-bottom: 8px;
    border-bottom: 2px solid rgba(125,108,160,0.14);
}
.price_category_header .cat_icon {
    flex: 0 0 auto;
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: linear-gradient(135deg, #f5f2f8 0%, #ece5f2 100%);
    display: flex;
    align-items: center;
    justify-content: center;
}
.price_category_header .cat_icon img {
    width: 28px;
    height: 28px;
}
.price_category_header h3 {
    font-family: "Noto Serif JP", "游明朝", YuMincho, serif;
    font-size: 1.35em;
    font-weight: 600;
    color: #2d2438;
    letter-spacing: .04em;
    margin: 0;
}
.s_table {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
table.price_table {
    width: 100%;
    border-collapse: collapse;
    margin: 0;
}
table.price_table thead th {
    background: linear-gradient(135deg, #6b5b8e 0%, #7d6ca0 100%);
    color: #ffffff;
    font-size: 0.85em;
    font-weight: 600;
    letter-spacing: .08em;
    padding: 14px 18px;
    text-align: left;
    white-space: nowrap;
}
table.price_table thead th:first-child { border-radius: 10px 0 0 10px; }
table.price_table thead th:last-child { border-radius: 0 10px 10px 0; text-align: right; }
table.price_table tbody td {
    padding: 18px 18px;
    border-bottom: 1px solid rgba(125,108,160,0.14);
    vertical-align: middle;
    line-height: 1.6;
}
table.price_table tbody tr:last-child td { border-bottom: none; }
table.price_table tbody tr:hover td { background: rgba(245,242,248,0.6); }
.price_table .item_name {
    font-weight: 600;
    color: #2d2438;
    font-size: 0.96em;
}
.price_table .item_sub {
    color: #8a7fa0;
    font-size: 0.85em;
    white-space: nowrap;
}
.price_table .item_price {
    text-align: right;
    font-weight: 700;
    color: #6b5b8e;
    font-size: 1.05em;
    white-space: nowrap;
    font-family: "Lato", "Noto Sans JP", sans-serif;
}
.price_table .item_price .unit {
    font-size: 0.7em;
    color: #c8a96a;
    margin-left: 2px;
}
.price_note {
    font-size: 0.82em;
    line-height: 1.8;
    color: #8a7fa0;
    margin: 16px 0 0;
}
.price_footer_note {
    background: linear-gradient(135deg, #f5f2f8 0%, #ece5f2 100%);
    border-left: 4px solid #6b5b8e;
    border-radius: 14px;
    padding: 26px 30px;
    font-size: 0.9em;
    line-height: 2.1;
    color: #3d3548;
    margin-top: 2em;
}
.price_footer_note strong {
    color: #6b5b8e;
}
@media only screen and (max-width: 768px) {
    .service_sec { padding: 4em 0 3.5em; }
    .service_inner { width: 92%; }
    h2.service_title { font-size: 1.6em; }
    .service_grid { gap: 22px; }
    .service_card { width: 100%; padding: 30px 24px; }
    .price_sec { padding: 4em 0; }
    .price_sec .content_inner { width: 92%; }
    .price_sec > .content_inner > h2 { font-size: 1.6em; }
    .price_category { padding: 8px 18px 22px; }
    .price_category_header h3 { font-size: 1.15em; }
    table.price_table tbody td { padding: 14px 12px; }
    .price_footer_note { padding: 20px 20px; }
}
/* =====================================================================
   ▲ サービス・料金ページ ___ END
   ===================================================================== */

/* =====================================================================
   ▼ 代表挨拶ページ (kp-main-content)
   ===================================================================== */
.kp-main-content {
    position: relative;
    z-index: 0;
    padding: 6em 0 7em;
    background: linear-gradient(180deg, #ffffff 0%, #faf8fc 100%);
    overflow: hidden;
}
.kp-main-content::after {
    content: '吉';
    position: absolute;
    font-family: "Noto Serif JP", serif;
    font-size: 22em;
    font-weight: 700;
    color: rgba(107,91,142,0.05);
    top: 50%;
    right: 3%;
    transform: translateY(-50%);
    z-index: 0;
    line-height: 1;
    pointer-events: none;
}
.kp-content_inner {
    width: 88%;
    max-width: 1120px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}
.kp-main-content > .kp-content_inner > h2 {
    font-family: "Noto Serif JP", "游明朝", YuMincho, serif;
    font-size: 1.85em;
    font-weight: 600;
    line-height: 1.7;
    letter-spacing: .05em;
    color: #2d2438;
    text-align: center;
    margin: 0 0 1.8em;
    padding-top: 48px;
    position: relative;
}
.kp-main-content > .kp-content_inner > h2::before {
    content: 'GREETING';
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    font-family: "Lato", sans-serif;
    font-size: 0.42em;
    font-weight: 600;
    letter-spacing: .5em;
    color: #6b5b8e;
}
.kp-main-content .wp-block-columns {
    display: flex;
    align-items: center;
    gap: 0;
    flex-wrap: wrap;
}
.kp-main-content .wp-block-column:first-child {
    flex: 1 1 50%;
    box-sizing: border-box;
    background: #ffffff;
    border-radius: 22px;
    padding: 44px 44px;
    box-shadow:
        0 4px 12px rgba(74,63,107,0.06),
        0 24px 56px rgba(74,63,107,0.12);
    position: relative;
    z-index: 2;
}
.kp-main-content .wp-block-column:first-child::before {
    content: 'ごあいさつ';
    position: absolute;
    top: -16px;
    left: 40px;
    background: #6b5b8e;
    color: #ffffff;
    padding: 7px 18px;
    border-radius: 100px;
    font-family: "Noto Serif JP", serif;
    font-size: 0.72em;
    letter-spacing: .15em;
    font-weight: 500;
    box-shadow: 0 6px 16px rgba(107,91,142,0.3);
}
.kp-main-content .wp-block-column:first-child p {
    font-size: 0.92em;
    line-height: 2.1;
    color: #3d3548;
    margin: 0 0 1.2em;
}
.kp-main-content .wp-block-column:first-child p:first-child {
    margin-top: 0;
}
.kp-main-content .wp-block-column:first-child p:last-child {
    margin-bottom: 0;
}
.kp-main-content .wp-block-column:last-child {
    flex: 1 1 46%;
    margin-left: -6%;
    box-sizing: border-box;
    position: relative;
    z-index: 1;
}
.kp-main-content .wp-block-image {
    margin: 0;
    border-radius: 22px;
    overflow: hidden;
    box-shadow: 0 30px 60px rgba(74,63,107,0.18);
    position: relative;
}
.kp-main-content .wp-block-image img {
    width: 100%;
    height: auto;
    display: block;
    transition: transform 1.2s cubic-bezier(.2,.7,.2,1);
}
.kp-main-content .wp-block-image:hover img {
    transform: scale(1.04);
}
.kp-main-content .wp-block-image figcaption {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    box-sizing: border-box;
    margin: 0;
    padding: 28px 22px 16px;
    font-family: "Noto Serif JP", serif;
    font-size: 0.88em;
    font-weight: 500;
    letter-spacing: .08em;
    color: #ffffff;
    text-align: right;
    background: linear-gradient(180deg, rgba(45,36,56,0) 0%, rgba(45,36,56,0.7) 100%);
}
@media only screen and (max-width: 768px) {
    .kp-main-content { padding: 4em 0 4.5em; }
    .kp-main-content::after { font-size: 13em; right: -4%; }
    .kp-content_inner { width: 92%; }
    .kp-main-content > .kp-content_inner > h2 { font-size: 1.4em; }
    .kp-main-content .wp-block-columns { flex-direction: column; }
    .kp-main-content .wp-block-column:first-child {
        flex: 1 1 100%;
        width: 100%;
        padding: 38px 26px 30px;
        order: 2;
    }
    .kp-main-content .wp-block-column:last-child {
        flex: 1 1 100%;
        width: 100%;
        margin-left: 0;
        margin-bottom: 28px;
        order: 1;
    }
}
/* =====================================================================
   ▲ 代表挨拶ページ ___ END
   ===================================================================== */

/* =====================================================================
   ▼ 業務内容一覧（worklist / price_category を流用）
   ===================================================================== */
.post-content ul.work_list {
    list-style: none;
    margin: 22px 0 0;
    padding: 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px 24px;
}
.work_list li {
    position: relative;
    padding: 16px 20px 16px 50px;
    background: linear-gradient(135deg, #f5f2f8 0%, #ece5f2 100%);
    border-radius: 14px;
    border: 1px solid rgba(125,108,160,0.10);
    box-sizing: border-box;
}
.work_list li::before {
    content: '✓';
    position: absolute;
    left: 16px;
    top: 18px;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: linear-gradient(135deg, #6b5b8e, #c8a96a);
    color: #ffffff;
    font-size: 0.72em;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}
.work_list .work_name {
    display: block;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 600;
    font-size: 0.98em;
    color: #2d2438;
    letter-spacing: .02em;
    line-height: 1.5;
}
.work_list .work_sub {
    display: block;
    margin-top: 4px;
    font-size: 0.82em;
    font-weight: 400;
    line-height: 1.7;
    color: #8a7fa0;
}
@media only screen and (max-width: 768px) {
    .post-content ul.work_list {
        grid-template-columns: 1fr;
        gap: 12px;
    }
    .work_list li { padding: 14px 16px 14px 46px; }
    .work_list li::before { left: 14px; top: 16px; }
}
/* =====================================================================
   ▲ 業務内容一覧 ___ END
   ===================================================================== */