/* ============================================================
   FOTOBOX ERZGEBIRGE – main.css
   Vollständiges Design-System: Gold, Silber, Weiß, Premium
   ============================================================ */

/* ── CSS-VARIABLES ── */
:root {
  --gold:         #C9A84C;
  --gold-light:   #E8C96A;
  --gold-pale:    #F5EDD4;
  --gold-dark:    #9A7630;
  --silver:       #A8B2BE;
  --silver-light: #D4DAE0;
  --silver-pale:  #F0F2F5;
  --green:        #4CAF26;
  --white:        #FFFFFF;
  --off:          #FAFAF8;
  --ink:          #0D0D0D;
  --ink-soft:     #3A3A3A;
  --ink-muted:    #7A7A7A;
  --grad-gold:    linear-gradient(135deg, #C9A84C 0%, #E8C96A 45%, #C9A84C 100%);
  --grad-silver:  linear-gradient(135deg, #9BA8B5 0%, #D4DAE0 50%, #9BA8B5 100%);
  --font-serif:   'Cormorant Garamond', Georgia, serif;
  --font-sans:    'Jost', system-ui, sans-serif;
  --radius:       4px;
  --max-width:    1100px;
  --section-pad:  120px 10%;
  --transition:   .3s cubic-bezier(.22,1,.36,1);
}

/* ── RESET & BASE ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body { font-family: var(--font-sans); font-weight: 300; color: var(--ink); background: var(--white); overflow-x: hidden; cursor: none; -webkit-font-smoothing: antialiased; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
button { cursor: pointer; font-family: var(--font-sans); border: none; background: none; }
ul { list-style: none; }

/* ── CUSTOM CURSOR ── */
#fbe-cursor {
  position: fixed; width: 10px; height: 10px; border-radius: 50%;
  background: var(--gold); pointer-events: none; z-index: 9999;
  transform: translate(-50%,-50%); mix-blend-mode: multiply;
  transition: width .3s, height .3s;
}
#fbe-cursor-ring {
  position: fixed; width: 36px; height: 36px; border-radius: 50%;
  border: 1px solid var(--gold); pointer-events: none; z-index: 9998;
  transform: translate(-50%,-50%); opacity: .45;
  transition: width .3s, height .3s, opacity .3s;
}
body:hover #fbe-cursor-ring { opacity: .45; }

/* ── TYPOGRAPHY ── */
.fbe-display-title {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 3.8vw, 3.6rem);
  font-weight: 300; line-height: 1.1; letter-spacing: -.01em;
}
.fbe-display-title em {
  font-style: italic;
  background: var(--grad-gold);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}
.fbe-body-text { font-size: .93rem; line-height: 1.9; color: var(--ink-muted); font-weight: 300; }

/* ── EYEBROW ── */
.fbe-eyebrow { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; }
.fbe-eyebrow__line { width: 30px; height: 1px; background: var(--grad-gold); flex-shrink: 0; }
.fbe-eyebrow__text { font-size: .66rem; letter-spacing: .2em; text-transform: uppercase; color: var(--gold); font-weight: 500; }

/* ── ORNAMENT ── */
.fbe-ornament { display: flex; align-items: center; justify-content: center; gap: 16px; padding: 56px 0 48px; }
.fbe-ornament__line { flex: 1; max-width: 120px; height: 1px; background: var(--grad-gold); opacity: .35; }
.fbe-ornament__diamond { width: 6px; height: 6px; background: var(--gold); transform: rotate(45deg); opacity: .65; }
.fbe-ornament__text { font-size: .6rem; letter-spacing: .22em; text-transform: uppercase; color: var(--gold); font-weight: 500; }

/* ── BUTTONS ── */
.fbe-btn-gold {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--grad-gold); color: var(--ink);
  padding: 16px 38px; font-size: .7rem; font-weight: 600;
  letter-spacing: .15em; text-transform: uppercase;
  transition: transform var(--transition), box-shadow var(--transition);
  box-shadow: 0 4px 24px rgba(201,168,76,.3);
}
.fbe-btn-gold:hover { transform: translateY(-2px); box-shadow: 0 10px 40px rgba(201,168,76,.45); }
.fbe-btn-ghost {
  display: inline-block; padding: 14px 32px; text-align: center;
  border: 1px solid rgba(0,0,0,.14); font-size: .66rem; letter-spacing: .14em;
  text-transform: uppercase; font-weight: 600; color: var(--ink);
  transition: background var(--transition), color var(--transition), border-color var(--transition);
}
.fbe-btn-ghost:hover { background: var(--ink); color: white; border-color: var(--ink); }
.fbe-btn-gold-block {
  display: block; text-align: center; padding: 14px;
  background: var(--grad-gold); font-size: .66rem; letter-spacing: .14em;
  text-transform: uppercase; font-weight: 600; color: var(--ink);
  transition: opacity var(--transition), transform var(--transition);
}
.fbe-btn-gold-block:hover { opacity: .85; transform: translateY(-1px); }
.fbe-btn-text {
  font-size: .7rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--ink-muted); display: inline-flex; align-items: center; gap: 8px;
  transition: color var(--transition), gap var(--transition);
}
.fbe-btn-text:hover { color: var(--ink); gap: 14px; }
.fbe-btn-whatsapp {
  display: inline-flex; align-items: center; gap: 10px; margin-top: 28px;
  background: #25D366; color: white; padding: 14px 28px;
  font-size: .76rem; font-weight: 500; letter-spacing: .06em;
  transition: opacity var(--transition);
}
.fbe-btn-whatsapp:hover { opacity: .88; }
.fbe-btn-submit {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--grad-gold); color: var(--ink); border: none;
  padding: 16px 40px; font-family: var(--font-sans); font-size: .68rem;
  font-weight: 600; letter-spacing: .15em; text-transform: uppercase;
  cursor: pointer; margin-top: 28px;
  transition: opacity var(--transition), transform var(--transition), box-shadow var(--transition);
  box-shadow: 0 4px 20px rgba(201,168,76,.25);
}
.fbe-btn-submit:hover { opacity: .87; transform: translateY(-2px); box-shadow: 0 10px 40px rgba(201,168,76,.4); }

/* ── CHIPS ── */
.fbe-chip { font-size: .58rem; letter-spacing: .12em; text-transform: uppercase; font-weight: 500; padding: 6px 14px; border: 1px solid var(--silver-light); color: var(--ink-muted); }
.fbe-chip--gold { border-color: rgba(201,168,76,.3); color: var(--gold-dark); }

/* ── SECTION BASE ── */
.fbe-section { padding: var(--section-pad); }
.fbe-section__inner { max-width: var(--max-width); margin: 0 auto; }

/* ── SCROLL REVEAL ── */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity .8s cubic-bezier(.22,1,.36,1), transform .8s cubic-bezier(.22,1,.36,1); }
.reveal.in { opacity: 1; transform: none; }

/* ══════════════════════════════════════════════
   HEADER
   ══════════════════════════════════════════════ */
.fbe-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  height: 82px; display: flex; align-items: stretch;
  background: rgba(255,255,255,.94); backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(201,168,76,.14);
  transition: height .4s, border-color .4s;
}
.fbe-header.is-scrolled { height: 64px; border-bottom-color: rgba(201,168,76,.28); }
.fbe-header__inner {
  width: 100%; max-width: 1400px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 6%;
}
.fbe-header__logo { display: flex; align-items: center; gap: 14px; }
.fbe-header__logo img, .fbe-header__logo .custom-logo { height: 38px; width: auto; }
.fbe-header__logo-name { font-family: var(--font-serif); font-size: 1.15rem; font-weight: 600; letter-spacing: .06em; color: var(--ink); display: block; line-height: 1.1; }
.fbe-header__logo-sub { font-size: .6rem; letter-spacing: .18em; text-transform: uppercase; color: var(--gold); font-weight: 500; display: block; margin-top: 3px; }
.fbe-nav__list { display: flex; align-items: center; gap: 32px; }
.fbe-nav__list li a {
  font-size: .7rem; font-weight: 500; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-soft);
  position: relative; transition: color .2s; padding-bottom: 3px;
}
.fbe-nav__list li a::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 1px; background: var(--gold); transform: scaleX(0); transform-origin: left; transition: transform .3s; }
.fbe-nav__list li a:hover { color: var(--ink); }
.fbe-nav__list li a:hover::after { transform: scaleX(1); }
.fbe-header__cta { border: 1px solid var(--gold); color: var(--gold-dark); padding: 10px 26px; font-size: .7rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; transition: background .25s, color .25s; }
.fbe-header__cta:hover { background: var(--gold); color: white; }

/* Hamburger */
.fbe-hamburger { display: none; flex-direction: column; gap: 5px; padding: 8px; }
.fbe-hamburger span { display: block; width: 24px; height: 1.5px; background: var(--ink); transition: transform .3s, opacity .3s; }
.fbe-hamburger.is-open span:nth-child(1) { transform: rotate(45deg) translate(4px, 4px); }
.fbe-hamburger.is-open span:nth-child(2) { opacity: 0; }
.fbe-hamburger.is-open span:nth-child(3) { transform: rotate(-45deg) translate(4px, -4px); }

/* Mobile Nav */
.fbe-mobile-nav { display: none; position: fixed; top: 82px; left: 0; right: 0; bottom: 0; background: white; padding: 40px 8%; overflow-y: auto; z-index: 99; flex-direction: column; gap: 0; }
.fbe-mobile-nav:not([hidden]) { display: flex; }
.fbe-mobile-nav__list { display: flex; flex-direction: column; }
.fbe-mobile-nav__list li a { display: block; padding: 18px 0; font-size: 1.2rem; font-family: var(--font-serif); font-weight: 300; color: var(--ink); border-bottom: 1px solid rgba(0,0,0,.07); }
.fbe-mobile-nav__cta { display: block; margin-top: 32px; text-align: center; }
.fbe-mobile-nav__phone { display: flex; align-items: center; gap: 10px; margin-top: 20px; color: var(--ink-muted); font-size: .88rem; }

/* ══════════════════════════════════════════════
   HERO
   ══════════════════════════════════════════════ */
.fbe-hero {
  min-height: 100vh; display: grid; grid-template-columns: 1fr 1fr;
  padding-top: 82px;
}
.fbe-hero__left {
  background: var(--off); display: flex; flex-direction: column;
  justify-content: center; padding: 80px 8% 80px 10%; position: relative;
}
.fbe-hero__left::after { content: ''; position: absolute; top: 0; right: -1px; bottom: 0; width: 1px; background: linear-gradient(to bottom, transparent, rgba(201,168,76,.4), transparent); }
.fbe-hero__title { font-family: var(--font-serif); font-size: clamp(2.8rem, 5vw, 4.8rem); font-weight: 300; line-height: 1.08; letter-spacing: -.01em; margin-bottom: 28px; opacity: 0; animation: riseIn .9s ease .4s forwards; }
.fbe-hero__title em { font-style: italic; background: var(--grad-gold); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
.fbe-hero__body { font-size: .95rem; line-height: 1.9; color: var(--ink-muted); max-width: 420px; margin-bottom: 48px; font-weight: 300; opacity: 0; animation: riseIn .9s ease .6s forwards; }
.fbe-hero__actions { display: flex; align-items: center; gap: 28px; flex-wrap: wrap; opacity: 0; animation: riseIn .9s ease .8s forwards; }
.fbe-hero__corner { position: absolute; bottom: 40px; right: 40px; font-size: .62rem; letter-spacing: .16em; color: var(--silver); writing-mode: vertical-rl; opacity: .5; }
.fbe-hero__right { background: var(--white); display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; }
.fbe-hero__circles { position: absolute; display: flex; align-items: center; justify-content: center; inset: 0; }
.fbe-hero__circles span { position: absolute; border-radius: 50%; border: 1px solid rgba(201,168,76,.1); pointer-events: none; }
.fbe-hero__circles span:nth-child(1) { width: 680px; height: 680px; }
.fbe-hero__circles span:nth-child(2) { width: 500px; height: 500px; border-color: rgba(201,168,76,.13); }
.fbe-hero__circles span:nth-child(3) { width: 320px; height: 320px; border-color: rgba(201,168,76,.2); }
.fbe-hero__circles span:nth-child(4) { width: 160px; height: 160px; border-color: rgba(201,168,76,.3); }
.fbe-hero__logo-wrap { position: relative; z-index: 2; display: flex; flex-direction: column; align-items: center; gap: 20px; opacity: 0; animation: riseIn 1s ease 1.1s forwards; }
.fbe-hero__logo-img, .fbe-hero__logo-wrap .custom-logo { width: 180px; height: auto; filter: drop-shadow(0 20px 60px rgba(201,168,76,.18)); animation: floatLogo 6s ease-in-out infinite; }
.fbe-hero__logo-placeholder { font-size: 5rem; color: var(--gold); opacity: .3; }
.fbe-hero__logo-label { font-size: .62rem; letter-spacing: .2em; text-transform: uppercase; color: var(--ink-muted); }
.fbe-hero__chips { display: flex; gap: 8px; flex-wrap: wrap; justify-content: center; }

/* ══════════════════════════════════════════════
   PROMISE
   ══════════════════════════════════════════════ */
.fbe-promise { background: var(--off); padding: var(--section-pad); }
.fbe-promise__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 100px; align-items: center; max-width: var(--max-width); margin: 0 auto; }
.fbe-promise__img-frame { width: 100%; aspect-ratio: 4/5; background: var(--silver-pale); display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; }
.fbe-promise__img-frame::before { content: ''; position: absolute; inset: 16px; border: 1px solid rgba(201,168,76,.22); pointer-events: none; z-index: 2; }
.fbe-promise__img-frame img { width: 52%; opacity: .14; filter: grayscale(1); }
.fbe-promise__float { position: absolute; bottom: -24px; right: -24px; background: var(--white); border: 1px solid rgba(201,168,76,.28); padding: 26px 30px; box-shadow: 0 16px 50px rgba(0,0,0,.08); min-width: 180px; }
.fbe-promise__float-num { font-family: var(--font-serif); font-size: 3.2rem; font-weight: 300; line-height: 1; background: var(--grad-gold); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
.fbe-promise__float-label { font-size: .66rem; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-muted); margin-top: 6px; }
.fbe-promise__features { margin-top: 40px; display: flex; flex-direction: column; }
.fbe-promise__feature { display: grid; grid-template-columns: 44px 1fr; gap: 16px; padding: 22px 0; border-bottom: 1px solid rgba(0,0,0,.07); align-items: start; transition: padding-left var(--transition); }
.fbe-promise__feature:last-child { border-bottom: none; }
.fbe-promise__feature:hover { padding-left: 8px; }
.fbe-promise__feature-num { font-family: var(--font-serif); font-size: 1rem; color: var(--gold); padding-top: 2px; }
.fbe-promise__feature-title { font-size: .78rem; font-weight: 600; letter-spacing: .07em; text-transform: uppercase; margin-bottom: 5px; }
.fbe-promise__feature-body { font-size: .85rem; line-height: 1.75; color: var(--ink-muted); font-weight: 300; }

/* ══════════════════════════════════════════════
   SERVICES
   ══════════════════════════════════════════════ */
.fbe-services { background: var(--white); padding: var(--section-pad); }
.fbe-svc__grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; margin-top: 64px; border: 1px solid rgba(0,0,0,.07); }
.fbe-svc-card { padding: 44px 32px; background: var(--white); position: relative; overflow: hidden; transition: background .4s; }
.fbe-svc-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: var(--grad-gold); transform: scaleX(0); transform-origin: left; transition: transform .5s; }
.fbe-svc-card:hover { background: var(--off); }
.fbe-svc-card:hover::before { transform: scaleX(1); }
.fbe-svc-card__num { font-family: var(--font-serif); font-size: 4rem; font-weight: 300; color: rgba(0,0,0,.04); line-height: 1; margin-bottom: 20px; transition: color .3s; }
.fbe-svc-card:hover .fbe-svc-card__num { color: rgba(201,168,76,.1); }
.fbe-svc-card__icon { font-size: 1.5rem; margin-bottom: 14px; display: block; }
.fbe-svc-card__title { font-family: var(--font-serif); font-size: 1.45rem; font-weight: 400; margin-bottom: 12px; }
.fbe-svc-card__body { font-size: .84rem; line-height: 1.8; color: var(--ink-muted); margin-bottom: 22px; font-weight: 300; }
.fbe-svc-card__tags { display: flex; flex-wrap: wrap; gap: 6px; }
.fbe-svc-tag { font-size: .58rem; letter-spacing: .1em; text-transform: uppercase; font-weight: 500; padding: 5px 11px; border: 1px solid var(--silver-light); color: var(--ink-muted); transition: border-color .2s, color .2s; }
.fbe-svc-card:hover .fbe-svc-tag { border-color: rgba(201,168,76,.35); color: var(--gold-dark); }

/* ══════════════════════════════════════════════
   EVENTS
   ══════════════════════════════════════════════ */
.fbe-events { background: var(--off); padding: var(--section-pad); }
.fbe-events__grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; margin-top: 64px; }
.fbe-event-card { position: relative; overflow: hidden; aspect-ratio: 3/4; cursor: pointer; }
.fbe-event-card__bg { position: absolute; inset: 0; transition: transform .6s ease; }
.fbe-event-card:hover .fbe-event-card__bg { transform: scale(1.05); }
.fbe-event-card--hochzeit .fbe-event-card__bg    { background: linear-gradient(155deg,#F5EDD4,#E8D5AA); }
.fbe-event-card--geburtstag .fbe-event-card__bg  { background: linear-gradient(155deg,#E8EDF5,#C8D4E8); }
.fbe-event-card--firmen .fbe-event-card__bg      { background: linear-gradient(155deg,#F0F0F0,#D8D8D8); }
.fbe-event-card--sonstige .fbe-event-card__bg    { background: linear-gradient(155deg,#F5F0E8,#E0D5C0); }
.fbe-event-card__icon { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-60%); font-size: 3rem; opacity: .3; transition: opacity .3s, transform .3s; }
.fbe-event-card:hover .fbe-event-card__icon { opacity: .45; transform: translate(-50%,-65%); }
.fbe-event-card__border { position: absolute; inset: 12px; border: 1px solid rgba(201,168,76,.2); pointer-events: none; transition: inset .4s, border-color .4s; }
.fbe-event-card:hover .fbe-event-card__border { inset: 7px; border-color: rgba(201,168,76,.5); }
.fbe-event-card__overlay { position: absolute; bottom: 0; left: 0; right: 0; padding: 28px 20px 20px; background: linear-gradient(to top, rgba(255,255,255,.94), transparent); }
.fbe-event-card__label { font-size: .58rem; letter-spacing: .18em; text-transform: uppercase; color: var(--gold); font-weight: 500; margin-bottom: 5px; }
.fbe-event-card__title { font-family: var(--font-serif); font-size: 1.3rem; font-weight: 400; }

/* ══════════════════════════════════════════════
   PRICING
   ══════════════════════════════════════════════ */
.fbe-pricing { background: var(--white); padding: var(--section-pad); }
.fbe-pricing__grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; margin-top: 64px; align-items: start; }
.fbe-price-card { border: 1px solid rgba(0,0,0,.09); padding: 42px 32px; position: relative; transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition); background: var(--white); }
.fbe-price-card:hover { border-color: rgba(201,168,76,.4); box-shadow: 0 16px 60px rgba(201,168,76,.1); transform: translateY(-4px); }
.fbe-price-card--featured { background: var(--ink); border-color: var(--ink); color: white; }
.fbe-price-card--featured:hover { border-color: var(--gold); box-shadow: 0 20px 60px rgba(0,0,0,.2); }
.fbe-price-card__top-bar { position: absolute; top: -1px; left: 0; right: 0; height: 2px; background: var(--grad-gold); opacity: 0; transition: opacity .3s; }
.fbe-price-card:hover .fbe-price-card__top-bar,
.fbe-price-card--featured .fbe-price-card__top-bar { opacity: 1; }
.fbe-price-card__recommended { font-size: .58rem; letter-spacing: .15em; text-transform: uppercase; font-weight: 600; color: var(--gold); border: 1px solid rgba(201,168,76,.45); padding: 5px 12px; display: inline-block; margin-bottom: 24px; }
.fbe-price-card__plan { font-size: .66rem; letter-spacing: .18em; text-transform: uppercase; color: var(--gold); font-weight: 500; margin-bottom: 12px; }
.fbe-price-card__amount { font-family: var(--font-serif); font-size: 3.8rem; font-weight: 300; line-height: 1; margin-bottom: 4px; }
.fbe-price-card__amount sup { font-size: 1.3rem; vertical-align: super; margin-right: 2px; }
.fbe-price-card__note { font-size: .73rem; color: var(--ink-muted); letter-spacing: .04em; margin-bottom: 30px; }
.fbe-price-card--featured .fbe-price-card__note { color: rgba(255,255,255,.38); }
.fbe-price-card__sep { height: 1px; background: rgba(0,0,0,.07); margin-bottom: 24px; }
.fbe-price-card--featured .fbe-price-card__sep { background: rgba(255,255,255,.12); }
.fbe-price-card__list { list-style: none; display: flex; flex-direction: column; gap: 11px; margin-bottom: 36px; }
.fbe-price-card__list li { display: flex; align-items: flex-start; gap: 11px; font-size: .84rem; line-height: 1.55; font-weight: 300; }
.fbe-price-card__list li::before { content: '—'; color: var(--gold); flex-shrink: 0; }
.fbe-price-card--featured .fbe-price-card__list li { color: rgba(255,255,255,.72); }
.fbe-pricing__note { text-align: center; margin-top: 28px; font-size: .76rem; color: var(--ink-muted); letter-spacing: .04em; }

/* ══════════════════════════════════════════════
   PROCESS
   ══════════════════════════════════════════════ */
.fbe-process { background: var(--off); padding: var(--section-pad); }
.fbe-process__steps { display: grid; grid-template-columns: repeat(4,1fr); margin-top: 64px; }
.fbe-proc-step { padding: 36px 28px; border-right: 1px solid rgba(0,0,0,.07); position: relative; transition: background .3s; }
.fbe-proc-step:last-child { border-right: none; }
.fbe-proc-step:hover { background: white; }
.fbe-proc-step__arrow { position: absolute; top: 50%; right: -10px; width: 20px; height: 20px; background: white; border: 1px solid rgba(201,168,76,.28); transform: rotate(45deg) translateY(-50%); z-index: 1; }
.fbe-proc-step:last-child .fbe-proc-step__arrow { display: none; }
.fbe-proc-step__num { font-family: var(--font-serif); font-size: 4.5rem; font-weight: 300; color: rgba(0,0,0,.04); line-height: 1; margin-bottom: 16px; transition: color .3s; }
.fbe-proc-step:hover .fbe-proc-step__num { color: rgba(201,168,76,.1); }
.fbe-proc-step__title { font-size: .76rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; margin-bottom: 10px; }
.fbe-proc-step__body { font-size: .83rem; line-height: 1.8; color: var(--ink-muted); font-weight: 300; }

/* ══════════════════════════════════════════════
   TESTIMONIALS
   ══════════════════════════════════════════════ */
.fbe-testimonials { background: var(--white); padding: var(--section-pad); }
.fbe-testi__grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; margin-top: 64px; }
.fbe-testi-card { border: 1px solid rgba(0,0,0,.07); padding: 38px 30px; position: relative; transition: border-color .3s, transform .3s; }
.fbe-testi-card:hover { border-color: rgba(201,168,76,.35); transform: translateY(-4px); }
.fbe-testi-card__quote { font-family: var(--font-serif); font-size: 3.5rem; line-height: .8; color: var(--gold-pale); margin-bottom: 14px; display: block; }
.fbe-testi-card__stars { display: flex; gap: 3px; margin-bottom: 16px; }
.fbe-star { width: 9px; height: 9px; background: var(--gold); clip-path: polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%); }
.fbe-testi-card__text { font-size: .86rem; line-height: 1.85; color: var(--ink-soft); font-weight: 300; font-style: italic; margin-bottom: 24px; }
.fbe-testi-card__sep { width: 28px; height: 1px; background: var(--gold); opacity: .5; margin-bottom: 18px; }
.fbe-testi-card__name { font-size: .76rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; }
.fbe-testi-card__sub { font-size: .7rem; color: var(--ink-muted); margin-top: 3px; }

/* ══════════════════════════════════════════════
   CTA BAND
   ══════════════════════════════════════════════ */
.fbe-cta-band { background: var(--ink); padding: 100px 10%; display: grid; grid-template-columns: 1fr auto; gap: 60px; align-items: center; position: relative; overflow: hidden; }
.fbe-cta-band::before { content: ''; position: absolute; top: -80px; right: -80px; width: 450px; height: 450px; border-radius: 50%; background: radial-gradient(circle,rgba(201,168,76,.05),transparent 60%); pointer-events: none; }
.fbe-cta-band__eyebrow { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.fbe-cta-band__eyebrow-line { width: 24px; height: 1px; background: var(--gold); }
.fbe-cta-band__eyebrow-text { font-size: .6rem; letter-spacing: .2em; text-transform: uppercase; color: var(--gold); font-weight: 500; }
.fbe-cta-band__title { font-family: var(--font-serif); font-size: clamp(2rem,3.5vw,3rem); font-weight: 300; color: white; line-height: 1.15; }
.fbe-cta-band__title em { font-style: italic; color: var(--gold-light); }
.fbe-cta-band__actions { display: flex; flex-direction: column; gap: 14px; align-items: flex-start; }
.fbe-cta-band__sub { font-size: .66rem; letter-spacing: .1em; color: rgba(255,255,255,.28); text-transform: uppercase; }

/* ══════════════════════════════════════════════
   CONTACT
   ══════════════════════════════════════════════ */
.fbe-contact { background: var(--off); padding: var(--section-pad); }
.fbe-contact__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 100px; align-items: start; max-width: var(--max-width); margin: 0 auto; }
.fbe-contact__items { display: flex; flex-direction: column; margin-top: 36px; }
.fbe-contact__item { padding: 20px 0; border-bottom: 1px solid rgba(0,0,0,.07); }
.fbe-contact__item:last-child { border-bottom: none; }
.fbe-contact__item-label { font-size: .6rem; letter-spacing: .2em; text-transform: uppercase; color: var(--gold); font-weight: 500; margin-bottom: 5px; display: block; }
.fbe-contact__item-value { font-size: .95rem; font-weight: 300; color: var(--ink); }
.fbe-contact__item-value a { transition: color .2s; }
.fbe-contact__item-value a:hover { color: var(--gold-dark); }
.fbe-contact__form-wrap { background: white; padding: 48px 40px; border: 1px solid rgba(0,0,0,.07); position: relative; }
.fbe-contact__form-wrap::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: var(--grad-gold); }

/* ── FORM (CF7 + native) ── */
.fbe-form .fbe-form__row,
.fbe-form .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 20px; }
.fbe-form .fbe-form__field,
.fbe-form .form-field { display: flex; flex-direction: column; gap: 8px; }
.fbe-form .fbe-form__field--full,
.fbe-form .form-field.full { grid-column: 1/-1; }
.fbe-form label,
.fbe-form .form-field label { font-size: .6rem; letter-spacing: .16em; text-transform: uppercase; font-weight: 500; color: var(--ink-muted); }
.fbe-form input[type="text"],
.fbe-form input[type="email"],
.fbe-form input[type="tel"],
.fbe-form input[type="date"],
.fbe-form select,
.fbe-form textarea {
  border: none; border-bottom: 1px solid rgba(0,0,0,.14);
  padding: 12px 0; font-size: .88rem; font-family: var(--font-sans); font-weight: 300;
  color: var(--ink); background: transparent; outline: none;
  transition: border-color var(--transition); -webkit-appearance: none; border-radius: 0;
}
.fbe-form input:focus, .fbe-form select:focus, .fbe-form textarea:focus { border-bottom-color: var(--gold); }
.fbe-form textarea { resize: vertical; min-height: 80px; }
.fbe-form input::placeholder, .fbe-form textarea::placeholder { color: var(--silver); }

/* CF7 Wrapper-Anpassungen */
.wpcf7-form { display: contents; }
.wpcf7-form p { margin: 0; }
.wpcf7-not-valid-tip { font-size: .72rem; color: #c0392b; margin-top: 4px; }
.wpcf7-response-output { font-size: .8rem; margin-top: 12px; padding: 12px 16px; border: 1px solid; }
.wpcf7-response-output.wpcf7-mail-sent-ok { border-color: var(--gold); color: var(--gold-dark); background: var(--gold-pale); }

/* ══════════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════════ */
.fbe-footer { background: var(--ink); padding: 56px 10% 28px; }
.fbe-footer__inner { max-width: 1400px; margin: 0 auto; }
.fbe-footer__top { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 40px; padding-bottom: 36px; border-bottom: 1px solid rgba(255,255,255,.08); margin-bottom: 24px; }
.fbe-footer__logo { display: flex; align-items: center; gap: 14px; }
.fbe-footer__logo img, .fbe-footer__logo .custom-logo { height: 30px; opacity: .35; filter: grayscale(1); }
.fbe-footer__logo-name { font-family: var(--font-serif); font-size: .95rem; color: rgba(255,255,255,.45); letter-spacing: .06em; }
.fbe-footer__tagline { font-size: .72rem; color: rgba(255,255,255,.25); margin-top: 6px; }
.fbe-footer__contact { display: flex; flex-direction: column; gap: 8px; margin-top: 20px; }
.fbe-footer__contact-item { display: flex; align-items: center; gap: 8px; font-size: .78rem; color: rgba(255,255,255,.35); }
.fbe-footer__contact-item svg { flex-shrink: 0; opacity: .5; }
.fbe-footer__contact-item a { color: rgba(255,255,255,.35); transition: color .2s; }
.fbe-footer__contact-item a:hover { color: var(--gold); }
.fbe-footer__social { display: flex; gap: 14px; margin-top: 24px; }
.fbe-social-icon { color: rgba(255,255,255,.3); transition: color .2s, transform .2s; display: block; }
.fbe-social-icon:hover { color: var(--gold); transform: translateY(-2px); }
.fbe-footer__divider { height: 1px; background: linear-gradient(90deg,transparent,rgba(201,168,76,.28),transparent); }
.fbe-footer__widgets { display: flex; gap: 60px; }
.fbe-footer__widget-col { min-width: 160px; }
.fbe-footer__widget-col .widget-title { font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.4); margin-bottom: 14px; }
.fbe-footer__widget-col ul li { margin-bottom: 8px; }
.fbe-footer__widget-col ul li a { font-size: .8rem; color: rgba(255,255,255,.28); transition: color .2s; }
.fbe-footer__widget-col ul li a:hover { color: var(--gold); }
.fbe-footer__bottom { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 10px; padding-top: 24px; }
.fbe-footer__copy { font-size: .68rem; letter-spacing: .05em; color: rgba(255,255,255,.28); }
.fbe-footer__nav-list { display: flex; gap: 24px; }
.fbe-footer__nav-list li a { font-size: .6rem; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.28); transition: color .2s; }
.fbe-footer__nav-list li a:hover { color: var(--gold); }
.fbe-footer__made { font-size: .6rem; letter-spacing: .1em; color: rgba(201,168,76,.35); }

/* ── BLOG / POSTS ── */
.fbe-blog-container { max-width: var(--max-width); margin: 120px auto; padding: 0 5%; }
.fbe-post-card { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; padding: 60px 0; border-bottom: 1px solid rgba(0,0,0,.07); }
.fbe-post-card:last-child { border-bottom: none; }
.fbe-post-card__date { font-size: .66rem; letter-spacing: .16em; text-transform: uppercase; color: var(--gold); }
.fbe-post-card__title { font-family: var(--font-serif); font-size: 2rem; font-weight: 300; margin: 12px 0 16px; line-height: 1.2; }
.fbe-post-card__title a { color: var(--ink); transition: color .2s; }
.fbe-post-card__title a:hover { color: var(--gold-dark); }
.fbe-post-card__excerpt { font-size: .88rem; line-height: 1.8; color: var(--ink-muted); margin-bottom: 24px; }

/* ══════════════════════════════════════════════
   KEYFRAMES
   ══════════════════════════════════════════════ */
@keyframes riseIn { from { opacity:0; transform:translateY(22px); } to { opacity:1; transform:none; } }
@keyframes floatLogo { 0%,100% { transform:translateY(0) rotate(-1deg); } 50% { transform:translateY(-14px) rotate(1deg); } }

/* ══════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════ */
@media (max-width: 1024px) {
  :root { --section-pad: 80px 6%; }
  .fbe-svc__grid { grid-template-columns: 1fr 1fr; }
  .fbe-events__grid { grid-template-columns: repeat(2,1fr); }
  .fbe-pricing-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
  body { cursor: auto; }
  #fbe-cursor, #fbe-cursor-ring { display: none; }
  :root { --section-pad: 60px 5%; }
  .fbe-header__nav, .fbe-header__cta { display: none; }
  .fbe-hamburger { display: flex; }
  .fbe-hero { grid-template-columns: 1fr; padding-top: 82px; }
  .fbe-hero__right { display: none; }
  .fbe-hero__left { padding: 60px 6%; }
  .fbe-promise__grid { grid-template-columns: 1fr; gap: 48px; }
  .fbe-promise__float { position: static; margin-top: 20px; }
  .fbe-svc__grid { grid-template-columns: 1fr; }
  .fbe-events__grid { grid-template-columns: 1fr 1fr; }
  .fbe-pricing__grid { grid-template-columns: 1fr; }
  .fbe-process__steps { grid-template-columns: 1fr 1fr; }
  .fbe-testi__grid { grid-template-columns: 1fr; }
  .fbe-cta-band { grid-template-columns: 1fr; }
  .fbe-contact__grid { grid-template-columns: 1fr; gap: 48px; }
  .fbe-form .fbe-form__row, .fbe-form .form-row { grid-template-columns: 1fr; }
  .fbe-footer__top { grid-template-columns: 1fr; text-align: center; }
  .fbe-footer__social, .fbe-footer__contact { justify-content: center; align-items: center; }
  .fbe-footer__widgets { flex-direction: column; gap: 32px; }
  .fbe-post-card { grid-template-columns: 1fr; gap: 24px; }
}
@media (max-width: 480px) {
  .fbe-events__grid { grid-template-columns: 1fr; }
  .fbe-process__steps { grid-template-columns: 1fr; }
  .fbe-hero__actions { flex-direction: column; align-items: flex-start; }
}

/* ── TRUST BAR ── */
.fbe-trust-bar { background: var(--gold-pale); padding: 18px 10%; border-bottom: 1px solid rgba(201,168,76,.15); }
.fbe-trust-bar__inner { max-width: var(--max-width); margin: 0 auto; display: flex; align-items: center; justify-content: center; gap: 40px; flex-wrap: wrap; }
.fbe-trust-bar__item { display: flex; align-items: center; gap: 9px; font-size: .78rem; font-weight: 500; color: var(--gold-dark); letter-spacing: .04em; }
