@layer blocks {

  .vwc-Footer {
    background: var(--vwc-navy-deep);
    border-top: 2px solid var(--vwc-accent-primary);
    padding: 3rem 1rem 2rem;
    color: var(--vwc-text-secondary);
  }

  .vwc-Footer-container {
    max-width: 1280px;
    margin-inline: auto;
    display: flex;
    flex-direction: column;
    gap: 2rem;
  }

  .vwc-Footer-brand img {
    height: 50px;
    width: auto;
  }

  .vwc-Footer-contact {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 2rem;
  }

  .vwc-Footer-disclaimer {
    background: var(--vwc-bg-elevated);
    border-radius: var(--radius);
    padding: 2rem;
  }

  .vwc-Footer-disclaimer p {
    margin-block-end: 1.5rem;
  }

  .vwc-Footer-actions {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
  }

  .vwc-Footer-nav {
    margin-block: 1rem;
  }

  .vwc-Footer-links {
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
    list-style: none;
    padding: 0;
    margin: 0;
  }

  .vwc-Footer-links a {
    color: var(--vwc-text-secondary);
    text-decoration: none;
    font-size: var(--text-sm);
  }

  .vwc-Footer-links a:hover {
    color: var(--vwc-accent-primary);
  }

  .vwc-Footer-legal {
    text-align: center;
    font-size: var(--text-sm);
    color: var(--vwc-text-muted);
    padding-block-start: 2rem;
    border-top: 1px solid var(--vwc-border-subtle);
  }

  .vwc-ContactItem {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
  }

  .vwc-ContactItem .vwc-Icon {
    flex-shrink: 0;
    color: var(--vwc-accent-primary);
  }

  .vwc-ContactItem strong {
    display: block;
    color: var(--vwc-text-primary);
    margin-block-end: 0.25rem;
  }

  .vwc-ContactItem a {
    color: var(--vwc-accent-primary);
    text-decoration: none;
  }

  .vwc-ContactItem a:hover {
    text-decoration: underline;
  }

  .vwc-ContactItem address {
    font-style: normal;
  }

  .vwc-AgeBadge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    background: var(--vwc-white);
    color: var(--vwc-navy-deep);
    border-radius: 50%;
    font-weight: 700;
    font-size: var(--text-lg);
    border: 3px solid var(--vwc-accent-primary);
  }
}
