/*
Theme Name: Hello Elementor Child
Theme URI: https://elementor.com/hello-theme/?utm_source=wp-themes&utm_campaign=theme-uri&utm_medium=wp-dash
Template: hello-elementor
Author: Elementor Team
Author URI: https://elementor.com/?utm_source=wp-themes&utm_campaign=author-uri&utm_medium=wp-dash
Description: Hello Elementor is a lightweight and minimalist WordPress theme that was built specifically to work seamlessly with the Elementor site builder plugin. The theme is free, open-source, and designed for users who want a flexible, easy-to-use, and customizable website. The theme, which is optimized for performance, provides a solid foundation for users to build their own unique designs using the Elementor drag-and-drop site builder. Its simplicity and flexibility make it a great choice for both beginners and experienced Web Creators.
Tags: accessibility-ready,flexible-header,custom-colors,custom-menu,custom-logo,featured-images,rtl-language-support,threaded-comments,translation-ready
Version: 3.4.4.1756904823
Updated: 2025-09-03 13:07:03

*/

/* *{
    font-family: 'Montserrat', sans-serif!important;
} */

/* .portfolio-listing{
    display:none;
} */
.embed-wrapper {
    width: 100%;
    height: 496px;
    overflow: hidden;
}

.embed-wrapper iframe {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border: none;
}

/* change text  */
.category-heading {
    position: relative;
    height: 150px;
    /* ensure fixed height to prevent layout jump */
    overflow: hidden;
    padding: 100px 56px;
}

.category-heading h2 {
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    margin: 20px 56px;
    font-size: 115px;
    font-family: "Amita";
    font-weight: 400;
    transition: transform 1s ease, opacity 1s ease;
    white-space: nowrap;
}

.category-heading h2.slide-out {
    transform: translateY(-150%);
    opacity: 0;
}

.category-heading h2.slide-in {
    transform: translateY(150%);
    opacity: 0;
}

.category-heading h2.visible {
    transform: translateY(-50%);
    opacity: 1;
}

/* change text  */
.category-sublime {
    position: relative;
    /* height: 150px; */
    /* ensure fixed height to prevent layout jump */
    overflow: hidden;
    padding: 0 56px;
}



/* Animation classes */
.portfolio-item {
    transition: opacity 0.5s ease, transform 0.5s ease;
    opacity: 1;
    transform: scale(1);
    display: block;
}

.portfolio-item.fade-out {
    opacity: 0;
    transform: scale(1);
}

.portfolio-item.hidden {
    display: none !important;
}

/* Animation classes end*/
.portfolio-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 40px 20px;
    max-width: 100%;
    margin: 80px 56px;
    justify-content: center;
}

.portfolio-item {
    text-decoration: none;
    color: inherit;
    display: block;
    height: auto;
    transition: all 0.3s ease;
}

.portfolio-item video,
.portfolio-item img {
    width: 100%;
    height: 496px;
    display: block;
    object-fit: cover;
}

.portfolio-item h2 {
    color: black;
    padding: 5px 0px;
    font-size: 18px;
    margin: 0;
}

.portfolio-item.half-width {
    flex: 0 0 49.3%;
}

.portfolio-item.full-width {
    flex: 0 0 70%;
    justify-content: center;
}

/* filter css */
.portfolio-filters {
    text-align: left;
    margin-bottom: 40px;
    margin: 0px 56px;
    border-bottom: 1px solid #000;
}

.portfolio-filters {
    position: sticky !important;
    top: 0px;
    padding-top: 115px;
    z-index: 9;
    background-color: #fff;
}

.filter-list {
    list-style: none;
    padding: 0;
    margin: 0;
    gap: 20px;
    justify-content: center;
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;

}

.filter-list .filter-button {
    font-size: 16px;
    color: #999;
    padding: 10px 0;
    position: relative;
    cursor: pointer;
    transition: color 0.3s;
}

.filter-button {
    cursor: pointer;
    font-size: 14px;
    font-weight: 400;
    color: #555;
    transition: all 0.3s ease;
    white-space: nowrap;
    /* Prevent line break inside */
}

.filter-button.active {
    font-weight: 600;
    color: #000;
}

.filter-button:hover {
    color: #000;
}

/* Optional tweak for very small screens */
@media (max-width: 480px) {
    .filter-list {
        gap: 10px 20px;
        justify-content: flex-start;
    }

    .filter-button {
        font-size: 13px;
    }
}

@media (max-width: 1548px) {

    .portfolio-item.half-width,
    .portfolio-item.full-width {
        flex: 0 0 100%;
    }

    .portfolio-item.half-width {
        flex: 0 0 48.3% !important;
    }

    .portfolio-grid {
        margin: 80px 20px;
        padding-top: 20px;
    }

    .portfolio-filters {
        margin: 0px 20px;
        padding-top: 120px;
    }

    .filter-list .filter-button {
        font-size: 13px;
    }

    .category-heading h2 {
        font-size: 65px;
        font-family: "Amita";
        position: relative;
        margin: 0;
        justify-content: start;
        display: flex;
    }

    .category-heading {
        padding: 30px 20px;
    }
}


@media (max-width: 768px) {

    .portfolio-item.half-width,
    .portfolio-item.full-width {
        flex: 0 0 100% !important;
    }

    .portfolio-grid {
        margin: 80px 20px;
    }

    .portfolio-filters {
        margin: 0px 20px;
        padding: 90px 0px 0px 0px;
        width: 91%;
    }

    .filter-list .filter-button {
        font-size: 13px;
    }

    .category-heading h2 {
        font-size: 48px;
        font-family: "Amita";
        position: relative;
        margin: 0;
        justify-content: Start;
        display: flex;
        white-space: break-spaces;
    }

    .category-heading {
        padding: 30px 20px 0px 20px;
    }
}

.video-container {
position: relative;
z-index: 1;
overflow: hidden;
}

.single-portfolio .content p {
    color: #fff;
}

/* Top Blur */
/* .video-container::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
height: 100px;
pointer-events: none;
background: linear-gradient(to bottom, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0) 100%);
z-index: 2;
} */

/* Bottom Blur */
/* .video-container::after {
content: '';
position: absolute;
bottom: 0;
left: 0;
right: 0;
height: 100px;
pointer-events: none;
background: linear-gradient(to top, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0) 100%);
z-index: 2;
} */
/* menu  */
/* Hide default icon */
.elementor-menu-toggle svg {
display: none !important;
}

/* Default button text */
.elementor-menu-toggle::before {
content: "";
font-size: 18px;
display: none;
cursor: pointer;
transition: color 0.3s ease;
}

/* When menu is open */
.elementor-menu-toggle.menu-open::before {
content: "";
}

/* Light background = black text */
.elementor-menu-toggle.light-bg::before {
color: #000;
}

/* Dark background = white text */
.elementor-menu-toggle.dark-bg::before {
color: #fff;
}

/*end menu  */

/* animation css for frontpage scroll effect */
.videosection {
position: relative;
height: 100vh;
overflow: hidden;
z-index: 1;
}

.videosection + .videosection {
margin-top: 0;
}

.textheading {
font-size: 3rem;
color: #fff;
position: relative;
bottom: 0;
z-index: 2;
text-align: left;
}
/* end */
.heading-hover-animation:hover{
letter-spacing:5px
}
.portfolio-posts .elementor-posts-container {
display: grid !important;
grid-template-columns: repeat(2, 1fr);
gap: 30px;
}

.portfolio-posts .elementor-post {
width: 100%;
}

.portfolio-posts .elementor-post:nth-child(3n) {
grid-column: 1 / -1 !important;
width: 100% !important;
}
/* mobile header */
nav.elementor-nav-menu--dropdown.elementor-nav-menu__container{
height:110vh;

}

/* homepage animation */
:root {
    --sticky-height: 100vh;
    --section-height: calc(var(--sticky-height) + 85vh);
    --content-top: var(--sticky-height);
    --content-height: calc(var(--section-height) - var(--sticky-height));
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

.section-wrapper {
    position: relative;
    height: var(--section-height);
}

.video-container {
    position: sticky;
    top: 0;
    height: var(--sticky-height);
    overflow: hidden;
}

.video-container video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    pointer-events: none;
}

.contenttext {
    position: absolute;
    top: 120vh;
    height: var(--content-height);
    height: 50vh;
    width: 100%;
    display: flex;
    align-items: start;
    justify-content: flex-start;
    z-index: 2;
}

.contenttext h2 {
    color: white;
    font-size: 85px;
    max-width: 95%;
        width:100%;
    padding: 20px;
        line-height: 110px;
}


.contenttextfirst {
    position: absolute;
    bottom: 0;
    height: var(--content-height);
    width: 100%;
    display: flex;
    align-items: start;
    justify-content: flex-start;
    z-index: 2;
}

.contenttextfirst h2 {
    color: white;
    font-size: 85px;
    max-width: 95%;
        width:100%;
    padding: 20px;
        line-height: 110px;
}

@media screen and (min-width: 768px) and (max-width: 1158px) {
  :root {
    --sticky-height: 90vh; /* slightly less to avoid white space */
    --section-height: calc(var(--sticky-height) + 85vh);
    --content-top: var(--sticky-height);
    --content-height: calc(var(--section-height) - var(--sticky-height));
  }

  .content h2 {
    font-size: 50px; /* scale down a bit for mid-size screens */
  }
}

.video-container {
  background-color: black; /* prevents white flash if video loads slow */
}

/* frontpage video blur */

.single-portfolio .ekit-template-content-footer {
    display: none;
}
