/* =========================================================================
   Wakutsuku - Main stylesheet
   ========================================================================= */

/* -------------------------------------------------------------------------
   1. CSS Variables
   ------------------------------------------------------------------------- */
:root {
	/* color */
	--color-blue: #167FE0;
	--color-blue-light: #EAF6FF;
	--color-blue-dark: #0B3F75;
	--color-orange: #F28A00;
	--color-orange-light: #FFF4E8;
	--color-yellow: #FFD21F;
	--color-navy: #0F1B2A;
	--color-footer: #061B2D;
	--color-text: #172033;
	--color-muted: #64748B;
	--color-bg: #FFFFFF;
	--color-bg-soft: #F7FBFF;
	--color-border: #E5EEF8;

	/* layout */
	--container: 1180px;
	--container-wide: 1320px;
	--container-narrow: 920px;
	--radius-card: 24px;
	--radius-pill: 999px;

	/* typography */
	--font-base: "Noto Sans JP", system-ui, -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Hiragino Sans", "Yu Gothic", sans-serif;
	--font-hero: clamp(48px, 6vw, 88px);
	--font-page-title: clamp(40px, 4vw, 72px);
	--font-section-title: clamp(28px, 3vw, 44px);
	--font-card-title: 18px;
	--font-body: 16px;
	--font-small: 13px;
}

/* -------------------------------------------------------------------------
   2. Reset / base
   ------------------------------------------------------------------------- */
*,
*::before,
*::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
	margin: 0;
	font-family: var(--font-base);
	font-size: var(--font-body);
	color: var(--color-text);
	background: var(--color-bg);
	line-height: 1.8;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

img,
svg { max-width: 100%; height: auto; display: block; }

a { color: inherit; text-decoration: none; }

button {
	font-family: inherit;
	color: inherit;
	background: none;
	border: 0;
	cursor: pointer;
	padding: 0;
}

h1, h2, h3, h4, h5, h6, p, ul, ol, figure {
	margin: 0;
	padding: 0;
}

ul, ol { list-style: none; }

:focus-visible { outline: 2px solid var(--color-orange); outline-offset: 2px; }

body.is-nav-open { overflow: hidden; }

.site-main { display: block; }

.u-visually-hidden {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* -------------------------------------------------------------------------
   3. Layout
   ------------------------------------------------------------------------- */
.l-container {
	width: 100%;
	max-width: var(--container);
	margin-inline: auto;
	padding-inline: 24px;
}

/* -------------------------------------------------------------------------
   4. Components
   ------------------------------------------------------------------------- */

/* c-button */
.c-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-direction: row-reverse;
	gap: 14px;
	min-height: 52px;
	padding: 12px 28px;
	border-radius: var(--radius-pill);
	font-weight: 500;
	font-size: 15px;
	letter-spacing: 0.02em;
	transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease, color 0.2s ease;
	white-space: nowrap;
}
.c-button:hover { transform: translateY(-2px); box-shadow: 0 10px 24px rgba(15, 27, 42, 0.12); }

.c-button--primary {
	background: linear-gradient(90deg, #F28A00, #FF9D1E);
	color: #fff;
}

.c-button--secondary {
	border: 1px solid var(--color-blue);
	color: var(--color-blue);
	background: #fff;
}
.c-button--secondary:hover { background: var(--color-blue-light); }

.c-button__arrow {
	width: 24px;
	height: 24px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: currentColor;
	color: #fff;
	font-size: 11px;
	line-height: 1;
}
.c-button--secondary .c-button__arrow { color: #fff; background: var(--color-blue); }
.c-button--primary .c-button__arrow { background: rgba(255, 255, 255, 0.25); color: #fff; }

/* c-section-head */
.c-section-head {
	display: flex;
	flex-direction: column;
	gap: 20px;
}
.c-section-head__eyebrow {
	font-size: 13px;
	letter-spacing: 0.18em;
	color: var(--color-orange);
	font-weight: 700;
}
.c-section-head__title {
	font-size: var(--font-section-title);
	font-weight: 700;
	line-height: 1.3;
	color: var(--color-navy);
	letter-spacing: 0.02em;
}
.c-section-head__lead {
	color: var(--color-text);
	font-size: 14px;
	line-height: 1.9;
}

/* c-link-arrow */
.c-link-arrow {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	color: var(--color-blue);
	font-size: 14px;
	font-weight: 500;
	border-bottom: 1px solid currentColor;
	padding-bottom: 4px;
	width: fit-content;
	transition: color 0.2s ease;
}
.c-link-arrow:hover { color: var(--color-blue-dark); }

/* -------------------------------------------------------------------------
   5. Site header
   ------------------------------------------------------------------------- */
.c-site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: rgba(255, 255, 255, 0.92);
	backdrop-filter: saturate(180%) blur(10px);
	-webkit-backdrop-filter: saturate(180%) blur(10px);
}
.c-site-header__inner {
	width: 100%;
	max-width: var(--container-wide);
	margin-inline: auto;
	padding: 16px 32px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
}
.c-site-header__logo img {
	width: auto;
	height: 36px;
	display: block;
}
.c-site-header__nav-list {
	display: flex;
	align-items: center;
	gap: 36px;
}
.c-site-header__nav-item a {
	font-size: 14px;
	font-weight: 500;
	color: var(--color-navy);
	padding: 4px 0;
	position: relative;
	transition: color 0.2s ease;
}
.c-site-header__nav-item a:hover { color: var(--color-blue); }
.c-site-header__nav-item a[aria-current="page"] {
	color: var(--color-orange);
}
.c-site-header__nav-item a[aria-current="page"]::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: -6px;
	height: 2px;
	background: var(--color-orange);
	border-radius: 2px;
}

.c-site-header__hamburger {
	display: none;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: var(--color-navy);
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 4px;
	color: #fff;
	transition: background 0.2s ease;
}
.c-site-header__hamburger:hover { background: var(--color-blue-dark); }
.c-site-header__hamburger-bar {
	display: block;
	width: 18px;
	height: 2px;
	background: #fff;
	border-radius: 2px;
}
.c-site-header__hamburger[aria-expanded="true"] .c-site-header__hamburger-bar:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.c-site-header__hamburger[aria-expanded="true"] .c-site-header__hamburger-bar:nth-child(2) { opacity: 0; }
.c-site-header__hamburger[aria-expanded="true"] .c-site-header__hamburger-bar:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }
.c-site-header__hamburger-bar { transition: transform 0.25s ease, opacity 0.2s ease; }

.c-site-header__mobile {
	display: none;
	position: fixed;
	inset: 64px 0 0 0;
	background: rgba(255, 255, 255, 0.98);
	z-index: 99;
	overflow-y: auto;
}
.c-site-header__mobile-list {
	padding: 32px 28px 48px;
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.c-site-header__mobile-list a {
	display: block;
	padding: 18px 4px;
	font-size: 18px;
	font-weight: 500;
	color: var(--color-navy);
	border-bottom: 1px solid var(--color-border);
}
.c-site-header__mobile-list a[aria-current="page"] { color: var(--color-orange); }

/* -------------------------------------------------------------------------
   6. Site footer
   ------------------------------------------------------------------------- */
.c-site-footer {
	position: relative;
	background: var(--color-footer);
	color: #fff;
	padding: 56px 0 32px;
	overflow: hidden;
}
.c-site-footer__decor {
	position: absolute;
	right: 0;
	bottom: 0;
	width: 60%;
	max-width: 700px;
	opacity: 0.35;
	pointer-events: none;
	user-select: none;
}
.c-site-footer__inner {
	position: relative;
	width: 100%;
	max-width: var(--container-wide);
	margin-inline: auto;
	padding: 0 32px;
	display: grid;
	grid-template-columns: 1.3fr 2fr auto;
	gap: 40px;
	align-items: center;
}
.c-site-footer__brand { display: flex; flex-direction: column; gap: 14px; }
.c-site-footer__logo img {
	width: auto;
	height: 30px;
	filter: brightness(0) invert(1);
}
.c-site-footer__copyright {
	font-size: 12px;
	color: rgba(255, 255, 255, 0.7);
}
.c-site-footer__nav-list {
	display: flex;
	flex-wrap: wrap;
	gap: 28px 32px;
}
.c-site-footer__nav-list a {
	font-size: 13px;
	color: rgba(255, 255, 255, 0.9);
	transition: color 0.2s ease;
}
.c-site-footer__nav-list a:hover { color: var(--color-orange); }
.c-site-footer__social {
	display: flex;
	gap: 16px;
}
.c-site-footer__social a {
	width: 32px;
	height: 32px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	transition: background 0.2s ease;
}
.c-site-footer__social a:hover { background: rgba(255, 255, 255, 0.1); }
.c-site-footer__social img {
	width: 18px;
	height: 18px;
	filter: brightness(0) invert(1);
}

/* -------------------------------------------------------------------------
   7. Page: Hero
   ------------------------------------------------------------------------- */
.p-hero {
	position: relative;
	background: #fff;
	overflow: hidden;
}
.p-hero__bg {
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
}
.p-hero__bg img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: right bottom;
}
.p-hero__inner {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: var(--container-wide);
	margin-inline: auto;
	padding: 0 32px;
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
	align-items: center;
	min-height: clamp(400px, 36vw, 520px);
}
.p-hero__text {
	display: flex;
	flex-direction: column;
	gap: 24px;
	padding-block: 24px;
}
.p-hero__title {
	font-size: var(--font-hero);
	font-weight: 700;
	line-height: 1.15;
	color: var(--color-navy);
	letter-spacing: 0.01em;
}
.p-hero__lead {
	color: var(--color-text);
	font-size: 14px;
	line-height: 2;
}
.p-hero .c-button {
	align-self: flex-start;
}

/* -------------------------------------------------------------------------
   8. Page: Our Approach
   ------------------------------------------------------------------------- */
.p-approach {
	background: #fff;
	padding-block: 80px;
}
.p-approach__grid {
	display: grid;
	grid-template-columns: minmax(0, 360px) minmax(0, 1fr);
	gap: 48px;
	align-items: start;
}
.p-approach__head { padding-top: 8px; }

.p-approach__steps {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 24px;
	align-items: start;
	counter-reset: step;
}
.p-approach__step {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 12px;
	position: relative;
}
.p-approach__step-visual {
	position: relative;
	width: 100%;
	max-width: 240px;
	margin-inline: auto;
}
.p-approach__step-visual img {
	display: block;
	width: 100%;
	height: auto;
}
.p-approach__step:not(:last-child) .p-approach__step-visual::after {
	content: "";
	position: absolute;
	left: 100%;
	top: 50%;
	width: 64px;
	height: 26px;
	margin-left: 6px;
	background-image: url("../images/decor/arrow-right-orange.svg?v=2");
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
	transform: translateY(-50%);
	pointer-events: none;
}
.p-approach__step-list {
	display: flex;
	flex-direction: column;
	gap: 6px;
	font-size: 13px;
	color: var(--color-text);
	text-align: center;
	line-height: 1.7;
	padding-inline: 8px;
}

/* -------------------------------------------------------------------------
   9. Page: WakuSpark5
   ------------------------------------------------------------------------- */
.p-spark {
	background: var(--color-bg-soft);
	padding-block: 72px;
}
.p-spark__layout {
	display: grid;
	grid-template-columns: minmax(0, 280px) minmax(0, 1fr);
	gap: 56px;
	align-items: center;
}
.p-spark__head { padding-top: 8px; }
.p-spark__title {
	font-size: clamp(22px, 1.8vw, 28px);
}
.p-spark__more { margin-top: 8px; }

.p-spark__list {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 20px;
}
/* 各「火花」をブランドカラーで色分けする（aboutのWakuSpark5と統一） */
.p-spark__item {
	--spark: var(--color-orange);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 14px;
	text-align: center;
}
.p-spark__item:nth-child(1) { --spark: #F28A00; }
.p-spark__item:nth-child(2) { --spark: #25AEEA; }
.p-spark__item:nth-child(3) { --spark: #F28A00; }
.p-spark__item:nth-child(4) { --spark: #F6B200; }
.p-spark__item:nth-child(5) { --spark: #A55BE8; }
.p-spark__icon {
	width: 88px;
	height: 88px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: color-mix(in srgb, var(--spark) 12%, #fff);
	box-shadow: 0 8px 20px color-mix(in srgb, var(--spark) 16%, transparent);
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.p-spark__item:hover .p-spark__icon {
	transform: translateY(-5px);
	box-shadow: 0 16px 30px color-mix(in srgb, var(--spark) 26%, transparent);
}
.p-spark__icon img {
	display: block;
	width: 46px;
	height: 46px;
	object-fit: contain;
}
.p-spark__num {
	font-size: 12px;
	font-weight: 700;
	color: var(--spark);
	letter-spacing: 0.16em;
}
.p-spark__name {
	font-size: 14px;
	font-weight: 700;
	color: var(--color-navy);
	line-height: 1.55;
}

/* -------------------------------------------------------------------------
   10. Page: What We Do
   ------------------------------------------------------------------------- */
.p-services {
	background: #fff;
	padding-block: 72px;
}
.p-services__layout {
	display: grid;
	grid-template-columns: minmax(0, 280px) minmax(0, 1fr);
	gap: 40px;
	align-items: start;
}
.p-services__head {
	padding-top: 8px;
	gap: 24px;
	display: flex;
	flex-direction: column;
}
/* 「知見が循環する、/ 4つの事業。」が狭い左カラムでも<br>位置だけで改行されるよう調整 */
.p-services__head .c-section-head__title {
	font-size: clamp(26px, 2.4vw, 32px);
}

.p-services__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 24px;
}
/* 各事業をブランドカラーでアクセント分けする */
.p-services__card {
	--accent: var(--color-orange);
	position: relative;
	display: flex;
	flex-direction: column;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-card);
	box-shadow: 0 10px 30px rgba(15, 27, 42, 0.05);
	overflow: hidden;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.p-services__card:nth-child(1) { --accent: #18538a; } /* Spekan: 青 */
.p-services__card:nth-child(2) { --accent: #F28A00; } /* 施設運営・運営代行: オレンジ */
.p-services__card:nth-child(3) { --accent: #18538a; } /* レンタルスペース運営ラボ: 青 */
.p-services__card:nth-child(4) { --accent: #1FA971; } /* AI推進支援: 緑 */
/* カード上辺のアクセントライン（hoverで左から伸びる） */
.p-services__card::before {
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 4px;
	background: var(--accent);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 0.3s ease;
	z-index: 3;
}
.p-services__card:hover {
	transform: translateY(-6px);
	box-shadow: 0 22px 48px rgba(15, 27, 42, 0.12);
}
.p-services__card:hover::before { transform: scaleX(1); }
/* カード全体を事業ページへのリンクに */
.p-services__card-link {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	width: 100%;
	flex: 1;
	color: inherit;
	text-decoration: none;
}
.p-services__card-visual {
	width: 100%;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	background: var(--color-bg-soft);
}
.p-services__card-visual img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
	transition: transform 0.45s ease;
}
.p-services__card:hover .p-services__card-visual img {
	transform: scale(1.05);
}
/* ブランドアイコンを白いバッジにし、ビジュアル下端へ重ねる */
.p-services__card-badge {
	width: 64px;
	height: 64px;
	margin-top: -32px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #fff;
	border-radius: 18px;
	box-shadow: 0 10px 24px rgba(15, 27, 42, 0.14);
	position: relative;
	z-index: 2;
}
.p-services__card-icon {
	width: 40px;
	height: 40px;
	object-fit: contain;
}
/* タイトル・本文は黒で統一し、色はリンク（詳しく見る）のみに使う */
.p-services__card-title {
	font-size: 16px;
	font-weight: 700;
	color: var(--color-navy);
	line-height: 1.5;
	padding: 0 18px;
	margin-top: 16px;
}
.p-services__card-text {
	font-size: 13px;
	color: var(--color-navy);
	line-height: 1.9;
	padding: 8px 18px 16px;
}
.p-services__card-more {
	margin-top: auto;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 4px 18px 26px;
	font-size: 13px;
	font-weight: 700;
	color: var(--accent);
}
.p-services__card-more-arrow {
	transition: transform 0.2s ease;
}
.p-services__card:hover .p-services__card-more-arrow {
	transform: translateX(4px);
}

/* -------------------------------------------------------------------------
   11. Page: Message + News
   ------------------------------------------------------------------------- */
.p-message-news {
	background: var(--color-bg-soft);
	padding-block: 80px;
}
.p-message-news__grid {
	display: grid;
	grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
	gap: 32px;
	align-items: stretch;
}
/* MESSAGE / NEWS を白いカードに収め、上の事業カードとトンマナを揃える */
.p-message,
.p-news {
	min-width: 0; /* グリッドアイテムが中身でトラック幅を超えないようにする */
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-card);
	box-shadow: 0 12px 32px rgba(15, 27, 42, 0.05);
	padding: 40px;
}

/* --- MESSAGE --- */
.p-message {
	display: flex;
	flex-direction: column;
	gap: 20px;
}
.p-message__body,
.p-message__text { min-width: 0; }
.p-message__title {
	font-size: 24px;
	font-weight: 700;
	color: var(--color-navy);
}
.p-message__body {
	display: grid;
	grid-template-columns: 200px 1fr;
	gap: 28px;
	align-items: start;
}
.p-message__photo {
	width: 200px;
	height: 200px;
	border-radius: 16px;
	overflow: hidden;
	background: var(--color-bg-soft);
	box-shadow: 0 12px 26px rgba(15, 27, 42, 0.12);
}
.p-message__photo img { width: 100%; height: 100%; object-fit: cover; }
.p-message__text {
	position: relative;
	display: flex;
	flex-direction: column;
	gap: 18px;
	font-size: 13px;
	line-height: 1.95;
	color: var(--color-text);
}
/* 装飾の引用符（エディトリアルな印象を加える） */
.p-message__text::before {
	content: "“";
	position: absolute;
	top: -34px;
	left: -8px;
	font-family: Georgia, "Times New Roman", serif;
	font-size: 72px;
	line-height: 1;
	color: color-mix(in srgb, var(--color-orange) 30%, #fff);
	pointer-events: none;
	z-index: 0;
}
.p-message__text > * { position: relative; z-index: 1; }
.p-message__sign-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-top: 4px;
}
.p-message__sign { font-weight: 700; color: var(--color-navy); font-size: 14px; }
.p-message__link {
	flex-shrink: 0;
	width: 40px;
	height: 40px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	border: 1px solid var(--color-blue);
	color: var(--color-blue);
	transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease;
}
.p-message__link:hover {
	background: var(--color-blue);
	color: #fff;
	transform: translateX(3px);
}

/* --- NEWS --- */
.p-news {
	display: flex;
	flex-direction: column;
	gap: 20px;
}
.p-news__title {
	font-size: 24px;
	font-weight: 700;
	color: var(--color-navy);
}
.p-news__list {
	display: flex;
	flex-direction: column;
	flex: 1;
}
.p-news__item { border-bottom: 1px solid var(--color-border); }
.p-news__item:first-child { border-top: 1px solid var(--color-border); }
.p-news__link {
	display: grid;
	grid-template-columns: 92px 1fr 18px;
	gap: 14px;
	padding: 16px 4px;
	align-items: center;
	font-size: 13px;
	transition: color 0.2s ease;
}
.p-news__link::after {
	content: "→";
	color: var(--color-blue);
	opacity: 0;
	transform: translateX(-4px);
	transition: opacity 0.2s ease, transform 0.2s ease;
}
.p-news__link:hover:not(.p-news__link--placeholder) { color: var(--color-blue); }
.p-news__link:hover:not(.p-news__link--placeholder)::after {
	opacity: 1;
	transform: translateX(0);
}
.p-news__link--placeholder::after { content: none; }
.p-news__date {
	color: var(--color-muted);
	font-size: 12px;
	letter-spacing: 0.04em;
	font-feature-settings: "tnum";
}
.p-news__title-text {
	color: var(--color-text);
	line-height: 1.7;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.p-news .c-link-arrow {
	margin-top: auto;
	align-self: flex-start;
}

/* -------------------------------------------------------------------------
   12. Component: Breadcrumbs
   ------------------------------------------------------------------------- */
.c-breadcrumbs { margin-bottom: 16px; }
.c-breadcrumbs__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 6px 10px;
	font-size: 13px;
	color: var(--color-muted);
}
.c-breadcrumbs__item {
	display: inline-flex;
	align-items: center;
	gap: 10px;
}
.c-breadcrumbs__link {
	color: var(--color-muted);
	transition: color 0.2s ease;
}
.c-breadcrumbs__link:hover { color: var(--color-blue); }
.c-breadcrumbs__current { color: var(--color-navy); font-weight: 500; }
.c-breadcrumbs__sep { color: var(--color-border); font-weight: 700; }

/* -------------------------------------------------------------------------
   13. Component: Page Hero
   ------------------------------------------------------------------------- */
.c-page-hero {
	position: relative;
	background: linear-gradient(180deg, #fff 0%, var(--color-blue-light) 100%);
	overflow: hidden;
	padding-block: 56px 80px;
}
.c-page-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image: url("../images/decor/orbit-lines.svg");
	background-repeat: no-repeat;
	background-position: center top;
	background-size: cover;
	opacity: 0.25;
	pointer-events: none;
}
.c-page-hero__inner {
	position: relative;
	width: 100%;
	max-width: var(--container-wide);
	margin-inline: auto;
	padding: 0 32px;
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
	gap: 40px;
	align-items: center;
	min-height: 360px;
}
.c-page-hero__text {
	display: flex;
	flex-direction: column;
	gap: 18px;
}
.c-page-hero__eyebrow {
	font-size: 14px;
	letter-spacing: 0.18em;
	color: var(--color-orange);
	font-weight: 700;
}
.c-page-hero__title {
	font-size: var(--font-page-title);
	font-weight: 700;
	line-height: 1.2;
	color: var(--color-navy);
	letter-spacing: 0.01em;
}
.c-page-hero__lead {
	font-size: 18px;
	font-weight: 700;
	color: var(--color-navy);
	line-height: 1.7;
}
.c-page-hero__description {
	font-size: 14px;
	color: var(--color-text);
	line-height: 2;
}
.c-page-hero__cta {
	margin-top: 28px;
}
.c-page-hero__visual {
	position: relative;
}
.c-page-hero__visual img {
	width: 100%;
	height: auto;
	display: block;
	border-radius: 12px;
}

/* -------------------------------------------------------------------------
   14. Component: CTA Band
   ------------------------------------------------------------------------- */
.c-cta-band {
	background: #fff;
	padding-block: 24px 64px;
}
.c-cta-band__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 32px;
	padding: 32px 40px;
	border-radius: var(--radius-card);
	background: var(--color-blue-light);
	border: 1px solid var(--color-border);
}
.c-cta-band__text {
	display: flex;
	align-items: center;
	gap: 18px;
	flex: 1;
}
.c-cta-band__icon {
	width: 52px;
	height: 52px;
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: #fff;
	color: var(--color-blue);
}
.c-cta-band__lead {
	font-size: 15px;
	color: var(--color-navy);
	font-weight: 500;
	line-height: 1.7;
}
.c-cta-band__actions {
	display: flex;
	gap: 12px;
	flex-shrink: 0;
}
.c-cta-band__actions .c-button { min-width: 200px; }

/* soft-blue modifier (news detail 等で使用) */
.c-cta-band--soft-blue { padding-block: 64px 72px; }
.c-cta-band--soft-blue .c-cta-band__inner {
	position: relative;
	background: var(--color-blue-light);
	border: 1px solid rgba(22, 127, 224, 0.18);
	border-radius: 64px;
	padding: 28px 56px;
	overflow: hidden;
}
.c-cta-band--soft-blue .c-cta-band__inner::after {
	content: "";
	position: absolute;
	right: -32px;
	bottom: -32px;
	width: 320px;
	height: 200px;
	background: url("../images/decor/soft-blue-cta-shape.svg") no-repeat right bottom / contain;
	opacity: 0.7;
	pointer-events: none;
}
.c-cta-band--soft-blue .c-cta-band__text,
.c-cta-band--soft-blue .c-cta-band__actions {
	position: relative;
	z-index: 1;
}
.c-cta-band--soft-blue .c-cta-band__icon {
	width: 60px;
	height: 60px;
	background: #fff;
	border: 1px solid var(--color-border);
	color: var(--color-blue);
}
.c-cta-band--soft-blue .c-cta-band__lead { font-size: 16px; }
/* お問い合わせボタンは /company と同じ標準プライマリボタン (オレンジグラデ + 円形矢印) を使用するため、
   soft-blue 固有のボタン上書きは行わない。 */

/* -------------------------------------------------------------------------
   15. Page: Business Relation
   ------------------------------------------------------------------------- */
.p-business-relation {
	background: #fff;
	padding-block: 80px 72px;
}
.p-business-relation__head {
	text-align: center;
	margin-bottom: 8px;
}
.p-business-relation__eyebrow {
	font-size: 13px;
	letter-spacing: 0.18em;
	color: var(--color-orange);
	font-weight: 700;
	margin-bottom: 14px;
}
.p-business-relation__title {
	font-size: var(--font-section-title);
	font-weight: 700;
	color: var(--color-navy);
	line-height: 1.3;
}
.p-business-relation__lead {
	margin-top: 18px;
	font-size: 15px;
	line-height: 1.9;
	color: var(--color-text);
}
/* 事業の関係性: Spekanを中心としたハブ型ダイアグラム (PC) */
.p-bizrel {
	position: relative;
	max-width: 1040px;
	margin: 44px auto 0;
	aspect-ratio: 1040 / 680;
}
.p-bizrel__links {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
	pointer-events: none;
}
.p-bizrel__orbit {
	fill: none;
	stroke: var(--color-border);
	stroke-width: 1.5;
	stroke-dasharray: 1 9;
	stroke-linecap: round;
}
.p-bizrel__link {
	fill: none;
	stroke: var(--color-blue);
	stroke-width: 2;
	stroke-dasharray: 1 8;
	stroke-linecap: round;
	opacity: 0.5;
}

/* 中央ハブ (Spekan) */
.p-bizrel__hub {
	position: absolute;
	left: 50%;
	top: 44.1%;
	transform: translate(-50%, -50%);
	z-index: 3;
	width: clamp(228px, 25vw, 280px);
	aspect-ratio: 1 / 1;
	border-radius: 50%;
	background: radial-gradient(circle at 50% 36%, #fff 58%, var(--color-blue-light) 100%);
	border: 1.5px solid rgba(22, 127, 224, 0.4);
	box-shadow: 0 26px 60px rgba(22, 127, 224, 0.18);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 14px;
	padding: 30px;
	text-align: center;
}
.p-bizrel__hub-logo {
	width: auto;
	height: 36px;
}
.p-bizrel__hub-label {
	font-size: 12.5px;
	line-height: 1.7;
	color: var(--color-text);
	font-weight: 500;
}

/* 周辺ノード */
.p-bizrel__node {
	position: absolute;
	z-index: 3;
	width: clamp(212px, 22vw, 248px);
	transform: translate(-50%, -50%);
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-card);
	box-shadow: 0 12px 30px rgba(15, 27, 42, 0.06);
	padding: 24px 22px;
	text-align: center;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.p-bizrel__node:hover {
	transform: translate(-50%, calc(-50% - 4px));
	box-shadow: 0 18px 42px rgba(15, 27, 42, 0.12);
}
.p-bizrel__node-visual {
	width: 96px;
	height: 96px;
	margin: 0 auto 14px;
	border-radius: 50%;
	background: var(--color-bg-soft);
	display: flex;
	align-items: center;
	justify-content: center;
}
.p-bizrel__node-visual img {
	width: 78px;
	height: 78px;
	object-fit: contain;
}
/* ロゴ画像(アプリアイコン型)を使うノードは丸背景を外して大きく表示 */
.p-bizrel__node-visual--logo {
	background: none;
}
.p-bizrel__node-visual--logo img {
	width: 88px;
	height: 88px;
	object-fit: contain;
}
.p-bizrel__node-title {
	font-size: 16px;
	font-weight: 700;
	color: var(--color-navy);
	margin-bottom: 8px;
}
.p-bizrel__node-text {
	font-size: 12.5px;
	line-height: 1.8;
	color: var(--color-muted);
}

/* ノード配置 (PC) — SVG終点と一致 */
.p-bizrel__node--op  { left: 16.9%; top: 35%; }
.p-bizrel__node--lab { left: 83.1%; top: 35%; }
.p-bizrel__node--ai  { left: 50%;   top: 82.1%; }

/* フローラベル (PC) — コネクタ中点に配置 */
.p-bizrel__node-flow {
	font-size: 11.5px;
	font-weight: 700;
	letter-spacing: 0.02em;
	color: var(--color-blue);
	margin-bottom: 6px;
}
.p-bizrel__node--ai .p-bizrel__node-flow { color: #10a96d; }

/* 事業の関係性: 900px以下は縦積みフローに切り替え */
@media (max-width: 900px) {
	.p-bizrel {
		aspect-ratio: auto;
		max-width: 460px;
		margin: 32px auto 0;
		display: flex;
		flex-direction: column;
		align-items: center;
	}
	.p-bizrel__links { display: none; }
	.p-bizrel__hub {
		position: static;
		transform: none;
		width: min(260px, 78%);
	}
	.p-bizrel__node {
		position: static;
		transform: none;
		width: 100%;
	}
	.p-bizrel__node:hover { transform: translateY(-4px); }
	.p-bizrel__hub { margin-bottom: 8px; }
	.p-bizrel__node + .p-bizrel__node { margin-top: 16px; }
}

/* -------------------------------------------------------------------------
   16. Page: Business Services
   ------------------------------------------------------------------------- */
.p-business-services {
	background: var(--color-bg-soft);
	padding-block: 80px 96px;
}
.p-business-services__head {
	text-align: center;
	margin-bottom: 48px;
}
.p-business-services__eyebrow {
	font-size: 13px;
	letter-spacing: 0.18em;
	color: var(--color-orange);
	font-weight: 700;
	margin-bottom: 14px;
}
.p-business-services__title {
	font-size: var(--font-section-title);
	font-weight: 700;
	color: var(--color-navy);
	line-height: 1.3;
}
.p-business-services__lead {
	margin-top: 18px;
	font-size: 15px;
	line-height: 1.9;
	color: var(--color-text);
}

/* サービスカード (イラスト型・事業別アクセント色) */
.p-bizsvc {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 24px;
}
.p-bizsvc__card {
	--accent: var(--color-blue);
	--accent-soft: var(--color-blue-light);
	display: flex;
	flex-direction: column;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-card);
	overflow: hidden;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.p-bizsvc__card--spekan { --accent: var(--color-blue);   --accent-soft: var(--color-blue-light); }
.p-bizsvc__card--op     { --accent: var(--color-orange); --accent-soft: var(--color-orange-light); }
.p-bizsvc__card--lab    { --accent: #167FE0;             --accent-soft: var(--color-blue-light); }
.p-bizsvc__card--ai     { --accent: #10a96d;             --accent-soft: rgba(16, 169, 109, 0.1); }
.p-bizsvc__card:hover {
	transform: translateY(-6px);
	box-shadow: 0 22px 46px rgba(15, 27, 42, 0.1);
}
.p-bizsvc__visual {
	position: relative;
	aspect-ratio: 16 / 10;
	background: var(--accent-soft);
	display: flex;
	align-items: center;
	justify-content: center;
}
.p-bizsvc__visual::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: var(--accent);
}
.p-bizsvc__visual img {
	width: 62%;
	max-width: 148px;
	height: auto;
	object-fit: contain;
}
/* 事業ロゴを画像左上に小さく重ねる(白チップで視認性を確保)
   .p-bizsvc__visual img(width:62%)より詳細度を上げて確実に40px角にする */
.p-bizsvc__visual img.p-bizsvc__logo {
	position: absolute;
	top: 12px;
	left: 12px;
	width: 40px;
	max-width: 40px;
	height: 40px;
	padding: 5px;
	background: #fff;
	border-radius: 10px;
	box-shadow: 0 4px 10px rgba(15, 27, 42, 0.12);
	object-fit: contain;
	z-index: 1;
}
.p-bizsvc__body {
	display: flex;
	flex-direction: column;
	gap: 8px;
	padding: 22px 22px 24px;
	flex: 1;
}
.p-bizsvc__eyebrow {
	font-size: 11px;
	letter-spacing: 0.14em;
	font-weight: 700;
	color: var(--accent);
}
.p-bizsvc__title {
	font-size: 16px;
	font-weight: 700;
	color: var(--color-navy);
	line-height: 1.5;
}
.p-bizsvc__text {
	font-size: 12.5px;
	line-height: 1.85;
	color: var(--color-muted);
	flex: 1;
}
.p-bizsvc__link {
	margin-top: 12px;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 13px;
	font-weight: 700;
	color: var(--accent);
}
.p-bizsvc__arrow {
	transition: transform 0.2s ease;
}
.p-bizsvc__card:hover .p-bizsvc__arrow {
	transform: translateX(4px);
}
/* 関係図ノードでロゴ画像をそのまま使う場合は背景の丸を外す */
.p-business-relation__icon--logo {
	background: none !important;
	border-radius: 0;
}
.p-business-relation__icon--logo img {
	width: 32px;
	height: 32px;
	object-fit: contain;
}

/* -------------------------------------------------------------------------
   16b. Page: Business Detail (事業詳細)
   ------------------------------------------------------------------------- */
/* Hero ロゴ */
.c-page-hero__logo {
	margin-bottom: 4px;
}
.c-page-hero__logo img {
	height: 40px;
	width: auto;
	display: block;
}

.p-bizdetail-overview {
	background: #fff;
	padding-block: 72px 80px;
}
.p-bizdetail-overview__layout {
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
	gap: 56px;
	align-items: center;
}
.p-bizdetail-overview--reverse .p-bizdetail-overview__body { order: 2; }
.p-bizdetail-overview--reverse .p-bizdetail-overview__visual { order: 1; }
.p-bizdetail-overview__text {
	margin-top: 24px;
	display: flex;
	flex-direction: column;
	gap: 18px;
}
.p-bizdetail-overview__text p {
	font-size: 15px;
	line-height: 2;
	color: var(--color-text);
}
/* アプリ画面を重ねカードで浮遊させ、奥に淡いブランドパネルを覗かせる */
.p-bizdetail-overview__visual {
	position: relative;
	isolation: isolate;
}
.p-bizdetail-overview__visual::before {
	content: "";
	position: absolute;
	inset: 22px -20px -20px 26px;
	border-radius: 20px;
	background: linear-gradient(135deg, rgba(22, 127, 224, 0.14), rgba(242, 138, 0, 0.12));
	z-index: -1;
}
.p-bizdetail-overview__visual img {
	position: relative;
	display: block;
	width: 100%;
	height: auto;
	border-radius: 16px;
	border: 1px solid rgba(15, 27, 42, 0.07);
	box-shadow:
		0 28px 56px -28px rgba(15, 27, 42, 0.32),
		0 8px 20px -12px rgba(15, 27, 42, 0.12);
}

.p-bizdetail-features {
	background: var(--color-bg-soft);
	padding-block: 72px 88px;
}
.p-bizdetail-features__head {
	align-items: center;
	text-align: center;
	max-width: 720px;
	margin-inline: auto;
	margin-bottom: 48px;
}
.p-bizdetail-features__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 24px;
}
.p-bizdetail-features__card {
	position: relative;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: 18px;
	padding: 30px 30px 28px;
	display: flex;
	flex-direction: column;
	gap: 14px;
	overflow: hidden;
	transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
/* 上辺にホバーで伸びるグラデーションアクセント */
.p-bizdetail-features__card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--color-blue), var(--color-orange));
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 0.3s ease;
}
.p-bizdetail-features__card:hover {
	transform: translateY(-4px);
	box-shadow: 0 24px 44px -26px rgba(15, 27, 42, 0.34);
	border-color: rgba(22, 127, 224, 0.32);
}
.p-bizdetail-features__card:hover::before {
	transform: scaleX(1);
}
/* 番号チップ */
.p-bizdetail-features__num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: 13px;
	background: linear-gradient(135deg, var(--color-blue), var(--color-blue-dark));
	color: #fff;
	font-size: 15px;
	font-weight: 700;
	letter-spacing: 0.04em;
	box-shadow: 0 10px 20px -10px rgba(22, 127, 224, 0.65);
}
/* アイコンタイル (番号チップの代替) */
.p-bizdetail-features__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	border-radius: 14px;
	background: var(--color-blue-light);
	border: 1px solid rgba(22, 127, 224, 0.18);
	transition: background 0.25s ease, transform 0.25s ease;
}
.p-bizdetail-features__icon img {
	width: 26px;
	height: 26px;
	display: block;
}
.p-bizdetail-features__card:hover .p-bizdetail-features__icon {
	background: #fff;
	transform: translateY(-1px);
}
/* 施設運営: 現場の温かみを表すオレンジ系アクセント */
.p-bizdetail--operation .p-bizdetail-features__icon {
	background: var(--color-orange-light);
	border-color: rgba(242, 138, 0, 0.20);
}
/* featureカード上辺アクセントをページ別ブランドカラーに統一 */
.p-bizdetail--operation .p-bizdetail-features__card::before {
	background: var(--color-orange);
}
.p-bizdetail--spekan .p-bizdetail-features__card::before,
.p-bizdetail--lab .p-bizdetail-features__card::before {
	background: #18538a;
}
/* AI推進支援: テクノロジー感のあるグリーン系アクセントで統一 */
.p-bizdetail--ai .p-bizdetail-features__icon {
	background: rgba(16, 169, 109, 0.10);
	border-color: rgba(16, 169, 109, 0.22);
}
.p-bizdetail--ai .p-bizdetail-features__card::before {
	background: linear-gradient(90deg, #10A96D, #42B85C);
}
.p-bizdetail--ai .p-bizdetail-features__card:hover {
	border-color: rgba(16, 169, 109, 0.34);
}
.p-bizdetail--ai .p-bizdetail-overview__visual::before {
	background: linear-gradient(135deg, rgba(16, 169, 109, 0.16), rgba(22, 127, 224, 0.10));
}
.p-bizdetail-features__card-title {
	font-size: 18px;
	font-weight: 700;
	color: var(--color-navy);
	line-height: 1.5;
}
.p-bizdetail-features__card-text {
	font-size: 14px;
	line-height: 1.95;
	color: var(--color-muted);
}

.p-bizdetail-flow {
	background: #fff;
	padding-block: 72px 88px;
}
.p-bizdetail-flow__head {
	align-items: center;
	text-align: center;
	max-width: 720px;
	margin-inline: auto;
	margin-bottom: 44px;
}
.p-bizdetail-flow__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 16px;
	max-width: 820px;
	margin-inline: auto;
}
.p-bizdetail-flow__item {
	display: flex;
	gap: 20px;
	align-items: flex-start;
	background: var(--color-bg-soft);
	border-radius: var(--radius-card);
	padding: 24px 26px;
}
.p-bizdetail-flow__step {
	flex-shrink: 0;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: var(--color-blue);
	color: #fff;
	font-weight: 700;
	display: flex;
	align-items: center;
	justify-content: center;
}
.p-bizdetail-flow__item-title {
	font-size: 16px;
	font-weight: 700;
	color: var(--color-navy);
	margin-bottom: 6px;
}
.p-bizdetail-flow__item-text {
	font-size: 13.5px;
	line-height: 1.9;
	color: var(--color-muted);
}

/* -------------------------------------------------------------------------
   Page: 事業詳細 — 改善の循環 (Cycle)
   現場(オレンジ) と Spekan(ブルー) が噛み合い一周して戻る循環を表現
   ------------------------------------------------------------------------- */
.p-bizdetail-cycle {
	background: #fff;
	padding-block: 72px 92px;
}
.p-bizdetail-cycle__head {
	align-items: center;
	text-align: center;
	max-width: 760px;
	margin-inline: auto;
	margin-bottom: 56px;
}
.p-bizcycle {
	position: relative;
	max-width: 1040px;
	margin-inline: auto;
	padding-top: 60px; /* 上部のループブラケット用の余白 */
}
/* 上部: step3 → step1 へ戻る破線ブラケット(循環の閉じ) */
.p-bizcycle__loop {
	position: absolute;
	top: 8px;
	left: 16%;
	right: 16%;
	height: 46px;
	border: 2px dashed rgba(242, 138, 0, 0.55);
	border-bottom: none;
	border-radius: 18px 18px 0 0;
}
.p-bizcycle__loop::before {
	content: "";
	position: absolute;
	left: 0;
	bottom: -2px;
	transform: translateX(-50%);
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-top: 9px solid rgba(242, 138, 0, 0.7); /* step1 に向かう下向き矢印 */
}
.p-bizcycle__loop-label {
	position: absolute;
	top: -12px;
	left: 50%;
	transform: translateX(-50%);
	background: #fff;
	padding: 0 16px;
	white-space: nowrap;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.02em;
	color: var(--color-orange);
}
.p-bizcycle__steps {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: 60px;
}
.p-bizcycle__step {
	flex: 1;
	position: relative;
	background: var(--color-bg-soft);
	border: 1px solid var(--color-border);
	border-radius: 18px;
	padding: 30px 26px 28px;
	display: flex;
	flex-direction: column;
	gap: 12px;
}
/* ステップ間の進行矢印 (→) */
.p-bizcycle__step:not(:first-child)::before {
	content: "→";
	position: absolute;
	left: -42px;
	top: 34px;
	color: var(--color-orange);
	font-size: 24px;
	font-weight: 700;
	line-height: 1;
}
.p-bizcycle__num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--color-orange), #ff9d1e);
	color: #fff;
	font-weight: 700;
	font-size: 16px;
	box-shadow: 0 8px 18px -8px rgba(242, 138, 0, 0.6);
}
/* 中央のステップ(Spekan開発)はブルーにして、現場とSpekanの噛み合いを示す */
.p-bizcycle__step:nth-child(2) .p-bizcycle__num {
	background: linear-gradient(135deg, var(--color-blue), var(--color-blue-dark));
	box-shadow: 0 8px 18px -8px rgba(22, 127, 224, 0.6);
}
.p-bizcycle__step:nth-child(2) {
	border-color: rgba(22, 127, 224, 0.28);
	background: var(--color-blue-light);
}
.p-bizcycle__step-title {
	font-size: 17px;
	font-weight: 700;
	color: var(--color-navy);
	line-height: 1.5;
}
.p-bizcycle__step-text {
	font-size: 13.5px;
	line-height: 1.95;
	color: var(--color-muted);
}
/* モバイル用の「くりかえし」表示 (PCではブラケットを使うので非表示) */
.p-bizcycle__repeat {
	display: none;
}

/* -------------------------------------------------------------------------
   17. Page: Company
   ------------------------------------------------------------------------- */
.p-company-info {
	background: #fff;
	padding-block: 56px 96px;
}
.p-company-info__layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: 64px;
	align-items: start;
}
.p-company-info__col-title {
	font-size: 22px;
	font-weight: 700;
	color: var(--color-navy);
	letter-spacing: 0.04em;
	margin-bottom: 24px;
	padding-bottom: 12px;
	border-bottom: 1px solid var(--color-border);
}

/* 会社情報 dl */
.p-company-info__dl {
	display: flex;
	flex-direction: column;
}
.p-company-info__row {
	display: grid;
	grid-template-columns: 130px 1fr;
	gap: 16px;
	padding: 16px 4px;
	border-bottom: 1px solid var(--color-border);
	font-size: 14px;
	line-height: 1.8;
}
.p-company-info__dt {
	color: var(--color-muted);
	font-weight: 500;
	font-size: 13px;
	letter-spacing: 0.04em;
}
.p-company-info__dd {
	color: var(--color-text);
	margin: 0;
}

/* 事業内容 list */
.p-company-info__service-list {
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.p-company-info__service-item {
	display: grid;
	grid-template-columns: 56px 1fr auto;
	gap: 16px;
	align-items: center;
	padding: 18px 18px;
	border-radius: 14px;
	background: var(--color-bg-soft);
	border: 1px solid var(--color-border);
	color: inherit;
	text-decoration: none;
	transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}
.p-company-info__service-item:hover {
	transform: translateY(-2px);
	box-shadow: 0 12px 28px rgba(15, 27, 42, 0.08);
	border-color: var(--color-blue);
}
.p-company-info__service-arrow {
	align-self: center;
	color: var(--color-blue);
	font-size: 18px;
	line-height: 1;
	transition: transform 0.2s ease;
}
.p-company-info__service-item:hover .p-company-info__service-arrow {
	transform: translateX(4px);
}
.p-company-info__service-icon {
	width: 56px;
	height: 56px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	/* ロゴ画像が自前の背景（角丸の青）を持つため、枠の白背景・枠線は付けない */
}
.p-company-info__service-icon img { width: 100%; height: 100%; object-fit: contain; }
.p-company-info__service-body {
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.p-company-info__service-title {
	font-size: 15px;
	font-weight: 700;
	color: var(--color-navy);
	line-height: 1.5;
}
.p-company-info__service-text {
	font-size: 13px;
	color: var(--color-muted);
	line-height: 1.7;
}

/* -------------------------------------------------------------------------
   18. Page: News Index
   ------------------------------------------------------------------------- */

/* News用 page-hero モディファイア
   /about と同じ溶け込み方式: 画像をセクションの上・右・下端までブリードさせ、
   左側だけを大きな円弧状にぼかして白背景へ溶け込ませ、テキストを前面に重ねる。
   高さも /about と統一。 */
.c-page-hero--news {
	padding-block: 0; /* 画像をセクション上下端までブリードさせる */
}
.c-page-hero--news .c-page-hero__inner {
	position: static; /* visual をセクション(.c-page-hero)基準で絶対配置する */
	grid-template-columns: minmax(0, 1fr);
	padding-block: 64px 88px; /* テキスト用の上下余白を確保 */
	min-height: 460px;
}
.c-page-hero--news .c-page-hero__text {
	position: relative;
	z-index: 2; /* 画像より前面にテキストを置く */
	max-width: 600px;
}
.c-page-hero--news .c-page-hero__visual {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	width: clamp(440px, 58vw, 1040px);
	margin: 0;
	z-index: 1;
	pointer-events: none;
}
.c-page-hero--news .c-page-hero__visual img {
	width: 100%;
	height: 100%;
	aspect-ratio: auto;
	object-fit: cover;
	border-radius: 0;
	box-shadow: none;
	/* 右端に焦点を置いた大きな楕円グラデで、左側を円弧状に白へフェードさせる */
	-webkit-mask-image: radial-gradient(118% 128% at 100% 44%, #000 44%, rgba(0, 0, 0, 0) 82%);
	        mask-image: radial-gradient(118% 128% at 100% 44%, #000 44%, rgba(0, 0, 0, 0) 82%);
}
/* 横幅が狭くなるとテキストが画像の濃い部分に重なるため、/about と同様に早めに縦積みへ切り替える */
@media (max-width: 900px) {
	.c-page-hero--news {
		padding-block: 40px 56px; /* 画像がフロー内カードに戻るので余白を復帰 */
	}
	.c-page-hero--news .c-page-hero__inner {
		position: relative;
		grid-template-columns: 1fr;
		padding-block: 0;
		min-height: auto;
	}
	.c-page-hero--news .c-page-hero__text { max-width: none; }
	.c-page-hero--news .c-page-hero__visual {
		position: static;
		width: auto;
		margin: 0;
	}
	.c-page-hero--news .c-page-hero__visual img {
		height: auto;
		aspect-ratio: 16 / 10;
		border-radius: 16px;
		-webkit-mask-image: none;
		        mask-image: none;
	}
}

/* News list section */
.p-news-list {
	background: #fff;
	padding-block: 56px 32px;
}
.p-news-list__items {
	display: flex;
	flex-direction: column;
	border-top: 1px solid var(--color-border);
}
.p-news-list__item {
	border-bottom: 1px solid var(--color-border);
}
.p-news-list__link {
	display: grid;
	grid-template-columns: 120px minmax(0, 1fr) 32px;
	gap: 24px;
	align-items: center;
	padding: 20px 8px;
	font-size: 14px;
	color: var(--color-text);
	transition: color 0.2s ease, background 0.2s ease;
}
.p-news-list__link:hover {
	color: var(--color-blue);
	background: var(--color-bg-soft);
}
.p-news-list__date {
	color: var(--color-muted);
	font-size: 13px;
	letter-spacing: 0.04em;
	font-feature-settings: "tnum";
	font-weight: 500;
}
.p-news-list__title-text {
	color: inherit;
	line-height: 1.7;
	overflow: hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}
.p-news-list__arrow {
	width: 28px;
	height: 28px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: var(--color-blue-light);
	color: var(--color-blue);
	transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease;
	justify-self: end;
}
.p-news-list__link:hover .p-news-list__arrow {
	background: var(--color-blue);
	color: #fff;
	transform: translateX(2px);
}
.p-news-list__empty {
	padding: 40px 0;
	text-align: center;
	color: var(--color-muted);
}

/* News pagination — the_posts_pagination() の出力に合わせる */
.p-news-pagination {
	padding: 40px 0 24px;
	display: flex;
	justify-content: center;
}
.p-news-pagination .screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}
.p-news-pagination .nav-links {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 10px 16px;
	background: var(--color-bg-soft);
	border-radius: var(--radius-pill);
}
.p-news-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	height: 36px;
	padding: 0 10px;
	border-radius: var(--radius-pill);
	font-size: 14px;
	font-weight: 500;
	color: var(--color-navy);
	letter-spacing: 0.02em;
	transition: background 0.2s ease, color 0.2s ease;
}
.p-news-pagination a.page-numbers:hover {
	background: #fff;
	color: var(--color-blue);
}
.p-news-pagination .page-numbers.current {
	background: var(--color-blue);
	color: #fff;
	font-weight: 700;
}
.p-news-pagination .page-numbers.dots {
	background: transparent;
	color: var(--color-muted);
	padding: 0 4px;
	min-width: auto;
}
.p-news-pagination .page-numbers.prev,
.p-news-pagination .page-numbers.next {
	background: #fff;
	color: var(--color-blue);
	min-width: 36px;
	padding: 0;
}
.p-news-pagination .page-numbers.prev:hover,
.p-news-pagination .page-numbers.next:hover {
	background: var(--color-blue);
	color: #fff;
}
.p-news-pagination__chevron {
	width: 12px;
	height: 12px;
	display: inline-block;
	background: currentColor;
	-webkit-mask: url("../images/decor/chevron-right.svg") no-repeat center / contain;
	mask: url("../images/decor/chevron-right.svg") no-repeat center / contain;
}
.p-news-pagination__chevron--prev { transform: scaleX(-1); }

/* -------------------------------------------------------------------------
   19. Page: News Detail
   ------------------------------------------------------------------------- */
.p-news-detail {
	padding-block: 24px 64px;
	background: #fff;
}
.p-news-detail__container {
	width: 100%;
	max-width: var(--container);
	margin-inline: auto;
	padding-inline: 32px;
}

.p-news-detail__head {
	margin-top: 24px;
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.p-news-detail__date {
	font-size: 14px;
	font-weight: 700;
	color: var(--color-blue);
	letter-spacing: 0.04em;
	font-feature-settings: "tnum";
}
.p-news-detail__title {
	font-size: clamp(22px, 2.4vw, 30px);
	font-weight: 700;
	line-height: 1.5;
	color: var(--color-navy);
	letter-spacing: 0.02em;
}

/* Body grid (left main + right share) */
.p-news-detail__main {
	margin-top: 32px;
	display: grid;
	grid-template-columns: minmax(0, 1fr) 88px;
	gap: 48px;
	align-items: start;
}
.p-news-detail__body { min-width: 0; }
.p-news-detail__visual {
	border-radius: 16px;
	overflow: hidden;
	background: var(--color-bg-soft);
	aspect-ratio: 16 / 9;
}
.p-news-detail__visual img,
.p-news-detail__visual :is(img, picture) {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* Share aside */
.p-news-detail__share {
	position: sticky;
	top: 96px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 18px;
}
.p-news-detail__share-label {
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.18em;
	color: var(--color-muted);
}
.p-news-detail__share-list {
	display: flex;
	flex-direction: column;
	gap: 14px;
}
.p-news-detail__share-btn {
	width: 40px;
	height: 40px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: #fff;
	border: 1px solid var(--color-border);
	color: var(--color-navy);
	transition: background 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
	cursor: pointer;
}
.p-news-detail__share-btn:hover {
	background: var(--color-blue-light);
	border-color: var(--color-blue);
	transform: translateY(-2px);
}
.p-news-detail__share-btn img { width: 16px; height: 16px; }

/* Article content (the_content) */
.p-news-detail__content {
	margin-top: 32px;
	font-size: 15px;
	line-height: 2;
	color: var(--color-text);
}
.p-news-detail__content > * + * { margin-top: 1.4em; }
.p-news-detail__content p { margin: 0; }
.p-news-detail__content h2 {
	margin-top: 2.4em;
	padding: 4px 0 4px 14px;
	border-left: 4px solid var(--color-blue);
	font-size: 18px;
	font-weight: 700;
	line-height: 1.6;
	color: var(--color-navy);
}
.p-news-detail__content h3 {
	margin-top: 2em;
	font-size: 16px;
	font-weight: 700;
	color: var(--color-navy);
}
.p-news-detail__content a {
	color: var(--color-blue);
	text-decoration: underline;
	text-underline-offset: 3px;
}
.p-news-detail__content a:hover { color: var(--color-blue-dark); }
.p-news-detail__content ul,
.p-news-detail__content ol {
	padding-left: 4px;
	display: flex;
	flex-direction: column;
	gap: 14px;
}
.p-news-detail__content ul > li {
	position: relative;
	padding-left: 22px;
	font-weight: 700;
	color: var(--color-navy);
	line-height: 1.7;
}
.p-news-detail__content ul > li::before {
	content: "";
	position: absolute;
	left: 4px;
	top: 0.7em;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--color-blue);
}
.p-news-detail__content ul > li > :not(strong):not(b) {
	font-weight: 400;
	color: var(--color-text);
}
.p-news-detail__content ol {
	counter-reset: news-ol;
	list-style: none;
}
.p-news-detail__content ol > li {
	position: relative;
	padding-left: 28px;
	counter-increment: news-ol;
}
.p-news-detail__content ol > li::before {
	content: counter(news-ol) ".";
	position: absolute;
	left: 4px;
	top: 0;
	font-weight: 700;
	color: var(--color-blue);
}
.p-news-detail__content blockquote {
	margin: 0;
	padding: 16px 20px;
	border-left: 3px solid var(--color-blue);
	background: var(--color-bg-soft);
	color: var(--color-muted);
	border-radius: 0 8px 8px 0;
}
.p-news-detail__content img {
	border-radius: 12px;
	width: 100%;
	height: auto;
}
.p-news-detail__content table {
	width: 100%;
	border-collapse: collapse;
	font-size: 14px;
}
.p-news-detail__content table th,
.p-news-detail__content table td {
	border: 1px solid var(--color-border);
	padding: 10px 14px;
	text-align: left;
	vertical-align: top;
}
.p-news-detail__content table th {
	background: var(--color-bg-soft);
	font-weight: 700;
	color: var(--color-navy);
}

/* Prev/Next nav */
.p-news-detail__nav {
	margin-top: 64px;
	display: grid;
	grid-template-columns: 1fr 1fr;
	border: 1px solid var(--color-border);
	border-radius: 16px;
	background: #fff;
	box-shadow: 0 4px 16px rgba(15, 27, 42, 0.04);
	overflow: hidden;
}
.p-news-detail__nav-item {
	display: flex;
	align-items: center;
	gap: 16px;
	padding: 20px 24px;
	color: var(--color-navy);
	transition: background 0.2s ease;
	min-height: 88px;
}
.p-news-detail__nav-item:hover:not(.p-news-detail__nav-item--empty) {
	background: var(--color-bg-soft);
}
.p-news-detail__nav-item:nth-child(2) {
	border-left: 1px solid var(--color-border);
}
.p-news-detail__nav-item--next {
	justify-content: flex-end;
	text-align: right;
}
.p-news-detail__nav-item--empty {
	background: var(--color-bg-soft);
	pointer-events: none;
}
.p-news-detail__nav-arrow {
	flex: 0 0 auto;
	width: 32px;
	height: 32px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.p-news-detail__nav-text {
	display: flex;
	flex-direction: column;
	gap: 4px;
	min-width: 0;
}
.p-news-detail__nav-date {
	font-size: 13px;
	font-weight: 700;
	color: var(--color-blue);
	letter-spacing: 0.04em;
}
.p-news-detail__nav-title {
	font-size: 14px;
	color: var(--color-navy);
	line-height: 1.5;
}
/* Related posts */
.p-news-detail__related { margin-top: 64px; }
.p-news-detail__related-title {
	font-size: 18px;
	font-weight: 700;
	color: var(--color-navy);
	margin-bottom: 20px;
}
.p-news-detail__related-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 20px;
}
.p-news-detail__related-card {
	display: flex;
	flex-direction: column;
	border: 1px solid var(--color-border);
	border-radius: 14px;
	background: #fff;
	overflow: hidden;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.p-news-detail__related-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 14px 28px rgba(15, 27, 42, 0.08);
}
.p-news-detail__related-image {
	aspect-ratio: 16 / 9;
	background: var(--color-bg-soft);
	overflow: hidden;
}
.p-news-detail__related-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.p-news-detail__related-body {
	position: relative;
	padding: 16px 18px 20px;
	display: flex;
	flex-direction: column;
	gap: 8px;
	flex: 1;
}
.p-news-detail__related-date {
	font-size: 12px;
	font-weight: 700;
	color: var(--color-blue);
	letter-spacing: 0.04em;
	font-feature-settings: "tnum";
}
.p-news-detail__related-heading {
	font-size: 14px;
	font-weight: 500;
	color: var(--color-navy);
	line-height: 1.7;
}
/* Copy toast */
.p-news-detail__toast {
	position: fixed;
	bottom: 32px;
	left: 50%;
	transform: translateX(-50%);
	background: var(--color-navy);
	color: #fff;
	font-size: 13px;
	padding: 12px 20px;
	border-radius: var(--radius-pill);
	box-shadow: 0 12px 30px rgba(15, 27, 42, 0.25);
	z-index: 200;
	opacity: 0;
	transition: opacity 0.2s ease;
	pointer-events: none;
}
.p-news-detail__toast.is-visible { opacity: 1; }

/* -------------------------------------------------------------------------
   20. Page: Contact
   ------------------------------------------------------------------------- */
.u-visually-hidden {
	position: absolute !important;
	width: 1px; height: 1px;
	padding: 0; margin: -1px;
	overflow: hidden; clip: rect(0, 0, 0, 0);
	white-space: nowrap; border: 0;
}

/* hero modifier for contact */
/* /about の Page Hero と同じ溶かし方に統一:
   画像をセクションの上・右・下端までブリードさせ、左側だけを大きな円弧状に
   ぼかして白背景へ溶け込ませることで、一枚絵として馴染ませる (下端のハードな
   切れもなくなる)。総高さも /about と同じ 460px に揃う。 */
.c-page-hero--contact {
	padding-block: 0; /* 画像をセクション上下端までブリードさせる */
}
.c-page-hero--contact .c-page-hero__inner {
	position: static; /* visual をセクション(.c-page-hero)基準で絶対配置する */
	grid-template-columns: minmax(0, 1fr);
	padding-block: 64px 88px; /* テキスト用の上下余白を確保 */
	min-height: 460px;
}
.c-page-hero--contact .c-page-hero__text {
	position: relative;
	z-index: 2; /* 画像より前面にテキストを置く */
	max-width: 600px;
}
.c-page-hero--contact .c-page-hero__visual {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	width: clamp(440px, 58vw, 1040px);
	margin: 0;
	z-index: 1;
	pointer-events: none;
}
.c-page-hero--contact .c-page-hero__visual img {
	width: 100%;
	height: 100%;
	aspect-ratio: auto;
	object-fit: cover;
	border-radius: 0;
	box-shadow: none;
	/* 右端に焦点を置いた大きな楕円グラデで、左側を円弧状に白へフェードさせる */
	-webkit-mask-image: radial-gradient(118% 128% at 100% 44%, #000 44%, rgba(0, 0, 0, 0) 82%);
	        mask-image: radial-gradient(118% 128% at 100% 44%, #000 44%, rgba(0, 0, 0, 0) 82%);
}
/* 横幅が狭くなるとテキストが画像の濃い部分に重なるため、早めに縦積みへ切り替える */
@media (max-width: 900px) {
	.c-page-hero--contact {
		padding-block: 40px 56px; /* 画像がフロー内カードに戻るので余白を復帰 */
	}
	.c-page-hero--contact .c-page-hero__inner {
		position: relative;
		grid-template-columns: 1fr;
		padding-block: 0;
		min-height: auto;
	}
	.c-page-hero--contact .c-page-hero__text { max-width: none; }
	.c-page-hero--contact .c-page-hero__visual {
		position: static;
		width: auto;
		margin: 0;
	}
	.c-page-hero--contact .c-page-hero__visual img {
		height: auto;
		aspect-ratio: 16 / 10;
		border-radius: 16px;
		-webkit-mask-image: none;
		        mask-image: none;
	}
}

.p-contact-main {
	background: var(--color-bg-soft);
	padding-block: 56px 80px;
}
.p-contact-main__inner {
	display: grid;
	grid-template-columns: minmax(0, 320px) minmax(0, 1fr);
	gap: 32px;
	align-items: start;
}

/* 左サイドバー */
.p-contact-side {
	display: flex;
	flex-direction: column;
	gap: 20px;
	position: sticky;
	top: 88px;
}

.p-contact-types {
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: 18px;
	padding: 22px 18px;
	box-shadow: 0 8px 28px rgba(15, 27, 42, 0.04);
}
.p-contact-types__title {
	font-size: 15px;
	font-weight: 700;
	color: var(--color-navy);
	padding: 0 6px 14px;
	margin-bottom: 8px;
	border-bottom: 1px solid var(--color-border);
}
.p-contact-types__list {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

/* お問い合わせ種類カード */
.p-contact-type-card {
	width: 100%;
	display: grid;
	grid-template-columns: 44px 1fr 16px;
	align-items: center;
	gap: 12px;
	padding: 10px 12px;
	border: 1px solid transparent;
	border-radius: 12px;
	background: #fff;
	text-align: left;
	transition: background-color 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
}
.p-contact-type-card:hover {
	background: var(--color-bg-soft);
	border-color: var(--color-border);
	transform: translateX(2px);
}
.p-contact-type-card[aria-pressed="true"] {
	background: var(--color-blue-light);
	border-color: var(--color-blue);
}
.p-contact-type-card[aria-pressed="true"] .p-contact-type-card__chev {
	color: var(--color-blue);
	transform: translateX(2px);
}
.p-contact-type-card__icon {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--color-bg-soft);
	flex-shrink: 0;
}
.p-contact-type-card__icon img {
	width: 28px;
	height: 28px;
	object-fit: contain;
}
.p-contact-type-card--blue   .p-contact-type-card__icon { background: #EAF6FF; }
.p-contact-type-card--orange .p-contact-type-card__icon { background: #FFF4E8; }
.p-contact-type-card--green  .p-contact-type-card__icon { background: #E8F8EC; }
.p-contact-type-card--purple .p-contact-type-card__icon { background: #F3EAFB; }
.p-contact-type-card--sky    .p-contact-type-card__icon { background: #E6F4FB; }
.p-contact-type-card--gray   .p-contact-type-card__icon { background: #F0F2F5; }
/* /company と同じロゴ画像 (自前背景つき) は色付き円枠を外し、ロゴをそのまま表示 */
.p-contact-type-card .p-contact-type-card__icon--logo {
	background: transparent;
}
.p-contact-type-card__icon--logo img {
	width: 100%;
	height: 100%;
}
.p-contact-type-card__label {
	font-size: 13.5px;
	font-weight: 500;
	color: var(--color-navy);
	line-height: 1.4;
}
.p-contact-type-card__chev {
	color: var(--color-muted);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: color 0.18s ease, transform 0.18s ease;
}
.p-contact-type-card__chev img { width: 14px; height: 14px; }

/* 電話案内カード */
.p-contact-phone-card {
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: 18px;
	padding: 20px;
	box-shadow: 0 8px 28px rgba(15, 27, 42, 0.04);
	display: flex;
	flex-direction: column;
	gap: 14px;
}
.p-contact-phone-card__head {
	display: flex;
	align-items: center;
	gap: 12px;
}
.p-contact-phone-card__icon {
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: var(--color-blue-light);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.p-contact-phone-card__icon img { width: 28px; height: 28px; }
.p-contact-phone-card__heading {
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.p-contact-phone-card__label {
	font-size: 13px;
	font-weight: 700;
	color: var(--color-navy);
	line-height: 1.4;
}
.p-contact-phone-card__hours {
	font-size: 11px;
	color: var(--color-muted);
	line-height: 1.4;
}
.p-contact-phone-card__tel {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	font-size: 22px;
	font-weight: 700;
	color: var(--color-blue);
	letter-spacing: 0.02em;
	font-feature-settings: "tnum";
	padding: 8px 0;
	border-top: 1px dashed var(--color-border);
}
.p-contact-phone-card__tel:hover { color: var(--color-blue-dark); }

/* 右メイン */
.p-contact-body {
	display: flex;
	flex-direction: column;
	gap: 28px;
	/* sticky ヘッダー(約68px)分の余白。確認/送信結果へスクロールした際に隠れないように */
	scroll-margin-top: 88px;
}

/* 送信結果バナー (フォームタイトル上部) */
.p-contact-alert {
	display: flex;
	align-items: flex-start;
	gap: 16px;
	padding: 20px 24px;
	border-radius: 16px;
	border: 1px solid var(--color-border);
	background: #fff;
	box-shadow: 0 10px 30px rgba(15, 27, 42, 0.06);
	opacity: 0;
	transform: translateY(-8px);
	transition: opacity 0.35s ease, transform 0.35s ease;
}
.p-contact-alert.is-visible {
	opacity: 1;
	transform: translateY(0);
}
.p-contact-alert__icon {
	flex-shrink: 0;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: #fff;
}
.p-contact-alert__body { padding-top: 2px; }
.p-contact-alert__title {
	font-size: 16px;
	font-weight: 700;
	color: var(--color-navy);
	line-height: 1.5;
}
.p-contact-alert__text {
	margin-top: 4px;
	font-size: 13px;
	color: var(--color-muted);
	line-height: 1.7;
}
/* success */
.p-contact-alert--success {
	background: #F1FBF4;
	border-color: #C8ECD4;
}
.p-contact-alert--success .p-contact-alert__icon {
	background: linear-gradient(135deg, #2BB673, #1F9D63);
	box-shadow: 0 6px 16px rgba(31, 157, 99, 0.3);
}
/* error */
.p-contact-alert--error {
	background: var(--color-orange-light);
	border-color: #FBD8AC;
}
.p-contact-alert--error .p-contact-alert__icon {
	background: linear-gradient(135deg, #F28A00, #FF9D1E);
	box-shadow: 0 6px 16px rgba(242, 138, 0, 0.3);
}

.p-contact-form {
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: 22px;
	padding: 36px 40px;
	box-shadow: 0 8px 28px rgba(15, 27, 42, 0.05);
}
.p-contact-form__head {
	margin-bottom: 28px;
	padding-bottom: 20px;
	border-bottom: 1px solid var(--color-border);
}
.p-contact-form__title {
	font-size: 22px;
	font-weight: 700;
	color: var(--color-navy);
	line-height: 1.4;
}
.p-contact-form__lead {
	margin-top: 6px;
	font-size: 13px;
	color: var(--color-muted);
}
.p-contact-form__notice {
	font-size: 12px;
	color: var(--color-orange);
	background: var(--color-orange-light);
	border-radius: 8px;
	padding: 10px 14px;
	margin-bottom: 20px;
}

.p-contact-form__row { margin-bottom: 18px; }
.p-contact-form__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 14px 20px;
	margin-bottom: 18px;
}
.p-contact-form__grid .p-contact-form__row { margin-bottom: 0; }

.p-contact-form__label {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: 13px;
	font-weight: 700;
	color: var(--color-navy);
	margin-bottom: 8px;
}
.p-contact-form__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 10px;
	font-weight: 700;
	padding: 2px 8px;
	border-radius: var(--radius-pill);
	letter-spacing: 0.04em;
	line-height: 1.6;
}
.p-contact-form__badge--required {
	color: #fff;
	background: var(--color-orange);
}
.p-contact-form__badge--optional {
	color: var(--color-muted);
	background: var(--color-bg-soft);
	border: 1px solid var(--color-border);
}

/* 共通フォームコントロール (フォールバック + CF7 出力共通) */
.p-contact-form input[type="text"],
.p-contact-form input[type="email"],
.p-contact-form input[type="tel"],
.p-contact-form input[type="url"],
.p-contact-form input[type="number"],
.p-contact-form select,
.p-contact-form textarea {
	width: 100%;
	font-family: inherit;
	font-size: 14px;
	color: var(--color-text);
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: 10px;
	padding: 12px 14px;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	box-sizing: border-box;
	line-height: 1.6;
}
.p-contact-form input:focus,
.p-contact-form select:focus,
.p-contact-form textarea:focus {
	outline: none;
	border-color: var(--color-blue);
	box-shadow: 0 0 0 3px rgba(22, 127, 224, 0.15);
}
.p-contact-form select {
	appearance: none;
	-webkit-appearance: none;
	background-image: linear-gradient(45deg, transparent 50%, var(--color-blue) 50%),
		linear-gradient(135deg, var(--color-blue) 50%, transparent 50%);
	background-position: calc(100% - 18px) 50%, calc(100% - 12px) 50%;
	background-size: 6px 6px, 6px 6px;
	background-repeat: no-repeat;
	padding-right: 36px;
}
.p-contact-form textarea {
	min-height: 160px;
	resize: vertical;
}

/* CF7 が <p> でラップしてもボトムマージンが破綻しないよう */
.p-contact-form .wpcf7-form p { margin: 0 0 18px; font-size: 13px; }
.p-contact-form .wpcf7-form p:last-of-type { margin-bottom: 0; }
.p-contact-form .wpcf7-form label {
	display: block;
	font-size: 13px;
	font-weight: 700;
	color: var(--color-navy);
	margin-bottom: 6px;
}
.p-contact-form .wpcf7-list-item { display: inline-flex; align-items: center; gap: 8px; margin: 0; }
.p-contact-form .wpcf7-list-item input { width: 18px; height: 18px; accent-color: var(--color-blue); }
.p-contact-form .wpcf7-not-valid-tip { color: var(--color-orange); font-size: 12px; margin-top: 6px; display: block; }
/* CF7 標準のレスポンス出力は非表示。送信結果は上部の .p-contact-alert に集約表示する */
.p-contact-form .wpcf7-response-output {
	display: none;
}

/* 同意チェック */
.p-contact-form__consent {
	margin: 32px 0 4px;
	padding: 18px 20px;
	background: var(--color-bg-soft);
	border-radius: 12px;
	font-size: 13px;
	color: var(--color-text);
}
.p-contact-form__consent label {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	cursor: pointer;
}
.p-contact-form__consent input[type="checkbox"] {
	width: 18px;
	height: 18px;
	accent-color: var(--color-blue);
	margin: 0;
}
.p-contact-form__policy {
	color: var(--color-blue);
	border-bottom: 1px solid currentColor;
}

/* 送信ボタン */
.p-contact-form__actions {
	margin-top: 24px;
	display: flex;
	justify-content: center;
}
.p-contact-form .wpcf7-submit,
.p-contact-form__submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	min-width: 320px;
	min-height: 56px;
	padding: 14px 32px;
	border-radius: var(--radius-pill);
	background: linear-gradient(90deg, #F28A00, #FF9D1E);
	color: #fff;
	font-weight: 700;
	font-size: 15px;
	letter-spacing: 0.04em;
	cursor: pointer;
	border: 0;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.p-contact-form .wpcf7-submit:hover,
.p-contact-form__submit:hover {
	transform: translateY(-2px);
	box-shadow: 0 12px 28px rgba(242, 138, 0, 0.3);
}
.p-contact-form__submit-arrow {
	width: 28px;
	height: 28px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.25);
	font-size: 13px;
}

/* 入力 → 確認 → 送信 の2ステップ */
/* クライアント側の必須チェック表示 */
.p-contact-form .is-confirm-invalid {
	border-color: var(--color-orange);
	box-shadow: 0 0 0 3px rgba(242, 138, 0, 0.12);
}
.p-contact-confirm-tip {
	display: block;
	color: var(--color-orange);
	font-size: 12px;
	font-weight: 700;
	margin-top: 6px;
}

/* ステップ表示切替 */
.p-contact-confirm { display: none; }
.wpcf7-form.is-confirming .p-contact-form__fields { display: none; }
.wpcf7-form.is-confirming .p-contact-confirm { display: block; }

.p-contact-confirm__title {
	font-size: 18px;
	font-weight: 700;
	color: var(--color-navy);
}
.p-contact-confirm__lead {
	margin-top: 6px;
	margin-bottom: 32px;
	font-size: 13px;
	color: var(--color-muted);
}
.p-contact-confirm__list {
	/* margin-top で文言と入力内容の間に余白を確保
	   (リード文の margin-bottom は CF7 の p:last-of-type ルールで打ち消されるため) */
	margin: 28px 0 0;
	border: 1px solid var(--color-border);
	border-radius: 12px;
	overflow: hidden;
}
.p-contact-confirm__term {
	margin: 0;
	padding: 12px 16px 4px;
	font-size: 12px;
	font-weight: 700;
	color: var(--color-muted);
	background: var(--color-bg-soft);
	border-top: 1px solid var(--color-border);
}
.p-contact-confirm__list .p-contact-confirm__term:first-child { border-top: 0; }
.p-contact-confirm__desc {
	margin: 0;
	padding: 4px 16px 14px;
	font-size: 14px;
	color: var(--color-text);
	background: var(--color-bg-soft);
	word-break: break-word;
}
.p-contact-confirm__desc--pre { white-space: pre-wrap; }

.p-contact-confirm__actions {
	position: relative;
	gap: 16px;
	flex-wrap: wrap;
}
/* CF7 のスピナーはレイアウトから外して右端へ。ボタン2つを厳密に中央へ揃える */
.p-contact-confirm__actions .wpcf7-spinner {
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	margin: 0;
}
.p-contact-confirm__back {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 200px;
	min-height: 56px;
	padding: 14px 28px;
	border-radius: var(--radius-pill);
	background: #fff;
	color: var(--color-navy);
	font-weight: 700;
	font-size: 15px;
	border: 1px solid var(--color-border);
	cursor: pointer;
	transition: background 0.2s ease;
}
.p-contact-confirm__back:hover { background: var(--color-bg-soft); }

/* -------------------------------------------------------------------------
   21. Page: About — Page Hero modifier
   ------------------------------------------------------------------------- */
/* About Hero: 画像はセクションの上・右・下端までブリードさせ、左側だけを
   大きな円弧状にぼかして白背景へ溶け込ませることで、一枚絵として馴染ませる */
.c-page-hero--about {
	padding-block: 0; /* 画像をセクション上下端までブリードさせる */
}
.c-page-hero--about .c-page-hero__inner {
	position: static; /* visual をセクション(.c-page-hero)基準で絶対配置する */
	grid-template-columns: minmax(0, 1fr);
	padding-block: 64px 88px; /* テキスト用の上下余白を確保 */
	min-height: 460px;
}
.c-page-hero--about .c-page-hero__text {
	position: relative;
	z-index: 2; /* 画像より前面にテキストを置く */
	max-width: 600px;
}
/* タイトルを1行に収める */
.c-page-hero--about .c-page-hero__title {
	font-size: clamp(34px, 3.4vw, 50px);
	white-space: nowrap;
}
.c-page-hero--about .c-page-hero__visual {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	width: clamp(440px, 58vw, 1040px);
	margin: 0;
	z-index: 1;
	pointer-events: none;
}
.c-page-hero--about .c-page-hero__visual img {
	width: 100%;
	height: 100%;
	aspect-ratio: auto;
	object-fit: cover;
	border-radius: 0;
	box-shadow: none;
	/* 右端に焦点を置いた大きな楕円グラデで、左側を円弧状に白へフェードさせる */
	-webkit-mask-image: radial-gradient(118% 128% at 100% 44%, #000 44%, rgba(0, 0, 0, 0) 82%);
	        mask-image: radial-gradient(118% 128% at 100% 44%, #000 44%, rgba(0, 0, 0, 0) 82%);
}
/* 横幅が狭くなるとテキストが画像の濃い部分に重なるため、早めに縦積みへ切り替える */
@media (max-width: 900px) {
	.c-page-hero--about {
		padding-block: 40px 56px; /* 画像がフロー内カードに戻るので余白を復帰 */
	}
	.c-page-hero--about .c-page-hero__inner {
		position: relative;
		grid-template-columns: 1fr;
		padding-block: 0;
		min-height: auto;
	}
	.c-page-hero--about .c-page-hero__text { max-width: none; }
	.c-page-hero--about .c-page-hero__title {
		font-size: clamp(28px, 5.2vw, 40px);
		white-space: normal;
	}
	.c-page-hero--about .c-page-hero__visual {
		position: static;
		width: auto;
		margin: 0;
	}
	.c-page-hero--about .c-page-hero__visual img {
		height: auto;
		aspect-ratio: 16 / 10;
		border-radius: 16px;
		-webkit-mask-image: none;
		        mask-image: none;
	}
}

/* Page: Company — Hero
   /about と同じ溶け込み方式: 画像をセクションの上・右・下端までブリードさせ、
   左側だけを大きな円弧状にぼかして白背景へ溶け込ませ、テキストを前面に重ねる。
   高さも /about と統一。フェードは about より強めにして、より大きく溶かす。 */
.c-page-hero--company {
	padding-block: 0; /* 画像をセクション上下端までブリードさせる */
}
.c-page-hero--company .c-page-hero__inner {
	position: static; /* visual を .c-page-hero 基準で絶対配置する */
	grid-template-columns: minmax(0, 1fr);
	padding-block: 64px 88px;
	min-height: 460px; /* /about と統一 */
}
.c-page-hero--company .c-page-hero__text {
	position: relative;
	z-index: 2; /* 画像より前面にテキストを置く */
	max-width: 600px;
}
.c-page-hero--company .c-page-hero__visual {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	width: clamp(440px, 58vw, 1040px);
	margin: 0;
	z-index: 1;
	pointer-events: none;
}
.c-page-hero--company .c-page-hero__visual img {
	width: 100%;
	height: 100%;
	aspect-ratio: auto;
	object-fit: cover;
	border-radius: 0;
	box-shadow: none;
	/* about(#000 44% → 82%)よりフェード開始を早め・範囲を広げ、より大きく溶かす */
	-webkit-mask-image: radial-gradient(120% 132% at 100% 44%, #000 34%, rgba(0, 0, 0, 0) 80%);
	        mask-image: radial-gradient(120% 132% at 100% 44%, #000 34%, rgba(0, 0, 0, 0) 80%);
}
/* 横幅が狭くなるとテキストが画像の濃い部分に重なるため、早めに縦積みへ切り替える */
@media (max-width: 900px) {
	.c-page-hero--company {
		padding-block: 40px 56px; /* 画像がフロー内カードに戻るので余白を復帰 */
	}
	.c-page-hero--company .c-page-hero__inner {
		position: relative;
		grid-template-columns: 1fr;
		padding-block: 0;
		min-height: auto;
	}
	.c-page-hero--company .c-page-hero__text { max-width: none; }
	.c-page-hero--company .c-page-hero__visual {
		position: static;
		width: auto;
		margin: 0;
	}
	.c-page-hero--company .c-page-hero__visual img {
		height: auto;
		aspect-ratio: 16 / 10;
		border-radius: 16px;
		-webkit-mask-image: none;
		        mask-image: none;
	}
}

/* 事業紹介Hero: /about・/company と同じ溶け込み方式に統一する。
   ビジュアルをセクションの上・右・下端までブリードさせ、左側を大きな円弧状に
   白背景へフェードさせ、テキストを前面に重ねる。高さも /about と統一(460px)。 */
.c-page-hero--business {
	padding-block: 0; /* 画像をセクション上下端までブリードさせる */
}
.c-page-hero--business .c-page-hero__inner {
	position: static; /* visual を .c-page-hero 基準で絶対配置する */
	grid-template-columns: minmax(0, 1fr);
	padding-block: 64px 88px;
	min-height: 460px;
}
.c-page-hero--business .c-page-hero__text {
	position: relative;
	z-index: 2; /* 画像より前面にテキストを置く */
	max-width: 600px;
}
.c-page-hero--business .c-page-hero__visual {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	width: clamp(440px, 58vw, 1040px);
	margin: 0;
	z-index: 1;
	pointer-events: none;
}
.c-page-hero--business .c-page-hero__visual img {
	width: 100%;
	height: 100%;
	aspect-ratio: auto;
	/* 透過デバイス画像なので contain で全体を保ち、右寄せで配置する */
	object-fit: contain;
	object-position: right center;
	border-radius: 0;
	box-shadow: none;
	/* 右端に焦点を置いた大きな楕円グラデで、左側を円弧状に白へフェードさせる */
	-webkit-mask-image: radial-gradient(118% 128% at 100% 44%, #000 44%, rgba(0, 0, 0, 0) 82%);
	        mask-image: radial-gradient(118% 128% at 100% 44%, #000 44%, rgba(0, 0, 0, 0) 82%);
}
/* 横幅が狭くなるとテキストが画像の濃い部分に重なるため、早めに縦積みへ切り替える */
@media (max-width: 900px) {
	.c-page-hero--business {
		padding-block: 40px 56px; /* 画像がフロー内カードに戻るので余白を復帰 */
	}
	.c-page-hero--business .c-page-hero__inner {
		position: relative;
		grid-template-columns: 1fr;
		padding-block: 0;
		min-height: auto;
	}
	.c-page-hero--business .c-page-hero__text { max-width: none; }
	.c-page-hero--business .c-page-hero__visual {
		position: static;
		width: auto;
		margin: 0;
	}
	.c-page-hero--business .c-page-hero__visual img {
		height: auto;
		aspect-ratio: 16 / 10;
		object-fit: contain;
		-webkit-mask-image: none;
		        mask-image: none;
	}
}

/* -------------------------------------------------------------------------
   Page Hero: 事業詳細 (一覧の事業紹介Heroと差別化したアプリ画面ショー)
   ------------------------------------------------------------------------- */
.c-page-hero--business-detail {
	padding-block: 64px 84px;
	background: linear-gradient(168deg, #ffffff 0%, #f1f7ff 100%);
}
/* 装飾を周回ラインからドットグリッドへ差し替え、上端へ向けてフェード */
.c-page-hero--business-detail::before {
	background-image: radial-gradient(circle, rgba(22, 127, 224, 0.16) 1.4px, transparent 1.6px);
	background-repeat: repeat;
	background-position: 0 0;
	background-size: 22px 22px;
	opacity: 1;
	-webkit-mask-image: linear-gradient(135deg, rgba(0, 0, 0, 0.9) 0%, transparent 62%);
	mask-image: linear-gradient(135deg, rgba(0, 0, 0, 0.9) 0%, transparent 62%);
}
.c-page-hero--business-detail .c-page-hero__inner {
	min-height: 420px;
}
/* 既定のビジュアル: 写真/画像を浮遊カードで見せ、背面に淡いアクセントパネルを覗かせる
   (Spekan は下記でブラウザ風フレームに上書き) */
.c-page-hero--business-detail .c-page-hero__visual {
	position: relative;
	isolation: isolate;
}
.c-page-hero--business-detail .c-page-hero__visual::after {
	content: "";
	position: absolute;
	inset: 22px -18px -18px 24px;
	border-radius: 20px;
	background: linear-gradient(135deg, rgba(22, 127, 224, 0.14), rgba(242, 138, 0, 0.12));
	z-index: -1;
}
.c-page-hero--business-detail .c-page-hero__visual img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 16px;
	border: 1px solid rgba(15, 27, 42, 0.07);
	box-shadow:
		0 28px 56px -28px rgba(15, 27, 42, 0.32),
		0 8px 20px -12px rgba(15, 27, 42, 0.12);
}

/* Spekan: アプリ画面をブラウザウィンドウ風フレームで見せる + ブルーアクセント */
.c-page-hero--spekan .c-page-hero__eyebrow {
	color: var(--color-blue);
}
.c-page-hero--spekan .c-page-hero__visual {
	padding-top: 38px;
	background: #fff;
	border: 1px solid rgba(15, 27, 42, 0.08);
	border-radius: 14px;
	overflow: hidden;
	box-shadow:
		0 32px 60px -24px rgba(11, 63, 117, 0.34),
		0 10px 24px -12px rgba(22, 127, 224, 0.16);
}
/* ウィンドウのタイトルバー */
.c-page-hero--spekan .c-page-hero__visual::before {
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 38px;
	background: #f4f7fb;
	border-bottom: 1px solid rgba(15, 27, 42, 0.07);
	z-index: 1;
}
/* タイトルバーの信号機ドット(浮遊パネルの ::after を上書き) */
.c-page-hero--spekan .c-page-hero__visual::after {
	content: "";
	position: absolute;
	inset: 14px auto auto 16px;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: #ff5f57;
	box-shadow: 18px 0 0 #febc2e, 36px 0 0 #28c840;
	z-index: 2;
}
.c-page-hero--spekan .c-page-hero__visual img {
	position: relative;
	border-radius: 0;
	border: none;
	box-shadow: none;
}

/* Lab (レンタルスペース運営ラボ): メディア/編集トーン。Heroはデバイス写真なので
   business-detail 既定の浮遊パネル装飾をそのまま活かし、ブルーアクセントを添える */
.c-page-hero--lab .c-page-hero__eyebrow {
	color: var(--color-blue);
}

/* 知見の循環: ステップ番号を立体的なチップにし、ステップ間を細い線でつないで
   「現場 → 蓄積 → 発信 → 還元」が循環するフローを表現する */
.p-bizdetail--lab .p-bizdetail-flow__step {
	background: linear-gradient(135deg, var(--color-blue), var(--color-blue-dark));
	box-shadow: 0 10px 20px -10px rgba(22, 127, 224, 0.6);
}
.p-bizdetail--lab .p-bizdetail-flow__item {
	position: relative;
}
.p-bizdetail--lab .p-bizdetail-flow__item:not(:last-child)::after {
	content: "";
	position: absolute;
	left: 46px;
	bottom: -16px;
	width: 2px;
	height: 16px;
	background: linear-gradient(180deg, var(--color-blue), rgba(22, 127, 224, 0.25));
	transform: translateX(-50%);
}

/* AI推進支援: テクノロジー感のあるグリーンアクセント。導入フローは番号チップを
   立体化し、ステップ間を細い線でつないで「入口 → 設計 → 構築 → 定着」の流れを表現 */
.c-page-hero--ai .c-page-hero__eyebrow {
	color: #10A96D;
}
.p-bizdetail--ai .p-bizdetail-flow__step {
	background: linear-gradient(135deg, #10A96D, #42B85C);
	box-shadow: 0 10px 20px -10px rgba(16, 169, 109, 0.6);
}
.p-bizdetail--ai .p-bizdetail-flow__item {
	position: relative;
}
.p-bizdetail--ai .p-bizdetail-flow__item:not(:last-child)::after {
	content: "";
	position: absolute;
	left: 46px;
	bottom: -16px;
	width: 2px;
	height: 16px;
	background: linear-gradient(180deg, #10A96D, rgba(16, 169, 109, 0.25));
	transform: translateX(-50%);
}

/* -------------------------------------------------------------------------
   22. Page: About — Name Origin
   ------------------------------------------------------------------------- */
.p-name-origin {
	background: #fff;
	padding-block: 100px;
}
.p-name-origin__head {
	text-align: center;
	align-items: center;
	margin-bottom: 56px;
}
.p-name-origin__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 28px;
}
/* カードは「左:テキスト / 右:イラスト」の横型。白地＋淡いカラー枠で洗練した印象に */
.p-name-origin__card {
	position: relative;
	display: grid;
	grid-template-columns: minmax(0, 1fr) 164px;
	align-items: center;
	gap: 24px;
	padding: 40px;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-card);
	box-shadow: 0 12px 32px rgba(15, 27, 42, 0.05);
	overflow: hidden;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.p-name-origin__card:hover {
	transform: translateY(-6px);
	box-shadow: 0 22px 48px rgba(15, 27, 42, 0.10);
}
/* 右上に置く淡いカラーグロー(装飾) */
.p-name-origin__card::after {
	content: "";
	position: absolute;
	top: -56px;
	right: -56px;
	width: 220px;
	height: 220px;
	border-radius: 50%;
	pointer-events: none;
}
.p-name-origin__card--orange { border-color: rgba(242, 138, 0, 0.22); }
.p-name-origin__card--orange::after {
	background: radial-gradient(circle, rgba(242, 138, 0, 0.13), rgba(242, 138, 0, 0) 70%);
}
.p-name-origin__card--blue { border-color: rgba(22, 127, 224, 0.22); }
.p-name-origin__card--blue::after {
	background: radial-gradient(circle, rgba(22, 127, 224, 0.13), rgba(22, 127, 224, 0) 70%);
}
.p-name-origin__body {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	gap: 14px;
}
.p-name-origin__title {
	font-size: 24px;
	font-weight: 700;
	color: var(--color-navy);
	line-height: 1.4;
}
.p-name-origin__card--orange .p-name-origin__title { color: #B66700; }
.p-name-origin__card--blue .p-name-origin__title { color: var(--color-blue-dark); }
.p-name-origin__text {
	font-size: 15px;
	color: var(--color-text);
	line-height: 1.95;
}
.p-name-origin__figure {
	position: relative;
	z-index: 1;
	margin: 0;
}
.p-name-origin__figure img {
	width: 100%;
	height: auto;
	display: block;
}
.p-name-origin__closing {
	margin-top: 48px;
	text-align: center;
	font-size: 16px;
	color: var(--color-text);
	letter-spacing: 0.02em;
}
.p-name-origin__closing span {
	color: var(--color-blue);
	font-weight: 700;
}

/* -------------------------------------------------------------------------
   23. Page: About — Mission
   ------------------------------------------------------------------------- */
.p-mission {
	position: relative;
	background: var(--color-bg-soft);
	padding-block: 88px;
	overflow: hidden;
}
.p-mission::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image: url("../images/decor/orbit-lines.svg");
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	opacity: 0.18;
	pointer-events: none;
}
/* 左:見出し+本文 / 右:豊かさの循環ネットワーク図 の2カラム */
.p-mission__inner {
	position: relative;
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 540px);
	gap: 56px;
	align-items: center;
}
.p-mission__head {
	text-align: left;
	align-items: flex-start;
	margin-bottom: 0;
}
.p-mission__head .c-section-head__title {
	font-size: clamp(32px, 3.4vw, 48px);
}
.p-mission__head .c-section-head__lead {
	text-align: left;
	width: 100%;
	max-width: 520px;
}

/* ---- 循環ネットワーク図 ---- */
.p-mission__diagram {
	position: relative;
	width: 100%;
	max-width: 540px;
	margin-inline: auto;
	aspect-ratio: 1 / 1;
}
.p-mission__lines {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	overflow: visible;
}
.p-mission__ring,
.p-mission__spoke {
	fill: none;
	stroke: var(--color-blue);
	stroke-opacity: 0.22;
	stroke-width: 0.4;
	stroke-dasharray: 1.4 2;
	stroke-linecap: round;
}
.p-mission__center {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	z-index: 2;
	width: 190px;
	height: 190px;
	border-radius: 50%;
	background: #fff;
	box-shadow: 0 18px 44px rgba(22, 127, 224, 0.16);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 8px;
}
.p-mission__center img {
	width: 92px;
	height: 92px;
	object-fit: contain;
}
.p-mission__center-label {
	font-size: 13px;
	font-weight: 700;
	color: var(--color-navy);
	letter-spacing: 0.02em;
}
.p-mission__node {
	position: absolute;
	z-index: 1;
	width: 128px;
	/* icon中心をアンカー点(=spoke終点)に合わせる: 横は中央、縦はアイコン半径ぶん上げる */
	transform: translate(-50%, -38px);
	text-align: center;
}
.p-mission__node--money      { left: 50%; top: 12%; }
.p-mission__node--time       { left: 86%; top: 38%; }
.p-mission__node--knowledge  { left: 72%; top: 81%; }
.p-mission__node--experience { left: 28%; top: 81%; }
.p-mission__node--connection { left: 14%; top: 38%; }
.p-mission__node-icon {
	display: block;
	width: 76px;
	height: 76px;
	margin-inline: auto;
	border-radius: 50%;
	background: #fff;
	box-shadow: 0 8px 20px rgba(22, 127, 224, 0.10);
}
.p-mission__node-icon img {
	width: 100%;
	height: 100%;
	display: block;
}
.p-mission__node-label {
	display: block;
	margin-top: 10px;
	font-size: 14px;
	font-weight: 700;
	color: var(--color-navy);
	letter-spacing: 0.04em;
}
.p-mission__node-sub {
	display: block;
	margin-top: 3px;
	font-size: 11px;
	color: var(--color-muted);
	line-height: 1.5;
}

/* -------------------------------------------------------------------------
   24. Page: About — WakuSpark5 (詳細版)
   ------------------------------------------------------------------------- */
.p-about-spark {
	background: #fff;
	padding-block: 88px;
}
.p-about-spark__head {
	text-align: center;
	align-items: center;
	margin-bottom: 48px;
}
.p-about-spark__head .c-section-head__lead {
	text-align: center;
	max-width: 640px;
}
.p-about-spark__grid {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 20px;
}
/* カードは中央寄せ。各指針の「火花」をブランドカラーで色分けする */
.p-about-spark__card {
	--spark: var(--color-orange);
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 14px;
	padding: 38px 22px 32px;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-card);
	box-shadow: 0 10px 28px rgba(15, 27, 42, 0.04);
	overflow: hidden;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}
/* カード上辺に「火花」の色のアクセントライン */
.p-about-spark__card::before {
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 3px;
	background: var(--spark);
	opacity: 0;
	transition: opacity 0.25s ease;
}
.p-about-spark__card:hover {
	transform: translateY(-6px);
	box-shadow: 0 22px 44px rgba(15, 27, 42, 0.10);
}
.p-about-spark__card:hover::before { opacity: 1; }
.p-about-spark__card:nth-child(1) { --spark: #F28A00; }
.p-about-spark__card:nth-child(2) { --spark: #25AEEA; }
.p-about-spark__card:nth-child(3) { --spark: #F28A00; }
.p-about-spark__card:nth-child(4) { --spark: #F6B200; }
.p-about-spark__card:nth-child(5) { --spark: #A55BE8; }
.p-about-spark__icon {
	width: 84px;
	height: 84px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: color-mix(in srgb, var(--spark) 13%, #fff);
}
.p-about-spark__icon img {
	width: 48px;
	height: 48px;
	object-fit: contain;
}
.p-about-spark__num {
	font-size: 12px;
	font-weight: 700;
	color: var(--spark);
	letter-spacing: 0.16em;
}
.p-about-spark__title {
	font-size: 17px;
	font-weight: 700;
	color: var(--color-navy);
	line-height: 1.5;
}
.p-about-spark__text {
	font-size: 13px;
	color: var(--color-muted);
	line-height: 1.85;
}

/* -------------------------------------------------------------------------
   25. Page: About — Representative Message
   ------------------------------------------------------------------------- */
.p-about-message {
	position: relative;
	background: var(--color-bg-soft);
	padding-block: 88px;
	overflow: hidden;
}
.p-about-message::before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: 480px;
	height: 480px;
	background-image: url("../images/decor/soft-blue-orange-corner.svg");
	background-repeat: no-repeat;
	background-position: top right;
	background-size: contain;
	opacity: 0.65;
	pointer-events: none;
}
.p-about-message .l-container { position: relative; }
.p-about-message__inner {
	display: grid;
	grid-template-columns: minmax(0, 320px) minmax(0, 1fr);
	gap: 56px;
	align-items: start;
}
.p-about-message__photo {
	width: 100%;
	max-width: 320px;
	aspect-ratio: 1 / 1;
	border-radius: 20px;
	overflow: hidden;
	background: #fff;
	box-shadow: 0 16px 36px rgba(15, 27, 42, 0.10);
}
.p-about-message__photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.p-about-message__body {
	display: flex;
	flex-direction: column;
	gap: 20px;
	padding-top: 8px;
}
.p-about-message__eyebrow {
	font-size: 13px;
	letter-spacing: 0.18em;
	color: var(--color-orange);
	font-weight: 700;
}
.p-about-message__title {
	font-size: clamp(24px, 2.4vw, 32px);
	font-weight: 700;
	color: var(--color-navy);
	line-height: 1.5;
}
.p-about-message__text {
	display: flex;
	flex-direction: column;
	gap: 16px;
	font-size: 14px;
	color: var(--color-text);
	line-height: 1.9;
}
.p-about-message__signature {
	display: inline-flex;
	align-items: baseline;
	gap: 12px;
	padding-top: 12px;
	border-top: 1px solid var(--color-border);
	margin-top: 8px;
}
.p-about-message__role {
	font-size: 12px;
	color: var(--color-muted);
	letter-spacing: 0.06em;
}
.p-about-message__name {
	font-size: 18px;
	font-weight: 700;
	color: var(--color-navy);
	letter-spacing: 0.04em;
}

/* -------------------------------------------------------------------------
   27. Responsive
   ------------------------------------------------------------------------- */
@media (max-width: 1024px) {
	.p-hero__inner { grid-template-columns: 1fr 1fr; gap: 24px; min-height: auto; }
	.p-approach__grid,
	.p-spark__layout,
	.p-services__layout { grid-template-columns: 1fr; gap: 32px; }
	.p-services__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.p-spark__list { grid-template-columns: repeat(5, minmax(0, 1fr)); }
	.p-message-news__grid { grid-template-columns: 1fr; gap: 48px; }

	/* business */
	.p-bizsvc { grid-template-columns: repeat(2, minmax(0, 1fr)); }

	/* company */
	.p-company-info__layout { grid-template-columns: 1fr; gap: 48px; }

	/* contact */
	.p-contact-main__inner { grid-template-columns: 1fr; gap: 24px; }
	.p-contact-side {
		position: static;
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 16px;
		align-items: stretch;
	}
	.p-contact-types { padding: 18px 14px; }
	.p-contact-types__list { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; }

	/* about */
	.p-name-origin__grid { grid-template-columns: 1fr; gap: 20px; }
	.p-mission__inner { grid-template-columns: 1fr; gap: 48px; }
	.p-mission__head { text-align: center; align-items: center; width: 100%; max-width: 620px; margin-inline: auto; }
	.p-mission__head .c-section-head__lead { text-align: center; align-self: stretch; max-width: none; }
	.p-about-spark__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
	.p-about-message__inner { grid-template-columns: minmax(0, 260px) minmax(0, 1fr); gap: 40px; }
}

@media (max-width: 768px) {
	.c-site-header__inner { padding: 12px 20px; }
	.c-site-header__nav { display: none; }
	.c-site-header__logo img { height: 28px; }
	.c-site-header__hamburger { display: inline-flex; }
	.c-site-header__mobile:not([hidden]) { display: block; }

	.p-hero__inner { grid-template-columns: 1fr; padding: 32px 20px 48px; min-height: clamp(420px, 90vw, 560px); }
	.p-hero__text { gap: 18px; padding-block: 0; }
	.p-hero__title { line-height: 1.2; }
	.p-hero__bg img { object-position: right bottom; }
	.p-hero__bg::after {
		content: "";
		position: absolute;
		inset: 0;
		background: linear-gradient(
			to bottom,
			rgba(255, 255, 255, 0.95) 0%,
			rgba(255, 255, 255, 0.85) 35%,
			rgba(255, 255, 255, 0.55) 70%,
			rgba(255, 255, 255, 0.35) 100%
		);
		pointer-events: none;
	}

	.p-approach { padding-block: 56px; }
	.p-approach__grid { grid-template-columns: 1fr; gap: 32px; }
	.p-approach__steps {
		grid-template-columns: 1fr;
		gap: 56px;
	}
	.p-approach__step:not(:last-child) .p-approach__step-visual::after {
		display: none;
	}
	.p-approach__step:not(:last-child)::after {
		content: "";
		position: absolute;
		left: 50%;
		top: 100%;
		width: 18px;
		height: 36px;
		margin-top: 10px;
		background-image: url("../images/decor/arrow-down-orange.svg?v=2");
		background-size: contain;
		background-repeat: no-repeat;
		background-position: center;
		transform: translateX(-50%);
		pointer-events: none;
	}

	.p-spark { padding-block: 56px; }
	.p-spark__list {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 24px;
	}

	.p-services { padding-block: 56px; }
	.p-services__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 20px; }
	.p-services__head .c-button { width: 100%; }
	/* 狭い2カラムでは固定改行を無効化し、カード内で折り返す（横はみ出し防止） */
	.p-services__card-text br { display: none; }

	.p-message-news { padding-block: 56px; }
	.p-message-news__grid { gap: 24px; }
	.p-message,
	.p-news { padding: 28px 22px; }
	.p-message__body {
		grid-template-columns: 1fr;
		gap: 20px;
		text-align: left;
	}
	/* 写真は中央寄せ、本文は全幅でカード内に収め自然に折り返す */
	.p-message__photo { width: 160px; height: 160px; margin-inline: auto; }
	.p-message__text { width: 100%; min-width: 0; }
	.p-message__text::before { top: -30px; left: -4px; font-size: 60px; }
	/* SPでは固定改行を無効化し、カード幅に合わせて折り返す */
	.p-message__text p br { display: none; }

	.c-site-footer { padding: 48px 0 24px; }
	.c-site-footer__inner {
		grid-template-columns: 1fr;
		gap: 28px;
		padding: 0 20px;
		text-align: left;
	}
	.c-site-footer__nav-list { gap: 12px 20px; }
	.c-site-footer__social { justify-content: flex-start; }

	.l-container { padding-inline: 20px; }
	.c-button { width: 100%; }

	/* page hero */
	.c-page-hero { padding-block: 40px 56px; }
	.c-page-hero__inner {
		grid-template-columns: 1fr;
		padding: 0 20px;
		gap: 24px;
		min-height: auto;
	}
	.c-page-hero__title { font-size: 38px; line-height: 1.25; }
	.c-page-hero__lead { font-size: 16px; }
	/* 事業紹介Hero: SPでは縦積みになるため余白・最小高さを基本値へ戻す */
	.c-page-hero--business { padding-block: 40px 56px; }
	.c-page-hero--business .c-page-hero__inner { padding-block: 0; min-height: auto; }

	/* 事業詳細Hero: SPでもブラウザフレームを維持しつつ余白を圧縮 */
	.c-page-hero--business-detail { padding-block: 40px 56px; }
	.c-page-hero--business-detail .c-page-hero__inner { min-height: auto; }

	/* CTA band */
	.c-cta-band__inner {
		flex-direction: column;
		align-items: stretch;
		padding: 24px;
		gap: 20px;
	}
	.c-cta-band__text { flex-direction: column; align-items: flex-start; gap: 12px; }
	.c-cta-band__actions { flex-direction: column; width: 100%; }
	.c-cta-band__actions .c-button { width: 100%; min-width: 0; }

	/* business relation */
	.p-business-relation { padding-block: 48px 44px; }
	.p-business-relation__head { margin-bottom: 4px; }
	.p-business-relation__title { font-size: 24px; }
	.p-business-relation__lead { font-size: 14px; }
	.p-bizrel { margin-top: 28px; }
	.p-bizrel__node-text { font-size: 13px; }

	/* business services */
	.p-business-services { padding-block: 48px 56px; }
	.p-business-services__head { margin-bottom: 32px; }
	.p-business-services__title { font-size: 24px; }
	.p-business-services__lead { font-size: 14px; }
	.p-bizsvc { grid-template-columns: 1fr; gap: 16px; }

	/* business detail */
	.p-bizdetail-overview { padding-block: 48px 52px; }
	.p-bizdetail-overview__layout { grid-template-columns: 1fr; gap: 32px; }
	.p-bizdetail-overview--reverse .p-bizdetail-overview__body { order: 1; }
	.p-bizdetail-overview--reverse .p-bizdetail-overview__visual { order: 2; }
	.p-bizdetail-features { padding-block: 48px 56px; }
	.p-bizdetail-features__head { margin-bottom: 32px; }
	.p-bizdetail-features__grid { grid-template-columns: 1fr; }
	.p-bizdetail-flow { padding-block: 48px 56px; }
	.p-bizdetail-flow__item { gap: 14px; padding: 18px 18px; }
	.p-bizdetail--lab .p-bizdetail-flow__item:not(:last-child)::after { left: 38px; }

	/* 改善の循環: SPでは縦積みにし、矢印を下向きへ。上部ブラケットは隠し、下に「くりかえし」を表示 */
	.p-bizdetail-cycle { padding-block: 48px 60px; }
	.p-bizdetail-cycle__head { margin-bottom: 36px; }
	.p-bizcycle { padding-top: 0; }
	.p-bizcycle__loop { display: none; }
	.p-bizcycle__steps { flex-direction: column; gap: 40px; }
	.p-bizcycle__step:not(:first-child)::before {
		content: "↓";
		left: 50%;
		top: -32px;
		transform: translateX(-50%);
	}
	.p-bizcycle__repeat {
		display: block;
		margin-top: 28px;
		text-align: center;
		font-size: 13px;
		font-weight: 700;
		color: var(--color-orange);
	}
	.p-bizcycle__repeat::before { content: "↻ "; }
	.c-page-hero__logo img { height: 32px; }

	/* company */
	.p-company-info { padding-block: 40px 64px; }
	.p-company-info__layout { gap: 40px; }
	.p-company-info__col-title { font-size: 20px; margin-bottom: 18px; }
	.p-company-info__row { grid-template-columns: 100px 1fr; gap: 12px; padding: 14px 4px; font-size: 13px; }
	.p-company-info__dt { font-size: 12px; }
	.p-company-info__service-item { grid-template-columns: 48px 1fr; gap: 12px; padding: 14px; }
	.p-company-info__service-icon { width: 48px; height: 48px; }
	.p-company-info__service-icon img { width: 100%; height: 100%; }
	.p-company-info__service-title { font-size: 14px; }
	.p-company-info__service-text { font-size: 12px; }

	/* news index — hero は max-width:900px のブロックで /about と同じ縦積みへ切り替え済み */
	.p-news-list { padding-block: 40px 16px; }
	.p-news-list__link {
		grid-template-columns: 92px minmax(0, 1fr) 28px;
		gap: 14px;
		padding: 16px 4px;
		font-size: 13px;
	}
	.p-news-list__date { font-size: 12px; }
	.p-news-list__arrow { width: 24px; height: 24px; }
	.p-news-list__arrow svg { width: 12px; height: 12px; }
	.p-news-pagination { padding: 28px 0 16px; }
	.p-news-pagination .nav-links { gap: 2px; padding: 6px 10px; flex-wrap: nowrap; max-width: 100%; overflow-x: auto; }
	.p-news-pagination .page-numbers { min-width: 32px; height: 32px; font-size: 13px; padding: 0 8px; }
	.p-news-pagination .page-numbers.prev,
	.p-news-pagination .page-numbers.next { min-width: 32px; }

	/* news detail */
	.p-news-detail { padding-block: 16px 48px; }
	.p-news-detail__container { padding-inline: 20px; }
	.p-news-detail__main {
		grid-template-columns: 1fr;
		gap: 24px;
		margin-top: 24px;
	}
	.p-news-detail__share {
		position: static;
		flex-direction: row;
		align-items: center;
		justify-content: flex-start;
		gap: 12px;
		order: 2;
	}
	.p-news-detail__share-label { font-size: 11px; }
	.p-news-detail__share-list { flex-direction: row; gap: 10px; }

	.p-news-detail__nav { grid-template-columns: 1fr; margin-top: 48px; }
	.p-news-detail__nav-item:nth-child(2) {
		border-left: 0;
		border-top: 1px solid var(--color-border);
	}
	.p-news-detail__nav-item--next { justify-content: flex-end; }

	.p-news-detail__related { margin-top: 48px; }
	.p-news-detail__related-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }

	/* CTA band: soft-blue */
	.c-cta-band--soft-blue { padding-block: 40px 56px; }
	.c-cta-band--soft-blue .c-cta-band__inner {
		border-radius: var(--radius-card);
		padding: 24px;
	}
	.c-cta-band--soft-blue .c-cta-band__inner::after { width: 200px; height: 140px; opacity: 0.5; }

	/* contact */
	.p-contact-main { padding-block: 40px 56px; }
	.p-contact-side {
		grid-template-columns: 1fr;
		gap: 16px;
	}
	.p-contact-types__list { grid-template-columns: 1fr; }
	.p-contact-phone-card { padding: 18px; }
	.p-contact-phone-card__tel { font-size: 20px; }
	.p-contact-form { padding: 24px 20px; border-radius: 16px; }
	.p-contact-form__title { font-size: 18px; }
	.p-contact-form__grid { grid-template-columns: 1fr; gap: 0; margin-bottom: 0; }
	.p-contact-form__grid .p-contact-form__row { margin-bottom: 18px; }
	.p-contact-form .wpcf7-submit,
	.p-contact-form__submit { min-width: 0; width: 100%; }
	.p-contact-confirm__actions { flex-direction: column-reverse; }
	.p-contact-confirm__back { width: 100%; min-width: 0; }

	/* about / company hero の縦積みは max-width:900px のブロックで対応済み */

	.p-name-origin { padding-block: 64px; }
	.p-name-origin__head { margin-bottom: 36px; }
	.p-name-origin__grid { gap: 16px; }
	/* SPはカードを縦積みにし、イラストを上に置く */
	.p-name-origin__card {
		grid-template-columns: 1fr;
		gap: 18px;
		padding: 28px 24px;
	}
	.p-name-origin__figure {
		order: -1;
		width: 160px;
		margin-inline: auto;
	}
	.p-name-origin__body { text-align: center; align-items: center; }
	.p-name-origin__title { font-size: 21px; }
	.p-name-origin__closing { margin-top: 32px; font-size: 14px; }

	.p-mission { padding-block: 64px; }
	.p-mission__inner { gap: 40px; }
	.p-mission__head { margin-bottom: 0; }
	/* SPでは放射線を隠し、中心シンボル＋ノードをグリッドに再構成 */
	.p-mission__diagram {
		position: static;
		aspect-ratio: auto;
		max-width: 360px;
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 28px 16px;
		justify-items: center;
	}
	.p-mission__lines { display: none; }
	.p-mission__center {
		position: static;
		transform: none;
		grid-column: 1 / -1;
		width: 168px;
		height: 168px;
		margin-inline: auto;
	}
	.p-mission__node {
		position: static;
		transform: none;
		width: auto;
	}
	.p-mission__node:last-child { grid-column: 1 / -1; }

	.p-about-spark { padding-block: 64px; }
	.p-about-spark__head { margin-bottom: 32px; }
	.p-about-spark__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 16px;
	}
	.p-about-spark__card { padding: 30px 18px 26px; gap: 12px; }
	.p-about-spark__card:last-child { grid-column: 1 / -1; }
	.p-about-spark__icon { width: 72px; height: 72px; }
	.p-about-spark__icon img { width: 42px; height: 42px; }

	.p-about-message { padding-block: 56px; }
	.p-about-message::before { width: 280px; height: 280px; opacity: 0.5; }
	.p-about-message__inner {
		grid-template-columns: 1fr;
		gap: 28px;
		justify-items: center;
	}
	.p-about-message__photo { max-width: 240px; }
	.p-about-message__body { padding-top: 0; width: 100%; }
	.p-about-message__title br { display: none; }
}

@media (max-width: 480px) {
	.p-hero__title { font-size: 40px; }
	.c-section-head__title { font-size: 28px; }
	.p-spark__list { grid-template-columns: 1fr; }
	.p-news__link { grid-template-columns: 80px 1fr; gap: 12px; }
	.p-news__link::after { display: none; }

	/* about */
	.p-mission__diagram { max-width: 300px; gap: 24px 12px; }
	.p-mission__node-sub { font-size: 10px; }
	.p-about-message__title { font-size: 22px; }

	/* news index */
	.p-news-list__link { grid-template-columns: 80px minmax(0, 1fr) 24px; gap: 10px; }
	.p-news-list__title-text { font-size: 13px; }

	/* news detail */
	.p-news-detail__related-grid { grid-template-columns: 1fr; }
	.p-news-detail__title { font-size: 20px; }
}
