html {
  font-size: 10px;
}

body {
  font-family: 'Lato', "Segoe UI", "Helvetica Neue", Arial, sans-serif;
  font-size: 1.6rem;
  line-height: 1.5;
  margin: 0;
  background-color: #fefdfd;
  color: #010101;
}

@media (min-width: 1400px) {
  body {
    font-size: 2.5rem;
    line-height: 1.8;
  }
}

/* Menu Bar */
.menu-bar {
  background: #5f43b2;
  padding: 2rem 0;
  display: flex;
  justify-content: space-around;
  position: sticky;
  top: 0;
  z-index: 100;
}

.menu-bar a {
  color: #fefdfd;
  text-decoration: none;
  font-size: 1.8rem;
  font-weight: 500;
  padding: 1rem 2rem;
  border-radius: 4px;
  transition: background-color 0.3s;
}

.menu-bar a:hover {
  background-color: rgba(255, 255, 255, 0.1);
  text-decoration: none;
}

.menu-bar a:visited {
  color: #fefdfd;
}

/* Back to Top Button */
.back-to-top {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  background: #5f43b2;
  color: #fefdfd;
  width: 5rem;
  height: 5rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  text-decoration: none;
  box-shadow: 0 0.4rem 0.8rem rgba(0, 0, 0, 0.2);
  transition: background-color 0.3s;
}

.back-to-top:hover {
  background: #3a3153;
  text-decoration: none;
}

.back-to-top:visited {
  color: #fefdfd;
}

h1 {
  font-size: 6rem;
  font-family: "Libre Baskerville", serif;
  font-weight: bold;
  color: #3a3153;
}

#subheader {
  font-weight: 300;
  color: #b1aebb;
  text-transform: uppercase;
  font-size: 1.8rem;
}

@media (max-width: 400px) {
  h1 {
    font-size: 4rem;
  }
}

@media (min-width: 1400px) {
  h1 {
    font-size: 7rem;
  }
}

h2 {
  font-size: 3rem;
  font-family: "Libre Baskerville", serif;
  text-align: center;
  padding-bottom: 3rem;
  color: #3a3153;
}

@media (min-width: 1400px) {
  h2 {
    font-size: 4rem;
  }
}

blockquote {
  font-size: 2rem;
  font-style: italic;
  font-family: "Libre Baskerville", serif;
  text-align: center;
  margin-bottom: 3rem;
  color: #010101;
}

@media (min-width: 1400px) {
  blockquote {
    font-size: 3rem;
  }
}

ul {
  list-style: none;
  padding-left: 0;
  line-height: 2;
}

.donation-links {
  text-align: center;
  font-size: 1.8rem;
}

.donation-links li {
  margin-bottom: 1rem;
}

a {
  text-decoration: none;
  color: #5f43b2;
}

a:hover {
  text-decoration: underline;
  color: #3a3153;
}

a:visited {
  color: #b1aebb;
}

/* Images */

img {
  max-width: 100%;
  height: auto;
  display: block;
  box-shadow: 0 1rem 2rem rgba(0, 0, 0, 0.1);
  border-radius: 8px;
}

/* First row columns */

.column-header {
  float: left;
  width: 65%;
  padding: 2.5%;
  box-sizing: border-box;
}

.column-image {
  float: left;
  padding: 2.5%;
  width: 35%;
  box-sizing: border-box;
}

.container::after {
  content: "";
  display: table;
  clear: both;
}

@media screen and (max-width: 1000px) {

  .column-header,
  .column-image {
    width: 100%;
    float: none;
  }

  #image-div img {
    margin: auto;
  }
}

/* Sections */

.first-row {
  padding: 5rem 5rem 8rem 5rem;
  background: linear-gradient(135deg, rgba(177, 174, 187, 0.2) 0%, rgba(177, 174, 187, 0.1) 100%);
}

.second-row {
  color: #010101;
  padding: 4rem 5rem;
  background-color: #fefdfd;
}

.third-row {
  background: linear-gradient(135deg, rgba(177, 174, 187, 0.3) 0%, rgba(177, 174, 187, 0.2) 100%);
  color: #010101;
  padding: 5rem;
  text-align: center;
}

.fourth-row {
  padding: 4rem 5rem;
  background-color: rgba(177, 174, 187, 0.1);
}

.celebration-section .celebration-content {
  max-width: 800px;
  margin: 0 auto;
  text-align: center;
}

.celebration-section p {
  margin-bottom: 2rem;
  font-size: 1.8rem;
  line-height: 1.6;
}

.fifth-row {
  padding: 4rem 5rem;
  text-align: center;
  background-color: #fefdfd;
  margin-bottom: 0;
}

.donations-section p {
  font-size: 1.8rem;
  margin-bottom: 2rem;
  color: #010101;
}

.footer {
  background: #5f43b2;
  color: #fefdfd;
  padding: 2rem;
  text-align: center;
  font-style: italic;
}

#second-row-container {
  margin: auto;
  padding: 2.5%;
  max-width: 900px;
}

#second-row-container p {
  margin-bottom: 2rem;
  font-size: 1.8rem;
  line-height: 1.6;
}

/* Responsive adjustments */
@media (max-width: 768px) {

  .first-row,
  .second-row,
  .third-row,
  .fourth-row,
  .fifth-row {
    padding: 3rem 2rem;
  }

  h1 {
    font-size: 4rem;
  }

  h2 {
    font-size: 2.5rem;
  }

  blockquote {
    font-size: 1.8rem;
  }

  .celebration-section p,
  .donations-section p,
  #second-row-container p {
    font-size: 1.6rem;
  }

  .menu-bar {
    padding: 1.5rem 0;
  }

  .menu-bar a {
    font-size: 1.6rem;
    padding: 0.8rem 1rem;
  }

  .back-to-top {
    width: 4rem;
    height: 4rem;
    font-size: 1.8rem;
  }
}

/* Pet image styling */
.pet-image {
  text-align: center;
  margin-top: 2rem;
}

.pet-image img {
  display: block;
  margin: 0 auto;
}

/* Special styling for emphasis */
strong {
  color: #010101;
  font-weight: 700;
}

#quote {
  font-size: 2.4rem;
  margin: 0;
}

@media (min-width: 1400px) {
  #quote {
    font-size: 3.2rem;
  }
}