/**
 * Tan Bao Phat base design system.
 *
 * Scope: design tokens, shared buttons, and atomic color utilities only.
 * Page layout, header, footer, and WooCommerce rules do not belong here.
 */

:root {
	--tbp-blue-dark: #1e40af;
	--tbp-blue: #2563eb;
	--tbp-blue-light: #38b2f6;
	--tbp-orange: #ff7a00;
	--tbp-orange-light: #ff9f1a;
	--tbp-white: #fff;
	--tbp-bg-soft: #f8fafc;
	--tbp-bg-blue-soft: #eef2f7;
	--tbp-bg-blue-lighter: #e2e8f0;
	--tbp-text: #0f172a;
	--tbp-text-soft: #64748b;
	--tbp-green: #10b981;
	--tbp-border: #dce6f0;
	--tbp-radius: 16px;
	--tbp-shadow: 0 8px 24px rgba(15, 23, 42, 0.08);

}

.tbp-bright-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: 46px;
	padding: 0 18px;
	border: 2px solid transparent;
	border-radius: 10px;
	font-size: 14px;
	font-weight: 800;
	line-height: 1.2;
	text-decoration: none;
	cursor: pointer;
	transition:
		opacity 0.18s,
		transform 0.15s,
		background-color 0.18s,
		border-color 0.18s,
		color 0.18s;
}

.tbp-bright-btn:hover {
	opacity: 0.9;
	transform: translateY(-1px);
}

.tbp-bright-btn:focus-visible {
	.tbp-bright-actions {
	display: flex;
	align-items: center;
	gap: 14px;
	flex-wrap: wrap;
}

.tbp-bright-actions--right {
	justify-content: flex-end;
}
	outline: 3px solid rgba(37, 99, 235, 0.3);
	outline-offset: 3px;
}

.tbp-bright-btn:active {
	transform: scale(0.98);
}

.tbp-bright-btn--primary {
	color: var(--tbp-white);
	background: linear-gradient(135deg, #d96200, #e87800);
}

.tbp-bright-btn--primary:hover {
	opacity: 0.92;
}

.tbp-bright-btn--outline {
	color: var(--tbp-blue-dark);
	background: transparent;
	border-color: var(--tbp-blue-dark);
}

.tbp-bright-btn--outline:hover {
	background: var(--tbp-bg-blue-soft);
}

.tbp-bright-btn--blue {
	color: var(--tbp-white);
	background: var(--tbp-blue-dark);
}

.tbp-bright-btn--white {
	color: var(--tbp-blue-dark);
	background: var(--tbp-white);
}

.tbp-bg-blue {
	background: #eef2ff;
}

.tbp-bg-green {
	background: #dffbf0;
}

.tbp-bg-orange {
	background: #fff3e8;
}

.tbp-bg-sky {
	background: #e0f2fe;
}

.tbp-bg-purple {
	background: #f0e8ff;
}

.tbp-icon-success {
	color: var(--tbp-green);
	background: #dffbf0;
}

.tbp-icon-blue {
	color: var(--tbp-blue);
	background: #eef2ff;
}

.tbp-icon-orange {
	color: var(--tbp-orange);
	background: #fff3e8;
}
