body,form,figure{margin:0;padding:0}img{border:0}header,footer,nav,section,aside,article,figure,figcaption{display:block}body{font-size:100.01%}select,input,textarea{font-size:99%}#container,.inside{position:relative}#main,#left,#right{float:left;position:relative}#main{width:100%}#left{margin-left:-100%}#right{margin-right:-100%}#footer{clear:both}#main .inside{min-height:1px}.ce_gallery>ul,.content-gallery>ul{margin:0;padding:0;overflow:hidden;list-style:none}.ce_gallery>ul li,.content-gallery>ul li{float:left}.ce_gallery>ul li.col_first,.content-gallery>ul li.col_first{clear:left}.float_left,.media--left>figure{float:left}.float_right,.media--right>figure{float:right}.block{overflow:hidden}.media{display:flow-root}.clear,#clear{height:.1px;font-size:.1px;line-height:.1px;clear:both}.invisible{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}.custom{display:block}#container:after,.custom:after{content:"";display:table;clear:both}
@media (max-width:767px){#wrapper{margin:0;width:auto}#container{padding-left:0;padding-right:0}#main,#left,#right{float:none;width:auto}#left{right:0;margin-left:0}#right{margin-right:0}}img{max-width:100%;height:auto}.audio_container audio{max-width:100%}.video_container video{max-width:100%;height:auto}.aspect,.responsive{position:relative;height:0}.aspect iframe,.responsive iframe{position:absolute;top:0;left:0;width:100%;height:100%}.aspect--16\:9,.responsive.ratio-169{padding-bottom:56.25%}.aspect--16\:10,.responsive.ratio-1610{padding-bottom:62.5%}.aspect--21\:9,.responsive.ratio-219{padding-bottom:42.8571%}.aspect--4\:3,.responsive.ratio-43{padding-bottom:75%}.aspect--3\:2,.responsive.ratio-32{padding-bottom:66.6666%}
/* ============================================================
   Johannes Jaumann – Contao CSS
   Supervision | Coaching | Wegbegleitung
   Erstellt für Contao 5 / layout.html5
   ============================================================ */

/* ---------- Lokale Fonts ---------- */
@font-face {
  font-family: 'Lora';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../../files/files/Theme/fonts/lora-v37-latin-regular.woff2') format('woff2');
}
@font-face {
  font-family: 'Lora';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url('../../files/files/Theme/fonts/lora-v37-latin-italic.woff2') format('woff2');
}
@font-face {
  font-family: 'Lora';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../../files/files/Theme/fonts/lora-v37-latin-600.woff2') format('woff2');
}
@font-face {
  font-family: 'Source Sans 3';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('../../files/files/Theme/fonts/source-sans-3-v19-latin-300.woff2') format('woff2');
}
@font-face {
  font-family: 'Source Sans 3';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../../files/files/Theme/fonts/source-sans-3-v19-latin-regular.woff2') format('woff2');
}
@font-face {
  font-family: 'Source Sans 3';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../../files/files/Theme/fonts/source-sans-3-v19-latin-600.woff2') format('woff2');
}

/* ---------- CSS-Variablen ---------- */
:root {
  --color-bg:          #faf8f5;
  --color-text:        #2c2c2c;
  --color-text-light:  #6b6b6b;
  --color-border:      #e0d8ce;
  --color-earth:       #8b6f4e;
  --color-earth-light: #f2ede6;
  --color-earth-dark:  #6b5238;
  --color-blue:        #4a6fa5;
  --color-blue-light:  #eef2f8;
  --color-green:       #5a7a5a;
  --color-green-light: #eef4ee;
  --font-heading:      'Lora', Georgia, serif;
  --font-body:         'Source Sans 3', Helvetica, sans-serif;
  --space-xs:   0.5rem;
  --space-sm:   1rem;
  --space-md:   2rem;
  --space-lg:   4rem;
  --space-xl:   7rem;
  --max-width:  1100px;
  --radius:     6px;
}

/* ---------- Reset & Basis ---------- */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  font-size: 17px;
}

body {
  background-color: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-body);
  font-weight: 400;
  line-height: 1.75;
  -webkit-font-smoothing: antialiased;
}

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

a {
  color: var(--color-earth);
  text-decoration: none;
  transition: color 0.2s;
}

a:hover {
  color: var(--color-earth-dark);
}

h1, h2, h3, h4 {
  font-family: var(--font-heading);
  font-weight: 400;
  line-height: 1.3;
  color: var(--color-text);
}

h1 { font-size: 2.4rem; margin-bottom: 1.25rem; }
h2 { font-size: 1.8rem; margin-bottom: 1rem; }
h3 { font-size: 1.3rem; margin-bottom: 0.75rem; }

p { margin-bottom: 1rem; }
p:last-child { margin-bottom: 0; }

/* ---------- Layout-Wrapper ---------- */
#wrapper {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.inside {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-md);
  width: 100%;
}

/* ---------- Header ---------- */
#header {
  background-color: var(--color-bg);
  border-bottom: 1px solid var(--color-border);
  position: sticky;
  top: 0;
  z-index: 100;
}

#header .inside {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 1.1rem;
  padding-bottom: 1.1rem;
}

.site-logo {
  font-family: var(--font-heading);
  font-size: 1.2rem;
  font-weight: 400;
  color: var(--color-text);
  text-decoration: none;
  letter-spacing: 0.01em;
}

.site-logo span {
  display: block;
  font-family: var(--font-body);
  font-size: 0.72rem;
  font-weight: 300;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-light);
  margin-top: 0.15rem;
}

/* ---------- Navigation ---------- */
nav#nav ul,
.mod_navigation ul {
  list-style: none;
  display: flex;
  gap: 0.25rem;
  align-items: center;
}

nav#nav ul li a,
.mod_navigation ul li a {
  font-family: var(--font-body);
  font-size: 0.88rem;
  font-weight: 400;
  letter-spacing: 0.04em;
  color: var(--color-text-light);
  padding: 0.45rem 0.85rem;
  border-radius: var(--radius);
  transition: all 0.2s;
  text-decoration: none;
}

nav#nav ul li a:hover,
.mod_navigation ul li a:hover,
nav#nav ul li.active a,
.mod_navigation ul li.active a {
  color: var(--color-earth);
  background-color: var(--color-earth-light);
}

/* ---------- Hauptinhalt ---------- */
#main {
  flex: 1;
}

#main .inside {
  padding-top: var(--space-lg);
  padding-bottom: var(--space-lg);
}

/* ---------- Hero ---------- */
.hero {
  padding: var(--space-xl) 0 var(--space-lg);
}

.hero-inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-md);
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: var(--space-lg);
  align-items: center;
}

.hero-links {
  max-width: 560px;
}

.eyebrow {
  font-size: 0.75rem;
  font-weight: 400;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-earth);
  margin-bottom: 1rem;
}

.hero h1 {
  font-size: 2.8rem;
  font-weight: 400;
  line-height: 1.2;
  margin-bottom: 1.5rem;
}

.hero-text {
  font-size: 1.1rem;
  color: var(--color-text-light);
  line-height: 1.8;
  margin-bottom: 2rem;
}

.hero-cta {
  display: inline-flex;
  gap: 1rem;
  flex-wrap: wrap;
}

.btn {
  display: inline-block;
  padding: 0.75rem 1.75rem;
  border-radius: var(--radius);
  font-family: var(--font-body);
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  transition: all 0.2s;
  text-decoration: none;
  cursor: pointer;
}

.btn-primary {
  background-color: var(--color-earth);
  color: #fff;
  border: 2px solid var(--color-earth);
}

.btn-primary:hover {
  background-color: var(--color-earth-dark);
  border-color: var(--color-earth-dark);
  color: #fff;
}

.btn-secondary {
  background-color: transparent;
  color: var(--color-earth);
  border: 2px solid var(--color-earth);
}

.btn-secondary:hover {
  background-color: var(--color-earth-light);
}

.hero-image img {
  border-radius: 4px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.10);
  width: 100%;
  max-width: 380px;
}

/* ---------- Angebots-Karten ---------- */
.angebote {
  background-color: #fff;
  padding: var(--space-lg) 0;
}

.angebote-inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-md);
}

.section-title {
  font-size: 0.75rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-earth);
  margin-bottom: 0.5rem;
}

.section-heading {
  font-family: var(--font-heading);
  font-size: 2rem;
  font-weight: 400;
  margin-bottom: var(--space-md);
}

.angebot-block {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
  margin-top: var(--space-md);
}

.angebot-karte {
  background: var(--color-bg);
  border-radius: var(--radius);
  padding: 2rem;
  border-top: 3px solid var(--color-earth);
}

.angebot-karte.blau { border-top-color: var(--color-blue); }
.angebot-karte.gruen { border-top-color: var(--color-green); }

.angebot-karte h3 {
  font-size: 1.2rem;
  margin-bottom: 0.75rem;
}

.angebot-karte p {
  font-size: 0.95rem;
  color: var(--color-text-light);
  line-height: 1.75;
}

.karte-link {
  display: inline-block;
  margin-top: 1.25rem;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-earth);
}

.angebot-karte.blau .karte-link { color: var(--color-blue); }
.angebot-karte.gruen .karte-link { color: var(--color-green); }

/* ---------- Über mich ---------- */
.ueber-mich-grid {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: var(--space-lg);
  align-items: start;
}

.ueber-mich-image img {
  border-radius: 4px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.10);
  width: 100%;
}

/* ---------- Kontakt ---------- */
.kontakt-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-lg);
  align-items: start;
}

.kontakt-info p {
  font-size: 1rem;
  color: var(--color-text-light);
  margin-bottom: 0.5rem;
}

.kontakt-info a {
  color: var(--color-earth);
}

/* ---------- Footer ---------- */
#footer {
  background-color: #fff;
  border-top: 1px solid var(--color-border);
  padding: var(--space-md) 0;
}

#footer .inside {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
}

.footer-copy {
  font-size: 0.85rem;
  color: var(--color-text-light);
}

.footer-nav ul {
  list-style: none;
  display: flex;
  gap: 1.5rem;
}

.footer-nav ul li a {
  font-size: 0.85rem;
  color: var(--color-text-light);
  text-decoration: none;
}

.footer-nav ul li a:hover {
  color: var(--color-earth);
}

/* ---------- Impressum / Datenschutz ---------- */
.legal-content h2 {
  font-size: 1.3rem;
  margin-top: 2rem;
  margin-bottom: 0.75rem;
  padding-top: 2rem;
  border-top: 1px solid var(--color-border);
}

.legal-content h2:first-child {
  border-top: none;
  padding-top: 0;
  margin-top: 0;
}

/* ---------- Supervision/Coaching/Wegbegleitung Seiten ---------- */
.leistung-header {
  background-color: var(--color-earth-light);
  padding: var(--space-lg) 0;
}

.leistung-header.blau { background-color: var(--color-blue-light); }
.leistung-header.gruen { background-color: var(--color-green-light); }

.leistung-content {
  max-width: 720px;
}

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
  .hero-inner,
  .ueber-mich-grid,
  .kontakt-grid {
    grid-template-columns: 1fr;
  }

  .hero-image {
    order: -1;
  }

  .hero-image img,
  .ueber-mich-image img {
    max-width: 280px;
    margin: 0 auto;
  }

  .angebot-block {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  :root {
    --space-lg: 2.5rem;
    --space-xl: 4rem;
  }

  #header .inside {
    flex-direction: column;
    gap: 0.75rem;
    text-align: center;
  }

  nav#nav ul,
  .mod_navigation ul {
    justify-content: center;
  }

  nav#nav ul li a,
  .mod_navigation ul li a {
    padding: 0.4rem 0.6rem;
    font-size: 0.8rem;
  }

  .cards-grid {
    grid-template-columns: 1fr;
  }

  #footer .inside {
    flex-direction: column;
    text-align: center;
  }
}

/* ---------- Contao-spezifische Helfer ---------- */
.invisible { display: none !important; }
.block { display: block; }

.mod_breadcrumb {
  font-size: 0.85rem;
  color: var(--color-text-light);
  padding: 0.75rem 0;
}

.mod_breadcrumb li { display: inline; }
.mod_breadcrumb li + li::before { content: ' › '; color: var(--color-border); }

.pagination {
  display: flex;
  gap: 0.5rem;
  justify-content: center;
  margin-top: var(--space-md);
  list-style: none;
}

.pagination li a,
.pagination li span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.2rem;
  height: 2.2rem;
  border-radius: 50%;
  font-weight: 600;
  font-size: 0.9rem;
  border: 1.5px solid var(--color-border);
  color: var(--color-text);
  transition: all 0.2s;
}

.pagination li.active span,
.pagination li a:hover {
  background: var(--color-earth);
  border-color: var(--color-earth);
  color: #fff;
}

