.auth-page {
	max-width: 720px;
	margin: 0 auto;
	padding: var(--space-8) var(--space-4) var(--space-12);
}

.auth-card {
	background: var(--color-base-1);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: var(--space-6);
	box-shadow: var(--shadow-sm);
}

.auth-card__header {
	margin-bottom: var(--space-6);
	text-align: center;
}

.auth-card__title {
	margin: 0 0 var(--space-2);
	font-size: var(--font-size-2xl);
	color: var(--color-text-primary);
}

.auth-card__sub {
	margin: 0;
	color: var(--color-text-secondary);
	font-size: var(--font-size-sm);
}

.auth-card__sub a {
	color: var(--color-accent-2);
	font-weight: 700;
	text-decoration: none;
}

.auth-card__sub a:hover {
	text-decoration: underline;
}

.auth-card__lead {
	display: inline-block;
	margin: 0 0 var(--space-2);
	padding: 4px var(--space-3);
	border-radius: var(--radius-full);
	background: var(--color-base-2);
	color: var(--color-accent-1);
	font-size: var(--font-size-xs);
	font-weight: 700;
	letter-spacing: 0.02em;
}

.auth-card__errors {
	margin-bottom: var(--space-4);
	padding: var(--space-3);
	border-radius: var(--radius-md);
	background: var(--cat-ningen-bg);
	color: var(--cat-ningen-text);
	font-size: var(--font-size-sm);
}

.auth-card__notice {
	display: block;
	margin-bottom: var(--space-4);
	padding: var(--space-2) var(--space-3);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	font-size: var(--font-size-sm);
	color: var(--color-text-secondary);
	background: var(--color-base-2);
}

.auth-social {
	margin-bottom: var(--space-6);
}

.auth-social__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	min-height: 52px;
	gap: var(--space-3);
	padding: var(--space-3) var(--space-4);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-full);
	background: var(--color-base-1);
	color: var(--color-text-primary);
	font-size: var(--font-size-base);
	font-weight: 700;
	text-decoration: none;
	box-shadow: var(--shadow-sm);
	transition: background-color 0.15s ease, box-shadow 0.15s ease, transform 0.05s ease;
}

.auth-social__btn:hover {
	background: var(--color-base-2);
	box-shadow: var(--shadow-md);
}

.auth-social__btn:active {
	transform: translateY(1px);
}

.auth-social__btn:focus-visible {
	outline: 2px solid var(--color-main);
	outline-offset: 2px;
}

.auth-social__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	font-size: var(--font-size-lg);
	font-weight: 700;
	line-height: 1;
	color: var(--color-accent-2);
}

.auth-social__note {
	margin: var(--space-2) 0 0;
	text-align: center;
	font-size: var(--font-size-xs);
	color: var(--color-text-secondary);
}

.auth-form__divider {
	margin: 0 0 var(--space-4);
	text-align: center;
	font-size: var(--font-size-xs);
	color: var(--color-text-secondary);
}

.auth-form__hint {
	margin: 0 0 var(--space-4);
	text-align: center;
	font-size: var(--font-size-sm);
	color: var(--color-text-secondary);
}

/* ===========================================================
   メールで〜（セクション見出し兼CTA）
   - Google ボタンの下に置く、左右に水平線が入ったピル型ボタン
   - タップで対応する email input にフォーカス
=========================================================== */
.auth-section-divider {
	display: flex;
	align-items: center;
	margin: 0 0 var(--space-5);
}

.auth-section-divider::before,
.auth-section-divider::after {
	content: "";
	flex: 1;
	height: 1px;
	background: var(--color-border);
}

.auth-section-heading {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	min-height: 44px;
	margin: 0 var(--space-3);
	padding: var(--space-2) var(--space-5);
	border: 1.5px solid var(--color-main);
	border-radius: var(--radius-full);
	background: var(--color-base-1);
	color: var(--color-accent-2);
	font-size: var(--font-size-base);
	font-weight: 700;
	cursor: pointer;
	box-shadow: var(--shadow-sm);
	transition: background-color 0.15s ease, box-shadow 0.15s ease, transform 0.05s ease;
}

.auth-section-heading:hover {
	background: var(--color-base-2);
	box-shadow: var(--shadow-md);
}

.auth-section-heading:active {
	transform: translateY(1px);
}

.auth-section-heading:focus-visible {
	outline: 2px solid var(--color-main);
	outline-offset: 2px;
}

.auth-section-heading__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 18px;
	height: 18px;
	color: var(--color-main);
}

.auth-section-heading__icon svg {
	width: 100%;
	height: 100%;
}

.form-group {
	margin-bottom: var(--space-4);
}

.form-label {
	display: inline-block;
	margin-bottom: var(--space-2);
	font-size: var(--font-size-sm);
	font-weight: 700;
	color: var(--color-text-primary);
}

.form-required {
	color: var(--cat-ningen-text);
	font-size: var(--font-size-xs);
}

.form-input {
	width: 100%;
	min-height: 48px;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	background: var(--color-base-1);
	padding: var(--space-3);
	font-size: var(--font-size-base);
	color: var(--color-text-primary);
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.form-input::placeholder {
	color: var(--color-text-muted);
}

.form-input:hover {
	border-color: var(--color-text-muted);
}

.form-input:focus {
	outline: none;
	border-color: var(--color-main);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-main) 18%, transparent);
}

.form-hint {
	margin: var(--space-1) 0 0;
	font-size: var(--font-size-xs);
	color: var(--color-text-secondary);
}

.auth-password {
	position: relative;
}

.auth-password .form-input {
	padding-right: 64px;
}

.auth-password__toggle {
	position: absolute;
	right: var(--space-1);
	top: 50%;
	transform: translateY(-50%);
	min-width: 56px;
	min-height: 40px;
	padding: var(--space-2) var(--space-3);
	border: none;
	border-radius: var(--radius-sm);
	background: transparent;
	color: var(--color-text-secondary);
	font-size: var(--font-size-sm);
	font-weight: 700;
	cursor: pointer;
	transition: background-color 0.15s ease, color 0.15s ease;
}

.auth-password__toggle:hover {
	background: var(--color-base-2);
	color: var(--color-main);
}

.auth-password__toggle:focus-visible {
	outline: 2px solid var(--color-main);
	outline-offset: 2px;
}

.auth-card__terms {
	margin: var(--space-4) 0 var(--space-3);
	text-align: center;
	color: var(--color-text-secondary);
	font-size: var(--font-size-xs);
	line-height: 1.6;
}

.auth-card__terms a {
	color: var(--color-accent-2);
	text-decoration: underline;
}

.auth-card__terms a:hover {
	color: var(--color-main);
}

/* ===========================================================
   レスポンシブ（スマホ）
=========================================================== */
@media (max-width: 575px) {
	.auth-page {
		padding: var(--space-4) var(--space-3) var(--space-8);
	}

	.auth-card {
		padding: var(--space-5) var(--space-4);
	}

	.auth-card__header {
		margin-bottom: var(--space-5);
	}

	.auth-card__title {
		font-size: var(--font-size-xl);
	}

	.auth-section-heading {
		padding: var(--space-2) var(--space-4);
		font-size: var(--font-size-sm);
	}
}
