.pwa-network-banner {
  position: fixed;
  right: 16px;
  bottom: 16px;
  z-index: 2147483000;
  display: none;
  width: min(420px, calc(100vw - 32px));
  padding: 12px 14px;
  border: 1px solid #d7dee8;
  border-radius: 8px;
  background: #ffffff;
  box-shadow: 0 14px 40px rgba(16, 24, 40, 0.18);
  color: #1f2937;
}

.pwa-network-banner.is-visible {
  display: flex;
  align-items: center;
  gap: 12px;
}

.pwa-network-banner__status {
  flex: 1;
  min-width: 0;
}

.pwa-network-banner__title {
  display: block;
  margin-bottom: 2px;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.3;
}

.pwa-network-banner__message {
  display: block;
  color: #667085;
  font-size: 13px;
  line-height: 1.35;
}

.pwa-network-banner__action {
  flex: 0 0 auto;
  min-height: 34px;
  padding: 0 12px;
  border: 0;
  border-radius: 6px;
  background: #008be6;
  color: #ffffff;
  font: inherit;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
}

.pwa-network-banner__action:focus {
  outline: 2px solid #94c2ff;
  outline-offset: 2px;
}

.pwa-network-banner.is-online {
  border-color: #b7e4c7;
}

.pwa-network-banner.is-online .pwa-network-banner__title {
  color: #176b3a;
}

.pwa-network-banner.is-offline {
  border-color: #ffd6a5;
}

.pwa-network-banner.is-offline .pwa-network-banner__title {
  color: #9a4d00;
}

@media (max-width: 575.98px) {
  .pwa-network-banner {
    right: 10px;
    bottom: 10px;
    width: calc(100vw - 20px);
  }

  .pwa-network-banner.is-visible {
    align-items: stretch;
    flex-direction: column;
  }

  .pwa-network-banner__action {
    width: 100%;
  }
}
