/*===============================================

global-marketing-responsive.css.pt-br
Global styles for marketing pages
across the global such as
http://www.wolfram.com/france/

For overrides and special cases, please create a
separate stylesheet such as
http://www.wolfram.com/france/css/france.css

developr: suef, yhechler
requires:    /common/framework/css/framework.pt-br.css

=================================================*/

:root {
	--orange: #f77700;
	--red: #dd1100;
}
main {
	color: #535353;
	font-family: 'Source Sans Pro', Arial, Helvetica, sans-serif;
	font-size: 1.125rem;
}
.inner {
	margin: 0 auto;
	max-width: 62.5rem;
	padding: 4.375rem 2rem;
}
.header .inner {
	padding-bottom: 0
}
section:not(.header, .info),
.divider {
	border-top: 1px solid #b8b8b8;
}
.divider {
	padding: 2rem 0 0 0;
}
main a {
	color: var(--red);
	font-size: 0.875rem;
	text-decoration: none;
}
main a:hover {
	color: var(--orange);
}
h1 {
	color: #000;
	font-size: 2.375rem;
	font-weight: 400;
	margin: 0;
	text-transform: uppercase;
}
h2 {
	color: var(--red);
	font-size: 2.1875rem;
	font-weight: 300;
	margin: 0 0 30px;
}
h3 {
	font-size: 1.6rem;
	font-weight: 400;
	line-height: 1.5;
}
/* Intro content
=========================*/

.info .inner {
	padding: 2.125rem 2rem 4.375rem 2rem;
}
.info p:nth-child(2n) {
	max-width: 90%;
}
.medium-text {
	font-size: 1.3125rem;
	font-weight: 300;
	line-height: 1.5;
	margin: 15px 0 45px;
}
p.orange {
	color: var(--orange);
	font-size: 1.6875rem;
	font-weight: 300;
	line-height: 1.5;
}
.flag {
	vertical-align: middle;
}
.title-wrapper{
	margin-left: 0.5rem;
}
.tagline {
	font-size: 1.8125rem;
	font-weight: 300;
	margin: 0;
}
.side-box {
	border: 2px solid #c3c3c3;
	padding: 1.875rem;
}
.side-box p {
	font-size: 0.875rem;
}
p.side-box-heading {
	color: var(--red);
	font-size: 1.25rem;
	margin: 5px 0;
}
.side-box .button {
	margin: 1.25rem 0 0;
}
.button {
	background-color: var(--red);
	border-radius: 0.25rem;
	border: 1px solid #b00f00;
	color: #fff;
	cursor: pointer;
	display: inline-block;
	font-size: 1rem;
	padding: 0.25rem 0.75rem;
}
.button:hover {
	background: #fe0000;
	color: #fff;
}
.event+.event:before {
	border-top: 1px solid #ddd;
	margin: 20px auto 15px;
	content: " ";
	display: block;
}
.carousel {
	align-items: center;
	display: flex;
	position: relative;
}

img.academic-icon {
	margin-top:4px;
}

/* Sliders
=========================*/
.sliders {
	align-items: center;
	display: flex;
	gap: 3rem;
	max-height: 80vh;
	overflow-x: scroll;
	overscroll-behavior-x: contain;
	position: relative;
	scroll-snap-type: x mandatory;
	scrollbar-width: none;
}
.sliders::-webkit-scrollbar {
	display: none;
}
.slide {
	align-items: center;
	display: flex;
	flex-shrink: 0;
	justify-content: start;
	scroll-snap-align: start;
	width: 100vw;
}
.slide a img {
	height: 100%;
	max-width: 100%;
	object-fit: contain;
}
.slide-navs {
	display: flex;
	position: absolute;
	top: 100%;
	right: 50%;
}
.slide-nav {
	padding: 0;
}
.slide-nav-button {
	background: none;
	border: none;
	color: #c1c1c1;
	cursor: pointer;
	display: flex;
	flex-direction: column;
	margin: 0;
	overflow: hidden;
	padding: 0;
}
.slide-nav-button:after {
	color: #c1c1c1;
	content: '\2022';
	font-size: 2.6em;
	letter-spacing: 0.5rem;
	padding: 0;
}
.slide-nav-button:hover:after {
	color: #FFA32C;
}
.slide-nav-button:active {
	color: var(--orange);
	padding: 0;
}
.slide-nav-button[aria-pressed="true"]:after {
	color: var(--orange);
	content: '\2022';
}
.carousel a div {
	width: 90%;
}
.carousel.hide__900 .next {
	color: #c1c1c1;
	cursor: pointer;
	display: flex;
	font-family: Arial, Helvetica, sans-serif;
	font-size: 4.375rem;
	position: absolute;
	right: 0;
	top: 10%;
	width: 10px;
	z-index: 1000;
}
.carousel a:hover span {
	color: var(--orange);
}
.margin-bt-3-2 {
	margin: 1.5rem 0;
}

/* ==========================================================================
   responsive breakpoint styles
   ========================================================================== */

/* styles for large screens (1200px)
   ========================================================================== */

@media all and (max-width: 1200px) {
	.scroll-slide a>* {
		height: auto;
		max-width: 16.75rem;
		width: 100%;
	}
	.scroll-slide span {
		display: inline-block;
		max-width: 16.75rem;
	}
}
/* styles for medium screens (900px)
   ========================================================================== */

@media all and (max-width: 900px) {
	.sliders {
		align-items: center;
		display: flex;
		gap: 1rem;
		overflow-x: scroll;
		overscroll-behavior-x: contain;
		position: relative;
		scroll-snap-type: x mandatory;
		scrollbar-width: none;
	}
	.hide.show__900.hide__600.slide-navs {
		display: flex !important;
		position: absolute;
		top: 100%;
	}
	.carousel.hide.show__900 .next {
		color: #c1c1c1;
		cursor: pointer;
		display: flex;
		font-family: Arial, Helvetica, sans-serif;
		font-size: 4.375rem;
		position: absolute;
		top: 10%;
		right: 0;
		width: 10px;
		z-index: 1000;
	}
}
/* styles for small screens (600px)
   ========================================================================== */

@media all and (max-width: 600px) {
	.info p:nth-child(2n) {
		max-width: 100%;
	}
}
/* styles for minimum supported screen width (320px)
   ========================================================================== */

@media all and (max-width: 320px) {
	.inner {
		padding: 4.375rem 1rem;
	}
	main img {
		max-width: 100%;
		height: auto;
	}
}
/* printer styles
   ========================================================================== */

@media print {}
