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

.grecaptcha-badge {display:none;}

.blue_color {color:#192e83;}
.cyan_color {color:#009de0;}
.black_bg {background:#000; color:#fff;}
.blue_bg {background:#192e83;}
.cyan_bg {background:#009de0; color:#fff;}
.grey_bg {background:#f6f6f6;}
.white_bg {background:#fff;}

.col5{ width: 20%; float: left; position: relative; min-height: 1px; padding-right: 15px; padding-left: 15px; }

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, tt, var, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td { margin: 0px; padding: 0px; border: 0px none; outline: 0px none; font-weight: inherit; font-style: inherit; font-size: 100%; font-family: inherit; vertical-align: baseline; }
html{scroll-behavior: smooth;}
:focus { outline: 0px none; }
ol, ul { list-style: none outside none; }
strong{font-weight:bold;}
a{color:#1A171B; text-decoration:none; }
a:hover{ text-decoration:none;}
.text-centered {text-align:center; display: flex; justify-content: center;}
.clear {clear:both;}
.divider {clear:both;height:30px;}
em, i{font-style: italic;}

.no-gutter > [class*='col-'],  .no-gutter .row > [class*='col-'] {
    padding-right:0;
    padding-left:0;
}
.padd{
	padding-top: 40px;
	padding-bottom: 40px;
}
.padd_top{
	padding-top: 40px;
}
.padd_bottom{
	padding-bottom: 40px;
}
.padd_small{
	padding-top: 20px;
	padding-bottom: 20px;
}
.padd_big{
	padding-top: 80px;
	padding-bottom: 80px;
}
.padd_top_big{
	padding-top: 80px;
}
.no-padding{padding-right:0;padding-left:0;}
.margin_bottom{margin-bottom: 30px;}
body { font-size: 14px; font-family: 'Inter', Helvetica Neue, Helvetica, Arial, sans-serif; color:#000; background:#fff;-moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box; }
body.nav-open {
	overflow: hidden;
	touch-action: none;
}

.cd-main-content{		
	/*padding-top: 30px;*/
}
.cd-main-content::after {
  clear: both;
  content: "";
  display: table;
}

img.img-responsive{width:100%;}

a.overlay_link {display:block;width:100%;height:100%;position:absolute;top:0px;left:0px;text-indent: -999999px; z-index:10; }

#top_bar {  width: 100%; height:auto;  padding: 5px 0; margin:0; color: #1A171B; display: flex; }

.top_links_left { color:#1A171B; }
.top_links_left a {  display:inline-block; margin:0 5px 0 0px;  color:#1A171B; line-height:36px;  transition: all 0.2s ease-in; }
.top_links_left a:hover {  color:#bfbebe; transition: all 0.2s ease-in;}

.top_links_right { display:inline-block; float:right; text-align:right; }
.top_links_right a {  display:inline-block; margin:0 15px 0 15px;  color:#fff; line-height:36px; padding-left:36px; background-repeat: no-repeat; background-position: center left; background-size:28px;  transition: all 0.2s ease-in;font-size: 20px; }
.top_links_right a:hover {  color:#bfbebe; transition: all 0.2s ease-in;}
a.cd-cart-trigger{ background-color: #000;  border-radius: 50px; background-position:15px center}
.races_quantity{padding-right: 30px; top: 2px; position: relative; left: 5px;}


/* .top_links_right a.user_login{  background-image: url('../img/layout/user_login_black.svg'); } */
/* .top_links_right a.user_register{  background-image: url('../img/layout/user_register_black.svg'); } */
/* .top_links_right a.user_account{  background-image: url('../img/layout/user_account_black.svg'); } */
/* .top_links_right a.user_logout{  background-image: url('../img/layout/user_logout_black.svg'); } */
.top_links_right a.cd-cart-trigger{ z-index:99999; background-image: url('../img/layout/icons/basket_white.svg'); background-size: 24px; width: 80px; height: 40px; top: -1px; position: relative;}
.top_links_right a.registration_button{background: #dd384c; margin: 0 auto; line-height: 20px; padding: 10px 20px; font-size: 20px; border-radius: 40px; font-weight: 500;  background-color: #dd384c;  border: none;  color: #ffffff;  text-align: center;  text-decoration: none;  display: inline-flex;  cursor: pointer;  overflow: hidden;  position: relative;  transition: all 0.3s ease;}
.top_links_right a.registration_button:after { content: "";  position: absolute;  top: 50%;  left: 50%;  width: 0;  height: 0;  background-color: rgba(255, 255, 255, 0.1);  border-radius: 50%;  opacity: 0;  transform: translate(-50%, -50%);  transition: all 0.5s ease;}
.top_links_right a.registration_button:hover:after { width: 100%;height: 200px; opacity: 1;}
.top_links_right a.registration_button:focus { outline: none;}
.top_links_right a.registration_button:active {transform: translateY(2px);box-shadow: none;}

.social-icons-footer { display:contents; float:left;  }
.social-icons-footer a {  display:inline-block; width:32px; height: 32px; margin-right: 10px; }
.social-icons-footer a.facebook { background: url('../img/layout/icons/fb_1.svg') no-repeat scroll center center transparent;  transition: all 0.2s ease-in; padding: 20px; border-radius: 50%; }
.social-icons-footer a.facebook:hover { background: url('../img/layout/icons/fb_2.svg') no-repeat scroll center center transparent; transition: all 0.2s ease-in;}
.social-icons-footer a.instagram { background: url('../img/layout/icons/insta_1.svg') no-repeat scroll center center transparent;transition: all 0.2s ease-in; padding: 20px; border-radius: 50%;}
.social-icons-footer a.instagram:hover {background: url('../img/layout/icons/insta_2.svg') no-repeat scroll center center transparent; transition: all 0.2s ease-in;  }
.social-icons-footer a.youtube { background: url('../img/layout/icons/yt_1.svg') no-repeat scroll center center transparent; transition: all 0.2s ease-in;padding: 20px; border-radius: 50%; }
.social-icons-footer a.youtube:hover {background: url('../img/layout/icons/yt_2.svg') no-repeat scroll center center transparent; transition: all 0.2s ease-in;}

.footer_mob { display: none; }

.has-submenu{margin-left: 15px;}
.user-header.has-submenu{position: relative; display:inline-block; float:left;  background: url('../img/layout/icons/user_white.svg') no-repeat scroll center center transparent; background-color: #000;   transition: all 0.2s ease-in;padding: 20px; border-radius: 50%;cursor: pointer;}
/* Το δικό σου στυλ με τις απαραίτητες προσθήκες */
.user-header.has-submenu {
    position: relative; 
    display: inline-block; 
    float: left;  
    background: url('../img/layout/icons/user_white.svg') no-repeat scroll center center transparent; 
    background-color: #000;  
    transition: all 0.2s ease-in;
    padding: 20px; 
    border-radius: 50%;
    cursor: pointer;
    background-size: 24px;
}

.user-header.has-submenu .submenu {
    display: none;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: 110%; 
    margin-top: 5px;    
    background: #fff;
    min-width: 140px;
    border-radius: 10px;
    box-shadow: 0px 4px 12px rgba(0,0,0,0.15);
    list-style: none;
    padding: 10px 0;
    z-index: 1000;
}

.user-header.has-submenu .submenu::before {
    content: "";
    position: absolute;
    top: -15px;
    left: 0;
    width: 100%;
    height: 15px;
    background: transparent;
}

@media (hover: hover) {
    .user-header.has-submenu:hover > .submenu {
        display: block;
    }

    .languages-top:hover .languages.submenu {
       display: block;
    }
}

.user-header.has-submenu .submenu li {
    display: block;
    text-align: center;
}

.user-header.has-submenu .submenu li a {
    color: #000;
    padding: 0px 15px;
    display: block;
    text-decoration: none;   
    white-space: nowrap;
	font-size: 16px;
    font-weight: 500;
	transition:all 0.5s;
}

.user-header.has-submenu .submenu li a:hover {
  	color: #bfbebe;
	transition:all 0.5s;
}

.languages-top {position: relative; display:inline-block; float:left;  background: url('../img/layout/icons/lang_white.svg') no-repeat scroll center center transparent;     background-color: #000;   transition: all 0.2s ease-in;padding: 20px; border-radius: 50%;cursor: pointer;    background-size: 24px;}
.languages-top li { float: left; display: flex; color: #fff; }
.languages-top li a { color: #1A171B; padding: 6px 5px 3px 5px; margin: 0 2px; }
.languages-top li a:hover { color: #bfbebe; }
.languages-top li.active a { text-decoration: underline; }
.languages-top img { display: block; width: 20px; height: auto; }

.languages.submenu {
    display: none;
    position: absolute;
    top: 100%;
    background: #fff;
    min-width: 110px;
    list-style: none;
    padding: 10px 0;
    margin-top: 10px; 
    border-radius: 8px;
    /* box-shadow: 0px 4px 10px rgba(0,0,0,0.2); */
    z-index: 999;
	left: 50%;
    transform: translateX(-50%);
}

.languages.submenu::before {
    content: "";
    position: absolute;
    top: -15px;
    left: 0;
    width: 100%;
    height: 15px;
    background: transparent;
}

.languages.submenu li { width: 100%; display: block; }
.languages.submenu li a { 
    color: #000; 
    display: block; 
    padding: 0px 15px; 
	text-align: center;
    text-decoration: none;
	font-size: 16px;
    font-weight: 500;
	transition:all 0.5s;
}

.languages.submenu li a:hover { color: #bfbebe;  transition:all 0.5s; }
/* .languages.submenu li.active a { font-weight: bold; text-decoration: underline; } */


/* #header { display: block; width: 100%; height:auto;  padding: 25px 0; margin:0; position:absolute; z-index:999; transition:all 0.5s;} */
#header {
    display: block; 
    height:auto;
    padding: 25px 0; 
    margin:0;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 999;
	background: rgba(255, 255, 255, 0);
	box-shadow: 0 0 0 rgba(0, 0, 0, 0);
	transition:
		background 0.4s ease,
		box-shadow 0.4s ease,
		transform 0.4s ease;
}

#header.is-sticky {
	transform: translateY(0);
}


#logo { display: block; width: 50px; height: 52px; margin: 0px 0 0px 0px;overflow:hidden; transition: all .3s ease-in-out; float: left;}
#logo a { position:relative; display: block; width: 100%; height:100%;text-indent: -999999px!important; background: url('../img/layout/logo_small.png') no-repeat scroll center center transparent; transition: all .3s ease-in-out; background-size:100%;z-index:99; }

#countdown-box { display:block; width:350px; position:absolute; top: 45px; left:auto; margin-left: 350px; }
#countdown-box p{color:#fff;font-size:26px;display:block;font-weight:bold;text-align:right;}
#countdown-box .counter{margin-top: 0px;float:right;display:block;}
#countdown-box ul.countdown {list-style: none;margin:0;padding: 0;display: block;text-align: center;}
#countdown-box ul.countdown li {display: inline-block;float:left;margin-left:2px;margin-right:2px;margin-top:10px;color:#fff;}
#countdown-box ul.countdown li span {float:left;font-size:20px;color:#fff;font-weight:700;}
#countdown-box ul.countdown li p {float:left;font-size:14px;margin-top:7px;margin-left:2px;margin-right:5px;font-weight:normal;font-style:italic;}

.top_icons{ display: none; }

#navi { display:inline-block; background: #fff; border-radius: 30px;padding: 0px 25px;}
#navi ul{  text-align:right;  }
#navi ul li{ display:inline-block; position: relative;}
#navi ul li a{ display:flex; color:#000; font-size: 20px; margin:0 5px; padding: 10px;  transition: all 0.2s ease-in;font-weight: 600;align-items: center;}
#navi ul li a:hover{ color:#bfbebe; transition: all 0.2s ease-in; }
#navi ul li.has_children{position: relative;}
#navi ul li.has_children::after{content: '';position: absolute; right: -4px; bottom: -1px; width: 12px; height: 100%; background: url(../img/layout/icons/arrow_down.png) no-repeat scroll center center transparent; background-size: 100%;}
#navi .submenu_arrow{width: 12px; height: 12px; margin-left: 7px;}
@media (hover: hover) {
    #navi ul li.has_submenu:hover ul.submenu {display: block!important;}
}
.submenu_arrow {vertical-align: middle; margin-left: 5px;}
#navi ul li ul.submenu {
	display: none; 
    position: absolute;
    background: #fff;
    list-style: none;
    padding: 10px;
	width: 100%;
}
#navi ul li ul.submenu, #navi ul li ul.submenu li, #navi ul li ul.submenu li a{
	width: max-content;
    display: flex;
    flex-direction: column;
	padding: 0;
    margin: 0;
}
#navi ul li ul.submenu li a{
	padding: 5px 0;
	font-size: 18px;
	font-weight: 500;
}

.submenu_arrow {
    transition: transform 0.3s ease;
}

.rotate-arrow {
    transform: rotate(180deg);
}

#navi ul li {
    position: relative;
    display: inline-block;
}

#navi ul li ul.submenu {
    display: none;
    position: absolute;
    top: 100%; 
    left: 0;
    margin-top: 5px; 
    background: #ffffff;
    border-radius: 10px; 
    padding: 10px 20px;  
    list-style: none;
    z-index: 999;
}

#navi ul li ul.submenu::before {
    content: "";
    position: absolute;
    top: -10px; 
    left: 0;
    width: 100%;
    height: 15px; 
    background: transparent;
    display: block;
}

.main_navigation{width: fit-content; display: inline-block; float: left; margin-left: 20px;}

/* #mobile-nav { display:none; top: 82px; right: 0px; background:#1A171B;  color:#fff; width: 100%; height:auto;  padding:50px 0; z-index: 999999; overflow: visible; position: absolute; transition: all 0.3s ease-in 0s;pointer-events: none;}   
#mobile-nav.nav-open {	display:block;border-top:10px double #fff}  */
#mobile-nav {
	position: fixed;
    top: 80px;
	/* bottom: 0; */
	left: 0;
	width: 100%;
	height: calc(100vh - 80px);
	transform: translateY(-20px);
	opacity: 0;
	pointer-events: none;
    background:#1A171B;  
    color:#fff;
    overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	transition:
		transform 0.45s cubic-bezier(.4,0,.2,1),
		opacity 0.35s ease;
}
#mobile-nav.nav-open {
	transform: translateY(0);
	opacity: 1;
	pointer-events: auto;
}

#mobile-nav p.menu_heading { font-size:20px; font-style: italic; color: #fff;margin-bottom:20px;  }
#mobile-nav p.menu_heading  a{ color: #fff; transition: all 0.3s ease-in 0s;  }
#mobile-nav p.menu_heading  a:hover{ color: #bfbebe;  transition: all 0.3s ease-in 0s; }
#mobile-nav p.menu_heading::after {
    content: '';
    width: 50px;
    height: 1px;
    background-color: #fff;
    display: block;
    margin-top: 10px;
}

#mobile-nav ul {  margin:0px;padding:0px; }
#mobile-nav ul li {  display:flex; color: #7c7c7c; margin-bottom:10px; font-size:16px; }
#mobile-nav ul li a{ display:block; color: #7c7c7c; transition: all 0.3s ease-in 0s; }
#mobile-nav ul li a:hover{ color: #bfbebe; transition: all 0.3s ease-in 0s; }
#mobile-nav.is-visible,#mobile-nav.active,#mobile-nav.open {pointer-events: auto;}

.video-wrapper {
  position: relative;
  width: 100%;
  padding-top: 56.25%; /* 16:9 aspect ratio */
  overflow: hidden;
  transform: none !important;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  z-index: 0;
}

.video-wrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
  pointer-events: auto; 
  filter: grayscale(1) 
}
.section_video{
    top: -85px;
    position: relative;
    width: 100%;
    height: 100vh; 
    overflow: hidden;
}
.align_banner_text{
	display: flex; 
	justify-content: space-between; 
	align-items: flex-end; 
	height: 100vh; 
	bottom:50px;
}
.video-text {
	position: relative;
    color: #fff;
    text-align: left;
    z-index: 10;
    bottom: 40px;
    height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
	width: 100%;
}
.video-text.right {
	position: relative;
    color: #fff; 
    z-index: 10;
    width: 100%;
    bottom: 50px;
    height: 100vh;
    display: flex;
    justify-content: flex-end;
    right: 0;
    float: right;
    align-items: flex-end;
}
.video-text h1{
    color: #dd384c;
	font-size: 80px;
    font-weight: 600;
    max-width: 520px;
    line-height: 75px;
}
.video-text.right h2{
    font-size: 35px;
    font-weight: 500;
    line-height: 40px;
}
.video_button{
	margin: 60px 0 10px 0;
    display: flex;
}
.video_button .main_button{
	background: #dd384c;
	color: #fff;
	padding: 20px 35px;
    font-size: 18px;
    border-radius: 40px;
	font-weight: 500;
}
.run_date{display: none;}
.main_button {
  background-color: #dd384c;
  border: none;
  color: #ffffff;
  padding: 20px 35px;
  text-align: center;
  text-decoration: none;
  display: inline-block;
  cursor: pointer;
  overflow: hidden;
  position: relative;
  transition: all 0.3s ease;
}

.main_button:after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  background-color: rgba(255, 255, 255, 0.1);
  border-radius: 50%;
  opacity: 0;
  transform: translate(-50%, -50%);
  transition: all 0.5s ease;
}

.main_button:hover:after {
  width: 100%;
  height: 200px;
  opacity: 1;
}

.main_button:focus {
  outline: none;
}

.main_button:active {
  transform: translateY(2px);
  box-shadow: none;
}

.video_button .white_button{
	background: #fff;
	color: #000;
	padding: 20px 35px;
    font-size: 18px;
    border-radius: 40px;
	margin-left: 20px;
	font-weight: 500;
}

.video_button .white_button {
  background-color: #fff;
  border: none; 
  text-align: center;
  text-decoration: none;
  display: inline-block;
  cursor: pointer;
  overflow: hidden;
  position: relative;
  transition: all 0.3s ease;
}

.video_button .white_button:after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  background-color: rgba(0,0,0,0.05);
  border-radius: 50%;
  opacity: 0;
  transform: translate(-50%, -50%);
  transition: all 0.5s ease;
  /* z-index: -1; */
}

.video_button .white_button:hover:after {
  width: 100%;
  height: 200px;
  opacity: 1;
  /* z-index: -1; */
}

.video_button .white_button:focus {
  outline: none;
}

.video_button .white_button:active {
  transform: translateY(2px);
  box-shadow: none;
}

.title-lines {
    position: relative;
}
.m-top-30 {
    margin-top: 30px !important;
}
.m-bot-30 {
    margin-top: 30px !important;
    margin-bottom: 30px !important;
}
.m-bot-50 {
    margin-top: 50px !important;
    margin-bottom: 50px !important;
}
.m-bot-20 {
    margin-bottom: 20px;
}
.m-bot-10 {
    margin-bottom: 10px;
}
.m-bot-40{
     margin-bottom: 40px;
}
.mar-top-bot{margin-top:30px;margin-bottom:30px;}
.m-top-bot-15{margin-top:15px;margin-bottom:15px;}
.m-top-bot-5{margin-top:5px;margin-bottom:5px;}

.title-block {
    color: #404041;
    display: inline-block;
    font-size: 46px;
    font-weight: 300;
    height: 68px;
	box-sizing: border-box;
}

.title-block p{
     font-size: 32px;
}

.title-block hr{
	width:30%;
	margin-left:0;
	margin-bottom:40px;
    height: 1px;
    border: 0;
    border-top: 2px solid #999374;
    padding: 0; 
}
.title-block hr.center{
	margin-left:35%;
}

.title-block span{
    color: #333;
    display: block;
    font-size: 18px;
    font-weight: 300;	
}
.view-all-container {
    float: right;
    margin-top: 10px;
}
.view-all-container.all-owl-carousel{
	margin-right:25px;
}

.button.all  {
    color: #fff;
    background-color: #eed700;
    border: medium none;   
    outline: medium none;
    position: relative;
    transition: all 0.3s ease 0s;
	display: inline-block;
    font-size: 15px;
    padding: 12px 18px 13px;

}
.button.all:hover  {
	background-color:#1A171B;
}
.cd-overlay {
    pointer-events: none;
}
.cd-overlay.is-visible {
    pointer-events: auto;
}

#cookie-consent-wrapper {
    position: fixed!important;
    z-index: 2147483647!important;
    display: block!important;
    width: 280px;
    top: auto; 
	bottom:100px;
    padding: 10px;    
    color: #1A171B;
	font-family: 'Inter', Helvetica Neue, Helvetica, Arial, sans-serif;
	right:0; 
	bottom:5px;
	/*left:50%;
	transform:translate(-50%, -50%);*/
	background:rgba(0,0,0,0.9);
}

#cookie-consent-wrapper .content p{
	font-size:12px;
	font-weight:400;
	line-height:14px;
	padding:0px;
	color:#fff!important;
}

#cookie-close, #link, .btn_concern {
    font-size: 12px;
	margin-top:7px;
	padding:5px 0;
    background: #1A171B!important;
    width:100%;
	display:block;
	text-align:center;
    color: #fff!important;
	right: 20%!important;	
	margin-top: 5px;
}
#cookie-consent-wrapper .btn_concern, #cookie-close{background: #fff!important;color: #1A171B!important;}
#cookie-close a, #link a {
	font-size: 12px;
}

.eolsmay-highlight{
	padding: 5px 20px;
	background-color: #e4ebee;
}


#newsletter{ margin-top:50px;margin-bottom:20px;padding:0px; width:100%; }
.newsletter{}
.newsletter h5{ color:#1A171B;margin:0px 0 0px 0; font-size:50px; font-weight:bold; }
.newsletter p{ color:#1A171B;margin:0px 0 0px 0; font-size:18px;}
.newsletterform { width:100%;padding: 10px 0px 0px 0px; height:auto; margin:0 auto; background:#fff; border-bottom:1px solid #1a171b;}
.newsletter_input{ display:inline-block; float:left;}
.newsletter_input input{border-radius:0px;box-shadow:none;border:none;background: none; padding:18px 0;color:#1A171B;font-size:14px;width:400px; }
.newsletter_input input:hover{}
.nl-button { position:relative; float:right; display:inline-block; overflow: hidden; padding-right: 70px; background: none; border:0px; margin-top:15px; color:#1A171B; font-size:16px; font-weight:bold; letter-spacing: 1.2px;  transition: all 0.2s ease-in; }
.nl-button::after { display: block; content: '';  height: 2px; width: 50px;  position: absolute;  right: 0px; top: 0;  bottom: 0;	margin:auto; background: #1A171B; transition: all 0.2s ease-in;	}
.nl-button::before { opacity: 0; display: block; content: ''; height: 2px; width: 50px;  position: absolute;  left: -70px; top: 0;  bottom: 0; margin:auto; background: #5ce1e6; transition: all 0.2s ease-in; }
.nl-button:hover { padding-right: 0;  padding-left: 70px; color:#5ce1e6; transition: all 0.2s ease-in; }
.nl-button:hover::after { right: -50px;  opacity: 0; transition: all 0.2s ease-in; }
.nl-button:hover::before { left: 0; opacity: 1; transition: all 0.2s ease-in; }

.newsletter_pref legend{padding: 5px;text-transform: uppercase;font-size: 20px;font-family: 'Inter', Helvetica Neue, Helvetica, Arial, sans-serif;}

.lead_text{ margin-bottom:5px;}
.lead_text p{ font-size:16px;}
.lead_text strong{ color:#fff;background:#eed700;padding:3px;}

.button.thin-bg-dark {
    background-color: #1A171B !important;
    border: 0px none !important;
    color: #fff!important;
    display: block;
    padding: 15px 15px !important;
    position: relative;
    transition: all 0.3s ease 0s;
	width:100%;
	margin:20px 0;
	font-size:18px;
	font-weight:bold;
	letter-spacing: 1.2px;
	border-radius: 0px;
}
.button.thin-bg-dark:hover {
    background-color: #3d3d3d !important;   
    transition: all 0.3s ease 0s;
}
.button.thin-bg-dark.reverse {
    background-color: #dd384c !important;  
	color:#fff !important;   
	font-size: 20px;
    border-radius: 50px;    
}
.button.thin-bg-dark.reverse:hover {
    background-color: #e7e7e7 !important;      
}
.button.black_button{
	display: flex;
    background-color: #000 !important;
    background: #000;
	color: #fff;
    margin: 0 auto;
    line-height: 20px;
    padding: 20px 20px;
    font-size: 20px;
    border-radius: 40px;
    font-weight: 500;
    letter-spacing: 0;
    width: 100%;
	justify-content: center;
}
.privacy_label {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	cursor: pointer;
}
.privacy_label span{
	color: #7c7c7c
}
.privacy_label input {
	margin-top: 3px;
}

#sponsors { margin-top:30px; text-align:center;}
#sponsors .sponsor_category  { margin-top:15px; margin-bottom:15px;display: flex;flex-wrap: wrap;align-items: center;text-align:left;}
#sponsors .sponsor_category h3 { font-size:28px; color: #1A171B; 	font-weight: bold; 	font-style: italic; /*margin-bottom:15px;*/}
#sponsors .sponsor { display: flex; background: #fff; border-radius: 10px;  width: 100%; justify-content: center; min-height: 500px; align-items: center; transition: transform 0.3s; overflow: hidden;cursor:pointer;}
#sponsors .sponsor img { transition: transform 0.3s; max-width:300px; display:block; width: 100%; object-fit: cover; transform: scale(1);}
#sponsors .sponsor:hover img { transition: transform 0.3s;transform: scale(1.05);}
#sponsors .sponsor_category:last-of-type { border-bottom:none}
#sponsors .col-md-6:first-of-type {padding-right: 20px !important; padding-left: 0 !important;}
#sponsors .col-md-6:last-of-type {padding-left: 20px !important; padding-right: 0 !important;}

#sponsors a {display: block; text-decoration: none;}
#sponsors .align_titles {margin-right: 10px;}
/*#sponsors .sponsor:hover {box-shadow: 0 4px 15px rgba(0,0,0,0.1);transition: transform 0.2s; }*/



#all_sponsors { margin-top:30px; text-align:center;}
#all_sponsors .sponsor_category  { margin-top:15px; margin-bottom:15px;display: flex;flex-wrap: wrap;align-items: center;text-align:left; flex-direction: row; align-content: flex-start;}
#all_sponsors .sponsor_category h3 { font-size:28px; color: #1A171B; 	font-weight: bold; 	font-style: italic; /*margin-bottom:15px;*/}
#all_sponsors .sponsor_category p{padding-bottom: 20px}
#all_sponsors .sponsor {overflow: hidden; cursor:pointer; display: flex; background: #fff; border-radius: 10px;  width: auto; justify-content: center; min-height: 250px; align-items: center; transition: transform 0.3s;margin-bottom: 30px; }
#all_sponsors .sponsor img { max-width:200px; display:block; width: 100%;object-fit: cover; transform: scale(1);  transition: transform 0.3s;}
#all_sponsors .sponsor:hover img { transition: transform 0.3s;transform: scale(1.05);}
#all_sponsors .sponsor_category:last-of-type { border-bottom:none}
#all_sponsors .col-md-6:first-of-type {padding-right: 20px !important; padding-left: 0 !important;}
#all_sponsors .col-md-6:last-of-type {padding-left: 20px !important; padding-right: 0 !important;}
#all_sponsors a {display: block; text-decoration: none;}

#footer, #header_mobile_menu {  width: 100% ; padding: 65px 5% 35px 5%;color: #fff; background:#000 }

.footer_box { margin-left:0px; margin-right:0px;}
.footer_box.last { border-left:1px solid #fff; padding:20px 0 20px 50px;}
.footer_box h6{ margin:0px 0 30px 0; font-size:20px; color:#fff;font-weight:bold; font-style:italic; }
.footer_box p { line-height:26px; }
.footer_box p a{ font-size:20px; color:#fff; font-weight:bold; transition: all 0.2s ease-in; }
.footer_box p a:hover{color:#bfbebe; transition: all 0.2s ease-in;}

ul.footer_menu { margin:0px;}
ul.footer_menu li{margin-bottom:6px; font-size:15px; color:#fff; }
ul.footer_menu li, ul.footer_menu li a{color:#7c7c7c;display:flex; transition: all 0.2s ease-in;}
ul.footer_menu li a:hover{color:#bfbebe; transition: all 0.2s ease-in;}
ul.footer_menu .contact_link{padding-left: 5px;}

#logo_black.footer{width: 230px; height: 125px;margin: 65px 15px 40px 0px}

p.footer_note{font-size: 14px; font-weight: 600; padding-top: 50px; bottom: 0; position: absolute; padding-right: 10px;}

.info_footer_container{margin-bottom: 30px;}
.info_footer_container h6, .info_footer_container h6 a{font-size: 17px;font-weight: 400;padding-bottom:10px; color: #fff}
.info_footer_container h6.faq{margin-top:35px}
    
.section_footer{display: flex;align-items: stretch;}
.bank_icons{text-align:center;}

.align_center{display: flex; align-items: center; }


.footer_copyright { position:relative;z-index:0;padding-bottom:20px;padding-top:20px; background:#fff; color: #000;}
.footer_copyright p { line-height:20px;font-size:13px;color: #000;font-weight:400;}
.footer_copyright a { color: #000; text-decoration: none; transition: all 0.4s ease 0s; }
.footer_copyright a:hover { text-decoration: underline; transition: all 0.4s ease 0s;}

#wapp {position:relative;float:right;}
#wapp a{	display: block;	width: 75px;height: 20px;background:transparent url(../img/layout/wapp_logo_black.svg) no-repeat center;text-indent: -999999px!important;background-size:100%;}
#iframe {position:relative;float:right; margin-left: 15px;}
#iframe a{	display: block;	width: 52px;height: 20px;background:transparent url(../img/layout/iframe.png) no-repeat center;text-indent: -999999px!important;background-size:100%;}


/* GENERAL STYLES */
#content {  width: 100%; }

.content {    }
.content h1 {font-size:30px;font-weight:bold;color:#1a171b;margin:20px 0px 25px 0px; }
.content h2 {font-size: 25px;font-weight: 700;color:#1a171b;margin:30px 0px 30px 0px; }
.content h3 {font-size:18px;font-weight:bold;color:#1a171b;margin:20px 0px 15px 0px; }
.content h4 {font-size:16px;font-weight:bold;line-height:20px;margin:10px 0px 10px 0px; }
.content h5 {font-size: 25px;font-weight: 600;color: #000;	margin: 10px 0px 10px 0px;flex: 0 0 20%; margin: 0;line-height: 32px;}
.content h6 {font-size: 25px;font-weight: 600;color: #000;	margin: 10px 20px 10px 0px;flex: 0 0 50%; line-height: 32px;}
.content p { font-size: 18px; line-height: 25px; flex: 1; margin: 0; color: #000;}
.content p.intro_title{font-size: 35px;font-weight: 600;color: #000;	margin: 10px 0px 30px 0px;flex: 0 0 20%; margin: 0;line-height: 32px;padding-bottom: 30px}
.content p.hotel_subtitles{font-size: 25px;font-weight: 600;color: #000;margin: 10px 20px 10px 0px;flex: 0 0 20%;line-height: 32px;}
.content ul { margin:15px 5px 15px 0px;overflow:auto; }
.content ul li { margin:0 0 10px 0; font-size:18px; line-height:24px; background:transparent url(../img/layout/icons/black_circle.png) no-repeat 0 8px;padding-left:16px;}
.content ul li ul li{ margin:0 0 10px 0; font-size:18px; line-height:24px; background:transparent url(../img/layout/icons/grey_circle.png) no-repeat 0 9px;padding-left:16px; background-size: 6px;}
.content ul li.starting_point{ background:transparent url(../img/layout/icons/bell.png) no-repeat left 3px; padding-left: 40px; font-size: 18px; line-height: 30px; padding-bottom: 15px;}
.content ul li.time{ background:transparent url(../img/layout/icons/clock.png) no-repeat left 3px; padding-left: 40px; font-size: 18px; line-height: 30px; padding-bottom: 15px;}
.content ul li.date{ background:transparent url(../img/layout/icons/calendar.png) no-repeat left 3px; padding-left: 40px; font-size: 18px; line-height: 30px; padding-bottom: 15px;}
.content ul li.starting_point strong, .content ul li.time strong, .content ul li.date strong{display:block}

.content table { width: 100%;	border-collapse: collapse;margin-bottom:20px;}
.content table td {text-align: left;padding: 10px 7px; vertical-align: middle;font-size: 14px;}
.content table td.text-right {text-align: right;}
.content table td strong { font-size: 16px;}
.content table tr { border-bottom: 1px solid #e2e3e4;}
.content table tr.heading_row{ background:#1A171B; color:#fff; }

.dynamic_content h2.half_width{width:35%; font-size: 50px; font-weight: 600;margin: 0px 0px 5px 0px;}
.dynamic_content h2.full_width{width:100%; font-size: 50px; font-weight: 600;margin: 0px 0px 30px 0px;}
.dynamic_content h2.hotel_title{cursor:pointer; font-size: 45px;line-height: 50px;color: #000;  font-weight: 600; padding: 20px 0; position: relative; transition: all .3s ease-in-out;}
.dynamic_content h3{width:35%; font-size: 50px; font-weight: 600; color: #7c7c7c;margin: 0px 0px 70px 0px;}
.dynamic_content h5{cursor:pointer; font-size: 45px;line-height: 50px;color: #000; border-bottom: 1px solid #000; font-weight: 600; padding: 20px 0; position: relative; transition: all .3s ease-in-out;}
.dynamic_content h5 a{transition: all .3s ease-in-out;}
.dynamic_content h5:hover a{color: #7c7c7c; transition: all .3s ease-in-out;}
.dynamic_content h5::after{transition: all .3s ease-in-out;content: '';position: absolute;	right: 0; bottom: 0px; width: 35px; height: 100%; background: url(../img/layout/icons/arrow_up_right.svg) no-repeat scroll center center transparent; background-size: 100%; max-height: 90px;transform: translateY(0) rotate(0deg); transition: transform 0.3s ease;}
.dynamic_content h5:hover::after{transition: all .3s ease-in-out; background:  url(../img/layout/icons/arrow_up_right_grey.svg) no-repeat center;background-size: contain;}
.dynamic_content h5.active::after {transform: translateY(0) rotate(135deg);}
.dynamic_content .h5-content.open {padding: 20px 0px;}
.dynamic_content .h5-content.open p{padding-bottom: 10px;font-size: 19px;line-height: 27px;}
.dynamic_content p{padding-bottom: 10px;}

.remove_bottom_space{margin-bottom: -30px}

.flex-row {display: flex; padding: 20px 20px 20px 0px;align-items: flex-start;}
.flex-row.vertical {flex-direction: column;}
.content .flex-row h5{padding-right: 30px;}
.race_description{display: flex;flex-direction: column;}
.race_description h6{position: relative; font-size: 21px; line-height: 24px; font-weight: 500; color: #000; display: table-cell; vertical-align: middle;width: fit-content; margin-bottom: 20px;}
.race_description h6::after{content: ''; position: absolute;  left: 0;  bottom: 0px;  width: 100%;  height: 1px; background: #000;}
.race_description.certificates p{font-size: 20px;line-height: 37px;padding-bottom: 10px;}
.useful_info{display: flex;flex-direction: column; width: 100%;}
.useful_info h4{margin-top: 30px; font-size: 18px}
.useful_info h5{background: #fff;border-radius: 7px; font-size: 23px; padding: 10px 20px;cursor: pointer;position: relative;padding-right: 20px; margin:10px 0 0px 0;}
.useful_info p{padding: 5px 0;}

.useful_info h5::after {
	content: "";
	position: absolute;
	right: 20px;
	top: 50%;
	width: 16px;
	height: 16px;
	background: url("../img/layout/icons/caret_down.png") no-repeat center center;
	background-size: contain;
	transform: translateY(-50%) rotate(0deg);
	transition: transform 0.3s ease;
}
.useful_info h5.active{
	border-bottom-left-radius:0px;
	border-bottom-right-radius:0px;
}
.useful_info h5.active::after {
	transform: translateY(-50%) rotate(180deg);
}

.h5-content {
  max-height: 0;              
  overflow: hidden;           
  opacity: 0;                  
  transform: scaleY(0);         
  transform-origin: top center;  
  transition: max-height 0.4s ease, transform 0.4s ease, opacity 0.4s ease, padding 0.4s ease;
}

.h5-content.open {
    max-height: 5000px;  
    transform: scaleY(1);  
    opacity: 1;
	padding: 15px 20px;
	background: #fff;
	border-bottom-left-radius:7px;
	border-bottom-right-radius:7px;
}

.top_runner_description{padding: 20px 40px;}

.divider_line{background: #d2d2d2; height:1px; width: 100%;margin: 10px 0;}

.table_container {	overflow-x:auto; }
.table_container table {	width: 100%!important; height:auto!important;border-collapse: collapse!important;	}

ul.static_list { margin:15px 5px 15px 5px;overflow:auto;}
ul.static_list li { margin:0 0 10px 0; font-size:16px; line-height:24px; background:transparent url(../img/layout/arrow-list.png) no-repeat 0 5px;padding-left:13px;}

p.highlight {font-size: 18px; line-height:28px; font-weight: 400; color: #000; padding-right: 10%;}
p.highlight.black {   background: #1a171b;     }

a.read_more { position:relative; z-index:50; display:inline-block; overflow: hidden; margin-top: 30px; margin-bottom: 30px; padding:10px 50px 10px 10px; background:#1A171B; color:#fff; font-size:16px; font-weight:bold; letter-spacing: 1.2px;  transition: all 0.2s ease-in; }
a.read_more::after { display: block; content: '';  height: 2px; width: 30px;  position: absolute;  right: 0px; top: 0;  bottom: 0;	margin:auto; background: #fff; transition: all 0.2s ease-in;	}
a.read_more::before { opacity: 0; display: block; content: ''; height: 2px; width: 30px;  position: absolute;  left: -50px; top: 0;  bottom: 0; margin:auto; background: #fff; transition: all 0.2s ease-in; }
a.read_more:hover { padding-right: 10px;  padding-left: 50px; color:#fff; transition: all 0.2s ease-in; }
a.read_more:hover::after { right: -30px;  opacity: 0; transition: all 0.2s ease-in; }
a.read_more:hover::before { left: 0; opacity: 1; transition: all 0.2s ease-in; }
a.read_more.black { background:#1a171b;  }
a.read_more.yellow { background:#1a171b;  }
a.read_more.white { background:#fff; color:#1A171B }
a.read_more.white::before,a.read_more.white::after{background: #1A171B;}
a.read_more.greene { background:#05fe00; color:#1A171B; }

a.read_more.free{
	margin-top:10px;
	margin-bottom: 10px;
}

.partner_box {
	text-align: center;
    /* border: 1px solid rgba(0, 0, 0, 0.1); */
    padding-bottom: 15px;
    margin-bottom: 20px;
    float: left;
    width: calc(25% - 23px);
    position: relative;
    display: inline-flex;
    flex-direction: column;
	margin-left: 15px;
	margin-right: 15px;
	box-sizing: border-box;
	align-items:flex-start
}

.partner_box img{
	background: #f6f6f6;
}
.content .partner_box p {
	margin: 0;
    padding: 0 0px;
    text-align: left;
    line-height: 25px;
	color: #7c7c7c;
}

.content .partner_box h2 {
    margin: 20px 0px 20px 0px; 
  	text-align: left;
}

.proud_partners_wrap p.highlight {
	margin: 50px 0 35px 0;
    position: relative;
    overflow: hidden;
    font-size: 25px;
    font-weight: 600;
}

.partners_flex {
  display: flex;
  flex-wrap: wrap;
}

.partner_box:nth-child(4n + 1) { 
  margin-left: 0;
}
.partner_box:nth-child(4n) { 
  margin-right: 0;
}
.partner_box .underline_button{
	font-weight: 500;
    margin-top: 10px;
	z-index: 99;
}
hr.races {
	height: 1px;
    display: inline-block;
    background: #d2d2d2;
    width: 100%;
}
.title_thumb{width: 130px; margin: 0 7px -4px 7px;height: auto;}
.left_thumb { margin: 0px 0px 30px 0px; max-width: 630px; width: 100%; }
img.organizer { float: left; margin: 0px 30px 10px 10px; }

.access {  border-left:10px solid #1A171B;  padding: 5px 10px 5px 20px; margin: 15px 0; }

.gallery_bottom { border:1px solid #fff; } 

.group_logo { margin-top: 15px;	margin-bottom: 15px; text-align:center; padding: 15%; } 
.group_logo img { max-width:100%; } 

.iframe iframe {    width: 100%;    min-height: 1000px; }

.resultsform .button.thin-bg-dark {  margin-top: 40px; } 

.volunteers_link a.read_more { display:block; margin-top: 0px; font-size:24px; text-align:center; }
.volunteers_link .underline_button {padding-bottom: 3px;}

.black_bg_form label.control-label {   color: #000; } 
.checkbox label.control-label{font-weight: 300;}

/* HOME STYLES */

.vertical_banner {position:relative; overflow:hidden;  }
.vertical_banner .vertical_banner_text{ width:100%; height:100%; padding:20px; display:table; text-align:center;  }
.vertical_banner p { position:relative; font-size: 21px; line-height: 24px; font-weight: 500; color:#000;  display: table-cell;  vertical-align: middle; padding-bottom: 0}
.vertical_banner p span {  display:block; font-size: 32px;   }
.vertical_banner_text p::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 1px;
    background: #000;
    transform-origin: right;
    transform: scaleX(1);
    transition: transform 0.4s ease;
	
}
.vertical_banner_text p::before {
    content: '';
    position: absolute;
    top: 50%;
    right: -23px;
    width: 16px;
    height: 16px;
    background:  url(../img/layout/icons/arrow_up_right.svg) no-repeat center;
    background-size: contain;

    opacity: 0;
    transform: translateY(-50%) translateX(-6px);
    transition: opacity 0.3s ease, transform 0.3s ease;
}
.vertical_banner:hover .vertical_banner_text p::before {
    opacity: 1;
    transform: translateY(-50%) translateX(0);
}

.vertical_banner:hover .vertical_banner_text p::after {
    transform: scaleX(0);
}

.vertical_banner_text p {display: inline-block;	position: relative;}

.boxes-row {display: flex;width: 100%;}
.box-item {flex: 1 1 0;}
p.grey_text{color: #7c7c7c;font-size: 30px; font-weight: 600; line-height: 37px;}
p.text_message{color: #dd384c; border: 2px solid #dd384c; width: fit-content;float: right; padding: 5px 15px;border-radius: 20px; font-size: 19px; font-weight: 500;}
p.text_message a{color: #dd384c;}
p.black_label{color: #000; border: 2px solid #000; width: fit-content; float: left; margin-bottom: 40px; padding: 6px 20px; border-radius: 28px; font-size: 18px;  font-weight: 500;}

.race_list p{font-size: 45px; color: #000; border-bottom: 1px solid #000;font-weight: 600; padding: 15px 0; position: relative;transition: all .3s ease-in-out;}
.race_list p:hover{color: #7c7c7c;transition: all .3s ease-in-out; }
.race_list p::after{content: '';position: absolute;	right: 0; bottom: 0px; width: 35px; height: 100%; background: url(../img/layout/icons/arrow_up_right.svg) no-repeat scroll center center transparent; background-size: 100%; transition: all .3s ease-in-out;}
.race_list:hover p::after{background:  url(../img/layout/icons/arrow_up_right_grey.svg) no-repeat center;background-size: contain;transition: all .3s ease-in-out;}


#logo_black {display: block; width: 457px; height: 238px; margin: 0px 0 50px 0px; overflow: hidden; transition: all .3s ease-in-out;}
#logo_black a {position: relative;display: block; width: 100%; height: 100%; text-indent: -999999px !important; background: url(../img/layout/logo_black.png) no-repeat scroll center center transparent; transition: all .3s ease-in-out; background-size: 100%; z-index: 99;}

.middle_banner {position:relative; margin:30px 0;}
.middle_banner p { position:absolute; width:80%; background:#1A171B; padding:10px; font-size:34px; bottom:30px; color:#fff; font-weight:700; font-style:italic; }

.heading_box { display:flex; margin:0px 0 30px 0; color:#000; padding:15px; position:relative;justify-content: space-between;}
/* .heading_box::before {display: block; content: ''; height: 100%; width: 80%;  position: absolute;  left: -80%; top: 0;  bottom: 0; margin:auto; background: #1a171b; } */
.heading_box h1.heading_title, .heading_box h2.heading_title { font-size:20px; font-weight:normal; margin:0px; display: flex; justify-content: space-between; align-content: center; width: 100%; align-items: center; }      
.heading_box h1.heading_title strong, .heading_box h2.heading_title strong { font-size:35px; font-weight:bold; margin-right:30px;  }      
.heading_box.reverse {  background:#fff; color:#1a171b;}
.heading_box.reverse::before { background: #fff; }  
.heading_box.white{background:#fff; color:#1A171B;}
.heading_box.white::before{background:#fff; }

h2.page_subtitle{color: #000; font-size: 45px; font-weight: 600; margin-bottom: 50px;}
h2.page_subtitle strong{color: #7c7c7c;font-weight: 600;}
h2.general_subtitle{color: #000; font-size: 20px; font-weight: 600; margin-bottom: 30px; margin-top: 20px; text-align: center;}

.deltio_link a.read_more { display:block; margin-top: 30px; font-size:30px; text-align:center;margin-bottom: 0px; }

.facebook_video {height:500px;}

.video_post { margin-top:20px; margin-bottom:20px; }

.full_width_banner {position: relative; width: 100%; overflow: hidden;}
.full-width-img { width: 100% !important; height: auto; display: block;border-radius: 10px;}
.text-overlay {position: absolute; color: #ffffff; padding: 15px; font-weight: bold; pointer-events: none; z-index: 2;}
.top-left {top: 10px; left: 10px; font-size: 25px; font-weight: 500; width: 30%;}
.bottom-left {bottom: 10px; left: 10px; font-size: 20px; width: 30%; font-weight: 400;}
.overlay_link {position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 1;}
.row_list{display: flex; justify-content: space-between;}
.row_list a{font-size: 21px; line-height: 24px; font-weight: 500; color: #000; display: table-cell; vertical-align: middle;position: relative;}
.row_list a::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 1px;
    background: #000;
    transform-origin: right;
    transform: scaleX(1);
    transition: transform 0.4s ease;
}
.row_list a:hover::after {
    transform: scaleX(0);
}
.row_list a::before {
    content: '';
    position: absolute;
    top: 50%;
    right: -23px;
    width: 16px;
    height: 16px;
    background:  url(../img/layout/icons/arrow_up_right.svg) no-repeat center;
    background-size: contain;

    opacity: 0;
    transform: translateY(-50%) translateX(-6px);
    transition: opacity 0.3s ease, transform 0.3s ease;
}
.row_list a:hover::before {
    opacity: 1;
    transform: translateY(-50%) translateX(0);
}
.semi_width_banner {position:relative;}
.semi_width_banner p { position:absolute; width:80%; background:#1A171B; padding:10px; font-size:34px; bottom:30px; color:#fff; font-weight:700; font-style:italic; }
.semi_width_banner img{border-radius: 10px}
.semi_width_banner {position: relative; overflow: hidden; width: 100%; cursor:pointer}
.semi_width_banner img {width: 100%; display: block;transition: all 0.3s ease-in-out}
.semi_width_banner:hover img{filter: grayscale(0.7); transition: all 0.3s ease-in-out}
.gradient-overlay {position: absolute;bottom: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(to top, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0) 100%);	border-bottom-left-radius: 10px;border-bottom-right-radius: 10px; z-index: 1; pointer-events: none; }
.banner-text {position: relative; color: #ffffff; left: 20px; z-index: 2; text-shadow: 1px 1px 3px rgba(0,0,0,0.5); pointer-events: none;}
.semi_width_banner .overlay_link {position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 3;}
.align_info{display: flex; position: absolute; height: 100%; top: 0; justify-content: center; width: 100%; flex-direction: column; text-align: center;z-index: 99;}
.align_info .banner_text.title_text {font-size: 45px; font-weight: 600;color: #fff}
.align_info .banner_text.subtitle_text {padding: 10% 25%; font-size: 18px; font-weight: 500;color: #fff}
.align_info .banner_text.button_text {color: #dd384c; font-size: 18px; font-weight: 400;position: relative; width: fit-content; margin: 0 auto;}
.align_info .banner_text.button_text::after {content: ''; position: absolute;left: 0; bottom: 0px; width: 100%; height: 1px; background: #dd384c; transform-origin: right;    transform: scaleX(1); transition: transform 0.4s ease;}
.align_info:hover .banner_text.button_text::after { transform: scaleX(0);}
.align_info .banner_text.button_text::before { content: ''; position: absolute; top: 50%; right: -23px; width: 16px; height: 16px; background:  url(../img/layout/icons/arrow_up_right_pink.svg) no-repeat center; background-size: contain; opacity: 0;  transform: translateY(-50%) translateX(-6px);  transition: opacity 0.3s ease, transform 0.3s ease;}
.align_info:hover .banner_text.button_text::before { opacity: 1; transform: translateY(-50%) translateX(0);}

.volunteers_intro_text {display: flex; flex-direction: column; padding-right: 40%;}  
.volunteers_intro_text p{color: #000;}  
.volunteers_intro_text p.volunteers_title{font-size: 35px; font-weight: 600;line-height: 40px;}
.volunteers_intro_text p.volunteers_subtitle{color: #7c7c7c; font-size: 25px; font-weight: 600;line-height: 32px; padding: 30px 0 50px 0;}
.linear_button{font-size: 21px; line-height: 24px; font-weight: 500; color: #000;position: relative;width: fit-content;} 
.linear_button::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 1px;
    background: #000;
    transform-origin: right;
    transform: scaleX(1);
    transition: transform 0.4s ease;
}
.linear_button:hover::after {
    transform: scaleX(0);
}
.linear_button::before {
    content: '';
    position: absolute;
    top: 50%;
    right: -23px;
    width: 16px;
    height: 16px;
    background:  url(../img/layout/icons/arrow_up_right.svg) no-repeat center;
    background-size: contain;

    opacity: 0;
    transform: translateY(-50%) translateX(-6px);
    transition: opacity 0.3s ease, transform 0.3s ease;
}
.linear_button:hover::before {
    opacity: 1;
    transform: translateY(-50%) translateX(0);
}

/* BLOG STYLES */
.blog_mobile{display: none;}
.page_title.article_title h1{ font-size: 55px;}

.blog_post { margin-top:20px; margin-bottom:20px; cursor:pointer; }
.blog_post img { border-radius: 10px;  transition: all 0.3s ease-in-out}
.blog_post:hover img{filter: grayscale(0.7); transition: all 0.3s ease-in-out}
.blog_post span.date {display: block; font-size: 14px; padding-top: 20px; font-weight: 600;color: #1A171B; }
.blog_intro span.date {display: block; font-size: 14px; padding-top: 0px; padding-bottom:20px; font-weight: 600;color: #1A171B; }
.blog_post h3 {color: #1A171B;    min-height: 110px; font-size: 30px; margin-top: 20px; margin-bottom: 20px; font-weight: 600; line-height: 35px;display: -webkit-box;  -webkit-line-clamp: 3;   -webkit-box-orient: vertical;  overflow: hidden; text-overflow: ellipsis; }
.blog_post p { color: #7c7c7c; font-size: 19px; font-weight: 600;display: -webkit-box; -webkit-line-clamp: 4;  -webkit-box-orient: vertical;  overflow: hidden;    text-overflow: ellipsis;}
.blog_post.event_post { color: #fff;  }
.blog_post.event_post h3, .blog_post.event_post p { color: #1A171B;  }

.blog_content p, .blog_content br{padding-bottom: 20px}
.blog_gallery{margin-bottom: -30px;}
.blog_gallery .row { margin-left: -12.5px; margin-right: -12.5px;}
/* .blog_gallery .col-md-3,.blog_gallery .col-sm-4,.blog_gallery .col-xs-6 { padding-left: 12.5px;  padding-right: 12.5px;  }
.blog_gallery .col-md-3:nth-child(4n+1) {padding-right: 0;}
.blog_gallery .col-md-3:nth-child(4n) { padding-left: 0;} */

.align_titles {display: flex; justify-content: space-between; align-items: center;}
.align_titles a.underline_button{margin-left: 50px;font-weight: 500; font-size: 21px;}
.blog_intro {padding: 0px 10% 20px 0; color: #000;  }
.blog_intro p { font-size: 23px; line-height: 32px; font-weight: 600;  }
p.heading_title{color: #000; font-size: 30px; font-weight: 600;line-height: 35px;}
p.sponsor_title{color: #000; font-size: 25px; font-weight: 600;line-height: 35px;padding-bottom: 20px;}
.freeraces p.heading_title, .dynamic_titles p.heading_title{font-size: 35px; margin-bottom: 30px;}
.freeraces p.heading_title span, .dynamic_titles p.heading_title span{display: block; color: #7c7c7c; font-size: 25px; padding-top: 30px;}
.underline_button{font-size: 18px; color: #000; /*border-bottom: 1px solid #000;*/position: relative;}
.underline_button::after { 
    content: '';
    position: absolute;
    left: 0;
    bottom: 3px;
    width: 100%;
    height: 1px;
    background: #000;
    transform-origin: right;
    transform: scaleX(1);
    transition: transform 0.4s ease;
}
.underline_button:hover::after {
    transform: scaleX(0);
}
.underline_button::before {
    content: '';
    position: absolute;
    top: 50%;
    right: -23px;
    width: 16px;
    height: 16px;
    background:  url(../img/layout/icons/arrow_up_right.svg) no-repeat center;
    background-size: contain;

    opacity: 0;
    transform: translateY(-50%) translateX(-6px);
    transition: opacity 0.3s ease, transform 0.3s ease;
}
.underline_button:hover::before {
    opacity: 1;
    transform: translateY(-50%) translateX(0);
}
#baby-lake-run, #kids-run, #amea-run, #family-run {scroll-margin-top: 80px;}

.blog_intro.page_intro{padding: 20px 10% 20px 0;}
.blog_intro.page_intro p{color: #7c7c7c}

.home_news .align_titles a{font-size: 19px; font-weight: 500;}

.bordered_button{margin-top: 30px;border: 2px solid #000; width: fit-content;  float: left; margin-bottom: 40px; padding: 6px 20px; border-radius: 28px; font-size: 18px; font-weight: 600;}

.bordered_button {
  text-align: center;
  text-decoration: none;
  display: inline-block;
  cursor: pointer;
  overflow: hidden;
  position: relative;
  transition: all 0.3s ease;
}

.bordered_button:after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  background-color: rgba(0, 0, 0, 0.05);
  border-radius: 50%;
  opacity: 0;
  transform: translate(-50%, -50%);
  transition: all 0.5s ease;
}

.bordered_button:hover:after {
  width: 100%;
  height: 200px;
  opacity: 1;
}

.bordered_button:focus {
  outline: none;
}

.bordered_button:active {
  transform: translateY(2px);
  box-shadow: none;
}

/* GALLERY STYLES */

.gallery_box {position:relative; margin:15px 0;  }
.gallery_box p {position: relative; width: 100%; padding: 10px 10px 10px 0; font-size: 26px; color: #000; font-weight: 700; }
.gallery_box img{border-radius: 10px;transition: all 0.3s ease-in-out;}
.gallery_box:hover img{filter: grayscale(0.7);transition: all 0.3s ease-in-out;}
.gallery { margin-top:30px; margin-bottom:0px; }    


/* HOTEL STYLES */

.hotels_bg {  background-image:url('../img/layout/hotels_bg.jpg'); background-repeat: repeat;  background-size: cover;  background-position: center bottom;  background-attachment: scroll; }

.hotels_bg h1 {
	text-align: center;
    font-size: 28px;
	font-style: italic;
    margin-bottom: 30px;
    margin-top: 30px;
	font-weight: bold;
}

.hotels_bg .flex_center {
	display: flex;
    justify-content: center;
    align-items: center;
}

.hotel_box { position:relative; margin:0; padding-top:20px; padding-bottom:20px; border: 1px solid rgba(255,255,255,0.5); background: #f6f6f6; text-align:center; transition: all 0.2s ease-in;}
.hotel_box:hover{border: 1px solid rgba(255,255,255,0.7); transition: all 0.2s ease-in;}
.hotel_box p{ font-size:18px; font-weight:300; margin-top:20px;}
.hotel_box img{filter: invert(1)}

.hotel_cover_bg { background-repeat: no-repeat;background-position:center center; background-size:cover; height: 60vh; min-height:300px; position:relative; text-align:center; }
.hotel_cover_bg .hotel_logo { position:absolute;top:auto;bottom:50px;width:100%; text-align:center; }

.hotel_notice { }
.hotel_notice img { display:inline-block;  height:100px; vertical-align:middle; }
.hotel_notice p { display:inline-block; color: #1A171B;	font-weight: bold;	font-size: 18px;  }

.hotel_contact p { font-weight: bold; 	font-size: 15px; }

.hotel_facilities ul li { display:inline-block; width:32%; margin-right:1%;}


/* RACES STYLES */
.page_cover_bg {background-repeat: no-repeat; background-position: center center; background-size: cover; height: 70vh; min-height: 350px; position: relative; text-align: center;}
.page_cover_bg.small {height: 40vh;}
.page_cover_bg.checkout {height: 50vh;}
.page_cover_bg .gradient-overlay {border-bottom-left-radius: 0px;border-bottom-right-radius: 0px;}
.page_title{position: relative; top: auto;bottom: 50px; text-align: left;z-index: 9; height: 100%; display: flex; align-items: flex-end;justify-content: flex-start;}
.page_title h1{color: #dd384c; font-size: 80px; font-weight: 600;}
.page_cover_bg.checkout .page_title {
    position: relative;
    top: auto;
    bottom: 50px;
    text-align: left;
    z-index: 9;
    height: 100%;
    display: flex;
    align-items: flex-start;
    justify-content: flex-end;
    flex-direction: column;
}

.page_sponsor{position: relative; top: auto;bottom: 50px; text-align: right;z-index: 9; height: 100%; display: flex;align-items: flex-end;justify-content: flex-end;}
.page_sponsor img{width:200px}
.page_sponsor .sponsor_bg{background: #fff; padding: 15px 60px 30px 60px; border-radius: 10px;}
.page_sponsor .sponsor_bg p{color: #7c7c7c;text-align: center; font-size: 15px; font-weight: 400; padding-bottom: 5px;}


.race {position:relative; margin:15px 0;  }
.race p {position: relative; width: 100%; padding: 15px 10px 10px 0; font-size: 18px;color: #000; font-weight: 400;}
.race p span { display:block; font-size:26px; font-weight:700;  }
.race.white p{ color:#1A171B; background:#fff}

.iaaf_certificate { max-width:100%; }

.google_map { display:block;margin:30px 0 20px 0;}

.race_box{ margin:30px 0 30px 0;text-align:center;display:block; border:5px solid #fff;padding:20px 0; transition: all 0.2s ease-in; }
.race_box:hover{ border:5px solid #bdbdbd; transition: all 0.2s ease-in;}
.race_box a {display:block; }
.race_box h3 { color:#fff; font-size:30px; margin-top:20px; }
.race_box p { color:#fff; font-size:14px; margin-top:10px; }   

.freerace-card{
	position:relative;
	padding: 20px;	
	background: #f5f5f5;
	display: flex;
    flex-direction: column;
    align-items: center;
	transition: opacity 0.2s linear;
}
.freerace-card .main_button{
	line-height: 20px;
    padding: 20px 20px;
    font-size: 21px;
    border-radius: 40px;
    font-weight: 500;
	background: #dd384c;
	color: #fff;
	width: 100%;
    text-align: center;
	margin-top: 15px;
	max-width: 250px;
}
.submit_button.main_button{
    font-size: 21px;
    border-radius: 40px;
	padding: 15px 60px;
	display: flex;
    margin: 20px auto 0 auto;
}
.contactform .submit_button.main_button{
    margin-top: 0;
    float: right;
}
.product-card{
	position:relative;
	padding: 20px;	
	background: #f5f5f5;
	transition: opacity 0.2s linear;
}

.product-card.is-fixed, .freerace-card.is-fixed {
	position: fixed;
	top: 0px;
	z-index: 1000;
}

.product-card.is-hidden, .freerace-card.is-hidden {
	opacity: 0;
	transform: translateY(40px);
	pointer-events: none;
}

.product-card p, .freerace-card p{
    font-size: 17px;
    text-align: center;
}

.product-actions input.quantity {
    width: 56px;
    height: 52px;
	line-height: 60px;
	border-radius: 0;
	box-shadow: none;
    display: inline-block;
    font-size: 22px; 
    text-align: center;
    font-weight: bold;
    color: #1a171b;
	background:#fff;    
	border: 1px solid #f6f6f6;
	float:left;
}
.product-actions .minus, .product-actions .plus, .cart .minus, .cart .plus {
    display: inline-block;
    width: 56px;
    height: 52px;
	line-height: 50px;
    text-align: center;
    font-weight: bold;
    font-size: 28px;   
    color: #1a171b;
    background: #fff;
    -webkit-transition: background 200ms ease-in-out;
    transition: background 200ms ease-in-out;
    border: 1px solid #f6f6f6;
	margin:0px 5px;
	float:left;
}
.product-actions .minus { 
	line-height: 46px;   
}

.product-actions .minus:hover, .product-actions .plus:hover, .cart .minus:hover, .cart .plus:hover {
    background: #1a171b;
    color: #fff;
}
.product-actions input[type=number]::-webkit-inner-spin-button, 
.product-actions input[type=number]::-webkit-outer-spin-button { 
  -webkit-appearance: none; 
  margin: 0; 
}

.form-quantity{
	margin: 0px 0 0 0;
	padding:0px;
	display:inline-block;
}
.form-quantity label{	
	float:left;
	font-size:18px!important;
	font-weight:bold!important;
	margin-top:13px!important;
}

.form-checkboxes .select{
	display: flex;
}
.form-checkboxes .select label{
	background-color: #fff;
	color: #1A171B;
}
.form-checkboxes .select label:last-child{
	margin-right: 0px;
}
.form-options{
	margin: 10px 0;
	padding:0px;
	border-bottom: 1px solid #f6f6f6;
}
.form-options label{	
	float:left;
	font-size:14px!important;
	padding-left:0px!important;
	cursor:default;
}

.form-options .select2Buttons{
	display: inline-block;
}
.form-options .select2Buttons ul{
	margin: 0;	
}
.form-options .select-buttons li {	
	background-image: none!important;
	padding-left:0px!important;	
}
.form-options .select-buttons li a{
	color: #1a171b;
	background: #fff;
	font-weight: bold;	
	border: 1px solid #1a171b;
	margin:0 4px;
	padding:8px;
}
.form-options .select-buttons li.disabled  {	
	border: 1px solid #f6f6f6;		
	overflow: hidden;
}
.form-options .select-buttons li.disabled span {		
	margin:0 4px;
	padding:8px;
}
.form-options .select-buttons li a:hover { 
	background: #1a171b;
	color: #fff;
}
.form-options .select-buttons li a:hover:not(.out-of-stock), .form-options .select2Buttons .picked {   
    border-color: transparent;
}
.form-options .select2Buttons .picked{
	background: #1A171B;
	color: #fff;
}


/* ==================================
   PRODUCT FILTERS
   =================================== */

.no-results .icon-info{
	display: block;	
	margin: 20px auto 20px auto;
	width:48px;
	height:48px;
	background: url(../img/layout/icon-info.svg) no-repeat center center;
}
.no-results h2{
	font-size:26px;margin:10px 0px 20px 0px;
}
.no-results p{
	line-height:22px;margin:15px 0px 15px 0;
}

.pagination{
	clear: both;
	display: block;
	width: 100%;
	margin: 20px 0 0 0;
}
.pagination .disabled{
	display: none;
}

.page-navigation{
	margin-top:10px;
	padding: 10px 0px;
	text-align: center;
	width: 100%;
	display: inline-block;
	border-top: 1px solid #d2d2d2;
	font-size: 12px;
}
.page-navigation a, .page-navigation span{
	width: auto;
	min-width: 33px;
	margin: 0;
    display: inline-block;
    text-align: center;
    color: #1a171b;
    text-transform: uppercase;
    text-decoration: none;
    font-weight: 400;
	font-size:14px;
    letter-spacing: .25px;
    -webkit-transition: all .25s ease-in-out;
    transition: all .25s ease-in-out;
    border: solid 2px #fff;
	border-radius:0px;
}
.page-navigation a, .page-navigation span.current{
	padding: 5px 10px;
	border-radius: 50%;
}
.page-navigation span.current{
	background-color: #1A171B;
	color: #fff;
	/* border: 2px solid #1A171B; */
}
.page-navigation a:hover{
	color: #fff;
	/* border: 2px solid #1A171B; */
	background: #1A171B;
}
.page-navigation .next-prev{
	display: block;
	width: 100%;
	border: 0;
	margin-top: 5px;
}
.page-navigation .next-prev a{	
	padding: 5px 10px 5px 10px;
	border:2px solid #1A171B;
	background: #1A171B;
	color: #fff;
	border-radius:30px;
}
.page-navigation .next-prev a:hover{	
	border:2px solid #1A171B;
	background: #1A171B;
}
.page-navigation .next-prev span{
	/*width: 48%;*/
	display: inline-block;
}
.page-navigation .next-prev .disabled{
	display: none;
}
.page-navigation .next-prev span.prev{
	float: left;
	display: inline-block;
	text-align: left;
}
.page-navigation .next-prev span.next{
	float: right;
	display: inline-block;
	text-align: right;
}



/* LOADER MASK
================================================== */

.js-loading{
/* 	position: relative; */
}
.js-loading-overlay {  
  position:absolute;
  top:0; bottom:0;
  left:0; right:0;  
  z-index:199;  
  background:#1A171B;
  opacity:0.8;  
  border-radius: inherit;
}
.jscroll-loading{
	position: relative;
	display: inline-block;
	width: 100%;
}

.spinner {	
  top:42%;
  left: 45%;
  position: absolute;
  width: 50px;
  height: 30px;
  text-align: center;
  font-size: 15px;
  z-index:200;
}

.spinner > div {
  background-color: #1a171b;
  height: 100%;
  width: 6px;
  margin-right: 2px;
  display: inline-block;  
  -webkit-animation: stretchdelay 1.2s infinite ease-in-out;
  animation: stretchdelay 1.2s infinite ease-in-out;
}

.spinner .rect2 {
  -webkit-animation-delay: -1.1s;
  animation-delay: -1.1s;
}

.spinner .rect3 {
  -webkit-animation-delay: -1.0s;
  animation-delay: -1.0s;
}

.spinner .rect4 {
  -webkit-animation-delay: -0.9s;
  animation-delay: -0.9s;
}

.spinner .rect5 {
  -webkit-animation-delay: -0.8s;
  animation-delay: -0.8s;
}


@-webkit-keyframes stretchdelay {
  0%, 40%, 100% { -webkit-transform: scaleY(0.4) }  
  20% { -webkit-transform: scaleY(1.0) }
}

@keyframes stretchdelay {
  0%, 40%, 100% { 
    transform: scaleY(0.4);
    -webkit-transform: scaleY(0.4);
  }  20% { 
    transform: scaleY(1.0);
    -webkit-transform: scaleY(1.0);
  }
}

/* ==================================
   CUSTOMERS
   =================================== */

.customer_dashboard{
	display:block;
	margin-bottom:20px;	
}

/* ==================================
   CHECKOUT
   =================================== */

.checkout-navigation {
	display: block;
	width: 100%;
	margin: 0 0 0px 0;
	padding: 40px 0 0 0;  
	background-size: 16px;	
	color: #fff;
	/* border-bottom: 1px solid #000; */
}

.checkout-navigation h1{
	margin-bottom: 30px;
	position: relative;
	font-size: 32px;	
	font-weight:bold;
}
.checkout-navigation h1 .first-word{	
	color: #1A171B;
	line-height: 40px;
	letter-spacing: 0.4em;	
}

.checkout-navigation .row {
    margin-left: 0;
    margin-right: 0
}

.checkout-navigation .step-item {
    height: auto;
    color: #fff;
}

.checkout-navigation .step-item .step-line {
    background-color: #fff;
    height: 1px;
    margin-top: 14px;
    padding: 0;
    transition: all .25s ease-in;
    -webkit-transition: all .25s ease-in
}

.checkout-navigation .step-item .step-index {
    font-size: 3em;
    font-weight: bold;
	margin-top: -0.4em;
    padding: 0;
    text-align: center;
    transition: all .25s ease-in;
    -webkit-transition: all .25s ease-in;
}

.checkout-navigation .step-item .step-title {
    font-size: 14px;
    text-align: center;
    font-weight: bold;
    transition: all .25s ease-in;
    -webkit-transition: all .25s ease-in;
    letter-spacing: .25px;
    color: #fff;
}

.checkout-navigation .step-item.complete .step-line {
    background-color: #fff;
}
.checkout-navigation .step-item.active .step-line {
    background-color: #fff;
}
.checkout-navigation .step-item.complete .step-index {
	color: #fff;
}
.checkout-navigation .step-item.active .step-index {
	color: #fff;
}
.checkout-navigation .step-item.active .step-title {
	color: #fff;
}
.checkout-navigation .step-item.complete .step-title a{
	color: #fff;
}

.checkout-navigation .step-item.complete:hover {
    cursor: pointer;
    color: #fff;
}

.checkout-navigation .step-item.complete:hover .step-line {
    background-color: #fff;
}

@media (max-width:767px) {
	.checkout-navigation .step-item{
		height: auto;
	}
    .checkout-navigation .step-item .step-title {
        opacity: 0
    }
}


.checkout-field{
	display: block;
	margin-bottom: 40px;
}
.checkout-field label{
	font-size: 1.5em;
	font-weight: bold;
	color:#414141;
}
.checkout-field label:hover{
	color: #bfbebe;					
}
.checkout-field input{
	font-size: 2em;
	font-weight: bold;
	margin: 15px 10px 0 0!important;
}
.checkout-field .badge{
	display: inline-block;
	float: right;
	font-weight: bold;
	margin-top: 5px;
	background:#1a171b;
	font-size: 13px;
}
.checkout-field .image{
	display: inline-block;
	margin-left: 10px;
}
.checkout-field .description{
	display: block;
	padding-top: 10px;
	margin-top: 10px;
	border-top: 1px solid #f6f6f6;
	font-size: 	1.0em;
	text-align: justify;
}


.checkout-field .description{padding:15px 0;}
.checkout-field .description h5{font-size:14px;font-weight:bold;}
.checkout-field .description ul {margin-bottom:10px;}
.checkout-field .description ul li{margin:5px 0px 5px 5px;font-size:14px;position:relative;padding-left:12px;background: url('../img/layout/arrow-list-black.png') no-repeat scroll 0px 5px transparent; }

.checkbox input.form-control[type="checkbox"]{
	width: 30px;
	margin-top: 16px;
	margin-left: -10px;
}

/* ==================================
   CART
   =================================== */
   
.icon_close {	
	background: url(../img/layout/cd-remove-item.svg) no-repeat center center;
	width: 32px;
	height: 32px;
	display:inline-block;
}
   
.close {
    color: #1A171B;
    font-size: 22px;
    font-weight: 600;
    opacity: 0.9;
	float:none;
}

.form-group{margin-bottom:5px;}
.form-group.number.form-quantity{margin-bottom: 25px;text-align: center; display: flex; flex-wrap: wrap; justify-content: center;    margin-top: 10px;}

.table.cart{
	background: #f6f6f6;
	font-size: 14px;	
}
.table.cart > tbody > tr > td, .table.cart > tbody > tr > th, .table.cart > tfoot > tr > td, .table.carte > tfoot > tr > th,
.table.cart > thead > tr > td, .table.cart > thead > tr > th {
    vertical-align: middle;
    padding: 10px;
	border-bottom: 1px solid #f6f6f6;	
	font-weight:300;
	text-align: left;
}
.table > thead > tr > th{
		background:#1a171b;
		color:#fff;
		font-weight:700!important;
}
.table-hover > tbody > tr:hover {
    background-color: #f6f6f6;
}

.cart_button .btn {width:100%;}

.cd-cart {
  position: absolute;
  top: 0;
  margin-right: 15px;
  height: auto;
  width: 380px;
  border:3px solid #1a171b;  
  background: #fff;
  padding-top: 0px;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  z-index: 99999;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: opacity .3s 0s, visibility 0s .3s;
  -moz-transition: opacity .3s 0s, visibility 0s .3s;
  transition: opacity .3s 0s, visibility 0s .3s;	
}
.cd-cart.static{
	position: relative;
	opacity: 1;
	visibility: visible;
	width: 100%;
	height: auto;
	top:auto;
	box-shadow:none;
	border:0px;
	margin-bottom:70px;
}

.cd-cart.static{
	background:none
}

.cd-cart.is-visible {
  opacity: 1;
  visibility: visible;
  -webkit-transition: opacity .3s 0s, visibility 0s 0s;
  -moz-transition: opacity .3s 0s, visibility 0s 0s;
  transition: opacity .3s 0s, visibility 0s 0s;
  display:block;
}

.cd-cart.speed-in {
  right: 0;
}
.cd-cart > * {
  padding: 0 10px;
}
.cd-cart.static > * {
  padding: 0 0;
}
.cart-empty{
	padding: 50px 30px!important;
	text-align: center;
	color: #1a171b;
}
.cart-empty .icon-info{
	display: block;
	width:48px;
	height:48px;
	background: url(../img/layout/icon-info-black.svg) no-repeat center center;
	margin: 0 auto 30px auto;	
}
.cart-empty p{	
	margin-bottom: 50px;		
}

.cd-cart .cd-cart-items {
  padding: 0;
}
.cd-cart .cd-cart-items li {
  position: relative;
  padding: 10px 10px;
  border-bottom: 1px solid #f6f6f6;
  background:none;
  margin-bottom:0px;
}
.cd-cart .cd-cart-items li:last-child {
  border-bottom: 1px solid #f6f6f6;
}
.cd-cart .cd-image, .cd-cart .cd-info{
	display: inline-block;
	vertical-align: top;
}
.cd-cart .cd-image{
	 width: 25%;
}
.cd-cart .cd-info{
	/* margin-left: 13%; */
    text-align: left;
    width: 100%;
	margin-top:5px;
}
.badge{
	background-color: #1A171B;
}
.cd-cart .cd-qty, .cd-cart .cd-price {
  color: #1a171b;
}
.cd-cart .cd-price {
  margin-top: .4em;
}
.cd-cart .cd-item-remove {
  position: absolute;
  right: 10px;
  top: 35px;
  bottom: auto;
  -webkit-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: #f2f2f2 url("../img/layout/cd-remove-item.svg") no-repeat center center;
}
.cd-cart .cd-item-remove:hover {
  background-color: red;
}
.cd-cart .cd-cart-total {
  padding-top: 1em;
  padding-bottom: 1em;
  font-size: 14px;
}
.cd-cart .cd-cart-total p{
	line-height: 22px;
	margin: 10px 0px 10px 0;
}
.cd-cart .cd-cart-finaltotal {	
	font-size: 18px;
}
.cd-img-replace {
  /* replace text with a background-image */
  display: inline-block;
  overflow: hidden;
  text-indent: 100%;
  white-space: nowrap;
}
.cd-cart .cd-cart-total span {
  float: right;
}
.cd-cart .cd-cart-total::after {
  /* clearfix */
  content: '';
  display: table;
  clear: both;
}
.cd-cart .checkout-btn {
  display: block;
  width: 100%;
  height: 60px;
  line-height: 60px;
  background: #1a171b;
  color: #FFF;
  text-align: center;
  font-weight:bold;
  font-size: 20px;
  transition: all .3s ease;
}
.cd-cart .checkout-btn:hover ,.no-touch .cd-cart .checkout-btn:hover {
  background: rgba(0,0,0,0.8);
  transition: all .3s ease;
}
.cd-cart .cd-go-to-cart {
  text-align: center;
  margin: 10px 0;
}
.checkout .checkout-btn, .checkout .cd-go-to-cart, .checkout .cd-item-remove{
	display: none;
}

.cd-cart .cd-cart-notice { 
  background: #f6f6f6 url("../img/layout/shipping.svg") no-repeat 20px center;
  background-size:48px;
  border: 1px solid #f6f6f6;
  color:#1A171B;
  padding:10px 20px 10px 70px;  
  margin-top: 20px; 
  text-align:center;
}
.cd-cart .cd-cart-notice p {  
  font-size:16px;
  line-height:26px; 
}
.cd-cart .cd-cart-notice p strong:first-child {  
  color: #1A171B; 
}

/* Forms
================================================== */
.btn{
	text-shadow: none;
	border-radius: 0px;
 	padding: 15px 20px; 
	background-color: #1a171b;
	color: #fff;
	letter-spacing: 1.2px;
	cursor: pointer;
	display: inline-block;
	font-weight: bold;
	text-align: center;
	/* text-transform: uppercase; */
	text-decoration: none;
	white-space: normal;
	-webkit-transition: all .7s ease;
	transition: all .7s ease;
}

.btn-primary{
	background-color: #1A171B !important;
    border: 0px none !important;
	transition: all 0.3s ease 0s;
	border-radius: 40px;
    margin-top: 10px;
}

.btn-basket{display:flex; background-color: #dd384c!important; background: #dd384c; margin: 0 auto; line-height: 20px; padding: 20px 20px; font-size: 21px;    border-radius: 40px; font-weight: 500; letter-spacing: 0; width: 100%; border: none; color: #ffffff; text-align: center; text-decoration: none; display: inline-block;  cursor: pointer;  overflow: hidden; position: relative; transition: all 0.3s ease;}
.btn-basket:after {content: ""; position: absolute; top: 50%; left: 50%; width: 0;height: 0; background-color: rgba(255, 255, 255, 0.1); border-radius: 50%;  opacity: 0;  transform: translate(-50%, -50%); transition: all 0.5s ease;}
.btn-basket:hover:after { width: 100%; height: 200px; opacity: 1;}
.btn-basket:focus {outline: none;}
.btn-basket:active { transform: translateY(2px); box-shadow: none;}


p.disabled_button{display:flex; background-color: #7c7c7c!important; background: #7c7c7c; margin: 0 auto; line-height: 20px; padding: 20px 20px; font-size: 21px;    border-radius: 40px; font-weight: 500; letter-spacing: 0; width: 100%;color: #fff; justify-content: center;}
p.disabled_text{color: #7c7c7c; font-size: 19px;padding-top: 20px;}

.btn-primary.active, .btn-primary.focus, .btn-primary:active, .btn-primary:focus,
.btn-primary:hover, .open > .dropdown-toggle.btn-default {
    background-position: 99% 50%;
    background-color: #e04c5e!important;   
    transition: all 0.3s ease 0s;   
}

.btn-basket:hover, .btn-basket:active, .btn-basket:focus{ background-color: #e04c5e!important; }

.btn-default{
	text-transform: uppercase;
	font-weight: 700;
	background-position: 99% 50%;
    background: #fff;
    border: 2px solid #1a171b;
    color: #1a171b;
	border-radius:0px;
}
.btn-default.active, .btn-default.focus, .btn-default:active, .btn-default:focus,
.btn-default:hover, .open > .dropdown-toggle.btn-default {
    background-position: 99% 50%;
    background: #3d3d3d;
    color: #fff;
	border: 2px solid #3d3d3d;
}
.btn-link{
	color: #1A171B;
	text-transform: uppercase;
	font-weight: 700;
	border: none;
	border-radius: 0;
	background: transparent;
}
.btn-link span{
	color:#1A171B;
}
.btn-link:hover{
	color:#bfbebe;
}
.btn-more{
	padding: 15px 70px 15px 50px;
	margin-top: 50px;
	background-color: #fff;
	display: inline-block;
	border: 1px solid #6f7172;
}
.btn-more:focus, .btn-more:hover {
    background-color: #e0e0e0;
    border-color: #ccc;
    color: #292a2e;
}

.btn-more.active, .btn-more:active {
    background-color: #e0e0e0;
    border-color: #dbdbdb;
}

.btn-xlarge{
	font-size: 1.3em;
	line-height: 1.4em;
/* 	padding: 10px 70px; */
	letter-spacing: 1px;
	font-weight: 700;
}
label{
	color: #404041;
}
label.error, .help-block.text-danger{
	background: #EC2224;
	color: #fff;
	width: 100%;
	font-weight: bold;
	font-size: 12px;
	padding: 5px;
	margin: 0;
	line-height: normal;
	position: relative;
	bottom: auto;
	left: auto;
}
input.form-control.error{
	border-color: #EC2224;
}


label.control-label{margin:10px 0px 5px 0; font-size: 19px; font-weight: 600;color: #1a171b;width: 100%;}
legend{margin:10px 0 0px 0;font-size:18px; font-weight:normal; color: #1a171b;}

input[type="checkbox"], input[type="radio"] {    margin-right: 4px;  }

.form-control{
	border-radius: 0px;
	-webkit-box-shadow: none;
	box-shadow: none;
	border: none;
	padding: 15px 10px;	
	border: 2px solid #d2d2d2;
	height: auto;
	background: transparent;
	color: #1a171b;
	font-size:16px;
	border-radius: 7px;
}
.form-control:hover {
    border: 2px solid #d2d2d2;
	border-radius: 7px;
    box-shadow: none;
}
.form-control:focus {
    border: 2px solid #d2d2d2;
	border-radius: 7px;
    box-shadow: none;
}

form .required label:after{
	color: #e32;
	content: '*';
	display:inline;
	font-weight: bold;
	outline: none;
}
div.submit{
	text-align: center;
	margin:20px 0;
}
.text-right div.submit{
	text-align: right;
}

form div.checkbox .icheckbox_flat-orange, form div.checkbox .icheckbox_flat-green, form div.checkbox .icheckbox_flat-red, form div.checkbox .icheckbox_flat, form div.checkbox .icheckbox_flat-blue{
	display: inline-block!important;
	margin-top: 0px;
	margin-right: 0px;
}
form div.radio label, form div.checkbox label{
	padding-left: 20px;	
}
select.form-control {	
    background: transparent url("../img/layout/sort.png") no-repeat;
    background-position: right;
    -webkit-appearance: none;
    -moz-appearance: none;
    -ms-appearance: none;
    -o-appearance: none;
    appearance: none;
    cursor: pointer;
    max-width: 100%;
    padding: 0;
    position: relative;
    color: #1a171b;
	padding: 17px 20px 17px 10px;	
	border: none;
	border: 2px solid #d2d2d2;
	border-radius: 7px;
	height: auto;
	line-height: normal;	
}
select.form-control:hover{  
    outline: 0;
    -webkit-box-shadow: none;
    box-shadow: none;
	cursor: hand;
    cursor: pointer;
}

.form-sel-wrap .form-sel:hover{
	border: 1px solid #bfbebe;
	 outline: 0;
    -webkit-box-shadow: none;
}
ul.contact_menu, p.form_intro { margin:20px 0 0 0;}
ul.contact_menu li, p.form_intro{margin-bottom:6px; font-size:18px; color:#fff; }
ul.contact_menu li, ul.contact_menu li a, p.form_intro{color:#7c7c7c; transition: all 0.2s ease-in;}
ul.contact_menu li a:hover{color:#bfbebe; transition: all 0.2s ease-in;}
.contact_dark{
	text-align:center;
	background:#404041;
	color:#fff;
	padding:30px 0;
}

.contact_dark h3{
	font-size:20px;
	margin-bottom:50px;
	font-weight:300;
	position:relative; 
}
.contact_dark h3:after{	-moz-user-select: none;
	border-bottom: 1px solid #999374;
	bottom: -20px;
	content: "";
	font-size: 0;
	height: 0;
	left: 0%;
	line-height: 0;
	overflow: hidden;
	position: absolute;
	right: auto;
	text-indent: -9999px;
	top: auto;
	width: 10%; 
	left:45%;
}
.contact_dark p{
	font-size:13px;
	line-height:22px;
}

.well{background-color: #f6f6f6; border: 1px solid #f6f6f6; box-shadow:none; border-radius:0px;}

.well-{margin-bottom:30px;}

.auth-button {
    clear: both;
    display: inline-block;
    position: relative;
    width: auto;
    padding: 15px 10px 15px 60px;
    margin: 20px 0;
    border-radius: 4px;
    text-align: left;
    background: #f6f6f6;
    font-size: 16px;
    color: #fff;
    -webkit-transition: background 0.2s ease;
    -moz-transition: background 0.2s ease;
    transition: background 0.2s ease
}

.auth-button:hover {
    color: #fff;
}

.mini-form .auth-button.small {
    padding: 5px 10px 5px 60px;
    margin: 0 0 10px 0;
    font-size: 16px;
}

.auth-button .auth-icon {
    display: block;
    position: absolute;
    height: 100%;
    width: 50px !important;
    left: 0;
    top: 0;
    border-top-left-radius: 4px;
    border-bottom-left-radius: 4px;
    text-align: center;
    line-height: 40px;
    font-size: 30px;
    background-color: rgba(255, 255, 255, 0.1);
    background-repeat: no-repeat;
    background-position: center center;
}

.auth-button.facebook .auth-icon {
    background-image: url("../img/layout/facebook_white.svg");
	background-position: center -5px;
}

.auth-button.facebook {
    background: #3c5a98;
    color: #fff
}

.auth-button.facebook:hover {
    background: #4365aa
}

.auth-button.google {
    background: #dd4b39
}

.auth-button.google:hover {
    background: #e15f4f
}


.notifications {
    position: relative;
    color: #555;
    font-size: 20px;
    text-align: center;    
    width: 100%;
    height: auto;    
}

.notifications:after, .notifications:before {
    content: "";
    display: table
}

.notifications:after {
    clear: both
}
.notifications .message{
	background: #1A171B;
	color:#fff;
	padding: 13px 0;
}
.notifications .close {
    text-indent: -9999em;
/*     background: url(../img/hello-bar-close.png) no-repeat top left; */
    width: 21px;
    height: 21px;
    position: absolute;
    top: 15px;
    right: 15px
}

.notifications .close:hover {
    background-position: bottom left
}

h2.title{		
	font-size:20px;
	font-weight:400;	
	margin:20px 0px 30px 0px;
	padding: 15px 10px!important;
	background: #1A171B;
	color: #fff;
}
h2.title strong{		
	font-weight:400;		
}

h3.title{
	color:#fff;
	text-transform:uppercase;
	font-weight:300;
	display:block;
	padding-bottom:1.25rem;
	font-size:1.7em;
	position:relative;
}
h3.title::after {
    background-color: #EED700;
    content: "";
    display: block;
    height: 1px;
    margin-left: 46%;
    margin-top: 20px;
    position: relative;
    width: 8%;
}

h4.title{
	margin: 20px 0 20px 0;		
	font-size:18px;
	font-weight:bold;
}
h4.title span.counter{
	border-radius:100%;
	width:30px;
	height:30px;
	line-height:30px;
	text-align:center;
	display:inline-block;
	color:#fff;
	background:#1A171B;	
}
h4.title a.underline{
	font-size:14px!important;
	color:#1A171B;
	float:right;
}

.divider_menu{clear:both;display:block;width:100%;}

	.item, .grid-sizer {
		width: 16.66%;
		height: auto;
	}
	.item{
		border-bottom:1px solid #fff;
	}
	.item img{
		width:100%;
		height:100%;
	}
	
	.item{position:relative;overflow:hidden;background:#1A171B;}
	.item:hover img{opacity:0.8;}
	
	.item.w-2 { width:  33.33%; }
	.item.w-3 { width:  49.98%; }
	.item.w-4 { width:  66.64%; }
	.item.w-5 { width:  100%; }
	.item.h-2 { height: auto; }
	.item.h-3 { height: auto; }

.solid-brick{
	display: block;
	width: 100%;
}
.brick-type-background{height:305px;background:#232323;}



@media (max-width: 550px) {
	.item, .grid-sizer {width: 100%;}
	.item.w-2 { width:  100%; }
	.item.w-3 { width:  100%; }
	.item.w-4 { width:  100%; }
	.item.w-5 { width:  100%; }
	.brick-type-background{height:205px;}
	.swal2-modal .swal2-image{
		width:100%;
		height:auto;
	}
	.form-checkboxes .select{
		flex-wrap: wrap;
	}
	.form-checkboxes .select label{
		flex-basis: calc(50% - 5px);
	}
	.form-checkboxes .select label:nth-child(odd){
		margin-right: 0px;
	}
}
@media (min-width: 551px) and (max-width: 767px) {
	.item, .grid-sizer {width: 33.33%;}
	.item.w-2 { width:  66.66%; }
	.item.w-3 { width:  100%; }
	.item.w-4 { width:  100%; }
	.item.w-5 { width:  100%; }
	.item.h-1 { height: 230px; }
	.item.h-1 img{ height: 230px; }
	.item.h-2 { height: 460px; }
	.item.h-2 img{ height: 460px; }
	.brick-type-background{height:231px!important;}
}

@media (min-width: 768px) and (max-width: 991px) {
	.item, .grid-sizer {width: 33.33%;}
	.item.w-2 { width:  66.66%; }
	.item.w-3 { width:  100%; }
	.item.w-4 { width:  100%; }
	.item.w-5 { width:  100%; }
	.item.h-1 { height: 240px; }
	.item.h-1 img{ height: 240px; }
	.item.h-2 { height: 480px; }
	.item.h-2 img{ height: 480px; }
	.brick-type-background{height:241px!important;}
	
}
@media (min-width: 992px) and (max-width: 1200px)  {
	.item, .grid-sizer {width: 33.33%;}
	.item.w-2 { width:  66.66%; }
	.item.h-1 { height: 305px; }
	.item.h-1 img{ height: 305px; }
	.item.h-2 { height: 610px; }
	.item.h-2 img{ height: 610px; }
	.brick-type-background{height:306px!important;}
}
@media (min-width: 1200px) and (max-width: 1440px) {
	.item.h-1 { height: 205px; }
	.item.h-1 img{ height: 205px; }
	.item.h-2 { height: 410px; }
	.item.h-2 img{ height: 410px; }
	.brick-type-background{height:206px!important;}
}
@media (min-width: 1441px) and (max-width: 1620px) {
	.item.h-1 { height: 285px; }
	.item.h-1 img{ height: 285px; }
	.item.h-2 { height: 570px; }
	.item.h-2 img{ height: 570px; }
	.brick-type-background{height:286px!important;}	
}

@media (min-width:1200px){
    .auto-clear .col-lg-1:nth-child(12n+1){clear:left;}
    .auto-clear .col-lg-2:nth-child(6n+1){clear:left;}
    .auto-clear .col-lg-3:nth-child(4n+1){clear:left;}
    .auto-clear .col-lg-4:nth-child(3n+1){clear:left;}
    .auto-clear .col-lg-6:nth-child(odd){clear:left;}

	.auto-clear .col-md-1:nth-child(12n+1){clear:left;}
    .auto-clear .col-md-2:nth-child(6n+1){clear:left;}
    .auto-clear .col-md-3:nth-child(4n+1){clear:left;}
    .auto-clear .col-md-4:nth-child(3n+1){clear:left;}
    .auto-clear .col-md-6:nth-child(odd){clear:left;}
}
@media (min-width:992px) and (max-width:1199px){
    .auto-clear .col-md-1:nth-child(12n+1){clear:left;}
    .auto-clear .col-md-2:nth-child(6n+1){clear:left;}
    .auto-clear .col-md-3:nth-child(4n+1){clear:left;}
    .auto-clear .col-md-4:nth-child(3n+1){clear:left;}
    .auto-clear .col-md-6:nth-child(odd){clear:left;}
}
@media (min-width:768px) and (max-width:991px){
    .auto-clear .col-sm-1:nth-child(12n+1){clear:left;}
    .auto-clear .col-sm-2:nth-child(6n+1){clear:left;}
    .auto-clear .col-sm-3:nth-child(4n+1){clear:left;}
    .auto-clear .col-sm-4:nth-child(3n+1){clear:left;}
    .auto-clear .col-sm-6:nth-child(odd){clear:left;}
}
@media (max-width:767px){
    .auto-clear .col-xs-1:nth-child(12n+1){clear:left;}
    .auto-clear .col-xs-2:nth-child(6n+1){clear:left;}
    .auto-clear .col-xs-3:nth-child(4n+1){clear:left;}
    .auto-clear .col-xs-4:nth-child(3n+1){clear:left;}
    .auto-clear .col-xs-6:nth-child(odd){clear:left;}
}
@media (max-width:1499px){
    /*********** HEADER ************/	
    #navi ul li.hide_item{display: none;}

    /*********** FOOTER ************/	
    #logo_black.footer {width: 170px; height: 110px;}
    .bank_icons img{max-width: 55px;}
    #wapp a {width: 70px;}
    #iframe a {width: 50px;}

    /*********** HOME ************/	
    .video-text h1 {font-size: 70px;}
    .video-text.right h2 {font-size: 33px;}
    .video_button .main_button, .video_button .white_button{font-size: 17px;}
    .top-left, .bottom-left {width: 50%;}
    .align_info .banner_text.subtitle_text {padding: 5% 25%;}
    .align_info .banner_text.title_text { font-size: 40px;}
    .volunteers_intro_text {padding-right: 0;}
    

    /*********** BLOG ************/	
    .page_title h1 { font-size: 70px;}
    .blog_post h3 {font-size: 25px; line-height: 30px;}
    .blog_post p {font-size: 18px;}
    .blog_post h3 {min-height: 95px;}

    /*********** RACES ************/	
    .content .flex-row h5{padding-right: 30px;}

    /********** SPONSORS ********/
   .blog_intro.page_intro {padding: 20px 0 20px 0;}
   .blog_intro p {font-size: 22px;}

    /*********** DYNAMIC CONTENT ************/	
    .dynamic_content h2.half_width, .dynamic_content h3 {width: 50%;font-size: 45px;}
    .dynamic_content img{width: 100%;}
    .dynamic_content h5 img{width: 130px;}
    img.organizer{width: auto;}
    
}

@media (max-width:1349px){
    /*********** HOME ************/	
    p.text_message { padding: 5px 16px; font-size: 17px;}
}

@media only screen and (min-width:1200px) and (max-width:1349px) {
	/* #top_bar{background:purple;} */
	
	#countdown-box {  margin-left: 300px; }
	
}  

@media (max-width:1199px){
    .page_title h1 {font-size: 65px;}

    /********** HEADER ********/
    /* .cd-main-content{padding-top: 60px;} */
    #header {display:flex; padding: 0; /*position: relative;*/background: #fff;}
    #logo{ margin: 15px 0 1px 20px;width: 55px; height: 55px;}
    #logo a {filter: invert(1);}
    .top_links_right a.cd-cart-trigger {  background: url('../img/layout/icons/basket_grey.svg') no-repeat scroll 15px center transparent;  top: 1px; background-size: 24px;}
    a.cd-cart-trigger { background-color: unset;}
    .user-header.has-submenu{ background: url('../img/layout/icons/user_grey.svg') no-repeat scroll center center transparent;  background-size: 24px;background-color: unset; }
    .languages-top{ background: url('../img/layout/icons/lang_grey.svg') no-repeat scroll center center transparent; background-size: 24px; background-color: unset}
    .top_links_right {height: 100%; display: flex; align-items: center;}
    .top_icons{ /*margin: 32px 0px 0px 0px;*/ height: 100%; display: flex; align-items: center; justify-content: center; float:left; width:80px; text-align:right;  transition: all .5s ease-in-out;  background: #000}
    .top_icons .top_icon {width:48px;height:48px; background-repeat: no-repeat; background-position: center center; background-size:48px;  transition: all 0.2s ease-in; }
    .top_icons .top_icon span {display:none; }
    #header .col-md-12{padding-left:0}
    .races_quantity {color: #7c7c7c;font-weight: 500;}
    .top_links_right a.registration_button { padding: 15px 25px;}
	#header_mobile_menu  .dropdown_info ul{ display: inline-block; padding-top: 20px}
	#header_mobile_menu  .dropdown_info ul li {position: relative;margin-right: 0;transition: all ease-in-out .3s;margin-bottom: 10px;}
	#header_mobile_menu  .dropdown_info ul li a {display: block;}
    #mobile-nav .info_footer_container h6.dropdown{position: relative; border-bottom: 2px solid #7c7c7c}
    #mobile-nav .info_footer_container h6.dropdown::after {	content: " ";background: url(../img/layout/icons/arrow_down.png) no-repeat 0 0;	width: 12px;height: 12px;position: absolute;margin-top: 5px;right: 0; filter: invert(1);transform: translateY(-50%) rotate(0deg);transition: transform 0.3s ease;}
    #mobile-nav .info_footer_container.open h6.dropdown::after {transform: translateY(-50%) rotate(180deg);}
    #mobile-nav .info_footer_container h6.faq {margin-top: 0px;}
    #header_mobile_menu .dropdown_info {width: 100%;color: #7c7c7c;max-height: 0;	overflow: hidden;	opacity: 0;	transform: translateY(-5px);transition:	max-height 0.4s ease,	opacity 0.3s ease,	transform 0.3s ease;}
    #header_mobile_menu .dropdown_info.active {max-height: 1000px; 	opacity: 1;	transform: translateY(0);}
 



#checkbox {
  display: none;
}

.toggle {
  position: relative;
  width: 40px;
  cursor: pointer;
  margin: auto;
  display: block;
  height: calc(4px * 3 + 11px * 2);
}

.bar {
  position: absolute;
  left: 0;
  right: 0;
  height: 3px;
  border-radius: calc(4px / 2);
  background: #fff;
  color: inherit;
  opacity: 1;
  transition: none 0.35s cubic-bezier(.5,-0.35,.35,1.5) 0s;
}

.bar--top {
  bottom: calc(50% + 11px + 4px/ 2);
  transition-property: bottom,margin,transform;
  transition-delay: calc(0s + 0.35s),0s,0s;
}

.bar--middle {
  top: calc(50% - 4px/ 2);
  transition-property: top,opacity;
  transition-duration: 0.35s,0s;
  transition-delay: calc(0s + 0.35s * 1.3),calc(0s + 0.35s * 1.3);
}

.bar--bottom {
  top: calc(50% + 11px + 4px/ 2);
  transition-property: top,transform;
  transition-delay: 0s;
}

#checkbox:checked + .toggle .bar--top {
  bottom: calc(50% - 11px - 4px);
  margin-bottom: calc(11px + 4px/ 2);
  transform: rotate(45deg);
  transition-delay: calc(0s + 0.35s * .3),calc(0s + 0.35s * 1.3),calc(0s + 0.35s * 1.3);
}

#checkbox:checked + .toggle .bar--middle {
  top: calc(50% + 11px);
  opacity: 0;
  transition-duration: 0.35s,0s;
  transition-delay: 0s,calc(0s + 0.35s);
}

#checkbox:checked + .toggle .bar--bottom {
  top: calc(50% - 4px/ 2);
  transform: rotate(-45deg);
  transition-delay: calc(0s + 0.35s * 1.3),calc(0s + 0.35s * 1.3);
}


    /********** FOOTER ********/
   #sponsors .sponsor {min-height: 350px;}

    /********** HOME ********/
    p.text_message { padding: 5px 30px; font-size: 20px; float: left; margin-bottom: 35px;}
    .top-left {font-size: 22px;width: 60%;}
    .bottom-left {font-size: 19px;width: 60%;}
    .align_info .banner_text.subtitle_text {padding: 5% 18%;}
    .align_info .banner_text.title_text {font-size: 35px;}
    p.black_label {margin-bottom: 30px;}
    .volunteers_intro_text p.volunteers_title {font-size: 30px; line-height: 37px;}
    .volunteers_intro_text p.volunteers_subtitle {font-size: 22px; line-height: 30px; padding: 20px 0 30px 0;}
    .blog_post h3 {font-size: 21px;line-height: 28px;}

    /********** BLOG ********/
   .page_title.article_title h1 {font-size: 50px;}
   .blog_intro { padding: 0px 0 20px 0;}
    .blog_post h3 {min-height: 85px;}

    /********** RACES ********/
   .page_sponsor img {width: 150px;}
   .race_view .flex-row {flex-direction: column;}
   .race_view .flex-row h5{padding-bottom: 10px}

    /********** SPONSORS ********/
    .blog_intro p { font-size: 20px; line-height: 30px;}
    #all_sponsors .sponsor{padding: 5%;}

    /********** DYNAMIC CONTENT ********/
   .all_races_page p.text_message{float: right}
   .dynamic_content h2.half_width, .dynamic_content h3 {width: 60%; font-size: 40px;}
   .align_labels p.text_message{float:right}
   .dynamic_content h5 { font-size: 40px;}
   .dynamic_content h5::after {width: 30px;}
   /* .partner_box { width: calc(33.333% - 23px);} */
   .partner_box { width: 30%;}
   .partner_box:nth-child(4n + 1) {margin-left: 15px}
   .partner_box:nth-child(4n) { margin-right: 15px;}
   .partner_box:nth-child(3n) {margin-right: 0;}
   .partner_box:nth-child(3n + 1) {margin-left: 0;}
   .partner_box:nth-child(1) {margin-left: 0;}


    /********** CONTACT ********/
   .contactform .submit_button.main_button{font-size: 20px; padding: 15px 50px;}
   .contact_form{padding: 30px 0 0 0;}
   p.form_intro { margin-bottom: 15px;}
}

@media only screen and (min-width:992px) and (max-width:1199px) {	
	/* #top_bar{background:green;} */
	
	#countdown-box {	margin-left: 370px; }
	#navi { display:none;}

	.gallery_box p {  width:80%; font-size:20px; }

	.hotel_box p{ min-height:53px;}

	.languages-top, .social-icons-top { margin-left: 13px; }

	.partners_flex {
	    align-items: flex-start;
	}
	
}

@media (max-width:991px){	
    /*********** FOOTER ************/	
	.section_footer { flex-direction: column;}
    p.footer_note {position: relative; padding-bottom: 20px;padding-top: 40px;}
    #footer {padding: 65px 15px 35px 15px;}
    #logo_black.footer { width: 200px;height: 120px; margin: 65px 15px 25px 0px;}
    .footer_copyright .align_center { align-items: flex-start; flex-direction: column;}
    .bank_icons {text-align: left;padding: 15px 0;margin-left: -10px;}
    .company_logo {display: flex; flex-direction: row-reverse; justify-content: flex-end;}
    #iframe, #wapp {float: left}

    /*********** HOME ************/	
    .video-text.right{display: none;}
    .run_date{display:block;padding-bottom: 40px;}
    .run_date h2 {color: #7c7c7c; font-weight: 600; line-height: 46px; font-size: 35px;}
    .vertical_banner .vertical_banner_text {padding: 15px 0px 15px 0px;}
    .vertical_banner p{font-size: 18px;}
    p.grey_text {font-size: 25px; line-height: 35px;}
    .align_info .banner_text.subtitle_text {padding: 4% 15%;font-size: 17px;}
    .align_info .banner_text.title_text {font-size: 33px;}
    .volunteers_intro_text p.volunteers_title {font-size: 27px; line-height: 35px;}
    .volunteers_intro_text p.volunteers_subtitle {font-size: 20px; line-height: 27px;}
    .blog_mobile{display: block;}
    .blog_desktop{display: none;}
    .blog_mobile .swiper-pagination{bottom: 0}
    .home_news .align_titles{padding-left: 0; padding-right: 0;}
   

    /*********** BLOG ************/	
    .page_title.article_title h1 {font-size: 45px; }
    .dynamic_content h2.full_width {font-size: 42px;}

    /*********** RACES ************/	
    .iaaf_certificate {margin: 10px 0;}
    .page_sponsor .sponsor_bg {padding: 15px 50px 30px 50px;}
    .reverse_direction{display: flex; flex-direction: column-reverse;}
    .race_view .product-card {margin-bottom: 30px;}
    .race_view .product-actions .btn-basket { padding: 20px 50px; width: auto; margin: 0 auto; display: flex;}
    .freerace-card { margin-bottom: 30px;}

    /*********** SPONSORS ************/	
    #all_sponsors .sponsor { min-height: 210px; padding: 8%;}
       

    /*********** DYNAMIC PAGES ************/	
    .page_title h1 {font-size: 60px;}
    h2.page_subtitle {font-size: 40px;}
    .dynamic_content h5 {font-size: 37px;}
    .content .partner_box h2 {font-size: 22px;}


	#navi { display:none;}			
	
	.footer_box {  margin-top:20px; margin-bottom:20px;}	
	.footer_box.last {	border-left: 0px;		border-top: 1px solid #fff;		padding: 30px 0 0px 0px;	}
	
	.block { margin-bottom:10px; padding: 0 0px 0 15px;}
	.block.right { float: left;}	

	.blog_thumb { margin-bottom:30px; }

	.winners_divider {height:30px;}

	.hotel_box p{ min-height:53px;}

	.vertical_banner {  margin-top:10px; margin-bottom:10px; }

	.deltio_link a.read_more {  font-size:24px;  }

	#sponsors .sponsor_category {
		text-align: center;
	}
	#sponsors .sponsor_category h3 {
		margin-top: 15px;
		margin-bottom: 15px;
	}

	.partner_box {
        width: calc(33% - 18px);
	}

	.partner_box:nth-child(4n + 1) {
		margin-left: 15px;
	}

	.partner_box:nth-child(4n) {
		margin-right: 15px;
	}

	.partner_box:nth-child(3n) {
		margin-right: 0px;
	}

	.partner_box:nth-child(3n + 1) {
		margin-left: 0;
	}
}
  
@media only screen and (min-width:768px) and (max-width:991px) {	
	/* #top_bar{background:pink;} */
	
	#countdown-box {	margin-left: 270px; }

	.menu_divider_tablet {clear:both;height:30px;}
	
	.gallery_box p {  width:85%;  font-size:18px; }

	.hotel_facilities ul li { width:48%; margin-right:1%;}



	.checkout-navigation h1{		font-size: 2em;	}
}

@media (max-width:767px){	
    .padd {padding-top: 30px; padding-bottom: 30px;}
    .padd_big {padding-top: 50px;  padding-bottom: 50px;}
    .align_center { flex-direction: column;}

    /*********** HEADER ************/	
    .has-submenu { margin-left: 10px;}
    .top_links_right a { margin: 0 15px 0 10px;}
    .cd-cart { width: 70vw; position: absolute; top: 171px; left: 50%; transform: translate(-50%, -50%);}

    /*********** FOOTER ************/	
    .company_logo {align-items: flex-end;}
    .bank_icons {padding: 15px 0 0px 0;}
    .footer_mob { display: block; padding-bottom: 10px; }
    .section_footer{display: none;}
    .dropdown_links {width: 100%;color: #fff;transition: all ease-in-out .3s;-webkit-transition: all ease-in-out .3s;	-moz-transition: all ease-in-out .3s;display: none;	}
	.dropdown_links.active { display: block; }
	.dropdown_links ul, .dropdown_info ul{ display: inline-block; padding-top: 20px}
	.dropdown_links ul li, .dropdown_info ul li {position: relative;margin-right: 0;transition: all ease-in-out .3s;margin-bottom: 10px;}
	.dropdown_links ul li a, .dropdown_info ul li a {display: block;}
    .info_footer_container h6.dropdown{position: relative; border-bottom: 2px solid #7c7c7c}
    .info_footer_container h6.dropdown::after {	content: " ";background: url(../img/layout/icons/arrow_down.png) no-repeat 0 0;	width: 12px;height: 12px;position: absolute;margin-top: 5px;right: 0; filter: invert(1);transform: translateY(-50%) rotate(0deg);transition: transform 0.3s ease;}
    .info_footer_container.open h6.dropdown::after {transform: translateY(-50%) rotate(180deg);}
    .info_footer_container h6.faq {margin-top: 0px;}
    .dropdown_info {width: 100%;color: #fff;max-height: 0;	overflow: hidden;	opacity: 0;	transform: translateY(-5px);transition:	max-height 0.4s ease,	opacity 0.3s ease,	transform 0.3s ease;}
    .dropdown_info.active {max-height: 1000px; 	opacity: 1;	transform: translateY(0);}
    #sponsors .col-md-6:first-of-type {padding-right: 0px !important;}
    #sponsors .col-md-6:last-of-type { padding-left: 0px !important;margin-top:15px}

    /*********** HOME ************/	
    .video-text h1 {font-size: 65px;}
    .boxes-row {flex-direction: column; align-items: flex-start;}
    .vertical_banner { height: auto; margin-top: 0;  margin-bottom: 0;}
    .vertical_banner p {font-size: 20px; }
    .vertical_banner .vertical_banner_text {padding: 15px 0px 15px 15px;}
    #logo_black {width: 400px; height: 208px;}
    p.text_message {padding: 5px 14px; font-size: 18px;}
    .race_list p {font-size: 35px;}
    .top-left {font-size: 21px; width: 98%; line-height: 27px; top: 5px;}
    .bottom-left {font-size: 18px; width: 98%; bottom: 5px;line-height: 25px;}
    .row_list a {font-size: 17px;}
    .semi_width_banner {margin: 10px 0;}
    .align_info .banner_text.subtitle_text {font-size: 18px;}
    .volunteers_intro_text {margin-bottom: 30px;}


    /*********** BLOG ************/	
    .page_title.article_title h1 {font-size: 35px;}
    .dynamic_content h2.full_width {font-size: 40px;}
    p.highlight { padding-right: 0;}
    .blog_post h3 {min-height: auto;}

    /*********** HOTELS ************/	
    .dynamic_content h2.hotel_title { text-align: center;font-size: 38px;}

    /*********** CONTACT ************/	
    .contactform .submit_button.main_button { float: unset;}

    /*********** DYNAMIC PAGES ************/
    .page_cover_bg {height: 55vh;}	
    .page_title h1 {font-size: 50px;}
    .useful_info h5 {font-size: 21px;}
    h2.page_subtitle {font-size: 35px;}
    .dynamic_content .vertical_banner .vertical_banner_text {padding: 15px 0px 15px 0;}
    .align_labels{display: flex; flex-direction: column;}
    .dynamic_content h2.half_width, .dynamic_content h3 {width: 75%; font-size: 35px;}
    .dynamic_content h5{ font-size: 30px; padding-right: 30px; }
    .dynamic_content h5::after {width: 27px;}
    .page_sponsor { height: auto;position: absolute;left: 10px;text-align: left;justify-content: flex-start; padding-left: 10px; margin-top: 20px; bottom: 30px;}
    .page_title.race_title { bottom: 190px;padding-left: 0;}
    .page_sponsor img {width: 140px; }
    .page_sponsor .sponsor_bg {padding: 15px 40px 20px 40px;}
    
    /*********** CHECKOUT ************/	
    .checkout-navigation .step-item .step-index {font-size: 2.3em;}


	#countdown-box {	display:none; }

	.group_logo { padding: 7px;	}

	.menu_divider_mobile {clear:both;height:30px;}

	#wapp{float:none; margin-top:20px;}
	#wapp a{margin:0 auto; }	
	
	.heading_box h1.heading_title, .heading_box h2.heading_title { font-size:18px;  }  
	.heading_box h1.heading_title strong, .heading_box h2.heading_title strong { font-size:28px;  margin-right:0px; margin-bottom:10px; display:block;  }  

	.gallery_box p {  width:80%; font-size:20px; }	

	.resultsform .button.thin-bg-dark {  margin-top: 20px; } 

	.hotel_facilities ul li { width:100%; margin-right:0%;}

	.facebook_video {height:350px;}

	.content .partner_box h2 {
        font-size: 19px;
        margin-bottom: 13px;
	}

	.partner_box:nth-child(4n + 1) {
        margin-left: 10px;
    }

	.partner_box:nth-child(3n + 1) {
        margin-left: 10px;
    }

	.partner_box:nth-child(2n + 1) {
        margin-left: 0px;
    }

	.partner_box:nth-child(3n) {
        margin-right: 10px;
    }

	.partners_flex {
		align-items: flex-start;
	}

	.partner_box:nth-child(2n) {
        margin-right: 0px;
    }

	.partner_box {
        width: calc(50% - 10px);
        margin-left: 10px;
        margin-right: 10px;
    }

	.checkout-navigation h1{		font-size: 1.8em;	}
	
	.btn-back {   margin-bottom: 15px; }
	.languages-top, .social-icons-top { margin-left: 20px; }
		
}

@media only screen and (min-width:550px) and (max-width:767px){	
	/* #top_bar{background:red;}		 */
	
	
	
}

@media (max-width:549px){	
    .content h6 {font-size: 20px;line-height: 27px}

    /*********** HEADER ************/
    .races_quantity {left: 10px;}
    .top_links_right a.registration_button {padding: 14px 20px; font-size: 18px; }
    .top_links_right a.cd-cart-trigger { width: 70px;}
    .has-submenu {margin-left: 5px;}
    .top_links_right a { margin: 0 15px 0 0;}

    /*********** HOME ************/
    .video-text h1 {font-size: 55px; line-height: 60px;}
    .video_button .main_button, .video_button .white_button {padding: 20px 25px;}
    p.text_message {padding: 5px 10px;font-size: 15.4px;}
    #logo_black {width: 380px; height: 198px;}
    .race_list p {font-size: 30px;}
    .race_list p::after {width: 28px;}
    .row_list {flex-direction: column; align-items: flex-start;}
    .row_list a {font-size: 20px; margin: 7px 0;}
    .top-left {left: 0; top: 0; font-size: 19px; width: 100%; line-height: 25px;}
    .bottom-left {font-size: 17px; width: 100%;bottom: 0;line-height: 23px;left: 0;}
    .full_width_banner {border-radius: 10px;}
    .full_width_banner .full-width-img {width: 768px !important;height: 400px; max-width: 768px; min-width: 768px;}


    /*********** BLOG ************/
    .page_title.article_title h1 {font-size: 30px;}
    .dynamic_content h2.full_width {font-size: 35px;}
    p.highlight { padding-right: 0;}

    /*********** RACES ************/
    .hide_mobile{display: none}
    .race_view .form-group.number.form-quantity { flex-direction: row; flex-wrap: nowrap; align-items: center;}
    .product-actions .minus, .product-actions .plus, .cart .minus, .cart .plus{ width: 86px;}
    .freeraces p.heading_title, .dynamic_titles p.heading_title { font-size: 30px;}
    .freeraces p.heading_title span, .dynamic_titles p.heading_title span {font-size: 23px; padding-top: 20px;}

    /*********** SPONSORS ************/
    #all_sponsors .sponsor img {max-width: 180px;}
    #all_sponsors .sponsor {min-height: 200px;}

    /*********** DYNAMIC PAGES ************/
    .page_cover_bg {height: 50vh;}	
    .page_title h1 {font-size: 40px;}
    .useful_info h5 {font-size: 19px; }
    .useful_info h5::after {right: 15px;}
    .useful_info h5 { padding: 10px 20px 10px 15px;}
    .dynamic_content h2.half_width, .dynamic_content h3{width: 75%; font-size: 30px;}
    .dynamic_content h5 {font-size: 25px; padding-right: 30px; line-height: 40px;}

	.info_footer_container { width:100%;}	
	.footer_box.middle {border-top: 1px solid #fff;padding: 30px 0 0px 0px;}	
	
	.gallery_box p { width:85%;  font-size:18px; }

	.event_post_container { width: 100%; }	

	
	.table.cart > tbody > tr > td, .table.cart > tbody > tr > th, .table.cart > tfoot > tr > td, .table.carte > tfoot > tr > th, .table.cart > thead > tr > td, .table.cart > thead > tr > th{padding:5px;}	
	.table.cart td.cart-title{font-size:12px;width:50px;white-space:normal;}
	
	.checkout-navigation h1{		font-size: 1.2em;	}
	
	form div.radio label, form div.checkbox label {  font-size: 16px; }	
	
	/* .cd-cart {  width: 100%; margin-right: 0px; } */
	.cd-cart .cd-go-to-cart {  margin: 5px 0 0px 0; }	

	.content .partner_box h2 {
        font-size: 18px;
        margin-bottom: 10px;
    }
	
}

@media only screen and (min-width:480px) and (max-width:549px){	
	/* #top_bar{background:orange;} */
	
	.map_thumb { float: unset;	display:block; margin: 0px auto 10px auto;  max-width:100%;	}
	
	.block { width:48%;}

	.social-icons-top a { margin-top: 3px; width: 27px; height: 27px; }	
	.top_links_right a { padding-left: 30px; }
	.languages-top li a { padding: 6px 0px 3px 3px; }
	
}
@media only screen and (max-width:479px) {
    .flex-row {flex-direction: column; padding: 10px 0px 10px 0px;}	

    /******** HEADER *********/	
    #logo { width: 40px; height: 40px;margin: 15px 0 1px 12px;}
    .toggle {width: 25px;}
    .top_links_right a.cd-cart-trigger {width: 30px;}
    .languages-top, .social-icons-top {margin-left: 0;}
    .top_links_right a.registration_button {padding: 10px 15px; font-size: 15px;}
    .top_icons { width: 50px;}
    .top_links_right a.cd-cart-trigger { background: url(../img/layout/icons/basket_grey.svg) no-repeat scroll 0px center transparent;height: 30px;top: -1px;background-size: 26px;}
    .has-submenu { margin-left: 0;}
    #header .col-md-12 {padding-right: 5px;}
    .bar {height: 2px;}
    .bar--top { bottom: calc(50% + 7px + 4px / 2);}
    .bar--bottom {top: calc(50% + 7px + 4px / 2);}
    #checkbox:checked + .toggle .bar--top {bottom: calc(50% - 9px - 4px);}
    #mobile-nav {height: calc(100vh - 63px); top: 63px}
    #footer, #header_mobile_menu { padding: 50px 5% 35px 5%;}
    .races_quantity{display: none;}
 
    /******** FOOTER *********/	
	.bank_icons {margin-left: 0; }
    p.heading_title {font-size: 25px;}
    #sponsors .align_titles a.underline_button {margin-left: 15px; font-size: 17px;}
    #sponsors .sponsor {min-height: 300px;}
    #sponsors .sponsor img { max-width: 280px;}

    /******** HOME *********/	
    .video-text h1 {font-size: 45px; line-height: 55px;}
    .video_button { margin: 40px 0 10px 0;}
    .video_button { flex-direction: column; align-items: flex-start;}
    .video_button .white_button {margin-left: 0; margin-top: 20px; padding: 20px 35px;}
    .video_button .main_button {padding: 20px 35px;}
    .run_date h2 { line-height: 36px;font-size: 25px;}
    #logo_black { width: 270px; height: 141px;}
    p.grey_text {font-size: 22px;line-height: 30px;}
    .race_list p {font-size: 19px;}
    .race_list p::after {width: 20px;}
    .full_width_banner {border-radius: 10px;}
    .full_width_banner .full-width-img {width: 768px !important;height: 400px; max-width: 768px; min-width: 768px;}
    .align_info .banner_text.subtitle_text {padding: 4% 7%;}
    .align_info .banner_text.subtitle_text {font-size: 17px; line-height: 24px;}
    .align_info .banner_text.title_text {font-size: 25px; line-height: 27px;}
    .volunteers_intro_text p.volunteers_title {font-size: 24px; line-height: 30px;}

    /******** BLOG *********/	
    .blog_post h3 {font-size: 22px; line-height: 28px; margin-top: 10px; margin-bottom: 10px;}
    .page_title.article_title h1 {font-size: 25px;}
    .blog_intro p {font-size: 20px; line-height: 29px;}
    .dynamic_content h2.full_width {font-size: 25px;}
    p.highlight { padding-right: 0;}

    /******** HOTELS *********/	
    .dynamic_content h2.hotel_title {font-size: 33px;}

    /******** RACES *********/	
    .heading_box h1.heading_title, .heading_box h2.heading_title {align-items: flex-start; flex-direction: column;}
    .page_sponsor img {width: 100px;}
    .page_sponsor .sponsor_bg p {font-size: 14px;}
    .page_sponsor .sponsor_bg {padding: 15px 35px 15px 35px;}
    .page_sponsor {bottom: 20px;  padding-left: 5px;}
    .page_title.race_title { bottom: 150px;}
    .form-quantity label {font-size: 17px !important;}
    .product-card {padding: 20px 15px;}
    .race_view .product-actions .btn-basket{font-size: 19px; padding: 15px 40px;}
    .race_view .form-group.number.form-quantity {margin-bottom: 15px;}
    .freeraces p.heading_title, .dynamic_titles p.heading_title { font-size: 25px; line-height: 30px;}
    .freeraces p.heading_title span, .dynamic_titles p.heading_title span { font-size: 20px; padding-top: 15px; line-height: 28px;}
    .freerace-card .main_button {font-size: 19px; padding: 15px 40px;width: auto;}

    /******** SPONSORS *********/	
    #all_sponsors .sponsor {min-height: 150px; padding: 5%}
    #all_sponsors .sponsor img {max-width: 135px;}
    
    /*********** DYNAMIC PAGES ************/
    .page_title h1 {font-size: 35px;}
    h2.page_subtitle {font-size: 28px;}
    .content p.intro_title {font-size: 25px;}
    .useful_info h5 {font-size: 19px; line-height: 27px;    padding: 10px 20px 10px 15px;}
    .useful_info h5::after {right: 15px;}
    .flex-row.vertical { padding-right: 0;}
    .dynamic_content h2.half_width, .dynamic_content h3 {width: 100%; font-size: 26px;}
    .dynamic_content h5 {font-size: 22px; padding-right: 28px;line-height: 35px;}
    .dynamic_content h5::after {width: 25px;}
    img.organizer {float: unset;margin: 0 auto 10px auto; display: flex; width: auto; max-width: 290px;}
    .partner_box, .partner_box:nth-child(3n + 1), .partner_box:nth-child(4n + 1), .partner_box:nth-child(3n), .partner_box:nth-child(4n) { width: 100%;  margin-left: 0;}
    .sponsor_category{padding-left: 0; padding-right: 0}
    .sponsor_category .col-xs-6{padding-right: 5px}
          
    /******** CHECKOUT *********/	
    .checkout-navigation .step-item .step-index {font-size: 2.0em; margin-top: -0.25em;}



	.deltio_link a.read_more { font-size: 18px; }
	.title_thumb {width: 110px; margin: 12px 7px -4px 0;}
	.top_links_right a { padding-left:0px; margin: 3px 5px 0 5px; background-size: 21px; }
		
	.race_box_container { width:100%;}

	.left_thumb { float: unset;	display:block; margin: 0px auto 10px auto;  max-width:100%;	}	

	.volunteers_link a.read_more {  font-size:20px; }

	.facebook_video {height:280px;}

	.group_logo { padding: 0px;	}
	
	.btn { padding: 15px 5px; width:100%; }
	.btn-basket { padding: 15px 0px;}
	
	.form-quantity label{		float:none;	display:block; margin-top:0px;}
	.form-options label{		float:none;	display:block; margin-top:0px;}	
	
	.block { width:47%;}
	.languages-top { margin-top: 0px; }
	.languages-top li a { padding: 5px 5px 3px 5px; }
	.social-icons-top a { width: 24px; height: 24px; }
	
	#sponsors .sponsor_category h3 {
		font-size: 22px;
	}

	.content .partner_box h2 {
        font-size: 20px;
        margin-bottom: 10px;
        padding: 15px 10px 0 0px;
    }

	.partner_box {
    	margin-bottom: 15px;
	}

	.content .partner_box p {
        margin: 2px 0px 2px 0;
        padding: 0px;
        font-size: 18px;
        line-height: 24px;
    }
}

@media only screen and (max-width:445px) {		
	/* #top_bar{background:blue;} */
	
	#sponsors .sponsor { margin:5px 5px; padding:10px 5px;  }

	.volunteers_link a.read_more {  font-size:18px; }

	.hotel_box p{ font-size: 16px;  }

	.partner_box {
        width: 100%;
        margin-left: 0px;
        margin-right: 0px;
    }

	.partner_box:nth-child(3n) {
        margin-right: 0px;
    }

	.partner_box:nth-child(3n + 1) {
        margin-left: 0px;
    }
}
