@charset "UTF-8";

/**
 * ログイン画面（member = ライト / portal = ダーク）
 */

.matching-login-body {
	--login-radius: 16px;
	--login-radius-sm: 10px;
	--login-accent: var(--matching-color-primary);
	--login-accent-2: var(--matching-color-accent);

	margin: 0;
	min-height: 100vh;
	min-height: 100dvh;
	color: var(--login-text);
	font-family: inherit;
	-webkit-font-smoothing: antialiased;
}

/* 求職者（/member/）: 公開サイトと同系統のライト UI */
.matching-login-body--member {
	--login-surface: var(--matching-color-bg);
	--login-surface-border: var(--matching-color-border);
	--login-text: var(--matching-color-text);
	--login-text-muted: var(--matching-color-muted);
	--login-text-dim: var(--matching-color-secondary);
	--login-danger-bg: var(--matching-color-danger-bg);
	--login-danger-border: var(--matching-color-danger-border);
	--login-danger-text: var(--matching-color-danger-text);
	--login-input-bg: var(--matching-color-bg);
	--login-input-border: var(--matching-color-border);
	--login-input-text: var(--matching-color-text);
	--login-shadow: var(--matching-shadow-md);
	--login-ring: none;
	--login-link: var(--matching-color-link);
	--login-link-hover: var(--matching-color-link-hover);
	--login-info-bg: var(--matching-color-info-bg);
	--login-info-border: color-mix(in srgb, var(--matching-color-primary) 35%, transparent);
	--login-info-text: var(--matching-color-info-text);
	--login-success-bg: var(--matching-color-success-bg);
	--login-success-border: var(--matching-color-success-border);
	--login-success-text: var(--matching-color-success-text);
	--login-tab-track: var(--matching-color-surface);
	--login-google-bg: #ffffff;
	--login-google-hover: var(--matching-color-surface);

	background-color: #f8f7f6;
	background-image: var(--matching-gradient-page);
	background-attachment: fixed;
}

.matching-login-body--member .page-login-shell::before {
	background: radial-gradient(ellipse closest-side, rgba(0, 119, 199, 0.08), transparent 100%);
	opacity: 0.9;
}

.matching-login-body--member .page-login-card {
	backdrop-filter: none;
	-webkit-backdrop-filter: none;
}

.matching-login-body--member .page-login-card-glow {
	display: none;
}

/* 運営・企業（/portal/）: ダッシュボード系ダーク UI */
.matching-login-body--portal {
	--login-surface: rgba(15, 23, 42, 0.72);
	--login-surface-border: rgba(148, 163, 184, 0.14);
	--login-text: #f1f5f9;
	--login-text-muted: #94a3b8;
	--login-text-dim: #64748b;
	--login-danger-bg: rgba(248, 113, 113, 0.1);
	--login-danger-border: rgba(248, 113, 113, 0.35);
	--login-danger-text: #fecaca;
	--login-input-bg: rgba(2, 6, 23, 0.55);
	--login-input-border: rgba(148, 163, 184, 0.22);
	--login-input-text: #f8fafc;
	--login-shadow: 0 4px 7px rgba(0, 0, 0, 0.18), 0 24px 48px rgba(0, 0, 0, 0.38);
	--login-ring: 0 0 0 1px rgba(255, 255, 255, 0.06) inset;
	--login-link: #7dd3fc;
	--login-link-hover: #bae6fd;
	--login-info-bg: rgba(0, 119, 199, 0.12);
	--login-info-border: rgba(0, 119, 199, 0.35);
	--login-info-text: #bfdbfe;
	--login-success-bg: rgba(52, 211, 153, 0.12);
	--login-success-border: rgba(52, 211, 153, 0.35);
	--login-success-text: #a7f3d0;
	--login-tab-track: rgba(2, 6, 23, 0.45);
	--login-google-bg: var(--login-input-bg);
	--login-google-hover: rgba(0, 119, 199, 0.12);

	background-color: #06080d;
	background-image: var(--matching-gradient-login-mesh);
	background-attachment: fixed;
}

.page-login-main {
	margin: 0;
	padding: max(1.5rem, env(safe-area-inset-top)) max(1rem, env(safe-area-inset-right)) max(1.5rem, env(safe-area-inset-bottom)) max(1rem, env(safe-area-inset-left));
	min-height: 100vh;
	min-height: 100dvh;
	display: flex;
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
}

.page-login-shell {
	position: relative;
	width: 100%;
	max-width: 28rem;
	z-index: 1;
}

/* カード背後のソフトグロー */
.page-login-shell::before {
	content: "";
	position: absolute;
	inset: -20% -30% auto;
	height: 55%;
	background: radial-gradient(ellipse closest-side, rgba(0, 119, 199, 0.22), transparent 100%);
	pointer-events: none;
	z-index: -1;
	opacity: 0.85;
}

.page-login-card {
	position: relative;
	overflow: hidden;
	background: var(--login-surface);
	border: 1px solid var(--login-surface-border);
	border-radius: var(--login-radius);
	padding: 2rem 1.85rem 1.65rem;
	box-shadow: var(--login-shadow), var(--login-ring);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
}

/* 上部アクセントライン */
.page-login-card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--login-accent), var(--login-accent-2) 100%);
	opacity: 0.95;
}

.page-login-card-glow {
	position: absolute;
	top: -40%;
	right: -35%;
	width: 70%;
	height: 70%;
	background: radial-gradient(circle, rgba(129, 140, 248, 0.12) 0%, transparent 70%);
	pointer-events: none;
}

.page-login-brand {
	position: relative;
	margin-bottom: 1.5rem;
	text-align: center;
}

.page-login-logo .custom-logo-link {
	display: inline-flex;
	justify-content: center;
	align-items: center;
}

.page-login-logo .custom-logo {
	max-height: 52px;
	width: auto;
	height: auto;
	filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.2));
}

.page-login-site-name {
	display: inline-block;
	font-size: 1.6rem;
	font-weight: 700;
	color: var(--login-text);
	text-decoration: none;
	letter-spacing: -0.02em;
	line-height: 1.25;
}

.page-login-site-name:hover {
	color: var(--login-accent);
	text-decoration: none;
}

.page-login-kicker {
	margin: 1rem 0 0;
}

.page-login-kicker-pill {
	display: inline-flex;
	align-items: center;
	padding: 0.25rem 0.7rem;
	font-size: 1.1rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--login-accent);
	background: rgba(0, 119, 199, 0.12);
	border: 1px solid rgba(0, 119, 199, 0.28);
	border-radius: 999px;
}

.page-login-title {
	margin: 0.75rem 0 0;
	font-size: 2.4rem;
	font-weight: 700;
	letter-spacing: -0.03em;
	line-height: 1.25;
	color: var(--login-text);
}

.page-login-lead {
	margin: 0.6rem 0 0;
	font-size: 1.5rem;
	line-height: 1.65;
	color: var(--login-text-muted);
	max-width: 26rem;
	margin-left: auto;
	margin-right: auto;
}

.page-login-alert {
	display: flex;
	gap: 0.65rem;
	align-items: flex-start;
	margin: 0 0 1.25rem;
	padding: 0.85rem 1rem;
	border-radius: var(--login-radius-sm);
	background: var(--login-danger-bg);
	border: 1px solid var(--login-danger-border);
	color: var(--login-danger-text);
	font-size: 1.4rem;
	line-height: 1.55;
}

.page-login-alert-icon {
	flex-shrink: 0;
	width: 1.125rem;
	height: 1.125rem;
	margin-top: 0.1rem;
	border-radius: 50%;
	background: rgba(248, 113, 113, 0.35);
	position: relative;
}

.page-login-alert-icon::before,
.page-login-alert-icon::after {
	content: "";
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	background: var(--login-danger-text);
	border-radius: 1px;
}

.page-login-alert-icon::before {
	top: 0.35rem;
	width: 2px;
	height: 5px;
}

.page-login-alert-icon::after {
	bottom: 0.3rem;
	width: 2px;
	height: 2px;
}

.page-login-alert-text {
	flex: 1;
	min-width: 0;
}

.page-login-form {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	position: relative;
}

.page-login-field {
	display: flex;
	flex-direction: column;
	gap: 0.45rem;
}

.page-login-label {
	font-size: 1.4rem;
	font-weight: 600;
	color: var(--login-text-muted);
	letter-spacing: 0.01em;
}

.page-login-input {
	width: 100%;
	box-sizing: border-box;
	padding: 0.7rem 0.9rem;
	font-size: var(--matching-input-font-size, 1.5rem);
	line-height: 1.4;
	color: var(--login-input-text);
	background: var(--login-input-bg);
	border: var(--matching-input-border-width, 1px) solid var(--login-input-border);
	border-radius: var(--matching-input-radius, var(--login-radius-sm));
	transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.page-login-input::placeholder {
	color: var(--login-text-dim);
	opacity: 1;
}

.page-login-input:hover {
	border-color: color-mix(in srgb, var(--login-accent) 35%, var(--login-input-border));
}

.matching-login-body--portal .page-login-input:hover {
	background: rgba(2, 6, 23, 0.65);
}

.matching-login-body--member .page-login-input:hover {
	background: var(--matching-color-bg-soft);
}

.page-login-input:focus {
	outline: none;
	border-color: color-mix(in srgb, var(--login-accent) 65%, transparent);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--login-accent) 22%, transparent);
}

.matching-login-body--portal .page-login-input:focus {
	background: rgba(2, 6, 23, 0.75);
}

.matching-login-body--member .page-login-input:focus {
	background: var(--matching-color-bg);
}

.page-login-remember {
	margin: -0.15rem 0 0;
}

.page-login-check-label {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 1.4rem;
	color: var(--login-text-muted);
	cursor: pointer;
	user-select: none;
}

.page-login-check-label input {
	width: 1.05rem;
	height: 1.05rem;
	margin: 0;
	accent-color: var(--login-accent);
	border-radius: 4px;
	cursor: pointer;
}

/* .btn-primary より詳細度を上げてテーマ共通ボタンを上書き */
.matching-login-body button.page-login-submit.btn-primary {
	margin-top: 0.25rem;
	width: 100%;
	justify-content: center;
	padding: var(--matching-btn-padding-y, 1rem) var(--matching-btn-padding-x, 1.8rem);
	min-height: var(--matching-btn-min-height, 4rem);
	font-size: var(--matching-btn-font-size, 1.2rem);
	font-weight: 600;
	letter-spacing: 0.02em;
	border: none;
	border-radius: var(--login-radius-sm);
	background: linear-gradient(135deg, var(--login-accent) 0%, var(--login-accent-2) 100%);
	color: #fff;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15), 0 8px 24px color-mix(in srgb, var(--login-accent) 28%, transparent);
	transition: filter 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease;
}

.matching-login-body button.page-login-submit.btn-primary:hover {
	filter: brightness(1.06);
	background: linear-gradient(135deg, var(--matching-color-primary-hover, #0066ad) 0%, var(--login-accent-2) 100%);
	color: #fff;
	border-color: transparent;
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.18), 0 12px 28px color-mix(in srgb, var(--login-accent) 32%, transparent);
	transform: translateY(-1px);
}

.matching-login-body button.page-login-submit.btn-primary:active {
	transform: translateY(0);
}

.matching-login-body button.page-login-submit.btn-primary:focus-visible {
	outline: 2px solid var(--login-accent);
	outline-offset: 3px;
}

.page-login-footer-nav {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 0.5rem 0.75rem;
	margin-top: 1.5rem;
	padding-top: 1.35rem;
	border-top: 1px solid var(--login-surface-border);
}

.page-login-footer-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 1.35rem;
	color: var(--login-text-muted);
	text-decoration: none;
	text-align: center;
	transition: color 0.2s ease;
}

.page-login-footer-link:hover {
	color: var(--login-accent);
	text-decoration: none;
}

.page-login-footer-link--primary {
	color: var(--login-link, #7dd3fc);
	font-weight: 500;
}

.page-login-footer-link--primary:hover {
	color: var(--login-link-hover, #bae6fd);
}

.page-login-footer-link--home {
	min-width: 8.5em;
}

.page-login-footer-sep {
	width: 4px;
	height: 4px;
	border-radius: 50%;
	background: var(--login-text-dim);
	opacity: 0.7;
}

@media (max-width: 480px) {
	.page-login-card {
		padding: 1.5rem 1.25rem 1.35rem;
		border-radius: 14px;
	}

	.page-login-title {
		font-size: 2.1rem;
	}

	.page-login-lead {
		font-size: 1.4rem;
	}

	.page-login-footer-nav {
		flex-direction: column;
		gap: 0.65rem;
	}

	.page-login-footer-sep {
		display: none;
	}
}

@media (prefers-reduced-motion: reduce) {
	.page-login-input,
	.page-login-submit,
	.page-login-footer-link,
	.page-login-google-btn {
		transition: none;
	}

	.page-login-submit:active {
		transform: none;
	}
}

/* 単カラム（member / portal 各1画面） */
.page-login-shell--single {
	display: flex;
	justify-content: center;
	max-width: min(32rem, 100%);
	margin-inline: auto;
}

.page-login-shell--register {
	max-width: min(34rem, 100%);
}

.page-login-shell--single .page-login-card {
	width: 100%;
}

/* 求職者 / 運営 二系統レイアウト（旧 split・未使用） */
.page-login-shell--split {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1.6rem;
	max-width: min(72rem, 100%);
	align-items: stretch;
}

.page-login-card--seeker,
.page-login-card--staff {
	height: 100%;
}

.page-login-google-wrap {
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
	margin: 0 0 1.1rem;
}

.page-login-google-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.75rem;
	width: 100%;
	min-height: var(--matching-input-min-height, 4rem);
	padding: 0.75rem 1.15rem;
	border: 1px solid var(--login-input-border);
	border-radius: var(--login-radius-sm);
	background: var(--login-google-bg, var(--login-input-bg));
	color: var(--login-text);
	font-size: var(--matching-btn-font-size, 1.58rem);
	font-weight: 600;
	text-decoration: none;
	transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}

.matching-login-body--member .page-login-google-btn {
	box-shadow: var(--matching-shadow);
}

.page-login-google-btn:hover,
.page-login-google-btn:focus-visible {
	border-color: var(--login-accent);
	background: var(--login-google-hover, rgba(0, 119, 199, 0.12));
	color: var(--login-text);
}

.page-login-alert--info {
	background: var(--login-info-bg);
	border-color: var(--login-info-border);
}

.page-login-alert--info .page-login-alert-text {
	color: var(--login-info-text);
}

.page-login-alert--success {
	background: var(--login-success-bg);
	border-color: var(--login-success-border);
}

.page-login-alert--success .page-login-alert-text {
	color: var(--login-success-text);
}

.page-login-verified-next {
	margin: -0.5rem 0 1rem;
	text-align: center;
}

.page-login-alert-text .matching-auth-error-actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.55rem 0.85rem;
	margin-top: 0.55rem;
}

.page-login-alert-text .matching-auth-error-link {
	color: var(--login-link, #93c5fd);
}

.page-login-divider {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin: 0 0 1.15rem;
	color: var(--login-text-dim);
	font-size: 1.3rem;
	text-align: center;
}

.page-login-divider::before,
.page-login-divider::after {
	content: "";
	flex: 1;
	height: 1px;
	background: var(--login-surface-border);
}

.page-login-switch {
	margin: 1.15rem 0 0;
	font-size: 1.4rem;
	line-height: 1.55;
	color: var(--login-text-muted);
	text-align: center;
}

.page-login-switch .page-login-footer-link {
	font-size: inherit;
}

.page-login-seeker-resend {
	margin: 0.85rem 0 0;
	font-size: 1.35rem;
	color: var(--login-text-muted);
	text-align: center;
}

.page-login-form--resend {
	margin-top: 1.35rem;
	padding-top: 1.15rem;
	border-top: 1px dashed var(--login-surface-border);
}

.matching-login-body button.page-login-submit.page-login-submit--secondary {
	background: transparent;
	color: var(--login-text-muted);
	border: 1px solid var(--login-input-border);
	box-shadow: none;
}

.matching-login-body button.page-login-submit.page-login-submit--secondary:hover {
	background: rgba(148, 163, 184, 0.08);
	color: var(--login-text);
	border-color: rgba(148, 163, 184, 0.35);
	transform: none;
}

@media (max-width: 768px) {
	.page-login-shell--split {
		grid-template-columns: 1fr;
		max-width: 28rem;
	}
}

/* ========== 会員登録: パスワード表示切替 / 強度 ========== */
.matching-password-input-wrap {
	position: relative;
	display: block;
	width: 100%;
}

.matching-password-input-wrap .page-login-input {
	padding-right: 2.75rem;
}

.matching-password-toggle {
	position: absolute;
	top: 50%;
	right: 0.65rem;
	transform: translateY(-50%);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.2rem;
	height: 2.2rem;
	padding: 0;
	border: 0;
	border-radius: var(--login-radius-sm, 0.45rem);
	background: transparent;
	color: var(--login-text-muted, #64748b);
	cursor: pointer;
	transition: color 0.2s ease, background-color 0.2s ease;
}

.matching-password-toggle:hover,
.matching-password-toggle:focus-visible {
	color: var(--login-accent, var(--matching-color-primary));
	background: color-mix(in srgb, var(--login-accent, var(--matching-color-primary)) 10%, transparent);
	outline: none;
}

.matching-password-toggle-icon {
	display: block;
}

.matching-password-strength {
	margin-top: 0.55rem;
}

.matching-password-strength-bar {
	height: 0.35rem;
	border-radius: 999px;
	background: color-mix(in srgb, var(--login-input-border, #cbd5e1) 70%, transparent);
	overflow: hidden;
}

.matching-password-strength-bar span {
	display: block;
	height: 100%;
	width: 0;
	border-radius: inherit;
	background: var(--matching-color-danger, #dc2626);
	transition: width 0.2s ease, background 0.2s ease;
}

.matching-password-strength.is-fair .matching-password-strength-bar span {
	background: #d97706;
}

.matching-password-strength.is-strong .matching-password-strength-bar span {
	background: var(--login-accent, var(--matching-color-primary, #059669));
}

.matching-password-strength-label {
	margin: 0.35rem 0 0;
	font-size: 1.2rem;
	font-weight: 600;
	color: var(--login-text-muted, #64748b);
}

.matching-password-strength-prefix {
	color: var(--login-text-muted, #64748b);
	font-weight: 600;
}

.matching-password-strength-value {
	font-weight: 700;
}

.matching-password-strength.is-weak .matching-password-strength-value {
	color: var(--matching-color-danger, #dc2626);
}

.matching-password-strength.is-fair .matching-password-strength-value {
	color: #d97706;
}

.matching-password-strength.is-strong .matching-password-strength-value {
	color: var(--login-accent, var(--matching-color-primary, #059669));
}
