/* 
Theme Name: Colegio Marymount Bogotá
Theme URI: https://github.com/elementor/hello-theme-child/
Description: Hello Elementor Child is a child theme of Hello Elementor, created by Elementor team
Author: Elementor Team
Author URI: https://elementor.com/
Template: hello-elementor
Version: 2.0.0
Text Domain: hello-elementor-child
License: GNU General Public License v3 or later.
License URI: https://www.gnu.org/licenses/gpl-3.0.html
Tags: flexible-header, custom-colors, custom-menu, custom-logo, editor-style, featured-images, rtl-language-support, threaded-comments, translation-ready
*/

/* Add your custom styles here */
@import url('https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,400..700;1,400..700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');
/* GENERALES */

a {color: #599BD4; text-decoration:underline;}
a:active, a:hover {color: #E37425;}
.white-link a{color:white;text-decoration:underline;}
*:focus {outline: none!important;}
html,body{
	font-size:16px;
	color:#21213E;
  	font-family: "Montserrat", sans-serif;
  	font-weight: 400;
  	font-style: normal;
	line-height: 1.5em;
	overflow-x:hidden;
}
/* CONTENEDOR ELEMENTOR */
.elementor-section.elementor-section-boxed > .elementor-container {max-width: 95%;}
/* IMAGES */
.full-img *{width:100%;}
.full-img a{display: block;}
/* TÍTULOS */
.elementor-heading-title :is(h2,h3,h4,h5,h6), h1,h2,h3,h4,h5,h6 {
  font-family: "Lora", serif;
  font-optical-sizing: auto;
  font-weight: bold;
  font-style: normal;
	color:#21213E;
}

h1, .elementor-heading-title h1{font-size:35px;font-weight:700;font-family: "Montserrat", sans-serif;}
h2, .elementor-heading-title h2{font-size:28px;}
h3, .elementor-heading-title h3{font-size:23px;}
h4, .elementor-heading-title h4{font-size:21px;}
h5, .elementor-heading-title h5{font-size:20px;}
h6, .elementor-heading-title h6{font-size:18px}

.title-bg-shape b, .title-bg-shape-2 b{
    position: relative;
	z-index:1;
}
.title-bg-shape b::before,.title-bg-shape-2 b::before  {
    content: '';
    position: absolute;
    top:0;
    left:50%;
    width:335px;
    height:150px;
    transform: translateX(-50%);
    background-image: url('https://marymount.pixelpro.one/wp-content/uploads/2025/05/forma-titulos.svg');
    background-repeat:no-repeat;
    background-size: contain;
	z-index:-1;
}
.title-bg-shape-2 b::before{
	background-image: url('https://marymount.pixelpro.one/wp-content/uploads/2025/07/forma-titulos-mas-largos.svg');
	width: 420px;
}

/* Colores */
.title-color b {
    color: #246E86;
}
/* BOTONES 	*/
.btn-icon .elementor-button-icon {
    font-size: 35px;
}
.btn-icon .elementor-button-content-wrapper {
    align-items: center;
}
.full-btn a.elementor-button {
    display: block;
}
.btn-special span.elementor-button-text {
    text-align: left;
}
.btn-special span.elementor-button-icon {
    align-items: flex-start;
}
/* IMAGES */
.corner-rounded img {
    border-top-right-radius: 60px;
    border-bottom-left-radius: 60px;
}
.line-top-r .elementor-widget-container::before {
    content: '';
      width: 70px;
      height: 70px;
      border-top: 3px solid #d6ecf7;
      border-right: 3px solid #d6ecf7;
      border-top-right-radius: 160px;
      position: absolute;
      top: -15px;
      right: -15px;
}
.line-bottom-l .elementor-widget-container::before {
    content: '';
      width: 70px;
      height: 70px;
      border-bottom: 3px solid #d6ecf7;
      border-left: 3px solid #d6ecf7;
      border-bottom-left-radius: 160px;
      position: absolute;
      bottom: -15px;
      left: -15px;
}


/* TABLE */

/* Acordeones */
.custom-ac-color svg {
    background-color: white;
    border-radius: 100%;
    padding: 5px;
    width: 1.4em !important;
    height: 1.4em !important;
    margin-top: -3px;
}
.custom-ac-color .elementor-tab-title.elementor-active {
    border-top-left-radius: 15px;
    border-top-right-radius: 15px;
}

/* Show more */
.more-content{
	display:none;
}
.elementor-editor-active .more-content{
	display:block;
}

/*  --- HEADER --- */
.menu-popup a.dialog-close-button.dialog-lightbox-close-button {
    width: 35px;
    height: 35px;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    line-height: 0;
    border-radius: 100%;
    top: 16px;
}

/* - Vertical nav- */
.vertical-nav .sub-menu[aria-expanded="true"] {
    width: 300px !important;
}


/* --- FOOTER --- */
.barra-flotante {
    position: fixed;
    right: 0;
    width: 70px !important;
    top: 250px;
    border-top-left-radius: 20px;
    border-bottom-left-radius: 20px;
}


/*  --------------- HOME ------------------- */


/* --- Full carrusel --- */

.full-carrusel .custom-carrusel .ae-post-collection.ae-swiper-container{
	padding-bottom: 60px;
}
.full-carrusel .custom-carrusel .ae-swiper-button-next, .full-carrusel .custom-carrusel .ae-swiper-button-prev{
	width:40px;
	height:40px;
	display:inline-flex;
	justify-content: center;
	align-items: center;
	border-radius: 100%;
	border: 1px solid #b0b0b0;
}
.full-carrusel .custom-carrusel .ae-swiper-button-next:hover, .full-carrusel .custom-carrusel .ae-swiper-button-prev:hover{
	background-color: #589bd4 !important;
	border-color: #589bd4 ;
}
.full-carrusel .custom-carrusel .ae-swiper-button-next:hover svg, .full-carrusel .custom-carrusel .ae-swiper-button-prev:hover svg{
	fill:white !important;
}
.video-bloque.elementor-widget-video .elementor-wrapper {
    --video-aspect-ratio: 0.8 !important;!I;!;
    border-top-right-radius: 50px;
    border-bottom-left-radius: 50px;
    overflow: hidden;
	position: relative;
}
.video-bloque.elementor-widget-video .elementor-wrapper::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: transparent linear-gradient(180deg, #00000000 0%, #000000 100%) 0% 0% no-repeat padding-box;
    mix-blend-mode: multiply;
}

/* -- Custom iamge carrusel 1 -- */
.custom-car-image img.swiper-slide-image {
    height: 100px;
    object-fit: contain;
    margin: 0 27px;
    width: 150px;
    filter: grayscale(1);
    transition: 0.3s ease-in-out;
}
.custom-car-image img.swiper-slide-image:hover{
    filter: grayscale(0);
}
.custom-car-image.elementor-element .swiper .elementor-swiper-button {
    width: 40px;
    height: 40px;
    display: inline-flex;
    border: 1px solid #c3c3c3;
    justify-content: center;
    align-items: center;
    border-radius: 100%;
    transition: 0.3s ease-in-out;
}
.custom-car-image.elementor-element .swiper .elementor-swiper-button:hover{
    background-color:#599bd4;
    border-color: #599bd4;
}
.custom-car-image.elementor-element .swiper .elementor-swiper-button svg {
    fill: #626262;
}
.custom-car-image.elementor-element .swiper .elementor-swiper-button:hover svg{
    fill: white;
}

.custom-car-image.elementor-element .swiper .elementor-swiper-button.elementor-swiper-button-prev,.custom-car-image.elementor-element .swiper .elementor-swiper-button.elementor-swiper-button-next {
    bottom: 0 !important;
    top: inherit !important;
    left: inherit !important;
    right: 70px !important;
    transform: none !important;
}
.custom-car-image.elementor-element .swiper .elementor-swiper-button.elementor-swiper-button-next {
    right: 20px !important;
}
.custom-car-image.elementor-element .elementor-image-carousel-wrapper {
    padding-bottom: 60px;
}

/* -- Custom iamge carrusel 2 -- */

.custom-car-image-2.elementor-element .swiper .elementor-swiper-button {
    background-color: white;
    padding: 7px;
    border-radius: 100%;
}
.custom-car-image-2.elementor-element .swiper .elementor-swiper-button:hover{
    background-color:#599bd4;
}

.custom-car-image-2.elementor-element .swiper .elementor-swiper-button svg{
    fill: black;
}
.custom-car-image-2.elementor-element .swiper .elementor-swiper-button:hover svg{
    fill:white;
}
.custom-car-image-2.elementor-element .swiper .elementor-swiper-button.elementor-swiper-button-prev {
    left: auto;
    right: 90px;
    top: auto;
    transform: none;
    bottom: 60px;
}

.custom-car-image-2.elementor-element .swiper .elementor-swiper-button.elementor-swiper-button-next {
    top: auto;
    transform: none;
    bottom: 60px;
    right: 40px;
}
/* -- Custom iamge carrusel 3 -- */
.custom-car-image-3 .elementor-image-carousel-wrapper img {
    border-top-right-radius: 50px;
    border-bottom-left-radius: 50px;
}

.custom-car-image-3.elementor-element .swiper .elementor-swiper-button {
    background-color: white;
    padding: 7px;
    border-radius: 100%;
}
.custom-car-image-3.elementor-element .swiper .elementor-swiper-button:hover{
    background-color:#599bd4;
}

.custom-car-image-3.elementor-element .swiper .elementor-swiper-button svg{
    fill: black;
}
.custom-car-image-3.elementor-element .swiper .elementor-swiper-button:hover svg{
    fill:white;
}

/* --- TIME LINE --- */
.tml-bar {
    width: 2px;
    background-color: #2D519E;
    height: 0;
    transition: height 0.1s ease-out;
    position: absolute;
    top: 80px;
    left: 5%;
}

/* --- TIME LINE CARRUSEL --- */
.custom-spacer .elementor-spacer-inner,.custom-spacer .elementor-spacer {
    position: relative;
}
.custom-spacer .elementor-spacer-inner::before {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    width: 1px;
    height: 100%;
    background: #599bd4;
    transform: translateX(-50%);
}
.custom-spacer .elementor-spacer::before{
    content:'';
    position:absolute;
    bottom:0;
    left:50%;
    transform:translateX(-50%);
    width:34px;
    height:34px;
    border:1px solid #599bd4;
    background-color:rgb(236 236 239);
    border-radius:100%;
    z-index:1;
}
.custom-spacer .elementor-spacer::after{
    content:'';
    position:absolute;
    bottom:13px;
    left:50%;
    transform:translateX(-50%);
    width:7px;
    height:7px;
    background-color:black;
    border-radius:100%;
    z-index:1;
}

/* --- Noticias --- */
.bloque-noticia-contenido .elementor-widget-wrap {
    background-color: white !important;
}
.share-in-blog.elementor-share-buttons--color-custom.elementor-share-buttons--skin-gradient .elementor-share-btn {
    background-color: white !important;
    border: 1px solid #589bd4;
}

.share-in-blog.elementor-share-buttons--skin-gradient.elementor-share-buttons--view-icon .elementor-share-btn__icon {
    background-color: white;
    background-image: none;

}
/* -- Admisiones -- */
.c-form-elementor .elementor-field-type-acceptance {
    display: flex;
    flex-wrap: nowrap;
    flex-flow: row-reverse;
    justify-content: flex-end;
}

.c-form-elementor  .elementor-field-type-acceptance .elementor-field-subgroup{
    width:auto;
    max-width: fit-content !important;
    padding-right:10px;
}
/* - Nuestra esencia - */
.custom-ac-color .elementor-tab-content a.btn-lef-icon {
    background-color: white;
    font-weight: 600;
    text-transform: uppercase;
    border-radius: 22px 22px 22px 22px;
    color: #589bd4;
    display: inline-block;
    font-size: 15px;
    line-height: 1;
    padding: 12px 24px 12px 50px;
    fill: #fff;
    text-align: center;
    transition: all .3s;
    position:relative;
}

.custom-ac-color .elementor-tab-content a.btn-lef-icon svg {
    background-color: transparent;
    margin-top:0;
    padding:0;
    position:absolute;
    left:25px;
    width:15px !important;
    height:15px !important;
    fill: #589bd4;
}
/* -- Menu  semanal -- */
.custom-tab .elementor-tab-title {
    border-bottom: 1px solid #21213e !important;
}

.custom-tab .elementor-tab-title.elementor-active {
    border-color: white !important;
	position:relative;
}

.custom-tab.ct-blue .elementor-tab-title.elementor-active {
    border-color: #599bd4 !important;
}
.custom-tab .elementor-tabs-wrapper {
    overflow: visible;
}
.custom-tab.ct-white .elementor-tab-title.elementor-active::before{
    content: '';
    width: 0px;
    height: 0px;
    border-style: solid;
    border-width: 10px 6px 0 6px;
    border-color: #FFFFFF transparent transparent transparent;
    transform: rotate(0deg);
    position:absolute;
    right: 0;
    bottom: -11px;
    left: 50%;
    transform: translateX(-50%);
    overflow: visible !important;
}
.custom-tab.ct-white .elementor-tab-title.elementor-active::after{
    content: '';
    width: 0px;
    height: 0px;
    border-style: solid;
    border-width: 10px 5px 0 5px;
    border-color: #599bd4 transparent transparent transparent;
    transform: rotate(0deg);
    position:absolute;
    right: 0;
    bottom: -9px;
    left: 50%;
    transform: translateX(-50%);
    overflow: visible !important;   
}
.custom-tab.ct-blue .elementor-tab-title.elementor-active::before{
    content: '';
    width: 0px;
    height: 0px;
    border-style: solid;
    border-width: 10px 6px 0 6px;
    border-color: #599bd4 transparent transparent transparent;
    transform: rotate(0deg);
    position:absolute;
    right: 0;
    bottom: -11px;
    left: 50%;
    transform: translateX(-50%);
    overflow: visible !important;
}
.custom-tab.ct-blue .elementor-tab-title.elementor-active::after{
    content: '';
    width: 0px;
    height: 0px;
    border-style: solid;
    border-width: 10px 5px 0 5px;
    border-color: #ffffff transparent transparent transparent;
    transform: rotate(0deg);
    position:absolute;
    right: 0;
    bottom: -9px;
    left: 50%;
    transform: translateX(-50%);
    overflow: visible !important;   
}
/* - monthly - */
.custom-tab.ct-blue.mont .elementor-tabs-wrapper .elementor-tab-title:nth-child(2) {
    color: #69B3B5;
}
.custom-tab.ct-blue.mont .elementor-tabs-wrapper .elementor-tab-title:nth-child(3) {
    color: #8B3E8F;
}
.custom-tab.ct-blue.mont .elementor-tabs-wrapper .elementor-tab-title:nth-child(4) {
    color: #E30B69;
}
.custom-tab.ct-blue.mont .elementor-tab-title.elementor-active{
	color: #599BD4 !important;
}
/* - table - */

thead th {
	background: #232545;
	color: #ffffff;
}
.custom-tab table{
    font-weight:400;
}
.ct-white table > tbody > tr:first-child th {
    background-color: #21213e !important;
    color: white !important;
    border-radius: 5px;
}
.ct-white table > tbody > tr:first-child th h1,
.ct-white table > tbody > tr:first-child th h2,
.ct-white table > tbody > tr:first-child th h3,
.ct-white table > tbody > tr:first-child th h4,
.ct-white table > tbody > tr:first-child th h5,
.ct-white table > tbody > tr:first-child th h6,
.ct-white table > tbody > tr:first-child th p{
    color:white;
}

.ct-white table, .ct-white table tr, .ct-white table, .ct-white table th,.ct-white table td {
    border:none;
}
.ct-white table tbody>tr td, .ct-white table tbody>tr th{
    background-color:#edf3f92b;
    border-radius: 15px;
    border:4px solid #599bd4;
}
.ct-white table tbody>tr:nth-child(odd)>td, .ct-white table tbody>tr:nth-child(odd)>th{
    background-color: white;
    border-radius: 15px;
    border:4px solid #599bd4;
}

.ct-white table > tbody > tr:first-child th {
    background-color: #21213e !important;
    color: white !important;
    border-radius: 5px;
}
.ct-white table > tbody > tr:first-child th h1,
.ct-white table > tbody > tr:first-child th h2,
.ct-white table > tbody > tr:first-child th h3,
.ct-white table > tbody > tr:first-child th h4,
.ct-white table > tbody > tr:first-child th h5,
.ct-white table > tbody > tr:first-child th h6,
.ct-white table > tbody > tr:first-child th p{
    color:white;
}

.ct-white table, .ct-white table tr, .ct-white table, .ct-white table th,.ct-white table td {
    border:none;
}
.ct-white table tbody>tr td, .ct-white table tbody>tr th{
    background-color:#edf3f92b;
    border-radius: 15px;
    border:4px solid #599bd4;
}
.ct-white table tbody>tr:nth-child(odd)>td, .ct-white table tbody>tr:nth-child(odd)>th{
    background-color: white;
    border-radius: 15px;
    border:4px solid #599bd4;
}

.ct-blue table > tbody > tr:first-child th h1,
.ct-blue table > tbody > tr:first-child th h2,
.ct-blue table > tbody > tr:first-child th h3,
.ct-blue table > tbody > tr:first-child th h4,
.ct-blue table > tbody > tr:first-child th h5,
.ct-blue table > tbody > tr:first-child th h6,
.ct-blue table > tbody > tr:first-child th p{
    color:white;
}
.ct-blue table, .ct-blue table tr, .ct-blue table, .ct-blue table th,.ct-blue table td {
    border:none;
}
.ct-blue table tbody>tr td, .ct-blue table tbody>tr th{
    background-color:#edf3f92b;
    border-radius: 15px;
    border:4px solid #599bd4;
}
.ct-blue table tbody>tr:nth-child(odd)>td, .ct-blue table tbody>tr:nth-child(odd)>th{
    background-color: white;
    border-radius: 15px;
    border:4px solid #599bd4;
}

.ct-blue table > tbody > tr:first-child th {
    background-color: #599bd4 !important;
    color: white !important;
    border-radius: 5px;
}
.ct-blue table > tbody > tr:first-child th h1,
.ct-blue table > tbody > tr:first-child th h2,
.ct-blue table > tbody > tr:first-child th h3,
.ct-blue table > tbody > tr:first-child th h4,
.ct-blue table > tbody > tr:first-child th h5,
.ct-blue table > tbody > tr:first-child th h6,
.ct-blue table > tbody > tr:first-child th p{
    color:white;
}

.ct-blue table, .ct-blue table tr, .ct-blue table, .ct-blue table th,.ct-blue table td {
    border:none;
}
.ct-blue table tbody>tr td, .ct-blue table tbody>tr th{
    background-color:#599bd442;
    border-radius: 15px;
    border:4px solid white;
}
.ct-blue table tbody>tr:nth-child(odd)>td, .ct-blue table tbody>tr:nth-child(odd)>th{
    background-color: white;
    border-radius: 15px;
    border:4px solid white;
}
/* ------------------  FORMULARIO PQRS ----------------------- */
.wpcf7-form label {
	color: #21213E;
    font-weight: 600;
	width: 100%;
}
.wpcf7-form label select {
	width: 100%;
    background: #D3E2F0;
    border: none;
    border-radius: 50px;
    font-size: 14px;
	margin-top: 5px;
}
.wpcf7-form label input {
	width: 100%;
    background: #D3E2F0;
    border: none;
    border-radius: 50px;
    font-size: 14px;
	margin-top: 5px;
}
.wpcf7-form label textarea {
	width: 100%;
    background: #D3E2F0;
    border: none;
    border-radius: 25px;
    font-size: 14px;
    margin-top: 5px;
    height: 150px;
}
.wpcf7-form input[type="submit"] {
	color: #FFFFFF;
    border: none;
    width: 200px;
}


/* ------------------  RESPONSIVE ----------------------- */



@media all and (min-width: 768px) {
/*Dispositivos más grandes que móviles*/
	/* - Títulos - */
	h1, .elementor-heading-title h1{font-size:45px;}
	h2, .elementor-heading-title h2{font-size:35px;}
	h3, .elementor-heading-title h3{font-size:26px;}

	/* -- TÍTULOS -- */
	.title-bg-shape b::before {
		width:400px;
	}
	.title-bg-shape-2 b::before{
		width: 820px;
	}
	/* --- Full carrusel --- */
	.full-carrusel .custom-carrusel {
		margin-left: 8%;
	}	

	.full-carrusel .custom-carrusel .ae-swiper-button-wrapper {
		padding-right:13%;
	}
	/* --- TIME LINE --- */
	.tml-bar {
		left: 49.6%;
		transform: translateX(-50%);
	}
	/* -- CUSTOM TAB -- */
	.custom-tab .elementor-tabs-wrapper {
		display: flex;
		flex-wrap: wrap;
	}

	.custom-tab .elementor-tab-title {
		flex: 1;
		text-align: center;
	}	
}

/*Dispositivos más grandes que tablets*/
@media all and (min-width: 1024px) {
	/*  --------------- HOME ------------------- */

	.video-container{
	  position: relative;
		height:100vh;
	}
	.video-container > div{
	  position: sticky;
	  top: 0;
	  height: 100vh;
	  overflow: hidden;
	}
	.custom-scroll-video {
	  position: absolute;
	  top: 0;
	  left: 0;
	  width: 100%;
	  height: 100%;
	  object-fit: cover;
	  transform-origin: top left;
	  transform: scale(1);
	}
	.elementor-editor-active .video-container > div{
		height:inherit;
	}
	.elementor-editor-active .custom-scroll-video{
	  position: relative;
	  top: 0;
	  left: 0;
	  width:inherit;
	  height: inherit;
	  object-fit: inherit;
	  transform-origin: none;
	  transform: none);
		transition:none;	
	}

}

/*Portátiles comunes y más grande*/
@media all and (min-width: 1200px) {
	html,body{
		font-size:16px;
	}
	/* CONTENEDOR ELEMENTOR */
	.elementor-section.elementor-section-boxed > .elementor-container {max-width: 1100px;}
	/* TÍTULOS */
	h1, .elementor-heading-title h1{font-size:50px;}
	h2, .elementor-heading-title h2{font-size:35px;}
	

}

/*Tamaño intermedio entre portátiles comunes y Desktop grande*/
@media all and (min-width: 1500px) {


}

/*Desktop grande de 1920px, Desktop 4K y Retina*/
@media all and (min-width: 1800px) {

}

/*Tablets y móviles*/
@media all and (max-width: 1024px) {
	
	/*  --- HEADER --- */
	.menu-popup {
		position: fixed !important;
	}
	.vertical-nav.mobile nav.elementor-nav-menu--dropdown.elementor-nav-menu__container {
		max-height: max-content;
		transform: none;
	}

	.vertical-nav.mobile .elementor-menu-toggle {
		display: none;
	}
}