/* ==========================================
   Tech Support Page Styles
========================================== */

/* ==========================================
   Hero Section
========================================== */
.tech-hero {
	position: relative;
	width: 100%;
	height: calc(900px * var(--scale-factor));
	overflow: hidden;
}

.tech-hero-bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: 50% 50%;
	z-index: 1;
}

.tech-hero-content {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 3;
	display: flex;
	justify-content: flex-end;
	align-items: stretch;
	padding: calc(120px * var(--scale-factor)) 0 calc(96px * var(--scale-factor));
}

.tech-menu {
	display: flex;
	gap: calc(48px * var(--scale-factor));
	justify-content: center;
	width: 100%;
	max-width: calc(1280px * var(--scale-factor));
}

.tech-menu-item {
	flex: 1;
	max-width: calc(400px * var(--scale-factor));
	text-decoration: none;
	color: inherit;
	transition: opacity 0.3s ease;
	display: flex;
	flex-direction: column;
	align-items: center;
}

.tech-menu-text {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: calc(10px * var(--scale-factor));
	padding: 0 calc(48px * var(--scale-factor));
	min-height: calc(64px * var(--scale-factor));
	border-bottom: calc(2px * var(--scale-factor)) solid var(--color-white);
}

.tech-menu-text p {
	font-family: var(--font-hiragino-std-bold);
	font-size: calc(32px * var(--scale-factor));
	color: var(--color-white);
	margin: 0;
	line-height: 1.2;
	letter-spacing: calc(-0.32px * var(--scale-factor));
	text-align: center;
}

.tech-menu-icon {
	font-size: calc(32px * var(--scale-factor));
	color: var(--color-white);
	line-height: 1;
	display: inline-flex;
}

.tech-menu-item:hover,
.tech-menu-item:focus-visible {
	opacity: 0.85;
}

.tech-hero-inner {
	display: flex;
	flex-direction: column;
	gap: calc(64px * var(--scale-factor));
	max-width: calc(1280px * var(--scale-factor));
	margin: 0;
	align-items: flex-end;
	width: 100%;
}

.tech-hero-content .container {
	height: 100%;
	display: flex;
	align-items: flex-end;
	justify-content: flex-end;
	width: 100%;
	max-width: var(--container-max);
	margin-left: auto;
	margin-right: 0;
	padding-left: var(--padding-global);
	padding-right: 0;
}

.tech-hero-copy {
	display: flex;
	flex-direction: column;
	gap: calc(32px * var(--scale-factor));
	width: 100%;
	align-items: flex-start;
	padding-left: calc(360px * var(--scale-factor));
}

.tech-hero-divider {
	align-self: stretch;
	width: 100%;
	height: calc(2px * var(--scale-factor));
	background: rgba(255, 255, 255, 0.7);
}

.tech-subtitle span {
	display: block;
}

.tech-main-title {
	font-family: var(--font-hiragino-std-bold);
	font-size: calc(96px * var(--scale-factor));
	color: var(--color-white);
	margin: 0;
	line-height: 1;
	text-shadow: 0px 0px 4px rgba(0, 0, 0, 1);
	max-width: calc(814px * var(--scale-factor));
	text-align: left;
	align-self: flex-start;
}

.tech-title-line {
	display: block;
}

.tech-subtitle {
	font-family: var(--font-hiragino-std-bold);
	font-size: calc(32px * var(--scale-factor));
	color: var(--color-white);
	line-height: 1.3;
	letter-spacing: calc(-0.32px * var(--scale-factor));
	display: flex;
	flex-direction: column;
	gap: calc(4px * var(--scale-factor));
	align-items: flex-start;
	text-align: left;
	max-width: calc(560px * var(--scale-factor));
}

/* ==========================================
   Profile Section
========================================== */
.tech-profile {
	position: relative;
	width: 100%;
	height: calc(300px * var(--scale-factor));
	overflow: hidden;
}

.tech-profile-bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 1;
}

/* ==========================================
   About Section
========================================== */
.tech-about {
	position: relative;
	background-color: var(--color-main-navy);
	padding: var(--padding-section-large) 0;
	z-index: 1;
}

.tech-about .section-title {
	position: absolute;
	left: 0;
	top: calc(-56px * var(--scale-factor));
	width: calc(880px * var(--scale-factor));
	z-index: 1;
	display: block;
	pointer-events: none;
}

.tech-about .container {
	position: relative;
	z-index: 2;
}

.tech-about-title {
	font-size: calc(48px * var(--scale-factor));
	color: var(--color-white);
	margin: 0 0 calc(40px * var(--scale-factor));
	line-height: 1.2;
	letter-spacing: calc(-0.48px * var(--scale-factor));
}

.tech-about-content {
	display: flex;
	gap: calc(80px * var(--scale-factor));
	align-items: flex-start;
}

.tech-about-text {
	flex: 1;
	max-width: calc(720px * var(--scale-factor));
}

.tech-about-text p {
	font-family: var(--font-hiragino);
	font-size: calc(24px * var(--scale-factor));
	color: var(--color-white);
	line-height: 1.5;
	margin: 0 0 calc(24px * var(--scale-factor));
}

.tech-about-text p:last-child {
	margin-bottom: 0;
}

.tech-about-text strong {
	font-family: var(--font-hiragino-std-bold);
}

.tech-about-media {
	flex-shrink: 0;
	width: calc(480px * var(--scale-factor));
	display: flex;
	flex-direction: column;
	gap: calc(32px * var(--scale-factor));
}

.tech-about-video {
	width: 100%;
	height: calc(270px * var(--scale-factor));
	background-color: #d9d9d9;
	border-radius: calc(8px * var(--scale-factor));
	overflow: hidden;
}

.tech-about-video iframe {
	width: 100%;
	height: 100%;
	border: none;
	display: block;
}

.tech-about-image {
	width: 100%;
	height: calc(512px * var(--scale-factor));
	border-radius: calc(24px * var(--scale-factor));
	overflow: hidden;
}

.tech-about-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* ==========================================
   CTA Section
========================================== */
.tech-cta {
	position: relative;
	padding: var(--padding-section-large) var(--padding-global);
	overflow: hidden;
}

.tech-cta-bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: 50% 80%;
	z-index: 1;
}

.tech-cta-bg::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.5);
	z-index: 2;
}

.tech-cta .container {
	position: relative;
	z-index: 3;
}

.tech-cta-content {
	text-align: center;
	max-width: calc(900px * var(--scale-factor));
	margin: 0 auto;
}

.tech-cta-content h3 {
	font-size: calc(48px * var(--scale-factor));
	color: var(--color-white);
	margin: 0 0 calc(24px * var(--scale-factor));
	line-height: 1.2;
	letter-spacing: calc(-0.48px * var(--scale-factor));
}

.tech-cta-content p {
	font-family: var(--font-hiragino);
	font-size: calc(18px * var(--scale-factor));
	color: var(--color-white);
	line-height: 1.5;
	margin: 0 0 calc(32px * var(--scale-factor));
}

.tech-cta-buttons {
	display: flex;
	gap: calc(16px * var(--scale-factor));
	justify-content: center;
	align-items: center;
}

/* ==========================================
   Feature Sections
========================================== */

.tech-decoration {
	position: absolute;
	bottom: 0;
	z-index: 0;
	pointer-events: none;
	display: block;
}

.tech-decoration-1 {
	bottom: calc(-400px * var(--scale-factor));
	width: calc(1444px * var(--scale-factor));
	clip-path: inset(0 0 calc(400px * var(--scale-factor)) 0);
}

.tech-feature1 {
	position: relative;
	background-color: var(--color-off-white);
}

.tech-feature1 .container {
	position: relative;
	z-index: 2;
	padding-top: calc(120px * var(--scale-factor));
	padding-bottom: calc(80px * var(--scale-factor));
}

.tech-feature1 .section-title {
	position: absolute;
	left: 0;
	top: calc(-56px * var(--scale-factor));
	width: calc(968px * var(--scale-factor));
	z-index: 1;
	display: block;
	pointer-events: none;
}

.tech-feature1-content {
	display: flex;
	gap: calc(64px * var(--scale-factor));
	align-items: flex-end;
}

.tech-feature1-left {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: calc(80px * var(--scale-factor));
}

.tech-feature1-icon {
	width: calc(320px * var(--scale-factor));
	height: calc(320px * var(--scale-factor));
	border-radius: calc(40px * var(--scale-factor));
	overflow: hidden;
}

.tech-feature1-icon img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.tech-feature1-text h3 {
	font-family: var(--font-dela);
	font-size: calc(64px * var(--scale-factor));
	font-weight: 400;
	color: var(--color-black);
	margin: 0 0 calc(24px * var(--scale-factor));
	line-height: 1.2;
	letter-spacing: calc(-0.64px * var(--scale-factor));
}

.tech-feature1-text p {
	font-family: var(--font-hiragino);
	font-size: calc(24px * var(--scale-factor));
	color: var(--color-black);
	line-height: 1.5;
	margin: 0 0 calc(24px * var(--scale-factor));
}

.tech-feature1-text p:last-child {
	margin-bottom: 0;
}

.tech-feature1-right {
	flex: 1;
	width: calc(608px * var(--scale-factor));
	height: calc(608px * var(--scale-factor));
	border-radius: calc(40px * var(--scale-factor));
	overflow: hidden;
}

.tech-feature1-right img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* Feature 2 */
.tech-feature2 {
	background-color: var(--color-off-white);
	padding: var(--padding-section-large) var(--padding-global);
}

.tech-feature2 .container {
	max-width: calc(1280px * var(--scale-factor));
	margin: 0 auto;
}

.tech-feature2-content {
	max-width: calc(1275px * var(--scale-factor));
	margin-bottom: calc(80px * var(--scale-factor));
}

.tech-feature2-content h3 {
	font-family: var(--font-dela);
	font-size: calc(64px * var(--scale-factor));
	font-weight: 400;
	color: var(--color-black);
	margin: 0 0 calc(24px * var(--scale-factor));
	line-height: 1.2;
	letter-spacing: calc(-0.64px * var(--scale-factor));
}

.tech-feature2-content p {
	font-family: var(--font-hiragino);
	font-size: calc(24px * var(--scale-factor));
	color: var(--color-black);
	line-height: 1.5;
	margin: 0 0 calc(24px * var(--scale-factor));
}

.tech-feature2-content p:last-child {
	margin-bottom: 0;
}

.tech-feature2-image {
	width: calc(960px * var(--scale-factor));
	height: calc(758px * var(--scale-factor));
	border-radius: calc(40px * var(--scale-factor));
	overflow: hidden;
	margin: 0 auto;
}

.tech-feature2-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* Feature 3 */
.tech-feature3 {
	position: relative;
	background-color: var(--color-off-white);
	padding: var(--padding-section-large) 0;
	overflow: hidden;
}

.tech-decoration-2 {
	left: calc(-4px * var(--scale-factor));
	top: calc(-220px * var(--scale-factor));
	transform: scaleY(-1);
	width: calc(1444px * var(--scale-factor));
}

.tech-feature3 .container {
	position: relative;
	z-index: 2;
}

.tech-feature3-content {
	display: flex;
	gap: calc(64px * var(--scale-factor));
	align-items: flex-end;
}

.tech-feature3-left {
	flex: 1;
	width: calc(608px * var(--scale-factor));
	height: calc(624px * var(--scale-factor));
	border-radius: calc(40px * var(--scale-factor));
	overflow: hidden;
}

.tech-feature3-left img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.tech-feature3-right {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: calc(80px * var(--scale-factor));
	align-items: flex-end;
}

.tech-feature3-icon {
	width: calc(320px * var(--scale-factor));
	height: calc(320px * var(--scale-factor));
	border-radius: calc(40px * var(--scale-factor));
	overflow: hidden;
}

.tech-feature3-icon img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.tech-feature3-text h3 {
	font-family: var(--font-dela);
	font-size: calc(64px * var(--scale-factor));
	font-weight: 400;
	color: var(--color-black);
	margin: 0 0 calc(24px * var(--scale-factor));
	line-height: 1.2;
	letter-spacing: calc(-0.64px * var(--scale-factor));
}

.tech-feature3-text p {
	font-family: var(--font-hiragino);
	font-size: calc(24px * var(--scale-factor));
	color: var(--color-black);
	line-height: 1.5;
	margin: 0 0 calc(24px * var(--scale-factor));
}

.tech-feature3-text p:last-child {
	margin-bottom: 0;
}

/* ==========================================
   Best for Cases Section
========================================== */
.tech-cases {
	position: relative;
	background-color: var(--color-main-navy);
	padding: calc(220px * var(--scale-factor)) 0 calc(200px * var(--scale-factor));
}

.tech-decoration-3 {
	left: 0;
	bottom: calc(-280px * var(--scale-factor));
	transform: none;
	width: calc(1440px * var(--scale-factor));
	clip-path: inset(0 0 calc(280px * var(--scale-factor)) 0);
}

.tech-cases .section-title {
	position: absolute;
	left: 0;
	top: calc(-64px * var(--scale-factor));
	width: calc(1441px * var(--scale-factor));
	z-index: 1;
	display: block;
	pointer-events: none;
}

.tech-cases .container {
	position: relative;
	z-index: 3;
}

.tech-cases-content {
	display: flex;
	justify-content: space-between;
	gap: calc(80px * var(--scale-factor));
	align-items: flex-start;
}

.tech-cases-left {
	flex: 0 0 calc(460px * var(--scale-factor));
	max-width: calc(460px * var(--scale-factor));
	padding-top: calc(32px * var(--scale-factor));
}

.tech-cases-left h3 {
	font-size: calc(56px * var(--scale-factor));
	color: var(--color-white);
	margin: 0;
	line-height: 1.2;
	letter-spacing: calc(-0.64px * var(--scale-factor));
}

.tech-cases-right {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: calc(32px * var(--scale-factor));
	max-width: calc(620px * var(--scale-factor));
}

.tech-case-item {
	background-color: var(--color-white);
	border: none;
	border-radius: calc(32px * var(--scale-factor));
	padding: calc(28px * var(--scale-factor));
	box-shadow: 0 calc(24px * var(--scale-factor)) calc(64px * var(--scale-factor)) rgba(4, 20, 57, 0.25);
}

.tech-case-item h4 {
	font-family: var(--font-hiragino-std-bold);
	font-size: calc(26px * var(--scale-factor));
	color: var(--color-black);
	margin: 0 0 calc(20px * var(--scale-factor));
	line-height: 1.5;
	letter-spacing: calc(-0.26px * var(--scale-factor));
}

.tech-case-item p {
	font-family: var(--font-hiragino);
	font-size: calc(18px * var(--scale-factor));
	color: var(--color-black);
	line-height: 1.6;
	margin: 0;
}

/* ==========================================
   Benefits Section
========================================== */
.tech-benefits {
	background-color: var(--color-off-white);
	padding: var(--padding-section-large) 0;
}

.tech-benefits .section-title {
	position: absolute;
	left: 0;
	top: calc(-70px * var(--scale-factor));
	width: calc(1249px * var(--scale-factor));
	z-index: 1;
	display: block;
	pointer-events: none;
}

.tech-benefits .container {
	position: relative;
	z-index: 2;
}

.tech-benefits-title {
	font-family: var(--font-dela);
	font-size: calc(64px * var(--scale-factor));
	font-weight: 400;
	color: var(--color-black);
	text-align: center;
	margin: 0 0 calc(80px * var(--scale-factor));
	line-height: 1.2;
	letter-spacing: calc(-0.64px * var(--scale-factor));
}

.tech-benefits-title-primary,
.tech-benefits-title-secondary {
	display: inline;
}

.tech-benefits-content {
	display: flex;
	gap: calc(32px * var(--scale-factor));
	align-items: flex-start;
}

.tech-benefits-column {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: calc(32px * var(--scale-factor));
}

.tech-benefit-card {
	background-color: var(--color-white);
	border-radius: calc(8px * var(--scale-factor));
	overflow: hidden;
	display: flex;
	flex-direction: column;
}

.tech-benefit-large {
	height: calc(830px * var(--scale-factor));
}

.tech-benefit-side {
	display: flex;
	flex-direction: row;
	height: calc(620px * var(--scale-factor));
}

.tech-benefit-small {
	height: calc(600px * var(--scale-factor));
}

.tech-benefit-mini {
	height: calc(620px * var(--scale-factor));
}

.tech-benefit-text {
	padding: calc(24px * var(--scale-factor));
	display: flex;
	flex-direction: column;
	gap: calc(24px * var(--scale-factor));
	flex: 1;
}

.tech-benefit-text h4 {
	font-family: var(--font-hiragino-std-bold);
	font-size: calc(32px * var(--scale-factor));
	color: var(--color-black);
	margin: 0;
	line-height: 1.2;
	letter-spacing: calc(-0.32px * var(--scale-factor));
}

.tech-benefit-text p {
	font-family: var(--font-hiragino);
	font-size: calc(24px * var(--scale-factor));
	color: var(--color-black);
	line-height: 1.5;
	margin: 0;
}

.tech-benefit-image {
	flex-shrink: 0;
}

.tech-benefit-large .tech-benefit-image {
	width: 100%;
	height: calc(360px * var(--scale-factor));
}

.tech-benefit-side .tech-benefit-image {
	flex: 0 0 calc(240px * var(--scale-factor));
	width: calc(240px * var(--scale-factor));
	max-width: calc(240px * var(--scale-factor));
	height: 100%;
}

.tech-benefit-small .tech-benefit-image {
	width: 100%;
	height: calc(300px * var(--scale-factor));
}

.tech-benefit-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.tech-benefit-image img[alt="開発会社との関係性"] {
	object-position: 30% center;
}

.tech-benefit-cards-row {
	display: flex;
	gap: calc(20px * var(--scale-factor));
}

.tech-benefit-cards-row .tech-benefit-card {
	flex: 1;
}

/* ==========================================
   Example Section
========================================== */
.tech-example {
	position: relative;
	padding: var(--padding-section-large) 0;
}

.tech-example-bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 1;
}

.tech-example .section-title {
	position: absolute;
	left: 0;
	top: calc(-70px * var(--scale-factor));
	width: calc(1037px * var(--scale-factor));
	z-index: 1;
	display: block;
	pointer-events: none;
}

.tech-example .container {
	position: relative;
	z-index: 3;
}

.tech-example-title {
	font-size: calc(64px * var(--scale-factor));
	color: var(--color-white);
	margin: 0 0 calc(48px * var(--scale-factor));
	line-height: 1.2;
	letter-spacing: calc(-0.64px * var(--scale-factor));
}

.tech-example-content {
	max-width: calc(560px * var(--scale-factor));
	display: flex;
	flex-direction: column;
	gap: calc(24px * var(--scale-factor));
}

.tech-example-item h4 {
	font-family: var(--font-hiragino-std-bold);
	font-size: calc(32px * var(--scale-factor));
	color: var(--color-white);
	margin: 0 0 calc(10px * var(--scale-factor));
	line-height: 1.5;
}

.tech-example-item p {
	font-family: var(--font-hiragino);
	font-size: calc(24px * var(--scale-factor));
	color: var(--color-white);
	line-height: 1.5;
	margin: 0;
}

/* ==========================================
   Flow Section
========================================== */
.tech-flow {
	position: relative;
	background-color: var(--color-off-white);
	padding: var(--padding-section-large) 0;
}

.tech-decoration-4 {
	left: 0;
	bottom: calc(-440px * var(--scale-factor));
	width: calc(1440px * var(--scale-factor));
	clip-path: inset(0 0 calc(440px * var(--scale-factor)) 0);
}

.tech-flow .section-title {
	position: absolute;
	left: 0;
	top: calc(-50px * var(--scale-factor));
	width: calc(1441px * var(--scale-factor));
	z-index: 1;
	display: block;
	pointer-events: none;
	font-weight: 400;
}

.tech-flow .container {
	position: relative;
	z-index: 2;
}

.tech-flow-content {
	display: flex;
	gap: calc(80px * var(--scale-factor));
	align-items: flex-start;
}

.tech-flow-left {
	flex: 0 0 calc(500px * var(--scale-factor));
}

.tech-flow-left h3 {
	font-family: var(--font-dela);
	font-size: calc(56px * var(--scale-factor));
	font-weight: 400;
	color: var(--color-black);
	margin: 0;
	line-height: 1.2;
	letter-spacing: calc(-0.64px * var(--scale-factor));
}

.tech-flow-right {
	flex: 1;
}

.tech-flow-timeline {
	display: flex;
	flex-direction: column;
	gap: calc(16px * var(--scale-factor));
}

.tech-flow-item {
	display: flex;
	gap: calc(40px * var(--scale-factor));
	align-items: flex-start;
}

.tech-flow-step {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: calc(16px * var(--scale-factor));
	flex-shrink: 0;
}

.tech-flow-icon {
	width: calc(48px * var(--scale-factor));
	height: calc(48px * var(--scale-factor));
	border-radius: calc(8px * var(--scale-factor));
	background-color: var(--color-black);
	color: var(--color-white);
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--font-hiragino-std-bold);
	font-size: calc(24px * var(--scale-factor));
}

.tech-flow-line {
	width: calc(2px * var(--scale-factor));
	background-color: var(--color-black);
}

.tech-flow-line-long {
	height: calc(220px * var(--scale-factor));
}

.tech-flow-line-short {
	height: calc(110px * var(--scale-factor));
}


.tech-flow-item:last-child .tech-flow-line {
	display: none;
}

.tech-flow-text {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: calc(16px * var(--scale-factor));
}

.tech-flow-text h4 {
	font-family: var(--font-hiragino);
	font-size: calc(40px * var(--scale-factor));
	color: var(--color-black);
	margin: 0;
	line-height: 1.2;
	letter-spacing: calc(-0.4px * var(--scale-factor));
	font-weight: 400;
}

.tech-flow-text p {
	font-family: var(--font-hiragino);
	font-size: calc(18px * var(--scale-factor));
	color: var(--color-black);
	line-height: 1.5;
	margin: 0;
}

/* ==========================================
   Plan Section
========================================== */
.tech-plan {
	background-color: var(--color-main-navy);
	padding: var(--padding-section-large) 0;
}

.tech-plan .section-title {
	position: absolute;
	left: 0;
	top: calc(-70px * var(--scale-factor));
	width: calc(778px * var(--scale-factor));
	z-index: 1;
	display: block;
	pointer-events: none;
}

.tech-plan .container {
	position: relative;
	z-index: 2;
}

.tech-plan-header {
	text-align: center;
	margin-bottom: calc(80px * var(--scale-factor));
}

.tech-plan-header h3 {
	font-size: calc(64px * var(--scale-factor));
	color: var(--color-white);
	margin: 0 0 calc(24px * var(--scale-factor));
	line-height: 1.2;
	letter-spacing: calc(-0.64px * var(--scale-factor));
}

.tech-plan-header p {
	font-family: var(--font-hiragino-std-bold);
	font-size: calc(24px * var(--scale-factor));
	color: var(--color-white);
	line-height: 1.5;
	margin: 0;
}

.tech-plan-content {
	display: flex;
	gap: calc(32px * var(--scale-factor));
	margin-bottom: calc(80px * var(--scale-factor));
}

.tech-plan-card {
	flex: 1;
	background-color: var(--color-white);
	border: calc(2px * var(--scale-factor)) solid var(--color-black);
	border-radius: calc(32px * var(--scale-factor));
	padding: calc(32px * var(--scale-factor));
	display: flex;
	flex-direction: column;
	gap: calc(32px * var(--scale-factor));
}

.tech-plan-header-section {
	display: flex;
	flex-direction: column;
	gap: calc(16px * var(--scale-factor));
}

.tech-plan-header-section h4 {
	font-family: var(--font-dela);
	font-size: calc(32px * var(--scale-factor));
	font-weight: 400;
	color: var(--color-black);
	margin: 0 0 calc(4px * var(--scale-factor));
	line-height: 1.4;
	letter-spacing: calc(-0.32px * var(--scale-factor));
}

.tech-plan-header-section p {
	font-family: var(--font-hiragino);
	font-size: calc(24px * var(--scale-factor));
	color: var(--color-black);
	line-height: 1.5;
	margin: 0;
}

.tech-plan-price {
	text-align: center;
	padding: calc(16px * var(--scale-factor)) 0;
	border-top: calc(2px * var(--scale-factor)) solid var(--color-black);
	border-bottom: calc(2px * var(--scale-factor)) solid var(--color-black);
}

.tech-plan-amount {
	font-family: var(--font-hiragino-std-bold);
	font-weight: 700;
	color: var(--color-red);
	display: inline-flex;
	align-items: flex-end;
	gap: calc(12px * var(--scale-factor));
}

.tech-plan-amount-number {
	font-size: calc(48px * var(--scale-factor));
	line-height: 1;
}

.tech-plan-amount-unit {
	font-size: calc(32px * var(--scale-factor));
	line-height: 1.2;
}

.tech-plan-tax {
	font-family: var(--font-hiragino);
	font-size: calc(16px * var(--scale-factor));
	color: var(--color-black);
	line-height: 1.5;
	display: block;
	margin-top: calc(8px * var(--scale-factor));
}

.tech-plan-features {
	font-family: var(--font-hiragino-std-bold);
	flex-direction: column;
	color: var(--color-black);
	padding: calc(8px * var(--scale-factor)) 0;
}

.tech-plan-feature {
	display: flex;
	gap: calc(8px * var(--scale-factor));
	align-items: flex-start;
	margin-bottom: calc(16px * var(--scale-factor));
}

.tech-plan-check {
	width: calc(32px * var(--scale-factor));
	height: calc(32px * var(--scale-factor));
	flex-shrink: 0;
	color: var(--color-black);
	font-size: calc(24px * var(--scale-factor));
	line-height: 1;
}

.tech-plan-feature p {
	font-family: var(--font-hiragino);
	font-size: calc(20px * var(--scale-factor));
	color: var(--color-black);
	line-height: 1.2;
	margin: 0;
	flex: 1;
}

.tech-plan-notes {
	color: var(--color-white);
}

.tech-plan-notes p {
	font-family: var(--font-hiragino);
	font-size: calc(24px * var(--scale-factor));
	line-height: 1.5;
	margin: 0 0 calc(24px * var(--scale-factor));
}

.tech-plan-notes p:last-child {
	margin-top: calc(40px * var(--scale-factor));
	margin-bottom: 0;
}

/* ==========================================
   Button Styles
========================================== */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: calc(16px * var(--scale-factor)) calc(32px * var(--scale-factor));
	border-radius: calc(12px * var(--scale-factor));
	font-family: var(--font-hiragino-std-bold);
	font-size: calc(24px * var(--scale-factor));
	line-height: 1.5;
	text-decoration: none;
	cursor: pointer;
	border: none;
	transition: all 0.3s ease;
}

.tech-cta .btn-primary,
.tech-flow .btn-primary {
	background: linear-gradient(135deg, var(--color-yellow) 0%, var(--color-dark-yellow) 25%, var(--color-red) 100%);
	color: var(--color-white);
	box-shadow:
		0px 1px 2px 0px rgba(2, 6, 11, 0.05),
		inset 0px 32px 24px 0px rgba(255, 255, 255, 0.05),
		inset 0px 2px 1px 0px rgba(255, 255, 255, 0.25),
		inset 0px 0px 0px 1px rgba(2, 6, 11, 0.15),
		inset 0px -2px 1px 0px rgba(0, 0, 0, 0.2);
}

.btn-secondary {
	background-color: var(--color-white);
	color: var(--color-black);
	border: calc(2px * var(--scale-factor)) solid var(--color-black);
}

/* ==========================================
   Responsive Design
========================================== */
@media (max-width: 600px) {

	/* Hero Section - Mobile */
	.tech-hero {
		height: calc(900px * var(--scale-factor));
	}

	.tech-hero-content {
		padding: calc(96px * var(--scale-factor)) calc(32px * var(--scale-factor)) calc(48px * var(--scale-factor));
	}

	.tech-hero-content .container {
		align-items: flex-end;
		max-width: 100%;
		padding-left: calc(32px * var(--scale-factor));
	}

	.tech-hero-inner {
		gap: calc(40px * var(--scale-factor));
	}

	.tech-hero-copy {
		gap: calc(24px * var(--scale-factor));
		padding-left: calc(24px * var(--scale-factor));
	}

	.tech-hero-divider {
		max-width: none;
	}

	.tech-main-title {
		font-size: var(--text-xl);
	}

	.tech-subtitle {
		font-size: calc(24px * var(--scale-factor));
		gap: calc(2px * var(--scale-factor));
	}

	.tech-hero-bg {
		object-position: 30% 50%;
	}

	.tech-hero-divider {
		width: calc(100% + (32px * var(--scale-factor)));
		margin-right: calc(-32px * var(--scale-factor));
	}

	.tech-menu {
		flex-direction: column;
		gap: calc(20px * var(--scale-factor));
		position: relative;
		align-self: flex-end;
		width: calc(360px * var(--scale-factor));
		margin-top: auto;
	}

	.tech-menu-item {
		max-width: none;
		width: 100%;
	}

	.tech-menu-text {
		padding: 0;
		min-height: calc(48px * var(--scale-factor));
		width: 100%;
		justify-content: space-between;
	}

	.tech-menu-text p {
		font-size: calc(24px * var(--scale-factor));
	}

	.tech-menu-icon {
		font-size: calc(24px * var(--scale-factor));
	}

	/* About Section - Mobile */
	.tech-about .section-title {
		top: calc(-46px * var(--scale-factor));
		width: calc(740px * var(--scale-factor));
	}

	.tech-about-content {
		flex-direction: column;
		gap: calc(40px * var(--scale-factor));
	}

	.tech-about-media {
		width: 100%;
		align-items: center;
	}

	.tech-about-video {
		width: calc(480px * var(--scale-factor));
		max-width: 100%;
	}

	.tech-about-image {
		width: calc(480px * var(--scale-factor));
		max-width: 100%;
		height: calc(512px * var(--scale-factor));
	}

	/* Features - Mobile */
	.tech-feature1 .section-title {
		top: calc(-46px * var(--scale-factor));
		width: calc(800px * var(--scale-factor));
	}

	.tech-feature1-content,
	.tech-feature3-content {
		flex-direction: column;
		gap: calc(40px * var(--scale-factor));
		text-align: center;
	}

	.tech-feature1-text h3,
	.tech-feature2-content h3,
	.tech-feature3-text h3 {
		font-size: var(--text-xl);
	}

	.tech-feature1-left,
	.tech-feature3-right {
		align-items: center;
	}

	.tech-feature1-left {
		align-items: flex-start;
	}

	.tech-feature3-right {
		align-items: flex-start;
	}

	.tech-feature3-text {
		text-align: left;
	}

	.tech-feature1-text {
		text-align: left;
	}

	.tech-feature1-text p {
		text-align: left;
	}

	.tech-feature1-right,
	.tech-feature3-left {
		width: calc(600px * var(--scale-factor));
		max-width: 100%;
		height: calc(600px * var(--scale-factor));
		margin: 0 auto;
	}

	.tech-feature2 {
		padding: var(--padding-section-large) 0;
	}

	.tech-feature2-content {
		width: calc(600px * var(--scale-factor));
		max-width: 100%;
		margin: 0 auto;
	}

	.tech-feature2-image {
		width: calc(600px * var(--scale-factor));
		max-width: 100%;
		height: auto;
		margin-top: calc(16px * var(--scale-factor));
	}

	.tech-feature2-image img {
		width: 100%;
		height: 100%;
		object-fit: contain;
	}

	/* Cases Section - Mobile */
	.tech-cases {
		padding: calc(160px * var(--scale-factor)) 0 calc(160px * var(--scale-factor));
	}

	.tech-cases .section-title {
		top: calc(-46px * var(--scale-factor));
		width: calc(1100px * var(--scale-factor));
	}

	.tech-decoration-3 {
		left: 50%;
		transform: translateX(-50%);
		bottom: calc(-200px * var(--scale-factor));
	}

	.tech-cases-content {
		flex-direction: column;
		gap: calc(40px * var(--scale-factor));
	}

	.tech-cases-left {
		flex: none;
		max-width: 100%;
		padding-top: 0;
		text-align: left;
	}

	.tech-cases-left h3 {
		font-size: calc(56px * var(--scale-factor));
	}

	.tech-cases-right {
		max-width: 100%;
	}

	.tech-case-item {
		padding: calc(32px * var(--scale-factor));
		box-shadow: 0 calc(16px * var(--scale-factor)) calc(48px * var(--scale-factor)) rgba(4, 20, 57, 0.2);
	}

	.tech-case-item h4 {
		font-size: var(--text-md);
	}

	.tech-case-item p {
		font-size: var(--text-base);
	}

	/* Benefits Section - Mobile */
	.tech-benefits .section-title {
		top: calc(-52px * var(--scale-factor));
		width: calc(1000px * var(--scale-factor));
	}

	.tech-benefits-content {
		flex-direction: column;
	}

	.tech-benefits-title-primary {
		display: block;
	}

	.tech-benefit-side {
		flex-direction: column;
		height: auto;
	}

	.tech-benefit-side .tech-benefit-image {
		flex: none;
		width: 100%;
		max-width: 100%;
		height: calc(400px * var(--scale-factor));
	}

	.tech-benefit-cards-row {
		flex-direction: column;
	}

	.tech-example-content {
		gap: calc(48px * var(--scale-factor));
	}

	/* CTA Section - Mobile */
	.tech-cta {
		padding: calc(96px * var(--scale-factor)) calc(16px * var(--scale-factor));
	}

	.tech-cta .container {
		padding: 0;
	}

	.tech-cta-content {
		max-width: calc(500px * var(--scale-factor));
		width: 100%;
		margin: 0 auto;
	}

	.tech-cta-content h3 {
		font-size: var(--text-lg);
		text-align: left;
	}

	.tech-cta-content p {
		font-size: var(--text-base);
		text-align: left;
	}

	.tech-cta-buttons {
		flex-direction: column;
		align-items: center;
		gap: calc(24px * var(--scale-factor));
	}

	.tech-cta-buttons .btn {
		white-space: nowrap;
		width: calc(320px * var(--scale-factor));
		max-width: 100%;
	}

	/* Example Section - Mobile */
	.tech-example .section-title {
		top: calc(-54px * var(--scale-factor));
		width: calc(800px * var(--scale-factor));
	}

	/* Flow Section - Mobile */
	.tech-flow .section-title {
		top: calc(-36px * var(--scale-factor));
		width: calc(1100px * var(--scale-factor));
	}

	.tech-flow-content {
		flex-direction: column;
		gap: calc(40px * var(--scale-factor));
	}

	.tech-flow-left {
		flex: none;
		text-align: center;
	}

	.tech-flow-line {
		height: calc(150px * var(--scale-factor));
	}

	.tech-flow-text h4 {
		font-size: var(--text-md);
	}

	.tech-flow-text p {
		font-size: var(--text-sm);
	}

	/* Plan Section - Mobile */
	.tech-plan .section-title {
		top: calc(-62px * var(--scale-factor));
		width: calc(700px * var(--scale-factor));
	}

	.tech-plan-content {
		flex-direction: column;
	}
}