/* ================================================================================================================== */
/* VARIAVEIS */
/* ================================================================================================================== */

:root {
	--white: #ffffff;

	--1st_color: #1a7656;
	--2nd_color: #f6f6f6;
	--3rd_color: #ff9e1f;
	--4th_color: #ff9e1f;
	--5th_color: #1a7656;
	--6th_color: #e1e3e3;
	--7th_color: #606165;
	--8th_color: #929497;

	--nophoto_bgcolor: #cfd2d3;

	--event-featured-bgcolor: #1a7656;
	--event-featured-bgcolor_hover: #cfd2d3;

	--text_1st_color: #2b2c31;
	--text_2nd_color: #1a7656;
	--text_3rd_color: #929497;

	--input_text_border_color: #9e9e9f;
	--input_file_button_bgcolor: #9e9e9f;
	--input_file_button_bgcolor_hover: #1a7656;
	--input_submit_button_bgcolor: #1a7656;
	--input_submit_button_bgcolor_hover: #cfd2d3;

	--table_header_border_color: #9e9e9f;
	--table_header_bg: #f6f6f6;;

	--text_back_color: #929497;
	--text_back_color_hover: #1a7656;

	--text_attachment_color: #1a7656;
	--text_attachment_color_hover: #1a7656;

	--text_email_color: #929497;
	--text_email_color_hover: #1a7656;
	--text_phone_color: #929497;
	--text_phone_color_hover: #1a7656;
	--text_website_color: #929497;
	--text_website_color_hover: #1a7656;
	--text_search_color: #929497;
	--text_search_color_hover: #1a7656;
}

/* ================================================================================================================== */
/* fontes */
/* ================================================================================================================== */

h1, h2, h3, h4, h5, h6, p, div.text, a, input, label, textarea, span, select, table, tr, th, td, ::placeholder { font-family: 'Roboto', sans-serif; font-size: 14px; color: var(--text_1st_color); padding: 0; margin: 0; font-weight: 400; line-height: 20px; }

.font-title-1 { font-size: 20px; line-height: 25px; }
.font-title-2 { font-size: 22px; line-height: 25px; }
.font-title-3 { font-size: 16px; line-height: 20px; }
.font-title-4 { font-size: 40px; line-height: 45px; }

.regular { font-weight: 400; }
.semibold { font-weight: 600; }
.bold { font-weight: 700; }

.font-1 { font-family: 'Roboto', sans-serif; }
.font-2 { font-family: 'Archivo Narrow', sans-serif; }

.italic,
.italic::placeholder { font-style: italic; }

.margin-xxxsmall,	.margin-horizontal-xxxsmall,	.margin-left-xxxsmall	{ margin-left: 5px; }
.margin-xxxsmall,	.margin-horizontal-xxxsmall,	.margin-right-xxxsmall	{ margin-right: 5px; }
.margin-xxxsmall,	.margin-vertical-xxxsmall,	.margin-top-xxxsmall	{ margin-top: 5px; }
.margin-xxxsmall,	.margin-vertical-xxxsmall,	.margin-bottom-xxxsmall	{ margin-bottom: 5px; }

.margin-xxsmall,	.margin-horizontal-xxsmall,	.margin-left-xxsmall	{ margin-left: 10px; }
.margin-xxsmall,	.margin-horizontal-xxsmall,	.margin-right-xxsmall	{ margin-right: 10px; }
.margin-xxsmall,	.margin-vertical-xxsmall,	.margin-top-xxsmall	{ margin-top: 10px; }
.margin-xxsmall,	.margin-vertical-xxsmall,	.margin-bottom-xxsmall	{ margin-bottom: 10px; }

.margin-xsmall,		.margin-horizontal-xsmall,	.margin-left-xsmall	{ margin-left: 15px; }
.margin-xsmall,		.margin-horizontal-xsmall,	.margin-right-xsmall	{ margin-right: 15px; }
.margin-xsmall,		.margin-vertical-xsmall,	.margin-top-xsmall	{ margin-top: 15px; }
.margin-xsmall,		.margin-vertical-xsmall,	.margin-bottom-xsmall	{ margin-bottom: 15px; }

.margin-small,		.margin-horizontal-small,	.margin-left-small	{ margin-left: 20px; }
.margin-small,		.margin-horizontal-small,	.margin-right-small	{ margin-right: 20px; }
.margin-small,		.margin-vertical-small,		.margin-top-small	{ margin-top: 20px; }
.margin-small,		.margin-vertical-small,		.margin-bottom-small	{ margin-bottom: 20px; }

.margin-normal,		.margin-horizontal-normal,	.margin-left-normal	{ margin-left: 30px; }
.margin-normal,		.margin-horizontal-normal,	.margin-right-normal	{ margin-right: 30px; }
.margin-normal,		.margin-vertical-normal,	.margin-top-normal	{ margin-top: 30px; }
.margin-normal,		.margin-vertical-normal,	.margin-bottom-normal	{ margin-bottom: 30px; }

.margin-big,		.margin-horizontal-big,		.margin-left-big	{ margin-left: 50px; }
.margin-big,		.margin-horizontal-big,		.margin-right-big	{ margin-right: 50px; }
.margin-big,		.margin-vertical-big,		.margin-top-big		{ margin-top: 50px; }
.margin-big,		.margin-vertical-big,		.margin-bottom-big	{ margin-bottom: 50px; }

.padding-xxxsmall,	.padding-horizontal-xxxsmall,	.padding-left-xxxsmall	{ padding-left: 5px; }
.padding-xxxsmall,	.padding-horizontal-xxxsmall,	.padding-right-xxxsmall	{ padding-right: 5px; }
.padding-xxxsmall,	.padding-vertical-xxxsmall,	.padding-top-xxxsmall	{ padding-top: 5px; }
.padding-xxxsmall,	.padding-vertical-xxxsmall,	.padding-bottom-xxxsmall{ padding-bottom: 5px; }

.padding-xxsmall,	.padding-horizontal-xxsmall,	.padding-left-xxsmall	{ padding-left: 10px; }
.padding-xxsmall,	.padding-horizontal-xxsmall,	.padding-right-xxsmall	{ padding-right: 10px; }
.padding-xxsmall,	.padding-vertical-xxsmall,	.padding-top-xxsmall	{ padding-top: 10px; }
.padding-xxsmall,	.padding-vertical-xxsmall,	.padding-bottom-xxsmall{ padding-bottom: 10px; }

.padding-xsmall,	.padding-horizontal-xsmall,	.padding-left-xsmall	{ padding-left: 15px; }
.padding-xsmall,	.padding-horizontal-xsmall,	.padding-right-xsmall	{ padding-right: 15px; }
.padding-xsmall,	.padding-vertical-xsmall,	.padding-top-xsmall	{ padding-top: 15px; }
.padding-xsmall,	.padding-vertical-xsmall,	.padding-bottom-xsmall	{ padding-bottom: 15px; }

.padding-small,		.padding-horizontal-small,	.padding-left-small	{ padding-left: 20px; }
.padding-small,		.padding-horizontal-small,	.padding-right-small	{ padding-right: 20px; }
.padding-small,		.padding-vertical-small,	.padding-top-small	{ padding-top: 20px; }
.padding-small,		.padding-vertical-small,	.padding-bottom-small	{ padding-bottom: 20px; }

.padding-normal,	.padding-horizontal-normal,	.padding-left-normal	{ padding-left: 30px; }
.padding-normal,	.padding-horizontal-normal,	.padding-right-normal	{ padding-right: 30px; }
.padding-normal,	.padding-vertical-normal,	.padding-top-normal	{ padding-top: 30px; }
.padding-normal,	.padding-vertical-normal,	.padding-bottom-normal	{ padding-bottom: 30px; }

.padding-big,		.padding-horizontal-big,	.padding-left-big	{ padding-left: 50px; }
.padding-big,		.padding-horizontal-big,	.padding-right-big	{ padding-right: 50px; }
.padding-big,		.padding-vertical-big,		.padding-top-big	{ padding-top: 50px; }
.padding-big,		.padding-vertical-big,		.padding-bottom-big	{ padding-bottom: 50px; }

@media all and ( max-width: 1199px ) {
	.title { padding: 0 0 10px 0; }
		.title h1 { font-size: 22px; line-height: 30px; }
}

/* ================================================================================================================== */
/* principal e animacoes de defeito */
/* ================================================================================================================== */

html, body	{ position: relative; margin: 0; padding: 0; width: 100%; height: 100%; font-size: 0; }
*		{ transition-property: all; -webkit-transition-property: all; -moz-transition-property: all; transition-duration: 400ms; -webkit-transition-duration: 400ms; -moz-transition-duration: 400ms; }
.animation-long { transition-property: all; -webkit-transition-property: all; -moz-transition-property: all; transition-duration: 800ms; -webkit-transition-duration: 800ms; -moz-transition-duration: 800ms; }
.animation-none	{ transition-property: none; -webkit-transition-property: none; -moz-transition-property: none; transition-duration: 0ms; -webkit-transition-duration: 0ms; -moz-transition-duration: 0ms; }

/* ================================================================================================================== */
/* limpador e truque para inline-block alinhamento */
/* ================================================================================================================== */

div.clear { clear: both; }
.trick_align_middle { display: inline-block; position: relative; width: 0; height: 100%; vertical-align: middle; background-color: transparent; }
.trick_align_top { display: inline-block; position: relative; width: 0; height: 100%; vertical-align: top; background-color: transparent; }
.trick_align_bottom { display: inline-block; position: relative; width: 0; height: 100%; vertical-align: bottom; background-color: transparent; }

/* ================================================================================================================== */
/* cabecalho */
/* ================================================================================================================== */

div#header { display: block; position: relative; width: 100%; height: 125px; z-index: 100; margin: 0; padding: 0; }
	div#header div.responsive { display: none; }
	div#header div.header_responsive { display: block; position: fixed; width: 1200px; height: auto; margin: 0 auto; font-size: 0; background-color: var(--white); }
		div#header div.header_responsive span.responsive { display: none; }

		div#header div.header_responsive a.logo { display: inline-block; position: relative; width: 250px; height: 82px; margin: 16px 0 17px 0; top: 0; background: transparent url(../images/logo.png) no-repeat left center; background-size: contain; vertical-align: middle; }
		div#header div.header_responsive span.responsive_icon { display: none; }
		div#header div.header_responsive div.block { display: inline-block; position: relative; width: 800px; height: 100%; margin: 0 0 0 7px; vertical-align: top; text-align: right; }

			div#header div.header_responsive div.block form.top { display: inline-block; visibility: hidden; position: relative; width: auto; height: 25px; background-color: var(--2nd_color); margin: 12px 0 0 0; }
				div#header div.header_responsive div.block form.top input[type="text"],
				div#header div.header_responsive div.block form.top input[type="text"]::placeholder { display: inline-block; position: relative; width: 120px; font-size: 12px; background-color: transparent; box-sizing: border-box; border: none; line-height: 25px; vertical-align: middle; color: var(--text_search_color); }
				div#header div.header_responsive div.block form.top input[type="submit"] { display: inline-block; position: relative; width: 13px; height: 13px; background: transparent url(../images/search_icon.png) no-repeat; vertical-align: middle; border: none; cursor: pointer; margin: 0 0 0 10px; }
				div#header div.header_responsive div.block form.top input[type="submit"]:hover { background-position-y: -13px; }

			div#header div.header_responsive div.block div.middle { display: inline-block; position: relative; width: auto; height: 22px; margin: 10px 0 0 0; }
				div#header div.header_responsive div.block div.middle .menu { display: inline-block; position: relative; width: auto; font-size: 13px; line-height: 22px; color: var(--text_back_color); text-decoration: none; vertical-align: middle; text-transform: uppercase; cursor: pointer; }
				div#header div.header_responsive div.block div.middle .menu:after { content: ""; display: inline-block; position: relative; width: 3px; height: 3px; border-radius: 100%; background-color: var(--text_back_color); margin: 0 10px; vertical-align: middle; }
				div#header div.header_responsive div.block div.middle .menu.selected,
				div#header div.header_responsive div.block div.middle .menu:hover { color: var(--1st_color); }
				div#header div.header_responsive div.block div.middle div.languages { display: inline-block; position: relative; width: auto; line-height: 22px; }
					div#header div.header_responsive div.block div.middle div.languages a.languages { display: inline-block; position: relative; width: auto; font-size: 13px; line-height: 22px; text-decoration: none; vertical-align: middle; }
					div#header div.header_responsive div.block div.middle div.languages a.languages:after { content: ""; display: inline-block; position: relative; width: 1px; height: 13px; background-color: var(--text_back_color); margin: 0 4px; vertical-align: middle; }
					div#header div.header_responsive div.block div.middle div.languages a.languages:hover { color: var(--1st_color); }
					div#header div.header_responsive div.block div.middle div.languages a.languages.selected { color: var(--text_1st_color); }
					div#header div.header_responsive div.block div.middle div.languages a.languages:last-child:after { display: none; }

				div#header div.header_responsive div.block div.middle form { display: none; position: absolute; top: 22px; right: 0; height: auto; background-color: var(--text_1st_color); z-index: 10; text-align: left; font-size: 0; }
				div#header div.header_responsive div.block div.middle .menu:hover form { display: block; }
					div#header div.header_responsive div.block div.middle form span.arrow { display: block; position: absolute; top: -6px; right: 65px; border-top: 0; border-left: 7px solid transparent; border-right: 7px solid transparent; border-bottom: 8px solid var(--text_1st_color); }
					div#header div.header_responsive div.block div.middle form label { display: inline-block; position: relative; color: var(--white); font-size: 11px; line-height: 20px; white-space: nowrap; vertical-align: middle; width: 300px; box-sizing: border-box; cursor: default; padding-top: 2px; }
					div#header div.header_responsive div.block div.middle form label.captcha { width: 215px; }
					div#header div.header_responsive div.block div.middle form label.col { width: 140px; }
					div#header div.header_responsive div.block div.middle form img.captcha { display: inline-block; position: relative; vertical-align: bottom; width: 65px; cursor: default; }
					div#header div.header_responsive div.block div.middle form p.terms { margin: 5px 0 0 0; }
					div#header div.header_responsive div.block div.middle form p.terms,
					div#header div.header_responsive div.block div.middle form p.terms a { display: inline-block; position: relative; color: var(--white); font-size: 9px; line-height: 15px; width: 300px; box-sizing: border-box; cursor: default; vertical-align: top; }
					div#header div.header_responsive div.block div.middle form p.terms a { cursor: pointer; text-decoration: underline; width: auto; }
					div#header div.header_responsive div.block div.middle form p.terms a:hover { color: var(--1st_color); }
					div#header div.header_responsive div.block div.middle form textarea,
					div#header div.header_responsive div.block div.middle form input[type="text"] { display: block; position: relative; box-sizing: border-box; border: none; background-color: var(--white); font-size: 11px; line-height: 22px; width: 100%; resize: none; }
					div#header div.header_responsive div.block div.middle form textarea { height: 75px; }
					div#header div.header_responsive div.block div.middle form input[type="submit"] { display: block; position: relative; width: 100%; line-height: 25px; background-color: var(--1st_color); border: none; cursor: pointer; }
					div#header div.header_responsive div.block div.middle form input[type="submit"]:hover { background-color: var(--nophoto_bgcolor); }

			div#header div.header_responsive div.block div.bottom { display: inline-block; position: relative; width: auto; height: 22px; margin: 10px 0 0 0; }
				div#header div.header_responsive div.block div.bottom a.menu { display: inline-block; position: relative; width: auto; line-height: 25px; text-decoration: none; text-transform: uppercase; vertical-align: middle; color: var(--text_1st_color); }
				div#header div.header_responsive div.block div.bottom a.menu:after { content: ""; display: inline-block; position: relative; width: 3px; height: 3px; border-radius: 100%; background-color: var(--text_1st_color); margin: 0 10px; vertical-align: middle; }
				div#header div.header_responsive div.block div.bottom a.menu:last-child:after { display: none; }
				div#header div.header_responsive div.block div.bottom a.menu.selected,
				div#header div.header_responsive div.block div.bottom a.menu:hover { color: var(--1st_color); }

@media all and ( max-width: 1199px ) {
	div#header { display: block; position: fixed; top: 0; left: 0; height: 50px; background-color: var(--white); }
		div#header div.header_responsive { display: block; position: relative; width: 100%; height: auto; }

			div#header div.header_responsive span.responsive_icon { display: block; position: absolute; top: 10px; right: 7px; width: 41px; height: 30px; cursor: pointer; background: transparent url(../images/responsive.png) no-repeat; }
			div#header[data-responsive="closed"] div.header_responsive span.responsive_icon { background-position-y: 0; }
			div#header[data-responsive="opened"] div.header_responsive span.responsive_icon { background-position-y: -30px; }
			div#header div.header_responsive a.logo { width: 200px; height: 45px; margin: 2px; }
			div#header div.header_responsive div.block {position: absolute; top: 50px; left: 0; width: 100%; height: auto; background-color: var(--white); margin: 0; text-align: center; }
			div#header[data-responsive="closed"] div.header_responsive div.block { display: none; }
			div#header[data-responsive="opened"] div.header_responsive div.block { display: block; }
			div#header div.header_responsive div.block form.top { display: none; }
			div#header div.header_responsive div.block div.middle { display: block; position: relative; height: auto; }
				div#header div.header_responsive div.block div.middle .menu { display: block; position: relative; margin: 0; }
				div#header div.header_responsive div.block div.middle .menu { display: block; position: relative; margin: 0; }
				div#header div.header_responsive div.block div.middle .menu:after { display: none; }

			div#header div.header_responsive div.block div.bottom { display: block; margin: 25px 0 0 0; height: auto; padding: 0 0 15px 0; }
				div#header div.header_responsive div.block div.bottom a.menu { display: block; }
				div#header div.header_responsive div.block div.bottom a.menu:after { display: none; }
}

/* ================================================================================================================== */
/* estrutura principal */
/* ================================================================================================================== */

div#principal_container { display: table; position: relative; width: 1200px; min-height: 100%; margin: 0 auto; }
	div#principal_container div#principal_header { display: table-row; position: relative; width: 100%; }
	div#principal_container div#principal_body { display: table-row; position: relative; width: 100%; height: 100%; z-index: 10; }
	div#principal_container div#principal_footer { display: table-row; position: relative; width: 100%; }

@media all and ( max-width: 1199px ) {
	div#principal_container { width: 100%; }
		div#principal_container div#principal_header { height: 75px; }
}

/* ================================================================================================================== */
/* ficheiros */
/* ================================================================================================================== */

div.attachments { display: block; position: relative; width: auto; text-align: left; }
	div.attachments a { display: inline-block; position: relative; width: auto; height: 23px; line-height: 23px; background: transparent url(../images/attachment_icon.png) no-repeat; overflow: hidden; padding: 0 0 0 35px; text-decoration: none; color: var(--text_attachment_color); margin: 5px 0 0 0; }
	div.attachments a:first-child { margin: 0; }
	div.attachments a:hover { background-position-y: -23px; color: var(--text_attachment_color_hover); }

/* ================================================================================================================== */
/* voltar */
/* ================================================================================================================== */

a.back { display: block; position: relative; width: auto; height: 23px; line-height: 23px; background: transparent url(../images/back_icon.png) no-repeat; overflow: hidden; padding: 0 0 0 35px; text-decoration: none; color: var(--text_back_color); margin: 5px 0 0 0; }
a.back:hover { background-position-y: -23px; color: var(--text_back_color_hover); }

/* ================================================================================================================== */
/* icones */
/* ================================================================================================================== */

.email { display: inline-block; position: relative; width: auto; height: 19px; line-height: 19px; background: transparent url(../images/email_icon.png) no-repeat; overflow: hidden; padding: 0 0 0 40px; text-decoration: none; color: var(--text_email_color); }
.email:hover { background-position-y: -19px; color: var(--text_email_color_hover); }
.phone { display: inline-block; position: relative; width: auto; height: 19px; line-height: 19px; background: transparent url(../images/phone_icon.png) no-repeat; overflow: hidden; padding: 0 0 0 40px; text-decoration: none; color: var(text_phone_color); }
.phone:hover { background-position-y: -19px; color: var(--text_phone_color_hover); }
.website { display: inline-block; position: relative; width: auto; height: 19px; line-height: 19px; background: transparent url(../images/website_icon.png) no-repeat; overflow: hidden; padding: 0 0 0 40px; text-decoration: none; color: var(--text_website_color); }
.website:hover { background-position-y: -19px; color: var(--text_website_color_hover); }

/* ================================================================================================================== */
/* paginador */
/* ================================================================================================================== */

div.paginator { display: block; position: relative; width: auto; text-align: center; }
	div.paginator p,
	div.paginator a.page { display: inline-block; position: relative; width: auto; height: auto; line-height: 11px; text-decoration: none; margin: 5px 2px; color: var(--text_back_color); vertical-align: middle; }
	div.paginator a.prev { display: inline-block; position: relative; width: 6px; height: 11px; background: transparent url(../images/paginator_arrow.png) no-repeat 0 0; vertical-align: middle; margin: 0 10px 0 0; }
	div.paginator a.prev:hover { background-position-y: -11px; }
	div.paginator a.next { display: inline-block; position: relative; width: 6px; height: 11px; background: transparent url(../images/paginator_arrow.png) no-repeat -6px 0; vertical-align: middle; margin: 0 0 0 10px; }
	div.paginator a.next:hover { background-position-y: -11px; }
	div.paginator p {color:var(--text_1st_color);}
	div.paginator a.page:hover { color: var(--1st_color); }

/* ================================================================================================================== */
/* corpo */
/* ================================================================================================================== */

div#body { display: block; position: relative; width: 100%; height: auto; padding: 0; }

div#body div.lateral_menu { display: inline-block; position: relative; width: 250px; background-color: var(--2nd_color); box-sizing: border-box; vertical-align: top; }
	div#body div.lateral_menu span.responsive_lateral_menu { display: none; }
	div#body div.lateral_menu h1 { display: block; position: relative; background-color: var(--1st_color); color: var(--white); }
	div#body div.lateral_menu div.content { display: block; position: relative; border-bottom: 4px solid var(--1st_color); }
		div#body div.lateral_menu div.content a { display: block; position: relative; text-decoration: none; color: var(--text_1st_color); }
		div#body div.lateral_menu div.content a.selected,
		div#body div.lateral_menu div.content a:hover { color: var(--1st_color); }
		div#body div.lateral_menu div.content a:first-child { margin-top: 0; }

@media all and ( max-width: 1199px ) {
	div#body div.lateral_menu { display: block; position: fixed; top: 75px; z-index: 10; }
	div#body div.lateral_menu[data-responsive="closed"] { left: -250px; }
	div#body div.lateral_menu[data-responsive="opened"] { left: 0; }
	div#body div.lateral_menu span.responsive_lateral_menu { display: block; position: absolute; top: 35px; right: -30px; width: 30px; height: 22px; background: transparent url(../images/responsive_lateral_menu_icon.png) no-repeat; }
	div#body div.lateral_menu[data-responsive="closed"] span.responsive_lateral_menu { background-position-y: 0; }
	div#body div.lateral_menu[data-responsive="opened"] span.responsive_lateral_menu { background-position-y: -22px; }
	div#body div.lateral_menu div.content
	{
		overflow: auto;
		height: 350px;
		height: -webkit-calc(100vh - 75px - 100px);
		height:    -moz-calc(100vh - 75px - 75px);
		height:         calc(100vh - 75px - 100px);
	}
}

div#body div.content-with-lateral-menu { display: inline-block; position: relative; width: 930px; box-sizing: border-box; margin: 0 0 0 20px; vertical-align: top; }
div#body div.content-without-lateral-menu { display: block; position: relative; width: auto; box-sizing: border-box; }

@media all and ( max-width: 1199px ) {
	div#body div.content-without-lateral-menu { margin: 0 10px; }

	div#body div.content-with-lateral-menu { display: block; margin: 0 5px 0 30px; }
	div#body div.content-with-lateral-menu
	{
		width: -webkit-calc(100vw - 5px - 30px);
		width:    -moz-calc(100vw - 5px - 30px);
		width:         calc(100vw - 5px - 30px);
	}
}

/* ================================================================================================================== */
/* rodape */
/* ================================================================================================================== */

div#footer { display: block; position: relative; width: 100%; height: auto; }

	div#footer div.top { display: block; position: relative; width: auto; height: 100%; background-color: var(--text_1st_color); text-align: center; }
		div#footer div.top div.header { display: block; position: relative; width: auto; height: auto; border-bottom: 2px solid var(--6th_color); padding: 0 0 10px 0; margin: 0 0 10px 0; text-align: left; }
			div#footer div.top div.header h1 { display: inline-block; position: relative; color: var(--white); vertical-align: middle; width: 450px; }
			div#footer div.top div.header div.icons { display: inline-block; position: relative; color: var(--white); vertical-align: middle; height: 100%; width: 710px; text-align: right; }
				div#footer div.top div.header div.icons a.talktous { display: inline-block; position: relative; width: auto; height: 26px; line-height: 26px; background: transparent url(../images/talktous_icon.png) no-repeat; vertical-align: middle; text-decoration: none; padding: 0 0 0 40px; color: var(--nophoto_bgcolor); }
				div#footer div.top div.header div.icons a.talktous:hover { background-position-y: -26px; color: var(--1st_color) }
		div#footer div.top div.column { display: inline-block; position: relative; width: auto; height: auto; margin: 0 50px 0 0; text-align: left; vertical-align: top; }
		div#footer div.top div.column:last-child { margin: 0; }
			div#footer div.top div.column p,
			div#footer div.top div.column a { display: block; text-decoration: none; color: var(--nophoto_bgcolor); }
			div#footer div.top div.column p.font-title-bold,
			div#footer div.top div.column a.font-title-bold { margin: 0 0 5px 0; }
			div#footer div.top div.column a.selected,
			div#footer div.top div.column a:hover { color: var(--1st_color); }

	div#footer div.bottom { display: block; position: relative; width: auto; height: auto; text-align: center; }
		div#footer div.bottom a,
		div#footer div.bottom p { display: inline-block; position: relative; margin: 7px 0; text-decoration: none; font-size: 12px; line-height: 15px; color: var(--text_back_color); }
		div#footer div.bottom a:hover { color: var(--1st_color); }


@media all and ( max-width: 1199px )
{
	div#footer { position: relative; bottom: auto; left: auto; height: auto; }
		div#footer div.top { display: none; }
}

/* ================================================================================================================== */
/* input ficheiro */
/* ================================================================================================================== */

form div.file { display: block; position: relative; box-sizing: border-box; border: 1px solid var(--input_text_border_color); margin: 0; padding: 0; height: 25px; line-height: 25px; background-color: var(--white); }
	form div.file input[type="button"] { display: inline-block; position: relative; width: 125px; background: var(--input_file_button_bgcolor) url(../images/form_search_icon.png) no-repeat center center; border: none; height: 100%; cursor: pointer; vertical-align: top; }
	form div.file input[type="button"]:hover { background-color: var(--input_file_button_bgcolor_hover); }
	form div.file p { display: inline-block; position: relative; border: none; height: 100%; line-height: 24px; overflow: hidden; margin: 0 0 0 10px; font-size: 12px; }
	form div.file p
	{
		width: 150px;
		width: -webkit-calc(100% - 125px - 10px);
		width:    -moz-calc(100% - 125px - 10px);
		width:         calc(100% - 125px - 10px);
	}

/* ================================================================================================================== */
/* grelha */
/* ================================================================================================================== */

.grid { display: inline-block; position: relative; box-sizing: border-box; min-height: 50px; }

.grid.md-12 { width: 100%; }
.grid.md-11 { width:  91.66666666666666666667%; }
.grid.md-10 { width:  83.33333333333333333333%; }
.grid.md-9  { width:  75.00000000000000000000%; }
.grid.md-8  { width:  66.66666666666666666667%; }
.grid.md-7  { width:  58.33333333333333333333%; }
.grid.md-6  { width:  50.00000000000000000000%; }
.grid.md-5  { width:  41.66666666666666666667%; }
.grid.md-4  { width:  33.33333333333333333333%; }
.grid.md-3  { width:  25.00000000000000000000%; }
.grid.md-2  { width:  16.66666666666666666667%; }
.grid.md-1  { width:   8.33333333333333333333%; }

.grid.md-offset-12, .grid.md-offset-left-12 { margin-left: 100%; }
.grid.md-offset-11, .grid.md-offset-left-11 { margin-left:  91.66666666666666666667%; }
.grid.md-offset-10, .grid.md-offset-left-10 { margin-left:  83.33333333333333333333%; }
.grid.md-offset-9,  .grid.md-offset-left-9  { margin-left:  75.00000000000000000000%; }
.grid.md-offset-8,  .grid.md-offset-left-8  { margin-left:  66.66666666666666666667%; }
.grid.md-offset-7,  .grid.md-offset-left-7  { margin-left:  58.33333333333333333333%; }
.grid.md-offset-6,  .grid.md-offset-left-6  { margin-left:  50.00000000000000000000%; }
.grid.md-offset-5,  .grid.md-offset-left-5  { margin-left:  41.66666666666666666667%; }
.grid.md-offset-4,  .grid.md-offset-left-4  { margin-left:  33.33333333333333333333%; }
.grid.md-offset-3,  .grid.md-offset-left-3  { margin-left:  25.00000000000000000000%; }
.grid.md-offset-2,  .grid.md-offset-left-2  { margin-left:  16.66666666666666666667%; }
.grid.md-offset-1,  .grid.md-offset-left-1  { margin-left:   8.33333333333333333333%; }

.grid.md-offset-12, .grid.md-offset-right-12 { margin-right: 100%; }
.grid.md-offset-11, .grid.md-offset-right-11 { margin-right:  91.66666666666666666667%; }
.grid.md-offset-10, .grid.md-offset-right-10 { margin-right:  83.33333333333333333333%; }
.grid.md-offset-9,  .grid.md-offset-right-9  { margin-right:  75.00000000000000000000%; }
.grid.md-offset-8,  .grid.md-offset-right-8  { margin-right:  66.66666666666666666667%; }
.grid.md-offset-7,  .grid.md-offset-right-7  { margin-right:  58.33333333333333333333%; }
.grid.md-offset-6,  .grid.md-offset-right-6  { margin-right:  50.00000000000000000000%; }
.grid.md-offset-5,  .grid.md-offset-right-5  { margin-right:  41.66666666666666666667%; }
.grid.md-offset-4,  .grid.md-offset-right-4  { margin-right:  33.33333333333333333333%; }
.grid.md-offset-3,  .grid.md-offset-right-3  { margin-right:  25.00000000000000000000%; }
.grid.md-offset-2,  .grid.md-offset-right-2  { margin-right:  16.66666666666666666667%; }
.grid.md-offset-1,  .grid.md-offset-right-1  { margin-right:   8.33333333333333333333%; }

.grid.trick-to-vertical-align-top    { display: inline-block; position: relative; width: 0; height: 100%; background-color: transparent; vertical-align: top; }
.grid.trick-to-vertical-align-middle { display: inline-block; position: relative; width: 0; height: 100%; background-color: transparent; vertical-align: middle; }
.grid.trick-to-vertical-align-bottom { display: inline-block; position: relative; width: 0; height: 100%; background-color: transparent; vertical-align: bottom; }

.grid.no-wrap { white-space: nowrap; }

/* ================================================================================================================== */
/* popup */
/* ================================================================================================================== */

div#popup { display: block; position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 1000; text-align: center; overflow: auto; }
	div#popup span.bg { display: block; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-color: var(--white); opacity: 0.8; }
	div#popup div.container { display: inline-block; position: relative; max-width: 90%; max-height: 90%; vertical-align: middle; background-color: var(--7th_color); box-sizing: border-box; padding: 20px 35px; text-align: center; }
		div#popup div.container span.close { display: inline-block; position: relative; background-color: var(--1st_color); cursor: pointer; line-height: 25px; }
		div#popup div.container span.close:hover { background-color: var(--nophoto_bgcolor); }
		div#popup div.container h1 { color: var(--white); }
		div#popup div.container p { margin: 15px 0 0 0; color: var(--white); font-size: 16px; }
