.reservation-setup-message h3 {
	margin-top: 0;
}

.company-page > .breadcrumb {
	width: min(100% - 32px, var(--container));
	margin: 18px auto 0;
}

.company-hero > .breadcrumb {
	width: min(100% - 32px, var(--container));
	margin: 0 auto;
	padding: 8px 0 2px;
	color: #617586;
}

.company-hero {
	position: relative;
	isolation: isolate;
	overflow: hidden;
	width: 100%;
	max-width: none;
	margin: 0;
	padding: 0 0 clamp(30px, 5vw, 58px);
	border: 0;
	border-radius: 0;
	background:
		linear-gradient(135deg, rgba(58, 124, 165, 0.14), rgba(255, 255, 255, 0) 48%),
		linear-gradient(180deg, #fff, #f2f7fa);
	box-shadow: 0 22px 54px rgba(16, 35, 51, 0.09);
}

.company-hero::before {
	display: none;
}

.company-hero__inner {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: clamp(26px, 5vw, 58px);
	align-items: center;
	width: min(100% - 32px, var(--container));
	margin-inline: auto;
	padding-top: clamp(18px, 3vw, 34px);
}

.company-hero__inner > div {
	position: relative;
	z-index: 2;
	max-width: 860px;
}

.company-hero h1 {
	max-width: 860px;
	margin: 0;
	color: var(--color-ink);
	font-size: clamp(1.65rem, 3.2vw, 2.45rem);
	line-height: 1.15;
}

.company-hero__brand-note {
	margin: 10px 0 0;
	color: var(--color-ink);
	font-size: clamp(0.92rem, 1.25vw, 1.06rem);
	font-weight: 900;
	letter-spacing: 0.02em;
	line-height: 1.35;
}

.company-hero__description {
	max-width: 650px;
	margin: 10px 0 0;
	color: #40586a;
	font-size: clamp(0.94rem, 1.18vw, 1.03rem);
	font-weight: 700;
	line-height: 1.8;
}

.company-hero__catch {
	max-width: 820px;
	margin: clamp(14px, 2.2vw, 22px) 0 0;
	color: var(--color-ink);
	font-size: clamp(1.45rem, 2.2vw, 2.1rem);
	font-weight: 900;
	letter-spacing: 0;
	line-height: 1.26;
	text-wrap: balance;
}

.company-hero__records {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 8px;
	max-width: 640px;
	margin-top: clamp(16px, 2.6vw, 24px);
}

.company-hero__records div {
	min-height: 78px;
	padding: 10px 12px;
	border: 1px solid rgba(58, 124, 165, 0.16);
	border-radius: 10px;
	background: rgba(255, 255, 255, 0.72);
	box-shadow: 0 8px 18px rgba(16, 35, 51, 0.045);
}

.company-hero__records span,
.company-hero__records strong {
	display: block;
}

.company-hero__records span {
	color: #536878;
	font-size: 0.72rem;
	font-weight: 900;
	letter-spacing: 0.04em;
}

.company-hero__records strong {
	margin-top: 4px;
	color: var(--color-ink);
	font-size: clamp(1rem, 1.55vw, 1.28rem);
	font-weight: 900;
	line-height: 1.2;
	white-space: nowrap;
}

.company-hero .eyebrow {
	color: var(--color-blue, #1f5f86) !important;
}

.company-hero__catch span {
	display: block;
}

.company-hero .lead {
	max-width: 780px;
	margin-top: clamp(18px, 3vw, 28px);
	color: #334b5e;
	font-size: clamp(1rem, 1.5vw, 1.16rem);
	line-height: 2;
}

.company-hero__image {
	position: relative;
	z-index: 1;
	overflow: hidden;
	width: 100%;
	max-width: 860px;
	margin: clamp(16px, 2.4vw, 24px) 0 0;
	border: 1px solid rgba(58, 124, 165, 0.2);
	border-radius: 12px;
	background: #eef6fb;
	box-shadow: 0 24px 58px rgba(16, 35, 51, 0.16);
}

.company-hero .js-scroll-reveal {
	opacity: 0;
	transform: translateY(18px);
	transition: opacity 0.85s ease, transform 0.85s ease;
}

.company-hero .js-scroll-reveal.is-revealed {
	opacity: 1;
	transform: translateY(0);
}

.company-hero__image figcaption {
	position: absolute;
	right: 14px;
	bottom: 14px;
	z-index: 2;
	padding: 7px 12px;
	border-radius: 999px;
	background: rgba(5, 18, 29, 0.78);
	color: #fff;
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0.03em;
}

.company-hero__image img {
	display: block;
	width: 100%;
	aspect-ratio: 840 / 572;
	object-fit: cover;
	object-position: center;
	filter: saturate(1.05) brightness(1.08);
	opacity: 1;
}

.company-hero__image::after {
	display: none;
}

@media (min-width: 720px) {
	.company-hero__inner {
		grid-template-columns: minmax(0, 1fr) clamp(300px, 40vw, 560px);
	}

	.company-hero__inner > div {
		max-width: 720px;
	}

	.company-hero__image {
		justify-self: end;
		max-width: 560px;
		margin: 0;
	}
}

.company-section,
.company-editor-content {
	padding-block: clamp(32px, 6vw, 72px);
}

.company-section--paper {
	width: 100%;
	max-width: none;
	padding-inline: max(16px, calc((100vw - var(--container)) / 2));
	background: linear-gradient(180deg, #f5f9fc, #eef6fb);
}

.company-table {
	display: grid;
	overflow: hidden;
	border: 1px solid rgba(58, 124, 165, 0.16);
	border-radius: 16px;
	background: var(--color-white);
	box-shadow: 0 16px 36px rgba(16, 35, 51, 0.06);
}

.company-table div {
	display: grid;
	background: var(--color-white);
	border-bottom: 1px solid rgba(58, 124, 165, 0.13);
}

.company-table div:last-child {
	border-bottom: 0;
}

.company-table dt,
.company-table dd {
	margin: 0;
	padding: 16px 18px;
}

.company-table dt {
	background: #eef6fb;
	color: var(--color-blue);
	font-weight: 900;
}

.company-table dd {
	color: #334b5e;
	line-height: 1.8;
}

.company-profile-cards {
	display: grid;
	gap: clamp(16px, 2.2vw, 24px);
}

.company-profile-cards article {
	position: relative;
	overflow: hidden;
	padding: clamp(24px, 3.2vw, 36px);
	border: 1px solid rgba(58, 124, 165, 0.18);
	border-radius: 16px;
	background:
		linear-gradient(135deg, rgba(58, 124, 165, 0.1), rgba(255, 255, 255, 0) 50%),
		rgba(255, 255, 255, 0.92);
	box-shadow: 0 20px 46px rgba(16, 35, 51, 0.08);
}

.company-profile-cards article::after {
	position: absolute;
	right: -54px;
	bottom: -58px;
	width: 170px;
	height: 170px;
	border-radius: 999px;
	background: rgba(58, 124, 165, 0.08);
	content: "";
	pointer-events: none;
}

.company-profile-cards article:nth-child(2) {
	background:
		linear-gradient(135deg, rgba(32, 57, 79, 0.12), rgba(255, 255, 255, 0) 54%),
		rgba(255, 255, 255, 0.94);
}

.company-profile-cards article:nth-child(3) {
	background:
		linear-gradient(135deg, rgba(218, 164, 74, 0.13), rgba(255, 255, 255, 0) 52%),
		rgba(255, 255, 255, 0.94);
}

.company-profile-cards h3 {
	position: relative;
	margin: 0 0 18px;
	padding-left: 14px;
	color: var(--color-ink);
	font-size: clamp(1.16rem, 1.8vw, 1.42rem);
	line-height: 1.45;
}

.company-profile-cards h3::before {
	position: absolute;
	top: 0.18em;
	left: 0;
	width: 4px;
	height: 1.1em;
	border-radius: 999px;
	background: var(--color-blue);
	content: "";
}

.company-profile-cards dl {
	display: grid;
	gap: 12px;
	margin: 0;
}

.company-profile-cards dl div {
	display: grid;
	gap: 8px;
}

.company-profile-card--basic dl div {
	grid-template-columns: minmax(92px, 0.36fr) minmax(0, 1fr);
	gap: 12px;
	align-items: start;
}

.company-profile-cards dt,
.company-profile-cards dd {
	margin: 0;
}

.company-profile-cards dt {
	color: #5d7080;
	font-size: 0.9rem;
	font-weight: 700;
}

.company-profile-cards dd {
	color: var(--color-ink);
	font-size: 1rem;
	font-weight: 800;
	line-height: 1.65;
}

.company-profile-cards dd span,
.company-profile-cards dd small {
	display: block;
}

.company-profile-cards dd small {
	margin-top: 4px;
	color: var(--color-ink);
	font-size: 0.94em;
	font-weight: 700;
}

.company-profile-cards article:nth-child(2) dl div {
	gap: 4px;
}

.company-profile-card--licenses dl {
	gap: 18px;
}

.company-profile-card--licenses dl div + div {
	padding-top: 14px;
	border-top: 1px solid rgba(58, 124, 165, 0.14);
}

.company-profile-cards ul {
	display: flex;
	flex-wrap: wrap;
	gap: 9px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.company-profile-cards li {
	display: inline-flex;
	align-items: center;
	min-height: 32px;
	padding: 6px 12px;
	border-radius: 999px;
	background: #e8f0fb;
	color: #273f55;
	font-size: 0.92rem;
	font-weight: 700;
}

.company-profile-note {
	position: relative;
	z-index: 1;
	margin: 16px 0 0;
	padding-top: 14px;
	border-top: 1px solid rgba(58, 124, 165, 0.12);
	color: #526878;
	font-size: 0.95rem;
	font-weight: 500;
	line-height: 1.8;
}

.company-organization-section {
	margin-top: clamp(24px, 4vw, 46px);
	padding-top: clamp(18px, 3vw, 28px);
	border-top: 1px solid rgba(58, 124, 165, 0.14);
}

.company-organization-section .section__head {
	margin-bottom: 14px;
}

.company-organization {
	overflow: hidden;
	width: min(100%, 820px);
	margin: 0 auto;
	border: 1px solid rgba(58, 124, 165, 0.12);
	border-radius: 12px;
	background: rgba(255, 255, 255, 0.9);
	box-shadow: 0 10px 26px rgba(16, 35, 51, 0.04);
}

.company-organization img {
	display: block;
	width: 100%;
	height: auto;
	filter: none;
}

.company-about__grid,
.company-license__grid,
.company-access__grid {
	display: grid;
	gap: clamp(16px, 3vw, 28px);
}

.company-about__grid article,
.company-business-grid article,
.company-license__grid article,
.company-access__card {
	border: 1px solid rgba(58, 124, 165, 0.16);
	border-radius: 18px;
	background: var(--color-white);
	box-shadow: 0 16px 36px rgba(16, 35, 51, 0.06);
}

.company-about__grid article,
.company-business-grid article,
.company-license__grid article {
	padding: clamp(22px, 4vw, 34px);
}

.company-about__grid h3,
.company-business-grid h3,
.company-license__grid h3,
.company-access__card h3 {
	margin: 0 0 12px;
	color: var(--color-ink);
	font-size: clamp(1.26rem, 2vw, 1.64rem);
	line-height: 1.45;
}

.company-business-grid h3 {
	display: flex;
	align-items: center;
	gap: 12px;
}

.company-business-grid h3 img {
	flex: 0 0 auto;
	width: 28px;
	height: 28px;
	object-fit: contain;
	opacity: 0.78;
}

.company-business-grid article:nth-child(1) h3 img {
	filter: brightness(0) saturate(100%) invert(35%) sepia(18%) saturate(820%) hue-rotate(151deg) brightness(88%) contrast(84%);
}

.company-business-grid article:nth-child(2) h3 img {
	filter: brightness(0) saturate(100%) invert(39%) sepia(22%) saturate(610%) hue-rotate(76deg) brightness(86%) contrast(82%);
}

.company-business-grid article:nth-child(3) h3 img {
	filter: brightness(0) saturate(100%) invert(42%) sepia(23%) saturate(760%) hue-rotate(342deg) brightness(86%) contrast(84%);
}

.company-business-grid article:nth-child(4) h3 img {
	filter: brightness(0) saturate(100%) invert(35%) sepia(18%) saturate(760%) hue-rotate(207deg) brightness(84%) contrast(84%);
}

.company-about__grid p,
.company-business-grid p,
.company-license__grid p,
.company-access__card p {
	margin: 0;
	color: #334b5e;
	line-height: 1.9;
}

.company-business-grid {
	display: grid;
	gap: clamp(16px, 2.5vw, 24px);
}

.company-business-grid article {
	position: relative;
	overflow: hidden;
	border-color: rgba(58, 124, 165, 0.18);
	box-shadow: 0 18px 42px rgba(16, 35, 51, 0.07);
}

.company-business-grid article::after {
	position: absolute;
	right: -42px;
	bottom: -52px;
	width: 150px;
	height: 150px;
	border-radius: 999px;
	background: rgba(58, 124, 165, 0.08);
	content: "";
	pointer-events: none;
}

.company-license__grid article {
	background:
		linear-gradient(135deg, rgba(58, 124, 165, 0.08), rgba(255, 255, 255, 0) 54%),
		var(--color-white);
}

.company-history__list {
	position: relative;
	display: grid;
	gap: 0;
	overflow: hidden;
	margin: 0;
	border: 1px solid rgba(58, 124, 165, 0.2);
	border-radius: 16px;
	background:
		linear-gradient(135deg, rgba(58, 124, 165, 0.08), rgba(255, 255, 255, 0) 42%),
		var(--color-white);
	box-shadow: 0 18px 42px rgba(16, 35, 51, 0.07);
}

.company-history__list::before {
	position: absolute;
	top: 32px;
	bottom: 32px;
	left: 29px;
	z-index: 1;
	width: 2px;
	background: rgba(58, 124, 165, 0.2);
	content: "";
}

.company-history__list div {
	position: relative;
	display: grid;
	gap: 10px;
	overflow: hidden;
	padding: 22px 22px 22px 58px;
	border-bottom: 1px solid rgba(58, 124, 165, 0.13);
	transition: background-color 0.18s ease;
}

.company-history__list div::before {
	position: absolute;
	top: 26px;
	left: 24px;
	z-index: 1;
	width: 12px;
	height: 12px;
	border: 3px solid #cfe0eb;
	border-radius: 999px;
	background: var(--color-white);
	content: "";
	box-shadow: 0 0 0 6px rgba(58, 124, 165, 0.12);
	transition: background-color 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.company-history__list div::after {
	display: none;
	content: none;
}

.company-history__list div > * {
	position: relative;
	z-index: 2;
}

.company-history__list div::before,
.company-history__list div::after {
	z-index: 1;
}

.company-history__list div:last-child {
	border-bottom: 0;
}

.company-history__list div:hover {
	background: rgba(238, 246, 251, 0.72);
}

.company-history__list div:hover::before {
	border-color: rgba(58, 124, 165, 0.22);
	background: var(--color-blue);
	box-shadow: 0 0 0 6px rgba(58, 124, 165, 0.16);
}

.company-history__list dt,
.company-history__list dd {
	margin: 0;
}

.company-history__list dt {
	color: var(--color-blue);
	font-size: 1rem;
	font-weight: 900;
}

.company-history__list dd {
	color: #334b5e;
	font-size: 1.02rem;
	line-height: 1.85;
}

.company-access__card {
	padding: clamp(26px, 4vw, 42px);
	box-shadow: 0 20px 46px rgba(16, 35, 51, 0.08);
}

.company-access__card p + p {
	margin-top: 18px;
	padding-top: 18px;
	border-top: 1px solid rgba(58, 124, 165, 0.14);
}

.company-access__map {
	overflow: hidden;
	min-height: 320px;
	border: 1px solid rgba(58, 124, 165, 0.16);
	border-radius: 18px;
	background: var(--color-white);
	box-shadow: 0 20px 46px rgba(16, 35, 51, 0.08);
}

.company-access__map iframe {
	display: block;
	width: 100%;
	min-height: 320px;
}

.company-cta {
	width: min(100% - 32px, var(--container));
	margin-inline: auto;
}
