/* RESET */

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, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td{background: transparent; border: 0; margin: 0; padding: 0; list-style: none;} img{max-width: 100%; image-rendering: -webkit-optimize-contrast;}
.cf{zoom: 1;} .cf:before, .cf:after{content: ""; display: table;} .cf:after{clear: both;} .clear{clear: both;} *, *:before, *:after{box-sizing: border-box;}

html, body{background: #000; line-height: 1.5; height: 100%; width: 100%;}
::-moz-selection{background: #FF0000; color: #fff; text-shadow: none} ::selection{background: #FF0000; color: #fff; text-shadow: none}

.main{padding: 50px 0;}
.wrap{max-width: 1440px; margin: 0 auto; padding: 0 20px;}

.flex-row{display: flex; flex-wrap: wrap; gap: 25px;}
.flex-row .flex-col{flex: 1;}

/* TYPOGRAPHY */

h1, h2, h3, h4, h5, h6{font-weight: 700;}
a{text-decoration: none; color: inherit; cursor: pointer; transition: all .2s ease-in-out;} a:hover{color: inherit;}

/* HEADER */



/* NAVIGATION */

nav.primary{display: inline-block; background: #000; text-align: center; position: relative; width: 100%; z-index: 999;}
nav.primary ul{display: flex; justify-content: center; width: 100%; margin: 0; padding: 0;}
nav.primary ul li{display: inline-block; position: relative; height: 100%; transition: 0.3s;}
nav.primary ul li i{margin-left: 10px;}
nav.primary ul li a{display: block; padding: 12px 20px; font-size: 14px; font-weight: 700; text-transform: uppercase; text-align: center; color: #fff; transition: 0.2s ease-in;}
nav.primary ul li:hover > a{background: #C80000;}

nav.primary .primary-sub-menu li{border-bottom: 1px #555 solid;}
nav.primary .primary-sub-menu li a{display: block; background: #333; padding: 12px 14px; font-size: 12px; text-align: left;}
nav.primary .primary-sub-menu li:hover > a{background: #555;}

nav.primary ul ul{display: none; position: absolute; width: 250px; box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.1); z-index: 5;}
nav.primary ul li:hover > ul{display: block; position: absolute; white-space: nowrap; z-index: 100;}
nav.primary ul ul li{display: block; position: relative; float: none; margin: 0; font-size: 12px;}

nav.primary ul li.has-sub-menu a:after{display: inline-block; margin-left: 10px; font-family: "Font Awesome 6 Free"; font-weight: 900; content: "\f107"; color: #fff;}
nav.primary ul li.has-sub-menu ul a:after{content: "";}

/* BODY */

.landing{display: flex; align-items: center; justify-content: center; width: 100%; height: 100%; padding: 50px;}

/* FOOTER */



/* RESPONSIVE */

#menu-button{display: none; position: relative; z-index: 1000;}
#menu-button .menu-toggle{background: #333; width: 100%; padding: 12px 20px; font-size: 18px; font-weight: 700; text-align: center; color: #fff; transition: all .2s ease-in-out; cursor: pointer;}
#menu-button .menu-toggle:hover{background: #555;}

nav.mobile{display: none; position: fixed; top: 0; left: -300px; width: 300px; height: 100%; background: #333; color: #fff; z-index: 999999; overflow: auto; box-shadow: 5px 0px 10px 0px rgba(0, 0, 0, 0.1);}
nav.mobile .mobile-top{display: flex; align-items: center; justify-content: space-between; position: relative; height: 60px; padding: 10px 15px; font-size: 14px; font-weight: 700; text-transform: uppercase; border-bottom: 4px #FF0000 solid;}
nav.mobile .mobile-nav{display: flex; flex-direction: column; height: calc(100vh - 60px);}
nav.mobile .menu-toggle{display: block; font-size: 18px; padding: 5px; transition: all .2s ease-in-out; cursor: pointer;}
nav.mobile .menu-toggle:hover{opacity: .5;}

nav.mobile .social{margin: 25px 0; text-align: center;}
nav.mobile .social a{padding: 0 10px; opacity: .75;}
nav.mobile .social a:hover{opacity: 1;}
nav.mobile .nav-footer{font-size: 10px; text-align: center; text-transform: uppercase; letter-spacing: 2px; opacity: .75;}

nav.mobile ul{list-style: none; font-weight: 400; margin: 0; padding: 0;}
nav.mobile ul li{position: relative; border-bottom: 1px solid #444;}
nav.mobile ul li i{position: absolute; right: 15px;}
nav.mobile ul li a.active-mobile i{transform: rotate(180deg);}
nav.mobile ul li a{display: flex; align-items: center; position: relative; font-size: 12px; padding: 15px; font-weight: 700; text-transform: uppercase; color: #fff;}
nav.mobile ul li a:hover{background: #FF0000;}

nav.mobile ul ul{display: none;}
nav.mobile ul ul li a{background: #444;}
nav.mobile ul ul ul li a{background: #555;}

@media screen and (max-width: 1024px){
	.main{padding: 30px 0;}
}
@media screen and (max-width: 768px){
	nav.primary{display: none;}
	nav.mobile, #menu-button{display: block;}

	.flex-row{gap: 20px;}
	.flex-row .flex-col{flex: none; width: 100%;}
}
@media screen and (max-width: 480px){
	
}