
:root {
  --alpine-white: #F8FDFF;
  --sapphire: #0F52BA;
  --platinum: #E5E7EB;
  --cold-gold: #C6A15B;
  --midnight: #071B3A;
  --ice-text: #5f7188;
  --soft-shadow: 0 24px 70px rgba(7, 27, 58, 0.12);
  --brand-gradient: linear-gradient(135deg, #F8FDFF 0%, #0F52BA 42%, #E5E7EB 70%, #C6A15B 100%);
}

html { scroll-behavior: smooth; }
body {
  background: radial-gradient(circle at 18% 10%, rgba(248,253,255,0.95), transparent 26%),
              radial-gradient(circle at 82% 22%, rgba(15,82,186,0.14), transparent 30%),
              linear-gradient(180deg, #F8FDFF 0%, #ffffff 48%, #F4F8FC 100%);
  color: var(--ice-text);
}
body:before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: .38;
  background-image: linear-gradient(rgba(15,82,186,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(15,82,186,.04) 1px, transparent 1px);
  background-size: 54px 54px;
  z-index: -1;
}

a { color: var(--sapphire); }
a:hover { color: var(--cold-gold); }
h1,h2,h3,h4,h5,h6 { color: var(--midnight); }

.primary_bg {
  background: linear-gradient(135deg, rgba(248,253,255,0.96) 0%, rgba(229,231,235,0.75) 45%, rgba(15,82,186,0.08) 100%) !important;
  position: relative;
  overflow: hidden;
}
.primary_bg:before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 20% 15%, rgba(198,161,91,.22), transparent 26%), radial-gradient(circle at 80% 70%, rgba(15,82,186,.18), transparent 28%);
  pointer-events: none;
}
.primary_bg .container { position: relative; z-index: 1; }

.header_area {
  padding: 26px 0;
  transition: all .25s ease;
}
.header_area.navbar_fixed,
.header_area.header_absolute:hover {
  background: rgba(248,253,255,.92);
  backdrop-filter: blur(18px);
  box-shadow: 0 10px 36px rgba(7,27,58,.08);
}
.logo h3 {
  color: var(--sapphire);
  font-size: 26px;
  letter-spacing: .02em;
  text-transform: none;
  background: linear-gradient(120deg, #0F52BA 0%, #071B3A 55%, #C6A15B 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.main_menu ul li a {
  color: var(--midnight);
  font-weight: 600;
}
.main_menu ul li a:hover { color: var(--sapphire); }
.slicknav_menu { background: transparent; }
.slicknav_btn { background: var(--sapphire); }
.slicknav_nav { background: rgba(7,27,58,.96); border-radius: 18px; padding: 12px; }
.slicknav_nav a { color: #fff; }

.welcome_area {
  min-height: 850px;
  display: flex;
  align-items: center;
  background: linear-gradient(135deg, #F8FDFF 0%, rgba(248,253,255,.96) 25%, rgba(15,82,186,.12) 55%, rgba(229,231,235,.58) 78%, rgba(198,161,91,.16) 100%);
  overflow: hidden;
  position: relative;
}
.welcome_area:before {
  content: "";
  position: absolute;
  width: 880px;
  height: 880px;
  border-radius: 50%;
  right: -320px;
  top: -260px;
  background: var(--brand-gradient);
  opacity: .18;
  filter: blur(2px);
}
.welcome_area:after {
  content: "";
  position: absolute;
  width: 520px;
  height: 520px;
  left: -240px;
  bottom: -160px;
  border-radius: 50%;
  border: 1px solid rgba(15,82,186,.18);
  box-shadow: inset 0 0 90px rgba(198,161,91,.15);
}
.welcome_area .container { position: relative; z-index: 2; }
.title .eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 9px 16px;
  margin-bottom: 22px;
  border: 1px solid rgba(198,161,91,.45);
  border-radius: 999px;
  color: var(--sapphire);
  background: rgba(255,255,255,.66);
  box-shadow: 0 12px 32px rgba(7,27,58,.07);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.title h1 {
  font-size: clamp(42px, 6vw, 76px);
  line-height: .98;
  letter-spacing: -0.05em;
  color: var(--midnight);
}
.title h6 {
  max-width: 720px;
  color: #516a84;
  font-weight: 400;
  font-size: 22px;
  line-height: 1.55;
}
.apps img,
.feature_tab_img_right img,
.feature_tab_img_left img,
.apps_app img,
.single_screen img {
  border-radius: 34px;
  box-shadow: var(--soft-shadow);
  border: 1px solid rgba(248,253,255,.72);
}
.apps .apps_img {
  transform: rotate(1.4deg);
}

.heading h1 {
  letter-spacing: -0.035em;
  color: var(--midnight);
}
.heading p {
  color: var(--ice-text);
}
.hbm h1:after {
  background: linear-gradient(90deg, var(--sapphire), var(--cold-gold)) !important;
}

.single_core_feature,
.single_about,
.single_more_feature,
.card,
.contact_form,
.contact_info,
.single_footer {
  background: rgba(255,255,255,.84) !important;
  border: 1px solid rgba(229,231,235,.96) !important;
  border-radius: 28px !important;
  box-shadow: 0 20px 60px rgba(7,27,58,.08) !important;
  backdrop-filter: blur(14px);
}
.single_core_feature:hover,
.single_about:hover,
.single_more_feature:hover {
  transform: translateY(-6px);
  box-shadow: 0 30px 90px rgba(15,82,186,.16) !important;
}
.single_core_feature h6,
.single_about h6,
.single_more_feature h6 {
  color: var(--midnight) !important;
  font-size: 22px;
}
.content_box p { color: #65768a; }
.single_core_feature:before,
.single_about:before,
.single_more_feature:before {
  background: linear-gradient(135deg, var(--sapphire), var(--cold-gold)) !important;
}

.feature_area { position: relative; overflow: hidden; }
.feature_area:before {
  content: "";
  position: absolute;
  width: 320px;
  height: 320px;
  border-radius: 50%;
  background: rgba(15,82,186,.06);
  right: 8%;
  top: 8%;
  pointer-events: none;
}
.feature_img_right,
.feature_img_left {
  opacity: .5;
  filter: saturate(.8) blur(.5px);
}

.screen_carousel .owl-dots button,
.testimonials .owl-dots button { background: rgba(15,82,186,.22) !important; }
.screen_carousel .owl-dots button.active,
.testimonials .owl-dots button.active { background: var(--cold-gold) !important; }

.faq_area .card { margin-bottom: 18px; overflow: hidden; }
.faq_area .card-header { background: linear-gradient(90deg, rgba(248,253,255,.92), rgba(229,231,235,.52)); border: 0; }
.faq_area .btn-link {
  color: var(--midnight);
  font-weight: 700;
  text-decoration: none;
}
.faq_area .btn-link:hover { color: var(--sapphire); text-decoration: none; }
.card-body { color: #61748b; }

.contact_area {
  background: linear-gradient(135deg, rgba(248,253,255,.92), rgba(15,82,186,.08), rgba(198,161,91,.12));
  padding-top: 80px;
}
.contact_form { padding: 34px; }
.form-control {
  border-radius: 18px !important;
  border: 1px solid rgba(15,82,186,.16) !important;
  background: rgba(248,253,255,.88) !important;
  min-height: 58px;
  color: var(--midnight) !important;
}
.form-control:focus {
  border-color: var(--sapphire) !important;
  box-shadow: 0 0 0 4px rgba(15,82,186,.12) !important;
}
.btn-primary,
button.btn-primary {
  background: linear-gradient(135deg, var(--sapphire), #073B88 62%, var(--cold-gold)) !important;
  border: 0 !important;
  border-radius: 999px !important;
  color: #fff !important;
  padding: 16px 30px !important;
  font-weight: 800;
  letter-spacing: .02em;
  box-shadow: 0 18px 36px rgba(15,82,186,.22);
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 24px 44px rgba(15,82,186,.28); }
.contact_info { padding: 42px; }
.contact_info h3 { color: var(--sapphire); }
.contact_info strong { color: var(--midnight); }

.footer.footer1 {
  background: linear-gradient(135deg, #071B3A 0%, #0F52BA 58%, #1A3768 100%) !important;
  color: rgba(248,253,255,.82);
  position: relative;
  overflow: hidden;
}
.footer.footer1:before {
  content: "";
  position: absolute;
  width: 700px;
  height: 700px;
  right: -240px;
  top: -240px;
  background: radial-gradient(circle, rgba(198,161,91,.34), transparent 62%);
}
.footer .single_footer {
  background: rgba(248,253,255,.08) !important;
  border-color: rgba(248,253,255,.16) !important;
  box-shadow: none !important;
  padding: 28px;
}
.footer h3 { color: #fff !important; }
.footer p,
.footer li,
.footer a { color: rgba(248,253,255,.82) !important; }
.footer a:hover { color: var(--cold-gold) !important; }
.copyright {
  background: #06142A !important;
  color: rgba(248,253,255,.82);
}
.copyright a { color: var(--cold-gold); }

.page-simple {
  min-height: 100vh;
  padding: 120px 20px;
  background: linear-gradient(135deg, #F8FDFF, #E5E7EB);
}
.page-simple .panel {
  max-width: 920px;
  margin: 0 auto;
  background: rgba(255,255,255,.9);
  border: 1px solid rgba(15,82,186,.13);
  border-radius: 32px;
  box-shadow: var(--soft-shadow);
  padding: 48px;
}
.page-simple h1 { color: var(--sapphire); margin-bottom: 20px; }
.page-simple h2 { margin-top: 28px; font-size: 26px; }
.page-simple p, .page-simple li { color: #5f7188; }

@media (max-width: 991px) {
  .welcome_area { padding-top: 140px; min-height: auto; padding-bottom: 80px; }
  .title h1 { font-size: 44px; }
  .title h6 { font-size: 18px; }
  .apps { margin-top: 40px; }
  .contact_info { margin-top: 30px; text-align: left !important; }
}
@media (max-width: 575px) {
  body { font-size: 17px; line-height: 1.6; }
  .title h1 { font-size: 36px; }
  .contact_form, .contact_info, .page-simple .panel { padding: 24px; }
  .logo h3 { font-size: 21px; }
}
.single_more_feature {
  padding: 0 15px;
}