/* International Relations scoped styles from the provided CSS. */
.vzirb-scope {
/* Home-page brand tokens */
      --color-primary: #3A3F5C;
      --color-primary-dark: #2a2e44;
      --color-secondary: #B8A1B0;
      --color-accent: #C8B27D;
      --color-accent-dark: #b09a63;
      --color-accent-readable: #7B6428;
      --color-bg: #F8F6F4;
      --color-bg-warm: #F2EDEA;
      --color-text: #5F6472;
      --color-text-dark: #2E3144;
      --color-text-light: #707584;
      --color-white: #ffffff;
      --color-border: #e2dcd8;
      --color-border-light: #ede9e6;

      /* International Relations page aliases — preserve current UI sizing/layout */
      --color-primary-deep: #2B2F42;
      --color-accent-soft: #EFE6D0;
      --color-surface: var(--color-white);
      --color-text-strong: var(--color-text-dark);
      --color-line: rgba(58, 63, 92, 0.16);
      --color-line-soft: rgba(184, 161, 176, 0.30);

      /* Backwards-compatible --clr-* mapping to the home --color-* system */
      --clr-primary: var(--color-primary);
      --clr-primary-dark: var(--color-primary-dark);
      --clr-primary-deep: var(--color-primary-deep);
      --clr-secondary: var(--color-secondary);
      --clr-accent: var(--color-accent);
      --clr-accent-dark: var(--color-accent-dark);
      --clr-accent-readable: var(--color-accent-readable);
      --clr-bg: var(--color-bg);
      --clr-surface: var(--color-surface);
      --clr-text: var(--color-text);
      --clr-text-strong: var(--color-text-strong);

      --shadow-soft: 0 16px 50px rgba(58, 63, 92, 0.10);
      --shadow-strong: 0 28px 88px rgba(43, 47, 66, 0.22);
      --font-display: "Playfair Display", Georgia, serif;
      --font-heading: var(--font-display);
      --font-body: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
      --container: min(1140px, calc(100% - 2rem));
      --radius-sm: 8px;
      --radius-md: 18px;
      --radius-lg: 30px;
      --radius-xl: 44px;
      --transition: 240ms ease;
}

.vzirb-scope *,
.vzirb-scope *::before,
.vzirb-scope *::after {
box-sizing: border-box;
}

.vzirb-scope svg {
display: block; max-width: 100%;
}

.vzirb-scope.container,
.vzirb-scope .container {
width: var(--container);
      margin-inline: auto;
}

.vzirb-scope.eyebrow,
.vzirb-scope .eyebrow {
display: inline-flex;
      align-items: center;
      gap: 0.65rem;
      width: fit-content;
      color: var(--color-accent-readable);
      font-size: 0.72rem;
      font-weight: 800;
      letter-spacing: 0.17em;
      line-height: 1.35;
      text-transform: uppercase;
}

.vzirb-scope.eyebrow::before,
.vzirb-scope .eyebrow::before,
.vzirb-scope.eyebrow::after,
.vzirb-scope .eyebrow::after {
content: none !important;
      display: none !important;
}

.vzirb-scope.eyebrow--light,
.vzirb-scope .eyebrow--light {
color: var(--color-accent);
}

.vzirb-scope h1, .vzirb-scope h2, .vzirb-scope h3 {
  margin: 0;
  color: var(--color-primary);
  font-family: var(--font-heading);
  font-weight: 600;
  line-height: 1.1;
  text-wrap: balance;
  word-break: break-word;
  overflow-wrap: break-word;
  max-width: 100%;
}

.vzirb-scope p {
margin: 0; text-wrap: pretty;
}

.vzirb-scope.hero,
.vzirb-scope .hero {
position: relative;
      isolation: isolate;
      padding: clamp(4.1rem, 5.6vw, 6rem) 0 clamp(4rem, 5.6vw, 6rem);
      background: var(--color-primary);
      color: rgba(255, 255, 255, 0.86);
}

.vzirb-scope.hero::before,
.vzirb-scope .hero::before {
content: "";
      position: absolute;
      inset: 0;
      z-index: -2;
      background:
        linear-gradient(90deg, rgba(43, 47, 66, 0.99) 0%, rgba(58, 63, 92, 0.92) 49%, rgba(58, 63, 92, 0.58) 100%),
        var(--vzirb-hero-bg, url("https://rechtsanwalt-berlin-charlottenburg.de/wp-content/uploads/rechtsanwalt-lawyer-berlin-Miami-USAflag-pixabay.-e1553520239877.jpg")) center / cover no-repeat;
}

.vzirb-scope.hero::after,
.vzirb-scope .hero::after {
content: "";
      position: absolute;
      inset: 0;
      z-index: -1;
      background:
        linear-gradient(135deg, rgba(200, 178, 125, 0.10) 0 1px, transparent 1px 42px),
        radial-gradient(circle at 14% 20%, rgba(200, 178, 125, 0.20), transparent 22rem);
      opacity: 0.82;
      pointer-events: none;
}

.vzirb-scope.hero-grid,
.vzirb-scope .hero-grid {
display: grid;
      grid-template-columns: minmax(0, 1.03fr) minmax(320px, 0.72fr);
      gap: clamp(2rem, 5vw, 5.5rem);
      align-items: center;
}

.vzirb-scope.hero-copy,
.vzirb-scope .hero-copy {
display: grid;
      gap: 1.22rem;
      max-width: 780px;
}

.vzirb-scope.hero h1,
.vzirb-scope .hero h1 {
max-width: 10.5ch;
      color: var(--color-surface);
      font-size: clamp(3rem, 5.4vw, 5.8rem);
      letter-spacing: -0.045em;
}

.vzirb-scope.hero h1 span,
.vzirb-scope .hero h1 span {
display: block;
      color: var(--color-accent);
      font-size: 0.62em;
      font-style: italic;
      font-weight: 500;
      letter-spacing: -0.025em;
}

.vzirb-scope.hero-lede,
.vzirb-scope .hero-lede {
max-width: 680px;
      color: rgba(255, 255, 255, 0.88);
      font-size: clamp(1rem, 1.3vw, 1.12rem);
}

.vzirb-scope.hero-note,
.vzirb-scope .hero-note {
display: grid;
      grid-template-columns: 3px minmax(0, 1fr);
      gap: 1rem;
      max-width: 675px;
      margin-top: 0.45rem;
      padding: 1rem 0 0;
}

.vzirb-scope.hero-note::before,
.vzirb-scope .hero-note::before {
content: "";
      width: 3px;
      border-radius: 999px;
      background: linear-gradient(to bottom, var(--color-accent), var(--color-secondary));
}

.vzirb-scope.hero-note p,
.vzirb-scope .hero-note p {
color: rgba(255, 255, 255, 0.78);
      font-size: 0.95rem;
}

.vzirb-scope.portrait-panel,
.vzirb-scope .portrait-panel {
position: relative;
      overflow: hidden;
      border: 1px solid rgba(255, 255, 255, 0.20);
      border-radius: var(--radius-xl);
      background: rgba(255, 255, 255, 0.08);
      box-shadow: 0 30px 90px rgba(0, 0, 0, 0.28);
      backdrop-filter: blur(8px);
}

.vzirb-scope.portrait-panel::before,
.vzirb-scope .portrait-panel::before {
content: "";
      position: absolute;
      top: 1rem;
      right: 1rem;
      z-index: 2;
      width: 88px;
      height: 88px;
      border-top: 1px solid rgba(200, 178, 125, 0.82);
      border-right: 1px solid rgba(200, 178, 125, 0.82);
      border-radius: 0 22px 0 0;
      pointer-events: none;
}

.vzirb-scope.portrait-panel img,
.vzirb-scope .portrait-panel img {
width: 100%;
      min-height: 344px;
      aspect-ratio: 0.86 / 1;
      object-fit: cover;
      object-position: center top;
      filter: saturate(0.88) contrast(1.02);
}

.vzirb-scope.portrait-caption,
.vzirb-scope .portrait-caption {
display: grid;
      gap: 0.35rem;
      padding: 1.25rem 1.35rem 1.35rem;
      background: linear-gradient(180deg, rgba(43, 47, 66, 0.98), rgba(58, 63, 92, 0.98));
}

.vzirb-scope.portrait-caption strong,
.vzirb-scope .portrait-caption strong {
color: var(--color-surface);
      font-family: var(--font-heading);
      font-size: 1.35rem;
      font-weight: 600;
      line-height: 1.2;
}

.vzirb-scope.portrait-caption span,
.vzirb-scope .portrait-caption span {
color: rgba(255, 255, 255, 0.77);
      font-size: 0.88rem;
      line-height: 1.55;
}

.vzirb-scope.editorial-strip,
.vzirb-scope .editorial-strip {
padding: clamp(3.6rem, 6vw, 5.9rem) 0;
      background: var(--color-surface);
      border-bottom: 1px solid var(--color-line-soft);
}

.vzirb-scope.editorial-inner,
.vzirb-scope .editorial-inner {
position: relative;
      display: grid;
      grid-template-columns: 4px minmax(0, 1fr);
      gap: clamp(1.25rem, 4vw, 3.35rem);
      align-items: center;
      max-width: 990px;
      margin-inline: auto;
      padding: clamp(1.55rem, 3.3vw, 2.45rem);
      overflow: hidden;
      border: 1px solid var(--color-line-soft);
      border-radius: var(--radius-xl);
      background:
        linear-gradient(135deg, rgba(248, 246, 244, 0.96), rgba(255, 255, 255, 0.98)),
        radial-gradient(circle at right top, rgba(200, 178, 125, 0.18), transparent 18rem);
      box-shadow: var(--shadow-soft);
}

.vzirb-scope.editorial-inner::before,
.vzirb-scope .editorial-inner::before {
content: "";
      grid-column: 1;
      grid-row: 1 / span 2;
      align-self: center;
      width: 4px;
      height: min(170px, 100%);
      border-radius: 999px;
      background: linear-gradient(to bottom, var(--color-accent), var(--color-secondary));
}

.vzirb-scope.editorial-inner::after,
.vzirb-scope .editorial-inner::after {
content: "§";
      position: absolute;
      right: clamp(1rem, 3vw, 2rem);
      bottom: -0.55rem;
      color: rgba(58, 63, 92, 0.045);
      font-family: var(--font-heading);
      font-size: clamp(6rem, 12vw, 10rem);
      line-height: 1;
      pointer-events: none;
}

.vzirb-scope.editorial-title,
.vzirb-scope .editorial-title {
position: relative;
      display: grid;
      grid-column: 2;
      gap: 0.9rem;
      z-index: 1;
}

.vzirb-scope.editorial-title::before,
.vzirb-scope .editorial-title::before {
content: none;
}

.vzirb-scope.editorial-title h2,
.vzirb-scope .editorial-title h2 {
max-width: 820px;
      color: var(--color-primary);
      font-size: clamp(1.65rem, 3vw, 2.55rem);
      font-style: italic;
      line-height: 1.25;
}

.vzirb-scope.editorial-copy,
.vzirb-scope .editorial-copy {
display: grid;
      grid-column: 2;
      gap: 1rem;
      max-width: 780px;
      color: var(--color-text);
      font-size: clamp(0.96rem, 1.12vw, 1.03rem);
      z-index: 1;
}

.vzirb-scope.editorial-copy strong,
.vzirb-scope .editorial-copy strong {
color: var(--color-text-strong);
      font-weight: 800;
}

.vzirb-scope.content-block,
.vzirb-scope .content-block {
padding: clamp(4rem, 7vw, 6.6rem) 0;
      background: var(--color-bg);
}

.vzirb-scope.content-block--white,
.vzirb-scope .content-block--white {
background: var(--color-surface);
}

.vzirb-scope.section-head,
.vzirb-scope .section-head {
display: grid;
      gap: 0.75rem;
      max-width: 835px;
      margin-bottom: clamp(2rem, 4vw, 3.4rem);
}

.vzirb-scope.section-head h2,
.vzirb-scope .section-head h2 {
font-size: clamp(1.8rem, 3.4vw, 3.05rem);
}

.vzirb-scope.section-head p,
.vzirb-scope .section-head p {
max-width: 740px;
      font-size: 0.98rem;
}

.vzirb-scope.attorney-grid,
.vzirb-scope .attorney-grid {
display: grid;
      grid-template-columns: minmax(280px, 0.78fr) minmax(0, 1.22fr);
      gap: clamp(1.5rem, 4vw, 3.6rem);
      align-items: start;
}

.vzirb-scope.image-card,
.vzirb-scope .image-card {
overflow: hidden;
      border-radius: var(--radius-lg);
      background: var(--color-surface);
      box-shadow: var(--shadow-soft);
}

.vzirb-scope.content-block--white .image-card,
.vzirb-scope .content-block--white .image-card,
.vzirb-scope.content-block--white .narrative-card,
.vzirb-scope .content-block--white .narrative-card {
background: var(--color-bg);
}

.vzirb-scope.image-card img,
.vzirb-scope .image-card img {
width: 100%;
      height: 344px;
      object-fit: cover;
      filter: saturate(0.86) contrast(1.03);
}

.vzirb-scope.image-card figcaption,
.vzirb-scope .image-card figcaption {
padding: 1.15rem 1.25rem;
      border-top: 1px solid var(--color-line-soft);
      color: var(--color-text);
      font-size: 0.9rem;
      line-height: 1.6;
}

.vzirb-scope.image-card figcaption strong,
.vzirb-scope .image-card figcaption strong {
display: block;
      margin-bottom: 0.2rem;
      color: var(--color-primary);
      font-family: var(--font-heading);
      font-size: 1.25rem;
      font-weight: 600;
}

.vzirb-scope.narrative-card,
.vzirb-scope .narrative-card {
display: grid;
      gap: 1.1rem;
      padding: clamp(1.35rem, 3vw, 2.3rem);
      border: 1px solid var(--color-line-soft);
      border-radius: var(--radius-lg);
      background: var(--color-surface);
      box-shadow: var(--shadow-soft);
}

.vzirb-scope.narrative-card h3,
.vzirb-scope .narrative-card h3 {
font-size: clamp(1.45rem, 2.4vw, 2.1rem);
}

.vzirb-scope.language-list,
.vzirb-scope .language-list {
display: grid;
      grid-template-columns: repeat(auto-fit, minmax(118px, 1fr));
      gap: 0.65rem;
      width: 100%;
      margin: 0;
      padding: 1rem 0 0;
      list-style: none;
}

.vzirb-scope.language-list li,
.vzirb-scope .language-list li {
display: flex;
      align-items: center;
      justify-content: flex-start;
      text-align: center;
      gap: 0.46rem;
      min-width: 0;
      min-height: 46px;
      padding: 0.58rem 0.72rem;
      overflow: hidden;
      border: 1px solid rgba(58, 63, 92, 0.18);
      border-radius: 999px;
      background: var(--color-surface);
      color: var(--color-primary);
      font-size: 0.73rem;
      font-weight: 800;
      letter-spacing: 0.035em;
      line-height: 1.2;
      text-transform: uppercase;
      white-space: nowrap;
      box-shadow: 0 7px 20px rgba(58, 63, 92, 0.06);
}

.vzirb-scope.language-list img,
.vzirb-scope .language-list img {
flex: 0 0 20px;
      width: 20px !important;
      min-width: 20px;
      max-width: 20px;
      height: 14px !important;
      border-radius: 3px;
      object-fit: cover;
      box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.08);
}

.vzirb-scope.practice-grid,
.vzirb-scope .practice-grid {
display: grid;
      grid-template-columns: repeat(5, minmax(0, 1fr));
      gap: 1rem;
}

.vzirb-scope.practice-card,
.vzirb-scope .practice-card {
position: relative;
      min-height: 230px;
      padding: 1.25rem;
      overflow: hidden;
      border: 1px solid var(--color-line-soft);
      border-radius: var(--radius-md);
      background: var(--color-surface);
      box-shadow: 0 10px 34px rgba(58, 63, 92, 0.07);
      transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.vzirb-scope.practice-card:hover,
.vzirb-scope .practice-card:hover {
transform: translateY(-5px);
      border-color: rgba(200, 178, 125, 0.70);
      box-shadow: 0 18px 52px rgba(58, 63, 92, 0.12);
}

.vzirb-scope.practice-card::after,
.vzirb-scope .practice-card::after {
content: "";
      position: absolute;
      right: -40px;
      bottom: -40px;
      width: 120px;
      height: 120px;
      border: 1px solid rgba(200, 178, 125, 0.55);
      border-radius: 50%;
}

.vzirb-scope.practice-card span,
.vzirb-scope .practice-card span {
display: inline-grid;
      place-items: center;
      width: 42px;
      height: 42px;
      margin-bottom: 1.05rem;
      border-radius: 50%;
      background: var(--color-primary);
      color: var(--color-accent);
      font-family: var(--font-heading);
      font-weight: 700;
      line-height: 1;
}

.vzirb-scope.practice-card h3,
.vzirb-scope .practice-card h3 {
margin-bottom: 0.7rem;
      font-size: 1.24rem;
}

.vzirb-scope.practice-card p,
.vzirb-scope .practice-card p {
color: var(--color-text);
      font-size: 0.9rem;
      line-height: 1.65;
}

.vzirb-scope.split-feature,
.vzirb-scope .split-feature {
padding: clamp(4rem, 7vw, 6.6rem) 0;
      background: var(--color-primary-deep);
      color: rgba(255, 255, 255, 0.78);
}

.vzirb-scope.split-grid,
.vzirb-scope .split-grid {
display: grid;
      grid-template-columns: minmax(0, 1fr) minmax(300px, 0.82fr);
      gap: clamp(1.6rem, 4vw, 4rem);
      align-items: center;
}

.vzirb-scope.split-copy,
.vzirb-scope .split-copy {
display: grid;
      gap: 1rem;
}

.vzirb-scope.split-copy h2,
.vzirb-scope .split-copy h2 {
max-width: 760px;
      color: var(--color-surface);
      font-size: clamp(1.8rem, 3.4vw, 3.1rem);
}

.vzirb-scope.split-copy p,
.vzirb-scope .split-copy p {
max-width: 720px;
      color: rgba(255, 255, 255, 0.80);
}

.vzirb-scope.scenario-list,
.vzirb-scope .scenario-list {
display: grid;
      gap: 0.85rem;
      margin-top: 0.6rem;
}

.vzirb-scope.scenario-item,
.vzirb-scope .scenario-item {
display: grid;
      grid-template-columns: 48px minmax(0, 1fr);
      gap: 1rem;
      align-items: start;
      padding: 1rem;
      border: 1px solid rgba(200, 178, 125, 0.28);
      border-radius: var(--radius-md);
      background: rgba(255, 255, 255, 0.07);
}

.vzirb-scope.scenario-item span,
.vzirb-scope .scenario-item span {
display: grid;
      place-items: center;
      width: 48px;
      height: 48px;
      border-radius: 50%;
      background: rgba(200, 178, 125, 0.16);
      color: #ffffff;
      font-weight: bolder;
      line-height: 1;
}

.vzirb-scope.scenario-item h3,
.vzirb-scope .scenario-item h3 {
margin-bottom: 0.25rem;
      color: var(--color-surface);
      font-family: var(--font-body);
      font-size: 1rem;
      font-weight: 800;
      line-height: 1.35;
}

.vzirb-scope.scenario-item p,
.vzirb-scope .scenario-item p {
color: rgba(255, 255, 255, 0.90);
      font-size: 0.92rem;
      line-height: 1.65;
}

.vzirb-scope.miami-card,
.vzirb-scope .miami-card {
overflow: hidden;
      border: 1px solid rgba(255, 255, 255, 0.18);
      border-radius: var(--radius-xl);
      background: rgba(255, 255, 255, 0.08);
      box-shadow: var(--shadow-strong);
}

.vzirb-scope.miami-card img,
.vzirb-scope .miami-card img {
width: 100%;
      min-height: 390px;
      object-fit: cover;
      filter: saturate(0.86) contrast(1.04);
}

.vzirb-scope.miami-card figcaption,
.vzirb-scope .miami-card figcaption {
padding: 1.2rem 1.35rem;
      color: rgba(255, 255, 255, 0.78);
      font-size: 0.9rem;
      line-height: 1.6;
}

.vzirb-scope.network,
.vzirb-scope .network {
padding: clamp(4rem, 7vw, 6.6rem) 0;
      background: var(--color-surface);
}

.vzirb-scope.network-layout,
.vzirb-scope .network-layout {
display: grid;
      grid-template-columns: minmax(280px, 0.70fr) minmax(0, 1.30fr);
      gap: clamp(1.5rem, 4vw, 4rem);
      align-items: start;
}

.vzirb-scope.network-intro, .vzirb-scope .network-intro {
  position: sticky;
  top: 1.5rem;
  display: grid;
  gap: 1rem;
  padding: 1.55rem;
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-lg);
  background: var(--color-bg);
  box-shadow: 0 12px 38px rgba(58, 63, 92, 0.07);
  overflow: hidden;
  min-width: 0;
  box-sizing: border-box;
}

.vzirb-scope.network-intro h2,
.vzirb-scope .network-intro h2 {
font-size: clamp(1.65rem, 2.8vw, 2.6rem);
}

.vzirb-scope.state-panel,
.vzirb-scope .state-panel {
display: grid;
      gap: 1rem;
}

.vzirb-scope.state-panel details,
.vzirb-scope .state-panel details {
overflow: hidden;
      border: 1px solid var(--color-line-soft);
      border-radius: var(--radius-lg);
      background: var(--color-bg);
      box-shadow: 0 10px 34px rgba(58, 63, 92, 0.06);
}

.vzirb-scope.state-panel summary,
.vzirb-scope .state-panel summary {
position: relative;
      cursor: pointer;
      list-style: none;
      padding: 1.05rem 3.5rem 1.05rem 1.2rem;
      color: var(--color-primary);
      font-family: var(--font-heading);
      font-size: 1.25rem;
      font-weight: 600;
      line-height: 1.3;
}

.vzirb-scope.state-panel summary::-webkit-details-marker,
.vzirb-scope .state-panel summary::-webkit-details-marker {
display: none;
}

.vzirb-scope.state-panel summary::after,
.vzirb-scope .state-panel summary::after {
content: "+";
      position: absolute;
      top: 50%;
      right: 1.1rem;
      display: grid;
      place-items: center;
      width: 32px;
      height: 32px;
      border-radius: 50%;
      background: var(--color-primary);
      color: var(--color-surface);
      font-family: var(--font-body);
      font-size: 1.15rem;
      font-weight: 700;
      transform: translateY(-50%);
}

.vzirb-scope.state-panel details[open] summary::after,
.vzirb-scope .state-panel details[open] summary::after {
content: "−";
      background: var(--color-accent);
      color: var(--color-primary-deep);
}

.vzirb-scope.state-body,
.vzirb-scope .state-body {
padding: 0 1.2rem 1.2rem;
}

.vzirb-scope.state-grid,
.vzirb-scope .state-grid {
display: flex;
      flex-wrap: wrap;
      gap: 0.55rem;
      margin: 0;
      padding: 1rem 0 0;
      border-top: 1px solid var(--color-line-soft);
      list-style: none;
}

.vzirb-scope.state-grid li,
.vzirb-scope .state-grid li {
padding: 0.46rem 0.72rem;
      border: 1px solid rgba(58, 63, 92, 0.18);
      border-radius: 999px;
      background: var(--color-surface);
      color: var(--color-text-strong);
      font-size: 0.82rem;
      font-weight: 600;
      line-height: 1.2;
}

@media (prefers-reduced-motion: reduce) {
.vzirb-scope *,
.vzirb-scope *::before,
.vzirb-scope *::after {
animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        scroll-behavior: auto !important;
        transition-duration: 0.01ms !important;
}
.vzirb-scope.practice-card:hover,
.vzirb-scope .practice-card:hover {
transform: none;
}
}

@media (max-width: 1080px) {
.vzirb-scope.hero-grid,
.vzirb-scope .hero-grid,
.vzirb-scope.attorney-grid,
.vzirb-scope .attorney-grid,
.vzirb-scope.split-grid,
.vzirb-scope .split-grid,
.vzirb-scope.network-layout,
.vzirb-scope .network-layout,
.vzirb-scope.editorial-inner,
.vzirb-scope .editorial-inner {
grid-template-columns: 1fr;
}
.vzirb-scope.portrait-panel,
.vzirb-scope .portrait-panel,
.vzirb-scope.image-card,
.vzirb-scope .image-card,
.vzirb-scope.miami-card,
.vzirb-scope .miami-card {
max-width: 680px;
}
.vzirb-scope.practice-grid,
.vzirb-scope .practice-grid {
grid-template-columns: repeat(3, minmax(0, 1fr));
}
.vzirb-scope.language-list,
.vzirb-scope .language-list {
grid-template-columns: repeat(auto-fit, minmax(112px, 1fr));
}
.vzirb-scope.network-intro,
.vzirb-scope .network-intro {
position: static;
}
}

@media (max-width: 780px) {
.vzirb-scope {
--container: min(100% - 1.35rem, 1140px);
}
.vzirb-scope.hero,
.vzirb-scope .hero {
padding-top: clamp(3.5rem, 12vw, 5rem);
}
.vzirb-scope.hero h1,
.vzirb-scope .hero h1 {
font-size: clamp(2.75rem, 15vw, 4.9rem);
}
.vzirb-scope.hero-note,
.vzirb-scope .hero-note {
grid-template-columns: 1fr;
}
.vzirb-scope.hero-note::before,
.vzirb-scope .hero-note::before {
width: 78px; height: 3px;
}
.vzirb-scope.practice-grid,
.vzirb-scope .practice-grid {
grid-template-columns: 1fr;
}
.vzirb-scope.language-list,
.vzirb-scope .language-list {
grid-template-columns: repeat(auto-fit, minmax(108px, 1fr));
}
.vzirb-scope.editorial-inner,
.vzirb-scope .editorial-inner {
grid-template-columns: 1fr; gap: 1.25rem;
}
.vzirb-scope.editorial-inner::before,
.vzirb-scope .editorial-inner::before {
grid-column: 1; grid-row: auto; width: 82px; height: 3px;
}
.vzirb-scope.editorial-title,
.vzirb-scope .editorial-title,
.vzirb-scope.editorial-copy,
.vzirb-scope .editorial-copy {
grid-column: 1;
}
.vzirb-scope.practice-card,
.vzirb-scope .practice-card {
min-height: auto;
}
.vzirb-scope.scenario-item,
.vzirb-scope .scenario-item {
grid-template-columns: 40px minmax(0, 1fr);
}
.vzirb-scope.scenario-item span,
.vzirb-scope .scenario-item span {
width: 40px; height: 40px;
}
.vzirb-scope.portrait-panel img,
.vzirb-scope .portrait-panel img,
.vzirb-scope.image-card img,
.vzirb-scope .image-card img,
.vzirb-scope.miami-card img,
.vzirb-scope .miami-card img {
min-height: 320px; height: auto;
}
}

@media (max-width: 520px) {
.vzirb-scope.eyebrow,
.vzirb-scope .eyebrow {
letter-spacing: 0.12em;
}
.vzirb-scope.portrait-panel,
.vzirb-scope .portrait-panel,
.vzirb-scope.image-card,
.vzirb-scope .image-card,
.vzirb-scope.miami-card,
.vzirb-scope .miami-card,
.vzirb-scope.narrative-card,
.vzirb-scope .narrative-card,
.vzirb-scope.network-intro,
.vzirb-scope .network-intro {
border-radius: var(--radius-md);
}
.vzirb-scope.state-panel summary,
.vzirb-scope .state-panel summary {
font-size: 1.12rem;
}
}

/* ═══════════════════════════════════════════════════════
       DARK MODE — home page palette, WCAG 2.2 AA contrast
       CSS-only: no HTML, content, layout, or JavaScript changes.
    ═══════════════════════════════════════════════════════ */

html[data-theme="dark"] .vzirb-scope {
color-scheme: dark;
      --color-primary: #3A3F5C;
      --color-primary-dark: #4A5170;
      --color-secondary: #C7B6C2;
      --color-accent: #D9C47F;
      --color-accent-dark: #C3A95D;
      --color-accent-readable: #EAD99A;
      --color-bg: #101319;
      --color-bg-warm: #171B24;
      --color-form-bg: #1D2230;
      --color-text: #D4DBEA;
      --color-text-dark: #F4F1EA;
      --color-text-light: #BBC6D8;
      --color-white: #171B24;
      --color-border: #3B4254;
      --color-border-light: #2A3040;
      --color-primary-deep: #101319;
      --color-accent-soft: rgba(217, 196, 127, 0.18);
      --color-surface: var(--color-white);
      --color-text-strong: var(--color-text-dark);
      --color-line: rgba(212, 219, 234, 0.18);
      --color-line-soft: rgba(212, 219, 234, 0.16);
      --clr-primary: var(--color-primary);
      --clr-primary-dark: var(--color-primary-dark);
      --clr-primary-deep: var(--color-primary-deep);
      --clr-secondary: var(--color-secondary);
      --clr-accent: var(--color-accent);
      --clr-accent-dark: var(--color-accent-dark);
      --clr-accent-readable: var(--color-accent-readable);
      --clr-bg: var(--color-bg);
      --clr-surface: var(--color-surface);
      --clr-text: var(--color-text);
      --clr-text-strong: var(--color-text-strong);
      --shadow-soft: 0 16px 50px rgba(0, 0, 0, 0.36);
      --shadow-strong: 0 28px 88px rgba(0, 0, 0, 0.48);
}

html[data-theme="dark"] .vzirb-scope {
background: var(--color-bg);
      color: var(--color-text);
}

html[data-theme="dark"] .vzirb-scope ::selection {
background: rgba(217, 196, 127, 0.28);
      color: var(--color-text-dark);
}

html[data-theme="dark"] .vzirb-scope h1,
html[data-theme="dark"] .vzirb-scope h2,
html[data-theme="dark"] .vzirb-scope h3 {
color: var(--color-text-dark);
}

html[data-theme="dark"] .vzirb-scope.eyebrow,
html[data-theme="dark"] .vzirb-scope .eyebrow {
color: var(--color-accent-readable);
}

html[data-theme="dark"] .vzirb-scope.eyebrow--light,
html[data-theme="dark"] .vzirb-scope .eyebrow--light {
color: var(--color-accent);
}

html[data-theme="dark"] .vzirb-scope.hero,
html[data-theme="dark"] .vzirb-scope .hero {
background: var(--color-primary-deep);
      color: var(--color-text);
}

html[data-theme="dark"] .vzirb-scope.hero::before,
html[data-theme="dark"] .vzirb-scope .hero::before {
background:
        linear-gradient(90deg, rgba(16, 19, 25, 0.99) 0%, rgba(43, 47, 66, 0.94) 49%, rgba(58, 63, 92, 0.68) 100%),
        var(--vzirb-hero-bg, url("https://rechtsanwalt-berlin-charlottenburg.de/wp-content/uploads/rechtsanwalt-lawyer-berlin-Miami-USAflag-pixabay.-e1553520239877.jpg")) center / cover no-repeat;
}

html[data-theme="dark"] .vzirb-scope.hero::after,
html[data-theme="dark"] .vzirb-scope .hero::after {
background:
        linear-gradient(135deg, rgba(217, 196, 127, 0.10) 0 1px, transparent 1px 42px),
        radial-gradient(circle at 14% 20%, rgba(217, 196, 127, 0.16), transparent 22rem);
      opacity: 0.88;
}

html[data-theme="dark"] .vzirb-scope.hero h1,
html[data-theme="dark"] .vzirb-scope .hero h1,
html[data-theme="dark"] .vzirb-scope.hero h1 span,
html[data-theme="dark"] .vzirb-scope .hero h1 span,
html[data-theme="dark"] .vzirb-scope.portrait-caption strong,
html[data-theme="dark"] .vzirb-scope .portrait-caption strong,
html[data-theme="dark"] .vzirb-scope.split-copy h2,
html[data-theme="dark"] .vzirb-scope .split-copy h2,
html[data-theme="dark"] .vzirb-scope.scenario-item h3,
html[data-theme="dark"] .vzirb-scope .scenario-item h3 {
color: var(--color-text-dark);
}

html[data-theme="dark"] .vzirb-scope.hero h1 span,
html[data-theme="dark"] .vzirb-scope .hero h1 span,
html[data-theme="dark"] .vzirb-scope.portrait-caption .eyebrow,
html[data-theme="dark"] .vzirb-scope .portrait-caption .eyebrow,
html[data-theme="dark"] .vzirb-scope.split-copy .eyebrow,
html[data-theme="dark"] .vzirb-scope .split-copy .eyebrow,
html[data-theme="dark"] .vzirb-scope.practice-card span,
html[data-theme="dark"] .vzirb-scope .practice-card span {
color: var(--color-accent);
}

html[data-theme="dark"] .vzirb-scope.hero-lede,
html[data-theme="dark"] .vzirb-scope .hero-lede,
html[data-theme="dark"] .vzirb-scope.hero-note p,
html[data-theme="dark"] .vzirb-scope .hero-note p,
html[data-theme="dark"] .vzirb-scope.portrait-caption span,
html[data-theme="dark"] .vzirb-scope .portrait-caption span,
html[data-theme="dark"] .vzirb-scope.split-copy p,
html[data-theme="dark"] .vzirb-scope .split-copy p,
html[data-theme="dark"] .vzirb-scope.scenario-item p,
html[data-theme="dark"] .vzirb-scope .scenario-item p,
html[data-theme="dark"] .vzirb-scope.miami-card figcaption,
html[data-theme="dark"] .vzirb-scope .miami-card figcaption {
color: var(--color-text-light);
}

html[data-theme="dark"] .vzirb-scope.hero-note::before,
html[data-theme="dark"] .vzirb-scope .hero-note::before,
html[data-theme="dark"] .vzirb-scope.editorial-inner::before,
html[data-theme="dark"] .vzirb-scope .editorial-inner::before {
background: linear-gradient(to bottom, var(--color-accent), var(--color-secondary));
}

html[data-theme="dark"] .vzirb-scope.portrait-panel,
html[data-theme="dark"] .vzirb-scope .portrait-panel {
border-color: rgba(217, 196, 127, 0.28);
      background: rgba(23, 27, 36, 0.82);
      box-shadow: var(--shadow-strong);
}

html[data-theme="dark"] .vzirb-scope.portrait-panel::before,
html[data-theme="dark"] .vzirb-scope .portrait-panel::before {
border-color: rgba(217, 196, 127, 0.82);
}

html[data-theme="dark"] .vzirb-scope.portrait-caption,
html[data-theme="dark"] .vzirb-scope .portrait-caption {
background: linear-gradient(180deg, rgba(16, 19, 25, 0.98), rgba(23, 27, 36, 0.98));
}

html[data-theme="dark"] .vzirb-scope.editorial-strip,
html[data-theme="dark"] .vzirb-scope .editorial-strip,
html[data-theme="dark"] .vzirb-scope.content-block--white,
html[data-theme="dark"] .vzirb-scope .content-block--white,
html[data-theme="dark"] .vzirb-scope.network,
html[data-theme="dark"] .vzirb-scope .network {
background: var(--color-bg-warm);
      border-color: var(--color-border-light);
}

html[data-theme="dark"] .vzirb-scope.content-block,
html[data-theme="dark"] .vzirb-scope .content-block {
background: var(--color-bg);
}

html[data-theme="dark"] .vzirb-scope.editorial-inner,
html[data-theme="dark"] .vzirb-scope .editorial-inner {
border-color: var(--color-border);
      background:
        linear-gradient(135deg, rgba(23, 27, 36, 0.96), rgba(29, 34, 48, 0.98)),
        radial-gradient(circle at right top, rgba(217, 196, 127, 0.12), transparent 18rem);
      box-shadow: var(--shadow-soft);
}

html[data-theme="dark"] .vzirb-scope.editorial-inner::after,
html[data-theme="dark"] .vzirb-scope .editorial-inner::after {
color: rgba(244, 241, 234, 0.06);
}

html[data-theme="dark"] .vzirb-scope.editorial-title h2,
html[data-theme="dark"] .vzirb-scope .editorial-title h2,
html[data-theme="dark"] .vzirb-scope.editorial-copy strong,
html[data-theme="dark"] .vzirb-scope .editorial-copy strong,
html[data-theme="dark"] .vzirb-scope.section-head h2,
html[data-theme="dark"] .vzirb-scope .section-head h2,
html[data-theme="dark"] .vzirb-scope.narrative-card h3,
html[data-theme="dark"] .vzirb-scope .narrative-card h3,
html[data-theme="dark"] .vzirb-scope.image-card figcaption strong,
html[data-theme="dark"] .vzirb-scope .image-card figcaption strong,
html[data-theme="dark"] .vzirb-scope.practice-card h3,
html[data-theme="dark"] .vzirb-scope .practice-card h3,
html[data-theme="dark"] .vzirb-scope.network-intro h2,
html[data-theme="dark"] .vzirb-scope .network-intro h2,
html[data-theme="dark"] .vzirb-scope.state-panel summary,
html[data-theme="dark"] .vzirb-scope .state-panel summary {
color: var(--color-text-dark);
}

html[data-theme="dark"] .vzirb-scope.editorial-copy,
html[data-theme="dark"] .vzirb-scope .editorial-copy,
html[data-theme="dark"] .vzirb-scope.section-head p,
html[data-theme="dark"] .vzirb-scope .section-head p,
html[data-theme="dark"] .vzirb-scope.narrative-card p,
html[data-theme="dark"] .vzirb-scope .narrative-card p,
html[data-theme="dark"] .vzirb-scope.image-card figcaption,
html[data-theme="dark"] .vzirb-scope .image-card figcaption,
html[data-theme="dark"] .vzirb-scope.practice-card p,
html[data-theme="dark"] .vzirb-scope .practice-card p,
html[data-theme="dark"] .vzirb-scope.network-intro p,
html[data-theme="dark"] .vzirb-scope .network-intro p {
color: var(--color-text);
}

html[data-theme="dark"] .vzirb-scope.image-card,
html[data-theme="dark"] .vzirb-scope .image-card,
html[data-theme="dark"] .vzirb-scope.narrative-card,
html[data-theme="dark"] .vzirb-scope .narrative-card,
html[data-theme="dark"] .vzirb-scope.practice-card,
html[data-theme="dark"] .vzirb-scope .practice-card,
html[data-theme="dark"] .vzirb-scope.network-intro,
html[data-theme="dark"] .vzirb-scope .network-intro,
html[data-theme="dark"] .vzirb-scope.state-panel details,
html[data-theme="dark"] .vzirb-scope .state-panel details {
border-color: var(--color-border);
      background: var(--color-bg-warm);
      box-shadow: var(--shadow-soft);
}

html[data-theme="dark"] .vzirb-scope.content-block--white .image-card,
html[data-theme="dark"] .vzirb-scope .content-block--white .image-card,
html[data-theme="dark"] .vzirb-scope.content-block--white .narrative-card,
html[data-theme="dark"] .vzirb-scope .content-block--white .narrative-card {
background: var(--color-form-bg);
}

html[data-theme="dark"] .vzirb-scope.image-card figcaption,
html[data-theme="dark"] .vzirb-scope .image-card figcaption,
html[data-theme="dark"] .vzirb-scope.state-grid,
html[data-theme="dark"] .vzirb-scope .state-grid {
border-color: var(--color-border);
}

html[data-theme="dark"] .vzirb-scope.language-list li,
html[data-theme="dark"] .vzirb-scope .language-list li,
html[data-theme="dark"] .vzirb-scope.state-grid li,
html[data-theme="dark"] .vzirb-scope .state-grid li {
border-color: var(--color-border);
      background: var(--color-form-bg);
      color: var(--color-text-dark);
      box-shadow: none;
}

html[data-theme="dark"] .vzirb-scope.language-list img,
html[data-theme="dark"] .vzirb-scope .language-list img {
box-shadow: 0 0 0 1px rgba(244, 241, 234, 0.18);
}

html[data-theme="dark"] .vzirb-scope.practice-card:hover,
html[data-theme="dark"] .vzirb-scope .practice-card:hover {
border-color: rgba(217, 196, 127, 0.72);
      box-shadow: var(--shadow-strong);
}

html[data-theme="dark"] .vzirb-scope.practice-card::after,
html[data-theme="dark"] .vzirb-scope .practice-card::after {
border-color: rgba(217, 196, 127, 0.42);
}

html[data-theme="dark"] .vzirb-scope.practice-card span,
html[data-theme="dark"] .vzirb-scope .practice-card span,
html[data-theme="dark"] .vzirb-scope.state-panel summary::after,
html[data-theme="dark"] .vzirb-scope .state-panel summary::after {
background: var(--color-primary);
      color: var(--color-accent);
}

html[data-theme="dark"] .vzirb-scope.state-panel details[open] summary::after,
html[data-theme="dark"] .vzirb-scope .state-panel details[open] summary::after {
background: var(--color-accent);
      color: var(--color-primary-deep);
}

html[data-theme="dark"] .vzirb-scope.split-feature,
html[data-theme="dark"] .vzirb-scope .split-feature {
background: var(--color-primary-deep);
      color: var(--color-text);
}

html[data-theme="dark"] .vzirb-scope.scenario-item,
html[data-theme="dark"] .vzirb-scope .scenario-item,
html[data-theme="dark"] .vzirb-scope.miami-card,
html[data-theme="dark"] .vzirb-scope .miami-card {
border-color: rgba(217, 196, 127, 0.30);
      background: rgba(244, 241, 234, 0.06);
      box-shadow: var(--shadow-strong);
}

html[data-theme="dark"] .vzirb-scope.scenario-item span,
html[data-theme="dark"] .vzirb-scope .scenario-item span {
background: rgba(217, 196, 127, 0.16);
      color: var(--color-accent);
}

html[data-theme="dark"] .vzirb-scope.miami-card figcaption,
html[data-theme="dark"] .vzirb-scope .miami-card figcaption {
background: rgba(16, 19, 25, 0.72);
}

.vzirb-scope.hero h1 .vzirb-hero-heading-main,
.vzirb-scope .hero h1 .vzirb-hero-heading-main {
  display: inline;
  color: inherit;
  font-size: 1em;
  font-style: normal;
  font-weight: inherit;
  letter-spacing: inherit;
  line-height: inherit;
}
