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


/*
	=======================================
	DEFAULT VARIABLES
	=======================================
*/
:root {
	/* text sizes */
	--content-text-smallest: 1.2em;
	--main-menu-text-size: 1.8em;
	--alert-text: 1.6em;
	--main-content-text-size: 2em;
		
	--color-01: #f9f6f3;

	/* main margins and paddings*/
	--main-gap-half: 12px;
	--main-gap: 24px;
	--main-gap-double: 48px;
	--main-gap-tripple: 72px;
	--main-gap-section: 164px;
	--main-gap-section-bottom: 140px;

	--color-midnight-50: #eff8ff;
	--color-midnight-100: #deefff;
	--color-midnight-200: #b6e0ff;
	--color-midnight-300: #76c9ff;
	--color-midnight-400: #2daeff;
	--color-midnight-500: #0294f5;
	--color-midnight-600: #0074d2;
	--color-midnight-700: #005daa;
	--color-midnight-800: #004e8c;
	--color-midnight-900: #074173;
	--color-midnight-950: #031c34;

	--color-gold-sand-50: #fcf8f0;
	--color-gold-sand-100: #f7eedd;
	--color-gold-sand-200: #eedaba;
	--color-gold-sand-300: #dfb880;
	--color-gold-sand-400: #d69f61;
	--color-gold-sand-500: #cd8642;
	--color-gold-sand-600: #bf7037;
	--color-gold-sand-700: #9f592f;
	--color-gold-sand-800: #80482c;
	--color-gold-sand-900: #683c26;
	--color-gold-sand-950: #371e13;
}

/*
	=======================================
	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
	=======================================
*/
html { scroll-behavior: smooth;  }
body { font: 10px  'Inter', "Inter"; color: #666; background: #fff;  }

strong { font-weight: 700; }
h1 { color: var(--color-gold-sand-300); }
h2,h3 {  font-weight: 400; color: #005daa; }

h1 { font-size: 5.8em; margin-bottom: var(--main-gap);  }
h2 { font-size: 3.2em;  margin-bottom: var(--main-gap-half);  }
h3 { font-size: 2.6em; margin-bottom: var(--main-gap-half);  }

p { font-size: 2em; line-height: 1.8em; margin-bottom: var(--main-gap); }

@media only screen and (max-width: 960px) {
	h1 { font-size: 3.2em; }
	h2 { font-size: 2.4em; }
	h3 { font-size: 2em; }
	p { font-size: 1.6em; }
}

.heading_overline { display: block; font-size: 20px; color: #005daa;  margin-bottom: var(--main-gap-half);  }

a { color: var(--color-gold-sand-400); }
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_w { max-width: 2200px; margin: 0 auto; position: relative; }
.middle { max-width: 1440px; margin: 0 auto; position: relative;; }
.middle_t { max-width: 1000px; margin: 0 auto; position: relative; }
.middle_st { max-width: 960px; margin: 0 auto; position: relative; }

/*
	=======================================
	SCROLL UP
	=======================================
*/
#scrollup { position: fixed; bottom: var(--main-gap); right: var(--main-gap); z-index: 9999; }
#scrollup a { display: block;  width: 45px; padding-top: 15px; padding-bottom: 15px; text-align: center; background: var(--color-gold-sand-50); text-decoration: none; border-radius: 50%; }
#scrollup svg { fill: var(--color-gold-sand-900); transform: rotate(315deg); height: 15px; }
/*
	=======================================
	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; } }
@media only screen and (max-width: 1200px) {  .no_1200 { display: none; } }

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

.img_border_radius { border-radius: 8px; }