/* ============================================================
   NJ Business Solutions Theme — Main Stylesheet
   2026 Slate-Blue Professional Palette
   ============================================================ */

:root {
  --s900:#1e2a3a; --s800:#253447; --s700:#2f4260; --s600:#3d5578;
  --s500:#546e8f; --s400:#7a95b0; --s300:#a8bdd0; --s200:#d4e1ec;
  --s100:#eaf1f7; --s50:#f4f7fa;
  --b600:#1a6faa; --b500:#2383c4; --b400:#4a9fd4; --b100:#deeef9; --b50:#f0f7fd;
  --t600:#0f7c6e; --t500:#12907f; --t100:#d4f0ec; --t50:#ebf8f6;
  --cloud:#f8f9fb; --white:#fff; --paper:#f2f5f8;
  --tx9:#1e2a3a; --tx7:#2f4260; --tx5:#546e8f; --tx3:#a8bdd0;
  --grn:#0f7c6e; --grn-bg:#ebf8f6; --grn-bd:#a8ddd6;
  --red:#c0392b; --red-bg:#fdf0ee;
  --org:#c05621; --org-bg:#fff3e6; --org-bd:#f5c48a;
  --star:#e8a020;
  --fn-d:'Lora',Georgia,serif; --fn-b:'Plus Jakarta Sans',system-ui,sans-serif;
  --r:8px; --rl:14px; --rxl:20px;
  --sh:0 1px 8px rgba(30,42,58,.06);
  --shm:0 4px 24px rgba(30,42,58,.10);
  --shl:0 12px 44px rgba(30,42,58,.14);
  --bd:1px solid var(--s200);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--fn-b); background: var(--paper); color: var(--tx9); font-size: 15px; line-height: 1.6; overflow-x: hidden; }
a { text-decoration: none; color: inherit; }
img { max-width: 100%; height: auto; }

/* ── BADGES ── */
.njbiz-badge { display:inline-flex; align-items:center; gap:4px; font-size:11px; font-weight:700; padding:3px 9px; border-radius:20px; }
.badge-blue { background:var(--b100); color:var(--b600); border:1px solid #b8d8f0; }
.badge-teal { background:var(--t100); color:var(--t600); border:1px solid var(--grn-bd); }
.badge-slate { background:var(--s100); color:var(--s600); border:var(--bd); }
.badge-red { background:var(--red-bg); color:var(--red); border:1px solid #f5b8b0; }
.badge-org { background:var(--org-bg); color:var(--org); border:1px solid var(--org-bd); }

/* ── BUTTONS ── */
.njbiz-btn { display:inline-flex; align-items:center; justify-content:center; gap:7px; font-family:var(--fn-b); font-size:14px; font-weight:600; padding:10px 20px; border-radius:var(--r); cursor:pointer; border:none; text-decoration:none; transition:all .18s; white-space:nowrap; }
.btn-primary { background:var(--s900); color:var(--white); } .btn-primary:hover { background:var(--s700); color:var(--white); }
.btn-blue { background:var(--b600); color:var(--white); } .btn-blue:hover { background:var(--b500); color:var(--white); }
.btn-teal { background:var(--t600); color:var(--white); } .btn-teal:hover { background:var(--t500); color:var(--white); }
.btn-outline { background:var(--white); color:var(--tx7); border:var(--bd); } .btn-outline:hover { border-color:var(--s500); color:var(--s900); }
.btn-ghost { background:rgba(255,255,255,.1); color:rgba(255,255,255,.85); border:1px solid rgba(255,255,255,.2); }
.btn-sm { padding:7px 13px; font-size:12px; }
.btn-lg { padding:13px 28px; font-size:15px; }
.btn-xl { padding:16px 36px; font-size:16px; }
.btn-full { width:100%; }

/* ── FORMS ── */
.njbiz-field { margin-bottom:14px; }
.njbiz-field label { display:block; font-size:11px; font-weight:700; color:var(--tx5); margin-bottom:5px; text-transform:uppercase; letter-spacing:.05em; }
.njbiz-field input, .njbiz-field select, .njbiz-field textarea { width:100%; border:1.5px solid var(--s200); border-radius:var(--r); padding:10px 13px; font-family:var(--fn-b); font-size:14px; font-weight:500; color:var(--tx9); background:var(--white); outline:none; transition:border-color .18s, box-shadow .18s; }
.njbiz-field input:focus, .njbiz-field select:focus, .njbiz-field textarea:focus { border-color:var(--b500); box-shadow:0 0 0 3px rgba(35,131,196,.12); }
.njbiz-field input.has-error, .njbiz-field select.has-error, .njbiz-field textarea.has-error { border-color:var(--red); }
.njbiz-field .field-error { font-size:11px; color:var(--red); font-weight:600; margin-top:4px; display:none; }
.njbiz-field .field-error.visible { display:block; }
.njbiz-field textarea { height:90px; resize:vertical; }
.stars-picker { display:flex; gap:5px; font-size:26px; cursor:pointer; margin-top:4px; }
.stars-picker span { color:var(--s200); transition:color .12s; user-select:none; }
.stars-picker span.lit { color:var(--star); }

/* ── CARDS / BOXES ── */
.njbiz-card { background:var(--white); border:var(--bd); border-radius:var(--rl); padding:22px; box-shadow:var(--sh); }
.njbiz-card-lg { background:var(--white); border:var(--bd); border-radius:var(--rxl); padding:32px; box-shadow:var(--sh); }

/* ── NAV ── */
.njbiz-nav { position:sticky; top:0; z-index:300; background:var(--s900); display:flex; align-items:center; justify-content:space-between; padding:0 4%; height:62px; border-bottom:1px solid rgba(255,255,255,.06); }
.nav-logo { display:flex; align-items:center; gap:9px; cursor:pointer; }
.nav-mark { width:32px; height:32px; background:var(--b500); border-radius:7px; display:flex; align-items:center; justify-content:center; font-family:var(--fn-d); font-weight:700; font-size:15px; color:var(--white); flex-shrink:0; }
.nav-txt { font-family:var(--fn-d); font-size:13px; font-weight:600; color:var(--white); line-height:1.15; }
.nav-sub { font-size:9px; font-weight:500; color:rgba(255,255,255,.35); letter-spacing:.07em; text-transform:uppercase; }
.nav-links { display:flex; align-items:center; gap:4px; }
.nav-link { color:rgba(255,255,255,.6); font-size:13px; font-weight:500; padding:6px 11px; border-radius:6px; transition:all .14s; cursor:pointer; background:none; border:none; font-family:var(--fn-b); text-decoration:none; display:inline-flex; align-items:center; }
.nav-link:hover, .nav-link.current { color:var(--white); background:rgba(255,255,255,.08); }
.nav-avatar { width:30px; height:30px; border-radius:50%; background:var(--b500); color:var(--white); display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:700; cursor:pointer; border:2px solid rgba(255,255,255,.15); text-decoration:none; }
.nav-notif-wrap { position:relative; cursor:pointer; color:rgba(255,255,255,.5); font-size:17px; width:30px; height:30px; display:flex; align-items:center; justify-content:center; border-radius:6px; transition:background .14s; }
.nav-notif-wrap:hover { background:rgba(255,255,255,.08); }
.nav-notif-count { position:absolute; top:-2px; right:-2px; background:var(--red); color:var(--white); font-size:9px; font-weight:800; width:16px; height:16px; border-radius:50%; display:flex; align-items:center; justify-content:center; border:2px solid var(--s900); }
.mobile-menu-toggle { display:none; color:rgba(255,255,255,.7); font-size:20px; background:none; border:none; cursor:pointer; padding:6px; }

/* ── HERO ── */
.njbiz-hero { background:linear-gradient(135deg,var(--s900) 0%,var(--s700) 100%); padding:64px 4% 72px; position:relative; overflow:hidden; }
.njbiz-hero::after { content:''; position:absolute; top:-100px; right:-60px; width:400px; height:400px; border-radius:50%; background:radial-gradient(circle,rgba(35,131,196,.13) 0%,transparent 70%); pointer-events:none; }
.hero-inner { max-width:840px; position:relative; z-index:1; }
.hero-tag { display:inline-flex; align-items:center; gap:6px; background:rgba(35,131,196,.18); border:1px solid rgba(74,159,212,.35); color:#7ec8f0; font-size:11px; font-weight:700; letter-spacing:.07em; text-transform:uppercase; padding:5px 12px; border-radius:20px; margin-bottom:20px; }
.hero-tag::before { content:''; width:5px; height:5px; border-radius:50%; background:#7ec8f0; }
.hero-inner h1 { font-family:var(--fn-d); font-size:clamp(30px,4.2vw,52px); font-weight:700; color:var(--white); line-height:1.12; margin-bottom:14px; }
.hero-inner h1 em { font-style:italic; color:#7ec8f0; }
.hero-sub { font-size:16px; color:rgba(255,255,255,.58); max-width:500px; margin-bottom:30px; line-height:1.75; font-weight:400; }
.hero-stats { display:flex; align-items:center; gap:22px; margin-top:18px; flex-wrap:wrap; }
.hstat { color:rgba(255,255,255,.5); font-size:12px; font-weight:500; }
.hstat strong { display:block; font-family:var(--fn-d); font-size:20px; font-weight:600; color:var(--white); }
.hstat-div { width:1px; height:28px; background:rgba(255,255,255,.12); }

/* ── SEARCH BAR ── */
.njbiz-search-bar { background:var(--white); border-radius:var(--rl); padding:5px 5px 5px 14px; display:flex; align-items:center; gap:5px; max-width:660px; box-shadow:0 8px 30px rgba(30,42,58,.22); }
.njbiz-search-bar select { border:none; outline:none; font-family:var(--fn-b); font-size:13px; font-weight:500; color:var(--tx7); background:transparent; padding:9px 8px; border-right:1px solid var(--s200); cursor:pointer; min-width:155px; }
.njbiz-search-bar input[type="text"] { flex:1; border:none; outline:none; font-family:var(--fn-b); font-size:13px; font-weight:500; color:var(--tx9); background:transparent; padding:9px 8px; min-width:0; }
.njbiz-search-bar input::placeholder { color:var(--tx3); }
.search-result-count { font-size:12px; color:rgba(255,255,255,.5); margin-top:12px; font-weight:500; min-height:18px; }

/* ── CATEGORY BAR ── */
.cat-bar { background:var(--white); padding:12px 4%; border-bottom:var(--bd); }
.cat-pills { display:flex; align-items:center; gap:6px; overflow-x:auto; scrollbar-width:none; }
.cat-pills::-webkit-scrollbar { display:none; }
.cat-label-txt { font-size:10px; font-weight:700; color:var(--tx3); white-space:nowrap; margin-right:3px; text-transform:uppercase; letter-spacing:.07em; }
.cat-pill { display:inline-flex; align-items:center; gap:4px; background:var(--cloud); border:1px solid var(--s200); color:var(--tx5); font-size:12px; font-weight:600; padding:5px 12px; border-radius:20px; cursor:pointer; white-space:nowrap; transition:all .14s; font-family:var(--fn-b); }
.cat-pill:hover, .cat-pill.active { background:var(--b600); color:var(--white); border-color:var(--b600); }

/* ── STATS ROW ── */
.stats-row { background:var(--white); border-bottom:var(--bd); display:flex; justify-content:center; flex-wrap:wrap; }
.stat-item { text-align:center; padding:20px 40px; position:relative; }
.stat-item + .stat-item::before { content:''; position:absolute; left:0; top:20%; height:60%; width:1px; background:var(--s200); }
.stat-num { font-family:var(--fn-d); font-size:30px; font-weight:700; color:var(--s900); line-height:1; }
.stat-lbl { font-size:12px; color:var(--tx5); margin-top:3px; font-weight:600; }

/* ── DIRECTORY LAYOUT ── */
.directory-wrap { display:flex; gap:22px; padding:28px 4%; }
.dir-sidebar { width:230px; flex-shrink:0; }
.sidebar-box { background:var(--white); border:var(--bd); border-radius:var(--rl); padding:16px; margin-bottom:12px; box-shadow:var(--sh); }
.sidebar-title { font-size:10px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--tx3); margin-bottom:11px; }
.filter-row { margin-bottom:4px; }
.filter-row label { display:flex; align-items:center; gap:7px; font-size:13px; color:var(--tx5); cursor:pointer; padding:3px 0; font-weight:500; transition:color .14s; }
.filter-row label:hover { color:var(--tx9); }
.filter-row input[type="checkbox"] { accent-color:var(--b600); width:14px; height:14px; flex-shrink:0; }
.filter-count { margin-left:auto; font-size:10px; color:var(--tx3); background:var(--s100); padding:1px 6px; border-radius:10px; font-weight:600; }
.filter-range { width:100%; accent-color:var(--b600); margin-top:5px; }

/* ── LISTING CARDS ── */
.listings-main { flex:1; min-width:0; }
.listings-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; flex-wrap:wrap; gap:8px; }
.listings-count { font-size:13px; color:var(--tx5); font-weight:600; }
.listings-count strong { color:var(--tx9); }
.sort-select { border:var(--bd); border-radius:var(--r); padding:7px 11px; font-family:var(--fn-b); font-size:12px; font-weight:600; color:var(--tx7); background:var(--white); cursor:pointer; outline:none; }
.listing-card { background:var(--white); border:var(--bd); border-radius:var(--rl); padding:18px 20px; margin-bottom:10px; display:flex; gap:14px; transition:box-shadow .18s, border-color .18s; cursor:pointer; box-shadow:var(--sh); position:relative; animation:cardFadeIn .2s ease; }
@keyframes cardFadeIn { from { opacity:0; transform:translateY(6px); } to { opacity:1; transform:translateY(0); } }
.listing-card:hover { box-shadow:var(--shm); border-color:var(--s300); }
.listing-card.featured { border-left:3px solid var(--b500); }
.listing-logo { width:52px; height:52px; flex-shrink:0; border-radius:10px; display:flex; align-items:center; justify-content:center; font-family:var(--fn-d); font-size:18px; font-weight:700; border:var(--bd); }
.logo-blue { background:var(--b50); color:var(--b600); }
.logo-teal { background:var(--t50); color:var(--t600); }
.logo-slate { background:var(--s100); color:var(--s600); }
.listing-body { flex:1; min-width:0; }
.listing-top { display:flex; align-items:flex-start; justify-content:space-between; gap:8px; margin-bottom:3px; flex-wrap:wrap; }
.listing-name-row { display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.listing-name { font-family:var(--fn-d); font-size:16px; font-weight:600; color:var(--tx9); }
.listing-cat { font-size:10px; color:var(--tx3); text-transform:uppercase; letter-spacing:.05em; margin-bottom:6px; font-weight:700; }
.listing-rating { display:flex; align-items:center; gap:4px; white-space:nowrap; flex-shrink:0; }
.rating-val { font-size:12px; font-weight:700; color:var(--tx9); }
.rating-count { font-size:11px; color:var(--tx3); font-weight:600; }
.listing-desc { font-size:13px; color:var(--tx5); line-height:1.58; margin-bottom:10px; font-weight:500; }
.listing-meta { display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin-bottom:10px; }
.listing-meta-item { display:flex; align-items:center; gap:3px; font-size:11px; color:var(--tx3); font-weight:600; }
.listing-actions { display:flex; gap:6px; }
.save-btn { position:absolute; top:14px; right:14px; width:28px; height:28px; border-radius:50%; border:var(--bd); background:var(--white); display:flex; align-items:center; justify-content:center; font-size:14px; cursor:pointer; transition:all .15s; color:var(--tx3); }
.save-btn:hover { border-color:var(--b500); color:var(--b500); }
.save-btn.saved { border-color:var(--red); color:var(--red); background:var(--red-bg); }
.no-results { text-align:center; padding:48px 20px; color:var(--tx3); }
.no-results .no-icon { font-size:40px; margin-bottom:12px; }
.no-results h3 { font-family:var(--fn-d); font-size:18px; color:var(--tx7); margin-bottom:6px; }
.pagination { display:flex; align-items:center; justify-content:center; gap:4px; margin-top:22px; }
.page-btn { width:32px; height:32px; border-radius:var(--r); display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:700; cursor:pointer; border:var(--bd); color:var(--tx5); background:var(--white); transition:all .14s; font-family:var(--fn-b); text-decoration:none; }
.page-btn:hover, .page-btn.current-page { background:var(--b600); color:var(--white); border-color:var(--b600); }

/* ── LISTING DETAIL ── */
.detail-hero-bar { background:var(--white); border-bottom:var(--bd); padding:26px 4%; box-shadow:var(--sh); }
.detail-header { display:flex; align-items:flex-start; gap:18px; flex-wrap:wrap; }
.detail-logo { width:72px; height:72px; border-radius:var(--rl); display:flex; align-items:center; justify-content:center; font-family:var(--fn-d); font-size:24px; font-weight:700; flex-shrink:0; border:var(--bd); }
.detail-name { font-family:var(--fn-d); font-size:26px; font-weight:700; color:var(--tx9); margin-bottom:7px; }
.detail-meta-row { display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-bottom:11px; }
.detail-body { display:grid; grid-template-columns:1fr 320px; gap:22px; padding:24px 4%; align-items:start; }
.detail-section { margin-bottom:24px; }
.detail-section h3 { font-family:var(--fn-d); font-size:16px; font-weight:600; margin-bottom:11px; padding-bottom:9px; border-bottom:var(--bd); color:var(--tx9); }
.service-tags { display:flex; flex-wrap:wrap; gap:6px; }
.service-tag { background:var(--s50); border:var(--bd); color:var(--tx5); font-size:12px; font-weight:600; padding:5px 12px; border-radius:20px; }
.review-card { border:var(--bd); border-radius:var(--rl); padding:14px; margin-bottom:9px; background:var(--cloud); }
.reviewer-av { width:34px; height:34px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:800; }
.detail-sidebar-card { background:var(--white); border:var(--bd); border-radius:var(--rl); padding:20px; margin-bottom:12px; box-shadow:var(--sh); position:sticky; top:74px; }
.contact-row { display:flex; align-items:flex-start; gap:9px; padding:8px 0; border-bottom:var(--bd); }
.contact-row:last-child { border-bottom:none; }
.contact-icon { width:28px; height:28px; border-radius:6px; background:var(--s100); display:flex; align-items:center; justify-content:center; font-size:14px; flex-shrink:0; }
.contact-lbl { font-size:10px; color:var(--tx3); text-transform:uppercase; letter-spacing:.05em; font-weight:700; }
.contact-val { font-size:13px; color:var(--tx9); font-weight:600; }
.hours-row { display:flex; justify-content:space-between; font-size:12px; padding:5px 0; border-bottom:var(--bd); }
.hours-row:last-child { border-bottom:none; }
.hours-day { color:var(--tx5); font-weight:600; }
.hours-time { font-weight:700; color:var(--tx9); }
.map-placeholder { background:var(--s100); border-radius:var(--r); height:140px; display:flex; align-items:center; justify-content:center; color:var(--tx3); font-size:12px; font-weight:600; border:var(--bd); margin-bottom:10px; }

/* ── CONSULTING PACKAGES ── */
.consulting-hero { background:linear-gradient(135deg,var(--s800),var(--s700)); padding:60px 4%; text-align:center; position:relative; overflow:hidden; }
.consulting-hero::after { content:''; position:absolute; top:-80px; right:-80px; width:340px; height:340px; border-radius:50%; background:radial-gradient(circle,rgba(74,159,212,.12),transparent 70%); }
.packages-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); gap:16px; padding:40px 4%; max-width:1060px; margin:0 auto; }
.package-card { border:var(--bd); border-radius:var(--rxl); padding:26px; background:var(--white); box-shadow:var(--sh); transition:box-shadow .18s; }
.package-card:hover { box-shadow:var(--shm); }
.package-card.popular { border:2px solid var(--b500); position:relative; }
.popular-tag { position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:var(--b600); color:var(--white); font-size:10px; font-weight:700; padding:4px 14px; border-radius:20px; white-space:nowrap; }
.package-name { font-family:var(--fn-d); font-size:21px; font-weight:700; margin-bottom:5px; color:var(--tx9); }
.package-price { font-family:var(--fn-d); font-size:38px; font-weight:700; line-height:1; margin-bottom:3px; color:var(--s900); }
.package-sub { font-size:12px; color:var(--tx3); margin-bottom:12px; font-weight:600; }
.package-features { list-style:none; margin-bottom:22px; }
.package-features li { font-size:13px; color:var(--tx5); padding:5px 0; display:flex; align-items:flex-start; gap:7px; border-bottom:var(--bd); font-weight:500; }
.package-features li:last-child { border-bottom:none; }
.package-features li::before { content:'✓'; color:var(--t600); font-weight:800; flex-shrink:0; margin-top:1px; }

/* ── CHECKOUT ── */
.checkout-grid { display:grid; grid-template-columns:1fr 350px; gap:22px; padding:32px 4%; max-width:1060px; margin:0 auto; align-items:start; }
.step-bar { display:flex; align-items:flex-start; padding:18px 4% 0; max-width:1060px; margin:0 auto; width:100%; }
.step-group { display:flex; flex-direction:column; align-items:center; flex:0 0 auto; }
.step-dot { width:28px; height:28px; border-radius:50%; border:2px solid var(--s200); background:var(--white); display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:800; color:var(--tx3); }
.step-dot.active { border-color:var(--b600); background:var(--b600); color:var(--white); }
.step-dot.done { border-color:var(--t600); background:var(--t600); color:var(--white); }
.step-label { font-size:10px; font-weight:700; margin-top:5px; color:var(--tx3); }
.step-label.active { color:var(--b600); } .step-label.done { color:var(--t600); }
.step-line { flex:1; height:2px; background:var(--s200); margin-top:14px; }
.step-line.active, .step-line.done { background:var(--b600); }
.order-summary-card { background:var(--white); border:var(--bd); border-radius:var(--rl); padding:20px; position:sticky; top:74px; box-shadow:var(--sh); }
.os-row { display:flex; justify-content:space-between; font-size:13px; padding:7px 0; border-bottom:var(--bd); font-weight:500; }
.os-row.total { border-bottom:2px solid var(--s900); font-weight:800; font-size:14px; }
.os-feature { display:flex; align-items:center; gap:6px; font-size:12px; color:var(--tx5); padding:3px 0; font-weight:600; }
.os-feature::before { content:'✓'; color:var(--t600); font-weight:800; }

/* ── DASHBOARD ── */
.dashboard-layout { display:grid; grid-template-columns:200px 1fr; min-height:calc(100vh - 62px); }
.dash-sidebar { background:var(--white); border-right:var(--bd); }
.dash-sidebar-header { padding:16px; border-bottom:var(--bd); }
.dash-biz-label { font-size:9px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--tx3); margin-bottom:3px; }
.dash-biz-name { font-size:13px; font-weight:700; color:var(--tx9); }
.dash-biz-status { font-size:11px; color:var(--t600); font-weight:700; margin-top:2px; display:flex; align-items:center; gap:4px; }
.dash-biz-status::before { content:''; width:5px; height:5px; border-radius:50%; background:var(--t600); }
.dash-nav-item { display:flex; align-items:center; gap:8px; padding:9px 16px; font-size:12px; font-weight:700; color:var(--tx5); cursor:pointer; transition:all .13s; border-left:3px solid transparent; text-decoration:none; }
.dash-nav-item:hover { background:var(--s50); color:var(--tx9); }
.dash-nav-item.active { background:var(--b50); color:var(--b600); border-left-color:var(--b600); }
.dash-nav-sep { height:1px; background:var(--s200); margin:6px 16px; }
.dash-nav-badge { margin-left:auto; background:var(--b600); color:var(--white); font-size:9px; font-weight:800; padding:2px 6px; border-radius:10px; }
.dash-main { background:var(--paper); padding:24px; overflow:auto; }
.dash-topbar { display:flex; align-items:center; justify-content:space-between; margin-bottom:20px; flex-wrap:wrap; gap:10px; }
.metrics-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); gap:10px; margin-bottom:18px; }
.metric-card { background:var(--white); border:var(--bd); border-radius:var(--rl); padding:16px; box-shadow:var(--sh); }
.metric-label { font-size:10px; font-weight:700; color:var(--tx3); text-transform:uppercase; letter-spacing:.07em; margin-bottom:6px; }
.metric-value { font-family:var(--fn-d); font-size:26px; font-weight:700; color:var(--s900); line-height:1; }
.metric-change { font-size:11px; margin-top:4px; font-weight:700; }
.metric-up { color:var(--t600); } .metric-neutral { color:var(--tx3); } .metric-special { color:var(--b600); }

/* ── ADMIN ── */
.admin-layout { display:grid; grid-template-columns:200px 1fr; min-height:calc(100vh - 62px); }
.admin-sidebar { background:var(--s900); }
.admin-nav-item { display:flex; align-items:center; gap:8px; padding:9px 16px; font-size:12px; font-weight:700; color:rgba(255,255,255,.5); cursor:pointer; transition:all .13s; border-left:3px solid transparent; text-decoration:none; }
.admin-nav-item:hover, .admin-nav-item.active { background:rgba(255,255,255,.06); color:var(--white); border-left-color:var(--b400); }
.admin-nav-section { font-size:9px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.2); padding:9px 16px 3px; }
.admin-nav-sep { height:1px; background:rgba(255,255,255,.07); margin:5px 0; }
.admin-nav-badge { margin-left:auto; background:var(--b500); color:var(--white); font-size:9px; font-weight:800; padding:2px 6px; border-radius:10px; }

/* ── TABLES ── */
.njbiz-table-wrap { background:var(--white); border:var(--bd); border-radius:var(--rl); overflow:hidden; margin-bottom:16px; box-shadow:var(--sh); }
.table-header { padding:13px 16px; border-bottom:var(--bd); display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:8px; }
.table-header h3 { font-family:var(--fn-d); font-size:15px; font-weight:600; color:var(--tx9); }
table.njbiz-table { width:100%; border-collapse:collapse; }
table.njbiz-table th { background:var(--s50); text-align:left; padding:9px 14px; font-size:10px; font-weight:800; color:var(--tx3); text-transform:uppercase; letter-spacing:.06em; border-bottom:var(--bd); }
table.njbiz-table td { padding:11px 14px; font-size:12px; border-bottom:var(--bd); color:var(--tx7); font-weight:600; }
table.njbiz-table tr:last-child td { border-bottom:none; }
table.njbiz-table tr:hover td { background:var(--s50); }
.tbl-action { color:var(--b600); font-size:11px; cursor:pointer; background:none; border:none; font-family:var(--fn-b); font-weight:700; padding:0; text-decoration:none; }
.tbl-action:hover { text-decoration:underline; }
.tbl-action.danger { color:var(--red); }
.status-dot { display:inline-flex; align-items:center; gap:4px; font-size:11px; font-weight:700; }
.status-dot::before { content:''; width:5px; height:5px; border-radius:50%; }
.status-active::before { background:var(--grn); }
.status-pending::before { background:var(--b500); }
.status-inactive::before { background:var(--tx3); }

/* ── BLOG / RESOURCES ── */
.blog-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:16px; padding:40px 4%; max-width:1160px; margin:0 auto; }
.blog-card { background:var(--white); border:var(--bd); border-radius:var(--rl); overflow:hidden; cursor:pointer; transition:box-shadow .18s; box-shadow:var(--sh); }
.blog-card:hover { box-shadow:var(--shm); }
.blog-img { height:140px; display:flex; align-items:center; justify-content:center; font-size:34px; background:var(--s100); }
.blog-body { padding:16px; }
.blog-tag { font-size:10px; font-weight:800; text-transform:uppercase; letter-spacing:.06em; color:var(--b600); margin-bottom:6px; }
.blog-title { font-family:var(--fn-d); font-size:16px; font-weight:600; margin-bottom:6px; line-height:1.35; color:var(--tx9); }
.blog-excerpt { font-size:12px; color:var(--tx5); line-height:1.6; margin-bottom:11px; font-weight:500; }
.blog-meta-row { display:flex; align-items:center; justify-content:space-between; font-size:10px; color:var(--tx3); font-weight:700; }

/* ── GRANTS ── */
.grant-card { border:var(--bd); border-radius:var(--rl); padding:16px 20px; margin-bottom:9px; display:flex; align-items:center; gap:16px; flex-wrap:wrap; cursor:pointer; transition:box-shadow .15s; background:var(--white); box-shadow:var(--sh); }
.grant-card:hover { box-shadow:var(--shm); }
.grant-amount { font-family:var(--fn-d); font-size:18px; font-weight:700; color:var(--s900); min-width:95px; }
.grant-info { flex:1; }
.grant-name { font-size:13px; font-weight:700; margin-bottom:2px; color:var(--tx9); }
.grant-detail { font-size:11px; color:var(--tx5); font-weight:600; }

/* ── MODALS ── */
.njbiz-modal-overlay { position:fixed; inset:0; z-index:600; background:rgba(30,42,58,.55); backdrop-filter:blur(5px); display:flex; align-items:center; justify-content:center; padding:18px; opacity:0; pointer-events:none; transition:opacity .22s; }
.njbiz-modal-overlay.open { opacity:1; pointer-events:all; }
.njbiz-modal-box { background:var(--white); border-radius:var(--rxl); padding:32px; max-width:500px; width:100%; max-height:90vh; overflow-y:auto; transform:translateY(16px); transition:transform .22s; position:relative; box-shadow:var(--shl); }
.njbiz-modal-overlay.open .njbiz-modal-box { transform:translateY(0); }
.modal-close-btn { position:absolute; top:14px; right:14px; width:28px; height:28px; border-radius:50%; background:var(--s100); border:none; cursor:pointer; font-size:14px; color:var(--tx5); display:flex; align-items:center; justify-content:center; transition:background .15s; }
.modal-close-btn:hover { background:var(--s200); }
.modal-title { font-family:var(--fn-d); font-size:21px; font-weight:700; color:var(--tx9); margin-bottom:4px; }
.modal-subtitle { font-size:13px; color:var(--tx5); margin-bottom:20px; line-height:1.6; font-weight:500; }

/* ── TOASTS ── */
#njbiz-toasts { position:fixed; bottom:22px; right:22px; z-index:9999; display:flex; flex-direction:column; gap:8px; pointer-events:none; }
.njbiz-toast { background:var(--s900); color:var(--white); padding:12px 18px; border-radius:var(--rl); font-size:13px; font-weight:600; display:flex; align-items:center; gap:9px; box-shadow:var(--shm); animation:toastIn .25s ease; border-left:3px solid var(--b400); max-width:320px; }
.njbiz-toast.success { border-left-color:var(--t500); }
.njbiz-toast.error { border-left-color:var(--red); }
.njbiz-toast.warning { border-left-color:var(--org); }
@keyframes toastIn { from { transform:translateY(12px); opacity:0; } to { transform:translateY(0); opacity:1; } }

/* ── NOTIFICATION PANEL ── */
.notif-panel { position:fixed; top:62px; right:0; width:340px; background:var(--white); border-left:var(--bd); border-bottom:var(--bd); box-shadow:var(--shm); z-index:250; max-height:420px; overflow-y:auto; border-radius:0 0 0 var(--rl); animation:slideIn .2s ease; }
.notif-panel.hidden { display:none; }
@keyframes slideIn { from { transform:translateX(20px); opacity:0; } to { transform:translateX(0); opacity:1; } }
.notif-header { padding:12px 16px; border-bottom:var(--bd); display:flex; justify-content:space-between; align-items:center; }
.notif-item { padding:12px 16px; border-bottom:var(--bd); cursor:pointer; transition:background .13s; display:flex; gap:10px; align-items:flex-start; }
.notif-item:hover { background:var(--s50); }
.notif-item.unread { background:var(--b50); }
.notif-item:last-child { border-bottom:none; }
.notif-icon { width:30px; height:30px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:13px; flex-shrink:0; }
.notif-text { font-size:12px; color:var(--tx7); font-weight:500; line-height:1.5; }
.notif-text strong { color:var(--tx9); font-weight:700; }
.notif-time { font-size:10px; color:var(--tx3); font-weight:600; margin-top:2px; }

/* ── CTA STRIP ── */
.cta-strip { background:linear-gradient(90deg,var(--s800),var(--s700)); padding:38px 4%; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:18px; margin-top:auto; }
.cta-strip h3 { font-family:var(--fn-d); font-size:22px; color:var(--white); margin-bottom:4px; }
.cta-strip p { font-size:13px; color:rgba(255,255,255,.5); font-weight:500; }

/* ── FOOTER ── */
.njbiz-footer { background:var(--s900); color:rgba(255,255,255,.45); padding:44px 4% 24px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:32px; margin-bottom:28px; }
.footer-brand h3 { font-family:var(--fn-d); font-size:17px; color:var(--white); margin-bottom:8px; }
.footer-brand p { font-size:12px; line-height:1.7; font-weight:500; }
.footer-col h4 { font-size:9px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.22); margin-bottom:10px; }
.footer-col a { display:block; font-size:12px; color:rgba(255,255,255,.45); padding:3px 0; cursor:pointer; font-weight:500; transition:color .14s; text-decoration:none; }
.footer-col a:hover { color:#7ec8f0; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.07); padding-top:16px; display:flex; justify-content:space-between; align-items:center; font-size:11px; flex-wrap:wrap; gap:8px; font-weight:600; }

/* ── SUCCESS PAGE ── */
.success-wrap { display:flex; align-items:center; justify-content:center; min-height:calc(100vh - 62px); padding:36px 4%; background:var(--paper); }
.success-card { background:var(--white); border-radius:var(--rxl); padding:40px; max-width:520px; width:100%; text-align:center; box-shadow:var(--shl); border:var(--bd); }
.success-icon { width:64px; height:64px; border-radius:50%; background:var(--t50); border:2px solid var(--grn-bd); display:flex; align-items:center; justify-content:center; font-size:26px; margin:0 auto 20px; }
.success-step { display:flex; align-items:flex-start; gap:11px; padding:12px; background:var(--s50); border-radius:var(--r); margin-bottom:8px; text-align:left; }
.success-step-num { width:24px; height:24px; border-radius:50%; background:var(--b600); color:var(--white); display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:800; flex-shrink:0; }
.success-step-body { font-size:12px; color:var(--tx5); font-weight:600; line-height:1.5; }
.success-step-body strong { color:var(--tx9); display:block; margin-bottom:1px; font-size:12px; }

/* ── BREADCRUMB ── */
.njbiz-breadcrumb { background:var(--white); border-bottom:var(--bd); padding:10px 4%; display:flex; align-items:center; gap:6px; overflow-x:auto; scrollbar-width:none; }
.njbiz-breadcrumb::-webkit-scrollbar { display:none; }
.bc-item { display:flex; align-items:center; gap:6px; font-size:12px; color:var(--tx3); white-space:nowrap; font-weight:600; transition:color .14s; cursor:pointer; text-decoration:none; }
.bc-item:hover { color:var(--b600); }
.bc-item.done { color:var(--t600); }
.bc-item.current { color:var(--tx9); }
.bc-dot { width:19px; height:19px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:9px; font-weight:800; border:2px solid var(--s200); background:var(--white); }
.bc-item.done .bc-dot { border-color:var(--t600); background:var(--t600); color:var(--white); }
.bc-item.current .bc-dot { border-color:var(--b600); background:var(--b600); color:var(--white); }
.bc-sep { color:var(--tx2); font-size:11px; }

/* ── RESPONSIVE ── */
@media (max-width:768px) {
  .nav-links { display:none; }
  .nav-links.mobile-open { display:flex; flex-direction:column; position:fixed; top:62px; left:0; right:0; background:var(--s900); padding:16px; z-index:299; border-bottom:1px solid rgba(255,255,255,.1); }
  .mobile-menu-toggle { display:block; }
  .directory-wrap { flex-direction:column; padding:16px; }
  .dir-sidebar { width:100%; }
  .hero-stats, .footer-grid { display:none; }
  .detail-body, .dashboard-layout, .admin-layout, .checkout-grid { grid-template-columns:1fr; }
  .packages-grid { grid-template-columns:1fr; }
  .stats-row { justify-content:flex-start; overflow-x:auto; }
}
@media (max-width:480px) {
  .njbiz-hero { padding:40px 4% 48px; }
  .njbiz-search-bar { flex-wrap:wrap; }
  .njbiz-search-bar select { min-width:100%; border-right:none; border-bottom:1px solid var(--s200); }
}
