/* ===========================================
   Authentication Pages - Login/Register/Reset
   Premium Boutique Design - Krpice Theme
   =========================================== */

/* ===========================================
   Page Background - Clean & Simple
   =========================================== */
.krpice-auth {
	min-height: calc(100vh - var(--header-height, 70px) - 200px);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--spacing-xl) var(--spacing-md);
	background: var(--color-background);
}

/* ===========================================
   Card Container - Premium Feel
   =========================================== */
.auth-container {
	width: 100%;
	max-width: 440px;
	background: #fff;
	border-radius: var(--radius-lg);
	box-shadow:
		0 4px 6px rgba(86, 66, 51, 0.04),
		0 12px 24px rgba(86, 66, 51, 0.08),
		0 24px 48px rgba(86, 66, 51, 0.06);
	padding: var(--spacing-xl) var(--spacing-xl) var(--spacing-lg);
	position: relative;
	z-index: 1;
	border: 1px solid rgba(212, 163, 115, 0.15);

	/* Entry animation */
	animation: cardReveal 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) backwards;
}

@keyframes cardReveal {
	from {
		opacity: 0;
		transform: translateY(30px) scale(0.97);
	}
	to {
		opacity: 1;
		transform: translateY(0) scale(1);
	}
}

/* Subtle top accent line */
.auth-container::before {
	content: '';
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 60px;
	height: 3px;
	background: linear-gradient(90deg, transparent, var(--color-accent), transparent);
	border-radius: 0 0 3px 3px;
}

/* ===========================================
   Header / Logo with Decorative Elements
   =========================================== */
.auth-header {
	text-align: center;
	margin-bottom: var(--spacing-lg);
	animation: fadeInDown 0.5s ease 0.1s backwards;
}

@keyframes fadeInDown {
	from {
		opacity: 0;
		transform: translateY(-15px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.auth-logo {
	font-size: 1.7rem;
	font-weight: 400;
	font-family: var(--font-heading);
	color: var(--color-primary);
	text-decoration: none;
	display: inline-block;
	letter-spacing: -0.02em;
	position: relative;
}

.auth-logo .highlight {
	color: var(--color-accent);
	font-weight: 400;
}

/* Decorative ornament under logo */
.auth-header::after {
	content: '✦';
	display: block;
	margin-top: var(--spacing-sm);
	color: var(--color-accent);
	font-size: 0.75rem;
	opacity: 0.6;
	letter-spacing: 8px;
}

.auth-title {
	font-size: 1.6rem;
	font-weight: 400;
	font-family: var(--font-heading);
	color: var(--color-primary);
	text-align: center;
	margin: 0 0 var(--spacing-xs) 0;
	letter-spacing: -0.02em;
}

.auth-subtitle {
	font-size: 0.95rem;
	color: var(--color-text-light);
	text-align: center;
	margin: 0 0 var(--spacing-lg) 0;
	line-height: 1.6;
}

/* ===========================================
   Tab Navigation - Elegant Pill Style
   =========================================== */
.auth-tabs {
	display: flex;
	gap: var(--spacing-xs);
	margin-bottom: var(--spacing-lg);
	background: var(--color-background);
	padding: 5px;
	border-radius: var(--radius-full);
	animation: fadeInUp 0.5s ease 0.15s backwards;
}

@keyframes fadeInUp {
	from {
		opacity: 0;
		transform: translateY(15px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.auth-tab {
	flex: 1;
	padding: 12px var(--spacing-md);
	background: transparent;
	border: none;
	border-radius: var(--radius-full);
	font-size: 0.95rem;
	font-weight: 500;
	font-family: var(--font-heading);
	color: var(--color-text-light);
	cursor: pointer;
	position: relative;
	transition:
		color var(--transition-fast),
		background var(--transition-base),
		box-shadow var(--transition-base);
}

.auth-tab:hover:not(.active) {
	color: var(--color-text);
	background: rgba(255, 255, 255, 0.5);
}

.auth-tab.active {
	color: var(--color-primary);
	background: #fff;
	box-shadow:
		0 2px 8px rgba(86, 66, 51, 0.1),
		0 1px 3px rgba(86, 66, 51, 0.08);
}

/* ===========================================
   Form Panel with Staggered Animations
   =========================================== */
.auth-panel {
	animation: panelFadeIn 0.4s ease;
}

@keyframes panelFadeIn {
	from {
		opacity: 0;
		transform: translateX(10px);
	}
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

/* Staggered form field animations */
.auth-panel .form-field {
	display: flex;
	flex-direction: column;
	gap: 8px;
	margin-bottom: var(--spacing-md);
	animation: fieldSlideIn 0.4s ease backwards;
}

.auth-panel .form-field:nth-child(1) { animation-delay: 0.2s; }
.auth-panel .form-field:nth-child(2) { animation-delay: 0.25s; }
.auth-panel .form-field:nth-child(3) { animation-delay: 0.3s; }

@keyframes fieldSlideIn {
	from {
		opacity: 0;
		transform: translateY(10px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.auth-panel .form-field label {
	font-size: 0.85rem;
	font-weight: 500;
	color: var(--color-text);
	display: flex;
	align-items: center;
	gap: 4px;
}

.auth-panel .form-field .required {
	color: var(--color-accent);
	font-size: 0.9em;
}

/* ===========================================
   Input Fields - Refined Style
   =========================================== */
.auth-panel .form-field input[type="text"],
.auth-panel .form-field input[type="email"],
.auth-panel .form-field input[type="password"] {
	width: 100%;
	padding: 14px 16px;
	border: 1.5px solid var(--color-border);
	border-radius: var(--radius-md);
	font-size: 0.95rem;
	font-family: inherit;
	color: var(--color-text);
	background: #fff;
	transition:
		border-color var(--transition-fast),
		box-shadow var(--transition-fast),
		background var(--transition-fast);
}

.auth-panel .form-field input:hover {
	border-color: #d4cfc7;
}

.auth-panel .form-field input:focus {
	outline: none;
	border-color: var(--color-accent);
	box-shadow:
		0 0 0 4px rgba(212, 163, 115, 0.12),
		0 2px 8px rgba(212, 163, 115, 0.08);
	background: #fffdf9;
}

.auth-panel .form-field input::placeholder {
	color: var(--color-text-light);
	opacity: 0.5;
}

/* ===========================================
   Remember Me Checkbox - Custom Style
   =========================================== */
.remember-row {
	margin-bottom: var(--spacing-md);
	animation: fieldSlideIn 0.4s ease 0.35s backwards;
}

.remember-me {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	cursor: pointer;
	font-size: 0.9rem;
	color: var(--color-text);
	transition: color var(--transition-fast);
}

.remember-me:hover {
	color: var(--color-primary);
}

.remember-me input[type="checkbox"] {
	width: 16px;
	height: 16px;
	margin: 0;
	margin-bottom: 4px;
	flex-shrink: 0;
	accent-color: var(--color-accent);
	cursor: pointer;
}

/* ===========================================
   Submit Button - Premium Gradient
   =========================================== */
.form-actions {
	margin-top: var(--spacing-lg);
	animation: fieldSlideIn 0.4s ease 0.4s backwards;
}

.btn-auth {
	width: 100%;
	padding: 16px 24px;
	background: linear-gradient(135deg, var(--color-primary) 0%, #4a3729 100%);
	color: #fff;
	border: none;
	border-radius: var(--radius-md);
	font-size: 1rem;
	font-weight: 500;
	font-family: var(--font-heading);
	cursor: pointer;
	position: relative;
	overflow: hidden;
	transition:
		transform var(--transition-bounce),
		box-shadow var(--transition-base);
}

/* Shimmer effect on button */
.btn-auth::before {
	content: '';
	position: absolute;
	top: 0;
	left: -100%;
	width: 100%;
	height: 100%;
	background: linear-gradient(
		90deg,
		transparent,
		rgba(255, 255, 255, 0.2),
		transparent
	);
	transition: left 0.5s ease;
}

.btn-auth:hover {
	transform: translateY(-3px);
	box-shadow:
		0 8px 20px rgba(86, 66, 51, 0.25),
		0 4px 8px rgba(86, 66, 51, 0.15);
}

.btn-auth:hover::before {
	left: 100%;
}

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

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

/* ===========================================
   Links - Elegant Underline Effect
   =========================================== */
.auth-links {
	text-align: center;
	margin-top: var(--spacing-md);
	animation: fieldSlideIn 0.4s ease 0.45s backwards;
}

.lost-password-link {
	font-size: 0.875rem;
	color: var(--color-text-light);
	text-decoration: none;
	position: relative;
	transition: color var(--transition-fast);
}

.lost-password-link::after {
	content: '';
	position: absolute;
	bottom: -2px;
	left: 50%;
	width: 0;
	height: 1px;
	background: var(--color-accent);
	transition: all var(--transition-base);
	transform: translateX(-50%);
}

.lost-password-link:hover {
	color: var(--color-primary);
}

.lost-password-link:hover::after {
	width: 100%;
}

/* ===========================================
   Footer - Decorative Divider
   =========================================== */
.auth-footer {
	text-align: center;
	margin-top: var(--spacing-lg);
	padding-top: var(--spacing-lg);
	position: relative;
	animation: fieldSlideIn 0.4s ease 0.5s backwards;
}

/* Decorative divider with ornament */
.auth-footer::before {
	content: '';
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 80%;
	height: 1px;
	background: linear-gradient(
		90deg,
		transparent,
		var(--color-border) 20%,
		var(--color-border) 80%,
		transparent
	);
}

.auth-footer::after {
	content: '◆';
	position: absolute;
	top: -6px;
	left: 50%;
	transform: translateX(-50%);
	background: #fff;
	padding: 0 10px;
	color: var(--color-accent);
	font-size: 0.6rem;
}

.back-link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 0.9rem;
	color: var(--color-text-light);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.back-link:hover {
	color: var(--color-primary);
}

.back-arrow {
	font-size: 1.2rem;
	transition: transform var(--transition-bounce);
}

.back-link:hover .back-arrow {
	transform: translateX(-4px);
}

/* ===========================================
   Register Notes - Soft Highlight Box
   =========================================== */
.register-note {
	font-size: 0.875rem;
	color: var(--color-text-light);
	background: linear-gradient(135deg, var(--color-background) 0%, #f9f5ed 100%);
	padding: var(--spacing-sm) var(--spacing-md);
	border-radius: var(--radius-md);
	margin-bottom: var(--spacing-md);
	line-height: 1.6;
	border-left: 3px solid var(--color-accent);
}

.register-terms {
	font-size: 0.8rem;
	color: var(--color-text-light);
	text-align: center;
	margin-top: var(--spacing-md);
	line-height: 1.6;
	animation: fieldSlideIn 0.4s ease 0.45s backwards;
}

.register-terms a {
	color: var(--color-primary);
	text-decoration: underline;
	text-decoration-color: var(--color-accent);
	text-underline-offset: 2px;
}

.register-terms a:hover {
	color: var(--color-accent);
}

/* ===========================================
   WooCommerce Notices Override
   =========================================== */
.krpice-auth .woocommerce-message,
.krpice-auth .woocommerce-error,
.krpice-auth .woocommerce-info {
	padding: 14px 16px !important;
	border: 1px solid var(--color-border) !important;
	border-left: 4px solid var(--color-accent) !important;
	border-radius: var(--radius-md) !important;
	background: linear-gradient(135deg, #fff 0%, var(--color-background) 100%) !important;
	margin: 0 0 var(--spacing-md) 0 !important;
	font-size: 0.875rem !important;
	color: var(--color-text) !important;
	box-shadow: 0 2px 8px rgba(86, 66, 51, 0.06) !important;
	list-style: none !important;
	animation: noticeSlide 0.4s ease backwards;
}

@keyframes noticeSlide {
	from {
		opacity: 0;
		transform: translateY(-10px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.krpice-auth .woocommerce-message::before,
.krpice-auth .woocommerce-error::before,
.krpice-auth .woocommerce-info::before {
	display: none !important;
}

.krpice-auth .woocommerce-error {
	border-left-color: #c0392b !important;
	background: linear-gradient(135deg, #fff 0%, #fdf5f5 100%) !important;
}

.krpice-auth .woocommerce-message {
	border-left-color: var(--color-success) !important;
	background: linear-gradient(135deg, #fff 0%, #f5fdf8 100%) !important;
}

.krpice-auth .woocommerce-error li,
.krpice-auth .woocommerce-message li {
	list-style: none !important;
	margin: 0 !important;
}

/* ===========================================
   Responsive - Tablet
   =========================================== */
@media (max-width: 768px) {
	.krpice-auth {
		padding: var(--spacing-lg) var(--spacing-sm);
		min-height: calc(100vh - var(--header-height, 60px) - 150px);
	}

	.auth-container {
		padding: var(--spacing-lg);
		border-radius: var(--radius-md);
		max-width: 100%;
	}

	.auth-logo {
		font-size: 1.5rem;
	}

	.auth-title {
		font-size: 1.4rem;
	}

	.auth-tabs {
		padding: 4px;
	}

	.auth-tab {
		font-size: 0.9rem;
		padding: 10px var(--spacing-sm);
	}

	.auth-panel .form-field input[type="text"],
	.auth-panel .form-field input[type="email"],
	.auth-panel .form-field input[type="password"] {
		font-size: 16px; /* Prevent iOS zoom */
		padding: 14px;
	}

	.btn-auth {
		padding: 16px;
	}
}

/* ===========================================
   Responsive - Mobile
   =========================================== */
@media (max-width: 480px) {
	.krpice-auth {
		padding: var(--spacing-md) var(--spacing-xs);
		align-items: flex-start;
		padding-top: var(--spacing-lg);
	}

	.auth-container {
		padding: var(--spacing-md);
		box-shadow:
			0 2px 4px rgba(86, 66, 51, 0.04),
			0 8px 16px rgba(86, 66, 51, 0.06);
		border-radius: var(--radius-md);
	}

	.auth-container::before {
		width: 40px;
		height: 2px;
	}

	.auth-header {
		margin-bottom: var(--spacing-md);
	}

	.auth-header::after {
		margin-top: var(--spacing-xs);
		font-size: 0.6rem;
	}

	.auth-logo {
		font-size: 1.4rem;
	}

	.auth-title {
		font-size: 1.2rem;
	}

	.auth-subtitle {
		font-size: 0.85rem;
		margin-bottom: var(--spacing-md);
	}

	.auth-tabs {
		margin-bottom: var(--spacing-md);
		padding: 3px;
	}

	.auth-tab {
		font-size: 0.85rem;
		padding: 10px;
	}

	.auth-panel .form-field {
		margin-bottom: var(--spacing-sm);
	}

	.auth-panel .form-field label {
		font-size: 0.8rem;
	}

	.form-actions {
		margin-top: var(--spacing-md);
	}

	.auth-footer {
		margin-top: var(--spacing-md);
		padding-top: var(--spacing-md);
	}

	.register-terms {
		font-size: 0.75rem;
	}

	/* Disable complex animations on mobile */
	.auth-container,
	.auth-header,
	.auth-tabs,
	.auth-panel .form-field,
	.remember-row,
	.form-actions,
	.auth-links,
	.auth-footer,
	.register-terms {
		animation: none;
	}
}

/* ===========================================
   Reduced Motion - Accessibility
   =========================================== */
@media (prefers-reduced-motion: reduce) {
	.auth-container,
	.auth-header,
	.auth-tabs,
	.auth-panel,
	.auth-panel .form-field,
	.remember-row,
	.form-actions,
	.auth-links,
	.auth-footer,
	.register-terms,
	.krpice-auth .woocommerce-message,
	.krpice-auth .woocommerce-error,
	.krpice-auth .woocommerce-info {
		animation: none;
	}

	.btn-auth::before {
		display: none;
	}
}

/* ===========================================
   Google Sign-In Integration
   =========================================== */

/* Google Sign-In Wrapper */
.google-signin-wrapper {
	margin-bottom: var(--spacing-lg);
	animation: fieldSlideIn 0.4s ease 0.1s backwards;
}

/* Style the Google button container */
.google-signin-wrapper .S9gUrf-YoZ4jf,
.google-signin-wrapper > div {
	display: flex;
	justify-content: center;
	width: 100%;
}

/* Make the Google iframe button full width */
.google-signin-wrapper iframe {
	width: 100% !important;
	min-width: 100% !important;
}

/* Custom Google button alternative (if we render our own) */
.btn-google {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	padding: 14px 20px;
	background: #fff;
	border: 1.5px solid var(--color-border);
	border-radius: var(--radius-md);
	font-size: 0.95rem;
	font-weight: 500;
	font-family: var(--font-heading);
	color: var(--color-text);
	cursor: pointer;
	transition:
		border-color var(--transition-fast),
		box-shadow var(--transition-fast),
		transform var(--transition-bounce);
}

.btn-google:hover {
	border-color: #d4cfc7;
	box-shadow: 0 4px 12px rgba(86, 66, 51, 0.1);
	transform: translateY(-2px);
}

.btn-google:active {
	transform: translateY(0);
}

.btn-google svg {
	width: 20px;
	height: 20px;
	flex-shrink: 0;
}

/* Divider with "ili" text */
.auth-panel .auth-divider,
.krpice-auth .auth-divider {
	display: flex !important;
	align-items: center !important;
	gap: 16px;
	margin: 20px 0 !important;
	animation: fieldSlideIn 0.4s ease 0.15s backwards;
}

.auth-panel .auth-divider::before,
.auth-panel .auth-divider::after,
.krpice-auth .auth-divider::before,
.krpice-auth .auth-divider::after {
	content: '';
	flex: 1;
	height: 1px;
	background: #e5e0d8;
}

.auth-panel .auth-divider span,
.krpice-auth .auth-divider span {
	font-size: 0.85rem;
	font-weight: 500;
	color: #8b7355;
	text-transform: lowercase;
	letter-spacing: 0.05em;
	white-space: nowrap;
}

/* Hide default Google button styling conflicts */
.auth-panel .gsi-material-button {
	width: 100% !important;
	max-width: 100% !important;
}

/* Legacy Google button container */
.S9gUrf-YoZ4jf {
	margin-bottom: 0;
}
