/* = = = = = = = = = = = = = = = = = datei format.css = = = = = = = = = = = = = = = = = = = = = = = = = */

/* ############################################################ */
/* allgemein */
/* ############################################################ */

*, *:before, *:after {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

html, body {
  font-family:'open_sanslight',georgia, tahoma, arial, Verdana, Segoe, 'Open Sans',helvetica,roboto ,sans-serif;
  font-size:62.5%;
  line-height:1.5;
  font-weight:normal;
  height:100%;
}

body {
  overflow:hidden;
  font-size:1.7rem;
  margin: 0 auto;
  background:transparent;
  color:#000;
}

/* Top-Right-Buttons (Telefon & Termin) Styles + Animation */
.top-right-buttons {
  position: absolute;
  top: 20px;
  right: 20px;
  display: flex;
  gap: 18px;
  z-index: 100;
}
.top-right-buttons a {
  background: #4682B4;
  color: #fff;
  padding: 0.7em 1.6em;
  border-radius: 2em;
  font-size: 1.1em;
  font-weight: 600;
  display: flex;
  align-items: center;
  text-decoration: none;
  box-shadow: 0 2px 8px #0001;
  transition: background 0.3s, color 0.3s;
}
.top-right-buttons a i {
  margin-right: 0.7em;
  font-size: 1.3em;
  transition: transform 0.22s, color 0.22s;
}
.top-right-buttons a[href^="tel"]:hover i {
  color: #22c55e;
  transform: scale(1.45);
}
.top-right-buttons a[href*="calendly"]:hover i {
  color: orange;
  transform: scale(1.45);
}
.top-right-buttons a:hover {
  background: #3a6ea5;
}

/* andere zeilenabstände, absatz */
.content br {
  line-height:.7;
}

p.break  {
  line-height:7rem;margin:0;
}

/* Überschriften */
h1, h2, h3, h4, h5 {
  color:#000;
  text-align:left;
  letter-spacing:0px;
  font-weight:normal;
  text-transform:none;
}
h1 {
  font-size:3rem;
  line-height: 3.3rem;
  margin-top: 0rem;
  margin-bottom: 4.2rem;
}
h2 {
  text-align:left;
  font-size:2.4rem;
  line-height: 3rem;
  margin-top: 0rem;
  margin-bottom: 3.5rem;
}
h3 {
  font-size:2rem;
  line-height: 2.3rem;
  margin-top: 2.1rem;
  margin-bottom:1.4rem;
  letter-spacing:0rem;
}

/* allgemeine links  */
a {
  background-color:transparent;
  color:#A6A6A6;
  text-decoration: underline;
}
a:hover  {
  color:#A6A6A6;
  text-decoration:none;
}

/* ############################################################ */
/* bereich content - inhaltsbereich */
/* ############################################################ */

.section-content {
  display:table;
  width:100%;height:100%;
  padding:0;text-align:center;
}

/* inhalt */
.inhalt-back {
  position:absolute;
  top:0%; left:0%;
  height:100vh;
  width:100vw;
  margin-top:0vh;
  margin-bottom:0vh;
  display:table-cell;
  vertical-align:middle;
}
.inhalt {
  position:relative;
  top:0%; left:0%;
  height:100vh;
  width:100vw;
  margin-top:0vh;
  margin-bottom:0vh;
  margin-left:0vw;
  margin-right:0vw;
  display:table-cell;
  vertical-align:middle;
  padding:0 1rem;
}
.inhalt h2 {
  text-align:center;
  margin-bottom:0rem;
  text-shadow:2px 2px 2px #CFCFCF;
}
.inhalt span {
  display:block;
  text-align:center;
  margin:0rem 0 1rem 0 ;
}

/* fussname */
.fussname {
  display:block;
  font-weight:normal;
  color:#000;
  margin:0 auto;
  padding:2rem 0 1rem 0;
  font-size:1.2rem;
  letter-spacing:2px;
  text-transform:uppercase;
  text-shadow:2px 2px 2px #CFCFCF;
}

/* ############################################################ */
/* bereich infofenster */
/* ############################################################ */

/* -----contact - menu und icons ----- */
.contact  {margin:-1rem 0 0 0 }
.contact ul {text-align:left;
  padding:0rem;
  margin:0;
}
.contact  li {list-style:none;display:block;
  padding:0rem 0rem 0rem 0rem;
  margin:0;
}
.contact .fas ,
.contact .fab ,
.contact .far  {
  display:inline-block;
  margin:-.18rem  -.18rem 0 -.18rem;
  padding:.7rem 1rem .7rem 1rem;
  font-size:1.8rem;
  background:transparent;
  color:#fff;
  text-shadow:0px 0px 1px black;
}
.contact a   {
  text-decoration:none;
  color:#000;
}
.contact a .fas ,
.contact a .fab ,
.contact a .far  {
  color:#fff;
}
.contact a:hover .fas ,
.contact a:hover .fab ,
.contact a:hover .far  {
  color:#fff;
  background:firebrick ;
  animation:move-left .6s ease-out;
}

.top-right-buttons {
  position: absolute;
  right: 32px;
  top: 12px;
  z-index: 100;
  display: flex;
  gap: 10px;
}
.top-right-buttons a {
  background: #3A6EA5;
  color: #fff !important;
  border-radius: 30px;
  padding: 10px 24px;
  display: inline-flex;
  align-items: center;
  margin: 0 0 0 12px;
  text-decoration: none;
  font-size: 1.25rem;
  font-weight: 600;
  box-shadow: 0 2px 8px rgba(58,110,165,0.08);
  transition: background 0.2s;
  letter-spacing: 0.5px;
}
.top-right-buttons a:hover {
  background: #245486;
  color: #fff;
}
.top-right-buttons a i {
  margin-right: 10px;
  font-size: 1.35em;
  line-height: 1;
}

/* -----social media - menu und icons ----- */
#social ul {text-align:left;
  padding:0  0 0 1rem;
  margin:0;
}
#social  li {list-style:none;display:inline-block;
  padding:0rem .5rem 0rem 0rem;
  margin:0;
}
#social .fas ,
#social .fab ,
#social .far  {
  display:inline-block;
  margin:-.18rem  -.18rem 0 -.18rem;
  padding:1rem;
  font-size:1.8rem;
  background:#4682B4;
  color:#fff;
}
#social a:hover .fas ,
#social a:hover .fab ,
#social a:hover .far  {
  color:#fff;
  background:firebrick ;
  animation:move-down .6s ease-out;
}

/* ############################################################ */
/* M E D I A   Q U E R I E S - RESPONSIVE-BILDSCHIRMABFRAGEN */
/* ############################################################ */

/* ab 320 pixel */
/* ab 360 pixel */
@media (min-width: 360px) { }
/* ab 400 pixel */
@media (min-width: 400px) { }
/* ab 480 pixel */
@media (min-width: 480px) { }
/* ab 600 pixel */
@media (min-width: 600px) { }
/* ab 640 pixel */
@media (min-width: 640px) { }
/* ab 768 pixel */
@media (min-width: 768px) {
  html {font-size:70%;}
}
/* ab 800 pixel */
@media (min-width: 800px) { }
/* ab 1024 pixel */
@media (min-width: 1024px) { }
/* ab 1100 pixel */
@media (min-width: 1100px) {
  html { font-size:75%; }
}
/* ab 1280 pixel */
@media (min-width: 1280px) { }
/* ab 1400 pixel */
@media (min-width: 1400px) {
  html { font-size:80%; }
}

/* = = = = = = = = = = = = = = = = = LOGO-GRÖSSE = = = = = = = = = = = = = = = = = = = = = = = = = */

.logo {
  width: 455px;
  max-width: 90vw;
  height: auto;
  display: block;
  margin: 0 auto 2.5rem auto;
}

@media (max-width: 700px) {
  .logo {
    width: auto;
    max-width: 280px; /* Passe diesen Wert bei Bedarf an */
  }
}

/* = = = = = = = = = = = = = = = = = PARTICLES.JS BACKGROUND = = = = = = = = = = = = = = = = = = = = */

#particles-js {
  position: fixed;
  top: 0; left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 0;
  pointer-events: auto;
}

/* +  +  +  +  + +  +  +  +  +  C O D E ENDE  +  +  +  +  +  +  +  +  +  + */