/* =========================================================
   0) Design Tokens (Farben / Abstaende / Typo / Layout)
   ========================================================= */

:root {
  /* Layout */
  --header-height: 70px;
  --page-width: 80%;
  --page-min: 800px;
  --page-max: 1600px;
  --logo-height: 4rem;
  --logo-width: auto;
  --main-margin-y: 0px;
  --main-container-margin-x: 0px;
  --text-align-global: left;

  /* Farben */
  --color-text: #333333;
  --color-muted: #777777;
  --color-white: #ffffff;

  --color-page-bg: #9ea9a9;

  --color-header-bg: rgba(0, 0, 0, 0);
  --color-header2-bg: rgb(21, 21, 21);
  --color-header-text: #ffffff;

  --color-master-overlay: rgba(0, 0, 0, 0.50);
  --color-master-text: #ffffff;

  --color-card-bg: #ffffff;

  --color-border: #dddddd;

  --color-section-dark-bg: #222222;
  --color-section-dark-text: #ffffff;

  --color-footer-bg: #000000;
  --color-footer-text: #ffffff;

  --color-form-border: #cccccc;
  --color-button-bg: #3a3a3a;
  --color-button-text: #ffffff;

  /* Abstaende (Spacing) */
  --space-0: 0;
  --space-1: 0.5rem;
  --space-2: 1rem;
  --space-3: 1.5rem;
  --space-4: 2rem;
  --space-5: 3rem;
  --space-6: 4rem;
  --space-7: 5rem;

  /* Radius */
  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 10px;

  /* Schatten */
  --shadow-1: 0 16px 40px rgba(0, 0, 0, 0.22);
  --shadow-2: 0 6px 14px rgba(0, 0, 0, 0.18);

  /* Typografie */
  --font-family: Arial, Helvetica, sans-serif;
  --line-height: 1.6;
  --font-size-master: 3rem;
  --font-size-master-mobile: 2.2rem;
  --font-size-h2: 2.2rem;

  /* master */
  --master-height: 65vh;
  --master-bg-inset: -6%;
  --master-bg-inset-mobile: -3%;

  /* Raised Card */
  --raised-offset: -90px;
  --raised-offset-mobile: -40px;

  /* Dark Section "Bleed" (zieht bis an Card-Rand) */
  --dark-bleed-x: 1.5rem;
  --dark-bleed-x-mobile: 1rem;

  /* Footer */
  --footer-padding-y: 1.5rem;

}


.font-size-1{
    font-size: 1rem !important;
}
.font-size-1-5{
    font-size: 1.5rem !important;
}
.font-size-2{
    font-size: 2rem !important;
}
.font-size-2-5{
    font-size: 2.5rem !important;
}
.font-size-3{
    font-size: 3rem !important;
}
.font-size-3-5{
    font-size: 3.5rem !important;
}
.font-size-4{
    font-size: 4rem !important;
}
.font-size-4-5{
    font-size: 4.5rem !important;
}
.font-size-5{
    font-size: 5rem !important;
}
.font-size-5-5{
    font-size: 5.5rem !important;
}
.font-size-6{
    font-size: 6rem !important;
}
.font-size-6-5{
    font-size: 6.5rem !important;
}
.font-size-7{
    font-size: 7rem !important;
}

.feature .material-icons{
    font-size: 3rem !important;
}

/* =========================================================
   1) Basis / Reset
   ========================================================= */

* {
  box-sizing: border-box;
}



html,
body {
  margin: var(--space-0);
  padding: var(--space-0);
  width: 100%;
  overflow-x: hidden;
  font-family: var(--font-family);
  color: var(--color-text);
  line-height: var(--line-height);
  background-color: var(--color-page-bg);
}

/* Global link colors controlled by Customizer variables */
a {
  color: var(--color-link);
  text-decoration: underline;
  text-underline-offset: 2px;
}

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

a:hover,
a:focus {
  color: var(--color-link-hover);
  text-decoration: underline;
}

/* Make page a column flex layout so footer sticks to bottom when content is short */
body {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

/* Let the main content grow to fill available space (push footer down) */
.main-content {
  flex: 1 0 auto;
}

/* Tastatur-Fokus gut sichtbar machen */
:where(a, button, input, textarea, select):focus-visible {
  outline: 3px solid #66afe9;
  outline-offset: 2px;
}

/* Reset fuer typische Abstaende */
h1,
h2,
h3,
h4,
h5,
p {
  /* margin: var(--space-0); */
}
.archive-title, .entry-title , .page-title{
    margin-top: var(--space-0);
}
/* Skip-Link für Tastaturnutzer */
.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  background: #000;
  color: #fff;
  padding: 0.5rem 0.75rem;
  z-index: 9999;
}
.skip-link:focus,
.skip-link:focus-visible {
  left: 0.5rem;
}

/* Standardabstand innerhalb von Sektionen */
.section > * + * {
  margin-top: var(--space-2);
}

/* Optional: Anker-Spruenge nicht unter Header verstecken */
section {
  scroll-margin-top: calc(var(--header-height) + var(--space-4));
}

/* =========================================================
   2) Layout Container / Breite
   ========================================================= */

.container {
  max-width: var(--page-max);
  margin: var(--main-margin-y, 0px) auto;
  padding: var(--space-0) var(--space-2);
}

/* Override margins inside main only: set left/right as requested */
main .container {
  margin-left: var(--main-container-margin-x, 0px);
  margin-right: var(--main-container-margin-x, 0px);
}

footer .container {
    width: var(--page-width);
}

.main-content {
  width: var(--page-width);
  min-width: var(--page-min);
  max-width: var(--page-max);
  margin: var(--main-margin-y, 0px) auto;
}

/* Global text alignment for main content area */
.main-content,
main .container {
  text-align: var(--text-align-global, left);
}

/* =========================================================
   3) Header (fixed)
   ========================================================= */

.site-header {
  position: fixed;
  top: var(--space-0);
  left: var(--space-0);
  height: var(--header-height);
  width: 100%;
  z-index: 1000;
    padding-top: 5px;
  background: var(--color-header-bg);
  color: var(--color-header-text);
  transition: background 0.35s ease;
}

/* Wenn die WP-Adminbar sichtbar ist, Header nach unten schieben */
.admin-bar .site-header {
  top: calc(var(--space-0) + 32px);
}

@media screen and (max-width: 782px) {
  .admin-bar .site-header {
    top: calc(var(--space-0) + 46px);
  }
}

/* Hintergrundfarbe, wenn beim Scrollen aktiviert */
.site-header.is-scrolled {
  background: var(--color-header2-bg);
}

.header-inner {
  height: var(--header-height);
  display: flex;
  align-items: center;
  justify-content: space-between;

  /* Header-Inhalte genau so breit wie das Main-Layout */
  width: var(--page-width);
  min-width: var(--page-min);
  max-width: var(--page-max);
  margin: 0 auto;
  padding: 0 var(--space-2);

  position: relative;
}

.logo {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.logo img {
  height: var(--logo-height, 4rem);
  width: var(--logo-width, auto);
}

/* Stellt sicher, dass Site-Title und -Subtitle untereinander stehen */
.logo-text {
  display: flex;
  flex-direction: column;
  line-height: 1;
}

.logo .logo-text strong {
  display: block;
  font-size: 1.25rem;
}

.logo .logo-text span {
  display: block;
  font-size: 0.85rem;
  color: var(--color-header-text);
  opacity: 0.95;
  padding-top: 7px;
}

.main-nav ul {
  list-style: none;
  margin: var(--space-0);
  padding: var(--space-0);
  display: flex;
  gap: var(--space-4);
}

.main-nav li {
  position: relative;
}

.main-nav a {
  color: var(--color-header-text);
  text-decoration: none;
}

.main-nav .current-menu-item > a,
.main-nav .current_page_item > a {
  text-decoration: underline;
  text-underline-offset: 6px;
}

/* Dropdowns (Desktop) */
.main-nav .sub-menu {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 260px;
  padding: 10px;
  border-radius: var(--radius-sm);
  background: var(--color-header2-bg);
  box-shadow: var(--shadow-2);
  transform: translateY(10px);
  z-index: 100;
}

/* Verschachtelte Untermenüs (3. Stufe+) seitlich positionieren (Immer links auf Desktop) */
.main-nav .sub-menu .sub-menu {
    top: 0;
    left: auto;
    right: 100%;
    transform: translateX(-10px);
    /*filter: brightness(2); /* Ab Stufe 3 um 8% aufhellen */
    background-color: #383838;
}
/* Hover-Bridge: verhindert "Lücke" zwischen Parent und Submenu */
.main-nav .sub-menu::before {
  content: "";
  position: absolute;
  top: -10px;
  left: 0;
  right: 0;
  height: 10px;
}

/* Seitliche Hover-Bridge für tiefere Ebenen (auf der rechten Seite, da Menü links öffnet) */
.main-nav .sub-menu .sub-menu::before {
  top: 0;
  left: auto;
  right: -10px;
  width: 10px;
  height: 100%;
}

@media (min-width: 901px) {
  .main-nav li:hover > .sub-menu,
  .main-nav li:focus-within > .sub-menu {
    display: block;
  }
}

.main-nav .sub-menu {
  flex-direction: column;
  gap: 0;
}

.main-nav .sub-menu a {
  display: block;
  padding: 0.55rem 0.75rem;
  border-radius: var(--radius-sm);
}

.main-nav .sub-menu a:hover,
.main-nav .sub-menu a:focus {
  background: rgba(255, 255, 255, 0.08);
}

/* Marker für Untermenüs */
.main-nav .menu-item-has-children > a::after {
  content: "\25BE"; /* ▾ */
  display: inline-block;
  margin-left: 0.35rem;
  font-size: 0.85em;
  opacity: 0.9;
}

/* Marker für Untermenüs in Untermenüs (nach links zeigend, aber rechts positioniert) */
.main-nav .sub-menu .menu-item-has-children > a::after {
  content: "\25C2"; /* ◂ */
  float: right;
  margin-left: 0.5rem;
  margin-right: 0;
  margin-top: 0.1rem;
}

/* Standardmäßig öffnen Untermenüs ab der 3. Ebene nun links (siehe oben). 
   Diese Regeln werden nur noch für die 2. Ebene (Top-Level-Dropdown) benötigt, 
   falls dieses am rechten Rand ist. */
.main-nav .menu > .submenu-left > .sub-menu {
  left: auto !important;
  right: 0 !important;
  transform: translateY(10px) !important;
}


/* Mobile Nav Toggle (Hamburger) */
.nav-toggle {
  display: none;
  width: 44px;
  height: 44px;
  padding: 10px;
  border: 1px solid rgba(255, 255, 255, 0.35);
  border-radius: var(--radius-sm);
  background: transparent;
  cursor: pointer;
}

.nav-toggle-bar {
  display: block;
  height: 2px;
  background: var(--color-header-text);
  border-radius: 2px;
}

.nav-toggle-bar + .nav-toggle-bar {
  margin-top: 6px;
}

/* =========================================================
   4) master (hinter dem Header)
   ========================================================= */

.master {
  height: var(--master-height);
  position: relative;
  overflow: hidden;
  background-color: var(--color-page-bg);
  display: flex;
  align-items: center;
  justify-content: center;
}

.master-bg {
  position: absolute;
  inset: var(--master-bg-inset);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  background-image: none;
  will-change: transform;
  transform: translate3d(0, 0, 0);
  transition: opacity 1.6s ease-in-out;
  opacity: 1;
}

/* Inline edit button in Customizer preview */
.maharo-inline-edit-wrap {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
}

.maharo-inline-edit-button {
  z-index: 1200;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: none;
  background: #2b9edb;
  color: #fff;
  box-shadow: 0 2px 6px rgba(0,0,0,0.2);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
.maharo-inline-edit-button .maharo-edit-icon{font-size:16px;line-height:1}

/* Editable title styling in preview */
.maharo-inline-editable[contenteditable="true"] {
  outline: none;
}
.maharo-inline-editable:focus {
  text-decoration: underline dotted rgba(255,255,255,0.85);
}

@media (prefers-reduced-motion: reduce) {
  .site-header {
    transition: none;
  }

  .master-bg {
    transition: none;
  }
}

.master-overlay {
  position: absolute;
  inset: var(--space-0);
  background: var(--color-master-overlay);
  z-index: 1;
}

.master-content {
  position: relative;
  z-index: 2;
  color: var(--color-master-text);
  text-align: center;
  padding-top: 0px;

  opacity: 1;
  transition: opacity 0.5s ease-in-out;
  will-change: opacity;
}

.master-content.is-fading {
  opacity: 0;
}

.master-content h1 {
  font-size: var(--font-size-master);
}

/* =========================================================
   5) Main als „Raised Card“
   ========================================================= */

.main-raised {
  position: relative;
  z-index: 2;

  margin-top: var(--raised-offset);
  padding-bottom: var(--raised-offset);
  background: var(--color-card-bg);
  border-radius: var(--radius-lg) var(--radius-lg) var(--space-0) var(--space-0);

  padding: var(--space-3) var(--space-3) var(--space-3) var(--space-3);

  box-shadow: var(--shadow-1), var(--shadow-2);

  overflow: hidden; /* gegen Margin-Collapsing/Spalt */
}

/* =========================================================
   6) Sektionen / Inhalte
   ========================================================= */

.section {
  padding: var(--space-2) var(--space-2) var(--space-6) var(--space-2);
  text-align: center;
}

.section h2 {
  font-size: var(--font-size-h2);
}

.section-subtitle {
  color: var(--color-muted);
}

.features {
  margin-top: var(--space-6);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--space-4);
}

.feature {
  padding: var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-card-bg);
}

/* Dunkle Sektion (Kontakt) */
.section-dark {
  background: var(--color-section-dark-bg);
  color: var(--color-section-dark-text);

  margin-left: calc(var(--dark-bleed-x) * -1);
  margin-right: calc(var(--dark-bleed-x) * -1);
  padding-left: var(--dark-bleed-x);
  padding-right: var(--dark-bleed-x);
}

/* =========================================================
   7) Kontaktformular
   ========================================================= */

.contact-form {
  max-width: 500px;
  margin: var(--space-4) auto var(--space-0) auto;

  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.contact-form input,
.contact-form textarea {
  padding: 0.75rem; /* optional als Variable, siehe unten */
  border: 1px solid var(--color-form-border);
  border-radius: var(--radius-sm);
}

/* Wenn Sie auch dieses Padding als Variable wollen:
   - oben in :root ergaenzen: --form-field-padding: 0.75rem;
   - dann hier ersetzen: padding: var(--form-field-padding);
*/

.contact-form button {
  padding: 0.75rem; /* optional als Variable wie oben */
  background: var(--color-button-bg);
  color: var(--color-button-text);
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
}

/* Icon Utilities (statt Inline-Styles) */
.icon {
  display: block;
  margin: 0 auto var(--space-1);
  font-size: 36px;
}


/* =========================================================
   8) Footer (direkt am Main, ohne Abstand)
   ========================================================= */

.site-footer {
  width: 100%;
  margin: var(--space-0);
  padding: var(--footer-padding-y) var(--space-0);

  background: var(--color-footer-bg);
  color: var(--color-footer-text);
}

.site-footer .footer-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.site-footer p {
  margin: var(--space-0);
}
.site-footer a {
  color: var(--color-footer-text);
  text-decoration: none;
}
/* =========================================================
   9) Responsive Anpassungen
   ========================================================= */

@media (max-width: 900px) {
  .header-inner {
    width: 100%;
    min-width: 0;
    max-width: 100%;
  }

  .nav-toggle {
    display: inline-flex;
    flex-direction: column;
    justify-content: center;
  }

  /* Nav wird auf Mobile als Dropdown unter dem Header angezeigt */
  .main-nav {
    display: none;
    position: absolute;
    top: var(--header-height);
    left: 0;
    right: 0;
    background: var(--color-header2-bg);
    padding: var(--space-2);
    box-shadow: var(--shadow-2);
  }

  .site-header.nav-open .main-nav {
    display: block;
  }

  .main-nav ul {
    flex-direction: column;
    gap: var(--space-2);
  }

  /* Submenus auf Mobile/Tablet: per Klick öffnen */
  .main-nav .sub-menu {
    display: none;
    position: static;
    min-width: 0;
    padding: 0.25rem 0 0.25rem 0.75rem;
    margin: 0.25rem 0 0.5rem;
    background: transparent;
    box-shadow: none;
    border-left: 2px solid rgba(255, 255, 255, 0.18);
    border-radius: 0;
  }

  .main-nav .menu-item-has-children.submenu-open > .sub-menu {
    display: block;
  }

  /* Desktop-Pfeil ausblenden (wir nutzen einen Klick-Button) */
  .main-nav .menu-item-has-children > a::after {
    content: none;
  }

  .main-nav .menu-item-has-children > a {
    padding-right: 3rem;
  }

  .main-nav .submenu-toggle {
    position: absolute;
    right: 0.25rem;
    top: 50%;
    transform: translateY(-50%);
    width: 34px;
    height: 34px;
    border: none;
    border-radius: var(--radius-sm);
    background: #3b3b3b;
    color: var(--color-header-text);
    font-size: 0;
    line-height: 1;
    cursor: pointer;
  }

  /* Wenn Submenu offen ist, wächst das <li> in der Höhe – Toggle oben am Parent-Item halten */
  .main-nav .menu-item-has-children.submenu-open > .submenu-toggle {
    top: 21%;
  }

  /* kleines Dreieck als Indikator */
  .main-nav .submenu-toggle::before {
    content: "\25B8"; /* ▸ */
    font-size: 18px;
    display: block;
    line-height: 34px;
    text-align: center;
    opacity: 0.9;
  }

  .main-nav .menu-item-has-children.submenu-open > .submenu-toggle::before {
    content: "\25BE"; /* ▾ */
  }

  .main-nav .submenu-toggle:focus,
  .main-nav .submenu-toggle:hover {
    background: rgba(255, 255, 255, 0.08);
  }

  .main-nav a {
    display: block;
    padding: 0.6rem 0.75rem;
    border-radius: var(--radius-sm);
  }

  .main-nav a:focus,
  .main-nav a:hover {
    background: rgba(255, 255, 255, 0.08);
  }

  .main-content {
    width: 100%;
    min-width: 0;
    max-width: 100%;
    padding: var(--space-0) var(--space-2);
  }

  .main-raised {
    margin-top: var(--raised-offset-mobile);
    border-radius: var(--space-0);
  }

  .section-dark {
    margin-left: calc(var(--dark-bleed-x-mobile) * -1);
    margin-right: calc(var(--dark-bleed-x-mobile) * -1);
    padding-left: var(--dark-bleed-x-mobile);
    padding-right: var(--dark-bleed-x-mobile);
  }
}

@media (max-width: 768px) {
  .master-bg {
    inset: var(--master-bg-inset-mobile);
  }

  .master-content h1 {
    font-size: var(--font-size-master-mobile);
  }

  .site-footer .footer-inner {
    flex-direction: column;
    gap: var(--space-1);
  }
}
