/**
 * Project Steps Block - Frontend Styles
 *
 * @package B8LAB
 */

/* === CUSTOM PROCESS SECTION === */
.wp-block-b8lab-project-steps.section-custom-process {
	position: relative;
	background: var(--bg-primary);
	color: var(--text-primary);
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--space-16) var(--space-8);
	overflow: hidden;
}

.process-background {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 0;
}

.process-bg-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	opacity: 0.15;
}

.process-container {
	position: relative;
	z-index: 10;
	max-width: 1400px;
	width: 100%;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-16);
	align-items: start;
	transition: grid-template-columns var(--transition-base) var(--ease-in-out);
}

.process-container.full-width {
	grid-template-columns: 0fr 1fr;
}

.process-left,
.process-right {
	width: 100%;
	transition: opacity var(--transition-base) var(--ease-in-out);
}

.process-left {
	overflow: hidden;
	transition: opacity var(--transition-base) var(--ease-in-out);
}

.process-container.full-width .process-left {
	opacity: 0;
	pointer-events: none;
}

.process-container.full-width .process-left .process-title,
.process-container.full-width .process-left .accordion-container {
	display: none;
}

.process-title {
	font-size: var(--text-4xl);
	line-height: 1.2;
	font-weight: 700;
	color: var(--text-primary);
	margin-bottom: var(--space-8);
}

.process-description {
	font-size: var(--text-xl);
	line-height: 1.8;
	color: var(--text-secondary);
	margin-bottom: var(--space-8);
}

/* Accordion Styles */
.accordion-container {
	display: flex;
	flex-direction: column;
	gap: var(--space-4);
}

.accordion-item {
	border: 1px solid var(--border-color);
	background: var(--color-white);
	transition: all var(--transition-base) var(--ease-in-out);
}

.accordion-item:hover,
.accordion-item.active {
	border-color: var(--color-blue-primary);
}

.accordion-header {
	width: 100%;
	display: flex;
	align-items: center;
	gap: var(--space-4);
	padding: var(--space-6);
	background: transparent;
	border: none;
	cursor: pointer;
	text-align: left;
	transition: all var(--transition-base) var(--ease-in-out);
}

.accordion-header:hover,
.accordion-item.active .accordion-header {
	background: rgba(35, 154, 215, 0.05);
}

.accordion-icon {
	flex-shrink: 0;
	width: 40px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 2px solid var(--color-blue-primary);
	background: transparent;
	color: var(--color-blue-primary);
	font-size: var(--text-2xl);
	font-weight: 300;
	transition: all var(--transition-base) var(--ease-in-out);
}

.accordion-item.active .accordion-icon {
	background: var(--color-blue-primary);
	color: var(--color-white);
}

.icon-plus {
	display: block;
}

.icon-minus {
	display: none;
}

.accordion-item.active .icon-plus {
	display: none;
}

.accordion-item.active .icon-minus {
	display: block;
}

.accordion-title {
	font-size: var(--text-xl);
	font-weight: 600;
	color: var(--text-primary);
	font-family: var(--font-mono);
	letter-spacing: -0.02em;
}

.accordion-content {
	max-height: 0;
	overflow: hidden;
	transition: max-height var(--transition-base) var(--ease-in-out);
}

.accordion-item.active .accordion-content {
	max-height: 500px;
}

.accordion-content p {
	padding: var(--space-4) var(--space-6) var(--space-6) calc(var(--space-6) + 40px + var(--space-4));
	font-size: var(--text-base);
	line-height: 1.7;
	color: var(--text-secondary);
	margin: 0;
}

/* Layout Toggle Button */
.layout-toggle-btn {
	position: absolute;
	top: var(--space-6);
	left: calc(-1 * var(--space-16));
	width: 48px;
	height: 48px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--color-white);
	border: 2px solid var(--color-blue-primary);
	cursor: pointer;
	transition: all var(--transition-base) var(--ease-in-out);
	z-index: 100;
}

.layout-toggle-btn:hover {
	background: rgba(35, 154, 215, 0.1);
}

.layout-toggle-btn .material-icons-outlined {
	font-size: 24px;
	color: var(--color-blue-primary);
	transition: transform var(--transition-base) var(--ease-in-out);
}

.process-container.full-width .layout-toggle-btn .material-icons-outlined {
	transform: rotate(180deg);
}

/* Process Right Section */
.process-right {
	position: relative;
	padding: var(--space-12);
	background: var(--color-white);
	border: 2px solid var(--color-blue-primary);
	transition: all var(--transition-base) var(--ease-in-out);
	align-self: start;
}

.process-right .process-title {
	margin-bottom: var(--space-6);
}

.process-right .btn {
	margin-top: var(--space-8);
}

/* Multi-Step Form Progress Bar */
.form-progress {
	margin-bottom: var(--space-8);
}

.progress-bar {
	width: 100%;
	height: 6px;
	background: var(--bg-tertiary);
	border: 1px solid var(--border-color);
	margin-bottom: var(--space-3);
	overflow: hidden;
}

.progress-fill {
	height: 100%;
	background: var(--color-blue-primary);
	width: 16.67%;
	transition: width var(--transition-base) var(--ease-in-out);
}

.progress-text {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.progress-step {
	font-size: var(--text-sm);
	font-family: var(--font-mono);
	color: var(--text-secondary);
	font-weight: 600;
}

/* Multi-Step Form Container */
.multi-step-form {
	margin-top: var(--space-6);
	position: relative;
}

/* Form Step */
.form-step {
	display: none;
	animation: fadeInStep 0.4s var(--ease-in-out);
}

.form-step.active {
	display: block;
}

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

/* Step Header */
.step-header {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	margin-bottom: var(--space-6);
	padding-bottom: var(--space-4);
	border-bottom: 2px solid var(--color-blue-primary);
}

.step-icon {
	font-size: 32px;
	color: var(--color-blue-primary);
}

.step-title {
	font-size: var(--text-xl);
	font-weight: 700;
	color: var(--text-primary);
	margin: 0;
	font-family: var(--font-mono);
	letter-spacing: -0.02em;
}

/* Form Group */
.form-group {
	display: flex;
	flex-direction: column;
	margin-bottom: var(--space-6);
}

/* Form Row - 50/50 Grid */
.form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-4);
	margin-bottom: var(--space-6);
}

.form-row .form-group {
	margin-bottom: 0;
}

.form-label {
	display: block;
	font-size: var(--text-base);
	font-weight: 600;
	color: var(--text-primary);
	margin-bottom: var(--space-4);
	letter-spacing: 0.02em;
}

/* Option Grid for Radio Buttons */
.option-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-4);
}

.option-card {
	position: relative;
	cursor: pointer;
}

.option-card input[type="radio"] {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.option-content {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: var(--space-2);
	padding: var(--space-5);
	border: 2px solid var(--border-color);
	background: var(--bg-primary);
	transition: all var(--transition-base) var(--ease-in-out);
	min-height: 100px;
}

.option-card:hover .option-content {
	border-color: var(--color-blue-primary);
	background: rgba(35, 154, 215, 0.05);
}

.option-card input[type="radio"]:checked + .option-content,
.option-card.selected .option-content {
	border-color: var(--color-blue-primary);
	background: rgba(35, 154, 215, 0.1);
	border-width: 3px;
}

.option-label {
	font-size: var(--text-lg);
	font-weight: 600;
	color: var(--text-primary);
	text-align: center;
	line-height: 1.3;
}

.option-sublabel {
	font-size: var(--text-sm);
	color: var(--text-secondary);
	text-align: center;
	line-height: 1.4;
}

/* Input Fields */
.form-input-wrapper {
	position: relative;
	display: flex;
	align-items: center;
}

.form-input-wrapper .material-icons,
.form-input-wrapper .material-icons-outlined {
	position: absolute;
	right: var(--space-4);
	color: var(--text-tertiary);
	font-size: 20px;
	pointer-events: none;
	transition: color var(--transition-base) var(--ease-in-out);
}

.form-input-wrapper:focus-within .material-icons,
.form-input-wrapper:focus-within .material-icons-outlined {
	color: var(--color-blue-primary);
}

.form-input,
.form-textarea {
	width: 100%;
	padding: var(--space-4);
	border: 1px solid var(--border-color);
	background: var(--bg-primary);
	font-size: var(--text-base);
	font-family: inherit;
	color: var(--text-primary);
	transition: all var(--transition-base) var(--ease-in-out);
	border-radius: 0;
}

.form-input-wrapper .form-input {
	padding-right: calc(var(--space-4) + 20px + var(--space-3));
}

.form-input:focus,
.form-textarea:focus {
	outline: none;
	border-color: var(--color-blue-primary);
	background: var(--color-white);
}

.form-input::placeholder,
.form-textarea::placeholder {
	color: var(--text-tertiary);
}

.form-textarea {
	min-height: 120px;
	resize: vertical;
}

/* Form Navigation */
.form-navigation {
	display: flex;
	gap: var(--space-4);
	margin-top: var(--space-8);
	padding-top: var(--space-6);
	border-top: 1px solid var(--border-color);
}

.form-navigation .btn {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-2);
}

.form-navigation .material-icons,
.form-navigation .material-icons-outlined {
	font-size: 20px;
}

/* Form Validation Notice */
.form-validation-notice {
	margin-top: var(--space-5);
	padding: var(--space-4) var(--space-5);
	background: rgba(241, 90, 36, 0.08);
	border-left: 4px solid var(--color-orange-accent);
	border-top: 1px solid rgba(241, 90, 36, 0.2);
	border-right: 1px solid rgba(241, 90, 36, 0.2);
	border-bottom: 1px solid rgba(241, 90, 36, 0.2);
	color: var(--text-primary);
	font-size: var(--text-sm);
	line-height: 1.6;
	display: flex;
	align-items: flex-start;
	gap: var(--space-3);
	animation: slideInNotice 0.3s var(--ease-in-out);
	box-shadow: 0 2px 8px rgba(241, 90, 36, 0.1);
}

.form-validation-notice.error::before {
	content: '!';
	display: flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	background: var(--color-orange-accent);
	color: var(--color-white);
	font-family: var(--font-mono);
	font-size: var(--text-sm);
	font-weight: 700;
	border-radius: 50%;
	flex-shrink: 0;
}

/* Success Notice */
.form-validation-notice.success {
	background: rgba(40, 167, 69, 0.08);
	border-left: 4px solid #4CAF50;
	border-top: 1px solid rgba(40, 167, 69, 0.2);
	border-right: 1px solid rgba(40, 167, 69, 0.2);
	border-bottom: 1px solid rgba(40, 167, 69, 0.2);
	box-shadow: 0 2px 8px rgba(40, 167, 69, 0.1);
}

/* Remove pseudo-element for success - using Material Icon instead */
.form-validation-notice.success::before {
	display: none;
}

.form-validation-notice.success .success-icon {
	font-size: 28px;
	color: #4CAF50;
	flex-shrink: 0;
	line-height: 1;
}

.form-validation-notice .notice-text {
	flex: 1;
}

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

/* Spinning Animation for Loading State */
@keyframes spin {
	from {
		transform: rotate(0deg);
	}
	to {
		transform: rotate(360deg);
	}
}

.spinning {
	animation: spin 1s linear infinite;
}

/* Button Spinner - Loading State */
.btn-spinner {
	font-size: 24px;
	line-height: 1;
	vertical-align: middle;
	animation: spin 1s linear infinite;
}

/* Ensure submit button content is centered during loading */
.btn-submit {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	gap: var(--space-2);
}

.btn-submit span {
	display: inline-flex;
	align-items: center;
	line-height: 1;
}

.btn-submit .material-icons-outlined {
	font-size: 24px;
	line-height: 1;
}

/* === RESPONSIVE STYLES === */
@media (max-width: 1024px) {
	.process-container {
		grid-template-columns: 1fr !important;
		gap: var(--space-12);
	}

	.process-container.full-width {
		grid-template-columns: 1fr !important;
		max-width: 100%;
	}

	.process-container.full-width .process-left {
		display: none;
	}

	.process-container.full-width .process-right {
		width: 100%;
		max-width: 100%;
	}

	.process-right {
		position: relative;
		top: 0;
	}

	.layout-toggle-btn {
		display: none !important;
	}
}

@media (max-width: 768px) {
	.wp-block-b8lab-project-steps.section-custom-process {
		padding-top: var(--space-12);
		padding-bottom: var(--space-12);
	}

	.process-title {
		font-size: var(--text-3xl);
	}

	.accordion-header {
		padding: var(--space-4);
	}

	.accordion-icon {
		width: 32px;
		height: 32px;
		font-size: var(--text-xl);
	}

	.accordion-title {
		font-size: var(--text-lg);
	}

	.accordion-content p {
		padding: 0 var(--space-4) var(--space-4) calc(var(--space-4) + 32px + var(--space-3));
		font-size: var(--text-sm);
	}

	.process-right {
		padding: var(--space-8);
	}

	.option-grid {
		grid-template-columns: 1fr;
	}

	.step-header {
		gap: var(--space-2);
	}

	.step-icon {
		font-size: 28px;
	}

	.step-title {
		font-size: var(--text-lg);
	}

	.form-row {
		grid-template-columns: 1fr;
	}

	/* Fix: Remove translateX animation on mobile to prevent left gap */
	.form-step {
		animation: fadeInStepMobile 0.4s ease-out forwards;
	}

	@keyframes fadeInStepMobile {
		from {
			opacity: 0;
		}
		to {
			opacity: 1;
		}
	}

	/* Ensure full-width form takes 100% without offset */
	.process-container.full-width .process-right {
		width: 100%;
		max-width: 100%;
	}

	.process-container.full-width .form-step {
		width: 100%;
		transform: none;
	}
}

@media (max-width: 480px) {
	.wp-block-b8lab-project-steps.section-custom-process {
		padding: var(--space-16) var(--space-6) var(--space-16);
	}

	.process-right {
		padding: var(--space-6);
	}

	.step-header {
		flex-direction: column;
		align-items: flex-start;
	}

	.form-navigation {
		flex-direction: column;
		gap: 0 !important;
	}

	.form-navigation .btn {
		width: 100%;
	}
}

/* === reCAPTCHA BRANDING === */
.wp-block-b8lab-project-steps .recaptcha-branding {
	margin-top: var(--space-4);
	font-size: var(--text-xs);
	color: var(--text-tertiary);
	text-align: center;
	line-height: 1.5;
}

.wp-block-b8lab-project-steps .recaptcha-branding a {
	color: var(--text-tertiary);
	text-decoration: underline;
}

.wp-block-b8lab-project-steps .recaptcha-branding a:hover {
	color: var(--text-secondary);
}
