/*
 * Al Safar & Partners — Black & White Theme
 * Inspired by IBM Plex Sans Law Firm Dashboard (Behance)
 * Palette: Primary #1A1A1A · Secondary #FDFDFD · Tertiary #7A7A7A
 * Font: IBM Plex Sans (Google Fonts)
 * Version: 1.0
 *
 * Usage: Add <link href="/assets/css/theme-bw.css" rel="stylesheet"> AFTER theme.css
 *        Or replace theme.css link with this file to switch themes.
 */

/* ─────────────────────────────────────────────
   GOOGLE FONT — IBM Plex Sans
   ───────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&display=swap');

/* ─────────────────────────────────────────────
   CSS VARIABLES
   ───────────────────────────────────────────── */
:root {
  /* Core palette */
  --bw-black:        #1A1A1A;   /* Primary — nav bg, headings, dark surfaces */
  --bw-black-deep:   #0D0D0D;   /* Deeper black for hover states */
  --bw-black-mid:    #2E2E2E;   /* Dark sections, footer */
  --bw-gray-dark:    #4A4A4A;   /* Sub-headings, strong body */
  --bw-gray:         #7A7A7A;   /* Tertiary — body text, icons, borders */
  --bw-gray-mid:     #ABABAB;   /* Muted text, placeholder */
  --bw-gray-light:   #E0E0E0;   /* Borders, dividers */
  --bw-off-white:    #F5F5F5;   /* Alternate section bg */
  --bw-near-white:   #FDFDFD;   /* Secondary — card bg, page bg */
  --bw-white:        #FFFFFF;   /* Pure white */

  /* Typography */
  --bw-font-heading: "IBM Plex Sans", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --bw-font-body:    "IBM Plex Sans", "Helvetica Neue", Helvetica, Arial, sans-serif;

  /* Spacing & shape */
  --bw-radius-pill:  50px;      /* Pill buttons */
  --bw-radius-card:  12px;      /* Cards */
  --bw-radius-sm:    6px;       /* Small elements */
  --bw-transition:   all 0.18s ease;
}

/* ─────────────────────────────────────────────
   GLOBAL RESET OVERRIDES
   ───────────────────────────────────────────── */
body,
#wrapwrap,
main,
.o_main_navbar + #wrapwrap {
  font-family: var(--bw-font-body) !important;
  background-color: var(--bw-near-white) !important;
  color: var(--bw-black) !important;
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  font-family: var(--bw-font-heading) !important;
  font-weight: 700 !important;
  color: var(--bw-black) !important;
  letter-spacing: -0.01em;
}

p, li, span, td, th, div {
  font-family: var(--bw-font-body) !important;
}

/* ─────────────────────────────────────────────
   PARALLAX / BACKGROUND IMAGE FIX (Odoo)
   ───────────────────────────────────────────── */
.s_banner.parallax,
.s_parallax_is_fixed,
.s_parallax {
  position: relative !important;
  overflow: hidden !important;
}

.s_parallax_bg {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  background-size: cover !important;
  background-position: center center !important;
  background-attachment: fixed;
  z-index: 0 !important;
  display: block !important;
}

/* ─────────────────────────────────────────────
   NAVIGATION
   ───────────────────────────────────────────── */
header,
nav.o_main_navbar,
.navbar,
nav[class*="navbar"],
.website_published .o_main_navbar {
  background-color: var(--bw-black) !important;
  border-bottom: none !important;
  box-shadow: none !important;
}

.navbar-brand,
.navbar-brand *,
nav .navbar-brand span,
nav .navbar-brand img {
  color: var(--bw-white) !important;
  font-family: var(--bw-font-heading) !important;
  font-weight: 700 !important;
}

.nav-link,
.navbar-nav .nav-link,
nav a.nav-link {
  color: rgba(255, 255, 255, 0.65) !important;
  font-family: var(--bw-font-body) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  letter-spacing: 0.02em;
  transition: var(--bw-transition) !important;
  border-bottom: 2px solid transparent;
  padding-bottom: 4px;
}

.nav-link:hover,
.navbar-nav .nav-link:hover,
.nav-link:focus {
  color: var(--bw-white) !important;
  border-bottom-color: var(--bw-gray) !important;
}

/* ─────────────────────────────────────────────
   HERO / BANNER SECTION
   ───────────────────────────────────────────── */
.s_banner,
section.s_banner,
.o_full_screen_height {
  background-color: var(--bw-black) !important;
}

.s_banner h1,
.s_banner h2,
.s_banner .h1,
.s_banner .h2 {
  color: var(--bw-white) !important;
  font-family: var(--bw-font-heading) !important;
  font-weight: 700 !important;
  line-height: 1.15 !important;
}

.s_banner p,
.s_banner .lead,
.s_banner .o_cc p {
  color: rgba(255, 255, 255, 0.65) !important;
  font-family: var(--bw-font-body) !important;
  font-size: 14px !important;
  line-height: 1.75 !important;
}

/* Banner overlay for parallax bg visibility */
.s_banner > .container,
.s_banner > .container-fluid {
  position: relative;
  z-index: 2;
}

.s_banner::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    100deg,
    rgba(13, 13, 13, 0.94) 40%,
    rgba(13, 13, 13, 0.6) 100%
  );
  z-index: 1;
  pointer-events: none;
}

/* ─────────────────────────────────────────────
   BUTTONS — Pill shape (IBM Plex Dashboard style)
   ───────────────────────────────────────────── */
.btn,
.o_btn,
a.btn,
button.btn {
  font-family: var(--bw-font-body) !important;
  font-weight: 600 !important;
  font-size: 12px !important;
  letter-spacing: 0.04em !important;
  border-radius: var(--bw-radius-pill) !important;
  transition: var(--bw-transition) !important;
  padding: 10px 24px !important;
}

/* Primary button — black pill */
.btn-primary,
.o_btn_primary,
.btn.btn-primary {
  background-color: var(--bw-black) !important;
  border-color: var(--bw-black) !important;
  color: var(--bw-white) !important;
}

.btn-primary:hover,
.btn-primary:focus {
  background-color: var(--bw-black-deep) !important;
  border-color: var(--bw-black-deep) !important;
  color: var(--bw-white) !important;
}

/* Secondary / outline button — pill outline */
.btn-secondary,
.btn-outline,
.btn-outline-primary,
.btn-outline-dark,
.o_btn_secondary {
  background-color: transparent !important;
  border: 1.5px solid var(--bw-black) !important;
  color: var(--bw-black) !important;
}

.btn-secondary:hover,
.btn-outline:hover,
.btn-outline-primary:hover {
  background-color: var(--bw-black) !important;
  color: var(--bw-white) !important;
}

/* White outline (used on dark backgrounds) */
.s_banner .btn,
.s_cover .btn,
.o_cc5 .btn,
section.dark .btn {
  border-radius: var(--bw-radius-pill) !important;
}

.s_banner .btn-primary,
.o_cc5 .btn-primary {
  background-color: var(--bw-white) !important;
  color: var(--bw-black) !important;
  border-color: var(--bw-white) !important;
}

.s_banner .btn-primary:hover,
.o_cc5 .btn-primary:hover {
  background-color: var(--bw-gray-light) !important;
  border-color: var(--bw-gray-light) !important;
}

.s_banner .btn-secondary,
.o_cc5 .btn-secondary,
.s_banner a.btn:not(.btn-primary) {
  background-color: transparent !important;
  border: 1.5px solid rgba(255, 255, 255, 0.4) !important;
  color: var(--bw-white) !important;
}

.s_banner .btn-secondary:hover {
  border-color: var(--bw-white) !important;
  background-color: rgba(255, 255, 255, 0.08) !important;
}

/* ─────────────────────────────────────────────
   CARDS & CONTENT BLOCKS
   ───────────────────────────────────────────── */
.card,
.o_card,
.s_card,
[class*="card"]:not([class*="card-header"]):not([class*="card-body"]) {
  background-color: var(--bw-white) !important;
  border: 1px solid var(--bw-gray-light) !important;
  border-top: 2px solid var(--bw-black) !important;
  border-radius: var(--bw-radius-card) !important;
  box-shadow: none !important;
  transition: var(--bw-transition) !important;
}

.card:hover {
  box-shadow: 0 6px 24px rgba(0, 0, 0, 0.08) !important;
  transform: translateY(-2px);
}

.card-title,
.card-header,
.card h3,
.card h4 {
  font-family: var(--bw-font-heading) !important;
  font-weight: 700 !important;
  color: var(--bw-black) !important;
}

.card-text,
.card p,
.card-body p {
  color: var(--bw-gray) !important;
  font-size: 13px !important;
  line-height: 1.65 !important;
}

/* ─────────────────────────────────────────────
   SECTIONS
   ───────────────────────────────────────────── */
section,
.o_cc,
.s_text_block {
  font-family: var(--bw-font-body) !important;
}

/* Alternate section — off-white */
section:nth-child(even),
.s_text_image,
.o_cc2,
.s_features {
  background-color: var(--bw-off-white) !important;
}

/* Dark section */
.o_cc5,
section.o_cc5,
.o_colored_level_5 {
  background-color: var(--bw-black) !important;
  color: var(--bw-white) !important;
}

.o_cc5 h1, .o_cc5 h2, .o_cc5 h3,
.o_cc5 h4, .o_cc5 h5, .o_cc5 h6 {
  color: var(--bw-white) !important;
}

.o_cc5 p, .o_cc5 li, .o_cc5 span {
  color: rgba(255, 255, 255, 0.62) !important;
}

/* Section headings */
section h2,
.o_cc h2,
.s_title {
  font-family: var(--bw-font-heading) !important;
  font-weight: 700 !important;
  color: var(--bw-black) !important;
  font-size: clamp(22px, 3vw, 32px) !important;
}

/* Eyebrow labels */
.small,
small,
.text-muted {
  color: var(--bw-gray) !important;
  font-family: var(--bw-font-body) !important;
}

/* ─────────────────────────────────────────────
   TRUST STRIP / ICON ROW
   ───────────────────────────────────────────── */
.s_references,
.s_companies,
[class*="s_references"],
[class*="s_companies"] {
  background-color: var(--bw-black) !important;
}

.s_references p,
.s_companies p,
.s_references span,
.s_companies span {
  color: var(--bw-white) !important;
}

/* ─────────────────────────────────────────────
   PARALLAX / QUOTE SECTION
   ───────────────────────────────────────────── */
.s_parallax,
.s_parallax_is_fixed,
section[class*="parallax"] {
  background-color: var(--bw-black-mid) !important;
}

.s_parallax h2,
.s_parallax blockquote,
.s_parallax p {
  color: var(--bw-white) !important;
  font-family: var(--bw-font-heading) !important;
}

blockquote,
.blockquote {
  font-family: var(--bw-font-heading) !important;
  font-style: italic;
  color: var(--bw-white) !important;
  border-left: 3px solid var(--bw-gray) !important;
  padding-left: 20px !important;
}

/* ─────────────────────────────────────────────
   FORMS
   ───────────────────────────────────────────── */
.form-control,
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="number"],
textarea,
select {
  font-family: var(--bw-font-body) !important;
  border: 1.5px solid var(--bw-gray-light) !important;
  border-radius: var(--bw-radius-sm) !important;
  background-color: var(--bw-white) !important;
  color: var(--bw-black) !important;
  font-size: 13px !important;
  transition: var(--bw-transition) !important;
}

.form-control:focus,
input:focus,
textarea:focus,
select:focus {
  border-color: var(--bw-black) !important;
  box-shadow: 0 0 0 3px rgba(26, 26, 26, 0.1) !important;
  outline: none !important;
}

.form-label,
label {
  font-family: var(--bw-font-body) !important;
  font-weight: 600 !important;
  font-size: 12px !important;
  color: var(--bw-black) !important;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

/* ─────────────────────────────────────────────
   FOOTER
   ───────────────────────────────────────────── */
footer,
#footer,
.o_footer {
  background-color: var(--bw-black-mid) !important;
  color: rgba(255, 255, 255, 0.55) !important;
  font-family: var(--bw-font-body) !important;
}

footer h4,
footer h5,
footer .h4,
footer .h5,
#footer h4,
#footer h5 {
  font-family: var(--bw-font-heading) !important;
  font-weight: 700 !important;
  color: var(--bw-white) !important;
  font-size: 10px !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
}

footer a,
#footer a,
.o_footer a {
  color: rgba(255, 255, 255, 0.45) !important;
  transition: color 0.15s !important;
  text-decoration: none !important;
}

footer a:hover,
#footer a:hover {
  color: var(--bw-white) !important;
}

footer p,
#footer p,
.o_footer p {
  color: rgba(255, 255, 255, 0.42) !important;
  font-size: 12px !important;
  line-height: 1.75 !important;
}

/* Footer divider */
footer hr,
#footer hr {
  border-color: rgba(255, 255, 255, 0.08) !important;
}

/* Copyright bar */
footer .copyright,
footer .o_footer_copyright,
footer small {
  color: rgba(255, 255, 255, 0.22) !important;
  font-size: 11px !important;
}

/* ─────────────────────────────────────────────
   BADGES & TAGS
   ───────────────────────────────────────────── */
.badge,
.o_badge {
  font-family: var(--bw-font-body) !important;
  font-weight: 600 !important;
  letter-spacing: 0.05em !important;
  border-radius: var(--bw-radius-pill) !important;
  padding: 4px 12px !important;
}

.badge-primary,
.bg-primary {
  background-color: var(--bw-black) !important;
  color: var(--bw-white) !important;
}

.badge-secondary,
.bg-secondary {
  background-color: var(--bw-gray-light) !important;
  color: var(--bw-black) !important;
}

/* ─────────────────────────────────────────────
   BLOG / ARTICLE CARDS
   ───────────────────────────────────────────── */
.o_blog_post_page,
.website_blog .blog_post {
  font-family: var(--bw-font-body) !important;
  color: var(--bw-black) !important;
}

.o_blog_post_page h1,
.website_blog h2 {
  font-family: var(--bw-font-heading) !important;
  font-weight: 700 !important;
  color: var(--bw-black) !important;
}

.o_blog_post_page .blog_header_title {
  font-size: clamp(28px, 4vw, 48px) !important;
  line-height: 1.18 !important;
}

/* ─────────────────────────────────────────────
   LINKS
   ───────────────────────────────────────────── */
a {
  color: var(--bw-black) !important;
  transition: color 0.15s !important;
}

a:hover {
  color: var(--bw-gray-dark) !important;
}

/* On dark backgrounds */
.o_cc5 a,
footer a,
.s_parallax a {
  color: rgba(255, 255, 255, 0.55) !important;
}

.o_cc5 a:hover,
footer a:hover {
  color: var(--bw-white) !important;
}

/* ─────────────────────────────────────────────
   TABLES
   ───────────────────────────────────────────── */
table {
  font-family: var(--bw-font-body) !important;
  font-size: 13px !important;
}

thead th {
  background-color: var(--bw-off-white) !important;
  color: var(--bw-black) !important;
  font-weight: 700 !important;
  border-bottom: 2px solid var(--bw-black) !important;
  letter-spacing: 0.03em;
}

tbody td {
  color: var(--bw-gray-dark) !important;
  border-color: var(--bw-gray-light) !important;
}

tbody tr:hover {
  background-color: var(--bw-off-white) !important;
}

/* ─────────────────────────────────────────────
   UTILITY — EYEBROW LABELS
   ───────────────────────────────────────────── */
.text-uppercase.fw-bold.small,
[class*="o_label"],
.eyebrow {
  font-family: var(--bw-font-body) !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 0.18em !important;
  color: var(--bw-gray) !important;
  text-transform: uppercase !important;
}

/* Divider rule */
hr,
.o_hr {
  border-color: var(--bw-gray-light) !important;
}

/* ─────────────────────────────────────────────
   MOBILE RESPONSIVE
   ───────────────────────────────────────────── */
@media (max-width: 768px) {
  .s_banner h1,
  .s_banner .h1 {
    font-size: clamp(26px, 8vw, 40px) !important;
  }

  .btn {
    padding: 9px 20px !important;
    font-size: 12px !important;
  }

  section {
    padding: 40px 16px !important;
  }
}

@media (max-width: 480px) {
  h2, .sec-h {
    font-size: 22px !important;
  }
}
