








  footer.main {
    --offset-left: calc(624 * var(--px));
  }
  
  footer.main > .inner {
    position: relative;
  }
  
  
  
  
  
  

  footer.main .row--address {
    background: var(--base-color-light-gray);
    --padding-y: max(32px, calc(57 * var(--px)));
    padding: var(--padding-y) calc(122 * var(--px));
    padding-left: var(--offset-left);
  }
  
  body.view-b2b footer.main .row--address {
    background: var(--base-color-off-black);
  }

  footer.main .row--address .headline {
    text-transform: uppercase;
    margin-bottom: max(12px, .41666666666666666666em);
  }
  
  .hours-and-address {
    display: flex;
    flex-flow: row nowrap;
    gap: calc(52 * var(--px));
  }
  
  .hours-list > li {
    display: flex;
    flex-flow: row nowrap;
  }

  .hours-list .label {
    display: block;
    min-width: 4.31818181818181818181em;
  }
  
  
  @media (max-width: 850px) {
    
    footer.main .row--address {
      padding-left: var(--page-padding-left);
      padding-right: var(--page-padding-left);
    }
    
  }
  
  @media (max-width: 700px) {
    
    .hours-and-address {
      flex-flow: column nowrap;
      gap: 12px;
    }
    
  }
  
  
  






  .footer-bike {
    position: absolute;
    top: 0;
    left: var(--page-padding-left-l);
    width: calc(var(--offset-left) * 0.717);
    pointer-events: none;
    z-index: 2;
  }
  
  @media (max-width: 850px) {
    
    .footer-bike {
      left: auto;
      right: var(--page-padding-right);
    }
    
  }  
  
  @media (max-width: 700px) {
    
    .footer-bike {
      position: relative;
      top: auto;
      left: auto;
      right: auto;
      bottom: auto;
      width: 100%;
    }
    
    .footer-bike img {
      position: absolute;
      display: block;
      right: var(--page-padding-right);
      width: max(200px, 40vw);
      top: 0;
      transform: translateY(-60%);
    }
    
  }
  










  footer.main .row--teaser {
    background: var(--base-color-black);
    color: var(--base-color-white);
    --padding-y: calc(76 * var(--px));
    padding: var(--padding-y) var(--page-padding-left-l);
    padding-left: var(--offset-left);
  }
  
  .footer-teaser {
    max-width: max(454px, calc(560 * var(--px)));
  }
  
  .footer-teaser .headline {
    margin-bottom: .66666666666666666666em;
    color: var(--base-color-green);
    text-transform: uppercase;
  }
  
  body.view-b2b .footer-teaser .headline {
    color: var(--base-color-purple);
  }
  
  .footer-teaser .btn-set {
    margin-top: max(24px, calc(24 * var(--px)));
  }
  
  
  @media (max-width: 850px) {
    
    footer.main .row--teaser {
      padding-left: var(--page-padding-left);
      padding-right: var(--page-padding-left);
    }
    
  }
  
  @media (max-width: 700px) {
    
    footer.main .row--teaser {
      padding-top: 70px;
      padding-bottom: 48px;
    }
    
  }









  footer.main .row--sitemap {
    background: var(--base-color-black);
    color: var(--base-color-white);
    --padding-y: max(48px, calc(64 * var(--px)));
    padding: var(--padding-y) var(--page-padding-left-l);
    padding-right: 0;
    position: relative;
    display: flex;
    flex-flow: row nowrap;
    justify-content: space-between;
  }
  
  footer.main .row--sitemap::before {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: var(--page-padding-left-l);
    right: var(--page-padding-left-l);
    height: 1px;
    background: #4e4e4e;
  }
  
  footer.main .footer-logo img {
    width: max(170px, calc(210 * var(--px)));
  }

  nav.footer .menu {
    display: flex;
    flex-flow: row nowrap;
    text-transform: uppercase;
    justify-content: space-between;
  }
  
  nav.footer .menu > li + li {
    margin-left: calc(120 * var(--px));
  }
  
  nav.footer .menu > li > span {
    display: block;
    font-size: 1.41176470588235294117em;
    font-family: var(--base-font-1-demi);
    color: #4e4e4e;
    margin-bottom: max(16px, calc(32 * var(--px)));
  }
  
  nav.footer .sub-menu > li + li {
    margin-top: 1.2em;
  }
  
  nav.footer .sub-menu a {
    transition: color 250ms;
  }

  nav.footer .sub-menu > li.current-menu-any a {
    text-decoration: underline;
    text-decoration-thickness: 2px;
    text-underline-offset: 3px;
    color: var(--base-color-yellow);
  }
  
  @media (hover: hover) {
    nav.footer .sub-menu a:is(:hover, :focus) {
      color: var(--base-color-yellow);
    }
  }
  
  
  @media (max-width: 700px) {
    
    nav.footer {
      width: 100%;
    }
    
    nav.footer .menu {
      flex-flow: row wrap;
    }
    
    nav.footer .menu > li {
      width: 50%;
    }
    
    nav.footer .menu > li + li {
      margin-left: 0;
    }
    
    nav.footer .menu > li:nth-child(3) {
      margin-top: 48px;
    }
    
    .footer-logo {
      flex-shrink: 0;
    }
    
  }
  
  
  @media (max-width: 550px) {
    
    footer.main .row--sitemap {
      flex-flow: column nowrap;
      position: relative;
      padding-bottom: 100px;
    }
    
    footer.main .row--sitemap::before {
      left: 0;
      right: 0;
    }
    
    .footer-logo {
      position: absolute;
      right: 0;
      bottom: 40px;
    }
    
    footer.main .footer-logo img {
      width: 120px;
    }
    
    nav.footer .sub-menu > li + li {
      margin-top: 1em;
    }
    
    nav.footer .cpy-17 {
      font-size: 16px;
    }
    
    nav.footer .menu > li > span {
      font-size: 20px;
    }
    
  }  
  
  
  
  
  









  footer.main .row--legal {
    background: var(--base-color-yellow);
    padding: 12px var(--page-padding-left);
    display: flex;
    flex-flow: row nowrap;
  }
  
  body.view-b2b footer.main .row--legal {
    color: var(--base-color-black);
    background: var(--base-color-green);
  }
  
  footer.main .row--legal .col-1 {
    display: flex;
    flex-flow: row nowrap;
  }
  
  nav.legal {
    margin-left: var(--page-padding-left);
  }
  
  nav.legal .menu {
    display: flex;
    flex-flow: row nowrap;
  }
  
  nav.legal .menu > li:not(:last-child)::after {
    content: '·';
    display: inline-block;
    padding: 0 0.5em;
  }
  
  footer.main .row--legal .col-2 {
    margin-left: auto;
  }
  
  
  @media (max-width: 600px) {
    
    footer.main .row--legal {
      padding-top: 26px;
      padding-bottom: 34px;
      align-items: flex-start;
    }
    
    footer.main .row--legal .col-1 {
      flex-flow: column-reverse nowrap;
    }
    
    nav.legal {
      margin-left: 0;
      margin-bottom: 12px;
    }
    
    footer.main .row--legal .cpy-18 {
      font-size: 16px;
    }
    
  }
  
  
  @media (max-width: 500px) {
    
    nav.legal .menu {
      display: block;
    }
    
    nav.legal .menu > li:not(:last-child)::after {
      display: none;
    }
    
  }