@charset "UTF-8";
/*
Theme Name: Souzoku Pro Theme
Theme URI: https://souzoku-pro.com
Description: 相続の不安を生前から死後までワンストップで解決
Version: 1.0.0

==============================
  STYLE INDEX
==============================
  0. Notes / Conventions
  1. Tokens (Variables)
  2. Base / Typography
  3. Utilities
  4. Common Components
  5. Blog
    5.0 Blog common
    5.1 Blog Header (site-header)
    5.2 Blog List/content (home.php)
    5.3 Archive (archive.php)
    5.4 Single (single.php)
    5.5 Breadcrumb
    5.6 Blog CTA (article-cta) / Blogcard
    5.7　Related Posts / AI Summary
    5.8 Blog Footer
  6. LP
    6.1 LP Header Bar (！Blogと共有スタイル)
    6.2 LP Hero (main visual)
    6.3 LP Sections
    6.4 LP CTA / Sticky CTA
    6.5 LP Footer
  7. Legacy 
  8. Responsive (ONLY here)
    8.1 <= 1024 (if needed)
    8.2 <= 896  (if needed)
    8.3 <= 768
    8.4 <= 680  (if needed)
    8.5 <= 480
==============================
*/

/* ==============================
   0. Notes / Conventions
============================== */
/*
  Engineer Note (Motoko)
  style.css が未整理のままになっており失礼しました。
  Blog / LP / Common / Responsive の見出しで整理し、
  先日ご調整いただいたブログ側の修正（記事/一覧/サムネ等）も反映して整備しました。

  03/08
single.php/header/footer/related-posts　作業中です。style.cssにまだ古い記述が残っていますが後日整理いたします。


  */

/* ==============================
   1. Variable
============================== */
:root {
  /* Gradients */
  --gradientGr_45deg: linear-gradient(45deg, #395322, #9bb44a, #090b00);
  --gradientGrLt_45deg: linear-gradient(45deg, #f4ffe0, #c7cc83, #8e967b);
  --gradientGld_45deg: linear-gradient(
    45deg,
    #a47123,
    #f7f6d2,
    #a47123,
    #ceab5d,
    #e5ca7d,
    #a47123
  );
  --gradientGrCta_45deg: linear-gradient(
    45deg,
    rgba(244, 255, 244, 0.5),
    rgba(199, 204, 131, 0.5),
    rgba(142, 150, 123, 0.5)
  );
  --gradientSvr: linear-gradient(
    to bottom,
    #bcbcbc,
    #e3e3e3,
    #efe9e9,
    #ffffff,
    #afafaf
  );
  --gradientGr_down: linear-gradient(to bottom, #395322, #9bb44a, #090b00);
  --gradientOrg_down: linear-gradient(
    to bottom,
    #74320b,
    #aa4000,
    #cb672c,
    #ffb183,
    #aa4103
  );
  --gradientGr_radial: radial-gradient(circle at center, #ffffff, #d4e0cf);
  --gradientFooter: linear-gradient(45deg, #1d2615, #4c5f10, #4c5f10);

  /* Colors */
  --borderBoxGr: #45751a;
  --colorOrange: #ff8408;
  --ink: #393939;
  --inkGr: #354e13;

  /* Images */
  --bcgTexture: url('img/bcg_texture.jpg');

  /* Typography scale */
  --fs-body: clamp(16px, 1.1vw, 18px);
  --fs-h1: clamp(28px, 3.5vw, 40px);
  --fs-h2: clamp(35px, 3.29vw, 40px); /*sectionTitle*/
  --fs-h3: clamp(25px, 2.41vw, 30px);
  --fs-headlineL: clamp(28px, 2.68vw, 33px);
  --fs-headlineM: clamp(20px, 2.11vw, 28px);
  --fs-headlineS: clamp(18px, 1.84vw, 24px);
  --fs-standard: clamp(17px, 1.58vw, 19px);
  --fs-small: clamp(14px, 0.9vw, 16px);

  --fx-lpEmphasisXL: clamp(26px, 2.59vw, 33px);
  --fx-lpEmphasis: clamp(23px, 2.24vw, 28px);

  --fs-ctaBtn: clamp(20px, 1.89vw, 23px);
  --fs-ctaBtnSm: clamp(15px, 1.4vw, 17px);

  /* Hero */
  --fs-hero-main: clamp(26px, 2.98vw, 42px);
  --fs-hero-strong: clamp(36px, 4.08vw, 57px);

  /* Layout */
  --margin-standard: 7%;

  /* decoration */
  --boxShadow: 3px 3px 30px rgba(0, 0, 0, 0.3);
}

/* ==============================
   2. Base / Typography
============================== */
html {
  font-size: 62.5%; /* 16px * 62.5% = 10px */
}
body {
  max-width: 1920px;
  width: 100%;
  color: var(--ink);
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: var(--fs-body);
  font-feature-settings: 'palt';
  letter-spacing: 0.02em;
  -webkit-text-size-adjust: 100%;
  line-height: 1.9;
  margin: 0 auto;
}
a {
  appearance: none;
  color: #1b1d22;
  transition: all 0.4s;
}
a:hover {
  opacity: 0.6;
}
img {
  max-width: 100%;
  height: auto;
}
input {
  background-image: none;
  border: 1px solid rgba(0, 0, 0, 0.16);
  border-radius: 0;
  color: inherit;
  font-family: inherit;
  font-size: 1em;
  padding: 0.4em 0.8em;
}
button {
  appearance: none;
}
dl,
dt,
dd {
  line-height: 1.5;
  padding-bottom: 20px;
}
h1 {
  font-family: 'Zen Old Mincho', serif;
  font-weight: 700;
  font-size: var(--fs-h1);
  font-style: normal;
  /* white-space は必要箇所だけで */
}
h2 {
  font-size: var(--fs-h2);
  font-weight: 700;
  line-height: 1.4;
}
h3 {
  font-size: var(--fs-h3);
}
.hero-title {
  font-family: 'Zen Old Mincho', serif;
  font-size: var(--fs-hero-main);
  line-height: 1.2;
}
.hero-title strong {
  font-size: var(--fs-hero-strong);
}
.stickyCta {
  display: none;
}
/* ==============================
   3. Utilities
============================== */
.text-center {
  text-align: center;
}
.uppercase {
  text-transform: uppercase;
}

.wrapper {
  padding: 0 7.2%;
}
.sp_only {
  display: none;
}
.pc_only {
  display: block;
}
.br_sp {
  display: none;
}
/* ==============================
   4. Common Components
============================== */
/* JavaScript:  Fadein Animation */
.fadein {
  opacity: 0;
  transform: translateY(50px);
  transition:
    opacity 1s ease,
    transform 1.5s ease;
}
.fadein.is-visible {
  opacity: 1 !important;
  transform: translateY(0) !important;
}

/* ==============================
   5. Blog
============================== */
/* ------------------------------
   5.0 Blog common
------------------------------ */
.blog-main,
.posts_main {
  width: min(1100px, 92%);
  margin: 0 auto;
  padding: 150px 0 70px;
  box-sizing: border-box;
}
.blog__bcg {
  background: url(img/bcg_texture.jpg);
  background-repeat: repeat-y;
  background-size: cover;
  width: 100%;
}
strong {
  font-size: 1.03em;
  font-weight: 700;
}
/* ------------------------------
   5.1 Blog Header (site-header)
------------------------------ */
/* LP共有：LPセクションを参照 */

/* ------------------------------
   5.2 Blog List (home.php)
------------------------------ */
.list-header {
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.12);
}
.list-title {
  margin: 0 0 8px;
  font-size: 28px;
  line-height: 1.35;
  font-weight: 600;
}
.list-lead {
  margin: 0;
  font-size: 14px;
  color: rgba(0, 0, 0, 0.7);
  line-height: 1.8;
}
/* Cards list */
.post-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-top: 22px;
}
.post-card {
  border: 1px solid rgba(0, 0, 0, 0.1);
  border-radius: 14px;
  overflow: hidden;
  background: #fff;
}
.post-card__link {
  display: block;
  text-decoration: none;
  color: inherit;
  height: 100%;
}
/* Thumb: unified */
.post-card__thumb {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: rgba(0, 0, 0, 0.06);
}
.post-card__thumb img {
  position: absolute;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
  display: block;
}
.post-card__body {
  padding: 14px 14px 16px;
}
.post-card__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  font-size: 12px;
  color: rgba(0, 0, 0, 0.55);
  margin-bottom: 10px;
}
.post-card__cats {
  display: inline-flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.post-card__cat {
  display: inline-block;
  padding: 3px 8px;
  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: 999px;
  font-size: 11px;
  color: rgba(0, 0, 0, 0.65);
  background: #fff;
}
.post-card__title {
  margin: 0 0 10px;
  font-size: 16px;
  line-height: 1.45;
  font-weight: 600;
}
.post-card__excerpt {
  margin: 0;
  font-size: 13px;
  color: rgba(0, 0, 0, 0.75);
  line-height: 1.75;
}
/* Pagination */
.pagination {
  margin: 34px 0 0;
  text-align: center;
}
.pagination .page-numbers {
  display: inline-block;
  padding: 8px 12px;
  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: 10px;
  text-decoration: none;
  color: inherit;
  margin: 0 4px;
  font-size: 13px;
}
.pagination .page-numbers.current {
  font-weight: 600;
}
/* ------------------------------
   5.3 Archive (archive.php)
------------------------------ */
.archive-header {
  margin: 0 0 26px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.12);
}
.archive-title {
  margin: 0 0 10px;
  font-size: 28px;
  line-height: 1.35;
  font-weight: 600;
}
.archive-desc {
  font-size: 14px;
  color: rgba(0, 0, 0, 0.7);
  line-height: 1.8;
}
/* ------------------------------
   5.4 Single (single.php)
------------------------------ */
/* -------Titles ------- */
.article__title {
  margin: 0 0 12px;
  font-size: clamp(22px, 2.5vw, 35px);
  line-height: 1.35;
  font-weight: 600;
  white-space: normal;
}
.article__content {
  font-size: var(--fs-body);
  line-height: 1.9;
  overflow-wrap: break-word;
  word-break: break-word;
}
.article__content p {
  margin: 1.4em 0;
}
/* 自動投稿の見出し対策：最低限きれいに */
.article__content h2 {
  font-size: clamp(20px, 1.93vw, 24px);
  margin: 2.2em 0 1em;
  padding-left: 12px;
  border-left: 4px solid #354e13;
  white-space: normal;
  color: var(--inkGr);
}
.article__content h3 {
  font-size: clamp(16px, 1.58vw, 20px);
  margin: 2em 0 0.8em;
}
.article__content ul,
.article__content ol {
  margin: 1.4em 0 1.4em 1.6em;
}
.article__content img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 1.8em auto;
  border-radius: 6px;
}
.article-figure {
  max-width: 100%;
  overflow: hidden;
  margin: 1.8em 0;
}
/* Thumbnail */
.article__thumbnail {
  margin: 22px 0 30px;
}
.article__thumbnail img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 8px;
}
/* Author */
.article__author {
  margin-top: 50px;
  padding-top: 50px;
  border-top: 1px dotted #354e13;
}
.author-card {
  display: grid;
  grid-template-columns: 150px 1fr;
  gap: 24px;
  align-items: flex-start;
  width: min(700px, 100%);
}
.author-card__avatar {
  width: 150px;
  height: 150px;
  border-radius: 50%;
}
.author-card__avatar img {
  object-fit: cover;
  display: block;
  width: 100%;
  height: 100%;
}
.author-card__role {
  margin: 0 0 6px;
  font-size: var(--fs-small);
  color: var(--inkGr);
}
.author-card__name {
  margin: 0 0 10px;
  font-size: var(--fs-body);
  font-weight: 600;
  color: var(--inkGr);
}
.author-card__profile {
  margin: 0;
  font-size: var(--fs-small);
  line-height: 1.8;
  width: min(500px, 80%);
}
/* previous/next link */
.article-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 60px 0;
  gap: 20px;
}
.article-nav__link {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 20px;
  transition: 0.2s;
}
.article-nav__text {
  font-size: 13px;
}
.article-nav__link:hover {
  background: #eaeaea;
}
.article-nav__arrow {
  font-size: 1.3rem;
}
.article-hero {
  width: 100%;
  aspect-ratio: 16/9;
  height: auto;
  overflow: hidden;
}
.article-hero img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.article__meta {
  margin-top: 50px;
}
/* Blog Meta*/
.article__meta {
  display: flex;
  margin: 30px auto 50px;
  justify-content: space-between;
  align-items: center;
  font-size: var(--fs-small);
  font-weight: 500;
  color: var(--inkGr);
}
.article__date {
  white-space: nowrap;
}
.new__flag {
  padding: 2px 15px;
  line-height: 1.2;
  border-radius: 50px;
  color: #fff;
  font-size: 1.2em;
  background: var(--gradientGr_down);
  margin-left: 15px;
  display: inline-block;
  text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.2);
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.2);
  animation: newFlagShake 0.8s ease-in-out 9;
}
@keyframes newFlagShake {
  0% {
    transform: translateX(0);
  }
  25% {
    transform: translateX(-5px);
  }
  50% {
    transform: translateX(5px);
  }
  75% {
    transform: translateX(-3px);
  }
  100% {
    transform: translateX(0);
  }
}
.article__meta a {
  color: var(--inkGr);
}
.article__categories {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 10px;
}
.article__category:hover {
  opacity: 0.75;
}
.article__categories a {
  border-bottom: 1px solid #354e13;
  line-height: 1.2;
}
.article__header {
  margin-bottom: 60px;
  border-bottom: 1px dotted #354e13;
}
.article__content ul,
.article__content ol {
  padding: 30px 20px 20px 50px;
  background: linear-gradient(60deg, #fff, #e6e6e5);
  border: 1px solid rgb(181, 181, 181, 0.3);
  position: relative;
  border-radius: 3px;
  margin: 30px 20px;
}
.article__content ul::before,
.article__content ol::before {
  content: '';
  inset: 3px;
  padding: 10px;
  background: linear-gradient(60deg, #fff, #e6e6e5);
  border: 1px solid rgb(181, 181, 181, 0.8);
  position: absolute;
  z-index: 0;
}
.article__content ul li,
.article__content ol li {
  position: relative;
  list-style-type: disc;
  padding-right: 7px;
  z-index: 1;
}
/* ------------------------------
   5.5 Breadcrumb
------------------------------ */
.breadcrumb {
  margin: 0 0 16px;
  font-size: 14px;
}
.breadcrumb__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}
.breadcrumb__item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.breadcrumb__item + .breadcrumb__item::before {
  content: '›';
  opacity: 0.5;
}
.breadcrumb a {
  text-decoration: none;
  color: inherit;
}
.breadcrumb a:hover {
  opacity: 0.75;
}
.breadcrumb__item.is-current {
  color: rgba(0, 0, 0, 0.75);
}
/* ------------------------------
   5.6 Blog CTA / Blogcards
------------------------------ */
/* --- CTA -----  */
.articleCta {
  display: flex;
  justify-content: center;
  margin: 50px 0;
}
.articleCtaBtn {
  width: 500px;
  height: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  border-radius: 15px;
  text-decoration: none;
  color: #fff;
  background: rgba(1, 78, 57, 0.15);
  position: relative;
  box-shadow: 3px 3px 7px rgba(14, 75, 8, 0.2);
}
.articleCtaBtn::before {
  content: '';
  position: absolute;
  inset: 10px;
  background: rgba(1, 78, 57, 0.34);
  border-radius: 10px;
}
.ctaText {
  position: relative;
  z-index: 2;
  text-align: left;
}
.ctaMain {
  display: block;
  font-size: var(--fs-ctaBtn);
  font-weight: 600;
  text-shadow: 0 3px 6px rgba(0, 0, 0, 0.5);
  line-height: 1.2;
}
.ctaMain .ctaMainAdj {
  letter-spacing: -0.02em;
}
.ctaMain .ctaMainAdjS {
  font-size: 0.82em;
}
.ctaSub {
  display: block;
  font-size: var(--fs-ctaBtnSm);
  opacity: 0.9;
  text-shadow: 0 3px 6px rgba(0, 0, 0, 0.5);
}
.ctaIcon {
  position: relative;
  z-index: 2;
  width: 40px;
  flex: 0 0 40px;
}
.ctaIcon img {
  display: block;
  width: 100%;
  height: auto;
  margin: 0.5em auto;
}
.articleCtaBtn {
  transition: all 0.25s ease;
}
.articleCtaBtn:hover {
  transform: translateY(-3px);
  box-shadow: 6px 6px 14px rgba(14, 75, 8, 0.3);
}
/* ----- Blogcard -------- */
.blogCard {
  position: relative;
  width: min(700px, 100%);
  padding: 15px;
  border-radius: 8px;
  background: linear-gradient(to bottom, #fafafa, #efeae4);
  box-shadow: 0 3px 20px rgba(0, 0, 0, 0.3);
  box-sizing: border-box;
  margin: 50px auto;
}
.blogCard__content {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 15px;
}
.blogCard__text {
  flex: 1;
}
.blogCard__title {
  font-size: 18px;
  color: #014e39;
  font-weight: 700;
  margin: 0 0 10px;
  line-height: 1.4;
}
.blogCard__excerpt {
  font-size: 14px;
  line-height: 1.7;
  margin-bottom: 10px;
}
.blogCard__meta {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.blogCard__cat {
  font-size: 13px;
  color: #014e39;
  text-decoration: underline;
}
.blogCard__thumb {
  width: 210px;
  aspect-ratio: 16/9;
  border-radius: 5px;
  overflow: hidden;
  box-shadow: 0 3px 7px rgba(0, 0, 0, 0.3);
  margin-top: 15px;
}
.blogCard__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.blogCard__date {
  position: absolute;
  top: 10px;
  right: 18px;
  font-size: 12px;
  color: #014e39;
}
.blogCard {
  transition: 0.25s;
}
.blogCard:hover {
  transform: translateY(-3px);
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.18);
}
/* ------------------------------
   5.7 Blog: Related Posts
------------------------------ */
.relatedCard__excerpt {
  display: none;
}
.relatedArticles__box {
  background: rgba(255, 255, 255, 0.4);
  padding: 50px 40px;
  border-radius: 3px;
  margin-top: 100px;
}
.relatedArticles__title {
  color: var(--inkGr);
  font-size: var(--fs-headlineS);
  margin-bottom: 30px;
  font-weight: 600;
}
.relatedArticles__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.relatedCard {
  background: #fff;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 3px 3px 20px rgba(0, 0, 0, 0.2);
  transition: 0.25s;
}
.relatedCard:hover {
  transform: translateY(-4px);
  box-shadow: 5px 10px 24px rgba(0, 0, 0, 0.3);
}
.relatedCard__link {
  display: block;
  text-decoration: none;
  color: inherit;
}
.relatedCard__thumb img {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
}
.relatedCard__body {
  display: flex;
  flex-direction: column;
  padding: 10px 10px 12px;
}
.relatedCard__title {
  font-size: 14px;
  line-height: 1.4;
  margin-bottom: 5px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.relatedCard__date {
  font-size: 12px;
  color: var(--inkGr);
  margin-top: auto;
}
/*-------------------------*/
/*　Key Takeaways/AI Summary Box  */
/* ------------------------ */
.ai-summary {
  background: rgba(251, 255, 247, 0.68);
  border: 1px solid rgba(43, 38, 34, 0.08);
  border-radius: 5px;
  padding: 18px 18px 20px;
  margin: 50px 0 50px;
  box-shadow: 0 3px 12px rgba(0, 0, 0, 0.5);
}
.ai-summary p {
  margin: 0;
  margin-bottom: 1.03em;
}
.ai-definition {
  font-size: var(--fs-small);
  line-height: 1.6;
  margin-bottom: 16px !important;
}
.ai-conclusion {
  font-size: var(--fs-body);
  line-height: 1.7;
  font-weight: 600;
  color: var(--inkGr);
  border-left: 1.5px solid rgba(36, 67, 59, 0.7);
  padding-left: 16px;
  margin-left: 20px;
}
/* ------------------------------
   5.8 Blog Footer　(part in LP)
------------------------------ */
#page-top {
  position: fixed;
  right: 20px;
  bottom: 200px;
  z-index: 9999;
  margin: 0;
  width: fit-content;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease;
  display: inline-block;
  color: var(--ink);
  font-size: 13px;
  border-bottom: 1px solid rgba(43, 38, 34, 0.35);
  padding-bottom: 3px;
  white-space: nowrap;
}
#page-top.is-show {
  opacity: 1;
  visibility: visible;
}
.lpFooter__catList_wrap a {
  color: #fff;
}
.footerCategoryList {
  padding-left: 15px;
  margin: 0;
}
.footerCategoryList li a {
  color: #fff;
  font-size: clamp(14px, 1.36vw, 17px);
}
/* ==============================
   6. LP
============================== */
.bodyBcg {
  background: var(--bcgTexture);
  background-repeat: repeat-y;
  background-size: 100%, auto;
}
/* ------------------------------
   6.1 LP Header Bar
   （ブログヘッダーバーと共通）
------------------------------ */
/* Outer Grid */
.hero__bar {
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-areas: 'logo contact';
  align-items: flex-start;
  gap: 20px;
  padding: 10px 0;
  min-height: 75px;
  box-sizing: border-box;
}
.hero,
.blog__header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1000;
  background: linear-gradient(30deg, #000000, #002b02);
}
.hero {
  max-width: 1920px;
  margin: 0 auto;
  left: 50%;
  transform: translateX(-50%);
}
.hero .hero__bar_wrap {
  margin: 0 10px;
  width: calc(100% - 20px);
  box-sizing: border-box;
}
.blog__header .hero__bar_wrap {
  width: min(1100px, 96%);
  margin: 0 auto;
}
.logo_wrap {
  grid-area: logo;
  min-width: 0;
}
.hero__contact_wrap {
  grid-area: contact;
  min-width: 0;
}
/* Logo*/
.hero__logos {
  display: flex;
  gap: 10px;
  align-items: center;
}
.hero__logos a {
  display: block;
  width: 30%;
  max-width: 140px;
  min-width: 80px;
}
.hero__logo {
  display: block;
  width: 100%;
  height: auto;
}
.logo_wrap p {
  margin: 3px 0 0;
  font-size: clamp(1.2rem, 1.2vw, 1.4rem);
  line-height: 1.4;
  color: #fff;
  white-space: nowrap;
}
/* Right */
.blog__header .hero__contact_wrap {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-areas:
    'buttons'
    'tel';
  justify-items: end;
  row-gap: 4px;
}
.lp_hero_contact {
  display: grid !important;
  grid-template-columns: 70px 0.7fr 1fr 0.8fr;
  grid-template-areas: 'free heroTel line form';
  justify-items: center;
  gap: 5px;
  min-width: 0;
}
.lp_hero_contact > * {
  min-width: 0;
}
.lp_hero_contact .hero_contact__lead {
  grid-area: free;
  color: #fff;
  font-size: clamp(1.4rem, 1.32vw, 1.6rem);
  padding: 5px 10px;
  background: var(--gradientOrg_down);
  border-radius: 50%;
  line-height: 1.2;
  min-width: 0;
  max-height: 40px;
}
.lp_hero_contact .hero_tel {
  grid-area: heroTel;
  color: #fff;
  font-size: clamp(1.5rem, 1.49vw, 1.9rem);
  line-height: 1.2;
}
.lp_hero_contact .hero_tel span {
  font-size: clamp(1.3rem, 1.23vw, 1.5rem);
}
.hero__telIcon {
  display: none;
}
.hero__mailWrap {
  grid-area: form;
  line-height: 1;
  text-align: right;
  min-width: 0;
}
.sp__line_notice {
  display: none;
}
.hero_mailNote {
  color: #fff;
  font-size: 12px;
  padding: 0;
  text-align: center;
  display: inline-block;
}
.hero__LineWrap {
  grid-area: line;
  min-width: 0;
  text-align: center;
}
.lp_hero_contact .hero_form {
  color: #fff;
  font-weight: 400;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: clamp(1.6rem, 1.49vw, 1.8rem);
  padding: 4px 5px;
  background: var(--gradientOrg_down);
  border-radius: 30px;
  white-space: nowrap;
  box-sizing: border-box;
  height: 40px;
}
.lp_hero_contact .hero_Line {
  display: flex;
  gap: 2px;
  justify-content: center;
  align-items: center;
  padding: 4px 5px;
  background: linear-gradient(#00b74b, #9ad7b4, #00b249);
  border-radius: 30px;
  white-space: nowrap;
  box-sizing: border-box;
  height: 40px;
  margin-right: 0;
}
.hero__LineIcon {
  width: 17%;
  height: auto;
  display: block;
  max-width: 36px;
  min-width: 25px;
}
.hero__LineTxt {
  width: 60%;
  height: auto;
  display: block;
  max-width: 120px;
  min-width: 90px;
}
.hero_contact,
.blog_hero_contact {
  grid-area: buttons;
  display: flex;
  gap: 10px;
  align-items: flex-start;
  white-space: nowrap;
}
.blog__header_tel {
  grid-area: tel;
  color: #fff;
  text-decoration: none;
  line-height: 1.3;
  white-space: nowrap;
  font-size: var(--fs-small);
  padding: 3px 0;
  text-align: right;
  white-space: nowrap;
  display: flex;
  justify-content: flex-end;
  height: 40px;
}
.hero_formSP {
  display: none;
}
.blogListBtn a,
.lpBtn a {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 3px;
  color: #fff;
  white-space: nowrap;
  font-size: clamp(14px, 1.36vw, 17px);
  transform: translateY(-1px);
}
.blogListBtn img,
.lpBtn img {
  display: block;
  width: 18px;
  height: auto;
}
.lpBtn a {
  text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.3);
  color: #fff;
}
.blogListBtn,
.lpBtn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 7px 16px;
  line-height: 1.4;
  border-radius: 30px;
  box-sizing: border-box;
}
.blogListBtn {
  background: var(--gradientSvr);
}
.lpBtn {
  background: var(--gradientOrg_down);
}
.blogListBtn a {
  color: inherit;
}
.blog_hero_contact img {
  width: auto;
  height: 20px;
  padding-right: 5px;
}
.blog main {
  padding-top: 120px;
}

/* ------------------------------
   6.2 LP Hero (main visual)
------------------------------ */
/* ========== Hero ========== */
.hero__img {
  background: url('img/IsansouzokuMainV.jpg') center/cover no-repeat;
  width: 100%;
  aspect-ratio: 384/277;
}
.hero__inner {
  padding: 150px 0 30px;
  position: relative;
}
.hero__kicker {
  font-size: clamp(2rem, 2.28vw, 3.2rem);
  margin-bottom: 30px;
  color: #fff;
  font-weight: 500;
  text-align: center;
  text-shadow: 3px 3px 10px rgba(0, 0, 0, 0.5);
  font-family: 'Zen Old Mincho', serif;
}
.hero__headlineFrame {
  margin: 0 auto;
  text-align: center;
  box-shadow: var(--boxShadow);
  position: relative;
  width: fit-content;
}
.hero__title {
  margin: 0;
  text-align: center;
  color: #fff;
  font-weight: 700;
  letter-spacing: -0.02em;
  font-size: clamp(30px, 2.53vw, 55px);
  line-height: 1.3;
  text-shadow: 3px 4px 8px rgba(0, 0, 0, 0.55);
  background-image: url('img/H1bcg.png');
  padding: 28px 45px;
  display: inline-block;
  background-size: 100% 100%;
  background-repeat: no-repeat;
}
.hero__em {
  font-size: clamp(45px, 3.42vw, 70px);
  letter-spacing: -0.2em;
  font-weight: 900;
  text-shadow: 3px 4px 10px rgba(0, 0, 0, 0.75);
}
.hero_roundBadges {
  position: absolute;
  width: 40%;
  max-width: 350px;
  min-width: 150px;
  left: 100%;
  bottom: -40%;
  transform: translateX(-50%);
}
.hero__worries {
  width: min(55%, 800px);
  margin-right: 5%;
  margin-left: auto;
  margin-top: 120px;
}
.miniRibbon {
  padding: 10px 0;
  line-height: 1.6;
  background: var(--gradientGr_down);
  font-weight: 400;
  border-radius: 3px;
  box-shadow: 0 10px 18px rgba(0, 0, 0, 0.25);
  color: #fff;
  box-sizing: border-box;
  text-align: center;
  font-size: var(--fs-headlineL);
  margin-bottom: 10px;
}
.checkList {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5px;
}
.checkList li {
  color: #fff;
  font-size: var(--fs-headlineS);
  background: rgba(0, 0, 0, 0.75);
  border: 2px solid #c7a154;
  position: relative;
  padding: 10px 10px 10px 40px;
  box-sizing: border-box;
  text-align: left;
  line-height: 1.7;
}
.checkList li::before {
  content: '✓';
  position: absolute;
  left: 10px;
  top: 10px;
  font-size: 0.8em;
  color: #fff;
  font-weight: 900;
}
.checkList li:last-child {
  position: relative;
  padding-right: 40px;
}
.checkList li:last-child::after {
  content: '';
  position: absolute;
  width: 30%;
  aspect-ratio: 1/1.5;
  background: url('img/mainv_man.png') no-repeat center;
  background-size: contain;
  right: -40px;
  bottom: -40px;
  filter: drop-shadow(0 3px 4px rgba(0, 0, 0, 0.2));
}
.summaryProfile {
  display: none;
}
.profile__text {
  width: min(42%, 600px);
  max-width: 600px;
  margin-top: 50px;
  margin-left: 30%;
  padding: 5px;
  box-shadow: var(--boxShadow);
  background: rgba(237, 233, 217, 0.8);
  border: 1px solid transparent;
  position: relative;
}
.profile__text::before {
  content: '';
  position: absolute;
  inset: 1px;
  border: 1px solid rgba(64, 76, 70, 0.4);
  pointer-events: none;
}
.profile__text p {
  padding: 12px;
  line-height: 1.4;
  margin: 0;
}
.profile__text p span {
  font-size: 1.2em;
  color: var(--inkGr);
  display: block;
  font-weight: 500;
  margin-bottom: 7px;
}
/* ------------------------------
   6.3 LP Sections
------------------------------ */
.profile__cap {
  margin-top: 0;
}
.profile__cap,
.subCap {
  background: rgba(3, 3, 3, 0.7);
  color: #fff;
  padding: 50px 0;
  /* margin-top: -30px; */
  margin-bottom: 180px;
  width: 100%;
  text-align: left;
  box-shadow: var(--boxShadow);
  box-sizing: border-box;
  position: relative;
}
.decDownArrow {
  position: absolute;
  left: 50%;
  bottom: -110px;
  transform: translateX(-50%);
  width: min(500px, 50%);
}
.subCap {
  background-image: url('img/subCapBcg.png');
  background-size: 100% 100%;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  margin-bottom: 250px;
}
.sub__cap {
  display: flex;
  justify-content: center;
  gap: 10px;
  width: min(1100px, 92%);
  align-items: center;
  margin: 0 auto;
}
.profile__lead span,
.subCap__lead span {
  font-weight: 700;
  color: var(--colorOrange);
  font-size: var(--fx-lpEmphasisXL);
}
.profile__lead,
.subCap__lead {
  font-size: var(--fx-lpEmphasis);
  padding: 0;
  width: min(1100px, 92%);
  margin: 0 auto;
  line-height: 1.9;
  text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.8);
}
.subCap__lead span {
  padding: 1px 8px;
  margin-right: 5px;
  margin-left: 5px;
  border: 1px solid #fff;
  white-space: nowrap;
}
.sub__cap img {
  width: min(430px, 26%);
}
/* 今お悩みの方 */
.existingConcerns {
  padding-bottom: 200px;
}
.concernsBcg {
  background-image: url('img/bcg_town.png');
  background-repeat: no-repeat;
  background-size: cover;
  background-position: bottom;
}
.concernsBcg h3 {
  margin-bottom: 100px;
  font-size: var(--fs-headlineM);
}
.concern__imgs {
  text-align: center;
  width: 50%;
  margin: 0 auto;
}
.concern__imgs img {
  margin-bottom: -50px;
}
.existingConcerns p {
  font-size: var(--fs-headlineM);
  text-align: center;
  padding-top: 100px;
  font-weight: 700;
}
/* Issues */
.secTitleWrap {
  position: relative;
  text-align: center;
  margin-bottom: 100px;
}
.sectionTitle {
  font-size: var(--fs-h2);
  font-weight: 600;
  color: var(--inkGr);
}
.secTitleWrap .deco {
  position: absolute;
  top: -100px;
  left: 50%;
  color: var(--inkGr);
  transform: translateX(-50%);
  opacity: 0.1;
  font-family: 'Libre Baskerville', serif;
  font-weight: 600;
}
.secTitleWrap .deco {
  font-size: clamp(35px, 4.39vw, 65px);
  white-space: nowrap;
  top: -90%;
}
.secTitleWrap img {
  position: absolute;
  bottom: -45px;
  opacity: 0.6;
  width: 50%;
  left: 50%;
  transform: translateX(-50%);
  box-shadow: 0 -10px 30px rgba(0, 0, 0, 0.1);
}
.issues .secTitleWrap h2 {
  position: relative;
  display: inline;
}
.issues .secTitleWrap h2::before {
  content: '';
  display: block;
  background: url('img/tatoeba.png') no-repeat center / contain;
  position: absolute;
  top: -65px;
  left: -60px;
  width: 30%;
  min-width: 100px;
  height: auto;
  aspect-ratio: 2/1;
}
/* *********************** */
/* こんな問題抱えていませんか？ */
/* grid */
.worries__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  align-items: stretch;
  width: min(1100px, 92%);
  margin: 0 auto 100px;
}
.worriesCol__head {
  margin-bottom: 30px;
}
.worriesCol__headText {
  margin: 0;
  text-align: center;
  font-weight: 700;
  line-height: 1;
}
/* cards */
.worryCard,
.worriesCol__head {
  padding: 15px;
  border: 5px solid transparent;
  margin-bottom: 20px;
  box-shadow: var(--boxShadow);
  display: flex;
  flex-direction: column;
}
.worriesCol--before .worryCard {
  background:
    linear-gradient(#fff, #fff) padding-box,
    var(--gradientGr_45deg) border-box;
}
.worriesCol--after .worryCard {
  background:
    linear-gradient(#fff, #fff) padding-box,
    var(--gradientGld_45deg) border-box;
}
.worriesCol--before .worriesCol__head {
  background:
    var(--gradientSvr) padding-box,
    var(--gradientGr_45deg) border-box;
}
.worriesCol--after .worriesCol__head {
  background:
    var(--gradientSvr) padding-box,
    var(--gradientGld_45deg) border-box;
}
.worryCard__title {
  margin: 0 0 10px;
  font-size: var(--fs-headlineS);
  font-weight: 700;
  line-height: 1.4;
  text-align: center;
}
.worryCard__text {
  margin: 0;
  font-size: var(--fs-standard);
  line-height: 1.8;
  color: rgba(0, 0, 0, 0.78);
}
.worryCard__illu {
  position: absolute;
  right: 0;
  bottom: 2px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: right bottom;
  opacity: 0.95;
  pointer-events: none;
}
.worriesCol--before .worryCard__illu {
  width: 25%;
  aspect-ratio: 2/1;
}
.worriesCol--after .worryCard__illu {
  width: 18%;
  aspect-ratio: 1/1;
}
.worryCard.w_illust {
  position: relative;
  padding-right: 50px;
}
.worryCard__illu--house {
  background-image: url('img/issues_house.png');
}
.worryCard__illu--man {
  background-image: url('img/issues_man.png');
}
/* Fujiyoshi img */
.worries__bottom {
  margin: 0 auto;
  margin-bottom: 150px;
  background: url(img/subCapBcg.png);
  background-size: 100% 100%;
}
.worries__bottom > .subCap {
  background: none;
}
.worriesMessage {
  width: min(1100px, 92%);
  display: grid;
  grid-template-columns: 1fr 0.3fr;
  padding: 18px 20px;
  gap: 20px;
  margin: 0 auto;
}
.worriesPhoto {
  margin: 0;
  text-align: right;
}
.worriesPhoto__img {
  height: auto;
  border-radius: 8px;
  display: inline-block;
}
/* ****************** */
/* Trusted Expertise */
.features__list {
  display: grid;
  width: min(1100px, 100%);
  gap: 40px;
  margin: 0 auto 200px;
}
/* カード */
.feature {
  position: relative;
  padding: 15px 50px 15px 30px;
  background: var(--gradientSvr);
  border: 3px solid #859c3d; /* 緑枠 */
  border-radius: 2px;
}
/* 左の番号 */
.feature__num {
  font-family: 'Libre Baskerville', serif;
  font-weight: 300;
  font-size: 60px;
  line-height: 1;
  color: #de8a03;
  position: absolute;
  left: 15px;
  top: -15px;
  text-shadow: 2px 3px 3px rgba(0, 0, 0, 0.2);
}
/* 見出し（緑の帯） */
.feature__head {
  margin: 0 auto 20px 40px;
  display: inline-block;
  padding: 7px 16px;
  background: #45761a;
  border: 1px solid #4d960e;
  color: #fff;
  border-radius: 2px;
  font-size: var(--fs-headlineS);
  line-height: 1;
}
.feature__bullets {
  margin: 0;
  padding-left: 1.2em;
}
.feature__bullets li {
  margin: 0 0 8px;
  line-height: 1.8;
  list-style-type: disc;
  font-size: var(--fs-standard);
}
.feature__note {
  margin: 10px 0 0;
  font-size: 13px;
  opacity: 0.8;
}
.feature__illu {
  position: absolute;
  bottom: 10px;
  right: 10px;
  max-width: 80px;
  width: min(8%, 75px);
}
.illustTomb {
  width: min(6.3%, 60px);
}
.blueHighlight {
  font-size: 1.05em;
  color: #033c99;
  font-weight: 600;
}
/* ************* */
/* 選ばれる理由 */
.reason__lead {
  font-size: var(--fs-headlineS);
  text-align: center;
  line-height: 2;
  width: min(1100px, 90%);
  margin: 0 auto 100px;
}
.reasonsBcgS {
  background: url(img/reasonsBcgS.png) no-repeat;
  background-size: 100% 100%;
  background-position-y: top 80px;
}
.reasonsBcg {
  background: url(img/reasonsBcg.png) no-repeat;
  background-size: 100% 100%;
  margin-bottom: 200px;
}
.reason__header {
  text-align: center;
  margin-bottom: 70px;
}
/* ---------- Circle points ---------- */
.reasonPoints {
  list-style: none;
  display: flex;
  justify-content: center;
  gap: 34px;
  padding: 0;
  margin: 0;
  flex-wrap: wrap;
  position: relative;
  z-index: 2;
  padding-bottom: 100px;
}
.reasonPoints__item {
  width: 14%;
  min-width: 140px;
  max-width: 180px;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  background: var(--gradientGr_radial);
  box-shadow: var(--boxShadow);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  position: relative;
  text-align: center;
  padding: 18px;
  box-sizing: border-box;
}
.reasonPoints__num,
.reasonDetail__num {
  position: absolute;
  text-shadow: 2px 3px 3px rgba(0, 0, 0, 0.2);
  font-family: 'Libre Baskerville', serif;
  font-weight: 300;
  font-size: 50px;
  line-height: 1;
  color: #de8a03;
}
.reasonPoints__num {
  top: -20px;
  left: 50%;
  transform: translate(-50%, 0);
}
.reasonDetail__num {
  top: 20px;
  left: 0;
}
.reasonPoints__text {
  margin: 0;
  font-size: var(--fs-standard);
  line-height: 1.4;
  font-weight: 400;
}
.reasonPoints__text span {
  font-weight: 700;
  font-size: 1.02em;
}
/* ---------- Detail area ---------- */
.reasonDetails {
  padding-bottom: 150px;
  width: min(1100px, 92%);
  margin: 0 auto;
}
.reasonDetail {
  position: relative;
  padding-bottom: 20px;
  padding-top: 30px;
}
.reasonDetail__body {
  position: relative;
}
.reasonDetail__list {
  margin: 0;
  padding-left: 1.4em;
}
.reasonDetail__list li {
  margin-bottom: 10px;
  font-size: var(--fs-standard);
  line-height: 1.9;
  margin-left: 40px;
  list-style-type: disc;
}
.reasonDivider {
  width: min(750px, 45%);
  height: 5px;
  margin-left: 50px;
}
.reasonDivider img {
  height: 100%;
  width: 100%;
}
.reasonDetail--hasPhoto {
  position: relative;
}
.reasonDetail__photo {
  position: absolute;
  width: 28%;
  max-width: 380px;
  right: 20px;
  bottom: 0;
}
/* -------Media ---------- */
.media {
  padding-bottom: 150px;
  width: min(1300px, 100%);
  margin: 0 auto;
}
.mediaBox {
  position: relative;
  width: min(1100px, 92%);
  margin: 0 auto;
  padding: 50px 4%;
  border: 3px solid #859c3d;
  background: url('img/mediaBcg.png') center/cover no-repeat;
  box-shadow: var(--boxShadow);
}
.mediaTitle {
  margin: 0;
  font-size: var(--fs-headlineM);
}
.media_title_wrap {
  display: inline-flex;
  justify-content: flex-start;
  align-items: flex-end;
  position: relative;
  margin-top: -140px;
  left: -20px;
}
.mediaTitle__icon {
  width: min(220px, 40%);
  margin-left: -16px;
  transform: translateY(18px);
}
/* lead */
.mediaLead {
  margin-bottom: 40px;
  font-size: var(--fs-headlineS);
  margin-top: 50px;
}
.mediaLead .accent {
  color: #ff7a00;
  font-weight: 700;
  font-size: 1.03em;
}
/* layout */
.mediaContent {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 40px;
}
/* left list */
.mediaList {
  display: flex;
  flex-direction: column;
  gap: 30px;
}
.mediaItem {
  display: flex;
  gap: 20px;
  align-items: flex-start;
}
.mediaLabel {
  border: 2px solid #c7a154;
  padding: 5px 20px;
  font-weight: 500;
  background: rgba(255, 255, 255, 0.8);
  font-size: var(--fs-headlineS);
  white-space: nowrap;
}
.mediaText {
  line-height: 1.8;
  font-size: var(--fs-standard);
}
/* photo */
.mediaPhoto img {
  width: 260px;
  height: auto;
}
/* ***** Testimonial ***** */
.testimonialBcg {
  background: linear-gradient(
    to bottom,
    rgba(255, 253, 246, 0.5),
    rgb(238, 237, 220)
  );
  padding-top: 200px;
  padding-bottom: 100px;
  margin-top: -70px;
}
/* ---- top lead --- */
.voiceLead {
  text-align: center;
  margin-bottom: 60px;
  padding-top: 10px;
}
.voicelead_wrap {
  width: min(1100px, 100%);
  position: relative;
  margin: 0 auto;
}
.voiceLead__photo {
  position: absolute;
  top: -50px;
  left: 60px;
  margin: 0;
  width: 15%;
  min-width: 100px;
}
.voiceLead__text p {
  margin: 0;
  font-size: var(--fs-headlineS);
  line-height: 2;
}
/* ---------- cards ---------- */
.voiceCards {
  display: grid;
  gap: 44px;
  margin-bottom: 90px;
  width: min(1100px, 92%);
  margin: 0 auto 150px;
}
.voiceCard {
  display: grid;
  grid-template-columns: 1fr 180px;
  align-items: center;
  gap: 24px;
  padding: 36px 36px 28px;
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.06);
  box-shadow:
    0 6px 18px rgba(0, 0, 0, 0.1),
    inset 0 6px 25px rgba(0, 0, 0, 0.1);
}
.voiceCard__label {
  margin: 0 0 20px;
  font-size: 16px;
}
.voiceCard__titl.feature__head {
  margin-left: 0 !important;
}
.voiceCard__text {
  margin: 0 0 12px;
  font-size: var(--fs-standard);
  line-height: 1.7;
  font-family: 'Zen Old Mincho', serif;
  letter-spacing: normal;
}
.voiceCard__meta {
  margin: 0;
  text-align: right;
  font-size: 14px;
}
.voiceCard__illu {
  margin: 0;
  text-align: right;
  width: min(80%, 150px);
  min-width: 70px;
}
.voicecard__title.feature__head {
  margin-left: 0;
}

/* ---------- bottom copy ---------- */
.voiceBottom {
  text-align: center;
}
.voiceBottom__text {
  margin: 0 0 36px;
  font-size: var(--fx-lpEmphasis);
  line-height: 2;
}
.voiceBottom__text span {
  color: var(--colorOrange);
  font-weight: 700;
  text-shadow: 2px 2px 3px rgba(255, 255, 255, 1);
}
.voiceBottom__ornament img {
  width: min(500px, 50%);
  height: auto;
  display: inline-block;
  margin-bottom: 100px;
}
/* --------- service recap ------ */
.serviceRecap {
  margin-bottom: 200px;
}
.serviceSummary__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  width: min(1100px, 100%);
  margin: 0 auto;
}
.serviceCard {
  position: relative;
  min-height: 150px;
  padding: 20px 20px 30px;
  text-align: center;
  border: 8px solid transparent;
  background:
    url('img/bcg_LightReflection.png') padding-box,
    linear-gradient(#fff, #fff) padding-box,
    var(--gradientGr_45deg) border-box;
  box-shadow: var(--boxShadow);
  overflow: hidden;
  pointer-events: none;
}
.serviceCard__text {
  margin: 0;
  font-size: var(--fs-standard);
  line-height: 1.8;
}
.serviceCard > .feature__head {
  margin-left: 0 !important;
}

/* ------------------------------
   6.4 LP CTA / Sticky CTA
------------------------------ */
/* --- Sticky CTAはブログと共有　ーーーー */
.cta {
  margin-bottom: 200px;
  width: min(1000px, 90%);
  margin: 0 auto 180px;
}
.cta1 h2 {
  display: none;
}
.cta1 .ctaForm,
.cta2 .ctaForm,
.cta3 .ctaForm,
.cta4 .ctaForm {
  display: none;
}
.ctaItem_wrap {
  display: flex;
  flex-direction: column;
  margin-top: -40px;
}
.cta3.ctaItem_wrap {
  flex-direction: column-reverse;
}
.ctaWrap {
  position: relative;
  background: var(--gradientGrCta_45deg);
  box-shadow: var(--boxShadow);
  padding: 30px;
  text-align: center;
  border-radius: 8px;
}
.ctaWrap::before {
  content: '';
  position: absolute;
  inset: 15px;
  border: 1px solid #707070;
  pointer-events: none;
  border-radius: 4px;
  z-index: 10;
}
.ctaGoldRibbon {
  position: relative;
  width: min(690px, 55%);
  display: inline-block;
  margin-top: -13%;
  text-align: center;
  margin-bottom: 70px;
  z-index: 20;
}
.cta__desc {
  font-size: var(--fs-headlineS);
  text-align: center;
  line-height: 1.7;
  padding: 10px 20px;
  background: rgba(255, 255, 255, 0.25);
  width: min(1100px, 90%);
  margin: 0 auto 40px;
}
.cta__title {
  font-size: var(--fs-headlineM);
  font-weight: 500 !important;
  margin-bottom: 80px;
  margin-top: -30px;
}
.ctaBadges {
  display: flex;
  justify-content: center;
  gap: 25px;
  align-items: center;
  margin-bottom: 50px;
  font-size: var(--fs-standard);
}
.ctaBadges span {
  padding: 2px 10px;
  background: var(--gradientSvr);
  border-radius: 7px;
  line-height: 1.7;
  border: 1px solid rgba(0, 0, 0, 0.2);
  box-shadow: 3px 3px 10px rgba(0, 0, 0, 0.2);
}
.ctaWrap small {
  display: flex;
  justify-content: center;
  gap: 10px;
  align-items: center;
  line-height: 1;
}
.ctaWrap small img {
  width: 30px;
  height: auto;
}
/* -------- Hover Animation --- */
.cta__btn,
.lpFooterCta__btn {
  display: inline-block;
  transition:
    transform 0.35s ease,
    opacity 0.35s ease,
    box-shadow 0.35s ease;
}
.cta__btn img,
.lpFooterCta__btn img {
  display: block;
  transition: filter 0.35s ease;
}
@media (hover: hover) {
  .cta__btn:hover {
    transform: translateY(-6px);
    opacity: 0.9;
  }
  .cta__btn:hover img {
    filter: drop-shadow(0 10px 14px rgba(0, 0, 0, 0.35));
  }
}
@media (hover: hover) {
  .lpFooterCta__btn:hover {
    transform: scale(0.95);
    opacity: 0.9;
  }
  .lpFooterCta__btn:hover img {
    filter: drop-shadow(0 10px 14px rgba(0, 0, 0, 0.95));
  }
}
.cta__btn,
.lpFooterCta__btn {
  will-change: transform;
}
.cta__btn:active {
  transform: translateY(-2px);
}

/* ---- btn ------ */
.ctaBtnWrap {
  display: grid;
  grid-template-columns: repeat(2, 47%);
  justify-content: center;
  gap: 30px;
  margin: 0 auto 50px;
  width: min(800px, 80%);
}
.cta3 .ctaForm,
.cta4 .ctaForm {
  grid-column: 1/-1;
  width: 47%;
  justify-self: center;
}
/* ------------------------------
   6.5 LP Footer
------------------------------ */
.footerBcg {
  background: url('img/bcg_footer.jpg') center / cover no-repeat;
  padding-top: 70px;
  padding-bottom: 30px;
}
.lpFooter__head {
  text-align: center;
  width: min(700px, 92%);
  margin: 0 auto 24px;
}
.lpFooter__logos {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 18px;
  margin-bottom: 10px;
}
.lpFooter__logos a {
  width: 25%;
  max-width: 150px;
  min-width: 100px;
}
.lpFooter__logo {
  width: 100%;
  height: auto;
  /* height: 40px; */
  display: block;
}
.lpFooter p {
  color: #fff;
}
.lpFooter__sub {
  margin: 0 0 50px;
  font-size: var(--fs-body);
}
.lpFooter__lead {
  margin: 0;
  font-size: var(--fs-standard);
  line-height: 1.6;
}
.lpFooter__divider {
  height: 1px;
  width: 90%;
  background: rgba(255, 255, 255, 0.75);
  margin: 30px auto 50px;
}
/* main area */
.lpFooter__main,
.blogFooter__main {
  display: grid;
  grid-template-columns: 1fr 1.4fr 290px;
  gap: 32px;
  justify-content: center;
  align-items: start;
  width: min(900px, 92%);
  margin: 0 auto;
}
/* title boxes */
.lpFooter__titleBox,
.blogFooter__titleBox {
  display: inline-block;
  margin: 0 0 16px;
  padding: 5px 16px;
  border: 1px solid rgba(255, 255, 255, 0.8);
  font-size: var(--fs-standard);
  line-height: 1.2;
  font-weight: 600;
  color: #fff;
}
/* nav */
.lpFooterNav__list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.lpFooterNav__list li {
  margin-bottom: 8px;
  margin-left: 8px;
}
.lpFooterNav__list a {
  color: #fff;
  font-size: var(--fs-body);
}
/* offices */
.lpFooterOffice__block {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 10px;
  margin-bottom: 26px;
}
.lpFooterOffice__name {
  margin: 0;
  font-size: var(--fs-body);
  line-height: 1.1;
  font-weight: 500;
  color: #fff;
  border-right: 1px solid #fff;
}
.lpFooterOffice__body {
  padding-left: 10px;
}
.lpFooterOffice__body p {
  margin: 0 0 10px;
  font-size: clamp(14px, 1.36vw, 17px);
  line-height: 1.7;
  color: #fff;
}
.lpFooterOffice__body a {
  color: #fff;
}
.lpFooterOffice__btn {
  display: inline-block;
  min-width: 60px;
  padding: 3px 12px;
  border-radius: 999px;
  background: #fff;
  text-decoration: none;
  font-size: var(--fs-small);
  line-height: 1.3;
  color: var(--ink) !important;
  text-align: center;
}
/* CTA buttons */
.lpFooterCta {
  display: flex;
  flex-direction: column;
  gap: 18px;
  align-items: flex-end;
}
.lpFooterCta__btn {
  display: block;
  width: min(290px, 100%);
}
.lpFooterCta__btn img {
  height: auto;
  display: block;
}
.lpFooterCta .lpFooterCta__btn--form {
  display: none;
}

/* copy */
.lpFooter__copy {
  margin: 34px 0 0;
  text-align: center;
  font-size: 1.2rem;
  color: rgba(255, 255, 255, 0.88);
}
/* ==============================
   7. Others
============================== */
/* page.php */
.page-main,
.error404Page {
  padding-top: 120px;
  margin-bottom: 150px;
}
.privacy-policy h5 {
  margin-top: 30px !important;
}
.error404__btnWrap {
  margin-top: 30px;
  margin-bottom: 50px;
}
.error404__btnWrap a {
  padding: 5px 10px;
  background: var(--gradientSvr);
  font-size: var(--fs-body);
  margin: 20px;
  display: inline-block;
  border-radius: 30px;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.3);
}
/* ====================================
***************************************
   8. Responsive (ONLY here)
***************************************   
====================================== */
/* ==============================
   @ Media < 1440px
============================== */
@media (max-width: 1440px) {
  .hero__title {
    font-size: clamp(35px, 3.17vw, 43px);
    padding: 23px 40px;
  }
  .hero__em {
    font-size: clamp(40px, 3.73vw, 52px);
  }
  .hero__inner {
    padding-top: 120px;
  }
  .hero__worries {
    margin-top: 140px;
  }
  .hero__img {
    background: url('img/IsansouzokuMainV14.jpg') center/cover no-repeat;
    aspect-ratio: 14/15;
  }
  .profile__text {
    margin-top: 200px;
    width: 50%;
    margin-left: 40%;
  }
  .hero_roundBadges {
    width: 47%;
  }
}
/* ==============================
   @ Media < 1024px
============================== */
@media (max-width: 1024px) {
  .hero__title {
    font-size: clamp(30px, 3.91vw, 40px);
    padding: 23px 40px;
  }
  .hero__em {
    font-size: clamp(45px, 5.3vw, 50px);
  }
  .hero__inner {
    padding-top: 130px;
  }
  .hero__kicker {
    font-size: clamp(23px, 2.79vw, 27px);
  }
  .hero__worries {
    margin-top: 150px;
    width: 65%;
    padding: 10px 10px 10px 30px;
    margin-bottom: 50px;
  }
  .hero__img {
    background: url('img/IsansouzokuMainV10.jpg') center/cover no-repeat;
    aspect-ratio: 512/775;
  }
  .profile__text {
    margin-top: 0;
    width: 50%;
    margin-left: 45%;
  }
  .hero_roundBadges {
    width: 47%;
    min-width: 250px;
    bottom: -57%;
    left: 90%;
  }
  .checkList li:last-child::after {
    display: none;
  }
}
/* ==============================
   @ Media < 768px
============================== */
@media (max-width: 768px) {
  body {
    font-size: 1.8rem;
    padding-bottom: 60px;
  }
  .inner {
    margin-right: 5%;
    margin-left: 5%;
  }
  .wrapper {
    padding: 0 5%;
  }

  /* *********************** */
  /* 5. Blog  @media     */
  /************************  */
  strong {
    font-size: 1.01em;
    font-weight: 600;
  }
  .site-header__inner {
    padding: 10px 15px;
    flex-wrap: wrap;
    gap: 8px;
  }
  .breadcrumb__item {
    font-size: 13px;
    line-height: 1.3;
  }
  .article__title {
    font-size: 24px;
  }
  .article__meta {
    gap: 8px 12px;
  }
  /* footer */
  .footer_bcg {
    padding: 40px 0 24px;
    min-height: 800px;
  }
  .foot_cta img {
    height: 42px;
  }
  .blog-main {
    margin: 40px auto 0;
  }
  .article__title {
    font-size: 24px;
  }
  .article__content ul,
  .article__content ol {
    padding: 15px 10px 20px 35px;
    margin: 15px 0;
  }

  .article__content h3 {
    font-size: 18px;
  }
  .author-card {
    flex-direction: column;
    align-items: flex-start;
  }

  .hero_contact {
    flex-wrap: wrap;
  }
  .logo_wrap p {
    white-space: normal;
  }
  .blogListBtn {
    display: none;
  }
  .blog_hero_contact {
    justify-content: flex-end;
  }
  .blog__header_tel {
    font-size: 13px;
  }
  .blog-main,
  .posts_main {
    padding-top: 80px;
  }

  /* 　blog - Home @media --------*/
  .post-list {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .post-card__link {
    display: grid;
    grid-template-columns: 120px 1fr;
    gap: 12px;
    align-items: stretch;
  }
  .post-card__thumb {
    aspect-ratio: auto;
    height: 100%;
    min-height: 110px;
    border-radius: 0;
  }
  .post-card__body {
    display: flex;
    flex-direction: column;
    padding: 10px 12px 10px 0;
    min-width: 0;
  }
  .post-card__meta {
    order: 2;
    margin: 6px 0 0;
    font-size: 11px;
    gap: 8px;
    align-items: center;
  }
  .post-card__cats {
    justify-content: flex-start;
    gap: 4px;
  }
  .post-card__cat {
    font-size: 10px;
    padding: 2px 6px;
  }
  .post-card__title {
    margin: 0 0 6px;
    font-size: var(--fs-body);
    line-height: 1.45;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
  .post-card__excerpt {
    font-size: 12px;
    line-height: 1.6;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }

  /* ---- blogcard --- */
  .blogCard {
    width: 100%;
    padding: 15px;
  }
  .blogCard__content {
    display: grid;
    grid-template-columns: 1fr 180px;
    grid-template-areas:
      'title title'
      'excerpt thumb'
      'meta thumb';
    column-gap: 10px;
    align-items: start;
  }
  .blogCard__text {
    display: contents;
  }
  .blogCard__title {
    grid-area: title;
    font-size: 17px;
    margin: 15px 0 0;
  }

  .blogCard__excerpt {
    grid-area: excerpt;
    font-size: 13px;
    line-height: 1.7;
    margin: 0 0 8px;
  }
  .blogCard__meta {
    grid-area: meta;
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
  }

  .blogCard__thumb {
    grid-area: thumb;
    width: 180px;
    min-width: 120px;
    margin-top: 20px;
  }

  .blogCard__date {
    top: 8px;
    right: 15px;
    font-size: 12px;
  }
  /* ----- Related Posts ----- */
  .relatedCard__excerpt {
    display: block;
  }
  .relatedArticles__box {
    padding: 20px 0;
    background: none;
    margin: 70px auto 0;
    width: min(600px, 100%);
  }
  .relatedArticles__grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .relatedCard {
    border-radius: 6px;
    overflow: hidden;
  }
  .relatedCard__link {
    display: grid;
    grid-template-columns: 180px 1fr;
    gap: 12px;
    align-items: start;
  }
  .relatedCard__thumb {
    width: 100%;
    height: 100%;
  }
  .relatedCard__thumb img {
    height: 100%;
    display: block;
  }
  /* Right side */
  .relatedCard__body {
    display: grid;
    grid-template-columns: 1fr auto;
    padding: 10px 12px 10px 0;
    min-height: 100%;
    column-gap: 10px;
    align-items: start;
    row-gap: 6px;
    grid-template-areas:
      'title date'
      'excerpt excerpt';
    box-sizing: border-box;
  }
  .relatedCard__title {
    grid-area: title;
    font-size: 14px;
    font-weight: 600;
    line-height: 1.45;
    margin-bottom: 6px;
    /* -webkit-line-clamp: 2; */
  }
  .relatedCard__excerpt {
    grid-area: excerpt;
    font-size: 12px;
    line-height: 1.4;
    margin-bottom: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
  .relatedCard__date {
    grid-area: date;
    font-size: 11px;
    margin-top: 0;
    text-align: right;
    white-space: nowrap;
    color: var(--inkGr);
    font-weight: 500;
  }
  /***　Key Takeaways　  */
  .ai-conclusion {
    line-height: 1.6;
    font-weight: 500;
  }
  /* ----------------------
  Blog Footer
------------------------*/
  .footerBcg {
    background: url('img/bcg_footer.jpg') center / cover no-repeat;
    padding-top: 48px;
    padding-bottom: 24px;
  }
  .lpFooter .inner {
    width: min(92%, 580px);
    margin: 0 auto;
  }
  .lpFooter__head,
  .blogFooter__head {
    width: 100%;
    margin: 0 auto 18px;
    text-align: center;
  }
  .lpFooter__logos {
    gap: 12px;
    flex-wrap: nowrap;
  }
  .lpFooter__logos a {
    width: min(100px, 40%);
  }
  /* .lpFooter__logos .hero__logo{
  width: 100%;
} */
  .lpFooter__divider {
    width: 100%;
    margin: 30px auto 50px;
  }
  .lpFooter__main,
  .blogFooter__main {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-areas:
      'nav'
      'cta'
      'office';
    gap: 50px;
    width: 100%;
    margin: 0 auto 100px;
    text-align: center;
  }
  .blogFooterNav,
  .lpFooterOffice,
  .lpFooterCta {
    width: 100%;
  }
  .blogFooterNav {
    grid-area: nav;
  }
  .lpFooter__titleBox,
  .blogFooter__titleBox {
    display: inline-block;
    margin: 0 0 10px;
    padding: 5px 14px;
    font-size: 1.6rem;
  }
  .footerCategoryList {
    margin: 0;
    padding: 10px 20px 0;
    text-align: center;
  }
  .footerCategoryList li {
    display: inline-block;
    margin: 0 3px 0;
  }
  .footerCategoryList li a {
    font-size: 1.4rem;
    line-height: 1.2;
  }
  .catAll {
    display: block !important;
    margin: 0 0 7px;
  }
  .catAll a {
    font-weight: 500;
  }
  .lpFooterCta {
    gap: 12px;
    grid-area: cta;
  }
  .lpFooterCta__btn {
    display: block;
    width: min(300px, 80%);
    margin: 0 auto;
  }
  .lpFooterCta__btn img {
    display: block;
  }
  /* モバイルではLP導線だけ残す */
  .lpFooterCta__btn--tel,
  .lpFooterCta__btn--line {
    display: none;
  }
  .lpFooterOffice {
    width: auto;
    margin: 0 auto;
    grid-area: office;
  }
  .lpFooterOffice__block {
    display: grid;
    grid-template-columns: 52px 1fr;
    gap: 10px;
    margin-top: 10px;
    margin-bottom: 24px;
  }
  .lpFooterOffice__name {
    margin: 0;
    font-size: 1.5rem;
    line-height: 1.2;
    border-right: 1px solid #fff;
  }
  .lpFooterOffice__body {
    padding-left: 10px;
    text-align: left;
  }
  .lpFooterOffice__body p {
    margin: 0 0 8px;
    font-size: 1.35rem;
    line-height: 1.7;
  }
  .lpFooterOffice__btn {
    min-width: 54px;
    padding: 3px 10px;
    font-size: 1.1rem;
    line-height: 1.3;
  }

  .lpFooter__copy {
    margin: 28px 0 0;
    text-align: center;
    font-size: 1.1rem;
    line-height: 1.5;
  }
  /* ----------------------
  Sticky CTA
------------------------*/
  .stickyCta {
    position: fixed;
    bottom: 5px;
    left: 0;
    right: 0;
    bottom: 0;
    display: flex;
    gap: 5px;
    padding: 2px 3px;
    background: var(--inkGr);
    z-index: 999;
    box-sizing: border-box;
  }
  .stickyCta__btn {
    height: 54px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    text-decoration: none;
    box-sizing: border-box;
    padding: 5px;
    overflow: hidden;
    min-width: 0;
  }
  /* basisではなくflex比率で指定 */
  .stickyCta__btn--tel {
    flex: 53 1 0;
    background: linear-gradient(to bottom, #dcf4e9, #f4fffa, #acd0bf);
  }
  .stickyCta__btn--line {
    flex: 47 1 0;
    background: linear-gradient(to bottom, #cccccc, #ffffff, #c3c3c3);
  }
  /* 画像ラッパー */
  .stickyTelImg,
  .stickyLineImg {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
  }

  /* 画像は枠内に収める */
  .stickyCta__btn img {
    display: block;
    width: auto;
    height: auto;
    max-width: 100%;
    max-height: 100%;
  }
  /* ********************* */
  /* 6. LP　＠media */
  /* ******************* */
  /* ================
  common:
===================*/
  :root {
    /* Typography scale */
    --fs-h3: clamp(20px, 3.99vw, 25px);
  }
  h3 {
    line-height: 1.7;
  }

  /* hero bar */
  .lp_hero_contact .hero_contact__lead {
    display: none;
  }
  .lp_hero_contact {
    display: grid;
    grid-template-columns: 1fr 0.8fr;
    grid-template-areas:
      'line form'
      'heroTel heroTel';
    gap: 6px;
    justify-items: stretch;
    width: 100%;
  }
  .hero__LineWrap {
    grid-area: line;
  }
  .hero log_wrap p {
    white-space: no-wrap;
  }
  .hero__mailWrap {
    grid-area: form;
  }
  .lp_hero_contact .hero_Line {
    padding: 0;
    line-height: 1.2;
    width: 100%;
  }
  /* .hero__LineTxt img {
    min-width: 90px;
    width: 80%;
  }
  .hero__LineIcon img {
    width: 80%;
  } */
  .lp_hero_contact .hero_form {
    width: 100%;
    justify-content: center;
    font-size: 1.4rem;
    line-height: 1.2;
    padding: 0;
  }
  .lp_hero_contact .hero_tel {
    grid-area: heroTel;
    grid-column: 1/-1;
    width: 100%;
    text-align: center;
    font-size: 1.3rem;
    line-height: 1.25;
    white-space: normal;
    display: block;
    text-align: right !important;
  }
  .lp_hero_contact .hero_tel span {
    font-size: 1.05rem;
  }
  .hero__contact_wrap {
    width: 100%;
  }
  .lp_hero_contact .hero_tel br {
    display: none;
  }
  .lp_hero_contact .hero_tel {
    white-space: nowrap;
    font-size: 1.4rem;
  }
  .hero .logo_wrap p {
    display: block;
  }

  /*------ @medai768 Mainvisual ----- */
  .checkList li:last-child::after {
    display: none;
  }
  .hero__title {
    font-size: clamp(30px, 3.91vw, 40px);
    padding: 23px 30px;
  }
  .hero__em {
    font-size: clamp(45px, 5.3vw, 50px);
  }
  .hero__inner {
    padding-top: 110px;
  }
  .hero__kicker {
    font-size: clamp(23px, 2.79vw, 27px);
    text-shadow: 3px 3px 14px rgba(0, 0, 0, 0.9);
  }
  .hero__worries {
    width: 90%;
    padding: 0;
    margin: 130px auto 50px;
  }
  .hero__img {
    background: url('img/IsansouzokuMainV7.jpg') center/cover no-repeat;
    aspect-ratio: 384/850;
  }
  .standardProfile {
    display: none;
  }
  .summaryProfile {
    display: block;
  }
  .profile__text {
    margin-top: 0;
    width: 50%;
    margin-left: 45%;
  }
  .profile__text p {
    font-size: 1.6rem;
    padding: 7px;
  }
  .profile__text p span {
    font-size: 1.05em;
  }
  .hero_roundBadges {
    width: 47%;
    min-width: 250px;
    bottom: -57%;
    left: auto;
    right: 0;
    transform: translateX(0);
  }
  .miniRibbon {
    padding: 7px 0;
    font-size: var(--fs-headlineM);
  }
  .checkList {
    display: block;
    background: rgba(0, 0, 0, 0.75);
    border: 2px solid #c7a154;
    padding: 10px 5px;
  }
  .checkList li {
    border: none;
    background: transparent;
    padding: 5px 5px 5px 35px;
    font-size: clamp(16px, 3.01vw, 18px);
  }

  /*---- @768px　section items --- */
  .profile__lead,
  .subCap__lead {
    line-height: 1.7;
    width: 100%;
  }
  .profile__cap {
    margin-bottom: 100px;
    padding: 50px 20px;
  }
  .subCap {
    margin-bottom: 200px;
    padding: 20px;
  }
  .subCap__lead span {
    padding: 0;
    margin-right: 0;
    margin-left: 0;
    border: none;
    white-space: initial;
  }
  .concernsBcg {
    background-size: 140%;
  }
  .concern__imgs {
    width: 92%;
    max-width: 480px;
  }
  .existingConcerns {
    padding-bottom: 100px;
  }
  .existingConcerns h3 br {
    display: none;
  }
  .sub__cap {
    flex-direction: column;
  }
  .sub__cap img {
    width: 30%;
    min-width: 180px;
  }
  .decDownArrow {
    bottom: -100px;
  }
  .sectionTitle {
    font-size: clamp(24px, 5.2vw, 35px);
  }
  .secTitleWrap {
    margin-bottom: 70px !important;
  }
  .secTitleWrap .deco {
    font-size: clamp(28px, 5.59vw, 35px);
  }
  .issues .secTitleWrap h2::before {
    top: -50px;
    left: -30px;
  }
  .secTitleWrap img {
    bottom: -20px;
  }
  /* こんな問題抱えていませんか */
  .worries__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 30px;

    margin-bottom: 70px;
  }
  .worryCard,
  .worriesCol__head {
    padding: 10px;
    border: 3px solid transparent;
    margin-bottom: 5px;
  }
  .worries__bottom {
    width: 100%;
  }
  .worriesMessage {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .worriesPhoto__img {
    width: 50%;
    margin: 20px auto;
    display: block;
    max-width: 250px;
  }
  /* ---- 信頼のサービス ---- */

  .services .secTItleWrap .deco {
    top: -45%;
  }
  .feature {
    padding: 20px 55px 15px 20px;
  }
  .features__list {
    width: 100%;
    gap: 20px;
    margin-bottom: 150px;
  }
  .feature__illu {
    width: min(15%, 50px);
  }
  .feature__head {
    margin: 0 auto 15px 30px;
    line-height: 1.4;
  }
  .feature__num {
    font-size: 50px;
    top: 5px;
  }
  .feature__bullets li {
    line-height: 1.6;
  }
  /* ---- 選ばれる理由　ーーーー */
  .reasonDetail__list li {
    line-height: 1.6;
  }
  .reasonDetail__body .feature__head {
    margin: 0 auto 15px 40px;
  }
  .reasonDetails {
    width: auto;
    box-sizing: border-box;
  }
  .reasonDivider {
    width: min(600px, 70%);
    margin-left: 30px;
  }
  .reasonDetail__photo {
    width: 30%;
    max-width: 220px;
    right: 10px;
    bottom: -55%;
    min-width: 170px;
  }
  .reasonsBcg {
    margin-bottom: 120px;
  }
  .mediaBox {
    padding: 50px 4% 100px;
    background: url('img/mediaBcgSP.png');
  }
  .media {
    padding-bottom: 100px;
  }
  .media_title_wrap {
    margin-top: -90px;
    left: -20px;
  }
  .mediaTitle {
    margin: 0 !important;
  }
  .mediaTitle__icon {
    width: 30%;
    min-width: 100px;
    max-width: 150px;
    transform: translateY(0);
    left: 0;
  }
  .mediaItem {
    flex-direction: column;
  }
  .mediaContent {
    display: block;
    align-items: flex-start;
  }
  .mediaLabel {
    padding: 3px 16px;
    line-height: 1.4;
  }
  .mediaLead {
    padding-top: 30px;
    width: 90%;
    margin: 0 auto 50px;
    text-align: left;
  }
  .mediaItem:nth-of-type(2) .mediaText {
    padding-right: 20%;
  }
  .mediaText br {
    display: none;
  }
  .mediaPhoto {
    position: absolute;
    bottom: 40px;
    right: 10px;
    width: 30%;
  }
  .mediaList .mediaItem:last-of-type {
    padding-right: 100px;
  }
  .mediaList .mediaItem:last-of-type br {
    display: none;
  }
  /* testimonial */
  .voiceLead__text {
    padding: 0 30px 0 100px;
    text-align: left;
  }
  .voiceLead__text p br {
    display: none;
  }
  .voiceLead__photo {
    min-width: 60px;
    top: -20px;
    left: 10px;
  }
  .testimonialBcg {
    padding-top: 120px;
    margin-top: -110px;
    padding-bottom: 50px;
  }
  .voiceCards {
    width: 100%;
    margin-bottom: 100px;
  }
  .voiceCard {
    padding: 20px 15px 20px;
    display: grid;
    gap: 5px;
  }
  .voiceCard__text {
    margin: 0 5px 10px;
    line-height: 1.5;
  }
  .voiceCard__body {
    grid-column: 1/-1;
  }
  .voiceCard__meta {
    text-align: left;
  }
  .voiceCard__illu {
    grid-column: 1/-1;
    justify-self: flex-end;
    width: 25%;
    min-width: 40px;
    max-width: 100px;
    margin-top: -40px;
  }
  .voiceBottom__text {
    line-height: 1.7;
    text-align: left;
  }
  .voiceBottom__text br {
    display: none;
  }
  .serviceSummary__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
    width: min(500px, 95%);
  }
  .serviceCard {
    padding: 20px 10px 15px;
    min-height: auto;
    border: 3px solid transparent;
    background-size: cover;
  }
  .voiceBottom__ornament img {
    margin-bottom: 50px;
  }
  .serviceRecap {
    margin-bottom: 100px;
  }

  /* ---------------- 
  @media LP CTA
-------------------*/
  .cta1 {
    display: none;
  }
  .cta {
    margin: 9px auto 150px;
    width: min(680px, 100%);
  }
  .cta2 .ctaGoldRibbon,
  .cta3 .ctaGoldRibbon {
    display: none;
  }
  .cta2 .cta__title,
  .cta3 .cta__title {
    margin-top: 40px;
  }
  .ctaGoldRibbon {
    width: 80%;
    max-width: 400px;
    min-width: 300px;
    margin-top: -15%;
  }

  .cta__desc {
    text-align: left;
  }
  .cta__desc br {
    display: none;
  }
  .ctaWrap small {
    font-size: 11px;
  }
  .ctaWrap small img {
    width: 18px;
  }
  .ctaBtnWrap {
    grid-template-columns: 1fr;
    max-width: 320px;
    width: 60%;
    min-width: 280px;
  }
  .ctaBadges {
    display: grid;
    gap: 10px;
    grid-template-columns: 1fr 1fr;
    width: min(360px, 97%);
    margin: 0 auto 50px;
  }
  .ctaBadges span {
    font-size: 1.6rem;
  }
  .ctaBadges span:last-of-type {
    grid-column: 1 / -1; /* 2列分を使う */
    justify-self: center; /* 自分自身を中央 */
    width: fit-content; /* 中身幅で止める */
  }
}

/* ==============================
   @ Media < 480px
============================== */
@media (max-width: 480px) {
  /* common (to be adjusted) */
  p {
    font-size: 1.6rem;
  }

  h1 {
    font-size: 2.2rem;
    white-space: normal;
  }
  h2 {
    font-size: 2rem;
    font-weight: 700;
    white-space: normal;
  }
  h3 {
    font-size: 1.9rem;
    margin-bottom: 30px;
    white-space: normal;
  }
  .inner {
    margin: 0 10px;
  }
  .br_sp {
    display: block;
  }
  .br_tb {
    display: none;
  }
  .desktop {
    display: none !important;
  }
  .mobile {
    display: block;
  }
  /* -------------------------
           5. Blog @480
  -------------------------- */
  .hero__bar {
    padding: 7px 0;
    min-height: 75px;
    align-items: flex-start;
  }
  .logo_wrap p {
    display: none;
  }
  .gnavIcon {
    display: none;
  }
  .blogListBtn,
  .lpBtn {
    padding: 5px 7px;
    line-height: 1.2;
  }
  .blogListBtn a,
  .lpBtn a {
    font-size: 13px;
  }
  .hero__logos a {
    min-width: 80px;
  }
  .blog__header_tel {
    font-size: 11px;
  }
  .breadcrumb__item {
    font-size: 12px;
    line-height: 1.2;
  }
  /* Related posts */
  .relatedCard__link {
    display: grid;
    grid-template-columns: 120px 1fr;
    gap: 12px;
    align-items: start;
  }
  /* ctaBtn */
  .ctaMain {
    line-height: 1.15;
  }
  .ctaMain .ctaMainAdjS {
    font-size: 0.78em;
  }
  /* -------------------------
           6. LP @480
  -------------------------- */
  /*------ @medai480 Mainvisual ----- */
  .hero__em {
    font-size: clamp(40px, 7.54vw, 45px);
  }
  .hero__inner {
    padding-top: 100px;
  }
  .lp_hero_contact .hero_contact__lead {
    display: none;
  }
  .hero__telIcon {
    display: inline-grid;
    background: var(--gradientSvr);
    border-radius: 30px;
    box-sizing: border-box;
    height: 40px;
    padding: 4px 0;
    width: 100%;
    padding: 4px;
  }
  .hero__telIcon img {
    width: 50%;
    height: auto;
    margin: 0 auto;
  }
  .hero__telText {
    display: none;
  }
  .lp_hero_contact {
    display: grid;
    grid-template-columns: 50px 50px 50px;
    grid-template-areas:
      'heroTel line mail'
      'line_notice line_notice line_notice';
    gap: 6px;
    width: 166px;
    justify-content: start;
  }
  .hero_tel {
    grid-area: heroTel;
    grid-column: auto !important;
    text-align: auto;
  }
  .hero__LineWrap {
    grid-area: line;
  }
  .hero__mailWrap {
    grid-area: mail;
  }
  .hero__LineTxt {
    display: none;
  }
  .heroMail_txt {
    display: none;
  }
  .hero__contact_wrap {
    /* width: 100%; */
    display: flex;
    justify-content: flex-start;
  }
  .hero_mailNote {
    display: none;
  }
  .sp__line_notice {
    display: block;
    grid-area: line_notice;
    grid-column: 1/-1;
    text-align: right;
    font-size: 12px;
    color: #fff;
  }

  /* .hero_formPC {
    display: none;
  }
  .hero_formSP {
    display: block;
  } */
  .hero__kicker {
    font-size: clamp(21px, 4.08vw, 25px);
    line-height: 1.5;
  }
  .hero__worries {
    width: 90%;
    padding: 0;
    margin: 150px auto 70px;
  }
  .hero__img {
    background: url('img/IsansouzokuMainV4.jpg') center/cover no-repeat;
    aspect-ratio: 24/85;
  }
  .profile__text {
    margin-top: 80px;
    width: 55%;
    margin-left: auto;
    margin-right: 5%;
  }
  .profile__text p {
    font-size: 1.6rem;
  }
  .profile__text p span {
    font-size: 1.05em;
  }
  .hero_roundBadges {
    width: 50%;
    bottom: -50%;
  }
  .miniRibbon {
    padding: 9px 0;
    font-size: 21px;
  }
  .checkList {
    display: block;
    background: rgba(0, 0, 0, 0.75);
    border: 2px solid #c7a154;
  }
  .profile__lead,
  .subCap__lead {
    font-size: 1.8rem;
  }
  .profile__lead span,
  .subCap__lead span {
    font-size: 1.9rem;
  }
  .profile__cap,
  .subCap {
    padding: 15px;
  }
  /* testimonials */
  .testimonialBcg {
    padding-top: 100px;
    margin-top: -60px;
  }
  /* CTA */
  .ctaBadges span {
    font-size: 1.5rem !important;
  }
}
/* ==============================
   7. Balloon (Speech Bubble)
============================== */
.balloon-wrap {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin: 2em 0;
  max-width: 680px;
}

.balloon-icon {
  flex: 0 0 80px;
  width: 80px;
}

.balloon-icon img {
  width: 80px;
  height: auto;
  display: block;
  border-radius: 50%;
  border: 2px solid rgba(0, 0, 0, 0.1);
  object-fit: cover;
  background: #fff;
}

.balloon-body {
  position: relative;
  flex: 1;
  background: rgba(1, 78, 57, 0.08);
  border: 1px solid rgba(1, 78, 57, 0.18);
  border-radius: 14px;
  padding: 16px 20px;
  font-size: 17px;
  line-height: 1.8;
  color: #393939;
}
.balloon-body::before {
  content: '';
  position: absolute;
  top: 24px;
  left: -10px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 8px 10px 8px 0;
  border-color: transparent rgba(1, 78, 57, 0.18) transparent transparent;
}
.balloon-body::after {
  content: '';
  position: absolute;
  top: 25px;
  left: -8px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 7px 9px 7px 0;
  border-color: transparent rgba(1, 78, 57, 0.08) transparent transparent;
}
.balloon-body p {
  margin: 0;
}
.balloon-body p + p {
  margin-top: 0.6em;
}

/* --- Responsive: Balloon --- */
@media (max-width: 768px) {
  .balloon-wrap {
    gap: 12px;
  }
  .balloon-icon {
    flex: 0 0 60px;
    width: 60px;
  }
  .balloon-icon img {
    width: 60px;
  }
  .balloon-body {
    padding: 14px 16px;
    font-size: 16px;
  }
  .balloon-body::before {
    top: 18px;
  }
  .balloon-body::after {
    top: 19px;
  }
}

@media (max-width: 480px) {
  .balloon-icon {
    flex: 0 0 50px;
    width: 50px;
  }
  .balloon-icon img {
    width: 50px;
  }
  .balloon-body {
    padding: 12px 14px;
    font-size: 15px;
  }
}
