:root {
  --cyan: #65BED1;
  --cyan-dark: #3C5976;
  --cyan-op31: #cfebf1;
  --green: #A7C74E;
  --green-dark: #4E7564;
  --green-op31: #e4eec8;
  --yellow: #F3C62F;
  --yellow-dark: #DE9400;
  --yellow-op31: #fbedbe;
  --beige: #EEECDF;
  --beige-medium: #d3d0c3;
  /*--beige-dark: #BCBDB0;*/
  --beige-mediumdark: #BCBDB0;
  --beige-dark: #928D68; /* 2022-07-04 */
  --beige-darker-1: #8F8C76;
  --beige-darker: #706d48;
  --beige-op31: #faf9f5;
  --red: #DF7215;
  --red-dark: #AC2104;

  --gray: #BCBDB0;


  /*--primary: var(--beige);
  --primary-dark: var(--beige-dark); (2022-07-04) */
  --primary: var(--beige-medium);
  --primary-dark: var(--beige-dark);
  --primary-op31: var(--beige-op31);

  --section-padding: 3rem;

  accent-color: var(--primary);
  font-size:16px;
}
[data-colorscheme=beige] {
  --primary: var(--beige);
  --primary-dark: var(--beige-dark);
  --primary-op31: var(--beige-op31);
}
.tc-27 /* Wohnungswirtschaft */,
.tc-82 /* Stadtmoebel */,
[data-colorscheme=yellow] {
  --primary: var(--yellow);
  --primary-dark: var(--yellow-dark);
  --primary-op31: var(--yellow-op31);
}
[data-colorscheme=yellow-dark] {
  --primary: var(--yellow-dark);
  --primary-dark: var(--yellow);
  --primary-op31: var(--yellow-op31);
}
.tc-43,
.tc-68,
[data-colorscheme=green] {
  --primary: var(--green);
  --primary-dark: var(--green-dark);
  --primary-op31: var(--green-op31);
}
.tc-49,
.tc-90, .tc-89,
[data-colorscheme=cyan] {
  --primary: var(--cyan);
  --primary-dark: var(--cyan-dark);
  --primary-op31: var(--cyan-op31);
}
.tc-71,
[data-colorscheme=red] {
  --primary: var(--red-dark);
  --primary-dark: var(--red);
  /* --primary-op31: var(--red-op31); */
}
@media only screen and (min-width : 1200px) {
  :root {
    font-size:20px;
  }
}
@media only screen and (min-width : 1400px) {
  :root {
    font-size:24px;
  }
}
body {
  margin:0;
  padding:0;
  background:#fff;
  overflow-x: hidden;
  max-width: 100vw;
}
body,table,input,textarea,button,select {
  font-family:'Trenda',arial,sans-serif;
  font-weight: 400;
  font-size:1rem;
  line-height:1.6;
  color:#222;
}
h1,h2,h3,h4,h5,h6,p,ol,ul,dl,table,form,fieldset,object {
  margin:0 0 1.3rem 0;
}

article,aside,details,figcaption,figure,footer,header,hgroup,main,nav,section,summary {
  display: block;
}

h1,.h1 {
  font-size: clamp( 1.5rem, 0.6111111111111112rem + 1.8518518518518516vw, 2rem );
  line-height:1.35;
  line-height:1.1;
  font-weight:800;
  text-transform:uppercase;
}
h2,.h2 {
  font-size:1rem;
  line-height:1.35;
  font-weight:600;
  margin-bottom: 0;
  text-transform: uppercase;
}
h3,.h3 {
  font-size:1rem;
  line-height:1.35;
  font-weight:800;
  margin-bottom:0;
}
h4,.h4,
h5,.h5,
h6,.h6 {
  font-size:1rem;
  line-height:1.35;
  font-weight:800;
  margin:0;
}
a {
  text-decoration: underline;
  color:#000;
  transition: color .2s ease;
}
:visited {
  color:#000;
}
a:hover {
  text-decoration:underline;
  color:var(--primary-dark);
}

strong {
  font-weight: 600;
}

img {
  border:0;
  max-width:100%;
  height:auto;
}

table {
  border-spacing:1px;
}
table th,
table td {
  padding:.3em 1em .3em .3em;
  text-align:left;
  vertical-align:top;
  background:#fff;
}
table th {
  font-weight:600;
  vertical-align:bottom;
  background:#f5f4f2;
}

main ul {
  padding: 0;
}
main ul li {
  padding-left: 1.25rem;
  position: relative;
  list-style: none;
}
main ul li::before {
  content:'';
  display:block;
  position: absolute;
  left:0;
  top:.375em;
  width:.5rem;
  height: .6818em;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewbow='0 0 11 15' width='11' height='15'%3E%3Cpath d='M 0,0 11,7.5 0,15' /%3E%3C/svg%3E");
}

.nowrap {
  white-space: nowrap;
}
.sep {
  margin-left:1.5rem;
  margin-right:1.5rem;
}

/* Grid
********************************/
.container {
  padding-left: clamp(1rem, 8%, 2rem);
  padding-right: clamp(1rem, 8%, 2rem);
}
.container-wider {
  max-width: calc(100% - 4rem)
}
.row {
  --bs-gutter-x: 8%;
  --bs-gutter-x: 5%;
}
@media only screen and (min-width : 1800px) {
  .container-wide {
    max-width: 1740px;
  }
}

/* Seitenelemente (Master)
********************************/
.site-header {
  background-size:auto 100%;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  /*height:100vh;*/
  position: relative;
  overflow:hidden;
}
.site-header-city {
  position: relative;
  height: 43.5417vw;
  background-size:100% auto;
  background-position: 50% 50%;
  background-repeat: no-repeat;
}
.site-header-garage {
  position: absolute;
  left: 41.1458vw;
  top: 25.3125vw;
  width:43.2812vw;
}
.site-header-garage--bikeride {
  left: 35.7292vw;
  top: 17.34375vw;
  width:46.7vw;
}
.site-header-garage img {
  display:block;
  width:100%;
  height:auto;
  max-width: none;
}
.site-header-controls {
  padding-top:1.25rem;
}
.site-header-controls .container {
  display:flex;
  justify-content: flex-end;
  align-items: center;
}

.site-nv-toggle {
  --nv-toggle-size: 4.625rem;
  margin-left:2.25rem;
  padding:0;
  border:0;
  background:transparent;
  width:var(--nv-toggle-size);
  height:var(--nv-toggle-size);
  min-width:var(--nv-toggle-size);
  min-height:var(--nv-toggle-size);
  border-radius:100%;
  background:#000;
  transition: background-color .2s ease;
}
.site-nv-toggle:hover {
  background:var(--primary);
}
.site-nv-toggle svg {
  margin:0;
  display:block;
  width:100%;
  height:auto;
}
@media only screen and (max-width : 579px) {
  .site-nv-toggle {
    --nv-toggle-size: 3.5rem;
  }
}

.site-nv {
  position: fixed;
  left:0;
  top:0;
  right:0;
  bottom: 0;
  z-index:10;
  display: flex;
  justify-content: center;
  align-items: center;
  /*display:none;*/
  visibility: hidden;
  opacity: 0;
  transition: opacity .2s ease, visibility .2s ease;
}
.site-nv[aria-expanded=true] {
  display:flex;
  opacity: 1;
  visibility: visible;
}
.site-nv::before {
  content:'';
  display: block;
  position: absolute;
  left:0;
  top:0;
  right:0;
  bottom: 0;
  z-index:0;
  background:var(--primary);
  opacity: .85;
}
.site-nv-inner {
  position: relative;
  z-index: 2;
  padding:2rem;
  background:#000;
  color:#fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
}
.site-nv-close {
  width:2.083333rem;
  height:2.083333rem;
  margin:0;
  padding:.5rem;
  border: 0;
  border-radius:0;
  background:transparent;
}
.site-nv-close:hover {
  background:transparent;
}
.site-nv-close svg {
  display:block;
  margin: 0;
}
.site-nv ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
.site-nv li {
  margin: 0;
  padding: 0;
}
.site-nv li a {
  text-decoration: none;
}
.site-nv-main ul {
  margin-top:2rem;
  margin-bottom:2rem;
  line-height: 1.1;
  text-transform: uppercase;
}
.site-nv-main li {
  margin-top:1.5rem;
  margin-bottom:1.5rem;
}
.site-nv-main a {
  color:#fff;
  font-size:1.6666rem;
  font-weight: 400;
  text-decoration: none;
}
.site-nv-main ul ul {
  display: none;
}
.site-nv-meta a {
  color:#fff;
  font-size:1rem;
  text-transform: uppercase;
  font-weight: 400;
}

.site-nv-v2 .site-nv-main li {
  margin-block: .75rem;
}
.site-nv-v2 ul {
  margin-top: 0;
}
.site-nv-v2 ul ul {
  display: block;
  text-transform: none;
}
.site-nv-v2 ul ul li {
  margin: 0;
}

.site-header-headlines {
  margin-top: 2rem;
}
.site-header-headline-small {
  font-size:1.25rem;
  line-height:1.3;
  font-weight: 400;
  text-transform: uppercase;
}
.site-header-headline-big {
  font-size: 3.3333rem;
  font-size:2rem;
  line-height: 1.1;
  font-weight: 800;
  text-transform: uppercase;
}
.site-header-scroll {
  display: block;
  width:2rem;
  height:auto;
  position: absolute;
  bottom:0;
  left:calc(50% - 1rem);
}
@media only screen and (max-width : 767px) {
  .site-header-controls .container {
    width:100%;
    max-width: none;
  }
}
@media only screen and (min-width : 768px) {
  .site-header {
    background-size:100% auto;
    background-position: 50% 50%;
    /*height:56.25vw;*/
  }
  .site-header-garage {
    position: absolute;
    left: 41.1458vw;
    bottom: 0;
    width: 43.2812vw;
  }
  .site-header-garage img {
    width:100%;
    height:auto;
  }
  .site-nv-inner {
    width:37rem;
    height:37rem;
    border-radius:100%;
  }
}
@media only screen and (min-width : 992px) {
  .site-header-headline-small {
    font-size:1.25rem;
  }
  .site-header-headline-big {
    font-size:3rem;
    text-align: center;
  }
  .site-header-headline-big .container {
    width:100%;
    max-width: none;
  }
}

/* Laptop, low height */
@media only screen and (max-height : 600px) {
  .site-nv-inner {
    width: 28rem;
    height: 28rem;
  }
  .site-nv-main ul {
    margin-top: 1.5rem;
    margin-bottom: 1.5rem;
  }
  .site-nv-main li {
    margin-top: 1rem;
    margin-bottom: 1rem;
  }
  .site-nv-main a {
    font-size: 1.25rem;
  }
}

.site-footer {
  font-size: .8333rem;
}
.site-footer-main {
  background:var(--beige);
  padding-top:2.5rem;
  padding-bottom:2.5rem;
  position: relative;
}
.site-footer-eku img {
  display:block;
  width:7rem;
  height:auto;
}
.site-footer-main-grid {
  display: grid;
  row-gap: 2rem;
  column-gap:8%;
}
.site-footer-cta .btn {
  font-size:1.1666rem;
  border-radius:4.1499rem 0 0 4.1499rem;
  width:100%;
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
.site-footer-cta .btn:not(:last-child) {
  margin-bottom: 1rem;
}
/* .site-footer-cta .btn {
  background:var(--yellow);
}
.site-footer-cta .btn:hover {
  background:var(--yellow-dark);
} */

/* .tc-43 .site-footer-cta .btn {
  background:var(--green);
}
.tc-43 .site-footer-cta .btn:hover {
  background:var(--green-dark);
}

.tc-49 .site-footer-cta .btn {
  background:var(--cyan);
}
.tc-49 .site-footer-cta .btn:hover {
  background:var(--cyan-dark);
} */

.site-footer-cta .btn--contact svg {
  display:block;
  margin-right:1.5rem;
  width:2.7916rem;
  height:auto;
}
.site-footer-cta .btn--catalog svg {
  display:block;
  margin-right:1.5rem;
  width:2.0833rem;
  height:auto;
}
.site-footer-contact p {
  margin-bottom:.5rem;
  padding-bottom:.5rem;
  border-bottom: solid #000 1px;
}
.site-footer-contact a {
  color:#000;
  text-transform: uppercase;
  font-weight:800;
  text-decoration: none;
}
.site-footer-contact a {
  color:#000;
}
.site-footer-contact a:hover {
  text-decoration: underline;
}
.site-footer-social {
  padding-top:.5rem;
}
.site-footer-social a {
  display:inline-block;
  margin-right:1rem;
}
.site-footer-social svg {
  display:block;
  width:1.3333rem;
  height:1.3333rem;
}
.site-footer-social a path,
.site-footer-social a circle {
  transition: fill .2s ease;
}
.site-footer-social a:hover path,
.site-footer-social a:hover circle {
  fill:var(--primary-dark);
}
.site-footer-main .container {
  position: relative;
}

@media only screen and (min-width : 768px) {
  .site-footer-main-grid {
    row-gap:0;
    grid-template-areas: 'jiggy-header cta'
                         'jiggy-header-2 .'
                         'jiggy-content contact';
    grid-template-columns: 1fr 1fr;
  }
  .site-footer-main-grid > .jiggy {
    display:contents;
  }
  .site-footer-main-grid .jiggy-header {
    grid-area: jiggy-header;
    align-self: self-start;
    margin-bottom:3rem;
  }
  .site-footer-main-grid .jiggy-header-2 {
    grid-area: jiggy-header-2;
  }
  .site-footer-main-grid .jiggy-content {
    grid-area: jiggy-content;
  }
  .site-footer-main-grid .site-footer-cta {
    grid-area: cta;
    margin-bottom:3rem;
  }
  .site-footer-main-grid .site-footer-contact {
    grid-area: contact;
  }


  .site-footer-eku img {
    width:9.166rem;
  }
}
@media only screen and (min-width : 992px) {
  .site-footer-main-grid {
    /*column-gap: 4rem;*/
  }
  .site-footer-main {
    padding-bottom: 6.5rem;
  }
  .site-footer-eku {
    position: absolute;
    bottom:-6.5rem;
    transform: translate(0,50%);
  }
}

/* Info: Sitemap + Logos */
.site-footer-info {
  padding-top: 6.5rem;
  padding-bottom: var(--section-padding);
  background-color: var(--primary);
}
/* Start */
.tc-40 .site-footer-info {
  background-color: var(--yellow);
}
/* Bike+Ride */
.tc-71 .site-footer-info {
  background-color: var(--red);
}
/* Impressum, Datenschutz */
.tc-22 .site-footer-info,
.tc-25 .site-footer-info,
.tc-53 .site-footer-info,
.tc-63 .site-footer-info,
.tc-78 .site-footer-info {
  background-color: var(--beige-darker-1);
}
.site-footer-info .container {
  display: grid;
  gap: 1.5rem
}
@media only screen and (min-width : 768px) {
  .site-footer-info .container {
    /* grid-template-columns: repeat(3, 1fr); */
    grid-template-columns: 2fr 2fr 3fr;
  }
}
.site-footer-info ul {
  margin: 0;
  padding: 0 0 0 1rem;
  list-style: none;
  border-left: solid rgba(238,236,223,31) 2px;
}
.site-footer-info li {
  margin: 0;
  padding: 0;
}
.site-footer-info a {
  text-decoration: none;
  text-transform: uppercase;
  font-weight: 600;
}
.site-footer-info a path {
  transition: fill .2s ease;
}
.site-footer-info a:hover {
  color: #fff;
}
.site-footer-info a:hover path {
  fill: #fff;
}
.site-footer-info .imprint a,
.site-footer-info .terms a,
.site-footer-info .privacy a {
  text-decoration: none;
  text-transform: uppercase;
  font-weight: 400;
}
.site-footer-info .seals {
  display: flex;
  gap: 1.5rem;
}
.site-footer-info .seals img {
  display: block;
}
/* END: Info: Sitemap + Logos */

.site-footer-meta {
  padding-top:1rem;
  padding-bottom:5rem;
  text-align: center;
}
.site-footer-meta a {
  font-weight:600;
  color:#000;
  text-decoration: none;
}
.site-footer-meta a:hover {
  text-decoration: underline;
}

.site-footer-meta .cookie-settings:hover {
  text-decoration: none;
}
.site-footer-meta .cookie-settings svg {
  display: inline-block;
  width: .75rem;
  height:.75rem;
  vertical-align: baseline;
}

.site-footer-sponsored {
  text-align:center;
  font-weight:500;
  padding-bottom:3rem;
}

.site-top-link {
  display: block;
  width:4.625rem;
  height:4.625rem;
  position: absolute;
  bottom: 0;
  right:3rem;
}
.site-top-link svg {
  display: block;
  width:100%;
  height:auto;
}

.site-top-link--fixed {
  display: block;
  width:4.625rem;
  height:4.625rem;
  position: fixed;
  bottom: 1rem;
  right:1rem;
}
.site-top-link--fixed svg {
  display: block;
  width:100%;
  height:auto;
}