/* ============================================================
   COMPTAAIR PARTNERS — Refonte (guest pages + homepage)
   Source design: comptaair_homepage_refaite.html
   Palette: Blue #4285F4 | Purple #4B0082 | Navy #050b24
   Font: Inter
   Loads AFTER compta-air-theme.css and overrides it.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

:root {
  --cair-blue: #4285F4;
  --cair-purple: #4B0082;
  --cair-purple-2: #2b0063;
  --cair-dark: #050b24;
  --cair-navy: #07112e;
  --cair-text: #0b1026;
  --cair-muted: #667085;
  --cair-soft: #f7f5ff;
  --cair-line: #e8e6f5;
  --cair-gradient: linear-gradient(135deg, #4285F4 0%, #6532ff 45%, #4B0082 100%);
  --cair-btn-gradient: linear-gradient(135deg, #6532ff, #4B0082);
  --cair-shadow: 0 25px 70px rgba(44, 20, 120, .13);

  /* Remap platform variables */
  --main-color-one: #4285F4;
  --main-color-two: #4B0082;
  --secondary-color: #4B0082;
  --heading-color: #10162f;
  --paragraph-color: #4e5b78;
  --body-color: #4e5b78;
  --section-bg-1: #f7f5ff;
  --section-bg-2: #f1ecff;
  --footer-bg-1: #050b24;
  --footer-bg-2: #050b24;
  --border-color: #e8e6f5;
  --heading-font: 'Inter', sans-serif;
  --body-font: 'Inter', sans-serif;
}

/* ── Typography (beats Satoshi !important from previous theme) ── */
body, html {
  font-family: 'Inter', Arial, sans-serif !important;
  background: #fff;
  color: var(--cair-text);
}
h1, h2, h3, h4, h5, h6 {
  font-family: 'Inter', sans-serif !important;
  color: var(--cair-text);
}
p, span, a, li, td, th, input, textarea, select, label, button {
  font-family: 'Inter', sans-serif !important;
}

/* ============================================================
   HEADER / NAVBAR — white sticky, blur, purple active underline
   (restyles existing platform markup, keeps all functionality)
   ============================================================ */
.header-style-01,
header.header-style-01 {
  position: sticky;
  top: 0;
  z-index: 50;
}
.navbar-area,
nav.navbar-area,
.header-style-01 .navbar-area {
  background: rgba(255, 255, 255, .88) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(232, 230, 245, .6);
  box-shadow: none !important;
}
.navbar-area .nav-container,
.navbar-area .container {
  background: transparent !important;
  min-height: 82px;
}
.navbar-area .nav-container.bg-white { background: transparent !important; }

/* Nav links */
.navbar-area .navbar-nav > li > a,
.navbar-area .navbar-nav li a {
  color: #0e132f !important;
  font-family: 'Inter', sans-serif !important;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0;
  text-transform: none;
  transition: color .2s ease, border-color .2s ease;
}
.navbar-area .navbar-nav > li {
  border-bottom: 3px solid transparent;
}
.navbar-area .navbar-nav > li > a:hover,
.navbar-area .navbar-nav li a:hover {
  color: #4f1bce !important;
}
.navbar-area .navbar-nav > li.current-menu-item > a,
.navbar-area .navbar-nav > li.active > a {
  color: #4f1bce !important;
}
.navbar-area .navbar-nav > li.current-menu-item,
.navbar-area .navbar-nav > li.active {
  border-bottom-color: #6c4cff;
}

/* Dropdown submenu — white card */
.navbar-area .nav-container .navbar-collapse .navbar-nav li.menu-item-has-children .sub-menu {
  background-color: #fff !important;
  border: 1px solid var(--cair-line) !important;
  border-bottom: 3px solid #6c4cff !important;
  border-radius: 12px !important;
  box-shadow: 0 20px 45px rgba(35, 20, 100, .14) !important;
  overflow: hidden;
}
.navbar-area .nav-container .navbar-collapse .navbar-nav li.menu-item-has-children .sub-menu li a {
  color: #0e132f !important;
  font-weight: 600;
}
.navbar-area .nav-container .navbar-collapse .navbar-nav li.menu-item-has-children .sub-menu li a:hover {
  color: #4f1bce !important;
  background: var(--cair-soft) !important;
}

/* Logo — cancel old theme's white-out filter (invisible on white header) */
.navbar-area .logo-wrapper a,
.navbar-area .logo img { filter: none !important; }
.navbar-area .logo-wrapper .logo img { max-height: 52px; width: auto; }

/* Brand mark (gradient bars + wordmark) — logo fallback */
.ca-brand { display: inline-flex; align-items: center; gap: 10px; }
.ca-brand-mark {
  width: 44px; height: 44px; display: inline-flex; align-items: flex-end; gap: 3px;
}
.ca-brand-mark span {
  display: block; width: 9px; border-radius: 8px;
  background: linear-gradient(135deg, #4285F4 0%, #6532ff 45%, #4B0082 100%);
  box-shadow: 0 6px 14px rgba(75, 0, 130, .22);
}
.ca-brand-mark span:nth-child(1) { height: 14px; }
.ca-brand-mark span:nth-child(2) { height: 23px; }
.ca-brand-mark span:nth-child(3) { height: 32px; }
.ca-brand-mark span:nth-child(4) { height: 41px; }
.ca-brand-name {
  font-weight: 900; font-size: 24px; line-height: .96; letter-spacing: -.7px; color: #111;
}
.ca-brand-name small {
  display: block; font-size: 15px; font-weight: 500; color: #4a4a4a; margin-top: 4px;
}
.ca-brand-name-light { color: #fff; }
.ca-brand-name-light small { color: #b8c0d9; }
@media (max-width: 760px) {
  .ca-brand-mark { width: 36px; height: 36px; }
  .ca-brand-mark span { width: 7px; }
  .ca-brand-name { font-size: 20px; }
  .ca-brand-name small { font-size: 12px; }
}

/* Header buttons */
.navbar-area .cmn-btn,
.navbar-right-content .cmn-btn {
  border-radius: 12px !important;
  font-weight: 800 !important;
  font-size: 14px !important;
  padding: 13px 22px;
  transition: .25s;
  white-space: nowrap;
}
.navbar-area .cmn-btn:hover,
.navbar-right-content .cmn-btn:hover { transform: translateY(-2px); }

.navbar-right-content .cmn-btn.btn-outline-1,
.navbar-area .cmn-btn.btn-outline-1 {
  background: #fff !important;
  color: #4B0082 !important;
  border: 1px solid #ded8ff !important;
}
.navbar-right-content .cmn-btn.btn-bg-1,
.navbar-area .cmn-btn.btn-bg-1,
.cmn-btn.btn-bg-1 {
  background: var(--cair-btn-gradient) !important;
  color: #fff !important;
  border: none !important;
  box-shadow: 0 14px 34px rgba(75, 0, 130, .22);
}

/* Generic platform buttons on guest pages */
.cmn-btn.btn-bg-2 { background: var(--cair-btn-gradient) !important; color: #fff !important; border: none !important; }
.cmn-btn { border-radius: 12px !important; font-weight: 800 !important; }

/* Mobile toggler */
.navbar-area .navbar-toggler {
  border: 1px solid var(--cair-line);
  border-radius: 12px;
  color: var(--cair-purple);
}

/* Category strip under navbar */
body:has(.cair-home) .categorySub-area { display: none; } /* not part of homepage design */
.categorySub-area { background: #fff !important; border-top: 1px solid var(--cair-line) !important; }
.categorySub-list-slide-link { color: #0e132f !important; font-weight: 700 !important; }
.categorySub-list-slide-link:hover { color: #4f1bce !important; }

/* ============================================================
   FOOTER — dark navy
   ============================================================ */
footer.footer-area,
.footer-area,
.footer-area.footer-bg-1,
.footer-area-wrapper,
.footer-area-wrapper.footer-bg-1 {
  background: var(--cair-dark) !important;
  color: #fff;
}
.footer-area .widget-headline,
.footer-area h4,
.footer-area .footer-widget-title {
  color: #fff !important;
  font-size: 14px !important;
  text-transform: uppercase;
  letter-spacing: .3px;
}
.footer-area a,
.footer-area p,
.footer-area li,
.footer-area span,
.footer-area .footer-widget-para {
  color: #b8c0d9 !important;
  font-size: 13px;
}
.footer-area a:hover { color: #fff !important; }
.footer-area .copyright-area,
.footer-area .copyright-border {
  border-top: 1px solid rgba(255, 255, 255, .09) !important;
}
.footer-area input {
  background: rgba(255, 255, 255, .06) !important;
  border: 1px solid rgba(255, 255, 255, .14) !important;
  color: #fff !important;
  border-radius: 12px !important;
}

/* Back to top */
.back-to-top .back-top { background: var(--cair-btn-gradient) !important; color: #fff !important; }

/* Breadcrumb banner on inner guest pages */
.banner-inner-area {
  background: radial-gradient(circle at 78% 18%, #eee8ff 0, #f7f4ff 28%, transparent 49%), #fff !important;
  border-color: var(--cair-line) !important;
}
.banner-inner-title { color: #090e29 !important; letter-spacing: -1px; font-weight: 900 !important; }
.inner-menu .list a { color: #4f1bce !important; font-weight: 700; }

/* ============================================================
   HOMEPAGE SECTIONS (ca- prefixed, 1:1 port of reference HTML)
   ============================================================ */
.cair a { text-decoration: none; color: inherit; }
.cair img { max-width: 100%; display: block; }
.cair .ca-container { width: min(1180px, 92%); margin: auto; }

.cair .ca-btn {
  border-radius: 12px; border: 1px solid var(--cair-line); padding: 14px 22px;
  font-size: 14px; font-weight: 800; display: inline-flex; align-items: center;
  justify-content: center; gap: 10px; transition: .25s; cursor: pointer; white-space: nowrap;
}
.cair .ca-btn:hover { transform: translateY(-2px); }
.cair .ca-btn-primary {
  background: var(--cair-btn-gradient); color: #fff;
  box-shadow: 0 14px 34px rgba(75, 0, 130, .22); border-color: transparent;
}
.cair .ca-btn-primary:hover { color: #fff; }
.cair .ca-btn-outline { background: #fff; color: #4B0082; border-color: #ded8ff; }

/* HERO */
.cair .ca-hero {
  position: relative; padding: 68px 0 36px;
  background: radial-gradient(circle at 78% 18%, #eee8ff 0, #f7f4ff 28%, transparent 49%);
}
.cair .ca-hero-grid { display: grid; grid-template-columns: 1fr 1.12fr; align-items: center; gap: 44px; }
.cair .ca-eyebrow {
  display: inline-flex; align-items: center; gap: 8px; background: #f1ecff; color: #321078;
  font-weight: 900; font-size: 12px; letter-spacing: .2px; border-radius: 10px;
  padding: 10px 14px; margin-bottom: 28px;
}
.cair .ca-hero h1 {
  font-size: clamp(43px, 5.15vw, 72px); line-height: 1.07; letter-spacing: -2.7px;
  font-weight: 900; margin-bottom: 24px; color: #090e29;
}
.cair .ca-hero h1 span {
  background: var(--cair-gradient);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.cair .ca-hero p {
  max-width: 560px; color: #4e5b78; font-size: 18px; line-height: 1.7;
  margin-bottom: 30px; font-weight: 500;
}
.cair .ca-hero-actions { display: flex; gap: 16px; margin-bottom: 40px; flex-wrap: wrap; }
.cair .ca-hero-actions .ca-btn { min-width: 188px; height: 58px; }
.cair .ca-trust-row { display: flex; gap: 30px; flex-wrap: wrap; font-size: 12px; color: #353b56; font-weight: 700; }
.cair .ca-trust-row span { display: flex; align-items: center; gap: 8px; }
.cair .ca-trust-row i { color: #5d34df; font-style: normal; }

/* Dashboard illustration */
.cair .ca-hero-visual { position: relative; min-height: 470px; display: flex; align-items: center; justify-content: center; }
.cair .ca-blob {
  position: absolute; width: 500px; height: 315px; border-radius: 52% 48% 46% 54%;
  background: linear-gradient(135deg, #f0ecff, #e7dfff); right: 0; top: 38px; z-index: 0;
}
.cair .ca-device {
  position: relative; z-index: 2; width: min(660px, 100%); transform: rotate(3deg);
  filter: drop-shadow(0 35px 50px rgba(26, 14, 72, .2));
}
.cair .ca-laptop { height: 372px; background: #0a0b16; border-radius: 20px 20px 12px 12px; padding: 16px 16px 0; border: 1px solid rgba(0, 0, 0, .08); }
.cair .ca-laptop-screen { height: 332px; background: #fbfbff; border-radius: 12px; display: grid; grid-template-columns: 135px 1fr; overflow: hidden; }
.cair .ca-sidebar { background: #07112e; color: #fff; padding: 18px 14px; }
.cair .ca-sidebar .ca-mini-logo { height: 22px; width: 82px; background: #fff; border-radius: 5px; margin-bottom: 20px; opacity: .95; }
.cair .ca-side-item { height: 22px; background: rgba(255, 255, 255, .12); border-radius: 6px; margin: 11px 0; }
.cair .ca-side-item:first-of-type { background: #6532ff; }
.cair .ca-dash-main { padding: 24px; }
.cair .ca-dash-title { font-weight: 900; font-size: 20px; margin-bottom: 16px; }
.cair .ca-kpi { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 18px; }
.cair .ca-kpi div { height: 64px; background: #fff; border: 1px solid #eee; border-radius: 12px; box-shadow: 0 8px 25px rgba(30, 20, 80, .05); }
.cair .ca-graph { height: 150px; background: #fff; border: 1px solid #eee; border-radius: 14px; position: relative; overflow: hidden; }
.cair .ca-graph:before {
  content: ""; position: absolute; left: 28px; right: 28px; top: 76px; height: 4px;
  background: linear-gradient(90deg, #6d35ff, #4285F4); border-radius: 50%; transform: skewY(-10deg);
}
.cair .ca-base { height: 22px; width: 82%; margin: auto; background: linear-gradient(#cfd3dd, #aeb4c2); border-radius: 0 0 36px 36px; }
.cair .ca-float-card {
  position: absolute; z-index: 4; background: #fff; border: 1px solid #ece8ff; border-radius: 16px;
  box-shadow: 0 20px 45px rgba(35, 20, 100, .14); padding: 15px;
}
.cair .ca-expert-float { left: 0; top: 165px; width: 185px; display: flex; gap: 12px; align-items: center; }
.cair .ca-avatar {
  width: 45px; height: 45px; border-radius: 50%; background: linear-gradient(135deg, #ddd, #f9f9ff);
  display: grid; place-items: center; overflow: hidden;
}
.cair .ca-avatar img { width: 100%; height: 100%; object-fit: cover; }
.cair .ca-expert-float b { font-size: 12px; }
.cair .ca-expert-float small { display: block; color: #667085; font-size: 10px; margin-top: 3px; }
.cair .ca-phone {
  position: absolute; z-index: 5; left: 135px; bottom: 55px; width: 104px; height: 205px;
  background: #10121b; border-radius: 26px; padding: 8px; box-shadow: 0 25px 45px rgba(26, 14, 72, .18);
}
.cair .ca-phone-screen { height: 100%; border-radius: 20px; background: #fff; padding: 15px; }
.cair .ca-phone-line { height: 9px; background: #eee; border-radius: 5px; margin: 9px 0; }
.cair .ca-phone-line:nth-child(2) { background: #6532ff; width: 70%; }
.cair .ca-mission-float { right: 0; bottom: 80px; width: 178px; text-align: left; }
.cair .ca-mission-float strong { font-size: 29px; }
.cair .ca-briefcase {
  width: 42px; height: 42px; border-radius: 12px; background: #f1ecff; color: #4B0082;
  display: grid; place-items: center; margin-bottom: 10px; font-size: 22px;
}
.cair .ca-plant { position: absolute; z-index: 3; left: 95px; bottom: 30px; font-size: 70px; }
.cair .ca-card-note {
  position: absolute; z-index: 3; right: 42px; top: 145px; background: #fff; border-radius: 14px;
  padding: 14px 18px; box-shadow: 0 18px 40px rgba(35, 20, 100, .12); font-size: 12px; color: #667085;
}

/* STATS */
.cair .ca-stats {
  margin: 30px auto 45px; display: grid; grid-template-columns: repeat(4, 1fr);
  background: #fff; border: 1px solid var(--cair-line); border-radius: 24px;
  box-shadow: var(--cair-shadow); overflow: hidden;
}
.cair .ca-stat { padding: 31px 36px; display: flex; align-items: center; gap: 20px; border-right: 1px solid var(--cair-line); }
.cair .ca-stat:last-child { border-right: 0; }
.cair .ca-stat-icon {
  width: 58px; height: 58px; border-radius: 18px; background: #f1ecff; color: #6333ef;
  display: grid; place-items: center; font-size: 28px;
}
.cair .ca-stat h3 { font-size: 32px; font-weight: 900; letter-spacing: -1px; }
.cair .ca-stat p { color: #3e4660; font-weight: 700; font-size: 14px; margin-top: 4px; margin-bottom: 0; }

/* SECTIONS */
.cair section.ca-section { padding: 48px 0; }
.cair .ca-section-head { text-align: center; margin-bottom: 36px; }
.cair .ca-section-label { text-transform: uppercase; color: #4926d9; font-size: 12px; font-weight: 900; letter-spacing: .4px; margin-bottom: 10px; }
.cair .ca-section-head h2 { font-size: 34px; letter-spacing: -1px; color: #10162f; margin-bottom: 10px; }
.cair .ca-section-head p { font-size: 16px; color: #667085; }

/* SERVICES */
.cair .ca-services-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 16px; }
.cair .ca-service {
  min-height: 218px; border: 1px solid var(--cair-line); border-radius: 20px; padding: 27px 18px;
  text-align: center; background: #fff; box-shadow: 0 10px 28px rgba(37, 21, 88, .035); transition: .25s;
}
.cair .ca-service:hover { transform: translateY(-7px); box-shadow: 0 22px 50px rgba(75, 0, 130, .11); }
.cair .ca-service-icon {
  width: 67px; height: 67px; border-radius: 50%; display: grid; place-items: center;
  margin: 0 auto 20px; background: #f1ecff; color: #5426de; font-size: 28px;
}
.cair .ca-service:nth-child(2) .ca-service-icon { background: #e9faef; color: #1eb66a; }
.cair .ca-service:nth-child(3) .ca-service-icon { background: #f0e9ff; color: #7b43ef; }
.cair .ca-service:nth-child(4) .ca-service-icon { background: #eaf4ff; color: #3180ee; }
.cair .ca-service:nth-child(5) .ca-service-icon { background: #faeaff; color: #d050dc; }
.cair .ca-service:nth-child(6) .ca-service-icon { background: #fff2df; color: #f2a11d; }
.cair .ca-service h3 { font-size: 17px; line-height: 1.22; margin-bottom: 14px; }
.cair .ca-service p { font-size: 12px; line-height: 1.65; color: #5d667e; margin-bottom: 17px; }
.cair .ca-service a { font-size: 13px; color: #4b20d5; font-weight: 900; }

/* STEPS */
.cair .ca-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 30px; text-align: center; position: relative; }
.cair .ca-step-num {
  width: 35px; height: 35px; border-radius: 50%; background: linear-gradient(135deg, #4285F4, #4B0082);
  color: #fff; font-weight: 900; display: grid; place-items: center; margin: 0 auto 16px;
}
.cair .ca-step-icon {
  width: 88px; height: 88px; border-radius: 50%; background: #f5f3ff; margin: 0 auto 20px;
  display: grid; place-items: center; font-size: 34px; color: #171a33;
}
.cair .ca-step h3 { font-size: 16px; margin-bottom: 10px; }
.cair .ca-step p { font-size: 13px; line-height: 1.6; color: #667085; }

/* EXPERTS PANEL */
.cair .ca-experts-panel {
  background: linear-gradient(135deg, #4B0082 0%, #250063 100%); border-radius: 24px; padding: 42px;
  color: #fff; box-shadow: 0 25px 60px rgba(75, 0, 130, .2);
}
.cair .ca-panel-head { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 28px; }
.cair .ca-panel-head h2 { font-size: 28px; letter-spacing: -.5px; color: #fff; }
.cair .ca-panel-head a { font-weight: 800; font-size: 13px; color: #fff; }
.cair .ca-expert-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.cair .ca-expert { background: #fff; color: #111; border-radius: 14px; overflow: hidden; box-shadow: 0 18px 35px rgba(0, 0, 0, .15); }
.cair .ca-expert-photo {
  height: 164px; background: linear-gradient(135deg, #e9edf5, #fff); display: grid;
  place-items: center; font-size: 76px; overflow: hidden;
}
.cair .ca-expert-photo img { width: 100%; height: 100%; object-fit: cover; }
.cair .ca-expert-body { padding: 18px; }
.cair .ca-expert-body h3 { font-size: 16px; }
.cair .ca-expert-body .ca-job { font-size: 13px; color: #667085; margin: 3px 0 9px; }
.cair .ca-stars { color: #ffaf22; font-size: 13px; font-weight: 900; margin-bottom: 10px; }
.cair .ca-expert-meta { font-size: 12px; color: #667085; line-height: 1.9; margin-bottom: 12px; }
.cair .ca-expert a { font-size: 13px; color: #4b20d5; font-weight: 900; }
.cair .ca-dots { text-align: center; margin-top: 22px; }
.cair .ca-dots span { display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: rgba(255, 255, 255, .42); margin: 0 5px; }
.cair .ca-dots span:first-child { background: #fff; }

/* WHY */
.cair .ca-why {
  background: linear-gradient(135deg, #06112e, #020817); border-radius: 22px; padding: 50px 36px;
  color: #fff; display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px;
}
.cair .ca-why-item { text-align: center; padding: 0 20px; border-right: 1px solid rgba(255, 255, 255, .12); }
.cair .ca-why-item:last-child { border-right: 0; }
.cair .ca-why-icon {
  width: 68px; height: 68px; border-radius: 50%; background: rgba(110, 80, 255, .24);
  display: grid; place-items: center; margin: 0 auto 22px; font-size: 28px;
}
.cair .ca-why-item h3 { font-size: 16px; margin-bottom: 10px; color: #fff; }
.cair .ca-why-item p { font-size: 12px; line-height: 1.65; color: #d4d8e7; }

/* TESTIMONIALS */
.cair .ca-test-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.cair .ca-test {
  border: 1px solid var(--cair-line); border-radius: 18px; padding: 28px; background: #fff;
  box-shadow: 0 15px 35px rgba(37, 21, 88, .045);
}
.cair .ca-quote { font-size: 34px; color: #7857ff; line-height: 1; }
.cair .ca-test p { font-size: 13px; line-height: 1.75; color: #5e667c; margin-bottom: 20px; }
.cair .ca-person { display: flex; align-items: center; gap: 12px; }
.cair .ca-person .ca-avatar { background: #f1ecff; }
.cair .ca-person b { font-size: 13px; }
.cair .ca-person small { display: block; color: #667085; font-size: 11px; }
.cair .ca-test .ca-stars { margin-left: auto; margin-bottom: 0; }

/* CTA */
.cair .ca-cta {
  background: var(--cair-btn-gradient); border-radius: 22px; color: #fff; padding: 42px 54px;
  display: flex; align-items: center; justify-content: space-between; overflow: hidden; position: relative;
}
.cair .ca-cta h2 { font-size: 33px; letter-spacing: -.6px; margin-bottom: 10px; color: #fff; }
.cair .ca-cta p { color: #eee7ff; margin-bottom: 24px; }
.cair .ca-cta-art { font-size: 126px; filter: drop-shadow(0 25px 30px rgba(0, 0, 0, .2)); }

/* ── Responsive ── */
@media (max-width: 1120px) {
  .cair .ca-hero-grid { grid-template-columns: 1fr; }
  .cair .ca-hero { text-align: center; }
  .cair .ca-hero p { margin-left: auto; margin-right: auto; }
  .cair .ca-hero-actions, .cair .ca-trust-row { justify-content: center; }
  .cair .ca-hero-visual { min-height: 430px; }
  .cair .ca-services-grid { grid-template-columns: repeat(3, 1fr); }
  .cair .ca-expert-grid { grid-template-columns: repeat(2, 1fr); }
  .cair .ca-stats { grid-template-columns: repeat(2, 1fr); }
  .cair .ca-stat:nth-child(2) { border-right: 0; }
  .cair .ca-stat:nth-child(1), .cair .ca-stat:nth-child(2) { border-bottom: 1px solid var(--cair-line); }
}
@media (max-width: 760px) {
  .cair .ca-container { width: 90%; }
  .cair .ca-hero { padding: 42px 0 22px; }
  .cair .ca-hero h1 { font-size: 38px; letter-spacing: -1.2px; }
  .cair .ca-hero p { font-size: 15px; }
  .cair .ca-eyebrow { font-size: 10px; }
  .cair .ca-hero-actions { flex-direction: column; }
  .cair .ca-hero-actions .ca-btn { width: 100%; min-width: 0; }
  .cair .ca-trust-row { gap: 16px; }
  .cair .ca-hero-visual { min-height: 330px; }
  .cair .ca-device { transform: none; }
  .cair .ca-laptop { height: 260px; padding: 10px; }
  .cair .ca-laptop-screen { height: 236px; grid-template-columns: 80px 1fr; }
  .cair .ca-sidebar { padding: 12px 8px; }
  .cair .ca-side-item { height: 14px; margin: 7px 0; }
  .cair .ca-dash-main { padding: 14px; }
  .cair .ca-dash-title { font-size: 14px; }
  .cair .ca-kpi { grid-template-columns: repeat(2, 1fr); }
  .cair .ca-kpi div { height: 42px; }
  .cair .ca-graph { height: 100px; }
  .cair .ca-base { height: 14px; }
  .cair .ca-expert-float, .cair .ca-phone, .cair .ca-plant, .cair .ca-mission-float, .cair .ca-card-note { display: none; }
  .cair .ca-blob { width: 300px; height: 220px; right: -25px; top: 50px; }
  .cair .ca-stats, .cair .ca-services-grid, .cair .ca-steps, .cair .ca-expert-grid, .cair .ca-why, .cair .ca-test-grid { grid-template-columns: 1fr; }
  .cair .ca-stat { border-right: 0 !important; border-bottom: 1px solid var(--cair-line) !important; justify-content: center; text-align: center; }
  .cair .ca-stat:last-child { border-bottom: 0 !important; }
  .cair .ca-section-head h2 { font-size: 28px; }
  .cair .ca-services-grid { gap: 14px; }
  .cair .ca-experts-panel { padding: 28px 18px; border-radius: 18px; }
  .cair .ca-panel-head { flex-direction: column; align-items: flex-start; gap: 12px; }
  .cair .ca-why { padding: 34px 22px; }
  .cair .ca-why-item { border-right: 0; border-bottom: 1px solid rgba(255, 255, 255, .12); padding-bottom: 24px; }
  .cair .ca-why-item:last-child { border-bottom: 0; }
  .cair .ca-cta { padding: 32px 22px; flex-direction: column; text-align: center; }
  .cair .ca-cta h2 { font-size: 27px; }
  .cair .ca-cta-art { font-size: 78px; }
}

/* ============================================================
   GUEST PAGES — listings, filters, forms, auth, blog
   Same design language as homepage (white cards, soft purple
   shadows, 20px radii, gradient accents, Inter)
   ============================================================ */

/* Breadcrumb hero band */
.breadcrumb-area,
.banner-inner-area {
  background: radial-gradient(circle at 78% 18%, #eee8ff 0, #f7f4ff 28%, transparent 49%), #fff !important;
  border-top: 1px solid var(--cair-line) !important;
  padding-top: 42px !important;
  padding-bottom: 42px !important;
}
.breadcrumb-contents-title {
  color: #090e29 !important;
  font-weight: 900 !important;
  letter-spacing: -1.4px;
  font-size: clamp(30px, 3.4vw, 44px) !important;
}
.breadcrumb-contents-list-item,
.breadcrumb-contents-list-item-link {
  color: #4e5b78 !important;
  font-weight: 700;
  font-size: 13px;
}
.breadcrumb-contents-list-item-link:hover { color: #4f1bce !important; }

/* Soft section background */
.section-bg-2, .section-bg-1 { background: var(--cair-soft) !important; }

/* Generic section titles on guest pages */
.section-title .title, h2.title { color: #10162f; letter-spacing: -1px; font-weight: 900 !important; }

/* ── Cards: freelancers / projects / jobs / categories / blog ── */
.single-freelancer,
.single-project,
.project-category-item,
.categoryWrap-wrapper-item,
.single-jobs {
  background: #fff !important;
  border: 1px solid var(--cair-line) !important;
  border-radius: 20px !important;
  box-shadow: 0 10px 28px rgba(37, 21, 88, .035) !important;
  transition: transform .25s ease, box-shadow .25s ease !important;
}
.single-freelancer:hover,
.single-project:hover,
.project-category-item:hover,
.categoryWrap-wrapper-item:hover,
.single-jobs:hover {
  transform: translateY(-6px);
  box-shadow: 0 22px 50px rgba(75, 0, 130, .11) !important;
  border-color: #ded8ff !important;
}
.single-freelancer-author-name,
.single-project-content-title,
.single-jobs-title,
.categoryWrap-wrapper-item-contents .title {
  font-weight: 800 !important;
  color: #10162f !important;
  letter-spacing: -.3px;
}
.single-freelancer-author-name a:hover,
.single-project-content-title a:hover,
.single-jobs-title a:hover { color: #4f1bce !important; }
.single-freelancer-author-para,
.single-jobs-para,
.single-project-content .job { color: var(--cair-muted) !important; }

/* Prices & ratings accents */
.single-project-content-price,
.single-jobs-price,
.single-jobs-price-fixed { color: #4B0082 !important; font-weight: 900 !important; }
.single-project-content-review-icon,
.single-project-content-review-rating { color: #ffaf22 !important; font-weight: 900; }

/* Tag pills */
.single-jobs-tag-link {
  background: #f1ecff !important;
  color: #4926d9 !important;
  border-radius: 10px !important;
  border: none !important;
  font-weight: 700 !important;
  font-size: 12px !important;
  padding: 7px 12px !important;
}
.single-jobs-tag-link:hover { background: #e3daff !important; color: #321078 !important; }

/* Gray secondary buttons → soft purple */
.cmn-btn.btn-bg-gray {
  background: #f1ecff !important;
  color: #4B0082 !important;
  border: none !important;
  font-weight: 800 !important;
  border-radius: 12px !important;
  transition: .25s !important;
}
.cmn-btn.btn-bg-gray:hover {
  background: var(--cair-btn-gradient) !important;
  color: #fff !important;
  transform: translateY(-2px);
}
.cmn-btn.btn-outline-2 {
  border: 1px solid #ded8ff !important;
  color: #4B0082 !important;
  border-radius: 12px !important;
}

/* ── Filter sidebar ── */
.single-shop-left {
  background: #fff !important;
  border: 1px solid var(--cair-line) !important;
  border-radius: 20px !important;
  box-shadow: 0 10px 28px rgba(37, 21, 88, .035) !important;
}
.single-shop-left-title { color: #10162f !important; font-weight: 800 !important; }
.single-shop-left-filter-title { color: #10162f !important; font-weight: 900 !important; }
.single-shop-left-filter-reset { color: #4f1bce !important; font-weight: 800 !important; }

/* ── Forms (login, register, contact, filters) ── */
.form--control,
input.form--control,
textarea.form--control,
select.form--control,
.single-input input,
.single-input textarea,
.single-input select {
  border: 1px solid var(--cair-line) !important;
  border-radius: 12px !important;
  background: #fff !important;
  color: var(--cair-text) !important;
  font-weight: 500;
  transition: border-color .2s ease, box-shadow .2s ease !important;
}
.form--control:focus,
.single-input input:focus,
.single-input textarea:focus {
  border-color: #6c4cff !important;
  box-shadow: 0 0 0 4px rgba(108, 76, 255, .12) !important;
  outline: none !important;
}
.label-title { color: #10162f !important; font-weight: 700 !important; }
.select2-container--default .select2-selection--single,
.select2-container--default .select2-selection--multiple {
  border: 1px solid var(--cair-line) !important;
  border-radius: 12px !important;
}
.nice-select {
  border: 1px solid var(--cair-line) !important;
  border-radius: 12px !important;
}

/* Account-type chooser cards (register) */
.choose-account-single {
  background: #fff !important;
  border: 1px solid var(--cair-line) !important;
  border-radius: 20px !important;
  transition: .25s !important;
}
.choose-account-single:hover,
.choose-account-single.selected,
.choose-account-single.active {
  border-color: #6c4cff !important;
  box-shadow: 0 22px 50px rgba(75, 0, 130, .11) !important;
  transform: translateY(-4px);
}
.choose-account-single-contents-title { font-weight: 800 !important; color: #10162f !important; }

/* ── Pagination ── */
.custom_pagination .page-item .page-link,
.pagination .page-item .page-link {
  border: 1px solid var(--cair-line) !important;
  color: #10162f !important;
  border-radius: 10px !important;
  margin: 0 4px;
  font-weight: 700;
}
.custom_pagination .page-item.active .page-link,
.pagination .page-item.active .page-link {
  background: var(--cair-btn-gradient) !important;
  border-color: transparent !important;
  color: #fff !important;
}
.custom_pagination .page-item .page-link:hover,
.pagination .page-item .page-link:hover {
  background: #f1ecff !important;
  color: #4f1bce !important;
}

/* ── Alerts ── */
.alert { border-radius: 14px !important; border: 1px solid var(--cair-line); font-weight: 600; }

/* ── Misc accents ── */
a:hover { color: #4f1bce; }
.click_to_bookmark.active i, .click-wishlist.active i { color: #4f1bce !important; }
.preloader-inner-item { background: var(--cair-btn-gradient) !important; }

/* Online/offline dots keep semantic colors */
.single-freelancer-author-status-online { background: #1eb66a !important; }

/* ============================================================
   AUTH PAGES (login / register / password reset)
   ============================================================ */
.login-area {
  background: radial-gradient(circle at 78% 18%, #eee8ff 0, #f7f4ff 28%, transparent 49%), #fff !important;
}
.login-wrapper,
.login-wrapper-contents {
  background: #fff;
}
.login-wrapper {
  border: 1px solid var(--cair-line) !important;
  border-radius: 24px !important;
  box-shadow: var(--cair-shadow) !important;
  padding: 38px 34px !important;
}
.login-wrapper-contents-title {
  font-weight: 900 !important;
  letter-spacing: -1px;
  color: #090e29 !important;
  font-size: 30px !important;
}
.submit-btn,
button.submit-btn {
  background: var(--cair-btn-gradient) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 12px !important;
  font-weight: 800 !important;
  padding: 15px 22px !important;
  box-shadow: 0 14px 34px rgba(75, 0, 130, .22) !important;
  transition: .25s !important;
}
.submit-btn:hover { transform: translateY(-2px); color: #fff !important; }

/* Right promo panel → gradient purple card like experts panel */
.login-right-item {
  background: linear-gradient(135deg, #4B0082 0%, #250063 100%) !important;
  border-radius: 24px !important;
  box-shadow: 0 25px 60px rgba(75, 0, 130, .2) !important;
  padding: 36px !important;
}
.login-right-contents-title { color: #fff !important; font-weight: 900 !important; letter-spacing: -.5px; }
.login-right-contents-para { color: #e6ddff !important; }

/* Social login buttons */
.login-others-single-btn {
  border: 1px solid #ded8ff !important;
  border-radius: 12px !important;
  background: #fff !important;
  color: #4B0082 !important;
  font-weight: 800 !important;
  transition: .25s !important;
}
.login-others-single-btn:hover { transform: translateY(-2px); box-shadow: 0 14px 30px rgba(75, 0, 130, .12); }
.or-contents-para { color: var(--cair-muted) !important; font-weight: 700; }

/* Checkboxes / links */
.checkbox-label { color: #4e5b78 !important; }
.forgot-btn, .color-one { color: #4f1bce !important; font-weight: 700; }

/* Register step indicator inherits palette */
.ca-register-step.active .ca-register-step-num,
.ca-register-step.done .ca-register-step-num {
  background: var(--cair-btn-gradient) !important;
  border-color: transparent !important;
  color: #fff !important;
}
.ca-register-step-line.done { background: #6c4cff !important; }
.ca-register-step.active .ca-register-step-label,
.ca-register-step.done .ca-register-step-label { color: #4f1bce !important; }

/* Role selection modal */
.modal-content { border-radius: 20px !important; border: 1px solid var(--cair-line) !important; }

/* ============================================================
   ABOUT / CONTENT PAGES (page-builder widgets)
   ============================================================ */
.about-counter-item,
.credit-item,
.aboutWhat-wrapper,
.aboutTeam-item {
  background: #fff !important;
  border: 1px solid var(--cair-line) !important;
  border-radius: 20px !important;
  box-shadow: 0 10px 28px rgba(37, 21, 88, .035) !important;
  transition: transform .25s ease, box-shadow .25s ease !important;
}
.about-counter-item:hover,
.credit-item:hover,
.aboutWhat-wrapper:hover,
.aboutTeam-item:hover {
  transform: translateY(-6px);
  box-shadow: 0 22px 50px rgba(75, 0, 130, .11) !important;
}
.about-counter-item-title-heading,
.credit-item-title-heading {
  color: #10162f !important;
  font-weight: 900 !important;
  letter-spacing: -1px;
}
.aboutWhat-wrapper-icon {
  background: #f1ecff !important;
  color: #5426de !important;
  border-radius: 50% !important;
}
.section-title .title { color: #10162f !important; font-weight: 900 !important; letter-spacing: -1px; }
.section-para { color: #667085 !important; }

/* Breadcrumb eyebrow chip */
.ca-breadcrumb-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  background: #f1ecff; color: #321078;
  font-weight: 900; font-size: 11px; letter-spacing: .3px;
  border-radius: 10px; padding: 8px 12px; margin-bottom: 14px;
  text-transform: uppercase;
}

/* Listing page background → match hero softness */
.preview-area.section-bg-2 { background: #fbfaff !important; }

/* ============================================================
   REGISTER — step 1 role chooser (light redesign, overrides
   old full-viewport dark dual-panel from compta-air-theme.css)
   ============================================================ */
.choose-account-area {
  background: radial-gradient(circle at 78% 18%, #eee8ff 0, #f7f4ff 28%, transparent 49%), #fff !important;
  min-height: auto !important;
  padding: 70px 0 80px !important;
  display: block !important;
}
.choose-account-area .container {
  max-width: 920px !important;
  padding: 0 16px !important;
  display: block !important;
}
.choose-account { display: block !important; }
.choose-account-title {
  font-family: 'Inter', sans-serif !important;
  color: #090e29 !important;
  font-weight: 900 !important;
  letter-spacing: -1.2px;
  padding-top: 0 !important;
  font-size: clamp(28px, 3.4vw, 40px) !important;
}
.choose-account-para { color: #667085 !important; font-size: 15px !important; }

.choose-account-flex {
  gap: 18px !important;
  margin-top: 34px !important;
  min-height: 0 !important;
  flex: none !important;
  justify-content: center !important;
}
.choose-account-single {
  background: #fff !important;
  border: 2px solid var(--cair-line) !important;
  border-radius: 20px !important;
  padding: 40px 32px !important;
  max-width: 380px !important;
  box-shadow: 0 10px 28px rgba(37, 21, 88, .035) !important;
  transition: border-color .25s ease, box-shadow .25s ease, transform .25s ease !important;
  justify-content: flex-start !important;
}
.choose-account-single:first-child { border-right: 2px solid var(--cair-line) !important; }
.choose-account-single::before { display: none !important; }
.choose-account-single:hover,
.choose-account-single.selected,
.choose-account-single:last-child:hover,
.choose-account-single:last-child.selected {
  background: #fff !important;
  border-color: #6c4cff !important;
  box-shadow: 0 22px 50px rgba(75, 0, 130, .13) !important;
  transform: translateY(-4px) !important;
}
.choose-account-single.selected,
.choose-account-single:last-child.selected {
  background: #faf8ff !important;
}
.choose-account-single.selected::after {
  content: '✓';
  position: absolute;
  top: 14px; right: 16px;
  width: 26px; height: 26px;
  border-radius: 50%;
  background: var(--cair-btn-gradient);
  color: #fff;
  font-size: 14px; font-weight: 900;
  display: grid; place-items: center;
}
.choose-account-single-thumb svg { opacity: 1 !important; width: 64px !important; height: 64px !important; }
.choose-account-single-contents-title {
  font-family: 'Inter', sans-serif !important;
  color: #10162f !important;
  font-size: 20px !important;
  text-transform: none !important;
  letter-spacing: -.3px !important;
  font-weight: 800 !important;
}
.choose-account-single-desc,
.choose-account-single-contents p {
  font-size: 13px !important;
  color: #667085 !important;
  margin-top: 6px;
  line-height: 1.55;
}

/* Continue button + social area on light bg */
.choose-account .btn-wrapper { padding: 26px 0 6px !important; max-width: 420px !important; }
.btn-profile.btn-bg-1 {
  display: inline-block;
  padding: 15px 22px;
  text-align: center;
  cursor: pointer;
}
.choose-account .login-bottom-contents { max-width: 420px !important; padding: 0 0 10px !important; }
.or-contents { position: relative; text-align: center; }
.or-contents-para {
  background: transparent !important;
  color: #98a2b8 !important;
  font-weight: 700;
  padding: 0 12px;
}

/* Mobile: stack role cards */
@media (max-width: 760px) {
  .choose-account-flex { flex-direction: column !important; align-items: center !important; }
  .choose-account-single { width: 100%; max-width: 420px !important; padding: 30px 24px !important; }
}

/* Login right-panel trust bullets */
.ca-login-trust { margin-top: 22px; padding: 0; }
.ca-login-trust li {
  color: #efe9ff; font-weight: 700; font-size: 14px;
  padding: 9px 0; border-bottom: 1px solid rgba(255, 255, 255, .12);
  list-style: none;
}
.ca-login-trust li:last-child { border-bottom: 0; }

/* Avatar initials fallback (talents etc.) */
.ca-avatar-initials {
  width: 96px; height: 96px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--cair-gradient);
  color: #fff; font-weight: 900; font-size: 30px; letter-spacing: 1px;
}

/* Card thumb placeholder (blog etc.) */
.ca-thumb-placeholder {
  display: flex; align-items: center; justify-content: center;
  width: 100%; min-height: 170px; border-radius: 12px;
  background: linear-gradient(135deg, #f4f1ff, #ece5ff);
}
.ca-thumb-placeholder .ca-brand-mark { opacity: .85; }

/* Mobile header: keep one compact row of actions */
@media (max-width: 991px) {
  .navbar-area .nav-container { padding-top: 8px; padding-bottom: 8px; }
  .navbar-right-content .cmn-btn,
  .navbar-area .cmn-btn { padding: 9px 14px; font-size: 13px !important; }
  .navbar-right-content .navbar-right-flex { gap: 8px; flex-wrap: nowrap; }
}

/* ── Listing grids: quiet card CTAs, gradient reserved for page-level actions ── */
.single-project .cmn-btn.btn-bg-1,
.project-category-item .cmn-btn.btn-bg-1,
.single-jobs .cmn-btn.btn-bg-1,
.single-freelancer .cmn-btn.btn-bg-1 {
  background: #fff !important;
  color: #4B0082 !important;
  border: 1px solid #ded8ff !important;
  box-shadow: none !important;
}
.single-project .cmn-btn.btn-bg-1:hover,
.project-category-item .cmn-btn.btn-bg-1:hover,
.single-jobs .cmn-btn.btn-bg-1:hover,
.single-freelancer .cmn-btn.btn-bg-1:hover {
  background: var(--cair-btn-gradient) !important;
  color: #fff !important;
  border-color: transparent !important;
}

/* Sponsored / pro tier gets the visual priority instead */
.single-freelancer:has(.pro-profile-badge),
.single-project:has(.pro-badge),
.project-category-item:has(.pro-badge) {
  border-top: 3px solid #6c4cff !important;
  background: linear-gradient(180deg, #faf8ff 0, #fff 60px) !important;
}
.pro-profile-badge {
  background: var(--cair-btn-gradient) !important;
  color: #fff !important;
}

/* ── Listing empty state ── */
.ca-empty-state {
  text-align: center;
  background: #fff;
  border: 1px dashed #ded8ff;
  border-radius: 16px;
  padding: 56px 24px;
}
.ca-empty-state .ca-brand-mark {
  display: inline-flex;
  gap: 4px;
  margin-bottom: 18px;
  transform: scale(1.4);
}
.ca-empty-state h4 {
  font-size: 20px;
  font-weight: 700;
  color: #050b24;
  margin-bottom: 8px;
}
.ca-empty-state p {
  color: #5a6072;
  max-width: 420px;
  margin: 0 auto 20px;
}

/* ── Mobile filter toggle: label the bars icon ── */
.shop-icon-sidebar { display: inline-flex; align-items: center; gap: 8px; cursor: pointer; }
.ca-filter-label { font-weight: 600; font-size: 14px; color: #4B0082; }

/* ── WhatsApp floating button: pinned bottom-right, clear of CTAs ── */
.whatsapp-integration-wrap {
  position: fixed !important;
  right: 18px !important;
  bottom: 18px !important;
  top: auto !important;
  left: auto !important;
  z-index: 990 !important;
  line-height: 0;
  filter: drop-shadow(0 4px 12px rgba(5, 11, 36, 0.25));
}
.whatsapp-integration-wrap svg { display: block; }
@media (max-width: 991px) {
  .whatsapp-integration-wrap { right: 12px !important; bottom: 12px !important; }
  .whatsapp-integration-wrap svg { width: 44px; height: 44px; }
}
