/* ===========================
   niou-san main.css （BEM）
   緑系・派手だけど信頼感
   =========================== */

body {
    font-family: var(--ff-jp);
    color: var(--c-text);
    background: var(--c-bg);
    font-size: var(--fs-16);
    line-height: 1.75;
    overflow-x: hidden;
}

.wrap { width: min(100%, var(--wrap-max)); margin-inline: auto; padding-inline: var(--gutter); }
.wrap--narrow { max-width: var(--wrap-narrow); }

.btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    padding: 14px 28px;
    font-size: var(--fs-16); font-weight: 700;
    border-radius: var(--r-full);
    border: 2px solid transparent;
    transition: transform .15s ease, box-shadow .15s ease, background .15s ease, color .15s ease;
    white-space: nowrap;
}
.btn { max-width: 100%; }
@media (max-width: 480px) {
    .btn { padding: 12px 22px; font-size: var(--fs-15); }
    .btn--lg { padding: 14px 24px; font-size: var(--fs-16); }
}
.btn--primary { background: var(--c-green); color: #fff; box-shadow: var(--sh-md); }
.btn--primary:hover { background: var(--c-green-dark); transform: translateY(-2px); box-shadow: var(--sh-lg); }
.btn--gold { background: var(--c-gold); color: #1c1300; box-shadow: var(--sh-md); }
.btn--gold:hover { background: var(--c-gold-soft); transform: translateY(-2px); }
.btn--ghost { background: transparent; color: #fff; border-color: rgba(255,255,255,.6); }
.btn--ghost:hover { background: rgba(255,255,255,.12); border-color: #fff; }
.btn--lg { padding: 18px 36px; font-size: var(--fs-18); }

/* ===========================
   Header
   =========================== */
.site-header {
    position: sticky; top: 0; z-index: 50;
    background: rgba(255,255,255,.92);
    backdrop-filter: saturate(180%) blur(10px);
    -webkit-backdrop-filter: saturate(180%) blur(10px);
    border-bottom: 1px solid var(--c-border);
    height: var(--header-h);
}
.site-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 100%;
    gap: 20px;
    flex-wrap: nowrap;
    min-width: 0;
    width: 100%;
    max-width: 1440px;
    margin-inline: auto;
    padding-inline: var(--gutter);
}
.site-header > .wrap.site-header__inner { padding-inline: var(--gutter); }
.site-header__brand { flex-shrink: 0; }
.site-header__brand { display: flex; align-items: center; gap: 12px; color: var(--c-green-dark); font-weight: 700; }
.site-header__brand-logo { width: 44px; height: 44px; object-fit: contain; display: block; }
.site-header__brand-name { display: flex; flex-direction: column; line-height: 1.15; }
.site-header__brand-jp { font-size: var(--fs-16); letter-spacing: .04em; color: #1a1a1a; }
.site-header__brand-en { font-size: var(--fs-12); color: var(--c-text-mute); letter-spacing: .12em; font-family: var(--ff-en); }

.site-nav { display: flex; align-items: center; gap: 18px; flex-wrap: nowrap; min-width: 0; }
.site-nav__list { display: flex; align-items: center; gap: 20px; flex-wrap: nowrap; min-width: 0; margin-right: 8px; }
.site-nav__list > li { flex-shrink: 0; }
.site-nav__link { font-size: var(--fs-14); font-weight: 600; color: var(--c-text); position: relative; padding: 6px 0; }
.site-nav__link::after { content: ""; position: absolute; left: 50%; bottom: 0; width: 0; height: 2px; background: var(--c-green); transition: width .2s ease, left .2s ease; }
.site-nav__link:hover::after { width: 100%; left: 0; }

/* ヘッダー右の電話（シンプル版・アイコン＋番号のみ） */
.header-tel {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 8px 18px 8px 8px;
    border-radius: var(--r-full);
    background: linear-gradient(135deg, #fbf7ea 0%, #f3ecd0 100%);
    border: 1.5px solid var(--c-gold);
    transition: transform .15s, box-shadow .15s;
    flex-shrink: 0;
    text-decoration: none;
    line-height: 1;
}
.header-tel:hover { transform: translateY(-1px); box-shadow: var(--sh-md); }
.header-tel__icon { width: 32px; height: 32px; border-radius: 50%; background: var(--c-green-dark); color: var(--c-gold); display: grid; place-items: center; flex-shrink: 0; }
.header-tel__num {
    font-family: var(--ff-en);
    font-size: var(--fs-18);
    font-weight: 700;
    color: var(--c-green-dark);
    letter-spacing: .02em;
    line-height: 1;
    white-space: nowrap;
}

.header-cta {
    position: relative;
    display: inline-flex; align-items: center; gap: 8px;
    padding: 12px 22px 12px 18px;
    font-size: var(--fs-14); font-weight: 700;
    color: #fff;
    background: linear-gradient(135deg, var(--c-emerald) 0%, var(--c-green) 50%, var(--c-green-dark) 100%);
    border-radius: var(--r-full);
    box-shadow: 0 6px 18px rgba(29,93,58,.35);
    transition: transform .15s, box-shadow .15s;
    overflow: hidden;
    white-space: nowrap;
    flex-shrink: 0;
    line-height: 1;
}
.header-cta::before { content: ""; position: absolute; inset: 0; background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.3) 50%, transparent 70%); transform: translateX(-100%); transition: transform .6s; }
.header-cta:hover { transform: translateY(-2px); box-shadow: 0 10px 24px rgba(29,93,58,.5); }
.header-cta:hover::before { transform: translateX(100%); }
.header-cta > span { display: inline-flex; align-items: center; }
.header-cta__icon { display: inline-flex; align-items: center; flex-shrink: 0; }
.header-cta__arrow { font-size: 16px; transition: transform .2s; flex-shrink: 0; }
.header-cta:hover .header-cta__arrow { transform: translateX(3px); }

@media (max-width: 1200px) {
    .header-cta { padding: 10px 18px 10px 14px; font-size: var(--fs-13); }
}
@media (max-width: 1100px) {
    .site-nav__list { gap: 16px; }
    .site-nav__link { font-size: var(--fs-13); }
}

.site-nav-toggle { display: none; }
@media (max-width: 1280px) {
    .site-nav { display: none; position: fixed; top: var(--header-h); right: 0; bottom: 0; left: 0; background: #fff; flex-direction: column; align-items: stretch; padding: 32px var(--gutter); gap: 16px; overflow-y: auto; margin-right: 0; }
    .site-nav.is-open { display: flex; }
    .site-nav__list { flex-direction: column; align-items: stretch; gap: 8px; flex-wrap: nowrap; margin-right: 0; }
    .site-nav__link { padding: 16px; border-bottom: 1px solid var(--c-border); }
    .header-tel, .header-cta { width: 100%; justify-content: center; }
    .site-nav-toggle { display: inline-flex; flex-direction: column; gap: 5px; padding: 12px; background: transparent; border: 0; flex-shrink: 0; }
    .site-nav-toggle span { display: block; width: 22px; height: 2px; background: var(--c-green-dark); transition: transform .2s, opacity .2s; }
    .site-nav-toggle.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
    .site-nav-toggle.is-open span:nth-child(2) { opacity: 0; }
    .site-nav-toggle.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
}

/* ===========================
   Hero（メイン画像のみ）
   =========================== */
.hero { position: relative; width: 100%; overflow: hidden; background: var(--c-green-dark); }
.hero__picture { display: block; }
.hero__image { display: block; width: 100%; height: auto; max-width: 100%; }

/* ===========================
   Post-Hero H1 バナー（派手）
   =========================== */
.post-hero {
    position: relative;
    padding: clamp(48px, 7vw, 80px) 0;
    background: linear-gradient(135deg, #0a1f12 0%, #1d5d3a 60%, #225e3c 100%);
    color: #fff;
    overflow: hidden;
}
.post-hero__bg {
    position: absolute; inset: 0;
    background:
      radial-gradient(ellipse at 80% 20%, rgba(201,161,58,.15), transparent 50%),
      radial-gradient(ellipse at 10% 80%, rgba(47,170,107,.18), transparent 55%);
    pointer-events: none;
}
.post-hero::before {
    content: ""; position: absolute; inset: 0;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='400' height='400' viewBox='0 0 400 400'><g fill='none' stroke='%23c9a13a' stroke-opacity='0.08' stroke-width='1.5'><circle cx='200' cy='200' r='180'/><circle cx='200' cy='200' r='130'/><circle cx='200' cy='200' r='80'/></g></svg>") center / 700px;
    opacity: .9; pointer-events: none;
}
.post-hero__inner { position: relative; text-align: center; }
.post-hero__eyebrow {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 10px 22px; margin-bottom: 28px;
    background: rgba(255,255,255,.08); border: 1.5px solid var(--c-gold);
    border-radius: var(--r-full);
    font-size: var(--fs-13); letter-spacing: .14em; color: var(--c-gold-soft); font-weight: 600;
}
.post-hero__eyebrow svg { color: var(--c-gold); }
.post-hero__h1 {
    font-family: var(--ff-display);
    font-size: clamp(28px, 5vw, 56px);
    line-height: 1.35;
    font-weight: 700;
    letter-spacing: .01em;
    margin-bottom: 28px;
    text-shadow: 0 4px 24px rgba(0,0,0,.3);
}
.post-hero__h1 em {
    font-style: normal;
    color: var(--c-gold-soft);
    position: relative;
    padding: 0 6px;
    background: linear-gradient(180deg, transparent 60%, rgba(201,161,58,.25) 60%);
}
.post-hero__sub {
    font-size: clamp(var(--fs-15), 1.4vw, var(--fs-18));
    line-height: 1.95; max-width: 760px; margin: 0 auto 32px;
    color: rgba(255,255,255,.92);
}
.post-hero__sub strong { color: var(--c-gold-soft); font-weight: 700; }
.post-hero__badges { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; }
.post-hero__badge {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 8px 16px;
    background: rgba(255,255,255,.1);
    border: 1px solid rgba(201,161,58,.4);
    border-radius: var(--r-full);
    font-size: var(--fs-13); color: rgba(255,255,255,.95); font-weight: 500;
    backdrop-filter: blur(6px);
    white-space: nowrap;
    line-height: 1.4;
}
.post-hero__badge svg { color: var(--c-gold-soft); flex-shrink: 0; }

/* ===========================
   Mega CTA（H1直下の派手CTA）
   =========================== */
.mega-cta {
    position: relative;
    padding: clamp(40px, 6vw, 64px) 0;
    background:
      radial-gradient(ellipse at 50% 0%, rgba(201,161,58,.18), transparent 60%),
      linear-gradient(180deg, #f5f2e8 0%, #fafbf9 100%);
    overflow: hidden;
}
.mega-cta__deco {
    position: absolute; top: -100px; left: -100px; width: 360px; height: 360px;
    background: radial-gradient(circle, rgba(47,170,107,.15), transparent 70%);
    pointer-events: none;
}
.mega-cta__inner { position: relative; }
.mega-cta__head { text-align: center; margin-bottom: 36px; }
.mega-cta__eyebrow { display: inline-flex; align-items: center; gap: 8px; padding: 8px 20px; background: var(--c-green-dark); color: var(--c-gold-soft); border-radius: var(--r-full); font-size: var(--fs-13); letter-spacing: .12em; font-weight: 600; margin-bottom: 16px; }
.mega-cta__title { font-family: var(--ff-display); font-size: clamp(24px, 3.5vw, 38px); color: var(--c-green-dark); line-height: 1.45; font-weight: 700; }
.mega-cta__title em { font-style: normal; color: var(--c-gold); background: linear-gradient(180deg, transparent 60%, rgba(201,161,58,.2) 60%); padding: 0 4px; }
.mega-cta__sub { margin-top: 12px; color: var(--c-text-mute); font-size: var(--fs-15); }

.mega-cta__actions { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; max-width: 920px; margin: 0 auto; }
@media (max-width: 768px) { .mega-cta__actions { grid-template-columns: 1fr; } }

.mega-tel, .mega-mail {
    position: relative;
    display: flex; align-items: center; gap: 18px;
    padding: 24px 26px;
    border-radius: var(--r-16);
    transition: transform .2s, box-shadow .2s;
    color: inherit;
    overflow: hidden;
    min-width: 0;
}
.mega-tel__body, .mega-mail__body { min-width: 0; }
.mega-tel__num, .mega-mail__main { white-space: nowrap; }
@media (max-width: 600px) {
    .mega-tel, .mega-mail { padding: 14px 14px; gap: 12px; }
    .mega-tel__icon, .mega-mail__icon { width: 44px; height: 44px; }
    .mega-tel__icon svg, .mega-mail__icon svg { width: 22px; height: 22px; }
    .mega-tel__num { font-size: 22px; letter-spacing: 0; }
    .mega-mail__main { font-size: var(--fs-16); }
    .mega-mail__arrow { font-size: 20px; }
    .mega-tel__label, .mega-mail__label { font-size: 10px; }
    .mega-tel__hours, .mega-mail__hours { font-size: 10px; }
}
@media (max-width: 360px) {
    .mega-tel__num { font-size: 19px; }
}
.mega-tel {
    background: #fff;
    border: 2px solid var(--c-green-dark);
    box-shadow: 0 8px 24px rgba(14,61,39,.15);
}
.mega-tel:hover { transform: translateY(-3px); box-shadow: 0 14px 36px rgba(14,61,39,.25); }
.mega-tel__icon { flex-shrink: 0; width: 64px; height: 64px; border-radius: 50%; background: var(--c-green-dark); color: var(--c-gold); display: grid; place-items: center; box-shadow: inset 0 0 0 4px rgba(201,161,58,.3); }
.mega-tel__body { display: flex; flex-direction: column; gap: 2px; line-height: 1.2; }
.mega-tel__label { font-size: var(--fs-12); color: var(--c-text-mute); letter-spacing: .12em; font-weight: 600; }
.mega-tel__num { font-family: var(--ff-en); font-size: clamp(28px, 3.5vw, 38px); font-weight: 700; color: var(--c-green-dark); letter-spacing: .02em; }
.mega-tel__hours { font-size: var(--fs-12); color: var(--c-text-mute); }

.mega-mail {
    background: linear-gradient(135deg, var(--c-gold) 0%, #b08825 100%);
    color: #1c1300;
    box-shadow: 0 8px 24px rgba(201,161,58,.4);
}
.mega-mail::before { content: ""; position: absolute; inset: 0; background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.4) 50%, transparent 70%); transform: translateX(-100%); transition: transform .8s; }
.mega-mail:hover { transform: translateY(-3px); box-shadow: 0 14px 36px rgba(201,161,58,.55); }
.mega-mail:hover::before { transform: translateX(100%); }
.mega-mail__icon { flex-shrink: 0; width: 64px; height: 64px; border-radius: 50%; background: #1c1300; color: var(--c-gold-soft); display: grid; place-items: center; }
.mega-mail__body { display: flex; flex-direction: column; gap: 2px; line-height: 1.2; flex: 1; }
.mega-mail__label { font-size: var(--fs-12); letter-spacing: .12em; font-weight: 600; opacity: .8; }
.mega-mail__main { font-size: var(--fs-22); font-weight: 700; }
.mega-mail__hours { font-size: var(--fs-12); opacity: .75; }
.mega-mail__arrow { font-size: 28px; font-weight: 700; transition: transform .2s; }
.mega-mail:hover .mega-mail__arrow { transform: translateX(6px); }

/* ===========================
   セクション共通
   =========================== */
.section { padding: clamp(60px, 9vw, 120px) 0; overflow-x: hidden; }
section { max-width: 100vw; }
.section--alt { background: var(--c-bg-soft); }
.section--dark { background: linear-gradient(135deg, var(--c-green-dark), var(--c-green-mid)); color: #fff; }
.section--sand { background: var(--c-bg-sand); }

.section__head { text-align: center; margin-bottom: clamp(40px, 6vw, 72px); }
.section__eyebrow { display: inline-block; font-size: var(--fs-13); letter-spacing: .24em; color: var(--c-green); font-family: var(--ff-en); font-weight: 600; margin-bottom: 12px; text-transform: uppercase; }
.section--dark .section__eyebrow { color: var(--c-gold-soft); }
.section__title { font-family: var(--ff-display); font-size: clamp(28px, 4vw, 44px); font-weight: 700; line-height: 1.3; letter-spacing: .02em; color: var(--c-green-dark); }
.section--dark .section__title { color: #fff; }
.section__lead { margin-top: 20px; font-size: var(--fs-16); line-height: 1.9; color: var(--c-text-mute); max-width: 720px; margin-inline: auto; }
.section--dark .section__lead { color: rgba(255,255,255,.85); }

/* ===========================
   Strengths（強み5枚・写真上＋本文下）
   =========================== */
.strengths { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 24px; }
.strength {
    position: relative;
    background: #fff;
    border-radius: var(--r-16);
    box-shadow: var(--sh-sm);
    border: 1px solid var(--c-border);
    transition: transform .2s, box-shadow .2s, border-color .2s;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}
.strength:hover { transform: translateY(-6px); box-shadow: var(--sh-lg); border-color: var(--c-emerald-light); }

/* 写真版 */
.strength__photo {
    position: relative;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: var(--c-sage);
}
.strength__photo img {
    width: 100%; height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    transition: transform .5s ease;
}
.strength:hover .strength__photo img { transform: scale(1.06); }
.strength__photo::after {
    content: "";
    position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 50%, rgba(14,61,39,.55) 100%);
    pointer-events: none;
}
.strength__num {
    position: absolute;
    top: 14px; left: 14px;
    z-index: 2;
    display: inline-flex; align-items: center;
    padding: 6px 14px;
    background: linear-gradient(135deg, var(--c-gold), #a07d20);
    color: #fff;
    font-family: var(--ff-display);
    font-size: var(--fs-12);
    letter-spacing: .2em;
    font-weight: 700;
    border-radius: var(--r-full);
    box-shadow: 0 4px 12px rgba(0,0,0,.2);
}

.strength__body-wrap { padding: 24px 24px 26px; flex: 1; display: flex; flex-direction: column; }
.strength__title {
    display: flex; align-items: center; gap: 10px;
    font-size: var(--fs-18); font-weight: 700;
    color: var(--c-green-dark);
    margin-bottom: 12px; line-height: 1.5;
}
.strength__title svg { color: var(--c-emerald); flex-shrink: 0; }
.strength__body { font-size: var(--fs-14); line-height: 1.85; color: var(--c-text-mute); }

/* ===========================
   Service grid
   =========================== */
.services { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 20px; }
.service {
    display: flex; flex-direction: column; gap: 12px;
    padding: 28px 24px;
    background: #fff;
    border-radius: var(--r-12);
    border: 1px solid var(--c-border);
    transition: transform .15s, border-color .15s, box-shadow .15s;
    color: inherit;
}
.service:hover { transform: translateY(-4px); border-color: var(--c-emerald); box-shadow: var(--sh-md); }
.service__icon { width: 48px; height: 48px; border-radius: var(--r-12); background: linear-gradient(135deg, var(--c-emerald), var(--c-green)); color: #fff; display: grid; place-items: center; font-size: 22px; }
.service__title { font-size: var(--fs-18); font-weight: 700; color: var(--c-green-dark); }
.service__desc { font-size: var(--fs-14); line-height: 1.7; color: var(--c-text-mute); flex: 1; }
.service__more { font-size: var(--fs-13); color: var(--c-green); font-weight: 600; display: inline-flex; align-items: center; gap: 4px; }
.service__more::after { content: "→"; transition: transform .2s; }
.service:hover .service__more::after { transform: translateX(4px); }

/* ===========================
   Representative（代表者）
   =========================== */
.rep { display: grid; grid-template-columns: 1fr 1.2fr; gap: clamp(32px, 5vw, 64px); align-items: center; }
@media (max-width: 768px) { .rep { grid-template-columns: 1fr; } }
.rep__photo { aspect-ratio: 4/5; background: var(--c-sage); border-radius: var(--r-24); position: relative; overflow: hidden; box-shadow: var(--sh-lg); }
.rep__photo img { width: 100%; height: 100%; object-fit: cover; object-position: center top; display: block; }
.rep__photo::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 70%, rgba(14,61,39,.25) 100%); pointer-events: none; }
.rep__body { font-size: var(--fs-15); line-height: 1.95; color: var(--c-text); }
.rep__eyebrow { font-size: var(--fs-13); letter-spacing: .2em; color: var(--c-gold); font-weight: 700; margin-bottom: 12px; }
.rep__title { font-family: var(--ff-display); font-size: clamp(24px, 3vw, 36px); line-height: 1.4; color: var(--c-green-dark); margin-bottom: 20px; }
.rep__name { font-size: var(--fs-18); font-weight: 700; margin-top: 24px; }
.rep__credentials { margin-top: 16px; display: flex; flex-wrap: wrap; gap: 8px; }
.rep__credentials span { padding: 6px 12px; background: var(--c-bg-soft); color: var(--c-green-dark); border-radius: var(--r-full); font-size: var(--fs-12); font-weight: 600; border: 1px solid var(--c-sage); white-space: nowrap; }
@media (max-width: 480px) {
    .rep__credentials span { font-size: 11px; padding: 5px 10px; }
}

/* ===========================
   CTA セクション
   =========================== */
.cta-band {
    position: relative; overflow: hidden;
    padding: clamp(60px, 8vw, 100px) 0;
    color: #fff;
    background:
      radial-gradient(ellipse at 80% 30%, rgba(201,161,58,.22), transparent 50%),
      linear-gradient(135deg, #0a1f12 0%, #1d5d3a 100%);
}
.cta-band__inner { text-align: center; display: flex; flex-direction: column; align-items: center; gap: 24px; }
.cta-band__title { font-family: var(--ff-display); font-size: clamp(24px, 3.5vw, 38px); line-height: 1.4; }
.cta-band__sub { font-size: var(--fs-16); opacity: .9; max-width: 640px; line-height: 1.85; }
.cta-band__buttons { display: flex; flex-wrap: wrap; gap: 16px; justify-content: center; margin-top: 12px; }
.cta-band__tel { display: flex; flex-direction: column; align-items: center; gap: 4px; }
.cta-band__tel a { font-family: var(--ff-en); font-size: clamp(32px, 5vw, 48px); font-weight: 700; color: var(--c-gold-soft); letter-spacing: .04em; }
.cta-band__tel-note { font-size: var(--fs-13); opacity: .8; }

/* ===========================
   News（お知らせ）
   =========================== */
.news { display: flex; flex-direction: column; gap: 4px; max-width: 800px; margin-inline: auto; }
.news__item { display: grid; grid-template-columns: 100px 1fr; gap: 24px; padding: 20px 24px; border-bottom: 1px solid var(--c-border); align-items: baseline; transition: background .15s; }
.news__item:hover { background: var(--c-bg-soft); }
.news__date { font-family: var(--ff-en); font-size: var(--fs-13); color: var(--c-text-mute); white-space: nowrap; }
.news__title { font-size: var(--fs-15); font-weight: 500; line-height: 1.65; color: var(--c-text); }
@media (max-width: 640px) {
    .news__item { grid-template-columns: 1fr; gap: 4px; padding: 16px 8px; }
}

/* ===========================
   Access
   =========================== */
.access { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; align-items: stretch; }
@media (max-width: 768px) { .access { grid-template-columns: 1fr; } }
.access__visual { display: flex; flex-direction: column; gap: 16px; }
.access__photo { border-radius: var(--r-16); overflow: hidden; box-shadow: var(--sh-md); aspect-ratio: 3/2; background: var(--c-sage); }
.access__photo picture, .access__photo img { width: 100%; height: 100%; display: block; }
.access__photo img { object-fit: cover; }
.access__map { border-radius: var(--r-16); overflow: hidden; box-shadow: var(--sh-md); background: var(--c-sage); min-height: 240px; display: grid; place-items: center; color: var(--c-green-dark); font-size: var(--fs-14); }
.access__map iframe { width: 100%; height: 100%; min-height: 240px; }
.access__info { background: #fff; padding: 32px 28px; border-radius: var(--r-16); border: 1px solid var(--c-border); }
.access__row { display: grid; grid-template-columns: 100px 1fr; gap: 16px; padding: 14px 0; border-bottom: 1px solid var(--c-border); font-size: var(--fs-14); line-height: 1.75; }
.access__row:last-child { border-bottom: 0; }
.access__label { font-weight: 700; color: var(--c-green-dark); font-size: var(--fs-13); }
.access__value { color: var(--c-text); }

/* ===========================
   Footer（リッチ版）
   =========================== */
.site-footer {
    position: relative;
    background: linear-gradient(180deg, #0e3d27 0%, #0a1f12 60%, #061a0e 100%);
    color: rgba(255,255,255,.85);
    overflow: hidden;
}
.site-footer__pattern {
    position: absolute; inset: 0;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='400' height='400' viewBox='0 0 400 400'><g fill='none' stroke='%23c9a13a' stroke-opacity='0.05' stroke-width='1.2'><circle cx='200' cy='200' r='180'/><circle cx='200' cy='200' r='130'/><circle cx='200' cy='200' r='80'/></g></svg>") center / 600px;
    pointer-events: none;
}

/* CTA帯 */
.site-footer__cta {
    position: relative;
    padding: 32px 0;
    background: linear-gradient(135deg, rgba(201,161,58,.18) 0%, rgba(47,170,107,.12) 100%);
    border-bottom: 1px solid rgba(255,255,255,.1);
}
.site-footer__cta-inner {
    display: flex; align-items: center; justify-content: space-between; gap: 24px;
    flex-wrap: wrap;
}
.site-footer__cta-text { display: flex; flex-direction: column; gap: 8px; }
.site-footer__cta-eyebrow {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 4px 12px;
    background: var(--c-gold);
    color: #1c1300;
    font-size: var(--fs-12);
    font-weight: 700;
    letter-spacing: .12em;
    border-radius: var(--r-full);
    align-self: flex-start;
}
.site-footer__cta-title { font-family: var(--ff-display); font-size: clamp(20px, 2.5vw, 26px); color: #fff; font-weight: 700; margin: 0; }
.site-footer__cta-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; align-items: stretch; }
@media (max-width: 768px) { .site-footer__cta-actions { grid-template-columns: 1fr; } }

.site-footer__cta-card {
    position: relative;
    display: flex; align-items: center; gap: 14px;
    padding: 14px 20px;
    border-radius: var(--r-12);
    color: inherit;
    overflow: hidden;
    transition: transform .15s, box-shadow .2s, background .15s, border-color .15s;
    min-height: 74px;
    min-width: 0;
}
.site-footer__cta-card--tel {
    background: rgba(255,255,255,.08);
    border: 1.5px solid rgba(201,161,58,.4);
    color: #fff;
    backdrop-filter: blur(6px);
}
.site-footer__cta-card--tel:hover { background: rgba(201,161,58,.16); border-color: var(--c-gold); transform: translateY(-2px); }
.site-footer__cta-card--mail {
    background: linear-gradient(135deg, var(--c-gold) 0%, #a07d20 100%);
    border: 1.5px solid rgba(255,255,255,.3);
    color: #1c1300;
    box-shadow: 0 8px 20px rgba(201,161,58,.4);
}
.site-footer__cta-card--mail::before { content: ""; position: absolute; inset: 0; background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.4) 50%, transparent 70%); transform: translateX(-100%); transition: transform .8s; }
.site-footer__cta-card--mail:hover { transform: translateY(-2px); box-shadow: 0 14px 28px rgba(201,161,58,.55); }
.site-footer__cta-card--mail:hover::before { transform: translateX(100%); }

.site-footer__cta-card-icon {
    width: 44px; height: 44px;
    border-radius: 50%;
    display: grid; place-items: center;
    flex-shrink: 0;
}
.site-footer__cta-card--tel .site-footer__cta-card-icon { background: var(--c-gold); color: var(--c-green-dark); }
.site-footer__cta-card--mail .site-footer__cta-card-icon { background: #1c1300; color: var(--c-gold-soft); }

.site-footer__cta-card-body { display: flex; flex-direction: column; gap: 2px; line-height: 1.2; min-width: 0; flex: 1; }
.site-footer__cta-card-label { font-size: 11px; letter-spacing: .12em; font-weight: 600; opacity: .8; }
.site-footer__cta-card-main { font-family: var(--ff-en); font-size: var(--fs-20); font-weight: 700; white-space: nowrap; }
.site-footer__cta-card--mail .site-footer__cta-card-main { font-family: var(--ff-jp); font-size: var(--fs-18); }
.site-footer__cta-card-arrow { font-size: 22px; font-weight: 700; transition: transform .2s; flex-shrink: 0; }
.site-footer__cta-card--mail:hover .site-footer__cta-card-arrow { transform: translateX(4px); }

@media (max-width: 480px) {
    .site-footer__cta-card { padding: 12px 14px; gap: 10px; }
    .site-footer__cta-card-icon { width: 38px; height: 38px; }
    .site-footer__cta-card-icon svg { width: 20px; height: 20px; }
    .site-footer__cta-card-main { font-size: var(--fs-17); }
}

/* メイングリッド */
.site-footer__main { position: relative; padding: 56px 0 40px; }
.site-footer__grid {
    display: grid;
    grid-template-columns: 1.5fr 1fr 1fr 1.1fr;
    gap: 40px;
}
@media (max-width: 1024px) { .site-footer__grid { grid-template-columns: 1fr 1fr; gap: 36px; } }
@media (max-width: 600px) { .site-footer__grid { grid-template-columns: 1fr; gap: 32px; } }

.site-footer__brand { display: flex; align-items: center; gap: 14px; margin-bottom: 20px; }
.site-footer__logo {
    width: 56px; height: 56px;
    background: #fff; border-radius: 12px; padding: 6px;
    object-fit: contain;
    box-shadow: 0 4px 12px rgba(0,0,0,.25);
}
.site-footer__brand-text { display: flex; flex-direction: column; line-height: 1.2; }
.site-footer__brand-name { font-size: var(--fs-18); font-weight: 700; color: #fff; }
.site-footer__brand-en { font-size: var(--fs-11); color: var(--c-gold-soft); letter-spacing: .14em; font-family: var(--ff-en); margin-top: 4px; }
.site-footer__about { font-size: var(--fs-13); line-height: 1.85; color: rgba(255,255,255,.7); margin: 16px 0 20px; }

.site-footer__contact { display: flex; flex-direction: column; gap: 10px; padding: 16px; background: rgba(255,255,255,.04); border-radius: var(--r-12); border: 1px solid rgba(255,255,255,.08); }
.site-footer__contact-row { display: flex; gap: 10px; align-items: flex-start; margin: 0; font-size: var(--fs-12); color: rgba(255,255,255,.85); line-height: 1.6; }
.site-footer__contact-row a { color: var(--c-gold-soft); font-weight: 600; }
.site-footer__contact-row a:hover { color: var(--c-gold); }
.site-footer__contact-icon { display: inline-flex; flex-shrink: 0; color: var(--c-gold-soft); margin-top: 2px; }

.site-footer__title {
    font-size: var(--fs-13); font-weight: 700;
    color: var(--c-gold-soft); letter-spacing: .18em;
    margin-bottom: 18px; text-transform: uppercase;
    font-family: var(--ff-en);
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(201,161,58,.2);
    display: flex; align-items: center; gap: 8px;
}
.site-footer__title::before { content: ""; display: inline-block; width: 4px; height: 14px; background: var(--c-gold); border-radius: 2px; }

.site-footer__list { display: flex; flex-direction: column; gap: 10px; }
.site-footer__list a {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: var(--fs-13); color: rgba(255,255,255,.75);
    transition: color .15s, transform .15s;
}
.site-footer__list a::before { content: "›"; color: var(--c-gold-soft); font-weight: 700; opacity: .6; }
.site-footer__list a:hover { color: #fff; transform: translateX(3px); }
.site-footer__list a:hover::before { opacity: 1; }

/* 所属・登録 */
.site-footer__creds { display: flex; flex-direction: column; gap: 10px; margin-bottom: 18px; }
.site-footer__creds li { display: flex; gap: 12px; font-size: var(--fs-12); padding: 8px 12px; background: rgba(255,255,255,.04); border-radius: 8px; border-left: 3px solid var(--c-gold); }
.site-footer__creds-label { color: var(--c-gold-soft); font-weight: 700; min-width: 64px; }
.site-footer__creds-val { color: #fff; }

.site-footer__memberships { display: flex; flex-wrap: wrap; gap: 6px; }
.site-footer__chip { display: inline-block; padding: 4px 10px; background: rgba(255,255,255,.06); border: 1px solid rgba(201,161,58,.25); border-radius: var(--r-full); font-size: 11px; color: rgba(255,255,255,.8); }

/* ボトムバー */
.site-footer__bottom {
    position: relative;
    padding: 20px 0;
    background: rgba(0,0,0,.3);
    border-top: 1px solid rgba(255,255,255,.08);
}
.site-footer__bottom-inner { display: flex; justify-content: space-between; align-items: center; gap: 24px; flex-wrap: wrap; }
.site-footer__copy { margin: 0; font-size: var(--fs-12); color: rgba(255,255,255,.55); }
.site-footer__legal { display: flex; gap: 24px; flex-wrap: wrap; }
.site-footer__legal a { font-size: var(--fs-12); color: rgba(255,255,255,.7); }
.site-footer__legal a:hover { color: var(--c-gold-soft); }

/* ===========================
   Worries（こんなお悩み）
   =========================== */
.worries { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 16px; }
.worry { display: flex; align-items: flex-start; gap: 14px; padding: 22px 22px; background: #fff; border-radius: var(--r-12); border: 1px solid var(--c-border); transition: transform .15s, border-color .15s, box-shadow .15s; }
.worry:hover { transform: translateY(-3px); border-color: var(--c-emerald); box-shadow: var(--sh-md); }
.worry__check { flex-shrink: 0; width: 28px; height: 28px; border-radius: 50%; background: linear-gradient(135deg, var(--c-emerald), var(--c-green)); color: #fff; display: grid; place-items: center; font-size: 14px; font-weight: 700; }
.worry__text { font-size: var(--fs-14); line-height: 1.7; color: var(--c-text); font-weight: 500; }

/* ===========================
   Areas（対応地域）
   =========================== */
.area-intro { text-align: center; max-width: 680px; margin: 0 auto 32px; font-size: var(--fs-15); line-height: 1.85; color: var(--c-text-mute); }

/* 対応エリアのバナー画像（タグ一覧の上） */
.area-banner {
    margin: 0 0 32px;
    border-radius: var(--r-16);
    overflow: hidden;
    box-shadow: var(--sh-md);
    background: var(--c-bg-soft);
    line-height: 0;
    transition: transform .3s, box-shadow .3s;
}
.area-banner:hover { transform: translateY(-3px); box-shadow: var(--sh-lg); }
.area-banner img { width: 100%; height: auto; display: block; }
@media (max-width: 768px) {
    .area-banner { margin-bottom: 24px; }
}
.area-block { background: #fff; border: 1px solid var(--c-border); border-radius: var(--r-16); padding: 28px; margin-bottom: 16px; }
.area-block__title { font-size: var(--fs-16); font-weight: 700; color: var(--c-green-dark); margin-bottom: 14px; display: flex; align-items: center; gap: 10px; }
.area-block__title::before { content: ""; display: block; width: 4px; height: 18px; background: var(--c-green); border-radius: 2px; }
.area-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.area-tag { display: inline-block; padding: 8px 14px; background: var(--c-bg-soft); color: var(--c-green-dark); border: 1px solid var(--c-sage); border-radius: var(--r-full); font-size: var(--fs-13); font-weight: 500; transition: background .15s, color .15s; line-height: 1.5; }
@media (max-width: 480px) {
    .area-tag { font-size: var(--fs-12); padding: 7px 12px; }
}
.area-tag--strong { background: var(--c-green); color: #fff; border-color: var(--c-green); font-weight: 700; }
.area-tag:hover { background: var(--c-emerald); color: #fff; border-color: var(--c-emerald); }
.area-note { margin-top: 16px; padding: 14px 18px; background: var(--c-bg-sand); border-left: 3px solid var(--c-gold); border-radius: 6px; font-size: var(--fs-13); color: var(--c-text-mute); line-height: 1.7; }

/* ===========================
   Industries（業種別）
   =========================== */
.industries { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 12px; }
.industry { display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 24px 16px; background: #fff; border-radius: var(--r-12); border: 1px solid var(--c-border); transition: transform .15s, border-color .15s; color: inherit; text-align: center; }
.industry:hover { transform: translateY(-3px); border-color: var(--c-emerald); }
.industry__icon { font-size: 32px; line-height: 1; }
.industry__name { font-size: var(--fs-14); font-weight: 700; color: var(--c-green-dark); }
.industry__kw { font-size: var(--fs-12); color: var(--c-text-mute); line-height: 1.5; }

/* ===========================
   Price summary（料金抜粋）
   =========================== */
.price-summary { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 16px; }
.price-card { padding: 28px 24px; background: #fff; border: 1px solid var(--c-border); border-radius: var(--r-16); position: relative; overflow: hidden; }
.price-card--featured { border-color: var(--c-green); box-shadow: var(--sh-md); }
.price-card__label { font-size: var(--fs-13); color: var(--c-text-mute); letter-spacing: .04em; font-weight: 600; }
.price-card__name { font-size: var(--fs-18); font-weight: 700; color: var(--c-green-dark); margin: 6px 0 16px; }
.price-card__price { font-family: var(--ff-display); font-size: clamp(28px, 3.5vw, 36px); color: var(--c-green-dark); font-weight: 700; line-height: 1; }
.price-card__unit { font-size: var(--fs-14); color: var(--c-text-mute); margin-left: 6px; font-weight: 500; }
.price-card__desc { margin-top: 12px; font-size: var(--fs-13); line-height: 1.7; color: var(--c-text-mute); }

/* ===========================
   Flow（ご利用の流れ）
   =========================== */
.flow { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; counter-reset: flow-counter; }
@media (max-width: 768px) { .flow { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .flow { grid-template-columns: 1fr; } }
.flow__step { position: relative; padding: 32px 22px 24px; background: #fff; border: 1px solid var(--c-border); border-radius: var(--r-12); text-align: center; counter-increment: flow-counter; }
.flow__step::before { content: "STEP " counter(flow-counter); position: absolute; top: -14px; left: 50%; transform: translateX(-50%); background: var(--c-green); color: #fff; padding: 6px 16px; font-size: var(--fs-12); letter-spacing: .1em; border-radius: var(--r-full); font-weight: 700; font-family: var(--ff-en); }
.flow__icon { font-size: 36px; margin-bottom: 12px; line-height: 1; }
.flow__title { font-size: var(--fs-16); font-weight: 700; color: var(--c-green-dark); margin-bottom: 8px; }
.flow__desc { font-size: var(--fs-13); line-height: 1.7; color: var(--c-text-mute); }

/* ===========================
   4セクショングリッド（実績/コラム/声/お知らせ）
   =========================== */
.grid-4 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
@media (max-width: 768px) { .grid-4 { grid-template-columns: 1fr; } }
.panel { background: #fff; border: 1px solid var(--c-border); border-radius: var(--r-16); padding: 28px 24px 24px; display: flex; flex-direction: column; }
.panel__head { display: flex; align-items: center; justify-content: space-between; padding-bottom: 16px; margin-bottom: 16px; border-bottom: 2px solid var(--c-bg-soft); }
.panel__title { font-size: var(--fs-18); font-weight: 700; color: var(--c-green-dark); display: flex; align-items: center; gap: 10px; }
.panel__title::before { content: ""; display: inline-block; width: 6px; height: 22px; background: linear-gradient(180deg, var(--c-green), var(--c-emerald)); border-radius: 3px; }
.panel__more { font-size: var(--fs-13); color: var(--c-green); font-weight: 600; }
.panel__more::after { content: " →"; transition: transform .15s; display: inline-block; }
.panel__more:hover::after { transform: translateX(3px); }
.panel__body { flex: 1; display: flex; flex-direction: column; gap: 12px; }

/* 実績用 */
.work-item { display: grid; grid-template-columns: 80px 1fr; gap: 14px; padding: 12px 0; border-bottom: 1px dashed var(--c-border); }
.work-item:last-child { border-bottom: 0; }
.work-item__cat { font-size: var(--fs-11); background: var(--c-bg-soft); color: var(--c-green-dark); padding: 4px 8px; border-radius: 4px; text-align: center; align-self: start; font-weight: 600; letter-spacing: .04em; }
.work-item__text { font-size: var(--fs-13); line-height: 1.7; color: var(--c-text); }

/* コラム用 */
.column-item { display: flex; gap: 12px; padding: 12px 0; border-bottom: 1px dashed var(--c-border); }
.column-item:last-child { border-bottom: 0; }
.column-item__thumb { flex-shrink: 0; width: 64px; height: 64px; border-radius: 8px; background: linear-gradient(135deg, var(--c-sage), var(--c-emerald-light)); display: grid; place-items: center; color: #fff; font-size: 22px; }
.column-item__body { display: flex; flex-direction: column; gap: 4px; }
.column-item__date { font-size: var(--fs-12); color: var(--c-text-mute); font-family: var(--ff-en); }
.column-item__title { font-size: var(--fs-13); line-height: 1.6; color: var(--c-text); font-weight: 500; }

/* お客様の声用 */
.voice-item { padding: 14px 0; border-bottom: 1px dashed var(--c-border); }
.voice-item:last-child { border-bottom: 0; }
.voice-item__cat { display: inline-block; font-size: var(--fs-11); background: var(--c-gold); color: #1c1300; padding: 3px 10px; border-radius: var(--r-full); margin-bottom: 6px; font-weight: 700; }
.voice-item__title { font-size: var(--fs-13); font-weight: 700; color: var(--c-green-dark); margin-bottom: 4px; line-height: 1.5; }
.voice-item__excerpt { font-size: var(--fs-12); line-height: 1.7; color: var(--c-text-mute); }

/* お知らせ用 */
.news-item { display: flex; gap: 12px; padding: 12px 0; border-bottom: 1px dashed var(--c-border); align-items: baseline; }
.news-item:last-child { border-bottom: 0; }
.news-item__date { font-family: var(--ff-en); font-size: var(--fs-12); color: var(--c-text-mute); white-space: nowrap; min-width: 80px; }
.news-item__tag { font-size: var(--fs-11); background: var(--c-bg-soft); color: var(--c-green); padding: 2px 8px; border-radius: 4px; font-weight: 600; }
.news-item__title { font-size: var(--fs-13); line-height: 1.6; color: var(--c-text); }

/* ===========================
   FAQ
   =========================== */
.faq { max-width: 840px; margin-inline: auto; display: flex; flex-direction: column; gap: 12px; }
.faq__item { background: #fff; border: 1px solid var(--c-border); border-radius: var(--r-12); overflow: hidden; }
.faq__q { display: flex; align-items: center; gap: 16px; padding: 20px 24px; cursor: pointer; font-size: var(--fs-15); font-weight: 700; color: var(--c-green-dark); line-height: 1.6; list-style: none; }
.faq__q::-webkit-details-marker { display: none; }
.faq__q::before { content: "Q"; flex-shrink: 0; width: 32px; height: 32px; border-radius: 50%; background: var(--c-green); color: #fff; display: grid; place-items: center; font-family: var(--ff-display); font-weight: 700; }
.faq__q::after { content: "+"; margin-left: auto; font-size: 24px; color: var(--c-green); font-weight: 300; transition: transform .2s; }
.faq__item[open] .faq__q::after { transform: rotate(45deg); }
.faq__a { padding: 0 24px 24px 72px; font-size: var(--fs-14); line-height: 1.85; color: var(--c-text-mute); }

/* ===========================
   影絵SVGアイコン共通
   =========================== */
.ico { display: inline-block; vertical-align: middle; fill: currentColor; flex-shrink: 0; }

/* 強み・業務・業種・流れの影絵アイコンを「丸枠＋緑」で統一 */
.strength__icon { width: 88px; height: 88px; margin: 16px 0 22px; border-radius: 50%; background: linear-gradient(135deg, var(--c-bg-sand), var(--c-sage)); display: grid; place-items: center; color: var(--c-green-dark); transition: transform .25s, background .25s; }
.strength:hover .strength__icon { transform: rotate(-6deg) scale(1.05); background: linear-gradient(135deg, var(--c-gold-soft), var(--c-gold)); color: var(--c-green-dark); }

.service__icon { width: 64px; height: 64px; border-radius: var(--r-16); background: linear-gradient(135deg, var(--c-emerald) 0%, var(--c-green-dark) 100%); color: #fff; display: grid; place-items: center; transition: transform .2s; box-shadow: var(--sh-sm); }
.service:hover .service__icon { transform: scale(1.08) rotate(-4deg); }

.industry__icon { width: 56px; height: 56px; border-radius: 50%; background: var(--c-bg-soft); color: var(--c-green-dark); display: grid; place-items: center; line-height: 1; transition: transform .2s, background .2s, color .2s; }
.industry:hover .industry__icon { background: var(--c-green-dark); color: var(--c-gold-soft); transform: scale(1.08); }

.flow__icon { width: 72px; height: 72px; border-radius: 50%; background: linear-gradient(135deg, var(--c-emerald) 0%, var(--c-green) 100%); color: #fff; display: grid; place-items: center; margin: 0 auto 14px; box-shadow: var(--sh-sm); }

/* ===========================
   強み 3-2 レイアウト
   =========================== */
.strengths--3-2 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.strengths--3-2 > .strength:nth-child(4) { grid-column: 1 / span 1; grid-row: 2; }
.strengths--3-2 > .strength:nth-child(5) { grid-column: 2 / span 1; grid-row: 2; }
/* 4・5枚目を中央に寄せるため2列目・3列目の中央2マスに配置 */
.strengths--3-2 > .strength:nth-child(4) { grid-column: 1 / 2; }
.strengths--3-2 > .strength:nth-child(5) { grid-column: 2 / 3; }
/* PCで2行目を中央寄せ：grid-template-rowsで再配置 */
@media (min-width: 1025px) {
    .strengths--3-2 {
        grid-template-columns: repeat(6, 1fr);
    }
    .strengths--3-2 > .strength:nth-child(1) { grid-column: 1 / span 2; }
    .strengths--3-2 > .strength:nth-child(2) { grid-column: 3 / span 2; }
    .strengths--3-2 > .strength:nth-child(3) { grid-column: 5 / span 2; }
    .strengths--3-2 > .strength:nth-child(4) { grid-column: 2 / span 2; grid-row: 2; }
    .strengths--3-2 > .strength:nth-child(5) { grid-column: 4 / span 2; grid-row: 2; }
}
@media (max-width: 768px) {
    .strengths--3-2 { grid-template-columns: 1fr; }
    .strengths--3-2 > .strength { grid-column: auto !important; grid-row: auto !important; }
}

/* ===========================
   業務 4-2 レイアウト（下2を中央寄せ）
   =========================== */
.services--4-2 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
@media (min-width: 1025px) {
    .services--4-2 {
        grid-template-columns: repeat(8, 1fr);
    }
    .services--4-2 > .service:nth-child(1) { grid-column: 1 / span 2; }
    .services--4-2 > .service:nth-child(2) { grid-column: 3 / span 2; }
    .services--4-2 > .service:nth-child(3) { grid-column: 5 / span 2; }
    .services--4-2 > .service:nth-child(4) { grid-column: 7 / span 2; }
    .services--4-2 > .service:nth-child(5) { grid-column: 3 / span 2; grid-row: 2; }
    .services--4-2 > .service:nth-child(6) { grid-column: 5 / span 2; grid-row: 2; }
}
@media (max-width: 1024px) and (min-width: 769px) {
    .services--4-2 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
    .services--4-2 { grid-template-columns: 1fr; }
}
/* 7枚レイアウト（上4枚＋下3枚 中央寄せ） */
.services--4-3 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
@media (min-width: 1025px) {
    .services--4-3 { grid-template-columns: repeat(8, 1fr); }
    .services--4-3 > .service:nth-child(1) { grid-column: 1 / span 2; }
    .services--4-3 > .service:nth-child(2) { grid-column: 3 / span 2; }
    .services--4-3 > .service:nth-child(3) { grid-column: 5 / span 2; }
    .services--4-3 > .service:nth-child(4) { grid-column: 7 / span 2; }
    .services--4-3 > .service:nth-child(5) { grid-column: 2 / span 2; grid-row: 2; }
    .services--4-3 > .service:nth-child(6) { grid-column: 4 / span 2; grid-row: 2; }
    .services--4-3 > .service:nth-child(7) { grid-column: 6 / span 2; grid-row: 2; }
}
@media (max-width: 1024px) and (min-width: 769px) {
    .services--4-3 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
    .services--4-3 { grid-template-columns: 1fr; }
}

/* ===========================
   業種 4-4-2 レイアウト
   =========================== */
.industries--4-4-2 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
@media (min-width: 1025px) {
    .industries--4-4-2 {
        grid-template-columns: repeat(8, 1fr);
    }
    /* 1〜8番目：4列ずつ（各2マス） */
    .industries--4-4-2 > .industry:nth-child(1) { grid-column: 1 / span 2; }
    .industries--4-4-2 > .industry:nth-child(2) { grid-column: 3 / span 2; }
    .industries--4-4-2 > .industry:nth-child(3) { grid-column: 5 / span 2; }
    .industries--4-4-2 > .industry:nth-child(4) { grid-column: 7 / span 2; }
    .industries--4-4-2 > .industry:nth-child(5) { grid-column: 1 / span 2; grid-row: 2; }
    .industries--4-4-2 > .industry:nth-child(6) { grid-column: 3 / span 2; grid-row: 2; }
    .industries--4-4-2 > .industry:nth-child(7) { grid-column: 5 / span 2; grid-row: 2; }
    .industries--4-4-2 > .industry:nth-child(8) { grid-column: 7 / span 2; grid-row: 2; }
    /* 9・10：中央寄せ */
    .industries--4-4-2 > .industry:nth-child(9)  { grid-column: 3 / span 2; grid-row: 3; }
    .industries--4-4-2 > .industry:nth-child(10) { grid-column: 5 / span 2; grid-row: 3; }
}
@media (max-width: 1024px) and (min-width: 481px) {
    .industries--4-4-2 { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 480px) {
    .industries--4-4-2 { grid-template-columns: repeat(2, 1fr); }
}

/* ===========================
   料金リッチ化
   =========================== */
.price-summary--rich { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
@media (max-width: 1024px) and (min-width: 769px) { .price-summary--rich { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 768px) { .price-summary--rich { grid-template-columns: 1fr; } }
/* 2枚用（横に広げる） */
.price-summary--duo { grid-template-columns: repeat(2, 1fr); max-width: 800px; margin-inline: auto; }
@media (max-width: 600px) { .price-summary--duo { grid-template-columns: 1fr; } }

.price-summary--rich .price-card {
    position: relative;
    padding: 0 24px 28px;
    background: #fff;
    border: 1.5px solid var(--c-border);
    border-radius: var(--r-16);
    overflow: hidden;
    transition: transform .2s, box-shadow .2s, border-color .2s;
    display: flex; flex-direction: column;
    text-align: center;
}
.price-summary--rich .price-card:hover { transform: translateY(-6px); box-shadow: var(--sh-lg); border-color: var(--c-emerald); }
.price-summary--rich .price-card--featured {
    border-color: var(--c-gold);
    background: linear-gradient(180deg, #fff 0%, #fbf7ea 100%);
    box-shadow: 0 10px 30px rgba(201,161,58,.25);
}

/* リボンを「上部フル幅の色帯」に変更 */
.price-card__ribbon {
    display: flex; align-items: center; justify-content: center; gap: 6px;
    margin: 0 -24px 0;
    padding: 10px 12px;
    background: var(--c-bg-soft);
    color: var(--c-green-dark);
    font-size: var(--fs-12);
    font-weight: 700;
    letter-spacing: .08em;
    border-bottom: 1px solid var(--c-border);
}
.price-card--featured .price-card__ribbon {
    background: linear-gradient(90deg, var(--c-gold) 0%, var(--c-gold-soft) 50%, var(--c-gold) 100%);
    color: #1c1300;
    border-bottom: 0;
}
.price-card__ribbon svg { color: inherit; }

/* アイコンは中央上に大きく */
.price-card__icon-circle {
    margin: 24px auto 16px;
    width: 72px; height: 72px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--c-emerald), var(--c-green-dark));
    color: #fff;
    display: grid; place-items: center;
    box-shadow: var(--sh-sm);
}
.price-card--featured .price-card__icon-circle {
    background: linear-gradient(135deg, var(--c-gold), #a07d20);
    color: #fff;
}

.price-card__name {
    margin: 0 0 16px;
    font-size: var(--fs-18);
    font-weight: 700;
    line-height: 1.45;
    color: var(--c-green-dark);
}

.price-card__price-wrap {
    display: flex; flex-direction: column;
    padding: 16px 0;
    border-top: 1px dashed var(--c-border);
    border-bottom: 1px dashed var(--c-border);
    margin-bottom: 18px;
}
.price-card__price-from { font-size: var(--fs-12); color: var(--c-text-mute); letter-spacing: .08em; font-weight: 600; }
.price-card__price {
    font-family: var(--ff-display);
    font-size: clamp(30px, 3vw, 38px);
    color: var(--c-green-dark);
    font-weight: 700;
    line-height: 1.1;
    margin-top: 4px;
}
.price-card--featured .price-card__price { color: #a07d20; }
.price-card__unit { font-size: var(--fs-14); color: var(--c-text-mute); margin-left: 4px; font-weight: 500; }
.price-card__price-tax { font-size: var(--fs-11); color: var(--c-text-mute); margin-top: 4px; }

.price-card__feats { display: flex; flex-direction: column; gap: 8px; margin-bottom: 20px; flex: 1; }
.price-card__feats li { display: flex; align-items: flex-start; gap: 8px; font-size: var(--fs-13); line-height: 1.6; color: var(--c-text); }
.price-card__feats svg { color: var(--c-emerald); flex-shrink: 0; margin-top: 4px; }

.price-card__btn {
    display: block; text-align: center;
    padding: 12px 16px;
    background: var(--c-green-dark);
    color: #fff;
    border-radius: var(--r-full);
    font-size: var(--fs-13);
    font-weight: 700;
    transition: background .15s, transform .15s;
}
.price-card__btn:hover { background: var(--c-green); transform: translateY(-2px); }
.price-card--featured .price-card__btn { background: linear-gradient(135deg, var(--c-gold), #a07d20); color: #fff; }
.price-card--featured .price-card__btn:hover { background: linear-gradient(135deg, #a07d20, #7a5f15); }

.price-note { margin-top: 36px; padding: 16px 24px; background: rgba(255,255,255,.6); border-radius: var(--r-12); border-left: 4px solid var(--c-gold); }
.price-note p { display: flex; align-items: center; gap: 8px; font-size: var(--fs-13); color: var(--c-text-mute); margin: 0; }
.price-note svg { color: var(--c-gold); flex-shrink: 0; }

/* ===========================
   下部CTA（cta-pro 派手版）
   =========================== */
.cta-pro {
    position: relative;
    padding: clamp(60px, 8vw, 100px) 0;
    background:
      radial-gradient(ellipse at 80% 20%, rgba(201,161,58,.25), transparent 50%),
      radial-gradient(ellipse at 15% 80%, rgba(47,170,107,.2), transparent 55%),
      linear-gradient(135deg, #0a1f12 0%, #0e3d27 50%, #1d5d3a 100%);
    color: #fff;
    overflow: hidden;
}
.cta-pro__pattern {
    position: absolute; inset: 0;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='600' height='600' viewBox='0 0 600 600'><g fill='none' stroke='%23c9a13a' stroke-opacity='0.08' stroke-width='1.5'><circle cx='300' cy='300' r='250'/><circle cx='300' cy='300' r='180'/><circle cx='300' cy='300' r='110'/></g></svg>") center / 800px;
    pointer-events: none;
}
.cta-pro__deco-left, .cta-pro__deco-right {
    position: absolute; top: 50%; transform: translateY(-50%); width: 300px; height: 300px;
    background: radial-gradient(circle, rgba(201,161,58,.18), transparent 70%);
    pointer-events: none;
}
.cta-pro__deco-left { left: -150px; }
.cta-pro__deco-right { right: -150px; }

.cta-pro__inner { position: relative; }
.cta-pro__head { text-align: center; margin-bottom: 40px; }
.cta-pro__eyebrow {
    display: inline-flex; align-items: center; gap: 10px;
    padding: 10px 24px; margin-bottom: 24px;
    background: rgba(201,161,58,.12);
    border: 1.5px solid var(--c-gold);
    border-radius: var(--r-full);
    font-size: var(--fs-13); letter-spacing: .18em;
    color: var(--c-gold-soft); font-weight: 600;
    font-family: var(--ff-en);
}
.cta-pro__eyebrow svg { color: var(--c-gold); }

.cta-pro__title {
    font-family: var(--ff-display);
    font-size: clamp(28px, 4.5vw, 48px);
    line-height: 1.45;
    font-weight: 700;
    margin-bottom: 20px;
    text-shadow: 0 4px 24px rgba(0,0,0,.3);
}
.cta-pro__title em {
    font-style: normal;
    color: var(--c-gold-soft);
    background: linear-gradient(180deg, transparent 60%, rgba(201,161,58,.3) 60%);
    padding: 0 8px;
}

.cta-pro__sub {
    font-size: clamp(var(--fs-15), 1.4vw, var(--fs-17));
    color: rgba(255,255,255,.92);
    max-width: 720px; margin: 0 auto;
    line-height: 1.95;
}
.cta-pro__sub strong { color: var(--c-gold-soft); }

.cta-pro__panel {
    display: grid; grid-template-columns: 1fr 1fr; gap: 24px;
    max-width: 980px; margin: 0 auto;
}
@media (max-width: 768px) { .cta-pro__panel { grid-template-columns: 1fr; } }

.cta-pro-tel, .cta-pro-mail {
    position: relative;
    display: flex; align-items: center; gap: 20px;
    padding: 28px 28px;
    border-radius: var(--r-16);
    transition: transform .2s, box-shadow .2s;
    color: inherit;
    overflow: hidden;
    backdrop-filter: blur(8px);
}
.cta-pro-tel {
    background: rgba(255,255,255,.96);
    color: var(--c-green-dark);
    box-shadow: 0 12px 30px rgba(0,0,0,.3);
    border: 2px solid rgba(201,161,58,.4);
}
.cta-pro-tel:hover { transform: translateY(-4px); box-shadow: 0 18px 40px rgba(0,0,0,.45); border-color: var(--c-gold); }
.cta-pro-tel__icon { flex-shrink: 0; width: 80px; height: 80px; border-radius: 50%; background: var(--c-green-dark); color: var(--c-gold); display: grid; place-items: center; box-shadow: inset 0 0 0 5px rgba(201,161,58,.3); }
.cta-pro-tel__body { display: flex; flex-direction: column; gap: 4px; line-height: 1.2; }
.cta-pro-tel__label { font-size: var(--fs-12); color: var(--c-text-mute); letter-spacing: .14em; font-weight: 700; }
.cta-pro-tel__num { font-family: var(--ff-en); font-size: clamp(28px, 3.8vw, 42px); font-weight: 700; color: var(--c-green-dark); letter-spacing: .02em; }
.cta-pro-tel__hours { font-size: var(--fs-12); color: var(--c-text-mute); }

.cta-pro-mail {
    background: linear-gradient(135deg, var(--c-gold) 0%, #a07d20 100%);
    color: #1c1300;
    box-shadow: 0 12px 30px rgba(201,161,58,.45);
    border: 2px solid rgba(255,255,255,.3);
}
.cta-pro-mail::before { content: ""; position: absolute; inset: 0; background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.4) 50%, transparent 70%); transform: translateX(-100%); transition: transform .8s; }
.cta-pro-mail:hover { transform: translateY(-4px); box-shadow: 0 18px 44px rgba(201,161,58,.6); }
.cta-pro-mail:hover::before { transform: translateX(100%); }
.cta-pro-mail__icon { flex-shrink: 0; width: 80px; height: 80px; border-radius: 50%; background: #1c1300; color: var(--c-gold-soft); display: grid; place-items: center; }
.cta-pro-mail__body { display: flex; flex-direction: column; gap: 4px; line-height: 1.2; flex: 1; }
.cta-pro-mail__label { font-size: var(--fs-12); letter-spacing: .14em; font-weight: 700; opacity: .8; }
.cta-pro-mail__main { font-size: var(--fs-24); font-weight: 700; }
.cta-pro-mail__hours { font-size: var(--fs-12); opacity: .75; }
.cta-pro-mail__arrow { font-size: 32px; font-weight: 700; transition: transform .2s; }
.cta-pro-mail:hover .cta-pro-mail__arrow { transform: translateX(8px); }

@media (max-width: 600px) {
    .cta-pro-tel, .cta-pro-mail { padding: 18px 16px; gap: 14px; }
    .cta-pro-tel__icon, .cta-pro-mail__icon { width: 56px; height: 56px; }
    .cta-pro-tel__icon svg, .cta-pro-mail__icon svg { width: 28px; height: 28px; }
    .cta-pro-tel__num { font-size: 22px; letter-spacing: 0; }
    .cta-pro-mail__main { font-size: var(--fs-17); }
    .cta-pro-mail__arrow { font-size: 24px; }
    .cta-pro-tel__label, .cta-pro-mail__label { font-size: 10px; }
    .cta-pro-tel__hours, .cta-pro-mail__hours { font-size: 10px; }
}
@media (max-width: 360px) {
    .cta-pro-tel__num { font-size: 19px; }
    .cta-pro-mail__main { font-size: var(--fs-16); }
}

.cta-pro__bottom { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; max-width: 980px; margin: 40px auto 0; padding-top: 32px; border-top: 1px solid rgba(255,255,255,.15); }
@media (max-width: 768px) { .cta-pro__bottom { grid-template-columns: 1fr; gap: 12px; } }

.cta-pro__btn {
    position: relative;
    display: flex; align-items: center; gap: 14px;
    padding: 18px 22px;
    background: rgba(255,255,255,.08);
    border: 1.5px solid rgba(201,161,58,.5);
    border-radius: var(--r-12);
    color: #fff;
    font-size: var(--fs-15);
    font-weight: 700;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    transition: background .2s, border-color .2s, transform .15s, box-shadow .2s;
    overflow: hidden;
}
.cta-pro__btn:hover {
    background: rgba(201,161,58,.18);
    border-color: var(--c-gold);
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(0,0,0,.25);
}
.cta-pro__btn-icon {
    width: 36px; height: 36px;
    border-radius: 50%;
    background: rgba(201,161,58,.18);
    color: var(--c-gold-soft);
    display: grid; place-items: center;
    flex-shrink: 0;
    transition: background .2s;
}
.cta-pro__btn:hover .cta-pro__btn-icon { background: var(--c-gold); color: #1c1300; }
.cta-pro__btn > span:nth-child(2) { flex: 1; }
.cta-pro__btn-arrow { font-size: 20px; color: var(--c-gold-soft); transition: transform .2s; }
.cta-pro__btn:hover .cta-pro__btn-arrow { transform: translateX(4px); color: var(--c-gold); }

/* ===========================
   セクション背景画像（強み／料金／FAQ）
   =========================== */
.section--bg-strengths {
    position: relative;
    background-color: var(--c-bg-soft);
    background-image: url("../img/bg-01-pc.png");
    background-image: image-set(
        url("../img/bg-01-pc.webp") type("image/webp"),
        url("../img/bg-01-pc.png") type("image/png")
    );
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
.section--bg-strengths > .wrap { position: relative; z-index: 1; }
.section--bg-strengths::before {
    content: "";
    position: absolute; inset: 0;
    background: rgba(255,255,255,.55);
    pointer-events: none;
}

.section--bg-price {
    position: relative;
    background-color: var(--c-bg-soft);
    background-image: url("../img/bg-02-pc.png");
    background-image: image-set(
        url("../img/bg-02-pc.webp") type("image/webp"),
        url("../img/bg-02-pc.png") type("image/png")
    );
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
.section--bg-price > .wrap { position: relative; z-index: 1; }
.section--bg-price::before {
    content: "";
    position: absolute; inset: 0;
    background: rgba(250,251,249,.55);
    pointer-events: none;
}

/* FAQ：bg-03 が深緑なので、上に乗るカードは白で見やすく＋見出し色は白へ反転 */
.section--bg-faq {
    position: relative;
    background-color: var(--c-green-dark);
    background-image: url("../img/bg-03-pc.png");
    background-image: image-set(
        url("../img/bg-03-pc.webp") type("image/webp"),
        url("../img/bg-03-pc.png") type("image/png")
    );
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    color: #fff;
}
.section--bg-faq > .wrap { position: relative; z-index: 1; }
.section--bg-faq::before {
    content: "";
    position: absolute; inset: 0;
    background: rgba(10,31,18,.45);
    pointer-events: none;
}
.section--bg-faq .section__eyebrow { color: var(--c-gold-soft); }
.section--bg-faq .section__title { color: #fff; }
.section--bg-faq .section__lead { color: rgba(255,255,255,.85); }
.section--bg-faq .faq__item { background: rgba(255,255,255,.96); border-color: rgba(255,255,255,.3); backdrop-filter: blur(4px); }
.section--bg-faq .btn--primary { background: var(--c-gold); color: #1c1300; }
.section--bg-faq .btn--primary:hover { background: var(--c-gold-soft); }

/* ===========================
   三本柱 / 特典 バナー画像（セクション頭）
   =========================== */
.pillars__banner, .benefits__banner {
    margin: 0 auto 32px;
    max-width: 980px;
    border-radius: var(--r-16);
    overflow: hidden;
    box-shadow: var(--sh-md);
    line-height: 0;
    transition: transform .3s, box-shadow .3s;
}
.pillars__banner:hover, .benefits__banner:hover { transform: translateY(-3px); box-shadow: var(--sh-lg); }
.pillars__banner picture, .pillars__banner img,
.benefits__banner picture, .benefits__banner img { display: block; width: 100%; height: auto; }
@media (max-width: 768px) {
    .pillars__banner, .benefits__banner { margin-bottom: 24px; }
}

/* ===========================
   三本柱 Pillars（理念）
   =========================== */
.pillars__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
@media (max-width: 900px) { .pillars__grid { grid-template-columns: 1fr; } }
.pillar {
    position: relative;
    padding: 40px 28px 32px;
    background: linear-gradient(180deg, #fff 0%, #fbf7ea 100%);
    border: 1.5px solid var(--c-gold);
    border-radius: var(--r-16);
    box-shadow: 0 10px 30px rgba(201, 161, 58, .18);
    text-align: center;
    overflow: hidden;
    transition: transform .25s, box-shadow .25s;
}
.pillar:hover { transform: translateY(-6px); box-shadow: 0 16px 40px rgba(201, 161, 58, .3); }
.pillar::before {
    content: "";
    position: absolute; top: 0; left: 0; right: 0; height: 6px;
    background: linear-gradient(90deg, var(--c-gold) 0%, var(--c-gold-soft) 50%, var(--c-gold) 100%);
}
.pillar__num {
    position: absolute;
    top: 16px; right: 20px;
    font-family: var(--ff-display);
    font-size: 56px;
    color: rgba(201, 161, 58, .15);
    font-weight: 700;
    line-height: 1;
    user-select: none;
}
.pillar__icon {
    width: 88px; height: 88px;
    margin: 0 auto 20px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--c-green-dark), var(--c-green));
    color: var(--c-gold-soft);
    display: grid; place-items: center;
    box-shadow: 0 6px 18px rgba(14, 61, 39, .3);
    position: relative;
    z-index: 1;
}
.pillar__title {
    font-family: var(--ff-display);
    font-size: var(--fs-20);
    font-weight: 700;
    color: var(--c-green-dark);
    line-height: 1.55;
    margin-bottom: 16px;
}
.pillar__body {
    font-size: var(--fs-14);
    line-height: 1.95;
    color: var(--c-text-mute);
}

/* ===========================
   特典 Benefits
   =========================== */
.benefits__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
@media (max-width: 900px) { .benefits__grid { grid-template-columns: 1fr; } }
.benefit {
    position: relative;
    padding: 32px 28px;
    background: #fff;
    border: 1.5px solid var(--c-border);
    border-radius: var(--r-16);
    box-shadow: var(--sh-sm);
    transition: transform .2s, box-shadow .2s, border-color .2s;
    text-align: center;
    overflow: hidden;
}
.benefit:hover { transform: translateY(-4px); box-shadow: var(--sh-lg); border-color: var(--c-emerald); }
.benefit__icon-wrap {
    position: relative;
    display: inline-flex; align-items: center; justify-content: center;
    width: 80px; height: 80px;
    margin: 0 auto 18px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--c-gold), #a07d20);
    color: #fff;
    box-shadow: 0 6px 18px rgba(201, 161, 58, .3);
}
.benefit__label {
    position: absolute;
    top: -8px; left: 50%;
    transform: translateX(-50%);
    background: var(--c-green-dark);
    color: var(--c-gold-soft);
    font-size: 10px; font-weight: 700; letter-spacing: .1em;
    padding: 4px 10px;
    border-radius: var(--r-full);
    white-space: nowrap;
    line-height: 1;
}
.benefit__title {
    font-family: var(--ff-display);
    font-size: var(--fs-22);
    color: var(--c-green-dark);
    font-weight: 700;
    margin-bottom: 14px;
    line-height: 1.3;
}
.benefit__min {
    display: block;
    font-family: var(--ff-display);
    font-size: clamp(36px, 5vw, 48px);
    color: #a07d20;
    margin-top: 6px;
    line-height: 1;
}
.benefit__min small { font-size: var(--fs-18); color: var(--c-text-mute); margin-left: 4px; font-weight: 500; }
.benefit__body { font-size: var(--fs-14); line-height: 1.9; color: var(--c-text-mute); }

/* ===========================
   Partners（認定・所属バナー）
   =========================== */
.partners__list {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
    justify-content: center;
    align-items: center;
    max-width: 880px;
    margin: 0 auto;
}
.partners__item {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 16px 20px;
    background: #fff;
    border: 1px solid var(--c-border);
    border-radius: var(--r-12);
    box-shadow: var(--sh-sm);
    transition: transform .15s, box-shadow .15s, border-color .15s;
    text-decoration: none;
}
.partners__item:hover {
    transform: translateY(-3px);
    box-shadow: var(--sh-md);
    border-color: var(--c-emerald);
}
.partners__item--static { cursor: default; }
.partners__item--static:hover { transform: none; box-shadow: var(--sh-sm); border-color: var(--c-border); }
.partners__item img { display: block; max-width: 100%; height: auto; }
@media (max-width: 600px) {
    .partners__list { gap: 14px; }
    .partners__item { padding: 12px 16px; }
}

/* ===========================
   ページ共通 HERO（下層ページ用）
   =========================== */
.page-hero {
    position: relative;
    padding: clamp(72px, 9vw, 120px) 0 clamp(56px, 7vw, 88px);
    background: linear-gradient(135deg, #0a1f12 0%, #0e3d27 50%, #1d5d3a 100%);
    color: #fff;
    overflow: hidden;
    text-align: center;
}
.page-hero__bg {
    position: absolute; inset: 0;
    background:
      radial-gradient(ellipse at 80% 20%, rgba(201,161,58,.2), transparent 50%),
      radial-gradient(ellipse at 15% 80%, rgba(47,170,107,.18), transparent 55%);
    pointer-events: none;
}
.page-hero__pattern {
    position: absolute; inset: 0;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='400' height='400' viewBox='0 0 400 400'><g fill='none' stroke='%23c9a13a' stroke-opacity='0.08' stroke-width='1.5'><circle cx='200' cy='200' r='180'/><circle cx='200' cy='200' r='130'/><circle cx='200' cy='200' r='80'/></g></svg>") center / 700px;
    pointer-events: none; opacity: .9;
}
.page-hero__inner { position: relative; }
.page-hero__crumbs { display: flex; align-items: center; justify-content: center; gap: 6px; font-size: var(--fs-13); color: rgba(255,255,255,.7); margin-bottom: 20px; }
.page-hero__crumbs a { color: var(--c-gold-soft); }
.page-hero__crumbs a:hover { color: var(--c-gold); text-decoration: underline; }
.page-hero__eyebrow {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 8px 20px; margin-bottom: 20px;
    background: rgba(255,255,255,.08); border: 1.5px solid var(--c-gold);
    border-radius: var(--r-full);
    font-size: var(--fs-13); letter-spacing: .16em; color: var(--c-gold-soft);
    font-family: var(--ff-en); font-weight: 600;
}
.page-hero__eyebrow svg { color: var(--c-gold); }
.page-hero__title {
    font-family: var(--ff-display);
    font-size: clamp(32px, 5vw, 56px);
    font-weight: 700; line-height: 1.3;
    margin-bottom: 20px;
    text-shadow: 0 4px 24px rgba(0,0,0,.3);
}
.page-hero__title em {
    font-style: normal; color: var(--c-gold-soft);
    background: linear-gradient(180deg, transparent 60%, rgba(201,161,58,.3) 60%);
    padding: 0 6px;
}
.page-hero__lead { font-size: var(--fs-15); line-height: 1.95; color: rgba(255,255,255,.92); max-width: 720px; margin: 0 auto 28px; }
.page-hero__chips { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; }
.page-hero__chip {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 8px 16px;
    background: rgba(255,255,255,.1);
    border: 1px solid rgba(201,161,58,.4);
    border-radius: var(--r-full);
    font-size: var(--fs-13); color: rgba(255,255,255,.95); font-weight: 500;
    white-space: nowrap;
}
.page-hero__chip svg { color: var(--c-gold-soft); flex-shrink: 0; }
.page-hero__crumb-sep { color: rgba(255,255,255,.5); }
.page-hero__date { font-family: var(--ff-en); font-size: var(--fs-14); color: var(--c-gold-soft); margin-bottom: 14px; }
.page-hero__title--article { font-size: clamp(24px, 3.5vw, 40px); }
.page-hero--article { text-align: left; }
.page-hero--article .page-hero__crumbs { justify-content: flex-start; }

/* ===========================
   料金テーブル
   =========================== */
.price-table-wrap {
    overflow-x: auto;
    background: #fff;
    border-radius: var(--r-16);
    box-shadow: var(--sh-md);
    margin-bottom: 24px;
    border: 1.5px solid var(--c-border);
}
.price-table {
    width: 100%;
    min-width: 720px;
    border-collapse: collapse;
    font-size: var(--fs-14);
}
.price-table thead th {
    padding: 14px 16px;
    background: linear-gradient(135deg, var(--c-green-dark), var(--c-green));
    color: #fff;
    font-weight: 700;
    text-align: center;
    border-right: 1px solid rgba(255,255,255,.15);
    border-bottom: 2px solid var(--c-gold);
    line-height: 1.4;
}
.price-table thead th:last-child { border-right: 0; }
.price-table tbody td {
    padding: 14px 16px;
    text-align: center;
    border-bottom: 1px solid var(--c-border);
    border-right: 1px solid var(--c-border);
    vertical-align: middle;
    color: var(--c-text);
    line-height: 1.6;
}
.price-table tbody td:first-child { text-align: left; font-weight: 600; color: var(--c-green-dark); background: var(--c-bg-soft); }
.price-table tbody tr:nth-child(even) td { background: rgba(245, 242, 232, .3); }
.price-table tbody tr:nth-child(even) td:first-child { background: var(--c-bg-soft); }
.price-table tbody tr:hover td { background: rgba(201, 161, 58, .08); }
.price-table tbody tr:hover td:first-child { background: rgba(201, 161, 58, .15); }
.price-table__hl { font-weight: 700; color: var(--c-green-dark); font-size: var(--fs-15); }
.price-table__row--featured td { background: linear-gradient(180deg, #fffbef 0%, #fbf7ea 100%) !important; }
.price-table__row--featured td:first-child { background: linear-gradient(180deg, #fbf2d0, #f3ecd0) !important; color: #1c1300 !important; }
.price-table__plan { display: block; font-weight: 700; }
.price-table__badge { display: inline-block; margin-top: 4px; padding: 2px 8px; background: var(--c-gold); color: #1c1300; border-radius: var(--r-full); font-size: 10px; letter-spacing: .08em; }

/* 注意事項リスト */
.price-notes { margin: 24px 0 32px; display: flex; flex-direction: column; gap: 8px; padding: 20px 24px; background: rgba(255,255,255,.6); border-radius: var(--r-12); border-left: 4px solid var(--c-gold); }
.price-notes li { display: flex; align-items: flex-start; gap: 10px; font-size: var(--fs-13); line-height: 1.85; color: var(--c-text); }
.price-notes svg { color: var(--c-gold); flex-shrink: 0; margin-top: 4px; }
.price-notes-inline { margin-top: 12px; font-size: var(--fs-13); color: var(--c-text-mute); line-height: 1.85; }

.price-subhead {
    display: flex; align-items: center; gap: 12px;
    margin: 48px 0 24px;
    padding-bottom: 12px;
    border-bottom: 2px solid var(--c-gold);
    font-size: var(--fs-22);
    color: var(--c-green-dark);
    font-weight: 700;
}
.price-subhead svg { color: var(--c-emerald); }

/* 価格パッケージグリッド */
.price-pkg-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 16px;
    margin-bottom: 16px;
}
.price-pkg {
    display: flex; flex-direction: column; gap: 8px;
    padding: 24px 22px;
    background: #fff;
    border: 1.5px solid var(--c-border);
    border-radius: var(--r-12);
    box-shadow: var(--sh-sm);
    text-align: center;
    transition: transform .15s, box-shadow .15s, border-color .15s;
}
.price-pkg:hover { transform: translateY(-3px); box-shadow: var(--sh-md); border-color: var(--c-emerald); }
.price-pkg--featured { border-color: var(--c-gold); background: linear-gradient(180deg, #fff 0%, #fbf7ea 100%); }
.price-pkg__label { font-size: var(--fs-13); color: var(--c-text-mute); line-height: 1.55; font-weight: 600; }
.price-pkg__val {
    font-family: var(--ff-display); font-size: clamp(24px, 3vw, 32px); font-weight: 700;
    color: var(--c-green-dark); line-height: 1.15;
}
.price-pkg__val small { font-size: var(--fs-14); color: var(--c-text-mute); margin-left: 4px; font-weight: 500; }
.price-pkg--featured .price-pkg__val { color: #a07d20; }

/* 単発価格カード（記帳代行など） */
.single-price-card {
    background: #fff;
    border: 1.5px solid var(--c-gold);
    border-radius: var(--r-16);
    box-shadow: 0 10px 30px rgba(201, 161, 58, .2);
    overflow: hidden;
    position: relative;
}
.single-price-card::before {
    content: "";
    position: absolute; top: 0; left: 0; right: 0; height: 6px;
    background: linear-gradient(90deg, var(--c-gold) 0%, var(--c-gold-soft) 50%, var(--c-gold) 100%);
}
.single-price-card__inner { padding: 48px 32px; text-align: center; max-width: 600px; margin: 0 auto; }
.single-price-card__label { display: inline-block; padding: 6px 16px; background: var(--c-bg-soft); color: var(--c-green-dark); border-radius: var(--r-full); font-size: var(--fs-12); font-weight: 700; letter-spacing: .1em; margin-bottom: 16px; }
.single-price-card__price {
    display: block;
    font-family: var(--ff-display);
    font-size: clamp(40px, 6vw, 64px);
    color: var(--c-green-dark);
    font-weight: 700;
    line-height: 1.1;
}
.single-price-card__price small { font-size: var(--fs-18); color: var(--c-text-mute); margin-left: 8px; font-weight: 500; }
.single-price-card__sub { display: block; font-size: var(--fs-13); color: var(--c-text-mute); margin-top: 8px; }
.single-price-card__desc { margin-top: 20px; font-size: var(--fs-14); line-height: 1.85; color: var(--c-text-mute); }

/* 2カラム価格カード */
.price-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
@media (max-width: 768px) { .price-2col { grid-template-columns: 1fr; } }
.price-2col__card {
    padding: 32px 28px;
    background: #fff;
    border: 1.5px solid var(--c-border);
    border-radius: var(--r-16);
    box-shadow: var(--sh-sm);
    transition: transform .15s, box-shadow .15s, border-color .15s;
}
.price-2col__card:hover { transform: translateY(-4px); box-shadow: var(--sh-md); border-color: var(--c-emerald); }
.price-2col__title { font-size: var(--fs-20); color: var(--c-green-dark); font-weight: 700; padding-bottom: 14px; border-bottom: 2px solid var(--c-gold); margin-bottom: 18px; }
.price-2col__rows { display: flex; flex-direction: column; gap: 14px; }
.price-2col__row { display: flex; justify-content: space-between; align-items: baseline; padding: 14px 16px; background: var(--c-bg-soft); border-radius: var(--r-8); }
.price-2col__label { font-size: var(--fs-14); color: var(--c-text-mute); font-weight: 600; }
.price-2col__val { font-family: var(--ff-display); font-size: var(--fs-22); color: var(--c-green-dark); font-weight: 700; }
.price-2col__val small { font-size: var(--fs-13); color: var(--c-text-mute); margin-left: 2px; }
.price-2col__val strong { color: #a07d20; }

/* =========================================================
   下層ページ共通コンポーネント
   ========================================================= */

/* リード文ブロック */
.lead-block { max-width: 860px; margin: 0 auto; text-align: center; }
.lead-block__text { font-size: clamp(var(--fs-15), 1.6vw, var(--fs-18)); line-height: 2.1; color: var(--c-text); }
.lead-block__text strong { color: var(--c-green-dark); font-weight: 700; border-bottom: 2px solid var(--c-gold-soft); }

/* 縦並び番号ステップ（手順・流れ） */
.vsteps { max-width: 860px; margin: 0 auto; display: flex; flex-direction: column; gap: 0; }
.vstep { display: grid; grid-template-columns: 72px 1fr; gap: 24px; position: relative; padding-bottom: 40px; }
.vstep:not(:last-child)::before { content: ""; position: absolute; left: 35px; top: 72px; bottom: 0; width: 2px; background: linear-gradient(180deg, var(--c-emerald), var(--c-sage)); }
.vstep__num { width: 72px; height: 72px; border-radius: 50%; background: linear-gradient(135deg, var(--c-green-dark), var(--c-green)); color: #fff; display: grid; place-items: center; font-family: var(--ff-display); font-size: var(--fs-24); font-weight: 700; box-shadow: var(--sh-sm); position: relative; z-index: 1; }
.vstep__num span { font-size: 10px; display: block; letter-spacing: .1em; opacity: .8; }
.vstep__body { padding-top: 6px; }
.vstep__title { font-size: var(--fs-18); font-weight: 700; color: var(--c-green-dark); margin-bottom: 8px; display: flex; align-items: center; gap: 10px; }
.vstep__title svg { color: var(--c-emerald); }
.vstep__desc { font-size: var(--fs-14); line-height: 1.9; color: var(--c-text-mute); }
@media (max-width: 560px) {
    .vstep { grid-template-columns: 56px 1fr; gap: 16px; }
    .vstep__num { width: 56px; height: 56px; font-size: var(--fs-20); }
    .vstep:not(:last-child)::before { left: 27px; top: 56px; }
}

/* 特徴カード（アイコン＋見出し＋本文） */
.fcards { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 20px; }
.fcard { padding: 32px 26px; background: #fff; border: 1px solid var(--c-border); border-radius: var(--r-16); box-shadow: var(--sh-sm); transition: transform .2s, box-shadow .2s, border-color .2s; }
.fcard:hover { transform: translateY(-5px); box-shadow: var(--sh-lg); border-color: var(--c-emerald-light); }
.fcard__icon { width: 64px; height: 64px; border-radius: var(--r-16); background: linear-gradient(135deg, var(--c-emerald), var(--c-green-dark)); color: #fff; display: grid; place-items: center; margin-bottom: 18px; box-shadow: var(--sh-sm); }
.fcard__num { font-family: var(--ff-display); font-size: var(--fs-12); color: var(--c-gold); letter-spacing: .26em; font-weight: 700; display: block; margin-bottom: 8px; }
.fcard__title { font-size: var(--fs-18); font-weight: 700; color: var(--c-green-dark); margin-bottom: 12px; line-height: 1.5; }
.fcard__body { font-size: var(--fs-14); line-height: 1.9; color: var(--c-text-mute); }

/* チェック付き箇条書き（2カラム可） */
.checklist { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 12px; max-width: 920px; margin: 0 auto; }
.checklist__item { display: flex; align-items: flex-start; gap: 12px; padding: 16px 18px; background: #fff; border: 1px solid var(--c-border); border-radius: var(--r-12); font-size: var(--fs-14); line-height: 1.7; color: var(--c-text); }
.checklist__item svg { flex-shrink: 0; color: var(--c-emerald); margin-top: 3px; }
.checklist__item strong { color: var(--c-green-dark); }

/* 大型ポイントカード（番号付き・横並び/縦） */
.points { display: flex; flex-direction: column; gap: 20px; max-width: 980px; margin: 0 auto; }
.point { display: grid; grid-template-columns: 88px 1fr; gap: 28px; align-items: center; padding: 28px 32px; background: #fff; border: 1px solid var(--c-border); border-radius: var(--r-16); box-shadow: var(--sh-sm); border-left: 5px solid var(--c-gold); transition: transform .2s, box-shadow .2s; }
.point:hover { transform: translateX(4px); box-shadow: var(--sh-md); }
.point__num { font-family: var(--ff-display); font-size: clamp(40px, 5vw, 56px); font-weight: 700; color: var(--c-gold); line-height: 1; text-align: center; }
.point__num small { display: block; font-size: var(--fs-12); color: var(--c-text-mute); letter-spacing: .1em; margin-top: 4px; }
.point__title { font-size: var(--fs-20); font-weight: 700; color: var(--c-green-dark); margin-bottom: 10px; line-height: 1.45; }
.point__body { font-size: var(--fs-14); line-height: 1.9; color: var(--c-text-mute); }
@media (max-width: 560px) {
    .point { grid-template-columns: 1fr; gap: 12px; text-align: center; }
    .point__num { font-size: 44px; }
}

/* 定義テーブル（会社概要・サービス概要） */
.deftable { width: 100%; max-width: 860px; margin: 0 auto; background: #fff; border: 1px solid var(--c-border); border-radius: var(--r-16); overflow: hidden; box-shadow: var(--sh-sm); }
.deftable__row { display: grid; grid-template-columns: 220px 1fr; border-bottom: 1px solid var(--c-border); }
.deftable__row:last-child { border-bottom: 0; }
.deftable__label { padding: 18px 24px; background: var(--c-bg-soft); font-weight: 700; color: var(--c-green-dark); font-size: var(--fs-14); display: flex; align-items: center; }
.deftable__value { padding: 18px 24px; font-size: var(--fs-14); line-height: 1.8; color: var(--c-text); }
.deftable__value a { color: var(--c-green); font-weight: 600; }
@media (max-width: 600px) {
    .deftable__row { grid-template-columns: 1fr; }
    .deftable__label { padding: 12px 18px; }
    .deftable__value { padding: 12px 18px; }
}

/* 代表者プロフィール */
.profile { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(32px, 5vw, 56px); align-items: start; max-width: 1000px; margin: 0 auto; }
@media (max-width: 768px) { .profile { grid-template-columns: 1fr; } }
.profile__photo { border-radius: var(--r-24); overflow: hidden; box-shadow: var(--sh-lg); aspect-ratio: 4/5; background: var(--c-sage); }
.profile__photo picture, .profile__photo img { width: 100%; height: 100%; object-fit: cover; object-position: center top; display: block; }
.profile__name { font-family: var(--ff-display); font-size: clamp(24px, 3vw, 32px); color: var(--c-green-dark); font-weight: 700; }
.profile__name small { display: block; font-size: var(--fs-14); color: var(--c-text-mute); margin-top: 6px; font-weight: 500; }
.profile__creds { display: flex; flex-wrap: wrap; gap: 8px; margin: 18px 0; }
.profile__creds span { padding: 6px 14px; background: var(--c-bg-soft); color: var(--c-green-dark); border: 1px solid var(--c-sage); border-radius: var(--r-full); font-size: var(--fs-12); font-weight: 600; white-space: nowrap; }
.profile__msg { font-size: var(--fs-15); line-height: 2; color: var(--c-text); }
.profile__msg p { margin-bottom: 16px; }

/* LP誘導バナー（各ページ→税務調査LP） */
.lp-promo { display: flex; align-items: center; gap: 20px; max-width: 900px; margin: 0 auto; padding: 24px 28px; border-radius: var(--r-16); background: linear-gradient(135deg, #0e3d27, #1d5d3a); color: #fff; box-shadow: var(--sh-md); position: relative; overflow: hidden; transition: transform .2s, box-shadow .2s; }
.lp-promo::before { content: ""; position: absolute; inset: 0; background: radial-gradient(ellipse at 90% 20%, rgba(201,161,58,.25), transparent 55%); pointer-events: none; }
.lp-promo:hover { transform: translateY(-3px); box-shadow: var(--sh-lg); }
.lp-promo__icon { position: relative; flex-shrink: 0; width: 60px; height: 60px; border-radius: 50%; background: var(--c-gold); color: var(--c-green-dark); display: grid; place-items: center; }
.lp-promo__body { position: relative; flex: 1; min-width: 0; }
.lp-promo__label { display: inline-block; padding: 3px 12px; background: var(--c-gold); color: #1c1300; border-radius: var(--r-full); font-size: 11px; font-weight: 700; margin-bottom: 8px; }
.lp-promo__title { font-size: var(--fs-18); font-weight: 700; color: #fff; line-height: 1.5; }
.lp-promo__title strong { color: var(--c-gold-soft); }
.lp-promo__arrow { position: relative; flex-shrink: 0; color: var(--c-gold-soft); font-size: 24px; font-weight: 700; transition: transform .2s; }
.lp-promo:hover .lp-promo__arrow { transform: translateX(5px); }
@media (max-width: 560px) { .lp-promo { flex-direction: column; text-align: center; gap: 12px; } }

/* 汎用プロモバナー（既製バナー画像の配置用） */
.promo-banner { max-width: 1000px; margin: clamp(40px,6vw,72px) auto 0; border-radius: var(--r-16); overflow: hidden; box-shadow: var(--sh-md); line-height: 0; transition: transform .3s, box-shadow .3s; }
.promo-banner:hover { transform: translateY(-3px); box-shadow: var(--sh-lg); }
.promo-banner picture, .promo-banner img { width: 100%; height: auto; display: block; }

/* 事務所外観（about） */
.about-office-photo { max-width: 860px; margin: 0 auto 28px; border-radius: var(--r-16); overflow: hidden; box-shadow: var(--sh-md); line-height: 0; }
.about-office-photo picture, .about-office-photo img { width: 100%; height: auto; display: block; }

/* 経歴タイムライン */
.timeline { max-width: 760px; margin: 0 auto; }
.timeline__item { display: grid; grid-template-columns: 160px 1fr; gap: 24px; padding: 16px 0; border-bottom: 1px dashed var(--c-border); position: relative; }
.timeline__item:last-child { border-bottom: 0; }
.timeline__date { font-weight: 700; color: var(--c-gold); font-size: var(--fs-14); }
.timeline__text { font-size: var(--fs-14); line-height: 1.8; color: var(--c-text); }
@media (max-width: 560px) {
    .timeline__item { grid-template-columns: 1fr; gap: 4px; }
}

/* 関連リンク（内部リンク・ピックアップ） */
.pickup { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 16px; }
.pickup__card { display: flex; align-items: center; gap: 16px; padding: 22px 24px; background: #fff; border: 1px solid var(--c-border); border-radius: var(--r-12); transition: transform .15s, box-shadow .15s, border-color .15s; color: inherit; }
.pickup__card:hover { transform: translateY(-3px); box-shadow: var(--sh-md); border-color: var(--c-emerald); }
.pickup__icon { width: 48px; height: 48px; border-radius: 50%; background: var(--c-bg-soft); color: var(--c-green-dark); display: grid; place-items: center; flex-shrink: 0; }
.pickup__card:hover .pickup__icon { background: var(--c-green-dark); color: var(--c-gold-soft); }
.pickup__label { font-size: var(--fs-15); font-weight: 700; color: var(--c-green-dark); }
.pickup__sub { font-size: var(--fs-12); color: var(--c-text-mute); margin-top: 2px; }
.pickup__arrow { margin-left: auto; color: var(--c-emerald); font-weight: 700; transition: transform .2s; }
.pickup__card:hover .pickup__arrow { transform: translateX(4px); }

/* ミッドCTAストリップ */
.cta-strip { background: linear-gradient(135deg, var(--c-green-dark), var(--c-green)); border-radius: var(--r-24); padding: clamp(32px, 5vw, 56px); text-align: center; color: #fff; position: relative; overflow: hidden; box-shadow: var(--sh-lg); }
.cta-strip::before { content: ""; position: absolute; inset: 0; background: radial-gradient(ellipse at 80% 20%, rgba(201,161,58,.25), transparent 55%); pointer-events: none; }
.cta-strip__inner { position: relative; }
.cta-strip__title { font-family: var(--ff-display); font-size: clamp(22px, 3vw, 32px); font-weight: 700; line-height: 1.5; margin-bottom: 12px; }
.cta-strip__title em { font-style: normal; color: var(--c-gold-soft); }
.cta-strip__sub { font-size: var(--fs-15); opacity: .92; margin-bottom: 24px; line-height: 1.85; }
.cta-strip__actions { display: flex; flex-wrap: wrap; gap: 16px; justify-content: center; }
.cta-strip__tel { font-family: var(--ff-en); font-size: clamp(26px, 4vw, 36px); font-weight: 700; color: var(--c-gold-soft); display: inline-flex; align-items: center; gap: 10px; }

/* prose（法務・長文ドキュメント） */
.prose { max-width: 820px; margin: 0 auto; font-size: var(--fs-15); line-height: 2; color: var(--c-text); }
.prose h2 { font-size: var(--fs-22); color: var(--c-green-dark); font-weight: 700; margin: 40px 0 16px; padding-bottom: 10px; border-bottom: 2px solid var(--c-gold); display: flex; align-items: center; gap: 10px; }
.prose h2:first-child { margin-top: 0; }
.prose h3 { font-size: var(--fs-17); color: var(--c-green-dark); font-weight: 700; margin: 28px 0 12px; }
.prose p { margin-bottom: 18px; }
.prose ul, .prose ol { margin: 0 0 18px; padding-left: 1.4em; }
.prose ul li { list-style: disc; margin-bottom: 8px; }
.prose ol li { list-style: decimal; margin-bottom: 8px; }
.prose strong { color: var(--c-green-dark); }

/* お問い合わせフォーム */
.contact-grid { display: grid; grid-template-columns: 1fr 0.7fr; gap: 40px; align-items: start; }
@media (max-width: 900px) { .contact-grid { grid-template-columns: 1fr; } }
.cform { background: #fff; border: 1px solid var(--c-border); border-radius: var(--r-16); box-shadow: var(--sh-md); padding: clamp(24px, 4vw, 40px); }
.cform__row { margin-bottom: 22px; }
.cform__label { display: block; font-weight: 700; color: var(--c-green-dark); font-size: var(--fs-14); margin-bottom: 8px; }
.cform__req { display: inline-block; margin-left: 8px; padding: 2px 8px; background: var(--c-coral); color: #fff; border-radius: 4px; font-size: 10px; font-weight: 700; vertical-align: middle; }
.cform__opt { display: inline-block; margin-left: 8px; padding: 2px 8px; background: var(--c-bg-soft); color: var(--c-text-mute); border-radius: 4px; font-size: 10px; font-weight: 700; vertical-align: middle; }
.cform input[type=text], .cform input[type=email], .cform input[type=tel], .cform select, .cform textarea {
    width: 100%; padding: 14px 16px; font-size: var(--fs-15); border: 1.5px solid var(--c-border); border-radius: var(--r-8); background: var(--c-bg); transition: border-color .15s, box-shadow .15s; font-family: inherit;
}
.cform input:focus, .cform select:focus, .cform textarea:focus { outline: none; border-color: var(--c-green); box-shadow: 0 0 0 4px rgba(29,93,58,.1); }
.cform textarea { resize: vertical; min-height: 140px; }
.cform__hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.cform__agree { display: flex; align-items: flex-start; gap: 10px; font-size: var(--fs-13); color: var(--c-text-mute); line-height: 1.7; margin-bottom: 24px; }
.cform__agree input { margin-top: 4px; width: 18px; height: 18px; flex-shrink: 0; }
.cform__agree a { color: var(--c-green); font-weight: 600; }
.cform__submit { width: 100%; padding: 18px; font-size: var(--fs-18); font-weight: 700; color: #fff; background: linear-gradient(135deg, var(--c-gold), #a07d20); border: 0; border-radius: var(--r-full); cursor: pointer; box-shadow: 0 8px 22px rgba(201,161,58,.4); transition: transform .15s, box-shadow .15s; }
.cform__submit:hover { transform: translateY(-2px); box-shadow: 0 12px 28px rgba(201,161,58,.55); }
.cform__msg { padding: 16px 20px; border-radius: var(--r-12); margin-bottom: 24px; font-size: var(--fs-14); line-height: 1.7; }
.cform__msg--ok { background: #e6f5ec; color: #1e6e44; border: 1px solid #a9d9bd; }
.cform__msg--err { background: #fde6e6; color: #a3221f; border: 1px solid #e9b3b1; }

/* 問い合わせサイド情報 */
.contact-side { display: flex; flex-direction: column; gap: 20px; }
.contact-side__card { background: linear-gradient(135deg, var(--c-green-dark), var(--c-green)); color: #fff; border-radius: var(--r-16); padding: 28px; text-align: center; }
.contact-side__label { font-size: var(--fs-13); opacity: .85; letter-spacing: .08em; }
.contact-side__tel { font-family: var(--ff-en); font-size: clamp(28px, 4vw, 34px); font-weight: 700; color: var(--c-gold-soft); margin: 8px 0; display: block; }
.contact-side__hours { font-size: var(--fs-12); opacity: .8; }
.contact-side__note { background: var(--c-bg-soft); border-radius: var(--r-12); padding: 20px 22px; font-size: var(--fs-13); line-height: 1.85; color: var(--c-text-mute); border-left: 3px solid var(--c-gold); }

/* CPT: 実績カードグリッド */
.case-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 24px; }
.case-card { display: flex; flex-direction: column; background: #fff; border: 1px solid var(--c-border); border-radius: var(--r-16); overflow: hidden; box-shadow: var(--sh-sm); transition: transform .2s, box-shadow .2s; color: inherit; text-decoration: none; }
.case-card:hover { transform: translateY(-5px); box-shadow: var(--sh-lg); }
.case-card__more { display: inline-flex; align-items: center; gap: 5px; margin-top: 16px; color: var(--c-green); font-size: var(--fs-13); font-weight: 700; }
.case-card:hover .case-card__more { color: var(--c-gold); }
.case-card__head { padding: 16px 22px; background: linear-gradient(135deg, var(--c-green-dark), var(--c-green)); display: flex; gap: 8px; flex-wrap: wrap; }
.case-card__tag { padding: 4px 12px; background: rgba(255,255,255,.15); color: #fff; border-radius: var(--r-full); font-size: var(--fs-12); font-weight: 600; }
.case-card__tag--gold { background: var(--c-gold); color: #1c1300; }
.case-card__body { padding: 24px 22px; flex: 1; }
.case-card__title { font-size: var(--fs-17); font-weight: 700; color: var(--c-green-dark); margin-bottom: 12px; line-height: 1.5; }
.case-card__text { font-size: var(--fs-14); line-height: 1.85; color: var(--c-text-mute); }

/* CPT: お客様の声カード（大） */
.voice-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 24px; }
.vcard { position: relative; display: block; color: inherit; text-decoration: none; background: #fff; border: 1px solid var(--c-border); border-radius: var(--r-16); padding: 32px 28px 28px; box-shadow: var(--sh-sm); transition: transform .2s, box-shadow .2s; }
.vcard:hover { transform: translateY(-4px); box-shadow: var(--sh-lg); }
.vcard::before { content: "“"; position: absolute; top: 12px; right: 24px; font-family: var(--ff-display); font-size: 80px; color: rgba(201,161,58,.18); line-height: 1; }
.vcard__cat { display: inline-block; padding: 5px 14px; background: var(--c-gold); color: #1c1300; border-radius: var(--r-full); font-size: var(--fs-12); font-weight: 700; margin-bottom: 16px; }
.vcard__title { font-size: var(--fs-18); font-weight: 700; color: var(--c-green-dark); margin-bottom: 14px; line-height: 1.5; }
.vcard__text { font-size: var(--fs-14); line-height: 1.95; color: var(--c-text); }
.vcard__service { margin-top: 18px; padding-top: 16px; border-top: 1px dashed var(--c-border); font-size: var(--fs-12); color: var(--c-text-mute); }
.vcard__service strong { color: var(--c-green); }
.vcard__more { display: inline-flex; align-items: center; gap: 4px; margin-top: 16px; font-size: var(--fs-13); font-weight: 700; color: var(--c-green); }
.vcard:hover .vcard__more { color: var(--c-gold); }

/* CPT: ブログ一覧 */
.column-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 24px; }
.ccard { display: flex; flex-direction: column; background: #fff; border: 1px solid var(--c-border); border-radius: var(--r-16); overflow: hidden; box-shadow: var(--sh-sm); transition: transform .2s, box-shadow .2s; color: inherit; }
.ccard:hover { transform: translateY(-5px); box-shadow: var(--sh-lg); }
.ccard__thumb { aspect-ratio: 16/9; background: linear-gradient(135deg, var(--c-green-dark), var(--c-emerald)); display: grid; place-items: center; color: var(--c-gold-soft); }
.ccard__thumb img { width: 100%; height: 100%; object-fit: cover; }
.ccard__body { padding: 22px 22px 24px; flex: 1; display: flex; flex-direction: column; gap: 8px; }
.ccard__meta { display: flex; gap: 10px; align-items: center; font-size: var(--fs-12); color: var(--c-text-mute); }
.ccard__cat { padding: 2px 10px; background: var(--c-bg-soft); color: var(--c-green); border-radius: var(--r-full); font-weight: 600; }
.ccard__title { font-size: var(--fs-16); font-weight: 700; color: var(--c-text); line-height: 1.6; }

/* セクション内サブ見出し（汎用） */
.sub-title { display: flex; align-items: center; gap: 12px; margin: 0 0 24px; padding-bottom: 12px; border-bottom: 2px solid var(--c-gold); font-size: var(--fs-22); color: var(--c-green-dark); font-weight: 700; }
.sub-title svg { color: var(--c-emerald); }

/* 注意文・補足 */
.note-box { max-width: 860px; margin: 24px auto 0; padding: 18px 24px; background: var(--c-bg-soft); border-left: 4px solid var(--c-gold); border-radius: var(--r-8); font-size: var(--fs-13); line-height: 1.85; color: var(--c-text-mute); }
.note-box strong { color: var(--c-green-dark); }

/* 単一記事本文 */
.entry-content { max-width: 820px; margin: 0 auto; font-size: var(--fs-15); line-height: 2; color: var(--c-text); }
.entry-content h2 { font-size: var(--fs-22); color: var(--c-green-dark); margin: 36px 0 16px; padding: 10px 0 10px 16px; border-left: 5px solid var(--c-gold); background: var(--c-bg-soft); }
.entry-content h3 { font-size: var(--fs-18); color: var(--c-green-dark); margin: 28px 0 12px; }
.entry-content p { margin-bottom: 18px; }
.entry-content ul, .entry-content ol { margin: 0 0 18px; padding-left: 1.5em; }
.entry-content li { margin-bottom: 8px; }
.entry-content ul li { list-style: disc; }
.entry-content ol li { list-style: decimal; }
.entry-content img { border-radius: var(--r-12); margin: 16px 0; }
.entry-content a { color: var(--c-green); text-decoration: underline; }

/* アーカイブのページネーション */
.pagination { display: flex; justify-content: center; gap: 8px; margin-top: 48px; flex-wrap: wrap; }
.pagination .page-numbers { display: inline-grid; place-items: center; min-width: 44px; height: 44px; padding: 0 12px; border-radius: var(--r-8); background: #fff; border: 1px solid var(--c-border); color: var(--c-green-dark); font-weight: 600; transition: background .15s, color .15s; }
.pagination .page-numbers.current { background: var(--c-green-dark); color: #fff; border-color: var(--c-green-dark); }
.pagination .page-numbers:hover:not(.current) { background: var(--c-bg-soft); }

/* 空状態（準備中） */
.empty-state { text-align: center; padding: 60px 20px; max-width: 600px; margin: 0 auto; }
.empty-state__icon { width: 80px; height: 80px; margin: 0 auto 20px; border-radius: 50%; background: var(--c-bg-soft); color: var(--c-emerald); display: grid; place-items: center; }
.empty-state__title { font-size: var(--fs-20); font-weight: 700; color: var(--c-green-dark); margin-bottom: 12px; }
.empty-state__text { font-size: var(--fs-14); line-height: 1.9; color: var(--c-text-mute); }

/* ===========================
   ヘルパー
   =========================== */
.text-center { text-align: center; }
.mt-32 { margin-top: 32px; }
.mt-48 { margin-top: 48px; }
.mt-64 { margin-top: 64px; }
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }
