/* =========================================================
   Bloomy 共通フィードバック演出（UX-Phase 1）
   - window.BloomyFeedback（bloomy-feedback.js）と対。
   - トースト（下中央）/ ボタンbusy / カードのフェードイン・ハイライト。
   - 派手にしない・短い・すっと消える。白/淡ブルー/ネイビー基調。
   - prefers-reduced-motion で動きを弱める/無効化。
   - 既存レイアウトに干渉しないよう、独自プレフィックス bloomy-fb-* に隔離。
   ========================================================= */

/* ---- トースト・コンテナ（画面下中央・モバイル親和） ---- */
.bloomy-fb-toasts {
	position: fixed;
	left: 50%;
	bottom: max(18px, env(safe-area-inset-bottom));
	transform: translateX(-50%);
	z-index: 100000;
	display: flex;
	flex-direction: column-reverse; /* 新しいものが下＝視線の近くに */
	align-items: center;
	gap: 8px;
	width: max-content;
	max-width: min(92vw, 420px);
	pointer-events: none; /* 背面操作を邪魔しない。トースト本体だけ auto に戻す */
}

.bloomy-fb-toast {
	pointer-events: auto;
	display: flex;
	align-items: center;
	gap: 10px;
	width: 100%;
	box-sizing: border-box;
	padding: 11px 14px;
	border-radius: 14px;
	background: #ffffff;
	color: #14223f;
	font-size: 13.5px;
	font-weight: 700;
	line-height: 1.5;
	letter-spacing: -0.01em;
	border: 1px solid #e6ecf7;
	box-shadow: 0 8px 24px rgba(20, 40, 90, 0.12), 0 2px 6px rgba(20, 40, 90, 0.06);
	opacity: 0;
	transform: translateY(8px);
	transition: opacity 0.26s ease, transform 0.26s ease;
}

.bloomy-fb-toast.is-in {
	opacity: 1;
	transform: translateY(0);
}

.bloomy-fb-toast.is-out {
	opacity: 0;
	transform: translateY(6px);
}

/* 左の状態アクセント（細いドット）。怖くしすぎない控えめ配色。 */
.bloomy-fb-toast__icon {
	flex: 0 0 auto;
	width: 18px;
	height: 18px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.bloomy-fb-toast__icon svg { width: 18px; height: 18px; display: block; }

.bloomy-fb-toast--success .bloomy-fb-toast__icon { color: #1f9d6b; }
.bloomy-fb-toast--info    .bloomy-fb-toast__icon { color: #2f7ef7; }
.bloomy-fb-toast--warning .bloomy-fb-toast__icon { color: #c8881a; }
.bloomy-fb-toast--error   .bloomy-fb-toast__icon { color: #d2603f; }
.bloomy-fb-toast--loading .bloomy-fb-toast__icon { color: #2f7ef7; }

.bloomy-fb-toast__msg { flex: 1 1 auto; min-width: 0; }

/* ローディング・スピナー（軽量CSS） */
.bloomy-fb-spinner {
	width: 16px;
	height: 16px;
	border-radius: 50%;
	border: 2px solid #cfe0fb;
	border-top-color: #2f7ef7;
	animation: bloomy-fb-spin 0.7s linear infinite;
}

@keyframes bloomy-fb-spin {
	to { transform: rotate(360deg); }
}

/* ---- ボタン busy（多重クリック防止＋スピナー） ---- */
.bloomy-fb-busy {
	position: relative;
	pointer-events: none;
	opacity: 0.85;
}
.bloomy-fb-busy__spinner {
	display: inline-block;
	vertical-align: -3px;
	margin-right: 7px;
	width: 15px;
	height: 15px;
	border-radius: 50%;
	border: 2px solid rgba(255, 255, 255, 0.55);
	border-top-color: #ffffff;
	animation: bloomy-fb-spin 0.7s linear infinite;
}

/* ---- カードの軽いフェードイン（初回のみ） ---- */
.bloomy-fb-fadein {
	animation: bloomy-fb-fadein 0.42s ease both;
}
@keyframes bloomy-fb-fadein {
	from { opacity: 0; transform: translateY(8px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* ---- 状態変化時の一瞬の淡いハイライト ---- */
.bloomy-fb-highlight {
	animation: bloomy-fb-highlight 1.1s ease both;
}
@keyframes bloomy-fb-highlight {
	0%   { box-shadow: 0 0 0 0 rgba(47, 126, 247, 0); }
	22%  { box-shadow: 0 0 0 3px rgba(47, 126, 247, 0.18); }
	100% { box-shadow: 0 0 0 0 rgba(47, 126, 247, 0); }
}

/* ---- アクセシビリティ：動きを抑える ---- */
@media (prefers-reduced-motion: reduce) {
	.bloomy-fb-toast {
		transition: opacity 0.2s ease;
		transform: none;
	}
	.bloomy-fb-toast.is-in { transform: none; }
	.bloomy-fb-toast.is-out { transform: none; }
	.bloomy-fb-spinner,
	.bloomy-fb-busy__spinner { animation-duration: 1.2s; }
	.bloomy-fb-fadein { animation: bloomy-fb-fade-plain 0.3s ease both; }
	.bloomy-fb-highlight { animation: none; }
	@keyframes bloomy-fb-fade-plain {
		from { opacity: 0; }
		to   { opacity: 1; }
	}
}
