/*
	=======================================
	FONTS IMPORT
	=======================================
*/
@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');

/*
	=======================================
	DEFAULT VARIABLES
	=======================================
	
	4 / 8 / 12 / 16 / 32 / 64
*/
:root {
	/* text sizes */
	--content-text-smallest: 1.2em;
	--main-menu-text-size: 1.4em;
	--alert-text: 1.6em;
	--main-content-text-size: 1.6em;

	/* colors */
	--main-color-01: #209EA0;
	--main-color-02: #0BD0A2;
	--main-color-03: #F3FDFA;

	--oposite-color: #FD5901;
	

	/* main margins and paddings*/
	--main-gap-half: 12px;
	--main-gap: 24px;
	--main-gap-double: 48px;

	--logo-height: 45px;
}

/*
	=======================================
	RESET VALUES
	=======================================
*/
* { font-weight: inherit; font-family: inherit; font-style: inherit; color: inherit; font-size: 100%; border: 0 none; outline: 0; padding: 0; margin: 0; vertical-align: top; box-sizing: inherit; }
* { transition: background 0.4s; }

/*
	=======================================
	BASE ELEMENTS DEFINITIONS
	=======================================
*/
body { 
	font: 10px  'Inter', "Inter"; color: #888; 
	padding-top: calc(var(--main-gap-double) + var(--logo-height));
}

@media only screen and (max-width: 768px) { 
	body { padding-top: calc(var(--main-gap-double) + 32px); }
}

strong { font-weight: 600; }

h1, h2, h3 { color: var(--main-color-01);}

h1 { font-size: 4.2em;  }
h2 { font-size: 2.4em; margin-bottom: var(--main-gap); }
h3 { font-size: 1.8em; margin-bottom: var(--main-gap-half); }

.tmp_head_overline { font-size: 18px; display: block; margin-bottom: 5px; } 

p { font-size: var(--main-content-text-size); line-height: 1.6em; margin-bottom: var(--main-gap);  }
ul { font-size: var(--main-content-text-size); line-height: 1.6em; }
ul li ul { font-size: 1em; }

a:hover { cursor: pointer; text-decoration: none; }

input, textarea { -webkit-appearance: none; -moz-appearance: none; appearance: none; }

/*
	=======================================
	CLEARING ELEMENT
	=======================================
*/
div.clear, div.util, div.cleaner{ display: block; clear: both; font-size: 0px; line-height: 0px; z-index: 2000; }

/*
	=======================================
	MIDDLE DIV
	=======================================
*/
.middle { max-width: 1440px; margin: 0 auto; position: relative;; }
.middle_w { max-width: 2200px; margin: 0 auto; position: relative; }
.middle_t { max-width: 960px; margin: 0 auto; position: relative; }
.middle_st { max-width: 768px; margin: 0 auto; position: relative; }

/*
	=======================================
	SCROLL UP
	=======================================
*/
#scrollup { position: fixed; bottom: 0px; right: 0px; z-index: 9999; }
#scrollup a { display: block; height: 50px; width: 50px;  text-decoration: none; background: var(--main-color-03); }
#scrollup a svg { height: 50px; fill: var(--main-color-01); }
/*
	=======================================
	HELPERS
	=======================================
*/
.width_full { width: 100%; box-sizing: border-box; }
.width_fourty{ width: 40%; box-sizing: border-box; }
.width_half{ width: 50%; box-sizing: border-box; }
.width_eighty{ width: 80%; box-sizing: border-box; }
.width_seventy{ width: 70%; box-sizing: border-box; }
.width_sixty{ width: 60%; box-sizing: border-box; }
.width_thirty{ width: 30%; box-sizing: border-box; }
.width_quad{ width: 25%; box-sizing: border-box; }
.width_twenty{ width: 20%; box-sizing: border-box; }
.width_ten { width: 10%; box-sizing: border-box; }
.width_third{ width: 33.333%; box-sizing: border-box; }
.width_threequad{ width: 75%; box-sizing: border-box; }
.width_sixth { width: 16.6666666667%; box-sizing: border-box; }

@media only screen and (max-width: 960px) {
	.width_fourty, .width_half, .width_sixty, .width_thirty,
	.width_third, .width_quad, .width_twenty, .width_threequad, .width_ten, .width_eighty,
	.width_seventy{ width: 100%; }
	.width_sixth { width: 33.333%; }
}

.hide { display: none; }
.align_center { text-align: center; }
.align_left { text-align: left; }
.align_right { text-align: right; }
.float_right { float: right; }
.float_left { float: left; }

.margin_b { margin-bottom: var(--main-gap); }
.margin_bd { margin-bottom: var(--main-gap-double); }

@media only screen and (max-width: 960px) { .no_tablet { display: none; } }
@media only screen and (min-width: 960px) { .is_tablet { display: none; } }
@media only screen and (max-width: 768px) { .no_mobile { display: none; } }
@media only screen and (min-width: 768px) { .is_mobile { display: none; } }
@media only screen and (min-width: 960px) { .simulate_line { display: block; } }

sup { font-size: 0.5em; margin-top: -50%; }