/* Formulário de contato — layout minimalista (referência Untitled-1) */

.stahl-contact-panel .stahl-contact-form-inner {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
	width: 100%;
}

.stahl-contact-panel .stahl-contact-form-inner label {
	display: block;
	font-size: 0.7rem;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: #737373;
	margin-bottom: 0.5rem;
}

.stahl-contact-panel .stahl-contact-form-inner .stahl-required {
	color: #dc2626;
}

.stahl-contact-panel .stahl-contact-form-inner input[type='text'],
.stahl-contact-panel .stahl-contact-form-inner input[type='email'],
.stahl-contact-panel .stahl-contact-form-inner input[type='tel'],
.stahl-contact-panel .stahl-contact-form-inner select,
.stahl-contact-panel .stahl-contact-form-inner textarea {
	width: 100%;
	padding: 0.75rem 1rem;
	border: none;
	border-bottom: 1px solid #d4d4d4;
	border-radius: 0;
	font-size: 0.95rem;
	font-family: inherit;
	background: #fff;
	color: var(--wp--preset--color--brand-dark);
	box-shadow: none;
	transition: border-color 0.2s ease;
}

.stahl-contact-panel .stahl-contact-form-inner select {
	cursor: pointer;
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23525252' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 0.75rem center;
	padding-right: 2.25rem;
}

.stahl-contact-panel .stahl-contact-form-inner input:focus,
.stahl-contact-panel .stahl-contact-form-inner select:focus,
.stahl-contact-panel .stahl-contact-form-inner textarea:focus {
	outline: none;
	border-bottom-color: var(--wp--preset--color--brand-dark);
	box-shadow: none;
}

.stahl-contact-panel .stahl-contact-form-inner .is-invalid {
	border-bottom-color: #dc2626;
}

.stahl-contact-panel .stahl-contact-form-inner button[type='submit'] {
	width: 100%;
	padding: 1rem 1.25rem;
	margin-top: 0.25rem;
	background: var(--wp--preset--color--brand-dark);
	color: var(--wp--preset--color--white);
	border: none;
	font-family: var(--wp--preset--font-family--heading);
	font-weight: 700;
	font-size: 0.75rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	cursor: pointer;
	transition: background 0.2s ease, opacity 0.2s ease;
}

.stahl-contact-panel .stahl-contact-form-inner button[type='submit']:hover:not(:disabled) {
	background: var(--wp--preset--color--brand-contrast);
	opacity: 0.95;
}

.stahl-contact-panel .stahl-contact-form-inner button[type='submit']:disabled {
	opacity: 0.65;
	cursor: not-allowed;
}

.stahl-submit-loading {
	display: none;
}

#stahl-form-message {
	display: none;
	padding: 0.85rem 1rem;
	margin-bottom: 0.5rem;
	font-size: 0.875rem;
	font-weight: 500;
	border: 1px solid transparent;
}

#stahl-form-message.success {
	display: block;
	background: #ecfdf5;
	color: #065f46;
	border-color: #10b981;
}

#stahl-form-message.error {
	display: block;
	background: #fef2f2;
	color: #991b1b;
	border-color: #f87171;
}

.stahl-field-error {
	display: none;
	color: #dc2626;
	font-size: 0.75rem;
	margin-top: 0.25rem;
	font-weight: 500;
}

.stahl-contact-panel .stahl-contact-form-inner textarea {
	resize: vertical;
	min-height: 6.5rem;
}

/* Honeypot */
.stahl-field-hp {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

/* Filtros portfólio (barra = grupo; botões podem ser blocos HTML separados) */
.stahl-portfolio-filters {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-top: 0.75rem;
	align-items: center;
}

.stahl-portfolio-filters > .wp-block-html {
	margin: 0;
}

.stahl-portfolio-filters > .wp-block-html .stahl-filter-btn {
	margin: 0;
}

.stahl-filter-btn {
	padding: 0.5rem 1rem;
	border: 1px solid rgba(10, 10, 10, 0.2);
	background: var(--wp--preset--color--white);
	color: var(--wp--preset--color--brand-contrast);
	font-family: var(--wp--preset--font-family--heading);
	font-size: 0.7rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	cursor: pointer;
	transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.stahl-filter-btn:hover,
.stahl-filter-btn.is-active {
	background: var(--wp--preset--color--brand-dark);
	color: var(--wp--preset--color--white);
	border-color: var(--wp--preset--color--brand-dark);
}

/* Contadores */
.stahl-stats-row {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--wp--preset--spacing--50);
	margin-top: var(--wp--preset--spacing--60);
	padding-top: var(--wp--preset--spacing--60);
	border-top: 1px solid rgba(10, 10, 10, 0.08);
}

@media (min-width: 782px) {
	.stahl-stats-row {
		grid-template-columns: repeat(4, 1fr);
	}
}

.stahl-stat {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
}

.stahl-counter {
	font-family: var(--wp--preset--font-family--heading);
	font-size: clamp(2rem, 5vw, 3rem);
	font-weight: 700;
	line-height: 1.1;
	color: var(--wp--preset--color--brand-dark);
}

.stahl-stat-label {
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--wp--preset--color--brand-contrast);
}
