/* ═══════════════════════════════════════════
   Market Value Advisory — style.css
   ═══════════════════════════════════════════ */

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

:root {
  --bg: #f0efe9;
  --black: #0e0e0e;
  --text: #1c1c1c;
  --muted: #999;
  --blue: #2563EB;
  --glass: rgba(255,255,255,0.62);
  --glass-b: rgba(255,255,255,0.92);
}

html { scroll-behavior:smooth; }

body {
  font-family:'Plus Jakarta Sans',sans-serif;
  background:var(--bg);
  color:var(--text);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
  /* KEIN transform/animation auf body — sonst bricht position:fixed bei sticky + nav + modals */
}

/* Page fade läuft auf dem Content-Wrapper, nicht auf body */
.page-wrap {
  animation: pageIn .8s ease .05s both;
}

@keyframes pageIn {
  from { opacity:0; transform:translateY(6px); }
  to   { opacity:1; transform:translateY(0); }
}

/* ─── AURORA BLOBS ─── */
.bg-layer {
  position:fixed; inset:0; z-index:0;
  pointer-events:none; overflow:hidden;
  transition: transform .9s cubic-bezier(.25,.46,.45,.94);
}

.blob {
  position:absolute;
  border-radius:50%;
  filter:blur(80px);
  will-change:transform;
  mix-blend-mode: multiply;
}

/* Warmes Gold-Beige oben links */
.b1 {
  width:900px; height:800px;
  top:-200px; left:-200px;
  background:radial-gradient(circle, rgba(200,185,155,0.85) 0%, transparent 60%);
  animation: aurora1 26s ease-in-out infinite;
}
/* Kräftiges Blau rechts */
.b2 {
  width:800px; height:700px;
  top:10%; right:-180px;
  background:radial-gradient(circle, rgba(100,150,230,0.55) 0%, transparent 60%);
  animation: aurora2 30s ease-in-out infinite;
}
/* Lavendel unten links */
.b3 {
  width:700px; height:600px;
  bottom:-100px; left:5%;
  background:radial-gradient(circle, rgba(180,155,220,0.55) 0%, transparent 60%);
  animation: aurora3 22s ease-in-out infinite;
}
/* Warmes Amber Mitte-rechts */
.b4 {
  width:550px; height:550px;
  top:45%; right:15%;
  background:radial-gradient(circle, rgba(220,185,120,0.5) 0%, transparent 60%);
  animation: aurora4 34s ease-in-out infinite;
}
/* Soft Cyan Mitte */
.b5 {
  width:500px; height:450px;
  top:20%; left:28%;
  background:radial-gradient(circle, rgba(120,195,220,0.45) 0%, transparent 60%);
  animation: aurora1 20s ease-in-out infinite reverse;
}

@keyframes aurora1 {
  0%,100% { transform:translate(0,0) scale(1); }
  25%     { transform:translate(55px,-40px) scale(1.06); }
  50%     { transform:translate(25px,35px) scale(0.97); }
  75%     { transform:translate(-35px,-18px) scale(1.03); }
}
@keyframes aurora2 {
  0%,100% { transform:translate(0,0) scale(1); }
  30%     { transform:translate(-60px,50px) scale(1.08); }
  65%     { transform:translate(45px,-30px) scale(0.94); }
}
@keyframes aurora3 {
  0%,100% { transform:translate(0,0) scale(1); }
  40%     { transform:translate(50px,65px) scale(1.05); }
  80%     { transform:translate(-25px,28px) scale(0.98); }
}
@keyframes aurora4 {
  0%,100% { transform:translate(0,0) scale(1); }
  35%     { transform:translate(-45px,-55px) scale(1.1); }
  70%     { transform:translate(35px,22px) scale(0.93); }
}

/* ─── GLASS UTILITY ─── */
.glass {
  background:var(--glass);
  backdrop-filter:blur(48px) saturate(200%);
  -webkit-backdrop-filter:blur(48px) saturate(200%);
  border:1px solid var(--glass-b);
  border-radius:20px;
  box-shadow:
    0 2px 0 rgba(255,255,255,1) inset,
    0 1px 0 rgba(255,255,255,0.8),
    0 20px 60px rgba(0,0,0,0.06),
    0 4px 16px rgba(0,0,0,0.04);
  transition:transform .25s cubic-bezier(.25,.46,.45,.94), box-shadow .25s ease;
}

/* ─── NAV PILL ─── */
.nav-pill {
  position:fixed; top:20px; left:50%; transform:translateX(-50%);
  z-index:100;
  background:rgba(255,255,255,0.70);
  backdrop-filter:blur(32px) saturate(200%);
  -webkit-backdrop-filter:blur(32px) saturate(200%);
  border:1px solid rgba(255,255,255,0.95);
  border-radius:100px;
  padding:10px 16px 10px 20px;
  display:flex; align-items:center; gap:16px;
  box-shadow:0 2px 0 rgba(255,255,255,1) inset, 0 8px 32px rgba(0,0,0,0.09), 0 2px 8px rgba(0,0,0,0.05);
  white-space:nowrap;
}
.nav-logo svg { height:16px; width:auto; }
.nav-sep { width:1px; height:18px; background:rgba(0,0,0,0.08); }

.lang-pill {
  display:flex; background:rgba(0,0,0,0.05);
  border:1px solid rgba(0,0,0,0.07);
  border-radius:100px; padding:3px; gap:2px;
}
.lang-btn {
  font-size:11px; font-weight:700; letter-spacing:.03em;
  padding:4px 11px; border-radius:100px; cursor:pointer;
  border:none; background:transparent; color:#aaa;
  font-family:inherit; transition:all .2s;
}
.lang-btn.active { background:var(--black); color:white; }

/* ─── LAYOUT ─── */
.wrap { position:relative; z-index:2; max-width:1060px; margin:0 auto; padding:0 32px; }

/* ─── HERO ─── */
.hero {
  min-height:100vh;
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  text-align:center;
  padding:120px 32px 80px;
  position:relative; z-index:2;
}
.hero-inner {
  display:flex; flex-direction:column; align-items:center;
  will-change:transform;
  transition:transform .45s cubic-bezier(.25,.46,.45,.94);
}

.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(255,255,255,0.75);
  border:1px solid rgba(0,0,0,0.07);
  border-radius:100px; padding:6px 16px 6px 10px;
  font-size:11.5px; font-weight:600; color:#888;
  letter-spacing:.02em; margin-bottom:32px;
  backdrop-filter:blur(16px);
  box-shadow:0 2px 8px rgba(0,0,0,0.05);
  animation:fadeUp .6s ease .15s both;
}
.badge-dot { width:7px; height:7px; border-radius:50%; background:rgba(0,0,0,0.2); }

.hero-h {
  font-size:clamp(2.4rem,5.5vw,4.8rem);
  font-weight:800; letter-spacing:-.045em; line-height:1.06;
  color:var(--black); max-width:820px; margin-bottom:22px;
  animation:fadeUp .7s ease .3s both;
}
.hero-sub {
  font-size:17px; font-weight:400; color:#888;
  line-height:1.65; max-width:480px; margin-bottom:0;
  animation:fadeUp .7s ease .45s both;
}

.hero-scroll {
  position:absolute; bottom:40px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:8px;
  animation:fadeUp .7s ease .9s both;
}
.hero-scroll span { font-size:11px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:#ccc; }
.scroll-line { width:1px; height:32px; background:linear-gradient(to bottom, rgba(0,0,0,0.15), transparent); }

@keyframes fadeUp {
  from { opacity:0; transform:translateY(18px); }
  to   { opacity:1; transform:translateY(0); }
}

/* ─── BENTO GRID ─── */
.app-section { padding:0 0 120px; position:relative; z-index:2; }
.bento { display:grid; grid-template-columns:repeat(12,1fr); gap:12px; }

/* Card base */
.bc {
  padding:28px 28px 24px; position:relative; overflow:hidden;
  transition:transform .25s cubic-bezier(.25,.46,.45,.94), box-shadow .25s ease;
}
.bc:hover {
  transform:translateY(-5px) scale(1.009);
  box-shadow:0 2px 0 rgba(255,255,255,1) inset, 0 1px 0 rgba(255,255,255,0.8), 0 32px 80px rgba(0,0,0,0.1), 0 8px 28px rgba(0,0,0,0.07);
}

/* Card sizes */
.bc-workshop     { grid-column:span 7; min-height:260px; }
.bc-erstgespraech{ grid-column:span 5; min-height:260px; }
.bc-blog         { grid-column:span 4; }
.bc-about        { grid-column:span 4; }
.bc-produkte     { grid-column:span 4; }

.bc-eyebrow { font-size:10px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:#bbb; margin-bottom:14px; }
.bc-title   { font-size:1.15rem; font-weight:800; letter-spacing:-.025em; line-height:1.2; color:var(--black); margin-bottom:10px; }
.bc-text    { font-size:13px; color:#aaa; line-height:1.65; }

.bc-icon {
  width:40px; height:40px; border-radius:13px;
  background:rgba(0,0,0,0.05);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:18px;
}
.bc-icon svg { width:18px; height:18px; stroke:rgba(0,0,0,0.45); stroke-width:1.6; fill:none; }

/* Workshop card */
.bc-workshop .bc-title { font-size:1.4rem; }
.bc-workshop .bc-text  { font-size:13.5px; color:#888; }
.bc-workshop::after {
  content:''; position:absolute; right:-80px; top:-80px;
  width:260px; height:260px; border-radius:50%;
  background:radial-gradient(circle, rgba(37,99,235,0.07) 0%, transparent 65%);
  pointer-events:none;
}

/* Erstgespräch — blue */
.bc-erstgespraech {
  background:rgba(37,99,235,0.92) !important;
  backdrop-filter:blur(48px) saturate(200%);
  -webkit-backdrop-filter:blur(48px) saturate(200%);
  border:1px solid rgba(255,255,255,0.15) !important;
  border-radius:20px;
  box-shadow:0 20px 60px rgba(37,99,235,0.25), 0 4px 16px rgba(37,99,235,0.15) !important;
  display:flex; flex-direction:column; justify-content:space-between;
}
.bc-erstgespraech .bc-eyebrow { color:rgba(255,255,255,0.5); }
.bc-erstgespraech .bc-title   { color:white; font-size:1.4rem; }
.bc-erstgespraech .bc-text    { color:rgba(255,255,255,0.65); }
.bc-erstgespraech .bc-icon    { background:rgba(255,255,255,0.15); }
.bc-erstgespraech .bc-icon svg{ stroke:rgba(255,255,255,0.8); }

/* ─── BUTTONS ─── */
.bc-btn {
  display:inline-flex; align-items:center; gap:7px; margin-top:20px;
  background:var(--blue); color:white;
  border-radius:100px; padding:10px 18px;
  font-size:12.5px; font-weight:700; text-decoration:none;
  transition:opacity .2s, transform .15s;
  box-shadow:0 4px 14px rgba(37,99,235,0.22);
}
.bc-btn:hover { opacity:.88; transform:translateY(-1px); }
.bc-btn svg   { width:11px; height:11px; stroke:white; stroke-width:2.5; fill:none; }

.bc-btn-white {
  display:inline-flex; align-items:center; gap:7px; margin-top:20px;
  background:white; color:var(--black);
  border-radius:100px; padding:10px 18px;
  font-size:12.5px; font-weight:700; text-decoration:none;
  transition:opacity .2s, transform .15s;
  box-shadow:0 4px 14px rgba(255,255,255,0.12);
}
.bc-btn-white:hover { opacity:.9; transform:translateY(-1px); }
.bc-btn-white svg   { width:11px; height:11px; stroke:var(--black); stroke-width:2.5; fill:none; }

.bc-btn-ghost {
  display:inline-flex; align-items:center; gap:7px; margin-top:20px;
  background:rgba(255,255,255,0.8); color:var(--text);
  border:1px solid rgba(0,0,0,0.09);
  border-radius:100px; padding:10px 18px;
  font-size:12.5px; font-weight:600; text-decoration:none;
  transition:all .2s;
}
.bc-btn-ghost:hover { background:white; transform:translateY(-1px); }
.bc-btn-ghost svg   { width:11px; height:11px; stroke:var(--text); stroke-width:2.5; fill:none; }

/* ─── SCROLL FADE ─── */
.fade-up { opacity:0; transform:translateY(20px); transition:opacity .55s ease, transform .55s ease; }
.fade-up.visible { opacity:1; transform:translateY(0); }
.fd1 { transition-delay:.06s; }
.fd2 { transition-delay:.13s; }
.fd3 { transition-delay:.20s; }
.fd4 { transition-delay:.27s; }
.fd5 { transition-delay:.34s; }

/* ─── MODALS ─── */
.modal-overlay {
  /* position:fixed = immer relativ zum Viewport, egal wie weit gescrollt */
  position:fixed;
  top:0; left:0; right:0; bottom:0;
  z-index:9999;
  background:rgba(240,239,233,0.6);
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  /* Overlay zentriert die Box — scrollt selbst NIE */
  display:flex;
  align-items:center;
  justify-content:center;
  padding:20px;
  opacity:0; pointer-events:none;
  transition:opacity .3s ease;
}
.modal-overlay.open { opacity:1; pointer-events:all; }

/* modal-inner nicht mehr nötig — wird ignoriert */
.modal-inner { display:contents; }

.modal-box {
  position:relative;
  background:rgba(255,255,255,0.94);
  backdrop-filter:blur(60px) saturate(200%);
  -webkit-backdrop-filter:blur(60px) saturate(200%);
  border:1px solid rgba(255,255,255,0.95);
  border-radius:28px;
  box-shadow:0 2px 0 rgba(255,255,255,1) inset, 0 32px 80px rgba(0,0,0,0.12), 0 8px 24px rgba(0,0,0,0.07);
  max-width:600px; width:100%;
  /* Box scrollt intern — max 82% des Viewports */
  max-height:82vh;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  padding:36px;
  transform:translateY(14px) scale(0.98);
  transition:transform .3s ease;
}
.modal-overlay.open .modal-box { transform:translateY(0) scale(1); }

.modal-close {
  position:absolute; top:20px; right:20px;
  width:32px; height:32px; border-radius:50%;
  background:rgba(0,0,0,0.07); border:none; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:background .2s; font-family:inherit;
}
.modal-close:hover { background:rgba(0,0,0,0.12); }
.modal-close svg { width:14px; height:14px; stroke:rgba(0,0,0,0.5); stroke-width:2; fill:none; }

.modal-eyebrow      { font-size:10px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:#bbb; margin-bottom:14px; }
.modal-title         { font-size:1.6rem; font-weight:800; letter-spacing:-.03em; line-height:1.15; color:var(--black); margin-bottom:18px; }
.modal-body          { font-size:14px; color:#777; line-height:1.75; }
.modal-body p        { margin-bottom:14px; }
.modal-body p:last-child { margin-bottom:0; }
.modal-tags          { display:flex; flex-wrap:wrap; gap:8px; margin:20px 0; }
.modal-tag           { background:rgba(0,0,0,0.05); border:1px solid rgba(0,0,0,0.07); border-radius:100px; padding:5px 14px; font-size:12px; font-weight:600; color:#666; }
.modal-divider       { height:1px; background:rgba(0,0,0,0.07); margin:24px 0; }
.modal-section-title { font-size:12px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:#bbb; margin-bottom:12px; }

.modal-product-item  { display:flex; align-items:flex-start; gap:12px; padding:14px 0; border-bottom:1px solid rgba(0,0,0,0.06); }
.modal-product-item:last-child { border-bottom:none; }
.modal-product-dot   { width:7px; height:7px; border-radius:50%; background:var(--blue); flex-shrink:0; margin-top:6px; }
.modal-product-name  { font-size:14px; font-weight:700; color:var(--black); margin-bottom:3px; }
.modal-product-desc  { font-size:13px; color:#aaa; line-height:1.5; }

/* ─── STICKY BOTTOM ─── */
.sticky-bottom {
  position:fixed; bottom:24px; left:50%;
  transform:translateX(-50%); z-index:200;
}
.sticky-bottom a {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--blue);
  border-radius:100px; padding:14px 28px;
  font-size:14px; font-weight:700; color:white;
  text-decoration:none; letter-spacing:-.01em;
  box-shadow:0 8px 32px rgba(37,99,235,0.35), 0 2px 8px rgba(37,99,235,0.2);
  transition:opacity .2s, transform .15s;
  white-space:nowrap;
}
.sticky-bottom a:hover { opacity:.88; transform:translateY(-2px); }
.sticky-bottom svg { width:13px; height:13px; stroke:white; stroke-width:2.5; fill:none; }

/* ─── FOOTER ─── */
footer {
  position:relative; z-index:2;
  border-top:1px solid rgba(0,0,0,0.06);
  padding:28px 32px 96px;
}
.foot-inner {
  max-width:1060px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:14px;
}
.foot-inner svg   { height:15px; fill:rgba(0,0,0,0.2); width:auto; }
.foot-links       { display:flex; gap:18px; }
.foot-links a     { font-size:11.5px; color:rgba(0,0,0,0.28); text-decoration:none; transition:color .2s; }
.foot-links a:hover{ color:rgba(0,0,0,0.6); }

/* ─── RESPONSIVE ─── */
@media(max-width:768px) {
  .nav-pill { padding:8px 12px 8px 16px; gap:10px; }
  .hero     { padding:100px 20px 64px; }
  .hero-h   { font-size:2.2rem; }
  .wrap     { padding:0 16px; }
  .bento    { grid-template-columns:1fr; gap:10px; }
  .bc-workshop,.bc-erstgespraech,.bc-blog,.bc-about,.bc-produkte { grid-column:span 1; }
  footer    { padding:24px 20px 88px; }
}
