@charset "UTF-8";

/* ==========================================================================
 * Webseite: Zahnarztpraxis Wefelnberg
 * URL: www.zahnarztpraxis Wefelnberg.de
 * Datum: Juli 2013
 * Autor: graugans Design
 * ========================================================================== */
 
 /* ==========================================================================
 * Colors:
 * Masthead Graublau: #e3e5e7
 * Schrift Blau: #436a91
 * Schrift grau #a5a5a5
 * Hover-RotNavigation: #d13d5c
 * Fonts: Lato
 * ========================================================================== */
 
/* ------------------------------------------- */
/* Typografie */
/* ------------------------------------------- */

body {
   font-family: 'Poppins', sans-serif;
   line-height: 1.5;
   font-size: 16px;
   font-weight: 300;
}
h1 {
   font-weight: 300;
   font-size: 26px;
}
h2 {
   font-weight: 300;
   font-size: 22px; 
}  
h3 {
   font-weight: 600;
   font-size: 14px;  
}
a {
   color: #428bca;  
}
@media (min-width: 768px) {
   a {
   color: #333;  
}
}
a:hover, a:focus {
   border-bottom: 1px dotted #436a91; 
   text-decoration: none;
}
p {
   margin-top: 0;
}
.text-fade, .text-fade a {
   color: #ccc !important;  
}
.text-large {
   font-size: 20px;
}
/* Ein Trenner, der durch den Text überlagert wird */
.heading-with-divider {
   margin-top: -35px;  
   color: #a5a5a5;
   font-size: 18px;
}
.heading-with-divider span {
   background: #fff;
   padding: 0 10px;
}
ul {
   padding-left: 20px;  
}
@media (min-width: 768px) {
   hr {
      margin: 30px 0;  
   }
   .heading-with-divider {
      margin-top: -45px; 
      margin-bottom: 30px; 
   }
}
@media (min-width: 768px) {
   hr {
      margin: 40px 0;  
   }
   .heading-with-divider {
      margin-top: -55px; 
      margin-bottom: 30px; 
   }
}
@media (min-width: 992px) {
   h1 {
      font-size: 30px;
   }
   h2 {
      font-size: 22px; 
   }  
   h3 {
      font-size: 16px;  
   }  
}
@media (min-width: 1200px) {
   h1 {
      font-size: 34px;
   }
   h2 {
      font-size: 26px; 
   }  
   h3 {
      font-size: 18px;  
   }  
}
/* ------------------------------------------- */
/* Header, Navigation und Logo */
/* ------------------------------------------- */
@media (max-width: 767px) {
   #masthead {
      margin-bottom: 2rem;
   }
}

#pageheader {
   border-bottom: 1px solid #829FBA; 
   padding-bottom: 0px; 
}
#pageheader a:hover, 
#pageheader a:focus {
   border-bottom: none; 
}
.navbar-header {
   padding: 5px 0;
   margin-top: 5px;
   margin-bottom: 10px;
}  
/* Menu-Button */
.navbar-toggle {
   float: right;  
   display: block;
   border: none;
   padding: 7px 15px;
   margin-top: 2px;
   color: #fff;
   background-color: #333;
   opacity: .8;
   -webkit-transition: opacity 300ms;
   -moz-transition: opacity 300ms;
   -o-transition: opacity 300ms;
   transition: opacity 300ms;
}
.navbar-toggle:hover, .navbar-toggle:focus {
   opacity: 1;  
}
.navbar-brand {
   line-height: 40px;  
   font-weight: 600;
   color: #333 !important;
}
.navbar-brand:hover {
   text-decoration: none;   
}
.icon-logo {
   display: inline-block;
   width: 40px;
   height: 40px;
   background: url("/assets/zimmermann-logo.svg") no-repeat; 
   background-size: cover; 
   margin-right: 10px;
   float: left;
}
.navbar-collapse ul {
   margin: 0;  
}
.navbar-collapse a {
   display: block;
   padding: 5px;
   border-top: 1px dotted #829FBA; 
}  
.navbar-collapse a:hover, 
.navbar-collapse a:focus {
   background: #E3E5E7;  
   text-decoration: none;
}
@media (min-width: 768px) {
   #pageheader {
      border-bottom: none; 
   }
   .navbar-header {
      float: left;  
   }
   .navbar-brand {
      line-height: 60px; 
      font-size: 18px; 
   }
   .navbar-toggle {
      display: none;
   }
   .icon-logo {
      width: 60px;
      height: 60px;
   }
   .navbar-collapse {
      display: block;  
   }
   .navbar-collapse ul {
      float: right;  
      margin-top: 25px;
   }
   .navbar-collapse li {
      float: left;  
      margin-left: 10px;
   }
   .navbar-collapse a {
      display: block;
      padding: 5px;
      border-top: none; 
      color: #333;
      font-size: 20px;
   } 
}
@media (min-width: 992px) {
   .navbar-brand {
      font-size: 22px; 
   }
}
@media (min-width: 1200px) {
   .navbar-brand {
      font-size: 24px; 
   }
}
/* ------------------------------------------- */
/* Masthead */
/* ------------------------------------------- */

#masthead {
   background: #e3e5e7;
   padding: 10px 0;
}
.adressblock {
   margin: 2rem 0;
   font-size: 20px;
}
.adressblock span {
   display: block;
   margin-bottom: 1rem;
}
@media (min-width: 768px) {
    .adressblock {
      margin: 2rem 0;
   }  
}
@media (min-width: 992px) {
    .adressblock {
      margin: 6rem 0;
   }  
}
@media (min-width: 1200px) {
    .adressblock {
      margin: 8rem 0;
   }  
}

/* ------------------------------------------- */
/* Module */
/* ------------------------------------------- */

/* Bilder */
.img-frame {
   border: 6px solid #fff;
   box-shadow: 0 0 6px #999;  
}
@media (min-width: 767px) {
   .img-frame {
      border-width: 10px;
      box-shadow: 0 0 8px #999;  
   }
}
@media (max-width: 767px) {
   img:first-child {
      margin-right: 4%;  
   }
   .img-col-6-xs {
      width: 48%;
      float: left;  
   }
}
/* Infobox */
.infobox {
    margin: 20px 0; 
}
.infobox-head {
   background: #436B90;
   border-top-right-radius: 6px;  
   border-top-left-radius: 6px; 
   text-align: center;
   padding: 10px 0;
}
.infobox-head h2 {
   color: #fff;
   margin: 0;
}
.infobox-body {
   background: #eeeef0; 
   border-bottom-right-radius: 6px;
   border-bottom-left-radius: 6px;
   padding: 15px;
}
/* Infobox mit google-Map ohne padding */
.infobox-gm .infobox-body {
   padding: 0;   
}
.trenner-infobox {
   border-bottom: 1px solid #d4d4d4;  
   margin-top: 5px;
}
.infobox-arrow {
	position: relative;
	background: #436B90;
}
.infobox-arrow:after {
	top: 100%;
	left: 50%;
	border: solid transparent;
	content: " ";
	height: 0;
	width: 0;
	position: absolute;
	pointer-events: none;
	border-color: rgba(67, 107, 144, 0);
	border-top-color: #436B90;
	border-width: 10px;
	margin-left: -10px;
}
/* Mitgliedschafte, Text mit Logo */
.mod-mitgliedschaft {
   float: left; 
}
.mod-mitgliedschaft img {
   float: left;  
}
.mod-mitgliedschaft p {
   margin-left: 110px;  
   font-size: .9em;
}
@media (min-width: 992px) {
   .mod-mitgliedschaft {
      float: none; 
   }
   .mod-mitgliedschaft img {
      float: none;  
      display: block; 
      margin: 0 auto;
   }
   .mod-mitgliedschaft p {
      margin-left: 0;  
      text-align: center;
   }
}
.box-team-member {
   margin-bottom: 20px;
}
.box-team-member small {
   line-height: 1.4; 
   display: block; 
}
@media (min-width: 768px) {
   .box-team-member {
      margin-bottom: 20px;
		height: 370px;
   } 
	.article {
		padding: 2rem 0;
	}
}

/* ------------------------------------------- */
/* FOOTER */
/* ------------------------------------------- */  
#pagefooter {
   margin-bottom: 20px;  
   /*color: #a5a5a5;*/
}
#pagefooter a {
   color: #333;
}
#pagefooter address a {
   color: #428bca;
}
#pagefooter a:hover,
#pagefooter a:focus {
   text-decoration: none;
   /*color: #436B90 !important;*/
}
address {
   font-style: normal;  
   color: #333;
}
/* ------------------------------------------- */
/* Helferklassen */
/* ------------------------------------------- */
.nav {
   list-style: none; 
   padding-left: 0; 
}
.text-center {
   text-align: center;  
}
@media (max-width: 767px) {
   .text-left-xs {
      text-align: left;  
   }
}
/* Manche Spalten müssen enger zusammenstehen */
.less-padding-right {
    padding-right: 7px;  
}
.less-padding-left {
    padding-left: 7px;  
}

/* ========================================
   LAYOUT HELFER-KLASSEN ANFANG
   ======================================== */
.clearfix:before,
.clearfix:after,
.container:before,
.container:after,
.row:before,
.row:after,
.nav:before,
.nav:after,
.navbar:before,
.navbar:after,
.navbar-header:before,
.navbar-header:after,
.navbar-collapse:before,
.navbar-collapse:after {
  content: " ";
  display: table;
}
.clearfix:after,
.container:after,
.row:after,
.nav:after,
.navbar:after,
.navbar-header:after,
.navbar-collapse:after {
  clear: both;
}
.hidden {
  display: none !important;
  visibility: hidden !important;
}
@-ms-viewport {
  width: device-width;
}
.visible-xs,
.visible-sm,
.visible-md,
.visible-lg {
  display: none !important;
}
@media (max-width: 767px) {
  .visible-xs {
    display: block !important;
  }
}
@media (min-width: 768px) and (max-width: 991px) {
  .visible-sm {
    display: block !important;
  }
}
@media (min-width: 992px) and (max-width: 1199px) {
  .visible-md {
    display: block !important;
  }
}
@media (min-width: 1200px) {
  .visible-lg {
    display: block !important;
  }
}
@media (min-width: 1200px) {
  .visible-lg-block {
    display: block !important;
  }
}
@media (max-width: 767px) {
  .hidden-xs {
    display: none !important;
  }
}
@media (min-width: 768px) and (max-width: 991px) {
  .hidden-sm {
    display: none !important;
  }
}
@media (min-width: 992px) and (max-width: 1199px) {
  .hidden-md {
    display: none !important;
  }
}
@media (min-width: 1200px) {
  .hidden-lg {
    display: none !important;
  }
}
.visible-print {
  display: none !important;
}
@media print {
  .visible-print {
    display: block !important;
  }
}
@media print {
  .hidden-print {
    display: none !important;
  }
}
/* ========================================
	LAYOUT HELFER-KLASSEN ENDE
   ======================================== */

/* Modul Box */

.modul-box {
   background: #F7F7F7;
   border-radius: 6px;
   overflow: hidden;
   margin: 0 0 2rem 0;
}
.modul-box .head {
   background: #848484;
}
.modul-box hr {
   margin: 2rem 0 1rem 0;
}

@media (min-width: 768px) {
   .flex {
      display: flex;
      flex-wrap: nowrap;
      margin: 0;
   }
   .modul-box {
     margin-bottom: 4rem;
   }
   .has-border-right {
      border-right: 1px solid #ddd;
   }
}
.modul-box .head h2 {
   color: #fff;
   line-height: 1;
   margin: 0;
   font-size: 22px;
}
.modul-box .head {
	position: relative;
	background: #848484;
   padding: 15px;
   text-align: center;
}
.modul-box .head:after {
	top: 100%;
	left: 50%;
	border: solid transparent;
	content: "";
	height: 0;
	width: 0;
	position: absolute;
	pointer-events: none;
	border-color: rgba(132, 132, 132, 0);
	border-top-color: #848484;
	border-width: 15px;
	margin-left: -15px;
}
.modul-box .body {
   padding: 3rem 15px 1rem 15px;
}
iframe {
   border: 0 !important;
   margin: 0;
   display: block;
}
.iframe-hint {
  padding: 5px 15px; 
}


