:root {
  --tropical-turquoise: #06B6D4;
  --tropical-coral: #FF6B6B;
  --tropical-sand: #FDE68A;
  --tropical-palm: #15803D;
  --tropical-ink: #063F46;
  --tropical-soft: #FFF7DF;
  --tropical-mint: #E8FBF5;
}

body {
  color: #315b60;
  background: linear-gradient(180deg, #fffdf4 0%, #f3fffb 52%, #fff8e1 100%);
}

a { color: var(--tropical-ink); }
a:hover { color: var(--tropical-coral); }

.logo { max-width: none; }
.logo h3 {
  color: #ffffff;
  font-size: 26px;
  line-height: 1.15;
  letter-spacing: -0.5px;
  margin: 0;
  text-shadow: 0 2px 16px rgba(0,0,0,.18);
}

.header_absolute {
  background: linear-gradient(90deg, rgba(6,182,212,.96), rgba(255,107,107,.92), rgba(253,230,138,.92), rgba(21,128,61,.92));
  box-shadow: 0 14px 40px rgba(6, 63, 70, .14);
  backdrop-filter: blur(10px);
}
.header_area.sticky {
  background: rgba(255, 255, 255, .94);
  box-shadow: 0 15px 35px rgba(6, 63, 70, .12);
}
.header_area.sticky .logo h3,
.header_area.sticky .main_menu ul li a { color: var(--tropical-ink); }
.main_menu ul li a {
  color: #ffffff;
  font-size: 17px;
  font-weight: 700;
  letter-spacing: .2px;
}
.main_menu ul li a:hover { color: var(--tropical-sand); }
.slicknav_menu {
  background: transparent;
}
.slicknav_nav {
  background: rgba(6, 63, 70, .96);
  border-radius: 18px;
  padding: 14px;
  margin-top: 12px;
}
.slicknav_btn {
  background: var(--tropical-ink);
  border-radius: 14px;
}

.welcome_area {
  min-height: 900px;
  height: auto;
  overflow: hidden;
  isolation: isolate;
  background:
    radial-gradient(circle at 78% 28%, rgba(253,230,138,.78) 0 9%, transparent 10% 100%),
    radial-gradient(circle at 12% 78%, rgba(21,128,61,.24) 0 16%, transparent 17% 100%),
    linear-gradient(135deg, #06B6D4 0%, #28C8D3 22%, #FF6B6B 54%, #FDE68A 78%, #15803D 100%);
  padding-top: 110px;
}
.welcome_area:before,
.welcome_area:after {
  content: "";
  position: absolute;
  border-radius: 999px;
  z-index: -1;
  filter: blur(1px);
}
.welcome_area:before {
  width: 520px;
  height: 520px;
  right: -160px;
  top: 110px;
  background: rgba(255,255,255,.16);
}
.welcome_area:after {
  width: 680px;
  height: 680px;
  left: -220px;
  bottom: -260px;
  background: rgba(255,255,255,.12);
}
.title h1 {
  color: #ffffff !important;
  font-size: 62px;
  line-height: 72px;
  text-shadow: 0 14px 38px rgba(6, 63, 70, .28);
}
.title h6 {
  color: #fffdf4 !important;
  max-width: 720px;
  text-shadow: 0 8px 26px rgba(6, 63, 70, .2);
}
.apps img,
.apps_app img,
.feature_tab_img_right img,
.feature_tab_img_left img,
.mobile_feature_img img,
.mobile_feature_img2 img,
.single_screen img,
.feature_img_right,
.feature_img_left {
  border-radius: 34px;
  box-shadow: 0 30px 80px rgba(6, 63, 70, .22);
}
.apps img.apps_img,
.apps img.mobile_img {
  max-height: 660px;
  object-fit: cover;
  border: 9px solid rgba(255,255,255,.64);
}

.primary_bg {
  background: linear-gradient(135deg, rgba(6,182,212,.10) 0%, rgba(255,107,107,.08) 35%, rgba(253,230,138,.34) 70%, rgba(21,128,61,.10) 100%);
}
.heading h1,
.content_box h6,
h1, h2, h3, h4, h5, h6 {
  color: var(--tropical-ink);
}
.heading p,
.content_box p,
p { color: #315b60; }

.single_core_feature,
.single_more_feature,
.single_about,
.faq_area .card,
.contact_info {
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(6,182,212,.16);
  border-radius: 28px;
  box-shadow: 0 22px 60px rgba(6, 63, 70, .08);
}
.single_core_feature,
.single_about,
.single_more_feature {
  padding: 38px 32px;
  min-height: 100%;
}
.single_core_feature:hover,
.single_more_feature:hover,
.single_about:hover {
  transform: translateY(-6px);
  background: linear-gradient(135deg, rgba(255,255,255,.94), rgba(232,251,245,.96));
  box-shadow: 0 28px 70px rgba(6, 63, 70, .14);
}
.content_box h6:before {
  content: "";
  display: block;
  width: 54px;
  height: 6px;
  border-radius: 50px;
  margin: 0 auto 16px;
  background: linear-gradient(90deg, #06B6D4, #FF6B6B, #FDE68A, #15803D);
}
.more_feature_content h6:before { margin-left: 0; }
.single_about .content_box h6:before { margin-left: auto; margin-right: auto; }

.feature_area { overflow: hidden; }
.feature_area:nth-of-type(odd) {
  background: linear-gradient(180deg, rgba(255,255,255,0), rgba(232,251,245,.42));
}
img.feature_img_right,
img.feature_img_left {
  border: 10px solid rgba(255,255,255,.75);
}

.screen_carousel .owl-dots .owl-dot { background: rgba(6,182,212,.22); }
.screen_carousel .owl-dots .owl-dot.active { background: var(--tropical-coral); }
.single_screen img {
  border: 8px solid rgba(255,255,255,.75);
  max-height: 560px;
  object-fit: cover;
}

.faq_area {
  background: linear-gradient(135deg, rgba(6,182,212,.08), rgba(253,230,138,.28));
}
.faq_area .card {
  overflow: hidden;
  margin-bottom: 18px;
  border: 1px solid rgba(6,182,212,.18) !important;
}
.faq_area .card-header {
  background: rgba(255,255,255,.78);
  border-bottom: 1px solid rgba(6,182,212,.14);
}
.faq_area button.btn.btn-link {
  color: var(--tropical-ink);
  font-weight: 800;
  text-decoration: none;
  white-space: normal;
}
.faq_area button.btn.btn-link[aria-expanded=true] {
  color: var(--tropical-coral);
}
.card-body {
  color: #315b60;
  font-size: 17px;
  line-height: 1.72;
  background: #ffffff;
}

.contact_area {
  background: linear-gradient(135deg, rgba(6,182,212,.13), rgba(255,107,107,.06), rgba(253,230,138,.32));
  padding: 90px 0;
}
.contact_form .form-control {
  border: 1px solid rgba(6,182,212,.25);
  border-radius: 18px;
  padding: 16px 18px;
  background: rgba(255,255,255,.9);
  color: var(--tropical-ink);
}
.contact_form .form-control:focus {
  border-color: var(--tropical-turquoise);
  box-shadow: 0 0 0 4px rgba(6,182,212,.14);
}
.contact_form .btn-primary {
  background: linear-gradient(90deg, #06B6D4, #FF6B6B, #FDE68A, #15803D);
  background-size: 220% 100%;
  border: none;
  border-radius: 999px;
  color: #063F46;
  font-weight: 900;
  padding: 14px 34px;
  transition: all .3s ease;
}
.contact_form .btn-primary:hover {
  background-position: 100% 0;
  transform: translateY(-2px);
  box-shadow: 0 18px 38px rgba(6,63,70,.16);
}
.contact_info {
  padding: 36px;
}
.contact_info h3,
.contact_info p strong { color: var(--tropical-ink); }
.contact_info p { color: #315b60; }

.footer {
  background: linear-gradient(135deg, #063F46 0%, #06B6D4 28%, #FF6B6B 58%, #15803D 100%);
  color: #ffffff;
}
.single_footer h3,
.single_footer p,
.single_footer ul li p,
.single_footer ul li a,
.footer_pera {
  color: #ffffff !important;
}
.single_footer ul li a:hover {
  color: #FDE68A !important;
}
.copyright {
  background: #063F46;
  border-top: 1px solid rgba(255,255,255,.16);
}
.copyright p,
.copyright a { color: #ffffff; }
.copyright a:hover { color: #FDE68A; }

@media screen and (max-width: 767px) {
  .welcome_area { padding: 150px 0 80px; }
  .title h1 { font-size: 38px; line-height: 46px; }
  .title h6 { font-size: 19px; line-height: 30px; }
  .logo h3 { font-size: 20px; }
  .single_core_feature,
  .single_about,
  .single_more_feature { margin-bottom: 22px; }
}


/* FAQ expanded indicator */
.faq_area button.btn.btn-link[aria-expanded=true]:after {
    content: '✓';
    font-weight: 700;
    color: #15803D;
}
