* { margin: 0; padding: 0; box-sizing: border-box; }

body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
  color: #2e2e38;
  line-height: 1.8;
  font-size: 17.5px; /* vorher Standard ~16px */

}

h1 { font-size: 3rem; }
h2 { font-size: 2.1rem; }

.container {
  max-width: 900px;
  margin: 0 auto;
  padding: 60px 20px;
}

.hero {
  min-height: auto;
  background: linear-gradient(180deg, #1c2fd4 0%, #0c1b8f 100%);
  display: flex;
  align-items: center;
justify-content: center;  
  padding: 120px 8%;
}

.hero-inner {
  max-width: 1200px;


}

.hero-title {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-size: 3.4rem;        /* gilt jetzt für beide Zeilen */
  letter-spacing: 0.12em;
  font-weight: 600;
  color: #f1e6d8;
  margin-bottom: 20px;
  line-height: 1;          /* kein Zeilenabstand */
}

.hero-coaching {
  align-self: center;
}

.hero-hamburg {
  align-self: flex-end;
  font-size: inherit;     /* gleiche Größe wie Coachingstudio */
  letter-spacing: 0.12em;/* gleiche Laufweite */
  margin-top: 0;         /* kein Abstand nach oben */
}

.hero-claim {
  width: 100%;            /* volle Breite des Hero-Blocks */
  text-align: right;     /* Text rechtsbündig */
  color: #f1e6d8;        /* wieder hell */
  margin-top: 20px;
font-size: 1.9rem;
}

.hero-sie {
  font-size: 2.2rem;  /* Sie etwas größer */
  font-weight: 500;
}

.hero-welcome {
  margin-top: 10px;
  font-size: 1.9rem;
  font-weight: 400;
  color: #f1e6d8;
  opacity: 0.9;
  text-align: right;
}


.raum-section {
  position: relative;
  padding: 40px 0;
}

.raum-bg {
  position: absolute;
  inset: 0;
  background: #f1e6d8;
  }

.raum-container {
  position: relative;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 20px;
}

.raum-img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 14px;
  box-shadow: 0 30px 70px rgba(0,0,0,0.45);
  border: 6px solid rgba(255,255,255,0.75);
}





.raum-text {
 background: linear-gradient(180deg, #10069F 0%, #0c047a 100%);
  color: #f1e6d8;
  padding: 20px 20px;
  text-align: center;
margin-top:0;
}

.raum-text h2 {
  font-size: 2.1rem;
  margin-bottom: 18px;
}

.raum-text p {
  font-size: 1.05rem;
  line-height: 1.7;
  opacity: 0.95;
}

/* Responsive */
@media (max-width: 900px) {
  .raum-content {
    grid-template-columns: 1fr;
    gap: 20px;
  }
}

/* RAUM */
.raum-visual {
  min-height: 40vh;        /* Mindesthöhe für Design */
  padding: 4vw 4vw;       /* gleichmäßiger Rand */
  background: url("Studio.jpeg") center/cover no-repeat;
  display: flex;
  align-items: stretch;  /* Container passt sich Inhalten an */
}

.raum-gallery {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4vw;
  align-items: stretch;
}

.raum-gallery img {
  width: 100%;
  height: auto;
  max-height: 100%;
  object-fit: cover;
  border-radius: 18px;
  box-shadow: 0 30px 70px rgba(0,0,0,0.35);
  border: 6px solid rgba(255, 255, 255, 0.75); /* feiner Rahmen */
}

.raum-text {
  background: #10069F;
  color: #f1e6d8;
  text-align: center;
}

/* ZITAT + HELLE BLÖCKE */
.quote,
.angebot,
.methoden {
  background: #f1e6d8;
}

.quote { text-align: center; }

/* COACH */
.coach-section {
  position: relative;
  padding: 80px 0 55px;
}

.coach-bg {
  position: absolute;
  inset: 0;
  background: url("Meer.jpeg") center / cover no-repeat;
  filter: blur(6px) brightness(0.7);
}

.coach-container {
  position: relative;
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 70px;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 20px 40px;
  color: white;
  align-items: start;
}

.coach-left h2 {
  margin-bottom: 20px;
}

.coach-photo {
  width: 100%;
  border-radius: 14px;
  box-shadow: 0 30px 70px rgba(0,0,0,0.45);
  border: 6px solid rgba(255, 255, 255, 0.75); /* gleicher Look wie Raum */
}

.coach-text {
  max-width: 650px;
}

.coach-quote-bottom {
  position: relative;
  text-align: center;
  margin-top: 15px;
  color: #f1e6d8;
  font-style: italic;
}

/* ALLTAG */
.alltag-section {
  position: relative;
  min-height: 70vh;
  height: 70vh;
}

.alltag-bg {
  position: absolute;
  inset: 0;
  background: url("Kunsthalle.png") center/cover no-repeat;
  filter: brightness(0.75);
}

.alltag-box {
  position: relative;
  width: 34%;
  height: 100%;
  background: rgba(241, 230, 216, 0.75); /* transparenter */
  padding: 70px 50px;
  overflow-y: auto;
  font-size: 0.95rem;   /* minimal kleiner als der Rest */
  line-height: 1.7;    /* etwas kompakter */

}

/* STANDORT */
.standort {
  position: relative;
  min-height: 70vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.standort-bg {
  position: absolute;
  inset: 0;
  background: url("Standort.jpeg") center/cover no-repeat;
  
}

.standort-box {
  position: relative;
  max-width: 820px;                 /* vorher 650px → breiter */
  background: rgba(40, 40, 40, 0.65);
  color: #f1e6d8;
  padding: 80px 90px;               /* horizontal mehr Luft, Höhe bleibt gleich */
  text-align: center;
  border-radius: 14px;              /* Ecken bleiben gleich */
}

/* KONTAKT */
.contact {
  background: #10069F;
  color: #f1e6d8;
  text-align: center;
}

/* MAP */
.map iframe {
  width: 100%;
  height: 380px;
  border: 0;
}

/* FOOTER */
.footer {
  background: #0c047a;
  color: #f1e6d8;
  padding: 40px 20px;
  text-align: center;
}

.footer-inner a {
  color: #f1e6d8;
  margin: 0 15px;
  text-decoration: none;
}

/* Footer Buttons */
.footer .btn-footer {
  display: inline-block;
  padding: 12px 28px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  transition: 0.25s ease;
}

.footer .btn-footer:hover {
  background: rgba(255, 255, 255, 0.18);
  transform: translateY(-2px);
}



/* MOBILE */
@media (max-width: 900px) {
  .raum-gallery { grid-template-columns: 1fr; }
  .coach-container { grid-template-columns: 1fr; text-align: center; }
  .alltag-box, .standort-box { width: 100%; }
}


.subpage-header {
  background: linear-gradient(180deg, #0c2d48, #071c2f);
  padding: 140px 20px 80px;
  text-align: center;
}

.subpage-header h1 {
  font-size: 3rem;
  color: #f1e6d8;
  letter-spacing: 1px;
}

.subpage-container {
  max-width: 1100px;
  margin: -60px auto 120px;
  padding: 0 20px;
}

/* LEGAL PAGE – im Stil des Footers */
.legal-page {
  min-height: 100vh;
  background: #0c047a;
  color: #f1e6d8;
  padding: 120px 20px 80px;
}

.legal-container {
  max-width: 900px;
  margin: 0 auto;
  text-align: left;
}

.legal-container h1 {
  text-align: center;
  margin-bottom: 50px;
  font-size: 2.4rem;
}

.legal-container h2 {
  margin-top: 50px;
  margin-bottom: 15px;
  font-size: 1.5rem;
  color: #f1e6d8;
}

.legal-container p,
.legal-container li {
  font-size: 1.05rem;
  line-height: 1.8;
  opacity: 0.95;
}

.legal-container ul {
  margin: 20px 0 0 20px;
}


.back-link {
  display: inline-block;
  margin-top: 50px;
  color: #cfe9ff;
  text-decoration: none;
  font-size: 1.1rem;
  transition: 0.3s;
}

.back-link:hover {
  color: #ffffff;
}


