/* ═══════════════════════════════════════════════════════════
   Relocation Centers — Base Design System
   Velorix SL · relocationcenters.com
   ═══════════════════════════════════════════════════════════ */

/* ── TOKENS ── */
:root {
  --b:   #003da5;  /* brand blue */
  --b50: #eef3fc;
  --b100:#d4e0f7;
  --bd:  #001d5a;
  --bx:  #080e1e;  /* near-black hero */
  --r:   #dc1c2e;  /* accent red */
  --rh:  #b81625;
  --w:   #fff;
  --off: #f7f8fa;
  --g50: #f9fafb;
  --g100:#f1f3f5;
  --g200:#e1e4e8;
  --g300:#c8cdd3;
  --g400:#8c95a2;
  --g500:#5c6673;
  --g600:#3d4654;
  --g700:#2a3140;
  --g800:#1a1f2e;
  --g900:#0d1017;
  --gn:  #0d9f6e;  /* green check */
  --gnl: #ecfdf5;
  --wa:  #25d366;  /* WhatsApp */
  --gold:#f59e0b;  /* stars */
  --rd:  8px;
  --rl:  14px;
  --rx:  20px;
  --shadow: 0 2px 12px rgba(0,0,0,.06);
  --shadow-lg: 0 12px 40px rgba(0,0,0,.12);
}

/* ── RESET ── */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box }
html { scroll-behavior:smooth; scroll-padding-top:70px; overflow-x:hidden }
body {
  font-family:'Montserrat',system-ui,-apple-system,sans-serif;
  color:var(--g600); line-height:1.65; background:var(--w);
  overflow-x:hidden; -webkit-font-smoothing:antialiased; font-size:17px;
}
h1,h2,h3,h4 { font-family:'Montserrat',system-ui,-apple-system,sans-serif }
img { max-width:100%; height:auto }
a  { color:inherit }

/* ── NAV ── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:1000; height:60px;
  transition:background .3s,box-shadow .3s,border-color .3s;
  overflow-x:clip; background:transparent; border-bottom:1px solid transparent;
}
nav.scrolled {
  background:rgba(255,255,255,.97); backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px); border-bottom:1px solid rgba(0,0,0,.05);
  box-shadow:0 1px 12px rgba(0,0,0,.06);
}
.nav-inner {
  max-width:1200px; margin:0 auto; padding:0 40px; height:100%;
  display:flex; align-items:center; justify-content:space-between; gap:12px;
}
.nav-logo {
  display:flex; align-items:center; gap:10px; text-decoration:none; flex-shrink:0;
}
.nav-logo-mark {
  width:34px; height:34px; border-radius:8px; background:var(--b);
  display:flex; align-items:center; justify-content:center;
  font-size:16px; font-weight:900; color:#fff; letter-spacing:-.03em;
  transition:background .3s; flex-shrink:0;
}
nav.scrolled .nav-logo-mark { background:var(--b) }
.nav-logo-text {
  font-weight:800; font-size:.95rem; color:#fff;
  letter-spacing:-.01em; transition:color .3s; line-height:1.2;
}
.nav-logo-sub {
  font-size:.65rem; font-weight:600; color:rgba(255,255,255,.5);
  display:block; letter-spacing:.04em; transition:color .3s;
}
nav.scrolled .nav-logo-text { color:var(--b) }
nav.scrolled .nav-logo-sub  { color:var(--g400) }

.nav-links { display:flex; gap:4px; align-items:center }
.nav-links a {
  font-size:14px; font-weight:600; color:rgba(255,255,255,.6);
  text-decoration:none; padding:8px 12px; border-radius:6px; transition:color .2s,background .2s;
}
.nav-links a:hover { color:#fff }
nav.scrolled .nav-links a       { color:var(--g400) }
nav.scrolled .nav-links a:hover { color:var(--b); background:var(--g50) }

.nav-wa {
  display:inline-flex; align-items:center; gap:6px;
  background:var(--wa) !important; color:#fff !important;
  font-size:13px; font-weight:700 !important;
  padding:9px 16px !important; border-radius:var(--rd);
  transition:all .2s; margin-left:4px;
}
.nav-wa:hover { background:#1da851 !important; transform:translateY(-1px) }
.nav-wa svg   { width:15px; height:15px; fill:#fff; flex-shrink:0 }

.lng-bar { display:flex; gap:3px; align-items:center }
.lng-btn {
  background:none; border:2px solid transparent; border-radius:6px;
  cursor:pointer; padding:3px; width:32px; height:32px;
  display:flex; align-items:center; justify-content:center;
  transition:all .15s; opacity:.4;
}
.lng-btn:hover   { opacity:.85 }
.lng-btn.active  { opacity:1; border-color:var(--r); background:rgba(220,28,46,.08) }
.lng-btn .fi     { width:22px; height:16px; border-radius:2px; flex-shrink:0; display:block }

/* hamburger */
.hmb {
  display:none; background:none; border:none; font-size:26px; cursor:pointer;
  padding:4px 8px; color:#fff; line-height:1; transition:color .3s;
}
nav.scrolled .hmb { color:var(--g900) }
.mob-ov {
  display:none; position:fixed; inset:0;
  background:rgba(8,14,30,.98); backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px); z-index:9998;
  flex-direction:column; align-items:center; justify-content:flex-start;
  gap:6px; padding:72px 24px 40px; overflow-y:auto;
}
.mob-ov.open { display:flex }
.mob-ov .mob-label {
  font-size:11px; font-weight:800; color:rgba(255,255,255,.35);
  text-transform:uppercase; letter-spacing:1.2px;
  margin:16px 0 6px; width:100%; max-width:340px; text-align:left;
}
.mob-ov a {
  color:#fff; font-size:16px; font-weight:600; text-decoration:none;
  padding:14px 18px; border-radius:var(--rd); transition:background .2s;
  min-height:48px; display:flex; align-items:center;
  width:100%; max-width:340px;
  border:1px solid rgba(255,255,255,.08); background:rgba(255,255,255,.03);
}
.mob-ov a:hover { background:rgba(255,255,255,.1) }
.mob-ov a.mob-cta {
  background:var(--wa); border-color:var(--wa);
  justify-content:center; font-weight:800;
}
.mob-ov a.mob-cta:hover { background:#1da851 }
.mob-x {
  position:absolute; top:16px; right:16px; font-size:32px; color:#fff;
  background:rgba(255,255,255,.08); border:none; cursor:pointer; line-height:1;
  width:44px; height:44px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
}

/* ── HERO ── */
.hero {
  position:relative; min-height:100vh; display:flex; flex-direction:column;
  align-items:center; justify-content:center; overflow:hidden;
  background:var(--bx); padding:100px 24px 70px; text-align:center;
}
.hero::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 110% 75% at 50% 40%,rgba(0,61,165,.5) 0%,transparent 55%),
             linear-gradient(155deg,#060c1a 0%,#0b1830 42%,#091428 100%);
  z-index:0;
}
.hero::after {
  content:''; position:absolute; inset:0;
  background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);
  background-size:48px 48px; z-index:0; pointer-events:none;
}
.hero>* { position:relative; z-index:1 }

.hero-badge {
  display:inline-flex; align-items:center; gap:6px;
  background:rgba(0,61,165,.15); border:1px solid rgba(0,61,165,.3);
  border-radius:100px; padding:7px 16px; font-size:12px; font-weight:700;
  color:var(--b100); margin-bottom:24px; text-transform:uppercase; letter-spacing:.8px;
}
.hero h1 {
  font-size:clamp(2.2rem,5vw,3.5rem); font-weight:800; line-height:1.1;
  letter-spacing:-.03em; color:#fff; max-width:860px; margin:0 auto 20px;
}
.hero h1 em {
  font-style:normal; background:linear-gradient(120deg,#60a5fa,#d4e0f7);
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
}
.hero-sub {
  font-size:18px; color:rgba(255,255,255,.6); max-width:620px;
  margin:0 auto 36px; line-height:1.65;
}
.hero-filter-label {
  font-size:11px; font-weight:700; text-transform:uppercase;
  letter-spacing:2px; color:rgba(255,255,255,.35); margin:0 0 14px;
}
.hero-quiz { display:flex; flex-wrap:wrap; gap:8px; justify-content:center; max-width:780px; margin:0 auto 32px }
.quiz-btn {
  background:rgba(255,255,255,.04); border:1.5px solid rgba(255,255,255,.14);
  border-radius:100px; padding:10px 20px; font-family:inherit; font-size:13px;
  font-weight:600; color:rgba(255,255,255,.7); cursor:pointer; transition:all .2s;
  backdrop-filter:blur(8px);
}
.quiz-btn:hover { border-color:rgba(255,255,255,.35); background:rgba(255,255,255,.08); color:#fff }
.quiz-btn.active { border-color:var(--b); background:rgba(0,61,165,.2); color:#fff }

.hero-ctas { display:flex; gap:12px; flex-wrap:wrap; justify-content:center; margin-bottom:18px }
.hero-cta {
  display:inline-flex; align-items:center; gap:10px; padding:15px 30px;
  background:var(--wa); color:#fff; font-size:15px; font-weight:700;
  border-radius:var(--rd); text-decoration:none; transition:all .2s;
  box-shadow:0 4px 28px rgba(37,211,102,.35);
}
.hero-cta:hover { background:#1da851; transform:translateY(-2px); box-shadow:0 8px 36px rgba(37,211,102,.45) }
.hero-cta svg { width:20px; height:20px; fill:#fff; flex-shrink:0 }
.hero-cta2 {
  display:inline-flex; align-items:center; gap:8px; padding:15px 26px;
  background:transparent; border:1.5px solid rgba(255,255,255,.25); color:#fff;
  font-size:14px; font-weight:600; border-radius:var(--rd); text-decoration:none; transition:all .2s;
}
.hero-cta2:hover { border-color:rgba(255,255,255,.5); background:rgba(255,255,255,.06) }
.hero-micro { font-size:12px; color:rgba(255,255,255,.35); margin-bottom:16px; font-style:italic }
.hero-proof {
  display:flex; align-items:center; gap:18px; flex-wrap:wrap;
  justify-content:center; font-size:13px; color:rgba(255,255,255,.4); max-width:760px; margin:0 auto;
}
.hero-proof strong { color:rgba(255,255,255,.75); font-weight:700 }
.hero-sep { width:3px; height:3px; border-radius:50%; background:rgba(255,255,255,.2) }

/* ── TRUST STRIP ── */
.trust {
  padding:36px 24px; background:var(--g50);
  border-top:1px solid var(--g200); border-bottom:1px solid var(--g200);
}
.trust-inner {
  max-width:1200px; margin:0 auto; display:flex; flex-wrap:wrap;
  gap:24px 40px; justify-content:center; align-items:center;
}
.trust-item { display:flex; align-items:center; gap:10px; font-size:15px; font-weight:600; color:var(--g600) }
.trust-item span:first-child { font-size:1.25rem; line-height:1 }

/* ── SECTION PRIMITIVES ── */
.section-label {
  font-size:12px; font-weight:700; letter-spacing:2.5px; text-transform:uppercase;
  color:var(--r); margin-bottom:10px; text-align:center;
}
.section-h {
  font-size:clamp(1.7rem,3.2vw,2.4rem); font-weight:800; color:var(--g900);
  text-align:center; margin-bottom:12px; letter-spacing:-.03em; line-height:1.2;
}
.section-sub {
  font-size:17px; color:var(--g500); text-align:center;
  max-width:640px; margin:0 auto 52px; line-height:1.65;
}

/* ── SERVICE CARDS GRID ── */
.services { padding:96px 24px; background:var(--w) }
.srv-grid {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:22px; max-width:1200px; margin:0 auto;
}
.srv-card {
  background:var(--w); border:2px solid var(--g200); border-radius:var(--rl);
  padding:32px; display:flex; flex-direction:column; gap:14px;
  transition:all .25s; text-decoration:none; color:inherit;
  position:relative; overflow:hidden; box-shadow:0 2px 8px rgba(0,0,0,.03);
}
.srv-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:4px;
  background:var(--b); transform:scaleX(0); transform-origin:left; transition:transform .3s;
}
.srv-card:hover { border-color:var(--b); box-shadow:0 16px 48px rgba(0,61,165,.12); transform:translateY(-4px) }
.srv-card:hover::before { transform:scaleX(1) }
.srv-card.accent::before { background:var(--r) }
.srv-card.accent:hover   { border-color:var(--r); box-shadow:0 16px 48px rgba(220,28,46,.1) }
.srv-card.hidden { display:none }

.srv-icon { width:52px; height:52px; border-radius:12px; background:var(--b50); display:flex; align-items:center; justify-content:center; font-size:1.5rem }
.srv-card.accent .srv-icon { background:#fef2f2 }
.srv-tag {
  display:inline-block; font-size:11px; font-weight:700; letter-spacing:1px;
  text-transform:uppercase; color:var(--b); background:var(--b50);
  padding:4px 11px; border-radius:100px; align-self:flex-start;
}
.srv-card.accent .srv-tag { color:var(--r); background:#fef2f2 }
.srv-badge {
  position:absolute; top:20px; right:20px; background:var(--gn);
  color:#fff; font-size:10px; font-weight:800; padding:4px 10px;
  border-radius:100px; letter-spacing:.8px; text-transform:uppercase;
}
.srv-price {
  font-size:13px; font-weight:800; color:var(--b); letter-spacing:.01em;
  margin-top:-2px;
}
.srv-card.accent .srv-price { color:var(--r) }
.srv-reassure {
  font-size:12.5px; font-weight:600; color:var(--gn); line-height:1.5;
  background:var(--gnl); border-radius:var(--rd); padding:9px 12px;
  display:flex; align-items:flex-start; gap:7px;
}
.srv-reassure::before { content:'🔒'; font-size:12px; flex-shrink:0; margin-top:1px }
.srv-card h2 { font-size:1.25rem; font-weight:800; color:var(--g900); line-height:1.25; letter-spacing:-.02em }
.srv-card p  { font-size:15px; color:var(--g500); flex:1; line-height:1.65 }
.srv-features { list-style:none; display:flex; flex-direction:column; gap:8px; padding:0 }
.srv-features li {
  font-size:14px; color:var(--g600); display:flex; align-items:flex-start;
  gap:8px; font-weight:500;
}
.srv-features li::before {
  content:'✓'; width:18px; height:18px; border-radius:50%; background:var(--gnl);
  color:var(--gn); flex-shrink:0; margin-top:1px; display:inline-flex;
  align-items:center; justify-content:center; font-size:11px; font-weight:800;
}
.srv-card.accent .srv-features li::before { background:#fef2f2; color:var(--r) }
.srv-cta {
  display:inline-flex; align-items:center; gap:6px; background:var(--b);
  color:var(--w); font-size:14px; font-weight:700; padding:12px 22px;
  border-radius:var(--rd); text-decoration:none; transition:all .2s;
  margin-top:auto; width:fit-content;
}
.srv-cta:hover  { background:var(--bd); transform:translateX(2px) }
.srv-card.accent .srv-cta       { background:var(--r) }
.srv-card.accent .srv-cta:hover { background:var(--rh) }

/* ── VISA BANNER ── */
.visa-banner {
  margin:0 auto 0; max-width:1200px; padding:0 24px;
  display:none; /* shown by JS after services section */
}
.visa-banner-inner {
  background:linear-gradient(135deg,#0b1830 0%,#1a3a6e 100%);
  border:1px solid rgba(96,165,250,.25); border-radius:var(--rx);
  padding:48px 40px; display:flex; align-items:center; gap:40px;
  position:relative; overflow:hidden;
}
.visa-banner-inner::before {
  content:''; position:absolute; top:-40px; right:-40px;
  width:280px; height:280px; border-radius:50%;
  background:radial-gradient(circle,rgba(0,61,165,.4) 0%,transparent 70%);
  pointer-events:none;
}
.visa-icon { font-size:3.5rem; flex-shrink:0 }
.visa-body { flex:1 }
.visa-kicker { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:2px; color:#60a5fa; margin-bottom:8px }
.visa-body h3 { font-size:1.7rem; font-weight:800; color:#fff; margin-bottom:10px; letter-spacing:-.02em; line-height:1.2 }
.visa-body p  { font-size:15px; color:rgba(255,255,255,.65); margin-bottom:16px; line-height:1.6 }
.visa-pills { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:20px }
.visa-pill  {
  background:rgba(96,165,250,.15); border:1px solid rgba(96,165,250,.3);
  color:#93c5fd; font-size:12px; font-weight:700; padding:5px 14px;
  border-radius:100px; letter-spacing:.5px;
}
.visa-cta {
  display:inline-flex; align-items:center; gap:8px; background:var(--wa);
  color:#fff; font-size:15px; font-weight:700; padding:14px 28px;
  border-radius:var(--rd); text-decoration:none; transition:all .2s;
  box-shadow:0 4px 20px rgba(37,211,102,.3);
}
.visa-cta:hover { background:#1da851; transform:translateY(-1px) }
.visa-cta svg  { width:18px; height:18px; fill:#fff }
.visa-note { font-size:12px; color:rgba(255,255,255,.4); margin-top:10px; font-style:italic }

/* ── DARK SECTION (Why RC / eXp) ── */
.dark-section {
  padding:96px 24px; background:var(--bx); color:#fff;
  position:relative; overflow:hidden;
}
.dark-section::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 90% 60% at 50% 30%,rgba(0,61,165,.35) 0%,transparent 60%);
  pointer-events:none;
}
.dark-section>* { position:relative; z-index:1 }
.dark-section .section-h   { color:#fff }
.dark-section .section-label { color:#60a5fa }
.dark-section .section-sub { color:rgba(255,255,255,.6) }

.ds-inner { max-width:1200px; margin:0 auto }
.ds-head  { text-align:center; margin-bottom:48px }
.ds-grid  { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:20px }
.ds-card  {
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08);
  border-radius:var(--rl); padding:28px; transition:all .25s;
  backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
}
.ds-card:hover { background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.18); transform:translateY(-3px) }
.ds-ic   { font-size:2rem; margin-bottom:14px; display:block }
.ds-card h3 { font-size:1.05rem; font-weight:800; color:#fff; margin-bottom:8px; letter-spacing:-.01em }
.ds-card p  { font-size:14px; color:rgba(255,255,255,.55); line-height:1.6 }

/* ── INCOME STREAMS (agents page) ── */
.income-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:20px; max-width:1200px; margin:0 auto }
.income-card {
  background:var(--w); border:2px solid var(--g200); border-radius:var(--rl);
  padding:28px; transition:all .25s; position:relative; overflow:hidden;
}
.income-card::before { content:''; position:absolute; top:0; left:0; right:0; height:4px; background:var(--b) }
.income-card:nth-child(2)::before { background:var(--gn) }
.income-card:nth-child(3)::before { background:#7c3aed }
.income-card:nth-child(4)::before { background:var(--r) }
.income-card:hover { box-shadow:0 12px 36px rgba(0,0,0,.1); transform:translateY(-3px) }
.income-num  {
  font-size:2rem; font-weight:900; color:var(--b100); line-height:1;
  margin-bottom:12px; font-family:'Montserrat',sans-serif;
}
.income-card:nth-child(2) .income-num { color:#d1fae5 }
.income-card:nth-child(3) .income-num { color:#ede9fe }
.income-card:nth-child(4) .income-num { color:#fef2f2 }
.income-card h3 { font-size:1.1rem; font-weight:800; color:var(--g900); margin-bottom:8px }
.income-card p  { font-size:14px; color:var(--g500); line-height:1.6 }
.income-amount  {
  margin-top:14px; padding:12px 16px; background:#ecfdf5;
  border-radius:var(--rd); font-size:15.5px; font-weight:800; color:#047857;
  border:1px solid #a7f3d0; line-height:1.5;
}

/* ── HOW IT WORKS (steps) ── */
.steps-grid {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:0; max-width:960px; margin:0 auto; position:relative;
}
.steps-grid::before {
  content:''; position:absolute; top:28px; left:15%; right:15%; height:2px;
  background:linear-gradient(90deg,var(--b) 0%,var(--b100) 100%);
  z-index:0;
}
.step {
  display:flex; flex-direction:column; align-items:center; text-align:center;
  padding:0 16px; position:relative; z-index:1;
}
.step-num {
  width:56px; height:56px; border-radius:50%; background:var(--b);
  color:#fff; font-size:1.3rem; font-weight:800; display:flex;
  align-items:center; justify-content:center; margin-bottom:16px;
  box-shadow:0 4px 16px rgba(0,61,165,.3); flex-shrink:0;
}
.step h4  { font-size:1rem; font-weight:800; color:var(--g900); margin-bottom:6px }
.step p   { font-size:13px; color:var(--g500); line-height:1.55 }

/* ── DIVISION OF ROLES (lawyers page) ── */
.roles-split {
  display:grid; grid-template-columns:1fr 1fr; gap:24px; max-width:960px; margin:0 auto;
}
.role-col {
  border-radius:var(--rl); padding:32px; border:2px solid var(--g200);
}
.role-col.theirs { border-color:var(--g200); background:var(--g50) }
.role-col.ours   { border-color:var(--b100); background:var(--b50) }
.role-col h3 { font-size:1.1rem; font-weight:800; color:var(--g900); margin-bottom:20px; display:flex; align-items:center; gap:10px }
.role-col.ours h3 { color:var(--b) }
.role-list { list-style:none; display:flex; flex-direction:column; gap:10px }
.role-list li {
  display:flex; align-items:flex-start; gap:10px;
  font-size:14px; font-weight:500; color:var(--g600); line-height:1.5;
}
.role-list li::before {
  content:'✓'; width:20px; height:20px; border-radius:50%; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  font-size:11px; font-weight:800; margin-top:1px;
}
.role-col.theirs .role-list li::before { background:var(--gnl); color:var(--gn) }
.role-col.ours   .role-list li::before { background:var(--b100); color:var(--b) }

/* ── TESTIMONIALS ── */
.tsm { padding:96px 24px; background:var(--w) }
.tsm-inner { max-width:1200px; margin:0 auto }
.tsm-head  { text-align:center; margin-bottom:48px }
.tsm-stars { color:var(--gold); font-size:1.2rem; letter-spacing:3px; margin-bottom:6px }
.tsm-grid  { display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:24px }
.tsm-card  {
  background:var(--w); border:2px solid var(--g200); border-left:5px solid var(--b);
  border-radius:var(--rl); padding:30px; position:relative; transition:all .25s;
  box-shadow:0 4px 16px rgba(0,0,0,.04);
}
.tsm-card:hover { box-shadow:0 12px 40px rgba(0,0,0,.08); transform:translateY(-3px) }
.tsm-q   { position:absolute; top:14px; right:20px; font-size:54px; color:var(--b100); font-family:Georgia,serif; line-height:.8; pointer-events:none }
.tsm-s   { color:var(--gold); font-size:1rem; letter-spacing:3px; margin-bottom:10px }
.tsm-ctx {
  font-size:12px; color:var(--g500); background:var(--g50); padding:9px 12px;
  border-radius:var(--rd); margin-bottom:12px; line-height:1.55; border:1px solid var(--g100);
}
.tsm-text {
  font-size:15px; color:var(--g600); line-height:1.7; font-style:italic;
  margin-bottom:16px; position:relative; z-index:1;
}
.tsm-text strong { font-style:normal; color:var(--g800); font-weight:700 }
.tsm-attr  { display:flex; align-items:center; gap:14px; padding-top:14px; border-top:1px solid var(--g100) }
.tsm-av    {
  width:42px; height:42px; border-radius:50%;
  background:linear-gradient(135deg,var(--b),var(--bd));
  color:#fff; display:flex; align-items:center; justify-content:center;
  font-weight:800; font-size:13px; flex-shrink:0;
}
.tsm-nm { font-size:14px; font-weight:800; color:var(--g900) }
.tsm-rl { font-size:12px; color:var(--g400) }

/* ── FAQ ── */
.faq { padding:96px 24px; background:var(--bx); color:#fff; position:relative; overflow:hidden }
.faq::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 70% 50% at 50% 40%,rgba(0,61,165,.3) 0%,transparent 60%);
  pointer-events:none;
}
.faq>* { position:relative; z-index:1 }
.faq .section-h    { color:#fff }
.faq .section-label{ color:#60a5fa }
.faq-inner { max-width:860px; margin:0 auto }
.faq-head  { text-align:center; margin-bottom:40px }
.faq-list  { display:flex; flex-direction:column; gap:12px }
.faq-item  {
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.1);
  border-radius:var(--rl); overflow:hidden; transition:all .2s;
  backdrop-filter:blur(8px);
}
.faq-item:hover  { border-color:rgba(255,255,255,.2) }
.faq-item[open]  { background:rgba(255,255,255,.07); border-color:rgba(96,165,250,.35) }
.faq-q {
  width:100%; background:none; border:0; padding:20px 24px; font-family:inherit;
  font-size:15px; font-weight:700; color:#fff; text-align:left; cursor:pointer;
  display:flex; justify-content:space-between; align-items:center; gap:16px;
  letter-spacing:-.01em;
}
.faq-q::after { content:'+'; font-size:1.4rem; font-weight:300; color:#60a5fa; flex-shrink:0; transition:transform .2s; line-height:1 }
.faq-item[open] .faq-q::after { content:'−' }
.faq-a { padding:0 24px 22px; font-size:14px; color:rgba(255,255,255,.65); line-height:1.75 }
.faq-a a { color:#60a5fa; text-decoration:underline }

/* ── CTA STRIP ── */
.cta-strip {
  padding:96px 24px; background:var(--bx); color:#fff;
  text-align:center; position:relative; overflow:hidden;
  border-top:1px solid rgba(255,255,255,.06);
}
.cta-strip::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 80% 60% at 50% 50%,rgba(0,61,165,.4) 0%,transparent 60%);
}
.cta-strip>* { position:relative; z-index:1 }
.cta-strip h2 {
  font-size:clamp(1.7rem,3vw,2.3rem); font-weight:800;
  margin-bottom:14px; letter-spacing:-.03em; color:#fff;
}
.cta-strip p { font-size:17px; color:rgba(255,255,255,.65); max-width:580px; margin:0 auto 32px; line-height:1.65 }
.cta-btns { display:flex; flex-wrap:wrap; gap:12px; justify-content:center; align-items:center }
.cta-wa {
  display:inline-flex; align-items:center; gap:8px; background:var(--wa);
  color:#fff; font-weight:700; font-size:15px; padding:14px 28px;
  border-radius:var(--rd); text-decoration:none; transition:all .2s;
  box-shadow:0 4px 24px rgba(37,211,102,.3);
}
.cta-wa:hover { background:#1da851; transform:translateY(-2px) }
.cta-wa svg   { width:18px; height:18px; fill:#fff }
.cta-outline {
  display:inline-flex; align-items:center; gap:8px; background:transparent;
  color:#fff; border:1.5px solid rgba(255,255,255,.25); font-weight:600;
  font-size:14px; padding:13px 22px; border-radius:var(--rd); text-decoration:none; transition:all .2s;
}
.cta-outline:hover { background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.5) }
.cta-note { margin-top:20px; font-size:13px; color:rgba(255,255,255,.35); font-style:italic }

/* ── EXP SECTION (agents page) ── */
.exp-section {
  padding:96px 24px; background:#0a0a0a; position:relative; overflow:hidden;
  border-top:3px solid #dc1c2e;
}
.exp-section::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 80% 60% at 50% 30%,rgba(220,28,46,.1) 0%,transparent 60%);
}
.exp-section>* { position:relative; z-index:1 }
.exp-inner  { max-width:1100px; margin:0 auto }
.exp-head   { text-align:center; margin-bottom:48px }
.exp-kicker { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:2px; color:var(--r); margin-bottom:10px }
.exp-head h2{ font-size:clamp(1.7rem,3vw,2.4rem); font-weight:800; color:#fff; letter-spacing:-.03em; margin-bottom:12px }
.exp-head p { font-size:16px; color:rgba(255,255,255,.6); max-width:560px; margin:0 auto; line-height:1.65 }
.exp-grid   { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:16px; margin-bottom:40px }
.exp-card   {
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.1);
  border-radius:var(--rl); padding:24px; text-align:center; transition:all .2s;
}
.exp-card:hover { background:rgba(255,255,255,.08); transform:translateY(-2px) }
.exp-card .exp-ic  { font-size:2rem; margin-bottom:10px; display:block }
.exp-card h4 { font-size:1rem; font-weight:800; color:#fff; margin-bottom:6px }
.exp-card p  { font-size:13px; color:rgba(255,255,255,.55); line-height:1.55 }
.exp-ctas   { display:flex; flex-wrap:wrap; gap:12px; justify-content:center }
.exp-cta-main {
  display:inline-flex; align-items:center; gap:8px; background:var(--r);
  color:#fff; font-weight:700; font-size:15px; padding:14px 32px;
  border-radius:var(--rd); text-decoration:none; transition:all .2s;
  box-shadow:0 4px 20px rgba(220,28,46,.3);
}
.exp-cta-main:hover { background:var(--rh); transform:translateY(-2px) }
.exp-sponsor { text-align:center; margin-top:24px; font-size:13px; color:rgba(255,255,255,.4) }
.exp-sponsor strong { color:rgba(255,255,255,.7) }

/* ── PARTNER PERKS (lawyers / agents shared) ── */
.perks { padding:96px 24px; background:var(--g50) }
.perks-inner { max-width:1100px; margin:0 auto }
.perks-head  { text-align:center; margin-bottom:48px }
.perks-grid  { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:20px }
.perk-card   {
  background:var(--w); border-radius:var(--rl); padding:28px;
  border:1px solid var(--g200); box-shadow:var(--shadow); transition:all .25s; text-align:center;
}
.perk-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-3px) }
.perk-ic  { font-size:2.5rem; margin-bottom:14px; display:block }
.perk-card h3 { font-size:1rem; font-weight:800; color:var(--g900); margin-bottom:8px }
.perk-card p  { font-size:13px; color:var(--g500); line-height:1.6 }

/* ── WEBINAR SECTION ── */
.webinar {
  padding:80px 24px; background:linear-gradient(135deg,#0b1830 0%,#0d2050 100%);
  color:#fff; text-align:center; position:relative; overflow:hidden;
}
.webinar::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 60% 80% at 30% 50%,rgba(96,165,250,.1) 0%,transparent 60%);
}
.webinar>* { position:relative; z-index:1 }
.webinar h2 { font-size:clamp(1.5rem,2.5vw,2rem); font-weight:800; color:#fff; margin-bottom:12px; letter-spacing:-.02em }
.webinar p  { font-size:16px; color:rgba(255,255,255,.65); max-width:560px; margin:0 auto 28px; line-height:1.65 }
.webinar-topics { display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-bottom:28px }
.webinar-pill   {
  background:rgba(96,165,250,.15); border:1px solid rgba(96,165,250,.3);
  color:#93c5fd; font-size:13px; font-weight:600; padding:6px 16px; border-radius:100px;
}

/* ── STATS ROW ── */
.stats-row { padding:64px 24px; background:var(--w) }
.stats-inner { max-width:960px; margin:0 auto; display:flex; flex-wrap:wrap; gap:0; justify-content:center }
.stat-col { flex:1; min-width:160px; text-align:center; padding:20px 24px; position:relative }
.stat-col+.stat-col::before { content:''; position:absolute; left:0; top:20%; height:60%; width:1px; background:var(--g200) }
.stat-num  { font-size:2.8rem; font-weight:900; color:var(--b); letter-spacing:-.04em; line-height:1; display:block; margin-bottom:6px }
.stat-label{ font-size:14px; color:var(--g500); font-weight:500 }

/* ── FOOTER ── */
footer { background:var(--g900); color:var(--g400); padding:56px 24px 36px; font-size:14px }
.foot-inner {
  max-width:1200px; margin:0 auto;
  display:flex; flex-wrap:wrap; gap:40px; justify-content:space-between;
}
.foot-brand { flex:0 0 auto; max-width:280px }
.foot-logo-text { font-weight:800; color:#fff; font-size:17px; letter-spacing:-.01em; margin-bottom:4px }
.foot-logo-sub  { font-size:12px; color:var(--g500); margin-bottom:14px }
.foot-brand p   { font-size:13px; color:var(--g500); line-height:1.6 }
.foot-col h4  { font-size:13px; font-weight:700; color:rgba(255,255,255,.6); text-transform:uppercase; letter-spacing:1.5px; margin-bottom:16px }
.foot-links   { display:flex; flex-direction:column; gap:10px }
.foot-links a {
  color:var(--g400); text-decoration:none; transition:color .15s; font-size:14px; line-height:1.4;
}
.foot-links a:hover { color:#fff }
.foot-legal {
  width:100%; text-align:center; margin-top:16px; padding-top:20px;
  border-top:1px solid rgba(255,255,255,.06); font-size:12px; color:var(--g500);
}

/* ── FLOATING WHATSAPP ── */
.waf {
  position:fixed; bottom:24px; right:24px; z-index:999; width:60px; height:60px;
  border-radius:50%; background:var(--wa); display:flex; align-items:center; justify-content:center;
  box-shadow:0 8px 28px rgba(37,211,102,.45); transition:transform .2s,box-shadow .2s; text-decoration:none;
}
.waf:hover { transform:scale(1.08); box-shadow:0 12px 36px rgba(37,211,102,.6) }
.waf svg   { width:30px; height:30px; fill:#fff }

/* ── RESPONSIVE ── */
@media(max-width:900px) {
  .nav-wa span { display:none }
  .nav-wa { padding:9px 12px !important }
}
@media(max-width:768px) {
  nav { height:60px }
  .nav-inner { padding:0 16px; gap:6px }
  .nav-links { display:none }
  .hmb { display:block }
  /* The inline 6-flag language bar is too wide for mobile and pushes the
     hamburger + WhatsApp CTA off-screen. Hide it here; language switching
     lives in the hamburger overlay (#lngBarMob) on every page. */
  #lngBar { display:none }
  /* Comfortable touch targets (>=40px) for the nav controls and footer links. */
  .hmb    { padding:9px 11px }
  .nav-wa { padding:11px 13px !important; min-height:42px; box-sizing:border-box; justify-content:center }
  .foot-links   { gap:2px }
  .foot-links a { padding:8px 0 }
  /* The "verifiable company" block uses an INLINE 2-column grid that does not
     collapse on mobile — the text column shrank to 0px and stretched the office
     photo into a distorted vertical strip. Force a single column (!important
     beats the inline style) and give the photo a clean 3:2 box (its native ratio). */
  .trust-split { grid-template-columns:1fr !important }
  .trust-split > div:first-child { min-height:200px !important; aspect-ratio:3 / 2 }
  .hero { padding:90px 20px 56px; min-height:auto }
  .hero h1 { font-size:clamp(1.9rem,7vw,2.6rem) }
  .hero-sub { font-size:16px }
  .services,.dark-section,.tsm,.faq,.cta-strip,.perks,.exp-section,.webinar,.stats-row { padding:64px 20px }
  .srv-grid { grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:18px }
  .roles-split { grid-template-columns:1fr }
  .visa-banner-inner { flex-direction:column; padding:32px 24px; gap:24px }
  .steps-grid::before { display:none }
  .foot-inner { gap:28px }
}
@media(max-width:640px) {
  .srv-grid,.tsm-grid,.ds-grid,.income-grid { grid-template-columns:1fr }
  .steps-grid { grid-template-columns:1fr 1fr }
  .stat-col+.stat-col::before { display:none }
  .waf { bottom:18px; right:18px; width:54px; height:54px }
  .waf svg { width:26px; height:26px }
  .lng-btn { width:28px; height:28px; padding:2px }
  .lng-btn .fi { width:18px; height:13px }
  .lng-bar { gap:1px }
}
@media(max-width:480px) {
  .hero h1 { font-size:1.85rem }
  .section-h { font-size:1.5rem }
  .srv-card,.income-card { padding:22px }
  .steps-grid { grid-template-columns:1fr }
}
@media(hover:none) {
  .srv-card:active,.ds-card:active,.tsm-card:active,.income-card:active,
  .perk-card:active,.exp-card:active { transform:scale(.98); opacity:.92; transition:all .1s }
}
*:focus-visible { outline:2px solid var(--b); outline-offset:2px; border-radius:4px }
