/* FUENTE Gotham */
@font-face {
  font-family: 'Gotham';
  src: url('fonts/Gotham-Black.ttf');
  font-weight: bolder;
  font-style: normal;
}

@font-face {
  font-family: 'Gotham';
  src: url('fonts/Gotham-Bold.ttf');
  font-weight: bold;
  font-style: normal;
}

@font-face {
  font-family: 'Gotham';
  src: url('fonts/Gotham-Regular.ttf');
  font-weight: normal;
  font-style: normal;
}
/* FUENTE Gotham */

html {
  scroll-behavior: smooth;
}

body {
  font-family: 'Gotham';
  font-smooth: always;
}

* {
    scrollbar-width: thin;
    scrollbar-color: #102C54 #e8e8e8;
}

.feature-box {
    border: 2px solid #102C54;
    border-radius: 10px;
    height: 210px;
    padding: 6px;
}

/* Ajustes */
.page-header {
  background-color: #102C54;
}

.border-primary {
  border-color: #253f66 !important;
}

a:focus {
    color: #102C54;
}

a:hover {
    color: #546c8f;
}

#cc-main .cm__btn, #cc-main .pm__btn {
  background: #102C54 !important;
}

#cc-main .cm__btn--secondary, #cc-main .pm__btn {
  color: #FFFFFF !important;
}

.bg-gradient {
    background-color: #102C54 !important;
    background-image: linear-gradient(to right, #114ea3 0%, #102C54 100%) !important;
}

#footer {
  margin-top: 20px;
}

/* Contenido de gecsa-style.css */
.custom-bg-color-grey-1 {
	background-color: #f8f9fb;
}

.overlay-tertiary:before {
	background: var(--tertiary);
}

.custom-font-size-1 {
	font-size: 80px;
}

p, .text-color-gecsa, h1, h2, h3, h4, h5, h6 {
	color: #102C54;
}

.text-color-gecsa-alt {
	color: #F86C00;
}

.custom-heading-1 {
	-webkit-text-fill-color: transparent;
	-webkit-text-stroke-width: 0.5px;
	-webkit-text-stroke-color: #CCC;
	white-space: nowrap;
	font-size: 80px;
	font-weight: bold;
	letter-spacing: 1px;
}

.custom-stroke-text-effect-1 {
	-webkit-text-fill-color: transparent;
	-webkit-text-stroke-width: 1px;
	-webkit-text-stroke-color: #FFF;
	white-space: nowrap;
}

.custom-text-pos-1 {
	left: -80px;
}

.custom-text-pos-2 {
	right: -80px;
}

.custom-text-pos-3 {
	left: -10%;
	top: 45%;
}

.custom-drop-caps .custom-drop-caps-number {
	font-weight: bold;
	float: left;
	font-size: 90px;
	line-height: 90px;
	padding: 0;
	margin-right: 15px;
	margin-top: 0;
}

.custom-vr-1 {
	width: 6px;
	height: 70px;
}

.custom-carousel-1-wrapper {
	margin-top: -48px;
	margin-bottom: -100px;
	position: relative;
	z-index: 1;
	min-height: 300px;
}

.custom-carousel-1 .owl-stage-outer .owl-item {
	padding: 20px 2px 40px 18px;
}

.custom-carousel-1 .owl-stage-outer .owl-item .card {
	transition: all 0.1s ease-in-out;
}

.custom-carousel-1 .owl-stage-outer .owl-item.active .card {
	box-shadow: 0 0px 20px rgba(0, 0, 0, 0.05);
}

.custom-carousel-1 .owl-carousel.nav-bottom.nav-bottom-align-left .owl-nav {
	position: absolute;
	top: 73px;
	left: -78px;
}

.thumb-info-title-gecsa, .thumb-info-action-icon-gecsa {
	background: rgba(16, 44, 84, 0.8) !important;
}

.thumb-info-title-gecsa:hover, .thumb-info-action-icon-gecsa:hover {
	background: rgba(16, 44, 84, 0.9) !important;
}

.circle-gecsa {
	background: rgba(16, 44, 84, 0.7) !important;
    border-radius: 50%;
    display: inline-block;
    width: 26px;
    height: 26px;
    text-align: center;
    font-size: 12px;
    color: #ffffff;
    font-weight: bold;
}

.gecsa-home-button .feature-box {
	background-color: #FFFFFF !important;
	color: #102C54 !important;
	transition: all 0.3s ease;
	cursor: default;
}

.gecsa-home-button .feature-box h3 {
	transition: color 0.3s ease;
}

.gecsa-home-button:hover .feature-box {
	background-color: #102C54 !important;
	color: #FFFFFF !important;
	transform: translateY(-5px);
	box-shadow: 0 10px 20px rgba(0,0,0,0.2);
}

.gecsa-home-button:hover .feature-box h3 {
	color: #FFFFFF !important;
}

.gecsa-product-button .card-body, .gecsa-product-button .card-text, .gecsa-product-button:hover .circle-gecsa {
	background-color: #FFFFFF !important;
	color: #102C54 !important;
}

.gecsa-product-button:hover .card-body, .gecsa-product-button:hover .card-text {
	background-color: #102C54 !important;
	color: #FFFFFF !important;
	text-decoration: none !important;
}

.bottom-80 {
	bottom: 80% !important;
}

.thumb-info .thumb-info-title {
	bottom: 20%;
}

.gecsa-product-select {
	border: 2px solid #e8e8e8;
	border-radius: 6px;
	max-height:500px;
	overflow: auto;
}

.gecsa-product-select .card-body {
	padding: 6px;
}

.gecsa-product-select h4 {
	line-height: 18px;
}

.gecsa-product-select p {
	line-height: 14px;
}

.gecsa-product-select a:hover {
	text-decoration: none !important;
}


/* Modern Carousel Items */
.gecsa-modern-carousel .thumb-info {
    border: 1px solid rgba(0,0,0,.08) !important;
    border-radius: 14px !important;
    box-shadow: 0 10px 30px rgba(0,0,0,.06);
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
    overflow: hidden;
    display: block; /* Ensure it behaves like a block for the card effect */
    background: #fff;
}

.gecsa-modern-carousel .thumb-info:hover {
    transform: translateY(-3px);
    box-shadow: 0 14px 40px rgba(0,0,0,.10);
    border-color: rgba(0,0,0,.12) !important;
}

.gecsa-modern-carousel .thumb-info img {
    border-radius: 14px 14px 0 0; /* Optional: if we want the image to look like a card header, but overflow:hidden on parent handles it usually. Keeping it simple. */
    transition: transform 0.3s ease;
}

.gecsa-modern-carousel .thumb-info:hover img {
    transform: scale(1.03);
}

/* RESPONSIVE */
@media (max-width: 768px) {
  .feature-box {
    height: auto;
  }
	.owl-carousel .owl-nav button.owl-next:before {
	  left: -20px;
	}
	.sector-proyectos-referencia .card {
		height: 260px;
	}
	.gecsa-sector-botones a {
		width: 100%;
	}
}

@media (max-width: 991px) {
	.custom-carousel-1-wrapper {
		margin-top: -143px;
	}
	#header .header-logo img {
		max-width: 245px;
		height: auto;
	}
	.custom-heading-1 {
		font-size: 50px;
	}
	.custom-carousel-1 .owl-carousel.nav-bottom.nav-bottom-align-left {
		position: relative;
		top: 20px;
		width: 100% !important;
		padding-right: 20px;
	}
	.gecsa-home-video p {
	    line-height: normal;
	    text-align: center;
	}
}