/*
 * ファイル名: assets/css/main.css
 * 内容: HDS ORBIT Concept 表示スタイル
 * 作成日: 2026/05/23
 * 修正日: 2026/05/28
 * 作成者: Tatsuma Hoda
 */

:root {
	--ink: #0c1828;
	--text: #243142;
	--muted: #68778c;
	--paper: #f7f8f5;
	--paper-blue: #eef4f8;
	--surface: #ffffff;
	--deep: #050a14;
	--deep-2: #09182a;
	--navy: #102b4c;
	--blue: #2192f2;
	--cyan: #2ee6f0;
	--line: #d7e1ea;
	--line-dark: rgba(185, 216, 247, 0.18);
	--radius: 8px;
	--header-height: 78px;
	--shell: 1180px;
	--shadow: 0 24px 60px rgba(8, 22, 39, 0.12);
	--shadow-dark: 0 28px 80px rgba(0, 0, 0, 0.32);
}

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

html {
	scroll-behavior: smooth;
	scroll-padding-top: calc(var(--header-height) + 24px);
}

body {
	margin: 0;
	background: var(--paper);
	color: var(--text);
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic", Meiryo, sans-serif;
	font-size: 16px;
	line-height: 1.85;
	letter-spacing: 0;
	overflow-x: hidden;
}

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

a {
	color: inherit;
	text-decoration: none;
}

p,
h1,
h2,
h3,
dl,
dd {
	margin-top: 0;
}

p,
dd {
	margin-bottom: 0;
}

button,
input,
textarea,
select {
	font: inherit;
}

:focus-visible {
	outline: 3px solid rgba(46, 230, 240, 0.6);
	outline-offset: 4px;
}

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

.screen-reader-text:focus {
	position: fixed;
	top: 16px;
	left: 16px;
	z-index: 1000;
	width: auto;
	height: auto;
	padding: 10px 14px;
	clip: auto;
	background: var(--surface);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
}

.section-shell {
	position: relative;
	width: min(var(--shell), calc(100% - 44px));
	margin: 0 auto;
}

.section-block {
	padding: 104px 0;
	background: var(--paper);
}

.section-block--dark {
	position: relative;
	overflow: hidden;
	background: var(--deep);
	color: #ffffff;
}

.section-block--paper {
	background: var(--paper-blue);
}

.eyebrow {
	margin-bottom: 12px;
	color: var(--blue);
	font-size: 0.76rem;
	font-weight: 900;
	letter-spacing: 0.13em;
	text-transform: uppercase;
}

.section-block--dark .eyebrow,
.orbit-hero .eyebrow {
	color: var(--cyan);
}

.section-heading {
	margin-bottom: 44px;
}

.section-heading--split {
	display: grid;
	grid-template-columns: minmax(0, 0.95fr) minmax(280px, 0.65fr);
	gap: 44px;
	align-items: end;
}

.section-heading h2 {
	margin-bottom: 0;
	color: var(--ink);
	font-size: clamp(2rem, 3.15vw, 3.35rem);
	line-height: 1.08;
	letter-spacing: 0;
}

.section-heading p {
	color: var(--muted);
}

.section-block--dark .section-heading h2,
.section-block--dark .section-heading p {
	color: #ffffff;
}

.text-link {
	position: relative;
	display: inline-flex;
	align-items: center;
	min-height: 44px;
	color: var(--blue);
	font-weight: 900;
}

.text-link::after,
.contact-gateway__link::after {
	content: "";
	width: 28px;
	height: 1px;
	margin-left: 12px;
	background: currentColor;
	transform-origin: left;
	transition: transform 0.2s ease;
}

.text-link:hover::after,
.contact-gateway__link:hover::after {
	transform: scaleX(1.35);
}

/* 修正（追加）：2026/05/23 Hoda
   内容：HDS ORBIT Conceptとして、Global Headerを新規実装
   ここから */
.site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	min-height: var(--header-height);
	background: rgba(5, 10, 20, 0.76);
	border-bottom: 1px solid transparent;
	backdrop-filter: blur(16px);
	transition: background 0.2s ease, border-color 0.2s ease;
}

.site-header.is-scrolled,
body.nav-open .site-header {
	background: rgba(5, 10, 20, 0.94);
	border-bottom-color: rgba(46, 230, 240, 0.18);
}

body.admin-bar .site-header {
	top: 32px;
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: min(var(--shell), calc(100% - 44px));
	min-height: var(--header-height);
	margin: 0 auto;
	gap: 32px;
}

.site-brand {
	min-width: 0;
}

.site-brand .custom-logo-link {
	display: inline-flex;
	align-items: center;
	max-width: 360px;
}

.site-brand .custom-logo {
	max-height: 64px;
	width: auto;
}

/* 修正（追加）：2026/05/25 Hoda
   内容：指摘No.1〜4 正式HDSロゴ素材をヘッダーへ実装
   ここから */
.site-brand__logo {
	display: inline-flex;
	align-items: center;
	gap: 14px;
	min-width: 0;
	color: #ffffff;
}

.site-brand__logo img {
	display: block;
	width: clamp(124px, 12vw, 156px);
	height: auto;
	max-height: 74px;
	object-fit: contain;
}
/* ここまで */

.site-brand__text {
	display: inline-flex;
	align-items: center;
	gap: 13px;
	color: #ffffff;
	line-height: 1.2;
}

.site-brand__mark {
	display: grid;
	place-items: center;
	width: 44px;
	height: 36px;
	border: 1px solid rgba(46, 230, 240, 0.35);
	border-radius: var(--radius);
	background: rgba(46, 230, 240, 0.08);
	font-size: 0.78rem;
	font-weight: 900;
	letter-spacing: 0.08em;
}

.site-brand__copy {
	display: grid;
	gap: 3px;
}

.site-brand__name {
	font-weight: 900;
	letter-spacing: 0.04em;
}

.site-brand__tagline {
	color: rgba(255, 255, 255, 0.58);
	font-size: 0.68rem;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.site-nav__list,
.site-footer__menu {
	display: flex;
	align-items: center;
	gap: 28px;
	padding: 0;
	margin: 0;
	list-style: none;
}

.site-nav__list a {
	position: relative;
	display: inline-flex;
	align-items: center;
	min-height: 44px;
	color: rgba(255, 255, 255, 0.72);
	font-size: 0.88rem;
	font-weight: 850;
	letter-spacing: 0.04em;
	transition: color 0.18s ease;
}

.site-nav__list a::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 7px;
	width: 100%;
	height: 1px;
	background: var(--cyan);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 0.18s ease;
}

.site-nav__list a:hover,
.site-nav__list a:focus-visible {
	color: #ffffff;
}

.site-nav__list a:hover::after,
.site-nav__list a:focus-visible::after {
	transform: scaleX(1);
}

.site-nav-toggle {
	display: none;
	width: 46px;
	height: 46px;
	padding: 0;
	place-items: center;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: var(--radius);
	cursor: pointer;
}

.site-nav-toggle__line {
	display: block;
	width: 18px;
	height: 2px;
	margin: 3px 0;
	background: #ffffff;
	border-radius: 2px;
	transition: transform 0.18s ease, opacity 0.18s ease;
}

body.nav-open .site-nav-toggle__line:nth-child(1) {
	transform: translateY(5px) rotate(45deg);
}

body.nav-open .site-nav-toggle__line:nth-child(2) {
	opacity: 0;
}

body.nav-open .site-nav-toggle__line:nth-child(3) {
	transform: translateY(-5px) rotate(-45deg);
}
/* ここまで */

/* 修正（追加）：2026/05/23 Hoda
   内容：非対称Heroと軌道ライン表現を新規実装
   ここから */
.orbit-hero {
	position: relative;
	overflow: hidden;
	min-height: calc(100vh - var(--header-height));
	padding: 92px 0 56px;
	background:
		linear-gradient(140deg, rgba(5, 10, 20, 0.98), rgba(8, 24, 43, 0.96) 54%, rgba(5, 10, 20, 1)),
		var(--deep);
	color: #ffffff;
}

.orbit-hero__grid {
	position: absolute;
	inset: 0;
	background-image:
		linear-gradient(rgba(255, 255, 255, 0.04) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 255, 255, 0.04) 1px, transparent 1px);
	background-size: 44px 44px;
	mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.95), transparent 92%);
}

.orbit-hero__line {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	color: rgba(46, 230, 240, 0.56);
	pointer-events: none;
}

.orbit-hero__line path,
.orbit-hero__line circle {
	fill: none;
	stroke: currentColor;
	stroke-width: 1;
	vector-effect: non-scaling-stroke;
}

.orbit-hero__line path {
	stroke-dasharray: 1200;
	stroke-dashoffset: 1200;
	animation: orbitDraw 1.5s ease 0.15s forwards;
}

.orbit-hero__line circle {
	fill: currentColor;
	opacity: 0;
	animation: orbitPoint 0.5s ease 1.1s forwards;
}

.orbit-hero__shell {
	display: grid;
	grid-template-columns: repeat(12, minmax(0, 1fr));
	min-height: 650px;
	align-items: center;
}

.orbit-hero__statement {
	grid-column: 1 / 10;
	align-self: center;
}

.orbit-hero__identity {
	margin-bottom: 6px;
	color: var(--cyan);
	font-size: 0.82rem;
	font-weight: 900;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.orbit-hero__meta {
	margin-bottom: 42px;
	color: rgba(255, 255, 255, 0.58);
	font-size: 0.76rem;
	font-weight: 850;
	letter-spacing: 0.12em;
}

.orbit-hero__title {
	max-width: 900px;
	margin-bottom: 24px;
	color: #ffffff;
	font-size: clamp(3.3rem, 6.1vw, 6rem);
	font-weight: 900;
	line-height: 1.04;
	letter-spacing: 0;
}

.orbit-hero__title span {
	display: block;
	white-space: nowrap;
}

.orbit-hero__lead {
	max-width: 660px;
	margin-bottom: 20px;
	color: rgba(255, 255, 255, 0.78);
	font-size: 1.08rem;
	font-weight: 700;
}

.orbit-hero__substatement {
	display: inline-flex;
	margin-bottom: 32px;
	padding: 8px 12px;
	color: rgba(255, 255, 255, 0.78);
	border: 1px solid rgba(255, 255, 255, 0.14);
	border-radius: var(--radius);
	background: rgba(255, 255, 255, 0.04);
}

.orbit-hero__links {
	display: flex;
	flex-wrap: wrap;
	gap: 12px 24px;
}

.orbit-hero__links a {
	display: inline-flex;
	align-items: center;
	min-height: 44px;
	color: #ffffff;
	font-weight: 900;
}

.orbit-hero__links a::after {
	content: "";
	width: 34px;
	height: 1px;
	margin-left: 12px;
	background: var(--cyan);
	transition: transform 0.2s ease;
	transform-origin: left;
}

.orbit-hero__links a:hover::after {
	transform: scaleX(1.35);
}

.orbit-hero__index {
	grid-column: 8 / 13;
	align-self: end;
	display: grid;
	gap: 12px;
	margin-bottom: 22px;
}

.orbit-hero__index a {
	display: grid;
	gap: 6px;
	padding: 16px 18px;
	background: rgba(255, 255, 255, 0.045);
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: var(--radius);
	box-shadow: var(--shadow-dark);
	transition: transform 0.2s ease, border-color 0.2s ease;
}

.orbit-hero__index a:hover {
	transform: translateX(4px);
	border-color: rgba(46, 230, 240, 0.4);
}

.orbit-hero__index span {
	color: var(--cyan);
	font-size: 0.72rem;
	font-weight: 900;
	letter-spacing: 0.12em;
}

.orbit-hero__index strong {
	color: rgba(255, 255, 255, 0.86);
}
/* ここまで */

.orbit-index {
	background:
		linear-gradient(135deg, rgba(33, 146, 242, 0.06), rgba(255, 255, 255, 0) 50%),
		var(--paper);
}

.orbit-index__shell {
	display: grid;
	grid-template-columns: minmax(260px, 0.42fr) minmax(0, 0.58fr);
	gap: 72px;
	align-items: start;
}

.orbit-index__intro {
	position: sticky;
	top: calc(var(--header-height) + 32px);
}

.orbit-index__intro h2 {
	margin-bottom: 18px;
	color: var(--ink);
	font-size: clamp(2.6rem, 4.8vw, 4.8rem);
	line-height: 1;
}

.orbit-index__intro p:last-child {
	color: var(--muted);
}

.orbit-index__map {
	position: relative;
	display: grid;
	gap: 26px;
	padding-left: 44px;
}

.orbit-index__map::before {
	content: "";
	position: absolute;
	top: 28px;
	bottom: 28px;
	left: 14px;
	width: 1px;
	background: linear-gradient(180deg, transparent, var(--blue), var(--cyan), transparent);
}

.orbit-node {
	position: relative;
	display: grid;
	gap: 8px;
	padding: 22px 0 22px 28px;
	border-top: 1px solid var(--line);
	transition: transform 0.2s ease;
}

.orbit-node:nth-child(even) {
	margin-left: 52px;
}

.orbit-node::before {
	content: "";
	position: absolute;
	left: -36px;
	top: 30px;
	width: 12px;
	height: 12px;
	background: var(--paper);
	border: 2px solid var(--blue);
	border-radius: 50%;
	transition: border-color 0.2s ease, transform 0.2s ease;
}

.orbit-node:hover {
	transform: translateX(6px);
}

.orbit-node:hover::before {
	border-color: var(--cyan);
	transform: scale(1.25);
}

.orbit-node__number {
	color: var(--blue);
	font-size: 1.4rem;
	font-weight: 900;
	line-height: 1;
}

.orbit-node__label {
	color: var(--muted);
	font-size: 0.74rem;
	font-weight: 900;
	letter-spacing: 0.12em;
}

.orbit-node strong {
	color: var(--ink);
	font-size: 1.25rem;
	line-height: 1.45;
}

.orbit-node__description {
	color: var(--text);
}

.works-grid {
	display: grid;
	grid-template-columns: repeat(12, minmax(0, 1fr));
	/* 修正：2026/05/28 Hoda
	   内容：指摘No.2 AR縦長カード隣接領域の過剰な空白改善 */
	align-items: start;
	gap: 20px;
}

.work-item {
	position: relative;
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: 22px;
	min-height: 420px;
	padding: 28px;
	overflow: hidden;
	background: rgba(255, 255, 255, 0.045);
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: var(--radius);
	transition: transform 0.2s ease, border-color 0.2s ease;
}

.work-item:hover {
	transform: translateY(-4px);
	border-color: rgba(46, 230, 240, 0.42);
}

.work-item--lead {
	grid-column: 1 / 8;
	min-height: 560px;
}

.work-item--product {
	grid-column: 8 / 13;
	margin-top: 88px;
	background: linear-gradient(145deg, rgba(33, 146, 242, 0.16), rgba(255, 255, 255, 0.04));
}

.work-item--compact {
	grid-column: 2 / 7;
}

.work-item--concept {
	grid-column: 7 / 12;
	margin-top: 56px;
}

.work-item__meta {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 18px;
	color: var(--cyan);
	font-size: 0.74rem;
	font-weight: 900;
	letter-spacing: 0.12em;
}

.work-item__meta span {
	color: #ffffff;
	font-size: 2.4rem;
	line-height: 1;
}

.work-item__status {
	display: inline-flex;
	width: fit-content;
	margin-bottom: 14px;
	padding: 4px 8px;
	color: #08121f;
	background: var(--cyan);
	border-radius: var(--radius);
	font-size: 0.72rem;
	font-weight: 900;
	letter-spacing: 0.08em;
}

.work-item h2,
.work-item h3 {
	margin-bottom: 14px;
	color: #ffffff;
	font-size: clamp(1.35rem, 2.2vw, 2rem);
	line-height: 1.25;
}

.work-item--lead h2,
.work-item--lead h3 {
	font-size: clamp(1.7rem, 2.8vw, 2.45rem);
}

.work-item--product h2,
.work-item--product h3 {
	font-size: clamp(1.5rem, 2.4vw, 2.15rem);
}

.work-item p,
.work-item dd {
	color: rgba(255, 255, 255, 0.76);
}

.work-item dl {
	display: grid;
	gap: 12px;
	margin: 24px 0 0;
}

.work-item dl div {
	display: grid;
	grid-template-columns: 72px minmax(0, 1fr);
	gap: 14px;
	padding-top: 12px;
	border-top: 1px solid rgba(255, 255, 255, 0.12);
}

.work-item dt {
	color: rgba(255, 255, 255, 0.9);
	font-weight: 900;
}

.work-item__visual {
	align-self: end;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	min-height: 170px;
	padding: 18px;
	background:
		linear-gradient(rgba(255, 255, 255, 0.05) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 255, 255, 0.05) 1px, transparent 1px);
	background-size: 28px 28px;
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: var(--radius);
}

.work-item__visual-label {
	flex-basis: 100%;
	color: rgba(255, 255, 255, 0.52) !important;
	font-size: 0.72rem;
	font-weight: 900;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.work-item__visual span:not(.work-item__visual-label) {
	align-self: flex-end;
	height: fit-content;
	padding: 5px 8px;
	color: rgba(255, 255, 255, 0.82);
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: var(--radius);
	font-size: 0.78rem;
	font-weight: 850;
}

/* 修正（追加）：2026/05/25 Hoda
   内容：指摘No.1〜3 Featured Works向けイメージビジュアルと誤認防止ラベルを追加
   ここから */
.work-item__visual--image {
	position: relative;
	display: flex;
	flex-direction: column;
	min-height: 220px;
	padding: 0;
	overflow: hidden;
	aspect-ratio: auto;
	background: rgba(3, 12, 24, 0.72);
}

.work-item--lead .work-item__visual--image {
	min-height: 270px;
}

.work-item__visual--screen {
	aspect-ratio: auto;
}

.work-item__visual--portrait {
	width: min(100%, 420px);
	min-height: 420px;
	margin-inline: auto;
	aspect-ratio: auto;
}

.work-item__visual--image img {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 16 / 10;
	object-fit: cover;
	transition: transform 0.35s ease, filter 0.35s ease;
}

.work-item__visual--screen img {
	aspect-ratio: 2 / 1;
}

.work-item__visual--portrait img {
	aspect-ratio: 9 / 16;
}

.work-item:hover .work-item__visual--image img {
	transform: scale(1.025);
	filter: saturate(1.08);
}

.work-item__visual-caption {
	/* 修正：2026/05/28 Hoda
	   内容：指摘No.1 WorksおよびProduct Focus画像ラベルを画像直下キャプション表示へ変更
	   ここから */
	position: static;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	padding: 12px 14px;
	background: #06111f;
	border-top: 1px solid rgba(186, 229, 255, 0.22);
	pointer-events: none;
	/* ここまで */
}

.work-item__visual-kind,
.work-item__visual-note {
	display: inline-flex;
	width: fit-content;
	border-radius: var(--radius);
	font-weight: 900;
	line-height: 1.2;
}

/* 修正：2026/05/28 Hoda
   内容：指摘No.1 Works画像上ラベルの視認性再修正
   ここから */
.work-item__visual .work-item__visual-kind,
.work-item__visual .work-item__visual-note,
.product-focus__caption .work-item__visual-kind,
.product-focus__caption .work-item__visual-note {
	color: #ffffff;
	background: #020814;
	border: 1px solid rgba(186, 229, 255, 0.42);
	box-shadow: 0 12px 28px rgba(0, 0, 0, 0.42);
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.52);
	backdrop-filter: none;
}

.work-item__visual .work-item__visual-kind,
.product-focus__caption .work-item__visual-kind {
	padding: 6px 9px;
	background: #020814;
	font-size: 0.68rem;
	letter-spacing: 0.1em;
}

.work-item__visual .work-item__visual-note,
.product-focus__caption .work-item__visual-note {
	padding: 6px 8px;
	background: #071526;
	font-size: 0.7rem;
}
/* ここまで */

.section-block--dark .text-link {
	color: var(--cyan);
}

.product-focus {
	overflow: hidden;
	background: var(--paper);
}

.product-focus__shell {
	display: grid;
	grid-template-columns: minmax(0, 0.52fr) minmax(320px, 0.48fr);
	gap: 64px;
	align-items: center;
	min-height: 620px;
}

.product-focus__copy h2 {
	margin-bottom: 18px;
	color: var(--ink);
	font-size: clamp(2.7rem, 5.4vw, 5.3rem);
	line-height: 0.98;
}

.product-focus__tagline {
	margin-bottom: 22px;
	color: var(--navy) !important;
	font-size: clamp(1.55rem, 2.8vw, 2.6rem);
	font-weight: 900;
	line-height: 1.15;
}

.product-focus__copy > p:not(.eyebrow):not(.product-focus__tagline) {
	max-width: 600px;
	color: var(--text);
}

.product-focus__visual {
	position: relative;
	min-height: 420px;
	padding: 26px;
	background: var(--deep);
	border: 1px solid rgba(33, 146, 242, 0.28);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	color: #ffffff;
}

.product-focus__visual::before {
	content: "";
	position: absolute;
	inset: 24px;
	border: 1px solid rgba(46, 230, 240, 0.2);
	border-radius: var(--radius);
}

.product-focus__visual > span {
	position: relative;
	z-index: 1;
	color: var(--cyan);
	font-size: 0.78rem;
	font-weight: 900;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.product-focus__screen {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px;
	margin-top: 92px;
}

.product-focus__screen i {
	display: block;
	min-height: 84px;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: var(--radius);
}

.product-focus__screen i:first-child {
	grid-column: span 2;
}

/* 修正（追加）：2026/05/25 Hoda
   内容：指摘No.2 NeoQuote Nexus実画面をProduct Focusへ追加
   ここから */
.product-focus__visual--image {
	display: flex;
	flex-direction: column;
	min-height: auto;
	padding: 0;
	overflow: hidden;
	aspect-ratio: auto;
}

.product-focus__visual--image::before {
	display: none;
}

.product-focus__visual--image img {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 16 / 9;
	object-fit: cover;
	object-position: left top;
}

.product-focus__caption {
	position: static;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	padding: 12px 14px;
	background: #06111f;
	border-top: 1px solid rgba(186, 229, 255, 0.22);
	pointer-events: none;
}
/* ここまで */

.capabilities {
	background: var(--paper-blue);
}

.capabilities__shell {
	display: grid;
	grid-template-columns: minmax(250px, 0.34fr) minmax(0, 0.66fr);
	gap: 70px;
	align-items: start;
}

.capabilities__intro {
	position: sticky;
	top: calc(var(--header-height) + 32px);
}

.capabilities__intro h2 {
	margin-bottom: 18px;
	color: var(--ink);
	font-size: clamp(2.35rem, 4.2vw, 4.4rem);
	line-height: 1.02;
}

.capabilities__intro p {
	color: var(--muted);
}

.capabilities__list {
	display: grid;
	gap: 0;
	border-top: 1px solid var(--line);
}

.capability-item {
	display: grid;
	grid-template-columns: 72px minmax(0, 1fr);
	gap: 24px;
	padding: 28px 0;
	border-bottom: 1px solid var(--line);
}

.capability-item__number {
	color: var(--blue);
	font-size: 1.55rem;
	font-weight: 900;
	line-height: 1;
}

.capability-item h3 {
	margin-bottom: 10px;
	color: var(--ink);
	font-size: 1.25rem;
}

.capability-item p {
	color: var(--text);
}

.capability-item__note {
	margin-top: 12px;
	padding-left: 12px;
	border-left: 2px solid var(--blue);
	font-weight: 800;
}

.tag-list {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 18px;
	padding: 0;
	list-style: none;
}

.tag-list span {
	padding: 4px 8px;
	color: var(--navy);
	background: #ffffff;
	border: 1px solid var(--line);
	border-radius: var(--radius);
	font-size: 0.78rem;
	font-weight: 850;
}

/* 修正（追加）：2026/05/25 Hoda
   内容：指摘No.4・6 技術顧問支援と相談プロセスをOrbit Conceptへ追加
   ここから */
.partnership {
	background:
		linear-gradient(145deg, rgba(33, 146, 242, 0.14), rgba(5, 10, 20, 0) 48%),
		var(--deep);
}

.partnership__shell {
	display: grid;
	grid-template-columns: minmax(0, 0.52fr) minmax(320px, 0.48fr);
	gap: 64px;
	align-items: start;
}

.partnership__lead h2 {
	max-width: 720px;
	margin-bottom: 24px;
	color: #ffffff;
	font-size: clamp(2rem, 3.4vw, 3.6rem);
	line-height: 1.12;
}

.partnership__lead p:not(.eyebrow),
.partnership__notice {
	color: rgba(255, 255, 255, 0.76);
}

.partnership__lead p + p {
	margin-top: 18px;
}

.partnership__price {
	padding: 14px 16px;
	border: 1px solid rgba(46, 230, 240, 0.24);
	border-radius: var(--radius);
	background: rgba(255, 255, 255, 0.045);
	font-weight: 850;
}

.partnership__scope {
	display: grid;
	gap: 16px;
}

.partnership__panel {
	padding: 22px;
	background: rgba(255, 255, 255, 0.055);
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: var(--radius);
	box-shadow: var(--shadow-dark);
}

.partnership__panel--muted {
	background: rgba(255, 255, 255, 0.035);
}

.partnership__panel h3 {
	margin-bottom: 14px;
	color: #ffffff;
	font-size: 1.08rem;
}

.partnership__panel ul {
	display: grid;
	gap: 8px;
	margin: 0;
	padding-left: 1.1em;
	color: rgba(255, 255, 255, 0.78);
}

.partnership__notice {
	padding-left: 16px;
	border-left: 1px solid rgba(46, 230, 240, 0.38);
	font-size: 0.95rem;
}

.process {
	background: var(--paper);
}

.process__timeline {
	position: relative;
	display: grid;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	gap: 0;
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
}

.process__timeline::before {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	top: 48px;
	height: 1px;
	background: linear-gradient(90deg, var(--blue), var(--cyan), transparent);
}

.process__step {
	position: relative;
	display: grid;
	gap: 8px;
	padding: 28px 20px 30px 0;
}

.process__step + .process__step {
	padding-left: 20px;
	border-left: 1px solid var(--line);
}

.process__step span {
	position: relative;
	z-index: 1;
	display: inline-grid;
	place-items: center;
	width: 42px;
	height: 42px;
	color: var(--deep);
	background: var(--cyan);
	border-radius: 50%;
	font-weight: 900;
	line-height: 1;
}

.process__step h2,
.process__step h3 {
	margin-bottom: 0;
	color: var(--ink);
	font-size: 1.05rem;
}

.process__step p,
.process__note {
	color: var(--text);
}

.process__note {
	max-width: 860px;
	margin-top: 26px;
	padding-left: 16px;
	border-left: 2px solid var(--blue);
	font-weight: 800;
}
/* ここまで */

.about-philosophy__shell {
	display: grid;
	grid-template-columns: minmax(0, 0.62fr) minmax(300px, 0.38fr);
	gap: 64px;
	align-items: start;
}

.about-philosophy__quote h2 {
	margin-bottom: 28px;
	color: var(--ink);
	font-size: clamp(2.2rem, 3.8vw, 3.8rem);
	line-height: 1.06;
}

/* 修正（追加）：2026/05/23 Hoda
   内容：指摘No.1〜3 Aboutセクションの日本語改行と左右カラムバランスを調整
   ここから */
.about-philosophy__quote h2 span,
.about-philosophy__message span {
	display: block;
	white-space: nowrap;
}

.about-philosophy__message {
	color: var(--navy);
	font-size: clamp(1.55rem, 2.8vw, 2.6rem);
	font-weight: 900;
	line-height: 1.2;
}
/* ここまで */

.about-philosophy__body {
	padding-top: 86px;
}

.about-philosophy__body p {
	color: var(--text);
}

.about-philosophy__body p + p {
	margin-top: 18px;
}

.about-philosophy__profile {
	display: grid;
	gap: 6px;
	margin-top: 30px;
	padding-top: 22px;
	border-top: 1px solid var(--line);
}

.about-philosophy__profile strong {
	color: var(--ink);
}

.about-philosophy__profile span {
	color: var(--muted);
}

.journal-list {
	display: grid;
	grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
	gap: 14px;
}

.journal-item {
	display: grid;
	gap: 12px;
	padding: 22px 0;
	border-top: 1px solid var(--line);
}

.journal-item--latest {
	grid-row: span 2;
	padding: 34px;
	background: var(--surface);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
}

.journal-item time {
	color: var(--muted);
	font-size: 0.82rem;
	font-weight: 900;
}

.journal-item h3 {
	margin-bottom: 0;
	color: var(--ink);
	font-size: clamp(1.1rem, 2vw, 1.7rem);
	line-height: 1.45;
}

.journal-item h3 a:hover {
	color: var(--blue);
}

.empty-message {
	padding: 22px;
	background: var(--surface);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	color: var(--muted);
}

.contact-gateway {
	position: relative;
	overflow: hidden;
	background: var(--deep);
	color: #ffffff;
}

.contact-gateway::before {
	content: "";
	position: absolute;
	left: 50%;
	top: 0;
	width: 1px;
	height: 100%;
	background: linear-gradient(180deg, transparent, rgba(46, 230, 240, 0.46), transparent);
	transform: rotate(18deg);
}

.contact-gateway__shell {
	max-width: 880px;
	padding: 20px 0;
}

.contact-gateway h2 {
	margin-bottom: 20px;
	color: #ffffff;
	font-size: clamp(2rem, 3.5vw, 3.6rem);
	line-height: 1.12;
}

.contact-gateway p:not(.eyebrow) {
	max-width: 680px;
	color: rgba(255, 255, 255, 0.78);
}

.contact-gateway__topics {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	max-width: 820px;
	margin: 24px 0 0;
	padding: 0;
	list-style: none;
}

.contact-gateway__topics li {
	padding: 6px 9px;
	color: rgba(255, 255, 255, 0.82);
	background: rgba(255, 255, 255, 0.055);
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: var(--radius);
	font-size: 0.82rem;
	font-weight: 850;
}

.contact-gateway__link {
	display: inline-flex;
	align-items: center;
	min-height: 52px;
	margin-top: 34px;
	color: var(--cyan);
	font-size: 1.05rem;
	font-weight: 900;
}

.site-footer {
	padding: 54px 0;
	background: #03070d;
	color: rgba(255, 255, 255, 0.68);
}

.site-footer__inner {
	display: grid;
	grid-template-columns: minmax(260px, 0.42fr) minmax(0, 0.58fr);
	gap: 32px;
	width: min(var(--shell), calc(100% - 44px));
	margin: 0 auto;
}

.site-footer__logo {
	margin-bottom: 8px;
	color: #ffffff;
	font-weight: 900;
	letter-spacing: 0.08em;
}

.site-footer__logo-link {
	display: inline-flex;
	width: fit-content;
	margin-bottom: 12px;
}

.site-footer__logo-image {
	width: 128px;
	height: auto;
}

.site-footer__name {
	color: rgba(255, 255, 255, 0.84);
	font-weight: 850;
}

.site-footer__meta,
.site-footer__note,
.site-footer__copyright {
	color: rgba(255, 255, 255, 0.52);
}

.site-footer__nav {
	justify-self: end;
}

.site-footer__menu {
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 10px 18px;
}

.site-footer__menu a {
	color: rgba(255, 255, 255, 0.74);
}

.site-footer__menu a:hover {
	color: #ffffff;
}

.site-footer__menu span {
	color: rgba(255, 255, 255, 0.38);
}

.site-footer__note {
	grid-column: 1 / -1;
	padding-top: 20px;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.site-footer__copyright {
	grid-column: 1 / -1;
	font-size: 0.88rem;
}

.page-orbit-hero {
	position: relative;
	padding: 110px 0 76px;
	background: linear-gradient(140deg, var(--deep), var(--deep-2));
	color: #ffffff;
}

.page-orbit-hero h1 {
	max-width: 900px;
	margin-bottom: 14px;
	color: #ffffff;
	font-size: clamp(2.1rem, 4vw, 3.8rem);
	line-height: 1.1;
}

.page-orbit-hero p:not(.eyebrow),
.page-orbit-hero time,
.archive-description {
	color: rgba(255, 255, 255, 0.76);
}

.page-orbit-hero--center {
	min-height: 58vh;
	display: grid;
	align-items: center;
	text-align: center;
}

.page-orbit-hero--center .section-shell {
	max-width: 760px;
}

.content-shell {
	max-width: 900px;
}

.entry-panel,
.archive-item {
	background: var(--surface);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
}

.entry-panel {
	padding: 34px;
}

.entry-thumbnail {
	overflow: hidden;
	margin-bottom: 28px;
	border-radius: var(--radius);
}

.entry-content > * {
	margin-bottom: 1.35em;
}

.entry-content > *:last-child {
	margin-bottom: 0;
}

.entry-content h2,
.entry-content h3 {
	color: var(--ink);
	line-height: 1.45;
}

.entry-content a {
	color: var(--blue);
	text-decoration: underline;
	text-underline-offset: 0.18em;
}

.single-post-page {
	background: var(--deep);
	color: #ffffff;
}

.journal-single__hero {
	overflow: hidden;
	background:
		radial-gradient(circle at 82% 22%, rgba(46, 230, 240, 0.16), transparent 32%),
		radial-gradient(circle at 12% 78%, rgba(33, 146, 242, 0.18), transparent 34%),
		linear-gradient(140deg, var(--deep), var(--deep-2));
}

.journal-single__hero::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(rgba(255, 255, 255, 0.045) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 255, 255, 0.045) 1px, transparent 1px);
	background-size: 42px 42px;
	mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.9), transparent 92%);
	pointer-events: none;
}

.journal-single__hero::after {
	content: "";
	position: absolute;
	right: 9%;
	bottom: -80px;
	width: 360px;
	height: 360px;
	border: 1px solid rgba(46, 230, 240, 0.22);
	border-radius: 50%;
	pointer-events: none;
}

.journal-heading-flow {
	max-width: 860px;
	text-wrap: balance;
}

.journal-single__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 18px;
	color: rgba(255, 255, 255, 0.78);
	font-size: 0.88rem;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.journal-single__meta a {
	color: var(--cyan);
	text-decoration: none;
}

.journal-single__section {
	position: relative;
	margin-top: -1px;
	padding-top: 84px;
	background:
		linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 255, 255, 0.035) 1px, transparent 1px),
		var(--deep);
	background-size: 34px 34px;
}

.journal-single__shell {
	max-width: 900px;
}

.journal-single__panel,
.journal-single__cta,
.journal-single__post-nav a {
	background: rgba(8, 22, 36, 0.72);
	border: 1px solid rgba(120, 220, 255, 0.18);
	border-radius: var(--radius);
	box-shadow: var(--shadow-dark);
}

.journal-single__panel {
	padding: 42px;
	backdrop-filter: blur(14px);
}

.journal-single__thumbnail {
	overflow: hidden;
	margin-bottom: 32px;
	border: 1px solid rgba(120, 220, 255, 0.16);
	border-radius: var(--radius);
}

.journal-single__body {
	color: rgba(255, 255, 255, 0.82);
	font-size: 1.02rem;
	line-height: 1.95;
}

.journal-single__body > * + * {
	margin-top: 1.35em;
}

.journal-single__body :where(h2, h3, h4) {
	color: #ffffff;
	line-height: 1.42;
}

.journal-single__body h2 {
	margin-top: 2.1em;
	padding-top: 0.85em;
	border-top: 1px solid rgba(120, 220, 255, 0.16);
	font-size: clamp(1.45rem, 2.2vw, 2rem);
}

.journal-single__body h3 {
	margin-top: 1.85em;
	font-size: clamp(1.2rem, 1.8vw, 1.55rem);
}

.journal-single__body :where(ul, ol) {
	padding-left: 1.35em;
}

.journal-single__body li + li {
	margin-top: 0.45em;
}

.journal-single__body a {
	color: var(--cyan);
	font-weight: 800;
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.22em;
}

.journal-single__body :where(blockquote, pre) {
	padding: 18px 20px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(120, 220, 255, 0.14);
	border-radius: var(--radius);
}

.journal-single__body :where(img, iframe, video) {
	max-width: 100%;
}

.journal-single__cta {
	margin-top: 24px;
	padding: 28px;
}

.journal-single__cta p {
	max-width: 680px;
	color: rgba(255, 255, 255, 0.82);
}

.journal-single__links {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 20px;
}

.journal-single__links a {
	display: inline-flex;
	align-items: center;
	min-height: 44px;
	padding: 10px 16px;
	color: #06101d;
	background: var(--cyan);
	border-radius: var(--radius);
	font-weight: 900;
}

.journal-single__links a:nth-child(n+2) {
	color: #ffffff;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(120, 220, 255, 0.22);
}

.journal-single__post-nav {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px;
	margin-top: 20px;
}

.journal-single__post-nav a {
	display: grid;
	gap: 6px;
	padding: 20px;
}

.journal-single__post-nav span {
	color: var(--cyan);
	font-size: 0.72rem;
	font-weight: 900;
	letter-spacing: 0.13em;
	text-transform: uppercase;
}

.journal-single__post-nav strong {
	color: #ffffff;
	line-height: 1.5;
}

@media (max-width: 720px) {
	.journal-single__hero {
		padding: 92px 0 58px;
	}

	.journal-heading-flow {
		max-width: 100%;
		text-wrap: wrap;
		overflow-wrap: anywhere;
	}

	.journal-single__section {
		padding-top: 64px;
	}

	.journal-single__panel {
		padding: 24px;
	}

	.journal-single__body {
		font-size: 1rem;
		line-height: 1.9;
	}

	.journal-single__cta {
		padding: 24px;
	}

	.journal-single__links {
		display: grid;
	}

	.journal-single__links a {
		justify-content: center;
		width: 100%;
	}

	.journal-single__post-nav {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 420px) {
	.journal-single__panel,
	.journal-single__cta,
	.journal-single__post-nav a {
		padding: 20px;
	}
}

.orbit-page-list {
	display: grid;
	gap: 18px;
}

.orbit-page-item,
.orbit-detail-panel,
.sitemap-group {
	background: var(--surface);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
}

.orbit-page-item {
	display: grid;
	grid-template-columns: 72px minmax(0, 1fr);
	gap: 24px;
	padding: 28px;
}

.orbit-page-item__number {
	color: var(--blue);
	font-size: 1.65rem;
	font-weight: 900;
	line-height: 1;
}

.orbit-page-item h2,
.orbit-detail-panel h2,
.sitemap-group h2 {
	margin-bottom: 14px;
	color: var(--ink);
	font-size: clamp(1.35rem, 2.4vw, 2rem);
	line-height: 1.35;
}

.orbit-page-item p,
.orbit-detail-panel p {
	color: var(--text);
}

.orbit-page-item p + p,
.orbit-detail-panel p + p {
	margin-top: 12px;
}

.orbit-page-item__note {
	padding-left: 12px;
	border-left: 2px solid var(--blue);
	font-weight: 800;
}

.orbit-detail-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 20px;
}

.orbit-detail-panel {
	padding: 28px;
}

.orbit-detail-panel--wide {
	grid-column: 1 / -1;
}

.orbit-check-list {
	display: grid;
	gap: 10px;
	margin: 0;
	padding-left: 1.1em;
	color: var(--text);
}

/* 修正：2026/05/28 Hoda
   内容：指摘No.1 Servicesページを主力領域・構想支援・専門技術領域に再構成
   ここから */
.services-page {
	background: var(--deep);
	color: #ffffff;
}

.services-hero {
	overflow: hidden;
	padding-bottom: 92px;
}

.services-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(rgba(46, 230, 240, 0.045) 1px, transparent 1px),
		linear-gradient(90deg, rgba(46, 230, 240, 0.045) 1px, transparent 1px);
	background-size: 68px 68px;
	mask-image: linear-gradient(90deg, transparent, #000 18%, #000 82%, transparent);
	pointer-events: none;
}

.services-hero__shell {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
	gap: 56px;
	align-items: end;
}

.services-hero__content {
	max-width: 780px;
}

.services-hero__phases,
.services-hero__index {
	position: relative;
	z-index: 1;
}

.services-hero__phases {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 28px;
}

.services-hero__phases span {
	padding: 7px 10px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(185, 216, 247, 0.2);
	border-radius: var(--radius);
	color: rgba(255, 255, 255, 0.78);
	font-size: 0.72rem;
	font-weight: 900;
	letter-spacing: 0.12em;
}

.services-hero__index {
	display: grid;
	gap: 12px;
	padding: 22px;
	background: rgba(7, 18, 33, 0.72);
	border: 1px solid var(--line-dark);
	border-radius: var(--radius);
	box-shadow: var(--shadow-dark);
}

.services-hero__index a {
	display: grid;
	grid-template-columns: 42px minmax(0, 1fr);
	gap: 12px;
	align-items: center;
	min-height: 46px;
	color: rgba(255, 255, 255, 0.86);
	font-size: 0.82rem;
	font-weight: 900;
	letter-spacing: 0.08em;
	transition: color 0.2s ease, transform 0.2s ease;
}

.services-hero__index a:hover {
	color: var(--cyan);
	transform: translateX(4px);
}

.services-hero__index span {
	color: var(--cyan);
	font-size: 0.78rem;
}

.services-section {
	position: relative;
	padding: 104px 0;
}

.services-section--core,
.services-section--specialized {
	background: var(--deep);
	color: #ffffff;
}

.services-section--prototype {
	background: linear-gradient(180deg, var(--paper-blue), var(--paper));
	color: var(--ink);
}

.services-section--cta {
	background: linear-gradient(180deg, var(--deep), #030712);
	color: #ffffff;
}

.services-section-heading h2,
.services-section-heading p {
	color: #ffffff;
}

.services-section--prototype .services-section-heading h2,
.services-section--prototype .services-section-heading p {
	color: var(--ink);
}

.services-core-grid {
	display: grid;
	grid-template-columns: repeat(12, minmax(0, 1fr));
	gap: 20px;
	align-items: stretch;
}

.services-card,
.services-field-card {
	position: relative;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	gap: 18px;
	padding: 30px;
	background: linear-gradient(145deg, rgba(14, 31, 52, 0.92), rgba(7, 17, 31, 0.94));
	border: 1px solid var(--line-dark);
	border-radius: var(--radius);
	box-shadow: var(--shadow-dark);
}

.services-card::before,
.services-field-card::before,
.services-prototype::before,
.services-final-cta::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(rgba(46, 230, 240, 0.055) 1px, transparent 1px),
		linear-gradient(90deg, rgba(46, 230, 240, 0.055) 1px, transparent 1px);
	background-size: 42px 42px;
	opacity: 0.34;
	pointer-events: none;
}

.services-card > *,
.services-field-card > *,
.services-prototype > *,
.services-final-cta > * {
	position: relative;
	z-index: 1;
}

.services-card--primary,
.services-card--partner {
	grid-column: span 7;
}

.services-card--new-business,
.services-card--web {
	grid-column: span 5;
}

.services-card--primary {
	min-height: 420px;
	background: linear-gradient(145deg, rgba(18, 43, 72, 0.98), rgba(5, 13, 26, 0.98));
}

.services-card--primary h2 {
	font-size: clamp(2rem, 3vw, 3rem);
}

.services-card--new-business,
.services-card--partner {
	background: linear-gradient(145deg, rgba(8, 28, 48, 0.98), rgba(4, 12, 25, 0.98));
}

.services-card--web {
	background: linear-gradient(145deg, rgba(13, 38, 56, 0.98), rgba(5, 14, 26, 0.98));
}

.services-card__header {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	align-items: center;
}

.services-card__number {
	color: var(--cyan);
	font-size: 1.75rem;
	font-weight: 900;
	line-height: 1;
}

.services-card__label {
	padding: 5px 9px;
	background: rgba(46, 230, 240, 0.12);
	border: 1px solid rgba(46, 230, 240, 0.28);
	border-radius: var(--radius);
	color: var(--cyan);
	font-size: 0.68rem;
	font-weight: 900;
	letter-spacing: 0.12em;
}

.services-card h2,
.services-field-card h2,
.services-prototype h2,
.services-final-cta h2 {
	margin-bottom: 0;
	color: #ffffff;
	font-size: clamp(1.5rem, 2.4vw, 2.35rem);
	line-height: 1.22;
	letter-spacing: 0;
}

/* 修正：2026/05/28 Hoda
   内容：指摘No.1〜3 Servicesページ見出しの改行位置を自然な2行構成へ修正
   ここから */
.services-heading-flow span {
	display: block;
}
/* ここまで */

.services-card p,
.services-field-card p,
.services-prototype p,
.services-final-cta p {
	color: rgba(255, 255, 255, 0.78);
}

.services-card__fit strong {
	color: #ffffff;
}

.services-card__note {
	padding-left: 14px;
	border-left: 2px solid var(--cyan);
	font-weight: 800;
}

.services-card__link {
	display: inline-flex;
	align-items: center;
	width: fit-content;
	min-height: 44px;
	margin-top: auto;
	color: var(--cyan);
	font-weight: 900;
}

.services-card__link::after {
	content: "";
	width: 28px;
	height: 1px;
	margin-left: 12px;
	background: currentColor;
	transform-origin: left;
	transition: transform 0.2s ease;
}

.services-card__link:hover::after {
	transform: scaleX(1.35);
}

.services-card__link--muted {
	color: rgba(255, 255, 255, 0.82);
}

.services-prototype {
	position: relative;
	overflow: hidden;
	display: grid;
	grid-template-columns: minmax(0, 0.95fr) minmax(320px, 0.75fr);
	gap: 44px;
	align-items: center;
	padding: 42px;
	background: linear-gradient(135deg, #071322, #102b4c);
	border: 1px solid var(--line-dark);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	color: #ffffff;
}

.services-prototype__body {
	display: grid;
	gap: 16px;
}

.services-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 12px 24px;
	margin-top: 6px;
}

.services-prototype__visual {
	position: relative;
	min-height: 310px;
	border: 1px solid rgba(185, 216, 247, 0.2);
	border-radius: var(--radius);
	background:
		radial-gradient(circle at 70% 24%, rgba(46, 230, 240, 0.18), transparent 34%),
		rgba(255, 255, 255, 0.035);
}

.services-prototype__orbit {
	position: absolute;
	inset: 42px 24px;
	border: 1px solid rgba(46, 230, 240, 0.28);
	border-radius: 999px;
	transform: rotate(-12deg);
}

.services-prototype__node {
	position: absolute;
	width: 12px;
	height: 12px;
	background: var(--cyan);
	border-radius: 50%;
	box-shadow: 0 0 22px rgba(46, 230, 240, 0.7);
}

.services-prototype__node--idea {
	top: 58px;
	left: 24%;
}

.services-prototype__node--screen {
	top: 48%;
	right: 18%;
}

.services-prototype__node--build {
	bottom: 52px;
	left: 38%;
}

.services-prototype__screen {
	position: absolute;
	left: 50%;
	top: 50%;
	display: grid;
	gap: 12px;
	width: min(72%, 320px);
	padding: 22px;
	background: rgba(2, 8, 20, 0.82);
	border: 1px solid rgba(185, 216, 247, 0.22);
	border-radius: var(--radius);
	transform: translate(-50%, -50%);
}

.services-prototype__screen span {
	height: 11px;
	background: linear-gradient(90deg, var(--cyan), rgba(255, 255, 255, 0.18));
	border-radius: 999px;
}

.services-prototype__screen span:nth-child(2) {
	width: 74%;
}

.services-prototype__screen span:nth-child(3) {
	width: 48%;
}

.services-prototype__screen span:nth-child(4) {
	width: 86%;
}

.services-specialized-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 20px;
	align-items: start;
}

.services-field-card {
	min-height: 360px;
	background: linear-gradient(145deg, rgba(9, 23, 40, 0.96), rgba(4, 12, 24, 0.98));
}

.services-final-cta {
	position: relative;
	overflow: hidden;
	max-width: 920px;
	padding: 42px;
	background: linear-gradient(135deg, rgba(14, 36, 62, 0.92), rgba(4, 10, 20, 0.96));
	border: 1px solid var(--line-dark);
	border-radius: var(--radius);
	box-shadow: var(--shadow-dark);
}

.services-final-cta h2 {
	max-width: 720px;
}

.services-final-cta p {
	max-width: 760px;
}
/* ここまで */

/* 修正（追加）：2026/05/28 Hoda
   内容：Partnershipページ専用のOrbit Conceptレイアウト・カード・支援サイクル・CTAスタイルを追加
   ここから */
.partner-page {
	overflow: hidden;
	background: var(--deep);
	color: #ffffff;
}

.partner-hero {
	overflow: hidden;
	padding-bottom: 96px;
}

.partner-hero::before,
.partner-section::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(rgba(46, 230, 240, 0.045) 1px, transparent 1px),
		linear-gradient(90deg, rgba(46, 230, 240, 0.045) 1px, transparent 1px);
	background-size: 68px 68px;
	mask-image: linear-gradient(90deg, transparent, #000 16%, #000 84%, transparent);
	pointer-events: none;
}

.partner-hero__shell {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(300px, 390px);
	gap: 58px;
	align-items: end;
}

.partner-hero__content {
	max-width: 780px;
}

.partner-heading-flow span,
.partner-hero__lead span {
	display: block;
}

/* 修正（追加）：2026/05/28 Hoda
   内容：Partnershipページ対象見出し2箇所の自然な改行制御を追加
   ここから */
@media (min-width: 721px) {
	.partner-page .partner-heading-flow--cycle > span,
	.partner-page .partner-heading-flow--estimate > span {
		white-space: nowrap;
	}
}

@media (max-width: 720px) {
	.partner-page .partner-heading-flow--cycle > span,
	.partner-page .partner-heading-flow--estimate > span {
		white-space: normal;
	}
}
/* ここまで */

.partner-hero h1 {
	font-size: clamp(2.45rem, 4.6vw, 4.7rem);
}

.partner-hero__lead {
	margin: 24px 0 18px;
	color: #ffffff;
	font-size: clamp(1.18rem, 2vw, 1.55rem);
	font-weight: 850;
	line-height: 1.55;
}

.partner-index-panel {
	display: grid;
	gap: 12px;
	padding: 22px;
	background: rgba(7, 18, 33, 0.74);
	border: 1px solid var(--line-dark);
	border-radius: var(--radius);
	box-shadow: var(--shadow-dark);
}

.partner-index-panel__item {
	display: grid;
	grid-template-columns: 36px minmax(0, 1fr);
	gap: 8px 14px;
	align-items: baseline;
	padding: 13px 0;
	border-bottom: 1px solid rgba(185, 216, 247, 0.12);
}

.partner-index-panel__item:last-child {
	border-bottom: 0;
}

.partner-index-panel__item span {
	color: var(--cyan);
	font-size: 0.76rem;
	font-weight: 900;
	letter-spacing: 0.12em;
}

.partner-index-panel__item strong {
	color: #ffffff;
	font-size: 0.84rem;
	font-weight: 900;
	letter-spacing: 0.13em;
}

.partner-index-panel__item em {
	grid-column: 2;
	color: rgba(255, 255, 255, 0.68);
	font-size: 0.88rem;
	font-style: normal;
}

.partner-section {
	position: relative;
	padding: 104px 0;
	background: var(--deep);
	color: #ffffff;
}

.partner-section > .section-shell {
	position: relative;
	z-index: 1;
}

.partner-section--why,
.partner-section--monthly {
	background: linear-gradient(180deg, var(--deep), #06111f);
}

.partner-section--cycle,
.partner-section--estimate {
	background: #06101d;
}

.partner-section--cta {
	background: linear-gradient(180deg, #06101d, #030712);
}

.partner-section-heading {
	max-width: 820px;
	margin-bottom: 34px;
}

.partner-section-heading--split {
	display: grid;
	grid-template-columns: minmax(0, 0.72fr) minmax(280px, 0.48fr);
	gap: 48px;
	align-items: end;
	max-width: none;
}

.partner-section-heading h2,
.partner-scope-panel h2,
.partner-estimate-panel h2,
.partner-final-cta h2 {
	margin-bottom: 0;
	color: #ffffff;
	font-size: clamp(1.85rem, 3vw, 3rem);
	line-height: 1.2;
	letter-spacing: 0;
}

.partner-section-heading p,
.partner-scope-panel p,
.partner-estimate-panel p,
.partner-final-cta p {
	color: rgba(255, 255, 255, 0.76);
}

.partner-why-grid {
	display: grid;
	grid-template-columns: repeat(12, minmax(0, 1fr));
	gap: 18px;
	align-items: start;
}

.partner-why-card {
	position: relative;
	overflow: hidden;
	min-height: 180px;
	padding: 26px;
	background: linear-gradient(145deg, rgba(14, 31, 52, 0.94), rgba(7, 17, 31, 0.94));
	border: 1px solid var(--line-dark);
	border-radius: var(--radius);
	box-shadow: var(--shadow-dark);
}

.partner-why-card::before,
.partner-scope-panel::before,
.partner-estimate-panel::before,
.partner-final-cta::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(rgba(46, 230, 240, 0.05) 1px, transparent 1px),
		linear-gradient(90deg, rgba(46, 230, 240, 0.05) 1px, transparent 1px);
	background-size: 42px 42px;
	opacity: 0.38;
	pointer-events: none;
}

.partner-why-card > *,
.partner-scope-panel > *,
.partner-estimate-panel > *,
.partner-final-cta > * {
	position: relative;
	z-index: 1;
}

.partner-why-card--1,
.partner-why-card--4 {
	grid-column: span 5;
}

.partner-why-card--2,
.partner-why-card--3 {
	grid-column: span 7;
}

.partner-why-card--5 {
	grid-column: 3 / span 8;
}

.partner-why-card span {
	display: inline-flex;
	margin-bottom: 22px;
	color: var(--cyan);
	font-size: 0.82rem;
	font-weight: 900;
	letter-spacing: 0.12em;
}

.partner-why-card p {
	color: #ffffff;
	font-size: clamp(1.05rem, 1.7vw, 1.36rem);
	font-weight: 850;
	line-height: 1.55;
}

.partner-cycle {
	position: relative;
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 0;
	border-top: 1px solid var(--line-dark);
	border-bottom: 1px solid var(--line-dark);
}

.partner-cycle::before {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	top: 42px;
	height: 1px;
	background: linear-gradient(90deg, var(--cyan), rgba(33, 146, 242, 0.75), transparent);
}

.partner-cycle__step {
	position: relative;
	display: grid;
	gap: 9px;
	padding: 28px 22px 30px 0;
}

.partner-cycle__step + .partner-cycle__step {
	padding-left: 22px;
	border-left: 1px solid var(--line-dark);
}

.partner-cycle__step span {
	position: relative;
	z-index: 1;
	display: inline-grid;
	place-items: center;
	width: 34px;
	height: 34px;
	background: var(--deep);
	border: 1px solid rgba(46, 230, 240, 0.48);
	border-radius: 50%;
	color: var(--cyan);
	font-size: 0.72rem;
	font-weight: 900;
}

.partner-cycle__step h3 {
	color: #ffffff;
	font-size: 1.06rem;
}

.partner-cycle__step p {
	color: rgba(255, 255, 255, 0.7);
	font-size: 0.95rem;
}

.partner-scope-shell,
.partner-estimate-shell {
	max-width: 1040px;
}

.partner-scope-panel,
.partner-estimate-panel,
.partner-final-cta {
	position: relative;
	overflow: hidden;
	padding: 38px;
	background: linear-gradient(135deg, rgba(13, 36, 62, 0.96), rgba(4, 11, 22, 0.98));
	border: 1px solid var(--line-dark);
	border-radius: var(--radius);
	box-shadow: var(--shadow-dark);
}

.partner-scope-panel {
	display: grid;
	gap: 22px;
}

.partner-scope-list,
.partner-estimate-list {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.partner-scope-list li,
.partner-estimate-list li {
	padding: 14px 16px;
	background: rgba(255, 255, 255, 0.055);
	border: 1px solid rgba(185, 216, 247, 0.14);
	border-radius: var(--radius);
	color: rgba(255, 255, 255, 0.86);
	font-weight: 850;
}

.partner-scope-list li::before,
.partner-estimate-list li::before {
	content: "";
	display: inline-block;
	width: 7px;
	height: 7px;
	margin-right: 10px;
	background: var(--cyan);
	border-radius: 50%;
	box-shadow: 0 0 14px rgba(46, 230, 240, 0.6);
}

.partner-scope-panel__note,
.partner-estimate-panel__note {
	width: fit-content;
	max-width: 100%;
	padding: 10px 12px;
	background: rgba(46, 230, 240, 0.1);
	border: 1px solid rgba(46, 230, 240, 0.25);
	border-radius: var(--radius);
	color: #ffffff;
	font-weight: 900;
}

.partner-estimate-panel {
	display: grid;
	grid-template-columns: minmax(0, 0.9fr) minmax(320px, 1fr);
	gap: 34px;
	align-items: start;
	background: linear-gradient(135deg, rgba(8, 20, 36, 0.98), rgba(5, 12, 24, 0.98));
}

.partner-estimate-panel__note {
	grid-column: 1 / -1;
	background: rgba(255, 255, 255, 0.055);
	border-color: rgba(185, 216, 247, 0.16);
	color: rgba(255, 255, 255, 0.82);
}

.partner-final-cta {
	max-width: 920px;
}

.partner-final-cta h2 {
	max-width: 780px;
}

.partner-final-cta p {
	max-width: 740px;
	margin-top: 16px;
}

.partner-final-cta .services-actions {
	margin-top: 24px;
}

.partner-final-cta .text-link {
	color: var(--cyan);
}
/* ここまで */

/* 修正（追加）：2026/05/28 Hoda
   内容：Processページ専用のOrbit Conceptレイアウト、工程表示、
         判断ポイント、CTAおよび自然な見出し改行制御を追加
   ここから */
.process-page {
	overflow: hidden;
	background: var(--deep);
	color: #ffffff;
}

.process-hero {
	overflow: hidden;
	padding-bottom: 96px;
}

.process-hero::before,
.process-section::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(rgba(46, 230, 240, 0.045) 1px, transparent 1px),
		linear-gradient(90deg, rgba(46, 230, 240, 0.045) 1px, transparent 1px);
	background-size: 68px 68px;
	mask-image: linear-gradient(90deg, transparent, #000 16%, #000 84%, transparent);
	pointer-events: none;
}

.process-hero__shell {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(300px, 390px);
	gap: 58px;
	align-items: end;
}

.process-hero__content {
	max-width: 820px;
}

.process-heading-flow span,
.process-hero__lead span {
	display: block;
}

@media (min-width: 721px) {
	.process-page .process-heading-flow > span {
		white-space: nowrap;
	}
}

@media (max-width: 720px) {
	.process-page .process-heading-flow > span {
		white-space: normal;
	}
}

.process-hero h1 {
	font-size: clamp(2.45rem, 4.6vw, 4.7rem);
}

.process-hero__lead {
	margin-top: 22px;
	color: rgba(255, 255, 255, 0.8);
	font-size: clamp(1rem, 1.45vw, 1.22rem);
	line-height: 1.8;
}

.process-index-panel {
	display: grid;
	gap: 12px;
	padding: 22px;
	background: rgba(7, 18, 33, 0.74);
	border: 1px solid var(--line-dark);
	border-radius: var(--radius);
	box-shadow: var(--shadow-dark);
}

.process-index-panel__item {
	display: grid;
	grid-template-columns: 36px minmax(0, 1fr);
	gap: 8px 14px;
	align-items: baseline;
	padding: 13px 0;
	border-bottom: 1px solid rgba(185, 216, 247, 0.12);
}

.process-index-panel__item:last-child {
	border-bottom: 0;
}

.process-index-panel__item span {
	color: var(--cyan);
	font-size: 0.76rem;
	font-weight: 900;
	letter-spacing: 0.12em;
}

.process-index-panel__item strong {
	color: #ffffff;
	font-size: 0.84rem;
	font-weight: 900;
	letter-spacing: 0.13em;
}

.process-index-panel__item em {
	grid-column: 2;
	color: rgba(255, 255, 255, 0.68);
	font-size: 0.88rem;
	font-style: normal;
}

.process-section {
	position: relative;
	padding: 104px 0;
	background: var(--deep);
	color: #ffffff;
}

.process-section > .section-shell {
	position: relative;
	z-index: 1;
}

.process-section--journey,
.process-section--after {
	background: linear-gradient(180deg, var(--deep), #06111f);
}

.process-section--decision {
	background: #06101d;
}

.process-section--cta {
	background: linear-gradient(180deg, #06101d, #030712);
}

.process-section-heading {
	max-width: 840px;
	margin-bottom: 34px;
}

.process-section-heading--split {
	display: grid;
	grid-template-columns: minmax(0, 0.7fr) minmax(280px, 0.52fr);
	gap: 48px;
	align-items: end;
	max-width: none;
}

.process-section-heading h2,
.process-decision-panel h2,
.process-final-cta h2 {
	margin-bottom: 0;
	color: #ffffff;
	font-size: clamp(1.85rem, 3vw, 3rem);
	line-height: 1.2;
	letter-spacing: 0;
}

.process-section-heading p,
.process-decision-panel p,
.process-final-cta p {
	color: rgba(255, 255, 255, 0.76);
}

.process-journey-grid {
	position: relative;
	display: grid;
	grid-template-columns: repeat(12, minmax(0, 1fr));
	gap: 18px;
	align-items: stretch;
}

.process-journey-grid::before {
	content: "";
	position: absolute;
	left: 3%;
	right: 3%;
	top: 50%;
	height: 1px;
	background: linear-gradient(90deg, transparent, rgba(46, 230, 240, 0.52), transparent);
	pointer-events: none;
}

.process-step-card {
	position: relative;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	gap: 15px;
	min-height: 230px;
	padding: 26px;
	background: linear-gradient(145deg, rgba(14, 31, 52, 0.94), rgba(7, 17, 31, 0.94));
	border: 1px solid var(--line-dark);
	border-radius: var(--radius);
	box-shadow: var(--shadow-dark);
}

.process-step-card::before,
.process-decision-panel::before,
.process-final-cta::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(rgba(46, 230, 240, 0.05) 1px, transparent 1px),
		linear-gradient(90deg, rgba(46, 230, 240, 0.05) 1px, transparent 1px);
	background-size: 42px 42px;
	opacity: 0.38;
	pointer-events: none;
}

.process-step-card > *,
.process-decision-panel > *,
.process-final-cta > * {
	position: relative;
	z-index: 1;
}

.process-step-card--entry {
	grid-column: span 6;
	min-height: 190px;
}

.process-step-card--focus {
	grid-column: span 6;
	min-height: 320px;
	background: linear-gradient(145deg, rgba(18, 43, 72, 0.98), rgba(5, 13, 26, 0.98));
}

.process-step-card--build {
	grid-column: span 6;
	min-height: 210px;
	background: linear-gradient(145deg, rgba(8, 28, 48, 0.98), rgba(4, 12, 25, 0.98));
}

.process-step-card__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	align-items: center;
}

.process-step-card__meta span {
	color: var(--cyan);
	font-size: 1.55rem;
	font-weight: 900;
	line-height: 1;
}

.process-step-card__meta em {
	padding: 5px 9px;
	background: rgba(46, 230, 240, 0.12);
	border: 1px solid rgba(46, 230, 240, 0.28);
	border-radius: var(--radius);
	color: var(--cyan);
	font-size: 0.68rem;
	font-style: normal;
	font-weight: 900;
	letter-spacing: 0.12em;
}

.process-step-card h3 {
	color: #ffffff;
	font-size: clamp(1.35rem, 2.2vw, 2.1rem);
	line-height: 1.25;
}

.process-step-card p {
	color: rgba(255, 255, 255, 0.76);
}

.process-step-card--focus h3 {
	font-size: clamp(1.65rem, 2.65vw, 2.55rem);
}

.process-decision-panel {
	position: relative;
	overflow: hidden;
	display: grid;
	grid-template-columns: minmax(0, 0.9fr) minmax(320px, 0.72fr);
	gap: 42px;
	align-items: center;
	padding: 42px;
	background: linear-gradient(135deg, rgba(13, 36, 62, 0.96), rgba(4, 11, 22, 0.98));
	border: 1px solid var(--line-dark);
	border-radius: var(--radius);
	box-shadow: var(--shadow-dark);
}

.process-decision-panel__body {
	display: grid;
	gap: 18px;
}

.process-decision-panel .text-link {
	color: var(--cyan);
}

.process-decision-list,
.process-after-list {
	display: grid;
	gap: 12px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.process-decision-list li,
.process-after-list li {
	padding: 14px 16px;
	background: rgba(255, 255, 255, 0.055);
	border: 1px solid rgba(185, 216, 247, 0.14);
	border-radius: var(--radius);
	color: rgba(255, 255, 255, 0.86);
	font-weight: 850;
}

.process-decision-list li::before,
.process-after-list li::before {
	content: "";
	display: inline-block;
	width: 7px;
	height: 7px;
	margin-right: 10px;
	background: var(--cyan);
	border-radius: 50%;
	box-shadow: 0 0 14px rgba(46, 230, 240, 0.6);
}

.process-after-shell {
	display: grid;
	grid-template-columns: minmax(0, 0.72fr) minmax(300px, 0.45fr);
	gap: 46px;
	align-items: start;
}

.process-after-list {
	padding: 24px;
	background: rgba(7, 18, 33, 0.74);
	border: 1px solid var(--line-dark);
	border-radius: var(--radius);
	box-shadow: var(--shadow-dark);
}

.process-final-cta {
	position: relative;
	overflow: hidden;
	max-width: 980px;
	padding: 42px;
	background: linear-gradient(135deg, rgba(14, 36, 62, 0.92), rgba(4, 10, 20, 0.96));
	border: 1px solid var(--line-dark);
	border-radius: var(--radius);
	box-shadow: var(--shadow-dark);
}

.process-final-cta h2 {
	max-width: 840px;
}

.process-final-cta p {
	max-width: 760px;
	margin-top: 16px;
}

.process-final-cta .services-actions {
	margin-top: 24px;
}

.process-final-cta .text-link {
	color: var(--cyan);
}

@media (max-width: 1080px) {
	.process-hero__shell,
	.process-section-heading--split,
	.process-decision-panel,
	.process-after-shell {
		grid-template-columns: 1fr;
	}

	.process-index-panel {
		max-width: 560px;
	}
}

@media (max-width: 720px) {
	.process-hero {
		padding-bottom: 68px;
	}

	.process-hero__shell {
		gap: 36px;
	}

	.process-section {
		padding: 76px 0;
	}

	.process-section-heading,
	.process-section-heading--split {
		margin-bottom: 26px;
	}

	.process-section-heading h2,
	.process-decision-panel h2,
	.process-final-cta h2 {
		font-size: clamp(1.55rem, 7vw, 2.35rem);
	}

	.process-journey-grid {
		grid-template-columns: 1fr;
	}

	.process-journey-grid::before {
		top: 0;
		bottom: 0;
		left: 17px;
		right: auto;
		width: 1px;
		height: auto;
		background: linear-gradient(180deg, var(--cyan), rgba(33, 146, 242, 0.75), transparent);
	}

	.process-step-card--entry,
	.process-step-card--focus,
	.process-step-card--build {
		grid-column: auto;
		min-height: auto;
	}

	.process-step-card,
	.process-decision-panel,
	.process-after-list,
	.process-final-cta {
		padding: 24px;
	}

	.process-decision-list,
	.process-after-list {
		grid-template-columns: 1fr;
	}

	.process-final-cta .services-actions {
		display: grid;
	}
}

@media (max-width: 420px) {
	.process-index-panel__item {
		grid-template-columns: 30px minmax(0, 1fr);
	}
}
/* ここまで */

/* 修正（追加）：2026/05/28 Hoda
   内容：Contactページ専用のOrbit Conceptレイアウト、
         フォーム表示、Privacy導線および自然な見出し改行制御を追加
   ここから */
.contact-page {
	overflow: hidden;
	background: var(--deep);
	color: #ffffff;
}

.contact-hero,
.contact-section {
	position: relative;
	overflow: hidden;
}

.contact-hero {
	padding-bottom: 96px;
}

.contact-hero::before,
.contact-section::before {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	background-image:
		linear-gradient(rgba(46, 230, 240, 0.07) 1px, transparent 1px),
		linear-gradient(90deg, rgba(46, 230, 240, 0.07) 1px, transparent 1px);
	background-size: 68px 68px;
	mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.9), transparent 82%);
}

.contact-hero__shell {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(300px, 390px);
	gap: 58px;
	align-items: end;
}

.contact-hero__content {
	max-width: 850px;
}

.contact-heading-flow > span,
.contact-hero__lead > span {
	display: block;
}

@media (min-width: 721px) {
	.contact-page .contact-heading-flow > span {
		white-space: nowrap;
	}
}

@media (max-width: 720px) {
	.contact-page .contact-heading-flow > span {
		white-space: normal;
	}
}

.contact-hero h1 {
	margin: 0;
	color: #ffffff;
	font-size: 3rem;
	line-height: 1.12;
}

.contact-hero__lead {
	margin: 24px 0 0;
	color: rgba(255, 255, 255, 0.8);
	font-size: 1.12rem;
	line-height: 1.85;
}

.contact-index-panel {
	display: grid;
	gap: 12px;
	padding: 28px;
	border: 1px solid var(--line-dark);
	border-radius: var(--radius);
	background:
		linear-gradient(135deg, rgba(46, 230, 240, 0.12), transparent 42%),
		rgba(255, 255, 255, 0.045);
	box-shadow: var(--shadow-dark);
}

.contact-index-panel__item {
	display: grid;
	grid-template-columns: 40px minmax(0, 1fr);
	gap: 6px 14px;
	align-items: baseline;
	padding: 14px 0;
	border-bottom: 1px solid rgba(185, 216, 247, 0.14);
}

.contact-index-panel__item:last-child {
	border-bottom: 0;
}

.contact-index-panel__item span {
	grid-row: 1 / span 2;
	color: var(--cyan);
	font-weight: 900;
}

.contact-index-panel__item strong {
	color: #ffffff;
	font-size: 0.82rem;
}

.contact-index-panel__item em {
	color: rgba(255, 255, 255, 0.72);
	font-style: normal;
	font-size: 0.9rem;
}

.contact-section {
	padding: 104px 0;
	background: var(--deep);
}

.contact-section > .section-shell {
	position: relative;
	z-index: 1;
}

.contact-section--guide {
	background: linear-gradient(180deg, var(--deep) 0%, #06111f 100%);
}

.contact-section--form {
	background: linear-gradient(180deg, #06111f 0%, #030712 100%);
}

.contact-section-heading {
	margin-bottom: 34px;
}

.contact-section-heading--split {
	display: grid;
	grid-template-columns: minmax(0, 0.72fr) minmax(280px, 0.5fr);
	gap: 48px;
	align-items: end;
}

.contact-section-heading h2,
.contact-form-lead h2 {
	margin: 0;
	color: #ffffff;
	font-size: 2.75rem;
	line-height: 1.2;
}

.contact-form-lead h2 {
	font-size: 2rem;
}

.contact-section-heading p,
.contact-form-lead > p:not(.eyebrow) {
	margin: 0;
	color: rgba(255, 255, 255, 0.76);
	line-height: 1.9;
}

.contact-guide__items {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 12px;
}

.contact-guide__item {
	position: relative;
	min-height: 132px;
	padding: 18px;
	border: 1px solid rgba(185, 216, 247, 0.18);
	border-radius: var(--radius);
	background:
		linear-gradient(145deg, rgba(46, 230, 240, 0.08), transparent 48%),
		rgba(255, 255, 255, 0.045);
	box-shadow: var(--shadow-dark);
}

.contact-guide__item span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	margin-bottom: 18px;
	border: 1px solid rgba(46, 230, 240, 0.36);
	border-radius: var(--radius);
	color: var(--cyan);
	font-weight: 900;
	font-size: 0.78rem;
}

.contact-guide__item p {
	margin: 0;
	color: #ffffff;
	font-weight: 850;
	line-height: 1.55;
}

.contact-form-layout {
	display: grid;
	grid-template-columns: minmax(0, 0.58fr) minmax(360px, 0.72fr);
	gap: 42px;
	align-items: start;
}

.contact-form-lead,
.contact-form-panel {
	position: relative;
	overflow: hidden;
	border: 1px solid var(--line-dark);
	border-radius: var(--radius);
	box-shadow: var(--shadow-dark);
}

.contact-form-lead {
	padding: 34px;
	background:
		linear-gradient(135deg, rgba(46, 230, 240, 0.13), transparent 48%),
		rgba(255, 255, 255, 0.045);
}

.contact-before {
	margin-top: 30px;
	padding-top: 24px;
	border-top: 1px solid var(--line-dark);
}

.contact-before ul {
	display: grid;
	gap: 12px;
	margin: 14px 0 0;
	padding: 0;
	list-style: none;
}

.contact-before li {
	display: grid;
	grid-template-columns: 34px minmax(0, 1fr);
	gap: 12px;
	align-items: start;
	color: rgba(255, 255, 255, 0.78);
	line-height: 1.75;
}

.contact-before li span {
	color: var(--cyan);
	font-weight: 900;
}

.contact-before__links {
	display: flex;
	flex-wrap: wrap;
	gap: 18px;
	margin-top: 22px;
}

.contact-before__links .text-link,
.contact-privacy-note a {
	color: var(--cyan);
}

.contact-form-panel {
	padding: 30px;
	background:
		linear-gradient(150deg, rgba(33, 146, 242, 0.12), transparent 42%),
		rgba(3, 10, 20, 0.92);
}

.contact-form-panel__header {
	margin-bottom: 22px;
}

.contact-form-panel__header h2 {
	margin: 0;
	color: #ffffff;
	font-size: 1.35rem;
	line-height: 1.5;
}

.contact-form-panel__body {
	position: relative;
	z-index: 1;
}

.contact-form-panel__empty {
	padding: 22px;
	border: 1px solid rgba(185, 216, 247, 0.18);
	border-radius: var(--radius);
	background: rgba(255, 255, 255, 0.045);
	color: rgba(255, 255, 255, 0.76);
}

.contact-form-panel__empty p {
	margin: 0;
}

.contact-privacy-note {
	margin-top: 18px;
	padding-top: 16px;
	border-top: 1px solid var(--line-dark);
	color: rgba(255, 255, 255, 0.72);
	font-size: 0.92rem;
	line-height: 1.7;
}

.contact-privacy-note p {
	margin: 0;
}

.contact-page .wpcf7,
.contact-page .hds-contact-form {
	color: rgba(255, 255, 255, 0.86);
}

.contact-page .hds-contact-form {
	display: grid;
	gap: 18px;
}

.contact-page .hds-contact-form__field {
	display: grid;
	gap: 8px;
}

.contact-page .hds-contact-form label {
	color: #ffffff;
	font-weight: 850;
}

.contact-page .is-required,
.contact-page .is-optional {
	display: inline-flex;
	align-items: center;
	margin-left: 8px;
	padding: 2px 8px;
	border-radius: 999px;
	font-size: 0.72rem;
	font-weight: 900;
}

.contact-page .is-required {
	background: rgba(46, 230, 240, 0.14);
	color: var(--cyan);
}

.contact-page .is-optional {
	background: rgba(255, 255, 255, 0.08);
	color: rgba(255, 255, 255, 0.72);
}

.contact-page .wpcf7-form-control-wrap {
	display: block;
}

.contact-page .wpcf7 input[type="text"],
.contact-page .wpcf7 input[type="email"],
.contact-page .wpcf7 input[type="tel"],
.contact-page .wpcf7 select,
.contact-page .wpcf7 textarea {
	width: 100%;
	min-height: 48px;
	padding: 12px 14px;
	border: 1px solid rgba(185, 216, 247, 0.24);
	border-radius: var(--radius);
	background: rgba(3, 10, 20, 0.78);
	color: #ffffff;
	font: inherit;
}

.contact-page .wpcf7 textarea {
	min-height: 168px;
	resize: vertical;
}

.contact-page .wpcf7 input::placeholder,
.contact-page .wpcf7 textarea::placeholder {
	color: rgba(255, 255, 255, 0.46);
}

.contact-page .wpcf7 input:focus-visible,
.contact-page .wpcf7 select:focus-visible,
.contact-page .wpcf7 textarea:focus-visible,
.contact-page .wpcf7 input[type="checkbox"]:focus-visible {
	outline: 2px solid rgba(46, 230, 240, 0.42);
	outline-offset: 3px;
	border-color: var(--cyan);
}

.contact-page .wpcf7 input[type="checkbox"] {
	width: 18px;
	height: 18px;
	margin-right: 8px;
	accent-color: var(--cyan);
}

.contact-page .wpcf7 .wpcf7-list-item {
	margin: 0;
}

.contact-page .hds-contact-form__privacy {
	padding: 16px;
	border: 1px solid rgba(185, 216, 247, 0.18);
	border-radius: var(--radius);
	background: rgba(255, 255, 255, 0.045);
	line-height: 1.75;
}

.contact-page .hds-contact-form__privacy a {
	color: var(--cyan);
}

.contact-page .wpcf7 input[type="submit"],
.contact-page .wpcf7 .wpcf7-submit {
	width: 100%;
	min-height: 52px;
	padding: 14px 22px;
	border: 1px solid rgba(46, 230, 240, 0.7);
	border-radius: var(--radius);
	background: linear-gradient(135deg, var(--cyan), #3d8bff);
	color: #03101e;
	font: inherit;
	font-weight: 900;
	cursor: pointer;
	transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}

.contact-page .wpcf7 input[type="submit"]:hover,
.contact-page .wpcf7 .wpcf7-submit:hover,
.contact-page .wpcf7 input[type="submit"]:focus-visible,
.contact-page .wpcf7 .wpcf7-submit:focus-visible {
	transform: translateY(-2px);
	filter: brightness(1.04);
	box-shadow: 0 18px 40px rgba(46, 230, 240, 0.22);
}

.contact-page .wpcf7 .wpcf7-not-valid-tip {
	margin-top: 6px;
	color: #ffb4b4;
	font-size: 0.86rem;
}

.contact-page .wpcf7 .wpcf7-response-output {
	margin: 18px 0 0;
	padding: 14px 16px;
	border-color: rgba(46, 230, 240, 0.42);
	border-radius: var(--radius);
	color: #ffffff;
	background: rgba(46, 230, 240, 0.08);
}

@media (max-width: 1080px) {
	.contact-hero__shell,
	.contact-section-heading--split,
	.contact-form-layout {
		grid-template-columns: 1fr;
	}

	.contact-index-panel {
		max-width: 560px;
	}

	.contact-guide__items {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 720px) {
	.contact-hero {
		padding-bottom: 68px;
	}

	.contact-hero h1 {
		font-size: 2.25rem;
	}

	.contact-hero__lead {
		font-size: 1rem;
	}

	.contact-section {
		padding: 76px 0;
	}

	.contact-section-heading h2,
	.contact-form-lead h2 {
		font-size: 2rem;
	}

	.contact-guide__items {
		grid-template-columns: 1fr;
	}

	.contact-form-lead,
	.contact-form-panel {
		padding: 24px;
	}

	.contact-before__links {
		display: grid;
		gap: 12px;
	}
}

@media (max-width: 420px) {
	.contact-index-panel {
		padding: 22px;
	}

	.contact-index-panel__item {
		grid-template-columns: 30px minmax(0, 1fr);
	}

	.contact-hero h1 {
		font-size: 1.95rem;
	}
}
/* ここまで */

/* 修正（追加）：2026/05/28 Hoda
   内容：プライバシーポリシー専用ページテンプレート用のOrbit Conceptドキュメントレイアウトを追加
   ここから */
.privacy-page {
	overflow: hidden;
	background: var(--deep);
	color: #ffffff;
}

.privacy-hero,
.privacy-document {
	position: relative;
	overflow: hidden;
}

.privacy-hero {
	padding-bottom: 92px;
}

.privacy-hero::before,
.privacy-document::before {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	background-image:
		linear-gradient(rgba(46, 230, 240, 0.065) 1px, transparent 1px),
		linear-gradient(90deg, rgba(46, 230, 240, 0.065) 1px, transparent 1px);
	background-size: 68px 68px;
	mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.9), transparent 84%);
}

.privacy-hero__shell {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(320px, 430px);
	gap: 58px;
	align-items: end;
}

.privacy-hero__content {
	max-width: 760px;
}

.privacy-hero h1 {
	margin: 0;
	color: #ffffff;
	font-size: 3.7rem;
	line-height: 1.12;
}

.privacy-hero__lead {
	max-width: 720px;
	margin: 24px 0 0;
	color: rgba(255, 255, 255, 0.8);
	font-size: 1.12rem;
	line-height: 1.85;
}

.privacy-index-panel {
	display: grid;
	gap: 12px;
	padding: 28px;
	border: 1px solid var(--line-dark);
	border-radius: var(--radius);
	background:
		linear-gradient(135deg, rgba(46, 230, 240, 0.12), transparent 42%),
		rgba(255, 255, 255, 0.045);
	box-shadow: var(--shadow-dark);
}

.privacy-index-panel__item {
	display: grid;
	grid-template-columns: 40px minmax(0, 1fr);
	gap: 6px 14px;
	align-items: baseline;
	padding: 14px 0;
	border-bottom: 1px solid rgba(185, 216, 247, 0.14);
	color: inherit;
	text-decoration: none;
}

.privacy-index-panel__item:last-child {
	border-bottom: 0;
}

.privacy-index-panel__item span {
	grid-row: 1 / span 2;
	color: var(--cyan);
	font-weight: 900;
}

.privacy-index-panel__item strong {
	color: #ffffff;
	font-size: 0.82rem;
	letter-spacing: 0.08em;
}

.privacy-index-panel__item em {
	color: rgba(255, 255, 255, 0.72);
	font-style: normal;
	font-size: 0.9rem;
}

.privacy-index-panel__item:hover,
.privacy-index-panel__item:focus-visible {
	color: #ffffff;
}

.privacy-document {
	padding: 96px 0 112px;
	background: linear-gradient(180deg, var(--deep) 0%, #06111f 48%, #030712 100%);
}

.privacy-document__shell {
	position: relative;
	z-index: 1;
	max-width: 980px;
}

.privacy-stack {
	display: grid;
	gap: 0;
}

.privacy-policy-section {
	padding: 34px 0;
	border-top: 1px solid var(--line-dark);
}

.privacy-policy-section:first-child {
	border-top: 0;
	padding-top: 0;
}

.privacy-policy-section__label {
	margin: 0 0 12px;
	color: var(--cyan);
	font-size: 0.78rem;
	font-weight: 900;
	letter-spacing: 0.12em;
}

.privacy-policy-section h2 {
	margin: 0 0 18px;
	color: #ffffff;
	font-size: 1.65rem;
	line-height: 1.45;
}

.privacy-policy-section p,
.privacy-policy-section li,
.privacy-definition-list dd {
	color: rgba(255, 255, 255, 0.78);
	line-height: 1.95;
}

.privacy-policy-section p {
	margin: 0;
}

.privacy-policy-section p + p,
.privacy-policy-section p + .privacy-list,
.privacy-policy-section p + .privacy-note-panel {
	margin-top: 18px;
}

.privacy-list {
	display: grid;
	gap: 10px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.privacy-list li {
	position: relative;
	padding-left: 20px;
}

.privacy-list li::before {
	content: "";
	position: absolute;
	top: 0.88em;
	left: 0;
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: var(--cyan);
	box-shadow: 0 0 18px rgba(46, 230, 240, 0.34);
}

.privacy-definition-list {
	display: grid;
	gap: 12px;
	margin: 0;
}

.privacy-definition-list div {
	display: grid;
	grid-template-columns: 180px minmax(0, 1fr);
	gap: 16px;
	padding: 14px 0;
	border-bottom: 1px solid rgba(185, 216, 247, 0.12);
}

.privacy-definition-list div:last-child {
	border-bottom: 0;
}

.privacy-definition-list dt {
	color: rgba(255, 255, 255, 0.58);
	font-weight: 900;
}

.privacy-definition-list dd {
	margin: 0;
	font-weight: 800;
}

.privacy-definition-list a,
.privacy-contact-card a {
	color: var(--cyan);
	overflow-wrap: anywhere;
}

.privacy-policy-section--notice {
	padding: 30px;
	border: 1px solid rgba(185, 216, 247, 0.18);
	border-radius: var(--radius);
	background:
		linear-gradient(135deg, rgba(46, 230, 240, 0.08), transparent 45%),
		rgba(255, 255, 255, 0.04);
	box-shadow: var(--shadow-dark);
}

.privacy-policy-section--notice + .privacy-policy-section--notice {
	margin-top: 24px;
}

.privacy-note-panel {
	padding: 16px 18px;
	border: 1px solid rgba(46, 230, 240, 0.28);
	border-radius: var(--radius);
	background: rgba(46, 230, 240, 0.08);
}

.privacy-note-panel p {
	color: rgba(255, 255, 255, 0.82);
	font-size: 0.92rem;
	line-height: 1.8;
}

.privacy-contact-card {
	padding: 30px;
	border: 1px solid var(--line-dark);
	border-radius: var(--radius);
	background:
		linear-gradient(135deg, rgba(46, 230, 240, 0.12), transparent 48%),
		rgba(255, 255, 255, 0.045);
	box-shadow: var(--shadow-dark);
}

.privacy-contact-card__info {
	display: grid;
	gap: 6px;
	margin-top: 18px;
}

.privacy-cta-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 46px;
	margin-top: 24px;
	padding: 12px 18px;
	border: 1px solid rgba(46, 230, 240, 0.65);
	border-radius: var(--radius);
	background: linear-gradient(135deg, var(--cyan), #3d8bff);
	color: #03101e;
	font-weight: 900;
	text-decoration: none;
}

/* 修正：2026/05/28 Hoda 内容：Privacy Policyのお問い合わせボタン文字視認性改善 ここから */
.privacy-page .privacy-contact-card .privacy-cta-link,
.privacy-page .privacy-contact-card .privacy-cta-link:hover,
.privacy-page .privacy-contact-card .privacy-cta-link:focus-visible {
	color: #061321;
}
/* 修正：2026/05/28 Hoda 内容：Privacy Policyのお問い合わせボタン文字視認性改善 ここまで */

.privacy-cta-link:hover,
.privacy-cta-link:focus-visible {
	color: #03101e;
	filter: brightness(1.04);
}

.privacy-policy-dates {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 22px;
	padding: 24px 0 0;
	border-top: 1px solid var(--line-dark);
	color: rgba(255, 255, 255, 0.64);
}

.privacy-policy-dates p {
	margin: 0;
}

@media (max-width: 1080px) {
	.privacy-hero__shell {
		grid-template-columns: 1fr;
	}

	.privacy-index-panel {
		max-width: 620px;
	}
}

@media (max-width: 720px) {
	.privacy-hero {
		padding-bottom: 68px;
	}

	.privacy-hero h1 {
		font-size: 2.35rem;
	}

	.privacy-hero__lead {
		font-size: 1rem;
	}

	.privacy-document {
		padding: 76px 0 88px;
	}

	.privacy-policy-section,
	.privacy-policy-section--notice,
	.privacy-contact-card {
		padding: 24px;
	}

	.privacy-policy-section:not(.privacy-policy-section--notice):not(.privacy-contact-card) {
		padding-right: 0;
		padding-left: 0;
	}

	.privacy-policy-section h2 {
		font-size: 1.38rem;
	}

	.privacy-definition-list div {
		grid-template-columns: 1fr;
		gap: 4px;
	}
}

@media (max-width: 420px) {
	.privacy-index-panel {
		padding: 22px;
	}

	.privacy-index-panel__item {
		grid-template-columns: 30px minmax(0, 1fr);
	}
}
/* ここまで */

/* 修正（追加）：2026/05/28 Hoda
   内容：HTMLサイトマップページをOrbit Conceptに合わせて再設計
   ここから */
.sitemap-page {
	overflow: hidden;
	background: var(--deep);
	color: #ffffff;
}

.sitemap-hero {
	position: relative;
	overflow: hidden;
	padding: 108px 0 86px;
	background:
		radial-gradient(circle at 82% 18%, rgba(46, 230, 240, 0.14), transparent 34%),
		linear-gradient(135deg, #050a14 0%, #071321 58%, #081b2d 100%);
	border-bottom: 1px solid var(--line-dark);
}

.sitemap-hero__grid {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(rgba(46, 230, 240, 0.05) 1px, transparent 1px),
		linear-gradient(90deg, rgba(46, 230, 240, 0.05) 1px, transparent 1px);
	background-size: 34px 34px;
	mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.9), transparent 86%);
	pointer-events: none;
}

.sitemap-hero__shell {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(280px, 0.42fr);
	gap: 54px;
	align-items: end;
}

.sitemap-hero__content h1 {
	margin-bottom: 18px;
	color: #ffffff;
	font-size: clamp(2.8rem, 6vw, 6rem);
	line-height: 0.96;
	letter-spacing: 0;
}

.sitemap-heading-flow > span {
	display: block;
}

.sitemap-hero__content p:not(.eyebrow),
.sitemap-directory__heading p {
	max-width: 680px;
	color: rgba(232, 244, 255, 0.78);
	font-size: 1.04rem;
}

.sitemap-hero__index {
	display: grid;
	gap: 12px;
	padding: 24px;
	background: rgba(7, 18, 31, 0.76);
	border: 1px solid var(--line-dark);
	border-radius: 18px;
	box-shadow: var(--shadow-dark);
	backdrop-filter: blur(18px);
}

.sitemap-hero__index a {
	display: grid;
	grid-template-columns: 42px minmax(0, 1fr);
	gap: 14px;
	align-items: center;
	min-height: 48px;
	padding: 10px 0;
	border-bottom: 1px solid rgba(185, 216, 247, 0.12);
	color: rgba(236, 248, 255, 0.8);
}

.sitemap-hero__index a:last-child {
	border-bottom: 0;
}

.sitemap-hero__index span {
	color: var(--cyan);
	font-weight: 900;
}

.sitemap-hero__index strong {
	font-size: 0.78rem;
	letter-spacing: 0.12em;
}

.sitemap-directory {
	padding: 96px 0 118px;
	background:
		linear-gradient(180deg, #050a14 0%, #07111e 52%, #050a14 100%);
}

.sitemap-directory__heading {
	display: grid;
	grid-template-columns: minmax(0, 0.8fr) minmax(280px, 0.6fr);
	gap: 44px;
	align-items: end;
	margin-bottom: 44px;
}

.sitemap-directory__heading .eyebrow {
	grid-column: 1 / -1;
	margin-bottom: 0;
}

.sitemap-directory__heading h2 {
	margin-bottom: 0;
	color: #ffffff;
	font-size: clamp(2rem, 3.4vw, 3.6rem);
	line-height: 1.08;
	letter-spacing: 0;
}

.sitemap-directory__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 22px;
	align-items: start;
}

.sitemap-directory__group {
	position: relative;
	padding: 30px;
	background:
		linear-gradient(145deg, rgba(12, 29, 48, 0.92), rgba(6, 15, 28, 0.94));
	border: 1px solid rgba(185, 216, 247, 0.16);
	border-radius: 18px;
	box-shadow: var(--shadow-dark);
}

.sitemap-directory__group:nth-child(2) {
	margin-top: 36px;
}

.sitemap-directory__group:nth-child(3) {
	margin-top: -18px;
}

.sitemap-directory__group::before {
	content: "";
	position: absolute;
	top: 0;
	left: 30px;
	right: 30px;
	height: 1px;
	background: linear-gradient(90deg, transparent, rgba(46, 230, 240, 0.78), transparent);
}

.sitemap-directory__meta {
	display: inline-flex;
	gap: 10px;
	align-items: center;
	margin-bottom: 18px;
	color: var(--cyan);
	font-size: 0.75rem;
	font-weight: 900;
	letter-spacing: 0.12em;
}

.sitemap-directory__meta span {
	display: inline-grid;
	place-items: center;
	width: 32px;
	height: 32px;
	border: 1px solid rgba(46, 230, 240, 0.5);
	border-radius: 999px;
}

.sitemap-directory__group h3 {
	margin-bottom: 10px;
	color: #ffffff;
	font-size: clamp(1.35rem, 2vw, 2.1rem);
	line-height: 1.16;
	letter-spacing: 0;
}

.sitemap-directory__group > p:not(.sitemap-directory__meta) {
	margin-bottom: 24px;
	color: rgba(232, 244, 255, 0.74);
}

.sitemap-directory__group ul {
	display: grid;
	gap: 10px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.sitemap-directory__group a,
.sitemap-directory__current {
	display: flex;
	justify-content: space-between;
	gap: 16px;
	align-items: center;
	min-height: 58px;
	padding: 14px 16px;
	background: rgba(255, 255, 255, 0.045);
	border: 1px solid rgba(185, 216, 247, 0.13);
	border-radius: 12px;
	color: #ffffff;
	transition: border-color 0.2s ease, background 0.2s ease, transform 0.2s ease;
}

.sitemap-directory__group a:hover,
.sitemap-directory__group a:focus-visible {
	background: rgba(46, 230, 240, 0.09);
	border-color: rgba(46, 230, 240, 0.58);
	transform: translateY(-1px);
}

.sitemap-directory__group strong {
	font-size: 0.98rem;
	line-height: 1.5;
}

.sitemap-directory__group small {
	color: rgba(181, 203, 224, 0.76);
	font-size: 0.72rem;
	font-weight: 900;
	letter-spacing: 0.08em;
	text-align: right;
	text-transform: uppercase;
	white-space: nowrap;
}

.sitemap-directory__current {
	color: rgba(232, 244, 255, 0.72);
}

.sitemap-directory__current small {
	color: var(--cyan);
}

@media (min-width: 721px) {
	.sitemap-heading-flow > span {
		white-space: nowrap;
	}
}

@media (max-width: 900px) {
	.sitemap-hero__shell,
	.sitemap-directory__heading,
	.sitemap-directory__grid {
		grid-template-columns: 1fr;
	}

	.sitemap-hero__shell {
		align-items: start;
	}

	.sitemap-directory__group:nth-child(2),
	.sitemap-directory__group:nth-child(3) {
		margin-top: 0;
	}
}

@media (max-width: 720px) {
	.sitemap-hero {
		padding: 78px 0 64px;
	}

	.sitemap-directory {
		padding: 76px 0 88px;
	}

	.sitemap-heading-flow > span {
		white-space: normal;
	}

	.sitemap-hero__index,
	.sitemap-directory__group {
		padding: 24px;
	}

	.sitemap-directory__group a,
	.sitemap-directory__current {
		align-items: flex-start;
		flex-direction: column;
		gap: 4px;
	}

	.sitemap-directory__group small {
		text-align: left;
	}
}

@media (max-width: 420px) {
	.sitemap-hero__index a {
		grid-template-columns: 34px minmax(0, 1fr);
	}

	.sitemap-directory__group {
		padding: 22px;
	}
}
/* 修正（追加）：2026/05/28 Hoda
   内容：HTMLサイトマップページをOrbit Conceptに合わせて再設計
   ここまで */

.archive-list {
	display: grid;
	gap: 18px;
}

.archive-item {
	padding: 26px;
}

.archive-item time {
	display: block;
	margin-bottom: 10px;
	color: var(--muted);
	font-weight: 900;
}

.archive-item h2 {
	margin-bottom: 12px;
	color: var(--ink);
	font-size: 1.35rem;
}

.archive-item p {
	color: var(--muted);
}

.nav-links {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 28px;
}

.page-numbers,
.nav-previous a,
.nav-next a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 42px;
	padding: 8px 14px;
	background: var(--surface);
	border: 1px solid var(--line);
	border-radius: var(--radius);
	color: var(--navy);
	font-weight: 900;
}

.page-numbers.current {
	background: var(--blue);
	border-color: var(--blue);
	color: #ffffff;
}

.js [data-reveal] {
	opacity: 0;
	transform: translateY(18px);
	transition: opacity 0.55s ease, transform 0.55s ease;
}

.js [data-reveal].is-visible {
	opacity: 1;
	transform: translateY(0);
}

.js [data-reveal="hero"] {
	transition-delay: 0.08s;
}

@keyframes orbitDraw {
	to {
		stroke-dashoffset: 0;
	}
}

@keyframes orbitPoint {
	to {
		opacity: 0.8;
	}
}

@media (max-width: 1120px) {
	.site-nav__list {
		gap: 20px;
	}

	.site-nav__list a {
		font-size: 0.84rem;
	}

	.orbit-hero__statement {
		grid-column: 1 / 10;
	}

	.orbit-hero__index {
		grid-column: 7 / 13;
	}

	.works-grid {
		grid-template-columns: repeat(6, minmax(0, 1fr));
	}

	.work-item--lead,
	.work-item--product,
	.work-item--compact,
	.work-item--concept {
		grid-column: span 3;
		margin-top: 0;
	}
}

@media (max-width: 1080px) {
	.site-nav-toggle {
		display: grid;
		flex: 0 0 auto;
	}

	body.admin-bar .site-header {
		top: 46px;
	}

	.site-nav {
		position: absolute;
		top: calc(100% + 8px);
		left: 22px;
		right: 22px;
		display: block;
		padding: 12px;
		background: rgba(5, 10, 20, 0.98);
		border: 1px solid rgba(46, 230, 240, 0.2);
		border-radius: var(--radius);
		box-shadow: var(--shadow-dark);
		opacity: 0;
		visibility: hidden;
		transform: translateY(-8px);
		pointer-events: none;
		transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s ease;
	}

	body.nav-open .site-nav {
		opacity: 1;
		visibility: visible;
		transform: translateY(0);
		pointer-events: auto;
	}

	.site-nav__list {
		display: grid;
		gap: 4px;
	}

	.site-nav__list a {
		display: flex;
		min-height: 48px;
		padding: 8px 12px;
		border-radius: var(--radius);
	}

	.site-nav__list a::after {
		display: none;
	}

	.site-nav__list a:hover {
		background: rgba(255, 255, 255, 0.06);
	}

	.orbit-hero__shell,
	.orbit-index__shell,
	.product-focus__shell,
	.capabilities__shell,
	.partnership__shell,
	.about-philosophy__shell,
	.section-heading--split,
	.site-footer__inner {
		grid-template-columns: 1fr;
	}

	.orbit-hero__statement,
	.orbit-hero__index {
		grid-column: auto;
	}

	.orbit-hero__shell {
		gap: 48px;
		min-height: auto;
	}

	.orbit-index__intro,
	.capabilities__intro {
		position: static;
	}

	.orbit-index__map {
		padding-left: 34px;
	}

	.about-philosophy__body {
		padding-top: 0;
	}

	.journal-list {
		grid-template-columns: 1fr;
	}

	.process__timeline {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 720px) {
	:root {
		--header-height: 68px;
	}

	.section-shell,
	.site-header__inner,
	.site-footer__inner {
		width: min(var(--shell), calc(100% - 32px));
	}

	.section-block {
		padding: 76px 0;
	}

	.orbit-hero {
		min-height: auto;
		padding: 72px 0 44px;
	}

	.orbit-hero__line {
		opacity: 0.55;
	}

	.orbit-hero__title {
		font-size: clamp(2.05rem, 9vw, 3.45rem);
	}

	.orbit-hero__title span {
		white-space: normal;
		overflow-wrap: anywhere;
	}

	.about-philosophy__quote h2 span,
	.about-philosophy__message span {
		white-space: normal;
		overflow-wrap: anywhere;
	}

	.orbit-hero__meta {
		margin-bottom: 28px;
	}

	.orbit-hero__links {
		display: grid;
	}

	.orbit-hero__index {
		margin-bottom: 0;
	}

	.orbit-node:nth-child(even) {
		margin-left: 0;
	}

	.works-grid {
		grid-template-columns: 1fr;
	}

	.work-item--lead,
	.work-item--product,
	.work-item--compact,
	.work-item--concept {
		grid-column: auto;
	}

	.work-item {
		min-height: auto;
		padding: 22px;
	}

	.work-item__visual--image {
		min-height: 190px;
	}

	.work-item__visual--portrait {
		min-height: 360px;
	}

	.work-item dl div,
	.capability-item {
		grid-template-columns: 1fr;
	}

	.process__timeline {
		grid-template-columns: 1fr;
	}

	.process__timeline::before {
		top: 0;
		bottom: 0;
		left: 21px;
		right: auto;
		width: 1px;
		height: auto;
		background: linear-gradient(180deg, var(--blue), var(--cyan), transparent);
	}

	.process__step,
	.process__step + .process__step {
		grid-template-columns: 42px minmax(0, 1fr);
		padding: 20px 0;
		border-left: 0;
		column-gap: 16px;
	}

	.process__step h2,
	.process__step h3,
	.process__step p {
		grid-column: 2;
	}

	.process__step span {
		grid-row: 1 / span 2;
	}

	.product-focus__shell {
		min-height: auto;
	}

	.product-focus__visual {
		min-height: 320px;
	}

	.product-focus__visual--image {
		min-height: auto;
	}

	.capability-item {
		gap: 12px;
	}

	.site-footer__nav {
		justify-self: start;
	}

	.site-footer__menu {
		justify-content: flex-start;
	}

	.entry-panel {
		padding: 24px;
	}

	.orbit-page-item,
	.orbit-detail-grid,
	.sitemap-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 420px) {
	.site-brand__tagline {
		display: none;
	}

	.site-brand__logo img {
		width: 112px;
	}

	.site-brand__name {
		font-size: 0.92rem;
	}

	.orbit-hero__lead,
	.orbit-hero__substatement {
		font-size: 0.95rem;
	}

	.work-item__visual,
	.product-focus__screen {
		grid-template-columns: 1fr;
	}

	.work-item__visual--image {
		min-height: 172px;
	}

	.work-item__visual--portrait {
		min-height: 320px;
	}

	.work-item__visual-caption {
		right: 10px;
		bottom: 10px;
		left: 10px;
	}

	.work-item__visual-kind,
	.work-item__visual-note {
		font-size: 0.64rem;
	}

	.product-focus__screen i:first-child {
		grid-column: auto;
	}
}

@media (max-width: 1080px) {
	.services-hero__shell,
	.services-prototype {
		grid-template-columns: 1fr;
	}

	.services-hero__index {
		max-width: 520px;
	}

	.services-core-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.services-card--primary,
	.services-card--partner,
	.services-card--new-business,
	.services-card--web {
		grid-column: auto;
		min-height: auto;
	}

	.partner-hero__shell,
	.partner-section-heading--split,
	.partner-estimate-panel {
		grid-template-columns: 1fr;
	}

	.partner-index-panel {
		max-width: 560px;
	}

	.partner-why-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.partner-why-card--1,
	.partner-why-card--2,
	.partner-why-card--3,
	.partner-why-card--4,
	.partner-why-card--5 {
		grid-column: auto;
	}

	.partner-cycle {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 720px) {
	.services-hero {
		padding-bottom: 64px;
	}

	.services-section {
		padding: 76px 0;
	}

	.services-core-grid,
	.services-specialized-grid {
		grid-template-columns: 1fr;
	}

	.services-card,
	.services-field-card,
	.services-prototype,
	.services-final-cta {
		padding: 24px;
	}

	.services-card--primary h2,
	.services-card h2,
	.services-field-card h2,
	.services-prototype h2,
	.services-final-cta h2 {
		font-size: clamp(1.45rem, 7vw, 2.2rem);
	}

	.services-prototype__visual {
		min-height: 240px;
	}

	.services-hero__index a {
		grid-template-columns: 34px minmax(0, 1fr);
	}

	.partner-hero {
		padding-bottom: 68px;
	}

	.partner-hero__shell {
		gap: 36px;
	}

	.partner-section {
		padding: 76px 0;
	}

	.partner-section-heading--split,
	.partner-section-heading {
		margin-bottom: 26px;
	}

	.partner-section-heading h2,
	.partner-scope-panel h2,
	.partner-estimate-panel h2,
	.partner-final-cta h2 {
		font-size: clamp(1.55rem, 7vw, 2.35rem);
	}

	.partner-why-grid,
	.partner-scope-list,
	.partner-estimate-list {
		grid-template-columns: 1fr;
	}

	.partner-why-card,
	.partner-scope-panel,
	.partner-estimate-panel,
	.partner-final-cta {
		padding: 24px;
	}

	.partner-cycle {
		grid-template-columns: 1fr;
		border-bottom: 0;
	}

	.partner-cycle::before {
		top: 0;
		bottom: 0;
		left: 17px;
		right: auto;
		width: 1px;
		height: auto;
		background: linear-gradient(180deg, var(--cyan), rgba(33, 146, 242, 0.75), transparent);
	}

	.partner-cycle__step,
	.partner-cycle__step + .partner-cycle__step {
		grid-template-columns: 34px minmax(0, 1fr);
		padding: 20px 0;
		border-left: 0;
		column-gap: 16px;
	}

	.partner-cycle__step h3,
	.partner-cycle__step p {
		grid-column: 2;
	}

	.partner-cycle__step span {
		grid-row: 1 / span 2;
	}
}

@media (max-width: 420px) {
	.services-hero__phases,
	.services-actions {
		display: grid;
	}

	.services-card__link {
		width: 100%;
	}

	.services-prototype__visual {
		display: none;
	}

	.partner-index-panel__item {
		grid-template-columns: 30px minmax(0, 1fr);
	}

	.partner-final-cta .services-actions {
		display: grid;
	}
}

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

	.orbit-hero__line path {
		stroke-dashoffset: 0;
	}

	.orbit-hero__line circle {
		opacity: 0.55;
	}

	.js [data-reveal] {
		opacity: 1;
		transform: none;
	}
}
