
:root {
  --size-6: 1.75rem;
  --size-7: 2rem;
  --size-4: 1.25rem;
  --radius-2: 5px;
  --border-size-1: 1px;
  --size-3: 1rem;
  --radius-3: 1rem;
  --size-1: .25rem;
  --size-9: 4rem;
  --shadow-3: 0 -1px 3px 0 hsl(var(--shadow-color)/calc(var(--shadow-strength) + 2%)),0 1px 2px -5px hsl(var(--shadow-color)/calc(var(--shadow-strength) + 2%)),0 2px 5px -5px hsl(var(--shadow-color)/calc(var(--shadow-strength) + 4%)),0 4px 12px -5px hsl(var(--shadow-color)/calc(var(--shadow-strength) + 5%)),0 12px 15px -5px hsl(var(--shadow-color)/calc(var(--shadow-strength) + 7%));
  --size-8: 3rem;
  --size-2: .5rem;
  --size-5: 1.5rem;
  --gray-10: #16191d;
  --font-size-6: 2.5rem;
  --font-size-4: 1.5rem;
  --shadow-4: 0 -2px 5px 0 hsl(var(--shadow-color)/calc(var(--shadow-strength) + 2%)),0 1px 1px -2px hsl(var(--shadow-color)/calc(var(--shadow-strength) + 3%)),0 2px 2px -2px hsl(var(--shadow-color)/calc(var(--shadow-strength) + 3%)),0 5px 5px -2px hsl(var(--shadow-color)/calc(var(--shadow-strength) + 4%)),0 9px 9px -2px hsl(var(--shadow-color)/calc(var(--shadow-strength) + 5%)),0 16px 16px -2px hsl(var(--shadow-color)/calc(var(--shadow-strength) + 6%));
  --shadow-color: 220 40% 2%;
  --shadow-strength: 25%;
}
/* Farbvariablen (können später getauscht werden) */
:root {
  /* Primärfarbe (Orange) */
  --color-primary: #fd7e14; /* Haupt-Orange */
  --color-primary-200: #ffa24c; /* Helles Orange für Hover-Zustände */

  /* Hintergrundfarben */
  --color-bg: #001427; /* Sehr dunkles Blau – Haupt-Hintergrund */
  --color-bg-soft: #18314a; /* Weicheres Dunkelblau – Sektionen, Hover */

  /* Textfarben */
  --color-text: #f6f4f3; /* Fast-Weiß mit warmem Touch – Fließtext */
  --color-dark: #1f0812; /* Dunkles „Schwarz“ mit weinrotem Unterton – für starke Kontraste */
  --color-dark-accent: #3a0f20; /* Etwas hellerer Rosaton – als dezente Akzentfarbe */

  /* Optional: Muted / Graubereiche */
  --color-muted: #b0b0b0; /* Für Meta-Informationen, dezent sichtbar */

  --color-safety-orange: #fd7e14;
  --color-safety-orange-50: #ffe2ca;
  --color-safety-orange-100: #fed7b6;
  --color-safety-orange-200: #fec18d;
  --color-safety-orange-300: #feaa65;
  --color-safety-orange-400: #fd943c;
  --color-safety-orange-500: #fd7e14;
  --color-safety-orange-600: #d76302;
  --color-safety-orange-700: #9f4901;
  --color-safety-orange-800: #683001;
  --color-safety-orange-900: #301600;
  --color-safety-orange-950: #140900;

  --color-white-smoke: #f6f4f3;
  --color-white-smoke-50: #ffffff;
  --color-white-smoke-100: #ffffff;
  --color-white-smoke-200: #ffffff;
  --color-white-smoke-300: #ffffff;
  --color-white-smoke-400: #ffffff;
  --color-white-smoke-500: #f6f4f3;
  --color-white-smoke-600: #ded7d3;
  --color-white-smoke-700: #c6b9b3;
  --color-white-smoke-800: #ae9c93;
  --color-white-smoke-900: #967e73;
  --color-white-smoke-950: #877165;

  --color-licorice: #1f0812;
  --color-licorice-50: #b12e67;
  --color-licorice-100: #a1295d;
  --color-licorice-200: #80214a;
  --color-licorice-300: #601938;
  --color-licorice-400: #3f1025;
  --color-licorice-500: #1f0812;
  --color-licorice-600: #000000;
  --color-licorice-700: #000000;
  --color-licorice-800: #000000;
  --color-licorice-900: #000000;
  --color-licorice-950: #000000;

  --color-oxford-blue: #001427;
  --color-oxford-blue-50: #0072df;
  --color-oxford-blue-100: #0068ca;
  --color-oxford-blue-200: #0053a1;
  --color-oxford-blue-300: #003e79;
  --color-oxford-blue-400: #002950;
  --color-oxford-blue-500: #001427;
  --color-oxford-blue-600: #000000;
  --color-oxford-blue-700: #000000;
  --color-oxford-blue-800: #000000;
  --color-oxford-blue-900: #000000;
  --color-oxford-blue-950: #000000;
}
/*
Montserrat – Überschriften
Open Sans – Fließtext
Vollkorn – Akzente / Unterüberschriften
Varela Round – Logo
*/
/* Open Sans – Fließtext */
@font-face {
    font-family: 'Open Sans';
    src: url('../fonts/open-sans-light.woff2') format('woff2');
    font-weight: 300;
    font-style: normal;
    font-display: swap;
  }
@font-face {
    font-family: 'Open Sans';
    src: url('../fonts/open-sans-regular.woff2') format('woff2');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
  }
@font-face {
    font-family: 'Open Sans';
    src: url('../fonts/open-sans-bold.woff2') format('woff2');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
  }
/* Montserrat – Überschriften */
@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/montserrat-regular.woff2') format('woff2');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
  }
@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/montserrat-bold.woff2') format('woff2');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
  }
/* Vollkorn – Akzente / Unterüberschriften */
@font-face {
    font-family: 'Vollkorn';
    src: url('../fonts/vollkorn-regular.woff2') format('woff2');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
  }
@font-face {
    font-family: 'Vollkorn';
    src: url('../fonts/vollkorn-italic.woff2') format('woff2');
    font-weight: 400;
    font-style: italic;
    font-display: swap;
  }
@font-face {
    font-family: 'Courier Prime';
    src: url('../fonts/courier-prime-bold.woff2') format('woff2');
    font-weight: 700;
    font-style: bold;
    font-display: swap;
  }
body {
    font-family: 'Open Sans', sans-serif;
    font-weight: 300;
    font-size: 1.1rem;
    line-height: 1.6;
    background-color: var(--color-oxford-blue-400);
    margin: 0;
    color: var(--color-white-smoke);
    overflow-x: hidden;
  }
h1, h2, h3, .logo {
    font-family: 'Montserrat', sans-serif;
    font-weight: 700;
    line-height: 1.2;
  }
.accent,
  h4 {
    font-family: 'Vollkorn', serif;
    font-weight: 400;
    /*font-style: italic;*/
    font-size: 1.2rem;
  }
.features {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--size-6);
    padding: var(--size-7);
    background-color: var(--color-oxford-blue-500);
  }
.features-wrapper {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    max-width: 1200px;
    margin: 0 auto;
    gap: var(--size-4);
  }
.feature {
    /*background: white;*/
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: var(--size-4);
    border-radius: var(--radius-2);
    border: var(--border-size-1) solid var(--color-white-smoke);
    transition: box-shadow 0.3s ease;
    /*box-shadow: var(--shadow-1);*/
  }
.feature:hover {
    /*box-shadow: 0 0 12px rgba(246, 244, 243, 0.1);*/
    box-shadow: 0 0 8px var(--color-safety-orange);
  }
.feature button {
    margin-top: auto;
  }
.feature-details {
    margin-top: var(--size-3);
    background-color:  var(--color-white-smoke);
    color: var(--color-licorice);
    padding: var(--size-3);
    border-left: 4px solid var(--color-safety-orange);
    border-radius: var(--radius-3);
    overflow: hidden;
    transition: all 0.3s ease;
  }
@media (max-width: 640px) {
    .features-wrapper {
      grid-template-columns: 1fr;
    }
  
    .feature {
      padding: var(--size-4) var(--size-3);
    }
  
    .feature-details {
      font-size: 0.95rem;
    }
  }
.ueberuns {
    max-width: 1200px;
    margin: var(--size-4) auto;
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: var(--size-1);
    /*padding: var(--size-2);*/
    background-color: var(--color-oxford-blue-400);
    color: var(--color-white-smoke);
  }
.ueberuns i {
    font-size: 1.5rem;
    color: var(--color-safety-orange);
  }
@media (max-width: 640px) {

    .ueberuns {
      grid-template-columns: 1fr;
      padding: var(--size-4);
    }
  
    .ueberuns i {
      font-size: 2rem;
    }
  }
.course-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: var(--size-6);
    padding: var(--size-7) 0;
  }
.course-overview {
    max-width: 1200px;
    margin: var(--size-4) auto;
    background-color: var(--color-oxford-blue);
    padding: var(--size-4) var(--size-9);
    border-radius: var(--radius-3);
    box-shadow: var(--shadow-3);
  }
.course-detail {
    max-width: 800px;
    margin: var(--size-4) auto;
    padding: var(--size-3) var(--size-6) var(--size-8) var(--size-6);
    background: var(--color-white-smoke);
    color: var(--color-licorice);
    border-radius: var(--radius-3);
  }
.course-detail h1, .course-detail h2 {
    margin-bottom: var(--size-2);
  }
.content-booking {
    max-width: 1200px;
    margin: var(--size-4) auto;
    padding: var(--size-4) var(--size-9);
    background: var(--color-oxford-blue-500);
    color: var(--color-white-smoke);
    border-radius: var(--radius-3);
  }
.booking-form {
    display: flex;
    flex-direction: column;
    gap: var(--size-6);
  }
.booking-card {
    background: var(--color-white-smoke);
    color: var(--color-licorice);
    padding: var(--size-4) var(--size-5);
    border-radius: var(--radius-3);
    box-shadow: var(--shadow-3);
  }
.booking-card h2 {
    font-size: 1.2rem;
    margin-bottom: var(--size-2);
    font-weight: bold;
    color: var(--color-licorice);
  }
.form-group {
    display: flex;
    flex-direction: column;
    margin-bottom: var(--size-3);
  }
.form-group input,
  .form-group textarea,
  .form-group select {
    padding: var(--size-2);
    border: 2px solid var(--color-licorice-40);
    border-radius: var(--radius-2);
    background: white;
    color: var(--color-licorice);
    font-size: 1rem;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
  }
/* Fokus für Tastaturbedienung oder Klick */
.form-group input:focus,
  .form-group textarea:focus,
  .form-group select:focus {
    outline: none;
    border-color: var(--color-safety-orange);
    box-shadow: 0 0 0 3px rgba(253, 126, 20, 0.3); /* orange wie in deinem Farbschema */
  }
/* Checkboxen & Radiobuttons – Grundaussehen */
input[type="checkbox"],
input[type="radio"] {
  accent-color: var(--color-safety-orange); /* modern, funktioniert in allen modernen Browsern */
  width: 1.2em;
  height: 1.2em;
  vertical-align: middle;
  margin-right: 0.5em;
  margin-bottom: var(--size-1);
  cursor: pointer;
}
/* Labels daneben: bessere Lesbarkeit und Abstand */
.form-group label {
  margin-bottom: var(--size-1);
  gap: var(--size-2);
  font-weight: 500;
  cursor: pointer;
}
/* Fokus für Tastaturbedienung */
input[type="checkbox"]:focus,
input[type="radio"]:focus {
  outline: 2px solid var(--color-safety-orange);
  outline-offset: 2px;
}
.radio-group {
  display: flex;
  flex-direction: column;
  /*gap: var(--size-2);*/
}
.form-section {
    margin-bottom: var(--size-6);
    color: var(--color-licorice);
    padding: var(--size-4);
    border: 1px solid var(--color-licorice);
    border-radius: var(--radius-2);
    background: var(--color-white-smoke);
  }
.form-section legend {
    background-color: var(--color-white-smoke);
    border-radius: var(--radius-2);
    padding: var(--size-2) var(--size-4);
    font-weight: bold;
    margin-bottom: var(--size-2);
  }
.site-footer {
    background-color: var(--color-oxford-blue-500);
    color: var(--color-white-smoke);
    padding: var(--size-4);
    text-align: center;
    font-size: 0.9rem;
  }
.footer-container {
    max-width: 1200px;
    margin: 0 auto;
  }
.footer-links {
    display: flex;
    justify-content: center;
    gap: var(--size-3);
    margin-top: var(--size-2);
  }
.footer-links a {
    color: white;
    text-decoration: underline;
  }
html, body {
    height: 100%;
    margin: 0;
  }
body {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
  }
.page-wrapper {
    flex: 1; /* Das füllt den restlichen Platz */
    /*padding: var(--size-4) var(--size-6); /* oder was du sonst nutzt */
  }
input[type="checkbox"].checkbox {
    transform: scale(1.2);
    margin-right: 0.5rem;
  }
.checkbox-label {
    display: flex;
    align-items: center;
    gap: 0.5em;
  }
.thankyou {
    text-align: center;
    max-width: 800px;
    min-height: 800px;
    margin: var(--size-4) auto;
    padding: var(--size-4) var(--size-6);
    background: var(--color-white-smoke);
    color: var(--color-licorice);
    border-radius: var(--radius-3);
  }
.kontakt-flex {
    display: flex;
    flex-wrap: wrap;
    gap: var(--size-6);
    margin-top: var(--size-4);
  }
.kontakt-daten {
    flex: 1 1 300px;
    font-size: 1rem;
  }
.kontakt-daten a {
    color: var(--color-safety-orange);
    text-decoration: none;
  }
.kontakt-karte {
    flex: 1 1 400px;
  }
.map-consent {
    padding: var(--size-4);
    background: var(--color-white-smoke);
    border-radius: var(--radius-2);
    border: 2px dashed var(--color-safety-orange);
    text-align: center;
    color: var(--color-licorice);
  }
.map-footer {
    text-align: center;
    margin-top: var(--size-2);
    font-size: 0.875rem;
  }
.map-footer a {
    color: var(--color-orange);
    text-decoration: underline;
  }
.legal-page {
    max-width: 1200px;
    margin: var(--size-4) auto;
    padding: var(--size-4) var(--size-6);
    background: var(--color-white-smoke);
    color: var(--color-licorice);
    border-radius: var(--radius-3);
  }
.search-form {
    display: flex;
    align-items: center;
    gap: 0.5rem;
  }
.search-form input {
    padding: 0.5rem;
    border-radius: var(--radius-2);
    border: 1px solid var(--gray-10);
    font-size: 1rem;
  }
.search-form button {
    background: var(--color-safety-orange);
    color: var(--color-licorice);
    border: none;
    padding: 0.5rem 0.75rem;
    border-radius: var(--radius-2);
    cursor: pointer;
  }
.faq-container {
    max-width: 1200px;
    min-height: calc(100vh - 350px);
    background: var(--color-oxford-blue);
    color: var(--color-white-smoke);
    margin: var(--size-4) auto;
    padding: var(--size-3) var(--size-6) var(--size-8) var(--size-6);
    border-radius: var(--radius-3);
  }
.faq-btn {
    display: flex;
    align-items: center;
    gap: var(--size-3);
    padding: var(--size-2) var(--size-4);
    background-color: var(--color-white-smoke) !important;
    color: var(--color-licorice);
    border: none;
    border-radius: var(--radius-2);
    text-decoration: none;
    font-weight: 700;
    transition: background-color 0.3s ease;
    font-size: var(--size-3);
    text-align: left;
    width: 100%;
  }
.faq-btn:hover {
    background-color: var(--color-safety-orange-200) !important;
  }
.faq-icon {
     color: var(--color-safety-orange);
 }
.answer {
     color: var(--color-white-smoke);
     margin-left: var(--size-7);
     margin-top: var(--size-3);
     padding: var(--size-1) var(--size-4);
     background-color: var(--color-white-smoke);
     color: var(--color-licorice);
     border: none;
     border-radius: var(--radius-2);
     font-size: var(--size-3);
     font-weight: 400;
 }
/* Komponenten */
.btn {
    background-color: var(--color-safety-orange);
    color: var(--color-licorice);
    padding: var(--size-2) var(--size-4);
    border: none;
    border-radius: var(--radius-2);
    cursor: pointer;
    margin-top: var(--size-3);
    font-size: var(--size-3);
    font-family: "Open Sans", sans-serif;
    font-weight: 600;
  }
.navbar {
    background-color: var(--color-oxford-blue);
    padding: var(--size-3) var(--size-4);
    position: sticky;
    top: 0;
    z-index: 100;
  }
.navbar-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 1200px;
    margin: 0 auto;
  }
.logo {
    font-family: 'Courier Prime', 'Courier New', monospace;
    font-weight: bold;
    font-size: var(--font-size-6);
    text-decoration: none;
    color: var(--color-white-smoke);
  }
.logo .cursor {
    color: var(--color-safety-orange);
  }
.nav-links {
    display: flex;
    gap: var(--size-4);
  }
.nav-links a {
    text-decoration: none;
    color: white;
    font-weight: 500;
    position: relative;
  }
.nav-links a::after {
    content: '';
    display: block;
    height: 2px;
    background: var(--safety-orange);
    transform: scaleX(0);
    transition: transform 0.3s ease;
    transform-origin: left;
  }
.nav-links a:hover::after {
    transform: scaleX(1);
  }
.burger {
    display: none;
    background: none;
    border: none;
    font-size: var(--font-size-4);
    color: white;
    cursor: pointer;
  }
/* Mobile */
@media (max-width: 768px) {
    .burger {
      display: block;
    }
  
    .nav-links {
      position: absolute;
      top: 100%;
      right: 0;
      background: var(--color-oxford-blue);
      flex-direction: column;
      align-items: flex-start;
      padding: var(--size-4);
      width: 200px;
      transform: scaleY(0);
      transform-origin: top;
      transition: transform 0.2s ease-out;
      visibility: hidden;
      opacity: 0;
    }
  
    .nav-links.open {
      transform: scaleY(1);
      visibility: visible;
      opacity: 1;
    }
  }
.burger-lines {
    display: inline-block;
    width: 24px;
    height: 2px;
    background: white;
    position: relative;
    transition: all 0.3s ease-in-out;
    transform-origin: center;
  }
.burger-lines::before,
  .burger-lines::after {
    content: '';
    position: absolute;
    left: 0;
    width: 24px;
    height: 2px;
    background: var(--color-white-smoke);
    transition: all 0.3s ease-in-out;
    transform-origin: center;
  }
.burger-lines::before {
    top: -8px;
  }
.burger-lines::after {
    top: 8px;
  }
/* Animation: zu X */
.burger-lines.open {
    background-color: transparent;
  }
.burger-lines.open::before {
    top: 0;
    transform: rotate(45deg);
  }
.burger-lines.open::after {
    top: 0;
    transform: rotate(-45deg);
  }
.hero {
    background: url("../img/hero.png") center/cover no-repeat;
    padding: var(--size-9) 0;
    position: relative;
  }
.hero-overlay {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: auto auto;
    gap: var(--size-6);
    max-width: 1200px;
    margin: 0 auto;
    padding: var(--size-6);
  }
.hero-card {
    background: var(--color-white-smoke);
    color: var(--color-licorice);
    padding: var(--size-5);
    border-radius: var(--radius-3);
    box-shadow: var(--shadow-3);
  }
/*.hero-card:nth-child(3) {
    grid-column: span 2;
  }*/
.hero-card h1 {
    font-size: var(--font-size-4);
  }
.hero-card h2 {
    font-weight: 600;
    margin-top: var(--size-2);
  }
@media (max-width: 768px) {
    .hero-overlay {
      grid-template-columns: 1fr;
    }
  
    .hero-card:nth-child(3) {
      grid-column: auto;
    }
  }
.hero-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: var(--size-3); 
    margin-top: var(--size-3);
  }
@media (max-width: 640px) {
    .hero-buttons {
      flex-direction: column;
      align-items: stretch;
    }
  
    /*.hero-buttons .btn {
      width: 100%;
    }*/
  }
.card {
    display:flex;
    flex-direction: column;
    justify-content: space-between;
    background: var(--color-white-smoke);
    color: var(--color-licorice);
    padding: var(--size-2) var(--size-5);
    border-radius: var(--radius-3);
    box-shadow: var(--shadow-3);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    max-width: 600px;
    margin: 0 auto;
  }
.card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-4);
  }
.untertitel {
    font-family: 'Vollkorn', serif;
    font-style: italic;
    margin-top: var(--size-2);
    font-weight: 400;
    color: var(--color-licorice);
  }
.card-preis {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-licorice);
    margin-top: var(--size-2);
    text-align: left;
    margin-top: auto;
  }
.voll {
    color: var(--color-licorice-50);
  }
.card-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: var(--size-3);
  }
.details-btn {
    white-space: nowrap;
    padding: var(--size-2) var(--size-4);
    background-color: var(--color-safety-orange);
    color: var(--color-licorice);
    border: none;
    border-radius: var(--radius-2);
    text-decoration: none;
    font-weight: 600;
    transition: background-color 0.3s ease;
    font-size: var(--size-3);
  }
.details-btn:hover {
    background-color: var(--color-safety-orange-600);
  }
.card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--size-4);
  }
.kurs-labels {
    display: flex;
    gap: var(--size-2);
  }
.kurs-labels i {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.0rem;
    height: 2.0rem;
    background-color: var(--color-licorice-50);
    border-radius: var(--radius-2);
    color: var(--color-white-smoke);
    font-size: 1.5rem;
    transition: background-color 0.2s ease;
  }
.kurs-label:hover {
    background-color: var(--color-licorice);
  }
.mwst {
    font-size: 0.9rem;
    font-weight: 400;
    color: var(--color-licorice);
  }