/*
Theme Name: VB Web AI Tools
Theme URI: https://www.vbwebtools.com
Author: VB WEB AND SOFTWARE SOLUTION
Author URI: https://www.vbwebsol.com
Description: VB Web AI Tools - Premium AI Tools Directory. Fully responsive, SEO optimised, with tool listings, categories, blog, comparison pages, admin panel and submission system.
Version: 3.0.0
License: GNU General Public License v2 or later
Text Domain: vbwat
Tags: dark, directory, ai-tools, seo, responsive
*/

/* ─── GOOGLE FONTS ─── */
@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,700&display=swap');

/* ─── CSS VARIABLES ─── */
:root {
  --bg:      #05050a;
  --bg2:     #0a0a12;
  --bg3:     #111119;
  --bg4:     #18181f;
  --bg5:     #1e1e28;
  --border:  #1e1e2c;
  --border2: #2c2c40;
  --text:    #eeeef8;
  --text2:   #8888a8;
  --text3:   #55556a;
  --accent:  #1a6fff;
  --accent2: #4d8fff;
  --accent3: #85b4ff;
  --teal:    #00d4ff;
  --orange:  #ff6b2b;
  --pink:    #e040fb;
  --amber:   #ffb300;
  --green:   #00e676;
  --red:     #f44336;
  --grad:    linear-gradient(135deg,#1a6fff 0%,#00d4ff 100%);
  --grad2:   linear-gradient(135deg,#ff6b2b 0%,#ffb300 100%);
  --grad-logo: linear-gradient(135deg,#1a6fff 0%,#00d4ff 55%,#ff6b2b 100%);
  --r:       12px;
  --r2:      20px;
  --sh:      0 8px 32px rgba(0,0,0,.5);
  --sh2:     0 20px 60px rgba(0,0,0,.6);
  --tr:      all .22s ease;
}

/* ─── RESET & BASE ─── */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box }
html { scroll-behavior:smooth; overflow-x:hidden }
body { background:var(--bg); color:var(--text); font-family:'DM Sans',sans-serif; font-size:15px; line-height:1.7; overflow-x:hidden; -webkit-font-smoothing:antialiased }
img { max-width:100%; height:auto; display:block }
a { color:var(--accent2); text-decoration:none; transition:var(--tr) }
a:hover { color:var(--accent3) }
ul,ol { list-style:none }
h1,h2,h3,h4,h5,h6 { font-family:'Syne',sans-serif; color:var(--text); line-height:1.2; letter-spacing:-.03em }
p { margin-bottom:1rem; color:var(--text2) }
p:last-child { margin-bottom:0 }
button { cursor:pointer; font-family:'DM Sans',sans-serif }

/* ─── LAYOUT ─── */
.container { max-width:1200px; margin:0 auto; padding:0 24px }
.container-sm { max-width:840px; margin:0 auto; padding:0 24px }
.section { padding:64px 0 }
.section-sm { padding:40px 0 }

/* ─── TYPOGRAPHY ─── */
.section-title { font-size:clamp(20px,3vw,30px); font-weight:700 }
.section-subtitle { font-size:15px; color:var(--text2); margin-top:6px }
.section-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:28px; gap:12px; flex-wrap:wrap }
.text-grad { background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text }
.text-muted { color:var(--text2) }
.divider { height:1px; background:linear-gradient(90deg,transparent,var(--border),transparent); margin:48px 0 }

/* ─── BUTTONS ─── */
.btn { display:inline-flex; align-items:center; gap:7px; padding:10px 20px; border-radius:10px; font-family:'DM Sans',sans-serif; font-size:14px; font-weight:500; cursor:pointer; border:none; transition:var(--tr); text-decoration:none; white-space:nowrap; line-height:1 }
.btn-primary { background:var(--accent); color:#fff }
.btn-primary:hover { background:#1460e8; transform:translateY(-1px); color:#fff; box-shadow:0 8px 20px rgba(26,111,255,.35) }
.btn-secondary { background:var(--bg3); color:var(--text); border:1px solid var(--border2) }
.btn-secondary:hover { background:var(--bg4); border-color:var(--accent2); color:var(--accent3) }
.btn-outline { background:transparent; color:var(--text2); border:1px solid var(--border2) }
.btn-outline:hover { border-color:var(--accent2); color:var(--accent3); background:rgba(26,111,255,.06) }
.btn-grad { background:var(--grad); color:#fff; border:none }
.btn-grad:hover { opacity:.88; transform:translateY(-1px); color:#fff; box-shadow:0 8px 20px rgba(26,111,255,.3) }
.btn-sm { padding:6px 14px; font-size:12.5px; border-radius:8px }
.btn-lg { padding:13px 28px; font-size:15px; border-radius:12px }
.btn-full { width:100%; justify-content:center }

/* ─── BADGES ─── */
.badge { display:inline-flex; align-items:center; font-size:11px; padding:3px 10px; border-radius:100px; font-weight:600; white-space:nowrap; letter-spacing:.3px }
.badge-free { background:rgba(0,212,255,.1); color:var(--teal); border:1px solid rgba(0,212,255,.22) }
.badge-paid { background:rgba(255,107,43,.1); color:var(--orange); border:1px solid rgba(255,107,43,.22) }
.badge-new  { background:rgba(26,111,255,.12); color:var(--accent2); border:1px solid rgba(26,111,255,.22) }
.badge-hot  { background:rgba(224,64,251,.1); color:var(--pink); border:1px solid rgba(224,64,251,.22) }
.badge-feat { background:rgba(255,179,0,.1); color:var(--amber); border:1px solid rgba(255,179,0,.22) }
.badge-ok   { background:rgba(0,230,118,.1); color:var(--green); border:1px solid rgba(0,230,118,.22) }
.badge-warn { background:rgba(255,179,0,.1); color:var(--amber); border:1px solid rgba(255,179,0,.22) }
.badge-err  { background:rgba(244,67,54,.1); color:var(--red); border:1px solid rgba(244,67,54,.22) }

/* ─── CARDS ─── */
.card { background:var(--bg3); border:1px solid var(--border); border-radius:var(--r2); padding:24px; transition:var(--tr); position:relative; overflow:hidden }
.card:hover { border-color:var(--border2) }
.card-lift:hover { transform:translateY(-4px); box-shadow:var(--sh2) }

/* ─── FORMS ─── */
.form-group { margin-bottom:18px }
.form-label { display:block; margin-bottom:7px; font-size:13px; font-weight:600; color:var(--text) }
.form-label .req { color:var(--red); margin-left:2px }
.form-control { width:100%; background:var(--bg4); border:1.5px solid var(--border2); border-radius:10px; padding:11px 14px; color:var(--text); font-family:'DM Sans',sans-serif; font-size:14px; outline:none; transition:var(--tr) }
.form-control:focus { border-color:var(--accent); box-shadow:0 0 0 4px rgba(26,111,255,.1) }
.form-control::placeholder { color:var(--text3) }
textarea.form-control { resize:vertical; min-height:120px }
select.form-control { cursor:pointer; appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2355556a' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px }
.alert { padding:13px 16px; border-radius:10px; margin-bottom:18px; font-size:14px; display:flex; gap:10px; align-items:flex-start; line-height:1.5 }
.alert-success { background:rgba(0,230,118,.08); border:1px solid rgba(0,230,118,.25); color:var(--green) }
.alert-error   { background:rgba(244,67,54,.08); border:1px solid rgba(244,67,54,.25); color:var(--red) }
.alert-info    { background:rgba(26,111,255,.08); border:1px solid rgba(26,111,255,.25); color:var(--accent2) }
.alert-warn    { background:rgba(255,179,0,.08); border:1px solid rgba(255,179,0,.25); color:var(--amber) }

/* ─── STARS ─── */
.stars { color:var(--amber); font-size:13px; letter-spacing:1px }
.rating { display:flex; align-items:center; gap:5px; font-size:13px; color:var(--text2) }

/* ─── TAGS ─── */
.tag { display:inline-flex; align-items:center; background:var(--bg5); border:1px solid var(--border); border-radius:100px; padding:4px 13px; font-size:12px; color:var(--text2); transition:var(--tr); cursor:pointer; text-decoration:none }
.tag:hover { border-color:var(--accent2); color:var(--accent3) }
.tags-wrap { display:flex; flex-wrap:wrap; gap:8px }

/* ─── SPINNER ─── */
.spinner { width:28px; height:28px; border:2.5px solid var(--border); border-top-color:var(--accent); border-radius:50%; animation:spin .8s linear infinite; margin:0 auto }
@keyframes spin { to { transform:rotate(360deg) } }

/* ─── PULSE ─── */
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(1.4)} }

/* ══════════════════════════════════════════
   HEADER
══════════════════════════════════════════ */
#site-header { position:sticky; top:0; z-index:900; background:rgba(5,5,10,.94); backdrop-filter:blur(22px); -webkit-backdrop-filter:blur(22px); border-bottom:1px solid var(--border) }
.hdr-inner { display:flex; align-items:center; gap:14px; height:64px; padding:0 24px; max-width:1400px; margin:0 auto }

/* Logo */
.vb-logo { display:flex; align-items:center; gap:9px; text-decoration:none; flex-shrink:0; transition:opacity .2s }
.vb-logo:hover { opacity:.82 }
.logo-txt { display:flex; flex-direction:column; line-height:1.05 }
.logo-name { font-family:'Syne',sans-serif; font-weight:800; font-size:16px; letter-spacing:-.3px; background:var(--grad-logo); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text }
.logo-sub { font-size:8px; letter-spacing:2.2px; color:var(--text3); font-weight:600; text-transform:uppercase }

/* Nav */
.main-nav { display:flex; gap:2px; margin-left:10px }
.main-nav a { color:var(--text2); padding:7px 12px; border-radius:8px; font-size:13.5px; transition:var(--tr); text-decoration:none }
.main-nav a:hover,.main-nav a.active { background:var(--bg3); color:var(--text) }
.main-nav a.active { color:var(--accent2) }

/* Header right */
.hdr-right { margin-left:auto; display:flex; align-items:center; gap:8px }

/* Hamburger */
.hamburger { display:none; flex-direction:column; gap:5px; padding:8px; background:none; border:none; cursor:pointer }
.hamburger span { display:block; width:20px; height:2px; background:var(--text2); border-radius:2px; transition:var(--tr) }

/* Mobile menu */
.mobile-nav { display:none; position:fixed; inset:0; top:64px; background:rgba(5,5,10,.98); backdrop-filter:blur(20px); padding:20px 24px; overflow-y:auto; z-index:800 }
.mobile-nav.open { display:block }
.mobile-nav-logo { display:flex; align-items:center; gap:10px; padding-bottom:20px; border-bottom:1px solid var(--border); margin-bottom:16px }
.mobile-nav-logo span { font-family:'Syne',sans-serif; font-weight:800; font-size:18px; background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text }
.mobile-nav a { display:block; color:var(--text2); padding:13px 0; font-size:17px; border-bottom:1px solid var(--border); text-decoration:none; transition:color .2s }
.mobile-nav a:hover { color:var(--text) }
.mobile-nav .mob-cta { margin-top:20px; padding-top:20px; border-top:1px solid var(--border) }

/* Search modal */
#search-modal { display:none; position:fixed; inset:0; background:rgba(5,5,10,.97); backdrop-filter:blur(24px); z-index:1000; padding:60px 20px 20px; overflow-y:auto }
.search-modal-inner { max-width:700px; margin:0 auto }
.search-modal-close { position:absolute; top:20px; right:24px; background:none; border:none; color:var(--text2); font-size:28px; cursor:pointer; transition:color .2s; line-height:1 }
.search-modal-close:hover { color:var(--teal) }

/* ══════════════════════════════════════════
   HERO
══════════════════════════════════════════ */
.hero { padding:88px 0 64px; text-align:center; position:relative; overflow:hidden }
.hero-grid-bg { position:absolute; inset:0; background-image:linear-gradient(rgba(26,111,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(26,111,255,.03) 1px,transparent 1px); background-size:44px 44px; pointer-events:none }
.hero-glow { position:absolute; top:-200px; left:50%; transform:translateX(-50%); width:900px; height:600px; background:radial-gradient(ellipse,rgba(26,111,255,.14) 0%,rgba(0,212,255,.05) 45%,transparent 70%); pointer-events:none }
.hero-badge { display:inline-flex; align-items:center; gap:8px; background:rgba(26,111,255,.08); border:1px solid rgba(26,111,255,.22); border-radius:100px; padding:6px 18px; font-size:12.5px; color:var(--text2); margin-bottom:24px }
.hero-dot { width:7px; height:7px; border-radius:50%; background:var(--teal); animation:pulse 2s infinite; flex-shrink:0 }
.hero h1 { font-size:clamp(32px,7vw,80px); font-weight:800; letter-spacing:-3px; line-height:1.0; margin-bottom:20px }
.hero-sub { font-size:clamp(14px,2vw,18px); color:var(--text2); max-width:580px; margin:0 auto 40px; font-weight:300; line-height:1.8 }

/* Search */
.search-wrap { max-width:700px; margin:0 auto 32px }
.search-box { position:relative }
.search-inp { width:100%; background:var(--bg3); border:1.5px solid var(--border2); border-radius:14px; padding:16px 130px 16px 52px; font-size:15px; color:var(--text); font-family:'DM Sans',sans-serif; outline:none; transition:var(--tr) }
.search-inp:focus { border-color:var(--accent); box-shadow:0 0 0 4px rgba(26,111,255,.12) }
.search-inp::placeholder { color:var(--text3) }
.search-icon { position:absolute; left:18px; top:50%; transform:translateY(-50%); color:var(--text3); pointer-events:none }
.search-btn { position:absolute; right:8px; top:50%; transform:translateY(-50%); background:var(--grad); border:none; color:#fff; height:40px; padding:0 18px; border-radius:10px; font-family:'Syne',sans-serif; font-weight:700; font-size:13px; transition:var(--tr); white-space:nowrap }
.search-btn:hover { opacity:.88 }
.suggestions { position:absolute; top:calc(100% + 8px); left:0; right:0; background:var(--bg3); border:1px solid var(--border2); border-radius:14px; padding:6px; z-index:200; display:none; max-height:320px; overflow-y:auto; box-shadow:var(--sh2) }
.suggestions.show { display:block }
.suggest-item { display:flex; align-items:center; gap:10px; padding:10px 12px; border-radius:9px; transition:background .15s; font-size:14px; color:var(--text2); text-decoration:none }
.suggest-item:hover { background:var(--bg4); color:var(--text) }
.quick-tags { display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin-top:14px }

/* Stats bar */
.stats-bar { display:flex; justify-content:center; gap:48px; flex-wrap:wrap; padding:24px 24px; background:var(--bg2); border-top:1px solid var(--border); border-bottom:1px solid var(--border) }
.stat-item { text-align:center }
.stat-num { font-family:'Syne',sans-serif; font-size:28px; font-weight:800; background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text }
.stat-lbl { font-size:10.5px; color:var(--text3); text-transform:uppercase; letter-spacing:1px; margin-top:2px }

/* ══════════════════════════════════════════
   CATEGORY GRID
══════════════════════════════════════════ */
.cat-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(152px,1fr)); gap:10px }
.cat-card { background:var(--bg3); border:1px solid var(--border); border-radius:var(--r); padding:20px 16px; transition:var(--tr); text-decoration:none; display:block }
.cat-card:hover { border-color:var(--border2); background:var(--bg4); transform:translateY(-3px); box-shadow:var(--sh) }
.cat-card.feat { background:linear-gradient(135deg,rgba(26,111,255,.09),rgba(0,212,255,.05)); border-color:rgba(26,111,255,.28) }
.cat-card.feat:hover { border-color:var(--accent) }
.cat-emoji { font-size:28px; margin-bottom:10px; display:block }
.cat-name { font-family:'Syne',sans-serif; font-size:13px; font-weight:700; color:var(--text); margin-bottom:3px; line-height:1.3 }
.cat-count { font-size:11px; color:var(--text3) }

/* ══════════════════════════════════════════
   TOOL CARDS
══════════════════════════════════════════ */
.tools-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:16px }
.tool-card { background:var(--bg3); border:1px solid var(--border); border-radius:var(--r2); padding:22px; transition:var(--tr); position:relative; overflow:hidden; text-decoration:none; display:block; color:inherit }
.tool-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:var(--grad); opacity:0; transition:opacity .25s }
.tool-card:hover { border-color:var(--border2); background:var(--bg4); transform:translateY(-4px); box-shadow:var(--sh2) }
.tool-card:hover::before { opacity:1 }
.tc-head { display:flex; align-items:flex-start; gap:13px; margin-bottom:12px }
.tc-icon { width:50px; height:50px; border-radius:13px; flex-shrink:0; background:var(--bg5); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; font-size:24px; overflow:hidden }
.tc-icon img { width:100%; height:100%; object-fit:cover; border-radius:13px }
.tc-meta { flex:1; min-width:0 }
.tc-name { font-family:'Syne',sans-serif; font-size:15px; font-weight:700; color:var(--text); margin-bottom:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis }
.tc-cat { font-size:10px; color:var(--accent2); text-transform:uppercase; letter-spacing:.8px; font-weight:600 }
.tc-desc { font-size:13px; color:var(--text2); line-height:1.65; margin-bottom:13px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden }
.tc-foot { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:7px }
.tc-badges { display:flex; gap:5px; flex-wrap:wrap }

/* ══════════════════════════════════════════
   FILTER BAR
══════════════════════════════════════════ */
.filter-bar { background:var(--bg2); border-bottom:1px solid var(--border); padding:12px 0; position:sticky; top:64px; z-index:80 }
.filter-tabs { display:flex; gap:7px; align-items:center; overflow-x:auto; scrollbar-width:none; padding:0 2px }
.filter-tabs::-webkit-scrollbar { display:none }
.ftab { background:var(--bg3); border:1px solid var(--border); border-radius:100px; padding:7px 16px; font-size:12.5px; color:var(--text2); cursor:pointer; transition:var(--tr); font-family:'DM Sans',sans-serif; white-space:nowrap; text-decoration:none; display:inline-block }
.ftab:hover,.ftab.active { background:var(--accent); border-color:var(--accent); color:#fff }
.filter-count { margin-left:auto; font-size:12.5px; color:var(--text3); flex-shrink:0; padding-left:8px }

/* ══════════════════════════════════════════
   TRENDING
══════════════════════════════════════════ */
.trending-list { display:flex; flex-direction:column; gap:8px }
.tr-item { background:var(--bg3); border:1px solid var(--border); border-radius:12px; padding:13px 16px; display:flex; align-items:center; gap:12px; transition:var(--tr); text-decoration:none; color:inherit }
.tr-item:hover { border-color:var(--border2); background:var(--bg4) }
.tr-rank { font-family:'Syne',sans-serif; font-size:18px; font-weight:800; color:var(--border2); min-width:26px; flex-shrink:0 }
.tr-item:nth-child(1) .tr-rank { background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text }
.tr-item:nth-child(2) .tr-rank { color:var(--amber) }
.tr-emoji { width:42px; height:42px; background:var(--bg5); border:1px solid var(--border); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0 }
.tr-name { font-family:'Syne',sans-serif; font-size:13.5px; font-weight:700; color:var(--text) }
.tr-sub { font-size:11.5px; color:var(--text3) }

/* ══════════════════════════════════════════
   BLOG
══════════════════════════════════════════ */
.blog-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:22px }
.blog-card { background:var(--bg3); border:1px solid var(--border); border-radius:var(--r2); overflow:hidden; transition:var(--tr); text-decoration:none; display:block; color:inherit }
.blog-card:hover { border-color:var(--border2); transform:translateY(-4px); box-shadow:var(--sh2) }
.blog-img { height:190px; background:var(--bg5); overflow:hidden; position:relative }
.blog-img img { width:100%; height:100%; object-fit:cover; transition:transform .4s }
.blog-card:hover .blog-img img { transform:scale(1.05) }
.blog-cat-lbl { position:absolute; top:12px; left:12px; background:rgba(26,111,255,.85); backdrop-filter:blur(8px); color:#fff; font-size:11px; padding:3px 11px; border-radius:100px; font-family:'Syne',sans-serif; font-weight:700 }
.blog-body { padding:20px }
.blog-title { font-size:17px; font-weight:700; margin-bottom:9px; color:var(--text); line-height:1.35 }
.blog-card:hover .blog-title { color:var(--accent3) }
.blog-excerpt { font-size:13px; color:var(--text2); line-height:1.7; margin-bottom:14px; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden }
.blog-foot { display:flex; align-items:center; gap:10px; font-size:12px; color:var(--text3) }

/* Blog content */
.blog-content { font-size:15px; line-height:1.9; color:var(--text2) }
.blog-content h2 { font-size:22px; font-weight:700; color:var(--text); margin:32px 0 12px }
.blog-content h3 { font-size:18px; font-weight:700; color:var(--text); margin:24px 0 10px }
.blog-content p { margin-bottom:1.3rem }
.blog-content ul,.blog-content ol { padding-left:22px; margin-bottom:1.3rem }
.blog-content li { margin-bottom:7px }
.blog-content blockquote { border-left:3px solid var(--accent); padding:14px 20px; background:rgba(26,111,255,.06); border-radius:0 10px 10px 0; margin:24px 0; font-style:italic }
.blog-content a { color:var(--accent2) }
.blog-content code { background:var(--bg4); border:1px solid var(--border); padding:2px 7px; border-radius:5px; font-size:13px; color:var(--accent3) }
.blog-content pre { background:var(--bg4); border:1px solid var(--border); border-radius:var(--r); padding:20px; overflow-x:auto; margin:20px 0 }
.blog-content img { border-radius:var(--r2); margin:20px 0 }
.blog-content table { width:100%; border-collapse:collapse; margin:20px 0 }
.blog-content th { background:var(--bg4); padding:12px; border:1px solid var(--border); font-size:14px; text-align:left }
.blog-content td { padding:12px; border:1px solid var(--border); font-size:14px; color:var(--text2) }

/* ══════════════════════════════════════════
   TOOL DETAIL
══════════════════════════════════════════ */
.tool-hero { padding:52px 0 40px; border-bottom:1px solid var(--border) }
.tool-hdr { display:flex; align-items:flex-start; gap:22px; flex-wrap:wrap }
.tool-big-icon { width:88px; height:88px; border-radius:18px; background:var(--bg3); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; font-size:44px; flex-shrink:0; overflow:hidden }
.tool-big-icon img { width:100%; height:100%; object-fit:cover; border-radius:18px }
.tool-content-grid { display:grid; grid-template-columns:1fr 310px; gap:28px; margin-top:36px }
.sidebar-card { background:var(--bg3); border:1px solid var(--border); border-radius:var(--r2); padding:20px; margin-bottom:16px }
.sidebar-card h3 { font-size:15px; font-weight:700; margin-bottom:14px; color:var(--text) }
.detail-section { margin-bottom:36px }
.detail-section h2 { font-size:20px; font-weight:700; margin-bottom:14px }
.detail-li { padding:5px 0 5px 18px; position:relative; color:var(--text2); font-size:14px }
.detail-li::before { content:'→'; position:absolute; left:0; color:var(--accent2); font-size:11px; top:7px }

/* ══════════════════════════════════════════
   COMPARISON
══════════════════════════════════════════ */
.comp-table { width:100%; border-collapse:collapse }
.comp-table th { background:var(--bg3); border:1px solid var(--border); padding:14px 18px; font-family:'Syne',sans-serif; font-size:14px; font-weight:700; text-align:left; color:var(--text) }
.comp-table th:first-child { background:var(--bg4); width:180px }
.comp-table td { padding:13px 18px; border:1px solid var(--border); font-size:14px; color:var(--text2) }
.comp-table tr:hover td { background:rgba(255,255,255,.015) }
.comp-win-col { background:rgba(26,111,255,.05) }
.comp-check { color:var(--green) }
.comp-cross { color:var(--red) }

/* ══════════════════════════════════════════
   CONTACT
══════════════════════════════════════════ */
.contact-grid { display:grid; grid-template-columns:1fr 380px; gap:36px }
.ci-item { display:flex; align-items:flex-start; gap:13px; padding:14px 0; border-bottom:1px solid var(--border) }
.ci-item:last-child { border-bottom:none }
.ci-icon { width:40px; height:40px; border-radius:10px; display:flex; align-items:center; justify-content:center; flex-shrink:0; font-size:18px; background:rgba(26,111,255,.1); border:1px solid rgba(26,111,255,.2) }
.ci-label { font-size:11px; color:var(--text3); text-transform:uppercase; letter-spacing:1px; margin-bottom:3px }
.ci-value { font-size:14px; color:var(--text); font-weight:500 }

/* ══════════════════════════════════════════
   ADMIN
══════════════════════════════════════════ */
.admin-layout { display:grid; grid-template-columns:230px 1fr; min-height:calc(100vh - 64px) }
.admin-side { background:var(--bg2); border-right:1px solid var(--border); padding:20px 0; position:sticky; top:64px; height:calc(100vh - 64px); overflow-y:auto }
.admin-nav-link { display:flex; align-items:center; gap:10px; padding:10px 20px; font-size:13.5px; color:var(--text2); transition:var(--tr); border-left:2px solid transparent; text-decoration:none }
.admin-nav-link:hover,.admin-nav-link.active { background:rgba(26,111,255,.08); color:var(--text); border-left-color:var(--accent) }
.admin-body { padding:28px }
.admin-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:24px }
.admin-stat { background:var(--bg3); border:1px solid var(--border); border-radius:var(--r2); padding:18px }
.admin-stat .num { font-family:'Syne',sans-serif; font-size:28px; font-weight:800; color:var(--text); margin-bottom:3px }
.admin-stat .lbl { font-size:12px; color:var(--text3) }
.admin-tbl-wrap { background:var(--bg3); border:1px solid var(--border); border-radius:var(--r2); overflow:auto }
.admin-tbl { width:100%; border-collapse:collapse; min-width:700px }
.admin-tbl th { background:var(--bg4); padding:10px 14px; font-size:11px; font-weight:700; text-align:left; color:var(--text2); text-transform:uppercase; letter-spacing:.6px; border-bottom:1px solid var(--border) }
.admin-tbl td { padding:13px 14px; font-size:13.5px; color:var(--text2); border-bottom:1px solid var(--border); vertical-align:middle }
.admin-tbl tr:last-child td { border-bottom:none }
.admin-tbl tr:hover td { background:rgba(255,255,255,.015) }

/* ══════════════════════════════════════════
   NEWSLETTER
══════════════════════════════════════════ */
.nl-section { padding:56px 0 }
.nl-wrap { background:linear-gradient(135deg,var(--bg3),var(--bg4)); border:1px solid var(--border); border-radius:28px; padding:52px 40px; text-align:center; position:relative; overflow:hidden }
.nl-wrap::before { content:''; position:absolute; top:-80px; right:-80px; width:280px; height:280px; background:radial-gradient(circle,rgba(26,111,255,.13),transparent 70%); pointer-events:none }
.nl-wrap::after { content:''; position:absolute; bottom:-60px; left:-60px; width:220px; height:220px; background:radial-gradient(circle,rgba(0,212,255,.09),transparent 70%); pointer-events:none }
.nl-form { display:flex; gap:10px; max-width:440px; margin:0 auto }
.nl-inp { flex:1; background:var(--bg); border:1.5px solid var(--border2); border-radius:10px; padding:12px 16px; color:var(--text); font-size:14px; font-family:'DM Sans',sans-serif; outline:none; transition:var(--tr) }
.nl-inp:focus { border-color:var(--accent) }
.nl-inp::placeholder { color:var(--text3) }

/* ══════════════════════════════════════════
   FOOTER
══════════════════════════════════════════ */
#site-footer { background:var(--bg2); border-top:1px solid var(--border); padding:56px 0 0 }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:44px; margin-bottom:44px }
.footer-brand p { font-size:14px; color:var(--text3); line-height:1.8; max-width:300px }
.footer-socials { display:flex; gap:9px; margin-top:18px }
.social-btn { width:34px; height:34px; border-radius:8px; background:var(--bg3); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; color:var(--text3); font-size:14px; transition:var(--tr); text-decoration:none }
.social-btn:hover { background:var(--accent); border-color:var(--accent); color:#fff }
.footer-contact-mini { margin-top:16px; display:flex; flex-direction:column; gap:7px }
.footer-contact-mini a { font-size:12.5px; color:var(--text3); text-decoration:none; display:flex; align-items:center; gap:6px; transition:color .2s }
.footer-contact-mini a:hover { color:var(--teal) }
.footer-col h4 { font-family:'Syne',sans-serif; font-size:12px; font-weight:700; color:var(--text); text-transform:uppercase; letter-spacing:1.2px; margin-bottom:16px }
.footer-col a { display:block; color:var(--text3); font-size:13.5px; margin-bottom:9px; transition:color .2s }
.footer-col a:hover { color:var(--text) }
.footer-seo-section { border-top:1px solid var(--border); padding:18px 0 }
.seo-tags { display:flex; flex-wrap:wrap; gap:7px; margin-top:8px }
.seo-tag { font-size:11px; color:var(--text3); border:1px solid var(--border); border-radius:100px; padding:3px 11px; transition:var(--tr); text-decoration:none }
.seo-tag:hover { color:var(--accent2); border-color:var(--accent2) }
.footer-bottom { border-top:1px solid var(--border); padding:20px 0; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:10px }
.footer-bottom p { font-size:12.5px; color:var(--text3); margin:0 }
.footer-bottom a { color:var(--text3) }
.footer-bottom a:hover { color:var(--accent2) }

/* ══════════════════════════════════════════
   BREADCRUMB & PAGINATION
══════════════════════════════════════════ */
.breadcrumb { display:flex; align-items:center; gap:7px; font-size:13px; color:var(--text3); padding:14px 0; flex-wrap:wrap }
.breadcrumb a { color:var(--text3) }
.breadcrumb a:hover { color:var(--accent2) }
.breadcrumb .cur { color:var(--text2) }
.pagination { display:flex; gap:6px; justify-content:center; align-items:center; padding:36px 0 }
.pg-btn { width:40px; height:40px; border-radius:8px; background:var(--bg3); border:1px solid var(--border); color:var(--text2); font-size:14px; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:var(--tr); text-decoration:none }
.pg-btn:hover { background:var(--bg4); border-color:var(--border2); color:var(--text) }
.pg-btn.active { background:var(--accent); border-color:var(--accent); color:#fff }
.pg-btn.wide { width:auto; padding:0 14px; font-size:13px }

/* ══════════════════════════════════════════
   BACK TO TOP
══════════════════════════════════════════ */
#btt { position:fixed; bottom:22px; right:22px; width:42px; height:42px; border-radius:50%; background:var(--accent); color:#fff; border:none; font-size:18px; z-index:500; opacity:0; transform:translateY(16px); transition:all .3s; box-shadow:0 4px 16px rgba(26,111,255,.4); display:flex; align-items:center; justify-content:center }
#btt.show { opacity:1; transform:translateY(0) }

/* ══════════════════════════════════════════
   WORDPRESS CORE
══════════════════════════════════════════ */
.aligncenter { display:block; margin:0 auto }
.alignleft { float:left; margin:0 20px 14px 0 }
.alignright { float:right; margin:0 0 14px 20px }
.screen-reader-text { border:0; clip:rect(1px,1px,1px,1px); height:1px; margin:-1px; overflow:hidden; padding:0; position:absolute; width:1px }
::-webkit-scrollbar { width:6px; height:6px }
::-webkit-scrollbar-track { background:var(--bg2) }
::-webkit-scrollbar-thumb { background:var(--border2); border-radius:3px }
::-webkit-scrollbar-thumb:hover { background:var(--accent) }

/* ══════════════════════════════════════════
   RESPONSIVE – TABLET (≤900px)
══════════════════════════════════════════ */
@media(max-width:900px) {
  .main-nav { display:none }
  .hamburger { display:flex }
  .hdr-right .btn-secondary { display:none }
  .footer-grid { grid-template-columns:1fr 1fr }
  .tool-content-grid { grid-template-columns:1fr }
  .contact-grid { grid-template-columns:1fr }
  .admin-layout { grid-template-columns:1fr }
  .admin-side { display:none }
  .admin-stats { grid-template-columns:repeat(2,1fr) }
  .tools-grid { grid-template-columns:repeat(2,1fr) }
  .trending-layout { grid-template-columns:1fr }
  .featured-grid { grid-template-columns:1fr 1fr }
}

/* ══════════════════════════════════════════
   RESPONSIVE – MOBILE (≤640px)
══════════════════════════════════════════ */
@media(max-width:640px) {
  .hdr-inner { height:58px; padding:0 14px; gap:10px }
  .logo-name { font-size:13.5px }
  .logo-sub { display:none }
  .hdr-right .btn-grad { font-size:11.5px; padding:7px 11px }
  .filter-bar { top:58px }
  .hero { padding:48px 0 36px }
  .hero h1 { font-size:clamp(26px,8vw,44px); letter-spacing:-1.5px }
  .hero-sub { font-size:14px; margin-bottom:28px; padding:0 8px }
  .hero-badge { font-size:11.5px; padding:5px 14px }
  .search-inp { padding:13px 105px 13px 46px; font-size:14px }
  .search-btn { height:36px; padding:0 12px; font-size:11.5px }
  .quick-tags .tag { font-size:11.5px; padding:4px 11px }
  .stats-bar { display:grid; grid-template-columns:1fr 1fr; gap:14px; padding:16px }
  .stat-num { font-size:22px }
  .cat-grid { grid-template-columns:repeat(3,1fr); gap:7px }
  .cat-card { padding:14px 10px }
  .cat-emoji { font-size:22px; margin-bottom:6px }
  .cat-name { font-size:11px }
  .cat-count { font-size:9px }
  .tools-grid { grid-template-columns:1fr }
  .featured-grid { grid-template-columns:1fr !important }
  .blog-grid { grid-template-columns:1fr }
  .section { padding:36px 0 }
  .container,.container-sm { padding:0 16px }
  .section-title { font-size:20px }
  .section-header .btn { font-size:12px; padding:7px 11px }
  .footer-grid { grid-template-columns:1fr }
  .footer-bottom { flex-direction:column; text-align:center }
  .footer-socials { justify-content:center }
  .seo-tags { justify-content:center }
  .nl-wrap { padding:32px 16px }
  .nl-form { flex-direction:column }
  .nl-wrap h2 { font-size:22px }
  .form-row { grid-template-columns:1fr }
  .admin-stats { grid-template-columns:1fr 1fr }
  .mobile-nav a { font-size:15px }
  .pagination { gap:4px }
  .pg-btn { width:34px; height:34px; font-size:12px }
}

@media(max-width:380px) {
  .cat-grid { grid-template-columns:repeat(2,1fr) }
  .stats-bar { grid-template-columns:1fr }
}
@media(hover:none) {
  .tool-card:hover,.cat-card:hover,.blog-card:hover { transform:none; box-shadow:none }
}
a:focus-visible,button:focus-visible { outline:2px solid var(--accent); outline-offset:2px }
