/**
 * Coupon Block - Yuge Template CSS
 */

:root {
	--cy-red:    #c8390e;
	--cy-gold:   #b8882a;
	--cy-coral:  #d4603a;
	--cy-dark:   #1a1a1a;
	--cy-gray:   #6b6b6b;
	--cy-gray-l: #f4f2ef;
	--cy-border: #e4e0d8;
	--cy-cream:  #faf8f4;
}

/* ==========================================================================
   グリッド
   ========================================================================== */

.coupon-block--yuge .coupon-yuge-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 12px;
}

.coupon-block--yuge .coupon-yuge-grid--1 { grid-template-columns: 1fr; }
.coupon-block--yuge .coupon-yuge-grid--3 { grid-template-columns: repeat(3, 1fr); }
.coupon-block--yuge .coupon-yuge-grid--4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 900px) {
	.coupon-block--yuge .coupon-yuge-grid--tb-2 { grid-template-columns: repeat(2, 1fr); }
	.coupon-block--yuge .coupon-yuge-grid--tb-1 { grid-template-columns: 1fr; }
}

@media (max-width: 600px) {
	.coupon-block--yuge .coupon-yuge-grid {
		grid-template-columns: 1fr;
	}
	.coupon-block--yuge .coupon-yuge-grid--sp-2 {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* ==========================================================================
   カード
   ========================================================================== */

.coupon-card-yuge {
	background: #fff;
	border: 1px solid var(--cy-border);
	position: relative;
	display: flex;
	flex-direction: column;
	overflow: hidden;
	transition: box-shadow .25s, transform .25s;
}

.coupon-card-yuge:hover {
	box-shadow: 0 8px 32px rgba(0, 0, 0, .08);
	transform: translateY(-3px);
}

/* 左端アクセントライン */
.coupon-card-yuge::before {
	content: '';
	position: absolute;
	top: 0; left: 0; bottom: 0;
	width: 4px;
	background: var(--cy-red);
	z-index: 1;
}

/* 赤（デフォルト） */
.coupon-card-yuge--red::before                        { background: var(--cy-red); }
.coupon-card-yuge--red .coupon-card-yuge__plan        { color: var(--cy-red); }
.coupon-card-yuge--red .coupon-info-yuge__item::before { background: var(--cy-red); }

/* ゴールド */
.coupon-card-yuge--gold::before                        { background: var(--cy-gold); }
.coupon-card-yuge--gold .coupon-card-yuge__plan        { color: var(--cy-gold); }
.coupon-card-yuge--gold .coupon-info-yuge__item::before { background: var(--cy-gold); }
.coupon-card-yuge--gold .coupon-expire-yuge__label     { color: var(--cy-gold); }

/* 緑 */
.coupon-card-yuge--green::before                        { background: #2d7a4f; }
.coupon-card-yuge--green .coupon-card-yuge__plan        { color: #2d7a4f; }
.coupon-card-yuge--green .coupon-info-yuge__item::before { background: #2d7a4f; }

/* コーラル（サプライズ用） */
.coupon-card-yuge--coral::before                        { background: var(--cy-coral); }
.coupon-card-yuge--coral .coupon-card-yuge__plan        { color: var(--cy-coral); }
.coupon-card-yuge--coral .coupon-info-yuge__item::before { background: var(--cy-coral); }

/* 紫 */
.coupon-card-yuge--purple::before                        { background: #6b4c8a; }
.coupon-card-yuge--purple .coupon-card-yuge__plan        { color: #6b4c8a; }
.coupon-card-yuge--purple .coupon-info-yuge__item::before { background: #6b4c8a; }

/* ==========================================================================
   写真エリア
   ========================================================================== */

.coupon-card-yuge__photo {
	position: relative;
	width: 100%;
	overflow: hidden;
	background: var(--cy-gray-l);
	flex-shrink: 0;
}

.coupon-card-yuge__photo img {
	width: 100%; height: 100%;
	object-fit: cover;
	display: block;
	transition: transform .4s ease;
}

.coupon-card-yuge:hover .coupon-card-yuge__photo img {
	transform: scale(1.04);
}

/* プレースホルダー */
.coupon-card-yuge__photo--ph {
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 11px;
	letter-spacing: .16em;
	color: #ccc;
}

/* ==========================================================================
   コンテンツ
   ========================================================================== */

.coupon-card-yuge__content {
	flex: 1;
	display: flex;
	flex-direction: column;
}

.coupon-card-yuge__head {
	padding: 22px 24px 18px 28px;
	border-bottom: 1px dashed var(--cy-border);
}

.coupon-card-yuge__plan {
	font-size: 8px;
	letter-spacing: .38em;
	color: var(--cy-red);
	font-weight: 700;
	display: block;
	margin-bottom: 8px;
}

.coupon-card-yuge__title {
	font-size: clamp(13px, 1.4vw, 14px);
	font-weight: 600;
	line-height: 1.8;
	letter-spacing: .08em;
	color: var(--cy-dark);
}

/* ==========================================================================
   ボディ（条件・期限）
   ========================================================================== */

.coupon-card-yuge__body {
	padding: 16px 24px 20px 28px;
	background: var(--cy-gray-l);
	display: flex;
	flex-direction: column;
	gap: 12px;
	flex: 1;
}

/* 利用条件 */
.coupon-info-yuge__label,
.coupon-expire-yuge__label {
	font-size: 8px;
	letter-spacing: .36em;
	color: var(--cy-gray);
	font-weight: 700;
	display: block;
	margin-bottom: 7px;
}

.coupon-info-yuge__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 5px;
}

.coupon-info-yuge__item {
	display: flex;
	gap: 8px;
	align-items: flex-start;
	font-size: 12px;
	line-height: 1.7;
	color: var(--cy-gray);
	letter-spacing: .04em;
}

.coupon-info-yuge__item::before {
	content: '';
	display: block;
	flex-shrink: 0;
	width: 3px;
	height: 3px;
	border-radius: 50%;
	background: var(--cy-red);
	margin-top: 8px;
}

/* 有効期限 */
.coupon-expire-yuge {
	padding-top: 12px;
	border-top: 1px solid var(--cy-border);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
	margin-top: auto;
}

.coupon-expire-yuge__label {
	margin-bottom: 0;
	flex-shrink: 0;
}

.coupon-expire-yuge__date {
	font-size: 12px;
	letter-spacing: .06em;
	color: var(--cy-dark);
	text-align: right;
}

/* ==========================================================================
   空メッセージ
   ========================================================================== */

.coupon-block--yuge .coupon-block__empty {
	text-align: center;
	color: #999;
	padding: 40px 0;
}
