﻿@charset "utf-8";

@import url('https://fonts.googleapis.com/css2?family=Nunito:ital,wght@0,200..1000;1,200..1000&family=Roboto+Condensed:ital,wght@0,100..900;1,100..900&family=Roboto:ital,wght@0,100;0,300;0,400;0,500;0,700;0,900;1,100;1,300;1,400;1,500;1,700;1,900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Roboto+Condensed:ital,wght@0,100..900;1,100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Nunito:ital,wght@0,200..1000;1,200..1000&family=Roboto+Condensed:ital,wght@0,100..900;1,100..900&display=swap');

/* RESET */
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset,
form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td { margin: 0; padding: 0; border: 0; outline: 0; vertical-align: baseline; }

/* Make HTML 5 elements display block-level for consistent styling */
header, nav, article, footer, address { display: block; }

* { box-sizing: border-box; }

html { font-size: 20px; }
@media only screen and ( max-width: 1024px ) {
	html { font-size: 18px; }
}
@media only screen and ( max-width: 778px ) {
	html { font-size: 16px; }
}

body { width: 100%; max-width: 100%; color: #002832; font-family: 'Roboto', sans-serif; font-size: 1.1rem; font-weight: 300; line-height: 1.4em; background: #ffffff; }
a { text-decoration: none; }

/* classes */
.cleaner { clear: both; }
.centered { text-align: center; }
.center { text-align: center; }
.left { text-align: left; }
.right { text-align: right; }
.middle { vertical-align: middle; }
.top { vertical-align: top; }
.bottom { vertical-align: bottom; }
.row { clear: both; }
.onLeft { clear: left; float: left; }
.onRight { clear: right; float: right; }

.wrapper { margin: 0 auto; width: 1000px; height: 100%; position: relative; }

.hidden { display: none; }
.hide-field { height: 0px !important; overflow: hidden; }
.data { display: none; }
.dataHidden { display: none; }

.scroll-less { overflow: hidden; }

.vertical-aligner { display: flex; align-items: center; height: 100%; }
.vertical-aligner > div { margin: 0 auto; }

/**/
body[dev-mode="false"] .showOnDev { height: 0px !important; overflow: hidden !important; }

h2 { margin: 2rem 0 0.8em; font-size: 1.6rem; font-weight: 600; line-height: 1.1em; transition: all 0.3s ease-out 0s; }
h3 { margin: 2rem 0 0.8em; font-size: 1.4rem; font-weight: 600; line-height: 1.1em; transition: all 0.3s ease-out 0s; }
h4 { margin: 2rem 0 0.8em; font-size: 1.2rem; font-weight: 600; line-height: 1.1em; transition: all 0.3s ease-out 0s; }
h5 { margin: 2rem 0 0.8em; font-size: 1rem; font-weight: 600; line-height: 1.1em; transition: all 0.3s ease-out 0s; }
	.pre-title { margin: 0px 0px 24px 0px; font-size: 16px; font-weight: 600; line-height: 1.2em; letter-spacing: 3px; transition: all 0.3s ease-out 0s; }

h2 { font-family: 'Nunito'; font-size: 3.8rem; font-weight: 500; letter-spacing: -4px; }
h2 img { max-width: 100%; }
h2.featured { color: #ffffff; }
	h2.featured span { display: inline-block; position: relative; padding: 0.4rem 1.6rem; background: rgba(197,201,5,1); background: linear-gradient(90deg, rgba(197,201,5,1) 0%, rgba(207,6,85,1) 100%); }
	
@media only screen and ( max-width: 500px ) {
	h2.featured { margin-left: -10px; margin-right: -10px; }
	h2.featured span { display: block; }
	h2 { font-size: 2rem; }
}

p { margin: 0 auto; margin-bottom: 1.2em; font-size: 1rem; line-height: 1.2em; }

img { max-width: 100%; }

.row { box-sizing: border-box; position: relative; width: 100%; height: 100%; margin: 0 auto; text-align: center; }
.row .container { position: relative; max-width: 1160px; height: 100%; margin: 0 auto; padding: 4rem 20px; }
.row.row_splitted .container:before { content: ''; display: block; position: absolute; top: 0px; left: 20px; width: calc(100% - 40px); height: 1px; border-top: 1px solid rgba(0,40,50,0.3); }

.row .container { max-width: 800px; }
.row.wide .container { max-width: 1000px; }
.row.fullwidth .container { max-width: 100vw; }

.bt { display: block; position: relative; margin: 0 0 0.7rem; padding: 1rem 1rem 1rem; color: inherit; font-size: 1.5rem; font-weight: 600; line-height: 1em; letter-spacing: 1px; text-align: left; background: url() no-repeat center right #333; border: 3px solid inherit; z-index: 0; cursor: pointer; overflow: hidden; }
	.bt:before { content: ''; display: block; position: absolute; top: 49%; left: 49%; width: 2%; padding-bottom: 2%; background: rgba(0,0,0,0.25); transform: scale(0); border-radius: 1000px; z-index: -1; transition: all 0.5s ease-out 0s; }
	.bt:hover:before { transform: scale(100); }

.bt { display: block; position: relative; color: #fff; background-color: #002832; border-radius: 6px; }
.bt.bt_inline { display: inline-block; margin: 0.3rem 0.4rem; }
.bt { padding-right: 2.6rem; }
.bt.center { padding-left: 2.6rem; }

[class*="icon_"] { padding-right: 2.6rem !important; }
[class*="icon_"]:after { content: ''; display: block; position: absolute; top: calc(50% - 0.8rem); right: 0.5rem; width: 1.6rem; height: 1.6rem; background: url('') no-repeat center center transparent; background-size: cover; }
	.icon_external:after { background-image: url('icons_fff/external-link-svgrepo-com.svg'); }
	.icon_plus-square:after { background-image: url('icons_fff/add-plus-square-svgrepo-com.svg'); }

/**/
.bts_05 { display: flex; flex-wrap: wrap; justify-content: space-between; }
.bts_05 > .bt { width: 49%; }
@media only screen and ( max-width: 500px ) {
	.bts_05 > .bt { width: 100%; }
}

/**/
.accordion { display: block; position: relative; margin: 0rem 0rem 0.7rem; padding: 0rem; color: inherit; font-size: 1rem; font-weight: 400; line-height: 1.2em; border: 1px solid #002832; border-radius: 6px; z-index: 0; overflow: hidden; }
.accordion .accordion_title { display: block; position: relative; margin: 0rem; padding: 0.8rem 2.6rem 0.8rem 1rem; color: #fff; font-size: 1rem; font-weight: 600; line-height: 1em; text-align: left; background-color: #002832; border-radius-top-left: 6px; border-radius-top-right: 6px; cursor: pointer; overflow: hidden; }
	.accordion .accordion_title:after { content: ''; display: block; position: absolute; top: calc(50% - 0.8rem); right: 0.5rem; width: 1.6rem; height: 1.6rem; background: url('') no-repeat center center transparent; background-size: cover; }
		.accordion .accordion_title:after { background-image: url('icons_fff/add-plus-square-svgrepo-com.svg'); }
.accordion .accordion_content { display: block; position: relative; margin: 0rem; padding: 1rem 1rem 1.2rem; color: inherit; font-size: 1rem; font-weight: 400; line-height: 1.2em; text-align: left; }
.accordion .accordion_content > *:last-of-type{ margin-bottom: 0; }
/*
*/
.accordion.closed .accordion_content { display: none; }
.accordion:not(.closed) .accordion_title:after { background-image: url('icons_fff/close-square-svgrepo-com.svg'); }

/**/
.withSplitter:after { content: ''; display: block; width: 60%; max-width: 550px; height: 1px; margin: 0 auto; margin-top: 2.6rem; background: rgba(255,255,255,1); opacity: 0.5; }

.hightlight { font-size: 2rem; line-height: 1.2em; }
.hightlight strong { font-weight: 600; }

/**/
#topbar { position: fixed; top: 0px; height: auto; z-index: 4; }
#topbar:before { content: ''; display: block; position: absolute; top: 0px; left: 0px; width: 100%; height: 100%; background: rgba(0,0,0,0.5); background: #002832; opacity: 1; transition: all 0.3s ease-out 0s; }
#topbar .container { display: flex; align-items: center; justify-content: space-between; height: 132px; max-width: 1300px; padding: 26px; transition: all 0.3s ease-out 0s; }

	#topbar.floating:before { opacity: 1; }
	#topbar.floating .container { height: 60px; }
	#topbar.floating .logo-wrapper img { height: 40px; }
	
#topbar .logo-wrapper { position: relative; max-width: 60%; text-align: left; z-index: 1; }
#topbar .logo-wrapper img { height: 80px; max-width: 100%; margin-bottom: -4px; cursor: pointer; transition: all 0.3s ease-out 0s; }

#topbar #menu { position: relative; z-index: 0; }
#topbar #menu .menu_overlay { display: none; position: fixed; top: 0px; left: 0px; width: 100%; height: 100%; background: rgba(0,0,0,0.5); opacity: 0; z-index: -1; transition: all 0.3s ease-out 0s; }

#topbar #menu .menu_trigger { display: flex; position: relative; padding: 0; background-color: transparent; border: none; cursor: pointer; z-index: 2; }
#topbar #menu .menu_trigger svg { margin-top: 0.3rem; }
	.line { fill: none; stroke: white; stroke-width: 6; transition: stroke-dasharray 600ms cubic-bezier(0.4, 0, 0.2, 1), stroke-dashoffset 600ms cubic-bezier(0.4, 0, 0.2, 1); }
	.line1 { stroke-dasharray: 60 207; stroke-width: 6; }
	.line2 { stroke-dasharray: 60 60; stroke-width: 6; }
	.line3 { stroke-dasharray: 60 207; stroke-width: 6; }
	.opened .line1 { stroke-dasharray: 90 207; stroke-dashoffset: -134; stroke-width: 6; }
	.opened .line2 { stroke-dasharray: 1 60; stroke-dashoffset: -30; stroke-width: 6; }
	.opened .line3 { stroke-dasharray: 90 207; stroke-dashoffset: -134; stroke-width: 6; }
#topbar #menu .menu_trigger .menu_label { padding: 0.55rem; color: #fff; font-size: 0.7rem; font-weight: 600; letter-spacing: 2px; }

#topbar #menu .menu_content { display: block; position: fixed; top: 0px; right: -320px; width: 320px; min-height: 100vh; padding: 7rem 1rem 2rem; background: #232335; z-index: 1; transition: all 0.3s ease-out 0s; }
#topbar #menu .menu_content .menu_item { margin: 0px; padding: 0.7rem 0.5rem 0.8rem; color: #fff; font-size: 0.8rem; font-weight: 400; line-height: 1.2em; text-align: left; border-bottom: 1px solid rgba(255,255,255,0.2); cursor: pointer; }
#topbar #menu .menu_content .sm { display: block; margin: 1rem 0 0; padding: 0 0.1rem; text-align: left; }
#topbar #menu .menu_content .sm a { display: inline-block; width: 2.4rem; height: 2.4rem; margin: 0.2rem; line-height: 1em; }

		#topbar #menu .menu_content .sm a { transition: all 0.3s ease-out 0s; }
		#topbar #menu .menu_content  .sm a:hover { transform: scale(1.2); }
			#topbar #menu .menu_content  .sm svg { width: 2.4rem; height: 2.4rem; margin-right: 0.2rem; transform: scale(1.2); fill: #ffffff; transition: all 0.3s ease-out 0s; }
		#topbar #menu .menu_content  .sm span { font-size: 1.75rem; font-weight: 500; line-height: 1em; }

@media only screen and ( max-height: 520px ) {
	#topbar #menu .menu_content { padding-top: 90px; }
}

#topbar #menu.opened .menu_overlay { display: block; opacity: 1; z-index: 0; }
#topbar #menu.opened .menu_content { right: 0px; }

@media only screen and ( max-width: 420px ) {
	#topbar .container { height: 100px; padding: 14px; }
	#topbar #menu .menu_trigger .menu_label { display: none; }
}

/**/
body { padding-top: 110px; }
#topbar .container { height: 110px; max-width: 1000px; }

/* #footer */
#footer { color: rgba(50,40,0,1); font-size: 0.8rem; font-weight: 400; line-height: 1.4em; }
#footer { background: #ffffff; }
#footer .container { padding-top: 3rem; padding-bottom: 0; }
	#footer img { max-width: 100%; }
	#footer a { color: inherit; transition: all 0.3s ease-out 0s; }
	#footer a:hover { text-decoration: underline; }
		#footer a img { transition: all 0.3s ease-out 0s; }
		#footer a:hover img { transform: scale(1.2); }
	
	#footer .icon_small_footer { position: relative; top: 0.2rem; margin-right: 0.4rem; }
	
	#footer .sm {  }
	#footer .sm > * { display: inline-block; margin-left: -0.2rem; vertical-align: middle; }
		#footer .sm a { transition: all 0.3s ease-out 0s; }
		#footer .sm a:hover { transform: scale(1.2); }
			#footer .sm svg { width: 2.4rem; height: 2.4rem; margin-right: 0.2rem; transform: scale(1.2); fill: #002832; transition: all 0.3s ease-out 0s; }
		#footer .sm span { font-size: 1.75rem; font-weight: 500; line-height: 1em; }

#footer .columns { display: flex; justify-content: space-evenly; }
#footer .columns { margin: 0 auto; padding-bottom: 2rem; text-align: left; }
#footer .columns .columns_column { width: 440px; max-width: 440px; margin: 0 0 2rem; }
	#footer .columns .columns_column:last-of-type { width: 20%; text-align: right; }
	#footer .columns .columns_column { text-align: center !important; }
	
@media only screen and ( max-width: 1024px ) {
	#footer { font-size: 1rem; line-height: 1.4em; }
}
@media only screen and ( max-width: 768px ) {
	#footer { font-size: 1.1rem; line-height: 1.4em; }
}
@media only screen and ( max-width: 900px ) {
	#footer .columns { flex-direction: column; }
	#footer .columns .columns_column { width: 280px; max-width: 100%; margin: 0 auto; margin-bottom: 1rem; text-align: center; }
	#footer .columns .columns_column:last-of-type { margin-top: 1rem; width: 280px; text-align: center; }
}

/**/
#bottom-bar { padding: 0.8rem 0 1rem; color: rgba(255,255,255,0.2); font-size: 0.7rem; line-height: 1.2em; background: #002832; }
#bottom-bar .container { padding-top: 0; padding-bottom: 1rem; }
	#bottom-bar p { font-size: 0.7rem; line-height: 1.2em; }
	#bottom-bar img { position: relative; top: 0px; margin: 0 0 1rem; transition: all 0.3s ease-out 0s; }
	#bottom-bar a { color: inherit; }
	#bottom-bar a:hover { text-decoration: underline; }
/*
#bottom-bar img:hover { transition: all 0.5s ease-out 0s; -webkit-transform: rotate(360deg); -moz-transform: rotate(360deg); -ms-transform: rotate(360deg); -o-transform: rotate(360deg); transform: rotate(360deg); }
*/

/**/
.stripe_whatsapp { margin: 0px 0px 0px; padding: 20px 0px; font-size: 30px; line-height: 1em; white-space: nowrap; transition: all 0.3s ease-out 0s; }
.stripe_whatsapp a { color: inherit; }
.stripe_whatsapp img { vertical-align: middle; transition: all 0.3s ease-out 0s; }
@media only screen and ( max-width: 420px ) {
	.stripe_whatsapp { font-size: 22px; line-height: 1em; }
	.stripe_whatsapp img { width: 38px; }
}
.bottom-fixed { position: fixed; bottom: -100px; width: 100%; text-align: center; background: #333; z-index: 3; transition: all 0.5s ease-out 0s; }
.bottom-fixed .stripe_whatsapp { margin: 0px; padding: 12px 0px 10px; }
.bottom-fixed.enabled { bottom: 0px; }

/**/

body .wapp_flag { display: block; position: fixed; bottom: 48px; left: 0px; width: 60px; height: 60px; background: url('imgs/icon_wapp.png') no-repeat center right transparent !important; background-size: cover !important; border-top-right-radius: 43px; border-bottom-right-radius: 43px; opacity: 0.9; z-index: 10; transition: all 0.3s ease-out 0s; }
body .wapp_flag:hover { width: 86px; opacity: 1; }

body .wapp_flag_floating { display: block; position: fixed; bottom: 60px; right: 6px; width: 50px; height: 50px; background: url('imgs/icon_wapp_floating.png') no-repeat center center #65BC54 !important; background-size: 60% !important; border-radius: 100px; opacity: 0.9; z-index: 10; transition: all 0.3s ease-out 0s; }
body .wapp_flag_floating:hover { opacity: 1; }

body .wapp_flag_inline { display: inline-block; width: 50px; height: 50px; background: url('imgs/icon_wapp_floating.png') no-repeat center center #65BC54 !important; background-size: 60% !important; border-radius: 100px; opacity: 0.9; z-index: 10; transition: all 0.3s ease-out 0s; }
body .wapp_flag_inline:hover { opacity: 1; }

/* #overlay */
.popupContent { display: none; }

#overlay { display: none; align-items: center; justify-content: center; position: fixed; top: 0px; left: 0px; width: 100%; height: 100%; background-color: rgba(0,0,0,0.6); z-index: 1101; }
	#overlay.visible { display: flex; }
#overlay #overlay_container { position: relative; max-width: 100vw; max-height: 100vh; margin: 40px; background: #fff; z-index: 1102; }
	#overlay #overlay_container .overlay_closer { width: 100%; padding: 4px 14px 4px 14px; color: #fff; text-align: right; background-color: #fff; }
	#overlay #overlay_container .overlay_closer span { cursor: pointer; }
	#overlay #overlay_container .overlay_closer div { display: inline-block; position: relative; top: 3px; width: 44px; height: 44px; background: url('imgs/modal_closer.png') no-repeat center center transparent; cursor: pointer; opacity: 0.5; transition: all 0.3s ease-out 0s; }
	#overlay #overlay_container .overlay_closer div:hover { opacity: 1; }

#overlay #overlay_container #overlay_content { position: relative; width: 100%; max-width: 100%; max-height: calc(100vh - 136px); padding: 0px 60px 60px; color: #232335; font-family: R; font-size: 0.8rem; line-height: 1.2em; background: rgba(255,255,255,1); z-index: 1102; overflow: auto; }
#overlay #overlay_container #overlay_content > *:last-child { margin-bottom: 0px; }
#overlay #overlay_container #overlay_content h3 { margin: 0px 0px 2.5rem; font-size: 1.4rem; line-height: 1.2em; }
#overlay #overlay_container #overlay_content p { margin: 0px 0px 1.5rem; font-size: 1rem; font-weight: 300; line-height: 1.4em; }
#overlay #overlay_container #overlay_content p strong { font-weight: 500; }

@media only screen and ( max-width: 500px ) {
	#overlay #overlay_container { width: 100vw; height: 100vh; margin: 0 auto; }
	#overlay #overlay_container #overlay_content { max-height: calc(100vh - 56px); padding: 10px 40px 40px; }
}
@media only screen and ( max-width: 400px ) {
	#overlay #overlay_container #overlay_content { padding: 10px 20px 20px; }
}
