/*
 Theme Name:     Twenty Twenty-Five Child
 Theme URI:      https://example.com/twenty-twenty-five-child
 Description:    Twenty Twenty-Five の子テーマ
 Template:       twentytwentyfive
 Version:        1.0.0
 License:        GNU General Public License v2 or later
 License URI:    https://www.gnu.org/licenses/gpl-2.0.html
 Text Domain:    twentytwentyfive-child
*/

/* === Base Styles === */
body {
  font-family: "Noto Sans JP", sans-serif;
  background-color: #fdfdfd;
  color: #333;
  padding: 2rem;
  box-sizing: border-box;
}

h1, .entry-title {
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.4;
  margin-bottom: 1rem;
}

h2 {
  font-size: 1.8rem;
  font-weight: 600;
  line-height: 1.4;
  margin-top: 2rem;
  margin-bottom: 1rem;
}

p, .entry-content p {
  font-size: 1.1rem;
  line-height: 1.9;
  margin-bottom: 1.2rem;
}

/*section, .entry-content {
  padding: 2rem 1.5rem;
}*/
/* 余白を画面幅に応じて自動調整（小→大の滑らかな変化） */
:root{
  --pad-x: clamp(0.8rem, 4vw, 1.5rem);
  --pad-y: clamp(1rem, 5vw, 2rem);
}
/* 基本：セクション＆本文の余白 */
section,
.entry-content{
  padding: var(--pad-y) var(--pad-x);
  box-sizing: border-box;
}
/* 超小画面（～360px）ではさらにタイトに */
@media (max-width: 360px){
  section,
  .entry-content{
    padding: 0.75rem 0.9rem;
  }
}
/* “横いっぱい”のブロックは左右パディングを抑制（にじみ出し防止） */
.alignfull,
.wp-block-group.alignfull{
  padding-left: 0;
  padding-right: 0;
}
/* ワイド幅は中央寄せ＋最大幅で美しく */
.alignwide{
  max-width: min(1200px, 92vw);
  margin-inline: auto;
}
/* コンテンツ列の読みやすい最大幅（本文を締める） */
.entry-content > :where(p, h1, h2, h3, h4, h5, h6, ul, ol, figure, .wp-block-group, .wp-block-columns){
  max-width: min(960px, 100%);
  margin-left: auto;
  margin-right: auto;
}
/* 画像や動画のはみ出し防止（念のため） */
.entry-content img,
.entry-content video,
.entry-content svg{
  max-width: 100%;
  height: auto;
  display: block;
}
/* Gutenverse Post Block のサムネイルを見切れなしで表示 */
.guten-post-block .thumbnail-container{
  /* Gutenverse が作る固定比率を無効化 */
  aspect-ratio: auto !important;
  height: auto !important;
  /* はみ出し防止。グロー系のオーバーレイはそのまま重ねられます */
  overflow: visible !important;
}

.guten-post-block .thumbnail-container img.wp-post-image{
  position: static !important;       /* absolute指定を無効化 */
  display: block;
  width: 100% !important;
  height: auto !important;           /* 画像の高さを自動に */
  object-fit: contain !important;    /* 全体を収める（レターボックスOK） */
  object-position: center center !important;
}

.page-id-336 .entry-content.wp-block-post-content.has-global-padding.is-layout-constrained.wp-block-post-content-is-layout-constrained {
    padding-inline: 0;
}
.hotspot-content {
    padding: 4px;
}
.hotspots-container {
    margin-bottom: 80px;
}

.care-manager-card h3 a {
   --arrow-color:#f37b68;;
   position: relative;
   padding: 0 0.5em;
   color: var(--arrow-color);
   text-decoration: none;
}
.care-manager-card h3 a::before {
   border-bottom: 1px solid var(--arrow-color);
   border-right: 1px solid var(--arrow-color);
   bottom: 0;
   content: '';
   height: 12px;
   position: absolute;
   left: 0;
   transform: skewX(50deg);
   width: 100%;
   transition: all .3s;
}
.care-manager-card h3 a:hover::before {
   left: 10%; 
}
.care-manager-card .cm-thumb-link{ display:inline-block; }
.care-manager-card img{ display:block; margin:0 auto 1em; border-radius:50%; width:120px; height:120px; object-fit:cover; }

.single.single-care_manager main {
	margin-left: 8px;
	margin-right: 8px;
	background: #FBFAF3;
	padding: 12px;
}
.single.single-care_manager h2 {
    padding: 8px;
}
.single.single-care_manager .profile-section h2 {
	padding: 0;
}

.single.single-care_manager .entry-content {
	padding: 8px 16px;
}

/*投稿記事*/
 * .page-id-182 main {
	background: #fafafa;
}

/* ============= .h5-title（リンク見出し） ============= */
.h5-title {
  margin: .2em 0 1em;
  line-height: 1.3;
}

/* 見出しの中に a を入れて使う想定 */
.h5-title a{
  display: inline-flex;
  align-items: center;
  gap: .45em;
  font-weight: 700;
  color: var(--wp--preset--color--primary, #0a66c2);
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
  transition: color .2s ease, text-decoration-color .2s ease, transform .2s ease;
}
/* アイコン（↗ or →）で “リンク感” をプラス */
.h5-title a::after{
  content: "↗";
  font-size: .9em;
  transform: translateY(-1px);
  transition: transform .2s ease, opacity .2s ease;
  opacity: .9;
}
/* ホバー／フォーカスで色と動き */
.h5-title a:hover{
  color: var(--wp--preset--color--contrast, #111);
  text-decoration-color: currentColor;
}
.h5-title a:hover::after{
  transform: translate(3px,-3px);
}
.h5-title a:focus-visible{
  outline: 2px solid currentColor;
  outline-offset: 2px;
  border-radius: 4px;
  text-decoration: none; /* フォーカス時はアンダーラインを消して見やすく */
  box-shadow: 0 0 0 4px rgba(10,102,194,.18);
}
/* 訪問済みも色で分かるように（テーマ変数があれば自動で拾う） */
.h5-title a:visited{
  color: var(--wp--preset--color--accent-4, #6a3fb0);
}
/* アニメ苦手な人向けに配慮 */
@media (prefers-reduced-motion: reduce){
  .h5-title a, .h5-title a::after{ transition: none; }
}
/* ダークモードの色味微調整（任意） */
@media (prefers-color-scheme: dark){
  .h5-title a{ color: var(--wp--preset--color--primary, #7db0ff); }
  .h5-title a:visited{ color: var(--wp--preset--color--accent-4, #c7a7ff); }
}
/* ▼オプション：矢印を消したいときは .no-arrow を追加 */
.h5-title.no-arrow a::after{ content: none; }
/* ▼オプション：ブロック全幅をクリック可能にしたい場合 */
.h5-title.is-block a{ display: block; padding: .25em .35em; border-radius: 8px; }
.h5-title.is-block a:hover{ background: color-mix(in oklab, currentColor 10%, transparent); }



@media (max-width: 1024px){
  .no-side-pad{ padding-inline: 0 !important; }
}

@media (max-width: 768px) {
  .hide-on-mobile { display: none !important; }
.h1-logo {
 width: 40px;
}
.h1-title {
font-size: small;
}
.compact-gap {
    gap: .2em;
    flex-basis: 280px;
}
.single.single-care_manager main {
    margin-left: 0;
    margin-right: 0;
    background: #fff;
    padding: 0;
}
.single.single-care_manager h1.wp-block-post-title {
     text-align: center;
}   
.single.single-care_manager figure.wp-block-post-featured-image {
    margin-left: -8px !important;
    margin-right: -8px !important;
}
.guten-element.guten-wu2ydh{
    margin-right: 0 !important;
    margin-left: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    flex: 0 0 100% !important; /* 親がflexでも1列化 */
    box-sizing: border-box;
  }
h5.wp-block-gutenverse-heading.guten-element.guten-wu2ydh.__desktop-fadeInRight {
    text-align: center;
}
}


ul, ol {
  font-size: 1.05rem;
  line-height: 1.8;
  margin-bottom: 1.2rem;
}

.wp-caption-text {
  font-size: 0.95rem;
  color: #666;
}

/* === Member Profile === */
.member-profile {
  max-width: 960px;
  margin: 0 auto;
  padding: 2em;
  font-family: sans-serif;
  color: #333;
  background: #fff;
}

.member-profile a { 
  background: #0073aa;
  color: #fff;
  padding: 6px 12px;
  border-radius: 6px;
  text-decoration: none;
  display: inline-flex;
}

.member-profile a:hover {
  background: #005177;
}

.member-profile__header {
  display: flex;
  align-items: center;
  gap: 1.5em;
  margin-bottom: 2em;
  border-bottom: 1px solid #ddd;
  padding-bottom: 1em;
}

.member-profile__image {
  flex: 0 0 120px;
  max-width: 120px;
}
.member-profile__image{
  flex: 0 0 auto;
  width: 140px;
  display: grid;
  place-items: center;
}
.member-profile__image img {
  width: 100%;
  height: auto;
  border-radius: 0.5em;
  display: block;
}

.member-profile__text {
  flex: 1;
}

.member-profile__meta {
  font-size: 0.95rem;
  color: #666;
  margin-bottom: 0.3em;
}

.member-profile__name {
  font-size: 2.6rem;
  margin: 0;
  font-weight: bold;
}

.profile-section {
  margin-bottom: 1.5em;
}

.profile-section h3 {
  font-size: 1.2rem;
  margin-bottom: 0.5em;
  color: #444;
  border-left: 4px solid #3c82f6;
  padding-left: 0.5em;
}

.profile-section p { 
  font-size: 16px;
  color: #333;
  line-height: 2.0;
}

.btn-visit-site {
  display: inline-block;
  padding: 0.6em 1.2em;
  background-color: #3c82f6;
  color: #fff;
  text-decoration: none;
  border-radius: 0.4em;
  transition: background-color 0.3s ease;
}

.btn-visit-site:hover {
  background-color: #265dc1;
}

/* === List View === */
.person-list {
  max-width: 768px;
  margin: 0 auto;
  padding: 8px;
}

.person-block {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 20px;
  border: 1px solid #ededed;
  padding: 16px;
  background-color: #ffffff;
}

.person-image {
  flex: 0 0 auto;
  width: 160px;
}

.person-image img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 8px;
}

.person-text {
  flex: 1;
  min-width: 0;
}

.person-text h3,
.person-text p {
  font-size: initial;
}

/* === Hotspot === */
#hotspot-15 .hotspots-image-container {
  border-radius: 6px;
}

#hotspot-15 .hotspots-placeholder {
  padding: 0.2em !important;
  background: #fffbe7e6 !important;
}

#hotspot-15 .hotspot-title {
  margin-top: 0.4em;
}

/* === フォーム（検索など） === */
.searchandfilter {
  background-color: #ffffff;
  padding: 1.5rem 2rem;
  border-radius: 12px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
  max-width: 600px;
  margin: 0 auto;
}

.searchandfilter h4 {
  margin-bottom: 1rem;
  font-size: 1.25rem;
  font-weight: 600;
  color: #1f2937;
}

.searchandfilter p,
.searchandfilter li {
  display: inline-block;
  margin: 0.5rem 1rem 0.5rem 0;
  list-style: none;
}

.searchandfilter label {
  display: block;
  margin-bottom: 0.5rem;
  font-size: 0.95rem;
  color: #374151;
}

.searchandfilter input[type="text"],
.searchandfilter select {
  padding: 0.5rem 0.75rem;
  font-size: 0.95rem;
  border: 1px solid #d1d5db;
  border-radius: 8px;
  width: 100%;
  max-width: 250px;
  background-color: #ffffff;
  transition: border-color 0.2s ease;
}

.searchandfilter input[type="submit"] {
  background-color: #3b82f6;
  color: white;
  border: none;
  padding: 0.6rem 1.2rem;
  border-radius: 8px;
  font-size: 1rem;
  cursor: pointer;
  transition: background-color 0.3s ease;
}

.searchandfilter input[type="submit"]:hover {
  background-color: #2563eb;
}

/* === 都道府県セレクター === */
.care-manager-search-form {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1em;
  margin-bottom: 2em;
  background: #f9f9f9;
  padding: 1em 1.5em;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

.care-manager-search-form label {
  font-weight: bold;
  font-size: 1em;
  color: #333;
}

.care-manager-search-form select {
  flex: 1 1 auto;
  padding: 0.6em;
  font-size: 1em;
  border: 1px solid #ccc;
  border-radius: 6px;
  background: #fff;
}

.care-manager-search-form button {
  padding: 0.6em 1.2em;
  background-color: #007cba;
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: 1em;
  cursor: pointer;
}

.care-manager-search-form button:hover {
  background-color: #005f8d;
}

/* === ACF フロントエンドフォームのスタイル === */
.acf-form {
  max-width: 800px;
  margin: 2em auto;
  padding: 1.5em;
  background-color: #ffffff;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 2rem;
  color: #333;
}

/* フィールドグループのスタイル */
.acf-field {
  margin-bottom: 1.5em;
}

/* ラベルのスタイル */
.acf-label label {
  display: block;
  font-weight: bold;
  margin-bottom: 0.5em;
  font-size: 2rem;
  color: #1f2937;
}

/* 入力フィールドのスタイル */
.acf-input input[type="text"],
.acf-input input[type="email"],
.acf-input input[type="url"],
.acf-input input[type="number"],
.acf-input input[type="password"],
.acf-input select,
.acf-input textarea {
  width: 100%;
  padding: 0.75em 1em;
  border: 1px solid #d1d5db;
  border-radius: 6px;
  background-color: #f9fafb;
  font-size: 1.2rem !important;
  transition: border-color 0.2s ease;
}

.acf-input input[type="text"]:focus,
.acf-input input[type="email"]:focus,
.acf-input input[type="url"]:focus,
.acf-input input[type="number"]:focus,
.acf-input input[type="password"]:focus,
.acf-input select:focus,
.acf-input textarea:focus {
  border-color: #3b82f6;
  outline: none;
  background-color: #ffffff;
}

/* チェックボックスとラジオボタンのスタイル */
.acf-input input[type="checkbox"],
.acf-input input[type="radio"] {
  margin-right: 0.5em;
}
.acf-input ul,
.acf-input ol,
ul.acf-radio-list li,
ul.acf-checkbox-list li {
    font-size: 1.2rem !important;
    line-height: 1.4 !important;
    margin-bottom: 1.2rem;
}

/* === ACF画像フィールドのAdd Imageボタン強化 === */
.acf-field-image .acf-image-uploader .acf-button.button {
  display: inline-block;
  padding: 0.75em 1.5em;
  background-color: #10b981; /* エメラルドグリーン */
  color: #ffffff;
  border-radius: 6px;
  font-weight: bold;
  font-size: 1rem;
  text-align: center;
  border: none;
  cursor: pointer;
  transition: background-color 0.3s ease;
}

.acf-field-image .acf-image-uploader .acf-button.button:hover {
  background-color: #059669; /* 濃いめグリーン */
}

/* ボタンの中央寄せ */
.acf-field-image .acf-image-uploader {
  text-align: center;
}

/* 画像が選択された後のプレビューの余白 */
.acf-field-image .acf-image-uploader .image-wrap {
  margin-top: 1em;
}

/* テキストエリアのスタイル */
.acf-input textarea {
  min-height: 120px;
  resize: vertical;
}

/* 画像アップロードフィールドのスタイル */
.acf-field-image .acf-image-uploader {
  border: 2px dashed #d1d5db;
  padding: 1em;
  text-align: center;
  border-radius: 6px;
  background-color: #f9fafb;
}

/* 送信ボタンのスタイル */
.acf-form input[type="submit"] {
  background-color: #3b82f6;
  color: #ffffff;
  padding: 0.75em 1.5em;
  border: none;
  border-radius: 6px;
  font-size: 1rem;
  cursor: pointer;
  transition: background-color 0.3s ease;
}

.acf-form input[type="submit"]:hover {
  background-color: #2563eb;
}

/* =========================================================
   FEA Entry 共通デザイン（/case-study-entry/ & /care-manager-entry/）
   ========================================================= */
.is-fea-entry .frontend-form{
  max-width: 940px;
  margin: 0 auto;
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  padding: clamp(16px, 2.5vw, 28px);
  box-shadow: 0 6px 24px rgba(0,0,0,.05);
}

/* グリッド配置：PCは2カラム、モバイルは1カラム */
.is-fea-entry .acf-form-fields{
  display: grid;
  gap: 16px;
}
@media (min-width: 800px){
  .is-fea-entry .acf-form-fields{
    grid-template-columns: 1fr 1fr;
  }
}
/* 横幅いっぱいにしたい項目 */
.is-fea-entry .acf-field[data-type="textarea"],
.is-fea-entry .acf-field[data-type="wysiwyg"],
.is-fea-entry .acf-field[data-type="upload_image"],
.is-fea-entry .acf-field[data-type="checkbox"],
.is-fea-entry .acf-field[data-type="submit_button"]{
  grid-column: 1 / -1;
}

/* ラベル・必須表示 */
.is-fea-entry .acf-field .acf-label label{
  font-weight: 600;
  font-size: 0.98rem;
}
.is-fea-entry .acf-field.is-required .acf-label .acf-required{ display:none; }
.is-fea-entry .acf-field.is-required .acf-label label::after{
  content: "必須";
  display: inline-block;
  margin-left: .5em;
  padding: .12em .5em;
  font-size: .78rem;
  font-weight: 700;
  color: #fff;
  background: #ef4444;
  border-radius: 999px;
}

/* 入力UIの共通スタイル */
.is-fea-entry .acf-input input[type="text"],
.is-fea-entry .acf-input input[type="number"],
.is-fea-entry .acf-input input[type="search"],
.is-fea-entry .acf-input input[type="email"],
.is-fea-entry .acf-input select,
.is-fea-entry .acf-input textarea{
  width: 100%;
  border: 1px solid #d1d5db;
  border-radius: 10px;
  background: #fff;
  padding: 10px 12px;
  line-height: 1.5;
  font-size: 16px;
  transition: border-color .15s ease, box-shadow .15s ease, background-color .15s ease;
}
.is-fea-entry .acf-input textarea{ min-height: 150px; resize: vertical; }
.is-fea-entry .acf-input input:focus,
.is-fea-entry .acf-input select:focus,
.is-fea-entry .acf-input textarea:focus{
  outline: none;
  border-color: #60a5fa;
  box-shadow: 0 0 0 3px rgba(96,165,250,.25);
}

/* （企業事例のみの）匿名時グレーアウト用 */
.is-fea-entry .acf-input .is-disabled{
  background: #f3f4f6;
  color: #6b7280;
}

/* Select2（Post Object等） */
.is-fea-entry .select2-container{ width:100% !important; }
.is-fea-entry .select2-container .select2-selection--single{
  height: auto;
  min-height: 44px;
  border: 1px solid #d1d5db;
  border-radius: 10px;
  padding: 6px 38px 6px 12px;
}
.is-fea-entry .select2-selection__rendered{ line-height: 1.5 !important; }
.is-fea-entry .select2-selection__arrow{ right: 10px !important; top: 50% !important; transform: translateY(-50%); }

/* チェックボックス：タグ風 */
.is-fea-entry .acf-checkbox-list{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 8px;
}
.is-fea-entry .acf-checkbox-list li{ margin:0; }
.is-fea-entry .acf-checkbox-list label{
  display: flex;
  align-items: center;
  gap: .55em;
  padding: 10px 12px;
  border: 1px solid #e5e7eb;
  border-radius: 999px;
  background: #f8fafc;
  cursor: pointer;
  transition: background-color .15s ease, border-color .15s ease, box-shadow .15s ease, color .15s ease;
}
.is-fea-entry .acf-checkbox-list label:hover{
  background: #eef2ff;
  border-color: #c7d2fe;
}
@supports(selector(:has(*))){
  .is-fea-entry .acf-checkbox-list label:has(input:checked){
    background: #dbeafe;
    border-color: #93c5fd;
    box-shadow: inset 0 0 0 1px #60a5fa;
    color: #1e40af;
  }
}

/* 文字数カウンタ（JSが出す .cm-charcount） */
.is-fea-entry .cm-charcount{
  margin-top: 6px;
  font-size: .85rem;
  color: #6b7280;
  text-align: right;
}
.is-fea-entry .cm-charcount.is-over{ color: #b91c1c; }

/* 画像アップローダ（ドロップゾーン風） */
.is-fea-entry .acf-image-uploader .file-drop {
  display: grid;
  place-items: center;
  min-height: 140px;
  border: 2px dashed #d1d5db;
  border-radius: 14px;
  background: #f9fafb;
}
.is-fea-entry .acf-image-uploader .acf-actions a{
  background: #111827; color: #fff;
}

/* WYSIWYG */
.is-fea-entry .wp-editor-container{
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid #e5e7eb;
}

/* 送信ボタン：最下部で固定（スマホで便利） */
.is-fea-entry .acf-field[data-type="submit_button"]{
  position: sticky;
  bottom: 0;
  background: linear-gradient(#fff 70%, rgba(255,255,255,.8));
  padding-top: 10px;
  z-index: 5;
  border-top: 1px solid #f3f4f6;
}
.is-fea-entry .fea-submit-button.button{
  width: 100%;
  display: inline-block;
  padding: 14px 18px;
  font-weight: 700;
  font-size: 1rem;
  color: #fff;
  background: #10b981;
  border: none;
  border-radius: 12px;
  box-shadow: 0 8px 18px rgba(16,185,129,.25);
  transition: transform .05s ease, filter .15s ease;
}
.is-fea-entry .fea-submit-button.button:hover{ filter: brightness(1.03); }
.is-fea-entry .fea-submit-button.button:active{ transform: translateY(1px); }

/* 細かい余白 */
.is-fea-entry .acf-field{ padding: 8px; background: transparent; border: 0; }
.is-fea-entry .acf-label + .acf-input{ margin-top: 6px; }

/* ===== 相互リンク用：care_manager → 事例のカード ===== */
.cm-related-cases{
  margin-top: 1.5rem;
  padding: 1rem;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 4px 14px rgba(0,0,0,.04);
}
.cm-related-cases .cm-section-title{
  margin: .2em 0 .7em;
  font-size: 1.25rem;
}

.cm-case-grid{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 14px;
}
.cm-case-card{
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 10px;
  align-items: center;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  background: #fff;
  padding: 10px;
  box-shadow: 0 2px 8px rgba(0,0,0,.04);
}
.cm-case-thumb{
  display: grid; place-items: center;
  width: 56px; height: 56px;
  border-radius: 8px; background: #fff;
  border: 1px solid #eee;
  overflow: hidden;
}
.cm-case-thumb img{ width: 100%; height: 100%; object-fit: contain; }
.cm-case-thumb .noimg{
  display:block; width: 44px; height: 44px;
  border-radius: 6px; background:#f3f4f6; border:1px dashed #d1d5db;
}

.cm-case-title{
  margin: .1em 0 .2em;
  font-size: 1rem;
  line-height: 1.4;
}
.cm-case-title a{ color:#111; text-decoration:none; }
.cm-case-title a:hover{ text-decoration: underline; }

.cm-case-meta{ display:flex; flex-wrap:wrap; gap:.4em .6em; }
.cm-case-meta .item{
  display:inline-block;
  padding: .1em .5em;
  border-radius: 999px;
  background: #f3f4f6;
  color: #374151;
}


/* ==============================
   Case Study（単一ページ）
   ============================== */
.single-case_study .wp-block-post-content > *:not(.alignwide):not(.alignfull){
  max-width: min(960px, 95vw);
  margin-inline: auto;
}

.case-study{
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  background: #fff;
  padding: clamp(16px, 2.4vw, 28px);
  box-shadow: 0 8px 24px rgba(0,0,0,.05);
}

/* ヘッダー */
.case-study__header{
  display: grid;
  grid-template-columns: 88px 1fr;
  gap: 16px;
  align-items: center;
  margin-bottom: 12px;
}
.case-study__logo{
  width: 88px; height: 88px;
  display: grid; place-items: center;
  border: 1px solid #eee; border-radius: 10px;
  background: #fff; overflow: hidden;
}
.case-study__logo img{ width:100%; height:100%; object-fit: contain; }

.case-study__title{
  margin: .1em 0 .3em;
  font-size: clamp(1.25rem, 2.4vw, 1.6rem);
  line-height: 1.3;
}

/* メタ行（チップ風） */
.case-study__meta{
  display: flex; flex-wrap: wrap; gap: .5em .6em;
  padding: 0; margin: .2em 0 0;
  list-style: none;
  font-size: .95rem;
}
.case-study__meta li{
  display: inline-flex; align-items: center; gap: .4em;
  background: #f8fafc;
  border: 1px solid #e5e7eb;
  border-radius: 999px;
  padding: .25em .6em;
}
.case-study__meta .k{
  color: #6b7280; font-weight: 600;
}
.case-study__meta .v{ color:#111; }
.case-study__meta .ok{ color:#059669; font-weight:700; }
.case-study__meta li.is-tags .v{
  white-space: normal;
}

/* セクション */
.case-section{ margin-top: 1rem; }
.case-section__title{
  font-size: 1.1rem;
  margin: .2em 0 .4em;
  padding-left: .6em;
  border-left: 4px solid #3c82f6;
  line-height: 1.3;
}

/* 本文中の整形（WYSIWYG も含む） */
.case-rich p{ margin: .6em 0; line-height: 1.9; }
.case-rich ul, .case-rich ol{ margin: .6em 0 .6em 1.2em; }
.case-rich li{ margin: .25em 0; }
.case-rich img{ max-width:100%; height:auto; display:block; border-radius: 8px; }
.case-rich h3{ margin: .8em 0 .3em; font-size: 1.05rem; }

/* モバイル */
@media (max-width: 640px){
  .case-study__header{ grid-template-columns: 64px 1fr; }
  .case-study__logo{ width:64px; height:64px; }
}

/* モバイル対応 */
@media screen and (max-width: 600px) {
  .acf-form {
    padding: 1em;
  }

  .acf-label label {
    font-size: 0.95rem;
  }

  .acf-input input[type="text"],
  .acf-input input[type="email"],
  .acf-input input[type="url"],
  .acf-input input[type="number"],
  .acf-input input[type="password"],
  .acf-input select,
  .acf-input textarea {
    font-size: 0.95rem;
  }

  .acf-form input[type="submit"] {
    width: 100%;
    padding: 0.75em;
  }
}


/* === レスポンシブ対応 === */
@media screen and (max-width: 768px) {
  .person-block {
    flex-direction: column;
  }

  .person-image,
  .person-text {
    width: 100%;
  }

  .member-profile {
    flex-direction: column;
    align-items: center;
    padding: 1em;
  }

  .member-profile__header {
    flex-direction: column-reverse;
    align-items: center;
    text-align: center;
  }

  .member-profile__image {
    margin-bottom: 1em;
    text-align: center;
}

  .member-profile__image img {
    width: 100px;
    height: 100px;
  }

  .member-profile__name,
  .member-profile__meta {
    text-align: center;
  }

  .profile-section h3 {
    font-size: 16px;
  }

  .profile-section p {
    font-size: 15px;
  }
}

@media screen and (max-width: 600px) {
  body {
    padding: 0.2rem;
  }
  .acf-form {
    padding: 1em;
  }

  .acf-label label {
    font-size: 0.95rem;
  }

  .acf-input input[type="text"],
  .acf-input input[type="email"],
  .acf-input input[type="url"],
  .acf-input input[type="number"],
  .acf-input input[type="password"],
  .acf-input select,
  .acf-input textarea {
    font-size: 0.95rem;
  }

  .acf-form input[type="submit"] {
    width: 100%;
    padding: 0.75em;
  }
}




/* ========== Single Post（ニュース記事など）用の読みやすい余白 ========== */

/* 1) 記事本文の左右パディングと読み幅 */
body.single-post .wp-block-post-content{
  padding-inline: clamp(1rem, 4vw, 2rem);
}
body.single-post .wp-block-post-content > *:not(.alignwide):not(.alignfull){
  max-width: min(72ch, 100%);       /* 読みやすい最大幅 */
  margin-inline: auto;
}

/* 2) 余白リズム（上から下へ等間隔に） */
body.single-post .wp-block-post-content > * + *{
  margin-block-start: clamp(0.75rem, 2.5vw, 1.25rem);
}
body.single-post .wp-block-post-content h2{
  margin-block: clamp(1.25rem, 3.5vw, 2rem) 0.5rem;
}
body.single-post .wp-block-post-content h3{
  margin-block: clamp(1rem, 3vw, 1.5rem) 0.4rem;
}

/* 3) フル幅ブロックはモバイルだけ内側に息継ぎ（端ぎり防止） */
@media (max-width: 782px){
  body.single-post .wp-block-post-content .alignfull{
    padding-inline: clamp(.6rem, 3vw, 1rem);
    box-sizing: border-box;
  }
}

/* 4) 画像・表・埋め込みのはみ出し防止＆見栄え */
body.single-post .wp-block-post-content img,
body.single-post .wp-block-post-content video,
body.single-post .wp-block-post-content iframe{
  max-width: 100%;
  height: auto;
  display: block;
}
body.single-post .wp-block-image img{
  border-radius: 10px;
}
body.single-post .wp-block-table{
  display: block;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}



/* ========= For Companies LP – Polishing Layer ========= */
:root{
  --lp-radius:16px;
  --lp-radius-sm:12px;
  --lp-gap:16px;
  --lp-shadow:0 8px 24px rgba(0,0,0,.12);
  --lp-border:1px solid rgba(255,255,255,.12);
  --lp-border-dark:1px solid rgba(0,0,0,.06);
  --lp-accent:#22d3ee; /* teal-ish accent */
}

/* Hero */
.lp-gradient{
  background:
    radial-gradient(1200px 600px at 10% -10%, rgba(34,211,238,.15), rgba(34,211,238,0) 60%),
    radial-gradient(900px 500px at 90% 0%, rgba(129,140,248,.14), rgba(129,140,248,0) 60%),
    linear-gradient(#0b1220, #0b1220);
}
.eyebrow{
  letter-spacing:.14em;
  text-transform:uppercase;
  opacity:.8;
  font-size:12px;
  margin:0 0 8px;
}
.lp-hero__title{
  line-height:1.2;
  margin:.1em 0 .2em;
}
.lp-hero__subtitle{
  opacity:.9;
  margin:0 0 .6em;
}
.lp-hero__lead{
  opacity:.9;
  max-width:68ch;
}

/* Buttons */
.btn-primary .wp-block-button__link{
  background:linear-gradient(180deg, #22d3ee, #1fb3cb);
  color:#0b1220!important;
  border:none;
  border-radius:999px;
  padding:.7rem 1.2rem;
  box-shadow:var(--lp-shadow);
}
.btn-primary .wp-block-button__link:hover{ transform:translateY(-1px); }
.btn-secondary .wp-block-button__link{
  border-color:rgba(255,255,255,.5)!important;
  color:#fff!important;
  border-radius:999px;
  padding:.7rem 1.2rem;
}
.btn-ghost .wp-block-button__link{
  background:transparent!important;
  border-color:transparent!important;
  color:rgba(255,255,255,.9)!important;
  padding:.7rem 1rem;
}
.text-link{
  text-decoration:none;
  position:relative;
}
.text-link::after{
  content:"";
  position:absolute;left:0;bottom:-2px;width:100%;height:1px;
  background:currentColor;opacity:.3;transition:opacity .2s ease;
}
.text-link:hover::after{opacity:.6}

/* Metric cards */
.metric-row{gap:16px}
.metric-card{
  background:rgba(255,255,255,.06);
  border:var(--lp-border);
  border-radius:var(--lp-radius);
  padding:16px 18px;
  backdrop-filter:saturate(140%) blur(6px);
}
.metric-eyebrow{
  letter-spacing:.12em;
  text-transform:uppercase;
  opacity:.8;
  font-size:12px;
  margin:0 0 6px;
}
.metric-value{
  margin:0;
}
.metric-value span{opacity:.6;font-weight:400;font-size:.85em}

/* Sections */
.lp-section{max-width:1200px}
.section-title{margin:.2em 0 .5em}
.section-lead{opacity:.9;max-width:72ch}

/* Icon-like checklist */
.checklist{list-style:none;padding-left:0;margin:.6em 0}
.checklist li{
  position:relative;
  padding-left:28px;
  margin:.45em 0;
}
.checklist li::before{
  content:"";
  position:absolute;left:0.2rem;top:.45rem;
  width:18px;height:18px;border-radius:6px;
  background:linear-gradient(180deg,#22d3ee,#1fb3cb);
  mask: url('data:image/svg+xml;utf8,<svg width="20" height="20" viewBox="0 0 24 24" fill="white" xmlns="http://www.w3.org/2000/svg"><path d="M20.285 6.707l-11.4 11.4-5.657-5.657 1.414-1.414 4.243 4.243 9.986-9.986 1.414 1.414z"/></svg>') center / 16px 16px no-repeat;
}

/* Cards (models) */
.cards-3{gap:20px}
.card{
  border:var(--lp-border-dark);
  border-radius:var(--lp-radius);
  padding:20px;
  background:#fff;
}
.card.elevated{box-shadow:var(--lp-shadow)}
.card .badge{
  display:inline-block;
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
  background:#eef7fa;
  color:#0b1220;
  padding:.35rem .6rem;
  border-radius:999px;
  margin:0 0 8px;
}
.card-title{margin:.2em 0 .4em}
.card ul{margin:.4em 0 .6em}

/* Mini facet (quick search) */
.mini-facet{border:1px solid rgba(0,0,0,.08);border-radius:var(--lp-radius);padding:16px;background:#fff;box-shadow:var(--lp-shadow)}
.facet-grid{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:14px;
}
@media (max-width:980px){
  .facet-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:600px){
  .facet-grid{grid-template-columns:1fr}
}
.mini-facet label{display:flex;flex-direction:column;font-size:13px;gap:6px}
.mini-facet select,
.mini-facet input[type="search"]{
  appearance:none;
  border:1px solid rgba(0,0,0,.12);
  border-radius:10px;
  padding:.55rem .7rem;
  font-size:14px;
}
.facet-actions{display:flex;gap:12px;align-items:center;margin-top:12px}
.facet-actions .btn-ghost{display:inline-block;padding:.55rem .7rem;border-radius:999px;border:1px solid rgba(0,0,0,.12);color:#0b1220;text-decoration:none}

/* ROI panel */
.roi-panel{
  background:linear-gradient(180deg,#f8fbfc,#ffffff);
  border:1px solid rgba(0,0,0,.06);
  border-radius:var(--lp-radius);
  padding:20px;
  box-shadow:var(--lp-shadow);
}

/* FAQ */
.faq-item{
  border:1px solid rgba(0,0,0,.08);
  border-radius:12px;
  padding:14px 16px;
  background:#fff;
  box-shadow:0 4px 10px rgba(0,0,0,.04);
  margin:10px 0;
}
.faq-item summary{
  cursor:pointer;
  font-weight:600;
}

/* CTA Band */
.lp-cta-band{
  background:
    radial-gradient(900px 500px at 90% -10%, rgba(34,211,238,.16), rgba(34,211,238,0) 60%),
    #0f172a;
  color:#fff;
  text-wrap:balance;
}

/* Small notes */
.note{opacity:.75}

/* Accessibility & motion */
@media (prefers-reduced-motion:no-preference){
  .btn-primary .wp-block-button__link{transition:transform .15s ease, box-shadow .2s ease}
  .card:hover{transform:translateY(-1px);box-shadow:0 12px 28px rgba(0,0,0,.14)}
}




/* ===== Care Manager grid 強制レイアウト ===== */

/* グリッド自体を最優先で有効化 */
.wp-block-post-content .care-manager-grid,
.entry-content .care-manager-grid,
.care-manager-grid{
  display: grid !important;
  gap: 1.5rem !important;
  width: 100%;
  margin-inline: auto;
  /* 画面幅に応じて列数を確実に分ける */
  grid-template-columns: repeat(1, minmax(200px, 1fr));
}

/* 幅が確保できるところから列を増やす */
@media (min-width: 520px){
  .care-manager-grid{ grid-template-columns: repeat(2, minmax(200px, 1fr)) !important; }
}
@media (min-width: 820px){
  .care-manager-grid{ grid-template-columns: repeat(3, minmax(200px, 1fr)) !important; }
}
@media (min-width: 1120px){
  .care-manager-grid{ grid-template-columns: repeat(4, minmax(200px, 1fr)) !important; }
}

/* カード（高さを揃え、崩れを防止） */
.care-manager-card{
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  height: 100%;
  min-width: 0;               /* 文字のはみ出しで列が壊れるのを防止 */
  border: 1px solid #ddd;
  border-radius: 8px;
  padding: 1em;
  box-shadow: 0 2px 5px rgba(0,0,0,.05);
  background: #fff;
  box-sizing: border-box;
}

/* 画像は中央・丸・固定サイズ */
.care-manager-card .cm-thumb-link{ display:inline-block; }
.care-manager-card img{
  display:block;
  margin:0 auto 1em;
  width:120px; height:120px;
  border-radius:50%;
  object-fit:cover;
}

/* タイトル等の余白を安定させる */
.care-manager-card h3{ margin:0 0 .5em; font-size:1.1em; }
.care-manager-card h3 a{ text-decoration:none; color:#333; }

/* 親の制限で横幅が細くならないよう保険 */
.entry-content > .care-manager-grid{ max-width: min(1200px, 95vw); }

/* 画像や長いリンクが幅を押し広げない保険 */
.care-manager-card a,
.care-manager-card img{ max-width: 100%; }

