@charset "UTF-8";
/* =========================================================
   layout.css
   ヘッダー・フッター・フローティング要素など、サイト全体の骨格
   ========================================================= */

/* =========================================================
   サイトヘッダー
   - スティッキー / 背景透明
   - スクロール後は白背景にフェード(JSが data-scroll を切り替え)
   ========================================================= */
.site-header {
	position: fixed;
	top: 0;
	inset-inline: 0;
	z-index: var(--z-header);
	background: transparent;
	transition: background-color var(--transition-base),
		box-shadow var(--transition-base);
}

.site-header[data-scroll="scrolled"] {
	background: var(--color-header-bg);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	box-shadow: var(--shadow-sm);
}

.site-header__inner {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: var(--space-5);
	width: 100%;
	max-width: var(--container-max);
	height: var(--header-height);
	margin-inline: auto;
	padding-inline: var(--container-padding);
	padding-top: var(--space-6);  /* ロゴとナビを上端から少し下げる */
}

/* ---------- ロゴ(共通: ヘッダー・フッター) ---------- */
.site-header__logo,
.site-footer__logo {
	flex-shrink: 0;
	margin: 0;
}

.site-logo {
	display: inline-flex;
	align-items: center;
}

/* ロゴ画像の表示寸法
   原寸: 1024 × 213 (アスペクト比 約4.81:1)
   ヘッダーは高さ56pxで表示(幅 約269px)
   フッターは別途上書きでやや小さめに */
.site-logo img {
	width: auto;
	height: 56px;
	max-height: 56px;
	aspect-ratio: 1024 / 213;
	object-fit: contain;
}

/* ロゴはナビと上端を揃える(旧サイトに合わせて少し下げる) */
.site-header__logo {
	padding-top: var(--space-2);
}

/* 画像未配置時のフォールバック表示 */
.site-logo__text {
	display: inline-flex;
	flex-direction: column;
	gap: 2px;
	color: var(--color-heading);
	line-height: 1.2;
}

.site-logo__name {
	font-family: var(--font-family-mincho);
	font-size: var(--font-size-xl);
	font-weight: var(--font-weight-bold);
	letter-spacing: 0.05em;
}

.site-logo__en {
	font-family: var(--font-family-en);
	font-size: var(--font-size-xs);
	letter-spacing: 0.15em;
	color: var(--color-text-muted);
}

/* =========================================================
   グローバルナビ(PC: 縦書き)
   ========================================================= */
.global-nav {
	margin-left: auto;
}

.global-nav__list {
	display: flex;
	align-items: flex-start;
	gap: var(--space-6);
	/* 各<li>の中で縦書きにするため、ul自体は横並び */
}

.global-nav__list li {
	/* 各メニュー項目を縦書きの「列」にする */
}

.global-nav__list a {
	display: inline-block;
	writing-mode: vertical-rl;
	-webkit-writing-mode: vertical-rl;
	text-orientation: upright;
	-webkit-text-orientation: upright;
	color: var(--color-accent);
	font-size: var(--font-size-sm);
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.25em;
	padding: var(--space-2) var(--space-1);
	transition: color var(--transition-fast),
		opacity var(--transition-fast);
}

.global-nav__list a:hover,
.global-nav__list a:focus-visible {
	color: var(--color-accent-hover);
	opacity: 0.7;
}

.global-nav__list .current-menu-item > a,
.global-nav__list .current_page_item > a {
	color: var(--color-accent-hover);
	font-weight: var(--font-weight-bold);
}

/* =========================================================
   ハンバーガー(SPのみ)
   ========================================================= */
.site-header__menu-toggle {
	display: none;
	position: relative;
	width: 40px;
	height: 40px;
	margin-left: auto;
}

.site-header__menu-toggle-bar {
	position: absolute;
	left: 8px;
	right: 8px;
	height: 2px;
	background: var(--color-heading);
	transition: transform var(--transition-base), opacity var(--transition-base);
}

.site-header__menu-toggle-bar:nth-child(1) { top: 12px; }
.site-header__menu-toggle-bar:nth-child(2) { top: 19px; }
.site-header__menu-toggle-bar:nth-child(3) { top: 26px; }

.site-header__menu-toggle[aria-expanded="true"] .site-header__menu-toggle-bar:nth-child(1) {
	top: 19px;
	transform: rotate(45deg);
}
.site-header__menu-toggle[aria-expanded="true"] .site-header__menu-toggle-bar:nth-child(2) {
	opacity: 0;
}
.site-header__menu-toggle[aria-expanded="true"] .site-header__menu-toggle-bar:nth-child(3) {
	top: 19px;
	transform: rotate(-45deg);
}

/* =========================================================
   フローティング「お問い合わせ」ボタン(画面右端)
   ========================================================= */
.floating-contact {
	position: fixed;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	z-index: var(--z-floating);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: var(--floating-contact-width);
	min-height: 200px;
	padding: var(--space-5) var(--space-2);
	background: var(--color-contact);
	color: var(--color-white);
	transition: background-color var(--transition-fast);
}

.floating-contact:hover,
.floating-contact:focus-visible {
	background: var(--color-contact-hover);
	color: var(--color-white);
}

.floating-contact__text {
	writing-mode: vertical-rl;
	-webkit-writing-mode: vertical-rl;
	text-orientation: upright;
	-webkit-text-orientation: upright;
	font-size: var(--font-size-sm);
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.25em;
	line-height: 1.4;
}

/* =========================================================
   フローティング「トップへ戻る」ボタン(画面右下)
   ========================================================= */
.back-to-top {
	position: fixed;
	right: var(--space-5);
	bottom: var(--space-5);
	z-index: var(--z-floating);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: var(--floating-totop-size);
	height: var(--floating-totop-size);
	background: var(--color-totop);
	color: var(--color-white);
	border-radius: var(--radius-full);
	box-shadow: var(--shadow-md);
	opacity: 0;
	visibility: hidden;
	transform: translateY(20px);
	transition: opacity var(--transition-base),
		visibility var(--transition-base),
		transform var(--transition-base),
		background-color var(--transition-fast);
}

.back-to-top.is-visible {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.back-to-top:hover,
.back-to-top:focus-visible {
	background: var(--color-totop-hover);
}

.back-to-top svg {
	display: block;
}

/* =========================================================
   メイン
   ========================================================= */
.site-main {
	display: block;
	min-height: 60vh;
	/* ヘッダー固定なので、各ページのヒーローはmainの最上部から始まる。
	   下層ページは個別CSSで padding-top を入れる方針。 */
}

/* =========================================================
   サイトフッター
   ========================================================= */
.site-footer {
	background: var(--color-bg);
	padding-block: var(--space-8) var(--space-5);
	margin-top: var(--space-9);
	border-top: var(--border-width) solid var(--color-border);
}

.site-footer__inner {
	width: 100%;
	max-width: var(--container-max);
	margin-inline: auto;
	padding-inline: var(--container-padding);
}

.site-footer__main {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: var(--space-7);
	margin-bottom: var(--space-7);
}

.site-footer__company {
	flex: 1;
	min-width: 0;
}

.site-footer__logo {
	margin-bottom: var(--space-4);
}

.site-footer__logo img {
	height: 48px;
	max-height: 48px;
	width: auto;
	aspect-ratio: 1024 / 213;
}

.site-footer__address {
	font-style: normal;
	font-size: var(--font-size-sm);
	line-height: var(--line-height-base);
	color: var(--color-text);
}

.site-footer__address a {
	color: var(--color-text);
}

/* フッターナビ(PC: 縦書き) */
.footer-nav {
	flex-shrink: 0;
}

.footer-nav__list {
	display: flex;
	align-items: flex-start;
	gap: var(--space-5);
}

.footer-nav__list a {
	display: inline-block;
	writing-mode: vertical-rl;
	-webkit-writing-mode: vertical-rl;
	text-orientation: upright;
	-webkit-text-orientation: upright;
	color: var(--color-accent);
	font-size: var(--font-size-sm);
	letter-spacing: 0.25em;
	padding: var(--space-2) var(--space-1);
	transition: color var(--transition-fast),
		opacity var(--transition-fast);
}

.footer-nav__list a:hover,
.footer-nav__list a:focus-visible {
	color: var(--color-accent-hover);
	opacity: 0.7;
}

.site-footer__copyright {
	padding-top: var(--space-5);
	border-top: var(--border-width) solid var(--color-border);
	text-align: center;
	font-size: var(--font-size-xs);
	letter-spacing: 0.1em;
	color: var(--color-text-muted);
}

/* =========================================================
   タブレット(〜960px)
   ========================================================= */
@media (max-width: 960px) {

	.site-header__inner {
		height: var(--header-height-sp);
		align-items: center;          /* 追加 */
		padding-top: 0;               /* 追加 */
	}

	.site-header__logo {
		padding-top: 0;               /* 追加 */
	}

	.site-logo img {
		height: 40px;
		max-height: 40px;
	}

	.site-logo__name {
		font-size: var(--font-size-base);
	}

	.site-logo__en {
		font-size: 0.625rem;
	}

	.site-header__menu-toggle {
		display: block;
	}

	/* SPではフローティングお問い合わせは隠す(ナビに統合) */
	.floating-contact {
		display: none;
	}

	/* SP用ナビ:オーバーレイ式・横書きに戻す */
	.global-nav {
		position: fixed;
		inset: var(--header-height-sp) 0 0 0;
		background: var(--color-bg);
		padding: var(--space-6) var(--container-padding);
		transform: translateX(100%);
		transition: transform var(--transition-base);
		overflow-y: auto;
	}

	.global-nav.is-open {
		transform: translateX(0);
	}

	.global-nav__list {
		flex-direction: column;
		align-items: stretch;
		gap: 0;
	}

	.global-nav__list li {
		border-bottom: var(--border-width) solid var(--color-border);
	}

	.global-nav__list a {
		display: block;
		writing-mode: horizontal-tb;
		-webkit-writing-mode: horizontal-tb;
		padding: var(--space-4) 0;
		font-size: var(--font-size-md);
		letter-spacing: 0.05em;
		color: var(--color-text);
	}

	/* SPではヘッダーは常に白背景 */
	.site-header,
	.site-header[data-scroll="top"] {
		background: var(--color-bg);
		border-bottom: var(--border-width) solid var(--color-border);
	}

	/* ---------- フッター: SPは縦積み・横書きに ---------- */
	.site-footer__main {
		flex-direction: column;
		gap: var(--space-6);
		text-align: center;
	}

	.site-footer__logo img {
		height: 40px;
		max-height: 40px;
	}

	.footer-nav__list {
		flex-wrap: wrap;
		justify-content: center;
		gap: var(--space-3) var(--space-5);
	}

	.footer-nav__list a {
		writing-mode: horizontal-tb;
		-webkit-writing-mode: horizontal-tb;
		letter-spacing: 0.05em;
		padding: var(--space-2) 0;
	}

	.back-to-top {
		right: var(--space-4);
		bottom: var(--space-4);
		width: 44px;
		height: 44px;
	}
}
