/* page-sub.css — 下層ページ専用。styles.css と同名セレクタを定義しない。 */
.page-hero{background:linear-gradient(120deg,var(--navy-1) 0%,var(--navy-2) 78%);color:#fff;padding:54px 0}
.page-hero__eyebrow{font-family:var(--font-display);letter-spacing:.12em;font-size:13px;text-transform:uppercase;margin:0 0 10px;color:var(--accent-cyan);word-break:keep-all}
.page-hero__h1{font-family:var(--font-serif);font-weight:700;font-size:clamp(26px,4vw,36px);margin:0;line-height:1.3;word-break:keep-all;overflow-wrap:anywhere}
.page-hero__sub{margin:14px 0 0;font-size:15px;color:#e7ecf7;max-width:680px}

.content{padding:54px 0}
.content--alt{background:var(--bg-alt)}
.content__block{margin:0 0 40px}
.content__block:last-child{margin-bottom:0}
.content__h2{font-family:var(--font-serif);font-weight:700;font-size:clamp(21px,3vw,26px);color:var(--ink);margin:0 0 18px;line-height:1.4;word-break:keep-all;overflow-wrap:anywhere}
.content__h3{font-family:var(--font-serif);font-weight:700;font-size:19px;color:var(--navy-1);margin:28px 0 10px;line-height:1.5;word-break:keep-all}
.content p{margin:0 0 16px}
.content ul{margin:0 0 18px;padding-left:1.3em}
.content li{margin:0 0 7px}
.content .small{font-size:14px;color:var(--muted)}

/* 会社概要などの定義リスト：dd は serif（sans だと和文が太く見える事案 5-3） */
.spec-list{display:grid;gap:0;margin:8px 0 0;border-top:1px solid var(--line)}
.spec-list>div{display:grid;grid-template-columns:1fr;gap:2px;padding:16px 0;border-bottom:1px solid var(--line)}
.spec-list dt{font-weight:600;color:var(--ink);font-size:14px;margin:0}
.spec-list dd{font-family:var(--font-serif);font-weight:400;margin:0;color:var(--ink-soft)}
@media(min-width:620px){.spec-list>div{grid-template-columns:200px 1fr;align-items:baseline}}

/* 認定講座メタ（認定/対象/提携） */
.meta-list{list-style:none;margin:0 0 18px;padding:16px 18px;background:#fff;border:1px solid var(--line);border-radius:8px}
.meta-list li{margin:0 0 6px;font-size:15px}
.meta-list li:last-child{margin:0}
.meta-list b{font-weight:600;color:var(--ink)}

/* メディア付きブロック（下層） */
.figure{background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden;margin:18px 0}
.figure img{width:100%;display:block}
.figure__ph{aspect-ratio:1280/800;display:flex;align-items:center;justify-content:center;color:#9aa3b2;font-size:13px;text-align:center;padding:16px;background:#f7f8fa}
.portrait{max-width:360px}
.portrait .figure__ph{aspect-ratio:3/4}
.figcap{font-size:14px;color:var(--muted);margin:8px 0 0}

/* 規約・条文 */
.legal h2{font-family:var(--font-serif);font-weight:700;font-size:18px;color:var(--ink);margin:30px 0 8px;word-break:keep-all}
.legal p{margin:0 0 14px}
.legal ul{margin:0 0 16px;padding-left:1.3em}
.legal li{margin:0 0 5px}
.legal .intro{color:var(--muted)}

/* 関連リンク行 */
.related{margin-top:34px;padding-top:24px;border-top:1px solid var(--line)}
.related a{font-weight:500}

/* お申し込み/フォーム枠 */
.formframe{margin:18px 0;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:#fff;position:relative} /* v3.72: 読込中表示 */
.formframe::before{content:"フォームを読み込んでいます…";position:absolute;top:64px;left:0;right:0;text-align:center;font-size:14px;color:var(--muted)}
.formframe iframe{display:block;width:100%;min-height:920px;border:0;position:relative;z-index:1;background:#fff}
.formframe__fallback{padding:16px}


/* ===== v0.6 ルート画像枠のCSSビジュアル＋代表写真（新規クラスのみ｜既存セレクタ非干渉） ===== */
.svc__media .cssart,.figure .cssart{width:100%;height:100%}
.cssart{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:24px;text-align:center;overflow:hidden;min-height:200px}
.figure .cssart{aspect-ratio:1280/800;min-height:0}
.cssart__icon{width:60px;height:60px}
.cssart__icon svg{width:100%;height:100%;display:block}
.cssart__icon svg *{stroke:rgba(255,255,255,.95);stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round;vector-effect:non-scaling-stroke}
.cssart__label{font-family:var(--font-display);font-size:12px;letter-spacing:.16em;color:rgba(255,255,255,.92)}
.cssart__sub{font-family:var(--font-serif);font-size:14px;letter-spacing:.04em;color:rgba(255,255,255,.92)}
.cssart::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 120% at 82% 4%,rgba(255,255,255,.16),transparent 58%);pointer-events:none}
.cssart--slatre{background:linear-gradient(135deg,#1b3c8e,#13245d)}
.cssart--physical{background:linear-gradient(135deg,#1c6f86,#0f3a4a)}
.cssart--wellness{background:linear-gradient(135deg,#587d4d,#2f5132)}
.cssart--career{background:linear-gradient(135deg,#b0894f,#7a5a2d)}
.cssart--corp{background:linear-gradient(135deg,#2a3550,#13245d)}
.figure-photo{width:100%;overflow:hidden;border-radius:10px}
.portrait .figure-photo{aspect-ratio:3/4}
.figure-photo img{width:100%;height:100%;object-fit:cover;display:block}

/* ---- v3.15: 指示書対応（協創フォーム補助リンク降格・図解・副次CTA） ---- */
.formframe__fallback--quiet{padding:10px 16px;font-size:13px;text-align:center}
.formframe__fallback--quiet a{color:var(--muted);text-decoration:underline}
.co-figure{margin:18px 0 0}
.co-figure svg{display:block;width:100%;max-width:640px;height:auto;margin:0 auto}
.co-figure__cap{font-size:13px;color:var(--muted);text-align:center;margin:10px 0 0}
.cta-sub{font-size:14px;color:var(--muted);margin-top:10px}

/* ---- v3.19: 協創「こんな方」4区分見出しの視覚強調（新規クラスのみ・太字強化はしない） ---- */
.persona-h{padding-left:13px;border-left:4px solid var(--accent-cyan)}

/* ===== v3.60: 縦書き第一声（page-hero__subの縦化・対象=message/co-creationのみ・新規クラスのみ） ===== */
.page-hero--vt .wrap{display:flex;justify-content:flex-start;align-items:flex-start;gap:clamp(48px,12vw,150px)} /* v3.72: 縦書きをタイトル寄りに（分断感の微調整・ルール不変） */
.page-hero__sub--vt{writing-mode:vertical-rl;text-orientation:mixed;font-family:var(--font-serif);font-weight:500;margin:0;letter-spacing:.16em;font-size:clamp(20px,2.8vw,28px);line-height:1.7;padding:2px 2px 0 0;color:#fff}
.page-hero__sub--vt span{display:block}
