/**
 * Promyk Age Gate — modal + toast styles.
 *
 * Brand color przez CSS variable --pag-accent — łatwo nadpisać w theme.
 */

:root {
	--pag-accent:        #e6a219;
	--pag-accent-hover:  #c98a10;
	--pag-text:          #1a1a1a;
	--pag-text-muted:    #6a6a6a;
	--pag-bg:            #ffffff;
	--pag-overlay:       rgba(0, 0, 0, 0.6);
	--pag-border:        #e2e2e2;
	--pag-shadow:        0 20px 60px rgba(0, 0, 0, 0.25);
	--pag-radius:        12px;
}

/* Body lock — zatrzymuje scroll pod modalem. */
body.pag-body--locked {
	overflow: hidden;
	touch-action: none;
}

/* === Modal === */
.pag-modal {
	position: fixed;
	inset: 0;
	z-index: 99999;
	display: none;
	align-items: center;
	justify-content: center;
	padding: 16px;
}

.pag-modal--open {
	display: flex;
	animation: pag-fade-in 180ms ease-out;
}

.pag-modal--closing {
	animation: pag-fade-out 150ms ease-in;
	animation-fill-mode: forwards;
}

.pag-modal__overlay {
	position: absolute;
	inset: 0;
	background: var(--pag-overlay);
	cursor: pointer;
}

.pag-modal__dialog {
	position: relative;
	max-width: 460px;
	width: 100%;
	background: var(--pag-bg);
	color: var(--pag-text);
	border-radius: var(--pag-radius);
	box-shadow: var(--pag-shadow);
	padding: 28px 28px 24px;
	font-family: inherit;
	animation: pag-pop-in 220ms cubic-bezier(0.34, 1.2, 0.64, 1);
}

.pag-modal__title {
	margin: 0 0 12px;
	font-size: 22px;
	line-height: 1.2;
	font-weight: 700;
	color: var(--pag-text);
}

.pag-modal__desc {
	margin: 0 0 14px;
	font-size: 16px;
	line-height: 1.5;
	color: var(--pag-text);
}

.pag-modal__legal {
	margin: 0 0 22px;
	font-size: 13px;
	line-height: 1.5;
	color: var(--pag-text-muted);
	padding: 12px 14px;
	background: #f7f4ed;
	border-left: 3px solid var(--pag-accent);
	border-radius: 6px;
}

.pag-modal__actions {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}

.pag-btn {
	flex: 1 1 auto;
	min-width: 130px;
	padding: 12px 18px;
	border: 1px solid transparent;
	border-radius: 8px;
	font-size: 15px;
	font-weight: 600;
	cursor: pointer;
	transition: background 150ms ease, border-color 150ms ease, color 150ms ease, transform 80ms ease;
	font-family: inherit;
}

.pag-btn:focus-visible {
	outline: 3px solid var(--pag-accent);
	outline-offset: 2px;
}

.pag-btn:active {
	transform: translateY(1px);
}

.pag-btn--primary {
	background: var(--pag-accent);
	color: #fff;
}

.pag-btn--primary:hover,
.pag-btn--primary:focus-visible {
	background: var(--pag-accent-hover);
}

.pag-btn--primary:disabled {
	background: #c9c9c9;
	cursor: wait;
}

.pag-btn--secondary {
	background: transparent;
	color: var(--pag-text);
	border-color: var(--pag-border);
}

.pag-btn--secondary:hover,
.pag-btn--secondary:focus-visible {
	background: #f4f4f4;
	border-color: #c4c4c4;
}

/* === Toast === */
.pag-toast {
	position: fixed;
	bottom: 24px;
	right: 24px;
	max-width: 360px;
	background: #1a1a1a;
	color: #fff;
	padding: 14px 18px;
	border-radius: 10px;
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.25);
	font-size: 14px;
	line-height: 1.4;
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 200ms ease, transform 200ms ease;
	pointer-events: none;
	z-index: 100000;
}

.pag-toast--visible {
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
}

/* === Mobile === */
@media (max-width: 480px) {
	.pag-modal {
		padding: 0;
		align-items: flex-end;
	}

	.pag-modal__dialog {
		max-width: 100%;
		border-radius: 16px 16px 0 0;
		padding: 24px 20px 22px;
	}

	.pag-modal__title {
		font-size: 20px;
	}

	.pag-btn {
		flex: 1 1 100%;
		padding: 14px 18px;
		font-size: 16px;
	}

	.pag-toast {
		left: 16px;
		right: 16px;
		bottom: 16px;
		max-width: none;
	}
}

/* === Animations === */
@keyframes pag-fade-in {
	from { opacity: 0; }
	to   { opacity: 1; }
}

@keyframes pag-fade-out {
	from { opacity: 1; }
	to   { opacity: 0; }
}

@keyframes pag-pop-in {
	from {
		opacity: 0;
		transform: scale(0.94) translateY(8px);
	}
	to {
		opacity: 1;
		transform: scale(1) translateY(0);
	}
}

@media (prefers-reduced-motion: reduce) {
	.pag-modal--open,
	.pag-modal--closing,
	.pag-modal__dialog,
	.pag-toast {
		animation: none;
		transition: none;
	}
}
