.why-choose-us-bg {
  position: relative;
  width: 100%;
  min-height: 100vh;
  background: url('/why-us-bg.webp') center center / cover no-repeat;
  overflow-x: hidden;
}
.why-choose-us-bg__overlay {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(18,20,28,0.88) 60%, rgba(35,36,60,0.97) 100%);
  z-index: 1;
  pointer-events: none;
}

@media (max-width: 600px) {
  .why-choose-us-bg {
    background: url('/why-us-bg.webp') center center / cover no-repeat !important;
    animation: none !important;
    background-blend-mode: normal !important;
  }
}

.hero-section {
  padding: 6rem 2rem 4rem;
  text-align: center;
  position: relative;
  z-index: 3;
}
.hero-badge {
  display: inline-block;
  padding: 0.8em 2.4em;
  border-radius: 40px;
  font-size: 1.18rem;
  font-weight: 700;
  background: linear-gradient(90deg, #60a5fa 40%, #a855f7 100%);
  color: #fff;
  margin-bottom: 2.2rem;
  letter-spacing: 0.07em;
  box-shadow: 0 2px 12px rgba(59,130,246,0.09);
  text-transform: uppercase;
  position: relative;
  z-index: 2;
}
.hero-title {
  font-size: 3.3rem;
  font-weight: 800;
  margin-bottom: 1rem;
  letter-spacing: 0.02em;
  font-family: 'Inter', Arial, sans-serif;
  background: linear-gradient(135deg,#60a5fa,#a855f7 90%);
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 2px 32px rgba(96,165,250,0.13);
  line-height: 1.1;
  z-index: 2;
}
.hero-subtitle {
  color: #d1d5db;
  font-size: 1.44rem;
  margin-bottom: 2.5rem;
  font-weight: 500;
  text-shadow: 0 1px 8px #181a23;
  z-index: 2;
}
.main-reasons-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(430px, 1fr));
  gap: 2.5rem;
  margin-bottom: 3.2rem;
  position: relative;
  z-index: 2;
}
.glass-card {
  position: relative;
  background: rgba(18,22,38,0.82);
  border-radius: 24px;
  box-shadow: 0 16px 56px 0 rgba(0,0,0,0.32);
  border: 1px solid rgba(96,165,250,0.14);
  padding: 2.8rem 2.3rem;
  margin-bottom: 0.5rem;
  overflow: hidden;
  transition: box-shadow .2s, transform .2s;
  backdrop-filter: blur(12px);
}
.glass-card.large-card {
  min-height: 350px;
}
.card-content {
  position: relative;
  z-index: 2;
}
.card-title {
  font-size: 2.1rem;
  font-weight: 700;
  margin-bottom: 1.5rem;
  background: linear-gradient(135deg,#60a5fa,#a855f7 90%);
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  letter-spacing: 0.01em;
}
.feature-list {
  margin-bottom: 0.2em;
  padding-left: 0;
  list-style: none;
}
.feature-list li {
  font-size: 1.15em;
  color: #e5e7eb;
  margin-bottom: 0.7em;
  display: flex;
  align-items: flex-start;
  gap: 0.7em;
  line-height: 1.55;
}
.feature-icon {
  font-size: 1.3em;
  color: #60a5fa;
  margin-right: 0.2em;
  margin-top: 0.1em;
}
.team-grid {
  display: flex;
  justify-content: center;
  align-items: stretch;
  gap: 2.2em;
  margin: 0 auto 1.2em auto;
  flex-wrap: wrap;
  width: 100%;
  max-width: 1100px;
}
.team-member {
  flex: 1 1 270px;
  max-width: 330px;
  min-width: 240px;
  background: rgba(59,130,246,0.07);
  border-radius: 1em;
  box-shadow: 0 2px 12px rgba(59,130,246,0.10);
  display: flex;
  align-items: center;
  gap: 1em;
  padding: 1.2em 1.5em;
  margin: 0.4em;
  justify-content: flex-start;
}
.member-avatar {
  width: 54px;
  height: 54px;
  border-radius: 50%;
  background: linear-gradient(135deg,#60a5fa,#a855f7);
  color: #fff;
  font-size: 2em;
  font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 20px rgba(59,130,246,0.07);
}
.member-name {
  font-weight: 700;
  color: #60a5fa;
  font-size: 1.08em;
}
.member-role {
  font-size: 0.97em;
  color: #d1d5db;
}
.member-desc {
  font-size: 0.94em;
  color: #cbd5e1;
}
.expertise-note {
  text-align: center;
  font-size: 1.15em;
  color: #a855f7;
  margin-top: 2em;
  margin-bottom: 0.4em;
  width: 100%;
  display: block;
}
.team-section-title {
  text-align: center;
  font-size: 3.2rem;
  font-weight: 800;
  margin-bottom: 2rem;
  background: linear-gradient(135deg,#60a5fa,#a855f7 90%);
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  letter-spacing: 0.01em;
}
.features-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
  gap: 2.2rem;
  margin-bottom: 3.2rem;
  position: relative;
  z-index: 2;
}
.feature-card {
  padding: 2.2rem 1.5rem;
  min-height: 225px;
  border-radius: 22px;
}
.feature-icon-large {
  font-size: 2.7em; color: #60a5fa; margin-bottom: 0.5em;
}
.feature-title {
  font-size: 1.28em;
  font-weight: 700;
  color: #fff;
  margin-bottom: 0.8em;
}
.feature-list.small li {
  font-size: 1.07em; color: #e5e7eb;
}
.work-section {
  margin-bottom: 0;
  position: relative;
  z-index: 2;
}
.section-header {
  text-align: center;
  margin-bottom: 1.7em;
}
.section-title {
  font-size: 3em;
  font-weight: 700;
  background: linear-gradient(135deg,#60a5fa,#a855f7 90%);
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  margin-bottom: 0.3em;
}
.section-subtitle {
  font-size: 1.13em;
  color: #e0e7ef;
}
.masonry-container {
  margin-top: 0.5em;
  margin-bottom: 2.5em;
  z-index: 2;
  position: relative;
}
.page-bottom-section.separate-review-section {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  padding-bottom: 3.5em !important;
  position: relative;
  z-index: 3;
  clear: both;
  display: block;
}
.testimonials-section {
  position: relative;
  max-width: 900px;
  margin: 0 auto;
  padding-bottom: 4em;
}
.testimonial-card {
  background: rgba(18,22,38,0.86);
  border-radius: 18px;
  box-shadow: 0 8px 32px rgba(59,130,246,0.11);
  padding: 2em 1.5em;
  color: #fff;
  margin-bottom: 1em;
  font-size: 1.08em;
  transition: box-shadow .2s, transform .2s;
  border: 1px solid rgba(96,165,250,0.2);
}
.testimonial-center-container {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin-bottom: 1.5em;
}

/* === Animated Review Button - FINAL VERSION === */
.review-animated-btn {
  margin: 0;
  height: auto;
  background: transparent;
  padding: 0;
  border: none;
  cursor: pointer;
  position: relative;
  display: inline-block;
  border-radius: 0.75em;
  min-width: 220px;
  overflow: hidden;
}

.review-animated-btn .actual-text {
  letter-spacing: 3px;
  text-transform: uppercase;
  font-size: 1.15em;
  font-family: "Arial", "Inter", sans-serif;
  font-weight: bold;
  padding: 0.6em 2em;
  border-radius: 0.75em;
  box-shadow: 0 2px 12px rgba(59,130,246,0.09);
  background: linear-gradient(90deg, #60a5fa 45%, #a855f7 100%);
  color: transparent;
  position: relative;
  z-index: 1;
  -webkit-text-stroke: 1px rgba(255,255,255,0.6);
  transition: opacity 0.45s cubic-bezier(.4,0,.2,1);
  display: block;
  text-align: center;
}

.review-animated-btn .hover-text {
  letter-spacing: 3px;
  text-transform: uppercase;
  font-size: 1.15em;
  font-family: "Arial", "Inter", sans-serif;
  font-weight: bold;
  padding: 0.6em 2em;
  border-radius: 0.75em;
  box-shadow: 0 2px 12px rgba(59,130,246,0.09);
  background: linear-gradient(90deg, #60a5fa 45%, #a855f7 100%);
  color: #37FF8B;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
  -webkit-text-stroke: 1px #37FF8B;
  border-right: 6px solid #37FF8B;
  filter: drop-shadow(0 0 23px #37FF8B);
  overflow: hidden;
  max-width: 0;
  transition: max-width 0.45s cubic-bezier(.4,0,.2,1);
  text-align: center;
  pointer-events: none;
}

.review-animated-btn:hover .actual-text,
.review-animated-btn:focus .actual-text {
  opacity: 0.2;
}

.review-animated-btn:hover .hover-text,
.review-animated-btn:focus .hover-text {
  max-width: 100%;
}

.review-animated-btn .hover-text,
.review-animated-btn .actual-text {
  white-space: nowrap;
}

@media (max-width: 600px) {
  .review-animated-btn .actual-text,
  .review-animated-btn .hover-text {
    font-size: 1em;
    padding: 0.5em 1.2em;
  }
  .review-animated-btn {
    min-width: 140px;
  }
}

/* Modal styles for review */
.review-modal {
  background: rgba(18,22,38,0.97);
  border-radius: 20px;
  box-shadow: 0 10px 44px #232339;
  padding: 2.5em 2em 2em;
  position: fixed;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 9999;
  max-width: 380px;
  width: 90vw;
  min-width: 260px;
  max-height: 85vh;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  overflow-y: auto;
  border: 1px solid #60a5fa33;
  margin: 0;
}

/* For PC and large screens, ensure modal is always centered and not scrollable */
@media (min-width: 601px) {
  .review-modal {
    left: 50% !important;
    top: 50% !important;
    transform: translate(-50%, -50%) !important;
    position: fixed !important;
    margin: 0 !important;
  }
}

/* Prevent page scroll when modal is open (PC & mobile) */
body.review-modal-open,
html.review-modal-open {
  overflow: hidden !important;
  height: 100vh !important;
}

.fixed.inset-0.z-50.flex.items-center.justify-center.bg-black\/70.backdrop-blur-sm {
  position: fixed;
  z-index: 9998 !important;
  top: 0; left: 0; width: 100vw; height: 100vh;
  background: rgba(0,0,0,0.7);
  backdrop-filter: blur(4px);
  overflow: hidden;
}

.review-modal .close-btn,
.review-modal .absolute.top-3.right-3 {
  position: absolute;
  top: 1em;
  right: 1em;
  color: #fff;
  font-size: 1.6em;
  background: transparent;
  border: none;
  cursor: pointer;
  z-index: 10001;
  transition: color 0.2s;
}
.review-modal .close-btn:hover,
.review-modal .absolute.top-3.right-3:hover {
  color: #60a5fa;
}

/* Modal form styling */
.review-modal form {
  width: 100%;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 1em;
}
.review-modal input,
.review-modal textarea {
  width: 100%;
  background: #181818;
  border: 1.5px solid #60a5fa50;
  border-radius: 8px;
  color: #fff;
  font-size: 1em;
  padding: 0.75em 1em;
  transition: border 0.18s, box-shadow 0.18s;
  box-shadow: 0 2px 14px #23243c08;
  resize: none;
}
.review-modal input:focus,
.review-modal textarea:focus {
  border-color: #60a5fa;
  box-shadow: 0 0 0 2px #60a5fa25;
  outline: none;
}
.review-modal button[type="submit"] {
  background: linear-gradient(90deg, #60a5fa 45%, #a855f7 100%);
  color: #fff;
  font-weight: 700;
  border-radius: 9px;
  font-size: 1.1em;
  box-shadow: 0 4px 18px rgba(59,130,246,0.13);
  border: none;
  padding: 1em 2em;
  cursor: pointer;
  transition: background 0.14s, transform 0.14s;
  margin-top: 0.2em;
}
.review-modal button[type="submit"]:hover {
  background: linear-gradient(90deg,#a855f7 45%,#60a5fa 100%);
  transform: scale(1.02);
}
.review-modal h3 {
  font-size: 1.35em;
  font-weight: bold;
  margin-bottom: 1em;
  color: #60a5fa;
  text-align: center;
  letter-spacing: 0.02em;
}
.review-modal .text-red-400,
.review-modal .text-green-400 {
  font-size: 0.95em;
  font-weight: 500;
  text-align: center;
  margin-top: 0.5em;
}

/* Mobile styling (unchanged) */
@media (max-width: 600px) {
  .review-modal {
    padding: 1.2em 0.6em 1.2em;
    min-width: 0 !important;
    width: 96vw !important;
    max-width: 98vw !important;
    font-size: 0.98em !important;
    border-radius: 14px;
    left: 50% !important;
    top: 50% !important;
    transform: translate(-50%, -50%) !important;
    margin: 0 !important;
  }
  .review-modal h3 {
    font-size: 1.18em;
  }
  .review-modal .close-btn,
  .review-modal .absolute.top-3.right-3 {
    font-size: 1.5em !important;
    top: 0.7em !important;
    right: 0.7em !important;
  }
  .fixed.inset-0.z-50.flex.items-center.justify-center.bg-black\/70.backdrop-blur-sm {
    width: 100vw !important;
    height: 100vh !important;
    left: 0 !important;
    top: 0 !important;
    z-index: 9998 !important;
    position: fixed !important;
    overflow: hidden !important;
  }
  html, body {
    max-width: 100vw !important;
    overflow-x: hidden !important;
  }
}