:root {
	--ramsua-orange: #ff6600;
	/* CMYK 0,60,100,0 approximation */
	--ramsua-charcoal: #333333;
	/* 80% black */
	--font-ui: "Rubik", system-ui, -apple-system, Segoe UI, sans-serif;
}

body {
	font-family: var(--font-ui);
	line-height: 1.55;
}

h1,
h2,
h3 {
	font-weight: 700;
	letter-spacing: -.5px;
}

body {
	font-family: "Lato", sans-serif;
	color: var(--ramsua-charcoal);
	scroll-behavior: smooth;
}

.navbar-brand span {
	font-weight: 600;
	color: var(--ramsua-orange);
}

.hero {
	background: linear-gradient(135deg,
			rgba(0, 0, 0, 0.55),
			rgba(0, 0, 0, 0.55)),
		/* url("https://ramsua.mx/wp-content/uploads/2025/01/28-ene-ramsua-hor-6.jpg"); */
		url("../img/bg.png");
	background-size: cover;
	background-position: center;
	min-height: 100vh;
	display: flex;
	align-items: center;
	color: #fff;
}

.hero-title {
	font-size: 3rem;
}

.divider {
	width: 60px;
	height: 4px;
	background: var(--ramsua-orange);
	margin: 1rem 0;
}

.section-padding {
	padding: 5rem 0;
}

.icon-box {
	max-width: 350px;
	padding: 2rem;
	border-radius: 1rem;
	background: #fff;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.05);
	transition: transform 0.3s ease;
}

.icon-box:hover {
	transform: translateY(-8px);
}

.contact-section {
	background: var(--ramsua-orange);
	color: #fff;
}

footer {
	background: #111;
	color: #bbb;
	padding: 2rem 0;
	font-size: 0.9rem;
}

.form-label {
	color: var(--ramsua-charcoal);
}

.btn-primary {
	background-color: var(--ramsua-orange);
	border-color: var(--ramsua-orange);
}

.btn-primary:hover {
	background-color: #e65c00;
	border-color: var(--ramsua-orange);
}

.btn-outline-primary {
	background-color: transparent;
	color: var(--ramsua-orange);
	border-color: var(--ramsua-orange);
	--bs-btn-color: var(--ramsua-orange);
	--bs-btn-border-color: var(--ramsua-orange);
	--bs-btn-hover-color: #fff;
	--bs-btn-hover-bg: var(--ramsua-orange);
	--bs-btn-hover-border-color: var(--ramsua-orange);
	--bs-btn-focus-shadow-rgb: 13, 110, 253;
	--bs-btn-active-color: #fff;
	--bs-btn-active-bg: var(--ramsua-orange);
	--bs-btn-active-border-color: var(--ramsua-orange);
	--bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
	--bs-btn-disabled-color: var(--ramsua-orange);
	--bs-btn-disabled-bg: transparent;
	--bs-btn-disabled-border-color: var(--ramsua-orange);
	--bs-gradient: none;
}

.btn-outline-primary:hover {
	background-color: rgba(255, 102, 0, 0.1);
	color: var(--ramsua-orange);
	border-color: var(--ramsua-orange);
}

.address {
	color: #fff;
	text-decoration: none;
}

#proyectos1 .card-img-top {
	width: 100%;
	aspect-ratio: 16/9;
	object-fit: cover;
	object-position: center;
}

@supports not (aspect-ratio:1) {
	#proyectos1 .card-img-top {
		height: 240px;
	}
}


/* ===== Galería tipo mosaico ===== */

.proyectos-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	grid-auto-rows: 150px;
	/* altura base de cada fila */
	gap: 16px;
	grid-auto-flow: dense;
	/* rellena huecos como en el ejemplo */
}

/* Tamaños de los bloques */
.proyecto-item--big {
	grid-column: span 2;
	grid-row: span 2;
}

.proyecto-item--wide {
	grid-column: span 2;
}

.proyecto-item--tall {
	grid-row: span 2;
}

/* Responsivo */
@media (max-width: 1199.98px) {
	.proyectos-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		grid-auto-rows: 160px;
	}
}

@media (max-width: 991.98px) {
	.proyectos-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		grid-auto-rows: 180px;
	}
}

@media (max-width: 575.98px) {
	.proyectos-grid {
		grid-template-columns: 1fr;
		grid-auto-rows: 220px;

		/* Opcional: desactiva spans en móvil para hacerlo más simple */
		.proyecto-item--big,
		.proyecto-item--wide,
		.proyecto-item--tall {
			grid-column: span 1;
			grid-row: span 1;
		}
	}
}

/* Tarjeta / imagen */

.proyecto-card {
	position: relative;
	width: 100%;
	height: 100%;
	border-radius: 1rem;
	overflow: hidden;
	box-shadow: 0 10px 25px rgba(0, 0, 0, 0.08);
	background-color: #111;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.proyecto-card img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.45s ease;
}

.proyecto-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 18px 40px rgba(0, 0, 0, 0.18);
}

.proyecto-card:hover img {
	transform: scale(1.04);
}

/* Overlay de texto */

.proyecto-overlay {
	position: absolute;
	inset: auto 0 0 0;
	padding: 0.75rem 1rem 1rem;
	background: linear-gradient(to top,
			rgba(0, 0, 0, 0.75),
			transparent);
	color: #fff;
}

.proyecto-overlay h5 {
	font-size: 0.95rem;
	margin-bottom: 0.25rem;
	font-weight: 600;
}

.proyecto-overlay p {
	font-size: 0.75rem;
	margin: 0;
	opacity: 0.9;
}


/* Tabs / pills de Ramsua */
.nav-pills .nav-link {
	color: var(--ramsua-orange);
	/* texto naranja cuando NO está activo */
	border-radius: 999px;
	font-weight: 500;
}

.nav-pills .nav-link:hover {
	color: var(--ramsua-orange);
	/* un poquito más oscuro al hover */
}

/* Estado activo (el que ves azul en tu captura) */
.nav-pills .nav-link.active,
.nav-pills .show>.nav-link {
	background-color: var(--ramsua-orange);
	/* fondo naranja */
	color: #fff;
	/* texto blanco */
}