/* FAMILY&FLATS GLOBAL CSS */
/* Final frozen font: Manrope */
/* Universal header + top strip + dropdown system */

@import url("https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800;900&display=swap");

html,
body {
  font-family: "Manrope", Arial, sans-serif !important;
  color: #111827;
  font-size: 15px;
  line-height: 1.65;
  letter-spacing: -0.015em;
}

body,
body *:not(i):not(.fa):not(.fas):not(.far):not(.fal):not(.fab):not(.fa-solid):not(.fa-regular):not(.fa-brands):not(.fa-classic):not(.fa-sharp):not(.fa-duotone),
button,
input,
textarea,
select,
option {
  font-family: "Manrope", Arial, sans-serif !important;
}

i::before,
.fa::before,
.fas::before,
.far::before,
.fal::before,
.fab::before,
.fa-solid::before,
.fa-regular::before,
.fa-brands::before {
  font-family: inherit !important;
}

.fa,
.fas,
.fa-solid,
.fa-regular,
.far {
  font-family: "Font Awesome 6 Free" !important;
  font-weight: 900 !important;
}

.fab,
.fa-brands {
  font-family: "Font Awesome 6 Brands" !important;
  font-weight: 400 !important;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: "Manrope", Arial, sans-serif !important;
  font-weight: 800 !important;
  color: #0f172a;
  letter-spacing: -0.04em;
  line-height: 1.15;
}

p,
a,
li,
span,
div,
label,
td,
th,
small,
strong,
b,
button,
input,
textarea,
select {
  letter-spacing: -0.015em;
}

p {
  color: #64748b;
  line-height: 1.75;
}

/* UNIVERSAL TOP STRIP */
body .top-header {
  background: linear-gradient(90deg, #1d4ed8 0%, #4338ca 55%, #6d28d9 100%) !important;
  color: #ffffff !important;
  padding: 0 !important;
  min-height: 48px !important;
  height: 48px !important;
  display: flex !important;
  align-items: center !important;
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.18) !important;
}

body .top-header .container-fluid {
  width: 100% !important;
  padding-left: 28px !important;
  padding-right: 0 !important;
}

body .top-head-web {
  width: 100% !important;
  height: 48px !important;
  min-height: 48px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 20px !important;
}

body .a-content {
  display: flex !important;
  align-items: center !important;
  gap: 30px !important;
}

body .top-header a {
  color: #ffffff !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  line-height: 1 !important;
  text-decoration: none !important;
}

body .top-header i {
  color: #ffffff !important;
  margin-right: 8px !important;
  font-size: 14px !important;
}

body .top-header .socail-media-account,
body .top-header .social-media-account {
  height: 48px !important;
  display: flex !important;
  align-items: center !important;
}

body .top-header .socail-media-account > div,
body .top-header .social-media-account > div {
  height: 48px !important;
  display: flex !important;
  align-items: stretch !important;
  gap: 0 !important;
}

body .top-header .socail-media-account a,
body .top-header .social-media-account a,
body .top-header .link-in {
  width: 48px !important;
  height: 48px !important;
  min-width: 48px !important;
  min-height: 48px !important;
  max-width: 48px !important;
  max-height: 48px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: rgba(255, 255, 255, 0.08) !important;
  color: #ffffff !important;
  border-left: 1px solid rgba(255, 255, 255, 0.22) !important;
  border-right: 0 !important;
  border-top: 0 !important;
  border-bottom: 0 !important;
  border-radius: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
  line-height: 1 !important;
}

body .top-header .socail-media-account a i,
body .top-header .social-media-account a i,
body .top-header .link-in i {
  margin: 0 !important;
  color: #ffffff !important;
  font-size: 15px !important;
  line-height: 1 !important;
}

body .top-header .socail-media-account a:hover,
body .top-header .social-media-account a:hover,
body .top-header .link-in:hover {
  background: rgba(255, 255, 255, 0.18) !important;
  color: #ffffff !important;
}

/* UNIVERSAL MAIN NAVBAR */
body .navbar {
  background: #ffffff !important;
  padding: 16px 28px !important;
  min-height: 112px !important;
  box-shadow: 0 8px 28px rgba(15,23,42,0.08) !important;
  font-family: "Manrope", Arial, sans-serif !important;
  z-index: 9999 !important;
}

body .navbar .container-fluid {
  display: flex !important;
  align-items: center !important;
}

body .navbar-brand {
  display: flex !important;
  align-items: center !important;
  margin-right: 40px !important;
}

body .navbar-brand img {
  width: 105px !important;
  max-width: 105px !important;
  height: auto !important;
  display: block !important;
}

body .navbar-collapse {
  align-items: center !important;
}

body .navbar-nav {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
}

body .navbar-nav .nav-item {
  display: flex !important;
  align-items: center !important;
}

body .navbar-nav .nav-link {
  color: #111827 !important;
  font-size: 14px !important;
  font-weight: 900 !important;
  padding: 10px 4px !important;
  line-height: 1.2 !important;
  border-radius: 8px !important;
  white-space: nowrap !important;
}

body .navbar-nav .nav-link:hover {
  color: #2563eb !important;
}

/* UNIVERSAL CALL BUTTON */
body .call-action {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  background: linear-gradient(135deg, #2563eb 0%, #4f46e5 55%, #7c3aed 100%) !important;
  color: #ffffff !important;
  border-radius: 13px !important;
  padding: 14px 22px !important;
  font-size: 16px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  box-shadow: 0 14px 34px rgba(79,70,229,0.24) !important;
  text-decoration: none !important;
  white-space: nowrap !important;
}

body .call-action:hover {
  background: linear-gradient(135deg, #ffd166 0%, #f6c453 100%) !important;
  color: #0f172a !important;
}

body .call-action i {
  color: inherit !important;
}

/* UNIVERSAL CUSTOM DROPDOWN */
body .custom-dropdown {
  position: relative !important;
}

body .custom-dropdown > a {
  cursor: pointer !important;
}

body .custom-dropdown-menu {
  display: none !important;
  position: absolute !important;
  top: 100% !important;
  left: 0 !important;
  min-width: 190px !important;
  background: #ffffff !important;
  border: 1px solid #e5e7eb !important;
  border-radius: 14px !important;
  padding: 10px !important;
  margin: 0 !important;
  list-style: none !important;
  box-shadow: 0 18px 45px rgba(15,23,42,.14) !important;
  z-index: 999999 !important;
}

body .custom-dropdown:hover .custom-dropdown-menu,
body .custom-dropdown.open .custom-dropdown-menu {
  display: block !important;
}

body .custom-dropdown-menu li {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

body .custom-dropdown-menu a {
  display: block !important;
  padding: 10px 14px !important;
  border-radius: 8px !important;
  color: #111827 !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  text-decoration: none !important;
  background: #ffffff !important;
  white-space: nowrap !important;
}

body .custom-dropdown-menu a:hover {
  background: #f1f7fb !important;
  color: #2563eb !important;
}

/* MOBILE */
@media (max-width: 991px) {
  body .top-header {
    height: auto !important;
    min-height: auto !important;
    padding: 10px 0 !important;
  }

  body .top-header .container-fluid {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  body .top-head-web,
  body .a-content {
    height: auto !important;
    min-height: auto !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 8px !important;
  }

  body .top-header .socail-media-account > div,
  body .top-header .social-media-account > div {
    height: auto !important;
  }

  body .top-header .socail-media-account a,
  body .top-header .social-media-account a,
  body .top-header .link-in {
    width: 36px !important;
    height: 36px !important;
    min-width: 36px !important;
    min-height: 36px !important;
  }

  body .navbar {
    min-height: auto !important;
    padding: 14px 18px !important;
  }

  body .navbar-brand img {
    width: 92px !important;
  }

  body .navbar-nav {
    align-items: flex-start !important;
    gap: 4px !important;
    padding-top: 14px !important;
  }

  body .custom-dropdown-menu {
    position: static !important;
    box-shadow: none !important;
    margin-top: 8px !important;
  }
}
/* FAMILY&FLATS GLOBAL TOPBAR + NAVBAR */
.ff-topbar{
  background:#0b4f8a !important;
  color:#fff !important;
  padding:8px 22px !important;
  font-size:14px !important;
  font-family:"Manrope", Arial, sans-serif !important;
}

.ff-topbar-inner{
  max-width:1320px !important;
  margin:0 auto !important;
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:18px !important;
}

.ff-topbar-left,
.ff-topbar-right{
  display:flex !important;
  align-items:center !important;
  gap:18px !important;
}

.ff-topbar a{
  color:#fff !important;
  text-decoration:none !important;
  font-weight:700 !important;
}

.ff-topbar-right a{
  width:32px !important;
  height:32px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  background:#061b2d !important;
  border-radius:8px !important;
}

.ff-navbar-wrap{
  background:#fff !important;
  box-shadow:0 8px 28px rgba(15,23,42,.08) !important;
  position:sticky !important;
  top:0 !important;
  z-index:9999 !important;
}

.ff-navbar{
  max-width:1320px !important;
  margin:0 auto !important;
  padding:14px 22px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:20px !important;
}

.ff-logo img{
  width:105px !important;
  max-width:105px !important;
  height:auto !important;
  display:block !important;
}

.ff-nav-center{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:14px !important;
  flex-wrap:wrap !important;
}

.ff-nav-center a,
.ff-dropdown button{
  color:#111827 !important;
  background:transparent !important;
  border:0 !important;
  font-size:14px !important;
  font-weight:800 !important;
  text-decoration:none !important;
  padding:9px 6px !important;
  cursor:pointer !important;
  font-family:"Manrope", Arial, sans-serif !important;
}

.ff-nav-center a:hover,
.ff-dropdown button:hover{
  color:#00aeef !important;
}

.ff-dropdown{
  position:relative !important;
}

.ff-dropdown-menu{
  display:none !important;
  position:absolute !important;
  top:100% !important;
  left:0 !important;
  min-width:190px !important;
  background:#fff !important;
  padding:10px !important;
  border-radius:14px !important;
  box-shadow:0 18px 45px rgba(15,23,42,.14) !important;
  z-index:99999 !important;
}

.ff-dropdown:hover .ff-dropdown-menu{
  display:block !important;
}

.ff-dropdown-menu a{
  display:block !important;
  padding:10px 14px !important;
  border-radius:8px !important;
  white-space:nowrap !important;
}

.ff-dropdown-menu a:hover{
  background:#f1f7fb !important;
  color:#00aeef !important;
}

.ff-call-btn{
  background:#0b4f8a !important;
  color:#fff !important;
  padding:12px 18px !important;
  border-radius:10px !important;
  font-weight:800 !important;
  text-decoration:none !important;
  white-space:nowrap !important;
}

.ff-call-btn:hover{
  background:#00aeef !important;
  color:#fff !important;
}

@media(max-width:900px){
  .ff-topbar-inner,
  .ff-topbar-left,
  .ff-topbar-right{
    flex-direction:column !important;
    align-items:flex-start !important;
    gap:8px !important;
  }

  .ff-navbar{
    flex-direction:column !important;
    align-items:flex-start !important;
  }

  .ff-nav-center{
    justify-content:flex-start !important;
  }
}