/* ================================================
   Kinder Ergopraxis – Custom Theme Stylesheet
   Bootstrap 5 | Nunito Font
   ================================================ */

:root {
  --primary:         #4A8E9C;
  --primary-dark:    #396E7A;
  --primary-light:   #EAF5F7;
  --primary-xlight:  #F4FAFB;
  --accent-green:    #90BF86;
  --accent-blue:     #7EB0C8;
  --accent-purple:   #B39EC8;
  --accent-pink:     #D59898;
  --accent-yellow:   #D9CC88;
  --text-dark:       #2D3748;
  --text-body:       #4A5568;
  --text-muted:      #718096;
  --border:          #E2E8F0;
  --shadow-sm:       0 2px 10px rgba(74, 142, 156, 0.10);
  --shadow-md:       0 6px 24px rgba(74, 142, 156, 0.16);
  --r-sm: 8px;
  --r-md: 16px;
  --r-lg: 24px;
}

/* ─── Base ─────────────────────────────────── */
*,
*::before,
*::after { box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  overflow-x: hidden;
}

body {
  font-family: 'Nunito', "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 16px;
  line-height: 1.65;
  color: var(--text-body);
  background: #FAFCFD;
  overflow-x: hidden;
  max-width: 100%;
}

/* ─── Mobile Overflow Prevention ─────────────── */

/* Verhindert horizontalen Scroll auf allen Geräten */
html, body {
  max-width: 100%;
  overflow-x: hidden;
}

/* Elementor stretched sections verursachen width:100vw — überschreiben */
.elementor-section.elementor-section-stretched {
  width: 100% !important;
  left: auto !important;
  right: auto !important;
}

/* Alle Elementor-Strukturelemente auf 100% begrenzen */
.elementor,
.elementor-section,
.elementor-container,
.elementor-row,
.elementor-column,
.elementor-widget-wrap,
.elementor-widget-container,
.e-con,
.e-con-inner,
.e-child,
.e-flex {
  max-width: 100%;
  box-sizing: border-box;
}

/* Medien immer responsive */
img,
video,
iframe,
embed,
object,
figure {
  max-width: 100%;
  height: auto;
}

/* Elementor setzt max-width direkt auf img – mit !important überschreiben */
.elementor img,
.elementor video,
.elementor iframe,
.elementor [class*="wp-image-"],
.elementor .attachment-full,
.elementor .size-full {
  max-width: 100% !important;
}

/* Elementor image widget container */
.elementor-widget-image .elementor-widget-container,
.elementor-widget-image-box .elementor-widget-container {
  max-width: 100% !important;
  overflow: hidden;
}

/* Logo im Header explizit schützen – darf nicht von Elementor-Regeln betroffen sein */
.site-header .site-logo {
  height: 58px !important;
  width: auto !important;
  max-width: none !important;
}

@media (max-width: 767.98px) {
  .site-header .site-logo {
    height: 44px !important;
  }
}

h1, h2, h3, h4, h5, h6 {
  font-weight: 700;
  color: var(--text-dark);
  line-height: 1.3;
}

a {
  color: var(--primary);
  text-decoration: none;
  transition: color .2s;
}

a:hover {
  color: var(--primary-dark);
  text-decoration: underline;
}

img { max-width: 100%; height: auto; }

/* ─── Accent colour bar (top of page) ─────── */
.accent-bar {
  display: flex;
  height: 5px;
  width: 100%;
}
.accent-bar span { flex: 1; }
.accent-bar span:nth-child(1) { background: var(--accent-green); }
.accent-bar span:nth-child(2) { background: var(--accent-blue); }
.accent-bar span:nth-child(3) { background: var(--accent-purple); }
.accent-bar span:nth-child(4) { background: var(--accent-pink); }
.accent-bar span:nth-child(5) { background: var(--accent-yellow); }

/* ─── Navbar ────────────────────────────────── */
.site-header {
  background: #fff;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
  position: sticky;
  top: 0;
  z-index: 1030;
}

.navbar { padding: 0.7rem 0; }

.site-logo {
  height: 58px;
  width: auto;
  display: block;
}

.navbar-nav .nav-link {
  color: var(--text-dark) !important;
  font-weight: 600;
  font-size: 0.92rem;
  padding: 0.45rem 0.9rem !important;
  border-radius: var(--r-sm);
  transition: background .2s, color .2s;
}

.navbar-nav .nav-link:hover,
.navbar-nav .nav-link:focus {
  color: var(--primary) !important;
  background: var(--primary-xlight);
  text-decoration: none;
}

.navbar-nav .nav-link.active {
  color: var(--primary) !important;
}

/* CTA pill button in navbar */
.navbar-nav .nav-cta {
  background: var(--primary);
  color: #fff !important;
  border-radius: 50px !important;
  padding: 0.45rem 1.3rem !important;
  margin-left: 0.4rem;
  transition: background .2s, transform .15s;
}

.navbar-nav .nav-cta:hover,
.navbar-nav .nav-cta:focus,
.navbar-nav .nav-cta:active,
.navbar-nav .nav-cta.active {
  background: var(--primary-dark) !important;
  color: #fff !important;
  text-decoration: none;
  transform: translateY(-1px);
}

/* Hamburger icon colour */
.navbar-toggler {
  border-color: transparent;
  padding: 0.4rem;
}
.navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='%234A8E9C' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2.5' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}
.navbar-toggler:focus { box-shadow: 0 0 0 3px rgba(74,142,156,.25); }

/* Mobile collapse area */
@media (max-width: 991.98px) {
  .navbar-collapse {
    border-top: 1px solid var(--border);
    padding: 0.75rem 0 0.5rem;
    margin-top: 0.5rem;
  }
  .navbar-nav .nav-link { padding: 0.55rem 0.5rem !important; }
  .navbar-nav .nav-cta {
    display: inline-block;
    margin: 0.5rem 0 0;
  }
}

/* ─── Site main ──────────────────────────────── */
.site-main { min-height: calc(100vh - 220px); }

/* ─── Page hero (title banner) ───────────────── */
.page-hero {
  background: linear-gradient(135deg, var(--primary-light) 0%, var(--primary-xlight) 100%);
  padding: 2.5rem 0 2rem;
}

.page-hero h1 {
  color: var(--primary);
  font-size: 2rem;
  font-weight: 800;
  margin: 0;
}

/* ─── Content card (used by most page templates) */
.content-wrapper { padding: 2.5rem 0 4rem; }

.content-card {
  background: #fff;
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.content-card-header {
  background: var(--primary);
  padding: 1.1rem 1.6rem;
}

.content-card-header h1,
.content-card-header h2 {
  color: #fff;
  font-size: 1.3rem;
  font-weight: 600;
  margin: 0;
}

.content-card-body {
  padding: 1.8rem;
}

/* Inner content typography */
.content-card-body h2 { font-size: 1.3rem; color: var(--primary); margin-top: 1.4rem; }
.content-card-body h3 { font-size: 1.1rem; color: var(--text-dark); margin-top: 1.2rem; }
.content-card-body p  { margin-bottom: 1rem; }
.content-card-body ul { padding-left: 1.4rem; }
.content-card-body li { margin-bottom: 0.35rem; }
.content-card-body img { border-radius: var(--r-md); }

/* ─── Homepage ────────────────────────────────── */
.home-hero {
  background: linear-gradient(160deg, var(--primary-light) 0%, #fff 70%);
  padding: 4rem 0;
  text-align: center;
}

.home-logo {
  max-width: 480px;
  width: 90%;
  height: auto;
  margin-bottom: 2.5rem;
}

.home-intro {
  font-size: 1.1rem;
  color: var(--text-muted);
  max-width: 540px;
  margin: 0 auto 2rem;
}

.home-image-card {
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  transition: transform .3s ease, box-shadow .3s ease;
  display: block;
}

.home-image-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(74,142,156,.22);
  text-decoration: none;
}

.home-image-card img {
  width: 100%;
  display: block;
  border-radius: var(--r-lg);
}

/* ─── Praxis page – Google Maps ──────────────── */
.map-wrapper {
  margin-top: 2rem;
  border-radius: var(--r-md);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.map-wrapper iframe {
  display: block;
  width: 100%;
  height: 400px;
  border: none;
}

/* ─── Therapeutin photo ──────────────────────── */
.therapeutin-photo {
  border-radius: var(--r-md);
  box-shadow: var(--shadow-sm);
  width: 180px;
  display: block;
  margin: 0 auto 1.5rem;
}

/* ─── Anmeldung form ─────────────────────────── */
.form-section {
  background: var(--primary-xlight);
  padding: 3rem 0 4rem;
}

.form-card {
  background: #fff;
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.form-card-header {
  background: var(--primary);
  padding: 1.25rem 1.75rem;
}

.form-card-header h1 {
  color: #fff;
  font-size: 1.3rem;
  font-weight: 600;
  margin: 0;
}

.form-card-body {
  padding: 2rem 1.75rem;
}

/* Toggle button groups */
.toggle-group-label {
  font-weight: 700;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--text-muted);
  margin-bottom: 0.5rem;
}

.btn-group .btn-toggle {
  font-size: 0.88rem;
  font-weight: 600;
  font-family: 'Nunito', sans-serif;
  padding: 0.45rem 0.9rem;
  border: 1.5px solid var(--border);
  background: #fff;
  color: var(--text-body);
  cursor: pointer;
  transition: background .15s, color .15s, border-color .15s;
}

.btn-group .btn-toggle:hover {
  background: var(--primary-light);
  border-color: var(--primary);
  color: var(--primary);
}

.btn-group .btn-toggle.active {
  background: var(--primary);
  border-color: var(--primary);
  color: #fff;
}

/* Form controls */
.form-label {
  font-weight: 600;
  font-size: 0.88rem;
  color: var(--text-dark);
  margin-bottom: 0.35rem;
}

.form-control {
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  padding: 0.55rem 0.85rem;
  font-size: 0.95rem;
  font-family: 'Nunito', sans-serif;
  color: var(--text-dark);
  transition: border-color .2s, box-shadow .2s;
}

.form-control:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(74, 142, 156, .18);
  outline: none;
}

.form-control::placeholder { color: #A0AEC0; }

/* Submit button */
.btn-submit {
  background: var(--primary);
  color: #fff;
  border: none;
  border-radius: 50px;
  padding: 0.75rem 2.8rem;
  font-size: 1rem;
  font-weight: 700;
  font-family: 'Nunito', sans-serif;
  cursor: pointer;
  transition: background .2s, transform .15s, box-shadow .2s;
  box-shadow: 0 4px 14px rgba(74, 142, 156, .32);
}

.btn-submit:hover {
  background: var(--primary-dark);
  transform: translateY(-2px);
  box-shadow: 0 7px 20px rgba(74, 142, 156, .40);
}

/* Privacy note */
.privacy-note {
  font-size: 0.82rem;
  color: var(--text-muted);
  margin-bottom: 1.25rem;
}

.privacy-note a { color: var(--primary); }

/* ─── Footer ──────────────────────────────────── */
.site-footer {
  background: var(--primary-dark);
  color: rgba(255, 255, 255, 0.82);
  padding: 3.5rem 0 0;
  margin-top: 0;
}

.site-footer h5 {
  color: #fff;
  font-weight: 700;
  font-size: 0.95rem;
  letter-spacing: .04em;
  text-transform: uppercase;
  margin-bottom: 1.1rem;
}

.site-footer p,
.site-footer address,
.site-footer .footer-tagline {
  font-size: 0.88rem;
  line-height: 1.8;
  font-style: normal;
  color: #fff !important;
}

.site-footer a {
  color: rgba(255, 255, 255, 0.72);
  text-decoration: none;
  transition: color .2s;
}

.site-footer a:hover {
  color: #fff;
  text-decoration: underline;
}

.footer-links {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-links li { margin-bottom: 0.45rem; }

.footer-tagline {
  font-size: 0.88rem;
  color: rgba(255, 255, 255, 0.55);
  margin-top: 0.25rem;
}

.footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  margin-top: 2.5rem;
  padding: 1.1rem 0;
  text-align: center;
}

.footer-bottom p {
  font-size: 0.78rem;
  color: rgba(255, 255, 255, 0.4);
  margin: 0;
}

.footer-bottom a { color: rgba(255, 255, 255, 0.5); }

/* ─── Utility ─────────────────────────────────── */
.section-divider {
  height: 1px;
  background: var(--border);
  margin: 1.5rem 0;
}

/* ─── Responsive tweaks ───────────────────────── */
@media (max-width: 767.98px) {
  .site-logo   { height: 44px; }
  .page-hero h1 { font-size: 1.5rem; }
  .content-card-body { padding: 1.25rem; }
  .form-card-body { padding: 1.5rem 1.25rem; }
  .home-hero { padding: 2.5rem 0; }
  .home-logo { max-width: 300px; }
  .map-wrapper iframe { height: 280px; }
  .therapeutin-photo { width: 140px; }
}

@media print {
  .site-header,
  .site-footer { display: none; }
  a[href]::after { content: none !important; }
}
