﻿.area-common h1 {
  border-bottom: 3px solid #00a0e9;
  padding-bottom: .3em;
  margin-bottom: 1em;
}
.area-common h2 {
  border-left: 5px solid #00a0e9;
  padding-left: .6em;
  margin-top: 2em;
}
.area-common ul {
  margin-left: 1.5em;
  list-style-type: disc;
}
.area-common .callout {
  background: #f0f8ff;
  border-left: 4px solid #00a0e9;
  padding: 1em;
  margin: 1.5em 0;
}

.area-reviews {
    margin-bottom: 40px;
}

.area-reviews .review-item {
    margin-bottom: 30px;
    border-bottom: 1px solid #ddd;
    padding-bottom: 20px;
    max-width: 500px;
}

.area-reviews .review-text {
    margin: 10px 0;
    line-height: 1.6;
}

.area-reviews .review-user {
    margin: 8px 0 12px;
    font-weight: bold;
}

.area-reviews .review-image img {
    width: 150px;
    height: auto;
    display: block;
    margin-top: 10px;
    border-radius: 6px;
}

/* ========== area-single LP スタイル ========== */
/* ============================================================
   area-single.css
   カスタム投稿タイプ「area」個別ページ用スタイル（害獣駆除LP版）
   ============================================================ */

/* ---- 共通リセット ---- */
.area-single * { box-sizing: border-box; }
.area-single img { max-width: 100%; height: auto; }

/* ---- セクション共通 ---- */
.area-single section { margin: 40px 0; padding: 0 16px; }
.area-section-title {
    font-size: 1.4rem;
    font-weight: bold;
    border-left: 5px solid #e74c3c;
    padding-left: 12px;
    margin-bottom: 20px;
    color: #222;
}

/* ============================================================
   ① ヒーロー
   ============================================================ */
.area-hero {
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%);
    color: #fff;
    padding: 40px 16px;
    margin: 0 0 40px;
}
.area-hero__inner {
    max-width: 900px;
    margin: 0 auto;
    display: flex;
    gap: 24px;
    align-items: flex-start;
    flex-wrap: wrap;
}
.area-hero__thumb {
    flex: 0 0 280px;
    max-width: 280px;
}
.area-hero__thumb img {
    width: 100%;
    border-radius: 8px;
    object-fit: cover;
    aspect-ratio: 4/3;
}
.area-hero__content { flex: 1; min-width: 220px; }
.area-hero__label {
    display: inline-block;
    background: #e74c3c;
    color: #fff;
    font-size: 0.8rem;
    font-weight: bold;
    padding: 3px 10px;
    border-radius: 3px;
    margin-bottom: 10px;
}
.area-hero__title {
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.4;
    margin: 0 0 10px;
    color: #fff;
}
.area-hero__em {
    color: #f39c12;
    font-size: 2rem;
}
.area-hero__sub {
    font-size: 0.95rem;
    color: #ccc;
    margin-bottom: 20px;
    line-height: 1.7;
}
.area-hero__review {
    margin-top: 12px;
    font-size: 0.9rem;
    color: #ffd700;
}
.area-hero__review .review-score-num {
    font-size: 1.2rem;
    font-weight: bold;
    margin-left: 4px;
}
.area-hero__review .review-count {
    color: #ccc;
    font-size: 0.85rem;
}

/* ============================================================
   CTAボタン共通
   ============================================================ */
.area-cta-mid,
.area-cta-footer {
    background: #fff8f8;
    border: 2px solid #e74c3c;
    border-radius: 10px;
    padding: 30px 20px;
    text-align: center;
    margin: 40px 16px;
}
.area-cta-mid__inner,
.area-cta-footer__inner { max-width: 700px; margin: 0 auto; }
.area-cta-mid__lead,
.area-cta-footer p {
    font-size: 1rem;
    margin-bottom: 20px;
    color: #333;
}
.area-cta-footer h2 {
    font-size: 1.3rem;
    font-weight: bold;
    margin-bottom: 10px;
    color: #c0392b;
}
.area-cta-mid__buttons,
.area-cta-footer__buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    justify-content: center;
}

.btn-cta {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 14px 28px;
    border-radius: 8px;
    text-decoration: none;
    font-weight: bold;
    font-size: 1rem;
    line-height: 1.4;
    transition: opacity 0.2s, transform 0.1s;
    min-width: 200px;
}
.btn-cta:hover { opacity: 0.85; transform: translateY(-1px); }
.btn-cta--tel {
    background: #e74c3c;
    color: #fff;
}
.btn-cta--contact {
    background: #27ae60;
    color: #fff;
}
.btn-cta__icon { font-size: 1.4rem; }
.btn-cta__num {
    font-size: 1.4rem;
    font-weight: bold;
    letter-spacing: 0.05em;
}
.btn-cta__note {
    font-size: 0.75rem;
    font-weight: normal;
    opacity: 0.9;
}

/* ---- ヒーロー内CTA ---- */
.area-hero__cta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

/* ============================================================
   ② リード文
   ============================================================ */
.area-intro { max-width: 860px; margin: 0 auto 40px; }
.area-intro__inner {
    font-size: 1rem;
    line-height: 1.9;
    color: #333;
}

/* ============================================================
   ③ 本文
   ============================================================ */
.area-content { max-width: 860px; margin: 0 auto; }
.area-content__inner {
    font-size: 1rem;
    line-height: 1.9;
    color: #333;
}

/* ============================================================
   ④ 対応サービス
   ============================================================ */
.area-services__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 16px;
}
.area-services__item {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    background: #f9f9f9;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    padding: 16px;
}
.area-services__icon { font-size: 2rem; flex-shrink: 0; }
.area-services__item strong { display: block; font-size: 1rem; margin-bottom: 4px; }
.area-services__item p { font-size: 0.88rem; color: #555; margin: 0; line-height: 1.6; }

/* ============================================================
   ⑤ 対応の流れ
   ============================================================ */
.area-flow__steps {
    list-style: none;
    padding: 0;
    margin: 0;
    counter-reset: flow-counter;
}
.area-flow__step {
    display: flex;
    gap: 16px;
    align-items: flex-start;
    padding: 16px 0;
    border-bottom: 1px solid #eee;
}
.area-flow__step:last-child { border-bottom: none; }
.area-flow__num {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    background: #e74c3c;
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    font-weight: bold;
}
.area-flow__step strong { display: block; font-size: 1rem; margin-bottom: 4px; }
.area-flow__step p { font-size: 0.9rem; color: #555; margin: 0; line-height: 1.6; }

/* ============================================================
   ⑦ 口コミ
   ============================================================ */
.area-reviews__list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 16px;
    margin-bottom: 16px;
}
.review-card {
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 8px;
    padding: 16px;
}
.review-card__text {
    font-size: 0.9rem;
    color: #444;
    line-height: 1.7;
    margin: 8px 0;
}
.review-card__user {
    font-size: 0.82rem;
    color: #888;
}
.area-reviews__more { text-align: right; }
.area-reviews__more a {
    font-size: 0.9rem;
    color: #0073aa;
    text-decoration: underline;
}

/* ============================================================
   ⑧ 施工事例
   ============================================================ */
.area-case-card-list { list-style: none; padding: 0; margin: 0; }
.area-case-card { margin-bottom: 20px; }
.area-case-link {
    display: flex;
    gap: 15px;
    padding: 15px;
    border: 1px solid #ddd;
    border-radius: 8px;
    background: #fff;
    text-decoration: none;
    color: #333;
    transition: 0.2s;
}
.area-case-link:hover { background: #f7faff; border-color: #0073aa; }
.area-case-thumb img {
    width: 140px;
    height: 105px;
    object-fit: cover;
    border-radius: 6px;
}
.area-case-info h3 { margin: 0 0 8px; font-size: 1rem; font-weight: bold; }
.area-case-meta { display: flex; gap: 15px; font-size: 0.85rem; color: #555; }
.more-case { text-align: right; margin-top: 8px; }
.more-case a { font-size: 0.9rem; color: #0073aa; text-decoration: underline; }

/* ============================================================
   ⑨ 子エリア一覧
   ============================================================ */
.area-links {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
}
.area-links li a {
    display: block;
    padding: 10px 14px;
    background: #f0f4ff;
    border: 1px solid #c8d8f5;
    border-radius: 6px;
    text-decoration: none;
    color: #1a4fa0;
    font-size: 0.9rem;
    transition: 0.2s;
}
.area-links li a:hover { background: #dce8ff; }

/* ============================================================
   ⑩ FAQ
   ============================================================ */
.faq-list { max-width: 800px; }
.faq-item { border-bottom: 1px solid #eee; }
.faq-q-btn {
    width: 100%;
    text-align: left;
    background: none;
    border: none;
    padding: 16px 0;
    font-size: 1rem;
    font-weight: bold;
    cursor: pointer;
    color: #222;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.faq-q-btn .arrow { transition: transform 0.2s; }
.faq-q-btn.open .arrow { transform: rotate(180deg); }
.faq-a {
    padding: 0 0 16px 16px;
    font-size: 0.95rem;
    color: #444;
    line-height: 1.8;
}

/* ============================================================
   ⑪ 注意喚起
   ============================================================ */
.warning-box {
    background: #fff8e1;
    border-left: 5px solid #f39c12;
    padding: 16px 20px;
    border-radius: 0 6px 6px 0;
    font-size: 0.95rem;
    line-height: 1.8;
    color: #555;
}

/* ============================================================
   スター
   ============================================================ */
.sfs-stars .star.full  { color: #f39c12; }
.sfs-stars .star.half  { color: #f39c12; opacity: 0.5; }
.sfs-stars .star.empty { color: #ccc; }

/* ============================================================
   レスポンシブ
   ============================================================ */
@media (max-width: 599px) {
    .area-hero__inner { flex-direction: column; }
    .area-hero__thumb { flex: none; max-width: 100%; }
    .area-hero__title { font-size: 1.4rem; }
    .area-hero__em    { font-size: 1.6rem; }
    .area-hero__cta   { flex-direction: column; }
    .btn-cta          { width: 100%; }
    .area-case-link   { flex-direction: column; }
    .area-case-thumb img { width: 100%; height: auto; }
    .area-links       { grid-template-columns: 1fr; }
    .area-cta-mid__buttons,
    .area-cta-footer__buttons { flex-direction: column; align-items: center; }
}

/* ========== area-single LP スタイル ========== */
/* ============================================================
   area-single.css
   カスタム投稿タイプ「area」個別ページ用スタイル（害獣駆除LP版）
   ============================================================ */

/* ---- 共通リセット ---- */
.area-single * { box-sizing: border-box; }
.area-single img { max-width: 100%; height: auto; }

/* ---- セクション共通 ---- */
.area-single section { margin: 40px 0; padding: 0 16px; }
.area-section-title {
    font-size: 1.4rem;
    font-weight: bold;
    border-left: 5px solid #e74c3c;
    padding-left: 12px;
    margin-bottom: 20px;
    color: #222;
}

/* ============================================================
   ① ヒーロー
   ============================================================ */
.area-hero {
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%);
    color: #fff;
    padding: 40px 16px;
    margin: 0 0 40px;
}
.area-hero__inner {
    max-width: 900px;
    margin: 0 auto;
    display: flex;
    gap: 24px;
    align-items: flex-start;
    flex-wrap: wrap;
}
.area-hero__thumb {
    flex: 0 0 280px;
    max-width: 280px;
}
.area-hero__thumb img {
    width: 100%;
    border-radius: 8px;
    object-fit: cover;
    aspect-ratio: 4/3;
}
.area-hero__content { flex: 1; min-width: 220px; }
.area-hero__label {
    display: inline-block;
    background: #e74c3c;
    color: #fff;
    font-size: 0.8rem;
    font-weight: bold;
    padding: 3px 10px;
    border-radius: 3px;
    margin-bottom: 10px;
}
.area-hero__title {
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.4;
    margin: 0 0 10px;
    color: #fff;
}
.area-hero__em {
    color: #f39c12;
    font-size: 2rem;
}
.area-hero__sub {
    font-size: 0.95rem;
    color: #ccc;
    margin-bottom: 20px;
    line-height: 1.7;
}
.area-hero__review {
    margin-top: 12px;
    font-size: 0.9rem;
    color: #ffd700;
}
.area-hero__review .review-score-num {
    font-size: 1.2rem;
    font-weight: bold;
    margin-left: 4px;
}
.area-hero__review .review-count {
    color: #ccc;
    font-size: 0.85rem;
}

/* ============================================================
   CTAボタン共通
   ============================================================ */
.area-cta-mid,
.area-cta-footer {
    background: #fff8f8;
    border: 2px solid #e74c3c;
    border-radius: 10px;
    padding: 30px 20px;
    text-align: center;
    margin: 40px 16px;
}
.area-cta-mid__inner,
.area-cta-footer__inner { max-width: 700px; margin: 0 auto; }
.area-cta-mid__lead,
.area-cta-footer p {
    font-size: 1rem;
    margin-bottom: 20px;
    color: #333;
}
.area-cta-footer h2 {
    font-size: 1.3rem;
    font-weight: bold;
    margin-bottom: 10px;
    color: #c0392b;
}
.area-cta-mid__buttons,
.area-cta-footer__buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    justify-content: center;
}

.btn-cta {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 14px 28px;
    border-radius: 8px;
    text-decoration: none;
    font-weight: bold;
    font-size: 1rem;
    line-height: 1.4;
    transition: opacity 0.2s, transform 0.1s;
    min-width: 200px;
}
.btn-cta:hover { opacity: 0.85; transform: translateY(-1px); }
.btn-cta--tel {
    background: #e74c3c;
    color: #fff;
}
.btn-cta--contact {
    background: #27ae60;
    color: #fff;
}
.btn-cta__icon { font-size: 1.4rem; }
.btn-cta__num {
    font-size: 1.4rem;
    font-weight: bold;
    letter-spacing: 0.05em;
}
.btn-cta__note {
    font-size: 0.75rem;
    font-weight: normal;
    opacity: 0.9;
}

/* ---- ヒーロー内CTA ---- */
.area-hero__cta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

/* ============================================================
   ② リード文
   ============================================================ */
.area-intro { max-width: 860px; margin: 0 auto 40px; }
.area-intro__inner {
    font-size: 1rem;
    line-height: 1.9;
    color: #333;
}

/* ============================================================
   ③ 本文
   ============================================================ */
.area-content { max-width: 860px; margin: 0 auto; }
.area-content__inner {
    font-size: 1rem;
    line-height: 1.9;
    color: #333;
}

/* ============================================================
   ④ 対応サービス
   ============================================================ */
.area-services__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 16px;
}
.area-services__item {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    background: #f9f9f9;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    padding: 16px;
}
.area-services__icon { font-size: 2rem; flex-shrink: 0; }
.area-services__item strong { display: block; font-size: 1rem; margin-bottom: 4px; }
.area-services__item p { font-size: 0.88rem; color: #555; margin: 0; line-height: 1.6; }

/* ============================================================
   ⑤ 対応の流れ
   ============================================================ */
.area-flow__steps {
    list-style: none;
    padding: 0;
    margin: 0;
    counter-reset: flow-counter;
}
.area-flow__step {
    display: flex;
    gap: 16px;
    align-items: flex-start;
    padding: 16px 0;
    border-bottom: 1px solid #eee;
}
.area-flow__step:last-child { border-bottom: none; }
.area-flow__num {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    background: #e74c3c;
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    font-weight: bold;
}
.area-flow__step strong { display: block; font-size: 1rem; margin-bottom: 4px; }
.area-flow__step p { font-size: 0.9rem; color: #555; margin: 0; line-height: 1.6; }

/* ============================================================
   ⑦ 口コミ
   ============================================================ */
.area-reviews__list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 16px;
    margin-bottom: 16px;
}
.review-card {
    background: #fff;
    border: 1px solid #ddd;
    border-radius: 8px;
    padding: 16px;
}
.review-card__text {
    font-size: 0.9rem;
    color: #444;
    line-height: 1.7;
    margin: 8px 0;
}
.review-card__user {
    font-size: 0.82rem;
    color: #888;
}
.area-reviews__more { text-align: right; }
.area-reviews__more a {
    font-size: 0.9rem;
    color: #0073aa;
    text-decoration: underline;
}

/* ============================================================
   ⑧ 施工事例
   ============================================================ */
.area-case-card-list { list-style: none; padding: 0; margin: 0; }
.area-case-card { margin-bottom: 20px; }
.area-case-link {
    display: flex;
    gap: 15px;
    padding: 15px;
    border: 1px solid #ddd;
    border-radius: 8px;
    background: #fff;
    text-decoration: none;
    color: #333;
    transition: 0.2s;
}
.area-case-link:hover { background: #f7faff; border-color: #0073aa; }
.area-case-thumb img {
    width: 140px;
    height: 105px;
    object-fit: cover;
    border-radius: 6px;
}
.area-case-info h3 { margin: 0 0 8px; font-size: 1rem; font-weight: bold; }
.area-case-meta { display: flex; gap: 15px; font-size: 0.85rem; color: #555; }
.more-case { text-align: right; margin-top: 8px; }
.more-case a { font-size: 0.9rem; color: #0073aa; text-decoration: underline; }

/* ============================================================
   ⑨ 子エリア一覧
   ============================================================ */
.area-links {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
}
.area-links li a {
    display: block;
    padding: 10px 14px;
    background: #f0f4ff;
    border: 1px solid #c8d8f5;
    border-radius: 6px;
    text-decoration: none;
    color: #1a4fa0;
    font-size: 0.9rem;
    transition: 0.2s;
}
.area-links li a:hover { background: #dce8ff; }

/* ============================================================
   ⑩ FAQ
   ============================================================ */
.faq-list { max-width: 800px; }
.faq-item { border-bottom: 1px solid #eee; }
.faq-q-btn {
    width: 100%;
    text-align: left;
    background: none;
    border: none;
    padding: 16px 0;
    font-size: 1rem;
    font-weight: bold;
    cursor: pointer;
    color: #222;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.faq-q-btn .arrow { transition: transform 0.2s; }
.faq-q-btn.open .arrow { transform: rotate(180deg); }
.faq-a {
    padding: 0 0 16px 16px;
    font-size: 0.95rem;
    color: #444;
    line-height: 1.8;
}

/* ============================================================
   ⑪ 注意喚起
   ============================================================ */
.warning-box {
    background: #fff8e1;
    border-left: 5px solid #f39c12;
    padding: 16px 20px;
    border-radius: 0 6px 6px 0;
    font-size: 0.95rem;
    line-height: 1.8;
    color: #555;
}

/* ============================================================
   スター
   ============================================================ */
.sfs-stars .star.full  { color: #f39c12; }
.sfs-stars .star.half  { color: #f39c12; opacity: 0.5; }
.sfs-stars .star.empty { color: #ccc; }

/* ============================================================
   レスポンシブ
   ============================================================ */
@media (max-width: 599px) {
    .area-hero__inner { flex-direction: column; }
    .area-hero__thumb { flex: none; max-width: 100%; }
    .area-hero__title { font-size: 1.4rem; }
    .area-hero__em    { font-size: 1.6rem; }
    .area-hero__cta   { flex-direction: column; }
    .btn-cta          { width: 100%; }
    .area-case-link   { flex-direction: column; }
    .area-case-thumb img { width: 100%; height: auto; }
    .area-links       { grid-template-columns: 1fr; }
    .area-cta-mid__buttons,
    .area-cta-footer__buttons { flex-direction: column; align-items: center; }
}

/* ============================================================
   area-pref ページ：中央配置・HEROアイキャッチ対応
   ============================================================ */

/* ---- サイドバーマージンを無効化（area-prefページはサイドバーなし） ---- */
@media only screen and (min-width: 960px) {
    #main.area-pref,
    #main.area-single {
        margin-right: 0 !important;
        margin-left: 0 !important;
        padding: 0 !important;
        width: 100% !important;
    }
}

/* ---- コンテンツ全体の中央配置 ---- */
.area-pref .area-article,
.area-article {
    max-width: 860px !important;
    margin: 0 auto !important;
    padding: 0 20px;
    box-sizing: border-box;
}

/* ---- HEROセクション（アイキャッチ背景画像版） ---- */
.area-hero--image {
    position: relative;
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
    min-height: 420px;
    display: flex;
    align-items: center;
    padding: 0;
    margin: 0 0 0;
}

.area-hero__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.52);
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 40px 20px;
    box-sizing: border-box;
}

.area-hero--image .area-hero__inner {
    max-width: 860px;
    margin: 0 auto;
    width: 100%;
    flex-direction: column;
    align-items: center;
    text-align: center;
    box-sizing: border-box;
}

/* ---- HEROセクション（テキストのみ版） ---- */
.area-hero--text-only {
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%);
    color: #fff;
    padding: 48px 20px;
    margin: 0 0 0;
}

.area-hero--text-only .area-hero__inner {
    max-width: 860px;
    margin: 0 auto;
    flex-direction: column;
    align-items: flex-start;
}

/* ---- HERO内タイトル（h1）---- */
.area-hero__title {
    font-size: 1.9rem;
    font-weight: bold;
    line-height: 1.45;
    margin: 0 0 12px;
    color: #fff;
    text-shadow: 0 1px 4px rgba(0,0,0,0.6);
}

/* ---- HERO内サブテキスト ---- */
.area-hero__sub {
    font-size: 1rem;
    color: rgba(255,255,255,0.88);
    margin-bottom: 24px;
    line-height: 1.75;
    text-shadow: 0 1px 3px rgba(0,0,0,0.5);
}

/* ---- HERO内CTAボタン ---- */
.area-hero__cta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    width: 100%;
    max-width: 560px;
    box-sizing: border-box;
    justify-content: center;
}

/* ---- 本文・セクション共通（centered内） ---- */
.area-pref .area-article section,
.area-article section {
    padding-left: 0;
    padding-right: 0;
}

.area-pref .area-article .area-content,
.area-article .area-content {
    max-width: 100%;
    margin: 0;
}

/* ---- レスポンシブ（モバイル） ---- */
@media (max-width: 599px) {
    .area-hero--image {
        min-height: 300px;
    }
    .area-hero__overlay {
        padding: 32px 16px;
        box-sizing: border-box;
        align-items: center;
        justify-content: center;
    }
    .area-hero--image .area-hero__inner {
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
        align-items: center;
        text-align: center;
    }
    .area-hero__title {
        font-size: 1.4rem;
        width: 100%;
        box-sizing: border-box;
    }
    .area-hero__sub {
        font-size: 0.9rem;
        width: 100%;
        box-sizing: border-box;
    }
    .area-hero__cta {
        flex-direction: column;
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
        align-items: center;
    }
    .area-hero__cta .gaiju-aff-cta,
    .area-hero__cta .redbox {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }
    .area-pref .area-article,
    .area-article {
        padding: 0 16px;
    }
}

@media (min-width: 600px) and (max-width: 860px) {
    .area-pref .area-article,
    .area-article {
        padding: 0 24px;
    }
}

/* ---- HERO内CTAボックス：テキスト色の上書き（redboxクラスの白文字を打ち消す） ---- */
.area-hero__cta .gaiju-aff-cta,
.area-hero__cta .redbox {
    color: #333 !important;
}
.area-hero__cta .gaiju-aff-cta__title,
.area-hero__cta .gaiju-aff-cta__title .huto {
    color: #222 !important;
    font-size: 1.2rem !important;
}
.area-hero__cta .gaiju-aff-cta__lead {
    color: #555 !important;
}
.area-hero__cta .gaiju-aff-cta__label {
    color: #cf3c4f !important;
}
