.elementor-15488 .elementor-element.elementor-element-a60a77a{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-15488 .elementor-element.elementor-element-a60a77a:not(.elementor-motion-effects-element-type-background), .elementor-15488 .elementor-element.elementor-element-a60a77a > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#0F1117;}.elementor-theme-builder-content-area{height:400px;}.elementor-location-header:before, .elementor-location-footer:before{content:"";display:table;clear:both;}/* Start custom CSS for html, class: .elementor-element-05f3157 */.rm-footer, .rm-footer * {
  margin: 0; padding: 0;
  box-sizing: border-box;
  -webkit-font-smoothing: antialiased;
}

/* ── Variables ── */
.rm-footer {
  --f-primary:   #DD2928;
  --f-secondary: #3B82F6;
  --f-bg:        #0F1117;
  --f-surface:   #181C27;
  --f-border:    rgba(255,255,255,0.07);
  --f-white:     #ffffff;
  --f-muted:     rgba(255,255,255,0.52);
  --f-text:      rgba(255,255,255,0.82);
  --f-font:      'Clash Display', sans-serif;
}

/* ── Wrapper ── */
.rm-footer {
  font-family: var(--f-font);
  background: var(--f-bg);
  color: var(--f-text);
  width: 100%;
  position: relative;
  overflow: hidden;
}

/* ── Background decoration ── */
.rm-footer::before {
  content: '';
  position: absolute;
  top: -180px; left: -180px;
  width: 520px; height: 520px;
  background: radial-gradient(circle, rgba(221,41,40,0.12) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}
.rm-footer::after {
  content: '';
  position: absolute;
  bottom: -120px; right: -120px;
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(59,130,246,0.09) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}

/* ── Red top accent bar ── */
.rm-footer-accent {
  height: 4px;
  background: linear-gradient(90deg, var(--f-primary) 0%, #ff6b6b 50%, var(--f-secondary) 100%);
}

/* ── Main grid ── */
.rm-footer-main {
  position: relative;
  z-index: 1;
  max-width: 1320px;
  margin: 0 auto;
  padding: 64px 32px 48px;
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1.5fr;
  gap: 48px;
}

/* ── Column: About ── */
.rm-f-logo {
  display: block;
  margin-bottom: 20px;
}
.rm-f-logo img {
  height: 56px;
  width: auto;
  object-fit: contain;
  /* brighten logo for dark bg */
  filter: brightness(1.1);
}

.rm-f-about-text {
  font-size: 14px;
  font-weight: 400;
  line-height: 1.75;
  color: var(--f-muted);
  margin-bottom: 24px;
}

/* Contact pills */
.rm-f-contacts {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.rm-f-contact {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 13.5px;
  font-weight: 500;
  color: var(--f-text);
  text-decoration: none;
  transition: color 0.2s;
}
.rm-f-contact:hover { color: var(--f-primary); }
.rm-f-contact-icon {
  width: 34px; height: 34px;
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: transform 0.2s;
}
.rm-f-contact:hover .rm-f-contact-icon { transform: scale(1.1); }
.rm-f-contact-icon svg { width: 16px; height: 16px; }
.rm-f-contact-icon.phone { background: rgba(221,41,40,0.15); color: var(--f-primary); }
.rm-f-contact-icon.email { background: rgba(59,130,246,0.15); color: var(--f-secondary); }

/* ── Column headings ── */
.rm-f-col-title {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: var(--f-white);
  margin-bottom: 22px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.rm-f-col-title::after {
  content: '';
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, rgba(221,41,40,0.5), transparent);
}

/* ── Link lists ── */
.rm-f-links {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.rm-f-links li a {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 0;
  font-size: 13.5px;
  font-weight: 500;
  color: var(--f-muted);
  text-decoration: none;
  border-bottom: 1px solid var(--f-border);
  transition: color 0.2s, padding-left 0.2s;
}
.rm-f-links li:last-child a { border-bottom: none; }
.rm-f-links li a:hover {
  color: var(--f-white);
  padding-left: 6px;
}
.rm-f-links li a::before {
  content: '';
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--f-primary);
  flex-shrink: 0;
  opacity: 0.6;
  transition: opacity 0.2s, transform 0.2s;
}
.rm-f-links li a:hover::before {
  opacity: 1;
  transform: scale(1.4);
}

/* ── Offices column ── */
.rm-f-offices {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.rm-f-office {
  padding: 12px 0;
  border-bottom: 1px solid var(--f-border);
}
.rm-f-office:last-child { border-bottom: none; }

.rm-f-office-city {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  color: var(--f-primary);
  margin-bottom: 4px;
}
.rm-f-office-city svg { width: 12px; height: 12px; }

.rm-f-office-phone {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 600;
  color: var(--f-text);
  text-decoration: none;
  margin-bottom: 2px;
  transition: color 0.2s;
}
.rm-f-office-phone:hover { color: var(--f-primary); }

.rm-f-office-addr {
  font-size: 12px;
  font-weight: 400;
  color: var(--f-muted);
  line-height: 1.5;
}

/* ── Divider ── */
.rm-footer-divider {
  position: relative;
  z-index: 1;
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 32px;
}
.rm-footer-divider hr {
  border: none;
  height: 1px;
  background: var(--f-border);
}

/* ── Bottom bar ── */
.rm-footer-bottom {
  position: relative;
  z-index: 1;
  max-width: 1320px;
  margin: 0 auto;
  padding: 24px 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.rm-footer-copy {
  font-size: 13px;
  font-weight: 500;
  color: var(--f-muted);
}
.rm-footer-copy span { color: var(--f-primary); }

/* Social icons */
.rm-f-socials {
  display: flex;
  align-items: center;
  gap: 10px;
}
.rm-f-social {
  width: 38px; height: 38px;
  border-radius: 10px;
  background: var(--f-surface);
  border: 1px solid var(--f-border);
  display: flex; align-items: center; justify-content: center;
  color: var(--f-muted);
  text-decoration: none;
  transition: background 0.2s, color 0.2s, transform 0.2s, border-color 0.2s;
}
.rm-f-social:hover {
  transform: translateY(-3px);
}
.rm-f-social.fb:hover  { background: #1877F2; border-color: #1877F2; color: #fff; }
.rm-f-social.ig:hover  { background: linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888); border-color: transparent; color: #fff; }
.rm-f-social.wa:hover  { background: #25D366; border-color: #25D366; color: #fff; }
.rm-f-social svg { width: 18px; height: 18px; }

/* ── Responsive ── */
@media (max-width: 1100px) {
  .rm-footer-main {
    grid-template-columns: 1fr 1fr;
    gap: 40px;
  }
}
@media (max-width: 640px) {
  .rm-footer-main {
    grid-template-columns: 1fr;
    padding: 40px 20px 32px;
    gap: 32px;
  }
  .rm-footer-divider { padding: 0 20px; }
  .rm-footer-bottom {
    padding: 20px;
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
  }
  .rm-footer-copy { font-size: 12.5px; }
}/* End custom CSS */