* { box-sizing: border-box; }
body { margin: 0; font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; color: #0f172a; background: #f8fafc; line-height: 1.7; }
a { text-decoration: none; color: inherit; }
.container { max-width: 1180px; margin: 0 auto; padding: 0 18px; }
.hero { position: relative; overflow: hidden; background: linear-gradient(135deg, #0f172a, #1e40af); color: #fff; padding: 74px 0 78px; }
.hero::after { content: ""; position: absolute; right: -120px; top: -160px; width: 420px; height: 420px; border-radius: 999px; background: rgba(255,255,255,.08); }
.hero .container { position: relative; z-index: 1; }
.hero h1 { max-width: 860px; font-size: 46px; line-height: 1.18; margin: 10px 0 16px; letter-spacing: -1px; }
.hero p { max-width: 780px; margin: 0; color: #dbeafe; font-size: 17px; }
.hero-home { color: #bfdbfe; font-weight: 700; }
.eyebrow { display: inline-flex; align-items: center; color: #facc15; font-size: 13px; font-weight: 900; letter-spacing: .12em; text-transform: uppercase; }
.hero-stats { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 28px; }
.hero-stats span { display: inline-flex; align-items: center; gap: 6px; padding: 10px 14px; border: 1px solid rgba(255,255,255,.18); border-radius: 999px; background: rgba(255,255,255,.08); color: #e0f2fe; }
.hero-stats strong { color: #fff; font-size: 22px; line-height: 1; }
.grid { display: grid; gap: 16px; }
.directory-section { padding: 46px 0 56px; }
.section-head { max-width: 760px; margin-bottom: 24px; }
.section-head h2 { margin: 8px 0 8px; font-size: 32px; line-height: 1.25; }
.section-head p { margin: 0; color: #64748b; }
.company-list { display: grid; gap: 26px; }
.company-block { overflow: hidden; background: #fff; border: 1px solid #e2e8f0; border-radius: 20px; box-shadow: 0 18px 45px rgba(15, 23, 42, .06); }
.company-head { display: flex; justify-content: space-between; gap: 20px; padding: 26px 28px; background: linear-gradient(135deg, #f8fafc, #eff6ff); border-bottom: 1px solid #e2e8f0; }
.company-head h3 { margin: 6px 0 6px; font-size: 26px; line-height: 1.25; }
.company-head p { margin: 0; color: #475569; }
.company-tag { display: inline-flex; padding: 4px 10px; border-radius: 999px; background: #dbeafe; color: #1e40af; font-size: 12px; font-weight: 900; }
.company-count { min-width: 96px; height: 96px; display: inline-flex; flex-direction: column; align-items: center; justify-content: center; border-radius: 18px; background: #1e40af; color: #dbeafe; text-align: center; }
.company-count strong { color: #fff; font-size: 34px; line-height: 1; }
.company-count span { font-size: 13px; }
.company-summary { margin: 0; padding: 20px 28px 0; color: #475569; }
.city-grid { grid-template-columns: repeat(5, 1fr); padding: 24px 28px 28px; }
.card { background: #fff; border: 1px solid #e2e8f0; border-radius: 14px; padding: 18px; transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.card:hover { transform: translateY(-2px); border-color: #bfdbfe; box-shadow: 0 12px 28px rgba(30, 64, 175, .10); }
.selected-city-card { margin: 42px 0; }
.card h2, .card h3, .card h4 { margin: 0 0 8px; font-size: 18px; }
.muted { color: #64748b; }
.btn { display: inline-flex; margin-top: 14px; background: #1e40af; color: #fff; padding: 9px 15px; border-radius: 8px; font-weight: 800; box-shadow: 0 8px 18px rgba(30, 64, 175, .18); }
.footer { background: #020617; color: #94a3b8; padding: 28px 0; }

@media (max-width: 860px) {
  .hero { padding: 52px 0; }
  .hero h1 { font-size: 34px; }
  .section-head h2 { font-size: 26px; }
  .company-head { display: block; padding: 22px; }
  .company-count { margin-top: 16px; width: 92px; height: 82px; }
  .company-summary { padding: 18px 22px 0; }
  .city-grid { grid-template-columns: 1fr; padding: 22px; }
}
