:root {
    --primary-color: #449DD7;
    --secondary-color: #707070;
    --tertiary-color: #2C2C2C;
    --quaternary-color: #F2F2F2;
    --white-color: #ffffff;
    --black-color: #000000;
    --red-color: #E21A1A;
    --yellow-color: #F2C94C;
    --drk-red-color: #6F260B;
    --blue-gray-color: #566D7D;
    --orange-color: #DD6000;
    --light-gray-color: #F0F0F0;
    --off-white-color: #D9D9D9;
}

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

body {
    font-family: "Nunito Sans", sans-serif;
    font-weight: 400;
    color: var(--tertiary-color);
    font-size: 18px;
    font-optical-sizing: auto;
    line-height: 1.6;
    background-image: url('../img/desktop-background-homepage.jpg');
    background-size: 100%;
    background-position: top;
}
.overflowHidden{
    overflow: hidden;
}
@media (max-width: 992px){
    .container, .container-md, .container-sm{
        max-width: 830px;
    }
    .navbar-expand-lg .navbar-toggler{
        display: flex !important;
    }
    .collapse:not(.show){
        display: flex !important;
        width:100%;
        justify-content: center;
    }
    ul.navbar-nav.ms-auto{
        margin: 0!important;
        display: flex;
        flex-direction: row;
    }
    
}
@media (max-width: 768px) {
    .container, .container-md, .container-sm{
        max-width: 830px;
    }
    .menu {
        width: 30px;
        height: 25px;
        cursor: pointer;
        position: relative;
    }
    .menu span {
        background: black;
        position: absolute;
        height: 4px;
        width: 100%;
        left: 0;
        transition: 0.4s;
    }
    .menu span:nth-child(1) { top: 0; }
    .menu span:nth-child(2) { top: 10px; }
    .menu span:nth-child(3) { top: 20px; }
    
    .menu.open span:nth-child(1) {
        transform: rotate(45deg);
        top: 10px;
    }
    .menu.open span:nth-child(2) {
        opacity: 0;
    }
    .menu.open span:nth-child(3) {
        transform: rotate(-45deg);
        top: 10px;
    }
    .menu:focus-visible {
        border: 0;
        outline: navajowhite;
    }
    .navbar-toggler:focus{

    }
    .navbar-toggler:focus:not(:focus-visible) {
        outline: 0;
        border: 0;
        box-shadow: none;
    }
    .navbar-collapse {
        flex-basis: 100%;
        flex-grow: 1;
        align-items: center;
        position: fixed;
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
        display:flex;
        justify-content: center;
        align-items: center;
        flex-direction: column; 
        background: var(--white-color);
        z-index: 1;
    }
    ul.navbar-nav.ms-auto{
        margin: 0 !important;
        width: 80%;
        text-align: center;
        gap: 0;
        flex-direction: column;
    }
    .navbar-nav li.nav-item {
        padding: 12px;
        border-bottom: 1px solid #D9D9D9;
    }
    .collapse:not(.show){
        display:none !important;
    }
    .collapse.show{
        display: flex!important;
    }
}
.home-page nav.navbar {
    padding-top: 36px;
}
.home-page .navbar-brand{
padding:0;
margin:0;
margin-top:25px;


}
.site-logo {
    width: 236px;
    height: 107px;
}

.modal-dialog .modal-content .modal-header {
    border: 0;
    display: flex;
    flex-direction: column;
}

.modal-dialog .modal-content .modal-header .btn-close {
    position: absolute;
    right: 30px;
    top: 30px;
}

.modal-dialog .modal-content .modal-body {
    margin: 0 auto;
    width: 95%;
}
.navbar-toggler {
    position: absolute;
    right: 15px;
    top: 15px;
    padding: 0;
    border: 0;
    z-index:2;
}
.our-approach-page .hero-banner h1 {
    background: var(--drk-red-color);
    opacity: 0.93;
}

.project-page .hero-banner h1 {
    background: var(--blue-gray-color);
    opacity: 0.93;
}

.our-team-page .hero-banner h1 {
    background: var(--orange-color);
    opacity: 0.93;
}

.our-investor-page .hero-banner h1 {
    background: var(--blue-gray-color);
    opacity: 0.93;
}

.media-page .hero-banner h1,
.contact-page .hero-banner h1 {
    background: var(--red-color);
    opacity: 0.93;
}

@media (min-width: 1441px) {

    .container,
    .container-lg,
    .container-md,
    .container-sm,
    .container-xl,
    .container-xxl {
        max-width: 1370px;
        margin: 0 auto;
        padding: 0 12px;
    }
}


.back-to-top {
    position: fixed;
    bottom: 15px;
    right: 15px;
    background: var(--primary-color);
    color: var(--white-color);
    font-size: 26px;
    border-radius: 45px;
    cursor: pointer;
    padding: 10px;
    line-height: 0;
}

.display-1 {
    font-size: 25px;
    line-height: 30px;
    letter-spacing: 5px;
    font-weight: 700;

}

.subtitle {
    font-family: 'Original Handwriting';
    font-style: italic;
    color: var(--primary-color);
    margin: 30px 0;
    text-align: center;
}

.description .paragraph {
    width: 78%;
    margin-inline: auto;
}
@media (max-width: 675px) {
  .description .paragraph {
        width: 100%;
    }
    .navbar-nav li.nav-item {
        padding: 22px;
        border-bottom: 1px solid #D9D9D9;
    }
    
}

.paragraph {
    font-size: 18px;
    text-align: center;
    margin-bottom: 28px;
}

.tagline {
    font-family: 'Original Handwriting';
    font-style: italic;
    color: var(--primary-color);
    margin: 30px 0;
}

/* Home Page */
header {
    padding-top: 36px;
}


header .logo {
    max-width: 200px;
    margin: 20px auto;
}

header nav ul {
    list-style: none;
    display: flex;
    justify-content: center;
    margin-bottom: 25px;
}

header nav ul li {
    margin: 0 10px;
}

header nav ul li a {
    font-size: 16px;
    font-weight: 400;
    color: var(--secondary-color);
    text-decoration: none;
}

.about-section {
    text-align: center;
}




.about-section .tagline {
    font-size: 28px;
}

.about-section .locations {
    margin: 30px 0 0px;
}

.home-footer {
    text-align: center;
    background-size: cover;
    background-position: top;
    position: relative;
    padding-top: 85px
}

.home-footer .footer-img {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    object-fit: cover;
    width: 100%;
    z-index: -1;
}
@media (max-width: 768px){
    .home-footer{
        padding-top: 0;
    }
    .home-footer .social-links{
        display:none;
    }
    .home-footer .footer-img{
        bottom: 0;
    top: unset;
    }
    .home-footer p{
        padding-bottom: 8rem;
    }
}
@media (max-width: 675px){
    .about-section .locations{
        display: flex;
        flex-direction: column;
            gap: 10px;
            margin: 30px 0 30px;
    }
    .locations .separator-img{
        display: none;
    }
    .container, .container-md, .container-sm{
        max-width: 830px;
        padding: 0 22px;
    }
    .home-footer p{
        padding-bottom: 4rem;
    }
}

/* header2 */
.navbar-nav .nav-item .nav-link {
    color: var(--secondary-color);
    font-size: 16px;
    font-weight: 400;
    text-decoration: none;
    padding: 0;
    margin: 0 12px;
}

.navbar-nav .nav-item.active .nav-link {
    color: var(--primary-color);
}


/* dfad */
.social-links {
    position: fixed;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
    z-index: 1;
}


.locations span {
    display: inline-block;
    margin: 0 15px;
    color: var(--primary-color);
}

.separator {
    color: var(--primary-color);
}

@media (max-width: 768px) {
    body {
        padding: 0;
    }
    navbar {
        padding-top:50px;
    }
    .social-links {
        position: static;
        transform: none;
        margin: 20px auto;
    }

    .social-links a {
        display: inline-flex;
        margin: 0 10px;
    }

    .content {
        padding: 0 15px;
    }
}



/* approach */
.hero-banner-section .hero-banner {
    color: var(--white-color);
    margin-bottom: 20px;
    border-radius: 16px;
    overflow: hidden;
    text-align: center;
    position: relative;
}

.hero-banner-section .hero-banner .banner-img {
    width: 100%;
}
.hero-banner-section .hero-banner .banner-img-mobile {
    display: none;
}

.hero-banner h1 {
    padding: 10px 25px;
    display: inline;
    position: absolute;
    left: 0;
    right: 0;
    margin: auto;
    width: fit-content;
    top: 0;
    bottom: 0;
    height: fit-content;
}

.breadcrumbs {
    text-align: center;
    margin-bottom: 20px;
    font-size: 15px;
}

.breadcrumbs a {
    color: var(--tertiary-color);
    text-decoration: none;
}

.breadcrumbs a.active {
    color: var(--primary-color);
}

.content-section .tagline {
    font-size: 35px;
    text-align: center;
}

.description {
    text-align: center;
}

.separator-img {
    display: flex;
    align-items: center;
    justify-content: center;
    width: auto;
    height: auto;
    text-align: center;
    margin: 0 auto;
    max-width: 100%;
}

.creative-cards-section {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
    gap: 30px;
    margin: 40px 0;

}

.creative-box {
    background-image: url('../img/Creative-bg.png');
    background-size: cover;
    background-position: center;
    border-radius: 16px;
    height: 415px;
}
@media (max-width: 768px) {
    .creative-box{
        background-image: url('../img/Creative-bg-mobile.png');
        height: auto;
        background-position: 44%;
        background-repeat: no-repeat;
        padding: 75px 0;
    }
}
.card-tagline.tagline {
    text-align: center;
    color: var(--white-color);
    height: 71px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 10px;
}

.production-cards-section .tagline {
    color: var(--drk-red-color);
}

.production-cards-section .card {
    color: var(--drk-red-color);
}

.card {
    background: transparent;
    border: 0;
    color: var(--white-color);
    padding: 16px 46px;
    border-radius: 10px;
    min-height: 250px;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

@media (max-width: 1440px) {
    .card {
        padding: 16px 20px;
    }
}

.card img {
    margin-bottom: 14px;
}

.card p {
    line-height: 30px;
}

.card-icon {
    width: 60px;
    height: 60px;
    background: var(--white-color);
    border-radius: 50%;
    margin-bottom: 20px;
}

.social-links {
    position: fixed;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
}

@media (max-width: 768px) {
    .creative-cards-section {
        flex-direction: column;
        align-items: center;
    }

    .card {
        width: 100%;
        max-width: 330px;
    }

    .social-links {
        position: static;
        transform: none;
        margin: 20px auto;
    }

    .social-links a {
        display: inline-flex;
        margin: 0 10px;
    }

}

.production-cards-section {
    color: black;
    margin: 40px 0;
}

.production-box {
    background-image: url('../img/production-bg.png');
    background-size: cover;
    background-position: center;
    border-radius: 16px;
    height: 398px;
}
@media (max-width: 768px) {
    .hero-banner h1{
        font-size:16px;
        padding: 0px 33px;
    }
    .breadcrumbs{
        display: none;
    }
    .production-box {
        background-image: url('../img/Production-banner-mobile.png');
        height: auto;
        padding-bottom: 150px;
        background-color: #fac22e;
    }
}
.financial-cards-section {
    color: var(--white-color);
    margin: 40px 0 78px;
}

.financial-box {
    background-image: url('../img/Financial-bg.png');
    background-size: cover;
    background-position: center;
    border-radius: 16px;
    height: 580px;
}
@media (max-width: 768px) {
    
    .hero-banner-section .hero-banner{
        height: 76px;
        display: flex;
        border-radius: 9px;
        margin-bottom: 0;
    }
    .hero-banner-section .hero-banner .banner-img-mobile {
        display: block;
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    .hero-banner-section .hero-banner .banner-img {
        display: none;
    }
    .financial-cards-section{
        margin: 40px 0 46px;
    }
    .financial-box {
        background-image: url('../img/Financial-banner-mobile.png');
        height: auto;
        padding-bottom: 329px;
        background-position: center;
    }
     .mobile-hide{
        display: none;
     }
     .footer-social{
        justify-content:center !important;
     }
     .copyright{
        justify-content:center;
     }
     .footer-common{
        height: 162px !important;
     }
     .footer-social{
        margin:30px auto;
     }
     .back-to-top{
        display: none;
     }
     body:not(.home-page) .navbar-expand-lg .navbar-toggler{
        display: flex !important;
                top: 0;
                bottom: 0;
                margin: auto;
                height: 25px;
        
     }
     .site-logo{
        width: 148px;
        height: 68px;
     }
     .navbar-brand{
        margin:0;  
     }
 }
.section-title {
    font-size: 2em;
    margin-bottom: 30px;
}

.info-cards {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
    gap: 30px;
    max-width: 1000px;
    margin: 0 auto;
}

.info-card {
    flex: 1;
    min-width: 250px;
    max-width: 400px;
    text-align: center;
    padding: 20px;
}

.info-icon {
    width: 60px;
    height: 60px;
    background: var(--white-color);
    border-radius: 50%;
    margin: 0 auto 20px;
}

@media (max-width: 768px) {
    .info-cards {
        flex-direction: column;
        align-items: center;
    }

    .info-card {
        width: 100%;
    }
}

.footer-common {
    background: var(--light-gray-color);
    height: 110px;
    display: flex;
    align-items: center;
}

.copyright {
    margin: 0;
    display: flex;
    height: 100%;
    align-items: center;
}

.footer-social {
    text-align: right;
}

/* project */

.coming-soon {
    font-size: 35px;
    font-weight: bold;
    color: var(--secondary-color);
    margin: 100px 0 300px;
    letter-spacing: 7px;
    text-align: center;
}

/* out team */
.team-section {
    margin: 40px 0;
}

.team-grid {
    display: flex;
    justify-content: center;
    gap: 30px;
    padding: 20px 0 0;
}

.team-member {
    text-align: center;
}

.member-img {
    width: 312px;
    height: 226px;
    border-radius: 16px;
    object-fit: cover;
    margin-bottom: 15px;
    border: 1px solid var(--off-white-color);
    cursor: pointer;
}

.member-img img {
    width: 100%;
}

@media (max-width: 1440px) {
    .member-img {
        width: 256px;
        height: auto;
    }
}

.member-name {
    font-family: 'Original Handwriting';
    color: var(--primary-color);
    font-size: 30px;
    margin: 10px 0;
    cursor: pointer;
}

@media (max-width: 1440px) {
    .member-name {
        font-size: 24px;
    }
}

.member-title {
    color: #666;
    font-size: 0.9em;
}

.team-grid.deals .team-member .member-img {
    width: 305px;
    height: 158px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.team-grid.deals .team-member .member-img img {
    height: auto;
    width: auto;
}

.social-links {
    position: fixed;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
}

.social-links a {
    display: flex;
    margin: 10px 0;
    color: var(--white-color);
    width: 40px;
    height: 40px;
    border-radius: 50%;
    line-height: 40px;
    text-decoration: none;
    align-items: center;
    justify-content: center;
}

.social-links.footer-social a {
    opacity: 0.5;
    filter: grayscale(1);
}

.social-links.footer-social a.twitter {
    filter: grayscale(0) contrast(0.5);
}

.social-links.footer-social a:hover {
    opacity: 1;
    filter: grayscale(0);
}

.twitter {
    background: #1A1A1A;
}

.facebook {
    background: #154A9E;
}

.instagram {
    background: #CC1E5A;
}

.linkedin {
    background: #3176A2;
}


@media (max-width: 768px) {
    .team-grid {
        gap: 20px;
    }

    .team-member {
        width: 100%;
        max-width: 100%;
    }

    .social-links {
        position: static;
        transform: none;
        margin: 20px auto;
    }

    .social-links a {
        display: inline-flex;
        margin: 0 10px;
    }

    nav a {
        display: block;
        margin: 10px 0;
    }

    .team-grid {
        flex-direction: column;
    }
    
    .member-img {
        width: 100%;
        border-radius: 22px;
    }
    .team-grid.deals .team-member .member-img{
        width: 100%;
    }
    .investor-content.mt-5{
        margin-top:2rem!important;
    }
    .cta-section{
        margin: 20px 0 40px !important;
    }
    .news-card{
        max-width: 100%;
    }
    .coming-soon{
        margin: 170px auto 300px;
        width: 85%
    }
}

.partner-logos {
    display: flex;
    justify-content: center;
    gap: 40px;
    margin: 20px 0;
}

.partner-logos img {
    max-width: 150px;
    height: auto;
}

@media (max-width: 768px) {
    .partner-logos {
        flex-direction: column;
        align-items: center;
        gap: 20px;
    }

    .partner-logos img {
        max-width: 120px;
    }
}


/* CTA */
.cta-section {
    color: var(--white-color);
    border-radius: 10px;
    text-align: center;
    position: relative;
    margin: 80px 0;
}

.cta-section .banner-img {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    z-index: -1;
    width: 100%;
    height: 100%;
}

.cta-section .banner {
    color: var(--white-color);
    border-radius: 10px;
    padding: 40px 30px;
    position: relative;
    overflow: hidden;
}

.cta-section .banner-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
}

.cta-section .banner-content-mobile {
    display: none;
}

.cta-section .banner-img-mobile {
    display: none;
}

.cta-section .banner-text {
    font-size: 1.5rem;
    line-height: 1.6;
    font-weight: 500;
    margin: 0;
    text-align: left;
}

.cta-section .banner-button {
    background-color: var(--white-color);
    color: var(--tertiary-color);
    padding: 0 24px;
    border-radius: 999px;
    text-decoration: none;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: space-between;
    transition: background 0.3s ease;
}

.cta-section .banner-button:hover {
    background-color: var(--off-white-color);
}

.cta-section .arrow {
    margin-left: 10px;
    font-size: 1.2rem;
}

/* contact */



.topbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 2rem;
    background-color: var(--white-color);
}

.logo img {
    max-height: 50px;
}

.nav-links {
    list-style: none;
    display: flex;
    gap: 1.5rem;
}

.nav-links a {
    text-decoration: none;
    color: #444;
    font-weight: 500;
}

.nav-links a.active {
    color: var(--primary-color);
    font-weight: bold;
}

.banner {
    position: relative;
    width: 100%;
    max-height: 300px;
    overflow: hidden;
}

.banner img {
    width: 100%;
    height: auto;
    object-fit: cover;
}

.banner-title {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 2.5rem;
    color: var(--white-color);
    background: rgba(0, 0, 0, 0.4);
    padding: 0.5rem 1rem;
    border-radius: 10px;
}

.contact-section {
    padding: 0 0 3rem;
    text-align: center;
}



.contact-container {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem;
    justify-content: center;
}

.contact-info {
    text-align: left;
}

.contact-info-block {
    margin-bottom: 40px;
}

.contact-form {
    padding: 55px;
    width: 100%;
    max-width: unset;
    background: #F5F5F5;
    border-radius: 16px;
    overflow: hidden;
    text-align: left;
}
.contact-form h3{
    color: var(--primary-color);
    font-size: 22px;
    margin: 0 0 20px;
}

.contact-info h3 {
    color: var(--primary-color);
    font-size: 22px;
    margin: 0 0 20px;
}
.contact-row {
    margin-bottom: 40px;
}
.contact-info p {
    font-size: 18px;
    margin-bottom: 20px;
    line-height: 35px;
}

.contact-info a {
    color: var(--primary-color);
    text-decoration: none;
    font-size: 18px;
}



.accordion-item {
    border: 0;
}

.accordion-header p {
    color: var(--primary-color);
}

.accordion-content {
    display: none;

}

.accordion-content.show {
    display: block;
}

.contact-form .col-form-label {
    font-size: 18px;
    margin: 0;
    padding: 0;
}

.contact-form input,
.contact-form textarea {
    width: 100%;
    padding: 0.8rem;
    border: 1px solid #DBDBDB;
    background: #F5F4F4;
    border-radius: 6px;
}

.contact-form button {
    padding: 0.7rem 1.5rem;
    background-color: var(--primary-color);
    color: var(--white-color);
    border: none;
    border-radius: 23px;
    cursor: pointer;
    transition: background 0.3s;
    width: 165px;
    height: 46px;
    line-height: 24px;
    display: flex;
    justify-content: space-between;
    margin-left: auto;
}

.contact-form button:hover {
    background-color: var(--primary-color);
}

.social-icons a img {
    width: 24px;
    margin-left: 0.5rem;
}

/* media */

.news-card {
    border: none;
    border-radius: 10px;
    overflow: hidden;
    padding: 0;
    text-align: left;
    height: 100%;
    margin-bottom:50px;
}

.news-card .card-body {
    padding: 0;
}

.news-card img {
    height: auto;
    object-fit: cover;
    width: 100%;
}

.news-card .date {
    font-size: 0.9rem;
    color: #555;
    margin-bottom: 12px;
}

.news-card .title {
    font-size: 1.1rem;
    font-weight: 600;
    color: #000;
    display:block;
    margin-bottom: 20px;
    /* display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden; */
    text-decoration: none;
}

.news-card .text {
    font-size: 0.95rem;
    line-height: 30px;
    color: #333;
    margin-bottom: 12px;
}

.news-card .source {
    color: var(--primary-color);
    font-size: 0.9rem;
    display: inline-block;
    margin-bottom: 16px;
    text-decoration: none;
}

.read-more {
    font-size: 0.9rem;
    color: var(--black-color);
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    text-decoration: none;
    padding: 5px 20px;
    border: 1px solid var(--off-white-color);
    border-radius: 27px;
    width: 150px;
    justify-content: space-between;
    position: relative;
}

.read-more span {
    font-size: 27px;
    line-height: 0;
    position: absolute;
    right: 11px;
    top: 0;
    bottom: 0;
    margin: auto;
    height: 4px;
}

.read-more:hover {
    text-decoration: underline;
}

@media (max-width: 768px) {

    nav ul {
        flex-direction: column;
        gap: 12px;
    }
    
    .cta-section .banner {
        color: var(--white-color);
        border-radius: 10px;
        padding: 0;
        position: relative;
        overflow: hidden;
        max-height: fit-content;
    }
    .cta-section .banner-img{
        display: none;
    }
    .cta-section .banner-img-mobile{
        display: block;
    }
    .cta-section .banner-text {
        
        line-height: 1.6;
        margin: 0;
        text-align: left;
        position: absolute;
        text-align: center;
        font-size: 30px;
        font-weight: 800;
        top: 37px;
    }
    .cta-section .banner-button{
        position: absolute;
        bottom: 58px;
        left: 0;
        right: 0;
        width: 230px;
        margin: auto;
        height: 51px;
    }
    .contact-info{
        text-align: center;
    }
    .contact-form{
        padding:35px 20px;
        text-align:center;
    }
    .contact-row{
        text-align:left;    
    }
    .contact-form button{
        margin: auto;
    }
}

.investor-content .img-section img {
    width: 100%;
    

}

.footer-social {
    display: flex;
    gap: 10px;
    position: static;
    transform: none;
    justify-content: end;
}


.card-link-wrapper {
    text-decoration: none !important;
    color: inherit !important;
    display: block;
}

.card-link-wrapper:hover {
    text-decoration: none !important;
}

.card-link-wrapper .card {
    cursor: pointer;
}

.cta-section a {
    color: var(--primary-color);
    text-decoration: none;
}

.no-curser{
    cursor: auto !important;
}

@media (max-width: 1024px) {
.site-logo {
    width: 165px;
    height: auto;
}
}