/*
Theme Name: Inbound Lab
Theme URI: https://local.inboundlab/
Author: Inbound Lab
Description: インバウンド Lab サイト用のミニマルテーマ。TOPはヒーロー＋CTA構成。
Version: 1.0.16
Requires at least: 6.0
Tested up to: 6.9
Requires PHP: 7.4
Text Domain: inboundlab
*/

:root {
	--ilab-header-bg: #ffffff;
	--ilab-logo-green: #1d7a4a;
	--ilab-logo-green-light: #4caf7a;
	--ilab-lime: #a8d14e;
	--ilab-lime-deep: #7cb82d;
	--ilab-lime-mid: #9fc93c;
	--ilab-lime-bright: #c5d95a;
	--ilab-lime-pale: #d4e87a;
	--ilab-title-grad-top: #d8ea8f;
	--ilab-title-grad-mid: #b4cf4a;
	--ilab-title-grad-bottom: #8fba38;
	--ilab-contact-grad-start: #7fbc35;
	--ilab-contact-grad-end: #dbe878;
	--ilab-required: #e53935;
	--ilab-vline-height: 56px;
	--ilab-footer-bg: #4d4d4d;
	--ilab-sky-top: #c8e8f5;
	--ilab-sky-bottom: #e8f6fc;
	--ilab-text: #1a1a1a;
	--ilab-text-muted: #333333;
	--ilab-cta-green: #2e9d5c;
	--ilab-cta-blue: #2b7fd4;
}

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

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

body {
	margin: 0;
	display: flex;
	flex-direction: column;
	min-height: 100vh;
	font-family: "Noto Sans JP", -apple-system, BlinkMacSystemFont, sans-serif;
	font-size: 16px;
	line-height: 1.65;
	color: var(--ilab-text);
	background: #fff;
}

body > main {
	flex: 1 0 auto;
}

a {
	color: inherit;
}

/* ----- Site header (white bar) ----- */

.ilab-site-header {
	position: relative;
	z-index: 20;
	flex-shrink: 0;
	background: #ffffff;
	box-shadow: 0 1px 0 rgba(0, 0, 0, 0.06);
}

.ilab-site-header__inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0.65rem 1.25rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	flex-wrap: nowrap;
	min-height: 52px;
}

/* ロゴ + CONTACT を常に1行に（狭い幅ではロゴを縮小） */
.ilab-site-header__inner--with-contact .ilab-logo {
	min-width: 0;
	flex-shrink: 1;
}

.ilab-site-header__inner--with-contact .ilab-btn-contact {
	flex-shrink: 0;
}

.ilab-site-header__inner--with-contact .ilab-logo__icon {
	width: auto;
	max-width: min(240px, calc(100vw - 11rem));
	max-height: 44px;
	height: auto;
	object-fit: contain;
	object-position: left center;
}

.ilab-logo {
	display: inline-flex;
	align-items: center;
	text-decoration: none;
	flex-shrink: 0;
	line-height: 0;
}

.ilab-logo__icon {
	display: block;
	width: 259px;
	max-width: min(259px, 72vw);
	height: auto;
	flex-shrink: 0;
	object-fit: contain;
}

.ilab-btn-contact {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.55rem 1.45rem;
	border-radius: 7px;
	background: linear-gradient(
		90deg,
		var(--ilab-contact-grad-start) 0%,
		var(--ilab-lime-mid) 42%,
		var(--ilab-contact-grad-end) 100%
	);
	color: #ffffff;
	font-size: 0.8125rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-decoration: none;
	text-transform: uppercase;
	border: none;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
	transition: filter 0.2s ease, transform 0.15s ease;
	white-space: nowrap;
}

.ilab-btn-contact:hover,
.ilab-btn-contact:focus-visible {
	filter: brightness(1.06);
	color: #ffffff;
	outline: none;
}

.ilab-btn-contact:active {
	transform: scale(0.98);
	filter: brightness(0.96);
}

/* ----- TOP hero ----- */

.ilab-top {
	position: relative;
	min-height: min(92vh, 900px);
	overflow: hidden;
	background-color: var(--ilab-sky-bottom);
	/* 手前: ヒーロー画像は縦横とも全体が入るよう contain / 背面: 余白は空のグラデーション */
	background-image:
		url("assets/images/hero-bg.jpg"),
		linear-gradient(
			180deg,
			var(--ilab-sky-top) 0%,
			var(--ilab-sky-bottom) 45%,
			#dbeef8 100%
		);
	background-repeat: no-repeat;
	background-position: center bottom, center;
	background-size: cover;
}

.ilab-top__inner {
	position: relative;
	z-index: 2;
	max-width: 920px;
	margin: 0 auto;
	padding: clamp(2rem, 6vw, 4rem) 1.25rem clamp(10rem, 28vw, 16rem);
	text-align: center;
}

.ilab-top__title {
	margin: 0 0 1rem;
	font-size: clamp(1.75rem, 4.5vw, 2.75rem);
	font-weight: 900;
	line-height: 1.25;
	letter-spacing: 0.04em;
}

.ilab-top__lead {
	margin: 0;
	font-size: clamp(0.95rem, 2vw, 1.05rem);
	font-weight: 400;
	line-height: 1.75;
}

.ilab-top__lead + .ilab-top__lead {
	margin-top: 0.35rem;
}

/* Floating CTAs — モック準拠: CHECK 左約30%, CLICK 左約73%、CLICK はやや下 */
.ilab-top__ctas {
	position: absolute;
	inset: 0;
	z-index: 5;
	pointer-events: none;
}

.ilab-top__ctas .ilab-cta-bubble {
	pointer-events: auto;
}

.screen-reader-text {
	border: 0;
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
	white-space: nowrap;
}

.ilab-cta-bubble {
	position: absolute;
	display: block;
	width: clamp(100px, 18vw, 152px);
	aspect-ratio: 200 / 240;
	overflow: hidden;
	border: none;
	padding: 0;
	cursor: pointer;
	transition: transform 0.2s ease;
	text-decoration: none;
	transform: translateX(-50%);
}

.ilab-cta-bubble__graphic {
	display: block;
	width: 100%;
	height: 100%;
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
}

.ilab-cta-bubble__label {
	display: none;
}

.ilab-cta-bubble--check {
	left: 30%;
	top: 42%;
}

.ilab-cta-bubble--click {
	left: 73%;
	top: 42%;
}

.ilab-cta-bubble:hover,
.ilab-cta-bubble:focus-visible {
	transform: translateX(-50%) scale(1.05);
	outline: none;
}

.ilab-cta-bubble:focus-visible {
	box-shadow: 0 0 0 3px rgba(43, 127, 212, 0.45);
	border-radius: 50%;
}

.ilab-cta-bubble--check .ilab-cta-bubble__graphic {
	background-image: url("assets/images/company.png");
}

.ilab-cta-bubble--check:hover .ilab-cta-bubble__graphic,
.ilab-cta-bubble--check:focus-visible .ilab-cta-bubble__graphic {
	background-image: url("assets/images/company-over.png");
}

.ilab-cta-bubble--click .ilab-cta-bubble__graphic {
	background-image: url("assets/images/contact.png");
}

.ilab-cta-bubble--click:hover .ilab-cta-bubble__graphic,
.ilab-cta-bubble--click:focus-visible .ilab-cta-bubble__graphic {
	background-image: url("assets/images/contact-over.png");
}

/* Fallback layout when front-page content exists below hero */

.ilab-content-below {
	position: relative;
	z-index: 2;
	max-width: 720px;
	margin: 0 auto;
	padding: 2rem 1.25rem 3rem;
}

/* ----- Generic pages ----- */

.ilab-main {
	max-width: 720px;
	margin: 0 auto;
	padding: 2rem 1.25rem 3rem;
}

.ilab-main h1 {
	font-size: 1.75rem;
	margin-top: 0;
}

/* ----- Site footer ----- */

.ilab-site-footer {
	background: var(--ilab-footer-bg);
	color: #ffffff;
	padding: 2.25rem 1.25rem;
	margin-top: auto;
	flex-shrink: 0;
}

.ilab-site-footer__inner {
	max-width: 1120px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	gap: 1.5rem 2rem;
	align-items: center;
}

.ilab-site-footer__brand {
	justify-self: start;
}

.ilab-site-footer__logo-link {
	display: inline-block;
	text-decoration: none;
	line-height: 0;
}

.ilab-site-footer__logo {
	display: block;
	height: auto;
	width: min(200px, 42vw);
	max-height: 40px;
	object-fit: contain;
}

.ilab-site-footer__copy {
	margin: 0;
	justify-self: center;
	text-align: center;
	font-size: 0.8125rem;
	letter-spacing: 0.02em;
	opacity: 0.95;
}

.ilab-site-footer__nav {
	justify-self: end;
	text-align: right;
}

.ilab-site-footer__cols {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	align-items: flex-start;
	gap: 1.25rem 2.75rem;
}

.ilab-site-footer__col {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0.4rem;
	text-align: left;
	min-width: 7rem;
}

.ilab-site-footer__nav a {
	color: #ffffff;
	text-decoration: none;
	font-size: 0.875rem;
	transition: opacity 0.2s ease;
}

.ilab-site-footer__nav a:hover,
.ilab-site-footer__nav a:focus-visible {
	opacity: 0.75;
	outline: none;
}

@media (max-width: 820px) {
	.ilab-site-footer__inner {
		grid-template-columns: 1fr;
		text-align: center;
		justify-items: center;
	}

	.ilab-site-footer__brand,
	.ilab-site-footer__nav {
		justify-self: center;
	}

	.ilab-site-footer__nav {
		text-align: center;
	}

	.ilab-site-footer__cols {
		justify-content: center;
	}

	.ilab-site-footer__col {
		align-items: center;
		text-align: center;
	}
}

/* ----- Company profile page ----- */

body.ilab-company-page {
	color: var(--ilab-text-muted);
}

.ilab-company {
	max-width: 920px;
	margin: 0 auto;
	padding: clamp(2.5rem, 5vw, 3.75rem) 1.25rem clamp(3rem, 6vw, 4.5rem);
}

.ilab-company__section + .ilab-company__section {
	margin-top: clamp(3rem, 6vw, 4.5rem);
}

.ilab-section-head {
	text-align: center;
	margin-bottom: clamp(2rem, 4vw, 2.75rem);
}

.ilab-section-head__en {
	margin: 0;
	font-size: clamp(1.75rem, 4vw, 2.125rem);
	font-weight: 900;
	color: var(--ilab-lime);
	letter-spacing: 0.04em;
	line-height: 1.25;
}

/* 英語見出し — 上から明るいライム → やや濃いライム（モックの縦グラデーション） */
.ilab-section-head__en--gradient {
	background: linear-gradient(
		180deg,
		var(--ilab-title-grad-top) 0%,
		var(--ilab-title-grad-mid) 42%,
		var(--ilab-title-grad-bottom) 100%
	);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	-webkit-text-fill-color: transparent;
}

@supports not (background-clip: text) {
	.ilab-section-head__en--gradient {
		color: var(--ilab-lime);
		background: none;
		-webkit-text-fill-color: unset;
	}
}

.ilab-section-head__ja {
	margin: 0.35rem 0 0;
	font-size: 1rem;
	font-weight: 400;
	color: var(--ilab-text-muted);
	letter-spacing: 0.06em;
}

.ilab-company__table-wrap {
	width: 100%;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.ilab-profile-table {
	width: 100%;
	min-width: 280px;
	border-collapse: collapse;
	table-layout: fixed;
	font-size: 0.9375rem;
	line-height: 1.85;
	color: var(--ilab-text-muted);
}

.ilab-profile-table th,
.ilab-profile-table td {
	padding-top: clamp(1.35rem, 3.8vw, 2rem);
	padding-bottom: clamp(1.35rem, 3.8vw, 2rem);
	padding-left: 0;
	padding-right: 0;
	vertical-align: top;
	text-align: left;
	border-bottom: 1px solid #e5e5e5;
}

.ilab-profile-table th {
	width: 26%;
	max-width: 11rem;
	font-weight: 700;
	padding-right: 1rem;
	color: var(--ilab-text-muted);
}

/* 値の左側の縦ライン — border ではなく疑似要素で上下を枠線から離す */
.ilab-profile-table td {
	position: relative;
	padding-left: 1.15rem;
	padding-right: 0;
	word-break: break-word;
	border-left: none;
}

.ilab-profile-table td::before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 3px;
	height: var(--ilab-vline-height);
	background-color: var(--ilab-lime);
	border-radius: 2px;
}

.ilab-profile-table tbody tr:first-child th,
.ilab-profile-table tbody tr:first-child td {
	border-top: 1px solid #e5e5e5;
}

.ilab-profile-table__list {
	margin: 0;
	padding: 0;
	list-style: none;
	color: var(--ilab-text-muted);
}

.ilab-profile-table__list li + li {
	margin-top: 0.35rem;
}

.ilab-access-grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: clamp(1.5rem, 4vw, 2.75rem);
	align-items: start;
	max-width: 100%;
}

.ilab-access-map {
	margin: 0;
	line-height: 0;
}

.ilab-access-map__embed {
	position: relative;
	width: 100%;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	background: #e8e8e8;
}

.ilab-access-map__embed iframe {
	position: absolute;
	inset: 0;
	display: block;
	width: 100%;
	height: 100%;
	border: 0;
}

.ilab-access-card__title {
	margin: 0 0 1.25rem;
	padding-bottom: 0.65rem;
	border-bottom: 2px solid var(--ilab-lime);
	font-size: 1.0625rem;
	font-weight: 700;
	background: linear-gradient(
		180deg,
		var(--ilab-title-grad-top) 0%,
		var(--ilab-title-grad-mid) 50%,
		var(--ilab-title-grad-bottom) 100%
	);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	-webkit-text-fill-color: transparent;
	letter-spacing: 0.02em;
	text-align: left;
}

@supports not (background-clip: text) {
	.ilab-access-card__title {
		color: var(--ilab-lime);
		background: none;
		-webkit-text-fill-color: unset;
	}
}

.ilab-access-routes {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.ilab-access-routes__item {
	display: flex;
	align-items: flex-start;
	gap: 0.65rem;
	margin: 0;
}

.ilab-access-routes__icon {
	flex-shrink: 0;
	width: 22px;
	height: 22px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-top: 0.15rem;
}

.ilab-access-routes__icon-img {
	display: block;
	width: 22px;
	height: 22px;
	object-fit: contain;
}

.ilab-access-routes__text {
	flex: 1;
	font-size: 0.9375rem;
	line-height: 1.65;
	color: var(--ilab-text-muted);
}

.ilab-company__back {
	text-align: center;
	margin: clamp(3rem, 6vw, 4rem) 0 0;
}

.ilab-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	border: none;
	cursor: pointer;
	font-family: inherit;
	transition: background 0.2s ease, opacity 0.2s ease;
}

.ilab-btn--primary {
	background: linear-gradient(
		90deg,
		var(--ilab-contact-grad-start) 0%,
		var(--ilab-lime-mid) 45%,
		var(--ilab-contact-grad-end) 100%
	);
	color: #ffffff;
	font-size: 0.9375rem;
	font-weight: 700;
	padding: 0.85rem 2.75rem;
	border-radius: 8px;
	min-width: min(100%, 280px);
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}

.ilab-btn--primary:hover,
.ilab-btn--primary:focus-visible {
	filter: brightness(1.05);
	color: #ffffff;
	outline: none;
}

.ilab-btn--primary:active {
	filter: brightness(0.96);
}

/* ----- Contact page ----- */

body.ilab-contact-page {
	color: var(--ilab-text-muted);
}

body.ilab-contact-page .ilab-section-head__ja {
	color: var(--ilab-text);
	font-weight: 500;
}

.ilab-contact {
	width: 650px;
	max-width: 1024px;
	margin: 0 auto;
	padding: clamp(2.5rem, 5vw, 3.75rem) 1.25rem clamp(3rem, 6vw, 4.5rem);
}

.ilab-contact__notice {
	margin: 0 0 1.5rem;
	padding: 0.85rem 1rem;
	border-radius: 6px;
	font-size: 0.9375rem;
	text-align: center;
}

.ilab-contact__notice--error {
	background: #fdecea;
	color: #6a2115;
	border: 1px solid #ffcdd2;
}

/* 送信完了画面（?contact=sent） — Contact見出し下のセンター構成 */
.ilab-contact-thanks {
	text-align: center;
	margin-top: clamp(0.5rem, 2vw, 1rem);
	padding-bottom: clamp(1rem, 3vw, 2rem);
}

.ilab-contact-thanks__heading {
	margin: clamp(1.75rem, 5vw, 2.75rem) auto clamp(1.5rem, 4vw, 2.25rem);
	max-width: 22rem;
	font-size: clamp(1.35rem, 4.2vw, 1.85rem);
	font-weight: 900;
	line-height: 1.35;
	letter-spacing: 0.04em;
	background: linear-gradient(
		180deg,
		var(--ilab-title-grad-top) 0%,
		var(--ilab-title-grad-mid) 42%,
		var(--ilab-title-grad-bottom) 100%
	);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	-webkit-text-fill-color: transparent;
}

@supports not (background-clip: text) {
	.ilab-contact-thanks__heading {
		color: var(--ilab-lime);
		background: none;
		-webkit-text-fill-color: unset;
	}
}

.ilab-contact-thanks__body {
	margin: 0 auto;
	max-width: 22rem;
	padding: 0 0.5rem;
}

.ilab-contact-thanks__body p {
	margin: 0 0 0.65rem;
	font-size: 0.9375rem;
	line-height: 1.75;
	color: var(--ilab-text-muted);
}

.ilab-contact-thanks__body p:last-child {
	margin-bottom: 0;
}

.ilab-contact-thanks__action {
	margin: clamp(2.5rem, 7vw, 3.5rem) 0 0;
	text-align: center;
	padding: 0 0.25rem;
}

.ilab-contact-thanks__action .ilab-btn {
	text-decoration: none;
}

.ilab-contact-thanks__btn.ilab-contact-form__submit {
	width: 100%;
	max-width: min(100%, 320px);
	box-sizing: border-box;
}

.ilab-contact-form {
	margin: 0;
}

.ilab-contact-form__row {
	display: grid;
	grid-template-columns: minmax(148px, 30%) minmax(0, 1fr);
	gap: 0.75rem 1.25rem;
	align-items: start;
	padding-top: clamp(1.35rem, 3.8vw, 2rem);
	padding-bottom: clamp(1.35rem, 3.8vw, 2rem);
	border-bottom: 1px solid #e5e5e5;
}

.ilab-contact-form__row:first-of-type {
	border-top: 1px solid #e5e5e5;
}

.ilab-contact-form__label-wrap {
	position: relative;
	padding-left: 1.15rem;
}

/* 見出し（ラベル）行の高さのみ */
.ilab-contact-form__label-wrap::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 3px;
	background-color: var(--ilab-lime);
	border-radius: 2px;
}

.ilab-contact-form__label {
	display: inline-flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.35rem 0.5rem;
	font-weight: 700;
	font-size: 0.9375rem;
	color: var(--ilab-text);
	line-height: 1.5;
	cursor: pointer;
}

.ilab-required-badge {
	display: inline-block;
	padding: 0.18rem 0.55rem;
	font-size: 0.6875rem;
	font-weight: 700;
	line-height: 1.25;
	color: #ffffff;
	background: var(--ilab-required);
	border-radius: 9999px;
	letter-spacing: 0.04em;
}

.ilab-contact-form__field input,
.ilab-contact-form__field textarea {
	width: 100%;
	margin: 0;
	padding: 0.7rem 0.95rem;
	font-family: inherit;
	font-size: 0.9375rem;
	line-height: 1.55;
	color: var(--ilab-text-muted);
	background: #ffffff;
	border: 1px solid #e0e0e0;
	border-radius: 6px;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.ilab-contact-form__field input::placeholder,
.ilab-contact-form__field textarea::placeholder {
	color: #b8b8b8;
	opacity: 1;
}

.ilab-contact-form__field input:focus,
.ilab-contact-form__field textarea:focus {
	outline: none;
	border-color: var(--ilab-lime-mid);
	box-shadow: 0 0 0 2px rgba(167, 209, 78, 0.35);
}

.ilab-contact-form__field textarea {
	min-height: 9.5rem;
	resize: vertical;
	vertical-align: top;
}

.ilab-contact-form__submit-wrap {
	margin: clamp(2rem, 4vw, 2.75rem) 0 0;
	text-align: center;
}

.ilab-contact-form__submit {
	width: 100%;
	max-width: 420px;
	min-width: 0;
	cursor: pointer;
	box-sizing: border-box;
}

@media (max-width: 560px) {
	.ilab-contact-form__row {
		grid-template-columns: 1fr;
		gap: 0.5rem;
	}

	.ilab-contact-form__field input,
	.ilab-contact-form__field textarea {
		font-size: 16px;
	}
}

@media (max-width: 720px) {
	.ilab-access-grid {
		grid-template-columns: 1fr;
	}

	.ilab-profile-table th {
		width: 34%;
	}
}

@media (max-width: 520px) {
	.ilab-profile-table th,
	.ilab-profile-table td {
		display: block;
		width: 100%;
		padding-left: 0;
		padding-right: 0;
	}

	.ilab-profile-table th {
		padding-bottom: 0.5rem;
		border-bottom: none;
		max-width: none;
	}

	.ilab-profile-table td {
		padding-top: 0.65rem;
		padding-bottom: clamp(1.25rem, 3.8vw, 2rem);
		padding-left: 1rem;
		border-bottom: 1px solid #e5e5e5;
	}

	.ilab-profile-table tbody tr:first-child th {
		border-top: 1px solid #e5e5e5;
		padding-top: clamp(1.35rem, 3.8vw, 2rem);
	}
}

/* ----- Company profile: スマホのみモック準拠（520px の縦積みを上書き） ----- */

@media (max-width: 767px) {
	body.ilab-company-page .ilab-company {
		max-width: 100%;
		padding-top: clamp(1.5rem, 4vw, 2rem);
		padding-bottom: clamp(2.25rem, 6vw, 3rem);
	}

	body.ilab-company-page .ilab-company__section + .ilab-company__section {
		margin-top: clamp(2.25rem, 5vw, 3rem);
	}

	body.ilab-company-page .ilab-section-head {
		margin-bottom: clamp(1.35rem, 4vw, 1.75rem);
	}

	body.ilab-company-page .ilab-section-head__ja {
		color: var(--ilab-text);
		font-weight: 500;
	}

	body.ilab-company-page .ilab-company__table-wrap {
		overflow-x: visible;
	}

	body.ilab-company-page .ilab-profile-table {
		min-width: 0;
		table-layout: fixed;
		font-size: 0.875rem;
		line-height: 1.7;
	}

	body.ilab-company-page .ilab-profile-table tbody tr {
		display: table-row;
	}

	body.ilab-company-page .ilab-profile-table th,
	body.ilab-company-page .ilab-profile-table td {
		display: table-cell;
		width: auto;
		vertical-align: top;
		padding-top: clamp(1rem, 3vw, 1.25rem);
		padding-bottom: clamp(1rem, 3vw, 1.25rem);
		padding-left: 0;
		padding-right: 0;
		border-bottom: 1px solid #e5e5e5;
		text-align: left;
	}

	body.ilab-company-page .ilab-profile-table th {
		width: 34%;
		max-width: none;
		min-width: 5.5rem;
		padding-right: 0.65rem;
		border-bottom: 1px solid #e5e5e5;
		font-weight: 700;
		color: var(--ilab-text);
	}

	body.ilab-company-page .ilab-profile-table td {
		padding-left: 0;
		word-break: break-word;
		color: var(--ilab-text-muted);
	}

	body.ilab-company-page .ilab-profile-table td::before {
		display: none;
	}

	body.ilab-company-page .ilab-profile-table tbody tr:first-child th,
	body.ilab-company-page .ilab-profile-table tbody tr:first-child td {
		border-top: 1px solid #e5e5e5;
		padding-top: clamp(1.1rem, 3.2vw, 1.35rem);
	}

	body.ilab-company-page .ilab-access-grid {
		grid-template-columns: 1fr;
		gap: clamp(1.25rem, 4vw, 1.75rem);
	}

	body.ilab-company-page .ilab-access-map__embed {
		aspect-ratio: 4 / 3;
	}

	body.ilab-company-page .ilab-access-card__title {
		display: block;
		width: 100%;
		margin-bottom: 1rem;
		padding-bottom: 0.5rem;
		border-bottom: 2px solid var(--ilab-lime-mid);
		font-size: 1rem;
		text-align: left;
	}

	body.ilab-company-page .ilab-access-routes {
		gap: 0.85rem;
	}

	body.ilab-company-page .ilab-access-routes__text {
		font-size: 0.875rem;
		line-height: 1.6;
	}

	body.ilab-company-page .ilab-company__back {
		margin-top: clamp(2.25rem, 5vw, 3rem);
	}

	body.ilab-company-page .ilab-company__back .ilab-btn--primary {
		width: 100%;
		max-width: 100%;
		min-width: 0;
		padding: 0.9rem 1.25rem;
		box-sizing: border-box;
	}

	/* フッター（TOP以外）: ロゴ → 2列リンク → © */
	.ilab-site-footer__inner {
		display: flex;
		flex-direction: column;
		align-items: center;
		gap: 1.35rem;
	}

	.ilab-site-footer__brand {
		order: 1;
	}

	.ilab-site-footer__nav {
		order: 2;
		width: 100%;
		text-align: left;
	}

	.ilab-site-footer__copy {
		order: 3;
	}

	.ilab-site-footer__cols {
		flex-direction: row;
		flex-wrap: nowrap;
		justify-content: center;
		align-items: flex-start;
		gap: 2.5rem;
		max-width: 22rem;
		margin: 0 auto;
	}

	.ilab-site-footer__col {
		align-items: flex-start;
		text-align: left;
		min-width: 0;
	}
}

/* ----- Responsive: smartphone / small tablet ----- */

@media (max-width: 767px) {
	/* TOP — 絶対配置のバブルをやめ、テキスト下に横並びで配置 */
	.ilab-top {
		min-height: 0;
		padding-bottom: env(safe-area-inset-bottom, 0);
		background-image:
			url("assets/images/hero-bg-sp.jpg"),
			linear-gradient(
				180deg,
				var(--ilab-sky-top) 0%,
				var(--ilab-sky-bottom) 45%,
				#dbeef8 100%
			);
		/* SPヒーローはビュー幅いっぱいに表示（contain だと横に余白が出る） */
		background-size: 100% auto, cover;
		background-position: center bottom, center;
	}

	.ilab-top__inner {
		padding: clamp(1.25rem, 5vw, 2rem) 1rem clamp(0.75rem, 3vw, 1.25rem);
	}

	.ilab-top__ctas {
		position: relative;
		inset: auto;
		z-index: 6;
		display: flex;
		flex-direction: row-reverse;
		justify-content: center;
		align-items: flex-end;
		flex-wrap: nowrap;
		gap: clamp(0.65rem, 3.5vw, 1.25rem);
		margin-top: 0;
		padding: 0 max(1rem, env(safe-area-inset-left)) clamp(2rem, 8vw, 3rem)
			max(1rem, env(safe-area-inset-right));
		pointer-events: auto;
	}

	.ilab-cta-bubble {
		position: relative;
		left: auto !important;
		top: auto !important;
		transform: none;
		width: clamp(92px, 28vw, 128px);
		display: flex;
		flex-direction: column;
		align-items: center;
		gap: 0.35rem;
		aspect-ratio: unset;
		height: auto;
		overflow: visible;
	}

	.ilab-cta-bubble__graphic {
		width: 100%;
		aspect-ratio: 200 / 240;
		height: auto;
		flex-shrink: 0;
	}

	.ilab-cta-bubble__label {
		display: block;
		font-size: clamp(0.625rem, 2.8vw, 0.75rem);
		font-weight: 700;
		text-align: center;
		line-height: 1.15;
		letter-spacing: 0.03em;
		max-width: 11em;
	}

	.ilab-cta-bubble--check .ilab-cta-bubble__label {
		color: var(--ilab-cta-green);
	}

	.ilab-cta-bubble--click .ilab-cta-bubble__label {
		color: var(--ilab-cta-blue);
	}

	.ilab-cta-bubble:hover,
	.ilab-cta-bubble:focus-visible {
		transform: scale(1.05);
	}

	.ilab-site-header__inner {
		padding-left: max(1rem, env(safe-area-inset-left));
		padding-right: max(1rem, env(safe-area-inset-right));
		padding-top: max(0.5rem, env(safe-area-inset-top));
	}

	.ilab-logo__icon {
		width: min(240px, 70vw);
		max-width: 100%;
	}

	.ilab-site-header__inner--with-contact .ilab-logo__icon {
		width: auto;
		max-width: min(200px, calc(100vw - 9.5rem));
		max-height: 42px;
	}

	.ilab-btn-contact {
		min-height: 44px;
		min-width: 44px;
		padding: 0.55rem 1.2rem;
	}

	.ilab-site-footer {
		padding-bottom: max(2rem, env(safe-area-inset-bottom));
		padding-left: max(1.25rem, env(safe-area-inset-left));
		padding-right: max(1.25rem, env(safe-area-inset-right));
	}
}

@media (max-width: 680px) {
	.ilab-contact {
		width: 100%;
		max-width: 100%;
		padding-left: max(1rem, env(safe-area-inset-left));
		padding-right: max(1rem, env(safe-area-inset-right));
	}

	.ilab-company {
		padding-left: max(1rem, env(safe-area-inset-left));
		padding-right: max(1rem, env(safe-area-inset-right));
	}

	.ilab-main {
		padding-left: max(1rem, env(safe-area-inset-left));
		padding-right: max(1rem, env(safe-area-inset-right));
	}

	.ilab-content-below {
		padding-left: max(1rem, env(safe-area-inset-left));
		padding-right: max(1rem, env(safe-area-inset-right));
	}

	.ilab-contact-form__submit {
		max-width: 100%;
		padding-left: 1.25rem;
		padding-right: 1.25rem;
	}

	.ilab-contact-thanks__btn.ilab-contact-form__submit {
		max-width: 100%;
	}
}

@media (max-width: 380px) {
	.ilab-top__ctas {
		flex-wrap: wrap;
		justify-content: center;
		row-gap: 0.75rem;
	}

	.ilab-cta-bubble {
		width: clamp(84px, 38vw, 112px);
	}
}
