@import url('https://fonts.googleapis.com/css2?family=Crete+Round:ital@0;1&family=Newsreader:ital,opsz,wght@0,6..72,200..800;1,6..72,200..800&family=Roboto:ital,wght@0,100..900;1,100..900&family=SN+Pro:ital,wght@0,200..900;1,200..900&display=swap');
* {
font-family: "Roboto", sans-serif;
font-optical-sizing: auto;
font-weight: 400;
font-style: normal;
font-variation-settings:
"wdth" 100;
}


body {
  margin: 0;
  padding: 0;
  max-width: 100%;
  overflow-x: hidden important;
}
span{
  font-weight: bold;
}
section{
  overflow: hidden;
  width: 100%;
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/*--------Strat Disable Right Click----------*/
/*body {
user-select: none;
-webkit-user-select: none;
-ms-user-select: none;
}
p, h1, h2, h3, h4, h5, h6, span {
user-select: none;
}*/
/*--------Disable Right Click and----------*/
p{
line-height: 20px;
}
a:hover {
text-decoration: none;
}
/*------------Navbar--------------*/
.navbar{
transition: all 0.3s ease;
}


#navbarNav li a:hover{
transform: translateY(-2px);
transition: background-color 3s ease-in-out;
color: #fcbf03;
}
.navbar-nav li{
font-weight: bold;
}
/* ================= NAVBAR ================= */
.custom-navbar {
background: #076bd2;
min-height: 50px;
padding: 0 1rem;
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
position: relative;
z-index: 1030;
}

/* ================= LOGO ================= */
.company-logo {
width: 230px;
height: auto;
display: inline-block;
}

/* ================= DESKTOP MENU LINKS ================= */
.custom-nav-link {
color: rgba(255, 255, 255, 0.65) !important;
font-size: 14px !important;
font-weight: 700 !important;
padding: 7px 10px !important;
text-transform: uppercase;
transition: color 0.3s ease;
}
.custom-nav-link:hover {
color: #fcbf03 !important;
background: none !important;
}
.custom-nav-link.active {
color: #fcbf03 !important;
}
/* ================= MOBILE OFFCANVAS ================= */
.custom-offcanvas {
background: #076bd2 !important;
width: 100% !important;
}
.custom-offcanvas .offcanvas-header {
border-bottom: 1px solid rgba(255, 255, 255, 0.2);
}
.company-name-mobile {
font-size: 1.08rem;
font-weight: 600;
line-height: 1.3;
max-width: 65%;
}
/* X Close Button */
.custom-offcanvas .close-btn-x {
background: transparent;
border: none;
color: #fff;
cursor: pointer;
padding: 0.5rem;
min-width: 44px;
min-height: 44px;
display: inline-flex;
align-items: center;
justify-content: center;
transition: color 0.3s ease;
}
.custom-offcanvas .close-btn-x i {
color: inherit;
}
.custom-offcanvas .close-btn-x:hover {
color: #fcbf03;
}
/* ================= MOBILE MENU LINKS ================= */
.mobile-menu-links {
margin-top: 10px;
}
.custom-nav-link-mobile {
color: rgba(255, 255, 255, 0.7) !important;
font-size: 16px !important;
font-weight: 700 !important;
text-transform: uppercase;
transition: color 0.3s ease;
}
.custom-nav-link-mobile:hover {
color: #fcbf03 !important;
}
.custom-nav-link-mobile.active {
color: #ffffff !important;
}
/* ================= SOCIAL MOBILE ================= */
.social-mobile {
border-top: 1px solid rgba(255, 255, 255, 0.2);
margin-top: -10px;
}
.social-mobile-logo img {
width: 100px;
height: auto;
}
.social-icons-row a {
display: inline-flex;
align-items: center;
justify-content: center;
text-decoration: none;
}
.social-icons-row a i {
font-size: 28px;
color: #fff;
display: inline-block;
transition: transform 0.25s ease, color 0.25s ease;
}
.social-icons-row a:hover i {
color: #fcbf03 !important;
transform: translateY(-6px);
}
.social-icons-row a:active i {
color: #fcbf03 !important;
}
/* ================= HERO SECTION ================= */
.hero-section {
background: url("bg.jpg") no-repeat center;
background-size: cover;
min-height: calc(100vh - 80px);
}
/* Toggle button - show Font Awesome hamburger icon */
.custom-navbar .navbar-toggler {
padding: 0.5rem 0.75rem;
overflow: visible;
}
.custom-navbar .navbar-toggler-icon {
display: none;
}
.custom-navbar .navbar-toggler i {
color: #fff;
font-size: 1.25rem;
}
.custom-offcanvas .close-btn-x i {
font-size: 1.5rem;
}
/* ================= RESPONSIVE ADJUSTMENTS ================= */
@media (max-width: 991.98px) {
.custom-navbar .navbar-toggler {
display: block;
padding: 0.5rem 0.75rem;
}
.custom-offcanvas.offcanvas-end {
max-width: 100%;
}
}

/*------------------------ HOME SECTION ------------------------*/
.jumbotron {
    position: relative;
    width: 100%;
    min-height: 50vh;
    overflow: hidden;
    background-image:

    /* light circle top-right */ 
    radial-gradient(circle at 85% 20%,
    rgb(255 255 255 / 0%) 0%,
    rgb(255 255 255 / 0%) 15%,
    rgba(255, 255, 255, 0) 35%),

    /* strong blue from left */ 
    linear-gradient(90deg, 
    rgb(5 89 176 / 98%) 0%,
    rgb(6 102 202 / 89%) 30%,
    rgb(6 102 202 / 37%) 50%,
    rgba(6, 102, 202, 0) 65%),

    /* soft blue from right */
    linear-gradient(270deg,
    rgb(9 110 212 / 30%) 0%,
    rgba(9, 110, 212, 0.30) 20%,
    rgba(9, 110, 212, 0) 40%),

    /* bottom gradient */
    linear-gradient(to bottom,
    rgba(0, 0, 0, 0) 55%,
    rgb(8 107 209 / 60%) 85%,
    rgb(1 72 146 / 95%) 100%),

    url(img/modern-barhroom.jpg);
background-repeat: no-repeat;
background-size: cover;
background-position: center;
}
#home{
background-color: #f8f9fa;
margin-bottom: 0;
}


/* ---------Home btn------------- */
a.btn-first {
      background-image: linear-gradient(to right, #076bd2 0%, #b9a51c 51%, #0760bc 100%);
}

a.btn-first {
  padding: 9px 20px;
  text-align: center;
  text-transform: uppercase;
  transition: 0.5s;
  background-size: 200% auto;
  color: white;
  box-shadow: 4px 3px 16px 0px #02305f94;
  border-radius: 5px;
  outline: none;
  border: none;
}

a.btn-first:hover {
  background-position: right center;
  color: #fff;
  text-decoration: none;
}

/* ----------------home text------------------ */

h1 span {
  color: #fcbf03; /* highlight color */
}

.jumbotron h1 {
  color: #fff;
  font-style: normal;
  font-weight: bold;
  font-size: 42px; /* default desktop size */
  line-height: 1.2;
  padding-top: 0px;
}
.jumbotron .row{
position: relative;        
background: radial-gradient(circle, rgb(1 80 162 / 85%) 28%, rgb(6 81 158 / 11%) 66%, rgb(3 42 158 / 0%) 100%);
  padding: 25px 25px;
  display: inline-block;      
  border-radius: 5px;  
}
.company-name-home{
color: #fcbf03;
font-weight: bold;
font-size: 27px;
}


.home-mian-text {
  letter-spacing: 0.4px;
   position: relative;
  color: white;                    
}


@media (max-width: 768px) {
.jumbotron h1 {
    font-size: 32px;
  }
  .company-name-home{
    font-size: 23px;
  }

}

/* Mobile */
@media (max-width: 431px) {
  #home .row {
flex-direction: column;
text-align: center;
}
.home-mian-text{
  padding: 6px 2px;

}
.jumbotron {
background-position: right;

}

}
/*   text   */
.text-1{
font-weight: bold;
font-size: 35px;
color: #5e49ff;
}
.text-1 span{
font-weight: bold;
color: #5e49ff;
letter-spacing: 1px;
}
.cursor{
display: inline-block;
width: 3px;
background-color: #150061;
margin-left: 0.1rem;
}

/* ----------------\أPNG  ------------------ */
.logo-png1 {
width: 150px;
opacity: 0.7;
display: block;
margin: 0 auto 25px auto;
}
/* ---------------SVG----------------- */
#home {
position: relative;
}
/* SVG container */
/* Container */
.wave-full {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;       /* fill parent width */
  height: 150px;     /* height of waves */
  overflow: hidden;
  pointer-events: none; /* clicks pass through */
  z-index: 1;
}

/* SVG fills container */
.wave-full svg {
  display: block;
  width: 100%;
  height: 100%;
}

/* -----------------------About US------------------------- */
.aboutus {
position: relative;
width: 100%;
height: auto;
background: linear-gradient(180deg, #daecff 0%, #b8dbff 100%);
padding-top: 65px;
padding-bottom: 60px;
padding-right: 10px;
padding-left: 10px;
}

/* white shape */
.aboutus::after {
    content: "";
    position: absolute;
    bottom: -15px;
    left: 0;
    width: 100%;
    height: 40px;
    background: #076bd2;
    border-radius: 60% 60% 0 0;
}
.aboutus h2{
  font-weight: bold;
color: var(--text-dark);
}

.aboutus span{
  color: #076bd2;
}
.col-md-6 {
padding-top: 50px;
}
.row .about-text{
color: #494b4d;
padding-left: 0px;
padding-right: 0px;
text-align: justify;
text-align-last: left;
letter-spacing: 0.1px;
}
.aboutus img{
  width: 100%;
  height: auto;
  border-radius: 3px;
  border: solid 5px #ffffff00;
  border-bottom-right-radius: 50px;
  border-top-left-radius: 7px;
  border-top-right-radius: 50px;
  border-bottom-left-radius: 50px;
  box-shadow: 4px 4px 0px 1px #c2b202;
  display: block;
}
.aboutus h3{
color: #076bd2;
font-size: 22px;
font-weight: bold;
}

.aboutus h3 span{
  color: #000000;
}



/*------------------------Ourservices---------------------*/

.our-services {
width: 100%;
height: auto;
background-image:
radial-gradient(circle at 20% 30%, rgba(255,255,255,0.7) 0%, transparent 40%),
radial-gradient(circle at 80% 70%, rgba(255,255,255,0.6) 0%, transparent 40%),
linear-gradient(135deg, #daecff 0%, #b8dbff 100%);
background-size: cover;
background-position: center;
background-attachment: fixed;
color: var(--text-dark);
padding: 70px 10px 35px 10px;
margin: 0;
}


#services .col-md-4{
padding-bottom: 10px;
}

#services-title{
font-size: 36px;
color: #000;
font-weight: bold;
}
#services-title span{
color:#076bd2;
}
.service-areas{
color: #282929;
}
.content-wrapper{
padding-top: 50px;
padding-bottom: 10px;
}
.col-lg-4{
margin: 40px auto;
.card{
padding: 90px 10px 10px;
border: 0.5px solid rgb(205 214 245 / 21%);
background-color: #ffffff1a;
box-shadow: 0px 0px 8px 2px rgb(178 171 237 / 20%);
}
.card img{
top: -80px;
position: absolute;
left: calc(50% - 85px);
border: 4px solid #ffffff1a;
box-shadow: 1px 1px 5px rgb(182 177 214 / 48%);
}
.card-img-top{
width: 180px;
height: 180px;
border-radius: 50%;
}
.card p{
font-size: 14px;
line-height: 18px;
text-align-last: center;
}
}
/* Card title */
#services .card-title {
font-size: 20px;
margin-bottom: 12px;
font-weight: bold;
color: var(--text-dark);
}
/* Card hover (index-friendly) */
#services .card {
transition: transform 0.3s ease, box-shadow 0.3s ease;
}
#services .card:hover {
transform: translateY(-6px);
box-shadow: 0 10px 25px rgba(0,0,0,0.12);
}
/* card base */
#services .card {
transition: all 0.3s ease;
cursor: pointer;
}
/* hover card */
#services .card:hover {
transform: translateY(-6px);
box-shadow: 0 10px 25px rgba(0,0,0,0.12);
}
/* text limit */
#services .card-text {
max-height: 110px;
overflow: hidden;
transition: max-height 0.4s ease;
}
#services .card-text.expanded {
max-height: 2000px;
}




/*-----------read-more-services-button-------------*/
.read-more-services{
    display:inline-block;
    background:#076bd2;
    color:#fff;
    padding:7px 13px;
    text-decoration:none;
    border-radius:5px;
    font-size:13px;
    font-weight:500;
    transition:0.3s;
    letter-spacing: 1px;
    margin: 8px;
}

.read-more-services i{
    margin-left:6px;
}

.read-more-services:hover{
    background:#0557a8;
    transform: translateY(-1px);
}






/* ---------------- WHY CHOOSE US SECTION ----------------*/
.why-choose-us{
width: 100%;
height: auto;
background-image: radial-gradient(circle at 20% 30%, #accced 0%, #00000000 40%),
radial-gradient(circle at 80% 70%, #c9daec 0%, transparent 40%),
linear-gradient(135deg, #2992ff 0%, #ffffff 100%);
background-size: cover;
background-position: center;
background-attachment: fixed;
color: var(--text-dark);
padding: 70px 10px 35px 10px;
margin: 0;
}


.why-choose-us h2 {
text-align: center;
margin-bottom: 15px;
font-weight: bolder;
}

.fw-bold span{
color:#076bd2;
}
.section-description {
text-align: center;
max-width: 800px;
margin: 0 auto 50px auto;
font-size: 16px;
color: #2b2f34;
}
/* =====================================================
CARD BOX STYLE
===================================================== */
.why-choose-us .col-lg-4{
margin-bottom: 0px;
}
.why-box {
display: flex;
align-items: flex-start;
gap: 18px;
padding: 25px;
background: #edf6ff54;
border-radius: 14px;
box-shadow: 0 6px 25px rgba(0, 0, 0, 0.05);
transition: all 0.3s ease;
height: 100%;
}
.why-box:hover {
transform: translateY(-6px);
box-shadow: 0 12px 35px rgba(0, 0, 0, 0.08);
}
/* =====================================================
ICON STYLE
===================================================== */
.icon-circle {
width: 65px;
height: 65px;
min-width: 65px;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
color: #ffffff;
font-size: 22px;
box-shadow: 0 5px 15px rgba(0,0,0,0.08);
transition: 0.3s ease;
}
.icon-circle i {
font-weight: 900;
}
.why-box:hover .icon-circle {
transform: scale(1.05);
}
/* =====================================================
CONTENT TEXT
===================================================== */
.content h5 {
font-size: 17px;
font-weight: bold;
margin-bottom: 8px;
color: var(--text-dark);
}
.content p {
font-size: 14px;
color: #494b4d;
line-height: 1.6;
margin-bottom: 0;
}
/* =====================================================
COLOR VARIANTS
===================================================== */
.bg-success   { background-color: #2ecc71 !important; }
.bg-primary   { background-color: #3b82f6 !important; }
.bg-warning   { background-color: #f39c12 !important; }
.bg-info      { background-color: #17a2b8 !important; }
.bg-danger    { background-color: #e74c3c !important; }
.bg-secondary { background-color: #6c757d !important; }
.bg-dark      { background-color: #5e49ff !important; }
/* =====================================================
RESPONSIVE DESIGN
===================================================== */
@media (max-width: 992px) {
h2 { font-size: 28px; }
.section-description { font-size: 15px; }
.why-box {
flex-direction: column;
text-align: center;
align-items: center;
}
}
@media (max-width: 768px) {
.why-choose-us {
padding: 60px 0;
}
h2 {
font-size: 24px;
}
.why-box {
flex-direction: column;
text-align: center;
align-items: center;
}
.icon-circle {
width: 60px;
height: 60px;
min-width: 60px;
font-size: 20px;
}
.content h5 {
font-size: 16px;
}
.content p {
font-size: 13px;
}
}
/* =========================================
SECTION STYLE
========================================= */
.services-section {
background: #ffffff;
padding: 80px 0;
}
/* =========================================
IMAGE STYLE
========================================= */
.services-image img {
width: 100%;
border-radius: 12px;
box-shadow: 0 8px 25px rgba(0,0,0,0.08);
transition: 0.3s ease;
}
.services-image img:hover {
transform: scale(1.03);
}
/* =========================================
CONTENT STYLE
========================================= */
.services-content {
padding-left: 10px;
}
.service-title {
font-size: 22px;
font-weight: 700;
margin-bottom: 20px;
color: #111;
}
.service-subtitle {
font-size: 18px;
font-weight: 600;
margin-top: 30px;
margin-bottom: 15px;
color: #111;
}
/* =========================================
LIST STYLE
========================================= */
.service-list {
list-style: none;
padding: 0;
margin: 0;
}
.service-list li {
font-size: 15px;
color: #555;
margin-bottom: 10px;
position: relative;
padding-left: 20px;
}
/* =========================================
RESPONSIVE
========================================= */
@media (max-width: 768px) {
.services-content {
padding-left: 0;
margin-top: 20px;
}
.service-title {
font-size: 20px;
}
.service-subtitle {
font-size: 17px;
}
}
/* ---------------------------What We Offer------------------- */
/* =========================================
SERVICES SECTION
========================================= */
.services-section {
position: relative;
padding-top: 30px 0;
padding: 30px 0;
background-color: #076bd2; /* Main background color */
overflow: hidden;
background-image: linear-gradient(rgb(255 255 255 / 5%) 1px, transparent 1px),
linear-gradient(90deg, rgb(255 255 255 / 5%) 1px, #00000000 1px);
background-size: 30px 60px;
}
/* Left diagonal background image */
.services-section::before {
content: "";
position: absolute;
top: 0;
left: 0;
width: 40%;
height: 100%;
background: url("serveces/Mosaic4.jpg") center center / cover no-repeat;
clip-path: polygon(0 0, 100% 0, 85% 100%, 0% 100%);
z-index: 0;
}
/* Dark overlay on image */
.services-section::after {
content: "";
position: absolute;
top: 0;
left: 0;
width: 40%;
height: 100%;
background: rgb(99 79 255 / 22%);
clip-path: polygon(0 0, 100% 0, 85% 100%, 0% 100%);
z-index: 1;
}
/* Move content to the right so text does not sit on image */
.services-section .container {
position: relative;
z-index: 2;
margin-left: 40%;
}

@media (min-width: 992px) {
    .right-service {
        margin-left: -10px;
        margin-right: 0px;
    }
}
/* =========================================
TITLES
========================================= */
.section-title {
font-size: 22px;
font-weight: 700;
color: #f4c430;
padding-top: 15px;
}
/* Force left alignment for this specific heading */
.wall-floor-title {
text-align: left;
}
/* =========================================
LIST STYLE
========================================= */
.service-list {
list-style: none;
padding: 0;
margin: 0;
}
.service-list li {
font-size: 15px;
color: #f2f1ff;
margin-bottom: 12px;
display: flex;
align-items: center;
transition: 0.3s ease;
}
.service-list li:hover {
color: #f4c430;
transform: translateX(4px);
}
/* =========================================
ICON STYLE
========================================= */
.service-list li i {
font-size: 15px;      /* small icons */
color: #f4c430;
margin-right: 10px;
width: 15px;
text-align: center;
}
/* =========================================
RIGHT COLUMN LIST ALIGNMENT
========================================= */
.right-list li {
justify-content: flex-end;
text-align: right;
}
.right-list li i {
order: 2;           /* icon moves after text */
margin-left: 10px;
margin-right: 0;
}
/* =========================================
RESPONSIVE
========================================= */
@media (max-width: 768px) {
.services-section {
padding-bottom: 0px;
}
.right-list li {
justify-content: flex-start;
text-align: left;
}
.right-list li i {
order: 0;
margin-right: 10px;
margin-left: 0;
}
}
/* -------------------main portfolio------------------- */

#home-portfolio{
  display: flex;
  padding: 70px 15px 40px 15px;
  align-items: center;
  justify-content: center;
  background-image:
  radial-gradient(circle at 20% 30%, rgba(255,255,255,0.7) 0%, transparent 40%),
  radial-gradient(circle at 80% 70%, rgba(255,255,255,0.6) 0%, transparent 40%),
  linear-gradient(135deg, #daecff 0%, #b8dbff 100%);
}
#home-portfolio h2 {
text-align: center;
font-weight: bolder;
font-size: 36px;
color: #000;
}
#home-portfolio span{
  color: #076bd23;
}

.portfolio-first-text span{
  color: #076bd2;
}
#portfolio {
width: 100%;
height: auto;
background: #F2F4F7;
padding-top: 70px;
padding-bottom: 40px;
margin: 0px;
}

#home-portfolio p{
color: #494b4d;
text-align: center;
padding-bottom: 10px;
}
.portfolio{
position:relative;
overflow:hidden;
}

.portfolio img{
width:100%;
height:100%;
object-fit:cover;
display:block;
transition:transform .5s ease;
}

.portfolio:hover img{
transform:scale(1.15);
cursor:zoom-in;
}
/*--------------------------portfolio page------------------*/
.portfolio_page{
color: #065595;
text-align: center;
}
.portfolio_page1{
color: #065595;
}
.portfolio_page2{
color: #065595;
}

/*----------portfolio slider----------*/

.slider{
position:relative;
max-width:800px;
margin:auto;
overflow:hidden;
}

.slide{
width:100%;
display:none;
user-select:none;
}

.slide.active{
display:block;
}

/* arrows */

.arrow{
position:absolute;
top:50%;
transform:translateY(-50%);
background:rgba(0,0,0,0.24);
color:#fff;
border:none;
border-radius: 50%;
font-size:30px;
padding:1px 15px;
cursor:pointer;
}

.prev{
left:10px;
}

.next{
right:10px;
}

/* dots */

.slider-dots{
text-align:center;
margin-top:10px;
}

.slider-dots span{
display:inline-block;
width:7px;
height:7px;
margin:3px;
background:#b9d0e7;
border-radius:50%;
cursor:pointer;
}

.slider-dots span.active{
background:#fff;
}


.wrapper {
  display: flex;
  max-width: 1300px;
  position: relative;
}

.wrapper .carousel {
  touch-action: pan-y;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
  -webkit-user-select: none;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}
.wrapper .carousel {
  font-size: 0px;
  cursor: pointer;
  overflow: hidden;
  white-space: nowrap;
  scroll-behavior: smooth;
}

.carousel.dragging {
  cursor: grab;
  scroll-behavior: auto;
}

.carousel.dragging img {
  pointer-events: none;
}

.carousel img {
  height: 300px;
  object-fit: cover;
  user-select: none;
  margin-left: 14px;
  width: calc(100% / 3);
}

.carousel img:first-child {
  margin-left: 0px;
  margin-right: 0px;
}

@media screen and (max-width: 991.98px) {
  .carousel img {
    height: auto;
    width: calc(100% / 2);
  }
}

@media screen and (max-width: 550px) {
  .carousel img {
    height: auto;
    width: 100%;
  }
  .prev{
left:5px;
}
.next{
right:5px;
}
.arrow{
font-size:20px;
padding:1px 10px;
}
.slider-dots span{
width:5px;
height:5px;
margin:2px;
}
}


/*----------button----------*/
/* Main button styling */
.portfoliobutton-dot {
display: inline-block; /* Makes the link behave like a button */
padding: 10px 23px; /* Space inside the button */
font-size: 16px; /* Text size */
font-weight: 600; /* Boldness */
text-transform: uppercase; /* Capital letters */
color: #fff; /* Text color */
background: #2480de; 
border-radius: 10px; /* Rounded corners */
border: 2px solid transparent; /* Invisible border for smooth transition */
transition: all 0.3s ease; /* Smooth animation for hover effects */
position: relative; /* Needed for pseudo-element positioning */
overflow: hidden; /* Prevents pseudo-element overflow */
text-decoration: none; /* Remove underline */
}
/* Keep span text above pseudo-element */
.portfoliobutton-dot span {
position: relative;
z-index: 2; /* Ensures text is on top */
}
/* Hover light effect */
.portfoliobutton-dot::before {
content: '';
position: absolute;
top: 0;
left: -110%; /* Start off-screen */
width: 100%;
height: 100%;
background: rgba(255, 255, 255, 0.2); /* Light overlay */
transition: all 0.5s ease;
transform: skewX(-20deg); /* Diagonal skew for shine effect */
}
/* Animate the hover light across the button */
.portfoliobutton-dot:hover::before {
left: 200%; /* Move across button */
}
/* Button hover effects */
.portfoliobutton-dot{
transition: all 0.4s ease;
}

.portfoliobutton-dot:hover{
color:#fff;
transform:translateY(-3px);
box-shadow:0 8px 20px rgb(64 156 251 / 64%);
text-decoration:none;
}



/* ------------------------Contact US----------------------- */

.g-recaptcha{
transform:scale(0.9);
transform-origin:0 0;
margin-top:10px;
margin-bottom:10px;
} 

.recaptcha-box{
border-radius:8px;
overflow:hidden;
display:inline-block;
}

.contact {
width: 100%;
min-height: auto;
background-image: linear-gradient(to top, #e8f4ff 0%, #ffffff 10%);
position: relative;
padding: 75px 10px 40px 10px;
overflow: hidden;
}
.wave-divider {
width: 100%;
overflow: hidden;
line-height: 0;
margin: 0;
padding: 0;
}
.wave-divider svg {
display: block;
width: 100vw;
height: 75px;
}
.contact::before{
content: "";
position: absolute;
left: 0;
right: 0;
top: 0;
height: 290px;
background: #076bd2;
}
.contact .row{
align-items: flex-end;
}
.contact h2 {
color: #ffffff;
font-size: 36px;
font-weight: bold;
margin-bottom: 10px;
}
.Contact-us span{
  color: #fcbf03;
}
.contact h4 {
color: #ffffff;
margin-bottom: 8px;
}
.contact p {
color: rgba(255,255,255,0.9);
margin-bottom: 50px;
}

.getin-touch{
  color: #ffffff;
}
/* Carded form on the right */
.contact form{
background-image: linear-gradient(to top, #e8f4ff 0%, #ffffff 10%);
border-radius: 20px;
box-shadow: 0 10px 24px rgba(0,0,0,0.08);
padding: 28px;
max-width: 520px;
margin-left: auto;
margin-top: -80px;
}
.contact .form-control,
.contact .form-select,
.contact textarea{
background: #ffffff45 !important;
border: 0.5px solid #eeeeee !important;
color: #3a3b3b !important;
border-radius: 30px !important;
padding: 12px 16px !important;
}
.contact textarea{
border-radius: 16px !important;
min-height: 120px;
resize: vertical;
}
.contact .form-control::placeholder,
.contact .form-select::placeholder,
.contact textarea::placeholder{
color: #3a3b3b !important;
}
#submit {
position: relative;
font-size: 18px;
letter-spacing: 1px;
border-radius: 25px !important;
color: #fff;
cursor: pointer;
background-color: #076bd2;
overflow: hidden;
transition: 0.6s;
width: 100%;
}
#submit:before,
#submit:after {
position: absolute;
content: '';
left: 0;
top: 0;
height: 100%;
filter: blur(30px);
opacity: 0.4;
transition: 0.6s;
}
#submit:before {
width: 60px;
background: rgba(255,255,255,0.6);
transform: translateX(-130px) skewX(-45deg);
}
#submit:after {
width: 30px;
background: rgba(255,255,255,0.6);
transform: translateX(-130px) skewX(-45deg);
}
#submit:hover:before,
#submit:hover:after {
opacity: 0.6;
transform: translateX(320px) skewX(-45deg);
}
#submit:hover {
color: #D6E6F2;
background: #3296fc;
}
/* Right column image hidden in new design */
.emailemg1{
display: none;
}
/* Contact details and socials */
.contact-info-list{
display: grid;
grid-template-columns: 1fr;
gap: 14px;
padding-top: 30px;
}
.contact-info-item{
display: flex;
align-items: center;
gap: 12px;
color: #1d1d1d;
padding-bottom: 12px;
}
.contact-info-item span{
    font-weight: normal;
}

.contact-info-item i{
font-size: 18px;
color: #076bd2;
}

.contact-info-item a{
  text-decoration: none;
  color: #1d1d1d;
}
.contact-info-item a:hover{
  text-decoration: none;
}
.contact-social{
padding-top: 10px;
}
.contact-social .social-icons-row a{
width: 40px;
height: 40px;
border-radius: 50%;
display: inline-flex;
align-items: center;
justify-content: center;
transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.contact-social .social-icons-row a:nth-child(1){
background: linear-gradient(45deg, #feda75, #fa7e1e, #d62976, #962fbf, #4f5bd5);
}
.contact-social .social-icons-row a:nth-child(2){
background: #1877F2;
}
.contact-social .social-icons-row a:nth-child(3){
background: #FF6F00;
}
.contact-social .social-icons-row a:nth-child(4){
background: #25D366;
}
.contact-social .social-icons-row a i{
color: #ffffff;
font-size: 18px;
}
.contact-social .social-icons-row a:hover{
transform: translateY(-2px);
box-shadow: 0 8px 16px rgba(0,0,0,0.15);
text-decoration: none !important;
}
/* Left content spacing */
.contact .col-lg-8 h1,
.contact .col-lg-8 h4,
.contact .col-lg-8 p{
padding-left: 10px;
}
/* Mobile */
@media (max-width: 991.98px){

.contact-info-list {
padding-top: 0px;
}
.wave-divider svg {
display: block;
width: 100vw;
height: 95px;
}
.contact form{
max-width: 100%;
margin-top: -60px;
}
.emailemg1{
display: none;
}
.contact h1{
font-size: 30px;
}
}
/* Two equal columns at lg and above without changing HTML classes */
@media (min-width: 992px){
.contact .col-lg-8,
.contact .col-lg-4{
flex: 0 0 50%;
max-width: 50%;
}

.contact::before {
    content: "";
    position: absolute;
    height: 430px;
   
}
.contact .col-lg-8{
position: relative;
}
.contact .col-lg-4{
display: flex;
justify-content: flex-end;
align-items: flex-start;
padding-top: 0;
}
.contact form{
margin-left: 0;
}
/* Move intro copy into the top blue area */
.contact .col-lg-8 > h2,
.contact .col-lg-8 > h4,
.contact .col-lg-8 > p{
position: relative;
z-index: 1;
transform: none;
margin-top: -210px;
}
.contact .contact-info-list{
margin-top: -20px;
}
}
/* ------------------------------Star rating------------------------- */
/*---------------start underline ------------------*/
#toggleReviews{
position: relative;
}
.Review1{
width: 100%;
height: auto;
background: #fff;
padding-top: 30px;
padding-bottom: 30px;
}
.Review1 h2{
font-weight: bolder;
}

/* rope underline */
#toggleReviews::after{
content: "";
position: absolute;
left: 20px;
bottom: 6px;
width: 0;
height: 6px;
background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='6' viewBox='0 0 120 6'><path d='M0 3 Q15 0 30 3 T60 3 T90 3 T120 3' fill='none' stroke='white' stroke-width='2'/></svg>");
background-repeat: repeat-x;
background-size: 60px 6px;
transition: width 0.4s ease;
}
/* animate rope */
#toggleReviews:hover::after{
width: calc(100% - 40px);
animation: ropeMove 1.2s linear infinite;
}
@keyframes ropeMove{
from{
background-position: 0 0;
}
to{
background-position: 60px 0;
}
}
#review_content .card-footer{
font-size: 11px;
}
/*----------- underline and ------------------*/
/* review toggle button */
#toggleReviews{
position: relative;
display: inline-block;
padding: 10px 20px;
background: #076bd2;
color: #fff;
font-size: 16px;
text-decoration: none;
border-radius: 6px;
cursor: pointer;
transition: background 0.3s ease, color 0.3s ease;
}
#toggleReviews:hover{
background: #3296fc;
color: #fff;
}
#toggleReviews:hover::after{
width: calc(100% - 40px);
}
/* review date */

#review_content .card-footer{
  text-align: right;
font-size: 11px;
color: #494b4d;
}
.progress-label-left
{
float: left;
margin-right: 0.5em;
line-height: 1em;
}
.progress-label-right
{
float: right;
margin-left: 0.3em;
line-height: 1em;
}
.star-light
{
color:#e9ecef;
}

/* ----------------------FOOTER---------------------- */
.footer-section {
background: #076bd2;
padding: 50px 0 30px;
color: #fff;
}
/* Social Icons */
.social-icons {
margin-bottom: 15px;
}
.social-icons a {
display: inline-flex;
align-items: center;
justify-content: center;
width: 45px;
height: 45px;
margin: 0 8px;
border-radius: 50%;
background-color: #fff;
color: #076bd2;
font-size: 18px;
transition: 0.3s ease;
text-decoration: none;
}
.social-icons a:hover {
background-color: #076bd2;
color: #fff;
transform: translateY(-4px);
text-decoration: none;
}
/* Footer Menu */
.footer-menu {
list-style: none;
padding: 0;
margin: 0;
}
.footer-menu li {
display: inline-block;
margin: 0 18px;
margin-bottom: 25px;
}
.footer-menu li a {
color: #ddd;
text-decoration: none;
font-size: 15px;
transition: 0.3s ease;
text-transform: uppercase;
font-weight: 500;
}
.footer-menu li a:hover {
color: #fcbf03;
}
/* Responsive */
@media (max-width: 768px) {
.footer-menu li {
display: block;
margin: 15px 0;
padding-bottom: 10px;
}

}
.quicklink{
text-align: center;
font-weight: bold;
font-size: 30px;
margin-bottom: 25px;
}


/* -------------------------Footer----------------------- */
.footer {
width: 100%;
height: auto;
background: #076bd2;
padding-bottom: 20px;
padding-right: 10px;
padding-left: 10px;
}
.row-footer{
border-top: 1px solid #ddd;
}
.footer p{
color: #d1d4d6;
margin: 0;
letter-spacing: 0.4px;
font-size: 13px;
}









/*-----------read-more-about-button-------------*/
.read-more-about{
    display:inline-block;
    background:#076bd2;
    color:#fff;
    padding:10px 20px;
    text-decoration:none;
    border-radius:5px;
    font-size:15px;
    font-weight:500;
    transition:0.3s;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.read-more-about i{
    margin-left:6px;
}

.read-more-about:hover{
    background:#0557a8;
}

/* Target the icon inside .read-more-about */

.read-more-back{
  padding-top: 35px;
  text-align: center;
}


/*-------------wall-floor-tiling----------------*/
.wall-floor-tiling{
width: 100%;
min-height: auto;
background-image:
radial-gradient(circle at 20% 30%, rgba(255,255,255,0.7) 0%, transparent 40%),
radial-gradient(circle at 80% 70%, rgba(255,255,255,0.6) 0%, transparent 40%),
linear-gradient(135deg, #daecff 0%, #b8dbff 100%);
background-size: cover;
background-position: center;
background-attachment: fixed;
padding: 90px 10px 50px 10px;
overflow: hidden;
}
.wall-floor-tiling img {
 box-shadow: 0 6px 25px rgba(0, 0, 0, 0.05);
  border-radius: 5px; 
}
.wall-floor-tiling .col-md-6 {
  padding-top: 20px;
}

.wall-floor-tiling h2{
font-size: 1.4rem;
}

/*-------------about page----------------*/
.service-list-about li{
color: #212529;
font-size:16px;
transition: all 0.3s ease;
}
.service-list-about i{
margin-right:8px;
}
.service-list-about .fa-about{
  color:#076bd2;
}

.service-list-about li:hover{
color:#076bd2;
transform: translateX(3px);
}

/* Tablet devices (iPad) - 768px to 1024px */
@media (min-width: 768px) and (max-width: 1024px) {
  
  .row.equal-height {
    display: flex;
    align-items: stretch; /* Columns will stretch to the same height */
  }

  /* Each column uses flex to center content vertically */
  .row.equal-height > .col-md-6 {
    display: flex;
    flex-direction: column;
    justify-content: center; 
  }

  /* Make images fill their column height and maintain aspect ratio */
  .row.equal-height img {
    width: 100%;
    height: 100%;
    object-fit: cover; 
  }

  /* Optional: remove extra margin in paragraph text */
  .wall-floor-tiling p {
    margin: 0;
  }
}












/*-------------------------Resposive-----------------------*/



@media (max-width: 431px) {
.contact::before {
    content: "";
    height: 315px;
}
.aboutus h3 {
    font-size: 23px;
    padding-top: 0;
}
.navbar-toggler {
        margin-right: 15px;
    }
.navbar img{
  margin-left: 10px;
}
}
/* =========================================
   📱 MOBILE (iPhone Devices)
========================================= */

@media (max-width: 575px) {
  .aboutus h2,
  #home-portfolio h2,
  .why-choose-us h2,
  .contact h2,
  .Review1 h2,
  #services h2 {
      font-size: clamp(30px, 5vw, 35px);
  }
}

.aboutus {
    padding-top: 70px;
}

.aboutus h3 {
    font-size: 23px;
    padding-top: 0;
}
.aboutus .col-lg-6{
  padding-top: 20px;
}
.row .about-text {
    padding-top: 0;
    line-height: 1.4;
}

.navbar {
    padding: 10px;
}

.navbar-nav {
    flex-direction: column;
    text-align: center;
}

.nav-link {
    margin: 5px 0;
}

.aboutus img,
.Our img,
.portfolio img {
    width: 100%;
}

.contact input,
.contact select,
.contact textarea {
    width: 100%;
}

.quicklink {
    font-size: 20px;
    margin-bottom: 10px;
}

.footer p {
    font-size: 13px;
}


    body {
  margin: 0;
  padding: 0;
  overflow-x: hidden;
}
.aboutus h3 {
    font-size: 20px;
    padding-top: 0;
}

}


/* =========================================
   📲 SMALL TABLET (iPad Mini)
========================================= */
@media (min-width: 768px) and (max-width: 820px) {

.aboutus h2,
  #home-portfolio h2,
  .why-choose-us h2,
  .contact h2,
  .Review1 h2,
  #services h2 {
      font-size: clamp(35px, 5vw, 40px);
  }


.row .about-text {
    line-height: 1.3;
}

.home-png {
    max-width: 100%;
    height: auto;
}
 .right-service {
        margin-left: -10px;
        margin-right: 0px;
    }


}


/* =========================================
   📲 TABLET (iPad Air)
========================================= */
@media (min-width: 768px) and (max-width: 1023px) {

.row .about-text {
    line-height: 1.25;
}
 .right-service {
        margin-left: -10px;
        margin-right: 0px;
    }
   .contact::before {
    content: "";
    height: 459px;
}

}



/* =========================================
   💻 DESKTOP
========================================= */
@media (min-width: 1195px) {

 .right-service {
        margin-left: -10px;
        margin-right: 0px;
    }
  

}


/* =========================================
   🌍 GLOBAL (All Devices)
========================================= */

.maps {
    width: 100%;
    height: auto;
    padding-bottom: 0px;
}