.leonlab-modal__trigger {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	padding: 10px 14px;
	border-radius: 12px;
	border: 1px solid rgba(0,0,0,0.12);
	font-weight: 700;
	cursor: pointer;
}

.leonlab-modal__trigger--primary {
	background: rgba(0,0,0,0.92);
	color: #fff;
	border-color: rgba(0,0,0,0.92);
}

.leonlab-modal__trigger--secondary {
	background: rgba(255,255,255,0.65);
	color: inherit;
}

.leonlab-modal__trigger--link {
	background: transparent;
	border-color: transparent;
	padding: 0;
	text-decoration: underline;
	color: inherit;
}

.leonlab-modal__overlay {
	position: fixed;
	inset: 0;
	background: rgba(0,0,0,0.55);
	backdrop-filter: blur(6px);
	display: none;
	align-items: center;
	justify-content: center;
	padding: 22px;
	z-index: 9999;
}

.leonlab-modal__overlay.is-open {
	display: flex;
}

.leonlab-modal__dialog {
	width: 100%;
	max-height: 85vh;
	overflow: auto;
	background: rgba(255,255,255,0.98);
	border-radius: 18px;
	border: 1px solid rgba(0,0,0,0.12);
	box-shadow: 0 30px 80px rgba(0,0,0,0.25);
	padding: 18px;
	position: relative;
}

.leonlab-modal__dialog--sm { max-width: 520px; }
.leonlab-modal__dialog--md { max-width: 760px; }
.leonlab-modal__dialog--lg { max-width: 980px; }

.leonlab-modal__close {
	position: absolute;
	top: 12px;
	right: 12px;
	border: 1px solid rgba(0,0,0,0.12);
	background: rgba(0,0,0,0.04);
	border-radius: 999px;
	width: 34px;
	height: 34px;
	line-height: 34px;
	text-align: center;
	font-size: 20px;
	cursor: pointer;
}

.leonlab-modal__title {
	font-weight: 900;
	letter-spacing: -0.01em;
	margin: 0 0 12px;
	padding-right: 44px;
}

.leonlab-modal__content > *:first-child { margin-top: 0; }
.leonlab-modal__content > *:last-child { margin-bottom: 0; }
