/* Sign-in page: centered card. Tokens from theme.css. */

body.bare {
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--space-5);
}

.login-card {
	width: 100%;
	max-width: 360px;
	background: var(--surface-1);
	border: 1px solid var(--border-subtle);
	border-radius: var(--radius-lg);
	padding: var(--space-7) var(--space-6);
	text-align: center;
	box-shadow: var(--shadow-lg);
}

.login-logo {
	margin-bottom: var(--space-4);
}

.login-title {
	font-family: var(--font-display);
	font-size: 1.4rem;
	margin: 0 0 var(--space-1) 0;
}

.login-sub {
	color: var(--text-muted);
	margin: 0 0 var(--space-6) 0;
	font-size: 0.9rem;
}

.login-error {
	background: var(--danger-bg);
	color: var(--danger);
	border: 1px solid var(--danger);
	border-radius: var(--radius-sm);
	padding: var(--space-3);
	margin-bottom: var(--space-5);
	font-size: 0.88rem;
}

.btn-google {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-3);
	width: 100%;
	padding: var(--space-3) var(--space-4);
	background: var(--surface-3);
	color: var(--text-primary);
	border: 1px solid var(--border);
	border-radius: var(--radius-sm);
	text-decoration: none;
	font-weight: 500;
	transition: border-color var(--transition-base);
}

.btn-google:hover {
	border-color: var(--gold);
}

.btn-google-g {
	font-family: var(--font-display);
	font-weight: 700;
	color: var(--gold);
}

.login-note {
	margin: var(--space-5) 0 0 0;
	color: var(--text-disabled);
	font-size: 0.78rem;
}
