.sn-filter-form-element label,
.sn-filter-form-dropdown-kategorie .btn-primary,
.sn-filter-form-dropdown-kategorie .dropdown-menu li,
.sn-filter-form-element-text input,
.sn-filter-form-element-submit input,
.sn-list-kategorie ul li,
.sn-quicklinks--element,
.sn-mode-navigation,
.js-info-bubble-subheadline,
.js-info-bubble-list,
.js-info-bubble-more,
.sn-list-ort,
.sn-onlineberatung-button,
.sn-detail dt,
.sn-detail dd,
.sn-detail .fa,
.content .event-map .event p,
.content .event-map .event a {
  font-size: 18px;
  line-height: 26px;
}

.js-info-bubble-headline {
  font-size: 24px;
  line-height: 32px;
}

.sn-filter-form-container {
  padding: 0;
  background-color: rgb(46, 38, 114);
}

.sn-filter-form-container h3 {
  color: white;
  font-size: 24px;
  line-height: 32px;
}

.sn-filter-form-form {
  padding: 7%;
}

.sn-filter--parent-category--list,
.sn-filter--child-category--list {
  list-style-type: none;
  margin: 0;
  padding: 0;
}

.sn-filter--parent-category--list.panel {
  background-color: transparent;
  border: 0 none;
  -webkit-box-shadow: none;
  box-shadow: none;
}

.sn-filter-form-dropdown-kategorie .btn-primary {
  font-weight: normal;
  background-color: rgb(46, 38, 114);
  border: 1px solid white;
  border-radius: 0;
}

.sn-filter-form-dropdown-kategorie .btn-primary:after {
  content: url('../Images/icon-down-white.png');
  position: absolute;
  width: 16px;
  height: 10px;
  right: 16px;
  top: 8px;
}

.sn-filter-form-dropdown-kategorie .btn-primary:hover,
.sn-filter-form-dropdown-kategorie .btn-primary:focus,
.sn-filter-form-dropdown-kategorie .btn-primary:active,
.sn-filter-form-dropdown-kategorie .btn-primary.active,
.sn-filter-form-dropdown-kategorie .open .btn-primary.dropdown-toggle {
  color: rgb(68, 68, 68);
  background-color: white;
  text-decoration: none;
}

.sn-filter-form-dropdown-kategorie .btn-primary:hover:after,
.sn-filter-form-dropdown-kategorie .btn-primary:focus:after {
  content: url('../Images/icon-down-black.png');
}

.sn-filter-form-dropdown-kategorie .btn-primary.active:after,
.sn-filter-form-dropdown-kategorie .open .btn-primary.dropdown-toggle:after {
  content: url('../Images/icon-up-black.png');
}

.sn-filter-form-dropdown-kategorie .btn-primary:hover,
.sn-filter-form-dropdown-kategorie .btn-primary:focus,
.sn-filter-form-dropdown-kategorie .open .btn-primary:hover,
.sn-filter-form-dropdown-kategorie .open .btn-primary:focus {
  text-decoration: underline;
}

.sn-filter-form-dropdown-kategorie .dropdown-menu {
  width: 100%;
  padding: 1em 0;
  background-color: rgb(232, 232, 232);
  border: 1px solid rgb(46, 38, 114);
  border-width: 0 1px;
}

.sn-filter-form-dropdown-kategorie .dropdown-menu li {
  font-weight: normal;
}

.sn-filter-form-dropdown-kategorie .dropdown-menu li span {
  display: block;
}

.sn-filter-form-dropdown-kategorie .dropdown-menu li a,
.sn-filter-form-dropdown-kategorie .dropdown-menu li span {
  text-decoration: none;
}

.sn-filter-form-dropdown-kategorie .dropdown-menu>li>a {
  white-space: normal;
}

.sn-filter-form-dropdown-kategorie .panel-group {
  margin-bottom: 0;
}

.sn-filter--top-category,
.sn-filter--parent-category {
  margin-top: 0.4em;
}

.sn-filter--child-category {
  margin-bottom: 0.2em;
}

.sn-filter--child-category--list {
  margin-bottom: 1em;
}

.sn-filter--top-category>.sn-filter--top-category--link,
.sn-filter--parent-category>.sn-filter--parent-category--link,
.sn-filter--child-category>.sn-filter--child-category--link {
  display: block;
  padding: 0.4em 1em;
  color: rgb(68, 68, 68);
}

.sn-filter--top-category>.sn-filter--top-category--link,
.sn-filter--parent-category>.sn-filter--parent-category--link {
  font-weight: bold;
}

.sn-filter--child-category>.sn-filter--child-category--link {
  padding-left: 2em;
}

.sn-filter--top-category.active>.sn-filter--top-category--link,
.sn-filter--parent-category.active>.sn-filter--parent-category--link,
.sn-filter--child-category.active>.sn-filter--child-category--link {
  color: white;
  background-color: rgb(70, 38, 114);
}

.sn-filter--top-category>.sn-filter--top-category--link:hover,
.sn-filter--top-category>.sn-filter--top-category--link:focus,
.sn-filter--top-category>.sn-filter--top-category--link:active,
.sn-filter--parent-category>.sn-filter--parent-category--link:hover,
.sn-filter--parent-category>.sn-filter--parent-category--link:focus,
.sn-filter--parent-category>.sn-filter--parent-category--link:active,
.sn-filter--child-category>.sn-filter--child-category--link:hover,
.sn-filter--child-category>.sn-filter--child-category--link:focus,
.sn-filter--child-category>.sn-filter--child-category--link:active {
  background-color: rgb(46, 38, 114);
  color: white;
}

.sn-filter-form-element {
  margin-bottom: 1.5em;
}

.sn-filter-form-element label {
  color: white;
  margin-bottom: 8px;
}

.sn-filter-form-element .btn {
  white-space: normal;
}

.sn-filter-form-element .input-lg {
  height: auto;
}

.sn-filter-form-element-text input {
  width: 100%;
  color: rgb(17, 17, 17);
  background-color: white;
  border: 2px solid white;
  outline: none;
}

.sn-filter-form-element-text input ::-webkit-input-placeholder {
  /* Chrome/Opera/Safari */
  color: rgb(150, 150, 150);
}

.sn-filter-form-element-text input ::-moz-placeholder {
  /* Firefox 19+ */
  color: rgb(150, 150, 150);
}

.sn-filter-form-element-text input :-ms-input-placeholder {
  /* IE 10+ */
  color: rgb(150, 150, 150);
}

.sn-filter-form-element-text input :-moz-placeholder {
  /* Firefox 18- */
  color: rgb(150, 150, 150);
}

.sn-filter-form-element-text input:focus {
  border-color: rgb(0, 155, 220);
  transition: border-color ease-in-out 0.15s;
}

.sn-filter-form-element-submit {
  margin-bottom: 0;
}

.sn-filter-form-element-submit input {
  color: rgb(46, 38, 114);
  background-color: white;
  border: 1px solid white;
  font-weight: bold;
  outline: none;
}

.sn-filter-form-element-submit input:hover,
.sn-filter-form-element-submit input:focus {
  color: white;
  background-color: rgb(46, 38, 114);
  text-decoration: underline;
}

.sn-filter-form-dropdown-kategorie .btn-primary,
.sn-filter-form-element-text input,
.sn-filter-form-element-submit input {
  padding: 10px 18px;
}

.sn-quicklinks--container {
  padding: 7%;
  background-color: rgb(70, 38, 114);
}

.sn-quicklinks--list {
  list-style-type: none;
  margin: 0;
  padding: 0;
}

.sn-quicklinks--element {
  margin-top: 12px;
  margin-bottom: 12px;
}

.sn-quicklinks--headline,
.sn-quicklinks--element a {
  color: white;
}

.sn-quicklinks--element a .icon-link {
  position: relative;
  display: inline-block;
  margin-left: 32px;
  border-bottom: 1px solid transparent;
}

.sn-quicklinks--element a .icon-link::before {
  content: url('../Images/icon-internal-white.png');
  position: absolute;
  left: -32px;
  top: 0;
}

.sn-quicklinks--element a:hover .icon-link::before,
.sn-quicklinks--element a:focus .icon-link::before,
.sn-quicklinks--element a:active .icon-link::before {
  content: url('../Images/icon-internal-white_hover.png');
}

.sn-quicklinks--element a {
  font-weight: bold;
  text-decoration: none;
  border-bottom: 1px solid transparent;
}

.sn-quicklinks--element a:hover .icon-link,
.sn-quicklinks--element a:focus .icon-link,
.sn-quicklinks--element a:active .icon-link {
  border-bottom: 1px solid white;
}

.sn-mode-navigation {
  color: rgb(68, 68, 68);
  background-color: white;
  font-weight: bold;
}

.sn-mode-navigation div {
  padding: 8px;
  border-top: 1px solid rgb(171, 168, 196);
  text-align: center;
}

#sn-number-of-results.loading {
  color: white;
  background-color: rgb(0, 155, 220);
  border-bottom-color: rgb(0, 155, 220);
}

.sn-mode-button {
  border-bottom: 1px solid rgb(171, 168, 196);
}

.sn-mode-button.sn-mode-map {
  border-left: 1px solid rgb(171, 168, 196);
}

.sn-mode-button a {
  display: block;
}

.sn-mode-button.sn-mode-active {
  color: white;
  background-color: rgb(70, 38, 114);
  border-color: rgb(70, 38, 114);
}

.sn-mode-button.sn-mode-active a {
  color: white;
}

.sn-main-container.sn-preview {
  background-image: url('../Images/screenshot-map.jpg');
  background-position: top center;
  background-repeat: no-repeat;
}

.sn-main-container.sn-preview .sn-filter-form-container,
.sn-main-container.sn-preview .sn-content {
  visibility: hidden;
}

#sn-map-container {
  height: 80vh;
}

#sn-map-container,
#sn-list-container {
  width: 100%;
  background-color: white;
}

#sn-map {
  height: 100%;
}

#sn-list-container {
  padding: 0 5%;
}

#sn-list-container .no-results {
  margin-top: 2em;
}

.gm-style {
  font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
}

.js-info-bubble-bg {
  margin-right: 30px;
}

.js-info-bubble-more {
  margin: 20px 0 0 0;
}

.js-info-bubble-more a {
  font-weight: bold;
}

.js-info-bubble-bg,
.js-info-bubble-more a {
  color: white;
}

.js-info-bubble-close {
  margin: 20px;
}

.js-info-bubble-headline {
  margin: 0;
  margin-bottom: 1em;
  padding: 0;
}

.js-info-bubble-subheadline {
  margin-bottom: 0.5em;
  font-weight: normal;
}

.js-info-bubble-list {
  margin: 0;
  padding: 0;
  list-style-type: none;
}

.js-info-bubble-more a {
  text-decoration: none;
}

.js-info-bubble-more a .icon-link {
  position: relative;
  display: inline-block;
  margin-left: 32px;
  border-bottom: 1px solid transparent;
  color: #ffffff;
}

.js-info-bubble-more a .icon-link::before {
  content: url('../Images/icon-internal-white.png');
  position: absolute;
  left: -32px;
  top: 0;
}

.js-info-bubble-more a:hover .icon-link::before,
.js-info-bubble-more a:focus .icon-link::before,
.js-info-bubble-more a:active .icon-link::before {
  content: url('../Images/icon-internal-white_hover.png');
}

.js-info-bubble-more a:hover .icon-link,
.js-info-bubble-more a:focus .icon-link,
.js-info-bubble-more a:active .icon-link {
  border-bottom: 1px solid white;
}

.sn-map-legend {
  padding: 24px;
  background-color: rgb(232, 232, 232);
  text-align: center;
}

.sn-map-legend img {
  margin: 0 20px 0 50px;
}

.sn-map-legend .nowrap {
  white-space: nowrap;
}

.sn-list ul {
  list-style-type: none;
}

.content .std-list .sn-list-kategorie ul {
  margin-top: 10px;
}

.sn-list-ort {
  margin-bottom: 10px;
}

/*test*/
.sn-list-kategorie ul li {
  margin-bottom: 10px;
  font-weight: bold;
}

.sn-detail dt {
  margin-top: 20px;
}

.sn-detail dd {
  font-weight: 300;
  margin-bottom: 5px;
}

.sn-detail-address__headline {
  margin-top: 24px;
}

.sn-onlineberatung-button,
.sn-onlinebewerbung-button {
  margin-top: 20px;
}

.sn-onlineberatung-button a,
.sn-onlinebewerbung-button a {
  display: inline-block;
  padding: 10px 18px;
  color: white !important;
  background-color: rgb(46, 38, 114);
}

.sn-onlineberatung-button a:hover,
.sn-onlineberatung-button a:focus,
.sn-onlineberatung-button a:active,
.sn-onlinebewerbung-button a:hover,
.sn-onlinebewerbung-button a:focus,
.sn-onlinebewerbung-button a:active {
  background-color: rgb(70, 38, 114);
  text-decoration: underline !important;
}

.sn-detail .sn-onlineberatung-button,
.sn-detail .sn-onlinebewerbung-button {
  margin: 20px 0 !important;
}

.sn-detail .sn-onlineberatung-button a,
.sn-detail .sn-onlinebewerbung-button a {
  color: rgb(70, 38, 114) !important;
  background-color: white;
  font-weight: bold;
  text-decoration: none;
}

.sn-detail .sn-onlineberatung-button a {
  padding: 8px 18px 8px 10px;
}

.sn-detail .sn-onlineberatung-button a:hover,
.sn-detail .sn-onlineberatung-button a:focus,
.sn-detail .sn-onlineberatung-button a:active,
.sn-detail .sn-onlinebewerbung-button a:hover,
.sn-detail .sn-onlinebewerbung-button a:focus,
.sn-detail .sn-onlinebewerbung-button a:active {
  text-decoration: underline !important;
}

.sn-detail .sn-onlineberatung-button a img,
.sn-detail .sn-onlinebewerbung-button a img {
  margin-right: 16px;
}

.content .event-map .event h4,
.content .event-map .event p,
.content .event-map .event a {
  color: white;
}

.content .event-map .event p {
  margin-bottom: 12px;
}

.content .event-map .event a {
  font-weight: bold;
}

.content .event-map .event a:hover,
.content .event-map .event a:focus,
.content .event-map .event a:active {
  text-decoration: underline !important;
}

.sn-detail #gmap {
  min-height: 200px;
  height: 100%;
}

.sn-detail .fa {
  font-size: 1rem;
  color: white;
  width: 2rem;
}

.sn-detail .video-embed-container {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  max-width: 100%;
}

.sn-detail .video-embed-container iframe,
.sn-detail .video-embed-container object,
.sn-detail .video-embed-container embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
