#home { background:#fff; color:#1f1f1f; padding-bottom:90px; }
#home section { width:min(1180px, calc(100% - 40px)); margin:0 auto; }
#home p { line-height:1.72; word-break:keep-all; }
.home-label { margin-bottom:12px; color:#6c7a89; font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:0; }
.home-section-head { max-width:620px; margin:0 auto 34px; text-align:center; }
.home-section-head h2 { font-size:34px; line-height:1.25; font-weight:800; }
.home-section-head p:last-child { margin-top:12px; color:#666; font-size:16px; }
.home-visual { min-height:620px; padding:86px 0 70px; display:grid; grid-template-columns:0.9fr 1.1fr; align-items:center; gap:58px; }
.home-visual__text h1 { max-width:560px; font-size:54px; line-height:1.12; font-weight:800; }
.home-visual__text p:last-child { max-width:520px; margin-top:24px; color:#555; font-size:18px; }
.home-visual__stage { position:relative; min-height:390px; display:flex; align-items:center; justify-content:center; overflow:hidden; background:#f4f5f7 url('../img/theeternalcircle_bg.jpg') center/cover no-repeat; border:1px solid #e5e7eb; }
.home-visual__stage span { position:relative; z-index:2; padding:10px 16px; background:#fff; border:1px solid #d6dbe1; color:#7a828c; font-size:12px; font-weight:700; }
.home-paper { position:absolute; background:#fff; border:1px solid #d9dee5; box-shadow:0 18px 40px rgba(31,31,31,.08); }
.home-paper--one { width:48%; height:58%; left:11%; bottom:13%; }
.home-paper--two { width:38%; height:48%; right:12%; top:14%; }
.home-paper--three { width:26%; height:34%; right:27%; bottom:9%; background:#e9eef4; }
.home-solution { padding:78px 0; border-top:1px solid #ececec; }
.home-solution__grid { display:grid; grid-template-columns:repeat(3, minmax(0, 1fr)); gap:18px; }
.home-solution__grid article { min-height:230px; padding:28px; background:#fafafa; border:1px solid #e9e9e9; }
.home-solution__grid strong { color:#9aa3ad; font-size:13px; }
.home-solution__grid h3 { margin-top:50px; font-size:22px; font-weight:800; }
.home-solution__grid p { margin-top:12px; color:#666; font-size:15px; }
.home-package { padding:78px 0; }
.home-package__body { display:grid; grid-template-columns:1.05fr .95fr; gap:24px; align-items:stretch; }
.home-placeholder { min-height:440px; display:flex; align-items:center; justify-content:center; overflow:hidden; background:#f1f1f1; border:1px solid #e3e3e3; color:#858585; font-size:12px; font-weight:700; }
.home-placeholder img { width:100%; height:100%; object-fit:cover; display:block; }
.home-package__list { display:grid; gap:14px; }
.home-package__list article { padding:26px; background:#fff; border:1px solid #e7e7e7; }
.home-package__list h3 { font-size:21px; font-weight:800; }
.home-package__list p { margin-top:10px; color:#666; font-size:15px; }
.home-service { padding:78px 0 0; border-top:1px solid #ececec; }
.home-service__grid { display:grid; grid-template-columns:repeat(4, minmax(0, 1fr)); gap:16px; }
.home-service__grid article { padding:24px; background:#f8f9fa; border:1px solid #e8eaed; }
.home-service__icon { width:46px; height:46px; display:flex; align-items:center; justify-content:center; margin-bottom:28px; background:#202124; color:#fff; font-size:14px; font-weight:800; }
.home-service__grid h3 { font-size:20px; font-weight:800; }
.home-service__grid p { margin-top:10px; color:#666; font-size:15px; }
@media (max-width:900px){
	.home-visual { min-height:auto; padding:62px 0 54px; grid-template-columns:1fr; gap:34px; }
	.home-visual__text h1 { font-size:40px; }
	.home-visual__stage { min-height:320px; }
	.home-solution__grid { grid-template-columns:1fr; }
	.home-package__body { grid-template-columns:1fr; }
	.home-service__grid { grid-template-columns:repeat(2, minmax(0, 1fr)); }
}
@media (max-width:560px){
	#home { padding-bottom:60px; }
	#home section { width:calc(100% - 28px); }
	.home-section-head { margin-bottom:24px; text-align:left; }
	.home-section-head h2 { font-size:28px; }
	.home-visual__text h1 { font-size:34px; }
	.home-visual__text p:last-child { font-size:16px; }
	.home-visual__stage { min-height:260px; }
	.home-solution, .home-package, .home-service { padding:56px 0; }
	.home-placeholder { min-height:300px; }
	.home-service__grid { grid-template-columns:1fr; }
}
