@font-face { font-family: 'Cairo';
             src: url('fonts/Cairo/Cairo-Regular.ttf') format('truetype'); font-weight: 400; font-display: swap; }
@font-face { font-family: 'Cairo';
             src: url('fonts/Cairo/Cairo-SemiBold.ttf') format('truetype'); font-weight: 600; font-display: swap; }
@font-face { font-family: 'Cairo';
             src: url('fonts/Cairo/Cairo-Bold.ttf') format('truetype'); font-weight: 700; font-display: swap; }

body
{
	background-color: #fff;
	margin: 0;
	font-family: Cairo, sans-serif;
	line-height: 1.4rem;
	font-size: 16px;
  color: #333;
}

* {
	box-sizing: border-box;
}

img { border: 0; }

p
{
	margin: 0px 0px 1.2em 0px;
}
p.semibold { font-weight: 600; }

a { color: #000; }
a:hover { color: #ff0606; }

h1
{
	font-size: 2rem;
	font-weight: 600;
	margin: 0 0 1.4em 0;
}

h2
{
	font-size: 2rem;
	font-weight: 600;
	margin: 0 0 2rem 0;
}
article.text-only h2 {
	font-size: 1.2rem;
	margin: 0 0 .25rem 0;
}

h3
{
	font-size: 1.5rem;
	font-weight: 400;
	margin: 0;
}
article.text-only h3 {
	font-size: 1rem;
	font-weight: 600;
	margin: 0;
}

.nomargin { margin: 0; }
.marginbottom1 { margin-bottom: 1rem; }
.marginbottom2 { margin-bottom: 2rem; }
.marginbottom3 { margin-bottom: 3rem; }
.marginbottom4 { margin-bottom: 4rem; }
.marginbottom5 { margin-bottom: 5rem; }
.marginbottom6 { margin-bottom: 6rem; }

.text-nowrap { white-space: nowrap; }

/* Container */

#wrapper
{
	width: 100%;
	margin: auto;
}

header#top-header,
#footer { background: #ff0606; }

header#top-header
{
	position: sticky;
	top: 0;
	display: flex;
	flex-flow: row nowrap;
	justify-content: space-between;
	align-items: flex-end;
	width: 100%;
	height: 78px;
	padding: .75rem 2rem;
  margin: 0 auto;
}

#logo {
	flex: 0 0 191px;
}


/* MENU */
/* MENU Trigger */

#nav-trigger
{
	cursor: pointer;
	box-sizing: border-box;
	display: flex;
	justify-content: flex-start;
	padding-top: 4px;
	color: white;
}

	.line {
		width: auto;
		height: 3px;
		background: #fff;
		margin-bottom: 6px;
	}
	


#main-nav {
	position: fixed;
	top: 0;
	left: -100vw;
	z-index: 10000;
	width: 100vw;
	min-height: 23em;
	padding: 0 1rem;
	border-bottom: 1px solid #000;
	background-color: rgba(255,6,6,0.9);
	transition: left .5s;
}

#main-nav #x-close-wrapper { float: right; padding-top: 1rem; }
#main-nav a#x-close { display: inline-block; text-decoration: none; font-family: mono-space; padding: .2em .3em; background-color: #fff; margin-right: 0.5em; font-size: 2em; border: 1px solid #000; }
#main-nav a#x-close:hover { text-decoration: none; }

#main-nav nav {
    padding: 1rem 4.5rem 0 0;
}	

#main-nav ul { margin: 0; padding: 0; list-style: none; }


#main-nav ul
{
	margin: 0;
	padding: 0;
	list-style: none;
}

#main-nav ul li { 
	margin: 0;
	padding: 0 0.95rem;
	white-space: nowrap;
}

#main-nav ul li a
{
	display: block;
	color: #fff;
	margin: 0;
	padding: 0.5rem 0 0.5rem 0.5rem;
	text-decoration: none;
}

#main-nav ul li a:hover, 
#main-nav ul li a.current { background-color: rgba(255, 255, 255, .25); }



#footer-nav
{
	padding: 0 0.25rem;
}

#footer-nav ul { margin: 0; padding: 0; list-style: none; }

#footer-nav ul li { 
	margin: 0;
	padding: 0;
	text-align: center;
	float: left;
}

#footer-nav ul li a
{
	display: block;
	width: auto;
	height: auto;
	color: #fff;
	padding: 4px 10px;
	text-decoration: none;
}

#footer-nav ul li a:hover,
#footer-nav ul li a.current
{
	background-color: rgba(255, 255, 255, .25);
}


@media (min-width: 800px) {
	#nav-trigger { display: none; }
	#main-nav #x-close-wrapper { display: none; }
	#main-nav li#x-li { display: none; }
	
	#main-nav
	{
		position: static;
		border: 0;
		min-height: .8rem;
		z-index: 0;
		width: auto;
		margin-top: 1rem;
		padding: 0 0.25rem;
		overflow: auto;
		background-color: transparent;
		-webkit-transition: all 0.3s;
		-moz-transition: all 0.3s;
		transition: all 0.3s;
	}

	#main-nav nav {
			padding: 0 0.25rem;
	}	

	#main-nav ul
	{
		list-style-type: none;
		margin: 0;
		padding: 0;
	}

	#main-nav ul li { 
		margin: 0;
		padding: 0;
		text-align: center;
		float: left;
	}

	#main-nav ul li a
	{
		display: block;
		width: auto;
		height: auto;
		color: #fff;
		padding: 4px 10px;
		text-decoration: none;
	}
}



#top-image,
#top-image-no-bg
{
	display: flex;
	flex-flow: column wrap;
	justify-content: flex-end;
	width: 100vw;
	min-height: 70px;
	background-color: #eee;
}
#top-image {
	height: 23vw;
	background-image: url('images/fotos/FLAMOS-Factory-I.jpg');
	background-size: cover;
	background-repeat: no-repeat;
}
#top-image img { width: 100%; height: auto; }

main {display: block;}

.slogan-fullwidth
{
	min-height: 70px;
	padding: 1rem 2rem;
	font-size: 1.5rem;
	color: #000;
	font-weight: 600;
	/*position: sticky;
	top: 78px;*/
	margin-top: -70px;
}

.slogan-fullwidth > div { width: 100%; }

#slogan-text { margin-bottom: 1rem; }
#slogan-button { text-align: right; }

@media(min-width:1000px) {
	.slogan-fullwidth > div { width: auto; }
}

.bg-white-50 {
	background-color: rgba(225, 225, 225, .85);
}
.bg-black-50 {
	background-color: rgba(0, 0, 0, .25);
}
#product-nav ul
{
	display: flex;
	flex-flow: row nowrap;
	justify-content: center;
	list-style: none;
	margin: 0;
	padding: 0;
}
#product-nav ul li { padding: 0 .5rem; }
#product-nav ul li a
{
	display: block;
	padding: .5rem 3rem;
	background-color: rgba(255, 255, 255, .75);
	font-size: 1.5rem;
	font-weight: 600;
	color: #ff0606;
	outline: 0 none;
	text-decoration: none;
}
#product-nav ul li a:hover { background-color: white; }


/* CONTENT */

#content-wrapper
{
	width: 100%;
	padding: 4rem 1rem;
	max-width: 1120px;
	margin: auto;
}

.flexrow {
	display: flex;
	flex-flow: row wrap;
}

.col-50 { 
	flex: 1 0 50%;
}

.col-33 { 
	flex: 1 0 33.333%;
}

.col-25 { 
	flex: 1 0 25%;
}

.flexrow-buttons {
	display:flex;
	flex-flow: row wrap;
	width: 100%;
}

/* Flex horizontale Ausrichtung */
.space-around { 
	justify-content: space-around;
}
.space-between { 
	justify-content: space-between;
}
.flex-start { 
	justify-content: flex-start;
}
.flex-end { 
	justify-content: flex-end;
}
/* flex vertikale Ausrichtung */
.flex-align-top {
	align-items: flex-start;
}
.flex-align-middle {
	align-items: center;
}
.flex-align-bottom {
	align-items: flex-end;
}

.icons-inhalt
{
	padding: 0rem 0 5rem 0;
	color: #000;
	font-size: 1rem;
	text-align: center;
}
.icons-inhalt img { width: 45px; }

/* material icons overwrites und Zusätze */

ul.material-icons-list { list-style: none; margin: 0; padding: 0; }
ul.material-icons-list li { display: flex; flex-flow: row nowrap; padding-bottom: .25rem; }
.icon-check-circle { color: #16bc04; padding-right: .5rem; }
.button1,
.button2 {
	display: inline-block;
	padding: 0.5rem 1rem;
	font-size: 1.5rem;
	text-decoration: none;
	color: white;
	border-radius: .5rem;
}
.button-small {
	display: block;
	padding: 0.1rem 0.2rem;
	font-size: 1rem;
	text-decoration: none;
	color: white;
	border-radius: .15rem;
}
.button1 {background: #ff0606;}
.button2 { background: #16bc04; }
.button-small { background: #16bc04; text-align: center; }
@keyframes b1hover {
  from {background: #ff0606;}
  to {background: #cc0505;}
}
.button1:hover {
	background: #cc0505;
	color: #fff;
  animation-name: b1hover;
  animation-duration: .5s;
}
@keyframes b2hover {
  from {background: #16bc04;}
  to {background: #158e03;}
}
.button2:hover {
	background: #158e03;
	color: #fff;
  animation-name: b2hover;
  animation-duration: .5s;
}
.button-small:hover {
	background: #158e03;
	color: #fff;
}

.service-support,
.unterstuetzung { text-align: center; padding: 1rem 0; background-color: #e8e8e8; }
.productlisting { border: 1px solid #e8e8e8; }
.productlisting .foto-klein { width: 100%; }
.productlisting .t-header { display: none; background: #e8e8e8; }
.productlisting .flexrow { justify-content: space-between; border: 1px solid #e8e8e8; }
.productlisting .flexrow div { border-left: 1px solid #e8e8e8; padding: .25rem; }
.productlisting .flexrow div:nth-child(1) { flex-basis: 100%; }
.productlisting .flexrow div:nth-child(2) { flex-basis: 33%; }
.productlisting .flexrow div:nth-child(3) { flex-basis: 33%; }
.productlisting .flexrow div:nth-child(4) { flex-basis: 34%; }
.productlisting .flexrow div:nth-child(5) { flex-basis: 100%; }
.productlisting .flexrow div:nth-child(6) { flex-basis: 100%; align-content: center; }
.productlisting .flexrow-buttons { align-items: flex-end; width: auto; }
.productlisting .flexrow-buttons a { flex: 1 1 auto; }
@media (min-width: 450px) { 
	.productlisting .foto-klein { width: 90px; }
	.productlisting .t-header { display: flex; }
	.productlisting .flexrow div:nth-child(1) { flex-basis: 10%; }
	.productlisting .flexrow div:nth-child(2) { flex-basis: 10%; }
	.productlisting .flexrow div:nth-child(3) { flex-basis: 10%; }
	.productlisting .flexrow div:nth-child(4) { flex-basis: 20%; }
	.productlisting .flexrow div:nth-child(5) { flex-basis: 35%; }
	.productlisting .flexrow div:nth-child(6) { flex-basis: auto; align-content: center; }
}


/* FORMS */

.form-wrapper { width: 100%; max-width: 800px; margin: auto; }
.asterisk { padding-left: .25rem; }
#text_pflichtfelder { display: none; }
label { display: inline-block; }
input,
select,
textarea {
	font-size: 1rem;
	color: #333;
}
textarea { width: 100%;}
input[type="text"] { width: 100%; padding: .25rem; margin-bottom: 1rem; }
select { padding: .25rem;margin-bottom: 1rem; }
input[type="submit"] { float: right; background: #e8e8e8; padding: 1rem 2rem; cursor: pointer; border: 0; border-radius: 5px; }
input[type="submit"]:hover { background: #ccc; }
#webadresse, 
#label-webadresse {
    position:absolute;
    height:0;
    width:0;
    border:none;
    background:none;
    margin:0;
    top:0;
    left:0;
    clear:both;
    font-size:0px;
    line-height:0px;
}
#webadresse {z-index:998;}
#label-webadresse {z-index:999;}

/* FOOTER */

#footer
{
	width: 100%;
	padding: 2rem;
	color: white;
	display: flex;
	flex-flow: row wrap;
	justify-content: space-between;
	align-items: flex-start;
}

#footer a { color: white; text-decoration: none; }
#footer a:hover,
#footer a.current {text-decoration: underline;}

#footer .text-left,
#footer .text-right { flex: 1 1 50%; padding-right: 2rem; }

ul.addresslist {
	margin: 0;
	padding: 0;
	list-style: none;
}

ul.addresslist li {
	margin: 0;
	padding: 0 20px 0 0;
	float: left;
}

#footer address { font-style: normal; }

#footer-nav {
	flex-basis: 100%;
	display: flex;
	margin-top: 1rem;
}



