@font-face {
	font-family: 'AllianzNeo-Regular';
	src: url('./fonts/AllianzNeoW01-Regular.woff') format('woff');
	font-weight: normal;
	font-style: normal;
	font-display: swap;
}

@font-face {
    font-family: 'AllianzNeo-Light';
    src: url('./fonts/AllianzNeoW01-Light.woff');
	font-display: swap;
}

@font-face {
    font-family: 'AllianzNeo-SemiBold';
    src: url('./fonts/AllianzNeoW01-SemiBold.woff');
	font-display: swap;
}
@font-face {
    font-family: 'AllianzNeo-Bold';
    src: url('./fonts/AllianzNeoW01-Bold.woff');
	font-display: swap;
}

body {
  font-family: 'AllianzNeo-Regular', sans-serif;
  font-size: 18px;
  margin: 0;
  padding: 0;
  color: #414141;
  background: #ffffff;
  line-height: 1.3;
}

a.phone-link {
  color: #007ab3;
  text-decoration: none; /* Optional: removes underline */
}

a[href^="tel:"],
a[href^="mailto:"] {
  color: #007ab3;
  text-decoration: none;
}


strong {
	color: #414141;
	font-family: 'AllianzNeo-SemiBold', sans-serif;
	font-size: 18px;
}

sup {
    font-size: 10px;
}

.smaller {
	color: #414141;
	font-family: 'AllianzNeo-Regular', sans-serif;
	font-size: 14px;
}

.terms-conditions h3 {
    font-size: 18px;
    color: #58595bc4;
    margin-bottom: 20px;
}

.top-bar {
  background-color: #ffffff;
  padding: 10px 0;
  border-bottom: 1px solid #ccc;
}

.nav-container {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.logo img {
    height: 32px;
    margin-left: 50px;
}

.hero {
  background-color: #dfeff2;
  text-align: center;
  padding: 2rem 1rem;
}

.intro h1 {
	color: #003781;
	font-family: 'AllianzNeo-Bold', sans-serif;
	font-size: 48px;
	margin: 0;
}

.intro p {
	color: #414141;
	font-family: 'AllianzNeo-Regular', sans-serif;
	font-size: 24px;
	margin-top: 10px;
}

.hero-image img {
  width: 100%;
  height: auto;
  display: block;
}

.subtitle {
  font-size: 1.25rem;
}

.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0;
}

.border-frame {
  max-width: 1200px;
  margin: 0 auto;
}

section {
	padding: 1rem 6rem;
}

section.intro {
    background-color: #dfeff2;
}

section.country-list {
    margin-bottom: 54px;
}

.country-list .col {
  color: #003781;
}

section.terms-conditions {
	color: #58595bc4;
    font-size: 12px;
    line-height: 1.3;
}

.columns {
  columns: 2;
  column-gap: 2rem;
  padding-left: 1rem;
}

.columns div {
  break-inside: avoid;
  color: #003781;
  line-height: 1.4;
  font-weight: normal;
  font-size: 18px;
}

.border-frame {
  max-width: 1200px;
  margin: 0 auto;
  background-color: #fff;
}

.intro h1 {
  font-size: 2.5rem;
}

footer a {
  margin-left: 0.5rem;
}

.app-promo {
  background-color: #dfeff2;
  text-align: left;
}

.app-promo h2 {
	font-family: 'AllianzNeo-Bold', sans-serif;
	color: #003781;
	font-size: 1.5rem;
}

.app-promo p {
	margin-bottom: 0;
}

.app-promo-img {
  max-height: 260px;
  width: auto;
}

.allyz-btn {
  background-color: transparent;
  border: 2px solid #003781;
  border-radius: 4px;
  color: #003781;
  display: inline-block;
  margin-top: 1rem;
  max-width: 155px;
  padding: 0.45rem 1.7rem;
  text-decoration: none;
  text-align: center;
  transition: background-color 0.3s, color 0.3s;
}

.allyz-btn:hover {
  background-color: #003781;
  color: #ffffff;
}

.divider {
    border-top: 1px solid #414141;
    margin: 0 auto;
}

footer {
  align-items: center;
  background-color: #fff;
  color: #58595b;
  display: flex;
  flex-wrap: wrap;
  font-size: 13px;
  gap: 20px;
  padding: 1rem 3rem;
  text-align: left;
}

footer a {
  color: #007ab3;
  text-decoration: none;
}

/* override .bg-light bootstrap color */
.bg-light {
    background-color: #dfeff2 !important;
}

/* Get rid of padding from py-4 */
.no-vertical-padding {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

.app-promo__image {
  max-width: 300px;
  text-align: center;
}

.app-promo__content {
  max-width: 600px;
}

.app-promo {
	overflow: visible;
  position: relative;
  box-sizing: border-box;
}

.px-6 {
  padding-left: 4rem !important;  /* 64px */
  padding-right: 4rem !important;
}

.extra-padding {
  padding-top: 5rem;
  padding-bottom: 5rem;
}


@media (max-width: 768px) {
	
  .app-promo__content,
  .app-promo__image {
    width: 100%;
  }
  
    .app-promo__image {
    top: 0;
    margin-bottom: -8px;
  }

  .app-promo-img {
    transform: scale(0.8);
    transform-origin: bottom center;
  }
}

@media (max-width: 414px) {
	.intro,
	.country-list,
	.app-promo,
	.terms-conditions,
	.copyright	{
		padding-left: 1rem !important;  /* smaller side padding */
		padding-right: 1rem !important;
	}

  .logo img {
    margin-left: 20px;
  }

  section.country-list {
      margin-bottom: 0;
  }

  .app-promo-img {
    max-height: 154px;
  }

}


@media (min-width: 768px) {
  .app-promo__image {
    align-self: flex-end;
	  margin-bottom: -88px;
	  position: relative;
    top: -80px;
    
  }
}


