/*
Theme Name:  BRANDMENTUM 02-06-2026
Theme URI:   https://www.brandmentum.de
Description: Offizielles Block-Theme BRANDMENTUM — Marke. Marketing. Mensch.
Version:     2.0.0
Author:      BRANDMENTUM
Text Domain: brandmentum
Requires at least: 6.4
Requires PHP: 8.0
License:     Proprietary
*/

@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800;900&display=swap');

/* =========================================================
   BRANDMENTUM — Colors & Type Tokens
   Source: theme.json + style.css (DL6, v1.2.0)
   Marken: Marke. Marketing. Mensch.
   ========================================================= */

/* Webfont: Manrope is the primary BRANDMENTUM Sans family.
   Using Google Fonts CDN — substitute with self-hosted .woff2
   when font files are available.                              */
/* cyrillic-ext */

/* cyrillic */

/* greek */

/* vietnamese */

/* latin-ext */

/* latin */

/* cyrillic-ext */

/* cyrillic */

/* greek */

/* vietnamese */

/* latin-ext */

/* latin */

/* cyrillic-ext */

/* cyrillic */

/* greek */

/* vietnamese */

/* latin-ext */

/* latin */

/* cyrillic-ext */

/* cyrillic */

/* greek */

/* vietnamese */

/* latin-ext */

/* latin */

/* cyrillic-ext */

/* cyrillic */

/* greek */

/* vietnamese */

/* latin-ext */

/* latin */



:root {
    /* ── BRAND COLORS (v3.0) ─────────────────────────────── */
    --bm-orange:    #FF7F00;   /* Primärfarbe — "Marke"      */
    --bm-blue:      #174EFF;   /* Akzentfarbe 1 — "Marketing"*/
    --bm-green:     #24E41E;   /* Akzentfarbe 2 — "Mensch"   */

    /* ── NEUTRALS ────────────────────────────────────────── */
    --bm-black:     #000000;
    --bm-near-black:#1A1A1A;   /* default body bg            */
    --bm-dark:      #111111;
    --bm-dark-2:    #0D0D0D;
    --bm-dark-3:    #0A0A0A;
    --bm-off-white: #F5F4F1;
    --bm-white:     #FFFFFF;
    --bm-gray:      #888888;
    --bm-gray-light:#CCCCCC;
    --bm-gray-dark: #444444;

    /* ── SEMANTIC: FOREGROUND ────────────────────────────── */
    --fg-1:        #FFFFFF;          /* primary text on dark */
    --fg-2:        rgba(255,255,255,.72); /* body            */
    --fg-3:        rgba(255,255,255,.55); /* secondary       */
    --fg-4:        rgba(255,255,255,.4);  /* meta / muted    */
    --fg-on-color: #1A1A1A;          /* text on orange/green */
    --fg-on-blue:  #FFFFFF;
    --link:        var(--bm-orange);
    --link-hover:  #FFFFFF;

    /* ── SEMANTIC: BACKGROUND ────────────────────────────── */
    --bg-1:        #1A1A1A;          /* page                 */
    --bg-2:        #111111;          /* card / surface       */
    --bg-3:        #0D0D0D;          /* deeper layer         */
    --bg-inverse:  #F5F4F1;
    --border:      #1a1a1a;
    --border-soft: rgba(255,255,255,.12);

    /* ── BRAND GRADIENT ──────────────────────────────────── */
    --bm-gradient: linear-gradient(90deg, #FF7F00 0%, #174EFF 50%, #24E41E 100%);
    --bm-gradient-orange-blue: linear-gradient(90deg,#FF7F00 0%,#174EFF 50%,#FF7F00 100%);
    --bm-gradient-orange-dark: linear-gradient(135deg, #FF7F00 0%, #1A1A1A 100%);
    --bm-hero-overlay: linear-gradient(108deg, rgba(255,127,0,.90) 0%, rgba(255,127,0,.55) 65%, rgba(255,127,0,.20) 100%);

    /* ── TYPOGRAPHY: FAMILIES ────────────────────────────── */
    --font-sans:    'Manrope', 'Arial', 'Helvetica Neue', Helvetica, sans-serif;
    --font-arial:   Arial, Helvetica, sans-serif;
    --font-display: 'Manrope', 'Arial', sans-serif; /* used italic 900 */

    /* ── TYPOGRAPHY: SIZES (theme.json scale) ────────────── */
    --fs-small:    14px;
    --fs-medium:   17px;                              /* base body */
    --fs-large:    clamp(20px, 2vw, 24px);
    --fs-xlarge:   clamp(28px, 3.5vw, 48px);
    --fs-xxlarge:  clamp(44px, 6vw, 80px);            /* hero      */
    --fs-huge:     clamp(52px, 7.5vw, 100px);         /* mega      */

    /* ── TYPOGRAPHY: WEIGHTS ─────────────────────────────── */
    --fw-regular:  400;
    --fw-medium:   500;
    --fw-semibold: 600;
    --fw-bold:     700;
    --fw-black:    900;

    /* ── TYPOGRAPHY: LINE HEIGHTS ────────────────────────── */
    --lh-tight:    1.05;   /* h1            */
    --lh-snug:     1.15;
    --lh-base:     1.65;   /* body default  */
    --lh-relaxed:  1.85;   /* long-form     */

    /* ── TYPOGRAPHY: TRACKING ────────────────────────────── */
    --ls-display: -0.02em;   /* italic display headings */
    --ls-eyebrow: 0.18em;    /* eyebrow / label         */
    --ls-button:  0.10em;    /* uppercase button copy   */

    /* ── SPACING (theme.json: 24px base ×1.5 stepped) ────── */
    --sp-1:  4px;
    --sp-2:  8px;
    --sp-3:  16px;
    --sp-4:  24px;   /* mediumStep — block-gap default */
    --sp-5:  36px;
    --sp-6:  54px;
    --sp-7:  80px;
    --sp-8:  120px;

    /* ── RADII ───────────────────────────────────────────── */
    --r-none:    0;
    --r-1:       2px;     /* card                  */
    --r-2:       3px;     /* mobile button         */
    --r-pill:    50px;    /* CTA buttons (default) */
    --r-circle:  50%;

    /* ── ELEVATION / SHADOWS ─────────────────────────────── */
    --shadow-card:        0 24px 60px rgba(0,0,0,.50);
    --shadow-card-hover:  0 36px 80px rgba(0,0,0,.50);
    --shadow-card-lift:   0 50px 100px rgba(0,0,0,.60);
    --shadow-dropdown:    0 20px 60px rgba(0,0,0,.80);
    --shadow-text:        0 2px 20px rgba(0,0,0,.30);

    /* ── MOTION ──────────────────────────────────────────── */
    --ease-out:     cubic-bezier(.2, 1, .3, 1);
    --dur-fast:     .15s;
    --dur-base:     .25s;
    --dur-med:      .35s;
    --dur-slow:     .85s;

    /* ── LAYOUT ──────────────────────────────────────────── */
    --container:   1200px;
    --container-pad: 48px;
    --content:     760px;
}

/* =========================================================
   SEMANTIC ELEMENT STYLES
   ========================================================= */

body {
    font-family: var(--font-sans);
    font-size: var(--fs-medium);
    line-height: var(--lh-base);
    color: var(--fg-1);
    background: var(--bg-1);
    -webkit-font-smoothing: antialiased;
}

h1, .h1 {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: var(--fw-black);
    font-size: var(--fs-huge);
    line-height: var(--lh-tight);
    letter-spacing: var(--ls-display);
    margin: 0;
}

h2, .h2 {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: var(--fw-black);
    font-size: clamp(36px, 4.5vw, 64px);
    line-height: 1.08;
    letter-spacing: var(--ls-display);
    margin: 0;
}

h3, .h3 {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: var(--fw-black);
    font-size: clamp(24px, 2.5vw, 32px);
    line-height: var(--lh-snug);
    letter-spacing: -0.01em;
    margin: 0;
}

h4, .h4 {
    font-family: var(--font-sans);
    font-style: normal;
    font-weight: var(--fw-bold);
    font-size: 20px;
    line-height: 1.25;
    margin: 0;
}

p, .p {
    font-size: var(--fs-medium);
    line-height: var(--lh-base);
    color: inherit;
    margin: 0;
}

a {
    color: var(--link);
    text-decoration: none;
    transition: color var(--dur-base) ease;
}
a:hover { color: var(--link-hover); }

/* ── EYEBROW (orange tag w/ leading rule) ───────────────── */
.eyebrow {
    font-size: 12px;
    font-weight: var(--fw-bold);
    letter-spacing: var(--ls-eyebrow);
    text-transform: uppercase;
    color: var(--bm-orange);
    display: inline-flex;
    align-items: center;
    gap: 10px;
}
.eyebrow::before {
    content: '';
    display: block;
    width: 24px;
    height: 2px;
    background: currentColor;
}

/* ── HIGHLIGHT (italic colored word in a headline) ──────── */
.hl-o, .hl-orange { color: var(--bm-orange); font-style: italic; }
.hl-b, .hl-blue   { color: var(--bm-blue);   font-style: italic; }
.hl-g, .hl-green  { color: var(--bm-green);  font-style: italic; }
.hl-underline     { border-bottom: 5px solid rgba(255,255,255,.5); padding-bottom: 3px; }

/* ── BUTTON TOKENS (capsule + trapez variants in style.css) */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 15px 32px;
    font-family: var(--font-sans);
    font-size: 13px;
    font-weight: var(--fw-bold);
    letter-spacing: var(--ls-button);
    text-transform: uppercase;
    border: 0;
    border-radius: var(--r-pill);
    cursor: pointer;
    background: var(--bm-orange);
    color: var(--bm-near-black);
    transition: transform var(--dur-fast), filter var(--dur-base), background var(--dur-base);
}
.btn:hover { background: var(--bm-white); transform: translateY(-2px); color: var(--bm-near-black); }

.btn-ghost {
    background: transparent;
    color: var(--bm-white);
    border: 2px solid rgba(255,255,255,.35);
}
.btn-ghost:hover { border-color: var(--bm-white); background: rgba(255,255,255,.07); color: var(--bm-white); }

/* ── BRAND STRIPE (3px gradient divider) ────────────────── */
.brand-stripe { height: 3px; border: 0; background: var(--bm-gradient); }


/* =========================================================
   BRANDMENTUM — Shared site utilities (built on colors_and_type.css)
   ========================================================= */

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
html, body { margin: 0; padding: 0; }
body { background: var(--bm-near-black); color: var(--fg-1); overflow-x: clip; }
img { max-width: 100%; display: block; }
button { font-family: var(--font-sans); }
::selection { background: var(--bm-orange); color: #1A1A1A; }

/* ── Layout ─────────────────────────────────────────────── */
.bm-container { max-width: 1280px; margin: 0 auto; padding: 0 56px; }
.bm-section   { padding: 104px 0; }
.bm-section-sm{ padding: 72px 0; }
@media (max-width: 760px){
  .bm-container { padding: 0 24px; }
  .bm-section   { padding: 68px 0; }
}

/* ── Display headline helper ────────────────────────────── */
.bm-display {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 900;
  letter-spacing: -.02em;
  line-height: 1.05;
  margin: 0;
  text-wrap: pretty;
}

/* ── Buttons (pill capsule, gradient primary) ───────────── */
.bm-btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 16px 34px;
  font: 700 12px/1 var(--font-sans);
  letter-spacing: .14em; text-transform: uppercase;
  border: 0; border-radius: 50px; cursor: pointer;
  text-decoration: none; white-space: nowrap;
  transition: transform .2s var(--ease-out), background-position .5s var(--ease-out), box-shadow .3s, border-color .25s, background .25s, color .25s;
}
.bm-btn .arw { transition: transform .25s var(--ease-out); }
.bm-btn:hover .arw { transform: translateX(5px); }

.bm-btn-primary {
  color: #fff;
  background: var(--bm-gradient);
  background-size: 220% 100%; background-position: 0% 50%;
  box-shadow: 0 10px 32px rgba(255,127,0,.28);
}
.bm-btn-primary:hover { background-position: 100% 50%; transform: translateY(-2px); color: #fff; box-shadow: 0 16px 44px rgba(255,127,0,.42); }

.bm-btn-ghost {
  color: #fff; background: transparent;
  border: 1.5px solid rgba(255,255,255,.45);
}
.bm-btn-ghost:hover { border-color: #fff; background: rgba(255,255,255,.08); transform: translateY(-2px); color: #fff; }

/* dark pill on colored (orange/green) backgrounds */
.bm-btn-dark {
  color: #fff; background: #1A1A1A;
}
.bm-btn-dark:hover { background: #000; transform: translateY(-2px); color: #fff; }

.bm-btn-light {
  color: #1A1A1A; background: #fff;
}
.bm-btn-light:hover { background: #1A1A1A; color: #fff; transform: translateY(-2px); }

/* ── Eyebrow on dark (overrides color per accent via inline) */
.bm-eyebrow {
  font-size: 12px; font-weight: 700; letter-spacing: .2em;
  text-transform: uppercase; color: var(--bm-orange);
  display: inline-flex; align-items: center; gap: 12px;
}
.bm-eyebrow::before { content:''; display:block; width: 28px; height: 1.5px; background: currentColor; }

/* ── Text link (arrow) ──────────────────────────────────── */
.bm-link {
  font-size: 12px; font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; text-decoration: none;
  display: inline-flex; align-items: center; gap: 8px;
  border-bottom: 1px solid currentColor; padding-bottom: 4px;
  width: fit-content; white-space: nowrap; transition: gap .25s var(--ease-out), opacity .2s;
}
.bm-link:hover { gap: 13px; }

/* ── Scroll progress bar ────────────────────────────────── */
.bm-progress {
  position: fixed; top: 0; left: 0; height: 4px; width: 0%;
  background: var(--bm-gradient); z-index: 100;
  transition: width .1s linear;
}

/* ── Reveal on scroll ───────────────────────────────────── */
.bm-reveal { opacity: 0; transform: translateY(40px); transition: opacity .8s var(--ease-out), transform .8s var(--ease-out); }
.bm-reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce){ .bm-reveal { opacity:1; transform:none; } }

/* ── Floating brand shapes (hero / page heroes) ─────────── */
@keyframes bm-float-a { 0%,100%{ transform: translateY(0) rotate(0deg);} 50%{ transform: translateY(-26px) rotate(8deg);} }
@keyframes bm-float-b { 0%,100%{ transform: translateY(0) rotate(0deg);} 50%{ transform: translateY(22px) rotate(-10deg);} }
@keyframes bm-float-c { 0%,100%{ transform: translateY(0) translateX(0);} 50%{ transform: translateY(-16px) translateX(14px);} }
.bm-shape { position: absolute; pointer-events: none; }

/* ── Accordion (Works) ──────────────────────────────────── */
.bm-acc-item { border-top: 1px solid rgba(255,255,255,.12); }
.bm-acc-head {
  width: 100%; background: none; border: 0; cursor: pointer;
  display: flex; align-items: center; gap: 24px; text-align: left;
  padding: 30px 0; color: #fff;
}
.bm-acc-body { overflow: hidden; transition: max-height .45s var(--ease-out); max-height: 0; }
.bm-acc-plus { transition: transform .35s var(--ease-out); font-weight: 300; }

/* ── Cards ──────────────────────────────────────────────── */
.bm-card {
  background: var(--bm-dark-2); padding: 38px 34px;
  transition: transform .35s var(--ease-out), background .25s, box-shadow .35s;
}
.bm-card:hover { transform: translateY(-8px); background: #131313; box-shadow: var(--shadow-card-hover); }

/* ── Inputs (Kontakt) ───────────────────────────────────── */
.bm-field { display: flex; flex-direction: column; gap: 9px; }
.bm-label { font-size: 11px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--fg-3); }
.bm-input, .bm-textarea {
  font-family: var(--font-sans); font-size: 16px; color: #fff;
  background: #0d0d0d; border: 1px solid rgba(255,255,255,.14);
  padding: 15px 16px; border-radius: 2px; transition: border-color .2s, background .2s;
  width: 100%;
}
.bm-input:focus, .bm-textarea:focus { outline: none; border-color: var(--bm-orange); background: #111; }
.bm-input::placeholder, .bm-textarea::placeholder { color: rgba(255,255,255,.32); }

/* ── Segmented toggle (variant switcher) ────────────────── */
.bm-seg {
  display: inline-flex; border: 1px solid rgba(255,255,255,.18); border-radius: 50px;
  padding: 4px; gap: 2px; background: rgba(255,255,255,.03);
}
.bm-seg button {
  border: 0; background: none; cursor: pointer; color: rgba(255,255,255,.55);
  font: 700 11px/1 var(--font-sans); letter-spacing: .12em; text-transform: uppercase;
  padding: 9px 18px; border-radius: 50px; transition: background .25s, color .25s;
}
.bm-seg button.on { background: #fff; color: #1A1A1A; }

/* Variant note pill */
.bm-vnote {
  font-size: 11px; letter-spacing: .04em; color: var(--fg-4);
  border: 1px dashed rgba(255,255,255,.18); border-radius: 50px; padding: 6px 14px;
  display: inline-flex; align-items: center; gap: 8px;
}

/* =========================================================
   Diagonal-split modules (DL5b signature) + image plates
   ========================================================= */
.ds { position: relative; overflow: hidden; }
.ds-grid { display: grid; gap: 60px; align-items: center; }
.ds-num {
  position: absolute; top: -64px; left: -6px; font-family: var(--font-display);
  font-style: italic; font-weight: 900; font-size: 150px; line-height: 1;
  letter-spacing: -.05em; opacity: .12; pointer-events: none; z-index: 0;
}
.ds-text { position: relative; z-index: 2; }
.ds-body p { font-size: 17px; line-height: 1.7; color: var(--fg-2); margin: 0 0 18px; }
.ds-body p:last-child { margin-bottom: 0; }

/* media plate — diagonally clipped, fillable image + accent backing */
.ds-media { position: relative; }
.ds-plate { position: relative; width: 100%; height: 100%; }
.ds-media image-slot { position: absolute; inset: 0; width: 100%; height: 100%; display: block; z-index: 1; }
.ds-accent { position: absolute; inset: 0; z-index: 0; }
.ds-deco { position: absolute; z-index: 2; pointer-events: none; }

/* decorative geometric accents */
.bm-deco-sq { border: 3px solid currentColor; }
.bm-deco-tri { width: 0; height: 0; border-left: 26px solid transparent; border-right: 26px solid transparent; border-bottom: 46px solid currentColor; }
.bm-deco-plus { position: relative; }
.bm-deco-plus::before, .bm-deco-plus::after { content:''; position:absolute; background: currentColor; }
.bm-deco-plus::before { left:50%; top:0; width:3px; height:100%; transform:translateX(-50%); }
.bm-deco-plus::after { top:50%; left:0; height:3px; width:100%; transform:translateY(-50%); }

/* full-bleed diagonal colored band */
.bm-band { position: relative; overflow: hidden; }
.bm-band-ghost { position: absolute; pointer-events: none; opacity: .1; filter: brightness(0) invert(1); }

@media (max-width: 900px){
  .ds-grid { grid-template-columns: 1fr !important; gap: 36px; }
  .ds-media { order: 2 !important; height: 300px; }
  .ds-text { order: 1 !important; }
  .ds-num { font-size: 110px; top: -48px; }
}



/* =========================================================
   BRANDMENTUM — Startseite Header + Video-Hero (ported)
   Prefixed .hh-* so it never collides with site.css / .bm-*
   ========================================================= */

/* ───── HEADER ───── */
.hh-head { position: fixed; top: 0; left: 0; right: 0; z-index: 80; background: #000; }
.hh-head-inner {
  max-width: 1280px; margin: 0 auto; padding: 0 48px; height: 78px;
  display: flex; align-items: center; justify-content: space-between; gap: 32px;
}
.hh-logo { display: inline-flex; align-items: center; }
.hh-logo img { height: 30px; display: block; }
.hh-nav { display: flex; gap: 34px; align-items: center; }
.hh-nav-item { position: relative; }
.hh-nav-link {
  color: #fff; font-size: 12px; font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; text-decoration: none; display: inline-flex;
  align-items: center; gap: 6px; transition: color .2s; cursor: pointer; white-space: nowrap;
}
.hh-nav-link:hover, .hh-nav-link.is-current { color: var(--accent, #FF7F00); }
.hh-caret { font-size: 9px; opacity: .7; }
.hh-drop {
  position: absolute; top: 100%; left: -16px; background: #000;
  border: 1px solid #1a1a1a; padding: 12px 0; min-width: 264px; margin-top: 18px;
  box-shadow: 0 20px 60px rgba(0,0,0,.8);
}
.hh-drop-link {
  display: block; padding: 10px 22px; color: rgba(255,255,255,.75); text-decoration: none;
  font-size: 12px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
  transition: color .15s, background .15s;
}
.hh-drop-link:hover { color: var(--accent, #FF7F00); background: #0a0a0a; }
.hh-cta-pill {
  display: inline-flex; align-items: center; gap: 8px; padding: 12px 24px;
  background: var(--bm-gradient); background-size: 220% 100%; background-position: 0% 50%;
  color: #fff; border-radius: 50px;
  font-size: 12px; font-weight: 700; letter-spacing: .10em; text-transform: uppercase;
  text-decoration: none;
  transition: transform .15s var(--ease-out), background-position .5s var(--ease-out), box-shadow .25s;
  white-space: nowrap;
}
.hh-cta-pill:hover { transform: translateY(-2px); color: #fff; background-position: 100% 50%; box-shadow: 0 8px 28px rgba(255,127,0,.32); }
.hh-cta-pill span { transition: transform .25s var(--ease-out); }
.hh-cta-pill:hover span { transform: translateX(4px); }
.hh-stripe { height: 3px; border: 0; background: var(--bm-gradient); }

/* ───── HERO ───── */
.hh-hero {
  position: relative; overflow: hidden;
  margin-top: 81px;
  min-height: calc(100vh - 81px);
  display: flex; align-items: center;
  background: var(--bm-near-black);
}
.hh-hero-video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; }
.hh-hero-overlay { position: absolute; inset: 0; z-index: 1; }
.hh-hero-spot   { position: absolute; inset: 0; z-index: 2; mix-blend-mode: screen; }
.hh-shapes      { position: absolute; inset: 0; z-index: 3; }

.hh-hero-inner {
  position: relative; z-index: 6;
  max-width: 1280px; margin: 0 auto; width: 100%;
  padding: 64px 48px 120px;
}
.hh-eyebrow {
  display: inline-flex; align-items: center; gap: 12px;
  font-size: 12px; font-weight: 700; letter-spacing: .2em; text-transform: uppercase;
  color: #fff; margin-bottom: 26px;
}
.hh-eyebrow-rule { width: 32px; height: 2px; background: var(--accent, #FF7F00); }
.hh-h1 {
  font-family: var(--font-display); font-style: italic; font-weight: 900;
  font-size: clamp(40px, 5.4vw, 82px); line-height: 1.04; letter-spacing: -0.02em;
  color: #fff; margin: 0; max-width: 17ch; text-wrap: pretty;
  text-shadow: 0 2px 30px rgba(0,0,0,.45);
}
.hh-tagline {
  margin-top: 30px; font-family: var(--font-display); font-style: italic; font-weight: 900;
  font-size: clamp(20px, 2vw, 26px); color: #fff; letter-spacing: -0.01em;
}
.hh-tagline em { font-style: italic; }
.hh-tagline em:nth-child(1) { color: var(--bm-orange); }
.hh-tagline em:nth-child(2) { color: var(--bm-blue); }
.hh-tagline em:nth-child(3) { color: var(--bm-green); }
.hh-lede {
  margin-top: 22px; max-width: 540px; font-size: 17px; line-height: 1.65;
  color: rgba(255,255,255,.82); font-weight: 400;
}
.hh-actions { display: flex; gap: 16px; flex-wrap: wrap; margin-top: 40px; }
.hh-btn {
  display: inline-flex; align-items: center; gap: 10px; padding: 16px 34px;
  font-size: 12px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  text-decoration: none; cursor: pointer; border-radius: 50px;
  transition: transform .15s var(--ease-out), filter .25s, background .25s, border-color .25s;
}
.hh-btn-primary {
  background: var(--bm-gradient); background-size: 220% 100%; background-position: 0% 50%;
  color: #fff;
  transition: transform .15s var(--ease-out), background-position .5s var(--ease-out), box-shadow .25s;
}
.hh-btn-primary:hover { transform: translateY(-2px); color: #fff; background-position: 100% 50%; box-shadow: 0 10px 32px rgba(255,127,0,.32); }
.hh-btn-primary span { transition: transform .25s var(--ease-out); }
.hh-btn-primary:hover span { transform: translateX(5px); }
.hh-btn-ghost { background: transparent; color: #fff; border: 2px solid rgba(255,255,255,.4); }
.hh-btn-ghost:hover { border-color: #fff; background: rgba(255,255,255,.08); color: #fff; transform: translateY(-2px); }

.hh-scroll-hint {
  position: absolute; left: 48px; bottom: 26px; z-index: 7;
  display: flex; align-items: center; gap: 10px;
  font-size: 11px; font-weight: 700; letter-spacing: .22em; text-transform: uppercase;
  color: rgba(255,255,255,.65);
}
.hh-scroll-hint i { font-style: normal; font-size: 15px; animation: hh-bob 1.8s var(--ease-out) infinite; }

/* ───── KEYFRAMES ───── */
@keyframes hh-float {
  0%   { transform: translate3d(0,0,0) rotate(0deg); }
  25%  { transform: translate3d(18px,-26px,0) rotate(4deg); }
  50%  { transform: translate3d(-12px,-14px,0) rotate(-3deg); }
  75%  { transform: translate3d(14px,16px,0) rotate(3deg); }
  100% { transform: translate3d(0,0,0) rotate(0deg); }
}
@keyframes hh-bob { 0%,100% { transform: translateY(0); } 50% { transform: translateY(5px); } }

@media (prefers-reduced-motion: reduce) {
  .hh-shapes * { animation: none !important; }
  .hh-scroll-hint i { animation: none !important; }
}

/* ───── RESPONSIVE ───── */
.hh-nav-toggle { display: none; background: none; border: 0; cursor: pointer; flex-direction: column; gap: 5px; padding: 8px; }
.hh-nav-toggle span { width: 24px; height: 2px; background: #fff; display: block; }
.hh-mobile { display: none; background: #000; border-top: 1px solid #1a1a1a; padding: 8px 24px 22px; }
.hh-mobile a { display: block; padding: 13px 0; color: #fff; font-size: 13px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; text-decoration: none; border-bottom: 1px solid #141414; }

@media (max-width: 1080px) { .hh-nav { gap: 22px; } }
@media (max-width: 960px) {
  .hh-nav { display: none; }
  .hh-nav-toggle { display: flex; }
  .hh-head-inner { padding: 0 24px; }
  .hh-hero-inner { padding: 48px 24px 110px; }
  .hh-scroll-hint { left: 24px; }
}



/* =========================================================
   WORDPRESS BLOCK OVERRIDES
   ========================================================= */
body.wp-admin { background: var(--bm-near-black) !important; }
.editor-styles-wrapper { background: var(--bm-near-black) !important; color: #fff !important; }
.wp-block-navigation a { color: #fff; }
.wp-block-navigation a:hover { color: var(--bm-orange); }
.wp-site-blocks { padding: 0 !important; }
.wp-block-template-part { display: block; }

/* Gutenberg editability helpers */
.wp-block-html { display: block; }

/* Hover effects (CSS-only fallbacks for Gutenberg preview) */
.bm-card:hover { transform: translateY(-8px); background: #131313; box-shadow: 0 36px 80px rgba(0,0,0,.50); }
.bm-btn:hover .arw { transform: translateX(5px); }
.bm-btn-primary:hover { background-position: 100% 50%; transform: translateY(-2px); box-shadow: 0 16px 44px rgba(255,127,0,.42); }
.bm-btn-ghost:hover { border-color: #fff; background: rgba(255,255,255,.08); transform: translateY(-2px); }

/* ── Mobile nav: hidden by default ─────────────────────────── */
.bm-nav-mobile { display: none; }
.bm-nav-mobile.open { display: block; }
.hh-nav-toggle { display: none; }
@media (max-width: 1080px) {
  .hh-nav { display: none !important; }
  .hh-nav-toggle { display: flex !important; }
}
@media (max-width: 960px) {
  .hh-head-inner { padding: 0 24px !important; }
}

/* ═══════════════════════════════════════════════════════
   V2 FIXES
   ═══════════════════════════════════════════════════════ */

/* 1. Mobile nav: ALWAYS hidden on desktop, only shown via .open */
.bm-nav-mobile {
  display: none !important;
}
.bm-nav-mobile.open {
  display: block !important;
}

/* 2. Mobile toggle: hidden on desktop */
.hh-nav-toggle {
  display: none !important;
}

/* 3. Responsive breakpoints */
@media (max-width: 960px) {
  .hh-nav { display: none !important; }
  .hh-nav-toggle { display: flex !important; }
  .bm-nav-mobile.open { display: block !important; }
}

/* 4. Works grid text overflow fix */
.bm-container > div[style*="grid-template-columns:1fr 1fr"] {
  overflow: hidden;
}

/* 5. DS grid responsive */
@media (max-width: 900px) {
  .ds-grid {
    grid-template-columns: 1fr !important;
    gap: 36px !important;
  }
  .ds-media {
    height: 300px !important;
  }
}

/* 6. General grid responsive */
@media (max-width: 760px) {
  [style*="grid-template-columns: 1fr 1fr"],
  [style*="grid-template-columns:1fr 1fr"],
  [style*="grid-template-columns: 1.3fr .7fr"],
  [style*="grid-template-columns: 1.2fr .8fr"] {
    grid-template-columns: 1fr !important;
  }
}

/* 7. Prevent content overflow on all pages */
main { overflow-x: hidden; }
section { overflow-x: hidden; }

/* ═══════════════════════════════════════════════════════════════════
   V3 — HOVER EFFECTS (faithful to original React onMouseEnter/Leave)
   ═══════════════════════════════════════════════════════════════════ */

/* ── Pillar Cards (Startseite: Marke / Marketing / Mensch) ──────── */
.bm-pillar-card {
  transition: transform .4s var(--ease-out), background .3s, box-shadow .4s, border-top-width .3s !important;
}
.bm-pillar-card:hover {
  transform: translateY(-12px) !important;
  background: #151515 !important;
  text-decoration: none !important;
}
.bm-pillar-card:hover .bm-pillar-num {
  opacity: .2 !important;
  transform: scale(1.08) !important;
}
.bm-pillar-card:hover h3 {
  color: var(--bm-card-accent, var(--bm-orange)) !important;
}
.bm-pillar-card:hover .bm-link {
  gap: 13px !important;
}
.bm-pillar-card:hover .bm-link span { transform: translateX(6px); }

.bm-pillar-card--orange:hover {
  box-shadow: 0 32px 72px rgba(0,0,0,.55), 0 0 0 1px rgba(255,127,0,.35) !important;
  border-top-width: 5px !important;
}
.bm-pillar-card--blue:hover {
  box-shadow: 0 32px 72px rgba(0,0,0,.55), 0 0 0 1px rgba(23,78,255,.35) !important;
  border-top-width: 5px !important;
}
.bm-pillar-card--green:hover {
  box-shadow: 0 32px 72px rgba(0,0,0,.55), 0 0 0 1px rgba(36,228,30,.35) !important;
  border-top-width: 5px !important;
}

/* ── Strategy / Delivery Tiles (Erst denken / Dann umsetzen) ────── */
.bm-strat-tile {
  transition: transform .4s var(--ease-out), box-shadow .4s !important;
  position: relative !important;
  overflow: hidden !important;
}
.bm-strat-tile::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 4px;
  transition: width .35s var(--ease-out);
  z-index: 1;
}
.bm-strat-tile--green::before  { background: var(--bm-green); }
.bm-strat-tile--blue::before   { background: var(--bm-blue); }
.bm-strat-tile--orange::before { background: var(--bm-orange); }

.bm-strat-tile::after {
  content: '';
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity .4s var(--ease-out);
  pointer-events: none;
  z-index: 0;
}
.bm-strat-tile--green::after  { background: linear-gradient(100deg, rgba(36,228,30,.15) 0%, transparent 55%); }
.bm-strat-tile--blue::after   { background: linear-gradient(100deg, rgba(23,78,255,.15) 0%, transparent 55%); }
.bm-strat-tile--orange::after { background: linear-gradient(100deg, rgba(255,127,0,.15) 0%, transparent 55%); }

.bm-strat-tile:hover {
  transform: translateY(-10px) !important;
  text-decoration: none !important;
}
.bm-strat-tile:hover::before  { width: 10px !important; }
.bm-strat-tile:hover::after   { opacity: 1 !important; }
.bm-strat-tile:hover h3       { transform: translateX(6px); transition: transform .35s var(--ease-out); }
.bm-strat-tile--green:hover  { box-shadow: 0 32px 72px rgba(0,0,0,.55), 0 0 0 1px rgba(36,228,30,.25) !important; }
.bm-strat-tile--blue:hover   { box-shadow: 0 32px 72px rgba(0,0,0,.55), 0 0 0 1px rgba(23,78,255,.25) !important; }
.bm-strat-tile--orange:hover { box-shadow: 0 32px 72px rgba(0,0,0,.55), 0 0 0 1px rgba(255,127,0,.25) !important; }

/* ── Service Overview Cards (Leistungsüberblick) ────────────────── */
.bm-svc-card {
  transition: transform .3s var(--ease-out), background .25s, box-shadow .35s !important;
}
.bm-svc-card:hover {
  transform: translateY(-8px) !important;
  background: #131313 !important;
  box-shadow: 0 24px 60px rgba(0,0,0,.5) !important;
}

/* ── Navigation links ───────────────────────────────────────────── */
.hh-nav-link:hover,
.hh-nav-link.is-current { color: var(--bm-orange) !important; }

.hh-nav-link { 
  color: rgba(255,255,255,.85);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  text-decoration: none;
  transition: color .2s;
}

/* ── Header CTA Pill ────────────────────────────────────────────── */
.hh-cta-pill { transition: transform .15s var(--ease-out), background-position .5s var(--ease-out), box-shadow .25s !important; }
.hh-cta-pill:hover { transform: translateY(-2px) !important; color: #fff !important; background-position: 100% 50% !important; box-shadow: 0 8px 28px rgba(255,127,0,.32) !important; }

/* ── Footer nav links ───────────────────────────────────────────── */
.bm-foot-nav-list a:hover  { color: var(--bm-orange) !important; }
.bm-foot-social a:hover    { color: var(--bm-orange) !important; }
.bm-foot-contact a:hover   { opacity: .8; }

/* ── bm-link arrow animation ────────────────────────────────────── */
.bm-link {
  transition: gap .25s var(--ease-out), opacity .2s !important;
}
.bm-link:hover { gap: 13px !important; }
.bm-link span  { transition: transform .25s var(--ease-out); }
.bm-link:hover span { transform: translateX(6px) !important; }

/* ── Works accordion hover ──────────────────────────────────────── */
.bm-acc-head {
  transition: opacity .2s, border-left-color .25s !important;
}
.bm-acc-head:hover { opacity: .85; }

/* ── Works interplay cards ──────────────────────────────────────── */
.bm-works-link {
  transition: transform .35s var(--ease-out), box-shadow .35s !important;
  text-decoration: none !important;
}
.bm-works-link:hover {
  transform: translateY(-8px) !important;
  text-decoration: none !important;
}
.bm-works-link--orange:hover { box-shadow: 0 24px 60px rgba(0,0,0,.5), 0 0 0 1px rgba(255,127,0,.3) !important; }
.bm-works-link--blue:hover   { box-shadow: 0 24px 60px rgba(0,0,0,.5), 0 0 0 1px rgba(23,78,255,.3) !important; }

/* ── Direct contact links (Kontakt) ────────────────────────────── */
.bm-contact-link {
  transition: color .2s !important;
}
.bm-contact-link:hover { color: var(--bm-orange) !important; }

/* ── Social pills (Kontakt) ─────────────────────────────────────── */
.bm-social-pill {
  transition: border-color .2s, color .2s !important;
}
.bm-social-pill:hover {
  border-color: var(--bm-orange) !important;
  color: var(--bm-orange) !important;
}

/* ── Buttons (ensure all animations work) ───────────────────────── */
.bm-btn { transition: transform .2s var(--ease-out), background-position .5s var(--ease-out), box-shadow .3s, border-color .25s, background .25s, color .25s !important; }
.bm-btn-primary:hover { background-position: 100% 50% !important; transform: translateY(-2px) !important; color: #fff !important; box-shadow: 0 16px 44px rgba(255,127,0,.42) !important; }
.bm-btn-ghost:hover   { border-color: #fff !important; background: rgba(255,255,255,.08) !important; transform: translateY(-2px) !important; color: #fff !important; }
.bm-btn-dark:hover    { background: #000 !important; transform: translateY(-2px) !important; }
.bm-btn-light:hover   { background: #1A1A1A !important; color: #fff !important; transform: translateY(-2px) !important; }
.bm-btn .arw { transition: transform .25s var(--ease-out) !important; display: inline-block; }
.bm-btn:hover .arw { transform: translateX(5px) !important; }

/* ── BRANDMENTUM page: gradient CTA button ───────────────────────── */
.bmh-grad {
  display: inline-flex; align-items: center; gap: 10px; padding: 16px 34px;
  border-radius: 50px; font: 700 12px/1 var(--font-sans); letter-spacing: .10em;
  text-transform: uppercase; text-decoration: none; color: #fff;
  background: linear-gradient(90deg, var(--bm-orange) 0%, var(--bm-blue) 100%);
  background-size: 160% 100%; background-position: 0% center;
  box-shadow: 0 0 34px rgba(255,127,0,.40);
  transition: background-position .4s var(--ease-out), transform .2s;
  white-space: nowrap;
}
.bmh-grad:hover { background-position: 100% center !important; transform: translateY(-2px) !important; color: #fff !important; }
.bmh-grad .arw { transition: transform .25s var(--ease-out); }
.bmh-grad:hover .arw { transform: translateX(5px) !important; }

/* ── FIX: Header fixed positioning ──────────────────────────────────── */
.bm-header,
#bm-site-header {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  z-index: 9999 !important;
  width: 100% !important;
}

/* Compensate for fixed header height (80px header + 3px stripe) */
body {
  padding-top: 83px !important;
}

/* Scrolled state: slight transparency */
#bm-site-header.scrolled {
  background: rgba(0,0,0,.93) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
}

/* ── FIX: Footer grid always 3 columns on desktop ───────────────────── */
.bm-foot-grid {
  display: grid !important;
  grid-template-columns: 1.5fr 1fr 1fr !important;
  gap: 64px !important;
  padding: 76px 56px 40px !important;
}
@media (max-width: 760px) {
  .bm-foot-grid {
    grid-template-columns: 1fr !important;
    gap: 40px !important;
    padding: 48px 24px 32px !important;
  }
  body { padding-top: 78px !important; }
}

/* ── FIX: Accordion body expand on .open ────────────────────────────── */
.bm-acc-body {
  overflow: hidden !important;
  max-height: 0 !important;
  transition: max-height .45s cubic-bezier(.2,1,.3,1) !important;
}
.bm-acc-body.open {
  max-height: 2000px !important;
}
.bm-acc-head {
  border-left: 3px solid transparent;
  transition: border-left-color .25s !important;
}
.bm-acc-head.active {
  border-left-color: var(--bm-orange);
}

/* ── FIX: Accordion inner grid responsive ───────────────────────────── */
.bm-acc-body > div {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 24px 48px !important;
  padding-left: 48px !important;
  padding-bottom: 30px !important;
}
@media (max-width: 760px) {
  .bm-acc-body > div {
    grid-template-columns: 1fr !important;
    padding-left: 24px !important;
  }
}

/* ── FIX: Hero min-height compensates fixed header ──────────────────── */
.bm-hero-home,
section[style*="min-height: calc(100vh"] {
  min-height: calc(100vh - 83px) !important;
}
