/**************************************************************
   style.css — LTR base
   Version 3.1
   Created by: Morad M. Althaher
   Brand: primary #051939, secondary #ff4d00
   Comments in EN only
************************************************************** */
:root {
  --color-primary: #051939;
  --color-primary-rgb: 5, 25, 57; /* added for focus rings, shadows */
  --color-secondary: #ff4d00; /* updated 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;
}

body {
  font-family: var(--font-family-base);
  background-color: var(--color-background);
  color: var(--color-text);
  line-height: 1.6;
}

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 (2px, currentColor) ===== */
.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) variants ===== */
.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);
}
.card:hover { box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1); }
.card-body { overflow-x: auto; }

/* ===== 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);
}
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;
}
th, td {
  border: 1px solid var(--color-border);
  padding: 0.75rem;
  text-align: left;
}
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;
}
.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%;
}
.page-content img,
.page-content iframe {
  max-width: 100%;
  height: auto;
  display: block;
}
.btn i { margin-inline-start: 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-end: 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);
}
.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; /* ensure contrast on orange circle */
}
.circle-icon:hover { transform: rotate(360deg); }

.material-symbols-outlined,
.material-icons {
  font-size: 20rem;
  line-height: 1;
  display: inline-block;
  margin-bottom: 0.75rem;
  color: var(--color-secondary);
}
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: 0.5rem;
  color: var(--color-primary);
}
.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.5rem 0.75rem;
  font-size: 1rem;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}
.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 right, #f8f9fa, #ffffff);
  padding: 60px 0;
  border-top: 1px solid #ddd;
}
.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);
}
.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;
}

/* ===== video.js ===== */
.video-js .vjs-control-bar {
  height: 48px !important;
  align-items: center !important;
  padding: 0 !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;
}
.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;
}
.video-js video {
  object-fit: cover !important;
  width: 100% !important;
  height: 100% !important;
}
.video-js.vjs-fullscreen video { object-fit: cover !important; }

/* ===== Showroom pagination (theme-aligned) ===== */
.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);
}

/* ===========================
   HERO HEADER — LTR VERSION
   Place in: hero.ltr.css
   =========================== */
/* Section wrapper */
.hero.hero--category {
  position: relative;
  isolation: isolate; /* keep overlay under content */
  overflow: clip;
  direction: ltr; /* enforce LTR */
  color: #fff;
}

/* Background media */
.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 right in LTR) */
.hero .hero__overlay {
  position: absolute;
  inset: 0;
  z-index: -1;
  background: linear-gradient(
    90deg,
    rgba(0, 0, 0, 0.65) 0%,
    rgba(0, 0, 0, 0.4) 35%,
    rgba(0, 0, 0, 0.0) 70%
  );
}

/* Content area */
.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);
  /* Use your site container spacing here if you have one */
  margin-inline: auto;
  max-width: 1220px;
  padding-inline: 24px;
  text-align: left;
}

/* 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: 0.9;
  margin: 0 0 22px;
}

/* Actions */
.hero .hero__actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: flex-start; /* left in LTR */
}

/* Optional fallback button styling (if not using a framework) */
.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; }
}

/* Small tweaks */
#compareBar a.btn { font-size: 0.9rem; }

/* ===== 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; }
}

/* 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; /* force center */
}
.category-lead *{ text-align: inherit; } /* keep children centered */
.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; }

/* ===========================
   Auth modal (Bootstrap modal)
   =========================== */
.auth-modal {
  border-radius: var(--btn-radius);
  border: 1px solid var(--color-border);
  box-shadow: 0 12px 32px rgba(0,0,0,.12);
  background: var(--color-background);
}
.auth-modal .modal-header { border: 0; padding-bottom: .25rem; }
.auth-modal .modal-title { color: var(--color-primary); font-weight: 800; }
.auth-modal .form-label {
  font-weight: 600;
  color: var(--color-primary);
}
/* Match contact-form inputs (2px orange, same height) */
.auth-modal .form-control {
  border: 2px solid var(--color-secondary);
  border-radius: 8px;
  min-height: 46px;
  padding: 0.5rem 0.75rem;
  background: #fff;
  box-shadow: none;
  transition: border-color .2s ease, box-shadow .2s ease;
}
.auth-modal .form-control:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 .25rem rgba(255,77,0,.25);
}
.auth-modal .form-control::placeholder { color: #9aa0a6; }
.auth-modal .form-control.is-invalid { border-color: #dc3545; }
.auth-modal .form-control.is-invalid:focus { box-shadow: 0 0 0 .25rem rgba(220,53,69,.2); }
.auth-modal .form-control.is-valid { border-color: #28a745; }
.auth-modal .form-control.is-valid:focus { box-shadow: 0 0 0 .25rem rgba(40,167,69,.2); }