/* ════════════════════════════════════════════════════════════════
   ToolBaz Tools Directory Pro — v2.1  |  Premium White UI
   Clean · Modern · Futuristic · AdSense-Ready · Mobile-First
   ════════════════════════════════════════════════════════════════ */

/* ── Design Tokens ──────────────────────────────────────────── */
.tbz2 {
  --c-bg:          #ffffff;
  --c-bg-2:        #f8fafc;
  --c-surface:     #ffffff;
  --c-surface-2:   #f1f5f9;
  --c-surface-3:   #e8eef6;
  --c-border:      #e2e8f0;
  --c-border-h:    #c7b8ff;
  --c-text:        #0f172a;
  --c-muted:       #64748b;
  --c-muted-2:     #94a3b8;

  /* Brand */
  --c-violet:      #7c3aed;
  --c-indigo:      #6366f1;
  --c-cyan:        #0ea5e9;
  --c-grad:        linear-gradient(135deg, #7c3aed 0%, #6366f1 55%, #0ea5e9 100%);
  --c-grad-soft:   linear-gradient(135deg, rgba(99,102,241,.08) 0%, rgba(14,165,233,.06) 100%);

  /* Badges */
  --c-popular:     #f59e0b;
  --c-new:         #10b981;

  /* Shape / Shadow */
  --r-card:        16px;
  --r-chip:        999px;
  --r-input:       12px;
  --shadow-sm:     0 1px 4px rgba(15,23,42,.06), 0 4px 16px rgba(15,23,42,.06);
  --shadow-hover:  0 8px 32px rgba(99,102,241,.14), 0 0 0 1px rgba(99,102,241,.18);
  --blur-glass:    saturate(160%) blur(16px);

  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  font-feature-settings: "cv02","cv03","cv04","cv11";

  position: relative;
  max-width: 1400px;
  margin: 0 auto;
  padding: 26px 24px 44px;
  background: var(--c-bg);
  color: var(--c-text);
  border-radius: 24px;
  overflow: hidden;
  isolation: isolate;
}

.tbz2 *, .tbz2 *::before, .tbz2 *::after { box-sizing: border-box; }
.tbz2 a { color: inherit; }

/* ── Subtle top orbs (very light on white) ──────────────────── */
.tbz2-aurora { position:absolute; inset:0; pointer-events:none; z-index:-1; overflow:hidden; }
.tbz2-aurora__orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(100px);
}
.tbz2-aurora__orb--1 { width:480px; height:480px; background:radial-gradient(circle,#7c3aed,transparent 70%); top:-200px; left:-160px; opacity:.06; }
.tbz2-aurora__orb--2 { width:400px; height:400px; background:radial-gradient(circle,#0ea5e9,transparent 70%); bottom:-180px; right:-140px; opacity:.05; }
.tbz2-aurora__orb--3 { width:320px; height:320px; background:radial-gradient(circle,#6366f1,transparent 70%); top:38%; left:52%; transform:translate(-50%,-50%); opacity:.04; }

/* ── Hero ────────────────────────────────────────────────────── */
.tbz2-hero {
  text-align: center;
  padding: 14px 0 20px;
  max-width: 820px;
  margin: 0 auto;
}

.tbz2-hero__pill {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 5px 14px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--c-indigo);
  border: 1px solid rgba(99,102,241,.22);
  border-radius: var(--r-chip);
  background: rgba(99,102,241,.06);
  margin-bottom: 12px;
}
.tbz2-hero__dot {
  display: block; width:6px; height:6px; border-radius:50%;
  background: var(--c-indigo);
  animation: tbz2-pulse 2.4s ease-in-out infinite;
}
@keyframes tbz2-pulse {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:.4; transform:scale(.7); }
}

.tbz2-hero__h1 {
  font-size: clamp(26px, 3.6vw, 42px);
  font-weight: 800;
  line-height: 1.1;
  letter-spacing: -.025em;
  margin: 0 0 10px;
  color: var(--c-text);
}
.tbz2-gradient-text {
  background: var(--c-grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.tbz2-hero__sub {
  font-size: clamp(14px, 1.5vw, 16px);
  line-height: 1.65;
  color: var(--c-muted);
  max-width: 600px;
  margin: 0 auto 14px;
}

/* Compact counter badge */
.tbz2-hero__counter {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  border-radius: var(--r-chip);
}
.tbz2-hero__counter-num {
  font-size: 14px;
  font-weight: 800;
  background: var(--c-grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.tbz2-hero__counter-lbl {
  font-size: 12px;
  color: var(--c-muted);
  font-weight: 500;
}

/* ── Sticky Controls ────────────────────────────────────────── */
.tbz2-controls {
  position: sticky;
  top: 10px;
  z-index: 50;
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 12px 14px;
  margin: 0 0 34px;
  background: rgba(255,255,255,.88);
  backdrop-filter: var(--blur-glass);
  -webkit-backdrop-filter: var(--blur-glass);
  border: 1px solid var(--c-border);
  border-radius: 18px;
  box-shadow: var(--shadow-sm);
}

/* Search */
.tbz2-search { position: relative; }
.tbz2-search__icon {
  position:absolute; left:14px; top:50%; transform:translateY(-50%);
  color:var(--c-muted); pointer-events:none;
}
.tbz2-search input {
  width:100%; padding:12px 50px 12px 42px;
  font-size:14px; font-family:inherit;
  color:var(--c-text); background:var(--c-bg-2);
  border:1px solid var(--c-border); border-radius:var(--r-input);
  outline:none; transition:border-color .2s,box-shadow .2s;
}
.tbz2-search input::placeholder { color:var(--c-muted-2); }
.tbz2-search input:focus {
  border-color:var(--c-indigo);
  box-shadow:0 0 0 3px rgba(99,102,241,.14);
}
.tbz2-search__kbd {
  position:absolute; right:12px; top:50%; transform:translateY(-50%);
  font-size:10.5px; font-family:inherit; color:var(--c-muted-2);
  background:#fff; border:1px solid var(--c-border);
  border-radius:5px; padding:2px 6px; pointer-events:none;
}

/* Chips */
.tbz2-filters {
  display:flex; flex-wrap:wrap; gap:6px;
  overflow-x:auto; -webkit-overflow-scrolling:touch; scrollbar-width:none;
}
.tbz2-filters::-webkit-scrollbar { display:none; }

.tbz2-chip {
  display:inline-flex; align-items:center; gap:5px; flex:0 0 auto;
  padding:7px 13px;
  font-size:12.5px; font-weight:600; font-family:inherit;
  color:var(--c-muted);
  background:var(--c-surface-2); border:1px solid var(--c-border);
  border-radius:var(--r-chip); cursor:pointer;
  transition:color .18s,background .18s,border-color .18s,box-shadow .18s,transform .14s;
  -webkit-user-select:none; user-select:none;
}
.tbz2-chip:hover { color:var(--c-text); border-color:#c4b5fd; background:rgba(99,102,241,.05); transform:translateY(-1px); }
.tbz2-chip--active {
  color:#fff; background:var(--c-grad); border-color:transparent;
  box-shadow:0 3px 14px rgba(99,102,241,.28);
}
.tbz2-chip--active:hover { transform:translateY(-1px); }

.tbz2-chip__count {
  display:inline-grid; place-items:center;
  min-width:18px; height:17px; padding:0 5px;
  font-size:10.5px; font-weight:700;
  border-radius:999px;
}
.tbz2-chip:not(.tbz2-chip--active) .tbz2-chip__count {
  color:var(--c-indigo); background:rgba(99,102,241,.1);
}
.tbz2-chip--active .tbz2-chip__count {
  color:var(--c-indigo); background:rgba(255,255,255,.9);
}

/* ── Sections ───────────────────────────────────────────────── */
.tbz2-main { display:flex; flex-direction:column; gap:36px; }

.tbz2-section__head {
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  margin-bottom:16px; padding-bottom:12px; border-bottom:1px solid var(--c-border);
}
.tbz2-section__title-wrap { display:flex; align-items:center; gap:9px; }
.tbz2-section__icon {
  display:grid; place-items:center; width:30px; height:30px;
  background:var(--c-grad-soft); border:1px solid rgba(99,102,241,.15);
  border-radius:9px; color:var(--c-indigo); flex-shrink:0;
}
.tbz2-section__h2 {
  font-size:clamp(16px,1.8vw,20px); font-weight:700;
  letter-spacing:-.015em; margin:0; color:var(--c-text);
}
.tbz2-section__count { font-size:11.5px; color:var(--c-muted-2); white-space:nowrap; }

/* ── Grid ───────────────────────────────────────────────────── */
.tbz2-grid { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:14px; }
@media (max-width:1100px) { .tbz2-grid { grid-template-columns:repeat(3,minmax(0,1fr)); } }
@media (max-width: 800px) { .tbz2-grid { grid-template-columns:repeat(2,minmax(0,1fr)); } }
@media (max-width: 500px) { .tbz2-grid { grid-template-columns:1fr; gap:10px; } }

/* ── Cards ──────────────────────────────────────────────────── */
.tbz2-card {
  position:relative; display:flex; flex-direction:column; gap:8px;
  padding:18px; background:linear-gradient(180deg, rgba(99,102,241,.028) 0%, rgba(255,255,255,0) 42%), var(--c-surface);
  border:1px solid var(--c-border); border-radius:var(--r-card);
  overflow:hidden;
  transition:transform .26s cubic-bezier(.34,1.4,.64,1), border-color .22s, box-shadow .22s;
  will-change:transform;
}

/* Gradient top line on hover */
.tbz2-card::before {
  content:""; position:absolute; top:0; left:0; right:0; height:1px;
  background:var(--c-grad); transform:scaleX(0); transform-origin:left;
  transition:transform .28s ease; border-radius:1px 1px 0 0;
}
.tbz2-card:hover { transform:translateY(-4px); border-color:#c4b5fd; box-shadow:var(--shadow-hover); }
.tbz2-card:hover::before { transform:scaleX(1); }

.tbz2-card__link { position:absolute; inset:0; z-index:3; text-indent:-9999px; overflow:hidden; }
.tbz2-card__link:focus-visible { outline:2px solid var(--c-indigo); outline-offset:-3px; border-radius:inherit; }

/* Card top */
.tbz2-card__top { display:flex; align-items:center; justify-content:space-between; gap:8px; }
.tbz2-card__icon {
  display:grid; place-items:center; width:40px; height:40px; font-size:20px;
  background:var(--c-grad-soft); border:1px solid rgba(99,102,241,.12);
  border-radius:11px; transition:transform .28s ease; flex-shrink:0;
}
.tbz2-card:hover .tbz2-card__icon { transform:scale(1.1) rotate(-4deg); }
.tbz2-card__tag {
  font-size:10px; font-weight:600; letter-spacing:.06em; text-transform:uppercase;
  color:var(--c-muted); background:var(--c-surface-2); border:1px solid var(--c-border);
  padding:3px 8px; border-radius:999px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:110px;
}

/* Card body */
.tbz2-card__title { margin:2px 0 0; font-size:14.5px; font-weight:700; line-height:1.35; color:var(--c-text); letter-spacing:-.01em; }
.tbz2-card__desc  { margin:0; font-size:12.5px; line-height:1.58; color:var(--c-muted); flex:1; }

/* CTA */
.tbz2-card__footer { margin-top:auto; padding-top:10px; border-top:1px solid var(--c-border); }
.tbz2-card__cta {
  display:inline-flex; align-items:center; gap:5px;
  font-size:12.5px; font-weight:600;
  background:var(--c-grad); -webkit-background-clip:text;
  -webkit-text-fill-color:transparent; background-clip:text;
  transition:gap .18s;
}
.tbz2-card:hover .tbz2-card__cta { gap:9px; }
.tbz2-card__arrow { color:var(--c-cyan); transition:transform .18s; flex-shrink:0; -webkit-text-fill-color:initial; }
.tbz2-card:hover .tbz2-card__arrow { transform:translateX(3px); }

/* ── Empty state ────────────────────────────────────────────── */
.tbz2-no-results {
  display:flex; flex-direction:column; align-items:center; gap:12px;
  padding:52px 0; text-align:center; color:var(--c-muted); font-size:14px;
}
.tbz2-no-results svg { color:var(--c-muted-2); }

/* ── SEO section ────────────────────────────────────────────── */
.tbz2-seo {
  margin-top:40px; padding:30px 34px;
  background:var(--c-bg-2); border:1px solid var(--c-border); border-radius:20px;
}
.tbz2-seo__grid { display:grid; grid-template-columns:1fr 1fr; gap:40px 52px; }
@media (max-width:800px) { .tbz2-seo__grid { grid-template-columns:1fr; gap:28px; } }

.tbz2-seo__h2 { font-size:16px; font-weight:700; color:var(--c-text); margin:24px 0 6px; letter-spacing:-.01em; }
.tbz2-seo__h2:first-child { margin-top:0; }
.tbz2-seo p { font-size:13.5px; line-height:1.72; color:var(--c-muted); margin:0 0 6px; }
.tbz2-seo a { color:var(--c-indigo); text-decoration:none; font-weight:600; }
.tbz2-seo a:hover { text-decoration:underline; }

/* FAQ */
.tbz2-faq { display:flex; flex-direction:column; gap:7px; }
.tbz2-faq__item {
  background:var(--c-surface); border:1px solid var(--c-border);
  border-radius:12px; overflow:hidden;
  transition:border-color .2s, box-shadow .2s;
}
.tbz2-faq__item[open] { border-color:#c4b5fd; box-shadow:0 2px 14px rgba(99,102,241,.1); }
.tbz2-faq__q {
  cursor:pointer; font-weight:600; font-size:13.5px; color:var(--c-text);
  list-style:none; padding:13px 16px;
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  user-select:none; transition:color .18s;
}
.tbz2-faq__q:hover { color:var(--c-indigo); }
.tbz2-faq__q::-webkit-details-marker { display:none; }
.tbz2-faq__q::after { content:"+"; color:var(--c-muted); font-size:18px; font-weight:300; transition:color .2s; flex-shrink:0; }
.tbz2-faq__item[open] .tbz2-faq__q::after { content:"−"; color:var(--c-indigo); }
.tbz2-faq__body { overflow:hidden; height:0; transition:height .3s cubic-bezier(.4,0,.2,1); }
.tbz2-faq__body p { margin:0; padding:0 16px 13px; font-size:13px; line-height:1.65; color:var(--c-muted); }
.tbz2-faq__body a { color:var(--c-indigo); font-weight:600; text-decoration:none; }
.tbz2-faq__body a:hover { text-decoration:underline; }

/* ── Card entrance animation ────────────────────────────────── */
@keyframes tbz2-card-in { from { opacity:0; transform:translateY(12px); } to { opacity:1; transform:translateY(0); } }
.tbz2-card { animation:tbz2-card-in .35s ease both; }

/* ── Responsive tweaks ──────────────────────────────────────── */
@media (max-width:768px) {
  .tbz2 { padding:24px 14px 44px; border-radius:18px; }
  .tbz2-controls { padding:10px; top:6px; }
  .tbz2-seo { padding:22px 18px; }
}

/* ── Reduced motion ─────────────────────────────────────────── */
@media (prefers-reduced-motion:reduce) {
  .tbz2-card { animation:none; }
  .tbz2-hero__dot { animation:none; }
  .tbz2-card:hover { transform:none; }
}

/* ── Print ──────────────────────────────────────────────────── */
@media print {
  .tbz2-aurora, .tbz2-controls { display:none !important; }
}
