/* ============================================================
   JHS - 日本賃貸審査サポート メインCSS
============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
ul,ol{list-style:none}
button{cursor:pointer;font-family:inherit;border:none;background:none}

:root{
  --green:#8fc320;
  --green-dark:#6d9618;
  --green-pale:#eef7d6;
  --green-light:#f5fae8;
  --green-mid:#cae5d3;
  --red:#e74c3c;
  --red-dark:#c0392b;
  --gray-dark:#484848;
  --gray:#828990;
  --gray-light:#f5f5f5;
  --text:#333333;
  --text-sub:#555555;
  --border:#e0e0e0;
  --white:#ffffff;
  --font:-apple-system,BlinkMacSystemFont,'Hiragino Kaku Gothic ProN','Hiragino Sans','Noto Sans JP',Meiryo,sans-serif;
  --header-h:86px;
  --max-w:1212px;
  --ease:.2s ease;
  --r:4px;
  --shadow:0 2px 12px rgba(0,0,0,.08);
  --shadow-md:0 4px 24px rgba(0,0,0,.12);
}

html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font);color:var(--text);background:#fff;line-height:1.85;-webkit-font-smoothing:antialiased}

.container{max-width:var(--max-w);margin:0 auto;padding:0 32px}
.container--sm{max-width:860px;margin:0 auto;padding:0 32px}

h1{font-size:clamp(1.6rem,3vw,2.4rem);font-weight:bold;line-height:1.4}
h2{font-size:clamp(1.2rem,2.2vw,1.6rem);font-weight:bold;line-height:1.4}
h3{font-size:clamp(1rem,1.8vw,1.2rem);font-weight:bold;line-height:1.5}
p{line-height:1.9}

/* ボタン */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 36px;border-radius:25px;font-weight:bold;font-size:.95rem;white-space:nowrap;transition:transform var(--ease),background var(--ease),opacity var(--ease);cursor:pointer}
.btn--lg{padding:18px 48px;font-size:1.05rem}
.btn--full{width:100%}
.btn--green{background:var(--green);color:#fff}
.btn--green:hover{background:var(--green-dark);transform:translateY(3px)}
.btn--line{background:#06c755;color:#fff}
.btn--line:hover{background:#04a344;transform:translateY(3px)}
.btn--red{background:var(--red);color:#fff}
.btn--red:hover{background:var(--red-dark);transform:translateY(3px)}
.btn--outline{background:transparent;color:var(--green);border:2px solid var(--green)}
.btn--outline:hover{background:var(--green);color:#fff}
.btn--white{background:#fff;color:var(--green)}
.btn--white:hover{background:var(--green-pale)}

/* ヘッダー */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--header-h);background:#fff;border-bottom:3px solid var(--green);box-shadow:0 2px 10px rgba(0,0,0,.07);transition:box-shadow var(--ease)}
.site-header.scrolled{box-shadow:0 4px 20px rgba(0,0,0,.12)}
.header-inner{display:flex;align-items:center;gap:24px;height:100%}

.site-logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.logo-mark{width:44px;height:44px;background:var(--green);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:bold;font-size:.75rem;letter-spacing:-.02em;flex-shrink:0}
.logo-text{display:flex;flex-direction:column;line-height:1.2}
.logo-text__ja{font-size:.82rem;font-weight:bold;color:var(--text)}
.logo-text__en{font-size:.6rem;color:var(--gray);letter-spacing:.04em}

.global-nav{margin-left:auto}
.global-nav__list{display:flex;align-items:center}
.global-nav__item{position:relative}
.global-nav__link{display:block;padding:8px 12px;font-size:.85rem;font-weight:bold;color:var(--text);transition:color var(--ease);white-space:nowrap}
.global-nav__link:hover,.global-nav__link.active{color:var(--green)}
.global-nav__link.active{border-bottom:2px solid var(--green)}

.global-nav__item--dropdown:hover .dropdown{display:block}
.dropdown{display:none;position:absolute;top:100%;left:0;background:#fff;min-width:180px;border:1px solid var(--border);border-top:3px solid var(--green);box-shadow:var(--shadow-md);z-index:100}
.dropdown a{display:block;padding:12px 16px;font-size:.85rem;color:var(--text);border-bottom:1px solid var(--border);transition:background var(--ease),color var(--ease)}
.dropdown a:last-child{border-bottom:none}
.dropdown a:hover{background:var(--green-light);color:var(--green-dark)}

.header-ctas{display:flex;align-items:center;gap:8px;flex-shrink:0}
.header-cta{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:25px;font-size:.82rem;font-weight:bold;white-space:nowrap;transition:transform var(--ease),background var(--ease)}
.header-cta--line{background:#06c755;color:#fff}
.header-cta--line:hover{background:#04a344;transform:translateY(2px)}
.header-cta--tel{background:var(--green);color:#fff}
.header-cta--tel:hover{background:var(--green-dark);transform:translateY(2px)}

.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;padding:4px;margin-left:auto}
.hamburger span{display:block;width:100%;height:2px;background:var(--text);border-radius:2px;transition:transform .25s ease,opacity .25s ease}
.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-nav{display:none;position:fixed;top:var(--header-h);right:0;width:280px;height:calc(100vh - var(--header-h));background:#fff;border-left:3px solid var(--green);overflow-y:auto;z-index:999;transform:translateX(100%);transition:transform .3s ease;box-shadow:-4px 0 20px rgba(0,0,0,.1)}
.mobile-nav.open{transform:translateX(0)}
.mobile-nav__link{display:block;padding:14px 24px;font-size:.9rem;font-weight:bold;color:var(--text);border-bottom:1px solid var(--border)}
.mobile-nav__link:hover{background:var(--green-light);color:var(--green)}
.mobile-nav__sub{background:var(--gray-light)}
.mobile-nav__sub a{display:block;padding:12px 36px;font-size:.85rem;color:var(--text-sub);border-bottom:1px solid var(--border)}
.mobile-nav__sub a:hover{color:var(--green)}
.mobile-nav__ctas{padding:20px 16px;display:flex;flex-direction:column;gap:10px}

/* セクション */
.section{padding:64px 0}
.section--white{background:#fff}
.section--gray{background:var(--gray-light)}
.section--sky{background:#f0f8e8}
.section--green{background:var(--green)}
.section--dark{background:var(--gray-dark);color:#fff}

.sec-head{margin-bottom:48px}
.sec-head--center{text-align:center}
.sec-label{display:inline-block;font-size:.75rem;font-weight:bold;letter-spacing:.12em;color:var(--green);margin-bottom:8px}
.sec-title{font-size:clamp(1.3rem,2.5vw,1.8rem);font-weight:bold;color:var(--text)}
.sec-divider{width:48px;height:3px;background:var(--green);margin:12px 0 0}
.sec-head--center .sec-divider{margin:12px auto 0}
.sec-desc{color:var(--text-sub);margin-top:12px}

/* ページヒーロー */
.page-hero{margin-top:var(--header-h);background:var(--green);padding:40px 0}
.page-hero__title{font-size:clamp(1.4rem,3vw,2rem);font-weight:bold;color:#fff;margin-bottom:8px}
.page-hero__desc{color:rgba(255,255,255,.88);font-size:.95rem}

/* パンくず */
.breadcrumb{background:var(--gray-light);border-bottom:1px solid var(--border);padding:10px 0}
.breadcrumb__list{display:flex;flex-wrap:wrap;gap:4px;font-size:.82rem;color:var(--gray)}
.breadcrumb__list li{display:flex;align-items:center}
.breadcrumb__list li::after{content:'›';margin-left:4px;color:var(--gray)}
.breadcrumb__list li:last-child::after{display:none}
.breadcrumb__list a{color:var(--green)}
.breadcrumb__list a:hover{text-decoration:underline}

/* スタッツバー */
.stats-bar{display:grid;grid-template-columns:repeat(4,1fr);background:var(--green);color:#fff}
.stats-bar__item{padding:28px 16px;text-align:center;border-right:1px solid rgba(255,255,255,.25)}
.stats-bar__item:last-child{border-right:none}
.stats-bar__val{font-size:clamp(1.6rem,2.5vw,2.2rem);font-weight:bold;line-height:1;margin-bottom:6px}
.stats-bar__val small{font-size:.55em}
.stats-bar__label{font-size:.8rem;color:rgba(255,255,255,.85)}

/* カードグリッド */
.card-grid--2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.card-grid--3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card-grid--4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}

.card{background:#fff;border:1px solid var(--border);border-top:4px solid var(--green);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);transition:transform var(--ease),box-shadow var(--ease)}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.card__body{padding:24px}
.card__title{font-size:1rem;font-weight:bold;margin-bottom:10px;color:var(--text)}
.card__text{font-size:.88rem;color:var(--text-sub);line-height:1.8}

/* FAQ */
.faq-list{border-top:2px solid var(--green)}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{width:100%;display:flex;align-items:flex-start;gap:14px;padding:18px 16px;text-align:left;font-size:.95rem;font-weight:bold;color:var(--text);cursor:pointer;background:none;border:none;transition:background var(--ease)}
.faq-q::before{content:'Q';flex-shrink:0;width:28px;height:28px;border-radius:50%;background:var(--green);color:#fff;font-weight:bold;font-size:.85rem;display:flex;align-items:center;justify-content:center}
.faq-q::after{content:'＋';margin-left:auto;flex-shrink:0;font-size:1.2rem;color:var(--green);transition:transform .25s ease}
.faq-q[aria-expanded="true"]::after{transform:rotate(45deg)}
.faq-q:hover{background:var(--green-light)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s ease;background:var(--gray-light)}
.faq-a.open{max-height:600px}
.faq-a>p,.faq-a>div{padding:16px 16px 16px 58px;font-size:.92rem;color:var(--text-sub);line-height:1.85;position:relative}
.faq-a>p::before,.faq-a>div::before{content:'A';position:absolute;left:16px;top:16px;width:28px;height:28px;border-radius:50%;background:var(--gray-dark);color:#fff;font-weight:bold;font-size:.85rem;display:flex;align-items:center;justify-content:center}

/* お客様の声 */
.voice-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.voice-card{background:#fff;border:1px solid var(--border);border-top:4px solid var(--green);border-radius:var(--r);padding:24px;box-shadow:var(--shadow)}
.voice-stars{color:#f59e0b;font-size:1.1rem;margin-bottom:10px}
.voice-title{font-size:.95rem;font-weight:bold;color:var(--text);margin-bottom:12px;line-height:1.5}
.voice-text{font-size:.88rem;color:var(--text-sub);line-height:1.85;margin-bottom:16px}
.voice-meta{display:flex;align-items:center;gap:12px}
.voice-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:bold;font-size:.85rem;color:#fff;flex-shrink:0}
.voice-avatar--f{background:#e67e9a}
.voice-avatar--m{background:#5b9bd5}
.voice-name{font-size:.88rem;font-weight:bold}
.voice-attr{font-size:.78rem;color:var(--gray);margin-top:2px}

/* CTA */
.cta-section{background:var(--green);padding:60px 0;text-align:center}
.cta-section__title{font-size:clamp(1.3rem,2.5vw,1.9rem);font-weight:bold;color:#fff;margin-bottom:12px}
.cta-section__desc{color:rgba(255,255,255,.88);margin-bottom:32px;font-size:.95rem}
.cta-section__btns{display:flex;justify-content:center;flex-wrap:wrap;gap:16px}

/* フッター */
.site-footer{background:var(--gray-dark);color:#fff}
.footer-top{padding:48px 0}
.footer-top-inner{max-width:var(--max-w);margin:0 auto;padding:0 32px;display:grid;grid-template-columns:280px 1fr;gap:48px}
.footer-logo-wrap{display:flex;flex-direction:column;gap:14px}
.footer-logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.footer-logo .logo-mark{background:var(--green)}
.footer-logo .logo-text__ja{color:#fff}
.footer-logo .logo-text__en{color:rgba(255,255,255,.5)}
.footer-desc{font-size:.85rem;color:rgba(255,255,255,.65);line-height:1.8}
.footer-line-btn{display:inline-flex;align-items:center;gap:8px;background:#06c755;color:#fff;padding:10px 20px;border-radius:25px;font-size:.85rem;font-weight:bold;transition:background var(--ease),transform var(--ease);align-self:flex-start}
.footer-line-btn:hover{background:#04a344;transform:translateY(2px)}
.footer-nav-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.footer-nav-group__title{font-size:.8rem;font-weight:bold;letter-spacing:.08em;color:rgba(255,255,255,.5);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.15)}
.footer-nav-group nav{display:flex;flex-direction:column;gap:6px}
.footer-nav-group nav a{font-size:.84rem;color:rgba(255,255,255,.75);transition:color var(--ease)}
.footer-nav-group nav a:hover{color:var(--green)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:18px 32px;display:flex;justify-content:space-between;align-items:center}
.footer-copy{font-size:.8rem;color:rgba(255,255,255,.4)}
.footer-policy{display:flex;gap:20px}
.footer-policy a{font-size:.8rem;color:rgba(255,255,255,.4);transition:color var(--ease)}
.footer-policy a:hover{color:var(--green)}

/* 固定CTA */
.fixed-cta{position:fixed;bottom:24px;right:24px;z-index:900;display:flex;flex-direction:column;gap:10px;opacity:0;pointer-events:none;transform:translateY(20px);transition:opacity .3s ease,transform .3s ease}
.fixed-cta.show{opacity:1;pointer-events:auto;transform:none}
.fixed-cta__btn{display:flex;align-items:center;gap:8px;padding:12px 20px;border-radius:25px;font-weight:bold;font-size:.88rem;color:#fff;box-shadow:0 4px 16px rgba(0,0,0,.2);transition:transform var(--ease),box-shadow var(--ease);white-space:nowrap}
.fixed-cta__btn:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(0,0,0,.25)}
.fixed-cta__btn--line{background:#06c755}
.fixed-cta__btn--tel{background:var(--green)}

/* サイドバー */
.content-with-sidebar{display:grid;grid-template-columns:1fr 280px;gap:40px;align-items:flex-start}
.sidebar{display:flex;flex-direction:column;gap:20px}
.sidebar-widget{border:2px solid var(--green);border-radius:var(--r);overflow:hidden}
.sidebar-widget__title{background:var(--green);color:#fff;font-size:.88rem;font-weight:bold;padding:10px 14px}
.sidebar-nav{display:flex;flex-direction:column}
.sidebar-nav a{display:block;padding:10px 14px;font-size:.86rem;color:var(--text);border-bottom:1px solid var(--border);transition:background var(--ease),color var(--ease)}
.sidebar-nav a:last-child{border-bottom:none}
.sidebar-nav a:hover,.sidebar-nav a.current-menu-item{background:var(--green-light);color:var(--green-dark)}

/* お知らせ */
.news-list{border-top:2px solid var(--green)}
.news-item{display:flex;gap:14px;align-items:baseline;padding:14px 0;border-bottom:1px solid var(--border);font-size:.92rem}
.news-date{color:var(--gray);font-size:.82rem;white-space:nowrap;flex-shrink:0}
.news-cat{background:var(--green);color:#fff;font-size:.7rem;font-weight:bold;padding:2px 10px;border-radius:25px;white-space:nowrap;flex-shrink:0}
.news-cat--info{background:#e67e9a}
.news-title{color:var(--text);font-weight:bold;line-height:1.5;transition:color var(--ease)}
.news-title:hover{color:var(--green);text-decoration:underline}

/* ブログカード */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.blog-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);transition:transform var(--ease),box-shadow var(--ease)}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.blog-card__thumb{background:var(--green-pale);aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;font-size:3rem;border-bottom:3px solid var(--green);overflow:hidden}
.blog-card__thumb img{width:100%;height:100%;object-fit:cover}
.blog-card__body{padding:18px}
.blog-card__meta{display:flex;gap:8px;align-items:center;margin-bottom:10px}
.blog-card__cat{font-size:.7rem;font-weight:bold;color:#fff;background:var(--green);padding:2px 10px;border-radius:25px}
.blog-card__date{font-size:.78rem;color:var(--gray)}
.blog-card__title{font-size:.95rem;font-weight:bold;color:var(--text);line-height:1.5;margin-bottom:10px;transition:color var(--ease)}
.blog-card:hover .blog-card__title{color:var(--green)}
.blog-card__excerpt{font-size:.83rem;color:var(--text-sub);line-height:1.7}

/* ブログ一覧 */
.blog-list-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);display:flex;transition:transform var(--ease),box-shadow var(--ease)}
.blog-list-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.blog-list-card__thumb{width:180px;flex-shrink:0;background:var(--green-pale);display:flex;align-items:center;justify-content:center;font-size:2.5rem;border-right:3px solid var(--green);overflow:hidden}
.blog-list-card__thumb img{width:100%;height:100%;object-fit:cover}
.blog-list-card__body{padding:20px 24px;flex:1}
.blog-list-card__meta{display:flex;gap:10px;align-items:center;margin-bottom:10px}
.blog-list-card__cat{font-size:.7rem;font-weight:bold;color:#fff;background:var(--green);padding:2px 10px;border-radius:25px}
.blog-list-card__date{font-size:.8rem;color:var(--gray)}
.blog-list-card__title{font-size:1rem;font-weight:bold;color:var(--text);line-height:1.5;margin-bottom:10px;transition:color var(--ease)}
.blog-list-card:hover .blog-list-card__title{color:var(--green)}
.blog-list-card__excerpt{font-size:.87rem;color:var(--text-sub);line-height:1.7}
.blog-list-card__link{display:inline-flex;align-items:center;gap:4px;margin-top:12px;font-size:.84rem;font-weight:bold;color:var(--green)}

/* 記事 */
.article-header{margin-bottom:32px}
.article-meta{display:flex;gap:12px;align-items:center;margin-bottom:16px;flex-wrap:wrap}
.article-cat{font-size:.72rem;font-weight:bold;color:#fff;background:var(--green);padding:3px 12px;border-radius:25px}
.article-date{font-size:.82rem;color:var(--gray)}
.article-title{font-size:clamp(1.3rem,2.5vw,1.9rem);font-weight:bold;line-height:1.45;color:var(--text);margin-bottom:12px}
.article-desc{font-size:.93rem;color:var(--text-sub);line-height:1.85;background:var(--green-light);border-left:4px solid var(--green);padding:14px 18px;border-radius:0 4px 4px 0}

/* リッチテキスト */
.rich-text{line-height:1.9;color:var(--text)}
.rich-text h2{display:block;background:var(--green);color:#fff;font-size:1.1rem;font-weight:bold;padding:10px 16px;margin:40px 0 16px;border-left:5px solid var(--green-dark)}
.rich-text h3{font-size:1rem;font-weight:bold;color:var(--text);padding:8px 12px;border-left:4px solid var(--green);background:var(--green-light);margin:28px 0 12px}
.rich-text p{margin-bottom:16px;font-size:.95rem}
.rich-text ul,.rich-text ol{padding-left:0;margin-bottom:16px}
.rich-text ul li{padding:6px 6px 6px 24px;position:relative;font-size:.93rem;border-bottom:1px dotted var(--border)}
.rich-text ul li::before{content:'●';color:var(--green);position:absolute;left:4px;font-size:.7rem;top:10px}
.rich-text ol{counter-reset:ol-counter}
.rich-text ol li{padding:6px 6px 6px 32px;position:relative;font-size:.93rem;border-bottom:1px dotted var(--border);counter-increment:ol-counter}
.rich-text ol li::before{content:counter(ol-counter);position:absolute;left:0;top:4px;width:22px;height:22px;background:var(--green);color:#fff;border-radius:50%;font-size:.75rem;font-weight:bold;display:flex;align-items:center;justify-content:center}
.rich-text strong{color:var(--green-dark);font-weight:bold}
.rich-text a{color:var(--green);text-decoration:underline}

/* 料金テーブル */
.price-table{width:100%;border-collapse:collapse;margin-bottom:24px;font-size:.93rem}
.price-table th{background:var(--green);color:#fff;padding:12px 16px;text-align:left;font-weight:bold;border:1px solid var(--green-dark)}
.price-table td{padding:12px 16px;border:1px solid var(--border);vertical-align:top}
.price-table tr:nth-child(even) td{background:var(--green-light)}
.price-val{font-size:1.05rem;font-weight:bold;color:var(--green-dark);white-space:nowrap}

/* ページネーション */
.pagination{display:flex;justify-content:center;gap:8px;margin:40px 0;flex-wrap:wrap}
.pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--r);font-size:.9rem;font-weight:bold;color:var(--text);background:#fff;border:1px solid var(--border);transition:background var(--ease),color var(--ease),border-color var(--ease)}
.pagination .page-numbers:hover,.pagination .page-numbers.current{background:var(--green);color:#fff;border-color:var(--green)}
.pagination .prev,.pagination .next{width:auto;padding:0 16px}

/* フロントページ専用 */
.hero{margin-top:var(--header-h);position:relative;overflow:hidden;background:linear-gradient(135deg,#f5fae8 0%,#eef7d6 60%,#f5fae8 100%);padding:72px 0 64px}
.hero-inner{position:relative;z-index:2;max-width:1212px;margin:0 auto;padding:0 32px;display:grid;grid-template-columns:1fr 380px;gap:48px;align-items:center}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:var(--green);color:#fff;font-size:.76rem;font-weight:bold;padding:5px 14px;border-radius:25px;margin-bottom:20px}
.hero-title{font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:bold;line-height:1.35;color:var(--text);margin-bottom:20px}
.hero-title em{color:var(--green);font-style:normal}
.hero-desc{font-size:.97rem;color:var(--text-sub);line-height:1.95;margin-bottom:24px}
.hero-points{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:28px}
.hero-point{display:inline-flex;align-items:center;gap:5px;background:#fff;border:1px solid var(--green-mid);padding:6px 14px;border-radius:4px;font-size:.84rem;font-weight:bold;color:var(--text)}
.hero-point::before{content:'✓';color:var(--green)}
.hero-btns{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:14px}
.hero-note{font-size:.78rem;color:var(--gray)}

.hero-card{background:#fff;border-radius:8px;box-shadow:0 8px 40px rgba(0,0,0,.12);padding:28px 24px;border-top:5px solid var(--green)}
.hero-card__title{font-size:.88rem;font-weight:bold;color:var(--text);margin-bottom:18px;text-align:center;padding-bottom:12px;border-bottom:1px solid var(--border)}
.hero-card__title span{color:var(--green)}
.hero-card__stats{display:flex;flex-direction:column;gap:10px}
.hero-stat{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--green-light);border-radius:4px}
.hero-stat__icon{width:40px;height:40px;border-radius:50%;background:var(--green);color:#fff;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:1rem}
.hero-stat__val{font-size:1.35rem;font-weight:bold;color:var(--text);line-height:1}
.hero-stat__val small{font-size:.65em;font-weight:normal;color:var(--text-sub)}
.hero-stat__label{font-size:.75rem;color:var(--text-sub);margin-top:2px}
.hero-card__cta{margin-top:18px;display:flex;flex-direction:column;gap:8px}
.hero-card__note{font-size:.72rem;color:var(--gray);text-align:center;margin-top:4px}

.service-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.service-card{background:#fff;border:1px solid var(--border);border-top:4px solid var(--green);border-radius:var(--r);box-shadow:var(--shadow);padding:28px 20px;text-align:center;transition:transform var(--ease),box-shadow var(--ease);display:flex;flex-direction:column;align-items:center}
.service-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.service-card__icon{width:64px;height:64px;border-radius:50%;background:var(--green-pale);margin:0 auto 14px;display:flex;align-items:center;justify-content:center;font-size:1.75rem}
.service-card__title{font-size:.97rem;font-weight:bold;margin-bottom:8px}
.service-card__price{font-size:.8rem;color:var(--green-dark);font-weight:bold;background:var(--green-pale);padding:3px 12px;border-radius:25px;margin-bottom:12px}
.service-card__text{font-size:.84rem;color:var(--text-sub);line-height:1.7;flex:1}
.service-card__link{display:inline-flex;align-items:center;gap:4px;margin-top:14px;font-size:.84rem;font-weight:bold;color:var(--green)}

.reason-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.reason-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow);padding:32px 24px;text-align:center;transition:transform var(--ease),box-shadow var(--ease)}
.reason-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.reason-num{width:44px;height:44px;border-radius:50%;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:bold;font-size:.82rem;margin:0 auto 12px}
.reason-icon{font-size:2.2rem;margin-bottom:10px}
.reason-card__title{font-size:1rem;font-weight:bold;margin-bottom:10px}
.reason-card__hl{color:var(--green)}
.reason-card__text{font-size:.87rem;color:var(--text-sub);line-height:1.85}

.top-flow{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative}
.top-flow::before{content:'';position:absolute;top:32px;left:12.5%;right:12.5%;height:3px;background:var(--green-mid);z-index:0}
.top-flow__step{text-align:center;padding:0 12px 24px;position:relative;z-index:1}
.top-flow__num{width:64px;height:64px;border-radius:50%;background:var(--green);color:#fff;margin:0 auto 14px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:.68rem;font-weight:bold;line-height:1.3;box-shadow:0 3px 10px rgba(143,195,32,.4)}
.top-flow__num span{font-size:1.1rem;line-height:1}
.top-flow__title{font-size:.95rem;font-weight:bold;margin-bottom:8px}
.top-flow__text{font-size:.82rem;color:var(--text-sub);line-height:1.75}

/* レスポンシブ */
@media(max-width:1024px){
  :root{--header-h:72px}
  .global-nav{display:none}
  .header-ctas{display:none}
  .hamburger{display:flex}
  .mobile-nav{display:block}
  .card-grid--4{grid-template-columns:repeat(2,1fr)}
  .card-grid--3{grid-template-columns:repeat(2,1fr)}
  .footer-nav-grid{grid-template-columns:repeat(2,1fr)}
  .content-with-sidebar{grid-template-columns:1fr}
  .hero-inner{grid-template-columns:1fr}
  .hero-card{display:none}
  .service-grid{grid-template-columns:repeat(2,1fr)}
  .stats-bar{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  :root{--header-h:60px}
  .section{padding:48px 0}
  .container{padding:0 20px}
  .hero{padding:48px 0 36px}
  .reason-grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
  .top-flow{grid-template-columns:repeat(2,1fr)}
  .top-flow::before{display:none}
  .voice-grid{grid-template-columns:1fr}
  .blog-list-card{flex-direction:column}
  .blog-list-card__thumb{width:100%;height:100px;border-right:none;border-bottom:3px solid var(--green)}
  .footer-top-inner{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:12px;text-align:center}
  .stats-bar{grid-template-columns:repeat(2,1fr)}
}

/* レイアウト：サイドバー付き */
.layout-with-sidebar{display:grid;grid-template-columns:1fr 280px;gap:40px;align-items:flex-start}
.main-content{min-width:0}

/* サイドバー詳細 */
.sidebar-widget{border:2px solid var(--green);border-radius:var(--r);overflow:hidden;margin-bottom:0}
.sidebar-cat-list{list-style:none;padding:0;margin:0}
.sidebar-cat-list li a{display:flex;justify-content:space-between;padding:10px 14px;font-size:.875rem;color:var(--text);border-bottom:1px solid var(--border);transition:background var(--ease),color var(--ease)}
.sidebar-cat-list li:last-child a{border-bottom:none}
.sidebar-cat-list li a:hover{background:var(--green-pale,#f0f8e8);color:var(--green)}
.sidebar-cat-list li a span{color:var(--gray,#999);font-size:.8rem}
.sidebar-recent-item{display:flex;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border);align-items:flex-start}
.sidebar-recent-item:last-child{border-bottom:none}
.sidebar-recent-item__thumb{width:60px;height:60px;flex-shrink:0;overflow:hidden;border-radius:4px;background:var(--green-pale,#f0f8e8)}
.sidebar-recent-item__thumb img{width:100%;height:100%;object-fit:cover}
.sidebar-recent-item__title{font-size:.82rem;font-weight:700;color:var(--text);line-height:1.5;display:block;transition:color var(--ease)}
.sidebar-recent-item__title:hover{color:var(--green)}
.sidebar-recent-item__date{font-size:.75rem;color:var(--gray,#999);margin-top:4px;display:block}
.sidebar-cta{background:var(--green);color:#fff;padding:20px}
.sidebar-cta__title{font-weight:700;font-size:1rem;margin-bottom:.5rem}
.sidebar-cta__desc{font-size:.875rem;margin-bottom:1rem;line-height:1.6;opacity:.9}
.sidebar-service-list{list-style:none;padding:0;margin:0}
.sidebar-service-list li a{display:flex;align-items:center;gap:6px;padding:10px 14px;font-size:.875rem;color:var(--text);border-bottom:1px solid var(--border);transition:background var(--ease),color var(--ease)}
.sidebar-service-list li a::before{content:"›";color:var(--green);font-weight:700}
.sidebar-service-list li:last-child a{border-bottom:none}
.sidebar-service-list li a:hover{background:var(--green-pale,#f0f8e8);color:var(--green)}

/* ブログ一覧のフレックスレイアウト修正 */
.blog-list{display:flex;flex-direction:column;gap:20px}
.blog-list-card__meta{display:flex;justify-content:space-between;align-items:center;margin-top:12px}

/* ページヒーロー（小） */
.page-hero--sm .page-hero__title{font-size:clamp(1.2rem,2.5vw,1.6rem)}

@media(max-width:1024px){
  .layout-with-sidebar{grid-template-columns:1fr}
  .sidebar{order:2}
}
