/* ============================================================
   NJ Business Solutions Pro — main.css v3.0.0
   Design: Deep Indigo + Vibrant Blue + Amber/Gold accents
   Featured listings highlighted in warm amber/gold
   Google CWV optimised | Plus Jakarta Sans + Lora
   ============================================================ */

/* ── CUSTOM PROPERTIES ─────────────────────────────────── */
:root {
  /* Primary — deep indigo/navy (richer, more vibrant than old slate) */
  --s900:#151a3a;--s800:#1d2450;--s700:#262f63;--s600:#343f7d;
  --s500:#4a56a0;--s400:#6b76bd;--s300:#9aa2d6;--s200:#c3c8e8;
  --s100:#e2e5f5;--s50:#f3f4fc;
  /* Accent blue — brighter electric blue */
  --b600:#2563eb;--b500:#3b82f6;--b400:#60a5fa;--b100:#bfdbfe;--b50:#eff6ff;
  /* Teal — vibrant */
  --t600:#0d9488;--t500:#14b8a6;--t100:#99f6e4;--t50:#f0fdfa;
  /* Amber/Gold — FEATURED listings highlight */
  --am700:#b45309;--am600:#d97706;--am500:#f59e0b;--am400:#fbbf24;--am100:#fde68a;--am50:#fffbeb;
  --white:#fff;--paper:#f7f8fc;
  --tx9:#13182e;--tx7:#2a3150;--tx5:#4d5575;--tx3:#7e87a8;--tx2:#a8b0cc;
  --red:#ef4444;--org:#f59e0b;--star:#f59e0b;--grn:#14b8a6;
  --bd:1px solid #e7e9f5;--sh:0 2px 14px rgba(21,26,58,.08);
  --sh-am:0 4px 18px rgba(217,119,6,.18);
  --rl:14px;--r:9px;
  --fn-b:'Plus Jakarta Sans',system-ui,sans-serif;
  --fn-d:'Lora',Georgia,serif;
  --grn-bd:#99f6e4;
}

/* ── RESET ─────────────────────────────────────────────── */
*,*::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);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--b600);text-decoration:none}
a:hover{text-decoration:underline}
button{cursor:pointer;font-family:var(--fn-b)}
input,select,textarea{font-family:var(--fn-b)}
h1,h2,h3,h4{font-family:var(--fn-d);color:var(--tx9);line-height:1.25}
.screen-reader-text{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:absolute;top:-100%;left:0;padding:8px 16px;background:var(--s900);color:#fff;z-index:9999;border-radius:0 0 6px 0}
.skip-link:focus{top:0}

/* ── BUTTONS ────────────────────────────────────────────── */
.njbiz-btn{display:inline-flex;align-items:center;gap:5px;padding:9px 18px;border-radius:var(--r);font-size:13px;font-weight:700;font-family:var(--fn-b);border:1.5px solid transparent;transition:all .15s;line-height:1;white-space:nowrap;cursor:pointer;text-decoration:none}
.btn-primary{background:var(--s900);color:#fff;border-color:var(--s900)}
.btn-primary:hover{background:var(--s800);color:#fff;text-decoration:none}
.btn-blue{background:var(--b600);color:#fff;border-color:var(--b600)}
.btn-blue:hover{background:#1254a0;color:#fff;text-decoration:none}
.btn-teal{background:var(--t600);color:#fff;border-color:var(--t600)}
.btn-teal:hover{background:#0c5e49;color:#fff;text-decoration:none}
.btn-outline{background:transparent;color:var(--tx9);border-color:var(--s200)}
.btn-outline:hover{background:var(--s50);color:var(--tx9);text-decoration:none}
.btn-lg{padding:12px 24px;font-size:14px}
.btn-sm{padding:6px 13px;font-size:12px}
.btn-full{width:100%;justify-content:center}

/* ── NAVIGATION ─────────────────────────────────────────── */
.njbiz-nav{display:flex;align-items:center;justify-content:space-between;padding:0 4%;height:62px;background:var(--s900);position:sticky;top:0;z-index:1000;box-shadow:0 2px 16px rgba(0,0,0,.25)}
.nav-logo{display:flex;align-items:center;gap:9px;text-decoration:none}
.nav-logo:hover{text-decoration:none}
.nav-mark{width:34px;height:34px;background:var(--b600);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;color:#fff}
.nav-txt{font-size:14px;font-weight:700;color:#fff;line-height:1.2}
.nav-sub{font-size:10px;color:rgba(255,255,255,.4);font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.nav-links{display:flex;align-items:center;gap:3px}
.nav-link{font-size:13px;font-weight:600;color:rgba(255,255,255,.65);padding:6px 10px;border-radius:6px;transition:all .14s;text-decoration:none}
.nav-link:hover,.nav-link.current{color:#fff;background:rgba(255,255,255,.1);text-decoration:none}
.nav-notif-wrap{position:relative;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;cursor:pointer;color:rgba(255,255,255,.65)}
.nav-notif-wrap:hover{background:rgba(255,255,255,.1)}
.nav-notif-count{position:absolute;top:2px;right:2px;min-width:16px;height:16px;background:var(--red);border-radius:8px;font-size:10px;font-weight:800;color:#fff;display:flex;align-items:center;justify-content:center;padding:0 4px}
.nav-avatar{width:34px;height:34px;border-radius:50%;background:var(--b600);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff;text-decoration:none}
.mobile-menu-toggle{display:none;background:none;border:none;color:#fff;padding:4px}

/* ── NOTIFICATION PANEL ─────────────────────────────────── */
.notif-panel{position:fixed;top:66px;right:16px;width:300px;background:#fff;border:var(--bd);border-radius:var(--rl);box-shadow:0 8px 32px rgba(30,42,58,.18);z-index:2000;overflow:hidden}
.notif-panel.hidden{display:none}
.notif-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:var(--bd)}
.notif-item{display:flex;align-items:flex-start;gap:10px;padding:11px 14px;border-bottom:var(--bd);cursor:pointer}
.notif-item:last-child{border-bottom:none}
.notif-item.unread{background:var(--b50)}
.notif-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.notif-text{font-size:12px;color:var(--tx7);font-weight:500;line-height:1.4}
.notif-time{font-size:11px;color:var(--tx3);font-weight:600;margin-top:3px}

/* ── HERO ───────────────────────────────────────────────── */
.njbiz-hero{background:linear-gradient(135deg,var(--s900) 0%,var(--s700) 60%,#1a4a6b 100%);padding:56px 4% 48px;text-align:center;position:relative;overflow:hidden}
.hero-inner{position:relative;z-index:1;max-width:720px;margin:0 auto}
.hero-tag{display:inline-block;font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.35);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:5px 14px;margin-bottom:14px}
.njbiz-hero h1{font-size:clamp(26px,5vw,48px);color:#fff;font-weight:700;margin-bottom:12px;line-height:1.15}
.njbiz-hero h1 em{font-style:normal;color:#7ec8f0}
.hero-sub{font-size:15px;color:rgba(255,255,255,.55);max-width:480px;margin:0 auto 24px;line-height:1.75;font-weight:500}

/* ── SEARCH BAR ─────────────────────────────────────────── */
.njbiz-search-bar{display:flex;gap:7px;max-width:620px;margin:0 auto 20px;flex-wrap:wrap}
.njbiz-search-bar select,.njbiz-search-bar input{flex:1;min-width:0;padding:11px 14px;border-radius:var(--r);border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.12);color:#fff;font-size:13px;font-weight:600;outline:none}
.njbiz-search-bar select option{background:var(--s800);color:#fff}
.njbiz-search-bar select:focus,.njbiz-search-bar input:focus{border-color:rgba(255,255,255,.4);background:rgba(255,255,255,.18)}
.njbiz-search-bar input::placeholder{color:rgba(255,255,255,.4)}

/* ── HERO STATS ─────────────────────────────────────────── */
.hero-stats{display:flex;align-items:center;justify-content:center;gap:20px;flex-wrap:wrap;margin-top:12px}
.hstat{font-size:13px;color:rgba(255,255,255,.55);font-weight:600;display:flex;align-items:center;gap:5px}
.hstat strong{color:#fff;font-size:15px;font-weight:800}
.hstat-div{width:1px;height:16px;background:rgba(255,255,255,.15)}

/* ── CAT BAR ────────────────────────────────────────────── */
.cat-bar{background:#fff;border-bottom:var(--bd);padding:10px 4%;overflow-x:auto;-webkit-overflow-scrolling:touch}
.cat-pills{display:flex;gap:5px;align-items:center;min-width:max-content}
.cat-label-txt{font-size:11px;color:var(--tx3);font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-right:4px}
.cat-pill{display:inline-flex;align-items:center;gap:4px;padding:6px 13px;border-radius:20px;font-size:12px;font-weight:700;border:1px solid var(--s200);background:#fff;color:var(--tx5);cursor:pointer;white-space:nowrap;transition:all .14s;text-decoration:none}
.cat-pill:hover,.cat-pill.active{background:var(--s900);color:#fff;border-color:var(--s900);text-decoration:none}

/* ── STATS ROW ──────────────────────────────────────────── */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);background:#fff;border-bottom:var(--bd)}
.stat-item{padding:16px;text-align:center;border-right:var(--bd)}
.stat-item:last-child{border-right:none}
.stat-num{font-family:var(--fn-d);font-size:clamp(20px,3vw,28px);font-weight:700;color:var(--b600);line-height:1}
.stat-lbl{font-size:11px;color:var(--tx3);font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-top:3px}

/* ── SECTION HEADERS ────────────────────────────────────── */
.section-header{display:flex;align-items:flex-end;justify-content:space-between;padding:0 4%;margin-bottom:20px;flex-wrap:wrap;gap:10px}
.section-eyebrow{font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--tx3);margin-bottom:5px}
.section-title{font-size:clamp(20px,3vw,28px);font-weight:700;color:var(--tx9)}
.featured-listings-section{padding:40px 0 36px}
.homepage-categories{padding:40px 0;background:var(--s50);border-top:var(--bd);border-bottom:var(--bd)}

/* ── LISTING CARDS ──────────────────────────────────────── */
.listing-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:14px;padding:0 4%}
.listing-card{background:#fff;border:var(--bd);border-radius:var(--rl);padding:16px;cursor:pointer;transition:all .15s;position:relative;overflow:hidden;box-shadow:var(--sh)}
.listing-card:hover{border-color:var(--b400);box-shadow:0 6px 24px rgba(24,95,165,.12);transform:translateY(-2px)}
.listing-card.featured{border:2px solid var(--am400);background:linear-gradient(180deg,var(--am50) 0%,#fff 22%);box-shadow:var(--sh-am)}
.listing-card.featured:hover{border-color:var(--am500);box-shadow:0 8px 28px rgba(217,119,6,.24)}
.listing-card.featured::before{content:'⭐ FEATURED';position:absolute;top:0;right:0;background:linear-gradient(135deg,var(--am500),var(--am600));color:#fff;font-size:9px;font-weight:800;letter-spacing:.06em;padding:4px 12px 4px 14px;border-radius:0 var(--rl) 0 12px}
.listing-logo{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:800;flex-shrink:0;margin-bottom:10px}
.logo-blue{background:var(--b50);color:var(--b600)}
.logo-teal{background:var(--t50);color:var(--t600)}
.logo-slate{background:var(--s100);color:var(--s700)}
.logo-amber{background:var(--am50);color:var(--am600)}
.listing-body{flex:1}
.listing-name-row{display:flex;align-items:center;gap:5px;flex-wrap:wrap;margin-bottom:3px}
.listing-name{font-family:var(--fn-d);font-size:15px;font-weight:600;color:var(--tx9)}
.listing-cat{font-size:11px;color:var(--tx3);font-weight:600}
.listing-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:6px}
.listing-rating{display:flex;align-items:center;gap:4px;flex-shrink:0}
.rating-val{font-size:12px;font-weight:800;color:var(--tx9)}
.rating-count{font-size:11px;color:var(--tx3);font-weight:600}
.listing-desc{font-size:12px;color:var(--tx5);line-height:1.6;margin:8px 0;font-weight:500}
.listing-meta{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.listing-meta-item{font-size:11px;color:var(--tx3);font-weight:700}
.listing-actions{display:flex;gap:7px}
.save-btn{position:absolute;top:12px;right:12px;background:none;border:none;font-size:16px;color:var(--tx3);cursor:pointer;padding:2px;transition:color .14s;line-height:1}
.save-btn:hover,.save-btn.saved{color:var(--red)}

/* ── BADGES ─────────────────────────────────────────────── */
.njbiz-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700}
.badge-blue{background:var(--b50);color:var(--b600)}
.badge-teal{background:var(--t50);color:var(--t600)}
.badge-slate{background:var(--s100);color:var(--s700)}
.badge-org{background:var(--am50);color:var(--am700)}
.badge-amber{background:linear-gradient(135deg,var(--am400),var(--am500));color:#fff;font-weight:800}
.listing-card.featured .save-btn{top:30px}

/* ── CTA STRIP ──────────────────────────────────────────── */
.cta-strip,.cta-sc{background:var(--s900);padding:32px 4%;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.cta-strip h3,.cta-sc h3{font-family:var(--fn-d);font-size:clamp(18px,3vw,24px);font-weight:700;color:#fff;margin-bottom:5px}
.cta-strip p,.cta-sc p{font-size:13px;color:rgba(255,255,255,.55);font-weight:500}

/* ── AI MATCH PROMO ─────────────────────────────────────── */
.ai-match-promo{background:linear-gradient(135deg,var(--t500),var(--t600));padding:48px 4%;text-align:center}
.aip-inner{max-width:560px;margin:0 auto}
.aip-badge{display:inline-block;font-size:10px;font-weight:800;color:var(--t600);background:#fff;border-radius:20px;padding:3px 12px;letter-spacing:.06em;text-transform:uppercase;margin-bottom:12px}
.ai-match-promo h2{font-family:var(--fn-d);font-size:clamp(22px,4vw,34px);font-weight:700;color:#fff;margin-bottom:10px}
.ai-match-promo p{font-size:14px;color:rgba(255,255,255,.7);margin-bottom:22px;font-weight:500}

/* ── BLOG GRID ──────────────────────────────────────────── */
.homepage-blog{padding:40px 0 0;background:#fff;border-top:var(--bd)}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.blog-card{background:#fff;border:var(--bd);border-radius:var(--rl);overflow:hidden;cursor:pointer;transition:all .15s;box-shadow:var(--sh)}
.blog-card:hover{border-color:var(--b400);box-shadow:0 6px 20px rgba(24,95,165,.1);transform:translateY(-2px)}
.blog-img{height:90px;background:var(--s50);display:flex;align-items:center;justify-content:center;font-size:32px}
.blog-body{padding:14px}
.blog-tag{font-size:10px;font-weight:800;color:var(--b600);text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px}
.blog-title{font-family:var(--fn-d);font-size:14px;font-weight:600;color:var(--tx9);margin-bottom:6px;line-height:1.4}
.blog-excerpt{font-size:12px;color:var(--tx5);line-height:1.55;font-weight:500;margin-bottom:8px}
.blog-meta-row{display:flex;justify-content:space-between;font-size:11px;color:var(--tx3);font-weight:700}

/* ── FORMS ──────────────────────────────────────────────── */
.njbiz-card{background:#fff;border:var(--bd);border-radius:var(--rl);padding:20px;box-shadow:var(--sh)}
.njbiz-field{margin-bottom:12px}
.njbiz-field label{display:block;font-size:12px;font-weight:700;color:var(--tx5);margin-bottom:5px;text-transform:uppercase;letter-spacing:.04em}
.njbiz-field input,.njbiz-field select,.njbiz-field textarea{width:100%;padding:10px 12px;border:1.5px solid var(--s200);border-radius:var(--r);font-size:13px;font-weight:500;color:var(--tx9);background:#fff;outline:none;transition:border-color .14s}
.njbiz-field input:focus,.njbiz-field select:focus,.njbiz-field textarea:focus{border-color:var(--b600)}
.njbiz-field textarea{height:90px;resize:vertical}
.njbiz-field input.error,.njbiz-field textarea.error{border-color:var(--red)}
.field-error{font-size:11px;color:var(--red);font-weight:700;margin-top:4px;display:none}
.field-error.show{display:block}

/* ── MODALS ─────────────────────────────────────────────── */
.njbiz-modal-overlay{display:none;position:fixed;inset:0;background:rgba(30,42,58,.55);z-index:3000;align-items:center;justify-content:center;padding:16px;backdrop-filter:blur(3px)}
.njbiz-modal-overlay.open{display:flex}
.njbiz-modal-box{background:#fff;border-radius:var(--rl);padding:24px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px rgba(30,42,58,.25)}
.modal-title{font-family:var(--fn-d);font-size:20px;font-weight:700;color:var(--tx9);margin-bottom:4px}
.modal-subtitle{font-size:12px;color:var(--tx3);font-weight:600;margin-bottom:16px}
.modal-close-btn{position:absolute;top:14px;right:14px;background:var(--s50);border:none;border-radius:6px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:13px;cursor:pointer;color:var(--tx5)}
.modal-close-btn:hover{background:var(--s100)}

/* ── TOASTS ─────────────────────────────────────────────── */
#njbiz-toasts{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.njbiz-toast{background:var(--s900);color:#fff;padding:11px 18px;border-radius:var(--r);font-size:13px;font-weight:600;box-shadow:0 4px 20px rgba(30,42,58,.3);animation:slideInToast .25s ease;display:flex;align-items:center;gap:9px;max-width:320px}
.njbiz-toast.toast-ok{background:var(--t600)}
.njbiz-toast.toast-warn{background:#854f0b}
.njbiz-toast.toast-error{background:#a32d2d}
@keyframes slideInToast{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:none}}

/* ── BREADCRUMB ─────────────────────────────────────────── */
.njbiz-breadcrumb{display:flex;align-items:center;gap:6px;padding:12px 4%;background:#fff;border-bottom:var(--bd);flex-wrap:wrap}
.bc-item{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:700;color:var(--tx3);text-decoration:none}
.bc-item.done{color:var(--b600)}
.bc-item.current{color:var(--tx9)}
.bc-dot{width:18px;height:18px;border-radius:50%;background:var(--s100);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:800;color:var(--tx5);flex-shrink:0}
.bc-item.done .bc-dot{background:var(--b600);color:#fff}
.bc-sep{color:var(--tx2);font-size:12px}

/* ── DIRECTORY ──────────────────────────────────────────── */
.directory-wrap{display:grid;grid-template-columns:230px 1fr;gap:16px;padding:24px 4% 48px;align-items:start}
.dir-sidebar{background:#fff;border:var(--bd);border-radius:var(--rl);padding:16px;box-shadow:var(--sh);position:sticky;top:78px}
.sidebar-box{margin-bottom:16px;padding-bottom:16px;border-bottom:var(--bd)}
.sidebar-box:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}
.sidebar-title{font-size:11px;font-weight:800;color:var(--tx3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}
.filter-row{margin-bottom:6px;font-size:12px;font-weight:600;color:var(--tx7)}
.filter-row label{display:flex;align-items:center;gap:7px;cursor:pointer}
.filter-count{font-size:10px;color:var(--tx3);margin-left:auto}
.filter-range{width:100%;accent-color:var(--b600)}
.sb-promo{background:linear-gradient(135deg,var(--s900),var(--s800));border-radius:var(--r);padding:14px;text-align:center;margin-top:4px}
.sb-promo h4{font-family:var(--fn-d);font-size:13px;color:#fff;margin-bottom:5px}
.sb-promo p{font-size:11px;color:rgba(255,255,255,.45);margin-bottom:10px;font-weight:500}
.listings-main{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}
.sort-select{padding:7px 11px;border:var(--bd);border-radius:var(--r);font-size:12px;font-weight:600;color:var(--tx7);background:#fff;outline:none}
.pagination{display:flex;gap:6px;justify-content:center;margin-top:24px;flex-wrap:wrap}
.page-btn{padding:7px 13px;border:var(--bd);border-radius:var(--r);font-size:12px;font-weight:700;background:#fff;color:var(--tx7);cursor:pointer;transition:all .14s}
.page-btn:hover,.page-btn.active{background:var(--s900);color:#fff;border-color:var(--s900)}

/* ── LISTING DETAIL ─────────────────────────────────────── */
.detail-hero-bar{background:#fff;border-bottom:var(--bd);padding:20px 4%}
.detail-header{display:flex;gap:16px;align-items:flex-start;flex-wrap:wrap}
.detail-logo{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;flex-shrink:0}
.detail-name{font-family:var(--fn-d);font-size:clamp(20px,4vw,28px);font-weight:700;color:var(--tx9);margin-bottom:6px}
.detail-meta-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px}
.detail-body{display:grid;grid-template-columns:1fr 280px;gap:16px;padding:20px 4% 48px;align-items:start}
.detail-section{background:#fff;border:var(--bd);border-radius:var(--rl);padding:18px;margin-bottom:12px;box-shadow:var(--sh)}
.detail-section h3{font-family:var(--fn-d);font-size:17px;font-weight:600;margin-bottom:12px;color:var(--tx9)}
.detail-sidebar-card{background:#fff;border:var(--bd);border-radius:var(--rl);padding:16px;margin-bottom:12px;box-shadow:var(--sh)}
.contact-row{display:flex;align-items:flex-start;gap:10px;padding:9px 0;border-bottom:var(--bd)}
.contact-row:last-of-type{border-bottom:none}
.contact-icon{font-size:16px;flex-shrink:0;width:20px;text-align:center}
.contact-lbl{font-size:10px;font-weight:700;color:var(--tx3);text-transform:uppercase;letter-spacing:.04em}
.contact-val{font-size:13px;font-weight:600;color:var(--tx9)}
.service-tags{display:flex;flex-wrap:wrap;gap:6px}
.service-tag{padding:5px 11px;background:var(--s50);border:var(--bd);border-radius:20px;font-size:11px;font-weight:700;color:var(--tx5)}
.review-card{background:var(--s50);border-radius:var(--r);padding:13px;margin-bottom:10px}
.reviewer-av{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;flex-shrink:0}
.stars-picker{display:flex;gap:5px;font-size:28px;cursor:pointer;color:var(--s200)}
.stars-picker span:hover,.stars-picker span.active{color:var(--star)}
.map-placeholder{background:var(--s50);border:var(--bd);border-radius:var(--r);padding:16px;font-size:12px;color:var(--tx5);font-weight:600;margin-bottom:10px;text-align:center}

/* ── CONSULTING ─────────────────────────────────────────── */
.consulting-hero{background:linear-gradient(135deg,var(--s900),var(--s700));padding:52px 4%;text-align:center;position:relative;overflow:hidden}
.consulting-hero h1{font-size:clamp(24px,4vw,40px);color:#fff;font-weight:700;margin-bottom:10px}
.packages-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;padding:40px 4% 32px;max-width:1000px;margin:0 auto}
.package-card{background:#fff;border:var(--bd);border-radius:var(--rl);padding:28px 24px;box-shadow:var(--sh);position:relative;transition:all .18s;display:flex;flex-direction:column}
.package-card:hover{box-shadow:0 10px 32px rgba(37,99,235,.14);transform:translateY(-4px);border-color:var(--b400)}
.package-card.popular{border:2px solid var(--am400);background:linear-gradient(180deg,var(--am50) 0%,#fff 14%);box-shadow:var(--sh-am);transform:scale(1.03)}
.package-card.popular:hover{box-shadow:0 12px 36px rgba(217,119,6,.22);transform:scale(1.03) translateY(-4px)}
.popular-tag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--am500),var(--am600));color:#fff;font-size:11px;font-weight:800;letter-spacing:.04em;padding:5px 16px;border-radius:20px;white-space:nowrap;box-shadow:0 3px 10px rgba(217,119,6,.35)}
.package-name{font-family:var(--fn-d);font-size:21px;font-weight:700;margin-bottom:3px;color:var(--tx9)}
.package-price{font-size:42px;font-weight:800;color:var(--s900);line-height:1;margin-bottom:3px}
.package-card.popular .package-price{color:var(--am700)}
.package-sub{font-size:11px;color:var(--tx3);font-weight:700;margin-bottom:18px;text-transform:uppercase;letter-spacing:.04em}
.package-features{list-style:none;margin-bottom:20px;flex:1}
.package-features li{font-size:13px;color:var(--tx5);font-weight:500;padding:7px 0;border-bottom:var(--bd);display:flex;align-items:flex-start;gap:8px;line-height:1.4}
.package-features li::before{content:'✓';color:var(--t600);font-weight:800;flex-shrink:0;margin-top:1px}
.package-card.popular .package-features li::before{color:var(--am600)}

/* ── CHECKOUT ───────────────────────────────────────────── */
.checkout-grid{display:grid;grid-template-columns:1fr 300px;gap:20px;padding:24px 4% 48px;align-items:start;max-width:960px;margin:0 auto}
.order-summary-card{background:#fff;border:var(--bd);border-radius:var(--rl);padding:18px;position:sticky;top:78px;box-shadow:var(--sh)}
.os-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:var(--bd);font-size:13px;color:var(--tx5);font-weight:600}
.os-row.total{border-bottom:none;padding-top:12px;margin-top:4px}
.step-bar{display:flex;align-items:center;justify-content:center;padding:16px 4%;background:#fff;border-bottom:var(--bd)}
.step-group{display:flex;flex-direction:column;align-items:center;gap:4px}
.step-dot{width:28px;height:28px;border-radius:50%;background:var(--s100);color:var(--tx3);font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .2s}
.step-dot.active{background:var(--b600);color:#fff}
.step-dot.done{background:var(--t600);color:#fff}
.step-label{font-size:10px;font-weight:700;color:var(--tx3);text-transform:uppercase;letter-spacing:.05em}
.step-label.active{color:var(--b600)}
.step-line{width:60px;height:2px;background:var(--s100);margin:0 4px 16px;transition:background .2s}
.step-line.done{background:var(--t600)}
.success-card{background:#fff;border:var(--bd);border-radius:var(--rl);padding:32px 24px;text-align:center;box-shadow:var(--sh)}
.success-icon{width:60px;height:60px;border-radius:50%;background:var(--t50);color:var(--t600);font-size:26px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;border:3px solid var(--t100)}
.success-step{display:flex;align-items:flex-start;gap:10px;text-align:left;margin-bottom:12px}
.success-step-num{width:24px;height:24px;border-radius:50%;background:var(--b600);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.success-step-body strong{display:block;font-size:13px;font-weight:700;color:var(--tx9);margin-bottom:2px}

/* ── DASHBOARD ──────────────────────────────────────────── */
.dashboard-layout{display:grid;grid-template-columns:220px 1fr;min-height:calc(100vh - 62px)}
.dash-sidebar{background:var(--s900)}
.dash-sidebar-header{padding:16px 16px 14px;border-bottom:1px solid rgba(255,255,255,.07)}
.dash-biz-label{font-size:9px;color:rgba(255,255,255,.22);text-transform:uppercase;letter-spacing:.08em;margin-bottom:2px;font-weight:800}
.dash-biz-name{font-size:13px;color:#fff;font-weight:700;line-height:1.3}
.dash-biz-status{font-size:10px;color:rgba(255,255,255,.35);font-weight:600;margin-top:2px}
.dash-nav-item{display:flex;align-items:center;gap:9px;padding:10px 16px;font-size:12px;font-weight:700;color:rgba(255,255,255,.55);cursor:pointer;transition:all .14s;text-decoration:none;position:relative}
.dash-nav-item:hover,.dash-nav-item.active{background:rgba(255,255,255,.08);color:#fff;text-decoration:none}
.dash-nav-item.active{border-right:3px solid var(--b400)}
.dash-nav-badge{background:var(--red);color:#fff;font-size:10px;font-weight:800;min-width:18px;height:18px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;padding:0 4px;margin-left:auto}
.dash-nav-sep{height:1px;background:rgba(255,255,255,.07);margin:6px 0}
.dash-main{background:var(--paper);padding:24px;overflow:auto;min-width:0}
.dash-topbar{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:10px;flex-wrap:wrap}
.metrics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-bottom:20px}
.metric-card{background:#fff;border:var(--bd);border-radius:var(--rl);padding:14px 16px;box-shadow:var(--sh)}
.metric-label{font-size:10px;font-weight:800;color:var(--tx3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.metric-value{font-size:clamp(22px,4vw,30px);font-weight:800;color:var(--tx9);line-height:1;margin-bottom:4px}
.metric-change{font-size:11px;font-weight:700}
.metric-up{color:var(--t600)}
.metric-neutral{color:var(--tx3)}
.metric-special{color:var(--b600)}
.lead-row{display:flex;align-items:center;gap:11px;padding:12px 16px;border-bottom:var(--bd);cursor:pointer;transition:background .13s;position:relative}
.lead-row:hover{background:var(--s50)}
.lead-row:last-child{border-bottom:none}
.lead-av{width:34px;height:34px;border-radius:50%;background:var(--b100);color:var(--b600);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex-shrink:0}
.lead-unread-tag{position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--b600);border-radius:0 2px 2px 0}
.lead-info{flex:1;min-width:0}
.lead-name{font-size:12px;font-weight:700;color:var(--tx9)}
.lead-msg{font-size:11px;color:var(--tx3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}
.lead-time{font-size:10px;color:var(--tx2);white-space:nowrap;font-weight:600}
.lf-pill{padding:5px 12px;border-radius:20px;font-size:12px;font-weight:700;cursor:pointer;border:var(--bd);background:#fff;color:var(--tx5);transition:all .13s}
.lf-pill.active{background:var(--b600);color:#fff;border-color:var(--b600)}
.chart-wrap{display:flex;align-items:flex-end;gap:4px;height:64px}

/* ── ADMIN ──────────────────────────────────────────────── */
.admin-layout{display:grid;grid-template-columns:220px 1fr;min-height:calc(100vh - 62px)}
.admin-sidebar{background:var(--s900);overflow-y:auto}
.admin-nav-item{display:flex;align-items:center;gap:8px;padding:10px 16px;font-size:12px;font-weight:700;color:rgba(255,255,255,.55);cursor:pointer;transition:all .14s;text-decoration:none}
.admin-nav-item:hover,.admin-nav-item.active{background:rgba(255,255,255,.09);color:#fff;text-decoration:none}
.admin-nav-section{font-size:9px;color:rgba(255,255,255,.22);text-transform:uppercase;letter-spacing:.1em;padding:8px 16px 3px;font-weight:800}
.admin-nav-badge{background:var(--red);color:#fff;font-size:10px;font-weight:800;min-width:18px;height:18px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;padding:0 4px;margin-left:auto}
.admin-nav-sep{height:1px;background:rgba(255,255,255,.07);margin:6px 0}

/* ── TABLES ─────────────────────────────────────────────── */
.njbiz-table-wrap{background:#fff;border:var(--bd);border-radius:var(--rl);overflow:hidden;box-shadow:var(--sh)}
.table-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:var(--bd)}
.table-header h3{font-family:var(--fn-d);font-size:15px;font-weight:600;color:var(--tx9)}
.njbiz-table{width:100%;border-collapse:collapse}
.njbiz-table th{font-size:10px;font-weight:800;color:var(--tx3);text-transform:uppercase;letter-spacing:.05em;padding:10px 14px;border-bottom:var(--bd);background:var(--s50);text-align:left;white-space:nowrap}
.njbiz-table td{font-size:12px;color:var(--tx5);padding:11px 14px;border-bottom:var(--bd);font-weight:500}
.njbiz-table tr:last-child td{border-bottom:none}
.njbiz-table tr:hover td{background:var(--s50)}
.tbl-action{background:none;border:none;color:var(--b600);font-size:12px;font-weight:700;cursor:pointer;padding:0}
.tbl-action:hover{text-decoration:underline}
.tbl-action.danger{color:var(--red)}

/* ── STATUS DOTS ────────────────────────────────────────── */
.status-dot{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700}
.status-dot::before{content:'';width:7px;height:7px;border-radius:50%;flex-shrink:0}
.status-active::before{background:var(--t600)}
.status-pending::before{background:var(--org)}
.status-inactive::before,.status-rejected::before{background:var(--red)}

/* ── RESOURCES ──────────────────────────────────────────── */
.grant-card{background:#fff;border:var(--bd);border-radius:var(--r);padding:14px 16px;margin-bottom:8px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;cursor:pointer;transition:all .15s;box-shadow:var(--sh)}
.grant-card:hover{border-color:var(--b400)}
.grant-amount{font-size:clamp(16px,3vw,22px);font-weight:800;color:var(--t600);flex-shrink:0;min-width:90px}
.grant-info{flex:1;min-width:160px}
.grant-name{font-size:13px;font-weight:700;color:var(--tx9);margin-bottom:2px}
.grant-detail{font-size:11px;color:var(--tx3);font-weight:500}
.grant-deadline{font-size:10px;color:var(--tx3);font-weight:700;margin-top:3px}

/* ── CATEGORY GRID ──────────────────────────────────────── */
.njbiz-cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;padding:0 4% 8px}
.cat-grid-item{display:flex;flex-direction:column;align-items:center;padding:16px 10px;background:#fff;border:var(--bd);border-radius:var(--rl);text-align:center;cursor:pointer;transition:all .15s;text-decoration:none;box-shadow:var(--sh)}
.cat-grid-item:hover{border-color:var(--b400);background:var(--b50);transform:translateY(-2px);text-decoration:none}
.cgi-icon{font-size:26px;margin-bottom:7px}
.cgi-name{font-size:12px;font-weight:700;color:var(--tx9);margin-bottom:3px}
.cgi-count{font-size:10px;color:var(--tx3);font-weight:700}

/* ── SHORTCODE GRIDS ────────────────────────────────────── */
.njbiz-listing-grid-sc{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-bottom:20px}
.lgs-card{display:block;background:#fff;border:var(--bd);border-radius:var(--rl);padding:16px;text-align:center;cursor:pointer;transition:all .15s;text-decoration:none;box-shadow:var(--sh)}
.lgs-card:hover{border-color:var(--b400);transform:translateY(-2px);text-decoration:none}
.lgs-logo{width:52px;height:52px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;margin:0 auto 8px}
.lgs-name{font-size:13px;font-weight:700;color:var(--tx9);margin-bottom:3px}
.lgs-cat,.lgs-loc{font-size:11px;color:var(--tx3);font-weight:600;margin-bottom:2px}
.lgs-rating{font-size:11px;color:var(--star);font-weight:700;margin-top:5px}
.lgs-badge{display:inline-block;font-size:10px;font-weight:700;padding:2px 8px;background:var(--b50);color:var(--b600);border-radius:4px;margin-top:5px}
.njbiz-grants-sc{margin-bottom:20px}
.grant-row{display:flex;align-items:center;gap:14px;padding:14px;background:#fff;border:var(--bd);border-radius:var(--r);margin-bottom:8px;flex-wrap:wrap;box-shadow:var(--sh)}
.njbiz-stats-row-sc{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));background:#fff;border:var(--bd);border-radius:var(--rl);overflow:hidden;margin-bottom:20px}
.sr-item{padding:20px;text-align:center;border-right:var(--bd)}
.sr-item:last-child{border-right:none}
.sr-num{font-size:clamp(22px,4vw,32px);font-weight:800;color:var(--b600);line-height:1;margin-bottom:4px}
.sr-lbl{font-size:11px;color:var(--tx3);font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.njbiz-sc-title{font-family:var(--fn-d);font-size:clamp(22px,4vw,32px);font-weight:700;margin-bottom:20px;color:var(--tx9)}

/* ── WIDGETS ────────────────────────────────────────────── */
.njbiz-widget{margin-bottom:0}
.njbiz-widget-title{font-family:var(--fn-d);font-size:16px;font-weight:600;color:var(--tx9);margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid var(--b600);display:inline-block}
.njbiz-widget-listing-card{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:var(--bd);text-decoration:none}
.njbiz-widget-listing-card:last-child{border-bottom:none}
.wlc-logo{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex-shrink:0}
.wlc-name{font-size:13px;font-weight:600;color:var(--tx9)}
.wlc-rating{font-size:11px;color:var(--tx3)}
.njbiz-stats-widget{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;text-align:center}
.sw-num{font-size:24px;font-weight:800;color:var(--b600);line-height:1;margin-bottom:2px}
.sw-lbl{font-size:10px;color:var(--tx3);font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.njbiz-grant-widget .gw-item{padding:9px 0;border-bottom:var(--bd)}
.njbiz-grant-widget .gw-item:last-child{border-bottom:none}
.gw-amt{font-size:15px;font-weight:800;color:var(--t600);margin-bottom:2px}
.gw-name{font-size:12px;font-weight:600;color:var(--tx9);margin-bottom:1px}
.gw-dead{font-size:10px;color:var(--tx3);font-weight:700}
.njbiz-cta-widget{background:linear-gradient(135deg,var(--s900),var(--s700));border-radius:var(--r);padding:16px;text-align:center}
.njbiz-cta-widget h3{font-family:var(--fn-d);font-size:15px;color:#fff;margin-bottom:5px}
.njbiz-cta-widget p{font-size:12px;color:rgba(255,255,255,.5);margin-bottom:12px;font-weight:500}
.njbiz-cat-grid-widget{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:6px}
.cgw-item{display:flex;flex-direction:column;align-items:center;padding:10px 6px;background:var(--s50);border:var(--bd);border-radius:var(--r);text-align:center;text-decoration:none;transition:all .14s}
.cgw-item:hover{background:var(--b50);border-color:var(--b400);text-decoration:none}
.cgw-icon{font-size:20px;margin-bottom:4px}
.cgw-name{font-size:10px;font-weight:700;color:var(--tx9);margin-bottom:1px}
.cgw-count{font-size:9px;color:var(--tx3);font-weight:700}
.njbiz-compliance-widget .comp-item{padding:9px 0;border-bottom:var(--bd)}
.comp-item:last-child{border-bottom:none}
.comp-name{font-size:12px;font-weight:700;color:var(--tx9)}
.comp-date{font-size:11px;color:var(--tx3);font-weight:600;margin-top:1px}
.comp-days{font-size:11px;font-weight:700;color:var(--b600);margin-top:1px}
.njbiz-search-widget-form{display:flex;flex-direction:column;gap:7px}
.nsw-cat,.nsw-kw{padding:9px 10px;border:1.5px solid var(--s200);border-radius:var(--r);font-size:12px;font-weight:600;outline:none;width:100%}
.nsw-btn{width:100%;justify-content:center}
.njbiz-reviews-widget .rvw-item{padding:10px 0;border-bottom:var(--bd)}
.rvw-item:last-child{border-bottom:none}
.rvw-stars{color:var(--star);font-size:12px;margin-bottom:3px}
.rvw-text{font-size:12px;color:var(--tx5);font-weight:500;margin-bottom:3px;line-height:1.4}
.rvw-meta{font-size:10px;color:var(--tx3);font-weight:700}
.rvw-meta a{color:var(--b600)}

/* ── PAGE CONTENT ───────────────────────────────────────── */
.page-content-wrap{max-width:900px;margin:0 auto;padding:40px 4%}
.page-content-wrap h1,.page-content-wrap h2{font-family:var(--fn-d);margin-bottom:16px}
.page-content-wrap p{color:var(--tx5);margin-bottom:16px;line-height:1.7}

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

/* ── AI MATCH PAGE ──────────────────────────────────────── */
.ai-match-page{padding:32px 4%}
.match-card{background:#fff;border:2px solid var(--b100);border-radius:var(--rl);padding:16px;box-shadow:var(--sh)}
.match-rank{background:var(--b600);color:#fff;width:24px;height:24px;border-radius:50%;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;margin-bottom:10px}
.match-reason{font-size:11px;color:var(--t600);font-weight:700;padding:2px 0;display:flex;align-items:center;gap:5px}
.match-reason::before{content:'✓';flex-shrink:0}

/* ── COMPLIANCE ─────────────────────────────────────────── */
.compliance-page{padding:32px 4% 48px}
.comp-card{background:#fff;border:var(--bd);border-radius:var(--rl);padding:16px;box-shadow:var(--sh)}
.comp-urgency{font-size:10px;font-weight:700;padding:2px 8px;border-radius:4px}
.comp-urgency.urgent{background:var(--red);color:#fff}
.comp-urgency.warning{background:var(--org);color:#fff}
.comp-urgency.ok{background:var(--t50);color:var(--t600)}

/* ── COUNTY HUB ─────────────────────────────────────────── */
.county-hub-hero{background:linear-gradient(135deg,var(--s900),var(--s700));padding:40px 4%;color:#fff}
.county-hub-hero h1{font-size:clamp(24px,4vw,38px);margin-bottom:6px}
.county-hub-body{padding:32px 4% 48px}

/* ── RESPONSIVE ─────────────────────────────────────────── */
@media(max-width:768px){
  .dashboard-layout,.admin-layout{grid-template-columns:1fr}
  .dash-sidebar,.admin-sidebar{display:none}
  .directory-wrap{grid-template-columns:1fr}
  .dir-sidebar{position:static}
  .detail-body{grid-template-columns:1fr}
  .checkout-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .nav-links{display:none;flex-direction:column;position:absolute;top:62px;left:0;right:0;background:var(--s900);padding:12px 4%;gap:0;border-top:1px solid rgba(255,255,255,.1)}
  .nav-links.open{display:flex}
  .nav-link{padding:12px 8px;width:100%}
  .mobile-menu-toggle{display:block}
  .njbiz-search-bar{flex-direction:column}
  .njbiz-search-bar select,.njbiz-search-bar input{width:100%}
}
@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr}
  .stats-row{grid-template-columns:1fr 1fr}
  .listing-cards-grid{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}
