@charset "utf-8";
/* CSS Document */
.clear,
article,
aside,
footer,
header,
hgroup,
nav,
section {
	display: block;
}

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

.blog .items-more,
.clear,
.clrflt {
	clear: both;
}

blockquote,
body,
dd,
div,
dl,
dt,
fieldset,
form,
h1,
h2,
h3,
h4,
h5,
h6,
input,
li,
ol,
p,
pre,
td,
textarea,
th,
ul {
	margin: 0;
	padding: 0;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

iframe,
abbr,
acronym,
fieldset,
img {
	border: 0;
}

address,
caption,
cite,
code,
dfn,
em,
strong,
th,
var {
	font-style: normal;
	font-weight: 400;
}

ol,
ul {
	list-style: none;
}

caption,
th {
	text-align: left;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-size: 100%;
}

q:after,
q:before {
	content: "";
}

* {
	box-sizing: border-box;
}

.clear {
	font-size: 1px;
	line-height: 1px;
	height: 0;
}

a {
	outline: 0;
}

li {
	list-style: none;
}

body {
	color: #000;
	font-size: 21px;
	line-height: 31px;
	background: #fff;
	padding: 0;
	margin: 0;
	font-family: "Montserrat", sans-serif;
	background: url(../images/bkg.jpg) center top no-repeat;
    background-size: 2111px;
}

html {
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
}

h1 {
    color: #493474;
    font-size: 44px;
    line-height: 56px;
    font-weight: 900;
	margin: 0 0 24px;
}

.showroom h1 {
    font-size: 76px;
    line-height: 87px;
	margin: 77px 0 0;
}

h2 {
	font-size: 44px;
	line-height: 56px;
	font-weight: 900;
	color: #000;
}

.com-content-article h2 {
	font-size: 27px;
	line-height: 44px;
	margin: 24px 0 12px;
	font-weight: 800;
}

p.subline {
	color: #9268e8;
	font-size: 32px;
	line-height: 44px;
}

p {
	margin: 0 0 24px;
}

header {
	height: 166px;
	display: flex;
    align-items: center;
    justify-content: center;
	/*background: #f3edfe;*/
}

header .logo {
    width: 220px;
}

header .logo img {
    width: 100%;
    height: auto;
}

header .container li i {
    color: #493474;
    font-size: 28px;
}

.netzwerk .container,
header dl,
footer dl {
	display: flex;
}

header dl,
footer dl {
	justify-content: flex-end;
  z-index: 1;
}

header .container {
	display: flex;
	justify-content: space-between;
}

.wrapper {
	display: grid;
	gap: 24px;
}

.showroom {
	/*background: #f3edfe;*/
	min-height: 703px;
}

.showroom h2 {
	margin: 12px 0 32px;
    text-transform: uppercase;
    color: #493474;
    font-weight: 400;
    font-size: 34px;
}

.showroom p {
	font-size: 24px;
	line-height: 32px;
}

.showroom .btn {
    line-height: 78px;
    font-size: 29px;
    margin: 32px 0 0;
}

.box {
    border-radius: 7px;
    font-size: 24px;
    font-weight: bold;
    padding: 44px 32px;
	color: #493474;
	position: relative;
	text-align: center;
	cursor: pointer;
}

.box i {
    color: #493474;
    position: absolute;
    bottom: 18px;
    right: 18px;
    font-size: 24px;
}

.box .btn {
    white-space: nowrap;
    line-height: 54px;
    font-size: 18px;
    padding: 0;
    position: absolute;
    bottom: 24px;
    right: 24px;
    left: 24px;
}

.container li i,
.container p i {
	color: #9268e8;
}

.container a.btn i {
	color: #fff;
}

.saeulen .box p {
    font-weight: 500;
    font-size: 18px;
    line-height: 24px;
    margin-bottom: 56px;
}

.saeulen .box h4 {
	font-eight: 900;
	font-size: 32px;
	margin: 0 0 12px;
}

.forderungen .wrapper {
	grid-template-columns: repeat(3, 1fr);
}

.saeulen .wrapper {
	grid-template-columns: repeat(4, 1fr);
}

.lightvio {
	background: #c7b1f5;
}

.midvio {
	background: #e1d3ff;
}

.darkvio {
	background: #b197e6;
}

.allie,
.banner {
	background: #493474;
	color: #fff;
	font-size: 32px;
	text-align: center;
	padding: 77px 32px;
	margin: 77px 0;
	line-height: 44px;
}

.banner {
	font-size: 66px;
	line-height: 77px;
}

.banner p {
	color: #c7b1f5;
}

.allie h2 {
	font-size: 66px;
	color: #fff;
	text-transform: none;
	font-weight: 900;
	margin: 0 0 44px;
}

.allie .btn {
	color: #493474;
	background: #fff;
}

.allie i {
	color: #fff;
}

.maptext {
	padding-right: 77px;
}

.bullet {
	text-align: center;
	font-size: 44px;
	line-height: 66px;
}

.bullet li {
    border: 3px solid #493474;
    border-radius: 50px;
    line-height: 66px;
    color: #493474;
    font-weight: 900;
    text-transform: uppercase;
    font-size: 32px;
    width: fit-content;
    padding: 0 44px;
    margin: 0 auto 18px;
}

.bullet h3 {
    color: #9268e8;
    line-height: 56px;
	margin: 0 0 44px;
}

.bullet h3 span {
	color: #000;
}

footer li,
header li {
	list-style: none;
}

header li {
	line-height: 51px;
	margin-left: 24px;
	font-weight: 600;
}

header li a {
	color: #493474;
}

.container,
.com-content-article__body {
	width: 1280px;
	margin: 0 auto;
}

.com-content-article.item-page {
	background: #fff;
	padding: 77px 0;
	min-height: 666px;
}

.showroom,
.netzwerk {
	padding-bottom: 77px;
	margin-bottom: 77px;
}

.btmline {
	border-bottom: 5px dotted #9268e8;
	padding-bottom: 77px;
	margin-bottom: 77px;
}

.showroom .container {
	text-align: center;
	padding: 0 111px;
}

.quote-avatar {
	text-align: center;
	font-weight: 600;
	color: #493474;
	margin: 0 0 44px;
}

.quote-avatar span {
	color: #9268e8;
	display: block;
	font-weight: 300;
	font-size: 18px;
}

.quote-avatar img {
	display: block;
	margin: 0 auto 12px;
}

.btn {
    border-radius: 50px;
    background: #493474;
    color: #fff;
    font-weight: bold;
    font-size: 24px;
    line-height: 62px;
    display: inline-block;
    padding: 0 44px;
	text-align: center;
}

footer {
	padding: 0 0 111px;
	font-size: 18px;
	border-top: 5px dotted #9268e8;
	padding-top: 77px;
	background: #fff;
}  

footer a {
	color: #493474;
	font-weight: 600;
}

footer li {
	margin-left: 18px;
}

.quote-text {
	font-size: 32px;
	font-weight: bold;
	line-height: 44px;
	text-align: center;
	padding: 0 77px;
}

.content {
	padding: 77px 0;
}

.list li {
	list-style: disc;
}

button#topbtn {
    position: fixed;
    bottom: 32px;
    right: 32px;
    border-radius: 50%;
    line-height: normal;
    padding: 18px;
    background: #493474;
    border: 0;
    color: #fff;
}

.pad77_btm {
	padding-bottom: 77px;
}

.burger {
    display: none;
    font-size: 44px;
    background: none;
    border: none;
    cursor: pointer;
}

        .table-container {
            overflow-x: auto;
            -webkit-overflow-scrolling: touch;
            margin: 20px 0;
        }
        
        table {
            width: 100%;
            border-collapse: collapse;
            min-width: 600px;
        }
        
        th, td {
            padding: 12px;
            text-align: left;
            border: 1px solid #ddd;
        }
        
        th {
            background-color: #f4f4f4;
            font-weight: bold;
        }


.fieldset-1.active {
    border-radius: 7px;
    width: 777px;
    margin: 0 auto;
    text-align: center;
}

.fieldset-1.active input[type=email],
.fieldset-1.active input[type=text] {
    padding: 12px 24px;
    border-radius: 100px;
    border: 1px solid #ccc;
    font-size: 24px;
	width: 444px;
}

.fieldset-1.active textarea,
.fieldset-1.active input[type=email],
.fieldset-1.active input[type=text] {
	margin: 0 0 18px;
	font-family: "Montserrat", sans-serif;
}

.fieldset-1.active textarea {
    padding: 12px 24px;
    border-radius: 32px;
    border: 1px solid #ccc;
    font-size: 24px;
	width: 444px;
}

.asterix-ancor,
.vis_mandatory {
	display: none;
}

small {
    color: #999;
    font-size: 16px;
    margin: 24px 0 44px;
    display: block;
    line-height: 24px;
}

.popup {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.6);
  justify-content: center;
  align-items: center;
  z-index: 1000;
}

.popup-content {
  background: white;
  padding: 24px;
  border-radius: 7px;
  max-width: 555px;
  width: 90%;
  position: relative;
  text-align: center;
}

.popup-content p {
    margin: 32px 0;
}

.close {
  position: absolute;
  top: 10px;
  right: 15px;
  text-decoration: none;
  font-weight: bold;
  color: #555;
  cursor: pointer;
}

.close:hover {
  color: black;
}

.construction h2,
.construction h3 {
	color: #493474
}

ul.list {
	list-style: disc;
	margin: 44px 0 44px 24px;
}

    .event-info {
      background: #f2f2f2;
      padding: 24px;
      border-left: 6px solid #9b1c31;
      margin-bottom: 32px;
    }
    .event-info p {
      margin: 0.4em 0;
      font-weight: 600;
    }
    .speakers {
      margin-top: 32px;
    }
    .speaker {
      margin-bottom: 24px;
    }
.speaker strong {
    display: block;
    font-size: 1.6rem;
    margin-bottom: 12px;
    font-weight: bold;
}

hr {
  border-top: 3px dashed #ddd;
  margin: 44px 0;
}

.showroom .container {
  position: relative;
}

.showroom .container img {
  position: absolute;
  right: 0;
  top: -33px;
}

.quote iframe {
  width: 100%;
  height: 733px;
}

#popup {
    padding: 44px;
    border-radius: 7px;
    width: 830px;
  max-width: calc(100vw - 40px); /* wichtig für mobile Geräte */
  background: #fff;
  position: relative;
  text-align: center;
}

#popup button {
    background: none;
    border: 0;
    cursor: pointer;
    position: absolute;
    right: 12px;
    top: 12px;
    font-size: 24px;
    font-weight: bold;
}

.overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
}

#popup .btn {
  line-height: 77px;
  margin: 24px 0 18px;
}

#popup img {
    position: absolute;
    bottom: 12px;
    right: 12px;
    width: 122px;
}

#popup h2 {
    font-size: 56px;
    line-height: 72px;
}

#popup h3 {
    color: #493474;
    font-size: 28px;
    font-weight: 900;
    line-height: 44px;
    margin: 18px 0 24px;
}

.btn.fixed {
    position: fixed;
    bottom: 32px;
    left: 32px;
    font-size: 16px;
    line-height: 48px;
    padding: 0 28px;
    font-weight: 600;
}