
/*==========================================
 GABCA3.0 CSS Bootstrap based
==========================================*/

/*by @behrmart aka Tu Padre Y GABCA*/

/* GABCA3.0 Base Colors SAFE WEB COLORS
Colores: 
color: #6600cc 
*/


/* -------------------- GABCA2.0 Font faces --------------------------*/


/* 
-------------------- 
HTML doc & Body 
--------------------
*/

html, body {
	font-family: 'Quicksand', sans-serif;
	height: 100%;
	width: 100%;
	color: #6600cc ;
	overflow-x: hidden;
		}

h1 {
	font-size: 4em;
	font-weight: normal;
	line-height: 1.08;
}

h2 {
	font-size: 3em;
	font-weight: bold;
	line-height: 1.1;
}

h3 {
	font-size: 2em;
	font-weight: lighter;
	line-height: 1.35;
}

h4 {
	font-size: 1em;
	font-weight: bold;
}

h5 {
	font-size: 1em;
	font-weight: normal;
}

p {
	font-size: 1em;
	font-weight: lighter;
}


.whitetext {
	color: #fff;
}

a {
	color: #6600cc /*so link doesnt appear blue on mobile*/
}

a:hover {
	color: #6600cc;
}



/* 
-------------------- 
Bootstrap Navbar
--------------------
*/


.navbar {
	padding: .3rem;
	background-color: #000; 
	color: #fff;
	border-color: #fff !important;
}


.navbar-nav li {
	padding-right: 20px;
}

.nav-link {
	font-size: 1rem !important;
	color: #fff;
}

.navbar-inverse .navbar-toggle .icon-bar {
	color: #fff !important;
	border-color: #fff !important;
}

/* 
-------------------- 
GABCA2.0 Hero
--------------------
*/

.gabcahero {
	background-image: linear-gradient(to right, rgba(255,255,255,0), rgba(255,255,255,0), rgba(255,255,255,0)), url("../img/FOTO-PRINCIPAL.jpg");
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  position: relative;
  min-height: calc(100vh - 52px);
  min-height: calc(100svh - 52px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  overflow: hidden;
}

.gabcahero .row,
.quienessomos .row,
.mosaico .row {
	margin-left: 0;
	margin-right: 0;
}

.hero-logo-row {
	padding: clamp(1.75rem, 5vw, 4rem) 1rem 0;
}

.hero-logo {
	width: min(72vw, 380px);
	filter: drop-shadow(0 0.75rem 1.5rem rgba(102, 0, 204, 0.12));
}

.hero-copy {
	padding: clamp(1rem, 3vw, 2rem) 1.25rem clamp(1.75rem, 4vw, 3rem);
}

.hero-title {
	font-size: clamp(2.4rem, 7vw, 4rem);
	letter-spacing: 0;
}

.hero-subtitle {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 0.35rem 0.7rem;
	max-width: 860px;
	margin: 0 auto !important;
	font-size: clamp(1.1rem, 3.2vw, 2rem);
	letter-spacing: 0;
}

.hero-separator {
	color: #9966cc;
	font-weight: bold;
}

.hero-projects {
	width: 100%;
	margin-top: auto;
	padding-top: clamp(1rem, 3vw, 2.25rem);
}

.hero-projects-label {
	padding: 0.45rem 1rem;
}

.cintanegra {
	background-color: #000;
	color: #fff;
}


.quienessomos {
	background-image: linear-gradient(to right, rgba(12, 7, 18, 0.78), rgba(12, 7, 18, 0.72)), url("../img/FOTO10.jpg");
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  position: relative;
  color: #fff;
  overflow: hidden;
}

.quienessomos-content {
	max-width: 1040px;
	margin: 0 auto;
	padding: clamp(3rem, 8vw, 6rem) clamp(1rem, 4vw, 2.5rem) clamp(1.5rem, 4vw, 3rem);
}

.quienes-title {
	color: #caa7ef;
	font-size: clamp(2rem, 5vw, 3rem);
	font-weight: lighter;
	line-height: 1.1;
	margin: 0;
	padding: clamp(1rem, 3vw, 1.6rem) 0 clamp(0.65rem, 2vw, 1rem);
}

.quienes-text,
.quienes-list,
.quienes-steps {
	max-width: 860px;
	margin: 0 auto;
	font-size: clamp(1.08rem, 2.3vw, 1.5rem);
	font-weight: lighter;
	line-height: 1.55;
}

.quienes-list,
.quienes-steps {
	padding: 0;
}

.quienes-list {
	display: grid;
	gap: 0.25rem;
	list-style: none;
}

.quienes-steps {
	display: grid;
	gap: 0.55rem;
	list-style-position: inside;
}

.quienes-dots {
	display: flex;
	justify-content: center;
	gap: 0.85rem;
	color: #caa7ef;
	font-size: 1.25rem;
	line-height: 1;
	margin: clamp(1rem, 3vw, 1.6rem) 0 clamp(0.65rem, 2vw, 1rem);
}

.quienessomos-action {
	position: relative;
	z-index: 1;
	padding: 0 1rem clamp(2rem, 5vw, 3rem);
}


.containerimg {
  position: relative;
  overflow: hidden;
}

body.mosaic-animations-ready .mosaico .containerimg[data-mosaic] {
	opacity: 0;
	transform-style: preserve-3d;
	transition: opacity 0.7s ease, transform 0.9s ease;
	will-change: opacity, transform;
}

body.mosaic-animations-ready .mosaico .containerimg[data-mosaic="flip-up"] {
	transform: perspective(1200px) rotateX(-82deg);
}

body.mosaic-animations-ready .mosaico .containerimg[data-mosaic="flip-down"] {
	transform: perspective(1200px) rotateX(82deg);
}

body.mosaic-animations-ready .mosaico .containerimg[data-mosaic="flip-left"] {
	transform: perspective(1200px) rotateY(-82deg);
}

body.mosaic-animations-ready .mosaico .containerimg[data-mosaic="flip-right"] {
	transform: perspective(1200px) rotateY(82deg);
}

body.mosaic-animations-ready .mosaico .containerimg[data-mosaic].mosaic-visible {
	opacity: 1;
	transform: perspective(1200px) rotateX(0) rotateY(0);
}

@media (prefers-reduced-motion: reduce) {
	body.mosaic-animations-ready .mosaico .containerimg[data-mosaic] {
		opacity: 1;
		transform: none;
		transition: none;
	}
}

/* 
-------------------- 
Image Overlay
--------------------
*/

.image {
  display: block;
  width: 100%;
  height: auto;
}

.overlay {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  height: 100%;
  width: 100%;
  opacity: 0;
  transition: .7s ease;
  background-color: #6600cc;
}

.containerimg:hover .overlay {
  opacity: 1;
}

.text {
  color: white;
  font-size: 20px;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  text-align: center;
}



/* 
-------------------- 
Bootstrap Buttons
--------------------
*/


.btn-primary, .btn-primary:hover, .btn-primary:active, .btn-primary:visited {
    background-color: #6600cc !important;
    border-color: #9966cc !important;
}


/* 
-------------------- 
FOOTER
--------------------
*/

footer{
	background-color: #000;
	color: #fff;
}


footer a {
	color: #6600cc; /*so link doesnt appear blue on mobile*/
}

footer a:hover {
	color: #fff;
}







/*-----------------------------------------------------------------------------
Media Queries 
-------------------------------------------------------------------------------*/

/* 
-------------------- 
LARGE
--------------------
*/
@media (max-width: 992px) {

	html, body {
	font-size: large;
	}
  }

@media (max-width: 800px) {	          /* ----------kindle fire HDX* --------------*/
  	.carouselprev1 {
  		width:70%;
  	}
}
 
/* 
-------------------- 
MEDIUM
--------------------
*/  
@media (max-width: 768px) {    /*--------------- iPad -----------------------*/

	
	.menufooter1 {
		text-align: center;
	}

	.menufooter2 {
		text-align: center;
	}	

	.menufooter3 {
		text-align: center;
	}
	
}

/* 
-------------------- 
SMALL
--------------------
*/

@media (max-width: 576px) { /*--------------- iPhone -----------------------*/
  
	
	.menufooter1 {
		text-align: center;
	}

	.menufooter2 {
		text-align: center;
	}	

	.menufooter3 {
		text-align: center;
	}


}


/*---Firefox Bug Fix --*/
.carousel-item {
  transition: -webkit-transform 0.5s ease;
  transition: transform 0.5s ease;
  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
  -webkit-backface-visibility: visible;
  backface-visibility: visible;
}
/*--- Fixed Background Image --*/
figure {
  position: relative;
  width: 100%;
  height: 60%;
  margin: 0 !important;
}
.fixed-wrap {
  clip: rect(0, auto, auto, 0);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

#fixed {
  background-image: url('img/bg1.jpg');
  position: fixed;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center center;
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
  will-change: transform;
}
/*--- Bootstrap Padding Fix --*/
[class*="col-"] {
    padding: 1rem;
}

.gabcahero [class*="col-"],
.quienessomos [class*="col-"],
.mosaico [class*="col-"] {
	padding: 0;
}

@media (max-width: 767.98px) {
	.gabcahero {
		background-position: 54% center;
	}

	.hero-logo-row {
		padding-top: clamp(1.5rem, 8vw, 2.25rem);
	}

	.hero-logo {
		width: min(62vw, 240px);
	}

	.hero-copy {
		padding: 0.9rem 1rem 1.45rem;
	}

	.hero-title {
		max-width: 8.5em;
		margin-left: auto !important;
		margin-right: auto !important;
		font-size: clamp(2.05rem, 10vw, 2.8rem);
	}

	.hero-subtitle {
		flex-direction: column;
		gap: 0.25rem;
		font-size: clamp(1rem, 4.7vw, 1.18rem);
		line-height: 1.3;
	}

	.hero-separator {
		display: none;
	}

	.hero-projects {
		padding-top: 0.9rem;
	}

	.hero-projects-label {
		padding: 0.55rem 1rem;
	}

	.quienessomos {
		background-image: linear-gradient(to right, rgba(12, 7, 18, 0.86), rgba(12, 7, 18, 0.82)), url("../img/FOTO10.jpg");
		background-position: 58% center;
	}

	.quienessomos-content {
		padding: 2.6rem 1.1rem 1.4rem;
	}

	.quienes-title {
		font-size: clamp(1.9rem, 8vw, 2.35rem);
		padding: 0.95rem 0 0.6rem;
	}

	.quienes-text,
	.quienes-list,
	.quienes-steps {
		max-width: 34rem;
		font-size: clamp(1.02rem, 4.5vw, 1.15rem);
		line-height: 1.55;
	}

	.quienes-steps {
		padding-left: 1.25rem;
		list-style-position: outside;
		text-align: left;
	}

	.quienes-dots {
		margin: 1rem 0 0.6rem;
	}

	.quienessomos-action {
		padding: 0.4rem 1rem 2.25rem;
	}

	.quienessomos-action .btn {
		display: block;
		width: min(100%, 18rem);
		margin: 0 auto;
	}
}

@media (max-width: 360px) {
	.hero-title {
		font-size: 1.95rem;
	}

	.hero-logo {
		width: min(64vw, 220px);
	}
}



/*
Extra small (xs) devices (portrait phones, less than 576px)
No media query since this is the default in Bootstrap

Small (sm) devices (landscape phones, 576px and up)
@media (min-width: 576px) { ... }

Medium (md) devices (tablets, 768px and up)
@media (min-width: 768px) { ... }

Large (lg) devices (desktops, 992px and up)
@media (min-width: 992px) { ... }

Extra (xl) large devices (large desktops, 1200px and up)
@media (min-width: 1200px) { ... }
*/
