/* =========================================================
   Countdown Timer – フロントエンドスタイル
   ========================================================= */

/* CSS カスタムプロパティはショートコード側の style 属性で注入 */

.cdt-wrapper {
	display: inline-block;
	font-family: 'Helvetica Neue', Arial, sans-serif;
	text-align: center;
	padding: 1.5rem 1rem;
	width: 100%;
	box-sizing: border-box;
}

/* タイトル */
.cdt-title {
	margin: 0 0 1rem;
	font-size: 1.1rem;
	font-weight: 600;
	color: #333;
	letter-spacing: .04em;
}

/* タイマー表示行 */
.cdt-display {
	display: flex;
	align-items: flex-start;
	justify-content: center;
	gap: .25rem;
	flex-wrap: wrap;
}

/* 各ブロック（数字＋ラベル） */
.cdt-block {
	display: flex;
	flex-direction: column;
	align-items: center;
}

/* 数字バッジ */
.cdt-number {
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: var(--cdt-bg, #FF4B33);
	color:            var(--cdt-text, #FFFFFF);
	border-radius: 8px;
	font-size: clamp(2rem, 5vw, 3.5rem);
	font-weight: 800;
	line-height: 1;
	min-width: 2.5ch;
	padding: .35em .55em;
	letter-spacing: -.02em;
	transition: transform .12s ease;
	box-shadow: 0 4px 12px rgba(0,0,0,.15);
}

/* 数字が変わるときの微アニメーション */
.cdt-number.cdt-tick {
	animation: cdtTick .2s ease;
}

@keyframes cdtTick {
	0%   { transform: scaleY(.85); opacity: .7; }
	50%  { transform: scaleY(1.05); }
	100% { transform: scaleY(1);   opacity: 1; }
}

/* ラベル（日・時間・分・秒） */
.cdt-label {
	margin-top: .45rem;
	font-size: clamp(.65rem, 1.8vw, .85rem);
	color: var(--cdt-label, #FF4B33);
	font-weight: 500;
	letter-spacing: .06em;
}

/* セパレーター「:」 */
.cdt-separator {
	color: var(--cdt-bg, #FF4B33);
	font-size: clamp(1.8rem, 4.5vw, 3rem);
	font-weight: 800;
	line-height: 1;
	padding: .2em .1em 0;
	align-self: flex-start;
}

/* 終了メッセージ */
.cdt-expired {
	font-size: 1rem;
	color: #666;
	margin-top: 1rem;
}

/* エラーメッセージ */
.cdt-error {
	color: #c62828;
	font-size: .9rem;
	border-left: 3px solid #c62828;
	padding-left: .75rem;
}

/* ===== レスポンシブ ===== */
@media (max-width: 480px) {
	.cdt-display {
		gap: .15rem;
	}

	.cdt-number {
		padding: .3em .4em;
	}
}
