@charset "UTF-8";
/* --- ヒーローセクション --- */
.hero {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 40px 20px;
	max-width: 1280px;
	margin: 0 auto;
	position: relative;
	overflow: hidden;
}

.hero-content {
	flex: 1;
	max-width: 50%;
	z-index: 2;
}

.hero-title-sub {
	font-size: 32px;
	color: #666;
	margin-bottom: 10px;
	font-weight: bold;
}

.hero-title-main {
	font-size: 42px;
	color: var(--primary-green);
	margin: 0 0 40px 0;
	line-height: 1.2;
	font-weight: bold;
}

.hero-title-main span {
	color: #444;
}

.hero-buttons {
	display: flex;
	gap: 20px;
}

.hero-buttons .hero-btn {
	min-width: 200px;
	height: 25px;
	font-size: 16px;
}

.hero-buttons .hero-btn i {
	margin-left: 8px;
	font-size: 16px;
}

.hero-image {
	flex: 1;
	position: relative;
	display: flex;
	justify-content: flex-end;
}

.hero-section {
	text-align: center;
	font-family: "Hiragino Kaku Gothic ProN", "Yu Gothic", sans-serif;
	padding: 40px 20px;
	background-color: #fff;
}

.main-title {
	font-size: 32px;
	font-weight: bold;
	color: #444;
	line-height: 1.4;
	margin-bottom: 30px;
	position: relative;
	display: inline-block;
}

/* 上段のテキスト */
.title-sub {
	display: block;
	font-size: 0.9em;
	margin-bottom: 5px;
}

/* 緑色の強調部分 */
.highlight-green {
	color: #00A968;
	/* 画像に近い緑色 */
}

/* 装飾（キラキラ）の簡易再現 */
.deco {
	position: absolute;
	color: #8CDDbd;
	font-size: 20px;
}

.deco-left {
	top: 30px;
	left: -30px;
}

.deco-right {
	top: 10px;
	right: -30px;
}

/* ボタンエリア */
.button-container {
	display: flex;
	justify-content: center;
	gap: 15px;
}

.btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 260px;
	padding: 15px 0;
	color: #fff;
	text-decoration: none;
	border-radius: 4px;
	font-weight: bold;
	font-size: 14px;
	position: relative;
	transition: opacity 0.3s;
}

.btn:hover {
	opacity: 0.9;
}

/* 左のボタン（ダークグレー） */
.btn-gray {
	background-color: #4a4a4a;
}

/* 右のボタン（緑） */
.btn-green {
	background-color: #00A968;
}

/* 三角矢印の簡易再現 */
.arrow {
	margin-left: 10px;
	font-size: 10px;
}

.img-placeholder {
	width: 100%;
	max-width: 600px;
	height: 400px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: bold;
}

/* --- About Us セクション --- */
.about-section {
	text-align: center;
	padding: 20px 40px 120px 40px;
	/* ドット柄背景はそのまま残しています */
	background-image: radial-gradient(#e0e0e0 1px, transparent 1px);
	background-size: 20px 20px;
	position: relative;
}

.section-title-en {
	color: var(--primary-green);
	font-size: 36px;
	margin: 0;
	font-weight: bold;
}

.section-title-jp {
	font-size: 14px;
	color: #666;
	margin-top: 5px;
	margin-bottom: 40px;
	font-weight: bold;
}

.about-inner {
	max-width: 800px;
	margin: 0 auto;
	position: relative;
}

.about-logo-text {
	font-size: 28px;
	font-weight: bold;
	margin-bottom: 20px;
}

.about-lead {
	font-size: 50px;
	color: var(--primary-green);
	font-weight: bold;
	margin-bottom: 20px;
}

.about-lead .first-text{
	font-size: 40px;
}

.about-desc {
	font-size: 15px;
	color: #444;
	margin-bottom: 40px;
	line-height: 1.8;
}

.about-section .about-btn {
	width: 300px;
	height: 30px;
	margin: 0 auto;
}

/* --- reason セクション --- */
.reason-section {
	text-align: center;
	padding: 20px 40px 120px 40px;
	/* ドット柄背景はそのまま残しています */
	background-image: radial-gradient(#e0e0e0 1px, transparent 1px);
	background-size: 20px 20px;
	position: relative;
}

.title-en {
	color: var(--primary-green);
	font-size: 36px;
	margin: 0;
	font-weight: bold;
}

.title-jp {
	font-size: 14px;
	color: #666;
	margin-top: 5px;
	margin-bottom: 40px;
	font-weight: bold;
}

.reason-inner {
	max-width: 800px;
	margin: 0 auto;
	position: relative;
}

.reason-logo-text {
	font-size: 28px;
	font-weight: bold;
	margin-bottom: 20px;
}

.reason-lead {
	font-size: 50px;
	color: var(--primary-green);
	font-weight: bold;
	margin-bottom: 20px;
}

.reason-lead .first-text {
	font-size: 40px;
}

.reason-desc {
	font-size: 15px;
	color: #444;
	margin-bottom: 40px;
	line-height: 1.8;
}

.reason-section .reason-btn {
	width: 300px;
	height: 30px;
	margin: 0 auto;
}

/* --- features セクション --- */
.features-section {
	text-align: center;
	padding: 20px 40px 120px 40px;
	/* ドット柄背景はそのまま残しています */
	background-image: radial-gradient(#e0e0e0 1px, transparent 1px);
	background-size: 20px 20px;
	position: relative;
}

.section-title-en {
	color: var(--primary-green);
	font-size: 36px;
	margin: 0;
	font-weight: bold;
}

.section-title-jp {
	font-size: 14px;
	color: #666;
	margin-top: 5px;
	margin-bottom: 40px;
	font-weight: bold;
}

.features-inner {
	max-width: 800px;
	margin: 0 auto;
	position: relative;
}

.features-logo-text {
	font-size: 28px;
	font-weight: bold;
	margin-bottom: 20px;
}

.features-lead {
	font-size: 50px;
	color: var(--primary-green);
	font-weight: bold;
	margin-bottom: 20px;
}

.features-lead .first-text {
	font-size: 40px;
}

.features-desc {
	font-size: 15px;
	color: #444;
	margin-bottom: 40px;
	line-height: 1.8;
}

.features-section .features-btn {
	width: 300px;
	height: 30px;
	margin: 0 auto;
}

/* フロントページ用レスポンシブ */
@media (max-width: 768px) {
	.hero {
		flex-direction: column-reverse;
		padding: 40px 20px;
	}

	.hero-content {
		max-width: 100%;
		text-align: center;
	}

	.hero-buttons {
		flex-direction: column;
	}
}