/* =========================================================
   1. Grundlayout & Typografie
   ========================================================= */

:root {
  --color-text: #333;
  --color-bg-light: #f8f8f8;
  --color-accent: #a68c7d;
  --color-link: #005a8d;
  --color-focus: #99c7e4;
  --border-radius: 6px;
}

body {
  margin: 0;
  font-family: Arial, sans-serif;
  color: var(--color-text);
  line-height: 1.6;
}

h1,
h2,
h3 {
  margin: 16px 0;
  color: var(--color-text);
}

section {
  padding: 40px 20px;
  max-width: 900px;
  margin: auto;
}

/* =========================================================
   2. Header
   ========================================================= */

header {
  background: var(--color-bg-light);
  padding: 40px 20px;
  text-align: center;
}

header img {
  max-width: 200px;
}

.header-info {
  font-size: 1.1rem;
  margin-top: 10px;
}

/* =========================================================
   3. Skip-Link (Barrierefreiheit)
   ========================================================= */

.skip-link {
  position: absolute;
  left: -999px;
  top: 0;
  background: #333;
  color: #fff;
  padding: 8px 12px;
  z-index: 1000;
}

.skip-link:focus {
  left: 10px;
}

/* =========================================================
   4. Leistungen / Listen
   ========================================================= */

.leistungen ul {
  list-style: none;
  padding: 0;
}

.leistungen li {
  padding: 6px 0;
  position: relative;
  padding-left: 28px;
  font-size: 1.05rem;
}

.leistungen li::before {
  content: "•";
  position: absolute;
  left: 0;
  color: var(--color-text);
  font-size: 1.6em;
  top: -2px;
}

/* Einleitungstexte & Infos */
.kontakt-info,
.header-info,
.termininfo p {
  margin-top: 20px;
  font-size: 1.05rem;
  line-height: 1.5;
}

.termininfo {
  text-align: center;
  margin-top: 40px;
}

/* =========================================================
   5. Kontaktbereich & Formular
   ========================================================= */

.kontaktformular form {
  display: flex;
  flex-direction: column;
  gap: 14px;
  max-width: 600px;       /* schön breit, aber zentriert */
  margin: 0 auto;
}

.kontaktformular .form-group {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.kontaktformular label {
  font-weight: bold;
}

/* Eingabefelder nur im Kontaktformular kapseln */
.kontaktformular input,
.kontaktformular textarea {
  padding: 12px;
  font-size: 1rem;
  border: 1px solid var(--color-text);
  border-radius: var(--border-radius);
  background: #fefefe;
  width: 100%;
  box-sizing: border-box;
}

/* Fokus-Styles nur im Formular */
.kontaktformular input:focus,
.kontaktformular textarea:focus {
  outline: 3px solid var(--color-accent);
  border-color: var(--color-text);
}

/* Button nur im Kontaktformular */
.kontaktformular button {
  padding: 14px 30px;
  font-size: 1.1rem;
  border: none;
  background: var(--color-bg-light);
  color: var(--color-text);
  border-radius: var(--border-radius);
  cursor: pointer;
  transition: background 0.3s;
  align-self: center;
  width: auto;
}

.kontaktformular button:hover {
  background: var(--color-accent);
}

.kontaktformular button:focus {
  outline: 1px solid var(--color-text);
}

/* Meldungsbereich unter dem Formular */
#form-message {
  margin-top: 10px;
  min-height: 1.2em;
  font-size: 0.95rem;
}

/* Abstand für reCAPTCHA */
.kontaktformular .g-recaptcha {
  margin: 10px 0;
}

/* Kontaktinfos unter dem Formular */
.kontakt-info a,
.header-info a,
.termininfo a {
  color: var(--color-text);
  font-weight: bold;
  text-decoration: none;
}

/* =========================================================
   6. Google Maps / Anfahrt
   ========================================================= */

.map-container {
  width: 100%;
  height: 300px;
  border-radius: 8px;
  overflow: hidden;
}

/* =========================================================
   7. Impressum & Datenschutz
   ========================================================= */

.impressum p,
.datenschutz p {
  font-size: 1rem;
}

/* =========================================================
   8. Footer
   ========================================================= */

footer {
  text-align: center;
  padding: 20px;
  background: var(--color-bg-light);
  margin-top: 40px;
  font-size: 0.95rem;
}

/* =========================================================
   9. Links & Fokus-Stile (global)
   ========================================================= */

a {
  color: var(--color-link);
}

a:focus {
  outline: 3px solid var(--color-focus);
}

:focus-visible {
  outline: 3px solid var(--color-focus);
}

/* =========================================================
   10. Responsive Optimierung
   ========================================================= */

@media (max-width: 600px) {
  header {
    padding: 24px 16px;
  }

  section {
    padding: 24px 16px;
  }

  .kontaktformular form {
    max-width: 100%;   /* auf kleinen Displays randlos */
  }
}

/* =========================================================
   Dezente Hintergrund-Dekoration (Fußpflege-Icon)
   ========================================================= */

body::before {
  content: "";
  position: fixed;
  inset: 0;
  background-image: url("Fußpflege.png");
  background-repeat: no-repeat;
  background-position: right 10% bottom 15%;
  background-size: 380px auto;
  opacity: 0.06;
  transform: rotate(-12deg);
  pointer-events: none;
  z-index: -1;
}

/* =========================================================
   Refresh (Zwischending): dezent moderner, aber wie vorher
   ========================================================= */

/* Sanfter Hintergrund statt „flach weiß“ */
body {
  background:
    radial-gradient(800px 380px at 15% 0%, rgba(166,140,125,0.10), transparent 60%),
    radial-gradient(700px 340px at 85% 10%, rgba(153,199,228,0.10), transparent 55%),
    #ffffff;
}

/* Header etwas „heroiger“, ohne komplett neues Layout */
header {
  border-bottom: 1px solid rgba(0,0,0,0.08);
}

/* Kleine Kontaktzeile im Header */
.header-contact {
  margin: 10px 0 0;
  font-size: 1.0rem;
}
.header-contact a {
  color: var(--color-text);
  font-weight: bold;
  text-decoration: none;
}

/* Dezente CTA-Buttons im Header */
.header-cta {
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 14px;
}
.cta-btn {
  display: inline-block;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,0.12);
  background: rgba(255,255,255,0.70);
  text-decoration: none;
  color: var(--color-text);
  font-weight: 700;
  transition: transform 0.15s ease, background 0.2s ease;
}
.cta-btn:hover { transform: translateY(-1px); background: rgba(255,255,255,0.92); }
.cta-btn.cta-secondary { background: rgba(166,140,125,0.14); }

/* Sections minimal aufwerten: mehr Luft, aber keine „Kacheln“ */
section {
  padding: 44px 20px;
}

/* Formular: etwas wertiger, mobile-first */
.kontaktformular input,
.kontaktformular textarea {
  border-color: rgba(0,0,0,0.35);
}
.kontaktformular button {
  background: rgba(166,140,125,0.18);
  border: 1px solid rgba(0,0,0,0.14);
}
.kontaktformular button:hover {
  background: rgba(166,140,125,0.30);
}

/* Bilderbereich schöner auf Mobile */
.ueber-mich-bilder {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-top: 18px;
}
.ueber-mich-bilder figure {
  margin: 0;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,0.10);
}
.ueber-mich-bilder img { display: block; width: 100%; height: auto; }
.ueber-mich-bilder figcaption { padding: 10px 12px; font-size: 0.95rem; }

@media (max-width: 800px) {
  .ueber-mich-bilder { grid-template-columns: 1fr; }
  section { padding: 28px 16px; }
}
