@import url("https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css");

/* アラートボックスの基本スタイル */
.vk_alert {
	display: flex;
	align-items: center; /* 垂直中央揃え */
	padding: 1.25rem;
	gap: 0.75rem;
	margin: 1em auto;
	border-radius: 3px;
	border: 1px solid transparent;
}

.vk_alert_icon {
	display: flex;
	flex-direction: column;
	justify-content: center; /* 縦方向の中央揃え */
	align-items: center;     /* 横方向の中央揃え */
	height: 100%;            /* 高さを親に合わせる */
	width: 75px;
	gap: 0.375rem;
	line-height: 1;
	flex-shrink: 0; /* アイコンが潰れないように */
}

.vk_alert_icon_icon {
	display: flex;           /* Flexboxにする */
	align-items: center;     /* 垂直中央 */
	justify-content: center; /* 水平中央 */
	line-height: 1;          /* 行送りを詰める */
}

.vk_alert_icon_icon i {
	font-size: 24px;
	display: block;          /* ブロック要素にして隙間を消す */
}

.vk_alert_icon_text {
	display: flex;
	align-items: center;
	justify-content: center;
}

.vk_alert_icon_text span {
	font-size: 12px;
	font-weight: bold;
	text-align: center;
	line-height: 1.2;
}

.vk_alert_content {
	flex: 1;
	padding-left: 0.75rem;
	border-left: 1.5px solid currentColor;
	min-width: 0; /* flexboxでテキストがはみ出さないように */
}

.vk_alert_content p {
	margin: 0 0 0.5em 0;
}

.vk_alert_content p:last-child {
	margin-bottom: 0;
}

.vk_alert_content > *:first-child {
	margin-top: 0;
}

.vk_alert_content > *:last-child {
	margin-bottom: 0;
}

/* 各カラーバリエーション */
.alert-info {
	background-color: #d9edf7;
	color: #31708f;
	border-color: #bce8f1;
}

.alert-success {
	background-color: #dff0d8;
	color: #3c763d;
	border-color: #d6e9c6;
}

.alert-warning {
	background-color: #fcf8e3;
	color: #8a6d3b;
	border-color: #faebcc;
}

.alert-danger {
	background-color: #f2dede;
	color: #a94442;
	border-color: #ebccd1;
}

/* モバイル対応 */
@media (max-width: 575px) {
	.vk_alert {
		flex-wrap: wrap;
	}
	
	.vk_alert_icon {
		width: 100%;
		flex-direction: row;
		justify-content: flex-start;
		gap: 10px;
		margin-bottom: 10px;
	}
	
	.vk_alert_icon_text {
		justify-content: flex-start;
	}
	
	.vk_alert_content {
		padding-left: 0;
		border-left: none;
		border-top: 1.5px solid currentColor;
		padding-top: 0.75rem;
		width: 100%;
	}
}

/* Dark mode support (オプション) */
body.dark-mode .alert-info {
	background-color: #1a3a4a;
	color: #a8d5e2;
	border-color: #2a5a6a;
}

body.dark-mode .alert-success {
	background-color: #1a3a1a;
	color: #a8e2a8;
	border-color: #2a5a2a;
}

body.dark-mode .alert-warning {
	background-color: #4a3a1a;
	color: #e2d5a8;
	border-color: #6a5a2a;
}

body.dark-mode .alert-danger {
	background-color: #4a1a1a;
	color: #e2a8a8;
	border-color: #6a2a2a;
}

