﻿@font-face {
  font-family: "BMW Motorrad";
  font-weight: normal;
  font-style: normal;
  src: url("https://bmw-toronto-public.s3.amazonaws.com/motorrad/static/fonts/BMWMotorrad/BMWMotorrad-Regular.ttf") format("truetype");
}
@font-face {
  font-family: "BMW Motorrad";
  font-weight: 300;
  font-style: normal;
  src: url("https://bmw-toronto-public.s3.amazonaws.com/motorrad/static/fonts/BMWMotorrad/BMWMotorrad-Italic.ttf") format("truetype");
}
@font-face {
  font-family: "BMW Motorrad";
  font-weight: bold;
  font-style: normal;
  src: url("https://bmw-toronto-public.s3.amazonaws.com/motorrad/static/fonts/BMWMotorrad/BMWMotorrad-Bold.ttf") format("truetype");
}
@font-face {
  font-family: "BMW Motorrad";
  font-weight: bold;
  font-style: italic;
  src: url("https://bmw-toronto-public.s3.amazonaws.com/motorrad/static/fonts/BMWMotorrad/BMWMotorrad-BoldItalic.ttf") format("truetype");
}
@font-face {
  font-family: "BMW Motorrad";
  font-weight: 900;
  font-style: normal;
  src: url("https://bmw-toronto-public.s3.amazonaws.com/motorrad/static/fonts/BMWMotorrad/BMWMotorrad-Heavy.ttf") format("truetype");
}
@font-face {
  font-family: "BMW Motorrad";
  font-weight: 900;
  font-style: italic;
  src: url("https://bmw-toronto-public.s3.amazonaws.com/motorrad/static/fonts/BMWMotorrad/BMWMotorrad-HeavyItalic.ttf") format("truetype");
}
@font-face {
  font-family: "BMW Motorrad Outline";
  font-weight: normal;
  font-style: normal;
  src: url("https://bmw-toronto-public.s3.amazonaws.com/motorrad/static/fonts/BMWMotorrad/BMWMotorradOutline-Regular.ttf") format("truetype");
}
html {
  position: relative;
  min-height: 100%;
  font-size: 14px;
}
@media (min-width: 768px) {
  html {
    font-size: 16px;
  }
}

body {
  margin-bottom: 60px;
  font-family: "BMW Motorrad";
  background: black;
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder {
  color: var(--bs-secondary-color);
  text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder {
  text-align: start;
}

.header {
  background: black;
  padding-block: 25px;
  padding-inline: 140px;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
}
@media (max-width: 768px) {
  .header {
    flex-direction: column;
    justify-content: center;
    padding-inline: 20px;
    align-content: center;
    align-items: center;
    gap: 20px;
  }
}
.header .logo-container {
  display: flex;
  flex-direction: row;
  gap: 30px;
  text-decoration: none;
}
@media (max-width: 768px) {
  .header .logo-container {
    flex-direction: column;
    justify-content: center;
    align-content: center;
    align-items: center;
    gap: 20px;
  }
}
.header .logo-container .logo {
  height: 50px;
}
.header .logo-container .vertical-divider {
  width: 1px;
  height: 100%;
  background: white;
}
@media (max-width: 768px) {
  .header .logo-container .vertical-divider {
    width: 100%;
    height: 1px;
  }
}
.header .logo-container .retailer-info {
  color: white;
}
.header .logo-container .retailer-info .retailer-name {
  font-weight: 900;
  font-style: normal;
  font-size: 22px;
}
.header .logo-container .retailer-info .retailer-address {
  font-weight: normal;
  font-style: normal;
  font-size: 14px;
}
.header .cta-container {
  display: flex;
  flex-direction: row;
  gap: 10px;
  text-decoration: none;
  margin-block: auto;
}
@media (max-width: 768px) {
  .header .cta-container {
    gap: 30px;
  }
}
.header .cta-container .cta-icon {
  height: 20px;
}

.footer {
  background: #F2F2F2;
}
.footer .container {
  color: black;
}

.hero-container {
  width: 100%;
  position: relative;
  min-height: calc(100vh - 100px);
}
@media (max-width: 768px) {
  .hero-container {
    min-height: fit-content;
  }
}
.hero-container::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, black 0%, transparent 60%, transparent 100%);
  z-index: 2;
}
.hero-container .hero-img {
  position: relative;
  width: 100%;
  height: 100%;
}
.hero-container .hero-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.hero-container .content-container {
  z-index: 10;
  position: absolute;
  bottom: 60px;
  padding-inline: 140px;
  display: flex;
  flex-direction: column;
}
@media (max-width: 768px) {
  .hero-container .content-container {
    text-align: center;
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
}
.hero-container .content-container .headline {
  color: white;
  font-size: 60px;
  line-height: 60px;
  font-weight: 900;
}
@media (max-width: 768px) {
  .hero-container .content-container .headline {
    font-size: 40px;
    line-height: 40px;
  }
}
.hero-container .content-container .h-outline {
  font-family: "BMW Motorrad Outline";
  font-weight: 100;
}
.hero-container .content-container .subheadline {
  color: white;
  font-size: 30px;
  font-weight: 900;
}
@media (max-width: 768px) {
  .hero-container .content-container .subheadline {
    font-size: 20px;
  }
}
.hero-container .content-container .main-cta {
  width: 270px;
  height: 50px;
  background: white;
  display: flex;
  justify-content: center;
  align-items: center;
  align-content: center;
  color: black;
  font-weight: 900;
  text-decoration: none;
}

.two-column {
  padding-block: 40px;
  padding-inline: 140px;
  display: flex;
  flex-direction: row;
  position: relative;
}
@media (max-width: 768px) {
  .two-column {
    flex-direction: column;
    padding-inline: 20px;
    gap: 40px;
  }
}
.two-column .column {
  width: 50%;
  margin-block: auto;
}
@media (max-width: 768px) {
  .two-column .column {
    width: 100%;
  }
}
.two-column .column .map-img {
  width: 100%;
}
@media (max-width: 768px) {
  .two-column .column .map-img {
    aspect-ratio: 1/1;
  }
}
.two-column .column .map-img img {
  width: 100%;
}
@media (max-width: 768px) {
  .two-column .column .map-img img {
    aspect-ratio: 1/1;
    object-fit: cover;
  }
}
.two-column .column .retailer-name, .two-column .column .retailer-info, .two-column .column .info-container {
  padding-left: 80px;
}
@media (max-width: 768px) {
  .two-column .column .retailer-name, .two-column .column .retailer-info, .two-column .column .info-container {
    padding-left: unset;
  }
}
.two-column .column .retailer-name {
  color: white;
  font-weight: 900;
  font-size: 40px;
  line-height: 40px;
  margin-bottom: 40px;
}
@media (max-width: 768px) {
  .two-column .column .retailer-name {
    font-size: 30px;
  }
}
.two-column .column .info-container {
  display: flex;
  flex-direction: column;
  gap: 26px;
}
.two-column .column .info-container .info-item {
  display: flex;
  flex-direction: row;
  gap: 30px;
}
.two-column .column .info-container .info-item .info-icon {
  height: 30px;
}
.two-column .column .info-container .info-item .info-icon img {
  height: 30px;
}
.two-column .column .info-container .info-item .info-link {
  text-decoration: none;
  color: white;
  font-size: 22px;
  margin-block: auto;
}
@media (max-width: 768px) {
  .two-column .column .info-container .info-item .info-link {
    font-size: 18px;
  }
}

.template-map-cta-banner {
  background: #212121;
  width: 100vw;
  padding: 40px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  color: white;
  gap: 16px;
}
.template-map-cta-banner .address-row {
  display: flex;
  flex-direction: row;
  gap: 16px;
  width: 30%;
}
@media (max-width: 768px) {
  .template-map-cta-banner .address-row {
    width: 100%;
    flex-direction: column;
  }
}
.template-map-cta-banner .address-row input {
  height: 50px;
  background: transparent;
  outline: none;
  border: 1px solid #e2e2e2;
  box-shadow: none;
  width: 100%;
  color: white;
  padding-inline: 20px;
  font-size: 16px;
  min-width: 270px;
}
.template-map-cta-banner .address-row input::placeholder {
  color: #cdcdcd;
}
.template-map-cta-banner .address-row button {
  padding-inline: 40px;
}

.btn {
  height: 50px;
  background: white;
  display: flex;
  justify-content: center;
  align-items: center;
  align-content: center;
  color: black;
  font-weight: 900;
  text-decoration: none;
  border-radius: unset;
  text-transform: uppercase;
}
.btn:hover {
  background: white;
  color: darkgrey;
}
