/* ============================================
   AboutNearMe - Business Directory Styles
   assets/css/directory.css
   ============================================ */

:root {
  --green:       #1D9E75;
  --green-dark:  #157a5a;
  --green-light: #f0fdf4;
  --orange:      #f59e0b;
  --blue:        #3b82f6;
  --text:        #111827;
  --text-muted:  #6b7280;
  --border:      #e5e7eb;
  --bg-gray:     #f9fafb;
  --white:       #ffffff;
  --shadow-sm:   0 1px 3px rgba(0,0,0,0.08);
  --shadow-md:   0 4px 16px rgba(0,0,0,0.10);
  --shadow-lg:   0 8px 32px rgba(0,0,0,0.12);
  --radius:      12px;
  --radius-sm:   8px;
}

/* ── Top Bar ─────────────────────────────── */
.top-bar {
  background: #111827;
  color: #9ca3af;
  font-size: 12px;
  padding: 6px 0;
}
.top-bar-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.top-bar-left { display:flex; gap:16px; }
.top-bar-left span { display:flex; align-items:center; gap:4px; }
.top-bar-right { display:flex; align-items:center; gap:12px; }
.top-bar-right a { color:#9ca3af; text-decoration:none; display:flex; align-items:center; gap:4px; transition:color .2s; }
.top-bar-right a:hover { color:#fff; }
.top-bar-cta {
  background: var(--green) !important;
  color: #fff !important;
  padding: 4px 12px;
  border-radius: 20px;
  font-weight: 600;
}
.top-bar-cta:hover { background: var(--green-dark) !important; }

/* ── Header Overrides ────────────────────── */
.nav-dropdown { position:relative; }
.nav-dropdown-btn {
  background:none; border:none; cursor:pointer;
  font-size:14px; font-weight:500; color:var(--text);
  display:flex; align-items:center; gap:4px; padding:6px 8px;
  border-radius:var(--radius-sm);
}
.nav-dropdown-btn:hover { background:var(--bg-gray); }
.nav-dropdown-menu {
  display:none; position:absolute; top:calc(100% + 8px); left:0;
  background:#fff; border:1px solid var(--border); border-radius:var(--radius);
  box-shadow:var(--shadow-lg); min-width:220px; z-index:100; padding:8px;
}
.nav-dropdown:hover .nav-dropdown-menu { display:block; }
.nav-dropdown-menu a {
  display:flex; align-items:center; gap:10px; padding:8px 12px;
  border-radius:var(--radius-sm); text-decoration:none; color:var(--text);
  font-size:13px; transition:background .15s;
}
.nav-dropdown-menu a:hover { background:var(--bg-gray); }
.nav-dropdown-menu a i { font-size:16px; width:20px; text-align:center; }
.view-all-cats { color:var(--green) !important; font-weight:600; border-top:1px solid var(--border); margin-top:4px; padding-top:10px !important; }
.nav-cta-btn {
  background:var(--green); color:#fff !important; padding:7px 16px;
  border-radius:20px; font-weight:600; font-size:13px;
  display:flex; align-items:center; gap:6px; text-decoration:none;
  transition:background .2s;
}
.nav-cta-btn:hover { background:var(--green-dark); }

/* ── Hero ────────────────────────────────── */
.dir-hero {
  background: linear-gradient(135deg, #0f1724 0%, #1a2e1e 50%, #0f1724 100%);
  padding: 64px 0 56px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.dir-hero::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 50% 0%, rgba(29,158,117,0.25) 0%, transparent 70%);
}
.dir-hero .container { position:relative; z-index:1; }
.hero-text h1 { font-size:clamp(28px,5vw,52px); font-weight:800; color:#fff; margin:0 0 12px; line-height:1.15; }
.hero-text p  { font-size:17px; color:rgba(255,255,255,0.7); margin:0 0 32px; }
.text-green   { color:var(--green); }

/* Search box */
.dir-search-box {
  background:#fff;
  border-radius: 50px;
  box-shadow: 0 8px 40px rgba(0,0,0,0.3);
  max-width: 780px;
  margin: 0 auto 20px;
  overflow: hidden;
}
.dir-search-inner { display:flex; align-items:center; height:58px; }
.dir-search-field {
  flex:1; display:flex; align-items:center; gap:10px;
  padding:0 20px;
}
.dir-search-field i { color:var(--text-muted); font-size:18px; flex-shrink:0; }
.dir-search-field input {
  flex:1; border:none; outline:none; font-size:15px;
  color:var(--text); background:transparent;
}
.dir-search-field input::placeholder { color:#9ca3af; }
.dir-search-divider { width:1px; height:32px; background:var(--border); flex-shrink:0; }
.dir-search-btn {
  background:var(--green); color:#fff; border:none; cursor:pointer;
  height:58px; padding:0 28px; font-size:15px; font-weight:600;
  display:flex; align-items:center; gap:8px; flex-shrink:0;
  transition:background .2s;
}
.dir-search-btn:hover { background:var(--green-dark); }

/* Popular tags */
.hero-popular {
  display:flex; align-items:center; gap:10px; justify-content:center;
  flex-wrap:wrap; margin-bottom:32px;
}
.hero-popular span { color:rgba(255,255,255,0.5); font-size:13px; }
.hero-popular a {
  background:rgba(255,255,255,0.1); color:rgba(255,255,255,0.85);
  padding:5px 14px; border-radius:20px; font-size:13px;
  text-decoration:none; transition:all .2s; border:1px solid rgba(255,255,255,0.15);
}
.hero-popular a:hover { background:var(--green); color:#fff; border-color:var(--green); }

/* Stats bar */
.hero-stats {
  display:inline-flex; align-items:center; gap:0;
  background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.12);
  border-radius:50px; padding:12px 32px; gap:24px;
}
.hero-stat { text-align:center; }
.hero-stat strong { display:block; font-size:20px; font-weight:700; color:#fff; }
.hero-stat span   { font-size:12px; color:rgba(255,255,255,0.5); }
.hero-stat-divider { width:1px; height:32px; background:rgba(255,255,255,0.15); }

/* ── Sections ────────────────────────────── */
.dir-section      { padding:56px 0; }
.dir-section-gray { background:var(--bg-gray); }
.section-head     { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:28px; }
.section-head h2  { font-size:24px; font-weight:700; margin:0 0 4px; }
.section-head p   { color:var(--text-muted); margin:0; font-size:14px; }
.btn-link { color:var(--green); font-weight:600; text-decoration:none; font-size:14px; display:flex; align-items:center; gap:4px; white-space:nowrap; }
.btn-link:hover { color:var(--green-dark); }

/* ── Business Category Grid ─────────────── */
.biz-cat-grid {
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(130px,1fr));
  gap:12px;
}
.biz-cat-card {
  display:flex; flex-direction:column; align-items:center;
  padding:20px 12px; border-radius:var(--radius);
  background:#fff; border:1px solid var(--border);
  text-decoration:none; color:var(--text);
  transition:all .2s; text-align:center; gap:8px;
}
.biz-cat-card:hover { border-color:var(--green); box-shadow:var(--shadow-md); transform:translateY(-2px); }
.biz-cat-icon { width:52px; height:52px; border-radius:50%; display:flex; align-items:center; justify-content:center; }
.biz-cat-icon i { font-size:24px; }
.biz-cat-name { font-size:13px; font-weight:600; line-height:1.3; }
.biz-cat-count { font-size:11px; color:var(--text-muted); }

/* ── Business Cards (Featured) ───────────── */
.biz-cards-grid {
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(280px,1fr));
  gap:20px;
}
.biz-card {
  background:#fff; border-radius:var(--radius);
  border:1px solid var(--border); overflow:hidden;
  text-decoration:none; color:var(--text);
  transition:all .2s; display:flex; flex-direction:column;
}
.biz-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-3px); border-color:transparent; }
.biz-card-cover { position:relative; height:160px; overflow:hidden; }
.biz-card-cover img { width:100%; height:100%; object-fit:cover; }
.biz-card-cover-placeholder {
  width:100%; height:100%; display:flex; align-items:center; justify-content:center;
}
.biz-card-cover-placeholder i { font-size:48px; opacity:.5; }
.biz-badge {
  position:absolute; top:10px; left:10px;
  background:rgba(0,0,0,0.6); color:#fff;
  font-size:11px; font-weight:600; padding:3px 10px;
  border-radius:20px; backdrop-filter:blur(4px);
}
.biz-badge-featured { background:rgba(245,158,11,0.85); }
.biz-badge-verified { background:rgba(29,158,117,0.85); }
.biz-card-body { padding:16px; flex:1; display:flex; flex-direction:column; gap:6px; }
.biz-card-top  { display:flex; align-items:center; justify-content:space-between; margin-bottom:4px; }
.biz-logo-wrap { width:44px; height:44px; border-radius:8px; overflow:hidden; border:2px solid var(--border); }
.biz-logo      { width:100%; height:100%; object-fit:cover; }
.biz-logo-placeholder {
  width:44px; height:44px; border-radius:8px; border:2px solid var(--border);
  display:flex; align-items:center; justify-content:center;
}
.biz-logo-placeholder i { font-size:20px; }
.biz-rating    { display:flex; align-items:center; gap:4px; font-size:13px; }
.biz-rating strong { font-weight:700; }
.biz-rating span { color:var(--text-muted); }
.biz-name      { font-size:15px; font-weight:700; margin:0; line-height:1.3; }
.biz-cat-tag   { font-size:12px; font-weight:500; display:flex; align-items:center; gap:4px; }
.biz-location  { font-size:12px; color:var(--text-muted); margin:0; display:flex; align-items:center; gap:4px; }
.biz-phone     { font-size:12px; color:var(--text-muted); margin:0; display:flex; align-items:center; gap:4px; }

/* ── Add Business Banner ─────────────────── */
.add-biz-banner {
  background: linear-gradient(135deg, var(--green) 0%, #0d7a57 100%);
  padding: 56px 0;
}
.add-biz-inner {
  display:flex; align-items:center; justify-content:space-between;
  gap:32px; flex-wrap:wrap;
}
.add-biz-text h2 { font-size:28px; font-weight:800; color:#fff; margin:0 0 8px; }
.add-biz-text p  { color:rgba(255,255,255,0.85); margin:0 0 16px; font-size:16px; }
.add-biz-perks   { list-style:none; padding:0; margin:0; display:flex; flex-wrap:wrap; gap:8px 20px; }
.add-biz-perks li { color:rgba(255,255,255,0.9); font-size:14px; display:flex; align-items:center; gap:6px; }
.add-biz-perks li i { color:#fff; }
.add-biz-actions { display:flex; flex-direction:column; gap:12px; align-items:flex-start; flex-shrink:0; }
.btn-add-listing {
  background:#fff; color:var(--green); font-weight:700; font-size:16px;
  padding:14px 28px; border-radius:50px; text-decoration:none;
  display:flex; align-items:center; gap:8px; white-space:nowrap;
  box-shadow:0 4px 20px rgba(0,0,0,0.2); transition:all .2s;
}
.btn-add-listing:hover { transform:translateY(-2px); box-shadow:0 8px 30px rgba(0,0,0,0.25); }
.btn-browse-all {
  color:rgba(255,255,255,0.85); text-decoration:none; font-size:14px;
  display:flex; align-items:center; gap:4px; justify-content:center;
  transition:color .2s;
}
.btn-browse-all:hover { color:#fff; }

/* ── Business List Cards (Recent) ────────── */
.biz-list-grid { display:flex; flex-direction:column; gap:10px; }
.biz-list-card {
  display:flex; align-items:center; gap:16px; padding:16px 20px;
  background:#fff; border-radius:var(--radius); border:1px solid var(--border);
  text-decoration:none; color:var(--text); transition:all .2s;
}
.biz-list-card:hover { border-color:var(--green); box-shadow:var(--shadow-sm); }
.biz-list-logo { width:52px; height:52px; border-radius:10px; overflow:hidden; border:1px solid var(--border); flex-shrink:0; }
.biz-list-logo img { width:100%; height:100%; object-fit:cover; }
.biz-list-logo-placeholder {
  width:52px; height:52px; border-radius:10px; border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
}
.biz-list-logo-placeholder i { font-size:22px; }
.biz-list-info { flex:1; min-width:0; }
.biz-list-top  { display:flex; align-items:center; justify-content:space-between; gap:8px; }
.biz-list-top h3 { font-size:15px; font-weight:600; margin:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.biz-list-rating { display:flex; align-items:center; gap:3px; font-size:13px; font-weight:600; flex-shrink:0; }
.biz-list-meta { display:flex; align-items:center; gap:12px; margin-top:3px; }
.biz-list-meta span { font-size:12px; color:var(--text-muted); display:flex; align-items:center; gap:3px; }
.biz-list-phone { font-size:12px; color:var(--text-muted); margin:3px 0 0; display:flex; align-items:center; gap:3px; }
.biz-list-arrow { color:var(--border); margin-left:auto; flex-shrink:0; }

/* ── Cities Grid ─────────────────────────── */
.cities-grid {
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(140px,1fr));
  gap:12px;
}
.city-card {
  display:flex; flex-direction:column; align-items:center; gap:6px;
  padding:20px 12px; border-radius:var(--radius);
  background:#fff; border:1px solid var(--border);
  text-decoration:none; color:var(--text);
  transition:all .2s; text-align:center;
}
.city-card:hover { border-color:var(--green); box-shadow:var(--shadow-md); }
.city-card i    { font-size:28px; color:var(--green); }
.city-card span { font-size:14px; font-weight:600; }
.city-card small{ font-size:11px; color:var(--text-muted); }

/* ── IFSC Mini Widget ────────────────────── */
.ifsc-mini-widget { padding:20px 24px; }
.ifsc-mini-form {
  display:flex; gap:10px; flex-wrap:wrap; align-items:center;
}
.ifsc-mini-form select,
.ifsc-mini-form input { flex:1; min-width:160px; }

/* ── Blog Mini Grid ──────────────────────── */
.blog-mini-grid {
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(280px,1fr));
  gap:20px;
}
.blog-mini-card {
  background:#fff; border-radius:var(--radius); border:1px solid var(--border);
  overflow:hidden; text-decoration:none; color:var(--text);
  transition:all .2s; display:flex; flex-direction:column;
}
.blog-mini-card:hover { box-shadow:var(--shadow-md); transform:translateY(-2px); }
.blog-mini-card img { width:100%; height:160px; object-fit:cover; }
.blog-mini-placeholder { height:160px; background:var(--bg-gray); display:flex; align-items:center; justify-content:center; }
.blog-mini-placeholder i { font-size:40px; color:var(--border); }
.blog-mini-body { padding:16px; flex:1; display:flex; flex-direction:column; gap:6px; }
.blog-mini-body h3 { font-size:15px; font-weight:600; margin:0; line-height:1.4; }
.blog-mini-body p  { font-size:13px; color:var(--text-muted); margin:0; line-height:1.5; }
.blog-mini-date { font-size:12px; color:var(--text-muted); display:flex; align-items:center; gap:4px; margin-top:auto; }
.post-tag { font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.5px; }

/* ── Responsive ─────────────────────────── */
@media (max-width:768px) {
  .top-bar-left { display:none; }
  .dir-hero { padding:40px 0; }
  .dir-search-inner { flex-direction:column; height:auto; border-radius:var(--radius); }
  .dir-search-divider { width:100%; height:1px; }
  .dir-search-field { padding:12px 16px; width:100%; }
  .dir-search-btn { width:100%; height:48px; justify-content:center; }
  .hero-stats { flex-wrap:wrap; gap:16px; padding:12px 20px; }
  .hero-stat-divider { display:none; }
  .add-biz-inner { flex-direction:column; }
  .add-biz-actions { width:100%; }
  .btn-add-listing { width:100%; justify-content:center; }
  .biz-cat-grid { grid-template-columns:repeat(auto-fill,minmax(100px,1fr)); }
  .section-head { flex-direction:column; align-items:flex-start; gap:8px; }
  .dir-section { padding:36px 0; }
}
