/* tribus-modal.css */
.tribus-modal[hidden] { display: none !important; }

.tribus-modal {
	position: fixed;
	inset: 0;
	z-index: 10050; /* above cart drawer (9999) */
	display: grid;
	place-items: center;
	padding: 16px;
}

.tribus-modal__overlay {
	position: absolute;
	inset: 0;
	background: rgba(0,0,0,0.45);
	backdrop-filter: blur(14px) saturate(1.2);
	-webkit-backdrop-filter: blur(14px) saturate(1.2);
	opacity: 0;
	transition: opacity 180ms ease;
}

.tribus-modal:not([hidden]) .tribus-modal__overlay {
	opacity: 1;
}

.tribus-modal__panel {
	position: relative;
	width: min(520px, 92vw);

	/* glass */
	background: rgba(18, 20, 24, 0.62);
	background-image: linear-gradient(
		180deg,
		rgba(255,255,255,0.12),
		rgba(255,255,255,0.04)
	);
	border: 1px solid rgba(255,255,255,0.12);
	box-shadow:
		0 0 0 1px rgba(255,255,255,0.06) inset,
		0 18px 50px rgba(0,0,0,0.45);

	backdrop-filter: blur(24px) saturate(1.25);
	-webkit-backdrop-filter: blur(24px) saturate(1.25);

	border-radius: 16px;
	padding: 18px;
	color: #fff;

	transform: translateY(6px) scale(0.99);
	opacity: 0;
	transition: transform 180ms ease, opacity 180ms ease;
}

.tribus-modal:not([hidden]) .tribus-modal__panel {
	transform: translateY(0) scale(1);
	opacity: 1;
}

.tribus-modal__title {
	margin: 0 0 8px 0;
	font-size: 22px;
	line-height: 1.2;
}

.tribus-modal__desc {
	margin: 0 0 14px 0;
	opacity: 0.9;
	font-size: 16px;
	line-height: 1.4;
}

.tribus-modal__actions {
	display: flex;
	gap: 10px;
	justify-content: flex-end;
	margin-top: 10px;
}

.tribus-btn {
	appearance: none;
	border: 1px solid rgba(255,255,255,0.16);
	background: rgba(255,255,255,0.10);
	color: #fff;
	border-radius: 12px;
	padding: 10px 14px;
	font-weight: 700;
	cursor: pointer;
}

.tribus-btn:hover { filter: brightness(1.05); }

.tribus-btn--ghost {
	background: transparent;
}

.tribus-btn--danger {
	border-color: rgba(255, 120, 120, 0.35);
	background: rgba(255, 80, 80, 0.18);
}

:focus-visible {
	outline: 3px solid rgba(120, 190, 255, 0.9);
	outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce) {
	.tribus-modal__overlay,
	.tribus-modal__panel { transition: none; }
}