/* Virtorum UI Kit — website-specific styles built on colors_and_type.css */

/* MASTHEAD — dateline + volume (editorial FT/Economist tone) */
.v-masthead { background: var(--v-ink); color: var(--v-brass-300); padding: 6px 64px; display: flex; justify-content: space-between; align-items: center; font-family: var(--font-mono); font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; line-height: 1; white-space: nowrap; overflow: hidden; }
.v-masthead-left { display: flex; gap: 14px; align-items: center; min-width: 0; flex-shrink: 1; overflow: hidden; }
.v-masthead-line { white-space: nowrap; text-overflow: ellipsis; overflow: hidden; }
.v-masthead-dot { width: 5px; height: 5px; background: var(--v-bordeaux-lift); border-radius: 50%; display: inline-block; animation: pulse 2.4s ease-in-out infinite; }
.v-masthead-right { display: inline-flex; align-items: center; gap: 18px; }
.v-masthead-sep { display: inline-block; width: 1px; height: 12px; background: rgba(217,197,162,0.28); }
.v-masthead-link { color: var(--v-brass-300); letter-spacing: 2.5px; text-transform: uppercase; font-size: 11px; font-family: var(--font-mono); display: inline-flex; align-items: center; gap: 6px; cursor: pointer; transition: color .15s; text-decoration: none; }
.v-masthead-link:hover { color: var(--v-brass); }
.v-masthead-link.is-active { color: var(--v-brass); }
.v-masthead-link.is-active span { color: var(--v-brass); }
.v-masthead-link span { color: var(--v-bordeaux-lift); transition: transform .15s; }
.v-masthead-link:hover span { transform: translateX(2px); color: var(--v-brass); }
.v-masthead-login { color: var(--v-paper); letter-spacing: 2.5px; text-transform: uppercase; font-size: 11px; font-family: var(--font-mono); display: inline-flex; align-items: center; gap: 6px; cursor: pointer; transition: color .15s; text-decoration: none; }
.v-masthead-login:hover { color: var(--v-brass); }
.v-masthead-login span { color: var(--v-bordeaux-lift); transition: transform .15s; }
.v-masthead-login:hover span { transform: translateX(2px); color: var(--v-brass); }
@keyframes pulse { 0%, 100% { opacity: .6; } 50% { opacity: 1; } }

/* NAV */
.v-nav-minimal { position: absolute; top: 0; left: 0; right: 0; z-index: 90; display: flex; align-items: center; justify-content: flex-start; padding: 32px 80px; background: transparent; transition: opacity 280ms ease; color: var(--v-paper); }
.v-nav-minimal.is-hidden { opacity: 0; pointer-events: none; }
.v-nav-minimal.is-visible { opacity: 1; }
.v-nav-minimal .v-nav-logo { font-size: 22px; letter-spacing: 6px; color: var(--v-paper); }

.v-nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; background: var(--v-paper); border-bottom: 1px solid var(--v-border); display: flex; align-items: center; justify-content: space-between; padding: 0 64px; height: 84px; transition: transform 380ms ease, opacity 380ms ease; }
.v-nav.is-hidden { transform: translateY(-100%); opacity: 0; pointer-events: none; }
.v-nav.is-visible { transform: translateY(0); opacity: 1; }
.v-nav-logo { display: flex; align-items: center; gap: 14px; font-family: var(--font-serif); font-size: 21px; font-weight: 600; letter-spacing: 5px; text-transform: uppercase; }
.v-nav-links { display: flex; gap: 38px; align-items: center; }
.v-nav-links a { font-family: var(--font-mono); font-size: 15px; color: var(--v-ink-sub); letter-spacing: 1.2px; cursor: pointer; transition: color .15s; white-space: nowrap; position: relative; padding: 4px 0; }
.v-nav-links a:hover { color: var(--v-ink-soft); }
.v-nav-links a:hover::after { content: ''; position: absolute; left: 0; right: 0; bottom: -2px; height: 1px; background: var(--v-bordeaux); }

/* BUTTONS */
.v-btn-primary { display: inline-block; background: var(--v-bordeaux); color: #fff; padding: 14px 32px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; border: none; cursor: pointer; transition: opacity .15s; }
.v-btn-primary:hover { opacity: .85; }
.v-btn-outline { display: inline-block; background: transparent; color: var(--v-ink-soft); border: 1px solid var(--v-border); padding: 14px 32px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; cursor: pointer; transition: border-color .15s; }
.v-btn-outline:hover { border-color: var(--v-ink-soft); }
.v-btn-nav { background: var(--v-bordeaux); color: #fff; padding: 14px 28px; font-family: var(--font-mono); font-size: 13px; letter-spacing: 1.8px; text-transform: uppercase; border: none; cursor: pointer; transition: opacity .15s; white-space: nowrap; }
.v-btn-nav:hover { opacity: .88; }
.v-btn-cta { background: var(--v-bordeaux); color: #fff; padding: 18px 44px; font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 1.8px; text-transform: uppercase; border: none; cursor: pointer; white-space: nowrap; }
.v-btn-cta:hover { opacity: .88; }

/* EYEBROW */
.v-eyebrow { font-family: var(--font-mono); font-size: 11px; letter-spacing: 3px; text-transform: uppercase; color: var(--v-ink-muted); display: inline-flex; align-items: center; gap: 14px; margin-bottom: 20px; line-height: 1; }
.v-eyebrow::before { content: ''; display: block; width: 32px; height: 1px; background: var(--v-bordeaux); flex-shrink: 0; }
.tone-claret::before, .tone-bordeaux::before { background: var(--v-bordeaux); }
.tone-brass::before { background: var(--v-brass); }

/* SECTION SCAFFOLD */
.v-section { padding: 112px 64px; border-bottom: 1px solid var(--v-border); background: var(--v-paper); position: relative; }
.v-section-alt { background: var(--v-paper-alt); }
.v-section.on-dark { background: var(--v-ink); border: none; }
.v-section-header { margin-bottom: 64px; max-width: 900px; }
.v-section-sub { font-family: var(--font-mono); font-size: 13.5px; line-height: 1.8; color: var(--v-ink-sub); margin-top: 22px; max-width: 620px; }
.on-dark .v-section-sub { color: #8A8078; }
.on-dark .v-h1 { color: var(--v-paper); }
.on-dark .v-h1 em { color: var(--v-brass); }
.on-dark .v-eyebrow { color: #8A8078; }
.on-dark .v-eyebrow::before { background: var(--v-brass); }

/* HERO */
.v-hero { display: grid; grid-template-columns: minmax(0,1fr) minmax(600px, 720px); border-bottom: 1px solid var(--v-border); position: relative; }
.v-hero-left { padding: 72px 64px; display: flex; flex-direction: column; justify-content: center; border-right: 1px solid var(--v-border); position: relative; min-width: 0; }
.v-hero-dateline { font-family: var(--font-mono); font-size: 11px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--v-ink-muted); margin: 0 0 28px; display: flex; gap: 14px; align-items: center; }
.v-hero-dateline::before { content: ''; width: 40px; height: 1px; background: var(--v-bordeaux); }
.v-h-hero { font-family: var(--font-serif); font-weight: 300; font-style: italic; font-size: clamp(40px, 4.4vw, 56px); line-height: 1.12; color: var(--v-ink-soft); margin: 0 0 32px 0; letter-spacing: -0.015em; }
.v-h-hero em { font-style: normal; color: var(--v-bordeaux); }
.v-h-hero-soft { color: var(--v-ink-muted); }
.v-hero-sub { font-family: var(--font-mono); font-size: 15px; font-weight: 300; line-height: 1.7; color: var(--v-ink-sub); max-width: 560px; margin: 0 0 36px 0; }
.v-hero-sub strong { font-weight: 500; color: var(--v-ink-soft); }
.v-hero-btns { display: flex; gap: 12px; margin: 0 0 32px 0; }
.v-hero-qs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--v-border); padding-top: 24px; margin-top: 0; }
.v-hero-q { font-family: var(--font-mono); font-size: 13.5px; color: var(--v-ink-muted); line-height: 1.6; padding: 0 24px; border-right: 1px solid var(--v-border); }
.v-hero-q:first-child { padding-left: 0; }
.v-hero-q:last-child { border-right: none; padding-right: 0; }
.v-hero-q strong { display: block; font-family: var(--font-serif); font-style: italic; font-weight: 400; font-size: 20px; color: var(--v-ink-soft); margin-bottom: 8px; letter-spacing: -0.01em; }
.v-hero-right { display: flex; flex-direction: column; gap: 0; background: var(--v-paper); }

/* HERO CHAPTERS — shared base, used by .wie */
.v-hero-chapter { padding: 26px 32px 24px; position: relative; border-bottom: 1px solid var(--v-border); }
.v-hero-chapter.wie { background: var(--v-paper-alt); }
.v-hero-chapter-num { font-family: var(--font-mono); font-size: 10px; letter-spacing: 2.5px; text-transform: uppercase; margin-bottom: 10px; display: inline-flex; align-items: center; gap: 10px; color: var(--v-bordeaux); }
.v-hero-chapter-num::before { content: ''; width: 18px; height: 1px; background: currentColor; display: inline-block; }
.v-hero-chapter-head { font-family: var(--font-serif); font-weight: 300; font-style: italic; font-size: 26px; line-height: 1.08; letter-spacing: -0.015em; margin: 0 0 8px; color: var(--v-ink-soft); }
.v-hero-chapter-head em { font-style: normal; color: var(--v-bordeaux); }

/* HERO VERSUS — DE vs USA side-by-side with 5-row compare */
.v-hero-versus { border-bottom: 1px solid var(--v-border); position: relative; background: var(--v-paper); }
.v-hero-versus::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: var(--v-bordeaux); z-index: 2; }
.v-hero-versus-head { padding: 18px 32px 16px; display: flex; align-items: center; border-bottom: 1px solid var(--v-border); }
.v-hero-versus-num { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--v-bordeaux); display: inline-flex; align-items: center; gap: 10px; }
.v-hero-versus-num::before { content: ''; width: 20px; height: 1px; background: currentColor; display: inline-block; }
.v-hero-versus-sub { font-family: var(--font-serif); font-style: italic; font-weight: 400; font-size: 19px; color: var(--v-ink-soft); letter-spacing: -0.01em; }
.v-hero-versus-sub em { font-style: normal; }
.v-hero-versus-sub em:first-of-type { color: var(--v-ink-muted); }
.v-hero-versus-sub em:last-of-type { color: var(--v-bordeaux); }
.v-hero-versus-grid { display: grid; grid-template-columns: 1fr 1fr; }
.v-hero-versus-col { display: flex; flex-direction: column; min-width: 0; }
.v-hero-versus-col.de { background: var(--v-paper); border-right: 1px solid var(--v-border); }
.v-hero-versus-col.us { background: var(--v-ink); color: var(--v-paper); }
.v-hero-versus-img { aspect-ratio: 4 / 3; overflow: hidden; background: var(--v-paper-alt); position: relative; border-bottom: 1px solid var(--v-border); }
.v-hero-versus-col.us .v-hero-versus-img { border-bottom: 1px solid #2A2420; }
.v-hero-versus-img img { width: 100%; height: 100%; object-fit: cover; object-position: center center; display: block; filter: saturate(0.9) contrast(1.02); }
.v-hero-versus-img-tag { position: absolute; bottom: 8px; left: 10px; font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 1.2px; text-transform: uppercase; color: var(--v-paper); background: rgba(26, 21, 17, 0.78); padding: 4px 8px; border-radius: 1px; z-index: 2; }

/* DE real image — Gründerzeit facade, cropped + slight editorial tilt, entsättigt & trist */
.v-hero-versus-img.de-real { background: #DCD6CA; }
.v-hero-versus-img.de-real img { width: 112%; height: 112%; position: absolute; left: -6%; top: -6%; object-fit: cover; object-position: center center; transform: rotate(-1.4deg); transform-origin: center center; filter: grayscale(0.15) saturate(0.78) contrast(0.98) brightness(0.96); }
.v-hero-versus-img.de-real::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(70, 75, 85, 0.06) 0%, rgba(50, 55, 65, 0.10) 100%); mix-blend-mode: multiply; pointer-events: none; z-index: 1; }
.v-hero-versus-img-tag.de { background: rgba(26, 21, 17, 0.72); }

/* US image — Cleveland, wärmlicher Ton mit subtiler Brass-Wäsche */
.v-hero-versus-col.us .v-hero-versus-img img { filter: saturate(1.04) contrast(1.02) brightness(1.01) sepia(0.07) hue-rotate(-2deg); }
.v-hero-versus-col.us .v-hero-versus-img::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(201, 166, 107, 0.07) 0%, rgba(154, 108, 56, 0.03) 100%); mix-blend-mode: soft-light; pointer-events: none; z-index: 1; }

.v-hero-versus-col-title { padding: 16px 20px 14px; font-family: var(--font-serif); font-style: italic; font-weight: 400; font-size: 26px; line-height: 1.1; letter-spacing: -0.015em; border-bottom: 1px solid var(--v-border); }
.v-hero-versus-col-title.de { color: var(--v-bordeaux); }
.v-hero-versus-col-title.us { color: var(--v-brass); border-bottom: 1px solid #2A2420; background: rgba(201, 166, 107, 0.04); }

.v-hero-versus-row { padding: 12px 20px 13px; border-bottom: 1px solid var(--v-border); display: flex; flex-direction: column; gap: 5px; min-width: 0; }
.v-hero-versus-row:last-child { border-bottom: none; }
.v-hero-versus-col.us .v-hero-versus-row { border-bottom: 1px solid #2A2420; }
.v-hero-versus-col.us .v-hero-versus-row:last-child { border-bottom: none; }
.v-hero-versus-k { font-family: var(--font-mono); font-size: 11px; letter-spacing: 1.8px; text-transform: uppercase; line-height: 1.3; }
.v-hero-versus-col.de .v-hero-versus-k { color: var(--v-ink-muted); }
.v-hero-versus-col.us .v-hero-versus-k { color: #6A6259; }
.v-hero-versus-v { font-family: var(--font-serif); font-style: italic; font-weight: 400; font-size: 19px; line-height: 1.25; letter-spacing: -0.005em; }
.v-hero-versus-col.de .v-hero-versus-v { color: var(--v-bordeaux); }
.v-hero-versus-col.us .v-hero-versus-v { color: var(--v-brass); }
.v-hero-versus-v em { font-style: normal; font-family: var(--font-mono); font-size: 10px; letter-spacing: 1.2px; text-transform: uppercase; opacity: 0.6; margin-left: 6px; font-weight: 400; }

/* Big rows — Cashflow hero value */
.v-hero-versus-row.big { padding: 14px 20px 16px; gap: 6px; }
.v-hero-versus-row.big .v-hero-versus-v { font-size: 42px; line-height: 1; letter-spacing: -0.025em; display: inline-flex; align-items: baseline; gap: 4px; }
.v-hero-versus-row.big .v-hero-versus-v em { font-size: 11px; margin-left: 4px; opacity: 0.6; letter-spacing: 1.2px; }

/* Close-Strip — ruhiger Abschluss nach Versus-Grid (statt Fazit) */
.v-hero-versus-close { height: 28px; background: var(--v-paper); border-top: 1px solid var(--v-border); }

.v-hero-versus-foot { padding: 10px 28px 12px; font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.5px; color: var(--v-ink-muted); border-top: 1px solid var(--v-border); text-align: right; font-style: italic; background: var(--v-paper-alt); }

/* HERO PROOF — trust block under versus: stats + featured case + CTA */
.v-hero-proof { padding: 22px 28px 22px; background: var(--v-ink); color: var(--v-paper); position: relative; }
.v-hero-proof::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent 0%, var(--v-brass) 50%, transparent 100%); opacity: 0.35; }
.v-hero-proof-head { margin-bottom: 14px; }
.v-hero-proof-eyebrow { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--v-brass); display: inline-flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.v-hero-proof-eyebrow::before { content: ''; width: 20px; height: 1px; background: currentColor; display: inline-block; }
.v-hero-proof-title { font-family: var(--font-serif); font-style: italic; font-weight: 400; font-size: 18px; line-height: 1.3; letter-spacing: -0.01em; color: var(--v-paper); }
.v-hero-proof-title em { font-style: normal; color: var(--v-brass); }

.v-hero-proof-case { display: grid; grid-template-columns: 80px 1fr auto; gap: 14px; align-items: center; padding: 12px 14px; background: #1F1915; border: 1px solid #2A2420; text-decoration: none; color: inherit; transition: border-color .15s, background .15s; margin-bottom: 12px; }
.v-hero-proof-case:hover { border-color: var(--v-brass); background: #22191F; }
.v-hero-proof-case-img { width: 80px; aspect-ratio: 1 / 1; overflow: hidden; background: var(--v-paper-alt); }
.v-hero-proof-case-img img { width: 100%; height: 100%; object-fit: cover; object-position: center center; display: block; filter: saturate(0.9) contrast(1.02); }
.v-hero-proof-case-body { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.v-hero-proof-case-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 1.8px; text-transform: uppercase; color: #8A7D66; }
.v-hero-proof-case-metrics { display: flex; flex-wrap: wrap; align-items: baseline; gap: 10px; }
.v-hero-proof-m { display: inline-flex; align-items: baseline; gap: 4px; }
.v-hero-proof-m strong { font-family: var(--font-serif); font-style: italic; font-weight: 400; font-size: 17px; color: var(--v-brass); letter-spacing: -0.01em; }
.v-hero-proof-m em { font-style: normal; font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 1.2px; text-transform: uppercase; color: #8A7D66; }
.v-hero-proof-arrow { font-family: var(--font-mono); color: #6A6259; font-size: 13px; }
.v-hero-proof-case-arrow { font-family: var(--font-mono); font-size: 18px; color: var(--v-brass); margin-right: 6px; opacity: 0.7; transition: opacity .15s, transform .15s; }
.v-hero-proof-case:hover .v-hero-proof-case-arrow { opacity: 1; transform: translate(2px, -2px); }

.v-hero-proof-cta { display: flex; align-items: center; justify-content: center; padding: 13px 16px; font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 2px; text-transform: uppercase; color: var(--v-brass); text-decoration: none; border: 1px solid rgba(201, 166, 107, 0.4); transition: background .15s, border-color .15s; text-align: center; }
.v-hero-proof-cta:hover { background: rgba(201, 166, 107, 0.08); border-color: var(--v-brass); }

/* FALLSTUDIEN-BAR — full-width dark CTA banner between Hero and ProblemUSACompare */
.v-fsbar { padding: 40px 64px 36px; background: var(--v-ink); color: var(--v-paper); border-bottom: 1px solid #2A2420; position: relative; cursor: pointer; transition: background .2s; }
.v-fsbar:hover { background: #1A1513; }
.v-fsbar:focus-visible { outline: 2px solid var(--v-brass); outline-offset: -4px; }
.v-fsbar::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, transparent 0%, var(--v-brass) 50%, transparent 100%); opacity: 0.5; }
.v-fsbar-inner { max-width: 1400px; margin: 0 auto; display: flex; flex-direction: column; gap: 28px; }
.v-fsbar-top { display: grid; grid-template-columns: 1fr auto; gap: 56px; align-items: center; }
.v-fsbar-head { display: flex; flex-direction: column; gap: 10px; min-width: 0; }
.v-fsbar-eyebrow { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--v-brass); display: inline-flex; align-items: center; gap: 12px; }
.v-fsbar-eyebrow::before { content: ''; width: 22px; height: 1px; background: currentColor; display: inline-block; }
.v-fsbar-title { font-family: var(--font-serif); font-style: italic; font-weight: 300; font-size: clamp(22px, 2.2vw, 30px); line-height: 1.2; letter-spacing: -0.015em; color: var(--v-paper); max-width: 780px; }
.v-fsbar-title em { font-style: normal; color: var(--v-brass); }
.v-fsbar-sub { font-family: var(--font-mono); font-size: 11.5px; line-height: 1.6; color: #8A8078; font-weight: 300; letter-spacing: 0.3px; }
.v-fsbar-cta { display: inline-flex; align-items: center; gap: 14px; padding: 18px 28px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--v-brass); text-decoration: none; border: 1px solid rgba(201, 166, 107, 0.4); background: transparent; transition: background .15s, border-color .15s, transform .15s; white-space: nowrap; flex-shrink: 0; }
.v-fsbar-cta:hover { background: rgba(201, 166, 107, 0.08); border-color: var(--v-brass); }
.v-fsbar-cta-arrow { font-size: 15px; transition: transform .15s; }
.v-fsbar:hover .v-fsbar-cta-arrow { transform: translateX(3px); }

/* KPI-Strip — 3 reduzierte Case-Stats unter dem Head/CTA row */
.v-fsbar-kpis { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid #2A2420; padding-top: 22px; }
.v-fsbar-kpi { padding: 0 28px; border-right: 1px solid #2A2420; display: flex; flex-direction: column; gap: 8px; position: relative; min-width: 0; }
.v-fsbar-kpi:first-child { padding-left: 0; }
.v-fsbar-kpi:last-child { border-right: none; padding-right: 0; }
.v-fsbar-kpi::before { content: ''; position: absolute; top: -1px; left: 0; width: 32px; height: 2px; background: var(--v-brass); opacity: 0.4; }
.v-fsbar-kpi:first-child::before { left: 0; }
.v-fsbar-kpi:not(:first-child)::before { left: 28px; }
.v-fsbar-kpi.featured::before { opacity: 1; width: 44px; background: var(--v-bordeaux); }
.v-fsbar-kpi-head { display: flex; align-items: center; gap: 14px; }
.v-fsbar-kpi-head-txt { display: flex; align-items: center; gap: 10px; min-width: 0; }
.v-fsbar-kpi-thumb { width: 56px; height: 56px; overflow: hidden; background: var(--v-paper-alt); border: 1px solid #2A2420; flex-shrink: 0; }
.v-fsbar-kpi-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; filter: saturate(0.9) contrast(1.02); }
.v-fsbar-kpi-num { font-family: var(--font-mono); font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: #8A7D66; }
.v-fsbar-kpi-tag { font-family: var(--font-mono); font-size: 9px; letter-spacing: 1.4px; text-transform: uppercase; color: var(--v-bordeaux); border: 1px solid var(--v-bordeaux); padding: 2px 6px; background: rgba(122, 31, 40, 0.1); }
.v-fsbar-kpi-city { font-family: var(--font-serif); font-style: italic; font-weight: 400; font-size: 17px; line-height: 1.2; color: var(--v-paper); letter-spacing: -0.01em; }
.v-fsbar-kpi-city em { font-style: normal; color: #8A8078; font-family: var(--font-mono); font-size: 11px; letter-spacing: 1px; text-transform: uppercase; margin-left: 4px; }
.v-fsbar-kpi-vals { display: flex; flex-direction: row; align-items: baseline; gap: 18px; margin-top: 2px; flex-wrap: wrap; }
.v-fsbar-kpi-val { font-family: var(--font-serif); font-style: italic; font-weight: 300; font-size: clamp(28px, 2.6vw, 34px); line-height: 1; letter-spacing: -0.025em; color: var(--v-brass); display: inline-flex; align-items: baseline; gap: 10px; }
.v-fsbar-kpi.featured .v-fsbar-kpi-val { color: var(--v-bordeaux); }
.v-fsbar-kpi-val-sec { font-size: clamp(22px, 2vw, 28px); color: var(--v-paper); opacity: 0.88; font-style: normal; font-weight: 400; padding-left: 18px; border-left: 1px solid #2A2420; }
.v-fsbar-kpi.featured .v-fsbar-kpi-val-sec { color: var(--v-paper); opacity: 0.95; }
.v-fsbar-kpi-lbl { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 1.6px; text-transform: uppercase; color: #6B6259; font-style: normal; font-weight: 400; }

/* HERO IMAGE FRAME — crops MLS watermark via object-position:top */
.v-hero-img-frame { width: 100%; aspect-ratio: 3 / 2; overflow: hidden; background: var(--v-paper-alt); position: relative; }
.v-hero-img-frame.small { aspect-ratio: 4 / 3; }
.v-hero-img-frame img { width: 100%; height: 115%; object-fit: cover; object-position: top center; display: block; filter: saturate(0.92) contrast(1.02); }

/* HERO HERO IMAGE — the big one under thesis */
.v-hero-hero-img { margin: 0; padding: 0; border-bottom: 1px solid var(--v-border); position: relative; }
.v-hero-hero-img .v-hero-img-frame { aspect-ratio: 16 / 9; }
.v-hero-img-cap { padding: 14px 24px; display: flex; justify-content: space-between; align-items: baseline; gap: 16px; background: var(--v-paper); border-top: 1px solid var(--v-border); }
.v-hero-img-cap-l { font-family: var(--font-serif); font-style: italic; font-weight: 400; font-size: 15px; color: var(--v-ink-soft); }
.v-hero-img-cap-r { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 1.2px; text-transform: uppercase; color: var(--v-ink-muted); }

/* HERO COLLAGE — 2 small tiles side by side */
.v-hero-collage { display: grid; grid-template-columns: 1fr 1fr; gap: 0; border-top: 0; }
.v-hero-collage-item { margin: 0; padding: 0; border-right: 1px solid var(--v-border); display: flex; flex-direction: column; background: var(--v-paper); }
.v-hero-collage-item:last-child { border-right: none; }
.v-hero-collage-cap { padding: 12px 18px; display: flex; flex-direction: column; gap: 4px; border-top: 1px solid var(--v-border); }
.v-hero-collage-city { font-family: var(--font-serif); font-style: italic; font-weight: 400; font-size: 13px; color: var(--v-ink-soft); }
.v-hero-collage-stat { font-family: var(--font-mono); font-size: 10px; letter-spacing: 1.2px; text-transform: uppercase; color: var(--v-bordeaux); }

.v-chart-section { padding: 28px 36px 24px; border-bottom: 1px solid var(--v-border); }
.v-chart-section:last-of-type { border-bottom: none; }
.v-chart-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 4px; }
.v-chart-title { font-family: var(--font-serif); font-size: 19px; font-style: italic; font-weight: 400; color: var(--v-ink-soft); }
.v-chart-ticker { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--v-bordeaux); }
.v-chart-label { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 2px; text-transform: uppercase; color: var(--v-ink-muted); margin-bottom: 14px; }
.v-chart-note { font-family: var(--font-mono); font-size: 11px; color: var(--v-ink-muted); margin-top: 10px; letter-spacing: 0.3px; }
.v-chart-note a { color: var(--v-ink-sub); text-decoration: underline; text-decoration-thickness: 0.5px; text-underline-offset: 2px; }
.v-chart-note a:hover { color: var(--v-bordeaux); }
.v-legend { display: flex; gap: 20px; margin-top: 12px; align-items: center; }
.v-legend-item { display: flex; align-items: center; gap: 6px; font-family: var(--font-mono); font-size: 10px; color: var(--v-ink-sub); }
.v-dot { width: 8px; height: 8px; border-radius: 50%; }
.v-legend-note { font-family: var(--font-mono); font-size: 10.5px; color: var(--v-ink-muted); font-style: italic; }

.v-risk-list { display: flex; flex-direction: column; }
.v-risk-item { padding: 14px 0; border-top: 1px solid var(--v-border); display: grid; grid-template-columns: 140px 1fr; gap: 16px; align-items: baseline; }
.v-risk-item:first-child { border: none; padding-top: 4px; }
.v-risk-label { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 2px; text-transform: uppercase; color: var(--v-bordeaux); }
.v-risk-body { font-family: var(--font-mono); font-size: 11.5px; color: var(--v-ink-soft); line-height: 1.55; font-weight: 300; }

.v-hero-panel { padding: 28px 36px 32px; background: var(--v-ink); color: var(--v-paper); }
.v-hero-panel-eyebrow { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--v-brass); margin-bottom: 10px; display: flex; align-items: center; gap: 10px; }
.v-hero-panel-eyebrow::before { content: ''; width: 20px; height: 1px; background: var(--v-brass); }
.v-hero-panel-title { font-family: var(--font-serif); font-size: 20px; font-style: italic; font-weight: 400; color: var(--v-paper); margin-bottom: 20px; line-height: 1.2; }
.v-checklist { display: flex; flex-direction: column; gap: 0; }
.v-check-item { display: flex; align-items: flex-start; gap: 14px; font-family: var(--font-mono); font-size: 12px; color: #C8BFB2; line-height: 1.5; padding: 10px 0; border-top: 1px solid #2A2420; }
.v-check-item:first-child { border-top: none; padding-top: 4px; }
.v-check { width: 14px; height: 14px; border: 1px solid var(--v-brass); display: flex; align-items: center; justify-content: center; font-size: 9.5px; color: var(--v-brass); flex-shrink: 0; margin-top: 1px; }

/* STATS BAR */
.v-stats-bar { display: grid; grid-template-columns: repeat(4,1fr); border-bottom: 1px solid var(--v-border); background: var(--v-paper); position: relative; }
.v-stats-bar::before { content: 'Kennzahlen · Stand 2026'; position: absolute; top: -9px; left: 64px; background: var(--v-paper); padding: 0 12px; font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--v-ink-muted); }
.v-stat { padding: 40px 48px 36px; border-right: 1px solid var(--v-border); position: relative; }
.v-stat:last-child { border: none; }
.v-stat-eyebrow { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--v-bordeaux); margin-bottom: 16px; }
.v-stat-val { font-family: var(--font-serif); font-size: 54px; font-weight: 300; font-style: italic; line-height: 1; margin-bottom: 12px; color: var(--v-ink-soft); letter-spacing: -0.01em; }
.v-stat-val sup { font-size: 0.5em; vertical-align: top; margin-left: 2px; color: var(--v-ink-muted); font-style: normal; }
.v-stat-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--v-ink-soft); margin-bottom: 6px; font-weight: 500; }
.v-stat-note { font-family: var(--font-mono); font-size: 11px; color: var(--v-ink-sub); line-height: 1.5; }

/* HEADLINES (used in JSX) */
.v-h1 { font-family: var(--font-serif); font-weight: 300; font-style: italic; font-size: 54px; line-height: 1.05; color: var(--v-ink-soft); text-wrap: pretty; letter-spacing: -0.012em; }
.v-h1 em { font-style: normal; color: var(--v-bordeaux); }
.v-h2 { font-family: var(--font-serif); font-weight: 300; font-style: italic; font-size: 40px; line-height: 1.1; letter-spacing: -0.01em; }
.v-h2 em { font-style: normal; color: var(--v-bordeaux); }
.v-h3 { font-family: var(--font-serif); font-weight: 400; font-style: italic; font-size: 28px; line-height: 1.2; }
.v-h4 { font-family: var(--font-serif); font-weight: 400; font-style: italic; font-size: 22px; line-height: 1.25; color: var(--v-ink-soft); }
.v-h5 { font-family: var(--font-serif); font-weight: 400; font-style: italic; font-size: 18px; line-height: 1.3; color: var(--v-ink-soft); }
.v-body { font-family: var(--font-mono); font-size: 14.5px; line-height: 1.8; color: var(--v-ink-sub); }
.v-body-sm { font-family: var(--font-mono); font-size: 13.5px; line-height: 1.75; color: var(--v-ink-sub); }
.v-label { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--v-ink-muted); display: inline-block; }

/* PROBLEM GRID */
.v-problem-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: var(--v-border); margin-top: 40px; }
.on-dark .v-problem-grid { background: #2A2420; }
.v-problem-card { background: var(--v-paper); padding: 44px 36px 48px; position: relative; }
.on-dark .v-problem-card { background: var(--v-ink); }
.v-problem-num { font-family: var(--font-mono); font-size: 10px; font-weight: 400; letter-spacing: 2px; color: var(--v-bordeaux); margin-bottom: 24px; display: flex; align-items: center; gap: 10px; }
.v-problem-num::after { content: ''; flex: 1; height: 1px; background: var(--v-border); }
.on-dark .v-problem-num { color: var(--v-brass); }
.on-dark .v-problem-num::after { background: #3A322C; }
.v-problem-title { font-family: var(--font-serif); font-size: 24px; font-style: italic; font-weight: 400; color: var(--v-ink-soft); margin-bottom: 18px; line-height: 1.2; letter-spacing: -0.005em; }
.on-dark .v-problem-title { color: var(--v-paper); }
.on-dark .v-problem-card .v-body-sm { color: #A59B8F; }

/* Pullquote — editorial gravitas callout */
.v-pullquote { margin: 40px 0 0; padding: 36px 64px; border-top: 1px solid var(--v-border); border-bottom: 1px solid var(--v-border); display: grid; grid-template-columns: 180px 1fr; gap: 40px; align-items: baseline; background: var(--v-paper); }
.on-dark .v-pullquote { background: var(--v-ink); border-color: #2A2420; }
.v-pullquote-label { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--v-bordeaux); display: flex; align-items: center; gap: 10px; }
.v-pullquote-label::before { content: ''; width: 28px; height: 1px; background: var(--v-bordeaux); }
.on-dark .v-pullquote-label { color: var(--v-brass); }
.on-dark .v-pullquote-label::before { background: var(--v-brass); }
.v-pullquote-text { font-family: var(--font-serif); font-style: italic; font-weight: 300; font-size: 30px; line-height: 1.25; color: var(--v-ink-soft); letter-spacing: -0.01em; text-wrap: pretty; }
.on-dark .v-pullquote-text { color: var(--v-paper); }
.v-pullquote-text em { font-style: normal; color: var(--v-bordeaux); }
.on-dark .v-pullquote-text em { color: var(--v-brass); }

/* ARG STACK — used inside the DE / USA macro columns */
.v-arg-stack { display: flex; flex-direction: column; gap: 22px; }
.v-arg-stack .v-compare-charts { margin: 2px 0 8px; }
.v-arg-item { display: flex; flex-direction: column; gap: 8px; }
.v-arg-item-label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 2.2px; text-transform: uppercase; color: var(--v-bordeaux); display: flex; align-items: center; gap: 10px; }
.v-arg-item-label::before { content: ''; width: 22px; height: 1px; background: var(--v-bordeaux); }
.v-arg-stack.dark .v-arg-item-label { color: var(--v-brass); }
.v-arg-stack.dark .v-arg-item-label::before { background: var(--v-brass); }
.v-arg-item-body { font-family: var(--font-mono); font-size: 12.5px; line-height: 1.75; color: var(--v-ink-sub); font-weight: 300; margin: 0; }
.v-arg-item-body strong { font-family: var(--font-serif); font-style: italic; font-weight: 400; font-size: 15px; color: var(--v-ink-soft); letter-spacing: -0.005em; }
.v-arg-stack.dark .v-arg-item-body { color: #A59B8F; }
.v-arg-stack.dark .v-arg-item-body strong { color: var(--v-paper); }

/* ARG KPI WIDGET — used below argument text to emphasise a single metric */
.v-arg-kpi { background: var(--v-paper-alt); border-left: 2px solid var(--v-bordeaux); padding: 20px 24px; margin: 2px 0 4px; }
.v-arg-kpi-label { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 2px; text-transform: uppercase; color: var(--v-ink-muted); margin-bottom: 10px; }
.v-arg-kpi-val { font-family: var(--font-serif); font-style: italic; font-weight: 300; font-size: 42px; line-height: 1; color: var(--v-bordeaux); letter-spacing: -0.02em; }
.v-arg-kpi-val span { font-size: 18px; color: var(--v-ink-muted); font-style: italic; margin-left: 4px; }
.v-arg-kpi-note { font-family: var(--font-mono); font-size: 10.5px; line-height: 1.6; color: var(--v-ink-sub); margin-top: 12px; }
.v-arg-kpi.dark { background: #0A0908; border-left-color: var(--v-brass); }
.v-arg-kpi.dark .v-arg-kpi-label { color: var(--v-brass); }
.v-arg-kpi.dark .v-arg-kpi-val { color: var(--v-paper); }
.v-arg-kpi.dark .v-arg-kpi-val span { color: #8A8078; }
.v-arg-kpi.dark .v-arg-kpi-note { color: #8A8078; }

/* MACRO (legacy — still used in case-compare etc.) */
.v-macro-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--v-border); margin-top: 40px; }
.v-macro-col { background: var(--v-paper); padding: 48px 44px; position: relative; }
.v-macro-col-dark { background: var(--v-ink); color: var(--v-paper); padding: 48px 44px; position: relative; }
.v-macro-col-dark::before { content: ''; position: absolute; top: 0; left: 0; width: 3px; height: 64px; background: var(--v-brass); }
.v-macro-col::before { content: ''; position: absolute; top: 0; left: 0; width: 3px; height: 64px; background: var(--v-ink-muted); }
.v-macro-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--v-border); margin-top: 40px; }
.v-macro-stat { background: var(--v-paper-alt); padding: 24px 28px; }
.v-macro-stat-dark { background: #0A0908; padding: 24px 28px; }
.v-macro-stat-val { font-family: var(--font-serif); font-size: 44px; font-style: italic; font-weight: 300; line-height: 1; margin-bottom: 8px; color: var(--v-ink-soft); letter-spacing: -0.01em; }

/* COMPARE BULLETS — used in ProblemUSACompare (light + dark) */
.v-compare-bullets { list-style: none; padding: 0; margin: 0 0 32px 0; display: flex; flex-direction: column; }
.v-compare-bullets li { font-family: var(--font-mono); font-size: 12.5px; line-height: 1.75; color: var(--v-ink-sub); padding: 14px 0 14px 22px; border-top: 1px solid var(--v-border); position: relative; }
.v-compare-bullets li:first-child { border-top: none; padding-top: 4px; }
.v-compare-bullets li::before { content: ''; position: absolute; left: 0; top: 22px; width: 10px; height: 1px; background: var(--v-bordeaux); }
.v-compare-bullets li:first-child::before { top: 12px; }
.v-compare-bullets li strong { font-family: var(--font-serif); font-style: italic; font-weight: 400; color: var(--v-ink-soft); font-size: 14px; display: block; margin-bottom: 4px; }
.v-compare-bullets.dark li { color: #A59B8F; border-top-color: #2A2420; }
.v-compare-bullets.dark li::before { background: var(--v-brass); }
.v-compare-bullets.dark li strong { color: var(--v-paper); }

/* Compare charts — light card background */
.v-compare-charts { background: var(--v-paper); border: 1px solid var(--v-border); display: flex; flex-direction: column; }
.v-compare-charts .v-chart-section { padding: 20px 24px 16px; }
.v-compare-charts .v-chart-section:last-child { border-bottom: none; }

/* Compare charts — dark variant (US side) */
.v-compare-charts-dark { background: #0A0908; border: 1px solid #2A2420; }
.v-compare-charts-dark .v-chart-section { border-bottom-color: #2A2420; }
.v-chart-dark .v-chart-title { color: var(--v-paper); }
.v-chart-dark .v-chart-ticker { color: var(--v-brass); }
.v-chart-dark .v-chart-label { color: #6B6259; }
.v-chart-dark .v-chart-note { color: #6B6259; }
.v-chart-dark .v-chart-note a { color: #A59B8F; }
.v-chart-dark .v-chart-note a:hover { color: var(--v-brass); }
.v-chart-dark .v-legend-item { color: #A59B8F; }

/* MARKETS STRIP \u2014 editorial "markets at a glance" between USA + Cleveland */
.v-markets-strip { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--v-border); margin-top: 40px; border-top: 1px solid var(--v-border); border-bottom: 1px solid var(--v-border); }
.v-market { background: var(--v-paper); padding: 32px 32px 28px; position: relative; display: flex; flex-direction: column; }
.v-market.featured { background: var(--v-paper-alt); }
.v-market-tag { position: absolute; top: 0; right: 20px; background: var(--v-bordeaux); color: var(--v-paper); padding: 4px 10px; font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 2px; text-transform: uppercase; z-index: 2; }

/* Market card hero image — full-bleed top of card */
.v-market-img { margin: -32px -32px 24px; aspect-ratio: 16 / 10; overflow: hidden; background: var(--v-paper-alt); position: relative; }
.v-market-img img { width: 100%; height: 100%; object-fit: cover; object-position: center center; display: block; filter: saturate(0.9) contrast(1.02); transition: transform .4s ease; }
.v-market:hover .v-market-img img { transform: scale(1.02); }
.v-market-img::after { content: ''; position: absolute; inset: auto 0 0 0; height: 60%; background: linear-gradient(180deg, transparent 0%, rgba(26,21,17,0.55) 100%); pointer-events: none; }
.v-market-img-num { position: absolute; bottom: 10px; left: 14px; z-index: 2; font-family: var(--font-mono); font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--v-paper); background: rgba(26,21,17,0.72); padding: 4px 8px; border-radius: 1px; }
.v-market-name { font-family: var(--font-serif); font-size: 24px; font-style: italic; font-weight: 400; color: var(--v-ink-soft); margin-bottom: 2px; letter-spacing: -0.005em; }
.v-market-state { font-family: var(--font-mono); font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--v-ink-muted); margin-bottom: 22px; }
.v-market-row { display: flex; justify-content: space-between; align-items: baseline; padding: 10px 0; border-top: 1px dashed var(--v-border); font-family: var(--font-mono); font-size: 11px; }
.v-market-row:first-of-type { border-top: 1px solid var(--v-border); }
.v-market-k { color: var(--v-ink-sub); }
.v-market-v { color: var(--v-ink-soft); font-family: var(--font-serif); font-style: italic; font-size: 15px; font-weight: 400; white-space: nowrap; }

/* Cash-on-Cash emphasised row (legacy, single value) */
.v-market-coc { border-top: 1px solid var(--v-bordeaux) !important; padding-top: 12px !important; margin-top: 4px; }
.v-market-coc .v-market-k { color: var(--v-bordeaux); font-weight: 500; }
.v-market-coc .v-market-v { color: var(--v-bordeaux); font-size: 20px; }

/* Twin emphasised row — CoC + Cashflow side by side */
.v-market-headline { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; border-top: 1px solid var(--v-bordeaux); padding-top: 14px; margin-top: 6px; }
.on-dark .v-market-headline { border-top-color: var(--v-brass); }
.v-market-headline-item { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.v-market-headline-k { font-family: var(--font-mono); font-size: 10px; letter-spacing: 1.8px; text-transform: uppercase; color: var(--v-bordeaux); font-weight: 500; }
.on-dark .v-market-headline-k { color: var(--v-brass); }
.v-market-headline-v { font-family: var(--font-serif); font-style: italic; font-weight: 400; font-size: 22px; letter-spacing: -0.01em; line-height: 1; color: var(--v-bordeaux); white-space: nowrap; }
.on-dark .v-market-headline-v { color: var(--v-brass); }

/* Markets strip — dark variant (used in CaseStudies) */
.on-dark .v-markets-strip { background: #2A2420; border-top-color: #2A2420; border-bottom-color: #2A2420; }
.on-dark .v-market { background: var(--v-ink); }
.on-dark .v-market.featured { background: #1A1513; }
.on-dark .v-market-tag { background: var(--v-brass); color: var(--v-ink); }
.on-dark .v-market-name { color: var(--v-paper); }
.on-dark .v-market-state { color: #8A8078; }
.on-dark .v-market-row { border-top-color: #2A2420; }
.on-dark .v-market-row:first-of-type { border-top-color: #2A2420; }
.on-dark .v-market-k { color: #8A8078; }
.on-dark .v-market-v { color: var(--v-paper); }
.on-dark .v-market-coc { border-top-color: var(--v-brass) !important; }
.on-dark .v-market-coc .v-market-k { color: var(--v-brass); }
.on-dark .v-market-coc .v-market-v { color: var(--v-brass); }

/* DISCLAIMER */
.v-disclaimer { margin-top: 24px; padding: 18px 24px; background: var(--v-paper-alt); border-left: 2px solid var(--v-border); font-family: var(--font-mono); font-size: 11px; color: var(--v-ink-muted); line-height: 1.7; }
.v-disclaimer strong { font-weight: 400; color: var(--v-ink-sub); }
.v-disclaimer.dark { background: #2A2420; border-left-color: var(--v-brass); color: #8A8078; }
.v-disclaimer.dark strong { color: var(--v-paper); }

/* USA */
.v-usa-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 1px; background: #2A2420; }
.v-usa-item { background: var(--v-ink); padding: 44px 40px; display: grid; grid-template-columns: 64px 1fr; gap: 24px; }
.v-usa-num { font-family: var(--font-serif); font-size: 52px; font-style: italic; font-weight: 300; color: var(--v-brass); opacity: .85; line-height: 1; }
.v-usa-title { font-family: var(--font-serif); font-size: 22px; font-style: italic; color: var(--v-paper); margin-bottom: 14px; line-height: 1.2; }
.v-usa-item .v-body-sm { color: #A59B8F; line-height: 1.75; }

/* CLEVELAND */
.v-cleveland-layout { display: grid; grid-template-columns: 1fr 420px; gap: 72px; align-items: start; }
.v-cleveland-drop { font-family: var(--font-serif); font-size: 60px; font-style: italic; font-weight: 300; color: var(--v-bordeaux); line-height: 0.9; float: left; padding: 6px 14px 0 0; letter-spacing: -0.01em; }
.v-cleveland-data { background: var(--v-card); border: 1px solid var(--v-border); align-self: start; position: relative; }
.v-cleveland-data::before { content: ''; position: absolute; top: -1px; left: -1px; right: -1px; height: 2px; background: var(--v-bordeaux); }
.v-cleveland-head { padding: 22px 28px 20px; border-bottom: 1px solid var(--v-border); display: flex; align-items: baseline; justify-content: space-between; }
.v-cleveland-head-left { display: flex; flex-direction: column; gap: 4px; }
.v-cleveland-metric { padding: 18px 28px; border-bottom: 1px solid var(--v-border); display: flex; justify-content: space-between; align-items: baseline; }
.v-cleveland-metric:last-child { border: none; }
.v-cleveland-metric-label { font-family: var(--font-mono); font-size: 11.5px; color: var(--v-ink-sub); letter-spacing: 0.2px; }
.v-cleveland-val { font-family: var(--font-serif); font-size: 24px; font-style: italic; font-weight: 300; color: var(--v-ink-soft); letter-spacing: -0.005em; white-space: nowrap; }
.v-cleveland-val sup { font-size: 0.55em; vertical-align: top; color: var(--v-ink-muted); font-style: normal; margin-left: 1px; }
.v-cleveland-source { padding: 14px 28px; background: var(--v-paper-alt); font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.3px; color: var(--v-ink-muted); line-height: 1.5; }

/* STEPS */
.v-steps { display: flex; flex-direction: column; gap: 1px; background: var(--v-border); margin-top: 40px; }
.v-step { background: var(--v-paper); display: grid; grid-template-columns: 120px 1fr 1fr; }
.v-step-num { padding: 40px 36px; border-right: 1px solid var(--v-border); display: flex; align-items: flex-start; flex-direction: column; gap: 8px; }
.v-step-num-i { font-family: var(--font-serif); font-size: 60px; font-style: italic; font-weight: 300; color: var(--v-bordeaux); line-height: 1; letter-spacing: -0.02em; }
.v-step-num-label { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 2px; text-transform: uppercase; color: var(--v-ink-muted); }
.v-step-content { padding: 40px 44px; border-right: 1px solid var(--v-border); }
.v-step-detail { padding: 40px 44px; display: flex; flex-direction: column; gap: 10px; background: var(--v-paper-alt); }
.v-step-detail-label { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 2px; text-transform: uppercase; color: var(--v-ink-muted); margin-bottom: 6px; }
.v-step-item { font-family: var(--font-mono); font-size: 13.5px; color: var(--v-ink-soft); display: flex; gap: 12px; line-height: 1.6; }
.v-step-item::before { content: '—'; color: var(--v-bordeaux); flex-shrink: 0; }

/* Mobile-only: expandable "Was dabei passiert" dropdown under each step */
.v-step-toggle { display: none; }
.v-step-mobile-detail { display: none; }

/* QUALIFY */
.v-qualify-grid { display: grid; grid-template-columns: 1fr 1px 1fr; margin-top: 30px; }
.v-qualify-div { background: var(--v-border); }
.v-qualify-col { padding: 0 48px; }
.v-qualify-col:first-child { padding-left: 0; }
.v-qualify-col:last-child { padding-right: 0; }
.v-qualify-head { padding: 10px 0 22px; border-bottom: 1px solid var(--v-border); margin-bottom: 22px; }
.v-qualify-head .v-h3 { color: var(--v-ink-soft); }
.v-q-item { padding: 14px 0; border-bottom: 1px solid var(--v-border); font-family: var(--font-mono); font-size: 14.5px; color: var(--v-ink-sub); line-height: 1.8; display: flex; gap: 12px; align-items: flex-start; }
.v-q-item::before { content: ''; width: 5px; height: 5px; border-radius: 50%; flex-shrink: 0; margin-top: 7px; }
.v-q-yes::before { background: var(--v-bordeaux); }
.v-q-no::before { background: var(--v-ink-muted); }

/* === NEW QUALIFY CARDS — comparison/who-we-serve === */
.v-qualify-section { padding-top: 112px; padding-bottom: 112px; }
.v-qualify-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; margin-top: 30px; }
.v-qualify-card { display: flex; flex-direction: column; padding: 40px 36px 32px; position: relative; overflow: hidden; transition: transform .22s ease; }
/* "Geeignet" — sanftes Brass/Gold-Akzent auf Ink-Hintergrund (zurückhaltend). */
.v-qualify-card-yes { background: #1A1513; border: 1px solid rgba(201, 166, 107, 0.22); }
/* "Nicht geeignet" — gedämpftes Bordeaux/Rot-Akzent. */
.v-qualify-card-no  { background: #1A1410; border: 1px solid rgba(122, 31, 40, 0.30); }
.v-qualify-card-yes::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: var(--v-brass); opacity: 0.7; }
.v-qualify-card-no::before  { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: var(--v-bordeaux); opacity: 0.7; }

.v-qualify-card-head { padding-bottom: 24px; border-bottom: 1px solid rgba(247,243,236,0.08); margin-bottom: 24px; }
.v-qualify-card-yes .v-qualify-card-head { border-bottom-color: rgba(201, 166, 107, 0.18); }
.v-qualify-card-no .v-qualify-card-head  { border-bottom-color: rgba(122, 31, 40, 0.22); }

.v-qualify-card-tag { display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 2.5px; text-transform: uppercase; margin-bottom: 18px; }
.v-qualify-card-yes .v-qualify-card-tag { color: var(--v-brass-300); }
.v-qualify-card-no .v-qualify-card-tag  { color: #B47A82; }
.v-qualify-card-mark { width: 24px; height: 24px; border: 1px solid currentColor; display: inline-flex; align-items: center; justify-content: center; font-size: 13px; font-family: var(--font-mono); }
.v-qualify-card-yes .v-qualify-card-mark { background: rgba(201, 166, 107, 0.12); border-color: rgba(201, 166, 107, 0.45); color: var(--v-brass); }
.v-qualify-card-no  .v-qualify-card-mark { background: rgba(122, 31, 40, 0.18); border-color: rgba(122, 31, 40, 0.45); color: #B47A82; }

.v-qualify-card-title { font-family: var(--font-serif); font-size: 28px; font-weight: 300; font-style: italic; line-height: 1.22; letter-spacing: -0.01em; color: var(--v-paper); margin: 0; }

.v-qualify-card-list { display: flex; flex-direction: column; gap: 0; }
.v-qualify-item { padding: 14px 0; display: grid; grid-template-columns: 28px 1fr; gap: 16px; align-items: flex-start; font-family: var(--font-mono); font-size: 14px; line-height: 1.65; border-top: 1px solid rgba(247,243,236,0.05); }
.v-qualify-item:first-child { border-top: none; padding-top: 0; }
.v-qualify-item-icon { width: 24px; height: 24px; display: inline-flex; align-items: center; justify-content: center; font-size: 13px; font-family: var(--font-mono); flex-shrink: 0; line-height: 1; }
.v-qualify-item-yes .v-qualify-item-icon { background: transparent; color: var(--v-brass-300); border: 1px solid rgba(201, 166, 107, 0.35); }
.v-qualify-item-no .v-qualify-item-icon  { background: transparent; color: #B47A82; border: 1px solid rgba(122, 31, 40, 0.40); }
.v-qualify-item-yes .v-qualify-item-text { color: #C8BFB2; }
.v-qualify-item-no .v-qualify-item-text  { color: #A89691; }

@media (max-width: 1100px) {
  .v-qualify-cards { grid-template-columns: 1fr; gap: 20px; }
  .v-qualify-card { padding: 32px 28px 28px; }
  .v-qualify-card-title { font-size: 24px; }
}
@media (max-width: 640px) {
  .v-qualify-card { padding: 26px 22px 22px; }
  .v-qualify-card-title { font-size: 21px; }
  .v-qualify-item { font-size: 13.5px; gap: 14px; grid-template-columns: 26px 1fr; }
  .v-qualify-item-icon { width: 26px; height: 26px; font-size: 13px; }
}

/* QUALIFY — dark */
.on-dark .v-qualify-grid { background: transparent; }
.on-dark .v-qualify-div { background: #2A2420; }
.on-dark .v-qualify-head { border-bottom-color: #2A2420; }
.on-dark .v-qualify-head .v-h3 { color: var(--v-paper); }
.on-dark .v-q-item { border-bottom-color: #2A2420; color: #A59B8F; }
.on-dark .v-q-yes::before { background: var(--v-brass); }
.on-dark .v-q-no::before { background: #4A4239; }

/* TEAM */
.v-team-layout { display: grid; grid-template-columns: 420px 1fr; gap: 72px; align-items: stretch; margin-top: 20px; }
.v-team-left { display: flex; flex-direction: column; }
.v-team-right { display: flex; flex-direction: column; }
.v-team-img-wrap { position: relative; }
.v-team-placeholder { width: 100%; aspect-ratio: 4/5; background: var(--v-paper-deep); display: flex; align-items: center; justify-content: center; font-family: var(--font-mono); font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--v-ink-muted); }
.v-team-caption { border-top: 2px solid var(--v-bordeaux); padding: 14px 18px; background: var(--v-paper); font-family: var(--font-serif); font-style: italic; font-size: 18px; color: var(--v-ink-soft); display: flex; justify-content: space-between; align-items: baseline; gap: 16px; }
.v-team-caption-sub { font-family: var(--font-mono); font-style: normal; font-size: 10.5px; letter-spacing: 2px; text-transform: uppercase; color: var(--v-ink-muted); }
.v-team-intro { margin-top: 22px; }

.v-team-cards { display: flex; flex-direction: column; gap: 18px; flex: 1; }
.v-team-card { background: var(--v-paper); border: 1px solid var(--v-border); padding: 28px 30px 24px; position: relative; flex: 1; display: flex; flex-direction: column; }
.v-team-card::before { content: ''; position: absolute; top: -1px; left: -1px; right: -1px; height: 2px; background: var(--v-bordeaux); }
.v-team-card-head { display: flex; align-items: center; gap: 14px; margin-bottom: 14px; }
.v-team-card-num { font-family: var(--font-mono); font-size: 10px; font-weight: 500; letter-spacing: 2px; color: var(--v-bordeaux); }
.v-team-card-role { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 2px; text-transform: uppercase; color: var(--v-ink-muted); flex: 1; padding-left: 14px; border-left: 1px solid var(--v-border); }
.v-team-card-name { font-family: var(--font-serif); font-style: italic; font-weight: 300; font-size: 30px; line-height: 1.1; color: var(--v-ink-soft); letter-spacing: -0.01em; margin-bottom: 14px; }
.v-team-card-name span { font-size: 15px; color: var(--v-ink-muted); font-style: italic; letter-spacing: 0; }
.v-team-card-body { flex: 1; }
.v-team-card-foot { display: flex; gap: 12px; align-items: center; padding-top: 14px; border-top: 1px solid var(--v-border); font-family: var(--font-mono); font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; }
.v-team-card-foot a { color: var(--v-ink-sub); cursor: pointer; transition: color .15s; }
.v-team-card-foot a:hover { color: var(--v-bordeaux); }
.v-team-card-foot span { color: var(--v-ink-muted); }

/* TEAM + FAQ COMBINED */
.v-teamfaq-layout { display: grid; grid-template-columns: 420px 1fr; gap: 72px; align-items: start; margin-top: 20px; }
.v-teamfaq-left { display: flex; flex-direction: column; }
.v-teamfaq-left .v-team-cards { margin-top: 28px; }
.v-teamfaq-right { min-width: 0; }
.v-teamfaq-right .v-faq-list { max-width: none; }

/* FAQ */
.v-faq-list { margin-top: 30px; display: grid; grid-template-columns: 1fr; border-top: 1px solid var(--v-border); }
.v-faq-item { border-bottom: 1px solid var(--v-border); }
.v-faq-q { padding: 26px 0; display: flex; justify-content: space-between; align-items: center; cursor: pointer; gap: 24px; font-family: var(--font-serif); font-size: 24px; font-style: italic; color: var(--v-ink-soft); line-height: 1.32; }
.v-faq-q:hover { color: var(--v-bordeaux); }
.v-faq-toggle { width: 30px; height: 30px; border: 1px solid var(--v-border); display: flex; align-items: center; justify-content: center; font-size: 16px; color: var(--v-bordeaux); flex-shrink: 0; transition: transform .2s; font-family: var(--font-mono); }
.v-faq-item.open .v-faq-toggle { transform: rotate(45deg); }
.v-faq-a { font-family: var(--font-mono); font-size: 15px; line-height: 1.8; color: var(--v-ink-sub); padding-bottom: 26px; }

/* CTA */
.v-cta { background: var(--v-ink); padding: 100px 64px; display: grid; grid-template-columns: 1fr auto; gap: 80px; align-items: center; }
.v-cta-right { display: flex; flex-direction: column; align-items: flex-end; gap: 14px; }
.v-cta-note { font-family: var(--font-mono); font-size: 10px; color: #5A524A; text-align: right; line-height: 1.7; }

/* Centered CTA variant */
.v-cta.v-cta-centered { display: block; padding: 120px 64px; text-align: center; }
.v-cta-inner { max-width: 1100px; margin: 0 auto; display: flex; flex-direction: column; align-items: center; gap: 0; }
.v-cta-eyebrow { font-family: var(--font-mono); font-size: 10px; letter-spacing: 3px; text-transform: uppercase; color: var(--v-brass); margin-bottom: 28px; display: inline-flex; align-items: center; gap: 14px; }
.v-cta-eyebrow-line { width: 36px; height: 1px; background: var(--v-brass); }
.v-cta.v-cta-centered .v-h1 { max-width: 920px; }
.v-cta-lede { color: #A59B8F; margin-top: 26px; max-width: 880px; text-align: center; font-size: 16px; line-height: 1.75; }
.v-cta-actions { display: flex; gap: 14px; margin-top: 38px; flex-wrap: wrap; justify-content: center; }
.v-btn-cta-ghost { background: transparent; color: var(--v-paper); border: 1px solid rgba(247,243,236,0.30); padding: 18px 36px; }
.v-btn-cta-ghost:hover { background: rgba(247,243,236,0.06); border-color: var(--v-paper); opacity: 1; }

/* Center section headers from "Wie es funktioniert" onwards */
#prozess .v-section-header,
.v-qualify-section .v-section-header,
#team .v-section-header,
#faq .v-section-header,
.v-section[data-screen-label="07 Cleveland"] .v-section-header { margin-left: auto; margin-right: auto; text-align: center; max-width: 820px; }
#prozess .v-section-sub,
.v-qualify-section .v-section-sub,
#team .v-section-sub,
#faq .v-section-sub,
.v-section[data-screen-label="07 Cleveland"] .v-section-sub { margin-left: auto; margin-right: auto; text-align: center; }
#prozess .v-section-header .v-eyebrow,
.v-qualify-section .v-section-header .v-eyebrow,
#team .v-section-header .v-eyebrow,
#faq .v-section-header .v-eyebrow,
.v-section[data-screen-label="07 Cleveland"] .v-section-header .v-eyebrow { display: inline-flex; }

/* FOOTER */
.v-footer { background: var(--v-ink); color: var(--v-paper); padding: 44px 64px; display: flex; justify-content: space-between; align-items: center; border-top: 1px solid #2A2420; }
.v-footer-logo { display: flex; align-items: center; gap: 10px; font-family: var(--font-serif); font-size: 14px; font-weight: 600; letter-spacing: 4px; text-transform: uppercase; color: var(--v-paper); }
.v-footer-links { display: flex; gap: 28px; }
.v-footer-links a { font-family: var(--font-mono); font-size: 11px; color: #8A8078; letter-spacing: .5px; cursor: pointer; transition: color .15s; }
.v-footer-links a:hover { color: var(--v-brass); }
.v-footer-copy { font-family: var(--font-mono); font-size: 10px; color: #5A524A; }

/* LEGAL MODAL — Impressum / Datenschutz */
.v-legal-overlay { position: fixed; inset: 0; background: rgba(20, 18, 16, 0.72); display: flex; align-items: center; justify-content: center; z-index: 1000; padding: 40px 20px; animation: v-legal-fade .18s ease-out; }
.v-legal-modal { background: var(--v-paper); max-width: 720px; width: 100%; max-height: 85vh; overflow-y: auto; border-top: 3px solid var(--v-bordeaux); padding: 56px 64px 52px; position: relative; box-shadow: 0 20px 60px rgba(20, 18, 16, 0.25); animation: v-legal-rise .22s ease-out; }
.v-legal-close { position: absolute; top: 18px; right: 22px; width: 34px; height: 34px; border: 1px solid var(--v-border); background: transparent; font-size: 22px; line-height: 1; color: var(--v-ink-sub); cursor: pointer; font-family: var(--font-mono); display: flex; align-items: center; justify-content: center; transition: color .15s, border-color .15s; padding: 0; }
.v-legal-close:hover { color: var(--v-bordeaux); border-color: var(--v-bordeaux); }
.v-legal-eyebrow { font-family: var(--font-mono); font-size: 11px; letter-spacing: 2.2px; text-transform: uppercase; color: var(--v-bordeaux); margin-bottom: 14px; display: flex; align-items: center; gap: 10px; }
.v-legal-eyebrow::before { content: ''; width: 22px; height: 1px; background: var(--v-bordeaux); }
.v-legal-title { font-family: var(--font-serif); font-style: italic; font-weight: 300; font-size: 44px; line-height: 1.05; letter-spacing: -0.02em; color: var(--v-ink-soft); margin: 0 0 36px; }
.v-legal-body { display: flex; flex-direction: column; gap: 22px; }
.v-legal-section { display: flex; flex-direction: column; gap: 6px; }
.v-legal-label { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 2px; text-transform: uppercase; color: var(--v-ink-muted); }
.v-legal-body p { font-family: var(--font-mono); font-size: 12px; line-height: 1.8; color: var(--v-ink-sub); margin: 0; font-weight: 300; }
.v-legal-body p strong { font-family: var(--font-serif); font-style: italic; font-weight: 400; font-size: 15px; color: var(--v-ink-soft); letter-spacing: -0.005em; }
.v-legal-body a { color: var(--v-bordeaux); text-decoration: none; border-bottom: 1px solid rgba(122, 31, 40, 0.3); transition: border-color .15s; }
.v-legal-body a:hover { border-bottom-color: var(--v-bordeaux); }
@keyframes v-legal-fade { from { opacity: 0; } to { opacity: 1; } }
@keyframes v-legal-rise { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }


/* CASE STUDIES */
.v-cases { display: flex; flex-direction: column; gap: 28px; margin-top: 20px; }
.v-case { background: var(--v-paper); border: 1px solid var(--v-border); position: relative; }
.v-case::before { content: ''; position: absolute; top: -1px; left: -1px; right: -1px; height: 2px; background: var(--v-bordeaux); }
.v-case-meta { display: flex; justify-content: space-between; align-items: center; padding: 18px 32px; border-bottom: 1px solid var(--v-border); background: var(--v-paper-alt); }
.v-case-tag { font-family: var(--font-mono); font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--v-ink-muted); display: inline-flex; align-items: center; gap: 10px; }
.v-case-tag-right { color: var(--v-ink-sub); }
.v-case-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--v-bordeaux); display: inline-block; }

.v-case-body { display: grid; grid-template-columns: 1fr 320px; align-items: stretch; }
.v-case-main { padding: 44px 48px 40px; }
.v-case-hero { display: flex; gap: 32px; align-items: flex-start; margin-bottom: 28px; }
.v-case-num { font-family: var(--font-serif); font-size: 108px; font-style: italic; font-weight: 300; color: var(--v-bordeaux); line-height: 0.9; letter-spacing: -0.03em; flex-shrink: 0; min-width: 110px; }
.v-case-title-block { flex: 1; padding-top: 18px; }
.v-case-title { font-family: var(--font-serif); font-size: 36px; font-style: italic; font-weight: 300; color: var(--v-ink); line-height: 1.05; letter-spacing: -0.01em; }
.v-case-title span { color: var(--v-ink-muted); font-weight: 300; }
.v-case-subtitle { font-family: var(--font-mono); font-size: 11.5px; color: var(--v-ink-sub); letter-spacing: 0.3px; margin-top: 12px; line-height: 1.6; }
.v-case-strategy { font-family: var(--font-mono); font-size: 11px; color: var(--v-ink-soft); letter-spacing: 0.3px; margin-top: 8px; display: flex; gap: 12px; align-items: baseline; }
.v-case-strategy span { font-size: 10.5px; letter-spacing: 2px; text-transform: uppercase; color: var(--v-ink-muted); }

.v-case-copy { max-width: 640px; margin-bottom: 40px; font-size: 14px; line-height: 1.75; }

.v-case-kpis { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; padding-top: 28px; border-top: 1px solid var(--v-border); }
.v-case-kpi-group { display: flex; flex-direction: column; }
.v-case-kpi-head { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 2px; text-transform: uppercase; color: var(--v-ink-muted); padding-bottom: 14px; }
.v-case-kpi-row { display: flex; justify-content: space-between; align-items: baseline; padding: 12px 0; border-bottom: 1px solid var(--v-border); gap: 16px; }
.v-case-kpi-row:last-child { border-bottom: none; }
.v-case-kpi-l { font-family: var(--font-mono); font-size: 11px; color: var(--v-ink-sub); letter-spacing: 0.2px; }
.v-case-kpi-v { font-family: var(--font-serif); font-size: 17px; font-style: italic; font-weight: 400; color: var(--v-ink-soft); white-space: nowrap; letter-spacing: -0.005em; }
.v-case-kpi-row.is-featured .v-case-kpi-v { color: var(--v-bordeaux); font-size: 19px; font-weight: 500; }
.v-case-kpi-row.is-featured .v-case-kpi-l { color: var(--v-ink-soft); }

.v-case-side { background: var(--v-ink); color: var(--v-paper); padding: 40px 36px 32px; display: flex; flex-direction: column; position: relative; border-left: 1px solid var(--v-border); }
.v-case-side::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: var(--v-bordeaux); }
.v-case-side-label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--v-brass); margin-bottom: 20px; }
.v-case-side-coc { display: flex; align-items: flex-start; gap: 4px; line-height: 0.9; margin-bottom: 32px; }
.v-case-side-coc-n { font-family: var(--font-serif); font-size: 92px; font-style: italic; font-weight: 300; color: var(--v-paper); letter-spacing: -0.03em; }
.v-case-side-coc-pct { font-family: var(--font-serif); font-size: 36px; font-style: italic; font-weight: 300; color: var(--v-brass); margin-top: 12px; }
.v-case-side-split { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; padding-top: 22px; border-top: 1px solid rgba(255,255,255,0.08); margin-bottom: 24px; }
.v-case-side-mini-l { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 2px; text-transform: uppercase; color: #8A8078; margin-bottom: 8px; }
.v-case-side-mini-v { font-family: var(--font-serif); font-size: 20px; font-style: italic; font-weight: 300; color: var(--v-paper); white-space: nowrap; }
.v-case-side-mini-v span { font-size: 12px; color: #8A8078; margin-left: 2px; }
.v-case-side-foot { margin-top: auto; padding-top: 20px; border-top: 1px solid rgba(255,255,255,0.08); font-family: var(--font-mono); font-size: 11px; line-height: 1.7; color: #8A8078; letter-spacing: 0.3px; }

/* CASE COMPARE TABLE */
.v-case-compare { margin-top: 56px; border: 1px solid var(--v-border); background: var(--v-paper); position: relative; }
.v-case-compare::before { content: ''; position: absolute; top: -1px; left: -1px; right: -1px; height: 2px; background: var(--v-bordeaux); }
.v-case-compare-head { display: flex; justify-content: space-between; padding: 18px 32px; border-bottom: 1px solid var(--v-border); background: var(--v-paper-alt); }
.v-case-compare-grid { padding: 14px 32px 22px; }
.v-case-compare-row { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 24px; padding: 16px 0; border-bottom: 1px solid var(--v-border); align-items: baseline; }
.v-case-compare-row:last-child { border-bottom: none; }
.v-case-compare-l { font-family: var(--font-mono); font-size: 11px; color: var(--v-ink-sub); letter-spacing: 0.2px; }
.v-case-compare-v { font-family: var(--font-serif); font-size: 18px; font-style: italic; font-weight: 400; color: var(--v-ink-soft); text-align: right; white-space: nowrap; }
.v-case-compare-v-hi { color: var(--v-bordeaux); font-weight: 500; }

@media (max-width: 1080px) {
  .v-case-body { grid-template-columns: 1fr; }
  .v-case-side { border-left: none; border-top: 1px solid var(--v-border); }
  .v-case-kpis { grid-template-columns: 1fr; gap: 28px; }
  .v-case-compare-row { grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 12px; }
}


/* =========================================================================
   DEALS PAGES — overview grid + detail
   ========================================================================= */

/* Deals hero — more compressed than homepage */
.v-deals-hero { padding: calc(84px + 48px) 64px 44px; background: var(--v-paper); border-bottom: 1px solid var(--v-border); }
.v-deals-hero-inner { max-width: 1280px; margin: 0 auto; }
.v-deals-hero .v-h1 { font-size: clamp(32px, 3.2vw, 42px); line-height: 1.18; margin: 0; font-family: var(--font-serif); font-weight: 300; color: var(--v-ink-soft); letter-spacing: -0.01em; }
.v-deals-hero .v-h1 em { font-style: italic; color: var(--v-bordeaux); font-weight: 300; }
.v-deals-counts { display: flex; gap: 56px; margin-top: 30px; padding-top: 22px; border-top: 1px solid var(--v-border); }
.v-deals-count-n { font-family: var(--font-serif); font-style: italic; font-weight: 300; font-size: 42px; color: var(--v-ink-soft); display: block; line-height: 1; }
.v-deals-count-l { font-family: var(--font-mono); font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--v-ink-muted); margin-top: 10px; display: block; }

/* Deals body */
.v-deals-body { padding: 48px 64px 96px; background: var(--v-paper); max-width: none; }
.v-deals-filter { display: flex; align-items: center; gap: 20px; padding-bottom: 28px; margin-bottom: 40px; border-bottom: 1px solid var(--v-border); flex-wrap: wrap; }
.v-deals-filter-label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--v-ink-muted); padding-right: 20px; border-right: 1px solid var(--v-border); }
.v-deals-filter-chips { display: flex; gap: 4px; flex-wrap: wrap; }
.v-deals-chip { background: transparent; border: 1px solid var(--v-border); padding: 9px 18px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 1.2px; text-transform: uppercase; color: var(--v-ink-sub); cursor: pointer; transition: all .15s; }
.v-deals-chip:hover { color: var(--v-ink-soft); border-color: var(--v-ink-muted); }
.v-deals-chip.is-active { background: var(--v-ink); color: var(--v-paper); border-color: var(--v-ink); }

/* Deal card grid */
.v-deals-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--v-border); border: 1px solid var(--v-border); align-items: stretch; }
.v-deal-card { display: flex; flex-direction: column; background: var(--v-paper); text-decoration: none; color: inherit; transition: background .2s; cursor: pointer; height: 100%; }
.v-deal-card:hover { background: var(--v-paper-alt); }
.v-deal-card-verkauft { opacity: 0.92; }
.v-deal-card-verkauft:hover { opacity: 1; }

/* Placeholder image */
.v-deal-img { background: var(--v-paper-alt); aspect-ratio: 16 / 10; position: relative; overflow: hidden; border-bottom: 1px solid var(--v-border); display: flex; align-items: center; justify-content: center; }
.v-deal-img svg { width: 78%; height: 78%; }
.v-deal-img-cap { position: absolute; bottom: 10px; left: 14px; font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--v-ink-muted); }

/* Deal card body */
.v-deal-card-body { padding: 24px 28px 28px; display: flex; flex-direction: column; flex: 1; }
.v-deal-card-meta { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; }
.v-deal-case { font-family: var(--font-mono); font-size: 11px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--v-ink-muted); }
.v-deal-card-title { font-family: var(--font-serif); font-size: 24px; font-style: italic; font-weight: 300; color: var(--v-ink-soft); letter-spacing: -0.005em; line-height: 1.2; }
.v-deal-card-title span { color: var(--v-ink-muted); font-style: normal; font-size: 0.7em; }
.v-deal-card-sub { font-family: var(--font-mono); font-size: 11.5px; color: var(--v-ink-sub); margin-top: 6px; letter-spacing: 0.2px; }

/* Status pill */
.v-deal-status { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 2px; text-transform: uppercase; padding: 5px 10px; border: 1px solid currentColor; }
.v-deal-status-dot { width: 5px; height: 5px; border-radius: 50%; background: currentColor; }
.v-deal-status-verfuegbar { color: var(--v-bordeaux); }
.v-deal-status-reserviert { color: #9C7A2E; }
.v-deal-status-verkauft { color: var(--v-ink-muted); }

/* Deal card KPIs (legacy 5-tile) */
.v-deal-card-kpis { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--v-border); margin-top: 24px; border: 1px solid var(--v-border); }
.v-deal-kpi { background: var(--v-paper); padding: 14px 16px; display: flex; flex-direction: column; gap: 6px; }
.v-deal-card:hover .v-deal-kpi { background: var(--v-paper-alt); }
.v-deal-kpi-l { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 1.8px; text-transform: uppercase; color: var(--v-ink-muted); }
.v-deal-kpi-v { font-family: var(--font-serif); font-size: 17px; font-style: italic; font-weight: 400; color: var(--v-ink-soft); white-space: nowrap; letter-spacing: -0.005em; }
.v-deal-kpi-hi .v-deal-kpi-v { color: var(--v-bordeaux); font-weight: 500; }
.v-deal-kpi-hi .v-deal-kpi-l { color: var(--v-ink-soft); }

.v-deal-card-kpis .v-deal-kpi:nth-child(5) { grid-column: 1 / -1; }

/* Deal card boxes (Kaufpreis+EK | Cashflow) */
.v-deal-card-boxes { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: auto; padding-top: 24px; }
.v-deal-box { padding: 16px 18px; background: var(--v-paper); border: 1px solid var(--v-border); display: flex; flex-direction: column; gap: 8px; }
.v-deal-box.is-cf { background: var(--v-ink); border-color: var(--v-ink); justify-content: center; }
.v-deal-box-row { display: flex; justify-content: space-between; align-items: baseline; gap: 10px; }
.v-deal-box-row + .v-deal-box-row { padding-top: 8px; border-top: 1px solid var(--v-border); }
.v-deal-box-l { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 1.8px; text-transform: uppercase; color: var(--v-ink-muted); }
.v-deal-box-v { font-family: var(--font-serif); font-size: 19px; font-weight: 400; color: var(--v-ink-soft); letter-spacing: -0.005em; line-height: 1; white-space: nowrap; }
.v-deal-box.is-cf .v-deal-box-l { color: var(--v-paper); }
.v-deal-box.is-cf .v-deal-box-v { color: var(--v-brass); font-size: 28px; white-space: nowrap; }

.v-deal-card-foot { margin-top: 24px; padding-top: 16px; border-top: 1px solid var(--v-border); display: flex; justify-content: space-between; align-items: center; font-family: var(--font-mono); font-size: 10px; letter-spacing: 1px; text-transform: uppercase; color: var(--v-ink-muted); }
.v-deal-card-go { color: var(--v-bordeaux); transition: transform .15s; }
.v-deal-card:hover .v-deal-card-go { transform: translateX(3px); }

.v-deals-legal { margin-top: 56px; padding: 24px 28px; border-left: 2px solid var(--v-border); font-family: var(--font-mono); font-size: 10.5px; line-height: 1.7; color: var(--v-ink-muted); max-width: 820px; }
.v-deals-legal strong { color: var(--v-ink-soft); font-weight: 500; }

.v-deals-pager { display: flex; flex-direction: column; align-items: center; gap: 10px; margin-top: 48px; }
.v-deals-pager-btn { background: var(--v-ink); color: var(--v-paper); border: none; padding: 16px 36px; font-family: var(--font-mono); font-size: 12px; letter-spacing: 2px; text-transform: uppercase; cursor: pointer; display: inline-flex; align-items: center; gap: 12px; transition: opacity .15s; }
.v-deals-pager-btn:hover { opacity: .88; }
.v-deals-pager-meta { font-family: var(--font-mono); font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--v-ink-muted); }

/* === DEAL REQUEST MODAL === */
.v-req-overlay { position: fixed; inset: 0; background: rgba(20,18,16,0.78); z-index: 200; display: flex; align-items: center; justify-content: center; padding: 24px; backdrop-filter: blur(4px); }
.v-req-modal { background: var(--v-ink); color: var(--v-paper); width: 100%; max-width: 460px; padding: 44px 36px 36px; position: relative; border-top: 3px solid var(--v-bordeaux); display: flex; flex-direction: column; gap: 0; max-height: 92vh; overflow-y: auto; }
.v-req-close { position: absolute; top: 12px; right: 12px; width: 32px; height: 32px; border: 1px solid #2A2420; background: transparent; color: #8A8078; font-size: 22px; line-height: 1; cursor: pointer; font-family: var(--font-mono); display: flex; align-items: center; justify-content: center; padding: 0; transition: color .15s, border-color .15s; }
.v-req-close:hover { color: var(--v-paper); border-color: var(--v-brass); }
.v-req-eyebrow { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--v-brass); margin-bottom: 14px; display: inline-flex; align-items: center; gap: 12px; }
.v-req-eyebrow::before { content: ''; width: 22px; height: 1px; background: var(--v-brass); display: inline-block; }
.v-req-title { font-family: var(--font-serif); font-style: italic; font-weight: 300; font-size: 32px; color: var(--v-paper); margin: 0 0 14px; line-height: 1.18; letter-spacing: -0.01em; }
.v-req-title em { font-style: italic; color: var(--v-brass); }
.v-req-lede { font-family: var(--font-mono); font-size: 13px; line-height: 1.7; color: #B8ADA3; margin: 0 0 26px; }
.v-req-form { display: flex; flex-direction: column; gap: 16px; }
.v-req-field { display: flex; flex-direction: column; gap: 6px; }
.v-req-field span { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 1.8px; text-transform: uppercase; color: #8A8078; }
.v-req-field input { background: #1F1915; color: var(--v-paper); border: 1px solid #2A2420; padding: 12px 14px; font-family: var(--font-mono); font-size: 14px; outline: none; transition: border-color .15s; }
.v-req-field input:focus { border-color: var(--v-brass); }
.v-req-field input::placeholder { color: #6A6259; }
.v-req-submit { background: var(--v-bordeaux-lift); color: var(--v-paper); border: none; padding: 16px 24px; font-family: var(--font-mono); font-size: 12px; letter-spacing: 1.8px; text-transform: uppercase; cursor: pointer; margin-top: 8px; transition: opacity .15s; }
.v-req-submit:hover { opacity: .88; }
.v-req-submit:disabled { opacity: .55; cursor: not-allowed; }
.v-req-skip { background: transparent; color: #8A8078; border: none; padding: 12px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 1.8px; text-transform: uppercase; cursor: pointer; margin-top: 4px; }
.v-req-skip:hover { color: var(--v-paper); }
.v-req-note { font-family: var(--font-mono); font-size: 10.5px; line-height: 1.6; color: #6A6259; margin-top: 8px; }
.v-req-confirm-icon { width: 56px; height: 56px; border-radius: 50%; background: var(--v-brass); color: var(--v-ink); display: flex; align-items: center; justify-content: center; font-size: 30px; font-family: var(--font-mono); margin-bottom: 22px; }

@media (max-width: 560px) {
  .v-req-modal { padding: 36px 22px 26px; max-width: 100%; }
  .v-req-title { font-size: 26px; }
  .v-req-lede { font-size: 12.5px; }
}

/* is-active nav link */
.v-nav-links a.is-active { color: var(--v-ink-soft); position: relative; }
.v-nav-links a.is-active::after { content: ''; position: absolute; left: 0; right: 0; bottom: -2px; height: 1px; background: var(--v-bordeaux); }

/* =========================================================================
   DEAL DETAIL page
   ========================================================================= */
.v-dealdet-hero { padding: calc(84px + 32px) 64px 32px; border-bottom: 1px solid var(--v-border); background: var(--v-paper); }
.v-dealdet-hero-inner { max-width: 1280px; margin: 0 auto; }
.v-dealdet-breadcrumb { font-family: var(--font-mono); font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--v-ink-muted); margin-bottom: 18px; }
.v-dealdet-breadcrumb a { color: var(--v-ink-muted); text-decoration: none; border-bottom: 1px solid transparent; transition: border-color .15s; }
.v-dealdet-breadcrumb a:hover { border-bottom-color: var(--v-bordeaux); color: var(--v-ink-soft); }
.v-dealdet-breadcrumb span { margin: 0 10px; color: var(--v-border); }

.v-dealdet-head { display: grid; grid-template-columns: 1fr auto; gap: 32px; align-items: center; }
.v-dealdet-head-l { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.v-dealdet-title { font-family: var(--font-serif); font-weight: 300; font-style: italic; font-size: clamp(28px, 2.6vw, 36px); line-height: 1.18; color: var(--v-ink-soft); margin: 0; letter-spacing: -0.012em; }
.v-dealdet-title em { font-style: italic; color: var(--v-bordeaux); }
.v-dealdet-title span { color: var(--v-ink-muted); font-style: normal; font-size: 0.78em; font-weight: 300; }
.v-dealdet-sub { font-family: var(--font-mono); font-size: 12.5px; line-height: 1.8; color: var(--v-ink-sub); margin-top: 20px; max-width: 620px; }
.v-dealdet-expose-btn { background: var(--v-bordeaux); color: #fff; border: none; padding: 14px 26px; font-family: var(--font-mono); font-size: 12px; letter-spacing: 1.8px; text-transform: uppercase; cursor: pointer; transition: opacity .15s; white-space: nowrap; }
.v-dealdet-expose-btn:hover { opacity: .88; }

/* Object info table inside body (replaces inline header meta) */
.v-dealdet-objectinfo { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0 24px; padding: 22px 0; border-top: 1px solid var(--v-border); border-bottom: 1px solid var(--v-border); margin-bottom: 40px; }
.v-dealdet-objectinfo-row { display: flex; gap: 14px; padding: 8px 0; align-items: baseline; }
.v-dealdet-objectinfo-l { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 1.8px; text-transform: uppercase; color: var(--v-ink-muted); min-width: 80px; }
.v-dealdet-objectinfo-v { font-family: var(--font-serif); font-size: 16px; font-style: italic; font-weight: 300; color: var(--v-ink-soft); }

.v-dealdet-main { display: grid; grid-template-columns: 1.55fr 1fr; gap: 0; border-bottom: 1px solid var(--v-border); padding-top: 84px; }
.v-dealdet-left { padding: 56px 64px; border-right: 1px solid var(--v-border); }
.v-dealdet-right { padding: 56px 56px; background: var(--v-paper-alt); }
.v-dealdet-headline { font-family: var(--font-serif); font-weight: 300; font-style: italic; font-size: clamp(28px, 2.6vw, 36px); line-height: 1.18; color: var(--v-ink-soft); letter-spacing: -0.012em; margin: 0 0 28px; }

.v-dealdet-gallery { aspect-ratio: 16 / 10; background: var(--v-paper-alt); position: relative; border: 1px solid var(--v-border); margin-bottom: 16px; overflow: hidden; }
.v-dealdet-gallery .v-deal-img { aspect-ratio: auto; height: 100%; background: transparent; border: none; }
.v-dealdet-gallery-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 48px; }
.v-dealdet-gallery-mini { aspect-ratio: 4 / 3; background: var(--v-paper-alt); border: 1px solid var(--v-border); display: flex; align-items: center; justify-content: center; font-family: var(--font-mono); font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--v-ink-muted); }

.v-dealdet-narrative { font-family: var(--font-serif); font-size: 19px; font-weight: 300; line-height: 1.6; color: var(--v-ink-soft); max-width: 640px; margin: 0 0 40px; }
.v-dealdet-narrative::first-letter { font-size: 64px; float: left; line-height: .9; padding: 6px 12px 0 0; color: var(--v-bordeaux); font-style: italic; font-weight: 400; }

.v-dealdet-highlights { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--v-border); border: 1px solid var(--v-border); margin-top: 40px; }
.v-dealdet-hl { background: var(--v-paper); padding: 22px 24px; display: flex; gap: 16px; align-items: flex-start; }
.v-dealdet-hl-mark { font-family: var(--font-mono); font-size: 11px; color: var(--v-bordeaux); letter-spacing: 1.5px; flex-shrink: 0; padding-top: 2px; }
.v-dealdet-hl-t { font-family: var(--font-serif); font-size: 15px; color: var(--v-ink-soft); line-height: 1.5; }

/* Cashflow / Monat highlight card */
.v-dealdet-cfcard { background: var(--v-ink); color: var(--v-paper); padding: 24px 26px 26px; margin-bottom: 32px; border-left: 3px solid var(--v-brass); }
.v-dealdet-cfcard-l { font-family: var(--font-mono); font-size: 12px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--v-brass-300); margin-bottom: 14px; }
.v-dealdet-cfcard-v { font-family: var(--font-serif); font-size: 56px; font-weight: 400; line-height: 1; color: var(--v-brass); letter-spacing: -0.02em; font-style: normal; }
.v-dealdet-cfcard-sub { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.5px; color: #8A8078; margin-top: 14px; }

/* Detail KPI table on right sidebar */
.v-dealdet-kpicard { border: 1px solid var(--v-border); background: var(--v-paper); padding: 0; margin-bottom: 32px; }
.v-dealdet-kpicard-h { padding: 16px 24px; border-bottom: 1px solid var(--v-border); font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--v-ink-muted); display: flex; justify-content: space-between; }
.v-dealdet-row { display: grid; grid-template-columns: 1fr auto; gap: 16px; padding: 16px 24px; border-bottom: 1px solid var(--v-border); align-items: baseline; }
.v-dealdet-row:last-child { border-bottom: none; }
.v-dealdet-row-l { font-family: var(--font-mono); font-size: 12.5px; color: var(--v-ink-sub); letter-spacing: 0.4px; font-weight: 400; display: inline-flex; align-items: center; gap: 10px; }
.v-dealdet-row-sign { font-family: var(--font-mono); font-size: 13px; line-height: 1; color: var(--v-ink-muted); width: 12px; display: inline-block; text-align: center; flex: 0 0 12px; }
.v-dealdet-row.is-hi .v-dealdet-row-sign { color: var(--v-brass-300); font-weight: 500; }
.v-dealdet-row-v { font-family: var(--font-serif); font-size: 20px; font-style: normal; font-weight: 400; color: var(--v-ink-soft); white-space: nowrap; letter-spacing: -0.005em; }
.v-dealdet-row.is-hi { background: var(--v-ink); }
.v-dealdet-row.is-hi .v-dealdet-row-l { color: var(--v-brass-300); }
.v-dealdet-row.is-hi .v-dealdet-row-v { color: var(--v-brass); font-size: 24px; font-weight: 500; }

/* Info popover (Kaufpreis / LTV / Laufende Kosten) — ⓘ button beside the
   label opens a small card anchored below the row. Closes on outside click
   + Escape. Stays inside the card via left/right: 24px positioning. */
.v-dealdet-row-info { position: relative; }
.v-dealdet-row-info .v-dealdet-row-l { display: inline-flex; align-items: center; gap: 8px; }
.v-dealdet-row-info-btn { background: none; border: none; padding: 0 2px; margin: 0; cursor: pointer; color: var(--v-ink-muted); font-size: 13px; line-height: 1; transition: color .12s; font-family: inherit; }
.v-dealdet-row-info-btn:hover { color: var(--v-bordeaux); }
.v-dealdet-row-info.is-open .v-dealdet-row-info-btn { color: var(--v-bordeaux); }
.v-dealdet-row-info-pop { position: absolute; left: 24px; right: 24px; top: calc(100% - 1px); background: var(--v-paper); border: 1px solid var(--v-border); border-top: 2px solid var(--v-bordeaux); padding: 18px 22px 16px; z-index: 12; box-shadow: 0 18px 36px -16px rgba(20,18,16,0.22); animation: vDealdetPopIn .14s ease-out; }
@keyframes vDealdetPopIn { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: translateY(0); } }
.v-dealdet-row-info-pop-h { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 2px; text-transform: uppercase; color: var(--v-ink-muted); margin-bottom: 12px; }
.v-dealdet-row-info-pop-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.v-dealdet-row-info-pop-list li { display: flex; justify-content: space-between; align-items: baseline; gap: 14px; font-family: var(--font-mono); font-size: 11.5px; color: var(--v-ink-sub); padding-bottom: 8px; border-bottom: 1px solid var(--v-border); }
.v-dealdet-row-info-pop-list li:last-child { border-bottom: none; padding-bottom: 0; }
.v-dealdet-row-info-pop-item-l { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.v-dealdet-row-info-pop-label { color: var(--v-ink-sub); }
.v-dealdet-row-info-pop-rate { color: var(--v-ink-muted); font-size: 10px; letter-spacing: 0.3px; }
.v-dealdet-row-info-pop-amount { font-family: var(--font-serif); font-style: italic; font-size: 13px; color: var(--v-ink-soft); white-space: nowrap; flex-shrink: 0; }
.v-dealdet-row-info-pop-note { margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--v-border); font-family: var(--font-mono); font-size: 10.5px; line-height: 1.6; color: var(--v-ink-muted); letter-spacing: 0.2px; }
.v-dealdet-row-info-pop:has(.v-dealdet-row-info-pop-note:first-child) { /* note-only popover (no items): keep generous padding around the note */ }
.v-dealdet-row-info-pop > .v-dealdet-row-info-pop-note:first-child { margin-top: 0; padding-top: 0; border-top: none; }

@media (max-width: 560px) {
  .v-dealdet-row-info-pop { left: 12px; right: 12px; padding: 16px 16px 14px; }
}

.v-dealdet-cta { border: 1px solid var(--v-ink); background: var(--v-ink); color: var(--v-paper); padding: 32px; }
.v-dealdet-cta h3 { font-family: var(--font-serif); font-style: italic; font-weight: 300; font-size: 26px; color: var(--v-paper); margin: 0 0 12px; line-height: 1.25; }
.v-dealdet-cta h3 em { color: var(--v-brass); font-style: italic; }
.v-dealdet-cta p { font-family: var(--font-mono); font-size: 11.5px; line-height: 1.7; color: #B8ADA3; margin: 0 0 24px; }
.v-dealdet-cta button { background: var(--v-bordeaux-lift); color: #fff; border: none; padding: 14px 24px; font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 1.5px; text-transform: uppercase; cursor: pointer; width: 100%; transition: opacity .15s; }
.v-dealdet-cta button:hover { opacity: .88; }
.v-dealdet-cta .v-dealdet-cta-sub { font-family: var(--font-mono); font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; color: #8A8078; margin-top: 14px; text-align: center; }

.v-dealdet-statuscard { border: 1px solid var(--v-border); padding: 20px 24px; display: flex; justify-content: space-between; align-items: center; margin-bottom: 28px; background: var(--v-paper); }
.v-dealdet-statuscard-l { font-family: var(--font-mono); font-size: 11px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--v-ink-muted); }

/* Inline variants — when the statuscard / CTAs live in the left column
   instead of in the right sidebar. The status pill sits at the very
   top (before the gallery); CTAs sit below the narrative. They span
   the full left-column width. */
.v-dealdet-statuscard-top    { margin-bottom: 18px; }
.v-dealdet-statuscard-inline { margin-top: 40px; }
.v-dealdet-cta-inline        { margin-top: 32px; }

/* "Passt dieser Deal zu dir?" — reuses the QualifyGrid card pattern
   (green geeignet / bordeaux nicht-geeignet) but with paper-light
   backgrounds (the surrounding body is paper, not the dark homepage
   section). Stacks vertically; goes 2-up on wide screens. */
.v-dealdet-qualify { grid-template-columns: 1fr; gap: 18px; margin-top: 0; }
@media (min-width: 1280px) {
  .v-dealdet-qualify { grid-template-columns: 1fr 1fr; gap: 20px; }
}

/* Light-theme overrides for the qualify cards when used on the deal
   detail page (paper background context). */
.v-dealdet-qualify .v-qualify-card-yes {
  background: linear-gradient(165deg, rgba(78, 124, 96, 0.10) 0%, var(--v-paper) 70%);
  border: 1px solid rgba(110, 160, 130, 0.32);
}
.v-dealdet-qualify .v-qualify-card-no {
  background: linear-gradient(165deg, rgba(122, 31, 40, 0.10) 0%, var(--v-paper) 70%);
  border: 1px solid rgba(186, 60, 73, 0.30);
}
.v-dealdet-qualify .v-qualify-card-head { border-bottom-color: rgba(20, 18, 16, 0.08); }
.v-dealdet-qualify .v-qualify-card-yes .v-qualify-card-head { border-bottom-color: rgba(110, 160, 130, 0.20); }
.v-dealdet-qualify .v-qualify-card-no  .v-qualify-card-head { border-bottom-color: rgba(186, 60, 73, 0.20); }
.v-dealdet-qualify .v-qualify-card-title { color: var(--v-ink-soft); }
.v-dealdet-qualify .v-qualify-card-yes .v-qualify-card-tag { color: #4F7C60; }
.v-dealdet-qualify .v-qualify-card-no  .v-qualify-card-tag { color: var(--v-bordeaux); }
.v-dealdet-qualify .v-qualify-item { border-top-color: rgba(20, 18, 16, 0.06); }
.v-dealdet-qualify .v-qualify-item-yes .v-qualify-item-text { color: var(--v-ink-soft); }
.v-dealdet-qualify .v-qualify-item-no  .v-qualify-item-text { color: var(--v-ink-sub); }
.v-dealdet-qualify .v-qualify-item-yes .v-qualify-item-icon {
  background: rgba(110, 160, 130, 0.14);
  color: #4F7C60;
  border-color: rgba(110, 160, 130, 0.35);
}
.v-dealdet-qualify .v-qualify-item-no .v-qualify-item-icon {
  background: rgba(186, 60, 73, 0.10);
  color: var(--v-bordeaux);
  border-color: rgba(186, 60, 73, 0.30);
}

/* Section header small */
.v-dealdet-sec-h { font-family: var(--font-mono); font-size: 11px; letter-spacing: 3px; text-transform: uppercase; color: var(--v-ink-muted); margin: 0 0 28px; display: flex; align-items: center; gap: 14px; }
.v-dealdet-sec-h::before { content: ''; width: 32px; height: 1px; background: var(--v-bordeaux); }

/* Next / prev deals nav */
.v-dealdet-nextprev { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--v-border); border-bottom: 1px solid var(--v-border); }
.v-dealdet-nav { padding: 32px 48px; background: var(--v-paper); display: flex; flex-direction: column; gap: 6px; text-decoration: none; color: inherit; transition: background .15s; }
.v-dealdet-nav:hover { background: var(--v-paper-alt); }
.v-dealdet-nav.is-right { text-align: right; }
.v-dealdet-nav-dir { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--v-bordeaux); }
.v-dealdet-nav-t { font-family: var(--font-serif); font-size: 22px; font-style: italic; font-weight: 300; color: var(--v-ink-soft); letter-spacing: -0.005em; }
.v-dealdet-nav-sub { font-family: var(--font-mono); font-size: 10.5px; color: var(--v-ink-muted); }

/* Responsive */
@media (max-width: 1100px) {
  .v-deals-grid { grid-template-columns: repeat(2, 1fr); }
  /* Mobile: flatten the two columns + reorder so the user sees
     "Gelistet seit" → image → cashflow → KPIs → CTA → object info → narrative → highlights. */
  .v-dealdet-main {
    display: flex;
    flex-direction: column;
    grid-template-columns: 1fr;
    padding: calc(72px + 28px) 32px 40px;
    gap: 0;
    background: var(--v-paper-alt);
  }
  .v-dealdet-left, .v-dealdet-right { display: contents; }
  .v-dealdet-statuscard   { order: 1; margin-bottom: 16px; }
  .v-dealdet-gallery      { order: 2; margin-bottom: 16px; }
  .v-dealdet-gallery-grid { order: 3; margin-bottom: 32px; }
  .v-dealdet-cfcard       { order: 4; margin-bottom: 28px; }
  .v-dealdet-kpicard      { order: 5; }
  .v-dealdet-cta          { order: 6; margin-top: 24px; margin-bottom: 32px; }
  .v-dealdet-objectinfo   { order: 7; margin-top: 0; margin-bottom: 32px; }
  .v-dealdet-sec-h        { order: 8; }
  .v-dealdet-narrative    { order: 8; }
  .v-dealdet-highlights   { order: 9; grid-template-columns: 1fr; }
  .v-dealdet-headline { margin-bottom: 20px; }
  .v-deals-hero, .v-dealdet-hero { padding-left: 32px; padding-right: 32px; }
  .v-deals-hero { padding-top: calc(72px + 36px); padding-bottom: 36px; }
  .v-dealdet-hero { padding-top: calc(72px + 28px); padding-bottom: 24px; }
  .v-deals-body { padding-left: 32px; padding-right: 32px; }
  .v-dealdet-head { grid-template-columns: 1fr; gap: 18px; align-items: stretch; }
  .v-dealdet-head-l { gap: 12px; }
  .v-dealdet-expose-btn { justify-self: stretch; padding: 14px 20px; text-align: center; }
  .v-dealdet-nextprev { grid-template-columns: 1fr; }
  .v-dealdet-nav.is-right { text-align: left; }
  .v-dealdet-objectinfo { grid-template-columns: 1fr; gap: 0; padding: 18px 0; margin-bottom: 32px; }
  .v-dealdet-cfcard { padding: 22px 22px 22px; }
  .v-dealdet-cfcard-v { font-size: 48px; }
}
@media (max-width: 700px) {
  .v-deals-grid { grid-template-columns: 1fr; }
  .v-deals-counts { flex-direction: column; gap: 20px; }
  .v-deal-card-kpis { grid-template-columns: 1fr; }
  .v-deal-card-boxes { grid-template-columns: 1fr; gap: 10px; }
  .v-deal-box.is-cf { padding: 18px; }
}
@media (max-width: 640px) {
  .v-dealdet-hero { padding-left: 22px; padding-right: 22px; padding-top: calc(60px + 22px); padding-bottom: 18px; }
  .v-dealdet-breadcrumb { font-size: 9.5px; margin-bottom: 14px; }
  .v-dealdet-title { font-size: 24px; }
  .v-dealdet-main { padding-left: 22px; padding-right: 22px; padding-top: calc(60px + 22px); padding-bottom: 32px; }
  .v-dealdet-cfcard { padding: 20px 20px; margin-bottom: 22px; }
  .v-dealdet-cfcard-v { font-size: 42px; }
  .v-dealdet-cfcard-l { font-size: 11px; margin-bottom: 10px; }
  .v-dealdet-kpicard-h { padding: 14px 18px; font-size: 11px; }
  .v-dealdet-row { padding: 13px 18px; }
  .v-dealdet-row-l { font-size: 11.5px; }
  .v-dealdet-row-v { font-size: 17px; }
  .v-dealdet-row.is-hi .v-dealdet-row-v { font-size: 21px; }
  .v-dealdet-objectinfo-row { padding: 6px 0; }
  .v-dealdet-objectinfo-v { font-size: 14px; }
  .v-dealdet-narrative { font-size: 16px; }
  .v-dealdet-narrative::first-letter { font-size: 48px; padding: 4px 8px 0 0; }
  .v-dealdet-sec-h { font-size: 10px; margin-bottom: 18px; }
  .v-dealdet-gallery { aspect-ratio: 4 / 3; }
  .v-dealdet-gallery-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; margin-bottom: 32px; }
  .v-dealdet-cta { padding: 24px 22px; }
  .v-dealdet-cta h3 { font-size: 22px; }
  .v-dealdet-nav { padding: 22px 24px; }
  .v-dealdet-nav-t { font-size: 19px; }
}

/* =========================================================================
   HOMEPAGE RESPONSIVE
   ========================================================================= */

/* TABLET — collapse two-column editorial layouts */
@media (max-width: 1100px) {
  /* Section scaffolding */
  .v-section { padding: 80px 40px; }
  .v-section-header { margin-bottom: 48px; }
  .v-h1 { font-size: 44px; }
  .v-h2 { font-size: 32px; }
  .v-h3 { font-size: 24px; }

  /* Masthead + Nav */
  .v-masthead { padding: 6px 32px; }
  .v-nav { padding: 0 32px; height: 72px; }
  .v-nav-links { gap: 26px; }
  .v-nav-links a { font-size: 13px; }

  /* Hero stacks */
  .v-hero { grid-template-columns: 1fr; }
  .v-hero-left { padding: 56px 40px; border-right: none; border-bottom: 1px solid var(--v-border); }
  .v-hero-right { border-left: none; }

  /* Stats bar — 2 columns */
  .v-stats-bar { grid-template-columns: 1fr 1fr; }
  .v-stats-bar::before { left: 40px; }
  .v-stat { padding: 32px 36px 28px; }
  .v-stat:nth-child(2) { border-right: none; }
  .v-stat:nth-child(1), .v-stat:nth-child(2) { border-bottom: 1px solid var(--v-border); }

  /* Problem grid — 1 col */
  .v-problem-grid { grid-template-columns: 1fr; }
  .v-problem-card { padding: 36px 32px 40px; }

  /* Pullquote stacks */
  .v-pullquote { grid-template-columns: 1fr; padding: 32px 40px; gap: 16px; }
  .v-pullquote-text { font-size: 24px; }

  /* Macro / DE-USA compare stacks */
  .v-macro-layout { grid-template-columns: 1fr; }
  .v-macro-col, .v-macro-col-dark { padding: 40px 36px; }
  .v-macro-stats { grid-template-columns: 1fr 1fr; }

  /* Markets strip — 1 col */
  .v-markets-strip { grid-template-columns: 1fr; }

  /* USA grid */
  .v-usa-grid { grid-template-columns: 1fr; }

  /* Cleveland stacks */
  .v-cleveland-layout { grid-template-columns: 1fr; gap: 40px; }

  /* Steps: number on top, "Was dabei passiert" becomes expandable dropdown */
  .v-step { grid-template-columns: 1fr; }
  .v-step-num { border-right: none; border-bottom: 1px solid var(--v-border); flex-direction: row; align-items: center; gap: 20px; padding: 24px 32px; }
  .v-step-num-i { font-size: 44px; }
  .v-step-content { border-right: none; padding: 32px; display: flex; flex-direction: column; }
  .v-step-detail { display: none; }
  .v-step-toggle { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-top: 22px; padding: 14px 18px; background: var(--v-paper-alt); border: 1px solid var(--v-border); width: 100%; cursor: pointer; font-family: var(--font-mono); font-size: 12px; letter-spacing: 2px; text-transform: uppercase; color: var(--v-ink-soft); transition: background .15s, border-color .15s; }
  .v-step-toggle:hover { background: var(--v-paper); border-color: var(--v-bordeaux); }
  .v-step-toggle-icon { font-size: 18px; line-height: 1; color: var(--v-bordeaux); width: 18px; text-align: center; }
  .v-step-mobile-detail { display: flex; flex-direction: column; gap: 10px; padding: 20px 18px 4px; background: var(--v-paper-alt); border-left: 1px solid var(--v-border); border-right: 1px solid var(--v-border); border-bottom: 1px solid var(--v-border); margin-top: -1px; }
  .v-step.is-open .v-step-toggle { background: var(--v-paper); border-color: var(--v-bordeaux); border-bottom-color: transparent; color: var(--v-ink-soft); }
  .v-step.is-open .v-step-mobile-detail { border-color: var(--v-bordeaux); padding-bottom: 18px; }

  /* Qualify grid stacks */
  .v-qualify-grid { grid-template-columns: 1fr; gap: 32px; }
  .v-qualify-col { padding: 0; }
  .v-qualify-div { display: none; }

  /* Team stacks */
  .v-team-layout { grid-template-columns: 1fr; gap: 40px; }

  /* FAQ — 1 col */
  .v-faq-list { grid-template-columns: 1fr; }

  /* CTA stacks */
  .v-cta { grid-template-columns: 1fr; gap: 40px; padding: 72px 40px; }
  .v-cta-right { align-items: flex-start; }
  .v-cta-note { text-align: left; }
  .v-cta.v-cta-centered { padding: 80px 40px; }

  /* Footer stacks */
  .v-footer { flex-direction: column; gap: 20px; align-items: flex-start; padding: 32px 40px; }
  .v-footer-links { flex-wrap: wrap; gap: 18px; }
}

/* MOBILE — compact single-column */
@media (max-width: 640px) {
  .v-section { padding: 56px 20px; }
  .v-section-header { margin-bottom: 32px; }
  .v-h1 { font-size: 34px; }
  .v-h2 { font-size: 26px; }
  .v-h3 { font-size: 20px; }
  .v-h-hero { font-size: 36px; }

  /* Masthead: hide login button, dateline only */
  .v-masthead { padding: 6px 20px; font-size: 10.5px; letter-spacing: 1px; }
  .v-masthead-login { display: none; }

  /* Nav: hide links, keep logo + CTA */
  .v-nav { padding: 0 20px; height: 60px; }
  .v-nav-logo { font-size: 16px; letter-spacing: 3px; }
  .v-nav-links { display: none; }
  .v-btn-nav { padding: 12px 18px; font-size: 12px; }

  /* Hero */
  .v-hero-left { padding: 40px 20px; }
  .v-hero-dateline { font-size: 10px; }
  .v-hero-sub { font-size: 14px; margin-bottom: 28px; }

  /* Hero thesis card — mobile tighter */
  .v-hero-thesis { padding: 32px 24px 28px; }
  .v-hero-thesis-headline { font-size: 30px; margin-bottom: 24px; }
  .v-hero-thesis-stat-val { font-size: 44px; }
  .v-hero-thesis-stat-val span { font-size: 20px; }
  .v-hero-panel { padding: 24px 24px 28px; }
  .v-hero-btns { flex-direction: column; align-items: stretch; gap: 10px; margin-bottom: 32px; }
  .v-hero-qs { grid-template-columns: 1fr; gap: 16px; padding-top: 24px; }
  .v-hero-q { padding: 0; border-right: none; border-bottom: 1px solid var(--v-border); padding-bottom: 16px; }
  .v-hero-q:last-child { border-bottom: none; padding-bottom: 0; }

  /* Stats bar stacks */
  .v-stats-bar { grid-template-columns: 1fr; }
  .v-stats-bar::before { left: 20px; }
  .v-stat { border-right: none; border-bottom: 1px solid var(--v-border); padding: 24px 24px 22px; }
  .v-stat:last-child { border-bottom: none; }

  /* Pullquote tighter */
  .v-pullquote { padding: 24px 20px; }
  .v-pullquote-text { font-size: 20px; }

  /* Macro cols tighter */
  .v-macro-col, .v-macro-col-dark { padding: 32px 24px; }
  .v-macro-stats { grid-template-columns: 1fr; }

  /* Compare charts — keep in layout but tighten */
  .v-compare-charts .v-chart-section { padding: 16px 16px 12px; }

  /* Problem/Team/Market card internal padding */
  .v-problem-card { padding: 28px 22px 32px; }
  .v-market { padding: 24px 22px 22px; }
  .v-market-img { margin: -24px -22px 20px; }

  /* Fallstudien-Bar — stack on mobile */
  .v-fsbar { padding: 32px 20px 32px; }
  .v-fsbar-top { grid-template-columns: 1fr; gap: 20px; }
  .v-fsbar-title { font-size: 22px; }
  .v-fsbar-cta { justify-content: center; padding: 16px 24px; }
  .v-fsbar-kpis { grid-template-columns: 1fr; padding-top: 0; border-top: none; }
  .v-fsbar-kpi { padding: 20px 0 !important; border-right: none !important; border-top: 1px solid #2A2420; }
  .v-fsbar-kpi::before { left: 0 !important; }
  .v-fsbar-kpi-val { font-size: 32px; }

  .v-team-card { padding: 22px 22px 20px; }
  .v-team-card-name { font-size: 24px; }

  /* USA + Cleveland tighter */
  .v-usa-item { padding: 32px 24px; grid-template-columns: 48px 1fr; gap: 18px; }
  .v-usa-num { font-size: 42px; }
  .v-usa-title { font-size: 18px; }
  .v-cleveland-head { padding: 20px 22px; }
  .v-cleveland-metric { padding: 12px 22px; }
  .v-cleveland-source { padding: 12px 22px; }
  .v-cleveland-drop { font-size: 48px; padding: 4px 10px 0 0; }

  /* Steps tighter */
  .v-step-num { padding: 18px 20px; gap: 14px; }
  .v-step-num-i { font-size: 36px; }
  .v-step-content { padding: 24px 20px; }
  .v-step-toggle { padding: 12px 14px; font-size: 11px; }
  .v-step-mobile-detail { padding: 16px 14px 4px; }

  /* FAQ tighter */
  .v-faq-q { font-size: 19px; padding: 20px 0; gap: 14px; }
  .v-faq-a { font-size: 13.5px; padding-bottom: 20px; }

  /* CTA tighter */
  .v-cta { padding: 56px 20px; gap: 32px; }
  .v-btn-cta { width: 100%; }
  .v-cta.v-cta-centered { padding: 64px 20px; }
  .v-cta-actions { flex-direction: column; width: 100%; gap: 10px; }
  .v-btn-cta-ghost { width: 100%; }

  /* Footer tighter */
  .v-footer { padding: 28px 20px; }
  .v-footer-links { gap: 14px 18px; }

  /* Legal modal — tighter on mobile */
  .v-legal-modal { padding: 44px 24px 36px; max-height: 90vh; }
  .v-legal-title { font-size: 32px; margin-bottom: 28px; }
  .v-legal-close { top: 12px; right: 12px; width: 30px; height: 30px; font-size: 20px; }

  /* Disclaimer */
  .v-disclaimer { padding: 16px 18px; font-size: 10.5px; }

  /* Compare bullets tighter */
  .v-compare-bullets li { font-size: 12px; padding: 12px 0 12px 20px; }

  /* Team caption */
  .v-team-caption { padding: 12px 14px; font-size: 15px; gap: 10px; flex-wrap: wrap; }
}

/* Prozess section — vergrößerte Schriftgrößen */
#prozess .v-h4 { font-size: 28px; line-height: 1.22; }
#prozess .v-body-sm { font-size: 16.5px; line-height: 1.7; }
#prozess .v-step-item { font-size: 15.5px; line-height: 1.6; }
#prozess .v-step-detail-label { font-size: 12px; letter-spacing: 2.2px; }
#prozess .v-step-num-label { font-size: 12px; letter-spacing: 2.2px; }
#prozess .v-step-num-i { font-size: 72px; }

@media (max-width: 900px) {
  #prozess .v-h4 { font-size: 24px; }
  #prozess .v-body-sm { font-size: 15.5px; }
  #prozess .v-step-item { font-size: 14.5px; }
  #prozess .v-step-num-i { font-size: 52px; }
}

@media (max-width: 560px) {
  #prozess .v-h4 { font-size: 21px; }
  #prozess .v-body-sm { font-size: 14.5px; }
  #prozess .v-step-item { font-size: 14px; }
  #prozess .v-step-num-i { font-size: 42px; }
}
