﻿:root {
  --logo-navy: #010230;
  --bg: #080e10;
  --bg-2: #0c1b24;
  --surface: #eff4fd;
  --surface-deep: #f8fafe;
  --surface-soft: #f2f7fb;
  --text: #001a40;
  --muted: rgba(0, 26, 64, 0.7);
  --muted-strong: rgba(0, 26, 64, 0.82);
  --line: rgba(0, 26, 64, 0.1);
  --accent: #010230;
  --accent-hover: #0a0a54;
  --gold: #c7a86b;
  --gold-deep: #9a7a40;
  --gold-label-size: 0.92rem;
  --gold-label-spacing: 0.26em;
  --gold-label-size-mobile: 0.82rem;
  --gold-label-spacing-mobile: 0.22em;
  --white: #fff;
  --nav-bg: #010230;
  --nav-bg-solid: #010230;
  --footer-bg: #ffffff;
  --container: min(1260px, calc(100vw - 34px));
  --radius-xl: 40px 0 40px 0;
  --radius-lg: 28px 0 28px 0;
  --shadow: 0 28px 60px rgba(0, 26, 64, 0.12);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 110px; }
body { margin: 0; font-family: 'Open Sans', 'Segoe UI', sans-serif; color: var(--text); background: var(--surface); }
a { color: inherit; text-decoration: none; }
img { display: block; width: 100%; }
button, input, textarea { font: inherit; }
:focus-visible { outline: 2px solid var(--gold); outline-offset: 2px; }
.skip-link { position: absolute; left: -9999px; top: auto; width: 1px; height: 1px; overflow: hidden; z-index: 100; padding: 12px 24px; background: var(--accent); color: #fff; font-family: 'Sora', sans-serif; font-size: 0.95rem; font-weight: 600; border-radius: 0 0 12px 12px; }
.skip-link:focus { position: fixed; left: 50%; top: 0; transform: translateX(-50%); width: auto; height: auto; overflow: visible; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; scroll-behavior: auto !important; } .reveal-on-scroll { opacity: 1 !important; transform: none !important; } }
.container { width: var(--container); margin: 0 auto; }
.narrow { max-width: 820px; }
.hero-shell { position: relative; min-height: 100vh; background: linear-gradient(180deg, rgba(1, 2, 48, 0.18), rgba(1, 2, 48, 0.12)), url('assets/hero-desktop.webp') center center / cover no-repeat; color: #fff; }
.page-top { position: relative; background: linear-gradient(180deg, rgba(8, 14, 16, 0.55), rgba(8, 14, 16, 0.8)), var(--hero-image, linear-gradient(180deg, #0a1620, #122838)); background-size: cover; background-position: center; color: #fff; }
.site-header { position: fixed; inset-inline: 0; top: 0; z-index: 20; padding-top: 0; background: linear-gradient(180deg, rgba(1, 2, 48, 0.92), rgba(1, 2, 48, 0.86)); border-bottom: 1px solid rgba(255, 255, 255, 0.08); box-shadow: 0 10px 26px rgba(1, 2, 48, 0.1); transition: background 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease, backdrop-filter 0.35s ease; }
@supports (backdrop-filter: blur(1px)) { .site-header { background: linear-gradient(180deg, rgba(1, 2, 48, 0.72), rgba(1, 2, 48, 0.42)); backdrop-filter: saturate(135%) blur(12px); } }
.site-header--solid .site-nav, .site-header--solid .brand, .site-header--solid .header-cta { background: transparent; backdrop-filter: none; }
.site-header.is-condensed { background: linear-gradient(180deg, rgba(1, 2, 48, 0.96), rgba(1, 2, 48, 0.9)); border-bottom-color: rgba(255, 255, 255, 0.12); box-shadow: 0 16px 36px rgba(1, 2, 48, 0.24); backdrop-filter: saturate(150%) blur(16px); }
.nav-row { position: relative; display: grid; grid-template-columns: 86px 1fr auto; align-items: center; gap: 22px; min-height: 88px; transition: min-height 0.24s ease, gap 0.24s ease; }
.site-header.is-condensed .nav-row { min-height: 70px; gap: 18px; }
.brand { width: 86px; background: transparent; transition: width 0.24s ease; }
.site-header.is-condensed .brand { width: 68px; }
.brand img { aspect-ratio: 1 / 1; object-fit: cover; }
.site-nav { display: flex; align-items: center; justify-content: flex-start; gap: 28px; min-height: 68px; padding: 0; background: transparent; transition: gap 0.24s ease, min-height 0.24s ease; }
.site-header.is-condensed .site-nav { gap: 22px; min-height: 56px; }
.site-nav a { color: #fff; font-family: 'Sora', sans-serif; font-size: 0.92rem; font-weight: 500; opacity: 0.88; transition: opacity 0.2s ease, color 0.2s ease, font-size 0.24s ease; }
.site-header.is-condensed .site-nav a { font-size: 0.88rem; }
.site-nav a.is-active, .site-nav a:hover { opacity: 1; color: #ffffff; }
.site-nav__mobile-cta { display: none; }
.header-cta, .cta-button, .footer-chip { display: inline-flex; align-items: center; justify-content: center; min-height: 52px; padding: 0 26px; border: 0; border-radius: 999px; background: var(--accent); color: #fff; font-family: 'Sora', sans-serif; font-size: 0.92rem; font-weight: 600; transition: transform 0.2s ease, background 0.2s ease, min-height 0.24s ease, padding 0.24s ease, font-size 0.24s ease; }
.header-cta:hover, .cta-button:hover, .footer-chip:hover { transform: translateY(-1px); background: var(--accent-hover); }
.header-cta:active, .cta-button:active, .footer-chip:active { transform: translateY(0); opacity: 0.9; }
.header-actions { display: flex; align-items: center; gap: 8px; }
.header-cta { padding: 0 24px; text-align: center; line-height: 1.15; }
.site-header.is-condensed .header-cta { min-height: 46px; padding: 0 22px; font-size: 0.88rem; }
.site-header .header-cta { background: rgba(255, 255, 255, 0.08); border: 1px solid rgba(255, 255, 255, 0.14); }
.site-header .header-cta:hover { background: rgba(255, 255, 255, 0.14); }
.header-whatsapp { display: inline-flex; align-items: center; justify-content: center; width: 44px; height: 44px; margin-left: 10px; border-radius: 50%; color: #fff; transition: background 0.2s ease, transform 0.2s ease; }
.header-whatsapp:hover { background: rgba(255, 255, 255, 0.12); transform: translateY(-1px); }
.header-whatsapp svg { display: block; }

/* Legal pages */
.legal-table { width: 100%; border-collapse: collapse; margin: 18px 0; }
.legal-table td { padding: 10px 14px; border: 1px solid var(--line); font-size: 0.95rem; line-height: 1.7; vertical-align: top; }
.legal-table tr:first-child td { font-weight: 600; background: var(--surface-soft); }
.prose-flow h2 + p, .prose-flow h3 + p { margin-top: 12px; }
.prose-flow ul { margin: 14px 0; padding-left: 24px; }
.prose-flow li { margin: 6px 0; color: var(--muted); font-size: 1rem; line-height: 1.9; }
.prose-flow hr { margin: 40px 0; border: 0; border-top: 1px solid var(--line); }

/* Blog post pages */
.blog-article { max-width: 780px; margin: 0 auto; }
.blog-article h2 { margin: 40px 0 16px; }
.blog-article h3 { margin: 30px 0 12px; font-family: 'Sora', sans-serif; font-size: 1.3rem; font-weight: 600; color: var(--text); }
.blog-article p { margin: 14px 0; }
.blog-article img { max-width: 100%; height: auto; border-radius: var(--radius-lg); margin: 24px 0; }
.blog-meta { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 28px; }
.blog-meta__date, .blog-meta__category { font-family: 'Sora', sans-serif; font-size: 0.82rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gold-deep); }
.blog-back { display: inline-flex; align-items: center; gap: 8px; margin-bottom: 28px; font-family: 'Sora', sans-serif; font-size: 0.88rem; font-weight: 600; color: var(--accent); }
.blog-back:hover { color: var(--accent-hover); }

/* Cookie consent */
.cc-banner { position: fixed; bottom: 0; left: 0; right: 0; z-index: 9999; padding: 20px; background: var(--nav-bg); color: #fff; border-top: 1px solid rgba(255,255,255,0.1); transform: translateY(100%); transition: transform 0.3s ease; max-height: 90vh; overflow-y: auto; }
.cc-banner.is-visible { transform: translateY(0); }
.cc-banner__inner { max-width: 1120px; margin: 0 auto; }
.cc-banner__text { font-size: 0.92rem; line-height: 1.6; color: rgba(255,255,255,0.84); margin-bottom: 16px; }
.cc-banner__text a { color: var(--gold); text-decoration: underline; }
.cc-banner__actions { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.cc-btn { padding: 10px 22px; border: 0; border-radius: 999px; font-family: 'Sora', sans-serif; font-size: 0.88rem; font-weight: 600; cursor: pointer; transition: background 0.2s; }
.cc-btn--accept { background: var(--gold); color: var(--logo-navy); }
.cc-btn--accept:hover { background: #d4b87a; }
.cc-btn--reject { background: rgba(255,255,255,0.16); color: #fff; border: 1px solid rgba(255,255,255,0.3); font-size: 0.88rem; }
.cc-btn--reject:hover { background: rgba(255,255,255,0.26); }
.cc-btn--settings { background: transparent; color: rgba(255,255,255,0.7); text-decoration: underline; border: 0; padding: 10px 12px; }
.cc-btn--small { padding: 8px 18px; font-size: 0.82rem; }
.cc-settings { margin-top: 18px; padding-top: 18px; border-top: 1px solid rgba(255,255,255,0.1); }
.cc-category { padding: 12px 0; border-bottom: 1px solid rgba(255,255,255,0.06); }
.cc-category:last-of-type { border-bottom: 0; }
.cc-category__label { display: flex; align-items: center; gap: 10px; cursor: pointer; }
.cc-category__label input[type="checkbox"] { width: 18px; height: 18px; accent-color: var(--gold); }
.cc-category__label strong { font-family: 'Sora', sans-serif; font-size: 0.95rem; }
.cc-category__badge { font-size: 0.72rem; padding: 2px 8px; border-radius: 999px; background: rgba(199,168,107,0.2); color: var(--gold); font-weight: 600; letter-spacing: 0.04em; }
.cc-category p { margin: 6px 0 0 28px; font-size: 0.84rem; color: rgba(255,255,255,0.6); line-height: 1.5; }
.cc-settings__actions { padding-top: 14px; }
.cc-blocked-overlay { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; background: var(--surface-deep); border-radius: var(--radius-lg); z-index: 10; }
.cc-blocked-content { text-align: center; padding: 28px; max-width: 400px; }
.cc-blocked-content p { margin: 6px 0; color: var(--muted); font-size: 0.92rem; line-height: 1.6; }
.cc-blocked-content strong { color: var(--text); }

/* Form status messages */
.form-status { margin-top: 16px; padding: 14px 18px; border-radius: 12px; font-size: 0.92rem; line-height: 1.5; }
.form-status--success { background: #e8f5e9; color: #2e7d32; border: 1px solid #a5d6a7; }
.form-status--error { background: #fce4ec; color: #c62828; border: 1px solid #ef9a9a; }

/* Bezirk pages */
.bezirk-hero-meta { margin-top: 12px; font-size: 0.95rem; color: rgba(255,255,255,0.7); }
.cta-button--dark { background: #071214; }
.cta-button--dark:hover { background: #13242b; }
.nav-toggle { display: none; position: absolute; top: 26px; right: 18px; z-index: 6; border: 0; background: transparent; padding: 0; }
.nav-toggle span { display: block; width: 24px; height: 2px; margin: 5px 0; background: #fff; }
.nav-toggle span { transition: transform 0.22s ease, opacity 0.22s ease; transform-origin: center; }
.nav-toggle.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle.is-open span:nth-child(2) { transform: translateY(-7px) rotate(-45deg); }
.hero-overlay, .page-hero__overlay { position: absolute; inset: 0; background: radial-gradient(circle at center center, rgba(1, 2, 48, 0.22) 0%, rgba(1, 2, 48, 0.48) 100%), linear-gradient(180deg, rgba(8, 14, 16, 0.28) 0%, rgba(8, 14, 16, 0.92) 100%); }
.hero-content, .page-hero__inner { position: relative; z-index: 3; }
.hero-content { display: flex; align-items: center; justify-content: center; min-height: calc(100vh - 90px); padding: 160px 20px 120px; text-align: center; }
.hero-copy { max-width: 920px; }
.hero-logo { width: 12vw; min-width: 130px; max-width: 180px; margin: 0 auto 42px; border-radius: 10px; }
.hero-copy h1, .page-hero h1, .text-block h2, .cta-copy h2, .section-heading h2, .prose-panel h2, .contact-card h2, .news-card h2 { font-family: 'Sora', sans-serif; }
.hero-copy h1 { margin: 0; padding: 18px 0; background: transparent; color: #fff; font-size: clamp(3rem, 5.7vw, 5.7rem); font-weight: 700; line-height: 1.2; text-shadow: 28px 5px 40px rgba(45, 44, 44, 0.64); text-align: center; }
.hero-fade { position: absolute; inset-inline: 0; bottom: 0; height: 180px; background: linear-gradient(180deg, rgba(239, 244, 253, 0) 0%, rgba(239, 244, 253, 0.98) 92%); }
.page-hero { position: relative; min-height: 280px; display: flex; align-items: flex-end; }
.page-hero__inner { padding: 100px 0 48px; }
.blog-post-page .page-hero { min-height: 220px; }
.blog-post-page .page-hero h1 { font-size: clamp(1.8rem, 3.2vw, 2.8rem); line-height: 1.18; letter-spacing: -0.02em; }
.eyebrow { display: inline-block; margin-bottom: 18px; color: rgba(255, 255, 255, 0.78); font-family: 'Sora', sans-serif; font-size: 0.76rem; font-weight: 600; letter-spacing: 0.22em; text-transform: uppercase; }
.page-hero .eyebrow { font-size: 0.88rem; letter-spacing: 0.24em; }
.eyebrow--dark, .service-body span, .contact-card__label, .news-meta { font-family: 'Sora', sans-serif; font-size: var(--gold-label-size); letter-spacing: var(--gold-label-spacing); }
.eyebrow--dark { color: var(--gold); }
.eyebrow--featured { margin-bottom: 22px; }
.page-hero h1 { max-width: 820px; margin: 0; font-size: clamp(2.2rem, 4.4vw, 4.2rem); line-height: 1.14; }
.page-hero p { max-width: 820px; margin: 20px 0 0; color: rgba(255, 255, 255, 0.84); font-size: 1.14rem; line-height: 1.85; }
.section { padding: 84px 0 0; }
.section--tight { padding-top: 56px; }
.logo-ticker-section { padding-top: 0; }
.social-section--compact { padding-top: 72px; }
.ticker-shell { overflow: hidden; }
.ticker-track { display: flex; width: max-content; animation: ticker 42s linear infinite; gap: 90px; }
.ticker-group { display: flex; align-items: center; gap: 90px; }
.ticker-logo { display: grid; place-items: center; width: 164px; height: 72px; padding: 10px 14px; flex: 0 0 auto; }
.ticker-group img { width: 100%; height: 100%; object-fit: contain; object-position: center; }
@keyframes ticker { from { transform: translateX(0); } to { transform: translateX(calc(-50% - 45px)); } }
.text-block h2, .cta-copy h2, .section-heading h2, .prose-panel h2, .news-card h2 { margin: 0; color: var(--text); font-size: 2rem; font-weight: 600; line-height: 1.15; letter-spacing: -0.02em; }
.text-block, .prose-panel--center { text-align: center; }
.text-block p, .prose-panel p, .feature-card p, .news-card p, .contact-card p, .service-body--detail p, .cta-panel p, .mini-card p, .list-check li { color: var(--muted); font-size: 1rem; line-height: 1.9; }
.text-block p, .prose-panel p { margin: 28px 0 0; }
.prose-flow { text-align: left; }
.prose-flow h2 { margin: 0; color: var(--text); font-family: 'Sora', sans-serif; font-size: 2rem; font-weight: 600; line-height: 1.3; }
.prose-flow p { margin: 24px 0 0; color: var(--muted); font-size: 1rem; line-height: 1.9; }
.prose-flow .button-row { margin-top: 30px; }
.lead { margin-top: 0; text-align: center; }
.membership-logos { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; margin: 20px auto 0; max-width: 700px; align-items: center; }
.membership-logos img { width: auto; max-width: 100%; max-height: 98px; object-fit: contain; margin: 0 auto; }
.feature-grid, .card-grid, .contact-grid, .news-grid { display: grid; gap: 28px; }
.feature-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 60px; margin-top: 20px; padding: 0 20px; }
.feature-item { text-align: left; }
.feature-icon { margin-bottom: 20px; color: var(--text); font-size: 32px; }
.feature-item h3, .feature-card h3, .person-card h3, .service-body h3, .stat-card strong, .contact-card__label, .mini-card h3 { font-family: 'Sora', sans-serif; }
.feature-item h3 { margin: 0; color: var(--text); font-size: 19px; font-weight: 500; line-height: 1.4; }
.feature-grid--cards { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 28px; margin-top: 34px; padding: 0; }
.feature-card--home { display: grid; align-content: start; gap: 14px; padding: 30px 32px; border: 1px solid rgba(199, 168, 107, 0.18); background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(242, 247, 251, 0.98)); transition: transform 0.2s ease, box-shadow 0.2s ease; }
.feature-card--home:hover { transform: translateY(-4px); box-shadow: 0 18px 40px rgba(0, 26, 64, 0.1); }
.feature-card--home h3 { margin: 0; color: var(--text); font-size: 1.4rem; line-height: 1.28; }
.feature-card--home p { margin: 0; color: var(--muted); line-height: 1.8; }
.feature-icon--home { display: inline-grid; place-items: center; width: 54px; height: 54px; margin-bottom: 2px; border-radius: 16px 0 16px 0; background: linear-gradient(135deg, rgba(199, 168, 107, 0.16), rgba(154, 122, 64, 0.12)); color: var(--gold-deep); }
.feature-icon--home svg { width: 25px; height: 25px; fill: currentColor; }
.service-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 48px; margin-top: 20px; }
.service-grid--detail { margin-top: 0; }
.service-card a { display: block; }
.service-card img { width: 100%; margin: 0 auto 20px; aspect-ratio: 1 / 1; object-fit: cover; border-radius: var(--radius-xl); box-shadow: var(--shadow); }
.service-body { text-align: center; }
.service-body h3 { margin: 0; color: var(--text); font-size: 22px; font-weight: 500; line-height: 1.35; }
.service-body span { display: inline-flex; align-items: center; gap: 6px; margin-top: 20px; color: var(--gold); font-weight: 700; text-transform: uppercase; transition: gap 0.2s ease; }
.service-body span::after { content: '\2192'; transition: transform 0.2s ease; }
.service-card:hover .service-body span::after { transform: translateX(4px); }
.service-card--detail a {
  display: grid;
  grid-template-rows: auto 1fr;
  height: 100%;
  padding: 20px;
  border: 1px solid rgba(0, 26, 64, 0.05);
  border-radius: var(--radius-xl);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 254, 0.98));
  box-shadow: var(--shadow);
}
.service-card--detail img {
  margin-bottom: 22px;
  box-shadow: none;
}
.service-card--detail .service-body { display: grid; grid-template-rows: minmax(3.8rem, auto) 1fr auto; align-content: start; gap: 14px; padding: 0 8px 6px; text-align: left; }
.service-body--detail p { margin: 0; text-align: left; }
.service-card--detail .service-body span { margin-top: 0; }
.cta-section { padding-top: 60px; }
.cta-card, .search-callout, .calculator-card, .quote-card, .form-shell, .prose-panel, .contact-card, .feature-card, .person-card, .mini-card, .news-card, .cta-panel, .panel { border: 1px solid rgba(0, 26, 64, 0.05); border-radius: var(--radius-xl); background: var(--surface-deep); box-shadow: var(--shadow); }
.cta-card { display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 40px; padding: 64px 52px; background: #eef4f7; border-color: rgba(0, 26, 64, 0.08); }
.cta-card--gold, .cta-card--teal { background: #eef4f7; border-color: rgba(0, 26, 64, 0.08); }
.cta-copy p { margin: 0 0 10px; color: var(--muted); font-size: 1.35rem; font-weight: 600; }
.cta-copy h2 { font-size: 2.15rem; }
.section-heading { margin-bottom: 28px; text-align: center; }
.section-heading--left { text-align: left; }
.section-heading p { max-width: 720px; margin: 16px auto 0; }
.section-heading--left p { margin-left: 0; }
.split-layout { display: grid; grid-template-columns: minmax(0, 1fr) minmax(320px, 430px); gap: 32px; align-items: start; }
.split-layout--reverse { grid-template-columns: minmax(320px, 430px) minmax(0, 1fr); }
.split-layout--media { grid-template-columns: minmax(320px, 1.02fr) minmax(0, 0.98fr); }
.split-layout--centered { align-items: center; }
.split-layout--form { grid-template-columns: minmax(0, 0.95fr) minmax(340px, 0.95fr); }
.panel, .prose-panel, .contact-card, .feature-card, .news-card, .mini-card, .form-shell, .cta-panel, .calculator-card, .quote-card, .search-callout { padding: 30px; }
.prose-panel--tall { padding: 38px; }
.prose-panel--soft { background: var(--surface-soft); }
.stats-grid { display: grid; gap: 20px; }
.stat-card { display: grid; gap: 6px; padding: 28px 30px; border-radius: var(--radius-lg); background: linear-gradient(135deg, rgba(199, 168, 107, 0.08), rgba(154, 122, 64, 0.12)); border: 1px solid rgba(199, 168, 107, 0.24); }
.stat-card strong { font-size: 2.4rem; font-weight: 600; }
.stat-card span { color: var(--muted); font-size: 0.98rem; line-height: 1.7; }
.image-pair { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 28px; }
.image-pair img, .media-card { border-radius: var(--radius-xl); object-fit: cover; min-height: 100%; box-shadow: var(--shadow); }
.value-list, .list-panel { display: grid; gap: 24px; }
.card-grid--2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.card-grid--3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.feature-card--large { padding: 34px; }
.button-row { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 26px; }
.button-row--center { justify-content: center; }
.button-row .cta-button { min-height: 48px; }
.mini-card { min-height: 120px; display: flex; align-items: center; }
.mini-card h3 { margin: 0; font-size: 1.05rem; line-height: 1.6; }
.team-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 28px; }
.team-grid--compact { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.people-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 22px; align-items: stretch; }
.person-card { overflow: hidden; padding: 0; }
.person-card img { aspect-ratio: 4 / 5; object-fit: cover; object-position: center top; }
.person-card__image--klajd { object-position: center 16%; transform: scale(0.92); transform-origin: center center; background: rgba(239, 244, 253, 0.9); }
.person-card__body { padding: 28px; }
.person-card__body p { margin: 14px 0 0; }
.person-card h3 { margin: 0; font-size: 1.35rem; }
.person-card--compact { display: flex; flex-direction: column; height: 100%; padding: 22px; border: 1px solid rgba(0, 26, 64, 0.08); border-radius: 26px 0 26px 0; background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(242, 247, 251, 0.94)); box-shadow: var(--shadow); }
.person-card--compact img, .person-card__avatar { width: 100%; max-width: 128px; aspect-ratio: 1 / 1; margin: 0 auto 20px; border-radius: 22px 0 22px 0; object-fit: cover; box-shadow: 0 18px 38px rgba(0, 26, 64, 0.12); }
.person-card__avatar { display: grid; place-items: center; background: linear-gradient(135deg, rgba(1, 2, 48, 0.96), rgba(10, 10, 84, 0.88)); color: #fff; font-family: 'Sora', sans-serif; font-size: 1.5rem; font-weight: 600; letter-spacing: 0.08em; }
.person-card--compact .person-card__body { display: grid; grid-template-rows: minmax(2.8rem, auto) minmax(3.3rem, auto) 1fr; flex: 1; padding: 0; text-align: center; }
.person-card--compact .contact-card__label { display: flex; align-items: flex-start; justify-content: center; margin-bottom: 0; font-size: 0.72rem; letter-spacing: 0.14em; line-height: 1.35; text-align: center; }
.person-card--compact h3 { display: flex; align-items: flex-start; justify-content: center; font-size: 1.15rem; line-height: 1.35; text-wrap: balance; }
.person-card--compact p { margin-top: 0; font-size: 0.96rem; line-height: 1.75; }
.contact-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.contact-card { display: grid; grid-template-rows: auto minmax(64px, auto) 1fr; align-content: start; }
.contact-card__label { display: inline-block; margin-bottom: 14px; color: var(--gold); font-weight: 700; text-transform: uppercase; }
.contact-card h2 { margin: 0; font-size: clamp(1.45rem, 1.85vw, 1.78rem); line-height: 1.3; }
.contact-card h2 a { color: inherit; }
.contact-card__link { display: inline-block; }
.contact-card__link--email { white-space: nowrap; font-size: clamp(1.12rem, 1.55vw, 1.42rem); letter-spacing: -0.01em; }
.contact-card p { margin: 12px 0 0; }
.contact-card__address { margin-top: 6px; }
.contact-note { margin: 14px 0 0; color: var(--muted-strong); font-size: 0.92rem; line-height: 1.7; }
.form-shell { background: #fff; }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; }
.form-grid__full { grid-column: 1 / -1; }
.form-shell label { display: grid; gap: 8px; }
.form-shell span { color: var(--muted-strong); font-size: 0.95rem; }
.form-shell input, .form-shell textarea { width: 100%; padding: 14px 16px; border: 1px solid rgba(0, 26, 64, 0.12); border-radius: 16px; background: #f8fbff; color: var(--text); transition: border-color 0.2s ease, box-shadow 0.2s ease; }
.form-shell input:focus, .form-shell textarea:focus { outline: none; border-color: var(--gold); box-shadow: 0 0 0 3px rgba(199, 168, 107, 0.18); }
.checkbox-row { display: flex !important; align-items: flex-start; gap: 12px; margin-top: 18px; }
.checkbox-row input { width: 18px; height: 18px; margin-top: 4px; }
.form-button { margin-top: 22px; }
.table-wrap { overflow-x: auto; }
.content-switcher { display: grid; gap: 18px; }
.content-switcher__tabs { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; }
.content-switcher__tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 22px;
  border: 1px solid rgba(0, 26, 64, 0.1);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  color: var(--muted-strong);
  font-family: 'Sora', sans-serif;
  font-size: 0.92rem;
  font-weight: 600;
  line-height: 1.2;
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}
.content-switcher__tab:hover {
  transform: translateY(-1px);
  border-color: rgba(199, 168, 107, 0.34);
  color: var(--text);
}
.content-switcher__tab.is-active {
  border-color: rgba(1, 2, 48, 0.92);
  background: linear-gradient(180deg, rgba(1, 2, 48, 0.98), rgba(10, 10, 84, 0.94));
  color: #fff;
  box-shadow: 0 16px 30px rgba(1, 2, 48, 0.14);
}
.content-switcher__panel { padding: 34px; }
.content-switcher__panel[hidden] { display: none; }
.content-switcher__panel h3 { margin: 0 0 18px; }
.content-switcher__panel p + p { margin-top: 16px; }
.service-table { width: 100%; border-collapse: collapse; font-size: 0.94rem; }
.service-table th, .service-table td { padding: 14px 12px; border-bottom: 1px solid rgba(0, 26, 64, 0.1); text-align: left; vertical-align: top; }
.service-table th { color: var(--text); font-family: 'Sora', sans-serif; font-size: 0.9rem; }
.service-table td { color: var(--muted); line-height: 1.75; }
.service-table th:first-child, .service-table td:first-child { min-width: 144px; }
.service-table td:first-child { color: var(--text); font-weight: 600; }
.list-check { margin: 0; padding-left: 1.2rem; }
.list-check li { margin: 10px 0; }
.search-callout { display: grid; grid-template-columns: 1fr auto; gap: 24px; align-items: center; background: linear-gradient(135deg, rgba(199, 168, 107, 0.08), rgba(154, 122, 64, 0.12)); border-color: rgba(199, 168, 107, 0.24); }
.search-callout h2 { margin: 12px 0 0; font-size: 1.7rem; }
.search-callout p { margin: 12px 0 0; color: var(--muted); line-height: 1.85; }
.detail-grid { display: grid; gap: 24px; }
.detail-grid--3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.detail-card { padding: 30px; border: 1px solid rgba(199, 168, 107, 0.22); border-radius: var(--radius-lg); background: linear-gradient(180deg, #ffffff, var(--surface-deep)); box-shadow: var(--shadow); }
.detail-card h3 { margin: 0 0 14px; color: var(--text); font-family: 'Sora', sans-serif; font-size: 1.18rem; line-height: 1.45; }
.detail-card p { margin: 0; color: var(--muted); line-height: 1.85; }
.page--vires .page-hero__overlay { background: linear-gradient(180deg, rgba(1, 2, 48, 0.24) 0%, rgba(1, 2, 48, 0.56) 52%, rgba(8, 14, 16, 0.92) 100%); }
.page--vires .page-hero h1 { max-width: 760px; }
.page--vires .prose-panel .eyebrow--dark { display: inline-flex; align-items: center; gap: 12px; }
.page--vires .prose-panel .eyebrow--dark::after { content: ""; width: 72px; height: 1px; background: linear-gradient(90deg, rgba(199, 168, 107, 0.9), rgba(199, 168, 107, 0)); }
.page--vires-intro { align-items: center; }
.page--vires-intro > * { min-width: 0; }
.page--vires-intro .prose-panel { display: grid; gap: 0; }
.page--vires-intro .prose-panel h2 { overflow-wrap: anywhere; hyphens: auto; }
.page--vires-intro .prose-panel p { margin-top: 22px; max-width: 62ch; }
.page--vires-intro .button-row { margin-top: 30px; }
.page--vires-intro__media { align-self: stretch; }
.page--vires-intro__image { height: 100%; min-height: 560px; object-position: center center; }
.principles-grid { margin-top: 10px; }
.principle-card { position: relative; display: grid; align-content: start; grid-template-rows: auto minmax(3.5rem, auto) minmax(9.6rem, auto) 1fr; row-gap: 12px; overflow: hidden; padding: 34px; border: 1px solid rgba(199, 168, 107, 0.22); border-radius: var(--radius-xl); background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(242, 247, 251, 0.98)); box-shadow: var(--shadow); }
.principle-card::before { content: ""; position: absolute; top: -30px; right: -30px; width: 140px; height: 140px; border-radius: 50%; background: radial-gradient(circle, rgba(199, 168, 107, 0.18) 0%, rgba(199, 168, 107, 0) 72%); pointer-events: none; }
.principle-card__index { display: inline-flex; align-items: center; justify-content: center; min-width: 56px; min-height: 34px; padding: 0 14px; border-radius: 999px; background: rgba(199, 168, 107, 0.14); color: var(--gold-deep); font-family: 'Sora', sans-serif; font-size: 0.78rem; font-weight: 700; letter-spacing: 0.24em; text-transform: uppercase; }
.principle-card h3 { margin: 0; color: var(--text); font-family: 'Sora', sans-serif; font-size: 1.45rem; line-height: 1.3; }
.principle-card p { margin: 0; color: var(--muted); line-height: 1.76; }
.principle-list { display: grid; gap: 8px; margin: 2px 0 0; padding: 0; list-style: none; }
.principle-list li { position: relative; padding-left: 18px; color: var(--muted-strong); font-size: 0.96rem; line-height: 1.62; }
.principle-list li::before { content: ""; position: absolute; left: 0; top: 0.62rem; width: 8px; height: 8px; border-radius: 50%; background: var(--gold); box-shadow: 0 0 0 6px rgba(199, 168, 107, 0.12); }
.milestone-timeline { position: relative; display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 26px; margin-top: 36px; padding-top: 0; }
.milestone-timeline::before { content: ""; position: absolute; top: 7px; left: 0; right: -68px; height: 2px; background: linear-gradient(90deg, rgba(0, 26, 64, 0.26), rgba(0, 26, 64, 0.08)); }
.milestone-entry { position: relative; margin: 0; }
.milestone-entry summary { position: relative; display: grid; justify-items: center; gap: 8px; padding-top: 22px; cursor: default; list-style: none; text-align: center; }
.milestone-entry summary::-webkit-details-marker { display: none; }
.milestone-entry summary::before { content: ""; position: absolute; top: 0; left: 50%; width: 12px; height: 12px; border-radius: 50%; background: var(--surface); border: 2px solid rgba(1, 2, 48, 0.9); transform: translateX(-50%); }
.milestone-entry__year { display: block; color: rgba(0, 26, 64, 0.62); font-family: 'Sora', sans-serif; font-size: 0.8rem; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; transition: color 0.24s ease; }
.milestone-entry__title { display: block; max-width: 220px; margin-inline: auto; color: rgba(0, 26, 64, 0.46); font-family: 'Sora', sans-serif; font-size: 1.05rem; font-weight: 600; line-height: 1.45; transition: color 0.24s ease; }
.milestone-entry__body { max-width: 220px; margin: 10px auto 0; padding-top: 0; color: rgba(0, 26, 64, 0.34); line-height: 1.8; text-align: center; opacity: 0.42; transform: translateY(4px); transition: opacity 0.24s ease, transform 0.24s ease, color 0.24s ease; }
.milestone-entry__body p { margin: 0; }
.milestone-entry:hover .milestone-entry__year, .milestone-entry:focus-within .milestone-entry__year, .milestone-entry[open] .milestone-entry__year { color: var(--gold-deep); }
.milestone-entry:hover .milestone-entry__title, .milestone-entry:focus-within .milestone-entry__title, .milestone-entry[open] .milestone-entry__title { color: var(--text); }
.milestone-entry:hover .milestone-entry__body, .milestone-entry:focus-within .milestone-entry__body, .milestone-entry[open] .milestone-entry__body { color: var(--muted); opacity: 1; transform: translateY(0); }
.career-media-card { display: grid; align-self: center; gap: 0; padding: 18px; border: 1px solid rgba(0, 26, 64, 0.06); border-radius: var(--radius-xl); background: linear-gradient(180deg, rgba(255, 255, 255, 0.84), rgba(242, 247, 251, 0.9)); box-shadow: var(--shadow); }
.career-media-card__image { min-height: 100%; }
.cta-panel--career { display: grid; gap: 18px; }
.cta-panel--career .section-heading { margin-bottom: 0; }
.career-list { display: grid; gap: 14px; margin-top: 4px; }
.career-list__item { position: relative; padding-left: 26px; }
.career-list__item::before { content: ""; position: absolute; left: 0; top: 0.58rem; width: 10px; height: 10px; border-radius: 50%; background: var(--gold); box-shadow: 0 0 0 7px rgba(199, 168, 107, 0.12); }
.career-list__item h3 { margin: 0; color: var(--text); font-family: 'Sora', sans-serif; font-size: 1.02rem; line-height: 1.45; }
.career-list__item p { margin: 6px 0 0; color: var(--muted); line-height: 1.75; }
.page--team .cta-panel { align-self: center; }
.page--team .split-layout--centered .media-card { align-self: center; }
.prose-panel--statement { background: linear-gradient(135deg, rgba(199, 168, 107, 0.12), rgba(154, 122, 64, 0.08)); border-color: rgba(199, 168, 107, 0.22); }
.media-card--feature { width: 100%; min-height: 420px; object-position: center center; }
.media-card--tall { min-height: 420px; }
.quote-card { text-align: center; }
.quote-card blockquote { margin: 0; color: var(--text); font-family: 'Sora', sans-serif; font-size: 1.7rem; font-weight: 600; line-height: 1.5; }
.quote-card p { margin: 14px 0 0; color: var(--muted); }
.calculator-output { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 22px; margin: 8px 0 26px; }
.calculator-output span { display: block; margin-bottom: 10px; color: var(--muted); font-size: 0.9rem; letter-spacing: 0.08em; text-transform: uppercase; }
.calculator-output strong { font-family: 'Sora', sans-serif; font-size: 2rem; line-height: 1.2; }
.range-input { width: 100%; appearance: none; height: 4px; border-radius: 999px; background: rgba(0, 26, 64, 0.18); outline: none; }
.range-input::-webkit-slider-thumb { appearance: none; width: 22px; height: 22px; border-radius: 50%; background: #071214; cursor: pointer; }
.range-input::-moz-range-thumb { width: 22px; height: 22px; border: 0; border-radius: 50%; background: #071214; cursor: pointer; }
.news-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.news-heading { max-width: 920px; margin: 0 auto 34px; }
.news-heading p { max-width: 860px; }
.news-grid--archive { grid-template-columns: repeat(3, minmax(0, 1fr)); align-items: stretch; }
.news-card--archive-item { display: grid; grid-template-rows: auto 1fr; height: 100%; padding: 0; overflow: hidden; }
.news-card__image-link { display: block; background: rgba(0, 26, 64, 0.06); }
.news-card__image { aspect-ratio: 16 / 10; object-fit: cover; object-position: center; }
.news-card__body { display: grid; grid-template-rows: minmax(3.2rem, auto) minmax(7rem, auto) 1fr auto; gap: 14px; padding: 24px 24px 26px; }
.news-card h2 { margin: 0; font-size: 1.34rem; line-height: 1.38; }
.news-card h2 a { color: inherit; }
.news-card p { margin: 0; }
.news-meta { display: flex; flex-wrap: wrap; gap: 0.34rem; align-items: center; color: var(--gold); font-family: 'Sora', sans-serif; font-weight: 700; line-height: 1.6; text-transform: uppercase; }
.news-card__link { display: inline-flex; align-items: center; gap: 6px; margin-top: 2px; color: var(--accent); font-family: 'Sora', sans-serif; font-size: 0.88rem; font-weight: 600; transition: gap 0.2s ease; }
.news-card__link::after { content: '\2192'; transition: transform 0.2s ease; }
.news-card__link:hover { color: var(--accent-hover); }
.news-card__link:hover::after { transform: translateX(4px); }
.news-pagination { display: flex; justify-content: center; gap: 10px; margin-top: 34px; }
.news-pagination__link { display: inline-flex; align-items: center; justify-content: center; min-width: 44px; min-height: 44px; padding: 0 16px; border: 1px solid rgba(0, 26, 64, 0.1); border-radius: 999px; background: rgba(255, 255, 255, 0.9); color: var(--muted-strong); font-family: 'Sora', sans-serif; font-size: 0.92rem; font-weight: 600; transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.2s ease; }
.news-pagination__link:hover { transform: translateY(-1px); border-color: rgba(1, 2, 48, 0.18); color: var(--text); }
.news-pagination__link.is-active { border-color: rgba(1, 2, 48, 0.9); background: var(--accent); color: #fff; }
.valuation-hero { background: linear-gradient(180deg, rgba(1, 2, 48, 0.56), rgba(8, 14, 16, 0.82)), url('assets/bewertung-hero-live.webp') center center / cover no-repeat; }
.valuation-page .page-hero__overlay { background: linear-gradient(180deg, rgba(1, 2, 48, 0.18), rgba(8, 14, 16, 0.76)); }
.valuation-hero-actions { margin-top: 30px; }
.valuation-hero-actions .cta-button {
  min-width: 240px;
  box-shadow: 0 18px 34px rgba(1, 2, 48, 0.22);
}
.valuation-hero-actions .cta-button--dark {
  background: linear-gradient(135deg, rgba(199, 168, 107, 0.98), rgba(154, 122, 64, 0.94));
  border: 1px solid rgba(255, 255, 255, 0.22);
  color: var(--logo-navy);
}
.valuation-hero-actions .cta-button--dark:hover {
  background: linear-gradient(135deg, rgba(214, 185, 123, 0.98), rgba(173, 139, 75, 0.94));
  color: var(--logo-navy);
}
.valuation-ghost-button {
  background: rgba(1, 2, 48, 0.32);
  border: 1px solid rgba(255, 255, 255, 0.28);
  color: #fff;
  backdrop-filter: blur(10px);
}
.valuation-ghost-button:hover {
  background: rgba(1, 2, 48, 0.46);
  border-color: rgba(255, 255, 255, 0.42);
}
.valuation-intro p { max-width: 74ch; margin-inline: auto; }
.valuation-intro a { color: var(--accent); text-decoration: underline; text-underline-offset: 0.16em; }
.valuation-page .cta-button { text-decoration: none; }
.valuation-intro-highlights { margin-top: 30px; }
.valuation-intro-highlights .mini-card {
  min-height: 148px;
  justify-content: center;
  padding: 28px 24px;
  text-align: center;
}
.valuation-intro-actions { margin-top: 28px; }
.valuation-intro-actions .cta-button,
.valuation-video-actions .cta-button,
.valuation-question-actions .cta-button,
.valuation-process-actions .cta-button,
.valuation-testimonial-card__body .cta-button {
  min-width: 320px;
  color: #fff;
  text-decoration: none;
  box-shadow: 0 16px 30px rgba(1, 2, 48, 0.14);
}
.valuation-embed {
  padding: 34px;
  border: 1px solid rgba(0, 26, 64, 0.05);
  border-radius: var(--radius-xl);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(248, 250, 254, 0.98));
  box-shadow: var(--shadow);
}
.valuation-embed__frame {
  overflow: hidden;
  border: 1px solid rgba(0, 26, 64, 0.06);
  border-radius: 28px 0 28px 0;
  background: #fff;
}
.valuation-embed__frame iframe {
  display: block;
  width: 100%;
  min-height: 740px;
  border: 0;
}
.valuation-embed__note {
  max-width: 74ch;
  margin: 18px auto 0;
  color: var(--muted);
  font-size: 0.96rem;
  line-height: 1.85;
  text-align: center;
}
.valuation-video-card {
  display: grid;
  gap: 22px;
  padding: 30px;
  border: 1px solid rgba(0, 26, 64, 0.05);
  border-radius: var(--radius-xl);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(242, 247, 251, 0.96));
  box-shadow: var(--shadow);
}
.valuation-video-card--wide { gap: 26px; }
.valuation-video-card__poster {
  position: relative;
  display: block;
  padding: 0;
  border: 0;
  background: none;
  cursor: pointer;
}
.valuation-video-card__poster::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: var(--radius-xl);
  background: linear-gradient(180deg, rgba(1, 2, 48, 0.08), rgba(1, 2, 48, 0.28));
}
.valuation-video-card__poster img,
.valuation-video-card__embed iframe {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  border: 0;
  border-radius: var(--radius-xl);
  object-fit: cover;
  box-shadow: var(--shadow);
}
.valuation-video-card__play {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 2;
  width: 84px;
  height: 84px;
  border-radius: 50%;
  background: rgba(1, 2, 48, 0.9);
  box-shadow: 0 16px 30px rgba(1, 2, 48, 0.24);
  transform: translate(-50%, -50%);
}
.valuation-video-card__play::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 54%;
  border-top: 13px solid transparent;
  border-bottom: 13px solid transparent;
  border-left: 20px solid #fff;
  transform: translate(-50%, -50%);
}
.valuation-video-card__play--static { pointer-events: none; }
.valuation-video-card__body { text-align: center; }
.valuation-video-card__body h2 { margin: 0; color: var(--text); font-family: 'Sora', sans-serif; font-size: 1.9rem; line-height: 1.3; }
.valuation-video-card__body p { margin: 16px 0 0; color: var(--muted); line-height: 1.85; }
.valuation-video-card__note {
  margin: -4px 0 0;
  color: var(--muted);
  font-size: 0.94rem;
  line-height: 1.75;
  text-align: center;
}
.valuation-video-actions,
.valuation-process-actions { margin-top: 28px; }
.valuation-question-section { padding-top: 52px; }
.valuation-headline-mark {
  position: relative;
  display: inline-block;
  color: rgba(0, 26, 64, 0.34);
}
.valuation-headline-mark::after {
  content: "";
  position: absolute;
  left: 2%;
  right: 2%;
  bottom: -6px;
  height: 10px;
  background:
    radial-gradient(circle at 10% 60%, rgba(154, 122, 64, 0.92) 0 18%, transparent 19%) 0 100% / 14px 10px repeat-x,
    linear-gradient(90deg, rgba(154, 122, 64, 0.95), rgba(199, 168, 107, 0.92));
  border-radius: 999px;
  opacity: 0.92;
}
.valuation-question-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-top: 34px;
}
.valuation-question-card {
  display: grid;
  align-content: start;
  gap: 18px;
  min-height: 100%;
  padding: 28px 26px;
  border: 1px solid rgba(0, 26, 64, 0.08);
  border-radius: 24px 0 24px 0;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(242, 247, 251, 0.96));
  box-shadow: 0 12px 28px rgba(1, 2, 48, 0.08);
  text-align: center;
}
.valuation-question-card h3 {
  margin: 0;
  color: var(--text);
  font-family: 'Sora', sans-serif;
  font-size: 1.22rem;
  font-weight: 500;
  line-height: 1.52;
}
.valuation-question-card p {
  margin: 0;
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.8;
}
.valuation-question-actions {
  margin-top: 28px;
}
.reveal-on-scroll {
  opacity: 0;
  transform: translateY(26px);
  transition: opacity 0.55s ease, transform 0.55s ease;
  transition-delay: var(--reveal-delay, 0ms);
}
.reveal-on-scroll.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.valuation-process-section {
  padding-top: 64px;
}
.valuation-process-heading {
  margin-bottom: 34px;
}
.valuation-phase-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}
.valuation-phase-card {
  display: grid;
  grid-template-rows: auto auto 1fr;
  justify-items: center;
  gap: 18px;
  min-height: 100%;
  padding: 30px 28px;
  border: 1px solid rgba(0, 26, 64, 0.08);
  border-radius: 28px 0 28px 0;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(242, 247, 251, 0.96));
  box-shadow: 0 14px 30px rgba(1, 2, 48, 0.08);
  text-align: center;
}
.valuation-phase-card__icon {
  display: grid;
  place-items: center;
  width: 68px;
  height: 68px;
  border-radius: 18px 0 18px 0;
  background: linear-gradient(135deg, rgba(199, 168, 107, 0.18), rgba(154, 122, 64, 0.1));
  color: var(--text);
}
.valuation-phase-card__icon svg {
  width: 30px;
  height: 30px;
  fill: currentColor;
}
.valuation-phase-card h3 {
  margin: 0;
  color: var(--text);
  font-family: 'Sora', sans-serif;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.2;
}
.valuation-phase-card ol {
  display: grid;
  gap: 14px;
  width: 100%;
  margin: 0;
  padding: 0;
  list-style: none;
  counter-reset: phase-step;
  text-align: left;
}
.valuation-phase-card li {
  position: relative;
  min-height: 72px;
  padding: 14px 0 0 56px;
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.7;
}
.valuation-phase-card li::before {
  counter-increment: phase-step;
  content: counter(phase-step);
  position: absolute;
  left: 0;
  top: 6px;
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 999px;
  background: rgba(1, 2, 48, 0.94);
  color: #fff;
  font-family: 'Sora', sans-serif;
  font-size: 0.9rem;
  font-weight: 700;
}
.valuation-benefits {
  display: grid;
  gap: 22px;
  margin-top: 38px;
  padding: 38px 42px;
  border: 1px solid rgba(0, 26, 64, 0.07);
  border-radius: 28px 0 28px 0;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(242, 247, 251, 0.94));
  box-shadow: 0 14px 30px rgba(1, 2, 48, 0.06);
}
.valuation-benefits h2 {
  margin: 0;
  color: var(--text);
  font-family: 'Sora', sans-serif;
  font-size: 2rem;
  line-height: 1.2;
  text-align: center;
}
.valuation-benefits__list {
  display: grid;
  gap: 16px;
  max-width: 920px;
  margin: 0 auto;
  padding: 0;
  list-style: none;
}
.valuation-benefits__list li {
  position: relative;
  padding-left: 42px;
  color: var(--muted);
  font-size: 1.03rem;
  line-height: 1.8;
}
.valuation-benefits__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.48em;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background:
    radial-gradient(circle at center, #fff 0 19%, transparent 20%),
    linear-gradient(135deg, rgba(1, 2, 48, 0.98), rgba(10, 10, 84, 0.92));
  box-shadow: 0 8px 16px rgba(1, 2, 48, 0.12);
}
.valuation-benefits__list li::after {
  content: "";
  position: absolute;
  left: 7px;
  top: 0.86em;
  width: 8px;
  height: 4px;
  border-left: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(-45deg);
}
.valuation-testimonial-section { padding-top: 60px; }
.valuation-testimonial-card {
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(320px, 0.82fr);
  gap: 28px;
  align-items: center;
  padding: 30px;
  border: 1px solid rgba(0, 26, 64, 0.05);
  border-radius: var(--radius-xl);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(242, 247, 251, 0.96));
  box-shadow: var(--shadow);
}
.valuation-testimonial-card__media {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-xl);
}
.valuation-testimonial-card__media img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  object-position: center;
}
.valuation-testimonial-card__body {
  display: grid;
  gap: 16px;
  align-content: center;
}
.valuation-testimonial-card__body h3 {
  margin: 0;
  color: var(--text);
  font-family: 'Sora', sans-serif;
  font-size: 1.8rem;
  line-height: 1.22;
}
.valuation-testimonial-card__body p {
  margin: 0;
  color: var(--muted);
  line-height: 1.85;
}
.valuation-form-section { padding-top: 64px; }
.social-row { display: flex; justify-content: center; gap: 14px; }
.social-row a { display: grid; place-items: center; width: 44px; height: 44px; border: 1px solid rgba(1, 2, 48, 0.12); border-radius: 50%; background: linear-gradient(180deg, rgba(1, 2, 48, 0.98), rgba(10, 10, 84, 0.92)); color: #fff; box-shadow: 0 12px 24px rgba(1, 2, 48, 0.14); transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease; }
.social-row a:hover { transform: translateY(-1px); box-shadow: 0 16px 28px rgba(1, 2, 48, 0.18); background: linear-gradient(180deg, rgba(10, 10, 84, 0.98), rgba(1, 2, 48, 0.92)); }
.social-row svg { width: 19px; height: 19px; fill: currentColor; }
.site-footer { margin-top: 72px; padding: 64px 0 22px; background: var(--footer-bg); border-top: 1px solid rgba(0, 26, 64, 0.08); }
.footer-grid { display: grid; grid-template-columns: minmax(320px, 1.25fr) minmax(180px, 0.78fr) minmax(180px, 0.78fr); gap: 64px; align-items: start; }
.footer-col { display: grid; align-content: start; }
.footer-col h3 { margin: 2px 0 20px; color: var(--text); font-family: 'Sora', sans-serif; font-size: 13px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.22em; }
.footer-logo { width: 74px; margin-bottom: 8px; }
.footer-brand-col p, .footer-nav a, .footer-bottom, .footer-bottom a { color: var(--muted-strong); font-size: 14px; line-height: 1.85; }
.footer-brand-col { display: grid; gap: 18px; }
.footer-intro { display: grid; gap: 8px; max-width: 370px; }
.footer-intro strong { color: var(--text); font-family: 'Sora', sans-serif; font-size: 1.05rem; font-weight: 600; line-height: 1.35; }
.footer-brand-col p.footer-hours { margin: 0; max-width: 355px; font-size: 0.98rem; line-height: 1.7; }
.footer-actions { display: flex; flex-wrap: wrap; align-items: center; gap: 14px 18px; padding-top: 2px; }
.footer-phone { display: inline-flex; color: var(--text); font-family: 'Sora', sans-serif; font-size: 2.05rem; font-weight: 600; line-height: 1; letter-spacing: -0.02em; transition: color 0.2s ease; }
.footer-phone:hover { color: var(--accent); }
.footer-chip { min-height: 42px; padding: 0 18px; margin-top: 0; font-size: 0.88rem; }
.footer-badges { display: flex; flex-wrap: wrap; gap: 18px; align-items: center; max-width: 460px; padding-top: 8px; }
.footer-badge { display: block; padding: 0; border: 0; background: none; box-shadow: none; }
.footer-badge img { display: block; max-width: none; height: 52px; width: auto; object-fit: contain; object-position: left center; }
.footer-nav { display: grid; gap: 8px; }
.footer-bottom { display: flex; justify-content: space-between; gap: 20px; margin-top: 30px; padding-top: 16px; border-top: 1px solid var(--line); }
.footer-bottom div { display: flex; gap: 18px; }
@media (max-width: 1100px) { .feature-grid, .service-grid, .footer-grid, .contact-grid, .news-grid, .card-grid--3, .team-grid, .team-grid--compact, .split-layout, .split-layout--reverse, .split-layout--media, .split-layout--form, .cta-card, .search-callout, .detail-grid--3 { grid-template-columns: 1fr; } .feature-grid--cards { grid-template-columns: repeat(2, minmax(0, 1fr)); } .stats-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } .image-pair { grid-template-columns: 1fr; } .principles-grid { grid-template-columns: 1fr; } .people-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } .news-grid--archive { grid-template-columns: repeat(2, minmax(0, 1fr)); } .news-card__body { grid-template-rows: minmax(3.4rem, auto) minmax(6.2rem, auto) 1fr auto; } .milestone-timeline { grid-template-columns: 1fr; gap: 18px; padding: 0 0 28px 34px; } .milestone-timeline::before { top: 0; bottom: 0; left: 5px; right: auto; width: 1px; height: auto; background: linear-gradient(180deg, rgba(0, 26, 64, 0.24), rgba(0, 26, 64, 0.08)); } .milestone-entry summary { justify-items: start; gap: 6px; padding: 0 0 0 24px; cursor: pointer; text-align: left; } .milestone-entry summary::before { top: 4px; left: -29px; width: 10px; height: 10px; transform: translateX(-50%); } .milestone-entry__title, .milestone-entry__body { max-width: none; margin-inline: 0; text-align: left; } .milestone-entry__body { display: none; padding-top: 6px; opacity: 1; transform: none; } .milestone-entry[open] .milestone-entry__body { display: block; } .valuation-question-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } .valuation-phase-grid, .valuation-testimonial-card { grid-template-columns: 1fr; } }
@media (max-width: 900px) { .site-header, .site-header.is-condensed { background: rgba(1, 2, 48, 0.98); border-bottom-color: rgba(255, 255, 255, 0.08); box-shadow: 0 14px 32px rgba(1, 2, 48, 0.24); backdrop-filter: blur(14px) saturate(140%); } .nav-row { grid-template-columns: 72px 1fr; min-height: 76px; gap: 12px; } .site-header.is-condensed .nav-row { min-height: 76px; gap: 12px; } .brand { width: 72px; } .site-header.is-condensed .brand { width: 72px; } .nav-toggle { display: inline-block; top: 50%; right: 0; transform: translateY(-50%); width: 46px; height: 46px; border-radius: 14px; background: rgba(255, 255, 255, 0.08); } .nav-toggle span { margin-inline: auto; } .site-nav { position: absolute; top: calc(100% + 12px); left: 0; right: 0; display: none; flex-direction: column; align-items: stretch; gap: 8px; min-height: auto; padding: 18px; border-radius: 24px 0 24px 0; background: #010230; border: 1px solid rgba(255, 255, 255, 0.1); box-shadow: 0 24px 48px rgba(1, 2, 48, 0.34); opacity: 1; backdrop-filter: none; } .site-header--solid .site-nav { background: #010230; border: 1px solid rgba(255, 255, 255, 0.1); box-shadow: 0 24px 48px rgba(1, 2, 48, 0.34); backdrop-filter: none; } .site-nav a { display: flex; align-items: center; width: 100%; min-height: 50px; padding: 0 16px; border-radius: 14px 0 14px 0; font-size: 0.98rem; opacity: 1; color: #fff; background: rgba(255, 255, 255, 0.03); } .site-nav a.is-active { background: rgba(255, 255, 255, 0.12); font-weight: 700; } .site-nav a.is-active::before { content: ""; width: 8px; height: 8px; margin-right: 10px; border-radius: 50%; background: var(--gold); box-shadow: 0 0 0 4px rgba(199, 168, 107, 0.16); } .site-nav a:hover { background: rgba(255, 255, 255, 0.1); } .site-nav a.site-nav__mobile-cta { display: inline-flex; justify-content: center; margin-top: 10px; min-height: 54px; border-radius: 999px; background: linear-gradient(135deg, rgba(199, 168, 107, 0.98), rgba(154, 122, 64, 0.94)) !important; color: var(--logo-navy) !important; font-weight: 700; opacity: 1 !important; box-shadow: 0 14px 28px rgba(1, 2, 48, 0.18); } .site-nav a.site-nav__mobile-cta::before { display: none; } .site-nav a.site-nav__mobile-cta:hover { background: linear-gradient(135deg, rgba(214, 185, 123, 0.98), rgba(173, 139, 75, 0.94)) !important; } .site-nav.is-open { display: flex; } .header-actions { display: none; } .hero-logo { width: 28vw; min-width: 140px; } .hero-copy h1 { font-size: 8.5vw; padding-inline: 0; } .page-hero__inner { padding: 118px 0 54px; } .stats-grid { grid-template-columns: 1fr; } .form-grid, .calculator-output, .card-grid--2 { grid-template-columns: 1fr; } }
@media (max-width: 767px) { .section { padding-top: 68px; } .hero-shell { min-height: 100svh; background: linear-gradient(180deg, rgba(1, 2, 48, 0.18), rgba(1, 2, 48, 0.12)), url('assets/hero-mobile.webp') center 35% / 120% auto no-repeat; } .hero-content { min-height: calc(100svh - 72px); padding: 190px 20px 26px; } .hero-logo { width: 46vw; margin-bottom: 0; } .hero-copy h1 { margin-top: 40px; margin-bottom: 40px; line-height: 1.3; } .ticker-group, .ticker-track { gap: 26px; } .ticker-logo { width: 128px; height: 52px; padding: 6px 10px; } .membership-logos, .feature-grid, .service-grid, .footer-grid, .contact-grid, .news-grid, .card-grid--3, .team-grid, .team-grid--compact, .people-grid, .feature-grid--cards, .valuation-question-grid { grid-template-columns: 1fr; } .feature-grid, .service-grid { gap: 30px; } .membership-logos img { max-height: 84px; } .cta-card, .panel, .prose-panel, .contact-card, .feature-card, .news-card, .mini-card, .calculator-card, .quote-card, .form-shell, .search-callout, .cta-panel, .principle-card, .content-switcher__panel, .valuation-embed, .valuation-video-card, .valuation-question-card, .valuation-phase-card, .valuation-benefits, .valuation-testimonial-card { padding: 24px; border-radius: 20px 0 20px 0; } .feature-card--home { gap: 12px; padding: 24px; } .feature-card--home h3 { font-size: 1.24rem; } .page--vires-intro { gap: 24px; } .page--vires-intro .prose-panel { padding: 28px 24px; } .page--vires-intro .prose-panel h2 { font-size: 1.9rem; line-height: 1.2; } .page--vires-intro .prose-panel p { margin-top: 18px; } .page--vires-intro .button-row { margin-top: 24px; } .page--vires-intro__image { min-height: 320px; object-position: center center; } .news-card--archive-item { padding: 0; } .news-card__body { grid-template-rows: auto auto 1fr auto; padding: 22px 22px 24px; } .news-pagination { gap: 8px; } .news-pagination__link { min-width: 40px; min-height: 40px; padding: 0 14px; } .career-media-card { padding: 16px; border-radius: 20px 0 20px 0; } .faq-answer { padding: 0 24px 24px; } .service-card img, .image-pair img, .media-card, .person-card--compact img, .person-card__avatar, .valuation-video-card__poster img, .valuation-video-card__embed iframe, .valuation-testimonial-card__media, .valuation-testimonial-card__media img { border-radius: 20px 0 20px 0; } .text-block h2, .cta-copy h2, .section-heading h2, .prose-panel h2, .news-card h2, .contact-card h2, .valuation-video-card__body h2, .valuation-benefits h2, .valuation-testimonial-card__body h3 { font-size: 1.55rem; } .page-hero .eyebrow { font-size: 0.8rem; letter-spacing: 0.2em; } .page-hero h1 { font-size: 2.08rem; } .page-hero p, .text-block p, .prose-panel p, .feature-card p, .news-card p, .contact-card p, .faq-answer, .principle-card p, .career-list__item p, .valuation-video-card__body p, .valuation-embed__note, .valuation-question-card p, .valuation-benefits__list li, .valuation-phase-card li, .valuation-testimonial-card__body p { font-size: 1rem; } .footer-actions, .footer-bottom { flex-direction: column; align-items: flex-start; } .footer-phone { font-size: 1.6rem; } .footer-badges { gap: 16px; } .footer-badge img { height: 44px; } .eyebrow--dark, .service-body span, .contact-card__label, .news-meta { font-size: var(--gold-label-size-mobile); letter-spacing: var(--gold-label-spacing-mobile); } .principle-card { grid-template-rows: auto auto auto auto; row-gap: 16px; } .principle-card h3, .milestone-entry__title, .valuation-question-card h3 { font-size: 1.18rem; } .valuation-phase-card h3 { font-size: 1.5rem; } .valuation-phase-card li { min-height: auto; padding-top: 10px; } .valuation-benefits { gap: 18px; } .valuation-benefits__list li { padding-left: 36px; } .milestone-entry__year { font-size: 0.72rem; letter-spacing: 0.16em; } .person-card--compact { padding: 20px; } .person-card--compact img, .person-card__avatar { max-width: 108px; margin-bottom: 16px; } .person-card--compact .person-card__body { grid-template-rows: auto auto auto; } .content-switcher__tabs { flex-direction: column; } .content-switcher__tab { width: 100%; } .service-table, .service-table tbody, .service-table tr, .service-table td { display: block; width: 100%; } .service-table thead { display: none; } .service-table tr { padding: 18px 0; border-bottom: 1px solid rgba(0, 26, 64, 0.1); } .service-table tr:first-child { padding-top: 0; } .service-table td { padding: 0; border-bottom: 0; } .service-table td:first-child { margin-bottom: 12px; font-family: 'Sora', sans-serif; font-size: 0.94rem; } .service-table td[data-label] { display: grid; gap: 4px; margin-top: 12px; } .service-table td[data-label]::before { content: attr(data-label); color: var(--gold-deep); font-family: 'Sora', sans-serif; font-size: 0.75rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; } .valuation-hero-actions, .valuation-video-actions, .valuation-process-actions { flex-direction: column; align-items: stretch; } .valuation-hero-actions .cta-button, .valuation-video-actions .cta-button, .valuation-process-actions .cta-button, .valuation-testimonial-card__body .cta-button, .valuation-question-actions .cta-button { width: 100%; min-width: 0; } .valuation-embed__frame iframe { min-height: 680px; } .valuation-video-card__play { width: 68px; height: 68px; } .valuation-video-card__play::before { border-top-width: 11px; border-bottom-width: 11px; border-left-width: 18px; } .valuation-headline-mark::after { bottom: -5px; height: 8px; } }
