:root {
	--bg: #0b0c10;
	--card: rgba(22, 23, 28, 0.78);
	--card2: rgba(22, 23, 28, 0.58);
	--text: #e9e9ee;
	--muted: rgba(233, 233, 238, 0.62);
	--line: rgba(255, 255, 255, 0.12);
	--focus: rgba(255, 255, 255, 0.22);
	--accent: #d5b15c;
	--danger: #ff6b6b;

	--radius: 18px;
	--shadow: 0 22px 70px rgba(0, 0, 0, 0.55);
}

* {
	box-sizing: border-box;
}
html,
body {
	height: 100%;
}
body {
	margin: 0;
	font-family: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif;
	color: var(--text);
	background: var(--bg);
}

.page {
	min-height: 100vh;
	display: grid;
	place-items: center;
	padding: 28px;
	position: relative;
	overflow: hidden;
}

/* Background (blurred image + dark overlay) */
.bg {
	position: absolute;
	inset: 0;
	background-image: url("./bg.png");
	background-size: cover;
	background-position: center;
	transform: scale(1.06);
	filter: blur(4px) grayscale(100%);
	opacity: 0.95;
	background-position: 50% 45%; /* sube un poco el encuadre */
}

.bg-overlay {
	position: absolute;
	inset: 0;
	background: radial-gradient(
			1200px 700px at 75% 25%,
			rgba(213, 177, 92, 0.12),
			transparent 55%
		),
		radial-gradient(
			900px 600px at 25% 75%,
			rgba(255, 255, 255, 0.06),
			transparent 60%
		),
		linear-gradient(to bottom, rgba(0, 0, 0, 0.55), rgba(0, 0, 0, 0.74));
}

/* Card */
.card {
	position: relative;
	width: min(460px, 100%);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	background: linear-gradient(to bottom, var(--card), var(--card2));
	border: 1px solid rgba(255, 255, 255, 0.1);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}

.card-inner {
	padding: 28px 28px 22px;
}

.mark {
	display: grid;
	place-items: center;
	margin-top: 2px;
	margin-bottom: 12px;
}

.heart {
	font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu,
		Cantarell, "Noto Sans", sans-serif;
	font-size: 22px;
	line-height: 1;
	color: #ff7aa2;
}

.hero {
	text-align: center;
	margin-bottom: 22px;
}

.title {
	margin: 0;
	font-size: 34px;
	font-weight: 500;
	letter-spacing: 0.2px;
}

.date {
	margin: 10px 0 0;
	font-size: 12px;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: var(--muted);
	font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu,
		Cantarell, "Noto Sans", sans-serif;
}

.form {
	display: grid;
	gap: 16px;
}

.field {
	display: grid;
	gap: 8px;
}

.label {
	font-size: 12px;
	letter-spacing: 1px;
	text-transform: uppercase;
	color: rgba(233, 233, 238, 0.72);
	font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu,
		Cantarell, "Noto Sans", sans-serif;
}

.control {
	position: relative;
}

.icon {
	position: absolute;
	left: 14px;
	top: 50%;
	transform: translateY(-50%);
	color: rgba(233, 233, 238, 0.6);
	pointer-events: none;
}

.icon-btn {
	position: absolute;
	right: 10px;
	top: 50%;
	transform: translateY(-50%);
	width: 34px;
	height: 34px;
	display: grid;
	place-items: center;
	border: 1px solid rgba(255, 255, 255, 0.12);
	background: rgba(0, 0, 0, 0.18);
	color: rgba(233, 233, 238, 0.65);
	border-radius: 999px;
	cursor: pointer;
}

.icon-btn:hover {
	border-color: rgba(255, 255, 255, 0.22);
	color: rgba(233, 233, 238, 0.8);
}

input {
	width: 100%;
	height: 48px;
	border-radius: 12px;
	border: 1px solid var(--line);
	background: rgba(0, 0, 0, 0.18);
	color: var(--text);
	padding: 0 54px 0 44px;
	outline: none;
	font-size: 14px;
	font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu,
		Cantarell, "Noto Sans", sans-serif;
}

input::placeholder {
	color: rgba(233, 233, 238, 0.45);
}

input:focus {
	border-color: var(--focus);
	box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.05);
}

.hint {
	margin: 0;
	font-size: 12px;
	color: rgba(213, 177, 92, 0.85);
	font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu,
		Cantarell, "Noto Sans", sans-serif;
}

.actions {
	margin-top: 2px;
}

.btn {
	width: 100%;
	height: 52px;
	border-radius: 12px;
	border: 0;
	cursor: pointer;
	background: rgba(0, 0, 0, 0.35);
	color: rgba(233, 233, 238, 0.9);
	font-weight: 600;
	letter-spacing: 0.4px;
	font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu,
		Cantarell, "Noto Sans", sans-serif;
	box-shadow: 0 10px 34px rgba(0, 0, 0, 0.35);
	position: relative;
	overflow: hidden;
}

.btn::after {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: 12px;
	box-shadow: 0 0 32px rgba(56, 140, 255, 0.16);
	pointer-events: none;
}

.btn:hover {
	background: rgba(0, 0, 0, 0.45);
}

.btn:disabled {
	opacity: 0.65;
	cursor: not-allowed;
}

.spinner {
	display: none;
	width: 18px;
	height: 18px;
	border: 2px solid rgba(233, 233, 238, 0.25);
	border-top-color: rgba(233, 233, 238, 0.85);
	border-radius: 999px;
	margin-left: 10px;
	animation: spin 800ms linear infinite;
	vertical-align: middle;
}

.btn.is-loading .spinner {
	display: inline-block;
}

.btn.is-loading .btn-text {
	opacity: 0.92;
}

@keyframes spin {
	to {
		transform: rotate(360deg);
	}
}

.micro {
	margin: 8px 0 0;
	text-align: center;
	font-size: 11px;
	letter-spacing: 1px;
	text-transform: uppercase;
	color: rgba(233, 233, 238, 0.55);
	font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu,
		Cantarell, "Noto Sans", sans-serif;
}

.error {
	margin: 0;
	padding: 10px 12px;
	border-radius: 12px;
	border: 1px solid rgba(255, 107, 107, 0.28);
	background: rgba(255, 107, 107, 0.1);
	color: rgba(255, 107, 107, 0.95);
	font-size: 13px;
	font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu,
		Cantarell, "Noto Sans", sans-serif;
}

/* Small screens */
@media (max-width: 420px) {
	.card-inner {
		padding: 22px 18px 18px;
	}
	.title {
		font-size: 30px;
	}
}
