/* =============================================================
   FF PROFILES — Forms
   ============================================================= */

.ff-field {
	margin-bottom: 20px;
}
.ff-field label {
	display: block;
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	font-weight: 500;
	margin-bottom: 8px;
	color: var(--ff-black, #0F0F0F);
}
.ff-field input[type="text"],
.ff-field input[type="email"],
.ff-field input[type="password"],
.ff-field input[type="url"],
.ff-field input[type="tel"],
.ff-field input[type="number"],
.ff-field input[type="date"],
.ff-field input[type="search"],
.ff-field select,
.ff-field textarea {
	width: 100%;
	padding: 13px 16px;
	border: 1px solid var(--ff-border, #E7E7E4);
	border-radius: 0;
	font-family: inherit;
	font-size: 15px;
	background: var(--ff-paper, #fff);
	color: var(--ff-text, #1A1A1A);
	transition: border-color 0.2s, box-shadow 0.2s;
}
.ff-field input:focus,
.ff-field select:focus,
.ff-field textarea:focus {
	outline: none;
	border-color: var(--ff-black, #0F0F0F);
	box-shadow: 0 0 0 3px rgba(212, 175, 122, 0.25);
}
.ff-field textarea { resize: vertical; min-height: 120px; line-height: 1.6; }
.ff-hint {
	display: block;
	font-size: 12px;
	color: var(--ff-muted, #8B8B8B);
	margin-top: 6px;
}
.ff-req { color: var(--ff-danger, #EF4444); font-weight: bold; }

.ff-field-checkbox label,
.ff-field-checkbox-row label {
	display: flex;
	gap: 10px;
	align-items: flex-start;
	font-size: 14px;
	text-transform: none;
	letter-spacing: 0;
	color: var(--ff-text, #1A1A1A);
	cursor: pointer;
	line-height: 1.5;
}
.ff-field-checkbox-row {
	display: flex; gap: 24px; flex-wrap: wrap;
	margin-bottom: 20px;
}
.ff-field-checkbox input[type="checkbox"],
.ff-field-checkbox-row input[type="checkbox"] {
	margin-top: 3px;
	width: 18px; height: 18px;
	accent-color: var(--ff-black, #0F0F0F);
}

/* Error state */
.ff-field.is-error input,
.ff-field.is-error select,
.ff-field.is-error textarea {
	border-color: var(--ff-danger, #EF4444);
}
.ff-field.is-error .ff-hint {
	color: var(--ff-danger, #EF4444);
}

/* WP login form styled */
#ff-login-form {
	max-width: 420px;
	margin: 0 auto;
}
#ff-login-form p { margin-bottom: 16px; }
#ff-login-form label {
	display: block;
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	font-weight: 500;
	margin-bottom: 6px;
}
#ff-login-form input[type="text"],
#ff-login-form input[type="password"] {
	width: 100%;
	padding: 13px 16px;
	border: 1px solid var(--ff-border, #E7E7E4);
	font-size: 15px;
	border-radius: 0;
}
#ff-login-form #wp-submit {
	display: block;
	width: 100%;
	padding: 14px;
	background: var(--ff-black, #0F0F0F);
	color: var(--ff-gold, #D4AF7A);
	border: 0;
	font-size: 13px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	cursor: pointer;
	margin-top: 16px;
	transition: all 0.2s;
}
#ff-login-form #wp-submit:hover {
	background: var(--ff-gold, #D4AF7A);
	color: var(--ff-black, #0F0F0F);
}
#ff-login-form .forgetmenot label {
	display: inline-flex;
	gap: 8px;
	font-size: 13px;
	text-transform: none;
	letter-spacing: 0;
}

/* Social link row edit */
.ff-social-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 12px; }
.ff-social-row {
	display: grid;
	grid-template-columns: 140px 1fr 40px;
	gap: 8px;
	align-items: center;
}
.ff-social-row input {
	padding: 10px 12px;
	border: 1px solid var(--ff-border, #E7E7E4);
	font-family: inherit;
	font-size: 14px;
}
@media (max-width: 560px) {
	.ff-social-row { grid-template-columns: 1fr 40px; }
	.ff-social-row input[data-field="platform"] { grid-column: 1 / 3; }
}

/* Avatar edit */
.ff-avatar-edit {
	display: flex;
	gap: 24px;
	align-items: center;
	flex-wrap: wrap;
}
.ff-avatar-preview {
	width: 120px; height: 120px;
	background: var(--ff-cream, #FAFAF7);
	border: 1px solid var(--ff-border, #E7E7E4);
	overflow: hidden;
	display: flex; align-items: center; justify-content: center;
}
.ff-avatar-preview img { width: 100%; height: 100%; object-fit: cover; }
.ff-avatar-placeholder { font-size: 36px; color: var(--ff-gold, #D4AF7A); }

/* Completion bar */
.ff-completion-bar {
	margin-top: 12px;
	max-width: 480px;
}
.ff-completion-label {
	font-size: 13px;
	color: var(--ff-muted, #8B8B8B);
	margin-bottom: 6px;
}
.ff-progress {
	height: 6px;
	background: var(--ff-cream, #FAFAF7);
	border: 1px solid var(--ff-border, #E7E7E4);
	overflow: hidden;
}
.ff-progress-fill {
	height: 100%;
	background: linear-gradient(90deg, var(--ff-black, #0F0F0F), var(--ff-gold, #D4AF7A));
	transition: width 0.4s ease;
}

/* Edit sections */
.ff-edit-section {
	background: var(--ff-paper, #fff);
	border: 1px solid var(--ff-border, #E7E7E4);
	padding: 28px;
	margin-bottom: 16px;
}

.ff-save-bar {
	position: sticky;
	bottom: 0;
	display: flex; gap: 12px;
	padding: 16px 0;
	background: rgba(250, 250, 247, 0.95);
	backdrop-filter: blur(8px);
	justify-content: flex-end;
	flex-wrap: wrap;
	margin-top: 32px;
}

/* Feedback */
.ff-form-feedback {
	margin: 16px 0;
	min-height: 1px;
}
.ff-form-feedback:empty { display: none; }

@media (max-width: 640px) {
	.ff-edit-section { padding: 20px 16px; }
	.ff-save-bar { flex-direction: column-reverse; }
	.ff-save-bar .ff-btn { width: 100%; }
}
