:root {
	--color-primary: #003264;
	--color-accent: #C30C18;
	--color-text: #333;
	--color-muted: #E1EDEF;
	--color-bg: #fff;
	--color-surface: #f8fafc;
	--max-width: 1040px;
	--radius: 16px;
	--shadow-sm: 0 1px 4px rgba(2, 6, 23, .06);
	--shadow-md: 0 12px 32px rgba(2, 6, 23, .08);
}

body {
	font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic UI", "Yu Gothic", "Meiryo", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
	color: var(--color-text);
	background: var(--color-bg);
	line-height: 1.5;
	font-size: 16px;
	letter-spacing: 0.05em;
}

@font-face {
	font-family: "Gill Sans MT";
	src: url("../font/gill-sans-mt-webfont.woff2") format("woff2"),
		url("..//fonts/gill-sans-mt.woff") format("woff"),
		url("..//fonts/gill-sans-mt.ttf") format("truetype");
	font-display: swap;
}

main,#pageWrapper {
	position: relative;
	z-index: 0;
}

.pc_hide {
	display: none;
}

.container {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: 0 20px;
}

.section {
	padding: 72px 0;
}

.section-title {
	position: relative;
	text-align: center;
	margin-bottom: 60px;
	z-index: 0;
}

.section-title__en {
	position: relative;
	display: inline-block;
	text-align: center;
	font-size: 128px;
	font-family: "Gill Sans MT";
	font-weight: normal;
	color: #E1EDEF;
	letter-spacing: 0.1em;
	margin-bottom: 8px;
}

.section-title__en_w {
	color: #fff;
}

.section-title__ja {
	width: 100%;
	position: absolute;
	top: 60%;
	left: 50%;
	transform: translate(-50%, -50%);
	font-size: 40px;
	font-weight: bold;
	z-index: 2;
	color: var(--color-text);
}

.section-lead {
	color: var(--color-muted);
	margin-bottom: 32px;
}

a {
	cursor: pointer;
	color: var(--color-bg);
	text-decoration: none;
}

.btn {
	display: inline-flex;
	gap: 10px;
	align-items: center;
	justify-content: center;
	padding: 14px 22px;
	border-radius: 999px;
	background: var(--color-primary);
	color: #fff;
	font-weight: 700;
	box-shadow: var(--shadow-sm);
	transition: .2s ease;
}

.btn:hover {
	transform: translateY(-1px);
	box-shadow: var(--shadow-md);
}

.btn--ghost {
	background: #fff;
	color: var(--color-primary);
	border: 1px solid rgba(11, 95, 255, .2)
}

.badge {
	display: inline-block;
	padding: 6px 10px;
	border-radius: 999px;
	background: rgba(11, 95, 255, .08);
	color: var(--color-primary);
	font-weight: 700;
	font-size: 12px;
	letter-spacing: .06em;
}

.site-header {
	position: sticky;
	top: 0;
	background: #fff;
	border-bottom: 1px solid #eef1f6;
	z-index: 50;
}

.site-header .inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 64px;
}

.logo {
	display: flex;
	align-items: center;
	gap: 10px;
	font-weight: 800;
	color: var(--color-text);
	text-decoration: none;
}

.logo img {
	width: 32px;
	height: 32px;
}

.site-header.minimal .inner {
	justify-content: flex-start;
}

.kv {
	padding: 56px 0;
	background: linear-gradient(180deg, #fff 0%, #f9fafb 100%);
}

.kv .container {
	display: grid;
	grid-template-columns: 1.1fr .9fr;
	gap: 32px;
	align-items: center;
}

.kv-title {
	font-size: 48px;
	line-height: 1.25;
	font-weight: 800;
	letter-spacing: .01em;
}

.kv-lead {
	color: var(--color-muted);
	margin: 12px 0 22px;
}

.kv-actions {
	display: flex;
	gap: 12px;
}

.kv-visual {
	border-radius: 20px;
	overflow: hidden;
	box-shadow: var(--shadow-md);
	background: #fff;
}

.kv-visual img {
	width: 100%;
	height: auto;
	display: block;
}

/* strip */
.info-strip {
	background: #0b2c48;
	color: #fff
}

.info-strip .container {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 44px;
}

.info-strip .chip {
	background: #073256;
	border: 1px solid rgba(255, 255, 255, .18);
	padding: 4px 10px;
	border-radius: 999px;
	margin-right: 8px;
	font-size: 12px;
}

.info-strip .chip--alt {
	background: #115e59;
}

.info-strip .phone {
	color: #fff;
	text-decoration: none;
	font-weight: 700;
}

/* problem */
.problem {
	background: #f1f8ff;
}

.problem .panel {
	background: #0b2c48;
	color: #fff;
	border-radius: 16px;
	padding: 20px;
	position: relative;
	overflow: hidden;
}

.problem .panel-title {
	font-size: 18px;
	font-weight: 800;
	margin-bottom: 10px;
}

.problem .checks {
	display: grid;
	gap: 6px;
	color: #e5eef7;
}

.problem .panel-illust {
	position: absolute;
	right: 10px;
	bottom: 0;
	width: 160px;
	opacity: .9;
}

/* solution */
.solution {
	background: linear-gradient(180deg, #f1f8ff 0%, #fff 100%);
	padding: 40px 0;
}

.solution .eyebrow {
	color: #2563EB;
	font-weight: 800;
	letter-spacing: .08em;
}

.solution-title {
	font-size: 24px;
	font-weight: 800;
}

/* points */
.points .grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
}

.point {
	background: #fff;
	border-radius: 16px;
	padding: 16px;
	box-shadow: var(--shadow-sm);
	border: 1px solid #eef1f6;
}

.point-img {
	width: 100%;
	height: auto;
	border-radius: 12px;
	margin-bottom: 10px;
}

.point h3 {
	font-size: 18px;
	margin-bottom: 4px;
}

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

/* stats */
.stats {
	background: #0b2c48;
	color: #fff;
	padding: 28px 0;
}

.stats .row {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 16px;
	align-items: center;
}

.stat {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}

.stat .num {
	font-size: 28px;
	font-weight: 800;
}

.stat .unit {
	font-size: .8em;
	opacity: .9;
}

.stat .cap {
	opacity: .8;
}

/* diagram */
.diagram-fig {
	display: block;
	margin-top: 10px;
}

.diagram-fig img {
	width: 100%;
	height: auto;
}

/* services */
.service-card {
	background: #f8fafc;
	border: 1px solid #e5e7eb;
	border-radius: 16px;
	padding: 16px;
	text-align: center;
}

.service-card .icons {
	display: flex;
	gap: 10px;
	justify-content: center;
	margin-bottom: 8px;
}

.service-card .icons img {
	width: 40px;
	height: 40px;
}

.service-card .desc {
	color: var(--color-muted)
}

/* members */
.members .cards {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
}

.member {
	background: #fff;
	border: 1px solid #e5e7eb;
	border-radius: 12px;
	box-shadow: var(--shadow-sm);
	padding: 12px;
	text-align: center;
}

.member img {
	width: 100%;
	height: auto;
	border-radius: 8px;
	margin-bottom: 8px;
}

.member .name {
	font-weight: 800;
}

.member .role {
	color: var(--color-muted);
	font-size: 14px;
}

.cta-simple {
	background: var(--color-surface);
	text-align: center;
}

.cta-simple .cta-title {
	font-size: 28px;
	font-weight: 800;
	margin-bottom: 14px;
}

.steps .items {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
}

.step {
	background: #fff;
	border-radius: 16px;
	padding: 20px;
	box-shadow: var(--shadow-sm);
	border: 1px solid #eef1f6;
}

.step .num {
	font-weight: 800;
	color: var(--color-primary);
	margin-bottom: 6px;
}

.requirements .list {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 16px;
}

.req-item {
	background: #fff;
	border-radius: 12px;
	padding: 14px 16px;
	border: 1px dashed #dbe4ff;
}

.faq .qa {
	border-top: 1px solid #eef1f6;
}

.faq .qa:first-child {
	border-top: none;
}

.faq .q {
	display: flex;
	justify-content: space-between;
	gap: 12px;
	padding: 16px 0;
	font-weight: 700;
}

.faq .a {
	color: var(--color-muted);
	padding-bottom: 16px;
}

.cta {
	background: linear-gradient(180deg, #0B5FFF 0%, #4DA3FF 100%);
	color: #fff;
	text-align: center;
}

.cta .box {
	background: rgba(255, 255, 255, .1);
	border: 1px solid rgba(255, 255, 255, .2);
	border-radius: 16px;
	padding: 24px;
	backdrop-filter: saturate(140%) blur(6px);
}

.cta .title {
	font-size: 28px;
	font-weight: 800;
	margin-bottom: 10px;
}

.cta .desc {
	opacity: .9;
	margin-bottom: 16px;
}

footer.site-footer {
	border-top: 1px solid #eef1f6;
	padding: 32px 0;
	color: var(--color-muted);
}

@media (max-width:1024px) {
	.kv .container {
		grid-template-columns: 1fr;
	}

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

	.stats .row {
		grid-template-columns: 1fr 1fr;
	}

	.members .cards {
		grid-template-columns: 1fr 1fr;
	}
}

@media (max-width:640px) {
	.section {
		padding: 40px 0;
	}

	.hero-title {
		font-size: 32px;
	}

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

	.stats .row {
		grid-template-columns: 1fr 1fr;
	}

	.members .cards {
		grid-template-columns: 1fr;
	}
}