*{
  margin:0;
  padding:0;
  box-sizing:border-box;
}
body{
  margin:0;
font-family:'Open Sans', sans-serif;
background-color: black;
overflow-x:hidden;
}

html{
  overflow-x:hidden;
}

h1,
h2,
h3,
.logo,
.quote-btn{
  font-family:'Roboto', sans-serif;
}
.projects-hero{

 min-height:500px;

  background-image:

  linear-gradient(
    to right,
    rgba(0,0,0,0.95) 10%,
    rgba(0,0,0,0.75) 10%,
    rgba(0,0,0,0.25) 70%
  ),

  url("images/kuya-bg.jpg");

  background-size:cover;

  background-position:center;

  background-repeat:no-repeat;

}
/* NAVBAR */

.navbar{

  display:flex;

  justify-content:space-between;

  align-items:center;

  position:fixed;

  top:0;

  left:0;

  width:100%;

  z-index:9999;

  padding:18px 90px;

  transition:0.4s ease;
  background-color: black;

}

.logo img{
  width:130px;
}

.nav-links{

  display:flex;
  gap:40px;

}

.nav-links a{

  color:white;

  text-decoration:none;

  font-size:18px;

  transition:0.3s;

  position:relative;

  padding-bottom:6px;

  display:inline-block;

}

.nav-links a:hover{
  color:#ff2b2b;
}
/* RED LINE */

.nav-links a::after{

  content:"";

  position:absolute;

  left:0;

  bottom:0;

  width:0%;

  height:3px;

  background:#ff2b2b;

  transition:0.3s ease;

}

/* SHOW LINE */

.nav-links a:hover::after{

  width:100%;

}
/* BUTTON */

.quote-btn{

  background:#ff2b2b;
  color:white;

  text-decoration:none;

  padding:16px 28px;

  font-weight:700;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;

}

.quote-btn:hover{

  background:white;

  color:black;


}
/* HAMBURGER */

    .hamburger{

    display:none;

    flex-direction:column;

    gap:6px;

    cursor:pointer;

    }

    .hamburger span{

    width:30px;

    height:3px;

    background:white;

    border-radius:10px;

    }

.navbar.scrolled{

  background:rgba(0,0,0,0.95);

  backdrop-filter:blur(10px);

  box-shadow:0 5px 20px rgba(0,0,0,0.4);

}

.navbar.hide{

  transform:translateY(-120%);

}
/* DROPDOWN */

.dropdown{

  position:relative;

}

/* PROJECTS LINK */

.dropdown-link{

  display:flex;

  align-items:center;

  gap:8px;

}

/* DROPDOWN MENU */

.dropdown-menu{

  position:absolute;

  top:140%;

  left:0;

  background:black;

  min-width:240px;

  padding:15px 0;

  border:1px solid rgba(255,255,255,0.1);

  opacity:0;

  visibility:hidden;

  transform:translateY(10px);

  transition:0.3s ease;

  z-index:999;

}

/* DROPDOWN LINKS */

.dropdown-menu a{

  display:block;

  padding:14px 22px;

  color:white;

  text-decoration:none;

  font-size:16px;

  transition:0.3s ease;

}

/* HOVER EFFECT */

.dropdown-menu a:hover{

  background:#ff2b2b;

  color:white;

}

/* SHOW MENU */

.dropdown:hover .dropdown-menu{

  opacity:1;

  visibility:visible;

  transform:translateY(0);

}

@media(max-width:900px){

  .nav-links{

    position:absolute;

    top:100px;

    right:0;

    background:black;

    width:100%;

    flex-direction:column;

    align-items:center;

    padding:40px 0;

    gap:30px;

    display:none;

  }

  .nav-links.active{

    display:flex;

  }

  .hamburger{

    display:flex;

  }

  .quote-btn{

    display:none;

  }

}

/* TABLET */

@media(max-width:1200px){

  .navbar{

    padding:18px 40px;

  }

  .nav-links{

    gap:25px;

  }

  .nav-links a{

    font-size:16px;

  }

  .quote-btn{

    padding:14px 22px;

    font-size:14px;

  }

  .logo img{

    width:110px;

  }

}
/* ABOUT HERO */

.about-hero{

  background:rgba(0,0,0,0.65);

  padding:140px 90px 90px;

}

/* CONTAINER */

.about-container{

  display:grid;

  grid-template-columns:1.1fr 0.9fr;

  align-items:center;

  gap:70px;

}

/* LEFT SIDE */

.about-left{

  color:white;
  max-width: 1200px;

}

/* SMALL TITLE */

.about-small-title{

  color:#ff2b2b;

  font-size:28px;

  font-weight:800;

  margin-bottom:35px;
  margin-top: 65px;

}

/* TITLE */

.about-title{

  font-size:78px;

  line-height:1.05;

  font-weight:900;

  font-style:italic;

  margin-bottom:35px;

  color:white;

}

/* RED TEXT */

.about-title span{

  color:#ff2b2b;

}

/* DESCRIPTION */

.about-description{

  font-size:22px;

  line-height:1.5;

  color:#e0e0e0;

  max-width:850px;

  margin-bottom:45px;

}

/* BUTTON */

.about-btn{

  display:inline-block;

  background:#ff2b2b;

  color:white;

  text-decoration:none;

  padding:22px 48px;

  font-weight:700;

  transition:0.3s ease;

}

.about-btn:hover{

  background:white;

  color:black;

}

/* RIGHT IMAGE */

.about-right img{

  width:100%;

  height:720px;

  object-fit:cover;

  display:block;

}

/* MOBILE */

@media(max-width:1000px){

  .about-container{

    grid-template-columns:1fr;

  }

  .about-title{

    font-size:58px;

  }

  .about-description{

    font-size:21px;

  }

  .about-right img{

    height:500px;

  }

}

@media(max-width:768px){

  .about-hero{

    padding:120px 25px 70px;

  }

  .about-title{

    font-size:46px;

  }

  .about-description{

    font-size:18px;

  }

  .about-btn{

    width:100%;

    text-align:center;

  }

}
/* WHO WE ARE */

.who-we-are{

  background:black;

  padding:90px 90px;

}

/* CONTAINER */

.who-container{

  display:grid;

  grid-template-columns:0.9fr 1.1fr;

  align-items:center;

}

/* LEFT IMAGE */

.who-image img{

  width:100%;

  height:100%;

  object-fit:cover;

  display:block;

}

/* RIGHT CONTENT */

.who-content{

  color:white;

  padding:40px 50px;

}

/* TITLE */

.who-title{

  font-size:78px;

  font-weight:900;

  color:#ff2b2b;

  margin-bottom:35px;

}

/* DESCRIPTION */

.who-description{

  font-size:22px;

  line-height:1.5;

  color:#e0e0e0;

  margin-bottom:60px;

}

/* STATS */

.who-stats{

  display:grid;

  grid-template-columns:repeat(4,1fr);

  gap:25px;

}

/* STAT BOX */

.stat-box{

  border-left:1px solid rgba(255,255,255,0.25);

  padding-left:28px;

}

/* ICON */

.stat-box i{

  font-size:52px;

  color:#ff2b2b;

  margin-bottom:20px;

}

/* NUMBER */

.stat-box h3{

  font-size:30px;

  font-weight:900;

  margin-bottom:18px;

}

/* TEXT */

.stat-box p{

  font-size:22px;

  line-height:1.5;

  font-weight:700;

  color:#f1f1f1;

}

/* MOBILE */

@media(max-width:1100px){

  .who-container{

    grid-template-columns:1fr;

  }

  .who-content{

    padding:50px 0 0;

  }

  .who-stats{

    grid-template-columns:repeat(2,1fr);

  }

}

@media(max-width:768px){

  .who-we-are{

    padding:70px 25px;

  }

  /* TITLE */

  .who-title{

    font-size:48px;

    text-align:center;

  }

  /* DESCRIPTION */

  .who-description{

    font-size:18px;

    text-align:center;

    margin-bottom:45px;

  }

  /* STATS GRID */

  .who-stats{

    grid-template-columns:1fr;

    gap:0;

  }

  /* STAT BOX */

  .stat-box{

    border-left:none;

    border-top:1px solid rgba(255,255,255,0.15);

    padding:30px 0;

    text-align:center;

    display:flex;

    flex-direction:column;

    align-items:center;

    justify-content:center;

  }

  /* ICON */

  .stat-box i{

    font-size:46px;

    margin-bottom:18px;

  }

  /* NUMBER */

  .stat-box h3{

    font-size:30px;

    margin-bottom:12px;

  }

  /* TEXT */

  .stat-box p{

    font-size:20px;

    line-height:1.4;

  }

}
/* PROCESS SECTION */

.process-section{

  background:black;

  padding:90px 90px;

}

/* TITLE */

.process-title{

  color:#ff2b2b;

  font-size:78px;

  font-weight:900;

  margin-bottom:60px;

}

/* GRID */

.process-grid{

  display:grid;

  grid-template-columns:repeat(2,1fr);

  gap:90px 80px;

}

/* CARD */

.process-card{

  color:white;

}

/* TOP CONTENT */

.process-top{

  display:flex;

  align-items:flex-start;

  gap:22px;

  margin-bottom:35px;

}

/* NUMBER */

.process-number{

  width:72px;

  height:72px;

  border:4px solid #ff2b2b;

  border-radius:50%;

  display:flex;

  align-items:center;

  justify-content:center;

  font-size:42px;

  font-weight:900;

  flex-shrink:0;

}

/* TITLE */

.process-card h3{

  font-size:42px;

  font-weight:900;

  margin-bottom:12px;

}

/* DESCRIPTION */

.process-card p{

  font-size:22px;

  line-height:1.5;

  color:#e0e0e0;

  max-width:500px;

}

/* IMAGE */

.process-card img{

  width:100%;

  height:320px;

  object-fit:cover;

  display:block;

}

/* MOBILE */

@media(max-width:1000px){

  .process-grid{

    grid-template-columns:1fr;

    gap:70px;

  }

}

@media(max-width:768px){

  .process-section{

    padding:70px 25px;

  }

  .process-title{

    font-size:52px;

  }

  .process-top{

    gap:18px;

  }

  .process-number{

    width:60px;

    height:60px;

    font-size:32px;

  }

  .process-card h3{

    font-size:30px;

  }

  .process-card p{

    font-size:18px;

  }

  .process-card img{

    height:240px;

  }

}
/* COMMITMENT SECTION */

.commitment-section{

  background:black;

  padding:90px 90px;

}

/* TITLE */

.commitment-title{

  color:#ff2b2b;

  font-size:78px;

  font-weight:900;

  margin-bottom:60px;

}

/* GRID */

.commitment-grid{

  display:grid;

  grid-template-columns:repeat(3,1fr);

  gap:35px;

  justify-content:center;

}

/* CENTER THE LAST 2 CARDS */

.commitment-card:nth-child(4){

  grid-column:1 / 2;

}

.commitment-card:nth-child(5){

  grid-column:2 / 3;

}

/* WRAP BOTTOM ROW */

.commitment-grid{

  display:grid;

  grid-template-columns:repeat(6, 1fr);

  gap:35px;

}

/* TOP 3 */

.commitment-card:nth-child(1){

  grid-column:1 / 3;

}

.commitment-card:nth-child(2){

  grid-column:3 / 5;

}

.commitment-card:nth-child(3){

  grid-column:5 / 7;

}

/* BOTTOM 2 CENTERED */

.commitment-card:nth-child(4){

  grid-column:2 / 4;

}

.commitment-card:nth-child(5){

  grid-column:4 / 6;

}

/* CARD */

.commitment-card{

  border:4px solid rgba(255,255,255,0.8);

  padding:28px;

  display:flex;

  align-items:flex-start;

  gap:22px;

  color:white;

min-height:180px;
   display:flex;

  align-items:flex-start;

  justify-content:flex-start;
}

/* ICON */

.commitment-card i{

  font-size:60px;

  color:#ff2b2b;

  flex-shrink:0;

}

/* TITLE */

.commitment-card h3{

  font-size:30px;

  font-weight:900;

  margin-bottom:10px;
    line-height:1.1;


}

/* TEXT */

.commitment-card p{

  font-size:20px;

  line-height:1.5;

  color:#e0e0e0;

}
.commitment-card div{

  flex:1;

}

/* MOBILE */

@media(max-width:768px){

  .commitment-section{

    padding:70px 20px;

    overflow:hidden;

  }

  /* TITLE */

  .commitment-title{

    font-size:52px;

    text-align:center;

    margin-bottom:40px;

  }

  /* GRID */

  .commitment-grid{

    display:flex;

    flex-direction:column;

    align-items:center;

    gap:25px;

  }

  /* REMOVE DESKTOP GRID POSITIONING */

  .commitment-card:nth-child(1),
  .commitment-card:nth-child(2),
  .commitment-card:nth-child(3),
  .commitment-card:nth-child(4),
  .commitment-card:nth-child(5){

    grid-column:auto;

  }

  /* CARD */

  .commitment-card{

    width:100%;

    max-width:420px;

    flex-direction:column;

    align-items:center;

    text-align:center;

    padding:35px 25px;

    min-height:auto;

  }

  /* ICON */

  .commitment-card i{

    font-size:50px;

    margin-bottom:20px;

  }

  /* TITLE */

  .commitment-card h3{

    font-size:26px;

    margin-bottom:15px;

  }

  /* TEXT */

  .commitment-card p{

    font-size:18px;

    line-height:1.5;

  }

}

/* TABLET */

@media(max-width:1100px){

  .commitment-section{

    padding:80px 40px;

  }

  .commitment-title{

    font-size:64px;

    text-align:center;

  }

  .commitment-grid{

    grid-template-columns:repeat(2,1fr);

    gap:25px;

  }

  /* RESET DESKTOP POSITIONING */

  .commitment-card:nth-child(1),
  .commitment-card:nth-child(2),
  .commitment-card:nth-child(3),
  .commitment-card:nth-child(4),
  .commitment-card:nth-child(5){

    grid-column:auto;

  }

  .commitment-card{

    min-height:240px;

  }

  .commitment-card h3{

    font-size:26px;

  }

  .commitment-card p{

    font-size:18px;

  }

}
/* INSTALLATIONS SECTION */

.installations-section{

  background:black;

  padding:90px 90px;

}

/* TITLE */

.installations-title{

  color:#ff2b2b;

  font-size:78px;

  font-weight:900;

  margin-bottom:60px;

}

/* GRID */

.installations-grid{

  display:grid;

  grid-template-columns:repeat(2, 1fr);

  gap:70px;

}

/* CARD */

.installation-card{

  overflow:hidden;

}

/* IMAGE */

.installation-card img{

  width:100%;

  height:380px;

  object-fit:cover;

  display:block;

  transition:0.4s ease;

}

/* HOVER */

.installation-card:hover img{

  transform:scale(1.05);

}

/* MOBILE */

@media(max-width:900px){

  .installations-grid{

    grid-template-columns:1fr;

    gap:35px;

  }

}

@media(max-width:768px){

  .installations-section{

    padding:70px 25px;

  }

  .installations-title{

    font-size:52px;

  }

  .installation-card img{

    height:260px;

  }

}
/* ========================= */
/* LIVE MAP SECTION */
/* ========================= */

.map-section{

  background:#f2f2f2;

  padding:80px 70px;

}

/* MAP BOX */

.map-container{

  width:100%;

  height:650px;

  overflow:hidden;

}

/* IFRAME */

.map-container iframe{

  width:100%;

  height:100%;

  display:block;

}

/* MOBILE */

@media(max-width:1000px){

  .map-section{

    padding:40px 20px;

  }

  .map-container{

    height:450px;

  }

}
/* ========================= */
/* FOOTER CONTACT SECTION */
/* ========================= */

.footer-contact{

  background:black;

  padding:80px 70px 20px;

}

/* CONTAINER */

.footer-container{

  display:grid;

  grid-template-columns:
  1fr 1fr;

  gap:80px;

}

/* SMALL TITLE */

.footer-small-title{

  color:#ff2b2b;

  font-size:34px;

  font-weight:900;

  margin-bottom:40px;

}

/* BIG TITLE */

.footer-title{

  color:white;

  font-size:78px;

  line-height:1.15;

  font-weight:900;

  margin-bottom:20px;

}
.footer-title span{
  color:#ff2b2b;
}

/* LOGO */

.footer-logo{

  width:260px;

  margin-bottom:0px;

}
/* DESCRIPTION */

.footer-description{

  color:#dddddd;

  font-size:22px;

  line-height:1.7;

  max-width:700px;
  margin-top:40px;

}
.footer-left{

  display:flex;

  flex-direction:column;

  justify-content:flex-start;

  align-self:start;

}

/* RIGHT TEXT */

.footer-text{

  color:white;

  font-size:22px;

  margin-bottom:40px;

}

/* MESSENGER BUTTON */

.messenger-btn{

  display:inline-flex;

  align-items:center;

  gap:15px;

  background:#ff2b2b;

  color:white;

  text-decoration:none;

  padding:22px 32px;

  font-size:22px;

  font-weight:700;

  margin-bottom:50px;

  transition:0.3s;

}

.messenger-btn:hover{

  background:white;

  color:black;

}

/* CONTACT LIST */

.footer-contact-list{

  display:flex;

  flex-direction:column;

  gap:35px;

}

/* ITEM */

.footer-contact-item{

  display:flex;

  align-items:center;

  gap:25px;

}

/* ICON CIRCLE */

.footer-icon-circle{

  width:85px;

  height:85px;

  min-width:85px;

  border-radius:50%;

  background:#ff2b2b;

  display:flex;

  justify-content:center;

  align-items:center;

}

/* ICON */

.footer-icon-circle i{

  color:white;

  font-size:38px;

}

/* TEXT */

.footer-contact-item p{

  color:white;

  font-size:22px;

  line-height:1.5;

}

/* COPYRIGHT */

.footer-bottom{

  text-align:center;

  color:#bbbbbb;

  font-size:16px;

  margin-top:80px;

}

/* MOBILE */

@media(max-width:1000px){

  .footer-container{

    grid-template-columns:1fr;

    gap:60px;

  }

  .footer-contact{

    padding:60px 25px 20px;

  }

  .footer-title{

    font-size:56px;

  }

  .footer-description{

    font-size:22px;

  }

  .footer-text{

    font-size:22px;

  }

  .footer-contact-item p{

    font-size:22px;

  }

  .messenger-btn{

    font-size:18px;

    padding:18px 24px;

  }

}

/* ========================= */
/* FADE IN ANIMATION */
/* ========================= */

.fade-in{

  opacity:0;

  transform:translateY(60px);

  transition:
  opacity 0.9s ease,
  transform 0.9s ease;

}

/* ACTIVE */

.fade-in.show{

  opacity:1;

  transform:translateY(0);

}