/**************************************************************
   style-rtl.css — RTL base
   Version 3.6 (cleaned)
   Created by: Morad M. Althaher
   Brand: primary #051939, secondary #ff4d00
   Comments in EN only
***************************************************************/
:root {
  --color-primary: #051939;
  --color-primary-rgb: 5, 25, 57; /* focus rings, shadows */
  --color-secondary: #ff4d00; /* brand accent */
  --color-text: #333333;
  --color-background: #ffffff;
  --color-muted: #f4f4f4;
  --color-border: #dddddd;
  --color-whatsapp: #25D366;
  --font-family-base: 'Cairo', sans-serif;
  --btn-radius: 8px;
  --transition-speed: 0.3s;
  --swiper-navigation-size: 48px;
  --swiper-pagination-bullet-size: 12px;
  --swiper-pagination-bullet-horizontal-gap: 6px;
  --slide-min-height: 420px;
  --slide-border-radius: 12px;
  --slide-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  --slide-content-padding: 2rem;
  --arrow-color-rgb: 255, 77, 0; /* match secondary */
  --arrow-icon-color: white;
  --bullet-color: #ccc;
  --bullet-active-color: #000;
  --bullet-text-color: #fff;
}

/* Force light color scheme for the whole page */
html {
  color-scheme: light;
  background-color: #ffffff;
}

* { box-sizing: border-box; direction: rtl; }

body {
  font-family: var(--font-family-base);
  background-color: var(--color-background);
  color: var(--color-text);
  line-height: 1.6;
  text-align: right;
  margin: 0;
}

h1, h2, h3, h4, h5, h6 {
  color: var(--color-primary);
  font-weight: 700;
  margin-bottom: 1rem;
}
h1 { font-size: 2.5rem; }
h2 { font-size: 2rem; }
h3 { font-size: 1.75rem; }
h4 { font-size: 1.5rem; }
h5 { font-size: 1.25rem; }
h6 { font-size: 1rem; }

/* =============================
   Buttons (unified theme states)
   ============================= */
/* Base */
button, .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: 0.6rem 1.2rem;
  border-radius: var(--btn-radius);
  border: 1px solid transparent;
  font-weight: 600;
  line-height: 1.2;
  cursor: pointer;
  text-decoration: none;
  user-select: none;
  transition:
    background-color var(--transition-speed),
    color var(--transition-speed),
    box-shadow var(--transition-speed),
    border-color var(--transition-speed),
    opacity var(--transition-speed);
}
.btn:focus-visible { outline: none; box-shadow: 0 0 0 .25rem rgba(var(--color-primary-rgb), .25); }
.btn:disabled, .btn.disabled { opacity: .65; pointer-events: none; }

/* Sizes + layout */
.btn-sm { padding: .35rem .75rem; font-size: .875rem; }
.btn-lg { padding: .9rem 1.6rem; font-size: 1.05rem; }
.btn-block{ width: 100%; }
.btn-icon { width: 2.5rem; height: 2.5rem; padding: 0; }
.btn i, .btn svg { margin: 0 !important; } /* spacing via gap */

/* Anchor buttons — keep link buttons acting like buttons (no underline) without forcing colors */
a.btn,
a.btn:link,
a.btn:visited { text-decoration: none; }
a.btn:hover,
a.btn:focus { text-decoration: none; }

/* Safety: keep white text on filled variants even for visited anchors */
a.btn-primary:link, a.btn-primary:visited,
a.btn-dark:link, a.btn-dark:visited,
a.btn-info:link, a.btn-info:visited,
a.btn-success:link, a.btn-success:visited,
a.btn-danger:link, a.btn-danger:visited,
a.btn-accent:link, a.btn-accent:visited { color:#fff; }

/* Filled variants */
.btn-primary { background-color: var(--color-primary); color:#fff; border-color: var(--color-primary); }
.btn-primary:hover, .btn-primary:focus {
  background-color: color-mix(in srgb, var(--color-primary) 88%, black 12%);
  border-color: color-mix(in srgb, var(--color-primary) 88%, black 12%);
  box-shadow: 0 8px 18px rgba(var(--color-primary-rgb), .18);
}
.btn-primary:active, .btn-primary.active {
  background-color: color-mix(in srgb, var(--color-primary) 80%, black 20%);
  border-color: color-mix(in srgb, var(--color-primary) 80%, black 20%);
}

.btn-accent { background-color: var(--color-secondary); color:#fff; border-color: var(--color-secondary); }
.btn-accent:hover, .btn-accent:focus { background-color:#e04300; border-color:#e04300; color:var(--color-primary); }

.btn-danger { background-color:#a30000; color:#fff; border-color:#a30000; }
.btn-danger:hover, .btn-danger:focus { background-color:#c70808; border-color:#c70808; }

.btn-success { background-color:#28a745; color:#fff; border-color:#28a745; }
.btn-success:hover, .btn-success:focus { background-color:#218838; border-color:#218838; box-shadow:0 8px 18px rgba(40,167,69,.18); }
.btn-success:active, .btn-success.active { background-color:#1e7e34; border-color:#1e7e34; }

.btn-info { background-color:#17a2b8; color:#fff; border-color:#17a2b8; }
.btn-info:hover, .btn-info:focus { background-color:#138496; border-color:#138496; box-shadow:0 8px 18px rgba(23,162,184,.18); }
.btn-info:active, .btn-info.active { background-color:#117a8b; border-color:#117a8b; }

.btn-warning { background-color:#ffc107; color:#212529; border-color:#ffc107; }
.btn-warning:hover, .btn-warning:focus { background-color:#e0a800; border-color:#e0a800; box-shadow:0 8px 18px rgba(255,193,7,.18); }
.btn-warning:active, .btn-warning.active { background-color:#d39e00; border-color: #d39e00; }

.btn-dark { background-color:#343a40; color:#fff; border-color:#343a40; }
.btn-dark:hover, .btn-dark:focus { background-color:#23272b; border-color:#23272b; box-shadow:0 8px 18px rgba(52,58,64,.18); }
.btn-dark:active, .btn-dark.active { background-color:#1d2124; border-color:#1d2124; }

/* Outline variants */
.btn-outline-primary { background:#fff; color: var(--color-primary); border: 2px solid currentColor !important; }
.btn-outline-primary:hover, .btn-outline-primary:focus {
  background: var(--color-primary); color:#fff; border-color: var(--color-primary) !important;
  box-shadow: 0 8px 18px rgba(var(--color-primary-rgb), .18);
}
.btn-outline-secondary { background:#fff; color: var(--color-primary); border: 2px solid currentColor !important; }
.btn-outline-secondary:hover, .btn-outline-secondary:focus { background: var(--color-primary); color:#fff; border-color: var(--color-primary) !important; }
.btn-outline-accent { background:#fff; color: var(--color-secondary); border: 2px solid currentColor !important; }
.btn-outline-accent:hover, .btn-outline-accent:focus { background: var(--color-secondary); color:#fff; border-color: var(--color-secondary) !important; }
.btn-outline-danger { background:#fff; color:#a30000; border: 2px solid currentColor !important; }
.btn-outline-danger:hover, .btn-outline-danger:focus { background:#a30000; color:#fff; border-color:#a30000 !important; }
.btn-outline-success { background:#fff; color:#28a745; border: 2px solid currentColor !important; }
.btn-outline-success:hover, .btn-outline-success:focus {
  background:#28a745; color:#fff; border-color:#28a745 !important;
  box-shadow:0 8px 18px rgba(40,167,69,.18);
}
.btn-outline-info { background:#fff; color:#17a2b8; border: 2px solid currentColor !important; }
.btn-outline-info:hover, .btn-outline-info:focus {
  background:#17a2b8; color:#fff; border-color:#17a2b8 !important;
  box-shadow:0 8px 18px rgba(23,162,184,.18);
}
.btn-outline-warning { background:#fff; color:#ffc107; border: 2px solid currentColor !important; }
.btn-outline-warning:hover, .btn-outline-warning:focus {
  background:#ffc107; color:#212529; border-color:#ffc107 !important;
  box-shadow:0 8px 18px rgba(255,193,7,.18);
}
.btn-outline-dark { background:#fff; color:#343a40; border: 2px solid currentColor !important; }
.btn-outline-dark:hover, .btn-outline-dark:focus {
  background:#343a40; color:#fff; border-color:#343a40 !important;
  box-shadow:0 8px 18px rgba(52,58,64,.18);
}

/* Soft (tinted) */
.btn-soft-primary { color: var(--color-primary);
  background-color: color-mix(in srgb, var(--color-primary) 10%, white 90%);
  border-color: color-mix(in srgb, var(--color-primary) 15%, white 85%);
}
.btn-soft-primary:hover, .btn-soft-primary:focus{
  background-color: color-mix(in srgb, var(--color-primary) 16%, white 84%);
  border-color: color-mix(in srgb, var(--color-primary) 22%, white 78%);
}
.btn-soft-accent { color: var(--color-secondary);
  background-color: color-mix(in srgb, var(--color-secondary) 12%, white 88%);
  border-color: color-mix(in srgb, var(--color-secondary) 18%, white 82%);
}
.btn-soft-accent:hover, .btn-soft-accent:focus{
  background-color: color-mix(in srgb, var(--color-secondary) 20%, white 80%);
  border-color: color-mix(in srgb, var(--color-secondary) 28%, white 72%);
}
.btn-soft-success { color:#28a745;
  background-color: color-mix(in srgb, #28a745 10%, white 90%);
  border-color: color-mix(in srgb, #28a745 15%, white 85%);
}
.btn-soft-success:hover, .btn-soft-success:focus{
  background-color: color-mix(in srgb, #28a745 16%, white 84%);
  border-color: color-mix(in srgb, #28a745 22%, white 78%);
}
.btn-soft-info { color:#17a2b8;
  background-color: color-mix(in srgb, #17a2b8 10%, white 90%);
  border-color: color-mix(in srgb, #17a2b8 15%, white 85%);
}
.btn-soft-info:hover, .btn-soft-info:focus{
  background-color: color-mix(in srgb, #17a2b8 16%, white 84%);
  border-color: color-mix(in srgb, #17a2b8 22%, white 78%);
}
.btn-soft-warning { color:#ffc107;
  background-color: color-mix(in srgb, #ffc107 10%, white 90%);
  border-color: color-mix(in srgb, #ffc107 15%, white 85%);
}
.btn-soft-warning:hover, .btn-soft-warning:focus{
  background-color: color-mix(in srgb, #ffc107 16%, white 84%);
  border-color: color-mix(in srgb, #ffc107 22%, white 78%);
}
.btn-soft-dark { color:#343a40;
  background-color: color-mix(in srgb, #343a40 10%, white 90%);
  border-color: color-mix(in srgb, #343a40 15%, white 85%);
}
.btn-soft-dark:hover, .btn-soft-dark:focus{
  background-color: color-mix(in srgb, #343a40 16%, white 84%);
  border-color: color-mix(in srgb, #343a40 22%, white 78%);
}

/* Ghost (borderless) */
.btn-ghost-primary { background:transparent; color:var(--color-primary); border-color:transparent; }
.btn-ghost-primary:hover, .btn-ghost-primary:focus { background:rgba(var(--color-primary-rgb), .08); }
.btn-ghost-accent { background:transparent; color:var(--color-secondary); border-color:transparent; }
.btn-ghost-accent:hover, .btn-ghost-accent:focus { background:rgba(255,77,0,.08); }
.btn-ghost-success { background:transparent; color:#28a745; border-color:transparent; }
.btn-ghost-success:hover, .btn-ghost-success:focus { background:rgba(40,167,69,.08); }
.btn-ghost-info { background:transparent; color:#17a2b8; border-color:transparent; }
.btn-ghost-info:hover, .btn-ghost-info:focus { background:rgba(23,162,184,.08); }
.btn-ghost-warning { background:transparent; color:#ffc107; border-color:transparent; }
.btn-ghost-warning:hover, .btn-ghost-warning:focus { background:rgba(255,193,7,.08); }
.btn-ghost-dark { background:transparent; color:#343a40; border-color:transparent; }
.btn-ghost-dark:hover, .btn-ghost-dark:focus { background:rgba(52,58,64,.08); }

/* Link style */
.btn-link { color: var(--color-primary); background: transparent; border-color: transparent; padding: 0; font-weight: 600; }
.btn-link:hover, .btn-link:focus { text-decoration: underline; }

/* Branded: WhatsApp (outline style) */
.btn-whatsapp {
  background:#fff;
  color: var(--color-whatsapp);
  border: 2px solid currentColor !important;
}
.btn-whatsapp:hover, .btn-whatsapp:focus {
  background: var(--color-whatsapp);
  color:#fff;
  border-color: var(--color-whatsapp) !important;
}

/* In-card consistency */
.card .btn-primary:hover, .card .btn-primary:focus {
  background-color: color-mix(in srgb, var(--color-primary) 88%, black 12%);
  border-color: color-mix(in srgb, var(--color-primary) 88%, black 12%);
  color: #fff;
  box-shadow: 0 8px 18px rgba(var(--color-primary-rgb), .18);
}
.card .btn-accent:hover, .card .btn-accent:focus {
  background-color: #e04300;
  border-color: #e04300;
  color: var(--color-primary);
}
.card .btn-danger:hover, .card .btn-danger:focus {
  background-color: #c70808;
  border-color: #c70808;
  color: #fff;
}
.card .btn-success:hover, .card .btn-success:focus {
  background-color: #218838;
  border-color: #218838;
  color: #fff;
  box-shadow: 0 8px 18px rgba(40,167,69,.18);
}
.card .btn-info:hover, .card .btn-info:focus {
  background-color: #138496;
  border-color: #138496;
  color: #fff;
  box-shadow: 0 8px 18px rgba(23,162,184,.18);
}
.card .btn-warning:hover, .card .btn-warning:focus {
  background-color: #e0a800;
  border-color: #e0a800;
  color: #212529;
  box-shadow: 0 8px 18px rgba(255,193,7,.18);
}
.card .btn-dark:hover, .card .btn-dark:focus {
  background-color: #23272b;
  border-color: #23272b;
  color: #fff;
  box-shadow: 0 8px 18px rgba(52,58,64,.18);
}
.card .btn-outline-primary:hover, .card .btn-outline-primary:focus {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary) !important;
  box-shadow: 0 8px 18px rgba(var(--color-primary-rgb), .18);
}
.card .btn-outline-secondary:hover, .card .btn-outline-secondary:focus {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary) !important;
}
.card .btn-outline-accent:hover, .card .btn-outline-accent:focus {
  background: var(--color-secondary);
  color: #fff;
  border-color: var(--color-secondary) !important;
}
.card .btn-outline-danger:hover, .card .btn-outline-danger:focus {
  background: #a30000;
  color: #fff;
  border-color: #a30000 !important;
}
.card .btn-outline-success:hover, .card .btn-outline-success:focus {
  background: #28a745;
  color: #fff;
  border-color: #28a745 !important;
  box-shadow: 0 8px 18px rgba(40,167,69,.18);
}
.card .btn-outline-info:hover, .card .btn-outline-info:focus {
  background: #17a2b8;
  color: #fff;
  border-color: #17a2b8 !important;
  box-shadow: 0 8px 18px rgba(23,162,184,.18);
}
.card .btn-outline-warning:hover, .card .btn-outline-warning:focus {
  background: #ffc107;
  color: #212529;
  border-color: #ffc107 !important;
  box-shadow: 0 8px 18px rgba(255,193,7,.18);
}
.card .btn-outline-dark:hover, .card .btn-outline-dark:focus {
  background: #343a40;
  color: #fff;
  border-color: #343a40 !important;
  box-shadow: 0 8px 18px rgba(52,58,64,.18);
}
.card .btn-soft-primary:hover, .card .btn-soft-primary:focus {
  background-color: color-mix(in srgb, var(--color-primary) 16%, white 84%);
  border-color: color-mix(in srgb, var(--color-primary) 22%, white 78%);
  color: var(--color-primary);
}
.card .btn-soft-accent:hover, .card .btn-soft-accent:focus {
  background-color: color-mix(in srgb, var(--color-secondary) 20%, white 80%);
  border-color: color-mix(in srgb, var(--color-secondary) 28%, white 72%);
  color: var(--color-secondary);
}
.card .btn-soft-success:hover, .card .btn-soft-success:focus {
  background-color: color-mix(in srgb, #28a745 16%, white 84%);
  border-color: color-mix(in srgb, #28a745 22%, white 78%);
  color: #28a745;
}
.card .btn-soft-info:hover, .card .btn-soft-info:focus {
  background-color: color-mix(in srgb, #17a2b8 16%, white 84%);
  border-color: color-mix(in srgb, #17a2b8 22%, white 78%);
  color: #17a2b8;
}
.card .btn-soft-warning:hover, .card .btn-soft-warning:focus {
  background-color: color-mix(in srgb, #ffc107 16%, white 84%);
  border-color: color-mix(in srgb, #ffc107 22%, white 78%);
  color: #ffc107;
}
.card .btn-soft-dark:hover, .card .btn-soft-dark:focus {
  background-color: color-mix(in srgb, #343a40 16%, white 84%);
  border-color: color-mix(in srgb, #343a40 22%, white 78%);
  color: #343a40;
}
.card .btn-ghost-primary:hover, .card .btn-ghost-primary:focus {
  background: rgba(var(--color-primary-rgb), .08);
  color: var(--color-primary);
}
.card .btn-ghost-accent:hover, .card .btn-ghost-accent:focus {
  background: rgba(255,77,0,.08);
  color: var(--color-secondary);
}
.card .btn-ghost-success:hover, .card .btn-ghost-success:focus {
  background: rgba(40,167,69,.08);
  color: #28a745;
}
.card .btn-ghost-info:hover, .card .btn-ghost-info:focus {
  background: rgba(23,162,184,.08);
  color: #17a2b8;
}
.card .btn-ghost-warning:hover, .card .btn-ghost-warning:focus {
  background: rgba(255,193,7,.08);
  color: #ffc107;
}
.card .btn-ghost-dark:hover, .card .btn-ghost-dark:focus {
  background: rgba(52,58,64,.08);
  color: #343a40;
}
.card .btn-link:hover, .card .btn-link:focus {
  text-decoration: underline;
  color: var(--color-primary);
}
.card .btn-whatsapp:hover, .card .btn-whatsapp:focus {
  background: var(--color-whatsapp);
  color: #fff;
  border-color: var(--color-whatsapp) !important;
}

/* Mobile tweaks */
@media (max-width:576px){
  .btn { padding:.5rem 1rem; font-size:.95rem; }
  .btn-lg { padding:.7rem 1.2rem; font-size:1rem; }
  .btn-sm { padding:.3rem .6rem; font-size:.8rem; }
}

/* ====== Cards ====== */
.card {
  border: 1px solid var(--color-border);
  border-radius: 10px;
  background-color: var(--color-background);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05);
  padding: 20px;
  transition: box-shadow var(--transition-speed);
  text-align: right;
  margin: 1rem;
}
.card:hover { box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1); }
.card-body { overflow-x: auto; }
.card .btn-primary:hover, .card .btn-primary:focus {
  background-color: color-mix(in srgb, var(--color-primary) 88%, black 12%);
  border-color: color-mix(in srgb, var(--color-primary) 88%, black 12%);
  color: #fff;
}

/* ===== Forms ===== */
input[type="text"],
input[type="email"],
input[type="password"],
textarea,
select {
  border: 1px solid var(--color-border);
  border-radius: 5px;
  padding: 0.6rem 1rem;
  font-family: var(--font-family-base);
  width: 100%;
  transition: border-color var(--transition-speed), box-shadow var(--transition-speed);
  text-align: right;
}
input:focus, textarea:focus, select:focus {
  border-color: var(--color-secondary);
  outline: none;
  box-shadow: 0 0 0 0.25rem rgba(255, 77, 0, 0.25);
}

/* ===== Tables ===== */
table { width: 100%; border-collapse: collapse; margin-bottom: 1.5rem; direction: rtl; }
th, td { border: 1px solid var(--color-border); padding: 0.75rem; text-align: right; }
th { background-color: var(--color-primary); color: white; }
tr:nth-child(even) { background-color: var(--color-muted); }

/* ===== Alerts ===== */
.alert { padding: 1rem; border-radius: 5px; margin-bottom: 1rem; text-align: right; }
.alert-success { background-color: #d4edda; color: #155724; }
.alert-error { background-color: #f8d7da; color: #721c24; }

/* ===== Page content safety ===== */
.page-content { word-wrap: break-word; overflow-wrap: break-word; max-width: 100%; text-align: right; }
.page-content img, .page-content iframe { max-width: 100%; height: auto; display: block; }
.btn i { margin-inline-end: 0.5rem; }

/* ===== Footer ===== */
.logo-img { height: 50px; width: auto; }
.footer { background-color: var(--color-primary); color: var(--color-secondary); padding: 3rem 0; }
.footer h5 { color: var(--color-secondary); font-weight: bold; font-size: 1.2rem; }
.footer a, .footer .list-unstyled li a { color: white; text-decoration: none; transition: color var(--transition-speed); }
.footer a:hover, .footer .list-unstyled li a:hover { color: var(--color-secondary) !important; }
.footer .social-icons a { color: white; font-size: 1.25rem; margin-inline-start: 0.75rem; transition: color var(--transition-speed); }
.footer .social-icons a:hover { color: var(--color-secondary) !important; }

/* ===== Utilities ===== */
.ltr .highlight-brand, .highlight-brand { color: var(--color-secondary); font-weight: bold; }
.ltr, .ltr .banner-content { text-align: left; }

.service-feature { transition: all 0.3s ease; border: 1px solid var(--color-border); border-radius: var(--btn-radius); text-align: right; }
.service-feature:hover { transform: translateY(-5px); box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1); }

.icon-lg { font-size: 2.5rem; margin-bottom: 1rem; color: var(--color-secondary); }
.section-divider { height: 3px; width: 100px; background: var(--color-secondary); margin: 1.5rem auto; }

/* If you place text/icon directly inside the circle, make it white */
.circle-icon {
  width: 80px; height: 80px; background-color: var(--color-secondary); border-radius: 50%;
  display: flex; align-items: center; justify-content: center; transition: transform 0.4s ease;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.15); color: #fff;
}
.circle-icon:hover { transform: rotate(360deg); }

/* Circle icon container – define if missing */
.circle-icon-contact {
  width: 50px;
  height: 50px;
  background-color: var(--color-secondary); /* your orange */
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: transform 0.4s ease;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.15);
  color: #fff;
}

.circle-icon-contact i,
.circle-icon-contact .bi {
  font-size: 1.5rem;
  line-height: 1;
}

/* Force text inside contact info to align right in RTL */
[dir="rtl"] .contact-text {
  text-align: right;
}

/* Optional: add a small gap between icon and text (Bootstrap margin classes handle this) */
[dir="rtl"] .circle-icon-contact.ms-3 {
  margin-left: 0 !important;        /* prevent any left margin */
  margin-right: 1rem !important;    /* ensure right margin exists */
}

.material-symbols-outlined, .material-icons {
  font-size: 20rem; line-height: 1; display: inline-block;
  margin-bottom: 0.75rem; color: var(--color-secondary);
}
.material-symbols-outlined { font-variation-settings: 'FILL' 1, 'wght' 400, 'GRAD' 0, 'opsz' 48; }
.material-symbols-outlined.bg-primary, .fas.bg-primary { background-color: var(--color-secondary); padding: 0.5rem; border-radius: 50%; font-size: 1.5rem; }
iconify-icon { color: var(--color-secondary); }

/* ===== Contact forms ===== */
.contact-form { --form-border-color: var(--color-secondary); }
.contact-form .form-label { font-weight: 600; margin-bottom: 1rem; color: var(--color-primary); text-align: right; }
.contact-form .form-control,
.contact-form .form-select,
.contact-form textarea {
  border: 2px solid var(--form-border-color);
  border-radius: 8px;
  min-height: 46px;
  padding: 0.75rem 1rem;
  font-size: 1rem;
  text-align: right;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
  margin-bottom: 2rem; /* default for LTR pages; trimmed below for RTL forms */
}
.contact-form .form-control:focus,
.contact-form .form-select:focus,
.contact-form textarea:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 0.25rem rgba(255, 77, 0, 0.25);
}
.contact-form textarea.form-control { min-height: 120px; resize: vertical; }
.contact-form .btn { padding: 0.6rem 2rem; font-weight: 600; font-size: 1rem; border-radius: 6px; }

/* ===== Back to top battery ===== */
#backToTop { position: fixed; bottom: 30px; right: 30px; width: 100px; height: 180px; cursor: pointer; z-index: 9999; }
#batteryIcon { width: 100%; height: 100%; pointer-events: none; display: block; }

/* ===== Cards micro-interactions ===== */
.card.text-center:hover { transform: translateY(-5px); box-shadow: 0 8px 20px rgba(0, 0, 0, 0.1); transition: all 0.3s ease-in-out; }
.card .card-body i, .card .card-body svg, .card .card-body .fa, .card .card-body .fas, .card .card-body .material-icons {
  color: var(--color-secondary) !important; font-size: 2.5rem; margin-bottom: 1rem;
}
.card .card-body i.fas { font-size: 2.5rem !important; }

/* ===== Sections ===== */
.contact-info-section, .map-section {
  background: linear-gradient(to left, #f8f9fa, #ffffff);
  padding: 60px 0;
  border-top: 1px solid #ddd;
  text-align: center;
}
.contact-info-section h2, .map-section h2 { color: var(--color-primary); }
.contact-info-section p, .map-section p { color: #555; font-size: 1rem; }

.contact-card {
  background-color: #fff; border-radius: 16px; padding: 30px 20px; text-align: center;
  transition: all 0.3s ease; height: 100%; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06); margin: 0.5rem;
}
.contact-card:hover { transform: translateY(-5px); box-shadow: 0 8px 20px rgba(0, 0, 0, 0.08); }
.contact-card .icon { color: var(--color-secondary); margin-bottom: 16px; }
.contact-card i { font-size: 2rem; }
.contact-card h5 { color: var(--color-primary); font-size: 1.25rem; margin-bottom: 10px; }
.contact-card p, .contact-card a { color: #555; font-size: 0.95rem; }
.contact-card a:hover { color: var(--color-secondary); text-decoration: underline; }

.map-section iframe, .map-section #mapPreview, .map-section #mapCanvas {
  width: 100%; height: 400px; border: 0; border-radius: 12px;
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.1); background-color: var(--color-muted);
}

/* ===== Inputs (misc) ===== */
input[type="date"], input[type="datetime-local"] {
  direction: ltr;
  text-align: right;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: 1.5rem;
  position: relative;
  background-position: left center;
  background-repeat: no-repeat;
  background-size: 1rem;
}
[dir="rtl"] input[type="date"], [dir="rtl"] input[type="datetime-local"] { direction: ltr; text-align: right; }

/* ===== video.js ===== */
.video-js .vjs-control-bar { height: 48px !important; align-items: center !important; padding: 0 !important; direction: rtl !important; }
.video-js .vjs-progress-control { flex: 1 !important; height: 100% !important; margin: 0 !important; padding: 0 !important; display: flex !important; align-items: center !important; }
.video-js .vjs-progress-holder { height: 100% !important; background-color: #e0e0e0 !important; border-radius: 0 !important; }
.video-js .vjs-play-progress { background-color: var(--color-secondary) !important; height: 100% !important; border-radius: 0 !important; right: auto !important; left: 0 !important; }
.video-js .vjs-play-progress::before { display: none !important; }
.video-js .vjs-control:hover { color: var(--color-secondary) !important; }
.video-js { width: 100% !important; height: 400px !important; max-height: 500px; margin: 0 auto; display: block; background-color: #000; border-radius: 8px; overflow: hidden; direction: rtl !important; }
.video-js video { object-fit: cover !important; width: 100% !important; height: 100% !important; }
.video-js.vjs-fullscreen video { object-fit: cover !important; }
.video-js.vjs-rtl .vjs-progress-control { direction: ltr !important; }
.video-js.vjs-rtl .vjs-time-tooltip { right: auto !important; left: 50% !important; transform: translateX(-50%) !important; }
.video-js.vjs-rtl .vjs-mouse-display .vjs-time-tooltip { transform: translateX(50%) !important; }

/* ===== Showroom pagination ===== */
.pagination .page-link {
  color: var(--color-primary); background-color: #fff; border: 1px solid var(--color-border);
  border-radius: var(--btn-radius);
  transition: background-color var(--transition-speed), color var(--transition-speed), border-color var(--transition-speed), box-shadow var(--transition-speed);
}
.pagination .page-link:hover, .pagination .page-link:focus { background-color: var(--color-primary); border-color: var(--color-primary); color: #fff; }
.pagination .page-item.active .page-link { color: #fff; background-color: var(--color-primary); border-color: var(--color-primary); }
.pagination .page-item.disabled .page-link { color: #9aa0a6; background-color: #f6f7f9; border-color: var(--color-border); }

/* Small tweaks */
#compareBar a.btn { font-size: 0.9rem; }
section.bg-light { padding-top: 1rem; padding-bottom: 1rem; }
ul.rtl-list { direction: rtl; text-align: right; padding-right: 1.5rem; padding-left: 0; list-style-type: disc; list-style-position: inside; }
.empty-state .btn-outline-primary { border-color: var(--color-primary) !important; color: var(--color-primary) !important; background-color: transparent !important; opacity: 1 !important; visibility: visible !important; }

/* ===== Responsive ===== */
@media (max-width: 768px) {
  .contact-card { padding: 20px 15px; }
  .contact-card h5 { font-size: 1.1rem; }
  .contact-card i { font-size: 1.8rem; }
}
@media (max-width: 576px) {
  section.bg-light { padding-top: 1rem; padding-bottom: 1rem; }
}

/* Dark preference */
@media (prefers-color-scheme: dark) {
  :root {
    --color-background: #121212;
    --color-text: #f0f0f0;
    --color-border: #444;
    --color-muted: #1e1e1e;
  }
}

/* ===== Layout spacing improvements (cards + forms) ===== */
.industries-pills,
.industries-pills .row,
.industries-grid .row,
.industries-list .row,
#industries .row { --bs-gutter-x: 1.75rem; --bs-gutter-y: 1.25rem; }
.industries-pills .card,
.industries-grid .card,
.industries-list .card,
#industries .card { margin: 0.75rem 1rem; }
.section .row { --bs-gutter-y: 1rem; }

/* RTL form spacing to match EN */
[dir="rtl"] form .row,
[dir="rtl"] .contact-form .row,
[dir="rtl"] .form-row {
  --bs-gutter-x: 1.25rem !important; /* column gap */
  --bs-gutter-y: .75rem !important; /* row gap */
  margin-right: calc(var(--bs-gutter-x) * -0.5) !important;
  margin-left: calc(var(--bs-gutter-x) * -0.5) !important;
}
[dir="rtl"] form .row > [class*="col-"],
[dir="rtl"] .contact-form .row > [class*="col-"],
[dir="rtl"] .form-row > [class*="col-"] {
  padding-inline: calc(var(--bs-gutter-x) * .5) !important;
  margin-bottom: var(--bs-gutter-y) !important;
}

/* Trim RTL label and control margins to avoid tall rows */
[dir="rtl"] .contact-form .form-label { margin-bottom: .5rem !important; }
[dir="rtl"] .contact-form .form-control,
[dir="rtl"] .contact-form .form-select,
[dir="rtl"] .contact-form textarea { margin-bottom: .75rem !important; }

/* Reapply gutters if utilities remove them */
[dir="rtl"] .contact-form .row.g-0,
[dir="rtl"] .contact-form .row.gx-0 { --bs-gutter-x: 1.25rem !important; --bs-gutter-y: .75rem !important; }

/* Generic Bootstrap gutter helpers */
.g-4 { --bs-gutter-x: 2rem; --bs-gutter-y: 2rem; }
.g-3 { --bs-gutter-x: 1.5rem; --bs-gutter-y: 1.5rem; }
.row.mt-1 { margin-top: 2rem !important; }
.card { margin: 1rem; }

/* ===========================
   HERO HEADER — RTL VERSION
   Place in: hero.rtl.css
   =========================== */
.hero.hero--category {
  position: relative;
  isolation: isolate;
  overflow: clip;
  direction: rtl; /* enforce RTL */
  color: #fff;
}
.hero .hero__media { position: absolute; inset: 0; z-index: -2; overflow: hidden; }
.hero .hero__img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Dark overlay (fades to the left in RTL) */
.hero .hero__overlay {
  position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(270deg, rgba(0,0,0,.65) 0%, rgba(0,0,0,.4) 35%, rgba(0,0,0,0) 70%);
}

/* Content */
.hero .hero__content {
  position: relative;
  min-height: clamp(320px, 45vw, 560px);
  display: flex; flex-direction: column; justify-content: center;
  padding-block: clamp(40px, 6vw, 96px);
  margin-inline: auto; max-width: 1220px; padding-inline: 24px;
  text-align: right;
}

/* Typography */
.hero .hero__title { font-size: clamp(28px, 4.8vw, 56px); line-height: 1.1; margin: 0 0 10px; font-weight: 700; }
.hero .hero__subtitle { font-size: clamp(14px, 1.6vw, 18px); opacity: .9; margin: 0 0 22px; }

/* Actions */
.hero .hero__actions { display: flex; gap: 12px; flex-wrap: wrap; justify-content: flex-end; }

/* Fallback buttons */
.hero .btn { display: inline-flex; align-items: center; gap: .5rem; padding: .75rem 1.1rem; border-radius: .6rem; font-weight: 600; text-decoration: none; border: 1px solid transparent; transition: transform .12s ease, opacity .12s ease; }
.hero .btn-primary { background: #0d6efd; color: #fff; border-color: #0d6efd; }
.hero .btn-outline { background: transparent; color: #fff; border-color: rgba(255,255,255,.65); }
.hero .btn:hover { transform: translateY(-1px); opacity: .95; }

/* Small screens: give content more padding */
@media (max-width: 576px) { .hero .hero__content { padding-inline: 16px; } }

/* Always center the category header, RTL or LTR */
.category-lead{
  max-width: 1100px;
  margin: 2rem auto;
  padding: 1.25rem 1.5rem;
  background: #f6f9fc;
  border: 1px solid #e9eef5;
  border-radius: 14px;
  text-align: center !important;
}
.category-lead *{ text-align: inherit; }
.category-lead__title { margin: 0 0 .5rem; line-height: 1.25; font-weight: 800; }
.category-lead__subtitle{ margin: 0 0 .25rem; font-weight: 600; opacity:.95; }
.category-lead__desc { margin: .25rem 0 0; opacity:.9; }

/* RTL overrides for the auth modal (scope to pages with dir="rtl") */
html[dir="rtl"] .auth-modal { direction: rtl; text-align: right; }

/* ===== Contact section specific fixes ===== */
.contact-info-section .row.g-5 {
  --bs-gutter-x: 3rem;
}

.contact-info-section .card {
  margin: 0;
  height: 100%;
}

.contact-info-section .circle-icon-contact {
  width: 50px;
  height: 50px;
  background-color: var(--color-secondary);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: #fff;
}

.contact-info-section .circle-icon-contact i,
.contact-info-section .circle-icon-contact .bi,
.contact-info-section .circle-icon-contact .fas,
.contact-info-section .circle-icon-contact .fab {
  font-size: 1.5rem;
  color: #fff;
}

.contact-info-section .contact-text {
  text-align: right;
}

/* Fix margin for RTL when using ms-3 */
[dir="rtl"] .contact-info-section .circle-icon-contact.ms-3 {
  margin-right: 0 !important;
  margin-left: 1rem !important;
}