body {
    margin: 0;
    padding: 0;
    font-family: Public Sans, Helvetica, sans-serif;
    background-color: #1a1a1a;
    display: flex; 
    justify-content: center;
}

.main-content-container {
    width: 1280px; 
    flex-direction:column; 
    justify-content: flex-start;
    align-items: flex-start;
    gap: 48px;
    margin-top: 120px;
    display: inline-flex;
}

.top-content-container {
    lign-self: stretch;
    justify-content: flex-start; 
    align-items: flex-start; 
    display: inline-flex;
}

.top-content-left-container {
    width: 372px;
    flex-direction: column; 
    justify-content: flex-start; 
    align-items: flex-start; 
    gap: 2px;
    display: inline-flex;
}

.logo-container {
    padding-left: 8px;
    padding-bottom: 4px; 
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    display: flex;
}

.logo {
    width: 62px;
    height: 38px; 
    position: relative;
}

.logo-j {
    width: 18px; 
    height: 28px;
    left: 0px; 
    top: 10px; 
    position: absolute;
}

.logo-j-1 {
    width: 8px;
    height: 8px;
    left: 10px;
    top: 0px;
    position: absolute; 
    background: #63bdde; 
    border-radius: 2px;
}

.logo-j-2 {
    width: 8px; 
    height: 8px;
    left: 10px;
    top: 10px;
    position: absolute;
    background: #63bdde;
    border-radius: 2px;
}

.logo-j-3 {
    width: 8px;
    height: 8px;
    left: 10px;
    top: 20px;
    position: absolute;
    background: #63bdde;
    border-radius: 2px;
}

.logo-j-4 {
    width: 8px;
    height: 8px;
    left: 0px;
    top: 20px;
    position: absolute;
    background: #63bdde;
    border-radius: 2px;
}

.logo-d {
    width: 18px;
    height: 28px;
    left: 22px;
    top: 0px;
    position: absolute;
}

.logo-d-1 {
    width: 8px;
    height: 8px;
    left: 10px;
    top: 0px;
    position: absolute;
    background: #ec7dc2;
    border-radius: 2px;
}

.logo-d-2 {
    width: 8px;
    height: 8px;
    left: 0px;
    top: 10px;
    position: absolute;
    background: #ec7dc2;
    border-radius: 2px;
}

.logo-d-3 {
    width: 8px;
    height: 8px;
    left: 10px;
    top: 10px;
    position: absolute;
    background: #ec7dc2;
    border-radius: 2px;
}

.logo-d-4 {
    width: 8px;
    height: 8px;
    left: 0px;
    top: 20px;
    position: absolute;
    background: #ec7dc2;
    border-radius: 2px
}

.logo-d-5 {
    width: 8px; 
    height: 8px;
    left: 10px;
    top: 20px;
    position: absolute;
    background: #ec7dc2;
    border-radius: 2px;
}

.logo-b {
    width: 18px;
    height: 28px;
    left: 44px;
    top: 0px;
    position: absolute;
}

.logo-b-1 {
    width: 8px; 
    height: 8px; 
    left: 0px; 
    top: 0px; 
    position: absolute; 
    background: #e39e53; 
    border-radius: 2px;
}

.logo-b-2 {
    width: 8px; 
    height: 8px; 
    left: 0px; 
    top: 10px; 
    position: absolute; 
    background: #e39e53; 
    border-radius: 2px;
}

.logo-b-3 {
    width: 8px; 
    height: 8px; 
    left: 10px; 
    top: 10px; 
    position: absolute; 
    background: #e39e53; 
    border-radius: 2px;
}

.logo-b-4 {
    width: 8px; 
    height: 8px; 
    left: 0px; 
    top: 20px; 
    position: absolute; 
    background: #e39e53; 
    border-radius: 2px;
}

.logo-b-5 {
    width: 8px; 
    height: 8px; 
    left: 10px; 
    top: 20px; 
    position: absolute; 
    background: #e39e53; 
    border-radius: 2px;
}

.name-container {
    padding-top: 8px; 
    padding-bottom: 4px; 
    padding-left: 8px; 
    padding-right: 8px; 
    justify-content: flex-start; 
    align-items: flex-start;
    display: inline-flex;
    color: #FAFAFA;
    font-size: 11px;
    font-family: Public Sans, Helvetica, sans-serif; 
    font-weight: 700;
    line-height: 12px;
    letter-spacing: 0.10px; 
    word-wrap: break-word;
}

.links-container {
    padding-left: 8px;
    padding-right: 8px;
    padding-top: 4px;
    padding-bottom: 4px; 
    justify-content: flex-start; 
    align-items: flex-start; 
    display: inline-flex;
    color: #BABABA; 
    font-size: 12px; 
    font-family: Public Sans, Helvetica, sans-serif; 
    font-weight: 400; 
    line-height: 14px; 
    letter-spacing: 0.12px; 
    word-wrap: break-word;
}

.links-container a {
    color: #BABABA; 
    font-size: 12px; 
    font-family: Public Sans, Helvetica, sans-serif; 
    font-weight: 400; 
    line-height: 14px; 
    letter-spacing: 0.12px; 
    word-wrap: break-word;
    text-decoration: none;
}

.links-container a:hover {
    color: #BABABA; 
    font-size: 12px; 
    font-family: Public Sans, Helvetica, sans-serif; 
    font-weight: 400; 
    line-height: 14px; 
    letter-spacing: 0.12px; 
    word-wrap: break-word;
    text-decoration: underline;
}

.top-content-right-container {
    width: 100%;
    flex-direction: column;
    justify-content: flex-start; 
    align-items: flex-start; 
    display: inline-flex;
}

.greeting-container {
    align-self: stretch; 
    padding-bottom: 12px;
    justify-content: flex-start; 
    align-items: flex-start; 
    display: inline-flex;
    flex: 1 1 0;
    color: #FAFAFA; 
    font-size: 24px;
    font-family: Public Sans, Helvetica, sans-serif; 
    font-weight: 600; 
    line-height: 28px; 
    letter-spacing: 0.24px; 
    word-wrap: break-word;
}

.supporting-text-container {
    align-self: stretch;
    padding-bottom: 12px;
    flex-direction: column; 
    justify-content: flex-start; 
    align-items: flex-start; 
    gap: 12px; 
    display: flex;
    padding-right: 300px;
}

.supporting-text-primary-container {
    flex: 1 1 0;
    align-self: stretch; 
    justify-content: flex-start; 
    align-items: flex-start;
    display: inline-flex;
    color: #FAFAFA;
    font-size: 18px;
    font-family: Public Sans, Helvetica, sans-serif;
    font-weight: 400;
    line-height: 26px; 
    letter-spacing: 0.20px; 
    word-wrap: break-word;
}

.supporting-text-primary-value {
    color: #FAFAFA;
    font-size: 18px;
    font-family: Public Sans, Helvetica, sans-serif;
    font-weight: 400;
    line-height: 26px; 
    letter-spacing: 0.20px; 
    word-wrap: break-word;
}

.supporting-text-primary-color-darkblue {
    color: #63bdde;
    font-weight: 700;
}

.supporting-text-primary-color-lightblue {
    color: #ec7dc2;
    font-weight: 700;
}

.supporting-text-primary-color-orange {
    color: #e39e53;
    font-weight: 700;
}

.supporting-text-secondary-container {
    flex: 1 1 0;
    align-self: stretch; 
    justify-content: flex-start; 
    align-items: flex-start;
    display: inline-flex;
    color: #7A7A7A; 
    font-size: 16px; 
    font-family: Public Sans, Helvetica, sans-serif; 
    font-weight: 400; 
    line-height: 22px; 
    word-wrap: break-word;
}

.main-content-module {
    width: 100%;
    align-self: stretch; 
    justify-content: flex-start; 
    align-items: flex-start; 
    display: inline-flex;
    padding-bottom: 8px;
    padding-top: 8px;
    padding-right: 8px;
    border-radius: 8px;
}



a:hover .main-content-module-left-title {
    color: #63bdde;
}

a:hover .main-content-module-left-divider {
    background: #7a7a7a;
}

a:hover .main-content-module-left-company-name {
    color: #63bdde;
}

a:hover .main-content-module-left-year {
    color: #356374;
}


.main-content-module-left {
    width: 360px; 
    flex-direction: column; 
    justify-content: flex-start; 
    align-items: flex-start; 
    display: inline-flex;
    padding-left: 8px;
}

.main-content-module-left-title {
    flex: 1 1 0;
    align-self: stretch; 
    padding-bottom: 16px; 
    padding-right: 64px; 
    justify-content: flex-start; 
    align-items: flex-start;
    display: inline-flex;
    color: #FAFAFA; 
    font-size: 16px; 
    font-family: Public Sans, Helvetica, sans-serif;
    font-weight: 600;
    line-height: 22px;
    word-wrap: break-word;
}

.main-content-module-left-divider {
    flex-direction: column; 
    justify-content: flex-start; 
    align-items: flex-start;
    display: flex;
    width: 228px;
    height: 1px;
    background: #3a3a3a;
}

.main-content-module-left-company-name {
    align-self: stretch;
    padding-top: 16px;
    padding-right: 20px;
    justify-content: flex-start;
    align-items: flex-start;
    display: inline-flex;
    color: #DADADA;
    font-size: 14px;
    font-family: Public Sans, Helvetica, sans-serif; 
    font-weight: 600; 
    line-height: 18px; 
}

.main-content-module-left-year {
    align-self:stretch;
    padding-top: 8px; 
    justify-content: flex-start; 
    align-items: center;
    display: inline-flex;
    color: #7A7A7A;
    font-size: 14px; 
    font-family: Public Sans, Helvetica, sans-serif; 
    font-weight: 400; 
    line-height: 18px; 
    word-wrap: break-word;
}

.main-content-module-right-image-container {
    width: 100%; 
    flex-direction: column; 
    justify-content: flex-start; 
    align-items: flex-start;
    display: inline-flex;
    overflow: hidden; /* Hide the overflow to avoid seeing the zoomed-out parts */
    border-radius: 8px;
}

.main-content-module:hover .main-image {
    transform: scale(1.03);
}

.main-image {
    align-self: stretch;
    width: 100%; /* Ensure the image fits the container */
    height: auto; /* Maintain the aspect ratio */
    transition: transform 0.5s ease;
}

.main-content-module-left-info {
    display: flex; 
    align-items: center;
    flex-direction: column;
}




/* Modal overlay */
.modal {
  display: none; /* Hidden by default */
  position: fixed;
  z-index: 1000; /* Ensure it appears on top */
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.8);
  animation: fadeIn .3s;
}

.modal.show {
  display: block; /* Show the modal */
}

/* Modal content */
.modal-content {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transform-origin: center;
  background-color: #1a1a1a;
  padding: 32px;
  box-shadow: 0 5px 15px rgba(0,0,0,0.3);
  width: auto;
  height: auto;
  overflow: visible;
  border-radius: 16px;
}

/* Modal content when modal is open */
.modal.show .modal-content {
  opacity: 1; /* Fade in */
  transform: translate(-50%, -50%) scale(1); /* Scale up to full size */
}

.close {
  color: #bababa;
  position: absolute;
  top: 10px;
  right: 15px;
  font-size: 28px;
  font-weight: bold;
  cursor: pointer;
  text-decoration: none;
}

.close:hover,
.close:focus {
  color: #ec7dc2;
  text-decoration: none;
}

.modal.show .close {
  display: block;
}

/* Keyframes for fade-in animation */
@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

/* Disable background scrolling when modal is open */
body.modal-open {
  overflow: hidden;
}

.modal-page-content-container {
  width: 100%;
  display: block; /* Use block display to prevent flex issues */
  overflow: auto;
  padding-top: 24px;
  max-width: 960px;
}

.modal-page-image-container {
  flex: 1;   
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  border-radius: 16px;
  
}

/* Default image styles */
.modal-page-image-container img {
  width: 100%;
  height: auto;
  display: block;
  min-width:800px;
}


@media (max-width: 1024px) {
  /* Adjust modal-content */
  .modal-content {
    max-width: 90%;    /* Limit modal width to 90% of viewport */
    max-height: 90vh;  /* Limit modal height to 90% of viewport height */
    overflow: hidden;  /* Hide overflow */
  }

  /* Make image responsive */
  .modal-page-image-container img {
    min-width: 80vw;       /* Scale image to fit container */
    height: auto;      /* Maintain aspect ratio */
  }
}


.modal-extra-page-content-container {
  width: 100%;
  display: block; /* Use block display to prevent flex issues */
  overflow: hidden;
  padding-top: 24px;
  max-width: 960px;
  display: flex;
  min-width: 300px;
}

.modal-extra-left-image {
    margin-right: 24px;
    width: 200px;
}

.modal-extra-left-image img {
    width: 200px;
    height: 200px;
    margin-right: 40px;
    border-radius: 50%;
}


.modal-extra-right-text {
    flex:1;
    color: #dadada;
    font-size: 14px; 
    font-family: Public Sans, Helvetica, sans-serif;
    font-weight: 400;
    line-height: 20px;
    word-wrap: break-word;
}

.modal-extra-right-text p {
    margin-top: 8px;
}

@media (max-width: 1024px) {

  .modal-extra-left-image img {
    width: 120px;
    height: 120px;
}

  .modal-extra-page-content-container {
    flex-direction: column;
    align-items: flex-start;
    min-width: 300px;
  }

  .modal-extra-left-image {
    margin-right: 0;
    margin-bottom: 10px;
    align-self: center;
    width: 120px;
  }

  .modal-extra-right-text {
    color: #dadada;
    font-size: 12px; 
    font-family: Public Sans, Helvetica, sans-serif;
    font-weight: 400;
    line-height: 18px;
    word-wrap: break-word;
  }
}

.goat-link {
    color: #63bdde; 
    text-decoration: none;
}

.goat-link:hover{
    color: #63bdde; 
    text-decoration: underline;
}

.goat-link:visited {
    color: #63bdde; 
    text-decoration: underline;
}

.email-large {
    font-size: 20px;
    font-weight: 300;
}



.modal-page-text-container {
    width: 100%;
}

.modal-hero-company-name {
    flex: 1 1 0;
    align-self: stretch; 
    
    justify-content: flex-start; 
    align-items: flex-start;
    display: block;
    color: #FAFAFA; 
    font-size: 14px; 
    font-family: Public Sans, Helvetica, sans-serif;
    font-weight: 600;
    line-height: 22px;
    word-wrap: break-word;
    margin-top: 20px;
    width: 100%;
}

.modal-hero-year {
    flex: 1 1 0;
    align-self: stretch; 
    justify-content: flex-start; 
    align-items: flex-start;
    display: block;
    color: #bababa; 
    font-size: 14px; 
    font-family: Public Sans, Helvetica, sans-serif;
    font-weight: 400;
    line-height: 22px;
    word-wrap: break-word;
    width: 100%;
    margin-bottom: 8px;

}

.modal-hero-details-header {
    flex: 1 1 0;
    align-self: stretch; 
    justify-content: flex-start; 
    align-items: flex-start;
    display: block;
    color: #FAFAFA; 
    font-size: 14px; 
    font-family: Public Sans, Helvetica, sans-serif;
    font-weight: 600;
    line-height: 22px;
    word-wrap: break-word;
}

.modal-hero-details-text {
    flex: 1 1 0;
    align-self: stretch; 
    justify-content: flex-start; 
    align-items: flex-start;
    display: block;
    color: #bababa; 
    font-size: 14px; 
    font-family: Public Sans, Helvetica, sans-serif;
    font-weight: 400;
    line-height: 22px;
    word-wrap: break-word;
    width: 100%
}






/* Project Page Styles */

.project-hero-title {
    align-self: stretch; 
    padding-bottom: 24px;
    padding-right: 12px; 
    justify-content: flex-start; 
    align-items: flex-start; 
    display: inline-flex;
    flex: 1 1 0;
    color: #FAFAFA; 
    font-size: 24px;
    font-family: Public Sans, Helvetica, sans-serif; 
    font-weight: 600; 
    line-height: 28px; 
    letter-spacing: 0.24px; 
    word-wrap: break-word;
}

.project-hero-image-container {
    width: 100%;
    flex-direction: column; 
    justify-content: flex-start; 
    align-items: flex-start;
    display: inline-flex;
    overflow: hidden; /* Hide the overflow to avoid seeing the zoomed-out parts */
    border-radius: 16px;
}

.project-hero-company-name {
    flex: 1 1 0;
    align-self: stretch; 
    padding-bottom: 8px; 
    justify-content: flex-start; 
    align-items: flex-start;
    display: block;
    color: #FAFAFA; 
    font-size: 16px; 
    font-family: Public Sans, Helvetica, sans-serif;
    font-weight: 600;
    line-height: 22px;
    word-wrap: break-word;
    margin-top: 40px;
    width: 100%;
}

.project-hero-year {
    flex: 1 1 0;
    align-self: stretch; 
    justify-content: flex-start; 
    align-items: flex-start;
    display: block;
    color: #bababa; 
    font-size: 16px; 
    font-family: Public Sans, Helvetica, sans-serif;
    font-weight: 400;
    line-height: 24px;
    word-wrap: break-word;
    width: 100%;
    margin-bottom: 20px;

}

.project-hero-brief-header {
    flex: 1 1 0;
    align-self: stretch; 
    padding-bottom: 8px; 
    justify-content: flex-start; 
    align-items: flex-start;
    display: block;
    color: #FAFAFA; 
    font-size: 16px; 
    font-family: Public Sans, Helvetica, sans-serif;
    font-weight: 600;
    line-height: 22px;
    word-wrap: break-word;
}

.project-hero-brief-text {
    flex: 1 1 0;
    align-self: stretch; 
    justify-content: flex-start; 
    align-items: flex-start;
    display: block;
    color: #bababa; 
    font-size: 16px; 
    font-family: Public Sans, Helvetica, sans-serif;
    font-weight: 400;
    line-height: 24px;
    word-wrap: break-word;
    width: 100%;
    margin-bottom: 20px;

}

.project-hero-details-header {
    flex: 1 1 0;
    align-self: stretch; 
    padding-bottom: 8px; 
    justify-content: flex-start; 
    align-items: flex-start;
    display: block;
    color: #FAFAFA; 
    font-size: 16px; 
    font-family: Public Sans, Helvetica, sans-serif;
    font-weight: 600;
    line-height: 22px;
    word-wrap: break-word;
}

.project-hero-details-text {
    flex: 1 1 0;
    align-self: stretch; 
    justify-content: flex-start; 
    align-items: flex-start;
    display: block;
    color: #bababa; 
    font-size: 16px; 
    font-family: Public Sans, Helvetica, sans-serif;
    font-weight: 400;
    line-height: 24px;
    word-wrap: break-word;
    width: 80%;
    margin-bottom: 48px;
}

.project-content-title {
    flex: 1 1 0;
    align-self: stretch; 
    padding-bottom: 8px; 
    justify-content: flex-start; 
    align-items: flex-start;
    display: block;
    color: #FAFAFA; 
    font-size: 20px; 
    font-family: Public Sans, Helvetica, sans-serif;
    font-weight: 600;
    line-height: 22px;
    word-wrap: break-word;
}

.project-content-text {
    flex: 1 1 0;
    align-self: stretch; 
    justify-content: flex-start; 
    align-items: flex-start;
    display: block;
    color: #bababa; 
    font-size: 16px; 
    font-family: Public Sans, Helvetica, sans-serif;
    font-weight: 400;
    line-height: 24px;
    word-wrap: break-word;
    width: 80%;
    margin-bottom: 32px;
}

.project-hero-container {
    border-bottom: 1px solid #3a3a3a;
    width: 100%;
}

.project-content-container {


}

.project-image-container {
    width: 100%;
    flex-direction: column; 
    justify-content: flex-start; 
    align-items: flex-start;
    display: inline-flex;
    overflow: hidden; /* Hide the overflow to avoid seeing the zoomed-out parts */
    border-radius: 16px;
    margin-top: 12px;
    margin-bottom: 40px;
}

.main-content-container-project {
    width: 1280px; 
    flex-direction:column; 
    justify-content: flex-start;
    align-items: flex-start;
    gap: 48px;
    margin-top: 64px;
    display: inline-flex;
}


.back-to-home a {
    color: #63bdde; 
    font-size: 16px; 
    font-family: Public Sans, Helvetica, sans-serif; 
    font-weight: 400; 
    line-height: 14px; 
    letter-spacing: 0.12px; 
    word-wrap: break-word;
    text-decoration: none;
}

.back-to-home a:hover {
    color: #63bdde; 
    font-size: 16px; 
    font-family: Public Sans, Helvetica, sans-serif; 
    font-weight: 400; 
    line-height: 14px; 
    letter-spacing: 0.12px; 
    word-wrap: break-word;
    text-decoration: underline;
}


/* Footer */

.page-footer {
    width: 100%;
    margin-bottom: 40px;
    border-top: 1px solid #3a3a3a;
    padding-top: 40px;
    flex: 1 1 0;
    align-self: stretch; 
    justify-content: flex-start; 
    align-items: flex-start;
    display: inline-flex;
    color: #bababa; 
    font-size: 12px; 
    font-family: Public Sans, Helvetica, sans-serif;
    font-weight: 400;
    line-height: 24px;
    word-wrap: break-word;
}


.other-work-container {
    width: 100%;
    margin-top: 40px;
}

.other-work-title {
    flex: 1 1 0;
    align-self: stretch; 
    padding-bottom: 16px; 
    justify-content: flex-start; 
    align-items: flex-start;
    display: inline-flex;
    color: #FAFAFA; 
    font-size: 16px; 
    font-family: Public Sans, Helvetica, sans-serif;
    font-weight: 600;
    line-height: 22px;
    word-wrap: break-word;
}

@media (max-width: 640px) {
    .other-work-title {
        padding-top: 0px;
    }
}

/* Image Grid Styles */
.image-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 12px;
  max-width: 1280px;
  margin: 0 auto;
  padding-bottom: 40px;
}

.image-item {
    overflow: hidden;
  border-radius: 4px;
}

.image-item:hover .image-item-image{
    transform: scale(1.05);
}

.image-item-image {
  width: 100%;
  height: auto;
  display: block;
  cursor: pointer;
  align-self: stretch;
  width: 100%; /* Ensure the image fits the container */
  height: auto; /* Maintain the aspect ratio */
  transition: transform 0.5s ease;
}


/* Position the image wrapper relative */
.image-wrapper {
  position: relative;
}

/* Ensure the image fills its container */
.image-wrapper {
  width: 100%;
  display: block;
  overflow: hidden;
  border-radius: 8px;
}

/* Style the overlay label */
.image-label {
  display: none;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  background-color: rgba(0, 0, 0, 0.7);
  color: #fff; /* White text */
  padding: 12px;
  box-sizing: border-box;
  font-size: 12px; 
  font-family: Public Sans, Helvetica, sans-serif;
  font-weight: 400;
}


.image-item:hover .image-label {
    display: block;
}



/* Ensure the Swiper container fills the modal */
.modal-content .swiper {
  width: 100%;
  height: 100%;
}

.swiper-wrapper {
    border-radius: 0px;
}


/* Style the slides */
.swiper-slide img {
  width: 100%;
  height: auto;
  display: block;
  min-width:800px;
}

/* Adjust navigation buttons and pagination (optional) */
.swiper-button-next,
.swiper-button-prev {
  color: #fff; /* Adjust color as needed */
  width: 16px;
}

.swiper-pagination-bullet-active {
  background-color: #fff; /* Active pagination bullet color */
}

/* Customize the navigation buttons */

/* Base styles for both buttons */
.swiper-button-next,
.swiper-button-prev {
  width: 32px;
  height: 32px;
  border-radius: 32%; /* Make buttons circular */
  background-color: rgba(0, 0, 0, 0.2); /* Semi-transparent background */
}

/* Specific styles for the next button */
.swiper-button-next {
  right: 8px; /* Position from the right */
}

/* Specific styles for the previous button */
.swiper-button-prev {
  left: 8px; /* Position from the left */
}

/* Hover effects */
.swiper-button-next:hover,
.swiper-button-prev:hover {
  background-color: rgba(0, 0, 0, 0.4); /* Darken on hover */
}

/* Adjust the arrow icons */
.swiper-button-next::after,
.swiper-button-prev::after {
  font-size: 16px; /* Adjust icon size */
  color: #fff;
  line-height: 16px;
}

/* Customize the pagination bullets */

/* Base styles for the pagination container */
.swiper-pagination {
  text-align: center;
}

/* Base styles for bullets */
.swiper-pagination-bullet {
  width: 8px;
  height: 8px;
  background-color: rgba(0, 0, 0, 0.6); /* Semi-transparent white */
  opacity: 1; /* Ensure bullets are fully opaque */
  margin: 0 4px; /* Spacing between bullets */
  border-radius: 50%; /* Make bullets circular */
}

/* Active bullet */
.swiper-pagination-bullet-active {
  background-color: #63bdde; /* Solid white for active bullet */
}

@media (max-width: 600px) {
  /* Adjust button size on smaller screens */
  .swiper-button-next,
  .swiper-button-prev {
    display: none;
  }
}


@media (max-width: 1024px) {
  /* Adjust modal-content */
  .modal-content {
    max-width: 80%;    /* Limit modal width to 90% of viewport */
    max-height: 80vh;  /* Limit modal height to 90% of viewport height */
    overflow: hidden;  /* Hide overflow */
  }

  /* Make image responsive */
  .swiper-slide img {
    min-width: 80vw;       /* Scale image to fit container */
    height: auto;      /* Maintain aspect ratio */
  }
}






















/* Mobile Styles */

@media (max-width: 1280px) {
    .main-content-container, .main-content-container-project {
        margin-left: 40px;
        margin-right: 40px;
    }

    .supporting-text-container {
        padding-right: 0px;
    }
}


@media (max-width: 1024px) {
    
    body {
        display: block;
        padding: 0 32px;
    }

    .main-content-container,
    .main-content-container-project {
        width: 100%;
        margin-top: 36px;
        margin-left: 0px;
        margin-right: 0px;
    }

    .top-content-container {
        display: block;
        margin-bottom: 0px;
    }

    .top-content-left-container,
    .top-content-right-container {
        width: 100%;
        margin-bottom: 20px;
    }

    .logo-container,
    .name-container,
    .links-container,
    .greeting-container,
    .supporting-text-container {
        align-items: center;
        text-align: left;
        padding-right: 0px;
    }

    .logo-container,
    .name-container,
    .links-container {
        padding-left: 0px;
    }

    .supporting-text-secondary-container {
        text-align: left; 
        margin-top: 20px; 
        width: 100%; 
    }

    .main-content-module {
        width: 100%;
        flex-direction: column; 
        align-items: cs; 
        padding-bottom: 20px;
    }

    .main-content-module-left {
        width: 100%; 
        text-align: left;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        padding-left: 0px;
    }

    .main-content-module-left-title {
        font-size: 14px;
        margin-bottom: 0px;
        padding-bottom: 0px;
    }

    
    .main-content-module-left-info {
        display: flex; 
        align-items: center;
        flex-direction: row;
        padding-bottom: 8px;
        padding-top: 4px;
    }

    .main-content-module-left-company-name {
        display: inline-block; 
        font-size: 12px; 
        margin-right: 10px; 
        padding-top: 0px;
        border-right: 1px solid #3a3a3a;
        padding-right: 8px;
    }

    .main-content-module-left-year {
        display: inline-block; 
        font-size: 12px; 
        margin-right: 10px; 
        padding-top: 0px;
        padding-right: 8px;
    }

    .main-content-module-right-image-container {
        width: 100%; 
        padding: 0;
    }

    .main-content-module-left-divider {
        visibility: hidden;
    }

    .main-image {
        width: 100%; /
        height: auto; 
        border-radius: 8px;
    }

    a:hover .main-content-module-left-company-name {
    border-right: 1px solid #7a7a7a;
    }

    .project-content-text, .project-hero-details-text {
        width: 100%;
    }
}

@media (max-width: 480px) {
    
    .links-container-value a {
        font-size: 14px;
    }

    .greeting-container-value,
    .supporting-text-primary-value,
    .supporting-text-secondary-value {
        font-size: 16px;
        line-height: 1.5;
    }
}
