/**
 * Fábrica de Software — RF13 + RF14.
 */

.site-main--fabrica .portal-fabrica-body {
	max-width: var(--portal-max-width);
	margin: 0 auto;
	padding: 0 var(--portal-space) 2.5rem;
}

.portal-fabrica-header__badge {
	display: inline-block;
	margin: 0 0 0.5rem;
	padding: 0.25rem 0.65rem;
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--color-secondary, #0c326f);
	background: var(--color-highlight, #ffcd07);
	border-radius: 2px;
}

/* Destaques */
.portal-fabrica-highlights {
	margin-bottom: 2.25rem;
}

.portal-fabrica-highlights__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1rem;
}

.portal-fabrica-highlights__item {
	padding: 1rem;
	text-align: center;
	background: #fff;
	border: 1px solid #e3e8ef;
	border-radius: 4px;
}

.portal-fabrica-highlights__value {
	display: block;
	font-family: var(--font-heading);
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--color-secondary, #0c326f);
	line-height: 1.2;
}

.portal-fabrica-highlights__label {
	display: block;
	margin-top: 0.35rem;
	font-size: 0.8125rem;
	line-height: 1.35;
	color: #555;
}

/* Secções */
.portal-fabrica-section {
	margin-bottom: 2.5rem;
}

.portal-fabrica-section__title {
	margin: 0 0 0.75rem;
	font-family: var(--font-heading);
	font-size: 1.375rem;
	font-weight: 700;
	color: var(--color-secondary, #0c326f);
	border-bottom: 3px solid var(--color-highlight, #ffcd07);
	padding-bottom: 0.35rem;
}

.portal-fabrica-section__intro,
.portal-fabrica-section__text {
	margin: 0 0 1rem;
	font-size: 0.9375rem;
	line-height: 1.6;
	color: #333;
	max-width: 48rem;
}

/* Metodologia */
.portal-fabrica-steps {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 1rem;
}

.portal-fabrica-steps__item {
	display: grid;
	grid-template-columns: 2.5rem 1fr;
	gap: 1rem;
	align-items: start;
	padding: 1rem 1.1rem;
	background: #f8f9fb;
	border-left: 4px solid var(--color-secondary, #0c326f);
	border-radius: 0 4px 4px 0;
}

.portal-fabrica-steps__number {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 2.5rem;
	height: 2.5rem;
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: 1.125rem;
	color: #fff;
	background: var(--color-secondary, #0c326f);
	border-radius: 50%;
}

.portal-fabrica-steps__title {
	margin: 0 0 0.35rem;
	font-size: 1rem;
	font-weight: 700;
	color: var(--color-secondary, #0c326f);
}

.portal-fabrica-steps__text {
	margin: 0;
	font-size: 0.9375rem;
	line-height: 1.55;
	color: #444;
}

/* Cards tipos de projeto */
.portal-fabrica-cards {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1rem;
}

.portal-fabrica-cards__item {
	padding: 1.1rem 1.15rem;
	background: #fff;
	border: 1px solid #e3e8ef;
	border-radius: 4px;
}

.portal-fabrica-cards__title {
	margin: 0 0 0.5rem;
	font-size: 1rem;
	font-weight: 700;
	color: var(--color-secondary, #0c326f);
}

.portal-fabrica-cards__text {
	margin: 0;
	font-size: 0.875rem;
	line-height: 1.5;
	color: #555;
}

/* Equipe */
.portal-fabrica-roles {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
}

.portal-fabrica-roles__item {
	padding: 1rem;
	background: #fff;
	border: 1px solid #e3e8ef;
	border-radius: 4px;
}

.portal-fabrica-roles__title {
	margin: 0 0 0.45rem;
	font-size: 0.9375rem;
	font-weight: 700;
	color: var(--color-secondary, #0c326f);
}

.portal-fabrica-roles__text {
	margin: 0;
	font-size: 0.875rem;
	line-height: 1.5;
	color: #555;
}

/* Portfólio */
.portal-fabrica-section.portal-fabrica-portfolio {
	margin-top: 0.5rem;
}

section.portal-fabrica-portfolio > .portal-fabrica-portfolio__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 1.25rem;
}

.portal-fabrica-project {
	padding: 0;
	overflow: hidden;
	background: #fff;
	border: 1px solid #e3e8ef;
	border-radius: 4px;
}

.portal-fabrica-project__media {
	aspect-ratio: 16 / 9;
	background: #eef2f8;
	overflow: hidden;
}

.portal-fabrica-project__photo {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.portal-fabrica-project__body {
	padding: 1.25rem 1.35rem;
}

.portal-fabrica-project__actions {
	margin: 1rem 0 0;
}

.site-main--fabrica .portal-fabrica-project__link.portal-btn--secondary {
	background: #fff;
	color: var(--color-secondary, #0c326f);
	border-color: var(--color-secondary, #0c326f);
	font-size: 0.875rem;
}

.site-main--fabrica .portal-fabrica-project__link.portal-btn--secondary:hover,
.site-main--fabrica .portal-fabrica-project__link.portal-btn--secondary:focus-visible {
	background: var(--color-secondary, #0c326f);
	color: #fff;
}

.portal-fabrica-portfolio-empty {
	padding: 1.5rem;
	text-align: center;
	background: #f8f9fb;
	border: 1px dashed #c5ced9;
	border-radius: 4px;
}

.portal-fabrica-portfolio-empty p {
	margin: 0 0 1rem;
	color: #444;
}

.portal-fabrica-project__head {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	justify-content: space-between;
	gap: 0.5rem;
	margin-bottom: 0.65rem;
}

.portal-fabrica-project__name {
	margin: 0;
	font-family: var(--font-heading);
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--color-secondary, #0c326f);
}

.portal-fabrica-project__year {
	font-size: 0.8125rem;
	font-weight: 600;
	color: #666;
	background: #eef2f8;
	padding: 0.2rem 0.55rem;
	border-radius: 999px;
}

.portal-fabrica-project__desc {
	margin: 0 0 1rem;
	font-size: 0.9375rem;
	line-height: 1.55;
	color: #333;
}

.portal-fabrica-project__meta {
	margin: 0;
	display: grid;
	gap: 0.5rem;
}

.portal-fabrica-project__row {
	display: grid;
	grid-template-columns: 6.5rem 1fr;
	gap: 0.5rem 1rem;
	font-size: 0.875rem;
}

.portal-fabrica-project__row dt {
	margin: 0;
	font-weight: 700;
	color: var(--color-secondary, #0c326f);
}

.portal-fabrica-project__row dd {
	margin: 0;
	color: #444;
}

/* Parceria */
.portal-fabrica-partnership {
	margin-bottom: 2.75rem;
	padding: 1.5rem 1.5rem 1.6rem;
	background: #fff8e6;
	border: 1px solid #e8c84a;
	border-left: 4px solid var(--color-highlight, #ffcd07);
	border-radius: 4px;
}

.portal-fabrica-partnership .portal-fabrica-section__title {
	margin-bottom: 1rem;
}

.portal-fabrica-partnership__list {
	margin: 0;
	padding-left: 1.35rem;
	font-size: 0.9375rem;
	line-height: 1.65;
	color: #333;
}

.portal-fabrica-partnership__list li + li {
	margin-top: 0.75rem;
}

/* CTA parceria */
.portal-fabrica-cta {
	margin-top: 0.5rem;
}

.portal-fabrica-cta__inner {
	padding: 1.75rem 1.5rem;
	background: linear-gradient(135deg, #0c326f 0%, #1a4a8f 100%);
	border-radius: 4px;
	color: #fff;
}

.portal-fabrica-cta__title {
	margin: 0 0 0.65rem;
	font-family: var(--font-heading);
	font-size: 1.375rem;
	font-weight: 700;
	color: #fff;
}

.portal-fabrica-cta__text {
	margin: 0 0 1.25rem;
	font-size: 0.9375rem;
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.92);
	max-width: 42rem;
}

.portal-fabrica-cta__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.65rem;
	margin-bottom: 1rem;
}

.portal-fabrica-cta .portal-btn--primary {
	background: var(--color-highlight, #ffcd07);
	color: var(--color-secondary, #0c326f);
	border-color: var(--color-highlight, #ffcd07);
}

.portal-fabrica-cta .portal-btn--primary:hover,
.portal-fabrica-cta .portal-btn--primary:focus-visible {
	background: #fff;
	border-color: #fff;
	color: var(--color-secondary, #0c326f);
}

.portal-fabrica-cta .portal-btn--secondary {
	background: transparent;
	color: #fff;
	border-color: rgba(255, 255, 255, 0.85);
}

.portal-fabrica-cta .portal-btn--secondary:hover,
.portal-fabrica-cta .portal-btn--secondary:focus-visible {
	background: #fff;
	color: var(--color-secondary, #0c326f);
	border-color: #fff;
}

.portal-fabrica-cta__note {
	margin: 0;
	font-size: 0.8125rem;
	line-height: 1.45;
	color: rgba(255, 255, 255, 0.8);
}

@media (max-width: 900px) {
	.portal-fabrica-highlights__list {
		grid-template-columns: repeat(2, 1fr);
	}

	.portal-fabrica-roles {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 640px) {
	.portal-fabrica-highlights__list,
	.portal-fabrica-cards {
		grid-template-columns: 1fr;
	}

	.portal-fabrica-project__row {
		grid-template-columns: 1fr;
		gap: 0.15rem;
	}
}
