/* RTL preparation layer for Arabic localization */
html[dir="rtl"],
html[dir="rtl"] body {
  direction: rtl;
}

html[dir="rtl"] body {
  font-family: "Cairo", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-variation-settings: "slnt" 0;
  font-size: 18px;
  line-height: 1.8;
}

/* Force Cairo on all text nodes (exclude icon fonts) */
html[dir="rtl"] body *:not(i):not(.fa):not(.glyphicon):not([class^="fa-"]):not([class*=" fa-"]) {
  font-family: "Cairo", sans-serif !important;
  font-optical-sizing: auto;
  font-style: normal;
  font-variation-settings: "slnt" 0;
}

html[dir="rtl"] .navbar-inverse .navbar-brand,
html[dir="rtl"] .navbar-inverse .navbar-nav > li > a,
html[dir="rtl"] .header.active .navbar-nav > li > a {
  font-family: "Cairo", sans-serif !important;
  font-optical-sizing: auto;
  font-style: normal;
  font-variation-settings: "slnt" 0;
}

/* Typography scale-up for Arabic readability */
html[dir="rtl"] p {
  font-size: 18px;
  line-height: 1.95;
}

html[dir="rtl"] .navbar-nav > li > a,
html[dir="rtl"] .header.active .navbar-nav > li > a {
  font-size: 17px !important;
  font-weight: 500;
  letter-spacing: 0 !important;
  text-transform: none;
}

html[dir="rtl"] .primary-white-button a,
html[dir="rtl"] .primary-blue-button a,
html[dir="rtl"] .pop-button h4,
html[dir="rtl"] #contact button {
  font-size: 17px !important;
  letter-spacing: 0;
}

html[dir="rtl"] .filter-categories ul li span,
html[dir="rtl"] .tabs a,
html[dir="rtl"] .tabgroup .text-content span,
html[dir="rtl"] .tabgroup .text-content a,
html[dir="rtl"] #contact input,
html[dir="rtl"] #contact textarea,
html[dir="rtl"] footer .logo p,
html[dir="rtl"] footer .location h4,
html[dir="rtl"] footer .location ul li,
html[dir="rtl"] footer .contact-info h4,
html[dir="rtl"] footer .contact-info ul li,
html[dir="rtl"] footer .connect-us h4 {
  font-size: 17px !important;
}

html[dir="rtl"] .tabgroup .text-content h4,
html[dir="rtl"] #testimonial .testimonials-item h4 {
  font-size: 22px;
}

/* Align About section buttons across cards */
html[dir="rtl"] #about .row {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
}

html[dir="rtl"] #about .row > [class*="col-"] {
  display: flex;
}

html[dir="rtl"] #about .service-item {
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
}

html[dir="rtl"] #about .service-item .primary-blue-button {
  margin-top: auto;
  padding-top: 35px;
}

html[dir="rtl"] #about .service-item .icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  line-height: 1;
  width: 110px;
  height: 110px;
}

html[dir="rtl"] #about .service-item .icon img {
  display: inline-block;
  width: auto;
  height: auto;
  max-width: 52px;
  max-height: 52px;
}

html[dir="rtl"] .baner-content .text-content h2 {
  font-size: 65px;
  line-height: 1.3;
}

html[dir="rtl"] .section-heading h4,
html[dir="rtl"] #about .service-item h4 {
  font-size: 24px !important;
}

html[dir="rtl"] .tabgroup .text-content span,
html[dir="rtl"] .tabgroup .text-content a,
html[dir="rtl"] #contact input,
html[dir="rtl"] #contact textarea,
html[dir="rtl"] #contact button,
html[dir="rtl"] footer .logo p,
html[dir="rtl"] footer .location ul li,
html[dir="rtl"] footer .contact-info ul li {
  line-height: 1.9;
}

@media (max-width: 768px) {
  html[dir="rtl"] .baner-content .text-content h2 {
    font-size: 38px;
  }

  html[dir="rtl"] p,
  html[dir="rtl"] .tabs a,
  html[dir="rtl"] .filter-categories ul li span,
  html[dir="rtl"] #contact input,
  html[dir="rtl"] #contact textarea,
  html[dir="rtl"] footer .location ul li,
  html[dir="rtl"] footer .contact-info ul li {
    font-size: 16px !important;
  }
}

html[dir="rtl"] .navbar-header,
html[dir="rtl"] .navbar-brand {
  float: right;
}

html[dir="rtl"] .header .container {
  position: relative;
}

html[dir="rtl"] .header .navbar {
  position: relative;
  min-height: 80px;
}

html[dir="rtl"] .navbar-logo-left {
  position: fixed;
  left: 16px;
  top: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  z-index: 10002;
}

html[dir="rtl"] .navbar-logo-left img {
  display: block;
  width: auto;
  height: 52px;
  max-width: 180px;
  object-fit: contain;
}

@media (min-width: 768px) {
  html[dir="rtl"] .navbar-nav {
    float: right;
    margin-left: 190px;
  }

  html[dir="rtl"] .navbar-nav > li {
    float: right;
    margin-right: 45px;
    margin-left: 0;
  }
}

@media (max-width: 768px) {
  html[dir="rtl"] .navbar-logo-left {
    left: 8px;
    top: 8px;
    padding: 6px 8px;
  }

  html[dir="rtl"] .navbar-logo-left img {
    height: 42px;
    max-width: 150px;
  }

  html[dir="rtl"] .navbar-toggle {
    float: left;
    margin-left: 15px;
    margin-right: 0;
  }

  html[dir="rtl"] .navbar-inverse .navbar-nav > li {
    margin-right: 0;
    margin-left: 0;
  }
}

@media (min-width: 992px) {
  html[dir="rtl"] #portfolio .row > .col-md-4,
  html[dir="rtl"] #portfolio .row > .col-md-8,
  html[dir="rtl"] #blog .wrapper > .col-md-4,
  html[dir="rtl"] #blog .wrapper > .col-md-8,
  html[dir="rtl"] footer .row > [class*="col-md-"] {
    float: right;
  }
}

html[dir="rtl"] #portfolio .section-heading {
  margin-right: -100vh;
  margin-left: 0;
  padding-right: 100vh;
  padding-left: 0;
}

html[dir="rtl"] #portfolio .section-heading p {
  padding-left: 70px;
  padding-right: 0;
}

html[dir="rtl"] #blog .section-heading {
  text-align: right;
  margin-right: -100vh;
  margin-left: 0;
  padding-right: 100vh;
  padding-left: 0;
}

html[dir="rtl"] #blog .section-heading p,
html[dir="rtl"] .tabs {
  padding-left: 70px;
  padding-right: 0;
}

html[dir="rtl"] .tabgroup .text-content {
  text-align: right;
}

html[dir="rtl"] #contact input,
html[dir="rtl"] #contact textarea {
  text-align: right;
  padding-right: 15px;
  padding-left: 0;
}

html[dir="rtl"] #contact input[type="email"] {
  direction: ltr;
  text-align: left;
}

html[dir="rtl"] footer .location ul li:first-child {
  margin-left: 15px;
  margin-right: 0;
  padding-left: 15px;
  padding-right: 0;
  border-left: 1px solid rgba(250, 250, 250, 0.1);
  border-right: none;
}

html[dir="rtl"] footer .connect-us ul li {
  margin-left: 2px;
  margin-right: 0;
}

@media (max-width: 385px) {
  html[dir="rtl"] footer .location ul li:first-child {
    margin-left: 0;
    padding-left: 0;
    border-left: none;
  }
}
