/* ============================================================
   Vatlieuso — contractors.css (Thợ & Nhà thầu)
   ============================================================ */

/* Khối nội dung khu vực (trang /tho-thau/khu-vuc/{tỉnh}/) */
.vls-tha-region{background:#fff;border:1px solid #e8edf3;border-radius:16px;padding:24px;margin:8px 0 22px;box-shadow:0 10px 30px rgba(16,24,40,.05)}
.vls-tha-region>h2{font-size:1.35rem;margin:0 0 10px;color:#0f2a43}
.vls-tha-region>p{margin:0 0 14px;color:#475569;line-height:1.7;max-width:880px}
.vls-tha-region__notes{list-style:none;padding:0;margin:0 0 16px;display:grid;gap:9px}
.vls-tha-region__notes li{display:flex;gap:9px;align-items:flex-start;color:#334155;line-height:1.5}
.vls-tha-region__notes li>.vls-icon,.vls-tha-region__notes li>svg{color:#0E8F4A;flex:0 0 auto;margin-top:2px}
.vls-tha-region__cta{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}
.vls-tha-region__more{display:flex;flex-wrap:wrap;align-items:center;gap:8px 14px;padding-top:14px;border-top:1px dashed #e2e8f0;font-size:.9rem;color:#94a3b8}
.vls-tha-region__more a{color:#1e3a5f;font-weight:600;text-decoration:none}
.vls-tha-region__more a:hover{text-decoration:underline}
.vls-contractors { padding: var(--sp-6, 28px) 0 var(--sp-9, 72px); }

.vls-trade-filter { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: var(--sp-6, 28px); }
.vls-trade-filter a {
  padding: 7px 14px; border-radius: 999px;
  border: 1px solid var(--border, #E3E0D8); background: var(--bg-0, #fff);
  font-size: var(--fs-13); font-weight: 600; color: var(--fg-2);
  transition: border-color var(--dur-fast), background var(--dur-fast), color var(--dur-fast);
}
.vls-trade-filter a:hover { border-color: var(--accent, #1F5FBF); color: var(--accent, #1F5FBF); }
.vls-trade-filter a.is-active { background: var(--accent, #1F5FBF); border-color: var(--accent, #1F5FBF); color: #fff; }

.vls-contractors__grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--sp-4, 16px);
}

.vls-contractor-card {
  background: var(--bg-0, #fff); border: 1px solid var(--border, #E3E0D8);
  border-radius: var(--r-4, 16px); padding: var(--sp-5, 20px);
  display: flex; flex-direction: column; gap: var(--sp-4, 16px);
  transition: box-shadow var(--dur-fast), transform var(--dur-fast);
}
.vls-contractor-card:hover { box-shadow: var(--shadow-2, 0 8px 26px rgba(0,0,0,.08)); transform: translateY(-2px); }
.vls-contractor-card__head { display: flex; align-items: center; gap: 12px; }
.vls-contractor-card__avatar {
  position: relative;
  width: 72px; height: 72px; border-radius: 16px; flex-shrink: 0; overflow: visible;
  background: linear-gradient(135deg, #1F5FBF, #143A73); color: #fff;
  display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 24px;
}
.vls-contractor-card__avatar img,
.vls-contractor-card__avatar .vls-ava-ini { width: 100%; height: 100%; border-radius: 16px; object-fit: cover; }

/* Avatar fallback gradient + huy hiệu xác minh (dùng chung card + single) */
.vls-ava-ini { display: flex; align-items: center; justify-content: center; color: #fff; font-weight: 800; letter-spacing: .5px; }
.vls-ava-check { position: absolute; right: -3px; bottom: -3px; width: 19px; height: 19px; border-radius: 50%; background: #0E8F4A; color: #fff; display: flex; align-items: center; justify-content: center; border: 2px solid #fff; box-shadow: 0 1px 4px rgba(0,0,0,.25); }
.vls-ava-check--lg { width: 28px; height: 28px; right: -2px; bottom: -2px; border-width: 3px; }
.vls-contractor-card__id { flex: 1; min-width: 0; }
.vls-contractor-card__name { display: block; font-family: var(--font-display); font-size: var(--fs-16); font-weight: 700; color: var(--fg-1); }
.vls-contractor-card__trade { display: inline-flex; align-items: center; gap: 4px; font-size: var(--fs-12); color: var(--fg-3); }
.vls-contractor-card__badge {
  display: inline-flex; align-items: center; gap: 4px;
  background: rgba(14,143,74,.12); color: #0E8F4A;
  font-size: var(--fs-11); font-weight: 700; padding: 3px 8px; border-radius: 999px; white-space: nowrap;
}
.vls-contractor-card__stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; text-align: center; padding: var(--sp-3, 12px) 0; border-top: 1px solid var(--border, #F0EDE6); border-bottom: 1px solid var(--border, #F0EDE6); }
.vls-contractor-card__stats strong { display: block; font-size: var(--fs-15); color: var(--fg-1); }
.vls-contractor-card__stats span { font-size: var(--fs-11); color: var(--fg-3); }
.vls-contractor-card__price { font-size: var(--fs-13); color: var(--fg-2); }
.vls-contractor-card__price strong { color: var(--accent, #1F5FBF); }
.vls-contractor-card__actions { display: flex; gap: 8px; }
.vls-contractor-card__actions .vls-btn { flex: 1; justify-content: center; }

/* Single */
.vls-contractor-single { padding: var(--sp-6, 28px) 0 var(--sp-9, 72px); }
.vls-contractor-single__grid { display: grid; grid-template-columns: 1fr 320px; gap: var(--sp-6, 28px); align-items: start; }
.vls-contractor-single__main, .vls-contractor-contact {
  background: var(--bg-0, #fff); border: 1px solid var(--border, #E3E0D8);
  border-radius: var(--r-4, 16px); padding: var(--sp-6, 28px);
}
.vls-contractor-single__hero { display: flex; align-items: center; gap: 16px; margin-bottom: var(--sp-5, 20px); }
.vls-contractor-single__avatar {
  width: 72px; height: 72px; border-radius: 18px; flex-shrink: 0; overflow: hidden;
  background: linear-gradient(135deg, #1F5FBF, #143A73); color: #fff;
  display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 26px;
}
.vls-contractor-single__avatar img { width: 100%; height: 100%; object-fit: cover; }
.vls-contractor-single__hero h1 { font-family: var(--font-display); font-size: var(--fs-22, 24px); font-weight: 800; margin: 0 0 4px; color: var(--fg-1); display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.vls-contractor-single__trade { display: inline-flex; align-items: center; gap: 6px; color: var(--fg-3); font-size: var(--fs-14); }
.vls-contractor-single__stats { display: flex; gap: var(--sp-5, 20px); padding: var(--sp-4, 16px) 0; border-top: 1px solid var(--border, #F0EDE6); border-bottom: 1px solid var(--border, #F0EDE6); margin-bottom: var(--sp-5, 20px); }
.vls-contractor-single__stats strong { display: block; font-family: var(--font-display); font-size: 22px; color: var(--accent, #1F5FBF); }
.vls-contractor-single__stats span { font-size: var(--fs-12); color: var(--fg-3); }
.vls-contractor-single__desc { font-size: var(--fs-15); line-height: 1.7; color: var(--fg-2); }
.vls-contractor-contact { position: sticky; top: 90px; }
.vls-contractor-contact h3 { font-family: var(--font-display); font-size: var(--fs-17); margin: 0 0 var(--sp-4, 16px); color: var(--fg-1); }
.vls-contractor-contact .vls-btn { margin-bottom: 10px; }
.vls-contractor-contact__note { font-size: var(--fs-12); color: var(--fg-3); margin: 8px 0 0; line-height: 1.5; }

@media (max-width: 860px) {
  .vls-contractor-single__grid { grid-template-columns: 1fr; }
  .vls-contractor-contact { position: static; }
}

/* ════════════════════════════════════════════════════════════
   THỢ-THẦU — trang chi tiết nâng cấp
   ════════════════════════════════════════════════════════════ */
.vls-tho-hero{background:linear-gradient(120deg,#0f2a43 0%,#1e3a5f 60%,#2a4a6f 100%);color:#fff;padding:18px 0 28px}
.vls-tho-hero__bc{font-size:.82rem;opacity:.8;margin-bottom:18px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.vls-tho-hero__bc a{color:#fff;opacity:.85;text-decoration:none}
.vls-tho-hero__bc a:hover{opacity:1;text-decoration:underline}
.vls-tho-hero__row{display:flex;gap:20px;align-items:center}
.vls-tho-hero__avatar{position:relative;flex:0 0 116px;width:116px;height:116px;border-radius:22px;background:rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;font-size:2.4rem;font-weight:800;box-shadow:0 0 0 3px rgba(255,255,255,.22),0 10px 26px rgba(0,0,0,.28)}
.vls-tho-hero__avatar img,.vls-tho-hero__avatar .vls-ava-ini{width:100%;height:100%;object-fit:cover;border-radius:22px}
.vls-tho-hero__avatar .vls-ava-ini{font-size:2.4rem}
.vls-tho-hero__badges{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}
.vls-tho-chip{display:inline-flex;align-items:center;gap:5px;font-size:.74rem;font-weight:700;padding:4px 11px;border-radius:30px;background:rgba(255,255,255,.15)}
.vls-tho-chip--verified{background:#16a34a;color:#fff}
.vls-tho-chip--featured{background:var(--vls-gold,#e3a008);color:#1a1a1a}
.vls-tho-hero__name{font-size:1.9rem;line-height:1.15;margin:0 0 8px;color:#fff}
.vls-tho-hero__sub{display:flex;gap:16px;flex-wrap:wrap;align-items:center;font-size:.92rem;opacity:.92}
.vls-tho-hero__sub span{display:inline-flex;align-items:center;gap:5px}
.vls-tho-hero__rate b{color:var(--vls-gold,#fbbf24)}
.vls-tho-hero__rate--new{opacity:.7;font-style:italic}

.vls-tho-body{background:#f6f8fb;padding:28px 0 40px}
.vls-tho-grid{display:grid;grid-template-columns:1fr 320px;gap:24px;align-items:start}
.vls-tho-main{min-width:0}
.vls-tho-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin-bottom:20px}
.vls-tho-stat{background:#fff;border:1px solid #e8edf3;border-radius:14px;padding:16px;text-align:center}
.vls-tho-stat__n{display:block;font-size:1.5rem;font-weight:800;color:#0f2a43;line-height:1}
.vls-tho-stat__n--price{font-size:1.1rem;color:#15803d}
.vls-tho-stat__l{display:block;font-size:.78rem;color:#64748b;margin-top:5px}
.vls-tho-section{background:#fff;border:1px solid #e8edf3;border-radius:16px;padding:20px 22px;margin-bottom:18px}
.vls-tho-h2{display:flex;align-items:center;gap:8px;font-size:1.15rem;margin:0 0 14px;color:#0f2a43}
.vls-tho-desc{line-height:1.7;color:#334155}
.vls-tho-folio{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.vls-tho-folio__item{display:block;aspect-ratio:4/3;border-radius:12px;overflow:hidden;border:1px solid #e8edf3}
.vls-tho-folio__item img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.vls-tho-folio__item:hover img{transform:scale(1.06)}
.vls-tho-certs{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.vls-tho-certs li{display:flex;align-items:flex-start;gap:8px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:10px;padding:9px 12px;font-size:.92rem;color:#14532d}
.vls-tho-certs li svg{color:#16a34a;flex:0 0 auto;margin-top:2px}

.vls-tho-side{position:sticky;top:88px}
.vls-tho-contact{background:#fff;border:1px solid #e8edf3;border-radius:16px;padding:20px}
.vls-tho-contact h3{margin:0 0 14px;font-size:1.05rem;color:#0f2a43}
.vls-tho-contact .vls-btn{margin-bottom:10px}
.vls-tho-contact__trust{display:flex;gap:8px;margin-top:6px;padding-top:14px;border-top:1px dashed #e2e8f0}
.vls-tho-contact__trust svg{color:#16a34a;flex:0 0 auto}
.vls-tho-contact__trust p{font-size:.8rem;color:#64748b;margin:0;line-height:1.5}
.vls-tho-contact__facts{list-style:none;padding:14px 0 0;margin:14px 0 0;border-top:1px dashed #e2e8f0;display:grid;gap:10px}
.vls-tho-contact__facts li{display:flex;align-items:flex-start;gap:8px;font-size:.84rem;color:#475569;line-height:1.45}
.vls-tho-contact__facts li>.vls-icon,.vls-tho-contact__facts li>svg{color:#1e3a5f;flex:0 0 auto;margin-top:1px}
.vls-btn--zalo{background:#0068ff;color:#fff;border:1px solid #0068ff}
.vls-btn--zalo:hover{background:#0052cc;border-color:#0052cc;color:#fff}

@media(max-width:880px){.vls-tho-grid{grid-template-columns:1fr}.vls-tho-side{position:static}.vls-tho-hero__name{font-size:1.5rem}.vls-tho-hero__row{flex-direction:column;text-align:center;align-items:center}.vls-tho-hero__sub,.vls-tho-hero__badges{justify-content:center}}

/* Card thợ-thầu: rating + nổi bật */
.vls-contractor-card{position:relative}
.vls-contractor-card--featured{border-color:var(--vls-gold,#e3a008);box-shadow:0 0 0 1px var(--vls-gold,#e3a008)}
.vls-contractor-card__feat{position:absolute;top:10px;right:10px;display:inline-flex;align-items:center;gap:4px;background:var(--vls-gold,#e3a008);color:#1a1a1a;font-size:.68rem;font-weight:800;padding:3px 9px;border-radius:20px;z-index:1}
.vls-contractor-card__rate{display:flex;align-items:center;gap:5px;font-size:.78rem;color:#64748b;margin-top:3px}
.vls-contractor-card__rate b{color:#0f2a43}

/* ── Archive thợ-thầu: stats, toolbar, giá nhân công, how-it-works ── */
.vls-tho-statsband{display:flex;gap:24px;align-items:center;flex-wrap:wrap;margin-top:16px;padding-top:16px;border-top:1px solid rgba(255,255,255,.15)}
.vls-tho-statsband>div{display:flex;flex-direction:column}
.vls-tho-statsband b{font-size:1.5rem;font-weight:800;line-height:1}
.vls-tho-statsband span{font-size:.8rem;opacity:.8}
.vls-tho-statsband .vls-btn{margin-left:auto}
.vls-tho-toolbar{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap;background:#fff;border:1px solid #e8edf3;border-radius:12px;padding:12px 14px;margin-bottom:18px}
.vls-tho-toolbar .vls-field{display:flex;flex-direction:column;gap:4px;min-width:170px}
.vls-tho-toolbar .vls-field span{font-size:.78rem;color:#64748b}
.vls-tho-toolbar input,.vls-tho-toolbar select{padding:8px 10px;border:1px solid #e2e8f0;border-radius:8px}
.vls-tho-toolbar__count{margin-left:auto;font-size:.88rem;color:#64748b;align-self:center}
.vls-tho-toolbar__count b{color:#0f2a43}
.vls-labor-ref{margin:34px 0 8px}
.vls-labor-ref__head h2{display:flex;align-items:center;gap:8px;font-size:1.2rem;color:#0f2a43;margin:0 0 4px}
.vls-labor-ref__head p{color:#64748b;font-size:.9rem;margin:0 0 14px;max-width:760px}
.vls-labor-ref__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:10px}
.vls-labor-card{display:flex;flex-direction:column;gap:3px;background:#fff;border:1px solid #e8edf3;border-radius:12px;padding:13px 15px;text-decoration:none;transition:.18s}
.vls-labor-card:hover{border-color:var(--vls-gold,#e3a008);box-shadow:0 4px 14px rgba(15,42,67,.08);transform:translateY(-2px)}
.vls-labor-card__trade{font-size:.82rem;color:#64748b}
.vls-labor-card__price{font-size:1.15rem;font-weight:800;color:#15803d}
.vls-labor-card__price small{font-size:.62em;font-weight:600;color:#94a3b8}
.vls-labor-card__note{font-size:.72rem;color:#94a3b8}
.vls-tho-how{margin:34px 0 10px}
.vls-tho-how h2{font-size:1.2rem;color:#0f2a43;margin:0 0 16px;text-align:center}
.vls-tho-how__steps{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.vls-tho-how__steps>div{background:#fff;border:1px solid #e8edf3;border-radius:14px;padding:18px;text-align:center}
.vls-tho-how__n{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:#0f2a43;color:#fff;font-weight:800;margin-bottom:8px}
.vls-tho-how__steps b{display:block;margin-bottom:4px;color:#0f2a43}
.vls-tho-how__steps p{font-size:.85rem;color:#64748b;margin:0}
@media(max-width:720px){.vls-tho-how__steps{grid-template-columns:1fr}.vls-tho-toolbar__count{margin-left:0;width:100%}}

/* ════════ THỢ-THẦU ARCHIVE — thiết kế nâng cấp + bản đồ ════════ */
.vls-tha-hero{background:linear-gradient(125deg,#0f2a43 0%,#1e3a5f 55%,#2a4a6f 100%);color:#fff;padding:20px 0 30px}
.vls-tha-bc{font-size:.82rem;opacity:.82;display:flex;gap:8px;align-items:center;margin-bottom:18px}
.vls-tha-bc a{color:#fff;opacity:.85;text-decoration:none}.vls-tha-bc a:hover{opacity:1}
.vls-tha-hero__grid{display:grid;grid-template-columns:minmax(0,1fr) 380px;gap:36px;align-items:center}
.vls-tha-kicker{display:inline-flex;align-items:center;gap:6px;font-size:.76rem;font-weight:700;background:rgba(255,255,255,.14);padding:5px 12px;border-radius:30px;margin-bottom:12px}
.vls-tha-hero__copy h1{font-size:2rem;line-height:1.15;margin:0 0 10px;color:#fff}
.vls-tha-hero__copy p{opacity:.9;line-height:1.6;max-width:620px;margin:0 0 18px}
.vls-tha-actions{display:flex;gap:10px;flex-wrap:wrap}
.vls-tha-btn{display:inline-flex;align-items:center;gap:7px;font-weight:700;font-size:.9rem;padding:11px 18px;border-radius:10px;text-decoration:none;border:1px solid transparent;transition:.18s}
.vls-tha-btn--primary{background:var(--vls-gold,#e3a008);color:#1a1a1a}.vls-tha-btn--primary:hover{filter:brightness(1.06)}
.vls-tha-btn--ghost{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.3)}.vls-tha-btn--ghost:hover{background:rgba(255,255,255,.18)}
.vls-tha-metrics{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.vls-tha-metrics>div{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);border-radius:12px;padding:14px 16px}
.vls-tha-metrics span{display:block;font-size:.76rem;opacity:.82}
.vls-tha-metrics strong{font-size:1.5rem;font-weight:800}

.vls-tha{background:#f6f8fb;padding:24px 0 44px}
.vls-tha-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.vls-tha-chips a{font-size:.84rem;font-weight:600;padding:7px 14px;border-radius:30px;background:#fff;border:1px solid #e4e9f0;color:#334155;text-decoration:none;transition:.15s}
.vls-tha-chips a:hover{border-color:#cbd5e1}
.vls-tha-chips a.is-active{background:#0f2a43;color:#fff;border-color:#0f2a43}
.vls-tha-filter{display:flex;gap:12px;align-items:stretch;flex-wrap:wrap;background:#fff;border:1px solid #e4e9f0;border-radius:12px;padding:12px;margin-bottom:16px;box-shadow:0 10px 30px rgba(16,24,40,.06)}
.vls-tha-filter__field{display:flex;align-items:center;gap:8px;flex:1;min-width:220px;border:1px solid #e2e8f0;border-radius:9px;padding:0 12px;color:#94a3b8}
.vls-tha-filter__field input{border:0;outline:0;padding:11px 0;width:100%;color:#0f172a}
.vls-tha-filter__field select{border:0;outline:0;padding:11px 0;width:100%;min-width:0;color:#0f172a;background:transparent;cursor:pointer}
.vls-tha-filter > select{border:1px solid #e2e8f0;border-radius:9px;padding:0 12px;min-width:190px;color:#0f172a;background:#fff}
.vls-tha-filter button{display:inline-flex;align-items:center;gap:7px;background:#0f2a43;color:#fff;border:0;border-radius:9px;padding:11px 18px;font-weight:700;cursor:pointer}
.vls-tha-filter button:hover{background:#16395c}

.vls-tha-map-wrap{background:#fff;border:1px solid #e4e9f0;border-radius:14px;overflow:hidden;margin-bottom:18px;box-shadow:0 10px 30px rgba(16,24,40,.06)}
.vls-tha-map-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;border-bottom:1px solid #eef2f7}
.vls-tha-map-title{display:inline-flex;align-items:center;gap:7px;font-weight:700;color:#0f2a43}
.vls-tha-map-hint{font-size:.78rem;color:#94a3b8}
.vls-tha-map{height:380px;width:100%}
.vls-map-pop strong{display:block}.vls-map-pop span{display:block;font-size:.82em;color:#64748b;margin:2px 0 4px}.vls-map-pop a{font-size:.82em;font-weight:700;color:#1d4ed8;text-decoration:none}

.vls-tha-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;font-size:.9rem;color:#475569}
.vls-tha-toolbar strong{color:#0f2a43}
.vls-tha-toolbar a{display:inline-flex;align-items:center;gap:5px;color:#64748b;text-decoration:none;font-size:.85rem}
.vls-tha-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.vls-tha-empty{text-align:center;background:#fff;border:1px dashed #d8dee8;border-radius:16px;padding:44px 20px;color:#64748b}
.vls-tha-empty h2{color:#0f2a43;font-size:1.15rem;margin:10px 0 4px}
.vls-tha-cta{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:24px;margin-top:30px;padding:26px;border:1px solid #e4e9f0;border-left:5px solid var(--vls-gold,#e3a008);border-radius:14px;background:linear-gradient(90deg,#fff,#fffaf0)}
.vls-tha-cta span{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;font-weight:700;color:#92702a}
.vls-tha-cta h2{font-size:1.2rem;color:#0f2a43;margin:6px 0 4px}
.vls-tha-cta p{color:#64748b;margin:0;max-width:620px}

@media(max-width:880px){
  .vls-tha-hero__grid{grid-template-columns:1fr;gap:22px}
  .vls-tha-hero__copy h1{font-size:1.5rem}
  .vls-tha-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .vls-tha-cta{grid-template-columns:1fr}
}
@media(max-width:560px){.vls-tha-grid{grid-template-columns:1fr}.vls-tha-metrics{grid-template-columns:1fr 1fr}}

/* ════════════════════════════════════════════════════════════
   Bảng giá nhân công theo nghề (table + tabs)
   ════════════════════════════════════════════════════════════ */
.vls-rate{background:#fff;border:1px solid #e8edf3;border-radius:18px;padding:24px;margin:8px 0 22px;box-shadow:0 10px 30px rgba(16,24,40,.05)}
.vls-rate__kicker{display:inline-flex;align-items:center;gap:6px;font-size:.74rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#B45309;background:#fdf3e0;padding:5px 11px;border-radius:999px}
.vls-rate__head h2{font-size:1.5rem;margin:12px 0 6px;color:#0f2a43}
.vls-rate__head p{margin:0;color:#64748b;max-width:680px;line-height:1.55}
.vls-rate__tabs{display:flex;flex-wrap:wrap;gap:8px;margin:18px 0 14px}
.vls-rate__tab{border:1px solid #e2e8f0;background:#f8fafc;color:#334155;font-weight:700;font-size:.86rem;padding:8px 16px;border-radius:999px;cursor:pointer;transition:all .15s}
.vls-rate__tab:hover{border-color:#cbd5e1;background:#fff}
.vls-rate__tab.is-active{background:var(--vls-gold,#e3a008);border-color:var(--vls-gold,#e3a008);color:#1a1a1a}
.vls-rate__tablewrap{overflow-x:auto;border:1px solid #eef2f7;border-radius:14px}
.vls-rate__table{width:100%;border-collapse:collapse;min-width:560px}
.vls-rate__table thead th{text-align:left;font-size:.72rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:#94a3b8;padding:14px 18px;background:#f8fafc;border-bottom:1px solid #eef2f7}
.vls-rate__table tbody tr{border-bottom:1px solid #f1f5f9}
.vls-rate__table tbody tr:last-child{border-bottom:0}
.vls-rate__table tbody tr:nth-child(even){background:#fcfdfe}
.vls-rate__table td{padding:14px 18px;vertical-align:middle}
.vls-rate__job b{display:block;color:#0f2a43;font-size:.98rem}
.vls-rate__job span{display:block;color:#94a3b8;font-size:.8rem;margin-top:2px}
.vls-rate__unit{color:#475569;font-size:.9rem;white-space:nowrap}
.vls-rate__num{text-align:right;font-weight:800;color:#B45309;white-space:nowrap;font-variant-numeric:tabular-nums}
.vls-rate__num--high{color:#0f2a43}
.vls-rate__note{display:flex;align-items:center;gap:7px;margin:14px 0 0;font-size:.82rem;color:#94a3b8}

/* ════════════════════════════════════════════════════════════
   Đặt dịch vụ tìm thợ + Đăng ký làm thợ (forms)
   ════════════════════════════════════════════════════════════ */
.vls-svc,.vls-reg{margin:22px 0;scroll-margin-top:80px}
.vls-svc__kicker,.vls-reg__kicker{display:inline-flex;align-items:center;gap:6px;font-size:.74rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#0f2a43;background:#eef3f9;padding:5px 11px;border-radius:999px}
.vls-svc__head,.vls-reg__head{text-align:center;max-width:720px;margin:0 auto 20px}
.vls-svc__head h2,.vls-reg__head h2{font-size:1.6rem;margin:12px 0 8px;color:#0f2a43}
.vls-svc__head p,.vls-reg__head p{margin:0;color:#64748b;line-height:1.6}
.vls-svc__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:20px;align-items:start}
.vls-svc__why{background:linear-gradient(150deg,#0f2a43,#1e3a5f);color:#fff;border-radius:18px;padding:24px}
.vls-svc__why h3{margin:0 0 14px;font-size:1.1rem;color:#fff}
.vls-svc__why ul{list-style:none;padding:0;margin:0 0 18px;display:grid;gap:11px}
.vls-svc__why li{display:flex;gap:9px;align-items:flex-start;font-size:.92rem;line-height:1.45;color:rgba(255,255,255,.92)}
.vls-svc__why li>.vls-icon,.vls-svc__why li>svg{color:#fbbf24;flex:0 0 auto;margin-top:1px}
.vls-svc__alt{display:flex;gap:10px;align-items:flex-start;padding-top:16px;border-top:1px solid rgba(255,255,255,.16)}
.vls-svc__alt>.vls-icon,.vls-svc__alt>svg{color:#fbbf24;flex:0 0 auto;margin-top:2px}
.vls-svc__alt b{color:#fff;font-size:.92rem}
.vls-svc__alt p{margin:2px 0 0;font-size:.84rem;color:rgba(255,255,255,.72);line-height:1.4}

.vls-svc-form{background:#fff;border:1px solid #e8edf3;border-radius:18px;padding:22px;box-shadow:0 10px 30px rgba(16,24,40,.05)}
.vls-svc-form__head{display:flex;align-items:center;gap:8px;font-size:1.05rem;color:#0f2a43;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid #eef2f7}
.vls-svc-form__head>.vls-icon,.vls-svc-form__head>svg{color:#e3a008}
.vls-svc-form__grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.vls-svc-form__msg{padding:11px 14px;border-radius:10px;font-size:.88rem;font-weight:600;margin-bottom:14px}
.vls-svc-form__msg.is-ok{background:#ecfdf3;color:#15803d;border:1px solid #bbf7d0}
.vls-svc-form__msg.is-err{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}
.vls-svc-form__foot{display:flex;align-items:center;gap:7px;margin:14px 0 0;font-size:.8rem;color:#94a3b8;line-height:1.4}
.vls-svc-form .vls-tha-btn{margin-top:18px;width:100%;justify-content:center}

.vls-fld{display:flex;flex-direction:column;gap:6px}
.vls-fld--full{grid-column:1/-1}
.vls-fld>span{font-size:.85rem;font-weight:600;color:#334155}
.vls-fld input,.vls-fld select,.vls-fld textarea{border:1px solid #e2e8f0;border-radius:10px;padding:11px 13px;font-size:.92rem;color:#0f172a;font-family:inherit;background:#fff;width:100%}
.vls-fld input:focus,.vls-fld select:focus,.vls-fld textarea:focus{outline:0;border-color:#0f2a43;box-shadow:0 0 0 3px rgba(15,42,67,.1)}
.vls-fld textarea{resize:vertical;min-height:74px}
.vls-fld--check{flex-direction:row;align-items:flex-start;gap:9px}
.vls-fld--check input{width:auto;margin-top:3px;flex:0 0 auto}
.vls-fld--check span{font-size:.85rem;color:#64748b;font-weight:400;line-height:1.45}

.vls-reg__plans{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:0 0 22px}
.vls-reg-plan{position:relative;background:#fff;border:1px solid #e8edf3;border-radius:14px;padding:18px 18px 18px;text-align:center;cursor:pointer;transition:border-color .15s,box-shadow .15s,background .15s}
.vls-reg-plan:hover{border-color:#cbd5e1}
.vls-reg-plan input[type=radio]{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.vls-reg-plan__tag{position:absolute;top:-10px;left:50%;transform:translateX(-50%);background:var(--vls-gold,#e3a008);color:#1a1a1a;font-size:.66rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;padding:3px 10px;border-radius:999px;white-space:nowrap}
.vls-reg-plan__name{display:block;font-weight:800;color:#0f2a43;font-size:1rem}
.vls-reg-plan__price{display:block;font-size:1.35rem;font-weight:800;color:#B45309;margin:6px 0}
.vls-reg-plan__price small{font-size:.7rem;color:#94a3b8;font-weight:600}
.vls-reg-plan__d{display:block;font-size:.82rem;color:#64748b;line-height:1.45}
.vls-reg-plan__check{position:absolute;top:12px;right:12px;width:22px;height:22px;border-radius:50%;border:2px solid #cbd5e1;background:#fff;display:flex;align-items:center;justify-content:center;transition:all .15s}
.vls-reg-plan__check>.vls-icon,.vls-reg-plan__check>svg{opacity:0;color:#1a1a1a}
.vls-reg-plan.is-selected{border-color:var(--vls-gold,#e3a008);box-shadow:0 0 0 1px var(--vls-gold,#e3a008),0 10px 26px rgba(227,160,8,.16);background:#fffdf6}
.vls-reg-plan.is-selected .vls-reg-plan__check{background:var(--vls-gold,#e3a008);border-color:var(--vls-gold,#e3a008)}
.vls-reg-plan.is-selected .vls-reg-plan__check>.vls-icon,.vls-reg-plan.is-selected .vls-reg-plan__check>svg{opacity:1}
.vls-reg-form{margin:0}

/* Panel thanh toán phí gói */
.vls-reg-pay{margin:18px 0 0;border:1px dashed #e2c98a;background:#fffdf6;border-radius:14px;padding:16px}
.vls-reg-pay__head{display:flex;align-items:center;gap:8px;font-size:1rem;color:#0f2a43;margin-bottom:12px}
.vls-reg-pay__head>.vls-icon,.vls-reg-pay__head>svg{color:#e3a008}
.vls-reg-pay__amount{margin-left:auto;font-weight:800;color:#B45309}
.vls-reg-pay__hint{display:flex;align-items:flex-start;gap:7px;margin:12px 0 0;font-size:.82rem;color:#94a3b8;line-height:1.45}
.vls-reg-pay__hint>.vls-icon,.vls-reg-pay__hint>svg{flex:0 0 auto;margin-top:1px}
.vls-reg-pay .vls-platform-paybox{background:#fff;border:1px solid #eef0e4;border-radius:10px;padding:14px}
.vls-reg-pay .vls-dep__head{display:flex;align-items:center;gap:7px;font-weight:700;color:#0f2a43;margin-bottom:10px}
.vls-reg-pay .vls-dep__bank{display:flex;gap:14px;align-items:flex-start;flex-wrap:wrap}
.vls-reg-pay .vls-dep__bank img{border:1px solid #eef0e4;border-radius:8px;background:#fff}
.vls-reg-pay .vls-dep__bankinfo{font-size:.9rem;color:#334155;line-height:1.7;min-width:210px}
.vls-reg-pay .vls-dep__bankinfo b{color:#0f2a43}
.vls-reg-pay .vls-account__muted{font-size:.84rem;color:#94a3b8;line-height:1.5}

@media(max-width:860px){
  .vls-svc__grid{grid-template-columns:1fr}
  .vls-reg__plans{grid-template-columns:1fr}
}
@media(max-width:560px){
  .vls-svc-form__grid{grid-template-columns:1fr}
  .vls-rate,.vls-svc-form{padding:18px}
}
