/* =========================================
 * Beyond Steps – Website V5
 * Cosmic Sunrise (OE & Coaching)
 * =======================================*/


/*=====================================================
=                                                     =
=      =
=                                                     =
=====================================================*/


/* ==================================================
   ===                                            ===
   ===                                            ===
   === Local fonts (SIL OFL)                      ===
   ===   eindeutige Family-Namen                  ===
   ===                                            ===
   ================================================== */


/* Bebas Neue – Logo BEYOND */
@font-face{
  font-family: "Bebas Neue";                                /* Schriftfamilie */
  src: url("../assets/fonts/bebas-neue/bebas-neue-v15-latin-regular.woff2") format("woff2"); /* src */
  font-weight: 400;                                         /* Regular */
  font-style: normal;                                       /* Schriftschnitt */
  font-display: swap;                                       /* font-display */
}

/* Source Sans 3 – Logo STEPS & Boxen-Body */
@font-face{
  font-family: "Source Sans 3";                             /* Schriftfamilie */
  src: url("../assets/fonts/source-sans-3/source-sans-3-v19-latin-regular.woff2") format("woff2"); /* src */
  font-weight: 400;                                         /* Schriftstärke */
  font-style: normal;                                       /* Schriftschnitt */
  font-display: swap;                                       /* font-display */
}
@font-face{
  font-family: "Source Sans 3";                             /* Schriftfamilie */
  src: url("../assets/fonts/source-sans-3/source-sans-3-v19-latin-italic.woff2") format("woff2"); /* src */
  font-weight: 400;                                         /* Schriftstärke */
  font-style: italic;                                       /* Schriftschnitt */
  font-display: swap;                                       /* font-display */
}
@font-face{
  font-family: "Source Sans 3";                             /* Schriftfamilie */
  src: url("../assets/fonts/source-sans-3/source-sans-3-v19-latin-700.woff2") format("woff2"); /* src */
  font-weight: 700;                                         /* Schriftstärke */
  font-style: normal;                                       /* Schriftschnitt */
  font-display: swap;                                       /* font-display */
}
@font-face{
  font-family: "Source Sans 3";                             /* Schriftfamilie */
  src: url("../assets/fonts/source-sans-3/source-sans-3-v19-latin-700italic.woff2") format("woff2"); /* src */
  font-weight: 700;                                         /* Schriftstärke */
  font-style: italic;                                       /* Schriftschnitt */
  font-display: swap;                                       /* font-display */
}

/* Inter — mit eindeutigem Namen "InterLocal", um Windows-Inter auszuschließen */
@font-face{
  font-family: "InterLocal";                                /* Schriftfamilie */
  src: url("../assets/fonts/inter/Inter-ExtraLight.woff2") format("woff2"); /* src */
  font-weight: 200;                                         /* ExtraLight */
  font-style: normal;                                       /* Schriftschnitt */
  font-display: swap;                                       /* font-display */
}
@font-face{
  font-family: "InterLocal";                                /* Schriftfamilie */
  src: url("../assets/fonts/inter/Inter-ExtraLightItalic.woff2") format("woff2"); /* src */
  font-weight: 200;                                         /* Schriftstärke */
  font-style: italic;                                       /* Schriftschnitt */
  font-display: swap;                                       /* font-display */
}
/* Inter 400/600/700 (v19 latin) – liegen jetzt auch im /inter-Ordner */
@font-face{
  font-family: "InterLocal";                                /* Schriftfamilie */
  src: url("../assets/fonts/inter/inter-v19-latin-regular.woff2") format("woff2"); /* src */
  font-weight: 400;                                         /* Schriftstärke */
  font-style: normal;                                       /* Schriftschnitt */
  font-display: swap;                                       /* font-display */
}
@font-face{
  font-family: "InterLocal";                                /* Schriftfamilie */
  src: url("../assets/fonts/inter/inter-v19-latin-600.woff2") format("woff2"); /* src */
  font-weight: 600;                                         /* Schriftstärke */
  font-style: normal;                                       /* Schriftschnitt */
  font-display: swap;                                       /* font-display */
}
@font-face{
  font-family: "InterLocal";                                /* Schriftfamilie */
  src: url("../assets/fonts/inter/inter-v19-latin-700.woff2") format("woff2"); /* src */
  font-weight: 700;                                         /* Bold */
  font-style: normal;                                       /* Schriftschnitt */
  font-display: swap;                                       /* font-display */
}
/* Optional: Inter 800 (ExtraBold) – nur wenn benötigt */
@font-face{
  font-family: "InterLocal";                                /* Schriftfamilie */
  src: url("../assets/fonts/inter/Inter-ExtraBold.woff2") format("woff2"); /* src */
  font-weight: 800;                                         /* Schriftstärke */
  font-style: normal;                                       /* Schriftschnitt */
  font-display: swap;                                       /* font-display */
}
@font-face{
  font-family: "InterLocal";                                /* Schriftfamilie */
  src: url("../assets/fonts/inter/Inter-ExtraBoldItalic.woff2") format("woff2"); /* src */
  font-weight: 800;                                         /* Schriftstärke */
  font-style: italic;                                       /* Schriftschnitt */
  font-display: swap;                                       /* font-display */
}

/* Optional: Manrope — nur falls du sie irgendwo verwendest (eindeutiger Name "ManropeLocal") */
@font-face{
  font-family: "ManropeLocal";                              /* Schriftfamilie */
  src: url("../assets/fonts/manrope/manrope-v20-latin-regular.woff2") format("woff2"); /* src */
  font-weight: 400;                                         /* Schriftstärke */
  font-style: normal;                                       /* Schriftschnitt */
  font-display: swap;                                       /* font-display */
}
@font-face{
  font-family: "ManropeLocal";                              /* Schriftfamilie */
  src: url("../assets/fonts/manrope/manrope-v20-latin-600.woff2") format("woff2"); /* src */
  font-weight: 600;                                         /* Schriftstärke */
  font-style: normal;                                       /* Schriftschnitt */
  font-display: swap;                                       /* font-display */
}
@font-face{
  font-family: "ManropeLocal";                              /* Schriftfamilie */
  src: url("../assets/fonts/manrope/manrope-v20-latin-700.woff2") format("woff2"); /* src */
  font-weight: 700;                                         /* Schriftstärke */
  font-style: normal;                                       /* Schriftschnitt */
  font-display: swap;                                       /* font-display */
}


/* 00. Vars – Position & Größen
 * -------------------------------------*/

:root {
  /* Display / Headlines */
  --font-display: "Bebas Neue", system-ui, sans-serif;

  /* Body / Standard-Text */
  --font-text: "InterLocal", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;

  /* Alternative Body (weicher, editorial) */
  --font-text-alt: "Source Sans 3", "InterLocal", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;

  /* UI / Compact (optional, modern weich) */
  --font-ui: "ManropeLocal", "InterLocal", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;

  /* weights */
  --fw-regular: 400;
  --fw-medium: 500;
  --fw-semibold: 600;
  --fw-bold: 700;
  --fw-light: 200;
  --fw-display: 400;

  /* sizes (optional) */
  --fs-body: 16px;
  --fs-small: 13px;
  --fs-h2: clamp(38px, 4vw, 56px);


  /* Header / Global */
  --bs-v5-logo-pos-x: 2.4rem;  /* Abstand vom linken Rand */
  --bs-v5-logo-pos-y: 1.6rem;  /* Abstand vom oberen Rand */
  --bs-v5-logo-scale: 1.55;
  --bs-v5-about-right: 2.4rem;

  /* Claim-Typografie */
  --bs-v5-claim-font-size: clamp(1.0rem, 0.7rem + 0.5vw, 1.5rem);
  --bs-v5-claim-font-weight: 400;                                 /* 300 = light, 400 = normal, 500/600 = kräftiger */
  --bs-v5-claim-font-style: italic;                               /* normal oder italic */
  --bs-v5-claim-line-height: 1.7;

  /* Positionen im Raum */
  --bs-v5-claim-offset: -14vh;   /* höher = negativer */
  --bs-v5-segments-offset: -5vh; /* Cards nach oben/unten schieben */

  /* Höhe der Karten */
  --bs-v5-card-min-height: 233px;

  /* 🔧 Card-Global */
  --bs-v5-card-alpha: 0.15;                                   /* Transparenz beider Karten */
  --bs-v5-card-radius: 24px;                                  /* Abrundung */
  --bs-v5-card-blur: 15px;                                    /* Glas-Effekt Intensität */
  --bs-v5-card-shadow: 0 20px 50px rgba(0, 0, 0, 0.42);
  --bs-v5-card-border-color: rgba(255, 255, 255, 0.12);
  --bs-v5-card-gradient-angle: to bottom right;

  /* 🎨 Farben OE (links) – rgb ohne Alpha */
  --bs-v5-card-org-color-1: 20, 80, 120;                      /* heller Bereich */
  --bs-v5-card-org-color-2: 10, 30, 50;                       /* dunkler Bereich */

  /* 🎨 Farben Coaching (rechts) – rgb ohne Alpha */
  --bs-v5-card-coach-color-1: 180, 90, 30;                    /* heller Bereich */
  --bs-v5-card-coach-color-2: 120, 50, 20;                    /* dunkler Bereich */

  /* Hover-Effekt der Karten */
  --bs-v5-card-hover-scale: 1.015;
  --bs-v5-card-hover-translate-y: -6px;
  --bs-v5-card-hover-shadow: 0 28px 70px rgba(0, 0, 0, 0.55);

  /* Footer */
  --bs-v5-footer-bottom: 1.8rem;
  --bs-v5-footer-padding-x: 2.4rem;
  --bs-v5-footer-font-size: 0.82rem;
}

/* ==================================================
   ===                                            ===
   ===                                            ===
   === Fonts Global                               ===
   ===                                            ===
   ===                                            ===
   ================================================== */

html, body{
  font-family: var(--font-text);
  font-weight: var(--fw-regular);
  font-size: var(--fs-body);
  font-synthesis: none;
}

h1, h2, .bs-hero__title{
  font-family: var(--font-display);
  font-weight: 400;
  letter-spacing: 0.04em;
}

/* Mini-Header / Subheads */
.bs-sub-intro__kicker,
.oe-panel__sub,
.oew-subhead,
.oe-kern-panel__h{
  font-family: var(--font-text);
  font-weight: var(--fw-semibold);
  font-size: var(--fs-small);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* SVG: default Inter */
svg, svg text{
  font-family: var(--font-text);
  font-synthesis: none;
}

/* SVG: optional Display */
svg .svg-display, svg text.svg-display{
  font-family: var(--font-display);
  font-weight: 400;
}



/* 01. Basics
 * -------------------------------------*/

*,
*::before,
*::after {
  box-sizing: border-box;
}



.bs-v5-body {
  margin: 0;
  min-height: 100vh;
  font-family: var(--font-text);
  color: #ffffff;
  background-color: #030510; /* Fallback falls Bild nicht lädt */
}

/* Links allgemein */
a {
  color: inherit;
  text-decoration: none;
}

a:hover,
a:focus-visible {
  text-decoration: underline;
}

/* Images */
img {
  max-width: 100%;
  height: auto;
  display: block;
}

/* 02. Hero – Vollbild-Hintergrund
 * -------------------------------------*/

.bs-v5-hero {
  position: relative;
  min-height: 100vh;

  /* Hintergrundbild – dein Universe-Nebel */
  background-image: url("../assets/img/backgrounds/bg-universe-07.png");
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  background-attachment: fixed; /* Parallax-Effekt auf Desktop */
}

/* leichte Verdunkelung & Farbübergänge, damit Text lesbar bleibt */
.bs-v5-hero__overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 50% 10%, rgba(0, 0, 0, 0.00), rgba(0, 0, 0, 0.0)),
    linear-gradient(to bottom, rgba(0, 0, 0, 0.05), rgba(0, 0, 0, 0.00));
}

/* Innenraum für Inhalte */
.bs-v5-hero__inner {
  position: relative;
  z-index: 1; /* über dem Overlay */
  min-height: 100vh;

  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;

  padding: 2.4rem;
}

/* 03. Logo – oben links, frei justierbar
 * -------------------------------------*/

/* 03. Logo – oben links, frei justierbar */
.bs-v5-logo {
  position: fixed;
  left: var(--bs-v5-logo-pos-x);
  top: var(--bs-v5-logo-pos-y);
  z-index: 30;

  display: inline-flex;
  align-items: center;
  gap: 0.55rem;

  transform-origin: top left;
  transform: scale(var(--bs-v5-logo-scale));

  text-decoration: none;
  color: #ffffff;
}

.bs-v5-logo__icon {
  height: calc(32px * var(--bs-v5-logo-scale));
  width: auto;
}

.bs-v5-logo__text {
  font-size: calc(1.25rem * var(--bs-v5-logo-scale));
  font-family: var(--font-display);
  letter-spacing: 0.03em;
}


/* 04. Über mich – oben rechts
 * -------------------------------------*/

.bs-v5-about {
  position: fixed;
  top: var(--bs-v5-logo-pos-y);      /* gleiche Höhe wie Logo */
  right: var(--bs-v5-about-right);
  z-index: 30;

  font-size: 0.95rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;

  padding: 0.4rem 0.9rem;
  border-radius: 999px;

  background: rgba(3, 5, 16, 0.0);
  backdrop-filter: blur(10px);
  border: 0px solid rgba(255, 255, 255, 0.35);

  text-decoration: none;
  color: #ffffff;
}

.bs-v5-about:hover,
.bs-v5-about:focus-visible {
  background: rgba(3, 5, 16, 0.4);
  text-decoration: none;
}

/* 05. Claim – zentrale Botschaft
 * -------------------------------------*/

.bs-v5-claim {
  text-align: center;
  max-width: 40rem;

  /* steuerbar über Variable */
  transform: translateY(var(--bs-v5-claim-offset));
}

.bs-v5-claim-text {
  margin: 0;
  font-family: var(--font-text);
  font-weight: var(--bs-v5-claim-font-weight);
  font-style: var(--bs-v5-claim-font-style);
  line-height: var(--bs-v5-claim-line-height);
  font-size: var(--bs-v5-claim-font-size);
  text-shadow: 0 8px 30px rgba(0, 0, 0, 0.7);
}

/* 06. Segmente – OE & Coaching
 * -------------------------------------*/

.bs-v5-segments {
  margin-top: 3.2rem;
  width: 100%;
  max-width: 960px;

  display: flex;
  flex-direction: column;
  gap: 1.6rem;

  transform: translateY(var(--bs-v5-segments-offset));
}

.bs-v5-card {
  flex: 1 1 0;
  padding: 2.4rem 2.6rem;
  border-radius: var(--bs-v5-card-radius);

  backdrop-filter: blur(var(--bs-v5-card-blur));
  box-shadow: var(--bs-v5-card-shadow);
  border: 1px solid var(--bs-v5-card-border-color);

  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;        /* zentriert Inhalt horizontal */
  text-align: center;         /* Text zentriert */

  text-decoration: none;      /* Link ohne Unterstreichung */
  color: inherit;
  transform: translateY(0) scale(1);
  transition:
    transform 0.22s ease-out,
    box-shadow 0.22s ease-out,
    background 0.22s ease-out,
    border-color 0.22s ease-out;
  cursor: pointer;

  min-height: var(--bs-v5-card-min-height);
}

/* Hover/Focus-Effekt – Pop */
.bs-v5-card:hover,
.bs-v5-card:focus-visible {
  transform: translateY(var(--bs-v5-card-hover-translate-y))
             scale(var(--bs-v5-card-hover-scale));
  box-shadow: var(--bs-v5-card-hover-shadow);
  text-decoration: none;
}

/* Linke Karte – Organisationsentwicklung */
.bs-v5-card--org {
  position: relative;
  overflow: hidden;
  background: linear-gradient(
    var(--bs-v5-card-gradient-angle),
    rgba(var(--bs-v5-card-org-color-1), calc(var(--bs-v5-card-alpha) + 0.06)),
    rgba(var(--bs-v5-card-org-color-2), calc(var(--bs-v5-card-alpha) - 0.04))
  );
}

.bs-v5-card--org::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 16px; /* weicher Glow */
  background: linear-gradient(
      to bottom,
      rgba(255, 230, 190, 0.35),
      rgba(255, 230, 190, 0)
  );
  pointer-events: none;
}

/* Rechte Karte – Coaching */
.bs-v5-card--coach {
  position: relative;
  overflow: hidden;
  background: linear-gradient(
    var(--bs-v5-card-gradient-angle),
    rgba(var(--bs-v5-card-coach-color-1), calc(var(--bs-v5-card-alpha) + 0.06)),
    rgba(var(--bs-v5-card-coach-color-2), calc(var(--bs-v5-card-alpha) - 0.04))
  );
}

.bs-v5-card--coach::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 16px;
  background: linear-gradient(
      to bottom,
      rgba(120, 150, 255, 0.22),
      rgba(120, 150, 255, 0)
  );
  pointer-events: none;
}

/* Typografie in den Karten – für BEIDE identisch */

.bs-v5-card__title {
  margin: 0 0 1.0rem;
  font-size: clamp(1.6rem, 1.3rem + 0.6vw, 2.1rem);
  font-weight: 400;
  font-family: var(--font-display);
  font-weight: var(--fw-display);
  letter-spacing: 0.04em;
}

.bs-v5-card__subtitle {
  margin: 0.75rem 0 0;
  font-size: 0.95rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  opacity: 0.9;
  font-family: var(--font-text);
  font-weight: var(--fw-semibold);
}

/* Divider zwischen Titel & Untertitel */

.bs-v5-card__divider {
  width: 100%;
  max-width: 260px;
  height: 1px;
  margin: 0 auto;
  background: linear-gradient(
    to right,
    transparent,
    rgba(255, 255, 255, 0.75),
    transparent
  );
  opacity: 0.85;
}



/* 08. Footer
 * -------------------------------------*/

.bs-v5-footer {
  position: fixed;
  left: 0;
  right: 0;
  bottom: var(--bs-v5-footer-bottom);
  z-index: 20;

  padding: 0 var(--bs-v5-footer-padding-x);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.2rem;

  font-size: var(--bs-v5-footer-font-size);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.85);
}

.bs-v5-footer__left {
  opacity: 0.85;
  white-space: nowrap;
}

.bs-v5-footer__nav {
  display: flex;
  align-items: center;
  gap: 1.6rem;
}

.bs-v5-footer__nav a {
  text-decoration: none;
  opacity: 0.9;
}

.bs-v5-footer__nav a:hover,
.bs-v5-footer__nav a:focus-visible {
  text-decoration: underline;
  opacity: 1;
}



/* 06. Utilities
 * -------------------------------------*/

.u-visually-hidden {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

/* 07. Responsive Tweaks
 * -------------------------------------*/

@media (min-width: 800px) {

  /* NICHTS im :root überschreiben! */

  .bs-v5-hero__inner {
    padding: 2.4rem 3.2rem;
  }

  .bs-v5-claim {
    transform: translateY(var(--bs-v5-claim-offset));
  }

  .bs-v5-segments {
    flex-direction: row;
    gap: 2.4rem;
    margin-top: 3.6rem;
  }
}

/* Mobile-Optimierung */
@media (max-width: 600px) {
  :root {
    --bs-v5-claim-font-size: clamp(0.95rem, 0.9rem + 0.3vw, 1.1rem);
    --bs-v5-claim-line-height: 1.5;
    --bs-v5-claim-offset: 0vh;
    --bs-v5-segments-offset: 0vh;

    --bs-v5-footer-bottom: 1.2rem;
    --bs-v5-footer-padding-x: 1.4rem;
    --bs-v5-footer-font-size: 0.78rem;
  }

  .bs-v5-hero__inner {
    justify-content: flex-start;
    padding-top: 6rem;
  }

  .bs-v5-claim {
    max-width: 90vw;
  }

  .bs-v5-footer {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 0.3rem;
  }

  .bs-v5-footer__nav {
    gap: 1rem;
    flex-wrap: wrap;
    justify-content: center;
  }
}

