/*
 * Delight main stylesheet.
 *
 * Consumes design tokens from tokens.css (loaded earlier in the cascade).
 * Decisions live in docs/12-design-direction.md.
 */

/* ---------- Reset / base ---------- */

*, *::before, *::after { box-sizing: border-box; }

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

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

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

a {
	color: var(--color-accent);
	text-decoration: none;
	transition: color 120ms ease;
}
a:hover { color: var(--color-accent-light); }
a:focus-visible {
	outline: 2px solid var(--color-accent);
	outline-offset: 2px;
	border-radius: 2px;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-heading);
	color: var(--color-text);
	line-height: var(--leading-normal);
	margin: 0 0 var(--space-4);
	font-weight: 700;
}

p { margin: 0 0 var(--space-4); }
ul, ol { margin: 0; padding: 0; list-style: none; }

.container {
	width: 100%;
	max-width: var(--container-max);
	margin: 0 auto;
	padding-left: var(--space-5);
	padding-right: var(--space-5);
}

.screen-reader-text {
	position: absolute !important;
	width: 1px; height: 1px;
	padding: 0; margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.skip-link {
	position: absolute;
	top: -100px;
	left: var(--space-4);
	background: var(--color-text);
	color: #FFFFFF;
	padding: var(--space-2) var(--space-4);
	border-radius: var(--radius-sm);
	z-index: calc(var(--z-nav) + 10);
}
.skip-link:focus { top: var(--space-4); color: #FFFFFF; }

/* ---------- Buttons ---------- */

.btn {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	padding: 13px 22px;
	border-radius: var(--radius-md);
	font-weight: 600;
	font-size: var(--text-base);
	line-height: 1;
	transition: background 120ms ease, color 120ms ease, transform 120ms ease;
	border: 1px solid transparent;
	cursor: pointer;
}
.btn--lg { padding: 15px 28px; font-size: var(--text-lg); }
.btn--sm { padding: 9px 16px; font-size: var(--text-sm); }
.btn__arrow { transition: transform 160ms ease; }
.btn:hover .btn__arrow { transform: translateX(3px); }

.btn--primary {
	background: var(--color-text);
	color: #FFFFFF;
}
.btn--primary:hover { background: var(--color-accent); color: #FFFFFF; }

.btn--inverse {
	background: #FFFFFF;
	color: var(--color-text);
}
.btn--inverse:hover { background: var(--color-accent-light); color: #FFFFFF; }

/* ---------- Section primitives ---------- */

.section-head { margin-bottom: var(--space-7); }
.section-head--row {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: var(--space-5);
}

.eyebrow {
	font-family: var(--font-sans-en);
	font-size: var(--text-xs);
	font-weight: 600;
	letter-spacing: 3px;
	text-transform: uppercase;
	color: var(--color-accent);
	margin: 0 0 var(--space-3);
}

.section-title {
	font-size: var(--text-3xl);
	font-weight: 800;
	letter-spacing: -0.5px;
	margin: 0;
}

.text-link {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	font-weight: 600;
	color: var(--color-accent);
}
.text-link:hover { color: var(--color-accent-light); }

/* ---------- Header / nav ---------- */

.site-header {
	position: sticky;
	top: 0;
	z-index: var(--z-nav);
	background: rgba(255, 255, 255, 0.82);
	backdrop-filter: saturate(180%) blur(14px);
	-webkit-backdrop-filter: saturate(180%) blur(14px);
	border-bottom: 1px solid var(--color-line);
	transition: box-shadow 200ms ease, background 200ms ease;
}
.site-header.is-scrolled {
	background: rgba(255, 255, 255, 0.92);
	box-shadow: 0 6px 20px rgba(15, 20, 25, 0.05);
}
body.admin-bar .site-header { top: 32px; }
@media (max-width: 782px) {
	body.admin-bar .site-header { top: 46px; }
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-5);
	min-height: 108px;
}

.site-logo { display: inline-flex; align-items: center; }
.site-logo svg { height: 72px; width: auto; }

.site-nav__list {
	display: flex;
	align-items: center;
	gap: var(--space-5);
}
.site-nav__item a {
	color: var(--color-text);
	font-weight: 600;
	font-size: var(--text-sm);
}
.site-nav__item a:hover { color: var(--color-accent); }
.site-nav__item--cta a { color: #FFFFFF; }

@media (max-width: 820px) {
	.site-logo svg { height: 60px; }
}

/* ---------- Hamburger toggle ---------- */
.nav-toggle {
	display: none;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 5px;
	width: 44px;
	height: 44px;
	padding: 0;
	background: none;
	border: none;
	border-radius: var(--radius-md);
	cursor: pointer;
	flex-shrink: 0;
	-webkit-tap-highlight-color: transparent;
	transition: background 150ms ease;
}
.nav-toggle:hover { background: var(--color-surface); }
.nav-toggle:focus-visible {
	outline: 2px solid var(--color-accent);
	outline-offset: 2px;
}
.nav-toggle__bar {
	display: block;
	width: 22px;
	height: 2px;
	background: var(--color-text);
	border-radius: 2px;
	transition: transform 250ms ease, opacity 200ms ease;
	transform-origin: center;
}
/* ハンバーガー → X アニメーション */
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(2) {
	opacity: 0;
}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}
@media (prefers-reduced-motion: reduce) {
	.nav-toggle__bar { transition: none; }
}

/* ---------- Mobile nav (≤820px) ---------- */
@media (max-width: 820px) {
	.nav-toggle { display: flex; }

	/* ドロップダウンパネル: sticky ヘッダーの直下に absolute 配置 */
	.site-nav {
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		background: var(--color-bg);
		border-bottom: 1px solid var(--color-line);
		box-shadow: 0 8px 24px rgba(15, 20, 25, 0.08);
		opacity: 0;
		visibility: hidden;
		transform: translateY(-8px);
		transition: opacity 200ms ease, transform 200ms ease, visibility 0ms linear 200ms;
		pointer-events: none;
		z-index: 1;
	}
	.site-header.is-nav-open .site-nav {
		opacity: 1;
		visibility: visible;
		transform: translateY(0);
		transition: opacity 200ms ease, transform 200ms ease;
		pointer-events: auto;
	}
	.site-nav__list {
		flex-direction: column;
		align-items: stretch;
		flex-wrap: nowrap;
		justify-content: flex-start;
		gap: 0;
		padding: var(--space-3) var(--space-5);
	}
	.site-nav__item {
		border-bottom: 1px solid var(--color-line);
	}
	.site-nav__item:last-child { border-bottom: none; }
	.site-nav__item a {
		display: block;
		padding: var(--space-4) 0;
		font-size: var(--text-base);
	}
	/* CTA ボタンはモバイルではテキストリンク扱いでアクセントカラーに */
	.site-nav__item--cta a {
		color: var(--color-accent);
		background: none;
	}
}
@media (max-width: 820px) and (prefers-reduced-motion: reduce) {
	.site-nav { transition: none; }
}

/* ---------- Hero ---------- */

.hero { padding: var(--space-11) 0 var(--space-10); }
.hero__inner {
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: var(--space-8);
	align-items: center;
}
.hero__title {
	font-size: var(--text-hero);
	font-weight: 800;
	letter-spacing: -1px;
	line-height: var(--leading-tight);
	margin: 0 0 var(--space-5);
}
.hero__sub {
	font-size: var(--text-lg);
	font-weight: 500;
	color: var(--color-text-mute);
	line-height: 1.75;
	margin: 0 0 var(--space-6);
}
.hero-stage {
	position: relative;
	width: 100%;
	max-width: 560px;
	aspect-ratio: 4 / 3;
	margin-left: auto;
	border-radius: var(--radius-xl);
	overflow: hidden;
	box-shadow: 0 24px 48px rgba(15, 20, 25, 0.12);
	background: var(--color-surface);
}
.hero-slide {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	opacity: 0;
	transition: opacity 800ms ease;
	will-change: opacity;
}
.hero-slide.is-active {
	opacity: 1;
}
.hero-slide img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
@media (prefers-reduced-motion: reduce) {
	.hero-slide { transition: none; }
}

@media (max-width: 880px) {
	.hero { padding: var(--space-8) 0; }
	.hero__inner { grid-template-columns: 1fr; gap: var(--space-7); }
	.hero__title { font-size: var(--text-3xl); }
	.hero-stage { max-width: 480px; margin: 0 auto; }
}

/* ---------- Services ---------- */

.services {
	padding: var(--space-11) 0;
	background: var(--color-surface);
}
.card-grid {
	display: grid;
	gap: var(--space-5);
}
.card-grid--4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 980px) { .card-grid--4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .card-grid--4 { grid-template-columns: 1fr; } }

.card {
	background: #FFFFFF;
	border: 1px solid var(--color-line);
	border-radius: var(--radius-lg);
	padding: var(--space-6);
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
	transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}
.card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 32px rgba(15, 20, 25, 0.08);
	border-color: var(--color-accent-light);
}
.card__title {
	font-size: var(--text-xl);
	font-weight: 700;
	margin: 0;
}
.card__lead {
	color: var(--color-text-mute);
	margin: 0;
	flex: 1;
}
.card__link {
	font-weight: 600;
	color: var(--color-accent);
	display: inline-flex;
	gap: var(--space-2);
	margin-top: var(--space-2);
}

/* カード上端のアイキャッチ画像 (page-service.php の 4 領域サービスカードで使用)。
 * card の padding (var(--space-6)) を打ち消す negative margin で full-bleed 配置、
 * 上 2 隅のみ var(--radius-lg) で card 外形に合わせる。実画像は 3:2 / 16:9 と
 * バラついても CSS の aspect-ratio: 4/3 + object-fit: cover でクロップ統一
 * (docs/12 §6 hero-stage と同方針)。 */
.card__media {
	margin: calc(var(--space-6) * -1) calc(var(--space-6) * -1) 0;
	aspect-ratio: 4 / 3;
	border-radius: var(--radius-lg) var(--radius-lg) 0 0;
	overflow: hidden;
	background: var(--color-surface);
}
.card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 320ms ease;
}
.card:hover .card__media img {
	transform: scale(1.03);
}
@media (prefers-reduced-motion: reduce) {
	.card__media img,
	.card:hover .card__media img { transition: none; transform: none; }
}

/* ---------- About teaser ---------- */

.about-teaser { padding: var(--space-11) 0; }
.about-teaser__inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-8);
	align-items: center;
}
/* About teaser の写真は 4:3 にクロップ (docs/12 §6 hero-stage と craft 統一)。
 * 画像本体 (assets/photos/about-team.jpg) は 1200x800 = 3:2 なので、
 * <img> 側の width/height には実寸を記載しつつ、media コンテナ側で
 * aspect-ratio 4/3 を強制し object-fit: cover でクロップする。
 * service-detail__hero と同方針 (HTML 属性は実寸、CSS で見え方を整える)。 */
.about-teaser__media {
	width: 100%;
	aspect-ratio: 4 / 3;
	border-radius: var(--radius-lg);
	overflow: hidden;
	background: var(--color-surface);
}
.about-teaser__photo {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
@media (max-width: 880px) {
	.about-teaser__inner { grid-template-columns: 1fr; gap: var(--space-6); }
}

/* ---------- News ---------- */

.news {
	padding: var(--space-11) 0;
	background: var(--color-surface);
}
.news-list {
	border-top: 1px solid var(--color-line);
}
.news-list__item {
	display: grid;
	grid-template-columns: 110px 1fr;
	gap: var(--space-5);
	align-items: center;
	padding: var(--space-5) 0;
	border-bottom: 1px solid var(--color-line);
}
.news-list__date {
	font-family: var(--font-sans-en);
	font-size: var(--text-sm);
	color: var(--color-text-mute);
	letter-spacing: 1px;
}
.news-list__title {
	color: var(--color-text);
	font-weight: 600;
}
.news-list__title:hover { color: var(--color-accent); }

.news-empty {
	color: var(--color-text-mute);
	padding: var(--space-6) 0;
	border-top: 1px solid var(--color-line);
	border-bottom: 1px solid var(--color-line);
	text-align: center;
}

@media (max-width: 560px) {
	.news-list__item { grid-template-columns: 1fr; gap: var(--space-2); }
}

/* ---------- CTA band ---------- */

.cta-band {
	background: var(--color-text);
	color: #FFFFFF;
	padding: var(--space-11) 0;
}
.cta-band__inner { text-align: center; }
.cta-band__title {
	color: #FFFFFF;
	font-size: var(--text-3xl);
	font-weight: 800;
	letter-spacing: -0.5px;
	margin: 0 0 var(--space-4);
}
.cta-band__sub {
	color: rgba(255, 255, 255, 0.7);
	font-size: var(--text-lg);
	margin: 0 0 var(--space-6);
}
.cta-band__actions { margin: 0; }

/* ---------- Footer ---------- */

.site-footer {
	background: var(--color-dark);
	color: rgba(255, 255, 255, 0.78);
	padding: var(--space-11) 0 var(--space-6);
	font-size: var(--text-sm);
}
.site-footer__grid {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1fr;
	gap: var(--space-7);
	padding-bottom: var(--space-7);
	border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}
.site-footer__col { color: rgba(255, 255, 255, 0.78); }
.site-footer__logo { display: inline-flex; margin-bottom: var(--space-4); }
.site-footer__logo svg { height: 40px; width: auto; }
.site-footer__company {
	color: rgba(255, 255, 255, 0.6);
	margin: 0;
	line-height: var(--leading-relaxed);
}
.site-footer__heading {
	color: #FFFFFF;
	font-family: var(--font-sans-en);
	font-size: var(--text-xs);
	font-weight: 700;
	letter-spacing: 2.5px;
	text-transform: uppercase;
	margin: 0 0 var(--space-4);
}
.site-footer__list li { margin-bottom: var(--space-2); }
.site-footer__list a { color: rgba(255, 255, 255, 0.78); }
.site-footer__list a:hover { color: var(--color-accent-light); }

.site-footer__bottom {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-3);
	padding-top: var(--space-5);
}
.site-footer__legal {
	display: flex;
	gap: var(--space-5);
}
.site-footer__legal a { color: rgba(255, 255, 255, 0.6); font-size: var(--text-xs); }
.site-footer__legal a:hover { color: #FFFFFF; }
.site-footer__copyright {
	color: rgba(255, 255, 255, 0.5);
	font-family: var(--font-sans-en);
	letter-spacing: 1px;
}

@media (max-width: 980px) {
	.site-footer__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
	.site-footer__grid { grid-template-columns: 1fr; gap: var(--space-6); }
	.site-footer__bottom { flex-direction: column; align-items: flex-start; }
}

/* ---------- Motion: scroll fade-in ---------- */

.fade-in {
	opacity: 0;
	transform: translateY(16px);
	transition: opacity 600ms ease, transform 600ms ease;
	will-change: opacity, transform;
}
.fade-in.is-visible {
	opacity: 1;
	transform: none;
}
/* JS-disabled or pre-script: reveal everything so content is never trapped. */
.no-js .fade-in { opacity: 1; transform: none; transition: none; }
@media (prefers-reduced-motion: reduce) {
	.fade-in { opacity: 1; transform: none; transition: none; }
	/* Suppress global smooth-scroll for users who opt out of motion.
	   docs/12 §0 ("動きは控えめ") + WCAG 2.3.3 advisory at AA. */
	html { scroll-behavior: auto; }
}


/* ---------- Common page sections (page-about / page-contact / page-privacy) ----------
 * 5-B で新設した固定ページ用テンプレで使うクラス群。docs/12 §2 / §5 のトークンに
 * 揃えてレイアウトを与える。固定ページ H1 は section-title を上書きして --text-4xl
 * (front-page hero h1 = --text-hero=52px の一段下) を採用する。
 */

.about,
.contact,
.legal {
	padding: var(--space-11) 0;
}

.about .section-title,
.contact .section-title,
.legal .section-title {
	font-size: var(--text-4xl);
}

.section-lead {
	max-width: 680px;
	/* 左右 auto を外し eyebrow / section-title と左端を揃える。
	 * max-width は行長コントロール (可読性) のため維持。 */
	margin: var(--space-3) 0 0;
	color: var(--color-text-mute);
	line-height: var(--leading-relaxed);
}

.company-info {
	display: grid;
	grid-template-columns: 180px 1fr;
	gap: var(--space-3) var(--space-5);
	margin-top: var(--space-7);
}
.company-info dt {
	font-weight: 700;
	color: var(--color-text-mute);
}
.company-info dd {
	margin: 0;
}
.company-info dd small {
	display: block;
	margin-top: var(--space-1);
	font-size: var(--text-sm);
	color: var(--color-text-mute);
}

.company-services {
	list-style: disc;
	padding-left: var(--space-5);
	line-height: var(--leading-relaxed);
}
.company-services li {
	margin-bottom: var(--space-2);
}

/* ---------- About: Representative profile ---------- */
.profile {
	margin-top: var(--space-9);
	padding-top: var(--space-7);
	border-top: 1px solid var(--color-line);
	max-width: 760px;
}
.profile__label {
	font-size: var(--text-sm);
	font-family: var(--font-sans-en);
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--color-text-mute);
	margin-bottom: var(--space-5);
}
.profile__name {
	font-family: var(--font-heading);
	font-size: var(--text-2xl);
	font-weight: 700;
	margin: 0 0 var(--space-1);
}
.profile__role {
	font-size: var(--text-sm);
	color: var(--color-text-mute);
	margin: 0 0 var(--space-6);
}
.profile__bio {
	line-height: var(--leading-relaxed);
	margin-bottom: var(--space-5);
}
.profile__skills {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-2);
	padding: 0;
	list-style: none;
}
.profile__skill-tag {
	display: inline-block;
	padding: var(--space-1) var(--space-3);
	background: var(--color-surface);
	border: 1px solid var(--color-line);
	border-radius: 9999px;
	font-size: var(--text-sm);
	color: var(--color-text-mute);
}

/* ---------- About: Company achievements ---------- */
.about-works {
	margin-top: var(--space-9);
	padding-top: var(--space-7);
	border-top: 1px solid var(--color-line);
	max-width: 760px;
}
.about-works__label {
	font-size: var(--text-sm);
	font-family: var(--font-sans-en);
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--color-text-mute);
	margin-bottom: var(--space-5);
}
.about-works__list {
	list-style: none;
	padding: 0;
}
.about-works__item {
	display: grid;
	grid-template-columns: 140px 1fr;
	gap: var(--space-3);
	padding: var(--space-4) 0;
	border-bottom: 1px solid var(--color-line);
}
.about-works__item:first-child {
	border-top: 1px solid var(--color-line);
}
.about-works__industry {
	font-size: var(--text-sm);
	font-weight: 700;
	color: var(--color-text-mute);
	padding-top: 2px;
}
.about-works__desc {
	margin: 0;
	line-height: var(--leading-relaxed);
}
@media (max-width: 640px) {
	.about-works__item {
		grid-template-columns: 1fr;
		gap: var(--space-1);
	}
}

.contact-form__fallback {
	margin-top: var(--space-5);
	color: var(--color-text-mute);
	font-size: var(--text-sm);
	line-height: var(--leading-relaxed);
}

.contact-placeholder {
	margin-top: var(--space-7);
	max-width: 680px;
}
.contact-placeholder__cta {
	margin: var(--space-5) 0;
}
.contact-placeholder__detail {
	color: var(--color-text-mute);
	font-size: var(--text-sm);
}

.legal__draft-notice {
	margin-top: var(--space-3);
	color: var(--color-text-mute);
	font-size: var(--text-sm);
	font-style: italic;
}
.legal__body {
	max-width: 760px;
	margin-top: var(--space-7);
	line-height: var(--leading-relaxed);
}
.legal__body h2 {
	font-size: var(--text-xl);
	margin-top: var(--space-7);
	margin-bottom: var(--space-3);
}
.legal__body p,
.legal__body ul {
	margin-bottom: var(--space-5);
}
.legal__body ul {
	list-style: disc;
	padding-left: var(--space-5);
}
.legal__body ul li {
	margin-bottom: var(--space-2);
}
.legal__updated {
	margin-top: var(--space-7);
	color: var(--color-text-mute);
	font-size: var(--text-sm);
}

@media (max-width: 640px) {
	.company-info {
		grid-template-columns: 1fr;
	}
	.company-info dt {
		margin-top: var(--space-3);
	}
}

/* ---------- Service pages (page-service / page-it / page-cloud / page-video / page-ec) ----------
 * 5-C の親 (一覧) と子 (個別サービス詳細) で使うクラス。card-grid は既に
 * front-page section-services で定義済なので継承して使用。
 */

.service-index,
.service-detail {
	padding: var(--space-11) 0;
}

.service-index .section-title,
.service-detail .section-title {
	font-size: var(--text-4xl);
}

/* 親 (一覧) は section-services と同じ card-grid を使うので追加 CSS 不要 */

/* Service 詳細ページの hero 画像。docs/12 §6 hero-stage と同じ
 * aspect-ratio / 角丸 / 影で craft 感を揃え、本文 (760px) と左端を合わせる。
 * 画像実体は assets/photos/hero-{slug}.jpg を再利用 (docs/12 §8-1)。 */
.service-detail__hero {
	max-width: 760px;
	margin: var(--space-7) 0 0;
	aspect-ratio: 4 / 3;
	border-radius: var(--radius-xl);
	overflow: hidden;
	box-shadow: 0 24px 48px rgba(15, 20, 25, 0.12);
	background: var(--color-surface);
}
.service-detail__hero img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
@media (max-width: 880px) {
	.service-detail__hero { max-width: 100%; }
}

.service-detail__body {
	max-width: 760px;
	margin-top: var(--space-7);
	line-height: var(--leading-relaxed);
}
.service-detail__body h2 {
	font-size: var(--text-xl);
	margin-top: var(--space-7);
	margin-bottom: var(--space-3);
}
.service-detail__body p,
.service-detail__body ul {
	margin-bottom: var(--space-5);
}
.service-detail__body ul {
	list-style: disc;
	padding-left: var(--space-5);
}
.service-detail__body ul li {
	margin-bottom: var(--space-2);
}
.service-detail__section {
	margin-top: var(--space-9);
	padding-left: var(--space-6);
	border-left: 4px solid var(--color-accent);
}
/* section 内の大タイトルは通常の h2（text-xl）より一段大きく */
.service-detail__section h2.service-detail__section-title {
	font-size: var(--text-2xl);
	margin-top: 0;
	margin-bottom: var(--space-3);
}
.service-detail__section-lead {
	color: var(--color-text-mute);
	line-height: var(--leading-relaxed);
	margin-bottom: var(--space-6);
	padding-bottom: var(--space-6);
	border-bottom: 1px solid var(--color-line);
	max-width: 680px;
}

/* ---------- Archive / Single templates (news / works / blog) ----------
 * 5-D で追加した archive / single 用クラス。`.entry-content` (the_content
 * の出力) と post-nav (前後リンク) を共通化。works の card は既存
 * card-grid を流用し、news / blog のリストは独自の .news-list / .post-list
 * を使う (.news-list は front-page section-news.php で既定義)。
 */

/* archive / single 系はナビ直下にいきなり section-head (eyebrow + h1) が
 * 来る構成で、front-page の hero (画像 + H1 の 2 カラム) と違ってコンテンツが
 * 縦に薄い。標準 var(--space-11) (112px) だとナビバーに対してコンテンツが
 * 「相対的に小さく」見える + ナビバーが「圧的」に感じる現象が出るため、
 * docs/12 §5「密度が必要な場合は --space-7 (48px)」を採用してナビ直下に
 * コンテンツを引き寄せる。下 padding は標準 var(--space-11) 維持で
 * 後続 CTA セクションとの境界を保つ。
 *
 * セレクタは必ず `section.archive` / `section.single` / `article.single`
 * で specific 化する:
 * WordPress が `<body class="archive ...">` / `<body class="single ...">`
 * を自動付与するため、`.archive` / `.single` だけのセレクタは body にも
 * 当たり、ページ全体に上 padding が入ってナビバー上に空白ができる。
 * single-news / single-works は <article class="single"> を使うため
 * article.single も対象に加える。 */
section.archive,
section.single,
article.single {
	padding: var(--space-9) 0 var(--space-11);
}

.archive .section-title,
.single .section-title {
	font-size: var(--text-4xl);
}

.archive__empty {
	margin-top: var(--space-7);
	color: var(--color-text-mute);
}

/* post-list (.archive--blog で使用)。news-list と同じテイストだが
 * 抜粋を入れるため少し背の高い li になる。 */
.post-list {
	margin-top: var(--space-7);
}
.post-list__item {
	padding: var(--space-5) 0;
	border-bottom: 1px solid var(--color-line);
}
.post-list__date {
	display: block;
	color: var(--color-text-mute);
	font-size: var(--text-sm);
	margin-bottom: var(--space-1);
}
.post-list__title {
	font-size: var(--text-xl);
	margin: 0 0 var(--space-2);
}
.post-list__title a {
	color: var(--color-text);
}
.post-list__title a:hover {
	color: var(--color-accent);
}
.post-list__excerpt {
	color: var(--color-text-mute);
	line-height: var(--leading-relaxed);
}

/* archive--works の card-grid 内で使う eyebrow (service_category の term) */
.card__eyebrow {
	font-size: var(--text-xs);
	letter-spacing: 2px;
	text-transform: uppercase;
	color: var(--color-text-mute);
	margin-bottom: var(--space-2);
}

/* single の本文 (entry-content) と日付 / category */
.single__date {
	display: block;
	color: var(--color-text-mute);
	font-size: var(--text-sm);
	margin-bottom: var(--space-1);
}
.single__category {
	margin-bottom: var(--space-2);
}
.single__category a {
	color: var(--color-accent);
	font-size: var(--text-sm);
	letter-spacing: 1px;
	text-transform: uppercase;
}
.single__thumbnail {
	margin: var(--space-7) 0;
}
.single__thumbnail img {
	width: 100%;
	height: auto;
	border-radius: var(--radius-lg);
}

.entry-content {
	max-width: 760px;
	margin: var(--space-7) 0 0;
	line-height: var(--leading-relaxed);
}
.entry-content h2 {
	font-size: var(--text-xl);
	margin-top: var(--space-7);
	margin-bottom: var(--space-3);
}
.entry-content h3 {
	font-size: var(--text-lg);
	margin-top: var(--space-5);
	margin-bottom: var(--space-2);
}
.entry-content p,
.entry-content ul,
.entry-content ol {
	margin-bottom: var(--space-5);
}
.entry-content ul,
.entry-content ol {
	padding-left: var(--space-5);
}
.entry-content blockquote {
	border-left: 3px solid var(--color-accent);
	padding-left: var(--space-5);
	color: var(--color-text-mute);
	margin: var(--space-5) 0;
}

.post-nav {
	display: flex;
	justify-content: space-between;
	gap: var(--space-5);
	margin-top: var(--space-7);
	margin-bottom: var(--space-9);
	padding-top: var(--space-5);
	border-top: 1px solid var(--color-line);
	max-width: 760px;
	margin-left: 0;
	margin-right: 0;
}
.post-nav__prev,
.post-nav__next {
	font-size: var(--text-sm);
}
.post-nav__next {
	text-align: right;
}

@media (max-width: 640px) {
	.post-nav {
		flex-direction: column;
		gap: var(--space-3);
	}
	.post-nav__next {
		text-align: left;
	}
}
