/* ==========================================
   OFFICE PAGE SPECIFIC STYLES
   Figma基準: Desktop 1440 / Container 1280 / Padding 80
   既存サイトのscale-factorに連動
========================================== */

/* Header */
.office-header {
	position: relative;
	height: calc(400px * var(--scale-factor));
	overflow: hidden;
}

.office-header-bg {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: -1;
}

.office-header-inner {
	display: flex;
	flex-direction: column;
	gap: calc(80px * var(--scale-factor));
	padding-top: calc(200px * var(--scale-factor));
}

.office-heading {
	font-family: var(--font-dela);
	line-height: 1.2;
	letter-spacing: calc(6px * var(--scale-factor));
	color: var(--color-black);
}

/* 見出しテキストの白縁（スケール連動） */
.office-heading .office-heading-o,
.office-heading .office-heading-rest {
	/* 主要ブラウザ（WebKit系）のストローク */
	-webkit-text-stroke: calc(3px * var(--scale-factor)) var(--color-white);
	-webkit-text-fill-color: var(--color-black);
	/* 中抜き色（本文色） */
	paint-order: stroke fill;

	/* フォールバック（text-shadowで白縁を再現） */
	text-shadow:
		calc(1px * var(--scale-factor)) 0 0 var(--color-white),
		-calc(1px * var(--scale-factor)) 0 0 var(--color-white),
		0 calc(1px * var(--scale-factor)) 0 var(--color-white),
		0 -calc(1px * var(--scale-factor)) 0 var(--color-white),
		calc(1px * var(--scale-factor)) calc(1px * var(--scale-factor)) 0 var(--color-white),
		calc(1px * var(--scale-factor)) -calc(1px * var(--scale-factor)) 0 var(--color-white),
		-calc(1px * var(--scale-factor)) calc(1px * var(--scale-factor)) 0 var(--color-white),
		-calc(1px * var(--scale-factor)) -calc(1px * var(--scale-factor)) 0 var(--color-white);
}

.office-heading-o {
	font-size: calc(128px * var(--scale-factor));
}

.office-heading-rest {
	font-size: calc(96px * var(--scale-factor));
}

/* Office Section */
.office {
	position: relative;
	background-color: var(--color-off-white);
	min-height: calc(1040px * var(--scale-factor));
	overflow: hidden;
}

.office .container {
	position: relative;
}

.office-decoration {
	position: absolute;
	left: calc(840px * var(--scale-factor));
	top: 0;
	bottom: 0;
	width: 100%;
	transform: rotate(90deg) scaleY(-1);
	display: flex;
	align-items: center;
	justify-content: center;
	pointer-events: none;
}

.office-decoration img {
	height: 100%;
	object-fit: cover;
}

.office-content {
	display: flex;
	flex-direction: column;
	gap: calc(32px * var(--scale-factor));
	padding-top: calc(112px * var(--scale-factor));
	padding-bottom: calc(80px * var(--scale-factor));
}

.office-title {
	font-family: var(--font-hiragino);
	font-size: calc(48px * var(--scale-factor));
	line-height: 1.5;
	color: var(--color-black);
}

.office-item {
	display: flex;
	flex-direction: column;
	gap: calc(8px * var(--scale-factor));
}

.office-label {
	font-family: var(--font-hiragino);
	font-size: calc(24px * var(--scale-factor));
	line-height: 1.5;
	color: var(--color-black);
}

.office-value {
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: calc(10px * var(--scale-factor));
	padding-left: calc(48px * var(--scale-factor));
}

.office-value p {
	font-family: var(--font-hiragino);
	font-weight: 600;
	font-size: calc(24px * var(--scale-factor));
	line-height: 1.5;
	color: var(--color-black);
}

.office-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: calc(8px * var(--scale-factor));
}

.office-list li {
	position: relative;
	padding-left: 0;
	font-family: var(--font-hiragino);
	font-weight: 600;
	font-size: calc(24px * var(--scale-factor));
	line-height: 1.5;
	color: var(--color-black);
}

.office-list li::before {
	content: none;
}

/* ==========================================
   Responsive
========================================== */
@media (max-width: 600px) {
	.office-header {
		height: auto;
		min-height: calc(260px * var(--scale-factor));
	}

	.office-header-inner {
		gap: calc(40px * var(--scale-factor));
		padding-top: calc(120px * var(--scale-factor));
	}

	.office-heading-o {
		font-size: calc(72px * var(--scale-factor));
	}

	.office-heading-rest {
		font-size: calc(54px * var(--scale-factor));
	}

	.office {
		min-height: auto;
		padding-bottom: calc(60px * var(--scale-factor));
	}

	.office-decoration {
		left: calc(600px * var(--scale-factor));
	}

	.office-title {
		font-size: var(--text-lg);
	}

	.office-label,
	.office-value p,
	.office-list li {
		font-size: var(--text-base);
	}
}