@import url('https://fonts.googleapis.com/css2?family=Syncopate:wght@400;700&display=swap');

/*======================================================================
Formatting of Header begin
========================================================================*/
header.container-header {
    display: flex;
    align-items: center;   /* vertical alignment */
    justify-content: space-between; /* logo left, menu right */
}

header.header.container-header.full-width > .grid-child {
  width: auto;
}

.nav-item {
  font-size: 1.5rem;
  font-family: "Syncopate", sans-serif;
  font-weight: 400;
  font-style: normal;
  color: rgb(255,255,255);
}

/*======================================================================
Formatting of Header end
========================================================================*/

/*======================================================================
Formatting of Gallery begin
========================================================================*/
/* ===== Gallery container ===== */
.buildings .category-buildings .com-content-category-blog {
    padding: 1rem;
}

.buildings .image-wrapper{
  height: 250px;
}

/* ===== Items grid ===== */
.buildings .category-buildings .com-content-category-blog__items {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 1rem;
}

/* ===== Individual gallery item ===== */
.buildings .gallery-item {
    display: block;
    position: relative;
    overflow: hidden;
    cursor: pointer;
    height: 250px; /* Adjust as needed */
}

/* ===== Image styling ===== */
.buildings .gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.3s ease, filter 0.3s ease;
}

/* ===== Overlay styling ===== */
.buildings .overlay {
    position: absolute;
    top: 0; left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,0.5);
    opacity: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: opacity 0.3s ease;
}

.buildings .overlay-text {
    color: #fff;
    font-size: 1.2rem;
    text-align: center;
    padding: 0 0.5rem;
}

/* ===== Hover effects ===== */
.buildings .gallery-item:hover img {
    filter: grayscale(100%);
    transform: scale(1.05);
}

.buildings .gallery-item:hover .overlay {
    opacity: 1;
}

/* ===== Responsive adjustments ===== */
@media (max-width: 768px) {
    .buildings .com-content-category-blog__items {
        grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
        gap: 0.5rem;
    }

    .buildings .gallery-item {
        height: 180px;
    }

    .buildings .overlay-text {
        font-size: 1rem;
    }
}

/*======================================================================
Formatting of Gallery end
========================================================================*/

/*======================================================================
Formatting of Buildings Articles slideshow Begin
========================================================================*/
.project-slideshow {
    position: relative;
}

.project-slideshow .slideshow-track {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    min-height: 300px;
}

.project-slideshow .slide {
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity 0.5s ease;
    overflow: hidden;
}

.project-slideshow .slide .bg-blur {
    position: absolute;
    inset: -20px; /* slightly overflow to avoid blur edges */
    background-size: cover;
    background-position: center;
    filter: blur(20px) brightness(0.6);
    transform: scale(1.05);
}

.project-slideshow .slide.active {
    opacity: 1;
    z-index: 1;
}

.project-slideshow .slide img {
    position: relative;
    width: 100%;
    height: 100%;
    object-fit: contain;
    z-index: 1;
}



.project-slideshow .slideshow-track .slide-btn {
    position: absolute;
    top: calc(50% - 30px);
    transform: none;
    height: 60px;
    width: 60px;

    display: flex;
    align-items: center;
    justify-content: center;

    background: rgba(0, 0, 0, 0);
    border: none;

    opacity: 0;
    transition: opacity 0.3s ease, background 0.3s ease;

    font-size: 2rem;
    color: rgba(255,255,255,0.9);
    border-radius: 15px;
    padding-bottom: 8px;
}

.project-slideshow .slideshow-track .slide-btn.prev {
    left: 20px;
    background: linear-gradient(to right, rgba(0,0,0,0.25), transparent);
}

.project-slideshow .slideshow-track .slide-btn.next {
    right: 20px;
    background: linear-gradient(to right, rgba(0,0,0,0.25), transparent);
}
.project-slideshow:hover .slideshow-track .slide-btn {
    opacity: 1;
    z-index: 10;
    background: rgba(0,0,0,0.4);
}

.project-slideshow .slide-counter {
    text-align: center;
    margin-top: 0.5rem;
    color: #666;
    font-size: 0.9rem;
}

/*======================================================================
Formatting of Buildings Articles slideshow End
========================================================================*/

/*======================================================================
Formatting of Services Begin
========================================================================*/
/*===== Contact module at the bottom ===== */
.contact {
  /* ===== Remove Padding from container (card-body) ===== */
  .card-body{
    padding: 0;
  }
  /* ===== CTA full-width block ===== */
  .cta-module {
      min-height: 300px;
      background-color: #f0f0f0; /* or use background-image */
      display: flex;
      align-items: center;
      justify-content: center;
  }

  /* ===== Inner alignment ===== */
  .cta-inner {
      text-align: center;
      max-width: 800px;
      padding: 2rem;
  }

  /* ===== Text ===== */
  .cta-text {
      font-size: 1.4rem;
      margin-bottom: 1.5rem;
  }

  /* ===== Button ===== */
  .cta-btn {
      display: inline-block;
      padding: 0.75rem 2rem;
      background: #000;
      color: #fff;
      text-decoration: none;
      font-weight: 600;
  }

  /* ===== Optional hover ===== */
  .cta-btn:hover {
      background: #333;
  }
}

/* ===== Alternating article layout ===== */
.services .com-content-category-blog__items {
    display: block;
    margin-bottom: 0;
}

.services .com-content-category-blog__item.blog-item {
    display: block;
}

.services .service-item {
    display: flex;
    gap: 2rem;
    align-items: stretch;
    min-height: 300px;
    margin-bottom: 3rem;
}

/* ===== Reverse every second article  ===== */
.services .com-content-category-blog__item.blog-item:nth-child(even) .service-item {
    flex-direction: row-reverse;
}

/*  ===== Image sizing  ===== */
.services .image-wrapper {
    flex: 0 0 35%;
    overflow: hidden; 

    position: relative;
}

.services .image-wrapper img {
    position: absolute; /*image size is not supposed to affect container size, so that the container scales only with the text */
    inset: 0;
  
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    border-radius: 5pt;
}

/*  ===== Text column  ===== */
.services .service-text {
    flex: 1;
}

@media (max-width: 768px) {
    .service-item {
        flex-direction: column;
        min-height: auto;
    }

    .services .com-content-category-blog__item.blog-item:nth-child(even) .service-item {
        flex-direction: column;
    }

    .image-wrapper {
        min-height: 200px;
    }
}

/*======================================================================
Formatting of Services end
========================================================================*/
/*======================================================================
Formatting of Footer begin
========================================================================*/
/*
stacks footer items vertically instead of default horizontal stacking
*/
footer.container-footer.footer.full-width > .grid-child {
    display: block  
}

footer.container-footer.footer.full-width > .grid-child > .mod-custom,
footer.container-footer.footer.full-width > .grid-child > .mod-menu {
    width: 100% 
    margin-bottom: 1rem;
    text-align: center;
}
@media (max-width: 768px) {
    /*
    stacks footer items vertically instead of default horizontal stacking
    */
    footer.container-footer.footer.full-width > .grid-child > .mod-custom,
    footer.container-footer.footer.full-width > .grid-child > .mod-menu {
    width: 100% !important;
    margin-bottom: 1rem;
    text-align: center;
}
}

/*======================================================================
Formatting of Footer end
========================================================================*/