/**
 * Spend Billionaire Money Game - Stylesheet
 * Modern Fintech + Gaming UI Design
 *
 * @package SpendBillionaireMoneyGame
 * @version 1.0.0
 */

/* =============================================
   1. CSS CUSTOM PROPERTIES
   ============================================= */
.sbmg-app {
	--sbmg-primary: #00d4ff;
	--sbmg-accent: #ff6b35;
	--sbmg-gold: #ffd700;
	--sbmg-green: #00e676;
	--sbmg-red: #ff1744;

	--sbmg-bg: #0a0e1a;
	--sbmg-bg2: #111827;
	--sbmg-bg3: #1a2236;
	--sbmg-card-bg: rgba(255, 255, 255, 0.04);
	--sbmg-card-border: rgba(255, 255, 255, 0.08);
	--sbmg-card-hover-bg: rgba(0, 212, 255, 0.06);
	--sbmg-card-hover-border: rgba(0, 212, 255, 0.3);

	--sbmg-text: #f0f4ff;
	--sbmg-text-secondary: #8892aa;
	--sbmg-text-muted: #4a5568;

	--sbmg-bar-bg: rgba(10, 14, 26, 0.95);
	--sbmg-bar-border: rgba(0, 212, 255, 0.15);

	--sbmg-radius: 16px;
	--sbmg-radius-sm: 10px;
	--sbmg-radius-lg: 24px;

	--sbmg-shadow: 0 4px 24px rgba(0, 0, 0, 0.4);
	--sbmg-glow: 0 0 30px rgba(0, 212, 255, 0.2);

	--sbmg-font-display: 'Segoe UI', system-ui, -apple-system, sans-serif;
	--sbmg-font-body: 'Segoe UI', system-ui, -apple-system, sans-serif;

	--sbmg-transition: 0.25s cubic-bezier(0.4, 0, 0.2, 1);
	--sbmg-transition-fast: 0.15s ease;
	--sbmg-transition-bounce: 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* Light Mode */
.sbmg-app.sbmg-light {
	--sbmg-bg: #f0f4ff;
	--sbmg-bg2: #e8edf8;
	--sbmg-bg3: #dde4f5;
	--sbmg-card-bg: rgba(255, 255, 255, 0.8);
	--sbmg-card-border: rgba(0, 0, 0, 0.08);
	--sbmg-card-hover-bg: rgba(0, 212, 255, 0.08);
	--sbmg-card-hover-border: rgba(0, 212, 255, 0.4);
	--sbmg-text: #0a0e1a;
	--sbmg-text-secondary: #374151;
	--sbmg-text-muted: #9ca3af;
	--sbmg-bar-bg: rgba(255, 255, 255, 0.95);
	--sbmg-bar-border: rgba(0, 212, 255, 0.2);
	--sbmg-shadow: 0 4px 24px rgba(0, 0, 0, 0.12);
}

/* =============================================
   2. BASE RESET & CONTAINER
   ============================================= */
.sbmg-app *,
.sbmg-app *::before,
.sbmg-app *::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

.sbmg-app {
	font-family: var(--sbmg-font-body);
	background: var(--sbmg-bg);
	color: var(--sbmg-text);
	min-height: 100vh;
	position: relative;
	overflow-x: hidden;
	transition: background var(--sbmg-transition), color var(--sbmg-transition);
}

/* Animated background mesh */
.sbmg-app::before {
	content: '';
	position: fixed;
	inset: 0;
	background:
		radial-gradient(ellipse 80% 50% at 20% -10%, rgba(0, 212, 255, 0.08) 0%, transparent 60%),
		radial-gradient(ellipse 60% 40% at 80% 110%, rgba(255, 107, 53, 0.06) 0%, transparent 60%);
	pointer-events: none;
	z-index: 0;
}

.sbmg-app > * {
	position: relative;
	z-index: 1;
}

/* =============================================
   3. STICKY BALANCE BAR
   ============================================= */
.sbmg-balance-bar {
	position: sticky;
	top: 0;
	z-index: 100;
	background: var(--sbmg-bar-bg);
	border-bottom: 1px solid var(--sbmg-bar-border);
	backdrop-filter: blur(20px) saturate(1.5);
	-webkit-backdrop-filter: blur(20px) saturate(1.5);
	padding: 12px 20px;
	transition: background var(--sbmg-transition);
}

.sbmg-balance-inner {
	max-width: 1400px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	gap: 20px;
}

.sbmg-avatar-zone {
	display: flex;
	align-items: center;
	gap: 12px;
	min-width: 160px;
}

.sbmg-avatar {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--sbmg-primary), var(--sbmg-accent));
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 22px;
	flex-shrink: 0;
	box-shadow: 0 0 0 3px rgba(0, 212, 255, 0.2);
	overflow: hidden;
}

.sbmg-avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.sbmg-name-tag {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.sbmg-label {
	font-size: 10px;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--sbmg-text-secondary);
	font-weight: 600;
}

.sbmg-bname {
	font-size: 14px;
	font-weight: 700;
	color: var(--sbmg-text);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	max-width: 140px;
}

.sbmg-balance-center {
	flex: 1;
	text-align: center;
}

.sbmg-balance-label {
	font-size: 10px;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--sbmg-text-secondary);
	font-weight: 600;
	margin-bottom: 4px;
}

.sbmg-balance-display {
	font-size: clamp(22px, 4vw, 36px);
	font-weight: 800;
	background: linear-gradient(135deg, var(--sbmg-primary), #7b2fff);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	line-height: 1;
	margin-bottom: 8px;
	transition: transform 0.2s var(--sbmg-transition-bounce);
	letter-spacing: -0.02em;
}

.sbmg-balance-display.sbmg-pulse {
	transform: scale(1.05);
}

.sbmg-progress-track {
	height: 4px;
	background: rgba(255, 255, 255, 0.08);
	border-radius: 2px;
	overflow: hidden;
	max-width: 400px;
	margin: 0 auto;
}

.sbmg-progress-fill {
	height: 100%;
	width: 0%;
	background: linear-gradient(90deg, var(--sbmg-primary), var(--sbmg-accent));
	border-radius: 2px;
	transition: width 0.6s cubic-bezier(0.4, 0, 0.2, 1);
	box-shadow: 0 0 8px var(--sbmg-primary);
}

.sbmg-bar-controls {
	display: flex;
	gap: 8px;
	align-items: center;
	min-width: 120px;
	justify-content: flex-end;
}

.sbmg-icon-btn {
	width: 38px;
	height: 38px;
	border-radius: 10px;
	border: 1px solid var(--sbmg-card-border);
	background: var(--sbmg-card-bg);
	color: var(--sbmg-text);
	font-size: 16px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all var(--sbmg-transition);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}

.sbmg-icon-btn:hover {
	background: var(--sbmg-card-hover-bg);
	border-color: var(--sbmg-primary);
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0, 212, 255, 0.2);
}

.sbmg-icon-btn:active {
	transform: translateY(0) scale(0.95);
}

.sbmg-icon-btn.sbmg-reset:hover {
	border-color: var(--sbmg-accent);
	box-shadow: 0 4px 12px rgba(255, 107, 53, 0.2);
}

/* =============================================
   4. STATS BAR
   ============================================= */
.sbmg-stats-bar {
	max-width: 1400px;
	margin: 24px auto 0;
	padding: 0 20px;
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
}

.sbmg-stat-pill {
	flex: 1;
	min-width: 160px;
	background: var(--sbmg-card-bg);
	border: 1px solid var(--sbmg-card-border);
	border-radius: var(--sbmg-radius);
	padding: 16px 20px;
	display: flex;
	align-items: center;
	gap: 14px;
	transition: all var(--sbmg-transition);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}

.sbmg-stat-pill:hover {
	border-color: var(--sbmg-primary);
	box-shadow: var(--sbmg-glow);
	transform: translateY(-2px);
}

.sbmg-stat-icon {
	font-size: 28px;
	line-height: 1;
}

.sbmg-stat-value {
	font-size: 18px;
	font-weight: 800;
	color: var(--sbmg-text);
	letter-spacing: -0.02em;
	transition: all var(--sbmg-transition);
}

.sbmg-stat-label {
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--sbmg-text-secondary);
	font-weight: 600;
}

/* =============================================
   5. CATEGORY FILTER BAR
   ============================================= */
.sbmg-category-bar {
	max-width: 1400px;
	margin: 24px auto 0;
	padding: 0 20px;
	display: flex;
	gap: 8px;
	overflow-x: auto;
	scrollbar-width: none;
	-ms-overflow-style: none;
	flex-wrap: nowrap;
}

.sbmg-category-bar::-webkit-scrollbar {
	display: none;
}

.sbmg-cat-btn {
	flex-shrink: 0;
	padding: 8px 16px;
	border-radius: 50px;
	border: 1px solid var(--sbmg-card-border);
	background: var(--sbmg-card-bg);
	color: var(--sbmg-text-secondary);
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	transition: all var(--sbmg-transition);
	white-space: nowrap;
	font-family: var(--sbmg-font-body);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}

.sbmg-cat-btn:hover {
	color: var(--sbmg-text);
	border-color: rgba(0, 212, 255, 0.4);
	background: rgba(0, 212, 255, 0.06);
}

.sbmg-cat-btn.active {
	background: linear-gradient(135deg, var(--sbmg-primary), #7b2fff);
	border-color: transparent;
	color: #fff;
	box-shadow: 0 4px 16px rgba(0, 212, 255, 0.35);
}

/* =============================================
   6. PRODUCT GRID
   ============================================= */
.sbmg-grid {
	max-width: 1400px;
	margin: 24px auto;
	padding: 0 20px;
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 16px;
}

/* Product Card */
.sbmg-card {
	background: var(--sbmg-card-bg);
	border: 1px solid var(--sbmg-card-border);
	border-radius: var(--sbmg-radius-lg);
	padding: 20px;
	display: flex;
	flex-direction: column;
	gap: 14px;
	transition: all var(--sbmg-transition);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	position: relative;
	overflow: hidden;
	cursor: default;
	animation: sbmg-card-in 0.4s both;
}

@keyframes sbmg-card-in {
	from {
		opacity: 0;
		transform: translateY(16px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.sbmg-card::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(0, 212, 255, 0.03), transparent);
	opacity: 0;
	transition: opacity var(--sbmg-transition);
	pointer-events: none;
}

.sbmg-card:hover {
	border-color: var(--sbmg-card-hover-border);
	background: var(--sbmg-card-hover-bg);
	transform: translateY(-4px);
	box-shadow: var(--sbmg-shadow), 0 0 0 1px rgba(0, 212, 255, 0.1);
}

.sbmg-card:hover::before {
	opacity: 1;
}

.sbmg-card.sbmg-card-owned {
	border-color: rgba(0, 230, 118, 0.25);
}

.sbmg-card.sbmg-card-owned::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 2px;
	background: linear-gradient(90deg, transparent, var(--sbmg-green), transparent);
	animation: sbmg-shimmer 2s infinite;
}

@keyframes sbmg-shimmer {
	0% { background-position: -200% center; }
	100% { background-position: 200% center; }
}

.sbmg-card.sbmg-card-unaffordable {
	opacity: 0.45;
}

/* Card header */
.sbmg-card-header {
	display: flex;
	align-items: flex-start;
	gap: 12px;
}

.sbmg-card-emoji {
	width: 52px;
	height: 52px;
	border-radius: 14px;
	background: linear-gradient(135deg, rgba(0, 212, 255, 0.12), rgba(123, 47, 255, 0.12));
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 28px;
	flex-shrink: 0;
	transition: transform var(--sbmg-transition-bounce);
}

.sbmg-card:hover .sbmg-card-emoji {
	transform: scale(1.12) rotate(-3deg);
}

.sbmg-card-info {
	flex: 1;
	min-width: 0;
}

.sbmg-card-name {
	font-size: 15px;
	font-weight: 700;
	color: var(--sbmg-text);
	margin-bottom: 4px;
	line-height: 1.3;
}

.sbmg-card-cat {
	font-size: 10px;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--sbmg-primary);
	font-weight: 700;
}

.sbmg-card-price {
	font-size: 18px;
	font-weight: 800;
	color: var(--sbmg-gold);
	letter-spacing: -0.02em;
}

/* Card actions */
.sbmg-card-actions {
	display: flex;
	align-items: center;
	gap: 10px;
}

.sbmg-btn-buy,
.sbmg-btn-sell {
	height: 36px;
	border-radius: var(--sbmg-radius-sm);
	border: none;
	font-size: 13px;
	font-weight: 700;
	cursor: pointer;
	transition: all var(--sbmg-transition-bounce);
	font-family: var(--sbmg-font-body);
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 5px;
}

.sbmg-btn-buy {
	flex: 1;
	background: linear-gradient(135deg, var(--sbmg-primary), #7b2fff);
	color: #fff;
	box-shadow: 0 4px 14px rgba(0, 212, 255, 0.35);
}

.sbmg-btn-buy:hover:not(:disabled) {
	transform: scale(1.04);
	box-shadow: 0 6px 20px rgba(0, 212, 255, 0.5);
}

.sbmg-btn-buy:active:not(:disabled) {
	transform: scale(0.96);
}

.sbmg-btn-buy:disabled {
	background: rgba(255, 255, 255, 0.08);
	color: var(--sbmg-text-muted);
	cursor: not-allowed;
	box-shadow: none;
}

.sbmg-btn-sell {
	width: 36px;
	background: rgba(255, 23, 68, 0.12);
	color: var(--sbmg-red);
	border: 1px solid rgba(255, 23, 68, 0.2);
}

.sbmg-btn-sell:hover:not(:disabled) {
	background: rgba(255, 23, 68, 0.22);
	transform: scale(1.08);
}

.sbmg-btn-sell:disabled {
	opacity: 0.3;
	cursor: not-allowed;
}

.sbmg-qty-badge {
	width: 36px;
	height: 36px;
	border-radius: var(--sbmg-radius-sm);
	background: rgba(0, 230, 118, 0.1);
	border: 1px solid rgba(0, 230, 118, 0.2);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 14px;
	font-weight: 800;
	color: var(--sbmg-green);
	transition: all var(--sbmg-transition-bounce);
}

.sbmg-qty-badge.sbmg-qty-bump {
	transform: scale(1.3);
	background: rgba(0, 230, 118, 0.25);
}

/* =============================================
   7. ACHIEVEMENTS
   ============================================= */
.sbmg-achievements {
	max-width: 1400px;
	margin: 0 auto 40px;
	padding: 0 20px;
}

.sbmg-section-title {
	font-size: 22px;
	font-weight: 800;
	color: var(--sbmg-text);
	margin-bottom: 16px;
	letter-spacing: -0.02em;
}

.sbmg-badges-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

.sbmg-badge {
	background: var(--sbmg-card-bg);
	border: 1px solid var(--sbmg-card-border);
	border-radius: var(--sbmg-radius);
	padding: 12px 16px;
	display: flex;
	align-items: center;
	gap: 10px;
	transition: all var(--sbmg-transition);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}

.sbmg-badge.sbmg-badge-earned {
	border-color: rgba(255, 215, 0, 0.4);
	background: rgba(255, 215, 0, 0.06);
	animation: sbmg-badge-pop 0.5s var(--sbmg-transition-bounce);
}

@keyframes sbmg-badge-pop {
	0% { transform: scale(0.8); opacity: 0; }
	60% { transform: scale(1.1); }
	100% { transform: scale(1); opacity: 1; }
}

.sbmg-badge-icon {
	font-size: 28px;
}

.sbmg-badge-locked .sbmg-badge-icon {
	filter: grayscale(1) opacity(0.4);
}

.sbmg-badge-info {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.sbmg-badge-name {
	font-size: 13px;
	font-weight: 700;
	color: var(--sbmg-text);
}

.sbmg-badge-locked .sbmg-badge-name {
	color: var(--sbmg-text-muted);
}

.sbmg-badge-desc {
	font-size: 11px;
	color: var(--sbmg-text-secondary);
}

/* =============================================
   8. NOTIFICATIONS
   ============================================= */
.sbmg-notifications {
	position: fixed;
	top: 90px;
	right: 20px;
	z-index: 9999;
	display: flex;
	flex-direction: column;
	gap: 10px;
	pointer-events: none;
	max-width: 320px;
}

.sbmg-notification {
	background: var(--sbmg-bg2);
	border: 1px solid var(--sbmg-card-border);
	border-left: 3px solid var(--sbmg-primary);
	border-radius: var(--sbmg-radius-sm);
	padding: 12px 16px;
	font-size: 13px;
	font-weight: 600;
	color: var(--sbmg-text);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	box-shadow: var(--sbmg-shadow);
	animation: sbmg-notif-in 0.35s cubic-bezier(0.34, 1.56, 0.64, 1) both;
	display: flex;
	align-items: center;
	gap: 8px;
}

.sbmg-notification.sbmg-notif-out {
	animation: sbmg-notif-out 0.3s ease forwards;
}

.sbmg-notification.sbmg-notif-buy {
	border-left-color: var(--sbmg-green);
}

.sbmg-notification.sbmg-notif-sell {
	border-left-color: var(--sbmg-red);
}

.sbmg-notification.sbmg-notif-achievement {
	border-left-color: var(--sbmg-gold);
}

@keyframes sbmg-notif-in {
	from { opacity: 0; transform: translateX(100%) scale(0.9); }
	to { opacity: 1; transform: translateX(0) scale(1); }
}

@keyframes sbmg-notif-out {
	from { opacity: 1; transform: translateX(0); max-height: 80px; }
	to { opacity: 0; transform: translateX(100%); max-height: 0; padding: 0; margin: 0; }
}

/* =============================================
   9. CONFETTI CANVAS
   ============================================= */
.sbmg-confetti-canvas {
	position: fixed;
	inset: 0;
	pointer-events: none;
	z-index: 9998;
	width: 100%;
	height: 100%;
}

/* =============================================
   10. MONEY RAIN
   ============================================= */
.sbmg-money-rain {
	position: fixed;
	inset: 0;
	pointer-events: none;
	z-index: 9997;
	overflow: hidden;
}

.sbmg-money-drop {
	position: absolute;
	top: -60px;
	font-size: 24px;
	animation: sbmg-rain-fall linear forwards;
	pointer-events: none;
	user-select: none;
}

@keyframes sbmg-rain-fall {
	0% {
		opacity: 1;
		transform: translateY(0) rotate(0deg);
	}
	100% {
		opacity: 0;
		transform: translateY(110vh) rotate(720deg);
	}
}

/* =============================================
   11. FLOATING PURCHASE EFFECT
   ============================================= */
.sbmg-float-effect {
	position: fixed;
	pointer-events: none;
	z-index: 9996;
	font-size: 16px;
	font-weight: 800;
	color: var(--sbmg-red);
	animation: sbmg-float-up 1.2s ease forwards;
	white-space: nowrap;
	text-shadow: 0 2px 8px rgba(0, 0, 0, 0.5);
}

.sbmg-float-effect.sbmg-float-buy {
	color: var(--sbmg-red);
}

.sbmg-float-effect.sbmg-float-sell {
	color: var(--sbmg-green);
}

@keyframes sbmg-float-up {
	0% { opacity: 1; transform: translateY(0) scale(1); }
	40% { opacity: 1; transform: translateY(-40px) scale(1.15); }
	100% { opacity: 0; transform: translateY(-100px) scale(0.8); }
}

/* =============================================
   12. RESPONSIVE DESIGN
   ============================================= */
@media (max-width: 1024px) {
	.sbmg-grid {
		grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	}
}

@media (max-width: 768px) {
	.sbmg-balance-bar {
		padding: 10px 14px;
	}

	.sbmg-balance-inner {
		gap: 10px;
	}

	.sbmg-avatar-zone {
		min-width: auto;
	}

	.sbmg-name-tag {
		display: none;
	}

	.sbmg-balance-display {
		font-size: 22px;
	}

	.sbmg-stats-bar {
		gap: 10px;
		padding: 0 14px;
	}

	.sbmg-stat-pill {
		min-width: 140px;
		padding: 12px 14px;
	}

	.sbmg-stat-value {
		font-size: 15px;
	}

	.sbmg-category-bar {
		padding: 0 14px;
	}

	.sbmg-grid {
		grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
		padding: 0 14px;
		gap: 12px;
	}

	.sbmg-card {
		padding: 14px;
		gap: 10px;
	}

	.sbmg-card-emoji {
		width: 44px;
		height: 44px;
		font-size: 24px;
	}

	.sbmg-card-price {
		font-size: 15px;
	}

	.sbmg-btn-buy {
		font-size: 12px;
		height: 34px;
	}

	.sbmg-notifications {
		top: auto;
		bottom: 20px;
		right: 10px;
		left: 10px;
		max-width: none;
	}

	.sbmg-achievements {
		padding: 0 14px;
	}
}

@media (max-width: 480px) {
	.sbmg-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.sbmg-stats-bar {
		display: grid;
		grid-template-columns: 1fr 1fr;
	}

	.sbmg-stat-pill {
		min-width: 0;
	}

	.sbmg-bar-controls .sbmg-icon-btn:last-child {
		display: none;
	}
}

/* =============================================
   13. SMOOTH SCROLL
   ============================================= */
.sbmg-app {
	scroll-behavior: smooth;
}

/* =============================================
   14. ACCESSIBILITY
   ============================================= */
.sbmg-btn-buy:focus-visible,
.sbmg-btn-sell:focus-visible,
.sbmg-icon-btn:focus-visible,
.sbmg-cat-btn:focus-visible {
	outline: 2px solid var(--sbmg-primary);
	outline-offset: 2px;
}

/* =============================================
   15. UTILITY CLASSES
   ============================================= */
.sbmg-hidden {
	display: none !important;
}

.sbmg-sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* =============================================
   16. EMPTY STATE
   ============================================= */
.sbmg-empty {
	grid-column: 1 / -1;
	text-align: center;
	padding: 60px 20px;
	color: var(--sbmg-text-secondary);
}

.sbmg-empty-icon {
	font-size: 56px;
	margin-bottom: 16px;
	display: block;
}

/* =============================================
   17. LOADING SKELETON
   ============================================= */
.sbmg-skeleton {
	background: linear-gradient(90deg, var(--sbmg-card-bg) 25%, rgba(255,255,255,0.06) 50%, var(--sbmg-card-bg) 75%);
	background-size: 200% 100%;
	animation: sbmg-skeleton-anim 1.5s ease infinite;
	border-radius: var(--sbmg-radius-sm);
}

@keyframes sbmg-skeleton-anim {
	0% { background-position: 200% 0; }
	100% { background-position: -200% 0; }
}

/* =============================================
   18. RESET CONFIRM DIALOG
   ============================================= */
.sbmg-dialog-overlay {
	position: fixed;
	inset: 0;
	background: rgba(0,0,0,0.6);
	z-index: 10000;
	display: flex;
	align-items: center;
	justify-content: center;
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	animation: sbmg-fade-in 0.2s ease;
}

@keyframes sbmg-fade-in {
	from { opacity: 0; }
	to { opacity: 1; }
}

.sbmg-dialog {
	background: var(--sbmg-bg2);
	border: 1px solid var(--sbmg-card-border);
	border-radius: var(--sbmg-radius-lg);
	padding: 32px;
	max-width: 400px;
	width: 90%;
	text-align: center;
	animation: sbmg-dialog-in 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

@keyframes sbmg-dialog-in {
	from { opacity: 0; transform: scale(0.85); }
	to { opacity: 1; transform: scale(1); }
}

.sbmg-dialog h3 {
	font-size: 22px;
	font-weight: 800;
	margin-bottom: 10px;
}

.sbmg-dialog p {
	color: var(--sbmg-text-secondary);
	margin-bottom: 24px;
	font-size: 14px;
}

.sbmg-dialog-btns {
	display: flex;
	gap: 12px;
	justify-content: center;
}

.sbmg-dialog-btns button {
	padding: 10px 24px;
	border-radius: var(--sbmg-radius-sm);
	border: none;
	font-size: 14px;
	font-weight: 700;
	cursor: pointer;
	font-family: var(--sbmg-font-body);
	transition: all var(--sbmg-transition);
}

.sbmg-dialog-btns .sbmg-confirm {
	background: linear-gradient(135deg, var(--sbmg-red), #c62828);
	color: #fff;
}

.sbmg-dialog-btns .sbmg-cancel {
	background: var(--sbmg-card-bg);
	color: var(--sbmg-text);
	border: 1px solid var(--sbmg-card-border);
}

.sbmg-dialog-btns button:hover {
	transform: translateY(-2px);
}
