/* ============================================================
 * base.css ─ リセット・タイポグラフィ・グローバル基盤
 * ============================================================ */

/* ─── Modern CSS Reset ─── */
*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	font-size: 16px;
	-webkit-text-size-adjust: 100%;
	text-size-adjust: 100%;
	scroll-behavior: smooth;
	/* 固定ヘッダー分のみ。アンカージャンプ後に余分な余白を作らない。
	   要素ごとの追加オフセットは scroll-margin-top で個別調整する。 */
	scroll-padding-top: var(--header-height, 64px);
	overflow-x: clip;  /* clip：横スクロール禁止しつつ position: sticky を破壊しない（hidden だと sticky が効かなくなる） */
}

/**
 * アンカージャンプ用 sentinel：
 * <section> 直下の padding-top の中ではなく、見出し直前に置いてジャンプ位置を制御する。
 * 例：
 *   <section class="services-detail">  ← padding-top: 96px
 *     <div class="services-detail__inner">
 *       <span id="ax" class="anchor-sentinel"></span>  ← ここがジャンプ先
 *       <header>...</header>
 *
 * これで scroll-margin-top（ヘッダー分）だけ下にスクロールし、見出しがヘッダー直下に来る。
 * section 自身に id を付けて scroll-margin-top を指定する方式だと、padding-top 分の空白が
 * ヘッダーとコンテンツの間に必ず残るため、それを回避するための仕組み。
 */
.anchor-sentinel {
	display: block;
	height: 0;
	/* scroll-padding-top: var(--header-height) が html に当たっている前提。
	   sentinel 自身の scroll-margin-top は 0 で良い。sentinel を section padding-top の
	   内側（__inner の最初）に置くことで、ジャンプ後 sentinel がヘッダー直下に来て
	   その直後の見出しがそのまま表示される。 */
	scroll-margin-top: 0;
	pointer-events: none;
}

body {
	font-family: var(--font-sans-jp);
	font-size: var(--fs-base);
	line-height: var(--lh-loose);
	color: var(--color-text-primary);
	background: var(--color-bg-primary);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
	overflow-x: clip;
	min-height: 100vh;
}

/* コンテンツ領域はクールホワイト基盤（トークンに追随させる） */
main {
	--color-bg-primary:  #FAF9F7;  /* クールホワイト */
	--color-bg-surface:  #FFFFFF;  /* カード面 */
	--color-bg-elevated: #EAF3F1;  /* 淡アクアグレー */
	--color-bg-base:     #FFFFFF;  /* 浮かせる面・白ボタン用 */
	background: var(--color-bg-primary);
}

/* ─── Typography ───
   見出しは明朝（Shippori Mincho）で品格・知性を出す。本文はゴシックのまま、
   書体コントラストを作る。weight は明朝の可読性を踏まえ semibold を基準にする。 */
h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-serif-jp);
	font-weight: var(--fw-semibold);
	letter-spacing: var(--ls-tight);
	line-height: var(--lh-tight);
	color: var(--color-text-primary);
}

a {
	color: inherit;
	text-decoration: none;
	transition: color var(--duration-fast) var(--ease-out-expo);
}

a:hover {
	color: var(--color-brand);
}

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

/* SP 横はみ出し防止（メディア・埋め込み・テーブル・コードを画面幅に強制収納） */
iframe,
video,
embed,
object,
table,
pre {
	max-width: 100%;
}

pre {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

button {
	font: inherit;
	cursor: pointer;
	border: none;
	background: none;
	color: inherit;
}

ul, ol {
	list-style: none;
}

/* ─── 欧文書体タグ用ユーティリティクラス ─── */
.font-latin {
	font-family: var(--font-sans-latin);
}

.font-mono {
	font-family: var(--font-mono);
}

/* ─── Focus（キーボード操作時のみ可視化） ─── */
*:focus {
	outline: none;
}

*:focus-visible {
	outline: 2px solid var(--color-brand);
	outline-offset: 4px;
	border-radius: var(--radius-sm);
}

/* ─── テキスト選択 ─── */
::selection {
	background: var(--color-brand);
	color: var(--color-text-on-brand);
}

/* ─── スクロールバー（ライトモード対応） ─── */
::-webkit-scrollbar {
	width: 10px;
	height: 10px;
}

::-webkit-scrollbar-track {
	background: var(--color-bg-primary);
}

::-webkit-scrollbar-thumb {
	background: var(--color-bg-elevated);
	border-radius: var(--radius-full);
}

::-webkit-scrollbar-thumb:hover {
	background: var(--color-brand);
}

/* ─── prefers-reduced-motion を必ず尊重 ─── */
@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}

/* ─── ユーティリティ ─── */
.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* ─── 明朝/セリフ/等幅 書体ユーティリティ（新規・追加のみ） ───
   見出し以外の任意要素に書体コントラストを乗せるためのクラス。
   既存クラス名は変更していない。 */
.font-serif-jp {
	font-family: var(--font-serif-jp);
}

.font-serif-latin,
.font-en {
	font-family: var(--font-serif-latin);
	letter-spacing: var(--ls-wide);
}

/* ─── コーナーブラケット（四隅L字マーカー・ティール／ブランドガイド装飾） ───
   .has-brackets を付けた position 持ち要素の四隅にL字を描く。新規・追加のみ。 */
.has-brackets {
	position: relative;
}

.has-brackets::before,
.has-brackets::after {
	content: "";
	position: absolute;
	width: var(--bracket-size);
	height: var(--bracket-size);
	pointer-events: none;
	border-color: var(--color-decor-bracket);
	border-style: solid;
	border-width: 0;
}

/* 左上 + 右下を ::before / ::after で。残り2隅は .has-brackets--all で補完 */
.has-brackets::before {
	top: var(--bracket-inset);
	left: var(--bracket-inset);
	border-top-width: var(--bracket-thickness);
	border-left-width: var(--bracket-thickness);
}

.has-brackets::after {
	right: var(--bracket-inset);
	bottom: var(--bracket-inset);
	border-bottom-width: var(--bracket-thickness);
	border-right-width: var(--bracket-thickness);
}

/* ─── 建築図面的グリッド線の背景（薄いチャコール格子）───
   .has-blueprint-grid を付けた要素の背景に精緻なグリッドを敷く。新規・追加のみ。 */
.has-blueprint-grid {
	background-image:
		linear-gradient(var(--color-decor-grid) 1px, transparent 1px),
		linear-gradient(90deg, var(--color-decor-grid) 1px, transparent 1px);
	background-size: var(--space-7) var(--space-7);
	background-position: center center;
}

/* ─── 編集的な細罫線 ─── */
.hairline {
	border: 0;
	border-top: 1px solid var(--color-decor-hairline);
}
