/* =========================================
   Front Page
   ========================================= */

/* レイアウト共通 */
.container-large {
	margin: 0 auto;
	padding: 0 80px;
}

/* =========================================
   ヒーローセクション
   ========================================= */
.hero-home {
	position: relative;
	height: calc(1080px * var(--scale-factor));
}

.hero-frame {
	position: relative;
	height: 100%;
	padding-top: calc(60px * var(--scale-factor));
}

.hero-frame>* {
	position: absolute;
}

.hero-bg-vector {
	top: 0;
	left: calc(145px * var(--scale-factor));
	width: calc(1520px * var(--scale-factor));
	pointer-events: none;
	z-index: 1;
}

.hero-bg-vector img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.hero-main-photo {
	top: 0;
	left: calc(742px * var(--scale-factor));
	width: calc(1100px * var(--scale-factor));
	z-index: 3;
	overflow: visible;
	pointer-events: none;
}

.hero-main-photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.hero-copy {
	position: absolute;
	left: calc(40px * var(--scale-factor));
	top: calc(620px * var(--scale-factor));
	z-index: 4;
	pointer-events: auto;
}

.hero-copy .hero-copy-image {
	display: block;
	width: calc(1480px * var(--scale-factor));
	/* height: auto; */
}

.hero-brand {
	position: absolute;
	left: calc(120px * var(--scale-factor));
	top: calc(1010px * var(--scale-factor));
	width: calc(550px * var(--scale-factor));
	pointer-events: auto;
}

.hero-brand img,
.hero-brand .custom-logo-link img {
	width: 100%;
	height: auto;
	object-fit: contain;
}

.hero-bottom-line {
	position: absolute;
	left: 0;
	top: calc(953px * var(--scale-factor));
	width: 100vw;
	z-index: 5;
	pointer-events: none;
}

.hero-bottom-line img {
	width: 100%;
	height: auto;
	display: block;
}

/* =========================================
   リーダー募集セクション
   ========================================= */
.leader-recruit-section {
	position: relative;
	height: calc(2400px * var(--scale-factor));
}

.leader-frame {
	position: relative;
	height: 100%;
	padding: 0;
}

.leader-frame>* {
	position: absolute;
}

.leader-bg-line,
.leader-bg-panel,
.leader-bg-accent {
	pointer-events: none;
	z-index: 1;
}

.leader-bg-line--primary {
	top: 0;
	left: calc(-1000px * var(--scale-factor));
	width: 200vw;
	transform: rotate(-28.8deg);
	z-index: 0;
}

.leader-bg-line--secondary {
	top: calc(2200px * var(--scale-factor));
	left: calc(-1285px * var(--scale-factor));
	width: 250vw;
	transform: rotate(61.2deg);
}

.leader-bg-line--tertiary {
	top: calc(1490px * var(--scale-factor));
	left: 0;
	width: 100vw;
}

.leader-bg-line img,
.leader-bg-accent img {
	width: 100%;
	height: auto;
	display: block;
}

.leader-bg-accent {
	top: calc(850px * var(--scale-factor));
	left: calc(350px * var(--scale-factor));
	width: calc(1000px * var(--scale-factor));
}

.leader-photo {
	position: absolute;
	left: 0;
	top: calc(-200px * var(--scale-factor));
	width: calc(650px * var(--scale-factor));
	z-index: 3;
}

.leader-photo-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.leader-photo-caption {
	position: absolute;
	left: calc(120px * var(--scale-factor));
	bottom: calc(30px * var(--scale-factor));
	font-size: var(--font-size-xs);
	line-height: 1.5;
	color: var(--color-white);
	margin: 0;
}

.leader-subtitle {
	position: absolute;
	left: calc(420px * var(--scale-factor));
	top: calc(520px * var(--scale-factor));
	font-size: var(--font-size-subtitle);
	line-height: 1;
	letter-spacing: calc(-3.2px * var(--scale-factor));
	color: var(--color-secondary);
	z-index: 1;
	width: 100%;
	font-family: var(--font-family-bold);
	font-weight: var(--font-weight-bold);
}

.leader-content {
	position: absolute;
	right: calc(150px * var(--scale-factor));
	top: calc(650px * var(--scale-factor));
	width: calc(900px * var(--scale-factor));
	display: flex;
	flex-direction: column;
	gap: calc(48px * var(--scale-factor));
	color: var(--color-black);
	z-index: 2;
}

.leader-title {
	margin: 0;
	font-size: var(--font-size-h2);
	line-height: 1.2;
	letter-spacing: calc(-1.8px * var(--scale-factor));
}

.leader-description {
	display: flex;
	flex-direction: column;
	/* gap: calc(20px * var(--scale-factor)); */
	margin: 0;
	font-size: var(--font-size-base);
	line-height: 1.5;
}

.leader-description strong {
	font-size: var(--font-size-base);
	letter-spacing: calc(-1px * var(--scale-factor));
}

.leader-highlight {
	align-self: flex-start;
	display: inline-flex;
	gap: calc(4px * var(--scale-factor));
	padding: calc(6px * var(--scale-factor)) calc(24px * var(--scale-factor));
	background: var(--color-white);
	box-shadow: calc(8px * var(--scale-factor)) calc(8px * var(--scale-factor)) 0 var(--color-black);
	color: var(--color-text);
	margin-bottom: calc(24px * var(--scale-factor));
}

.leader-highlight-main {
	font-size: var(--font-size-h4);
	letter-spacing: calc(1px * var(--scale-factor));
	font-family: var(--font-family-bold);
	font-weight: var(--font-family-bold);
}

.leader-highlight-sub {
	font-size: var(--font-size-lx);
	letter-spacing: calc(0.6px * var(--scale-factor));
	color: var(--color-text);
	margin-top: calc(20px * var(--scale-factor));
	font-family: var(--font-family-bold);
	font-weight: var(--font-weight-bold);
}

.leader-cta {
	display: flex;
	gap: calc(24px * var(--scale-factor));
	align-items: center;
	justify-content: flex-end;
}

.leader-cta-button {
	border: calc(4px * var(--scale-factor)) solid var(--color-primary);
	color: var(--color-primary);
}

.leader-cta-button:hover {
	box-shadow: 0 0 calc(48px * var(--scale-factor)) var(--color-secondary);
	color: var(--color-primary);
}

/* =========================================
   拠点紹介セクション
   ========================================= */
.locations-section {
	position: relative;
	height: calc(3000px * var(--scale-factor));
	background: var(--color-background);
}

.locations-frame {
	position: relative;
	height: 100%;
	padding: 0;
}

.locations-frame>* {
	position: absolute;
}

.locations-bg-line {
	pointer-events: none;
	top: calc(2000px * var(--scale-factor));
	left: calc(-300px * var(--scale-factor));
	width: 200vw;
	transform: rotate(-28.8deg);
}

.locations-bg-line img {
	width: 100%;
	height: auto;
	display: block;
}

.locations-photo .subtitle {
	position: absolute;
	left: calc(-30px * var(--scale-factor));
	top: calc(400px * var(--scale-factor));
	font-size: var(--font-size-subtitle);
	letter-spacing: calc(-6px * var(--scale-factor));
	color: var(--color-secondary);
	line-height: 0.8;
	pointer-events: none;
	z-index: 3;
	font-family: var(--font-family-bold);
	font-weight: var(--font-weight-bold);
}

.locations-photo {
	position: absolute;
	left: 0;
	top: 0;
	width: calc(1000px * var(--scale-factor));
}

.locations-photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 2;
}

.locations-photo-caption {
	position: absolute;
	top: calc(20px * var(--scale-factor));
	left: calc(110px * var(--scale-factor));
	color: var(--color-white);
	font-size: var(--font-size-xs);
	z-index: 3;
}


.locations-title {
	margin: 0 0 calc(16px * var(--scale-factor));
	font-size: var(--font-size-h1);
	letter-spacing: calc(-2px * var(--scale-factor));
}

.locations-heading {
	position: absolute;
	left: calc(150px * var(--scale-factor));
	top: calc(500px * var(--scale-factor));
	width: calc(560px * var(--scale-factor));
	margin: 0;
	z-index: 4;
	margin: 0;
	font-size: var(--font-size-h3);
	letter-spacing: calc(-1.8px * var(--scale-factor));
	color: var(--color-text);
}

.locations-intro {
	margin: 0;
	font-size: var(--font-size-base);
	line-height: 1.5;
	width: calc(800px * var(--scale-factor));
	text-align: left;
}

.locations-list {
	display: flex;
	flex-direction: column;
	gap: calc(16px * var(--scale-factor));
	width: calc(700px * var(--scale-factor));
	position: absolute;
	top: calc(1300px*var(--scale-factor));
	left: calc(150px*var(--scale-factor));
	z-index: 4;
}

.location-region {
	position: relative;
}

.region-header {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: calc(16px * var(--scale-factor));
	height: calc(80px * var(--scale-factor));
	padding: 0 calc(40px * var(--scale-factor));
	background: var(--color-primary);
	color: var(--color-white);
	border: none;
	border-radius: calc(10px * var(--scale-factor));
	font-size: var(--font-size-xl);
	cursor: pointer;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	font-family: var(--font-family-bold);
	font-weight: var(--font-weight-bold);
}

.region-header:focus-visible {
	outline: calc(3px * var(--scale-factor)) solid var(--color-primary);
	opacity: 0.4;
	outline-offset: calc(3px * var(--scale-factor));
}

.location-region.is-active .region-header {
	box-shadow: 0 calc(8px * var(--scale-factor)) 0 var(--color-black);
	transform: translate(calc(-4px * var(--scale-factor)), calc(-4px * var(--scale-factor)));
}

.region-toggle-icon img {
	width: calc(42px * var(--scale-factor));
	height: calc(42px * var(--scale-factor));
	transform: rotate(90deg);
}

.location-region.is-active .region-toggle-icon img {
	transform: rotate(-90deg);
}

.prefecture-list {
	margin-top: calc(12px * var(--scale-factor));
	margin-left: calc(20px * var(--scale-factor));
	padding: 0 calc(8px * var(--scale-factor));
	background: transparent;
	overflow: hidden;
	max-height: 0;
	transition: max-height 0.35s ease;
	width: calc(650px * var(--scale-factor));
}

.prefecture-item {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: calc(16px * var(--scale-factor));
	padding: calc(16px * var(--scale-factor)) 0;
	border-bottom: 1px solid var(--color-border);
	font-size: var(--font-size-base);
	color: var(--color-black);
	cursor: pointer;
	text-decoration: none;
	transition: color 0.3s ease;
}

.prefecture-item:last-child {
	border-bottom: none;
}

.prefecture-item:hover .prefecture-name {
	color: var(--color-primary);
}

.prefecture-arrow img {
	width: calc(42px * var(--scale-factor));
	height: calc(42px * var(--scale-factor));
}

.locations-map {
	position: absolute;
	left: 0;
	top: calc(100px * var(--scale-factor));
	width: calc(2500px * var(--scale-factor));
	height: calc(2500px * var(--scale-factor));
	z-index: 1;
}

.location-map-layer {
	position: absolute;
	inset: 0;
	opacity: 0;
	transition: opacity 0.3s ease;
}

.location-map-layer.is-active {
	opacity: 1;
}

.location-map-layer img {
	width: 80%;
	object-fit: cover;
	object-position: center;
}

/* =========================================
   提供サービスセクション
   ========================================= */
.services-section {
	position: relative;
	height: calc(1665px * var(--scale-factor));
	color: var(--color-white);
}

.services-frame {
	position: relative;
	height: 100%;
	padding: 0;
}

.services-frame>* {
	position: absolute;
}

.services-bg-line,
.services-bg-vector,
.services-bg-accent {
	pointer-events: none;
	z-index: 1;
}

.services-bg-line {
	top: calc(652px * var(--scale-factor));
	left: calc(-1500px * var(--scale-factor));
	width: 300vw;
	transform: rotate(61.2deg);
	z-index: 0;
}

.services-bg-vector {
	top: calc(120px * var(--scale-factor));
	left: calc(-250px * var(--scale-factor));
	width: calc(2300px * var(--scale-factor));
	z-index: 2;
}

.services-bg-accent {
	bottom: calc(-96px * var(--scale-factor));
	left: calc(388px * var(--scale-factor));
	width: calc(986px * var(--scale-factor));
}

.services-bg-line img,
.services-bg-vector img,
.services-bg-accent img {
	width: 100%;
	height: auto;
	display: block;
}

.services-subtitle {
	position: absolute;
	top: calc(-20px * var(--scale-factor));
	right: 0;
	font-size: var(--font-size-subtitle);
	letter-spacing: 0;
	color: var(--color-secondary);
	line-height: 1;
	white-space: nowrap;
	pointer-events: none;
	z-index: 1;
	font-family: var(--font-family-bold);
	font-weight: var(--font-weight-bold);
}

.services-hero {
	position: absolute;
	top: calc(-150px * var(--scale-factor));
	right: 0;
	width: calc(1000px * var(--scale-factor));
}

.services-hero-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.services-panel {
	position: absolute;
	top: calc(263px * var(--scale-factor));
	left: calc(202px * var(--scale-factor));
	width: calc(1060px * var(--scale-factor));
	background: transparent;
	border: none;
	backdrop-filter: none;
	border-radius: 0;
	box-shadow: none;
	overflow: visible;
	padding: 0;
	z-index: 4;
}

.services-panel-content {
	display: flex;
	flex-direction: column;
	gap: calc(48px * var(--scale-factor));
	height: auto;
}

.services-copy {
	display: flex;
	flex-direction: column;
	gap: calc(32px * var(--scale-factor));
	width: calc(1600px * var(--scale-factor));
}

.services-heading {
	margin: 0;
	font-size: var(--font-size-h1);
	line-height: 1.2;
	letter-spacing: calc(-0.96px * var(--scale-factor));
}

.services-text {
	margin: 0;
	font-size: var(--font-size-base);
	line-height: 1.5;
	color: var(--color-white);
}

.services-cards {
	display: flex;
	gap: calc(40px * var(--scale-factor));
	width: calc(1400px * var(--scale-factor));
	height: calc(420px * var(--scale-factor));
}

.services-card {
	flex: 0 0 calc(440px * var(--scale-factor));
	background: var(--color-white);
	border-radius: 0;
	border: none;
	padding: calc(40px * var(--scale-factor)) 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: space-between;
	text-align: center;
	gap: 0;
	backdrop-filter: none;
	box-shadow: calc(12px * var(--scale-factor)) calc(12px * var(--scale-factor)) 0 var(--color-black);
}

.services-card-icon {
	width: calc(250px * var(--scale-factor));
	display: flex;
	align-items: center;
	justify-content: center;
}

.services-card-icon img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	opacity: 0.5;
}

.services-card-name {
	margin: 0;
	font-size: var(--font-size-lg);
	letter-spacing: 0;
	line-height: 1.5;
	color: var(--color-black);
}

.services-cta {
	display: flex;
	justify-content: flex-end;
	width: calc(1400px * var(--scale-factor));
}

.services-cta-button {
	color: var(--color-white);
	border: calc(2px * var(--scale-factor)) solid var(--color-white);
}

.services-cta-button:hover {
	box-shadow: 0 0 calc(24px * var(--scale-factor)) var(--color-secondary);
}

.services-panel-photo {
	position: absolute;
	left: 0;
	top: calc(1050px * var(--scale-factor));
	width: calc(884px * var(--scale-factor));
	z-index: 3;
}

.services-panel-photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* =========================================
   ビジョンセクション
   ========================================= */
.vision-section {
	position: relative;
	height: calc(1600px * var(--scale-factor));
}

.vision-frame {
	position: relative;
	height: 100%;
	padding: 0;
}

.vision-frame>* {
	position: absolute;
}

.vision-bg-texture {
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
	z-index: 1;
}

.vision-bg-texture img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: 0.15;
}

.vision-bg-line {
	top: calc(-50px * var(--scale-factor));
	left: calc(-300px * var(--scale-factor));
	width: 200vw;
	transform: rotate(-28.8deg);
	z-index: 0;
}

.vision-bg-line img {
	width: 100%;
	height: auto;
	display: block;
}

.vision-photo {
	position: absolute;
	right: 0;
	width: calc(1040px * var(--scale-factor));
	z-index: 1;
}

.vision-photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}

.vision-content {
	position: absolute;
	left: calc(50px * var(--scale-factor));
	top: calc(500px * var(--scale-factor));
	width: calc(1350px * var(--scale-factor));
	display: flex;
	flex-direction: column;
	z-index: 4;
}

.vision-points {
	display: flex;
	flex-direction: column;
	gap: calc(48px * var(--scale-factor));
}

.vision-point {
	display: flex;
	align-items: flex-start;
	gap: 0;
	position: relative;
}

.vision-point:nth-child(2) {
	padding-left: calc(106px * var(--scale-factor));
}

.vision-point:nth-child(3) {
	padding-left: calc(212px * var(--scale-factor));
}

.vision-point-icon {
	width: calc(240px * var(--scale-factor));
	flex: none;
	position: relative;
	z-index: 1;
}

.vision-point-icon img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.vision-point-text {
	margin: 0;
	margin-left: calc(-90px * var(--scale-factor));
	padding-top: calc(4px * var(--scale-factor));
	font-size: var(--font-size-h3);
	line-height: 1.5;
	color: var(--color-primary);
	position: relative;
	z-index: 2;
	font-family: var(--font-family-bold);
	font-weight: var(--font-weight-bold);
}

.vision-cta {
	display: flex;
	justify-content: flex-end;
	margin-top: auto;
}

.vision-cta-button {
	border: calc(4px * var(--scale-factor)) solid var(--color-primary);
	color: var(--color-primary);
}

.vision-cta-button:hover {
	box-shadow: 0 0 calc(48px * var(--scale-factor)) var(--color-secondary);
	color: var(--color-primary);
}

/* =========================================
   CTAセクション
   ========================================= */
.cta-section {
	position: relative;
	height: calc(1500px * var(--scale-factor));
}

.cta-frame {
	position: relative;
	height: 100%;
	padding: 0;
}

.cta-frame>* {
	position: absolute;
}

.cta-bg-vector {
	top: calc(-720px * var(--scale-factor));
	left: calc(-960px * var(--scale-factor));
	width: calc(2200px * var(--scale-factor));
	pointer-events: none;
	z-index: 1;
}

.cta-bg-vector img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	filter: brightness(0) saturate(100%) invert(32%) sepia(56%) saturate(1463%) hue-rotate(250deg) brightness(86%) contrast(89%);
}

.cta-photo {
	top: calc(0px * var(--scale-factor));
	right: 0;
	width: calc(1700px * var(--scale-factor));
	z-index: 2;
}

.cta-photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}

.cta-photo-caption {
	position: absolute;
	top: calc(20px * var(--scale-factor));
	right: calc(40px * var(--scale-factor));
	margin: 0;
	font-size: var(--font-size-xs);
	line-height: 1.5;
	color: var(--color-black);
	z-index: 3;
	text-align: right;
}

.cta-headline {
	position: absolute;
	left: calc(190px * var(--scale-factor));
	top: calc(700px * var(--scale-factor));
	width: calc(1500px * var(--scale-factor));
	z-index: 4;
}

.cta-headline-shadow-1 {
	position: absolute;
	left: calc(20px * var(--scale-factor));
	top: calc(20px * var(--scale-factor));
	width: calc(1225px * var(--scale-factor));
	height: calc(152px * var(--scale-factor));
	background: var(--color-black);
}

.cta-headline-shadow-2 {
	position: absolute;
	left: calc(320px * var(--scale-factor));
	top: calc(173px * var(--scale-factor));
	width: calc(1100px * var(--scale-factor));
	height: calc(152px * var(--scale-factor));
	background: var(--color-black);
}

.cta-headline-text {
	position: relative;
	z-index: 1;
	margin: 0;
	padding: 0;
	font-family: var(--font-family-bold);
	font-size: var(--font-size-h2);
	font-weight: var(--font-weight-bold);
	line-height: 1.7;
	color: var(--color-text);
}

.cta-headline-text>span {
	background: var(--color-white);
	padding: calc(8px * var(--scale-factor)) calc(32px * var(--scale-factor));
	display: inline-block;
}

.cta-headline-text .cta-headline-indent {
	margin-left: calc(300px * var(--scale-factor));
}

.cta-actions {
	position: absolute;
	left: 0;
	right: 0;
	margin: auto;
	top: calc(1100px * var(--scale-factor));
	width: calc(1450px * var(--scale-factor));
	display: flex;
	gap: calc(60px * var(--scale-factor));
	z-index: 4;
}

.cta-card {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: calc(20px * var(--scale-factor));
	flex: 1;
	padding: calc(15px * var(--scale-factor)) calc(40px * var(--scale-factor));
	border-radius: calc(10px * var(--scale-factor));
	border: calc(4px * var(--scale-factor)) solid var(--color-white);
	text-decoration: none;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.cta-card--leader {
	background: linear-gradient(90deg, #f2e882 0%, #ffbd2f 26%, #f07cd5 100%);
}

.cta-card--staff {
	background: linear-gradient(90deg, #7de4f4 0%, #9063f9 100%);
}

.cta-card:hover {
	transform: translateY(calc(-6px * var(--scale-factor)));
}

.cta-card-icon {
	width: calc(200px * var(--scale-factor));
	flex: none;
}

.cta-card-icon img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.cta-card-copy {
	display: flex;
	flex-direction: column;
	gap: calc(6px * var(--scale-factor));
	font-size: var(--font-size-base);
	line-height: 1.5;
	color: var(--color-white);
}

.cta-card-arrow {
	width: calc(60px * var(--scale-factor));
}

.cta-card-arrow img {
	width: 100%;
	height: 100%;
}