/* =============================================================
   BestAITools — Main Stylesheet
   Exact match to the 3 HTML design files provided
   ============================================================= */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f0f6ff;--bg2:#e4efff;--white:#fff;--blue:#0061ff;--blue2:#3380ff;
  --sky:#e8f2ff;--pink:#ec4899;--teal:#0891b2;--green:#059669;
  --amber:#d97706;--orange:#ea580c;--violet:#7c3aed;--indigo:#4f46e5;
  --ink:#0c1220;--ink2:#1e2d45;--muted:#5a6b85;--muted2:#8fa0b8;
  --border:#d0dff5;--border2:#c0d4f0;--star:#f59e0b;--red:#dc2626;
}
body{font-family:'Manrope',sans-serif;background:var(--bg);color:var(--ink);min-height:100vh}

/* ── NAV ── */
nav,.bat-nav{background:var(--white);border-bottom:1.5px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 4rem;height:66px;position:sticky;top:0;z-index:200;box-shadow:0 2px 20px rgba(0,97,255,.06)}
.logo,.bat-logo{font-family:'Bricolage Grotesque',sans-serif;font-size:1.25rem;font-weight:800;color:var(--ink);display:flex;align-items:center;gap:9px;text-decoration:none}
.logo-mark{width:32px;height:32px;border-radius:9px;background:var(--blue);display:flex;align-items:center;justify-content:center;color:#fff;font-size:.85rem;font-weight:900}
.nav-links{display:flex;gap:2px;list-style:none}
.nav-links a{text-decoration:none;color:var(--muted);font-size:.84rem;font-weight:600;padding:.4rem .9rem;border-radius:8px;transition:.18s}
.nav-links a:hover{color:var(--ink);background:var(--bg)}
.nav-cta,.bat-nav-cta{background:var(--blue);border:none;color:#fff;padding:.48rem 1.3rem;border-radius:9px;font-size:.83rem;font-weight:700;cursor:pointer;font-family:inherit;box-shadow:0 4px 14px rgba(0,97,255,.25);transition:.18s;text-decoration:none;display:inline-flex;align-items:center}
.nav-cta:hover,.bat-nav-cta:hover{background:var(--blue2)}

/* ── BREADCRUMB ── */
.breadcrumb-bar{background:var(--white);border-bottom:1.5px solid var(--border);padding:.75rem 4rem}
.breadcrumb,.bc-row{display:flex;align-items:center;gap:8px;font-size:.8rem;max-width:1280px;margin:0 auto;color:var(--muted2)}
.breadcrumb a,.bc-row a{color:var(--blue);text-decoration:none;font-weight:600;transition:.15s}
.breadcrumb a:hover,.bc-row a:hover{text-decoration:underline}
.breadcrumb-sep,.bc-sep{color:var(--muted2);font-size:.75rem}
.breadcrumb-cur,.bc-cur{color:var(--muted);font-weight:600}

/* ── HERO ── */
.hero{background:linear-gradient(150deg,#0050d8 0%,#0061ff 40%,#3b8bff 70%,#7bb8ff 100%);padding:5.5rem 4rem 6rem;color:#fff;position:relative;overflow:hidden;text-align:center}
.hero::before{content:'';position:absolute;top:-140px;right:-140px;width:520px;height:520px;background:rgba(255,255,255,.07);border-radius:50%}
.hero::after{content:'';position:absolute;bottom:-100px;left:-80px;width:380px;height:380px;background:rgba(255,255,255,.05);border-radius:50%}
.hero-inner{max-width:820px;margin:0 auto;position:relative;z-index:1}
.hero-badge{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.35);border-radius:100px;padding:.32rem 1rem;font-size:.71rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;margin-bottom:1.6rem}
.live{width:6px;height:6px;background:#4fffb0;border-radius:50%;animation:pulse 2s infinite;display:inline-block}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
h1,.hero-h1{font-family:'Bricolage Grotesque',sans-serif;font-size:clamp(2.6rem,5vw,4.4rem);font-weight:800;line-height:1.07;letter-spacing:-1.5px;margin-bottom:1.2rem;color:#fff}
.hero-sub{font-size:1.1rem;line-height:1.75;color:rgba(255,255,255,.82);max-width:580px;margin:0 auto 2.5rem}
.hero-btns{display:flex;gap:12px;justify-content:center;margin-bottom:3rem}
.h-cta1{display:inline-flex;align-items:center;background:#fff;color:var(--blue);padding:.9rem 2rem;border-radius:11px;font-family:'Bricolage Grotesque',sans-serif;font-size:.97rem;font-weight:800;cursor:pointer;transition:.2s;box-shadow:0 8px 28px rgba(0,0,0,.18);text-decoration:none}
.h-cta1:hover{transform:translateY(-2px);text-decoration:none;color:var(--blue)}
.h-cta2{display:inline-flex;align-items:center;background:rgba(255,255,255,.18);color:#fff;border:1.5px solid rgba(255,255,255,.4);padding:.9rem 1.8rem;border-radius:11px;font-family:'Bricolage Grotesque',sans-serif;font-size:.95rem;font-weight:700;cursor:pointer;transition:.2s;text-decoration:none}
.h-cta2:hover{background:rgba(255,255,255,.28);text-decoration:none;color:#fff}
.hero-stats{display:inline-flex;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);border-radius:14px;overflow:hidden}
.hs{padding:.85rem 2rem;border-right:1px solid rgba(255,255,255,.15);text-align:center}
.hs:last-child{border-right:none}
.hs-v{font-family:'Bricolage Grotesque',sans-serif;font-size:1.55rem;font-weight:800;color:#fff}
.hs-l{font-size:.67rem;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:.6px;margin-top:2px}

/* ── SEARCH BAR ── */
.search-wrap{background:var(--white);border-bottom:1.5px solid var(--border);padding:1.8rem 4rem;box-shadow:0 4px 20px rgba(0,97,255,.05)}
.sw-inner{max-width:900px;margin:0 auto}
.sw-label{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--muted2);margin-bottom:.75rem}
.sw-bar{display:flex;border:2px solid var(--border2);border-radius:14px;overflow:hidden;background:#fff;box-shadow:0 2px 12px rgba(0,97,255,.07);transition:.2s}
.sw-bar:focus-within{border-color:var(--blue);box-shadow:0 0 0 4px rgba(0,97,255,.1)}
.sw-bar input{flex:1;border:none;outline:none;padding:.95rem 1.3rem;font-family:inherit;font-size:.97rem;color:var(--ink)}
.sw-bar input::placeholder{color:var(--muted2)}
.sw-bar select{border:none;border-left:1.5px solid var(--border);outline:none;padding:0 1rem;font-family:inherit;font-size:.85rem;color:var(--ink2);background:var(--bg);font-weight:600;cursor:pointer;min-width:180px}
.sw-btn{background:var(--blue);border:none;color:#fff;padding:.95rem 2rem;font-family:'Bricolage Grotesque',sans-serif;font-size:.92rem;font-weight:800;cursor:pointer;white-space:nowrap;transition:.18s}
.sw-btn:hover{background:var(--blue2)}

/* ── CATEGORY PILLS ── */
.cats-zone{background:var(--bg);border-bottom:1.5px solid var(--border);padding:1.2rem 4rem;overflow-x:auto;scrollbar-width:none}
.cats-zone::-webkit-scrollbar{display:none}
.cats-row{display:flex;gap:8px;white-space:nowrap}
.cc{display:inline-flex;align-items:center;gap:6px;border-radius:10px;padding:.46rem 1.05rem;font-size:.79rem;font-weight:700;cursor:pointer;transition:.2s;border:1.5px solid transparent;font-family:'Bricolage Grotesque',sans-serif;text-decoration:none}
.cc em{font-style:normal;font-size:.64rem;opacity:.65;margin-left:2px}
.cc:hover{filter:brightness(.9);transform:translateY(-1px);text-decoration:none}
.cc-blue{background:#dbeafe;color:#1d4ed8;border-color:#bfdbfe}.cc-blue.on,.cc-blue.active{background:#0061ff;color:#fff;border-color:#0061ff}
.cc-violet{background:#ede9fe;color:#5b21b6;border-color:#ddd6fe}
.cc-pink{background:#fce7f3;color:#9d174d;border-color:#fbcfe8}
.cc-orange{background:#ffedd5;color:#9a3412;border-color:#fed7aa}
.cc-teal{background:#cffafe;color:#0e7490;border-color:#a5f3fc}
.cc-green{background:#dcfce7;color:#166534;border-color:#bbf7d0}
.cc-yellow{background:#fef9c3;color:#854d0e;border-color:#fef08a}
.cc-rose{background:#ffe4e6;color:#9f1239;border-color:#fecdd3}
.cc-indigo{background:#e0e7ff;color:#3730a3;border-color:#c7d2fe}
.cc-cyan{background:#ecfeff;color:#164e63;border-color:#a5f3fc}
.cc-amber{background:#fffbeb;color:#92400e;border-color:#fde68a}
.cc-emerald{background:#ecfdf5;color:#064e3b;border-color:#a7f3d0}
.cc-red{background:#fee2e2;color:#991b1b;border-color:#fca5a5}

/* ── HOMEPAGE GRID ── */
.page{max-width:1280px;margin:0 auto;padding:2.8rem 4rem 5rem;display:grid;grid-template-columns:1fr 295px;gap:2.5rem}
.sh{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.15rem}
.st{font-family:'Bricolage Grotesque',sans-serif;font-size:1.02rem;font-weight:800;color:var(--ink);display:flex;align-items:center;gap:8px}
.st-pip{width:12px;height:12px;border-radius:3px;background:var(--blue)}
.va{font-size:.77rem;font-weight:700;color:var(--blue);text-decoration:none;background:var(--sky);border:1.5px solid var(--border2);padding:.3rem .85rem;border-radius:7px;transition:.18s}
.va:hover{background:var(--blue);color:#fff;border-color:var(--blue)}

/* ── LOGO BOXES (real images or branded fallback) ── */
.li{width:40px;height:40px;border-radius:10px;overflow:hidden;flex-shrink:0;background:var(--bg2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center}
.li img{width:32px;height:32px;object-fit:contain}
.li-lg{width:50px;height:50px;border-radius:13px;overflow:hidden;flex-shrink:0;background:var(--bg2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center}
.li-lg img{width:40px;height:40px;object-fit:contain}
.li-sm{width:32px;height:32px;border-radius:8px;overflow:hidden;flex-shrink:0;background:var(--bg2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center}
.li-sm img{width:26px;height:26px;object-fit:contain}
/* brand-icon fallback when no real logo */
.brand-icon,.bi{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-family:'Bricolage Grotesque',sans-serif;font-weight:900;color:#fff;font-size:inherit}

/* ── FEATURED TOOLS (2-col big cards) ── */
.feat-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:2rem}
.fb{background:var(--white);border:1.5px solid var(--border);border-radius:16px;padding:1.5rem;cursor:pointer;transition:.22s;position:relative;overflow:hidden;text-decoration:none;display:block;color:inherit}
.fb::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.fb:nth-child(1)::before{background:linear-gradient(90deg,#0061ff,#4f46e5)}
.fb:nth-child(2)::before{background:linear-gradient(90deg,#ec4899,#ea580c)}
.fb:nth-child(3)::before{background:linear-gradient(90deg,#059669,#0891b2)}
.fb:nth-child(4)::before{background:linear-gradient(90deg,#7c3aed,#6366f1)}
.fb:hover{border-color:var(--border2);box-shadow:0 10px 32px rgba(0,97,255,.12);transform:translateY(-2px);text-decoration:none;color:inherit}
.fb-head{display:flex;align-items:center;gap:13px;margin-bottom:.9rem}
.fb-badge{font-size:.62rem;font-weight:800;letter-spacing:1px;text-transform:uppercase;margin-bottom:2px}
.fb:nth-child(1) .fb-badge{color:var(--blue)}
.fb:nth-child(2) .fb-badge{color:var(--pink)}
.fb:nth-child(3) .fb-badge{color:var(--green)}
.fb:nth-child(4) .fb-badge{color:var(--violet)}
.fb-name{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1.08rem;color:var(--ink)}
.fb-cat{font-size:.7rem;color:var(--muted2);margin-top:1px}
.fb-desc{font-size:.81rem;color:var(--muted);line-height:1.62}
.fb-foot{display:flex;gap:6px;margin-top:.95rem}

/* ── SMALL TOOL CARD GRIDS ── */
.g6{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin-bottom:2rem}
.g5{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:2rem}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:2rem}

.tc{background:var(--white);border:1.5px solid var(--border);border-radius:13px;padding:1.15rem;cursor:pointer;transition:.22s;text-decoration:none;display:block;color:inherit}
.tc:hover{border-color:var(--blue);box-shadow:0 6px 24px rgba(0,97,255,.11);transform:translateY(-2px);text-decoration:none;color:inherit}
.tc-h{display:flex;align-items:center;gap:10px;margin-bottom:.68rem}
.tc-name{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:.88rem;color:var(--ink)}
.tc-sub{font-size:.65rem;color:var(--muted2);margin-top:1px}
.tc-desc{font-size:.77rem;color:var(--muted);line-height:1.52}
.tc-foot{display:flex;gap:4px;margin-top:.68rem;flex-wrap:wrap}

/* ── BADGES ── */
.b{display:inline-block;font-size:.61rem;font-weight:700;padding:.14rem .48rem;border-radius:5px}
.b-new{background:#cffafe;color:#0e7490;border:1px solid #a5f3fc}
.b-free{background:#dcfce7;color:#166534;border:1px solid #86efac}
.b-paid{background:#ffe4e6;color:#9f1239;border:1px solid #fca5a5}
.b-fm{background:#e0e7ff;color:#3730a3;border:1px solid #a5b4fc}
.b-cat{background:var(--bg);color:var(--muted2);border:1px solid var(--border)}

/* ── DIVIDER ── */
.div{height:1px;background:var(--border);margin:2.2rem 0}

/* ── HOMEPAGE SIDEBAR ── */
.side{display:flex;flex-direction:column;gap:13px}
.sc{background:var(--white);border:1.5px solid var(--border);border-radius:14px;overflow:hidden}
.sc-hd{padding:.75rem 1.1rem;font-family:'Bricolage Grotesque',sans-serif;font-size:.83rem;font-weight:800;border-bottom:1.5px solid var(--border);display:flex;align-items:center;gap:6px;color:var(--ink)}
.sc-hd.blue{background:var(--blue);color:#fff;border-color:var(--blue)}
.sc-hd.sky{background:var(--sky);color:var(--blue)}
.sc-hd.green{background:#dcfce7;color:#166534;border-color:#bbf7d0}
.sc-hd.pink{background:#fce7f3;color:#9d174d;border-color:#fbcfe8}
.sc-hd.amber{background:#fffbeb;color:#92400e;border-color:#fde68a}
.sr{display:flex;align-items:center;gap:10px;padding:.68rem 1.1rem;border-bottom:1.5px solid var(--bg);cursor:pointer;transition:.15s;text-decoration:none;color:var(--ink)}
.sr:hover{background:var(--bg);text-decoration:none;color:var(--ink)}
.sr:last-child{border-bottom:none}
.sr-name{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:.83rem;color:var(--ink)}
.sr-cat{font-size:.67rem;color:var(--muted2)}
.sr-x{margin-left:auto;font-size:.72rem;font-weight:700;color:var(--muted2)}
.sr-x.up{color:var(--green)}

/* ── SUBMIT BANNER ── */
.sub-banner{background:linear-gradient(135deg,#0050d8,#0061ff,#3b8bff);border-radius:14px;padding:1.8rem 1.5rem;text-align:center;color:#fff}
.sub-t{font-family:'Bricolage Grotesque',sans-serif;font-size:1.1rem;font-weight:800;margin-bottom:.45rem}
.sub-s{font-size:.81rem;color:rgba(255,255,255,.75);margin-bottom:1.1rem}
.sub-btn{background:#fff;color:var(--blue);border:none;padding:.6rem 1.4rem;border-radius:8px;font-family:'Bricolage Grotesque',sans-serif;font-size:.86rem;font-weight:800;cursor:pointer;text-decoration:none;display:inline-block}

/* ── REVIEWS SECTION ── */
.reviews-wrap{background:var(--white);border-top:1.5px solid var(--border);border-bottom:1.5px solid var(--border);padding:3.5rem 4rem}
.reviews-inner{max-width:1280px;margin:0 auto}
.rev-hd{font-family:'Bricolage Grotesque',sans-serif;font-size:1.9rem;font-weight:800;color:var(--ink);text-align:center;margin-bottom:.5rem}
.rev-sub{text-align:center;color:var(--muted);font-size:.92rem;margin-bottom:2.5rem}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.rc{background:var(--bg);border:1.5px solid var(--border);border-radius:16px;padding:1.6rem;transition:.2s}
.rc:hover{border-color:var(--border2);box-shadow:0 6px 24px rgba(0,97,255,.08)}
.rc-top{display:flex;align-items:center;gap:12px;margin-bottom:1rem}
.rc-logo{width:46px;height:46px;border-radius:11px;overflow:hidden;background:var(--white);border:1.5px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center}
.rc-logo img{width:36px;height:36px;object-fit:contain}
.rc-tool{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:.97rem;color:var(--ink)}
.rc-cat{font-size:.7rem;color:var(--muted2)}
.rc-stars{color:var(--star);font-size:1rem;margin-bottom:.85rem;letter-spacing:1px}
.rc-text{font-size:.83rem;color:var(--muted);line-height:1.66;font-style:italic}
.rc-author{display:flex;align-items:center;gap:8px;margin-top:1.1rem;padding-top:1rem;border-top:1px solid var(--border)}
.rc-av{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:800;color:#fff;flex-shrink:0;font-family:'Bricolage Grotesque',sans-serif}
.rc-name{font-weight:700;font-size:.8rem;color:var(--ink2)}
.rc-date{font-size:.7rem;color:var(--muted2)}

/* ── FOOTER ── */
footer{background:var(--ink2);color:rgba(255,255,255,.4);padding:2rem 4rem;display:flex;justify-content:space-between;align-items:center;font-size:.8rem}
.fl{font-family:'Bricolage Grotesque',sans-serif;font-size:1.1rem;font-weight:800;color:#fff;display:flex;align-items:center;gap:9px;text-decoration:none}
.fl-m{width:26px;height:26px;border-radius:7px;background:var(--blue);display:flex;align-items:center;justify-content:center;color:#fff;font-size:.72rem;font-weight:900}
.foot-links{display:flex;gap:1.5rem}
.foot-links a{color:rgba(255,255,255,.4);text-decoration:none;transition:.18s}
.foot-links a:hover{color:rgba(255,255,255,.8)}

/* ═══════════════════════════════════════
   CATEGORY PAGE
   ═══════════════════════════════════════ */

/* Category Hero */
.cat-hero{background:linear-gradient(150deg,#0050d8 0%,#0061ff 40%,#3b8bff 75%,#7bb8ff 100%);padding:3rem 4rem 3.5rem;color:#fff;position:relative;overflow:hidden}
.cat-hero::before{content:'';position:absolute;top:-80px;right:-80px;width:400px;height:400px;background:rgba(255,255,255,.07);border-radius:50%}
.cat-hero::after{content:'';position:absolute;bottom:-60px;left:25%;width:260px;height:260px;background:rgba(255,255,255,.05);border-radius:50%}
.ch-inner{max-width:1280px;margin:0 auto;position:relative;z-index:1;display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:center}
.ch-eyebrow{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.3);border-radius:100px;padding:.28rem .9rem;font-size:.72rem;font-weight:700;letter-spacing:.4px;text-transform:uppercase;margin-bottom:1rem}
.ch-title{font-family:'Bricolage Grotesque',sans-serif;font-size:clamp(1.8rem,3.5vw,2.9rem);font-weight:800;line-height:1.1;letter-spacing:-.5px;margin-bottom:.8rem;color:#fff}
.ch-desc{font-size:.95rem;line-height:1.7;color:rgba(255,255,255,.78);max-width:560px;margin-bottom:1.4rem}
.ch-tags{display:flex;gap:8px;flex-wrap:wrap}
.ch-tag{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);border-radius:100px;padding:.28rem .8rem;font-size:.75rem;font-weight:700;cursor:pointer;transition:.18s;color:#fff;text-decoration:none}
.ch-tag:hover{background:rgba(255,255,255,.28);text-decoration:none;color:#fff}
.ch-stats{display:flex;flex-direction:column;gap:10px;align-items:flex-end;flex-shrink:0}
.ch-stat-box{background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.22);border-radius:12px;padding:.85rem 1.4rem;text-align:center;min-width:110px}
.ch-stat-n{font-family:'Bricolage Grotesque',sans-serif;font-size:1.7rem;font-weight:800;color:#fff;line-height:1}
.ch-stat-l{font-size:.67rem;color:rgba(255,255,255,.62);text-transform:uppercase;letter-spacing:.5px;margin-top:3px}

/* Controls bar */
.controls-bar{background:var(--white);border-bottom:1.5px solid var(--border);padding:1rem 4rem;position:sticky;top:66px;z-index:100;box-shadow:0 2px 10px rgba(0,97,255,.04)}
.ctrl-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.ctrl-count{font-family:'Bricolage Grotesque',sans-serif;font-size:.88rem;font-weight:800;color:var(--ink)}
.ctrl-count span{color:var(--blue)}
.ctrl-sep{width:1px;height:20px;background:var(--border2)}
.filter-pills{display:flex;gap:7px;flex-wrap:wrap}
.fp{display:inline-flex;align-items:center;gap:5px;border:1.5px solid var(--border2);background:var(--white);border-radius:100px;padding:.35rem 1rem;font-size:.78rem;font-weight:700;color:var(--muted);cursor:pointer;transition:.18s;font-family:inherit}
.fp:hover{border-color:var(--blue);color:var(--blue)}
.fp.on{background:var(--blue);border-color:var(--blue);color:#fff}
.fp.free.on{background:var(--green);border-color:var(--green)}
.fp.freemium.on{background:var(--violet);border-color:var(--violet)}
.fp.paid.on{background:var(--orange);border-color:var(--orange)}
.fp.trial.on{background:var(--teal);border-color:var(--teal)}
.sort-select{margin-left:auto;display:flex;align-items:center;gap:8px;font-size:.82rem;font-weight:600;color:var(--muted)}
.sort-select select{border:1.5px solid var(--border2);border-radius:9px;padding:.4rem .9rem;font-family:inherit;font-size:.82rem;font-weight:600;color:var(--ink2);background:var(--white);outline:none;cursor:pointer;transition:.18s}
.sort-select select:focus{border-color:var(--blue)}
.view-toggle{display:flex;border:1.5px solid var(--border2);border-radius:8px;overflow:hidden}
.vt{width:34px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.18s;background:var(--white);color:var(--muted2);font-size:1rem}
.vt:hover{color:var(--ink)}
.vt.on{background:var(--blue);color:#fff}

/* Category layout */
.layout{max-width:1280px;margin:0 auto;padding:2rem 4rem 5rem;display:grid;grid-template-columns:240px 1fr;gap:2.5rem}

/* Category sidebar */
.sidebar{display:flex;flex-direction:column;gap:14px}
.sb-card{background:var(--white);border:1.5px solid var(--border);border-radius:14px;overflow:hidden}
.sb-hd{padding:.75rem 1.1rem;font-family:'Bricolage Grotesque',sans-serif;font-size:.84rem;font-weight:800;color:var(--ink);border-bottom:1.5px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.sb-hd span{font-size:.7rem;color:var(--muted2);font-weight:500}
.cat-list{max-height:340px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border2) transparent}
.cat-item{display:flex;align-items:center;justify-content:space-between;padding:.55rem 1.1rem;border-bottom:1px solid var(--bg);cursor:pointer;transition:.15s;text-decoration:none;font-size:.82rem;color:var(--muted);font-weight:600}
.cat-item:hover{background:var(--bg);color:var(--ink);text-decoration:none}
.cat-item.active{background:var(--sky);color:var(--blue);font-weight:700}
.cat-item:last-child{border-bottom:none}
.cat-cnt{background:var(--bg2);border-radius:100px;padding:.1rem .5rem;font-size:.68rem;font-weight:700;color:var(--muted2)}
.cat-item.active .cat-cnt{background:rgba(0,97,255,.12);color:var(--blue)}

/* Featured sidebar card (blue gradient) */
.feat-sb{background:linear-gradient(135deg,#0050d8,#0061ff,#3b8bff);border-radius:14px;padding:1.3rem;color:#fff}
.feat-sb-label{font-size:.63rem;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:.65rem}
.feat-sb-tool{display:flex;align-items:center;gap:10px;margin-bottom:.75rem}
.feat-sb-logo{width:40px;height:40px;border-radius:10px;overflow:hidden;flex-shrink:0;border:1.5px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.15)}
.feat-sb-logo img{width:32px;height:32px;object-fit:contain}
.feat-sb-name{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1rem;color:#fff}
.feat-sb-cat{font-size:.7rem;color:rgba(255,255,255,.6)}
.feat-sb-desc{font-size:.78rem;color:rgba(255,255,255,.7);line-height:1.57;margin-bottom:.9rem}
.feat-sb-btn{display:block;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.28);border-radius:8px;padding:.6rem;text-align:center;color:#fff;font-family:'Bricolage Grotesque',sans-serif;font-size:.82rem;font-weight:700;cursor:pointer;transition:.2s;text-decoration:none}
.feat-sb-btn:hover{background:rgba(255,255,255,.28);text-decoration:none;color:#fff}

/* Price filter */
.price-filter{padding:.9rem 1.1rem;display:flex;flex-direction:column;gap:8px}
.pf-row{display:flex;align-items:center;justify-content:space-between;cursor:pointer}
.pf-check{display:flex;align-items:center;gap:7px;font-size:.82rem;font-weight:600;color:var(--muted)}
.pf-dot{width:14px;height:14px;border-radius:4px;border:2px solid var(--border2);flex-shrink:0;transition:.18s;display:flex;align-items:center;justify-content:center;font-size:.55rem;font-weight:900;color:#fff}
.pf-dot.checked{border-color:var(--blue);background:var(--blue)}
.pf-cnt{font-size:.7rem;font-weight:700;color:var(--muted2)}

/* Category tool cards (list style) */
.tools-area{}
.featured-tool-banner{background:linear-gradient(120deg,#0c1220 0%,#1e2d45 100%);border-radius:16px;padding:1.4rem 1.6rem;display:flex;align-items:center;gap:1.2rem;margin-bottom:1.5rem;cursor:pointer;transition:.2s;border:1.5px solid rgba(255,255,255,.06);text-decoration:none}
.featured-tool-banner:hover{box-shadow:0 8px 32px rgba(0,0,0,.25);transform:translateY(-1px);text-decoration:none}
.ftb-logo{width:52px;height:52px;border-radius:13px;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.1)}
.ftb-logo img{width:42px;height:42px;object-fit:contain}
.ftb-badge{display:inline-flex;align-items:center;gap:5px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-size:.63rem;font-weight:800;padding:.18rem .6rem;border-radius:4px;letter-spacing:.3px;text-transform:uppercase;margin-bottom:.35rem}
.ftb-name{font-family:'Bricolage Grotesque',sans-serif;font-size:1.15rem;font-weight:800;color:#fff;margin-bottom:.25rem}
.ftb-desc{font-size:.82rem;color:rgba(255,255,255,.58);line-height:1.55}
.ftb-right{margin-left:auto;flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}
.ftb-vote{font-family:'Bricolage Grotesque',sans-serif;font-size:1.3rem;font-weight:800;color:#fff;display:flex;align-items:center;gap:5px}
.ftb-vote-label{font-size:.68rem;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.4px}
.ftb-btn{background:var(--blue);border:none;color:#fff;padding:.62rem 1.4rem;border-radius:9px;font-family:'Bricolage Grotesque',sans-serif;font-size:.84rem;font-weight:800;cursor:pointer;white-space:nowrap;transition:.18s;text-decoration:none;display:inline-block}
.ftb-btn:hover{background:var(--blue2)}

/* Tool card — list style */
.tool-card{background:var(--white);border:1.5px solid var(--border);border-radius:14px;padding:1.2rem 1.4rem;display:flex;align-items:flex-start;gap:1.1rem;margin-bottom:10px;cursor:pointer;transition:.22s;text-decoration:none;position:relative;color:inherit}
.tool-card:hover{border-color:var(--blue);box-shadow:0 6px 24px rgba(0,97,255,.1);transform:translateY(-1px);text-decoration:none;color:inherit}
.tc-rank{width:28px;flex-shrink:0;text-align:center;font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1rem;color:var(--muted2);padding-top:10px}
.tc-rank.top3{color:var(--blue)}
.tc-logo{width:50px;height:50px;border-radius:12px;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--bg2)}
.tc-logo img{width:40px;height:40px;object-fit:contain}
.tc-logo .bi,.tc-logo .brand-icon{font-size:1.15rem}
.tc-body{flex:1;min-width:0}
.tc-name-row{display:flex;align-items:center;gap:8px;margin-bottom:.28rem;flex-wrap:wrap}
.tc-name{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1rem;color:var(--ink)}
.tc-verified{background:#dcfce7;color:#166534;border:1px solid #86efac;font-size:.6rem;font-weight:800;padding:.15rem .5rem;border-radius:4px;text-transform:uppercase;letter-spacing:.3px}
.tc-verified.gold{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border-color:#fcd34d}
.tc-desc{font-size:.83rem;color:var(--muted);line-height:1.6;margin-bottom:.65rem}
.tc-meta{display:flex;align-items:center;gap:.65rem;flex-wrap:wrap}
.tc-rating{display:flex;align-items:center;gap:4px}
.tc-stars{color:var(--star);font-size:.78rem;letter-spacing:.5px}
.tc-score{font-size:.78rem;font-weight:800;color:var(--ink2)}
.tc-pill{display:inline-flex;align-items:center;gap:4px;border-radius:100px;padding:.22rem .7rem;font-size:.72rem;font-weight:700;border:1px solid transparent}
.tp-free{background:#dcfce7;color:#166534;border-color:#bbf7d0}
.tp-fm{background:#e0e7ff;color:#3730a3;border-color:#a5b4fc}
.tp-paid{background:#ffe4e6;color:#9f1239;border-color:#fca5a5}
.tp-trial{background:#cffafe;color:#0e7490;border-color:#a5f3fc}
.tc-cat-tag{background:var(--bg);border:1px solid var(--border2);border-radius:100px;padding:.22rem .7rem;font-size:.72rem;font-weight:600;color:var(--muted);text-decoration:none;transition:.15s}
.tc-cat-tag:hover{background:var(--blue);color:#fff;border-color:var(--blue)}
.tc-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex-shrink:0;padding-top:2px}
.tc-upvote{display:flex;flex-direction:column;align-items:center;gap:2px;background:var(--bg);border:1.5px solid var(--border2);border-radius:9px;padding:.5rem .7rem;cursor:pointer;transition:.18s;min-width:54px}
.tc-upvote:hover{border-color:var(--blue);background:var(--sky)}
.tc-upvote-arrow{font-size:1rem;line-height:1;color:var(--muted2)}
.tc-upvote-n{font-family:'Bricolage Grotesque',sans-serif;font-size:.88rem;font-weight:800;color:var(--ink2)}
.tc-visit{display:inline-flex;align-items:center;gap:5px;background:var(--blue);color:#fff;border:none;padding:.52rem 1.1rem;border-radius:8px;font-family:'Bricolage Grotesque',sans-serif;font-size:.8rem;font-weight:700;cursor:pointer;transition:.18s;text-decoration:none;white-space:nowrap}
.tc-visit:hover{background:var(--blue2);text-decoration:none;color:#fff}
.tc-new-badge{position:absolute;top:.9rem;right:1.4rem;background:var(--teal);color:#fff;font-size:.6rem;font-weight:800;padding:.18rem .55rem;border-radius:4px;letter-spacing:.3px;text-transform:uppercase}

/* Newsletter banner */
.nl-banner{background:linear-gradient(135deg,#0050d8,#0061ff,#3b8bff);border-radius:16px;padding:2rem 2.5rem;color:#fff;text-align:center;margin-bottom:1.5rem}
.nl-t{font-family:'Bricolage Grotesque',sans-serif;font-size:1.25rem;font-weight:800;margin-bottom:.4rem}
.nl-s{font-size:.85rem;color:rgba(255,255,255,.75);margin-bottom:1.2rem}
.nl-form{display:flex;gap:8px;max-width:380px;margin:0 auto}
.nl-input{flex:1;border:none;border-radius:9px;padding:.75rem 1rem;font-family:inherit;font-size:.88rem;outline:none;color:var(--ink)}
.nl-btn{background:var(--ink2);color:#fff;border:none;border-radius:9px;padding:.75rem 1.3rem;font-family:'Bricolage Grotesque',sans-serif;font-size:.86rem;font-weight:800;cursor:pointer;transition:.18s;white-space:nowrap}
.nl-btn:hover{background:#000}

/* Load more */
.load-more-wrap{text-align:center;margin-top:2rem}
.load-more{background:var(--white);border:2px solid var(--border2);color:var(--ink2);padding:.85rem 2.5rem;border-radius:11px;font-family:'Bricolage Grotesque',sans-serif;font-size:.92rem;font-weight:800;cursor:pointer;transition:.2s}
.load-more:hover{border-color:var(--blue);color:var(--blue);background:var(--sky)}

/* ═══════════════════════════════════════
   TOOL LISTING PAGE
   ═══════════════════════════════════════ */

/* Tool Header */
.tool-header{background:var(--white);border-bottom:1.5px solid var(--border);padding:2.2rem 4rem}
.th-inner{max-width:1280px;margin:0 auto}
.th-row{display:flex;align-items:flex-start;justify-content:space-between;gap:2rem}
.th-left{display:flex;align-items:flex-start;gap:1.5rem;flex:1}
.tool-logo-wrap{width:72px;height:72px;border-radius:16px;overflow:hidden;flex-shrink:0;border:2px solid rgba(0,0,0,.08);display:flex;align-items:center;justify-content:center;background:var(--bg2)}
.tool-logo-wrap img{width:100%;height:100%;object-fit:contain}
.tool-logo-wrap .brand-icon{font-size:1.5rem;color:#fff}
.tool-meta-info{flex:1}
.tool-name-row{display:flex;align-items:center;gap:10px;margin-bottom:.35rem;flex-wrap:wrap}
.tool-name{font-family:'Bricolage Grotesque',sans-serif;font-size:1.9rem;font-weight:800;color:var(--ink);letter-spacing:-.5px}
.tool-verified{background:#dcfce7;color:#166534;border:1px solid #86efac;font-size:.65rem;font-weight:800;padding:.2rem .6rem;border-radius:5px;letter-spacing:.3px;text-transform:uppercase}
.tool-featured-badge{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-size:.65rem;font-weight:800;padding:.2rem .6rem;border-radius:5px;letter-spacing:.3px;text-transform:uppercase}
.tool-tagline{font-size:1rem;color:var(--muted);line-height:1.6;margin-bottom:.85rem;max-width:560px}
.tool-meta-row{display:flex;align-items:center;gap:.85rem;flex-wrap:wrap}
.rating-stars{display:flex;align-items:center;gap:5px}
.stars{color:var(--star);font-size:.95rem;letter-spacing:1px}
.rating-num{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:.95rem;color:var(--ink)}
.rating-count{font-size:.78rem;color:var(--muted2)}
.meta-pill{display:inline-flex;align-items:center;gap:5px;background:var(--bg);border:1.5px solid var(--border2);border-radius:100px;padding:.3rem .85rem;font-size:.75rem;font-weight:700;color:var(--muted)}
.meta-pill.green{background:#dcfce7;border-color:#bbf7d0;color:#166534}
.meta-pill.blue{background:var(--sky);border-color:var(--border2);color:var(--blue)}

/* CTAs */
.th-cta{display:flex;flex-direction:column;gap:10px;align-items:flex-end;flex-shrink:0}
.cta-visit{display:inline-flex;align-items:center;gap:8px;background:var(--blue);color:#fff;border:none;padding:.85rem 1.8rem;border-radius:11px;font-family:'Bricolage Grotesque',sans-serif;font-size:.97rem;font-weight:800;cursor:pointer;transition:.2s;text-decoration:none;box-shadow:0 4px 18px rgba(0,97,255,.28);white-space:nowrap}
.cta-visit:hover{background:var(--blue2);transform:translateY(-1px);text-decoration:none;color:#fff}
.cta-visit svg{width:16px;height:16px;flex-shrink:0}
.cta-row2{display:flex;gap:8px}
.cta-save{display:inline-flex;align-items:center;gap:7px;background:var(--white);color:var(--ink2);border:1.5px solid var(--border2);padding:.68rem 1.3rem;border-radius:10px;font-family:'Bricolage Grotesque',sans-serif;font-size:.86rem;font-weight:700;cursor:pointer;transition:.2s}
.cta-save:hover{border-color:var(--blue);color:var(--blue)}
.cta-share{display:inline-flex;align-items:center;gap:6px;background:transparent;color:var(--muted);border:1.5px solid var(--border);padding:.68rem 1.1rem;border-radius:10px;font-size:.84rem;font-weight:600;cursor:pointer;transition:.2s;font-family:inherit}
.cta-share:hover{color:var(--ink);border-color:var(--border2)}

/* Tabs */
.tabs-bar{background:var(--white);border-bottom:1.5px solid var(--border);padding:0 4rem;position:sticky;top:66px;z-index:100;box-shadow:0 2px 10px rgba(0,97,255,.04)}
.tabs-inner{max-width:1280px;margin:0 auto;display:flex;overflow-x:auto;scrollbar-width:none}
.tabs-inner::-webkit-scrollbar{display:none}
.tab{padding:.9rem 1.3rem;font-family:'Bricolage Grotesque',sans-serif;font-size:.87rem;font-weight:700;color:var(--muted);cursor:pointer;border-bottom:3px solid transparent;white-space:nowrap;transition:.18s;margin-bottom:-1.5px;user-select:none}
.tab:hover{color:var(--ink2)}
.tab.active{color:var(--blue);border-bottom-color:var(--blue)}
.tab-count{background:var(--blue);color:#fff;font-size:.6rem;padding:.1rem .45rem;border-radius:4px;margin-left:5px;font-weight:800;vertical-align:middle}

/* Tool page grid */
.tool-page{max-width:1280px;margin:0 auto;padding:2.5rem 4rem 4rem;display:grid;grid-template-columns:1fr 310px;gap:2.5rem}

/* Article content */
.section{margin-bottom:2.5rem}
.sec-title{font-family:'Bricolage Grotesque',sans-serif;font-size:1.1rem;font-weight:800;color:var(--ink);margin-bottom:1.1rem;display:flex;align-items:center;gap:8px}
.sec-title::before{content:'';width:4px;height:18px;background:var(--blue);border-radius:2px;display:block;flex-shrink:0}
.about-text{font-size:.9rem;color:var(--muted);line-height:1.82}
.about-text p{margin-bottom:.9rem}
.about-text p:last-child{margin-bottom:0}
.about-text h2{font-family:'Bricolage Grotesque',sans-serif;font-size:1.05rem;font-weight:800;color:var(--ink);margin:1.5rem 0 .6rem;scroll-margin-top:130px}
.about-text h3{font-family:'Bricolage Grotesque',sans-serif;font-size:.95rem;font-weight:700;color:var(--ink2);margin:1.2rem 0 .5rem}
.about-text ul,.about-text ol{padding-left:1.3rem;margin-bottom:.9rem}
.about-text li{font-size:.88rem;color:var(--muted);line-height:1.7;margin-bottom:.3rem}
.about-text table{width:100%;border-collapse:collapse;margin-bottom:1rem;font-size:.83rem}
.about-text th{background:var(--bg2);font-weight:700;color:var(--ink2);padding:.6rem .9rem;text-align:left;border:1px solid var(--border)}
.about-text td{padding:.55rem .9rem;border:1px solid var(--border);color:var(--muted)}
.about-text blockquote{border-left:3px solid var(--blue);padding:.6rem 1rem;background:var(--sky);border-radius:0 8px 8px 0;margin-bottom:.9rem;font-style:italic;color:var(--muted)}

/* Features grid */
.features-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.feat-card{background:var(--white);border:1.5px solid var(--border);border-radius:13px;padding:1.2rem;transition:.2s}
.feat-card:hover{border-color:var(--border2);box-shadow:0 4px 18px rgba(0,97,255,.08)}
.feat-icon-box{width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin-bottom:.7rem}
.feat-name{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:.9rem;color:var(--ink);margin-bottom:.3rem}
.feat-desc{font-size:.78rem;color:var(--muted);line-height:1.55}

/* Screenshots */
.screenshots{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.ss{border:1.5px solid var(--border);border-radius:12px;overflow:hidden;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.2s;position:relative}
.ss:hover{border-color:var(--blue);box-shadow:0 4px 18px rgba(0,97,255,.1)}
.ss-inner{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;font-size:.78rem;font-weight:700;color:#fff;opacity:.9}
.ss-label{position:absolute;bottom:.6rem;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.5);color:#fff;font-size:.64rem;font-weight:700;padding:.18rem .6rem;border-radius:4px;white-space:nowrap}

/* Pros & Cons */
.pros-cons{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.pc-col{background:var(--white);border:1.5px solid var(--border);border-radius:13px;padding:1.3rem}
.pc-header{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:.92rem;margin-bottom:1rem;display:flex;align-items:center;gap:7px}
.pc-header.pros{color:var(--green)}
.pc-header.cons{color:var(--red)}
.pc-item{display:flex;align-items:flex-start;gap:9px;margin-bottom:.7rem;font-size:.82rem;color:var(--muted);line-height:1.55}
.pc-item:last-child{margin-bottom:0}
.pc-dot{width:19px;height:19px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:900;margin-top:1px}
.pc-dot.pro{background:#dcfce7;color:#166534}
.pc-dot.con{background:#fee2e2;color:#991b1b}

/* Pricing */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.price-card{background:var(--white);border:1.5px solid var(--border);border-radius:14px;padding:1.5rem;text-align:center;transition:.2s;position:relative;overflow:hidden}
.price-card.popular{border-color:var(--blue);box-shadow:0 4px 22px rgba(0,97,255,.14)}
.price-popular-tag{position:absolute;top:0;left:50%;transform:translateX(-50%);background:var(--blue);color:#fff;font-size:.63rem;font-weight:800;padding:.22rem .9rem;border-radius:0 0 8px 8px;white-space:nowrap;letter-spacing:.3px}
.price-plan{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:.9rem;color:var(--muted);margin-bottom:.4rem;margin-top:.5rem}
.price-amount{font-family:'Bricolage Grotesque',sans-serif;font-size:2.1rem;font-weight:800;color:var(--ink);line-height:1}
.price-amount span{font-size:.85rem;color:var(--muted);font-weight:500}
.price-per{font-size:.72rem;color:var(--muted2);margin:.25rem 0 1rem}
.price-features{list-style:none;text-align:left;margin-bottom:1.2rem}
.price-features li{font-size:.79rem;color:var(--muted);padding:.32rem 0;border-bottom:1px solid var(--bg);display:flex;align-items:flex-start;gap:7px;line-height:1.45}
.price-features li:last-child{border-bottom:none}
.price-features li::before{content:'✓';color:var(--green);font-weight:900;font-size:.76rem;flex-shrink:0;margin-top:1px}
.price-btn{width:100%;background:var(--bg2);border:1.5px solid var(--border2);color:var(--ink2);padding:.68rem;border-radius:9px;font-family:'Bricolage Grotesque',sans-serif;font-size:.84rem;font-weight:700;cursor:pointer;transition:.2s}
.price-btn:hover{background:var(--blue);color:#fff;border-color:var(--blue)}
.price-card.popular .price-btn{background:var(--blue);color:#fff;border-color:var(--blue)}
.price-card.popular .price-btn:hover{background:var(--blue2)}

/* Reviews */
.review-summary{display:flex;align-items:center;gap:2.5rem;background:var(--white);border:1.5px solid var(--border);border-radius:14px;padding:1.6rem 2rem;margin-bottom:1.5rem}
.rs-big-num{font-family:'Bricolage Grotesque',sans-serif;font-size:3.8rem;font-weight:800;color:var(--ink);line-height:1}
.rs-stars{font-size:1.3rem;color:var(--star);letter-spacing:2px;margin:.15rem 0 .25rem}
.rs-count{font-size:.78rem;color:var(--muted2)}
.rs-breakdown{flex:1}
.rs-bar-row{display:flex;align-items:center;gap:8px;margin-bottom:.42rem}
.rs-bar-row:last-child{margin-bottom:0}
.rs-bar-label{font-size:.74rem;color:var(--muted);font-weight:700;width:30px;text-align:right;flex-shrink:0}
.rs-bar{flex:1;height:7px;background:var(--bg2);border-radius:4px;overflow:hidden}
.rs-bar-fill{height:100%;border-radius:4px}
.rs-bar-pct{font-size:.72rem;color:var(--muted2);width:30px;flex-shrink:0}
.review-card{background:var(--white);border:1.5px solid var(--border);border-radius:14px;padding:1.5rem;margin-bottom:12px;transition:.2s}
.review-card:hover{border-color:var(--border2);box-shadow:0 4px 14px rgba(0,97,255,.07)}
.rc-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.9rem}
.rc-user{display:flex;align-items:center;gap:11px}
.rc-av{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.82rem;font-weight:800;color:#fff;flex-shrink:0;font-family:'Bricolage Grotesque',sans-serif}
.rc-name{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:.88rem;color:var(--ink)}
.rc-role{font-size:.7rem;color:var(--muted2);margin-top:1px}
.rc-right{text-align:right}
.rc-stars-sm{color:var(--star);font-size:.82rem;letter-spacing:.5px}
.rc-date{font-size:.7rem;color:var(--muted2);margin-top:2px}
.rc-headline{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:.92rem;color:var(--ink);margin-bottom:.5rem}
.rc-text{font-size:.83rem;color:var(--muted);line-height:1.68}
.rc-helpful{display:flex;align-items:center;gap:.7rem;margin-top:1rem;padding-top:.9rem;border-top:1px solid var(--bg)}
.rc-helpful-label{font-size:.73rem;color:var(--muted2)}
.helpful-btn{background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:.28rem .8rem;font-size:.73rem;font-weight:700;color:var(--muted);cursor:pointer;transition:.15s;font-family:inherit}
.helpful-btn:hover{border-color:var(--border2);color:var(--ink)}

/* Write review form */
.write-review{background:var(--white);border:1.5px solid var(--border);border-radius:14px;padding:1.8rem;margin-top:1.5rem}
.wr-title{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1.05rem;color:var(--ink);margin-bottom:.5rem}
.wr-subtitle{font-size:.8rem;color:var(--muted2);margin-bottom:1.1rem}
.wr-star-label{font-size:.74rem;font-weight:700;color:var(--ink2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}
.wr-stars{display:flex;gap:5px;margin-bottom:1.2rem;cursor:pointer}
.wr-star{font-size:1.8rem;color:#dde5f5;transition:.15s;cursor:pointer;line-height:1}
.wr-star.lit{color:var(--star)}
.wr-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.wr-field{display:flex;flex-direction:column;gap:5px}
.wr-field.full{grid-column:span 2}
.wr-label{font-size:.73rem;font-weight:700;color:var(--ink2);text-transform:uppercase;letter-spacing:.5px}
.wr-input{border:1.5px solid var(--border2);border-radius:9px;padding:.78rem 1rem;font-family:inherit;font-size:.88rem;color:var(--ink);background:#fff;outline:none;transition:.18s}
.wr-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,97,255,.08)}
.wr-input::placeholder{color:var(--muted2)}
textarea.wr-input{resize:vertical;min-height:110px;line-height:1.65}
.wr-submit{background:var(--blue);border:none;color:#fff;padding:.85rem 2.2rem;border-radius:10px;font-family:'Bricolage Grotesque',sans-serif;font-size:.92rem;font-weight:800;cursor:pointer;transition:.2s;box-shadow:0 4px 14px rgba(0,97,255,.25)}
.wr-submit:hover{background:var(--blue2);transform:translateY(-1px)}

/* Tool sidebar */
.tool-side{display:flex;flex-direction:column;gap:16px}
.info-card{background:var(--white);border:1.5px solid var(--border);border-radius:14px;overflow:hidden}
.info-hd{background:var(--blue);color:#fff;padding:.78rem 1.2rem;font-family:'Bricolage Grotesque',sans-serif;font-size:.85rem;font-weight:800}
.info-row{display:flex;align-items:center;justify-content:space-between;padding:.72rem 1.2rem;border-bottom:1px solid var(--bg);font-size:.82rem}
.info-row:last-child{border-bottom:none}
.info-label{color:var(--muted);font-weight:600}
.info-val{font-weight:700;color:var(--ink2);text-align:right;max-width:55%}
.info-val.green{color:var(--green)}
.info-val a{color:var(--blue);text-decoration:none}
.info-val a:hover{text-decoration:underline}

/* Featured tool card in sidebar */
.featured-tool{background:linear-gradient(135deg,#0050d8,#0061ff,#3b8bff);border-radius:14px;padding:1.4rem;color:#fff}
.ft-label{font-size:.64rem;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:.75rem}
.ft-tool{display:flex;align-items:center;gap:12px;margin-bottom:.85rem}
.ft-logo{width:44px;height:44px;border-radius:11px;overflow:hidden;flex-shrink:0;border:2px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.1)}
.ft-logo img{width:36px;height:36px;object-fit:contain}
.ft-name{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1.05rem;color:#fff}
.ft-cat{font-size:.72rem;color:rgba(255,255,255,.6)}
.ft-desc{font-size:.8rem;color:rgba(255,255,255,.72);line-height:1.6;margin-bottom:1rem}
.ft-btn{display:block;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.3);border-radius:9px;padding:.68rem;text-align:center;color:#fff;font-family:'Bricolage Grotesque',sans-serif;font-size:.84rem;font-weight:700;cursor:pointer;transition:.2s;text-decoration:none}
.ft-btn:hover{background:rgba(255,255,255,.28);text-decoration:none;color:#fff}

/* Alternatives */
.alt-wrap{background:var(--white);border:1.5px solid var(--border);border-radius:14px;overflow:hidden}
.alt-hd{background:var(--sky);color:var(--blue);padding:.78rem 1.2rem;font-family:'Bricolage Grotesque',sans-serif;font-size:.85rem;font-weight:800;border-bottom:1.5px solid var(--border)}
.alt-card{display:flex;align-items:center;gap:11px;padding:.78rem 1.2rem;border-bottom:1px solid var(--bg);cursor:pointer;transition:.2s;text-decoration:none;color:inherit}
.alt-card:last-child{border-bottom:none}
.alt-card:hover{background:var(--bg);text-decoration:none;color:inherit}
.alt-logo{width:36px;height:36px;border-radius:9px;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--bg2);border:1px solid var(--border)}
.alt-logo img{width:28px;height:28px;object-fit:contain}
.alt-logo .brand-icon{font-size:.88rem}
.alt-name{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:.84rem;color:var(--ink)}
.alt-cat{font-size:.67rem;color:var(--muted2);margin-top:1px}
.alt-right{margin-left:auto;text-align:right;flex-shrink:0}
.alt-stars{font-size:.7rem;color:var(--star)}
.alt-price{font-size:.67rem;font-weight:700;color:var(--muted2)}

/* Tags */
.tags-wrap{background:var(--white);border:1.5px solid var(--border);border-radius:14px;padding:1.1rem}
.tags-hd{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:.82rem;color:var(--ink);margin-bottom:.75rem;display:flex;align-items:center;gap:6px}
.tags-cloud{display:flex;flex-wrap:wrap;gap:7px}
.tag{background:var(--bg2);border:1px solid var(--border2);border-radius:100px;padding:.3rem .85rem;font-size:.75rem;font-weight:700;color:var(--muted);cursor:pointer;transition:.18s;text-decoration:none;display:inline-block}
.tag:hover{background:var(--blue);color:#fff;border-color:var(--blue)}

/* Similar tools */
.similar-section{max-width:1280px;margin:0 auto 4rem;padding:0 4rem}
.similar-title{font-family:'Bricolage Grotesque',sans-serif;font-size:1.15rem;font-weight:800;color:var(--ink);display:flex;align-items:center;gap:8px;margin-bottom:1.1rem}
.similar-title::before{content:'';width:4px;height:18px;background:var(--blue);border-radius:2px;display:block}
.similar-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.sim-card{background:var(--white);border:1.5px solid var(--border);border-radius:13px;padding:1.1rem;cursor:pointer;transition:.22s;text-decoration:none;display:block;color:inherit}
.sim-card:hover{border-color:var(--blue);box-shadow:0 6px 22px rgba(0,97,255,.1);transform:translateY(-2px);text-decoration:none;color:inherit}
.sim-top{display:flex;align-items:center;gap:9px;margin-bottom:.65rem}
.sim-logo{width:38px;height:38px;border-radius:9px;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--bg2);border:1px solid var(--border)}
.sim-logo img{width:30px;height:30px;object-fit:contain}
.sim-logo .brand-icon{font-size:.9rem}
.sim-name{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:.88rem;color:var(--ink)}
.sim-cat{font-size:.66rem;color:var(--muted2);margin-top:1px}
.sim-desc{font-size:.76rem;color:var(--muted);line-height:1.5}
.sim-foot{display:flex;align-items:center;justify-content:space-between;margin-top:.7rem}
.sim-stars{font-size:.72rem;color:var(--star)}
.sim-badge{font-size:.65rem;font-weight:700;padding:.12rem .45rem;border-radius:4px}
.sim-badge.free{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}
.sim-badge.paid{background:#ffe4e6;color:#9f1239;border:1px solid #fca5a5}
.sim-badge.fm{background:#e0e7ff;color:#3730a3;border:1px solid #a5b4fc}

/* ── PAGINATION ── */
.bat-pagination,.pagination{display:flex;align-items:center;justify-content:center;gap:6px;flex-wrap:wrap;padding:2rem 0 1rem}
.bat-pagination .page-numbers,.pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 10px;border:1.5px solid var(--border);border-radius:8px;font-size:.82rem;font-weight:600;color:var(--ink);text-decoration:none;transition:.18s;background:var(--white);font-family:'Bricolage Grotesque',sans-serif}
.bat-pagination .page-numbers:hover,.bat-pagination .page-numbers.current,.pagination .page-numbers:hover,.pagination .page-numbers.current{background:var(--blue);border-color:var(--blue);color:#fff}
.bat-pagination .page-numbers.dots,.pagination .page-numbers.dots{border:none;background:transparent;cursor:default}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  nav,.controls-bar{padding:0 2rem}
  .hero,.search-wrap,.cats-zone{padding-left:2rem;padding-right:2rem}
  .page{padding:2rem;grid-template-columns:1fr 260px}
  .layout{padding:2rem;grid-template-columns:200px 1fr}
  .tool-header,.tabs-bar,.tool-page,.similar-section,.reviews-wrap{padding-left:2rem;padding-right:2rem}
  .breadcrumb-bar{padding:.75rem 2rem}
  .cat-hero{padding:2.5rem 2rem 3rem}
  .g6{grid-template-columns:repeat(3,1fr)}
  .g5{grid-template-columns:repeat(3,1fr)}
  .similar-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:768px){
  nav,.bat-nav{padding:0 1.2rem;flex-wrap:wrap;height:auto;min-height:56px}
  .hero{padding:3.5rem 1.5rem 4rem}
  h1,.hero-h1{font-size:2.2rem}
  .hero-btns{flex-direction:column;align-items:center}
  .search-wrap{padding:1.2rem 1.5rem}
  .sw-bar select{display:none}
  .cats-zone{padding:.8rem 1.5rem}
  .page{grid-template-columns:1fr;padding:1.5rem}
  .side{display:none}
  .feat-grid{grid-template-columns:1fr}
  .g6,.g5,.g4{grid-template-columns:repeat(2,1fr)}
  .rev-grid{grid-template-columns:1fr}
  .layout{grid-template-columns:1fr;padding:1.5rem}
  .sidebar{display:none}
  .tool-header{padding:1.5rem}
  .th-row{flex-direction:column}
  .th-cta{align-items:flex-start}
  .tabs-bar{padding:0 1.5rem}
  .tool-page{grid-template-columns:1fr;padding:1.5rem}
  .tool-side{display:none}
  .similar-section{padding:0 1.5rem}
  .similar-grid{grid-template-columns:repeat(2,1fr)}
  .pricing-grid{grid-template-columns:1fr}
  .features-grid{grid-template-columns:1fr}
  .pros-cons{grid-template-columns:1fr}
  footer{flex-direction:column;gap:1rem;text-align:center;padding:1.5rem}
  .reviews-wrap{padding:2rem 1.5rem}
}
