:root {
	--bg-color: #0d1b2a;
	--card-front: #1b263b;
	--card-front-text: #ffffff;
	--card-back: #ffffff;
	--card-radius: 12px;
	--card-shadow: 0 8px 16px rgba(0, 0, 0, 0.25);
	--gap: 12px; /* 간격을 살짝 줄여 공간 확보 */
}

* {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

body {
	font-family: "Segoe UI", sans-serif;
	/* iframe 내 스크롤 방지를 위해 min-height 대신 height 조정 */
	height: 100vh;
	background: radial-gradient(circle at top, #1b263b, #000814);
	display: flex;
	flex-direction: column; /* 헤더와 그리드를 수직 배치 */
	align-items: center;
	justify-content: flex-start; /* 상단부터 배치 */
	color: #e0e6f0;
	overflow: hidden; /* 바디 스크롤 완전 차단 */
	padding: 10px;
}

.game-wrapper {
	width: 100%;
	max-width: 800px; /* 너무 넓어지지 않게 조정 */
	height: 100%;
	display: flex;
	flex-direction: column;
}

.game-header {
	text-align: center;
	margin-bottom: 15px;
	flex-shrink: 0; /* 헤더 크기 고정 */
}

.game-title {
	font-size: 1.4rem;
	font-weight: 700;
	margin-bottom: 4px;
}

.game-subtitle {
	font-size: 0.85rem;
	opacity: 0.8;
}

/* 🏁 핵심 수정: 그리드 반응형 최적화 */
.card-grid {
	display: grid;
	/* 화면 너비에 따라 카드가 3~5줄로 유연하게 변함 */
	grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
	gap: var(--gap);
	overflow-y: auto; /* 카드 양이 많을 경우 내부에서만 스크롤 */
	padding-bottom: 20px;
	scrollbar-width: none; /* 파이어폭스 스크롤바 숨김 */
}

.card-grid::-webkit-scrollbar {
	display: none; /* 크롬/사파리 스크롤바 숨김 */
}

.card {
	position: relative;
	display: block;
	cursor: pointer;
	perspective: 1000px;
	width: 100%;
}

.card input[type="checkbox"] {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.card-inner {
	position: relative;
	width: 100%;
	aspect-ratio: 3 / 4;
	transform-style: preserve-3d;
	transition: transform 0.6s ease;
	box-shadow: var(--card-shadow);
	border-radius: var(--card-radius);
}

.card input[type="checkbox"]:checked + .card-inner {
	transform: rotateY(180deg);
}

.card-face {
	position: absolute;
	inset: 0;
	border-radius: var(--card-radius);
	backface-visibility: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
}

.card-front {
	background: linear-gradient(135deg, #1b263b, #243b58);
	color: var(--card-front-text);
	font-size: 1.4rem;
	font-weight: 700;
	border: 1px solid rgba(255, 255, 255, 0.1);
}

.card-back {
	background: var(--card-back);
	transform: rotateY(180deg);
	overflow: hidden;
}

.card-image-slot {
	width: 100%;
	height: 100%;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}

/* 조커 효과 */
.card.joker-found .card-inner {
	transform: rotateY(180deg);
	outline: 3px solid #ffcc00;
	box-shadow: 0 0 20px rgba(255, 204, 0, 0.6);
}

/* 이미지 클래스들 */
.img01 {
	background-image: url("../images/card/apple.png");
}
.img02 {
	background-image: url("../images/card/gam.png");
}
.img03 {
	background-image: url("../images/card/kiwi.png");
}
.img04 {
	background-image: url("../images/card/orange.png");
}
.img05 {
	background-image: url("../images/card/pair.png");
}
.img06 {
	background-image: url("../images/card/peach.png");
}
.img07 {
	background-image: url("../images/card/watermelon.png");
}
.img00 {
	background-image: url("../images/card/joker.png");
}

/* 모바일 대응: 카드가 너무 작아지지 않게 조정 */
@media (max-width: 480px) {
	.card-grid {
		grid-template-columns: repeat(3, 1fr);
		gap: 8px;
	}
	.game-title {
		font-size: 1.2rem;
	}
}
