/* Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@400;500;600;700&family=Barlow:wght@300;400;500;600;700&display=swap');

/* ===================================================================
   ESTIX ESTIMATION - FINAL PREMIUM CSS
   Palette: Deep Navy | Ink Black | Aqua | Frozen Water | Azure Mist
   =================================================================== */

:root{
  --primary:#091143;
  --primary-dark:#060315;
  --primary-light:#1A2566;

  --cta:#18CFC3;
  --cta-dark:#11B3A8;
  --cta-light:#46E3D9;

  --secondary:#647673;
  --secondary-light:#7E908D;
  --secondary-dark:#4E5E5C;

  --light-bg:#D7FFFE;
  --white:#EBFAFA;
  --pure-white:#ffffff;
  --dark:#060315;
  --dark-light:#091143;
  --muted:#647673;
  --muted-light:#8B9A97;
  --border:rgba(9,17,67,.12);

  --font-heading:'Oswald',sans-serif;
  --font-body:'Barlow',sans-serif;

  --shadow-xs:0 4px 12px rgba(9,17,67,.06);
  --shadow-sm:0 10px 26px rgba(9,17,67,.08);
  --shadow-md:0 18px 45px rgba(9,17,67,.12);
  --shadow-lg:0 30px 80px rgba(9,17,67,.18);
  --glow-aqua:0 0 0 4px rgba(24,207,195,.16),0 18px 45px rgba(24,207,195,.18);

  --gradient-dark:linear-gradient(135deg,#091143 0%,#060315 100%);
  --gradient-soft:linear-gradient(145deg,#EBFAFA 0%,#D7FFFE 100%);
  --gradient-aqua:linear-gradient(135deg,#18CFC3 0%,#11B3A8 100%);

  --transition-fast:.2s ease;
  --transition-normal:.35s ease;
  --transition-slow:.65s ease;
}

/* ===================================================================
   RESET & BASE
   =================================================================== */
*,
*::before,
*::after{
  box-sizing:border-box;
  margin:0;
  padding:0;
}

html{
  scroll-behavior:smooth;
}

body{
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.7;
  color:var(--dark);
  background:var(--white);
  overflow-x:hidden;
}

img{
  max-width:100%;
  height:auto;
  display:block;
}

a{
  text-decoration:none;
  color:inherit;
  transition:color var(--transition-fast), background var(--transition-fast), transform var(--transition-fast);
}

ul{
  list-style:none;
}

::selection{
  background:var(--cta);
  color:var(--dark);
}

/* ===================================================================
   TYPOGRAPHY
   =================================================================== */
h1,h2,h3,h4,h5,h6{
  font-family:var(--font-heading);
  font-weight:600;
  line-height:1.08;
  letter-spacing:.025em;
  text-transform:uppercase;
}

h1{font-size:clamp(2.8rem,7vw,5.7rem);}
h2{font-size:clamp(2rem,4.5vw,3.45rem);}
h3{font-size:clamp(1.2rem,2.4vw,1.65rem);}
h4{font-size:1.25rem;}

p{
  margin-bottom:1rem;
}

/* ===================================================================
   UTILITIES
   =================================================================== */
.container{
  width:100%;
  max-width:1200px;
  margin:0 auto;
  padding:0 2rem;
}

.section{
  padding:6.5rem 0;
  position:relative;
}

.section-dark{
  background:var(--gradient-dark);
  color:var(--white);
}

.section-gray{
  background:linear-gradient(180deg,#D7FFFE 0%,#EBFAFA 100%);
}

.section-secondary{
  background:var(--secondary);
  color:var(--white);
}

.text-center{text-align:center;}
.text-primary{color:var(--primary);}
.text-white{color:var(--white);}

.section-header{
  text-align:center;
  margin-bottom:4rem;
  position:relative;
  z-index:2;
}

.section-label{
  font-family:var(--font-body);
  font-size:.8125rem;
  font-weight:700;
  letter-spacing:.25em;
  text-transform:uppercase;
  color:var(--primary);
  margin-bottom:.75rem;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.75rem;
}

.section-label::before,
.section-label::after{
  content:'';
  width:30px;
  height:3px;
  background:var(--cta);
}

.section-dark .section-label{
  color:var(--cta);
}

.section-dark .section-label::before,
.section-dark .section-label::after{
  background:var(--cta);
}

.section-title{
  margin-bottom:1rem;
  color:var(--primary);
}

.section-subtitle{
  font-size:1.125rem;
  color:var(--muted);
  max-width:680px;
  margin:0 auto;
}

.section-dark .section-title,
.section-dark h2{
  color:var(--white);
}

.section-dark .section-subtitle,
.section-dark p{
  color:rgba(235,250,250,.78);
}

.hard-divider{
  display:flex;
  justify-content:center;
  gap:0;
  margin:1.5rem auto;
  width:90px;
  height:8px;
  overflow:hidden;
  border-radius:20px;
}

.hard-divider span{
  flex:1;
  height:100%;
}

.hard-divider span:nth-child(1){background:var(--primary);}
.hard-divider span:nth-child(2){background:var(--cta);}
.hard-divider span:nth-child(3){background:var(--secondary);}

/* ===================================================================
   BUTTONS
   =================================================================== */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.55rem;
  padding:1rem 2.25rem;
  font-family:var(--font-heading);
  font-size:1.05rem;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
  border:none;
  cursor:pointer;
  transition:all var(--transition-normal);
  position:relative;
  overflow:hidden;
}

.btn::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.22),transparent);
  transform:translateX(-120%);
  transition:transform .65s ease;
}

.btn:hover::before{
  transform:translateX(120%);
}

.btn-primary{
  background:var(--primary);
  color:var(--white);
  box-shadow:var(--shadow-sm);
}

.btn-primary:hover{
  background:var(--primary-dark);
  transform:translateY(-3px);
  box-shadow:var(--shadow-md);
}

.btn-secondary{
  background:transparent;
  color:var(--white);
  border:3px solid var(--white);
}

.btn-secondary:hover{
  background:var(--white);
  color:var(--dark);
  transform:translateY(-3px);
}

.btn-outline{
  background:transparent;
  color:var(--primary);
  border:3px solid var(--primary);
}

.btn-outline:hover{
  background:var(--primary);
  color:var(--white);
  transform:translateY(-3px);
}

.btn-outline-light{
  background:transparent;
  color:var(--white);
  border:3px solid rgba(255,255,255,.4);
}

.btn-outline-light:hover{
  border-color:var(--white);
  background:var(--white);
  color:var(--dark);
}


/* ===================================================================
   HEADER & NAVIGATION
   =================================================================== */

.header{
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  height: 87px;
  background: rgba(9,17,67,.96);
  backdrop-filter: blur(16px);
  border-bottom: 3px solid var(--cta);
  box-shadow: 0 10px 30px rgba(6,3,21,.16);
}

.header-inner{
  max-width: 1400px;
  height: 100%;
  margin: 0 auto;
  padding: .875rem 2rem;

  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* ===================================================================
   LOGO
   =================================================================== */

.logo{
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
}

.logo-img{
  width: 95px;
  height: auto;
  display: block;
}

.logo-text{
  display: flex;
  flex-direction: column;
  line-height: 1;
}

/* Main Logo Text */
.logo-main{
  font-family: var(--font-heading);
  font-size: 1.22rem;
  font-weight: 700;
  color: var(--white);
  letter-spacing: .02em;
  text-transform: uppercase; 
}

/* Sub Text */
.logo-sub{
  margin-top: 5px;
  font-family: var(--font-body);
  font-size: .58rem;
  font-weight: 700;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--cta);
}

/* ===================================================================
   NAVIGATION MENU
   =================================================================== */

.nav{
  display: flex;
  align-items: center;
  gap: 2.5rem;
}

.nav-link{
  position: relative;
  text-decoration: none;

  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 500;
  color: rgba(235,250,250,.84);
  letter-spacing: .08em;
  text-transform: uppercase;

  transition: .3s ease;
}

.nav-link::after{
  content: "";
  position: absolute;
  left: 0;
  bottom: -6px;

  width: 0;
  height: 3px;
  background: var(--cta);

  transition: width .3s ease;
}

.nav-link:hover,
.nav-link.active{
  color: var(--pure-white);
}

.nav-link:hover::after,
.nav-link.active::after{
  width: 100%;
}

/* ===================================================================
   HEADER BUTTON
   =================================================================== */

.header-cta{
  padding: .7rem 1.55rem;
  font-size: .875rem;
  text-decoration: none;

  background: var(--cta);
  color: var(--primary-dark) !important;
  border-radius: 6px;

  box-shadow: 0 12px 28px rgba(24,207,195,.18);
  transition: .3s ease;
}

.header-cta:hover{
  background: var(--cta-dark);
  color: var(--pure-white) !important;
  transform: translateY(-2px);
}

/* ===================================================================
   MOBILE MENU TOGGLE
   =================================================================== */

.nav-toggle{
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: .5rem;
}

.nav-toggle span{
  display: block;
  width: 26px;
  height: 3px;
  margin: 5px 0;
  background: var(--white);
  transition: .3s ease;
}

.nav-toggle.active span:nth-child(1){
  transform: rotate(45deg) translate(5px,6px);
}

.nav-toggle.active span:nth-child(2){
  opacity: 0;
}

.nav-toggle.active span:nth-child(3){
  transform: rotate(-45deg) translate(5px,-6px);
}

/* ===================================================================
   TABLET RESPONSIVE
   =================================================================== */

@media (max-width: 991px){

  .header{
    height: 80px;
  }

  .header-inner{
    padding: 0 1.2rem;
  }

  .logo-img{
    width: 78px;
  }

  .logo-main{
    font-size: 1.05rem;
  }

  .logo-sub{
    font-size: .52rem;
    letter-spacing: .18em;
  }

  .nav-toggle{
    display: block;
    z-index: 1001;
  }

  .nav{
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;

    background: rgba(9,17,67,.98);
    border-top: 1px solid rgba(255,255,255,.08);

    flex-direction: column;
    gap: 0;
    padding: 1rem 0;

    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: .3s ease;
  }

  .nav.active{
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
  }

  .nav-link{
    width: 100%;
    text-align: center;
    padding: 1rem 0;
  }

  .nav.nav-open,
  .nav.active{
    opacity:1 !important;
    visibility:visible !important;
    transform:translateY(0) !important;
    display:flex !important;
  }

  .header-cta{
    display: none;
  }
}

/* ===================================================================
   MOBILE RESPONSIVE
   =================================================================== */

@media (max-width: 576px){

  .logo-img{
    width: 68px;
  }

  .logo-main{
    font-size: .95rem;
  }

  .logo-sub{
    font-size: .48rem;
    letter-spacing: .14em;
  }

}


/* ===================================================================
   HERO SECTION
   =================================================================== */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  background:
    radial-gradient(circle at 86% 16%,rgba(24,207,195,.16),transparent 28%),
    radial-gradient(circle at 12% 85%,rgba(9,17,67,.10),transparent 32%),
    linear-gradient(180deg,#EBFAFA 0%,#D7FFFE 100%);
  overflow:hidden;
  padding-top:90px;
}

.hero::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,rgba(235,250,250,.94),rgba(215,255,254,.82)),
    repeating-linear-gradient(90deg,transparent,transparent 92px,rgba(9,17,67,.04) 92px,rgba(9,17,67,.04) 93px);
  pointer-events:none;
}

.hero::after{
  content:'';
  position:absolute;
  bottom:-1px;
  left:0;
  width:100%;
  height:120px;
  background:url("data:image/svg+xml;utf8,<svg viewBox='0 0 1440 120' xmlns='http://www.w3.org/2000/svg'><path fill='%23EBFAFA' d='M0,72 C180,120 350,18 540,65 C720,110 900,92 1080,52 C1260,12 1360,52 1440,40 L1440,120 L0,120 Z'/></svg>");
  background-size:cover;
  z-index:1;
}

.hero-content{
  position:relative;
  z-index:2;
  padding:1rem 2rem;
  max-width:1200px;
  width:100%;
  text-align:left;
}

.hero-tag{
  display:inline-block;
  font-size:.8125rem;
  font-weight:800;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--primary);
  margin-bottom:1.25rem;
  padding:.72rem 1.75rem;
  border:2px solid rgba(9,17,67,.36);
  background:rgba(235,250,250,.38);
  backdrop-filter:blur(10px);
}

.hero-title{
  color:var(--primary);
  line-height:.92;
  margin-bottom:1rem;
  font-size:clamp(2.85rem,6vw,5.7rem);
}

.hero-title span{
  display:block;
  color:var(--primary);
  position:relative;
}

.hero-description{
  font-size:1.18rem;
  color:var(--secondary);
  max-width:760px;
  margin-bottom:2.2rem;
  line-height:1.65;
}

.hero-cta{
  display:flex;
  gap:1rem;
  flex-wrap:wrap;
  margin-bottom:3rem;
}

.hero-cta .btn-primary{
  background:var(--cta);
  color:var(--primary-dark);
  box-shadow:0 16px 38px rgba(24,207,195,.25);
}

.hero-cta .btn-primary:hover{
  background:var(--cta-dark);
  color:var(--white);
}

.hero-cta .btn-secondary{
  background:transparent;
  color:var(--primary);
  border:3px solid var(--primary);
}

.hero-cta .btn-secondary:hover{
  background:var(--primary);
  color:var(--white);
}

.hero-stats{
  display:flex;
  gap:3rem;
  padding-top:2rem;
  border-top:1px solid rgba(100,118,115,.20);
  max-width:540px;
}

.hero-stat-number{
  font-family:var(--font-heading);
  font-size:2.55rem;
  font-weight:700;
  color:var(--primary);
  line-height:1;
}

.hero-stat-label{
  font-size:.8125rem;
  color:var(--secondary);
  text-transform:uppercase;
  letter-spacing:.1em;
  font-weight:700;
}

/* ===================================================================
   HERO IMAGE LAYOUT (RIGHT SIDE FRAME IMAGE - FINAL ALIGNMENT)
   =================================================================== */

/* SPLIT HERO INTO 2 COLUMNS */
.hero-content{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  align-items:flex-start; /* TOP ALIGN for better heading match */
  gap:3rem;
}

/* LEFT SIDE */
.hero-left{
  width:100%;
}

/* RIGHT SIDE */
.hero-right{
  display:flex;
  justify-content:center;
  align-items:flex-start;
  padding-top:4.8rem; /* 🔥 adjust this for perfect alignment */
}

.hero-image-box{
  position: relative;
  width: 100%;
  max-width: 560px;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  overflow: visible !important;
  animation: imageFloat 4s ease-in-out infinite;
}

.hero-image-box::before,
.hero-image-box::after{
  display: none !important;
  content: none !important;
}

.hero-image-box img{
  width: 100%;
  height: auto;
  display: block;
  background: transparent;
  animation: floatImage 4s ease-in-out infinite;
  filter: drop-shadow(0 25px 40px rgba(0,0,0,.12));
}

@keyframes floatImage{
  0%,100%{
    transform: translateY(0px);
  }

  50%{
    transform: translateY(-12px);
  }
}



/* ===================================================================
   SERVICES OVERVIEW
   =================================================================== */
.services-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:2rem;
}

.service-card{
  position:relative;
  overflow:hidden;
  text-align:center;
  padding:2.65rem 2rem;
  background:rgba(235,250,250,.56);
  border:1px solid rgba(9,17,67,.08);
  box-shadow:var(--shadow-xs);
  transition:all var(--transition-normal);
}

.service-card::before{
  content:'';
  display:block;
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(24,207,195,.10),rgba(9,17,67,.06));
  opacity:0;
  transition:opacity var(--transition-normal);
}

.service-card:hover{
  transform:translateY(-10px);
  box-shadow:var(--shadow-md);
  border-color:rgba(24,207,195,.35);
}

.service-card:hover::before{
  opacity:1;
}

.service-icon{
  width:76px;
  height:76px;
  margin:0 auto 1.5rem;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--gradient-dark);
  color:var(--white);
  font-size:1.75rem;
  position:relative;
  z-index:1;
  box-shadow:0 18px 36px rgba(9,17,67,.16);
  transition:all var(--transition-normal);
}

.service-card:hover .service-icon{
  background:var(--gradient-aqua);
  color:var(--primary-dark);
  transform:rotate(-4deg) scale(1.06);
}

.service-icon i{
  color:currentColor !important;
}

.service-card h3,
.service-card p{
  position:relative;
  z-index:1;
}

.service-card h3{
  color:var(--primary);
  margin-bottom:.75rem;
}

.service-card p{
  color:var(--secondary);
  font-size:.95rem;
  margin-bottom:0;
}

/* ===================================================================
   WHY CHOOSE US
   =================================================================== */
.why-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:2rem;
}

.why-card{
  position:relative;
  text-align:center;
  padding:2.25rem 1.5rem;
  background:rgba(255,255,255,.36);
  border:1px solid rgba(9,17,67,.08);
  box-shadow:var(--shadow-xs);
  transition:all var(--transition-normal);
  overflow:hidden;
}

.why-card::after{
  content:'';
  position:absolute;
  width:160px;
  height:160px;
  right:-90px;
  top:-90px;
  border-radius:50%;
  background:rgba(24,207,195,.13);
  transition:all var(--transition-normal);
}

.why-card:hover{
  transform:translateY(-9px);
  box-shadow:var(--shadow-md);
}

.why-card:hover::after{
  right:-45px;
  top:-45px;
}

.why-icon{
  width:68px;
  height:68px;
  margin:0 auto 1.25rem;
  display:flex;
  align-items:center;
  justify-content:center;
  border:2px solid rgba(9,17,67,.18);
  background:var(--white);
  color:var(--primary);
  font-size:1.45rem;
  position:relative;
  z-index:1;
}

.why-card:hover .why-icon{
  background:var(--primary);
  color:var(--white);
  border-color:var(--primary);
}

.why-card h3{
  color:var(--primary);
  margin-bottom:.5rem;
  font-size:1.125rem;
  position:relative;
  z-index:1;
}

.why-card p{
  color:var(--muted);
  font-size:.9375rem;
  margin:0;
  position:relative;
  z-index:1;
}

/* ===================================================================
   PROJECT / SERVICE IMAGE CARDS
   =================================================================== */
.projects-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2rem;
}

.project-card{
  position:relative;
  overflow:hidden;
  cursor:pointer;
  transition:transform var(--transition-normal), box-shadow var(--transition-normal);
  box-shadow:var(--shadow-sm);
}

.project-card:hover{
  transform:translateY(-8px);
  box-shadow:var(--shadow-lg);
}

.project-image{
  aspect-ratio:4/3;
  background:var(--secondary);
  background-size:cover;
  background-position:center;
  position:relative;
  overflow:hidden;
}

.project-image::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(6,3,21,.88) 0%,rgba(9,17,67,.16) 62%);
  z-index:1;
  transition:background var(--transition-normal);
}

.project-card:hover .project-image::before{
  background:linear-gradient(to top,rgba(9,17,67,.92) 0%,rgba(24,207,195,.20) 62%);
}

.project-label{
  position:absolute;
  top:1rem;
  left:1rem;
  z-index:2;
  font-size:.6875rem;
  font-weight:800;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--primary-dark);
  background:var(--cta);
  padding:.4rem .9rem;
}

.project-info{
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  padding:1.5rem;
  z-index:2;
}

.project-info h3{
  color:var(--white);
  font-size:1.25rem;
  margin-bottom:.25rem;
}

.project-info p{
  color:rgba(235,250,250,.78);
  font-size:.875rem;
  margin:0;
}

/* ===================================================================
   STATS SECTION
   =================================================================== */
.stats-section{
  background:var(--gradient-dark);
  position:relative;
  overflow:hidden;
  padding:5.5rem 0;
}

.stats-section::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 20% 15%,rgba(24,207,195,.12),transparent 28%),
    repeating-linear-gradient(90deg,transparent,transparent 80px,rgba(235,250,250,.045) 80px,rgba(235,250,250,.045) 81px);
}

.stats-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:2rem;
  position:relative;
  z-index:1;
}

.stat-item{
  text-align:center;
  padding:1rem;
}

.stat-number{
  font-family:var(--font-heading);
  font-size:clamp(2.7rem,5vw,3.8rem);
  font-weight:700;
  color:var(--white);
  line-height:1;
  margin-bottom:.5rem;
}

.stat-label{
  font-size:.875rem;
  font-weight:700;
  color:rgba(235,250,250,.82);
  text-transform:uppercase;
  letter-spacing:.15em;
}

/* ===================================================================
   TESTIMONIAL / FEATURE CARDS
   =================================================================== */
.testimonials-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.75rem;
}

.testimonial-card{
  position:relative;
  overflow:hidden;
  padding:2.5rem;
  min-height:360px;
  background:linear-gradient(145deg,#ffffff 0%,#EBFAFA 48%,#D7FFFE 100%);
  border:1px solid rgba(9,17,67,.10);
  box-shadow:var(--shadow-sm);
  transition:all .45s ease;
  isolation:isolate;
  opacity:0;
  transform:translateY(45px);
}

.testimonial-card.show{
  opacity:1;
  transform:translateY(0);
}

.testimonial-card::before{
  content:'';
  position:absolute;
  inset:0;
  background:var(--gradient-dark);
  opacity:0;
  transition:opacity .45s ease;
  z-index:-2;
}

.testimonial-card::after{
  content:'';
  position:absolute;
  width:180px;
  height:180px;
  right:-70px;
  top:-70px;
  border-radius:50%;
  background:rgba(24,207,195,.12);
  transition:all .45s ease;
  z-index:-1;
}

.testimonial-card:hover{
  transform:translateY(-14px);
  box-shadow:var(--shadow-lg);
  border-color:transparent;
}

.testimonial-card:hover::before{
  opacity:1;
}

.testimonial-card:hover::after{
  width:280px;
  height:280px;
  background:rgba(235,250,250,.08);
}

.testimonial-stars{
  width:66px;
  height:66px;
  background:var(--primary);
  color:var(--white);
  border-radius:20px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.35rem;
  font-size:.85rem;
  margin-bottom:2rem;
  transition:all .45s ease;
}

.testimonial-card:hover .testimonial-stars{
  background:var(--cta);
  color:var(--primary-dark);
  transform:rotate(-6deg) scale(1.08);
}

.testimonial-text{
  font-size:1.05rem;
  color:var(--secondary);
  line-height:1.85;
  margin-bottom:2rem;
  transition:color .35s ease;
}

.testimonial-author{
  display:flex;
  align-items:center;
  gap:1rem;
}

.testimonial-avatar{
  width:58px;
  height:58px;
  background:var(--primary);
  color:var(--white);
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--font-heading);
  font-size:1.15rem;
  font-weight:700;
  border-radius:16px;
  box-shadow:0 12px 25px rgba(9,17,67,.18);
  transition:all .4s ease;
}

.testimonial-info h4{
  font-size:1.05rem;
  color:var(--primary);
  margin-bottom:.15rem;
  text-transform:none;
  transition:color .35s ease;
}

.testimonial-info span{
  font-size:.85rem;
  color:var(--muted);
  transition:color .35s ease;
}

.testimonial-card:hover .testimonial-text,
.testimonial-card:hover .testimonial-info h4,
.testimonial-card:hover .testimonial-info span{
  color:var(--white);
}

.testimonial-card:hover .testimonial-avatar{
  background:var(--white);
  color:var(--primary);
  transform:scale(1.08);
}

.testimonial-card:nth-child(1){transition-delay:.05s;}
.testimonial-card:nth-child(2){transition-delay:.16s;}
.testimonial-card:nth-child(3){transition-delay:.27s;}

/* ===================================================================
   CTA SECTION
   =================================================================== */
.cta-section{
  background:var(--gradient-dark);
  position:relative;
  overflow:hidden;
  padding:5.5rem 0;
}

.cta-section::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 75% 20%,rgba(24,207,195,.20),transparent 28%),
    repeating-linear-gradient(-45deg,transparent,transparent 40px,rgba(235,250,250,.05) 40px,rgba(235,250,250,.05) 41px);
}

.cta-content{
  position:relative;
  text-align:center;
  z-index:1;
}

.cta-content h2{
  color:var(--white);
  margin-bottom:1rem;
}

.cta-content p{
  color:rgba(235,250,250,.88);
  font-size:1.125rem;
  max-width:650px;
  margin:0 auto 2rem;
}

.cta-content .btn-secondary{
  border-color:var(--white);
}

.cta-content .btn-secondary:hover{
  background:var(--white);
  color:var(--primary);
}

.cta-details{
  display:flex;
  justify-content:center;
  gap:3rem;
  margin-top:2.5rem;
  padding-top:2rem;
  border-top:1px solid rgba(235,250,250,.22);
}

.cta-detail span{
  display:block;
  font-family:var(--font-heading);
  font-size:.8125rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:rgba(235,250,250,.62);
  margin-bottom:.25rem;
}

.cta-detail p{
  color:var(--white);
  margin:0;
  font-size:1rem;
  font-weight:600;
}

/* ===================================================================
   FOOTER
   =================================================================== */
.footer{
  background:var(--dark);
  color:var(--white);
  padding:4rem 0 2rem;
  border-top:4px solid var(--cta);
}

.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:3rem;
  margin-bottom:3rem;
}

.footer-brand .logo{
  margin-bottom:1rem;
}

.footer-brand p{
  color:rgba(235,250,250,.62);
  font-size:.9375rem;
  max-width:330px;
}

.footer-social{
  display:flex;
  gap:.75rem;
  margin-top:1.5rem;
}

.footer-social a{
  width:42px;
  height:42px;
  display:flex;
  align-items:center;
  justify-content:center;
  border:2px solid rgba(235,250,250,.18);
  color:rgba(235,250,250,.68);
  transition:all var(--transition-fast);
  font-size:1rem;
}

.footer-social a:hover{
  background:var(--cta);
  border-color:var(--cta);
  color:var(--primary-dark);
  transform:translateY(-3px);
}

.footer h4{
  color:var(--white);
  font-size:1rem;
  margin-bottom:1.25rem;
  letter-spacing:.1em;
}

.footer-links{
  display:flex;
  flex-direction:column;
  gap:.625rem;
}

.footer-links a{
  color:rgba(235,250,250,.62);
  font-size:.9375rem;
}

.footer-links a:hover{
  color:var(--cta);
  transform:translateX(4px);
}

.footer-contact-item{
  display:flex;
  align-items:flex-start;
  gap:.75rem;
  color:rgba(235,250,250,.62);
  font-size:.9375rem;
  margin-bottom:.75rem;
}

.footer-contact-item i{
  color:var(--cta);
  width:18px;
  text-align:center;
  margin-top:4px;
}

.footer-bottom{
  padding-top:2rem;
  border-top:1px solid rgba(235,250,250,.10);
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:1rem;
}

.footer-bottom p,
.footer-legal a{
  color:rgba(235,250,250,.46);
  font-size:.875rem;
  margin:0;
}

.footer-bottom a,
.footer-legal a:hover{
  color:var(--cta);
}

.footer-legal{
  display:flex;
  gap:2rem;
}

/* ===================================================================
   ABOUT PAGE
   =================================================================== */
.page-hero{
  padding:10rem 0 5rem;
  background:var(--gradient-dark);
  text-align:center;
  position:relative;
  overflow:hidden;
}

.page-hero::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 75% 10%,rgba(24,207,195,.16),transparent 28%),
    repeating-linear-gradient(90deg,transparent,transparent 100px,rgba(235,250,250,.045) 100px,rgba(235,250,250,.045) 101px);
}

.page-hero::after{
  content:'';
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  height:6px;
  background:repeating-linear-gradient(-45deg,var(--cta),var(--cta) 8px,var(--dark) 8px,var(--dark) 16px);
}

.page-hero-content{
  position:relative;
  z-index:1;
}

.page-hero h1{
  color:var(--white);
  margin-bottom:1rem;
}

.page-hero p{
  color:rgba(235,250,250,.78);
  font-size:1.2rem;
  max-width:740px;
  margin:0 auto;
}

.story-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:4rem;
  align-items:center;
}

.story-image{
  position:relative;
  overflow:hidden;
  border-radius:26px;
  box-shadow:var(--shadow-lg);
  background:var(--white);
}

.story-image::after{
  content:'';
  position:absolute;
  inset:14px;
  border:2px solid rgba(235,250,250,.5);
  pointer-events:none;
}

.story-img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .55s ease;
}

.story-image:hover .story-img{
  transform:scale(1.05);
}

.story-content h2{
  color:var(--primary);
  margin-bottom:1rem;
}

.story-content p{
  color:var(--muted);
  margin-bottom:1rem;
}

.story-founded{
  display:inline-block;
  padding:1rem 2rem;
  background:var(--primary);
  color:var(--white) !important;
  font-weight:700;
  border-radius:12px;
  letter-spacing:.08em;
  margin-top:1rem;
  box-shadow:var(--shadow-sm);
}

.team-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:2rem;
}

.team-card{
  text-align:center;
  background:var(--gradient-soft);
  padding:2rem;
  border-radius:24px;
  box-shadow:var(--shadow-sm);
  transition:all var(--transition-normal);
  border:1px solid rgba(9,17,67,.08);
}

.team-card:hover{
  transform:translateY(-8px);
  box-shadow:var(--shadow-md);
}

.team-photo{
  width:140px;
  height:140px;
  margin:0 auto 1rem;
  border-radius:50%;
  overflow:hidden;
  border:4px solid var(--primary);
  background:var(--pure-white);
  display:flex;
  align-items:center;
  justify-content:center;
}

.team-img{
  width:100%;
  height:100%;
  object-fit:cover;
  background:var(--pure-white);
}

.team-card h3{
  color:var(--primary);
  margin-bottom:.25rem;
}

.team-role{
  color:var(--cta-dark);
  font-weight:800;
  font-size:.82rem;
  text-transform:uppercase;
  display:block;
  margin-bottom:.75rem;
}

.team-card p{
  color:var(--muted);
  font-size:.9375rem;
  margin:0;
}

.values-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:2rem;
}

.value-card{
  text-align:center;
  padding:2.5rem 1.5rem;
  background:rgba(235,250,250,.045);
  border:1px solid rgba(235,250,250,.12);
  border-radius:22px;
  transition:all var(--transition-normal);
}

.value-card:hover{
  transform:translateY(-10px);
  border-color:var(--cta);
  background:rgba(24,207,195,.08);
}

.value-icon{
  width:70px;
  height:70px;
  margin:0 auto 1.25rem;
  display:flex;
  align-items:center;
  justify-content:center;
  border:2px solid rgba(235,250,250,.18);
  border-radius:18px;
  color:var(--white);
}

.value-icon i{
  color:var(--white) !important;
  font-size:1.4rem;
}

.value-card h3{
  color:var(--white) !important;
  margin-bottom:.5rem;
}

.value-card p{
  color:rgba(235,250,250,.82) !important;
  line-height:1.8;
  margin:0;
}

.certs-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2rem;
}

.cert-card{
  text-align:center;
  padding:2.2rem;
  background:var(--gradient-soft);
  border-radius:22px;
  box-shadow:var(--shadow-sm);
  border:1px solid rgba(9,17,67,.08);
  transition:all var(--transition-normal);
}

.cert-card:hover{
  transform:translateY(-8px);
  box-shadow:var(--shadow-md);
}

.cert-icon{
  font-size:2rem;
  color:var(--primary);
  margin-bottom:1rem;
}

.cert-card h3{
  color:var(--primary);
  margin-bottom:.5rem;
}

.cert-card p{
  color:var(--muted);
  font-size:.9rem;
  margin:0;
}

.process-section{
  background:linear-gradient(180deg,#D7FFFE 0%,#EBFAFA 100%);
  padding:5.5rem 0;
}

.process-steps-home{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:1.5rem;
  position:relative;
}

.process-step-home{
  text-align:center;
  background:rgba(255,255,255,.45);
  border:1px solid rgba(9,17,67,.10);
  padding:2rem 1rem;
  box-shadow:var(--shadow-xs);
  transition:all .35s ease;
}

.process-step-home:hover{
  transform:translateY(-8px);
  box-shadow:var(--shadow-md);
}

.process-number-home{
  width:64px;
  height:64px;
  border-radius:50%;
  margin:0 auto 1.2rem;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--font-heading);
  font-size:1.8rem;
  font-weight:700;
  background:var(--primary);
  color:var(--white);
}

.process-step-home.active .process-number-home,
.process-step-home:hover .process-number-home{
  background:var(--cta);
  color:var(--primary-dark);
}

.process-step-home h3{
  color:var(--primary);
  font-size:1.05rem;
  margin-bottom:.75rem;
}

.process-step-home p{
  color:var(--muted);
  font-size:.92rem;
  margin:0;
}

@media(max-width:1024px){
  .process-steps-home{
    grid-template-columns:repeat(2,1fr);
  }
}

@media(max-width:600px){
  .process-steps-home{
    grid-template-columns:1fr;
  }
}
 


/* ===================================================================
   SERVICES PAGE DETAILS - ADVANCED SMOOTH FLOW
   =================================================================== */
.service-detail{
  padding:5.4rem 0;
  border-bottom:1px solid rgba(9,17,67,.08);
  position:relative;
  overflow:hidden;
  isolation:isolate;
  background:
    radial-gradient(circle at 12% 18%,rgba(24,207,195,.11),transparent 30%),
    radial-gradient(circle at 88% 84%,rgba(9,17,67,.08),transparent 32%),
    linear-gradient(180deg,#EBFAFA 0%,#D7FFFE 100%);
}

.service-detail:nth-child(even){
  background:
    radial-gradient(circle at 88% 18%,rgba(24,207,195,.13),transparent 30%),
    radial-gradient(circle at 10% 82%,rgba(9,17,67,.07),transparent 32%),
    linear-gradient(180deg,#D7FFFE 0%,#EBFAFA 100%);
}

.service-detail::before{
  content:"";
  position:absolute;
  inset:auto 0 -1px 0;
  height:110px;
  pointer-events:none;
  z-index:-1;
  opacity:.72;
  background:url("data:image/svg+xml;utf8,<svg viewBox='0 0 1440 120' xmlns='http://www.w3.org/2000/svg'><path fill='%23EBFAFA' d='M0,70 C180,118 360,24 560,66 C760,108 900,94 1085,54 C1260,16 1360,54 1440,38 L1440,120 L0,120 Z'/></svg>");
  background-size:cover;
  background-repeat:no-repeat;
}

.service-detail:nth-child(even)::before{
  background:url("data:image/svg+xml;utf8,<svg viewBox='0 0 1440 120' xmlns='http://www.w3.org/2000/svg'><path fill='%23D7FFFE' d='M0,45 C180,5 360,96 540,52 C735,4 920,28 1100,72 C1265,112 1365,62 1440,78 L1440,120 L0,120 Z'/></svg>");
  background-size:cover;
  background-repeat:no-repeat;
}

.service-detail::after{
  content:"";
  position:absolute;
  width:260px;
  height:260px;
  border-radius:50%;
  right:-120px;
  top:18%;
  background:rgba(24,207,195,.10);
  filter:blur(2px);
  z-index:-1;
  transition:transform .8s ease;
}

.service-detail:hover::after{
  transform:scale(1.15) translate(-18px,18px);
}

.service-detail:last-child{
  border-bottom:none;
}

.service-detail-inner{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:4rem;
  align-items:center;
  max-width:1200px;
  margin:0 auto;
  padding:0 2rem;
  position:relative;
  z-index:2;
}

.service-detail:nth-child(even) .service-detail-inner{
  direction:rtl;
}

.service-detail:nth-child(even) .service-detail-inner > *{
  direction:ltr;
}

.service-detail-image{
  aspect-ratio:16/10;
  background:var(--secondary);
  background-size:cover;
  background-position:center;
  position:relative;
  overflow:hidden;
  border-radius:28px;
  box-shadow:0 24px 65px rgba(9,17,67,.16);
  opacity:1;
  transform:none;
  transition:transform .45s ease,box-shadow .45s ease,filter .45s ease;
}

.service-detail-image::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(to top,rgba(9,17,67,.30),transparent 58%),
    linear-gradient(135deg,rgba(24,207,195,.18),transparent 45%);
  z-index:1;
}

.service-detail-image::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg,transparent 35%,rgba(255,255,255,.38),transparent 65%);
  transform:translateX(-135%);
  transition:transform .85s ease;
  z-index:2;
}

.service-detail:hover .service-detail-image::before{
  transform:translateX(135%);
}

.service-detail-image:hover{
  transform:translateY(-8px) scale(1.025);
  box-shadow:0 35px 90px rgba(9,17,67,.24);
  filter:saturate(1.08) contrast(1.04);
}

.service-detail-image i{
  display:none;
}

.service-detail-content{
  opacity:1;
  transform:none;
}

.service-detail-content h2{
  color:var(--primary);
  margin-bottom:1.15rem;
  position:relative;
  display:inline-block;
}

.service-detail-content h2::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-10px;
  width:68px;
  height:4px;
  border-radius:999px;
  background:var(--gradient-aqua);
  transform-origin:left;
  transition:transform .55s ease;
}

.service-detail:hover .service-detail-content h2::after{
  transform:scaleX(1.35);
}

.service-price-tag{
  display:inline-block;
  font-family:var(--font-heading);
  font-size:1.15rem;
  font-weight:600;
  color:var(--cta-dark);
  margin-bottom:1.25rem;
  letter-spacing:.05em;
}

.service-detail-content p{
  color:var(--muted);
  font-size:1rem;
  margin-bottom:1.5rem;
}

.service-includes{
  margin-bottom:2rem;
  padding:1.35rem;
  border-radius:22px;
  background:rgba(255,255,255,.48);
  border:1px solid rgba(9,17,67,.08);
  box-shadow:var(--shadow-xs);
  backdrop-filter:blur(12px);
}

.service-includes h4{
  color:var(--primary);
  font-size:1rem;
  margin-bottom:.9rem;
  text-transform:uppercase;
  letter-spacing:.1em;
}

.service-includes ul{
  display:flex;
  flex-direction:column;
  gap:.7rem;
}

.service-includes li{
  display:flex;
  align-items:flex-start;
  gap:.75rem;
  color:var(--secondary-dark);
  font-size:.9375rem;
  transition:transform .3s ease,color .3s ease;
}

.service-includes li:hover{
  transform:translateX(7px);
  color:var(--primary);
}

.service-includes li i{
  color:var(--cta-dark);
  font-size:.75rem;
  width:18px;
  min-width:18px;
  text-align:center;
  margin-top:6px;
  transition:transform .35s ease,color .35s ease;
}

.service-includes li:hover i{
  transform:scale(1.35) rotate(8deg);
  color:var(--primary);
}

.service-detail .btn{
  border-radius:999px;
  box-shadow:0 16px 35px rgba(9,17,67,.14);
}

.service-detail .btn:hover{
  background:var(--cta);
  color:var(--primary-dark);
  box-shadow:0 20px 45px rgba(24,207,195,.28);
}

.service-animate{
  opacity:0;
  transform:translateY(34px);
  transition:opacity .75s ease,transform .75s cubic-bezier(.2,.8,.2,1);
}

.service-animate.show{
  opacity:1;
  transform:translateY(0);
}

.service-detail.show .service-detail-image{
  animation:serviceImageIn .85s cubic-bezier(.2,.8,.2,1) both;
}

.service-detail.show .service-detail-content{
  animation:serviceContentIn .85s cubic-bezier(.2,.8,.2,1) .08s both;
}

@keyframes serviceImageIn{
  from{opacity:0;transform:translateY(38px) scale(.96);}
  to{opacity:1;transform:translateY(0) scale(1);}
}

@keyframes serviceContentIn{
  from{opacity:0;transform:translateY(42px);}
  to{opacity:1;transform:translateY(0);}
}

@media(max-width:900px){
  .service-detail-inner{
    grid-template-columns:1fr;
    gap:2.5rem;
  }

  .service-detail:nth-child(even) .service-detail-inner{
    direction:ltr;
  }
}

@media(max-width:768px){
  .service-detail{
    padding:4.2rem 0;
  }

  .service-detail::before{
    height:75px;
  }

  .service-detail-inner{
    padding:0 1.25rem;
  }

  .service-includes{
    padding:1.15rem;
  }
}

/* ===================================================================
   CONTACT PAGE
   =================================================================== */
.contact-grid{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:3rem;
  align-items:stretch;
}

.contact-form-section,
.contact-info-section{
  position:relative;
  overflow:hidden;
  border-radius:28px;
  animation:fadeUp .8s ease both;
}

.contact-form-section{
  background:var(--gradient-soft);
  padding:3rem;
  border:1px solid rgba(9,17,67,.10);
  box-shadow:var(--shadow-md);
}

.contact-form-section::before{
  content:'';
  position:absolute;
  right:-90px;
  top:-90px;
  width:220px;
  height:220px;
  background:var(--gradient-aqua);
  opacity:.10;
  border-radius:50%;
}

.contact-badge{
  display:inline-flex;
  padding:.45rem .95rem;
  background:rgba(24,207,195,.18);
  color:var(--primary);
  font-weight:800;
  font-size:.75rem;
  letter-spacing:.13em;
  text-transform:uppercase;
  margin-bottom:1rem;
}

.contact-badge.light{
  background:rgba(235,250,250,.12);
  color:var(--white);
}

.contact-form-section h2{
  color:var(--primary);
  margin-bottom:.5rem;
}

.contact-form-section > p{
  color:var(--muted);
  margin-bottom:2rem;
  max-width:640px;
}

.contact-form{
  display:flex;
  flex-direction:column;
  gap:1.25rem;
  position:relative;
  z-index:1;
}

.form-row{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1.25rem;
}

.form-group{
  display:flex;
  flex-direction:column;
  gap:.45rem;
}

.form-group label{
  font-weight:800;
  font-size:.78rem;
  color:var(--primary);
  letter-spacing:.08em;
  text-transform:uppercase;
}

.form-group input,
.form-group textarea,
.form-group select{
  padding:1rem 1.1rem;
  font-size:1rem;
  border:1px solid rgba(9,17,67,.12);
  background:#EBFAFA;
  color:var(--primary);
  border-radius:14px;
  transition:all .28s ease;
  box-shadow:var(--shadow-xs);
  font-family:var(--font-body);
}

.form-group select{
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  padding-right:2.8rem;
  background-image:url("data:image/svg+xml;utf8,<svg fill='%23091143' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'><path d='M5.5 7.5L10 12l4.5-4.5'/></svg>");
  background-repeat:no-repeat;
  background-position:right 14px center;
  background-size:18px;
}

.form-group select option{
  background:#EBFAFA;
  color:#091143;
}

.form-group input:hover,
.form-group textarea:hover,
.form-group select:hover{
  border-color:rgba(24,207,195,.45);
}

.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus{
  outline:none;
  border-color:var(--cta);
  box-shadow:var(--glow-aqua);
  transform:translateY(-2px);
}

.form-group textarea{
  resize:vertical;
  min-height:150px;
}

.contact-form .btn{
  width:fit-content;
  margin-top:.5rem;
  border-radius:999px;
  padding:1rem 2rem;
  background:#D7FFFE;
  color:#091143 !important;
  border:none;
  transition:all .35s ease;
  box-shadow:var(--shadow-sm);
}

.contact-form .btn:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-lg);
  background:#EBFAFA;
  color:#091143 !important;
}

.contact-form .btn:active,
.contact-form .btn:focus{
  background:#d9d9d9;
  color:#091143 !important;
  outline:none;
}

.contact-info-section{
  background:
    radial-gradient(circle at top right,rgba(24,207,195,.20),transparent 35%),
    var(--gradient-dark);
  padding:3rem;
  color:var(--white);
  box-shadow:var(--shadow-lg);
}

.contact-info-section h2{
  color:var(--white);
  margin-bottom:2rem;
}

.contact-info-item{
  display:flex;
  gap:1rem;
  margin-bottom:1.5rem;
  padding:1.15rem;
  border:1px solid rgba(235,250,250,.08);
  background:rgba(235,250,250,.045);
  border-radius:18px;
  transition:all .35s ease;
}

.contact-info-item:hover{
  transform:translateX(8px);
  background:rgba(235,250,250,.08);
  border-color:rgba(24,207,195,.30);
}

.contact-info-item i{
  width:44px;
  height:44px;
  min-width:44px;
  background:var(--gradient-aqua);
  color:var(--primary-dark);
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:14px;
  font-size:1rem;
  box-shadow:0 12px 25px rgba(24,207,195,.22);
}

.contact-info-item h4{
  color:var(--white);
  font-size:.85rem;
  margin-bottom:.25rem;
  letter-spacing:.12em;
}

.contact-info-item p{
  color:rgba(235,250,250,.78);
  font-size:.95rem;
  margin:0;
  line-height:1.6;
}

.contact-hours{
  margin-top:2rem;
  padding:1.5rem;
  border-radius:20px;
  background:rgba(235,250,250,.05);
  border:1px solid rgba(235,250,250,.10);
}

.contact-hours h4{
  color:var(--white);
  margin-bottom:1rem;
  font-size:.9rem;
  letter-spacing:.12em;
}

.hours-list{
  display:flex;
  flex-direction:column;
  gap:.75rem;
}

.hours-list li{
  display:flex;
  justify-content:space-between;
  gap:1rem;
  font-size:.94rem;
  color:rgba(235,250,250,.78);
}

.faq-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:2rem;
}

.faq-item{
  position:relative;
  overflow:hidden;
  padding:2.2rem;
  background:var(--gradient-soft);
  border:1px solid rgba(9,17,67,.08);
  border-radius:24px;
  box-shadow:var(--shadow-sm);
  transition:all .35s ease;
}

.faq-item::before{
  content:'';
  position:absolute;
  left:0;
  top:0;
  width:5px;
  height:100%;
  background:var(--gradient-aqua);
}

.faq-item:hover{
  transform:translateY(-8px);
  box-shadow:var(--shadow-md);
}

.faq-item h3{
  color:var(--primary);
  font-size:1.15rem;
  margin-bottom:.75rem;
}

.faq-item p{
  color:var(--muted);
  font-size:.95rem;
  line-height:1.75;
  margin:0;
}

/* ===================================================================
   FLOW TRANSITIONS + REVEAL
   =================================================================== */
.flow-section{
  position:relative;
  isolation:isolate;
  overflow:hidden;
}

.flow-section::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:-2;
}

.flow-section::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-1px;
  height:110px;
  pointer-events:none;
  z-index:-1;
}

.flow-hero{
  background:
    radial-gradient(circle at 85% 18%,rgba(9,17,67,.10),transparent 28%),
    radial-gradient(circle at 10% 80%,rgba(100,118,115,.12),transparent 32%),
    linear-gradient(180deg,#EBFAFA 0%,#D7FFFE 100%);
}

.flow-light{
  background:
    radial-gradient(circle at 90% 10%,rgba(9,17,67,.06),transparent 26%),
    linear-gradient(180deg,#EBFAFA 0%,#D7FFFE 100%);
}

.flow-mist{
  background:
    radial-gradient(circle at 8% 20%,rgba(9,17,67,.07),transparent 24%),
    radial-gradient(circle at 85% 80%,rgba(100,118,115,.10),transparent 28%),
    linear-gradient(180deg,#D7FFFE 0%,#EBFAFA 100%);
}

.flow-dark{
  background:
    radial-gradient(circle at 25% 0%,rgba(215,255,254,.10),transparent 28%),
    radial-gradient(circle at 78% 100%,rgba(100,118,115,.16),transparent 28%),
    var(--gradient-dark);
}

.flow-navy{
  background:
    radial-gradient(circle at 75% 15%,rgba(215,255,254,.13),transparent 26%),
    var(--gradient-dark);
}

.flow-wave-bottom::after{
  background:url("data:image/svg+xml;utf8,<svg viewBox='0 0 1440 120' xmlns='http://www.w3.org/2000/svg'><path fill='%23D7FFFE' d='M0,60 C180,110 360,20 540,62 C720,104 900,100 1080,55 C1260,10 1350,45 1440,30 L1440,120 L0,120 Z'/></svg>");
  background-size:cover;
  background-repeat:no-repeat;
}

.flow-curve-bottom::after{
  height:130px;
  background:linear-gradient(to bottom,transparent 0%,rgba(235,250,250,.20) 40%,#EBFAFA 100%);
}

.flow-glow-bottom::after{
  height:130px;
  background:linear-gradient(to bottom,transparent 0%,rgba(215,255,254,.18) 48%,#D7FFFE 100%);
}

.flow-curve-top{padding-top:7rem;}
.flow-curve-top::before{background:linear-gradient(to bottom,rgba(9,17,67,.12) 0%,transparent 22%);}

.flow-glow-top{padding-top:6rem;}
.flow-glow-top::before{background:linear-gradient(to bottom,rgba(215,255,254,.22) 0%,transparent 34%);}

.flow-angle-top{padding-top:6rem;}
.flow-angle-top::before{
  clip-path:polygon(0 0,100% 0,100% 16%,0 0);
  background:#D7FFFE;
  z-index:-1;
}

.flow-reveal,
.reveal{
  opacity:0;
  transform:translateY(38px);
  transition:opacity .75s ease,transform .75s ease;
}

.flow-reveal.show,
.reveal.show{
  opacity:1;
  transform:translateY(0);
}

@keyframes fadeUp{
  from{opacity:0;transform:translateY(35px);}
  to{opacity:1;transform:translateY(0);}
}

/* ===================================================================
   RESPONSIVE
   =================================================================== */
@media(max-width:1024px){
  .services-grid,
  .why-grid,
  .team-grid,
  .values-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .projects-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .footer-grid{
    grid-template-columns:repeat(2,1fr);
  }
}

@media(max-width:900px){
  .contact-grid{
    grid-template-columns:1fr;
  }
}

@media(max-width:768px){
  .nav-toggle{
    display:block;
  }

  .nav{
    display:none;
    position:absolute;
    top:100%;
    left:0;
    right:0;
    background:var(--primary);
    flex-direction:column;
    padding:1rem 0;
    border-top:1px solid rgba(235,250,250,.08);
    gap:0;
    z-index:99;
  }

  .nav.nav-open{
    display:flex;
  }

  .nav-link{
    padding:.875rem 2rem;
    width:100%;
    text-align:center;
  }

  .nav-link::after,
  .header-cta{
    display:none;
  }

  .hero{
    padding-top:100px;
  }

  .hero-content{
    text-align:center;
  }

  .hero-description{
    margin-left:auto;
    margin-right:auto;
  }

  .hero-cta{
    justify-content:center;
  }

  .hero-stats{
    justify-content:center;
    flex-wrap:wrap;
    gap:2rem;
    margin-left:auto;
    margin-right:auto;
  }

  .hero-stat{
    min-width:120px;
    text-align:center;
  }

  .story-grid,
  .service-detail-inner,
  .form-row,
  .faq-grid,
  .certs-grid{
    grid-template-columns:1fr;
  }

  .service-detail:nth-child(even) .service-detail-inner{
    direction:ltr;
  }

  .contact-form-section,
  .contact-info-section{
    padding:2rem;
    border-radius:22px;
  }

  .flow-section::after{
    height:75px;
  }

  .flow-curve-top,
  .flow-glow-top,
  .flow-angle-top{
    padding-top:5rem;
  }
}

@media(max-width:640px){
  .container{
    padding:0 1.25rem;
  }

  .section{
    padding:4.5rem 0;
  }

  .services-grid,
  .why-grid,
  .projects-grid,
  .testimonials-grid,
  .team-grid,
  .values-grid,
  .footer-grid,
  .stats-grid{
    grid-template-columns:1fr;
  }

  .stats-grid{
    gap:2rem;
  }

  .cta-details,
  .footer-bottom{
    flex-direction:column;
    text-align:center;
  }

  .footer-legal{
    justify-content:center;
  }

  .hero-tag{
    letter-spacing:.16em;
    font-size:.72rem;
    padding:.65rem 1rem;
  }

  .hero-cta{
    flex-direction:column;
  }

  .hero-cta .btn{
    width:100%;
  }
}

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


/* ===================================================================
   PROCESS SECTION
   =================================================================== */

   .process-advanced{
  padding:6rem 0;
  background:#f8fbfd;
  overflow:hidden;
}

.process-advanced-grid{
  display:grid;
  grid-template-columns:1fr 1.15fr;
  gap:5rem;
  align-items:center;
}

.process-visual{
  position:relative;
  min-height:540px;
}

.shape-bg{
  position:absolute;
  width:280px;
  height:280px;
  right:25px;
  top:80px;
  background:rgba(24,207,195,.16);
  clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);
  z-index:0;
}

.process-visual::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  width:230px;
  height:230px;
  border-top:3px solid var(--cta);
  border-left:3px solid var(--cta);
  border-radius:90px 0 0 0;
}

.image-card{
  position:absolute;
  overflow:hidden;
  background:#fff;
  box-shadow:0 22px 50px rgba(9,17,67,.16);
}

.image-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.image-card-main{
  width:78%;
  height:430px;
  left:35px;
  top:28px;
  border-radius:38px 18px 38px 18px;
  transform:rotate(-1deg);
}

.image-card-overlap{
  width:60%;
  height:300px;
  right:0;
  bottom:10px;
  border:8px solid #fff;
  border-radius:18px 48px 18px 48px;
  transform:rotate(1.5deg);
}

.process-details h2{
  color:var(--primary);
  margin-bottom:2.5rem;
}

.process-list{
  position:relative;
}

.process-list::before{
  content:"";
  position:absolute;
  left:28px;
  top:20px;
  bottom:20px;
  width:2px;
  background:linear-gradient(to bottom,var(--cta),rgba(9,17,67,.2));
}

.process-item{
  display:grid;
  grid-template-columns:60px 1fr;
  gap:1.5rem;
  position:relative;
  padding:0 0 1.7rem;
  margin-bottom:1.7rem;
  border-bottom:1px solid rgba(9,17,67,.12);
}

.process-item:last-child{
  margin-bottom:0;
}

.process-badge{
  width:58px;
  height:58px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#fff;
  color:var(--primary);
  border:2px solid rgba(9,17,67,.25);
  font-size:1.3rem;
  font-weight:800;
  font-family:var(--font-heading);
  clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);
  position:relative;
  z-index:2;
  transition:.35s ease;
}

.process-item.active .process-badge,
.process-item:hover .process-badge{
  background:var(--primary);
  color:#fff;
  border-color:var(--primary);
  transform:scale(1.08);
}

.process-info h3{
  color:var(--primary);
  font-size:1.35rem;
  margin-bottom:.55rem;
}

.process-info p{
  color:var(--muted);
  line-height:1.7;
  margin:0;
}

.process-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-top:1.2rem;
  padding:.85rem 1.7rem;
  border:2px solid var(--cta);
  border-radius:999px;
  color:var(--primary);
  font-weight:800;
  text-decoration:none;
  transition:.35s ease;
}

.process-btn:hover{
  background:var(--cta);
  color:var(--primary-dark);
  transform:translateY(-3px);
}

@media(max-width:1024px){
  .process-advanced-grid{
    grid-template-columns:1fr;
    gap:3rem;
  }

  .process-visual{
    min-height:520px;
  }
}

@media(max-width:600px){
  .process-advanced{
    padding:4rem 0;
  }

  .process-visual{
    min-height:420px;
  }

  .image-card-main{
    width:88%;
    height:310px;
    left:10px;
  }

  .image-card-overlap{
    width:72%;
    height:220px;
  }

  .process-item{
    grid-template-columns:48px 1fr;
    gap:1rem;
  }

  .process-list::before{
    left:23px;
  }

  .process-badge{
    width:48px;
    height:48px;
    font-size:1rem;
  }
}


/* ================= FIX: SERVICE IMAGE ALIGNMENT ================= */

.service-detail-inner{
  align-items:flex-start;
}

.service-detail-image{
  margin-top:.35rem;
}

.service-detail:nth-child(even) .service-detail-image{
  margin-top:.35rem;
}

@media(max-width:900px){
  .service-detail-image{
    margin-top:0;
  }
}


/* ================= HEADER SCROLL ================= */

.header{
  transition:height .35s ease, background .35s ease, box-shadow .35s ease;
}

.header.scrolled{
  height:76px;
  background:rgba(9,17,67,.985);
  box-shadow:0 16px 45px rgba(6,3,21,.22);
}


/* ================= BACK TO TOP ================= */

.back-to-top{
  position:fixed;
  right:22px;
  bottom:22px;
  width:48px;
  height:48px;
  border:none;
  border-radius:50%;
  background:var(--cta);
  color:var(--primary-dark);
  font-size:1.4rem;
  font-weight:800;
  cursor:pointer;
  z-index:999;
  opacity:0;
  visibility:hidden;
  transform:translateY(18px) scale(.9);
  transition:.35s ease;
  box-shadow:0 15px 35px rgba(24,207,195,.28);
}

.back-to-top.show{
  opacity:1;
  visibility:visible;
  transform:translateY(0) scale(1);
}

.back-to-top:hover{
  transform:translateY(-5px) scale(1.05);
  background:var(--cta-dark);
  color:#fff;
}


/* ================= SERVICE PREMIUM FLOW ================= */

.service-detail{
  position:relative;
  overflow:hidden;
  isolation:isolate;
}

.service-detail::after{
  content:"";
  position:absolute;
  width:260px;
  height:260px;
  border-radius:50%;
  right:-120px;
  top:20%;
  background:rgba(24,207,195,.10);
  z-index:-1;
  transition:.6s ease;
}

.service-detail:hover::after{
  transform:scale(1.15);
}


/* ================= IMAGE EFFECT ================= */

.service-detail-image{
  border-radius:28px;
  box-shadow:0 24px 65px rgba(9,17,67,.16);
  transition:.45s ease;
}

.service-detail-image::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg, transparent 35%, rgba(255,255,255,.38), transparent 65%);
  transform:translateX(-130%);
  transition:.8s ease;
}

.service-detail:hover .service-detail-image::before{
  transform:translateX(130%);
}

.service-detail-image:hover{
  transform:translateY(-8px) scale(1.03);
  box-shadow:0 35px 90px rgba(9,17,67,.24);
}


/* ================= HEADING STYLE ================= */

.service-detail-content h2{
  position:relative;
  display:inline-block;
}

.service-detail-content h2::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-10px;
  width:70px;
  height:4px;
  border-radius:50px;
  background:var(--gradient-aqua);
}


/* ================= LIST STYLE ================= */

.service-includes{
  padding:1.25rem;
  border-radius:20px;
  background:rgba(255,255,255,.45);
  border:1px solid rgba(9,17,67,.08);
  box-shadow:var(--shadow-xs);
}

.service-includes li{
  transition:.3s ease;
}

.service-includes li:hover{
  transform:translateX(6px);
}

.service-includes li i{
  transition:.3s ease;
}

.service-includes li:hover i{
  transform:scale(1.25);
  color:var(--primary);
}


/* ================= BUTTON ================= */

.service-detail .btn{
  border-radius:999px;
  box-shadow:0 16px 35px rgba(9,17,67,.14);
}

.service-detail .btn:hover{
  background:var(--cta);
  color:var(--primary-dark);
  box-shadow:0 20px 45px rgba(24,207,195,.28);
}


/* ================= RESPONSIVE ================= */

@media(max-width:768px){
  .header.scrolled{
    height:72px;
  }

  .back-to-top{
    right:16px;
    bottom:16px;
    width:44px;
    height:44px;
  }
}


/* ================= REDUCED MOTION ================= */

@media(prefers-reduced-motion:reduce){
  *{
    transition:none !important;
    transform:none !important;
  }
}