@charset "UTF-8";
/*==============================================================*/
/*     R E S E T     */
/*==============================================================*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, figure, figcaption, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-weight: inherit;
  font-style: inherit;
  font-size: 100%;
  font-family: inherit;
  vertical-align: baseline;
}

html, body {
  height: 100%;
}

abbr[title] {
  border-bottom: 1px dotted #888 !important;
  cursor: help;
}

*:focus {
  outline: 0;
}

ul {
  list-style-type: none;
}

/* Apply a natural box layout model to all elements */
*, *:before, *:after {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

/*==============================================================*/
/*     F O N T S     */
/*==============================================================*/
@font-face {
  font-family: "Komet";
  src: url(/fonts/Komet-Regular.woff2) format("woff2");
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: "Komet";
  src: url(/fonts/Komet-Medium.woff2) format("woff2");
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: "Komet";
  src: url(/fonts/Komet-Bold.woff2) format("woff2");
  font-weight: 700;
  font-style: normal;
}
#breakpoints:after {
  position: fixed;
  font-size: 10px;
  line-height: 12px;
  bottom: 0;
  left: 0;
  z-index: 10000;
  content: "0";
  color: black;
  background: white;
  font-weight: 700;
}
@media only screen and (min-width: 360px) {
  #breakpoints:after {
    content: "1";
  }
}
@media only screen and (min-width: 480px) {
  #breakpoints:after {
    content: "2";
  }
}
@media only screen and (min-width: 700px) {
  #breakpoints:after {
    content: "3";
  }
}
@media only screen and (min-width: 960px) {
  #breakpoints:after {
    content: "4";
  }
}
@media only screen and (min-width: 1200px) {
  #breakpoints:after {
    content: "5";
  }
}
@media only screen and (min-width: 1400px) {
  #breakpoints:after {
    content: "6";
  }
}
@media only screen and (min-width: 1800px) {
  #breakpoints:after {
    content: "7";
  }
}

.chars75 {
  color: #262626;
}

/*==================================================================================*/
/*==================================================================================*/
/*     T Y P E     */
/*==================================================================================*/
/*==================================================================================*/
html {
  font-size: 18px;
}
@media only screen and (min-width: 700px) {
  html {
    font-size: 19px;
  }
}
@media only screen and (min-width: 1400px) {
  html {
    font-size: 20px;
  }
}

body {
  font-family: Komet, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, sans-serif;
  line-height: 1.4rem;
  color: #262626;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
}

p + p {
  margin-top: 0.5rem;
}
p + .bullet-list {
  margin-top: 0.5rem;
}

h2, .h2 {
  font-size: 2rem;
  line-height: 1.2em;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: #8e2f45;
  margin-bottom: 1rem;
}

h3, .h3 {
  font-size: 1.1rem;
  font-weight: 500;
  letter-spacing: -0.005em;
  color: #002e5c;
  margin-bottom: 0.25rem;
}

strong {
  font-weight: 700;
}

.bullet-list li {
  position: relative;
  padding-left: 1rem;
}
.bullet-list li:before {
  content: "•";
  position: absolute;
  left: 0;
  color: #002e5c;
}
.bullet-list + p {
  margin-top: 0.5rem;
}

a {
  color: #002e5c;
  text-decoration: none;
}

section a {
  color: #003b75;
}

body.has-hover a:hover {
  color: #262626;
}

.content p {
  hyphens: auto;
}
.content h1 {
  font-size: 2rem;
  line-height: 1.25em;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: #8e2f45;
}
.content h1 + p {
  margin-top: 1rem;
}
.content h2 {
  font-size: 1.35rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: #002e5c;
  margin: 1rem 0 0.5rem 0;
}
@media only screen and (min-width: 1200px) {
  .content .container {
    width: 43rem;
  }
}
@media only screen and (min-width: 1400px) {
  .content .container {
    width: 45rem;
  }
}

::selection {
  background: #002e5c;
  color: white;
}

.icon {
  position: relative;
  padding-left: 1.4em;
}
.icon:before {
  font-family: "simple-line-icons";
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  position: absolute;
  left: 0;
  top: 0.1em;
}
.icon.icon-envelope::before {
  top: 0.2em;
}

/*==================================================================================*/
/*==================================================================================*/
/*     G R I D     */
/*==================================================================================*/
/*==================================================================================*/
main {
  flex-grow: 1;
}

.container {
  padding: 2rem 1.5rem;
  margin: 0 auto;
  max-width: 40rem;
}
@media only screen and (min-width: 480px) {
  .container {
    padding: 3rem 2rem;
  }
}
@media only screen and (min-width: 1200px) {
  .container {
    max-width: 84rem;
    padding: 4rem 4rem;
  }
}
@media only screen and (min-width: 1400px) {
  .container {
    padding: 5rem 5rem;
  }
}

header {
  text-align: center;
  top: 0;
  width: 100%;
  background: white;
  border-bottom: 1px solid #ebebeb;
}
header .container {
  padding-top: 0;
  padding-bottom: 0;
}
header .container .logo {
  display: block;
  margin: 2rem 0;
  transition: margin 500ms;
}
header .container .logo .logo-container {
  margin: 0 0 0.2rem 0;
}
header .container .logo .logo-container svg {
  width: 4rem;
  transition: width 500ms;
  display: block;
  margin: 0 auto;
}
header .container .logo .logo-container svg .logo-b1 {
  fill: #002e5c;
}
header .container .logo .logo-container svg .logo-b2 {
  fill: #8e2f45;
}
header .container .logo .logo-container svg .logo-section {
  fill: #cbdde6;
}
header .container .logo .logo-caption {
  display: block;
  font-size: 1.1rem;
  transition: font-size 500ms;
  font-weight: 500;
  letter-spacing: -0.01em;
}
header .container nav {
  margin-bottom: 1rem;
}
header .container nav ul {
  display: flex;
  justify-content: center;
}
header .container nav ul li {
  margin: 0 0.5rem;
  text-transform: uppercase;
  font-weight: 500;
  letter-spacing: 0.05em;
}
header .container nav ul li.nav-team, header .container nav ul li.nav-jobs {
  display: none;
}
@media only screen and (min-width: 480px) {
  header .container nav ul li {
    margin: 0 0.8rem;
  }
  header .container nav ul li.nav-team {
    display: block;
  }
}
@media only screen and (min-width: 700px) {
  header .container nav ul li {
    margin: 0 1rem;
  }
  header .container nav ul li.nav-jobs {
    display: block;
  }
}
@media only screen and (min-width: 1200px) {
  header {
    position: sticky;
    z-index: 1;
  }
  header .container {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  header .container .logo {
    display: flex;
    align-items: center;
  }
  header .container .logo .logo-container {
    margin: 0 0.75rem 0 0;
  }
  header .container nav {
    margin-bottom: 0;
  }
}

@media only screen and (min-width: 1200px) {
  header.tiny .container .logo {
    margin: 0.5rem 0;
  }
  header.tiny .container .logo .logo-container svg {
    width: 2rem;
  }
  header.tiny .container .logo .logo-caption {
    font-size: 1rem;
  }
}

body.has-hover header .container .logo:hover .logo-container svg .logo-b1 {
  fill: #8e2f45;
}
body.has-hover header .container .logo:hover .logo-container svg .logo-b2 {
  fill: #002e5c;
}

.hero {
  background: #002e5c;
}
.hero .hero-img {
  height: 60vw;
  background: url(../img/hero-bek.jpg) no-repeat;
  background-size: cover;
}
.hero .hero-msg {
  padding: 1.5rem;
  max-width: 40rem;
  margin: 0 auto;
  text-align: center;
}
.hero .hero-msg h1 {
  font-size: 1.1rem;
  line-height: 1.4em;
  font-weight: 500;
  color: white;
  margin-bottom: 0.75rem;
}
.hero .hero-msg .hero-phone {
  display: inline-block;
  color: white;
  font-size: 1.5rem;
  line-height: 1.2em;
  font-weight: 500;
}
.hero .hero-msg .hero-phone a {
  color: white;
}
@media only screen and (min-width: 480px) {
  .hero .hero-img {
    height: 50vw;
  }
  .hero .hero-msg {
    padding: 2rem;
  }
}
@media only screen and (min-width: 700px) {
  .hero .hero-img {
    height: 40vw;
  }
  .hero .hero-msg {
    padding: 2rem;
  }
}
@media only screen and (min-width: 960px) {
  .hero .hero-container {
    display: flex;
    height: 30vw;
    max-height: 600px;
    max-width: 2000px;
    margin: 0 auto;
  }
  .hero .hero-img {
    width: 50%;
    height: auto;
    order: 2;
  }
  .hero .hero-msg {
    width: 50%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 0 3rem;
  }
}
@media only screen and (min-width: 1200px) {
  .hero .hero-msg {
    padding: 0 4rem;
  }
  .hero .hero-msg h1 {
    font-size: 1.25rem;
    margin-bottom: 1rem;
  }
  .hero .hero-msg .hero-phone {
    font-size: 1.75rem;
  }
}
@media only screen and (min-width: 1400px) {
  .hero .hero-msg {
    padding: 0 5rem;
  }
  .hero .hero-msg h1 {
    font-size: 1.5rem;
    margin-bottom: 1.75rem;
  }
  .hero .hero-msg .hero-phone {
    font-size: 2rem;
  }
}
@media only screen and (min-width: 1800px) {
  .hero .hero-msg h1 {
    font-size: 1.75rem;
    margin-bottom: 2rem;
  }
}

section .section-content p {
  hyphens: auto;
}
@media only screen and (min-width: 1200px) {
  section .container {
    display: flex;
    align-items: baseline;
  }
}

.kanzlei .container {
  position: relative;
}
.kanzlei .container .badge {
  display: none;
}
@media only screen and (min-width: 1200px) {
  .kanzlei .section-heading {
    width: 25%;
  }
  .kanzlei .section-content {
    width: 36rem;
  }
  .kanzlei .container .badge {
    width: 9rem;
    height: 9rem;
    border-radius: 50%;
    position: absolute;
    bottom: -2.5rem;
    right: 1rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    color: white;
    background: #8e2f45;
  }
  .kanzlei .container .badge span {
    margin-bottom: 0.25rem;
  }
  .kanzlei .container .badge a {
    color: white;
  }
  .kanzlei .container .badge a:before {
    content: "↓";
  }
}

body.has-hover .kanzlei .container .badge a:hover {
  color: #e6b3be;
}

.leistungen {
  background: #f2f2f2;
}
.leistungen .section-content .leistungen-item {
  margin-bottom: 1rem;
}
.leistungen .section-content .leistungen-item:last-child {
  margin-bottom: 0;
}
@media only screen and (min-width: 700px) {
  .leistungen .section-content .leistungen-item {
    margin-bottom: 1.5rem;
  }
}
@media only screen and (min-width: 1200px) {
  .leistungen .section-heading {
    width: 25%;
  }
  .leistungen .section-content {
    width: 75%;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .leistungen .section-content .leistungen-item {
    width: calc(50% - 1rem);
  }
  .leistungen .section-content .leistungen-item:nth-last-child(-n+2) {
    margin-bottom: 0;
  }
}
@media only screen and (min-width: 1400px) {
  .leistungen .section-content .leistungen-item {
    width: calc(50% - 1.5rem);
    margin-bottom: 2rem;
  }
}

@media only screen and (min-width: 1200px) {
  .beratung .section-heading {
    width: 25%;
  }
  .beratung .section-content {
    width: 36rem;
  }
}

.team {
  background: #f2f2f2;
}
.team .team-item .team-img {
  width: 75%;
  margin-bottom: 0.75rem;
}
.team .team-item .team-img img {
  display: block;
  width: 100%;
}
.team .team-item.team-item--bek {
  margin-bottom: 2rem;
}
.team .team-item.team-item--bek .team-img img {
  border-radius: 50%;
}
@media only screen and (min-width: 360px) {
  .team .team-item .team-img {
    width: 70%;
  }
}
@media only screen and (min-width: 480px) {
  .team .team-item .team-img {
    width: 50%;
  }
}
@media only screen and (min-width: 700px) {
  .team .team-item .team-img {
    width: 40%;
  }
}
@media only screen and (min-width: 1200px) {
  .team .container {
    align-items: flex-start;
  }
  .team .section-heading {
    width: 25%;
  }
  .team .section-content {
    width: 75%;
  }
  .team .team-item {
    display: flex;
    align-items: center;
  }
  .team .team-item .team-img {
    width: 20%;
    margin-right: 2rem;
    margin-bottom: 0;
  }
  .team .team-item.team-item--bek {
    margin-bottom: 2rem;
  }
}
@media only screen and (min-width: 1400px) {
  .team .team-item.team-item--bek {
    margin-bottom: 3rem;
  }
}

.jobs {
  background: #002e5c;
}
.jobs p, .jobs h2, .jobs h3 {
  color: white;
}
.jobs a {
  color: #a3ccf5;
}
@media only screen and (min-width: 1200px) {
  .jobs .section-heading {
    width: 25%;
  }
  .jobs .section-content {
    width: 36rem;
  }
}

body.has-hover .jobs a:hover {
  color: white;
}

.kontakt .section-content .kontakt-item {
  margin: 0 0 1rem 0;
}
.kontakt .section-content .kontakt-map .kontakt-map--osm {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 60%;
  overflow: hidden;
  margin-bottom: 0.5rem;
}
.kontakt .section-content .kontakt-map .kontakt-map--osm object {
  position: absolute;
  top: 0;
  left: 0;
  width: 100% !important;
  height: 100% !important;
}
@media only screen and (min-width: 700px) {
  .kontakt .section-content {
    display: flex;
    flex-wrap: wrap;
  }
  .kontakt .section-content .kontakt-item {
    margin: 0 5rem 2rem 0;
  }
  .kontakt .section-content .kontakt-map {
    width: 100%;
  }
}
@media only screen and (min-width: 1200px) {
  .kontakt .section-heading {
    width: 25%;
  }
  .kontakt .section-content {
    width: 75%;
  }
  .kontakt .section-content .kontakt-item {
    margin: 0 7rem 3rem 0;
  }
}

.zertifikate {
  background: #f2f2f2;
}
.zertifikate .container .zertifikate-item {
  text-align: center;
  margin-bottom: 1.5rem;
}
.zertifikate .container .zertifikate-item:last-child {
  margin-bottom: 0;
}
.zertifikate .container .zertifikate-item span {
  display: block;
}
.zertifikate .container .zertifikate-item img {
  width: 4rem;
  margin-bottom: 0.25rem;
}
@media only screen and (min-width: 700px) {
  .zertifikate .container {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
  }
  .zertifikate .container .zertifikate-item {
    width: 50%;
    margin-bottom: 1.5rem;
  }
}
@media only screen and (min-width: 960px) {
  .zertifikate .container {
    justify-content: space-between;
    max-width: none;
    width: 50rem;
  }
  .zertifikate .container .zertifikate-item {
    width: 33%;
    margin-bottom: 0;
  }
}
@media only screen and (min-width: 1200px) {
  .zertifikate .container {
    width: 60rem;
  }
}
@media only screen and (min-width: 1400px) {
  .zertifikate .container {
    width: 70rem;
  }
}

footer {
  background: #ebebeb;
}
footer .container {
  padding-top: 2rem;
  padding-bottom: 2rem;
}
@media only screen and (min-width: 480px) {
  footer .container {
    display: flex;
    justify-content: space-between;
  }
}
@media only screen and (min-width: 700px) {
  footer .container ul {
    display: flex;
  }
  footer .container ul li {
    margin-left: 1.5rem;
  }
}

.cookie-notice {
  display: none;
  width: 100%;
  position: fixed;
  bottom: 0;
  flex-wrap: wrap;
  align-items: center;
  padding: 1rem;
  background: #002e5c;
}
.cookie-notice p {
  color: white;
  margin: 0 0 1rem 0;
}
.cookie-notice p a {
  color: white;
  border-bottom: 1px solid white;
}
.cookie-notice .btn {
  padding: 0.5rem 1rem;
  border-radius: 0.25rem;
  background: white;
  color: #002e5c;
  font-weight: 500;
  cursor: pointer;
}
.cookie-notice.active {
  display: flex;
}
@media only screen and (min-width: 360px) {
  .cookie-notice {
    padding: 1.4rem 1.5rem;
  }
}
@media only screen and (min-width: 700px) {
  .cookie-notice {
    padding: 1.75rem 2rem;
    flex-wrap: nowrap;
  }
  .cookie-notice p {
    margin: 0 1rem 0 0;
  }
}

body.has-hover .cookie-notice p a:hover {
  color: #a3ccf5;
  border-bottom: 1px solid #a3ccf5;
}
body.has-hover .cookie-notice .btn:hover {
  color: #002e5c;
  background: #a3ccf5;
}
