@import "https://fonts.googleapis.com/css?family=Roboto:300,300italic,400,400italic,700,700italic";
@import "https://fonts.googleapis.com/css?family=Montserrat:400,500,700";

/* Auswahlanzeige (Markieren von Text) */
::-webkit-selection {
  background-color: #ffd4bf;
  color: #1a1a1a;
  text-shadow: none;
}
::-moz-selection {
  background-color: #ffd4bf;
  color: #1a1a1a;
  text-shadow: none;
}
::selection {
  background-color: #ffd4bf;
  color: #1a1a1a;
  text-shadow: none;
}

/* Reset-/Basiseinstellungen */
*,
:before,
:after {
  padding: 0;
  margin: 0;
  border: 0;
  outline: 0;
  vertical-align: baseline;
  color: inherit;
  font: inherit;
  font-size: 100%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
  display: block;
}
audio,
canvas,
progress,
video {
  display: inline-block;
}
audio:not([controls]) {
  display: none;
  height: 0;
}
html,
body {
  height: 100%;
}
html {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
   scroll-behavior: smooth;
}
body {
  background-color: #fff;
  color: #666;
  font: normal 400 16px/1.75 Roboto, Helvetica, Arial, sans-serif;
}
body.overlay-visible {
  overflow: hidden;
}

/* Überschriften */
h1,
.h1,
h2,
.h2,
h3,
.h3,
h4,
.h4,
h5,
.h5,
h6,
.h6 {
  color: #1a1a1a;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-weight: 700;
  line-height: 1.25;
  text-transform: uppercase;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 48px 0 24px;
}
h1:first-child,
h2:first-child,
h3:first-child,
h4:first-child,
h5:first-child,
h6:first-child {
  margin-top: 0;
}
h1:last-child,
h2:last-child,
h3:last-child,
h4:last-child,
h5:last-child,
h6:last-child {
  margin-bottom: 0;
}
h1,
.h1 {
  font-size: 32px;
}
h2,
.h2 {
  font-size: 24px;
}
h3,
.h3 {
  font-size: 20px;
}
h4,
.h4 {
  font-size: 16px;
}
h5,
.h5 {
  font-size: 14px;
}
h6,
.h6 {
  font-size: 12px;
}

/* Links */
a {
  background-color: transparent;
  color: #f50;
  text-decoration: none;
  cursor: pointer;
  -webkit-touch-action: manipulation;
  -moz-touch-action: manipulation;
  -ms-touch-action: manipulation;
  -o-touch-action: manipulation;
  touch-action: manipulation;
}
a:active,
.not-touch a:hover {
  text-decoration: underline;
}

/* Typografische Basiselemente */
abbr,
acronym,
dfn {
  border-bottom: 1px solid #e6e6e6;
  cursor: help;
}
b,
strong {
  font-weight: 700;
}
big {
  font-size: 24px;
}
cite,
dfn,
em,
i,
q {
  font-style: italic;
}
code,
kbd,
samp,
tt,
var {
  font-family: "Lucida Console", Monaco, monospace;
}
del,
s,
strike {
  text-decoration: line-through;
}
ins,
mark {
  padding: 0 4px;
  background-color: #ff8040;
  text-decoration: none;
}
kbd {
  padding: 4px 8px;
  border: 1px solid #e6e6e6;
}
q:before {
  content: "„";
}
q:after {
  content: "“";
}
small,
sub,
sup {
  font-size: 12px;
}
sub,
sup {
  position: relative;
  line-height: 0;
}
sup {
  top: -8px;
}
sub {
  bottom: -4px;
}
u {
  text-decoration: underline;
}
address {
  margin-bottom: 24px;
  font-style: normal;
}
address:last-child {
  margin-bottom: 0;
}
address > :last-child {
  margin-bottom: 0;
}

/* Blockzitate */
blockquote {
  padding: 0 20px;
  margin-bottom: 24px;
  border-left: 4px solid #ffd4bf;
  font-size: 24px;
  font-weight: 300;
  font-style: italic;
  quotes: none;
}
blockquote:last-child {
  margin-bottom: 0;
}
blockquote:before,
blockquote:after {
  content: "";
  content: none;
}
blockquote > :last-child {
  margin-bottom: 0;
}
blockquote cite,
blockquote small {
  display: block;
  font-size: 12px;
  font-weight: 400;
}
blockquote cite:before,
blockquote small:before {
  content: "— ";
}

/* HR, Absatz, Pre, Listen */
hr {
  height: 1px;
  margin: 48px 0;
  background-color: #e6e6e6;
}
hr:first-child {
  margin-top: 0;
}
hr:last-child {
  margin-bottom: 0;
}
p {
  margin-bottom: 24px;
}
p:last-child {
  margin-bottom: 0;
}
pre {
  margin-bottom: 24px;
  padding: 16px 20px;
  overflow: auto;
  background-color: #f2f2f2;
  white-space: pre-wrap;
  word-wrap: break-word;
}
pre:last-child {
  margin-bottom: 0;
}
dl {
  margin-bottom: 24px;
}
dl:last-child {
  margin-bottom: 0;
}
dd,
dt {
  padding-bottom: 16px;
  margin-bottom: 16px;
  border-bottom: 1px solid #e6e6e6;
}
dt {
  color: #1a1a1a;
  font-weight: 700;
}
ol,
ul {
  margin: 0 0 24px 16px;
  list-style: none;
}
ol:last-child,
ul:last-child {
  margin-bottom: 0;
}
ol {
  list-style: outside decimal;
}
ul {
  list-style: outside disc;
}
ol > li {
  margin-bottom: 8px;
}
ol > li > ol,
ol > li > ul,
ul > li > ol,
ul > li > ul {
  margin-top: 8px;
  margin-bottom: 0;
}
figure {
  margin: 0;
  margin-bottom: 24px;
}
figure:last-child {
  margin-bottom: 0;
}

/* Bilder, Videos, Rahmen */
img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
  -ms-interpolation-mode: bicubic;
}
svg:not(:root) {
  overflow: hidden;
}
.frame-wrap {
  height: 0;
  padding-bottom: 56.25%;
  margin-bottom: 24px;
  overflow: hidden;
  position: relative;
}
.frame-wrap:last-child {
  margin-bottom: 0;
}
.frame-wrap > * {
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}

/* Buttons */
.btn-solid,
.btn-ghost {
  display: inline-block;
  vertical-align: middle;
  width: auto;
  position: relative;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.5;
  text-transform: uppercase;
  white-space: nowrap;
  cursor: pointer;
}
.btn-solid {
  padding: 18px 60px 18px 40px;
  background-color: #f50;
  color: #fff;
}
.not-touch .btn-solid {
  -webkit-transition: color 0.25s, background-color 0.25s;
  -moz-transition: color 0.25s, background-color 0.25s;
  -ms-transition: color 0.25s, background-color 0.25s;
  -o-transition: color 0.25s, background-color 0.25s;
  transition: color 0.25s, background-color 0.25s;
}
.btn-solid:active,
.btn-solid:focus,
.not-touch .btn-solid:hover {
  background-color: #fff;
  color: #f50;
  text-decoration: none;
}
.btn-ghost {
  padding: 16px 58px 16px 38px;
  border: 2px solid #f50;
  background-color: transparent;
  color: #f50;
}
.not-touch .btn-ghost {
  -webkit-transition: background-color 0.25s, color 0.25s;
  -moz-transition: background-color 0.25s, color 0.25s;
  -ms-transition: background-color 0.25s, color 0.25s;
  -o-transition: background-color 0.25s, color 0.25s;
  transition: background-color 0.25s, color 0.25s;
}
.btn-ghost:active,
.btn-ghost:focus,
.not-touch .btn-ghost:hover {
  background-color: #f50;
  color: #fff;
  text-decoration: none;
}
.btn-solid:after,
.btn-ghost:after {
  content: "";
  width: 20px;
  height: 20px;
  margin: -10px 0;
  position: absolute;
  top: 50%;
  right: 20px;
  background: transparent url(images/icon-sprite-arrows.svg) no-repeat 0 0;
}
.not-touch .btn-solid:after,
.not-touch .btn-ghost:after {
  -webkit-transition: background-position 0.25s;
  -moz-transition: background-position 0.25s;
  -ms-transition: background-position 0.25s;
  -o-transition: background-position 0.25s;
  transition: background-position 0.25s;
}
.not-svg .btn-solid:after,
.not-svg .btn-ghost:after {
  background-image: url(images/icon-sprite-arrows.png);
}
.btn-solid:after {
  background-position: -20px 0;
}
.btn-solid:active:after,
.not-touch .btn-solid:hover:after {
  background-position: 0 0;
}
.btn-ghost:after {
  background-position: -40px 0;
}
.btn-ghost:active:after,
.not-touch .btn-ghost:hover:after {
  background-position: -20px 0;
}
.btn-solid.disabled,
.btn-ghost.disabled {
  pointer-events: none;
  opacity: 0.5;
}
.btn-row {
  margin-bottom: 24px;
}
.btn-row:last-child {
  margin-bottom: 0;
}

/* Platzhalter (Inputs) */
::-webkit-input-placeholder {
  color: #999;
  opacity: 1;
}
:-moz-placeholder {
  color: #999;
  opacity: 1;
}
::-moz-placeholder {
  color: #999;
  opacity: 1;
}
:-ms-input-placeholder {
  color: #999;
  opacity: 1;
}

/* Formulare, Inputs */
form {
  margin-bottom: 24px;
}
form:last-child {
  margin-bottom: 0;
}
button,
input[type="button"],
input[type="reset"],
input[type="submit"],
input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="tel"],
input[type="number"],
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  -ms-appearance: none;
  -o-appearance: none;
  appearance: none;
}
button,
input,
select,
textarea {
  max-width: 100%;
  -webkit-border-radius: 0;
  -moz-border-radius: 0;
  -ms-border-radius: 0;
  -o-border-radius: 0;
  border-radius: 0;
  -webkit-box-shadow: none;
  -moz-box-shadow: none;
  -ms-box-shadow: none;
  -o-box-shadow: none;
  box-shadow: none;
  -webkit-touch-action: manipulation;
  -moz-touch-action: manipulation;
  -ms-touch-action: manipulation;
  -o-touch-action: manipulation;
  touch-action: manipulation;
}
button[disabled],
input[disabled],
select[disabled],
textarea[disabled] {
  cursor: default;
  opacity: 0.5;
}
button,
input,
select {
  line-height: 1.5;
  white-space: nowrap;
}
button {
  overflow: visible;
  text-transform: none;
}
button::-moz-focus-inner,
input::-moz-focus-inner {
  padding: 0;
  border: 0;
}
input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="tel"],
input[type="number"],
select,
textarea {
  vertical-align: middle;
  padding: 12px 16px;
  border: 1px solid #d9d9d9;
  background-color: #fff;
  color: #1a1a1a;
  -webkit-box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.125);
  -moz-box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.125);
  -ms-box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.125);
  -o-box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.125);
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.125);
}
.not-touch
  input[type="text"],
  .not-touch
  input[type="email"],
  .not-touch
  input[type="url"],
  .not-touch
  input[type="password"],
  .not-touch
  input[type="search"],
  .not-touch
  input[type="tel"],
  .not-touch
  input[type="number"],
  .not-touch
  select,
  .not-touch
  textarea {
  -webkit-transition: border-color 0.25s;
  -moz-transition: border-color 0.25s;
  -ms-transition: border-color 0.25s;
  -o-transition: border-color 0.25s;
  transition: border-color 0.25s;
}
input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="tel"]:focus,
input[type="number"]:focus,
select:focus,
textarea:focus {
  border-color: #f50;
}
input[type="file"] {
  width: 100%;
}
input[type="checkbox"],
input[type="radio"] {
  padding: 0;
  margin-right: 4px;
}
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  height: auto;
}
input[type="search"] {
  -webkit-appearance: textfield;
  -moz-appearance: textfield;
  -ms-appearance: textfield;
  -o-appearance: textfield;
  appearance: textfield;
}
input[type="search"]::-webkit-search-decoration,
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-results-button,
input[type="search"]::-webkit-search-results-decoration {
  display: none;
}
input::-ms-clear,
input::-ms-reveal {
  display: none;
}
label {
  display: inline-block;
  margin: 0 16px 4px 0;
  line-height: 1.5;
}
legend {
  margin-bottom: 24px;
  color: #1a1a1a;
  font-size: 24px;
  font-weight: 700;
}
select,
select[multiple] {
  height: auto;
}
select {
  background-repeat: no-repeat;
  background-position: 100% 50%;
  background-image: url(images/icon-select-arrow.svg);
  text-transform: none;
  cursor: pointer;
}
.not-svg select {
  background-image: none;
}
select[multiple] {
  background-image: none;
}
select[disabled] {
  background-image: none;
}
select::-ms-expand {
  display: none;
}
textarea {
  max-width: 100%;
  height: auto;
  min-height: 240px;
  overflow: auto;
}

/* Tabellen */
table,
th,
td {
  border: 1px solid #e6e6e6;
}
table {
  width: 100%;
  max-width: 100%;
  min-width: 640px;
  margin-bottom: 24px;
  border-collapse: collapse;
  border-spacing: 0;
  background-color: transparent;
}
table:last-child {
  margin-bottom: 0;
}
caption,
th,
td {
  line-height: 1.5;
  font-weight: 400;
  text-align: left;
}
caption,
th {
  border-width: 0 1px 1px 0;
  color: #1a1a1a;
  font-weight: 700;
}
caption {
  margin-bottom: 24px;
  font-size: 24px;
}
th,
td {
  padding: 8px 16px;
  border-width: 0 1px 1px 0;
}
td {
  border-width: 0 1px 1px 0;
}
.table-scrollable {
  overflow-x: auto;
  margin-bottom: 24px;
  border: 1px solid #e6e6e6;
  -webkit-overflow-scrolling: touch;
}
.table-scrollable > table {
  margin-bottom: 0;
  border: 0;
}
.table-scrollable > table th:last-child,
.table-scrollable > table td:last-child {
  border-right: 0;
}
.table-scrollable > table tr:last-child td {
  border-bottom: 0;
}

/* Align-Klassen */
.alignnone {
  display: block;
  width: 100%;
  max-width: none;
  margin-bottom: 24px;
}
.alignnone:last-child {
  margin-bottom: 0;
}
.alignnone img {
  width: 100%;
  max-width: none;
}
.aligncenter {
  display: block;
  max-width: 80%;
  max-width: none;
  margin-right: auto;
  margin-bottom: 24px;
  margin-left: auto;
  text-align: center;
}
.aligncenter:last-child {
  margin-bottom: 0;
}
.aligncenter img {
  width: 100%;
  max-width: none;
}
.alignright {
  max-width: 260px;
  margin-top: 8px;
  margin-bottom: 24px;
  margin-left: 24px;
  float: right;
}
.alignright:last-child {
  margin-bottom: 0;
}
.alignright img {
  width: 100%;
  max-width: none;
}
.alignleft {
  max-width: 260px;
  margin-top: 8px;
  margin-bottom: 24px;
  margin-right: 24px;
  float: left;
}
.alignleft:last-child {
  margin-bottom: 0;
}
.alignleft img {
  width: 100%;
  max-width: none;
}

form label {
    color: #1a1a1a; /* Dunkelgrau, damit lesbar */
    font-weight: 300; /* Optional: Etwas dicker für bessere Lesbarkeit */
    font-size: 12px;
}


/* Passwortformular */
.post-password-form {
  margin-bottom: 24px;
}
.post-password-form:last-child {
  margin-bottom: 0;
}
.post-password-form label {
  display: block;
  width: 100%;
  margin-bottom: 8px;
  font-size: 12px;
}
.post-password-form input[type="password"] {
  margin-top: 8px;
}
.post-password-form > :last-child {
  margin-bottom: 0;
}

/* Screen Reader */
.screen-reader-text {
  width: 1px;
  height: 1px;
  overflow: hidden;
  position: absolute !important;
  clip: rect(1px, 1px, 1px, 1px);
}

/* Hilfsklasse clearfix */
.clearfix {
  *zoom: 1;
}
.clearfix:before,
.clearfix:after {
  content: "";
  display: table;
  line-height: 0;
}
.clearfix:after {
  clear: both;
}

/* Grids & Rows */
.row,
.col {
  min-height: 1px;
  position: relative;
}
.row-spacing,
.row-spacing > .col {
  padding-right: 20px;
  padding-left: 20px;
}
.row {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-box-flex: 0 1 auto;
  -moz-box-flex: 0 1 auto;
  -webkit-flex: 0 1 auto;
  -moz-flex: 0 1 auto;
  -ms-flex: 0 1 auto;
  -o-flex: 0 1 auto;
  flex: 0 1 auto;
  -webkit-box-orient: horizontal;
  -moz-box-orient: horizontal;
  -webkit-box-direction: normal;
  -moz-box-direction: normal;
  -webkit-flex-direction: row;
  -moz-flex-direction: row;
  -ms-flex-direction: row;
  -o-flex-direction: row;
  flex-direction: row;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
}
.not-flexbox .row {
  display: block;
  *zoom: 1;
}
.row:before,
.row:after {
  content: "";
  width: 0;
}
.not-flexbox .row:before,
.not-flexbox .row:after {
  display: table;
  line-height: 0;
}
.not-flexbox .row:after {
  clear: both;
}
.col {
  -webkit-box-flex: 0 0 auto;
  -moz-box-flex: 0 0 auto;
  -webkit-flex: 0 0 auto;
  -moz-flex: 0 0 auto;
  -ms-flex: 0 0 auto;
  -o-flex: 0 0 auto;
  flex: 0 0 auto;
}
.not-flexbox .col {
  float: left;
}
.col-full {
  max-width: 100%;
  -webkit-box-flex: 0 0 100%;
  -moz-box-flex: 0 0 100%;
  -webkit-flex: 0 0 100%;
  -moz-flex: 0 0 100%;
  -ms-flex: 0 0 100%;
  -o-flex: 0 0 100%;
  flex: 0 0 100%;
}
.not-flexbox .col-full {
  width: 100%;
  max-width: none;
}
.col-threequarters {
  max-width: 75%;
  -webkit-box-flex: 0 0 75%;
  -moz-box-flex: 0 0 75%;
  -webkit-flex: 0 0 75%;
  -moz-flex: 0 0 75%;
  -ms-flex: 0 0 75%;
  -o-flex: 0 0 75%;
  flex: 0 0 75%;
}
.not-flexbox .col-threequarters {
  width: 75%;
  max-width: none;
}
.col-twothirds {
  max-width: 66.66%;
  -webkit-box-flex: 0 0 66.66%;
  -moz-box-flex: 0 0 66.66%;
  -webkit-flex: 0 0 66.66%;
  -moz-flex: 0 0 66.66%;
  -ms-flex: 0 0 66.66%;
  -o-flex: 0 0 66.66%;
  flex: 0 0 66.66%;
}
.not-flexbox .col-twothirds {
  width: 66.66%;
  max-width: none;
}
.col-half {
  max-width: 50%;
  -webkit-box-flex: 0 0 50%;
  -moz-box-flex: 0 0 50%;
  -webkit-flex: 0 0 50%;
  -moz-flex: 0 0 50%;
  -ms-flex: 0 0 50%;
  -o-flex: 0 0 50%;
  flex: 0 0 50%;
}
.not-flexbox .col-half {
  width: 50%;
  max-width: none;
}
.col-onethird {
  max-width: 33.33%;
  -webkit-box-flex: 0 0 33.33%;
  -moz-box-flex: 0 0 33.33%;
  -webkit-flex: 0 0 33.33%;
  -moz-flex: 0 0 33.33%;
  -ms-flex: 0 0 33.33%;
  -o-flex: 0 0 33.33%;
  flex: 0 0 33.33%;
}
.not-flexbox .col-onethird {
  width: 33.33%;
  max-width: none;
}
.col-onequarter {
  max-width: 25%;
  -webkit-box-flex: 0 0 25%;
  -moz-box-flex: 0 0 25%;
  -webkit-flex: 0 0 25%;
  -moz-flex: 0 0 25%;
  -ms-flex: 0 0 25%;
  -o-flex: 0 0 25%;
  flex: 0 0 25%;
}
.not-flexbox .col-onequarter {
  width: 25%;
  max-width: none;
}
.col-right {
  margin-left: auto;
}
.not-flexbox .col-right {
  float: right;
}

/* Abstände & Farben */
.g-spacing-big {
  padding-top: 120px;
  padding-bottom: 120px;
}
.g-spacing-regular {
  padding-top: 30px;
  padding-bottom: 30px;
}
.g-spacing-small {
  padding-top: 20px;
  padding-bottom: 20px;
}
.g-bg-white {
  background-color: #fff;
}
.g-bg-grey {
  background-color: #f2f2f2;
}
.g-bg-white .btn-solid:active,
.g-bg-white .btn-solid:focus,
.not-touch .g-bg-white .btn-solid:hover {
  background-color: #1a1a1a;
}
.g-bg-primary {
  background-color: #f50;
}
.g-bg-primary .btn-solid {
  background-color: #fff;
  color: #f50;
}
.g-bg-primary .btn-solid:active,
.g-bg-primary .btn-solid:focus,
.not-touch .g-bg-primary .btn-solid:hover {
  background-color: #ffd4bf;
}
.g-bg-primary .btn-solid:after {
  background-position: 0 0;
}
.g-bg-primary .btn-ghost {
  border-color: #fff;
  color: #fff;
}
.g-bg-primary .btn-ghost:active,
.g-bg-primary .btn-ghost:focus,
.not-touch .g-bg-primary .btn-ghost:hover {
  background-color: #fff;
  color: #f50;
}
.g-bg-primary .btn-ghost:after {
  background-position: -20px 0;
}
.g-bg-primary .btn-ghost:active:after,
.not-touch .g-bg-primary .btn-ghost:hover:after {
  background-position: 0 0;
}
.g-bg-primarydark {
  background-color: #d94800;
}
.g-bg-lightest {
  background-color: #f2f2f2;
}
.g-bg-lightest .btn-solid:active,
.g-bg-lightest .btn-solid:focus,
.not-touch .g-bg-lightest .btn-solid:hover {
  background-color: #1a1a1a;
}
.g-bg-dark {
  background-color: #404040;
}
.g-bg-darker {
  background-color: #262626;
}
.g-bg-darkest {
  background-color: #1a1a1a;
}
.g-bg-cover {
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: cover;
}
.g-bg-wolf {
  background-image: url(images/bg-wolf-white.svg);
  background-repeat: no-repeat;
  background-position: 95% 100%;
}
.not-svg .g-bg-wolf {
  background-image: url(images/bg-wolf-white.png);
}

/* Schatten */
.g-shadow-hard {
  -webkit-box-shadow: 0 20px 40px rgba(0, 0, 0, 0.25);
  -moz-box-shadow: 0 20px 40px rgba(0, 0, 0, 0.25);
  -ms-box-shadow: 0 20px 40px rgba(0, 0, 0, 0.25);
  -o-box-shadow: 0 20px 40px rgba(0, 0, 0, 0.25);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.25);
}
.g-shadow-soft {
  -webkit-box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1);
  -moz-box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1);
  -ms-box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1);
  -o-box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1);
}
.g-shadow-small {
  -webkit-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.05);
  -moz-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.05);
  -ms-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.05);
  -o-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.05);
  box-shadow: 0 5px 10px rgba(0, 0, 0, 0.05);
}
.g-margin-big {
  margin-bottom: 60px;
}
.g-margin-regular {
  margin-bottom: 40px;
}
.g-margin-small {
  margin-bottom: 20px;
}
.g-wrap {
  margin-right: auto;
  margin-left: auto;
}
.g-wrap-wide {
  max-width: 1480px;
}
.g-wrap-narrow {
  max-width: 760px;
}

/* Farbschema Weiß */
.g-type-white,
.g-type-white h1,
.g-type-white h2,
.g-type-white h3,
.g-type-white h4,
.g-type-white h5,
.g-type-white h6 {
  color: #fff;
}
.g-type-lead {
  font-size: 20px;
  font-weight: 300;
  font-style: italic;
}
.g-type-small {
  color: #999;
  font-size: 12px;
  font-weight: 400;
}
.g-type-center {
  text-align: center;
}

/* Titel / Überschriften */
.g-title-big {
  margin: 0 0 20px;
  padding: 0 0 20px;
  position: relative;
  font-size: 48px;
  letter-spacing: -1px;
}
.g-title-big:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
}
.g-title-big:after {
  content: "";
  width: 80px;
  height: 2px;
  position: absolute;
  bottom: 0;
  left: 0;
  background-color: #ffd4bf;
}
.g-type-white .g-title-big:after {
  background-color: #fff;
}
.g-title-big:last-child:after {
  display: none;
}
.g-type-center .g-title-big:after {
  margin: 0 -40px;
  left: 50%;
}
.g-title-regular + .g-title-big {
  margin-top: -16px;
}
.g-title-regular {
  font-size: 24px;
}
.g-title-small {
  font-size: 16px;
}
.g-title-primary {
  color: #f50 !important;
  padding-top: 30px;
}
.g-bg-primary .g-title-primary {
  color: #ffaa80 !important;
}

/* Loading-Bar */
.loading {
  width: 100%;
  height: 4px;
  position: fixed;
  top: 0;
  left: -100%;
  z-index: 100;
  transition: transform 0.25s;
}
.not-csstransforms .loading {
  display: none;
}

/* Page-Container */
.page {
  min-height: 100%;
  overflow: hidden;
  position: relative;
  background-color: #1a1a1a;
}



.bg-image-cover {
  background-image: url(images/rcw-bg.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

* Header */
.header {
  width: 100%;
  height: 160px;
  position: absolute;
  top: 0px;
  right: 0;
  left: 0;
  z-index: 90;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0, rgba(26, 26, 26, 1)), color-stop(100%, rgba(26, 26, 26, 0)));
  background: -webkit-linear-gradient(top, rgba(26, 26, 26, 1) 0, rgba(26, 26, 26, 0) 100%);
  background: -moz-linear-gradient(top, rgba(26, 26, 26, 1) 0, rgba(26, 26, 26, 0) 100%);
  background: -ms-linear-gradient(top, rgba(26, 26, 26, 1) 0, rgba(26, 26, 26, 0) 100%);
  background: -o-linear-gradient(top, rgba(26, 26, 26, 1) 0, rgba(26, 26, 26, 0) 100%);
  background: linear-gradient(to bottom, rgba(26, 26, 26, 1) 0, rgba(26, 26, 26, 0) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0, startColorstr='#FF1A1A1A', endColorstr='#001A1A1A');
  line-height: 1.5;
}

.header a {
  display: block;
  white-space: nowrap;
}
.header a:active,
.not-touch .header a:hover {
  text-decoration: none;
}
.header ul {
  margin: 0;
  list-style: none;
}
.header-logo {
  width: 200px;
  margin: 0 -100px;
  position: absolute;
  top: 20px;
  left: 50%;
  z-index: 30;
}
.header-logo a img {
  display: block;
  width: 200px;
  height: 110px;
}

/* Button-Item in Navi */
.header-nav .nav-col > ul > li.button {
  padding: 0;
}
.header-nav .nav-col > ul > li.button > a {
  padding: 6px 38px 6px 18px;
  border: 2px solid #f50;
  position: relative;
  background-color: transparent;
  color: #f50;
}
.not-touch .header-nav .nav-col > ul > li.button > a {
  -webkit-transition: background-color 0.25s, color 0.25s;
  -moz-transition: background-color 0.25s, color 0.25s;
  -ms-transition: background-color 0.25s, color 0.25s;
  -o-transition: background-color 0.25s, color 0.25s;
  transition: background-color 0.25s, color 0.25s;
}
.header-nav .nav-col > ul > li.button[class*="current"] > a,
.header-nav .nav-col > ul > li.button > a:active,
.not-touch .header-nav .nav-col > ul > li.button > a:hover {
  background-color: #f50;
  color: #fff;
}
.header-nav .nav-col > ul > li.button > a:after {
  content: "";
  width: 20px;
  height: 20px;
  margin: -10px 0;
  position: absolute;
  top: 50%;
  right: 8px;
  background: transparent url(images/icon-sprite-arrows.svg) no-repeat -40px 0;
}
.not-touch .header-nav .nav-col > ul > li.button > a:after {
  -webkit-transition: background-position 0.25s;
  -moz-transition: background-position 0.25s;
  -ms-transition: background-position 0.25s;
  -o-transition: background-position 0.25s;
  transition: background-position 0.25s;
}
.header-nav .nav-col > ul > li.button[class*="current"] > a:after,
.header-nav .nav-col > ul > li.button > a:active:after,
.not-touch .header-nav .nav-col > ul > li.button > a:hover:after {
  background-position: -20px 0;
}
.not-svg .header-nav .nav-col > ul > li.button > a:after {
  background-image: url(images/icon-sprite-arrows.png);
}
.header-nav .nav-left {
  padding-right: 120px;
}
.header-nav .nav-left > ul > li {
  margin-right: 16px;
}
.header-nav .nav-left > ul > li:last-child {
  margin-right: 0;
}
.header-nav .nav-right {
  padding-left: 120px;
}
.header-nav .nav-right ul {
  float: right;
}
.header-nav .nav-right > ul > li {
  margin-left: 16px;
}
.header-nav .nav-right > ul > li:first-child {
  margin-left: 0;
}
.header-menu {
  display: none;
}

/* Header: top bar */
.header-top {
  position: relative;
  z-index: 20;
  color: #999;
}
.header-top a {
  color: #999;
}
.header-top .top-col {
  height: 80px;
  padding-top: 28px;
  padding-bottom: 28px;
  position: relative;
}
.header-top .top-col:after {
  content: "";
  width: calc(100% - 160px);
  height: 2px;
  position: absolute;
  bottom: -1px;
  z-index: 1;
  background-color: #262626;
  background-color: rgba(255, 255, 255, 0.075);
}
.header-top .top-col span {
  display: inline-block;
  margin-right: 16px;
  white-space: nowrap;
}
.header-top .top-col span:last-child {
  margin-right: 0;
}
.header-top .top-col .col-mail {
  display: inline-block;
  border-bottom: 1px solid #999;
}
.not-touch .header-top .top-col .col-mail {
  -webkit-transition: color 0.25s, border-bottom-color 0.25s;
  -moz-transition: color 0.25s, border-bottom-color 0.25s;
  -ms-transition: color 0.25s, border-bottom-color 0.25s;
  -o-transition: color 0.25s, border-bottom-color 0.25s;
  transition: color 0.25s, border-bottom-color 0.25s;
}
.header-top .top-col .col-mail:active,
.not-touch .header-top .top-col .col-mail:hover {
  color: #fff;
  border-bottom-color: #fff;

}
.header-top .top-col .col-language a {
  font-weight: 700;
}
.not-touch .header-top .top-col .col-language a {
  -webkit-transition: color 0.25s;
  -moz-transition: color 0.25s;
  -ms-transition: color 0.25s;
  -o-transition: color 0.25s;
  transition: color 0.25s;
}
.header-top .top-col .col-language a img {
  display: inline-block;
  margin: -3px 4px 0 0;
}
.header-top .top-col .col-language > li {
  margin: -8px 0;
  padding: 8px 0;
  position: relative;
}
.header-top .top-col .col-language > li > a {
  display: inline-block;
}
.header-top .top-col .col-language > li.subnav-visible > a,
.not-touch .header-top .top-col .col-language > li:hover > a,
.not-touch .header-top .top-col .col-language > li > a:hover {
  color: #fff;
}
/* Dropdown-Menü bei Hover anzeigen */
.header-top .col-language > li ul {
  display: none;
  position: absolute;
  top: 40px;
  left: 0;
  background: #e6e6e6;
  box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
  padding: 10px 0;
  min-width: 150px;
}

/* Bei Hover oder Fokus anzeigen */
.header-top .col-language > li:hover > ul,
.header-top .col-language > li:focus-within > ul {
  display: block;
}
.header-top .top-col .col-language > li > ul:after {
  content: "";
  width: 20px;
  height: 20px;
  position: absolute;
  top: -14px;
  right: 32px;
  background: transparent url(images/icon-sprite-arrows.svg) no-repeat -40px -40px;
}
.not-svg .header-top .top-col .col-language > li > ul:after {
  background-image: url(images/icon-sprite-arrows.png);
}
.header-top .top-col .col-language > li > ul > li {
  border-bottom: 1px solid #e6e6e6;
  padding: 11px 40px 11px 12px;
  position: relative;
  color: #666;
}
.header-top .top-col .col-language > li > ul > li > a:after {
  content: "";
  width: 20px;
  height: 20px;
  margin: -10px 0;
  position: absolute;
  top: 50%;
  right: 10px;
  background: transparent url(images/icon-sprite-arrows.svg) no-repeat -40px -20px;
  opacity: 0.5;
}
.not-touch .header-top .top-col .col-language > li > ul > li > a:after {
  -webkit-transition: opacity 0.25s;
  -moz-transition: opacity 0.25s;
  -ms-transition: opacity 0.25s;
  -o-transition: opacity 0.25s;
  transition: opacity 0.25s;
}
.header-top .top-col .col-language > li > ul > li > a:active:after,
.not-touch .header-top .top-col .col-language > li > ul > li > a:hover:after {
  opacity: 1;
}
.not-svg .header-top .top-col .col-language > li > ul > li > a:after {
  background-image: url(images/icon-sprite-arrows.png);
}
.header-top .top-col .col-language > li > ul > li:last-child > a {
  border-bottom: 0;
}
.header-top .top-col .col-language > li > ul > li.current > a,
.header-top .top-col .col-language > li > ul > li > a:active,
.not-touch .header-top .top-col .col-language > li > ul > li > a:hover {
  color: #1a1a1a;
}
.header-top .top-left {
  padding-right: 120px;
}
.header-top .top-left:after {
  left: 20px;
  right: 140px;
}
.header-top .top-right {
  padding-left: 120px;
}
.header-top .top-right:after {
  left: 140px;
  right: 20px;
}
.header-top .top-right .col-inner {
  float: right;
}

.header-top .top-col .col-mail {
  color: #999; /* Standardfarbe */
  border-bottom: 1px solid #999;
  transition: color 0.3s ease, border-bottom-color 0.3s ease;
}

/* Hover: Helleres Weiß */
.header-top .top-col .col-mail:hover {
  color: #f2f2f2; /* Helleres Weiß */
  border-bottom-color: #f2f2f2;
}

/* Header-Navigation */
.header-nav {
  position: relative;
  z-index: 10;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  text-transform: uppercase;
}
.header-nav a {
  font-weight: 700;
}
.header-nav .nav-col {
  height: 80px;
  padding-top: 28px;
  padding-bottom: 28px;
}
.header-nav .nav-col a {
  color: #fff;
}
.not-touch .header-nav .nav-col a {
  -webkit-transition: color 0.25s;
  -moz-transition: color 0.25s;
  -ms-transition: color 0.25s;
  -o-transition: color 0.25s;
  transition: color 0.25s;
}
.header-nav .nav-col li[class*="current"] > a,
.header-nav .nav-col a:active,
.header-nav .nav-col li.menu-item-has-children.subnav-visible > a,
.not-touch .header-nav .nav-col li.menu-item-has-children:hover > a,
.not-touch .header-nav .nav-col a:hover {
  color: #f50;
}
.header-nav .nav-col > ul > li {
  display: inline-block;
  vertical-align: top;
  margin: -8px 0;
  padding: 8px 0;
}
.header-nav .nav-col > ul > li > a {
  padding-right: 20px;
}
.header-nav .nav-col > ul > li.menu-item-has-children {
  position: relative;
}
.header-nav .nav-col > ul > li.menu-item-has-children:after {
  display: none;
  content: "";
  width: 100%;
  height: 2px;
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: #f50;
}
.header-nav .nav-col > ul > li.menu-item-has-children.subnav-visible:after,
.not-touch .header-nav .nav-col > ul > li.menu-item-has-children:hover:after {
  display: block;
}
.header-nav .nav-col > ul > li.menu-item-has-children > a {
  position: relative;
}
.header-nav .nav-col > ul > li.menu-item-has-children > a:after {
  content: "";
  width: 20px;
  height: 20px;
  position: absolute;
  top: 2px;
  right: 0;
  background: transparent url(images/icon-sprite-arrows.svg) no-repeat 0 -40px;
}
.not-touch .header-nav .nav-col > ul > li.menu-item-has-children > a:after {
  -webkit-transition: background-position 0.25s;
  -moz-transition: background-position 0.25s;
  -ms-transition: background-position 0.25s;
  -o-transition: background-position 0.25s;
  transition: background-position 0.25s;
}
.header-nav .nav-col > ul > li.menu-item-has-children[class*="current"] > a:after,
.header-nav .nav-col > ul > li.menu-item-has-children.subnav-visible > a:after,
.header-nav .nav-col > ul > li.menu-item-has-children > a:active:after,
.not-touch .header-nav .nav-col > ul > li.menu-item-has-children:hover > a:after,
.not-touch .header-nav .nav-col > ul > li.menu-item-has-children > a:hover:after {
  background-position: 0 -20px;
}
.not-svg .header-nav .nav-col > ul > li.menu-item-has-children > a:after {
  background-image: url(images/icon-sprite-arrows.png);
}
.header-nav .nav-col > ul > li.menu-item-has-children > ul {
  display: none;
  min-width: 320px;
  padding: 11px 0;
  position: absolute;
  top: 40px;
  left: 0;
  font-family: "Roboto", Helvetica, Arial, sans-serif;
  font-size: 14px;
  background-color: rgba(0, 0, 0, 0.8);
}
.header-nav .nav-col > ul > li.menu-item-has-children.subnav-visible > ul,
.not-touch .header-nav .nav-col > ul > li.menu-item-has-children:hover > ul {
  display: block;
}
.header-nav .nav-col > ul > li.menu-item-has-children > ul > li {
  display: block;
  vertical-align: top;
  margin-right: 16px;
  margin-left: 16px;
  margin-bottom: 8px;
}
.header-nav .nav-col > ul > li.menu-item-has-children > ul > li:last-child {
  margin-right: 0;
}

/* Standardfarbe für alle Links */
.header-nav .nav-col > ul > li.menu-item > a {
  color: #fff; /* Standardfarbe */
  transition: color 0.25s ease-in-out;
}

/* Hover: Orange */
.header-nav .nav-col > ul > li.menu-item > a:hover {
  color: #f50;
}

/* Aktiv (wenn die Seite geladen ist und der Link zur aktuellen Seite gehört) */
.header-nav .nav-col > ul > li.menu-item.current-menu-item > a,
.header-nav .nav-col > ul > li.menu-item > a:active {
  color: #f50; /* Helles Orange für aktiven Link */
}

/* Fokus (wenn mit der Tastatur navigiert wird) */
.header-nav .nav-col > ul > li.menu-item > a:focus {
  outline: none; /* Falls der Standardrahmen stört */
  color: #f50; /* Etwas helleres Orange für Fokus */
}

/* Main-Container */
.main {
  position: relative;
  z-index: 10;
}
.main-hero {
  padding-top: 160px;
  background-color: transparent;
  overflow: hidden;
  position: relative;
  z-index: 10;
}
.main-hero-full {
  height: 100vh;
  height: calc(100vh - 240px);
  min-height: 720px;
  padding-top: 0;
}
.main-hero .hero-bg {
  width: 100%;
  height: 100%;
  overflow: hidden;
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  z-index: -1;
  opacity: 0.5;
}
.main-hero .hero-bg:after {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0, rgba(26, 26, 26, 0.5)), color-stop(100%, rgba(26, 26, 26, 0)));
  background: -webkit-linear-gradient(top, rgba(26, 26, 26, 0.5) 0, rgba(26, 26, 26, 0) 100%);
  background: -moz-linear-gradient(top, rgba(26, 26, 26, 0.5) 0, rgba(26, 26, 26, 0) 100%);
  background: -ms-linear-gradient(top, rgba(26, 26, 26, 0.5) 0, rgba(26, 26, 26, 0) 100%);
  background: -o-linear-gradient(top, rgba(26, 26, 26, 0.5) 0, rgba(26, 26, 26, 0) 100%);
  background: linear-gradient(to bottom, rgba(26, 26, 26, 0.5) 0, rgba(26, 26, 26, 0) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0, startColorstr='#7F1A1A1A', endColorstr='#001A1A1A');
}
.main-hero-full .hero-content {
  width: 100%;
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
}
.main-hero .hero-content .content-title {
  max-width: 960px;
}
.main-hero-full .hero-content .content-title {
  max-width: 600px;
}
.main-hero .hero-content .content-title .title-lead {
  margin: 0 0 32px;
}
.main-hero .hero-content .content-title .title-lead:last-child {
  margin-bottom: 0;
}
.main-hero .hero-content .content-title .btn-solid,
.main-hero .hero-content .content-title .btn-ghost {
  margin: 0 4px 4px 0;
}
.main-hero .hero-content .content-title .btn-solid:last-child,
.main-hero .hero-content .content-title .btn-ghost:last-child {
  margin-right: 0;
}
.main-hero .hero-pages {
  width: 100%;
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  line-height: 1.5;
  text-transform: uppercase;
}
.main-hero .hero-pages .pages-menu ul {
  height: 50px;
  margin: 0;
  overflow: hidden;
  list-style: none;
}
.main-hero .hero-pages .pages-menu li {
  margin-right: 4px;
  float: left;
}
.main-hero .hero-pages .pages-menu li:last-child {
  margin-right: 0;
}
.main-hero .hero-pages .pages-menu li a {
  display: block;
  padding: 18px 40px 8px;
  background-color: #1a1a1a;
  color: #666;
  font-weight: 700;
  white-space: nowrap;
}
.not-touch .main-hero .hero-pages .pages-menu li a {
  -webkit-transition: color 0.25s;
  -moz-transition: color 0.25s;
  -ms-transition: color 0.25s;
  -o-transition: color 0.25s;
  transition: color 0.25s;
}
.main-hero .hero-pages .pages-menu li a:active,
.not-touch .main-hero .hero-pages .pages-menu li a:hover {
  color: #fff;
  text-decoration: none;
}
.main-hero .hero-pages .pages-menu li[class*="current"] a,
.main-hero .hero-pages .pages-menu li[class*="current"] a:active,
.not-touch .main-hero .hero-pages .pages-menu li[class*="current"] a:hover {
  background-color: #fff;
  color: #f50;
  cursor: default;
}

/* Scroll-Element */
.main-hero .hero-scroll {
  width: 40px;
  height: 100px;
  position: absolute;
  right: 5%;
  bottom: 0;
}
.main-hero .hero-scroll a {
  display: block;
  width: 40px;
  height: 100px;
  overflow: hidden;
  position: relative;
}
.main-hero .hero-scroll a:after {
  content: "";
  width: 2px;
  height: 40px;
  margin: 0 -1px;
  position: absolute;
  bottom: 0;
  left: 50%;
  background-color: #fff;
}
.not-touch .main-hero .hero-scroll a:after {
  -webkit-transition: -webkit-transform 0.25s;
  -moz-transition: -moz-transform 0.25s;
  -ms-transition: -ms-transform 0.25s;
  -o-transition: -o-transform 0.25s;
  transition: transform 0.25s;
}
.not-touch .main-hero .hero-scroll a:hover:after {
  -webkit-transform: translateY(8px);
  -moz-transform: translateY(8px);
  -ms-transform: translateY(8px);
  -o-transform: translateY(8px);
  transform: translateY(8px);
}
.main-hero .hero-scroll a:active,
.not-touch .main-hero .hero-scroll a:hover {
  opacity: 1;
}
.main-hero .hero-scroll a .scroll-circle {
  display: block;
  width: 40px;
  height: 40px;
}
.main-hero .hero-scroll a .scroll-circle-fallback {
  display: none;
}
.not-svg .main-hero .hero-scroll a .scroll-circle {
  display: none;
}
.not-svg .main-hero .hero-scroll a .scroll-circle-fallback {
  display: block;
}
.not-touch .main-hero .hero-scroll a .scroll-circle .circle-arrow {
  -webkit-transition: opacity 0.25s, -webkit-transform 0.25s;
  -moz-transition: opacity 0.25s, -moz-transform 0.25s;
  -ms-transition: opacity 0.25s, -ms-transform 0.25s;
  -o-transition: opacity 0.25s, -o-transform 0.25s;
  transition: opacity 0.25s, transform 0.25s;
}
.not-touch .main-hero .hero-scroll a:hover .scroll-circle .circle-arrow {
  opacity: 0;
  -webkit-transform: translateY(8px);
  -moz-transform: translateY(8px);
  -ms-transform: translateY(8px);
  -o-transform: translateY(8px);
  transform: translateY(8px);
}
.main-hero .hero-scroll a .scroll-circle .circle-arrow-clone {
  opacity: 0;
  -webkit-transform: translateY(-100%);
  -moz-transform: translateY(-100%);
  -ms-transform: translateY(-100%);
  -o-transform: translateY(-100%);
  transform: translateY(-100%);
}
.not-touch .main-hero .hero-scroll a:hover .scroll-circle .circle-arrow-clone {
  opacity: 1;
  -webkit-transform: translateY(0);
  -moz-transform: translateY(0);
  -ms-transform: translateY(0);
  -o-transform: translateY(0);
  transform: translateY(0);
}



.shop-inlining {
  margin-left: 50px !important;
}

.shop-entry {
  margin-top: 30px !important;
  font-style: normal !important;
}

.shop-progress {
  font-size: 15px !important;
  margin-bottom: 30px !important;
}

.btn-slim {
  padding: 10px 10px 10px 10px !important;
}

.btn-startscreen {
  width: 250px !important;
  padding-left: 22px !important;
  color: white !important;
}

.loginbox {
  width: 350px;
}

.starttext {
  margin-left: -5%;
  width: 450px;
  vertical-align: text-bottom;
}

.menu-item-with-icon {
  padding-left: 30px !important;
}

.menu-item-basket {
  background: transparent url(images/Warenkorb.png) left center no-repeat !important;
}

.menu-item-profil {
  background: transparent url(images/Mein-Bereich.png) left center no-repeat !important;
}

.main {
  margin-bottom: 100px;
}


.footer {
  position: absolute !important;
  bottom: 0 !important;
  width: 100% !important;
  z-index: 100 !important;
}

/* Basis für .footer */
.footer {
  position: relative;
  z-index: 1;
  line-height: 1.5;
}
.footer a {
  white-space: nowrap;
}
.footer a:active,
.not-touch .footer a:hover {
  text-decoration: none;
}
.footer ul {
  margin: 0;
  list-style: none;
}

/* Footer-Bereich “oben” (falls vorhanden) */
.footer-top {
  overflow: hidden;
  position: relative;
  z-index: 1;
  font-family: "Montserrat",Helvetica,Arial,sans-serif;
  text-transform: uppercase;
}
.footer-top a {
  display: block;
}
.footer-top:before {
  content: "";
  width: 680px;
  height: 680px;
  margin: -340px;
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 1;
  background-color: #f50;
  border-radius: 340px;
}
/* usw. */

/* Footer-"Bottom" Zeile */
.footer-bottom {
  position: relative; /* oder: ... */
  z-index: 1;
  line-height: 1.5;
}
.footer-bottom a {
  display: block;
}
.footer-bottom .bottom-menu ul {
  padding: 8px 0;
}
.footer-bottom .bottom-menu ul li {
  display: inline-block;
  vertical-align: top;
  margin-right: 24px;
}
.footer-bottom .bottom-menu ul li a {
  color: #666;
  /* Bei Hover evtl. */
  transition: color .25s;
}
.footer-bottom .bottom-menu ul li[class*="current"] a,
.footer-bottom .bottom-menu ul li a:active,
.not-touch .footer-bottom .bottom-menu ul li a:hover {
  color: #f50;
  text-decoration: none;
}

/* Standard-Link-Styling */
.footer-bottom .bottom-menu ul li a {
  color: #666;
  text-decoration: none;
  transition: color 0.3s ease, text-decoration 0.3s ease;
}

/* Hover-Effekt */
.footer-bottom .bottom-menu ul li a:hover {
  color: #f50;

}

/* “Scroll hoch”-Button, z.B. .bottom-scroll a */
.bottom-scroll a {
  opacity: .5;
  transition: opacity .25s;
}
.bottom-scroll a:active,
.not-touch .bottom-scroll a:hover {
  opacity: 1;
}
.bottom-scroll a .scroll-circle {
  display: block;
  width: 40px;
  height: 40px;
}
/* usw. */

.header-nav .nav-col > ul > li > a {
  padding-right: 30px !important;
}

.g-spacing-big {
  padding-top: 40px !important;
  padding-bottom: 30px !important;
}

.cover-container {
  position: relative;
  overflow: hidden;
}

.cover-container img {
  display: block;
  width: 100%;
  transition: transform 0.3s ease-in-out;
}

.cover-container:hover img {
  transform: scale(1.1);
}

/* Optional: Einblendung von Text oder Overlay */
.cover-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  opacity: 0;
  transition: opacity 0.3s ease-in-out;
}

.cover-container:hover .cover-overlay {
  opacity: 1;
}

.btn-solid {
  transition: background-color 0.3s ease, color 0.3s ease;
}

.btn-solid:hover {
  background-color: #fff;
  color: #f50;
}

.nav-item {
  position: relative;
}

.nav-item ul {
  position: absolute;
  top: 100%;
  left: 0;
  background: white;
  list-style: none;
  padding: 0;
  margin: 0;
  display: none;
}

.nav-item:hover ul,
.nav-item:focus-within ul {
  display: block;
}

.loginbox {
    padding: 30px;
    width: 350px;
    background-color: #fff;
    border-radius: 5px;
    box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.1);
}

.loginbox h2 {
    text-align: center;
    color: #f50;
}

.form-main fieldset {
    margin-bottom: 15px;
    border: none;
}

.form-col {
    padding-top: 0px;
}

.form-main label {
    font-weight: bold;
    display: block;
    margin-bottom: 5px;
}

.form-main input {
    width: 100%;
    padding: 10px;
    border: 1px solid #ccc;
    border-radius: 3px;
}

.btn-solid {
    background-color: #f50; /* Orange */
    color: #fff; /* Weiß */
    padding: 14px 30px;
    font-size: 16px;
    font-weight: 700;
    text-transform: uppercase;
    border: none;
    cursor: pointer;
    display: inline-block;
    transition: background-color 0.3s ease, color 0.3s ease;
}

.btn-solid:hover {
    background-color: #d94800; /* Dunkleres Orange für Hover */
    color: #fff;
}

.btn-solid:focus {
    outline: none;
    box-shadow: 0 0 5px rgba(245, 80, 0, 0.5);
}

/* Anpassungen für die Registrierungsbox */
.starttext {
    text-align: center;
}

.btn-startscreen {
    display: inline-block;
    margin-top: 20px;
    padding: 15px 30px;
    font-size: 18px;
    font-weight: bold;
    border: 2px solid #f50;
    background-color: transparent;
    color: #f50;
    text-transform: uppercase;
    transition: background 0.3s, color 0.3s;
}

.btn-startscreen:hover {

    color: #fff;
}

form a {
    color: #f50; /* Gleiche Farbe wie andere Links */
    text-decoration: none;
    font-weight: 700;
}

form a:hover {
    text-decoration: underline;
}

/* Entfernt Standard-Button-Styling */
.input-context-button {
    background: none;
    border: none;
    cursor: pointer;
    position: absolute;
    right: 0px;
    top: 66%;
    transform: translateY(-50%);
    width: 24px;
    height: 16px;
    padding: 0;
}

/* Standard-Icon (geschlossen) */
.input-context-button img {
    width: 24px;
    height: 16px;
    display: block;
}

/* Optional: Hover-Effekt */
.input-context-button:hover {
    opacity: 0.8;
}

/* ============ MEDIA QUERIES ============ */

/* <= 1280px */
@media only screen and (max-width: 1280px) {
  .header-top .top-col {
    height: 60px;
    padding-top: 18px;
    padding-bottom: 18px;
  }
  .header-top .top-left {
    padding-right: 80px;
  }
  .header-top .top-right {
    padding-left: 80px;
  }
  .header-nav .nav-col {
    height: 60px;
    padding-top: 18px;
    padding-bottom: 18px;
  }
  .header-nav .nav-left {
    padding-right: 80px;
  }
  .header-nav .nav-right {
    padding-left: 80px;
  }
  .main-hero {
    padding-top: 120px;
  }
  .main-hero-full {
    padding-top: 0;
  }
}

/* <= 1080px */
@media only screen and (max-width: 1080px) {
  .main-hero {
    padding-top: 120px;
  }
  .main-section .section-images .images-big .big-caption {
    padding: 20px !important;
  }
  .main-section .section-teaser .teaser-item-half .item-content {
    padding: 20px !important;
  }
  .main-section .section-form .form-main {
    padding: 20px !important;
  }
  .navigation-menu {
    padding: 160px 40px 40px;
  }
  .navigation-menu a,
  .navigation-menu span {
    padding: 4px 0;
  }
}

/* <= 960px */
@media only screen and (max-width: 960px) {
  .main-section .section-timeline .timeline-event .entry-image {
    margin: 0 0 24px;
    padding-right: 20px;
  }
  .main-section .section-timeline .timeline-event-reversed .entry-image {
    padding-left: 20px;
  }
  .main-section .section-timeline .timeline-event .entry-content {
    padding-left: 20px;
  }
  .main-section .section-timeline .timeline-event-reversed .entry-content {
    padding-right: 20px;
  }
  .main-section .section-articles .articles-row,
  .main-section .section-articles .articles-container {
    padding: 0;
  }
  .main-section .section-articles .articles-container .container-body .body-entry .entry-title a {
    padding-right: 40px;
  }
  .main-section .section-delivery .delivery-map {
    margin-bottom: 40px;
  }
}

/* <= 640px */
@media only screen and (max-width: 640px) {
  .g-spacing-big {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .main {
    margin-bottom: 200px;
  }
  .main-section .section-images {
    margin: 60px 0;
  }
  .main-section .section-images:first-child {
    margin-top: 0;
  }
  .main-section .section-images:last-child {
    margin-bottom: 40px;
  }
  .main-section .section-teaser .teaser-item-full .item-content {
    padding: 40px;
  }
  .main-section .section-articles .articles-container .container-body .body-entry .entry-title a {
    padding-left: 100px;
  }
  .main-section .section-articles .articles-container .container-body .body-entry-image .entry-title a {
    padding-left: 20px;
  }
}

/* <= 480px */
@media only screen and (max-width: 480px) {
  .btn-solid {
    padding: 18px 50px 18px 20px;
  }
  .btn-ghost {
    padding: 16px 48px 16px 18px;
  }
  .aligncenter {
    max-width: 100%;
  }
  .alignright,
  .alignleft {
    max-width: 100%;
    margin-top: 0;
    margin-right: auto;
    margin-left: auto;
    float: none;
  }
  .g-spacing-big {
    padding-top: 40px;
    padding-bottom: 40px;
  }
  .g-spacing-regular {
    padding-top: 20px;
    padding-bottom: 20px;
  }
  .g-margin-big {
    margin-bottom: 40px;
  }
  .g-margin-regular {
    margin-bottom: 20px;
  }
  .main-section .section-images .images-big .big-caption {
    padding: 20px;
  }
  .main-section .section-teaser .teaser-item .item-container {
    padding-bottom: 0;
  }
  .main-section .section-teaser .teaser-item .item-content {
    padding: 40px 20px;
  }
  .main-section .section-card .card-item .item-content {
    padding: 20px;
  }
  .main-section .section-timeline .timeline-event .entry-image {
    padding: 0;
  }
  .main-section .section-timeline .timeline-event .entry-content {
    padding: 0;
  }
  .main-section .section-team .team-container .container-head .head-title .title-headline a {
    padding-left: 20px;
  }
  .main-section .section-team .team-container .container-body .body-item {
    padding-left: 0;
  }
  .main-section .section-team .team-container .container-body .body-item .item-profile {
    position: static;
  }
  .main-section .section-team .team-container .container-body .body-item .item-data {
    padding: 0;
  }
  .main-section .section-articles .articles-container .container-filter {
    margin-right: 20px;
    margin-left: 20px;
  }
  .main-section .section-articles .articles-container .container-body {
    margin-top: -40px;
    padding: 40px 20px 20px;
  }
  .main-section .section-articles .articles-container .container-body .body-entry {
    height: auto;
  }
  .main-section .section-articles .articles-container .container-body .body-entry .entry-meta {
    padding: 8px 20px;
  }
  .main-section .section-articles .articles-container .container-body .body-entry .entry-meta .meta-month,
  .main-section .section-articles .articles-container .container-body .body-entry .entry-meta .meta-type {
    margin: 0 8px 0 0;
  }
  .main-section .section-articles .articles-container .container-body .body-entry .entry-title a {
    padding: 16px 40px 16px 20px;
  }
  .main-section .section-icons .icons-container {
    padding: 0 20px;
  }
  .main-section .section-form .form-main {
    padding: 20px;
  }
  .navigation-menu {
    padding: 120px 20px 40px;
  }
  .row-spacing .col {
    padding: 0;
    margin-left: -5px;
  }
  .row-spacing .col-right {
    margin-left: auto;
  }
  .main {
    margin-bottom: 200px;
  }
  .loginbox {
    width: 300px;
  }
  .starttext {
    vertical-align: text-bottom;
    padding-top: 0;
    margin-left: 15px !important;
    width: 300px !important;
    max-width: 300px !important;
  }
}

/* [MAIN: SECTION - ICONS] */

.main-section .section-icons .icons-container {
    margin-bottom: -20px;
    padding: 0 40px;
    text-align: center;
}

.main-section .section-icons .icons-item {
    display: inline-block;
    vertical-align: top;
    margin-right: 20px;
    margin-left: 20px;
    font-family: "Montserrat", Helvetica, Arial, sans-serif;
    line-height: 1.5;
    font-weight: 700;
    text-transform: uppercase;
    text-align: left;
}

.main-section .section-icons .icons-item .item-icon,
.main-section .section-icons .icons-item .item-content {
    display: inline-block;
    vertical-align: middle;
}

.main-section .section-icons .icons-item .item-icon {
    width: 60px;
    height: 60px;
    margin: 0 8px 0 0;
    -webkit-border-radius: 30px;
    -moz-border-radius: 30px;
    -ms-border-radius: 30px;
    -o-border-radius: 30px;
    border-radius: 30px;
}

.main-section .section-icons .icons-item .item-icon img {
    display: block;
    width: 60px;
    height: 60px;
    padding: 14px;
}

.main-section .section-icons .icons-item .item-content span {
    display: block;
    white-space: nowrap;
}

.main-section .section-icons .icons-item .item-content .content-label {
    color: #ff5500;
    font-size: 12px;
}

.main-section .section-icons .icons-item .item-content .content-data {
    color: #1a1a1a;
    font-size: 16px;
}

.g-type-white .main-section .section-icons .icons-item .item-content .content-data {
    color: #fff;
}

.not-touch .main-section .section-icons .icons-item .item-content a.content-data {
    -webkit-transition: color 0.25s;
    -moz-transition: color 0.25s;
    -ms-transition: color 0.25s;
    -o-transition: color 0.25s;
    transition: color 0.25s;
}

.main-section .section-icons .icons-item .item-content a.content-data:active,
.not-touch .main-section .section-icons .icons-item .item-content a.content-data:hover {
    color: #ff5500;
    text-decoration: none;
}

/* [MAIN: SECTION - DELIVERY] */

.main-section .section-delivery .delivery-row {
    display: table;
    width: 100%;
    direction: rtl;
    text-align: left;
}

.main-section .section-delivery .delivery-half {
    display: table-cell;
    vertical-align: middle;
    width: 50%;
    max-width: none;
    direction: ltr;
}

.not-flexbox .main-section .section-delivery .delivery-half {
    float: none;
}

.main-section .section-delivery .delivery-map img {
    display: block;
    width: 100%;
    max-width: none;
    margin: 0;
}

.main-section .section-delivery .delivery-content .content-item {
    padding-left: 80px;
}

.main-section .section-delivery .delivery-content .content-item:last-child {
    margin-bottom: 0;
}

.main-section .section-delivery .delivery-content .content-item .item-entry {
    max-width: 480px;
    margin-left: -80px;
    line-height: 1.5;
}

.main-section .section-delivery .delivery-content .content-item .item-entry:last-child {
    margin-bottom: 0;
}

.main-section .section-delivery .delivery-content .content-item .item-entry .entry-icon,
.main-section .section-delivery .delivery-content .content-item .item-entry span {
    display: inline-block;
    vertical-align: middle;
}

.main-section .section-delivery .delivery-content .content-item .item-entry .entry-icon {
    width: 60px;
    height: 60px;
    margin: 0 16px 0 0;
    -webkit-border-radius: 30px;
    -moz-border-radius: 30px;
    -ms-border-radius: 30px;
    -o-border-radius: 30px;
    border-radius: 30px;
}

.main-section .section-delivery .delivery-content .content-item .item-entry .entry-icon img {
    display: block;
    width: 60px;
    height: 60px;
    padding: 14px;
}

.main-section .section-delivery .delivery-content .content-item .item-entry span {
    width: 75%;
    width: calc(100% - 80px);
}