/**
 * Plugga Registration Styles
 * Playful, fun, and approachable design
 * Uses design system variables with page-specific overrides
 */

/* Page Wrapper */
.fo-page-wrapper.join-page,
.fo-join-page-wrapper {
	min-height: 100vh;
	background: var(--fo-join-page-background-color, var(--fo-page-background-color, linear-gradient(135deg, #f5f7fa 0%, #c3cfe2 100%)));
	padding: 40px 20px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.fo-container {
	max-width: var(--fo-join-page-container-max-width, 500px);
	width: 100%;
}

/* Join Form Container */
.fo-join-form-container,
.fo-verify-container {
	background: var(--fo-join-page-container-background, var(--fo-color-background, #fff));
	border-radius: var(--fo-join-page-container-border-radius, var(--fo-border-radius-xl, 20px));
	padding: var(--fo-join-page-container-padding, 40px);
	box-shadow: var(--fo-join-page-container-box-shadow, var(--fo-shadow-lg, 0 10px 40px rgba(0, 0, 0, 0.1)));
}

.fo-page-title {
	font-size: var(--fo-join-page-title-font-size, var(--fo-font-size-h1, 32px));
	font-weight: var(--fo-join-page-title-font-weight, var(--fo-font-weight-bold, 700));
	color: var(--fo-join-page-title-color, var(--fo-color-text, #333));
	margin: 0 0 10px 0;
	line-height: var(--fo-line-height-heading, 1.2);
}

.fo-page-subtitle {
	font-size: var(--fo-join-page-subtitle-font-size, var(--fo-font-size-base, 16px));
	color: var(--fo-join-page-subtitle-color, var(--fo-color-text-light, #666));
	margin: 0 0 30px 0;
	line-height: var(--fo-line-height-text, 1.6);
}

/* Form Styles */
.fo-join-form,
.fo-verify-form {
	margin-top: 30px;
}

.fo-form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 15px;
}

.fo-form-field {
	margin-bottom: 20px;
}

.fo-form-field label {
	display: block;
	margin-bottom: 8px;
	font-weight: var(--fo-join-page-form-label-font-weight, var(--fo-form-label-font-weight, 600));
	color: var(--fo-join-page-form-label-color, var(--fo-form-label-color, #333));
	font-size: var(--fo-join-page-form-label-font-size, var(--fo-form-label-font-size, 14px));
}

.fo-form-field .required {
	color: var(--fo-color-error, #d63638);
}

.fo-form-input {
	width: 100%;
	padding: var(--fo-join-page-form-input-padding, var(--fo-form-input-padding, 12px 16px));
	border-width: var(--fo-join-page-form-input-border-width, var(--fo-form-input-border-width, 2px));
	border-style: var(--fo-join-page-form-input-border-type, var(--fo-form-input-border-type, solid));
	border-color: var(--fo-join-page-form-input-border-color, var(--fo-form-input-border-color, #e0e0e0));
	border-radius: var(--fo-join-page-form-input-border-radius, var(--fo-form-input-border-radius, 12px));
	font-size: var(--fo-font-size-base, 16px);
	line-height: 1.5;
	color: var(--fo-color-text, #333);
	background-color: var(--fo-join-page-form-input-background, var(--fo-form-input-background, #fff));
	transition: all var(--fo-transition-base, 0.2s ease);
	box-sizing: border-box;
	font-family: inherit;
}

.fo-form-input:focus {
	outline: none;
	border-color: var(--fo-join-page-form-input-focus-border-color, var(--fo-form-input-focus-border-color, #2271b1));
	box-shadow: var(--fo-join-page-form-input-focus-box-shadow, var(--fo-form-input-focus-box-shadow, 0 0 0 3px rgba(34, 113, 177, 0.1)));
}

.fo-form-input::placeholder {
	color: #999;
}

.fo-verify-code-input {
	text-align: center;
	font-size: 20px;
	letter-spacing: 4px;
	font-weight: 600;
}

.fo-field-help {
	font-size: 13px;
	color: #666;
	margin-top: 6px;
	margin-bottom: 0;
}

/* Password Strength Meter */
.fo-password-strength {
	margin-top: 8px;
	padding: 8px 12px;
	border-radius: 6px;
	font-size: 13px;
	font-weight: 500;
	min-height: 20px;
	transition: all 0.2s ease;
}

.fo-password-strength.short {
	background-color: #fee2e2;
	color: #991b1b;
}

.fo-password-strength.bad {
	background-color: #fef3c7;
	color: #92400e;
}

.fo-password-strength.good {
	background-color: #dbeafe;
	color: #1e40af;
}

.fo-password-strength.strong {
	background-color: #d1fae5;
	color: #065f46;
}

.fo-password-strength .strength-label {
	display: inline-block;
}

/* Password Match Indicator */
.fo-password-match {
	margin-top: 8px;
	padding: 8px 12px;
	border-radius: 6px;
	font-size: 13px;
	font-weight: 500;
	min-height: 20px;
	transition: all 0.2s ease;
}

.fo-password-match.match {
	background-color: #d1fae5;
	color: #065f46;
}

.fo-password-match.mismatch {
	background-color: #fee2e2;
	color: #991b1b;
}

.fo-password-match .match-text,
.fo-password-match .mismatch-text {
	display: inline-block;
}

/* Buttons */
.fo-button {
	display: inline-block;
	cursor: pointer;
	text-decoration: none;
	text-align: center;
	font-family: inherit;
	position: relative;
	min-height: 48px;
}

.fo-button-primary {
	background-color: var(--fo-join-page-button-primary-background-color, var(--fo-button-primary-background-color, #2271b1));
	color: var(--fo-join-page-button-primary-text-color, var(--fo-button-primary-text-color, #fff));
	border-style: var(--fo-join-page-button-primary-border-type, var(--fo-button-primary-border-type, none));
	border-width: var(--fo-join-page-button-primary-border-width, var(--fo-button-primary-border-width, 0));
	border-color: var(--fo-join-page-button-primary-border-color, var(--fo-button-primary-border-color, transparent));
	border-radius: var(--fo-join-page-button-primary-border-radius-top, var(--fo-button-primary-border-radius-top, 12px)) var(--fo-join-page-button-primary-border-radius-right, var(--fo-button-primary-border-radius-right, 12px)) var(--fo-join-page-button-primary-border-radius-bottom, var(--fo-button-primary-border-radius-bottom, 12px)) var(--fo-join-page-button-primary-border-radius-left, var(--fo-button-primary-border-radius-left, 12px));
	padding: var(--fo-join-page-button-primary-padding-top, var(--fo-button-primary-padding-top, 14px)) var(--fo-join-page-button-primary-padding-right, var(--fo-button-primary-padding-right, 32px)) var(--fo-join-page-button-primary-padding-bottom, var(--fo-button-primary-padding-bottom, 14px)) var(--fo-join-page-button-primary-padding-left, var(--fo-button-primary-padding-left, 32px));
	font-size: var(--fo-join-page-button-primary-font-size, var(--fo-button-primary-font-size, 16px));
	font-weight: var(--fo-join-page-button-primary-font-weight, var(--fo-button-primary-font-weight, 600));
	box-shadow: var(--fo-join-page-button-primary-box-shadow, var(--fo-button-primary-box-shadow, none));
	transition: all var(--fo-join-page-button-primary-transition, var(--fo-button-primary-transition, 0.2s ease));
	width: 100%;
}

.fo-button-primary:hover:not(:disabled) {
	background-color: var(--fo-join-page-button-primary-background-hover, var(--fo-button-primary-background-hover, #135e96));
	color: var(--fo-join-page-button-primary-text-hover, var(--fo-button-primary-text-hover, #fff));
	border-color: var(--fo-join-page-button-primary-border-hover, var(--fo-button-primary-border-hover, transparent));
	box-shadow: var(--fo-join-page-button-primary-box-shadow-hover, var(--fo-button-primary-box-shadow-hover, 0 4px 12px rgba(34, 113, 177, 0.3)));
	transform: var(--fo-join-page-button-primary-hover-transform, var(--fo-button-primary-hover-transform, translateY(-2px)));
}

.fo-button-primary:active:not(:disabled) {
	transform: translateY(0);
}

.fo-button-primary:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}

.fo-button-link {
	background-color: var(--fo-join-page-button-link-background-color, var(--fo-button-link-background-color, transparent));
	color: var(--fo-join-page-button-link-text-color, var(--fo-button-link-text-color, #2271b1));
	border: none;
	padding: var(--fo-join-page-button-link-padding-top, var(--fo-button-link-padding-top, 8px)) var(--fo-join-page-button-link-padding-right, var(--fo-button-link-padding-right, 12px)) var(--fo-join-page-button-link-padding-bottom, var(--fo-button-link-padding-bottom, 8px)) var(--fo-join-page-button-link-padding-left, var(--fo-button-link-padding-left, 12px));
	font-size: var(--fo-join-page-button-link-font-size, var(--fo-button-link-font-size, 14px));
	cursor: pointer;
	text-decoration: underline;
}

.fo-button-link:hover {
	color: var(--fo-join-page-button-link-text-hover, var(--fo-button-link-text-hover, #135e96));
}

.fo-button-loading {
	display: none;
}

/* Messages */
.fo-form-message {
	padding: 14px 18px;
	margin-bottom: 20px;
	border-radius: var(--fo-border-radius-xl, 12px);
	font-size: 14px;
	line-height: 1.5;
}

.fo-message-success {
	background-color: var(--fo-join-page-form-message-success-background, var(--fo-form-success-background, rgba(0, 163, 42, 0.1)));
	color: var(--fo-join-page-form-message-success-color, var(--fo-form-success-color, #00a32a));
	border: 2px solid var(--fo-join-page-form-message-success-color, var(--fo-form-success-color, #00a32a));
}

.fo-message-error {
	background-color: var(--fo-join-page-form-message-error-background, var(--fo-form-error-background, rgba(214, 54, 56, 0.1)));
	color: var(--fo-join-page-form-message-error-color, var(--fo-form-error-color, #d63638));
	border: 2px solid var(--fo-join-page-form-message-error-color, var(--fo-form-error-color, #d63638));
}

.fo-message-info {
	background-color: #e7f0f7;
	color: #2271b1;
	border: 2px solid #2271b1;
}

/* Verify Actions */
.fo-verify-actions {
	text-align: center;
	margin-top: 20px;
	padding-top: 20px;
	border-top: 1px solid #eee;
}

.fo-separator {
	color: #ccc;
	margin: 0 10px;
}

.fo-update-email-form {
	margin-top: 30px;
	padding: 20px;
	background: #f9f9f9;
	border-radius: 12px;
}

.fo-update-email-form h3 {
	margin-top: 0;
	font-size: 18px;
}

/* Loading Popup with Warren Buffett Quotes */
.fo-loading-popup {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: var(--fo-join-page-loading-popup-overlay-background, var(--fo-popup-overlay-background, rgba(0, 0, 0, 0.7)));
	z-index: 10001;
	display: flex;
	align-items: center;
	justify-content: center;
}

.fo-loading-content {
	background: var(--fo-join-page-loading-popup-background, var(--fo-popup-background, #fff));
	border-radius: var(--fo-join-page-loading-popup-border-radius, var(--fo-popup-border-radius, 12px));
	padding: var(--fo-join-page-loading-popup-padding, var(--fo-popup-padding, 40px));
	max-width: 500px;
	width: 90%;
	text-align: center;
	box-shadow: var(--fo-join-page-loading-popup-box-shadow, var(--fo-popup-box-shadow, 0 10px 40px rgba(0, 0, 0, 0.3)));
}

.fo-loading-spinner {
	border: 4px solid #f3f3f3;
	border-top: 4px solid #3b82f6;
	border-radius: 50%;
	width: 50px;
	height: 50px;
	animation: spin 1s linear infinite;
	margin: 0 auto 20px;
}

@keyframes spin {
	0% { transform: rotate(0deg); }
	100% { transform: rotate(360deg); }
}

.fo-loading-content h3 {
	margin: 0 0 20px 0;
	font-size: 24px;
	color: #333;
}

.fo-buffett-quote {
	font-size: 16px;
	color: #666;
	font-style: italic;
	line-height: 1.6;
	margin: 0;
	min-height: 60px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: opacity 0.5s ease;
}

/* Responsive */
@media (max-width: 600px) {
	.fo-page-wrapper {
		padding: 20px 15px;
	}
	
	.fo-join-form-container,
	.fo-verify-container {
		padding: 30px 20px;
		border-radius: 16px;
	}
	
	.fo-page-title {
		font-size: 28px;
	}
	
	.fo-form-row {
		grid-template-columns: 1fr;
		gap: 0;
	}
	
	.fo-loading-content {
		padding: 30px 20px;
	}
	
	.fo-loading-content h3 {
		font-size: 20px;
	}
	
	.fo-buffett-quote {
		font-size: 14px;
		min-height: 50px;
	}
}

