/* Selbst gehostete Schriften */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('/fonts/playfair-display-600-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('/fonts/playfair-display-600-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'Source Sans Pro';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/fonts/source-sans-pro-400-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Source Sans Pro';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/fonts/source-sans-pro-400-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'Source Sans Pro';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('/fonts/source-sans-pro-700-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Source Sans Pro';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('/fonts/source-sans-pro-700-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

.service-single .title {
  color: #ff7a00;
  font-weight: bold;
}

.title {
  font-weight: bold;
}

.site-version {
  font-size: 0.85em;
  opacity: 0.6;
  margin-left: 0.5em;
}

.footer {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 1000;
}

.footer-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 10px;
  margin-top: 10px;
  border-top: 1px solid rgba(255,255,255,0.2);
  font-size: 0.8em;
  color: rgba(255,255,255,0.8);
}

.footer-meta-left  { flex: 1; text-align: left; }
.footer-meta-center { flex: 1; text-align: center; opacity: 0.55; }
.footer-meta-right { flex: 1; text-align: right; }

.footer .footer-meta a {
  color: #ffe0b2 !important;
  text-decoration: underline;
}

.footer .footer-meta a:hover {
  color: #ffffff !important;
}

body {
  padding-bottom: 130px;
}

/* Startseite: Abstände reduzieren */
@media (min-width: 768px) {
  .page-home .intro {
    padding-bottom: 60px;
  }
  .page-home .strip-grey .container {
    padding-top: 40px !important;
    padding-bottom: 40px !important;
  }
}

/* Logo-Shrink beim Scrollen */
.logo img,
.logo-mobile img {
  transition: height 0.2s ease;
}

.sticky .logo img,
.sticky .logo-mobile img {
  height: 32px;
}

/* Kontaktformular */
.page-contact .form-control {
  border: 1px solid #ddd;
  border-radius: 4px;
  padding: 0.5rem 0.75rem;
  width: 100%;
  font-family: inherit;
  font-size: 1rem;
  color: #2f2f41;
}

.page-contact .form-control:focus {
  outline: none;
  border-color: #ff7a00;
  box-shadow: 0 0 0 3px rgba(255, 122, 0, 0.15);
}

.page-contact .form-label {
  display: block;
  margin-bottom: 0.3rem;
  font-weight: 600;
  color: #2f2f41;
}

.page-contact .required {
  color: #ff7a00;
}

.page-contact .form-check {
  display: flex;
  gap: 0.6rem;
  align-items: flex-start;
}

.page-contact .form-check-input {
  margin-top: 0.25rem;
  flex-shrink: 0;
  accent-color: #ff7a00;
}

.form-message {
  padding: 0.75rem 1rem;
  border-radius: 4px;
  display: none;
}

.form-message.info    { display: block; background: #f0f0f0; color: #444; }
.form-message.success { display: block; background: #eaf7ea; color: #2a6b2a; }
.form-message.error   { display: block; background: #fdecea; color: #8b1a1a; }
