@charset "utf-8";

/* ----------------------------------------
	item.css
---------------------------------------- */

h1 {
	padding: 8rem 15% 6rem 15%;
	background: linear-gradient(135deg, #6EB6FE 20%, #ECF4FF 80%);
	color: #fff;
}

.ok-item {
	margin: 8rem 15%;
}

.together-item {
	margin: 8rem 15%;
}

.ng-item {
	margin: 8rem 15%;
}

/* 共通リスト */
#item .item-list {
	display: grid;
	/* grid-template-columns: repeat(5, 1fr); */
	/* grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); */
	grid-template-columns: repeat(auto-fill, 250px);
	justify-content: center;
	gap: 2rem;
	padding: 0;
}

/* 正方形カード */
#item .item-list li {
	background: #fff;
	padding: 1rem;
	border-radius: 15px;
	box-shadow: rgba(0,0,0,.15) 0 2px 8px;

	aspect-ratio: 1 / 1;

	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}

/* 画像専用エリア（重要） */
#item .item-list li div {
	width: 72px;
	height: 72px;

	display: flex;
	align-items: center;
	justify-content: flex-start;

	margin-bottom: 1.5rem;
}

/* 画像を枠にフィット */
#item .item-list img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: block;
}

.item-intro {
	background-color: #ECF4FF;
    padding: 2rem;
	margin-bottom: 4rem;
}

.item-intro-ttl {
	background-color: #fff;
    padding: .5rem 0;
	color: #488CFE;
	font-size: 1.2rem;
	font-weight: 500;
	text-align: center;
	margin-bottom: 2rem;
}

.item-intro-content {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 6rem;
}

.item-intro-right p:not(:last-child) {
	font-size: 1.1rem;
	font-weight: 500;
	margin-bottom: 0.5rem;
}

.fa-circle-dot {
	color: #488CFE;
	margin-right: 0.5rem;
}

.ng-item h2::before {
	background-color: #F45D13;
}

/* ----------------------------------------
   Responsive
---------------------------------------- */

/* ===============================
   タブレット（1024px以下）
=============================== */
@media screen and (max-width: 1024px) {

	h1 {
		padding: 6rem 8% 4rem 8%;
	}

	.ok-item,
	.together-item,
	.ng-item {
		margin: 6rem 8%;
	}

	/* 5列 → 3列 */
	#item .item-list {
		grid-template-columns: repeat(3, 1fr);
		gap: 1.5rem;
	}

	.item-intro-content {
		gap: 3rem;
	}

	#item .item-list li div {
		width: 64px;
		height: 64px;
	}
}


/* ===============================
   スマホ（768px以下）
=============================== */
@media screen and (max-width: 768px) {

	h1 {
		padding: 5rem 5% 3rem 5%;
		font-size: 1.6rem;
		text-align: center;
	}

	.ok-item,
	.together-item,
	.ng-item {
		margin: 4rem 5%;
	}

	/* 3列 → 2列 */
	#item .item-list {
		grid-template-columns: repeat(2, 1fr);
		gap: 1rem;
	}

	/* intro縦並び */
	.item-intro-content {
		flex-direction: column;
		gap: 2rem;
		text-align: center;
	}

	.item-intro-left img {
		max-width: 220px;
		height: auto;
	}

	.item-intro-right p {
		font-size: 1rem;
	}

	#item .item-list li {
		padding: 1rem 0.5rem;
	}

	#item .item-list li div {
		width: 56px;
		height: 56px;
		margin-bottom: 1rem;
	}

	#item .item-list li p {
		font-size: 0.9rem;
		text-align: center;
	}
}


/* ===============================
   小型スマホ（480px以下）
=============================== */
@media screen and (max-width: 480px) {

	h1 {
		font-size: 1.4rem;
		padding: 4rem 4% 2.5rem 4%;
	}

	/* 2列維持だが余白縮小 */
	#item .item-list {
		gap: 0.8rem;
	}

	.item-intro {
		padding: 1.5rem;
	}

	.item-intro-ttl {
		font-size: 1rem;
		padding: 0.4rem 0;
	}

	.item-intro-right p {
		font-size: 0.95rem;
	}

	#item .item-list li div {
		width: 48px;
		height: 48px;
	}

	#item .item-list li p {
		font-size: 0.8rem;
	}
}
