/* ═══════════════════════════════════════
   CSS CUSTOM PROPERTIES — DUAL THEME
═══════════════════════════════════════ */
:root {
  --transition-theme: background 0.35s ease, color 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease;
}

[data-theme="dark"] {
  --bg:          #07090f;
  --bg2:         #0b0e18;
  --surface:     #0f1320;
  --surface2:    #141928;
  --surface3:    #1a2035;
  --border:      rgba(99,179,255,0.10);
  --border-md:   rgba(99,179,255,0.20);
  --border-hi:   rgba(99,179,255,0.45);
  --text:        #eef2ff;
  --text2:       #8899bb;
  --text3:       #3d5070;
  --text4:       #1d2840;
  --accent:      #4fa3ff;
  --accent2:     #a78bfa;
  --accent3:     #f472b6;
  --green:       #34d399;
  --gold:        #fbbf24;
  --red:         #f87171;
  --orange:      #fb923c;
  --glow:        rgba(79,163,255,0.18);
  --glow2:       rgba(167,139,250,0.12);
  --shadow:      0 8px 32px rgba(0,0,0,0.6);
  --shadow-lg:   0 24px 64px rgba(0,0,0,0.7);
  --nav-bg:      rgba(7,9,15,0.88);
  --input-bg:    rgba(255,255,255,0.04);
  --card-hover-bg: rgba(79,163,255,0.04);
  --grid-color:  rgba(99,179,255,0.025);
  --orb1:        rgba(79,163,255,0.06);
  --orb2:        rgba(167,139,250,0.06);
}

[data-theme="light"] {
  --bg:          #f5f7ff;
  --bg2:         #eef1fb;
  --surface:     #ffffff;
  --surface2:    #f8faff;
  --surface3:    #f0f4ff;
  --border:      rgba(79,130,220,0.12);
  --border-md:   rgba(79,130,220,0.25);
  --border-hi:   rgba(79,130,220,0.55);
  --text:        #111827;
  --text2:       #4b5780;
  --text3:       #9baac8;
  --text4:       #c8d4ea;
  --accent:      #2563eb;
  --accent2:     #7c3aed;
  --accent3:     #db2777;
  --green:       #059669;
  --gold:        #d97706;
  --red:         #dc2626;
  --orange:      #ea580c;
  --glow:        rgba(37,99,235,0.12);
  --glow2:       rgba(124,58,237,0.08);
  --shadow:      0 8px 32px rgba(100,120,200,0.12);
  --shadow-lg:   0 24px 64px rgba(100,120,200,0.18);
  --nav-bg:      rgba(245,247,255,0.92);
  --input-bg:    rgba(0,0,0,0.04);
  --card-hover-bg: rgba(37,99,235,0.04);
  --grid-color:  rgba(79,130,220,0.05);
  --orb1:        rgba(37,99,235,0.06);
  --orb2:        rgba(124,58,237,0.05);
}

/* ═══════════════════════════════════════
   RESET & BASE
═══════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);
  color:var(--text);
  font-family:'Outfit',sans-serif;
  overflow-x:hidden;
  min-height:100vh;
  transition:var(--transition-theme);
  line-height:1.6;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:'Outfit',sans-serif}
input,textarea{font-family:'Outfit',sans-serif}
ul{list-style:none}

/* ═══════════════════════════════════════
   BACKGROUND SYSTEM
═══════════════════════════════════════ */
.bg-grid{
  position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:
    linear-gradient(var(--grid-color) 1px,transparent 1px),
    linear-gradient(90deg,var(--grid-color) 1px,transparent 1px);
  background-size:72px 72px;
  transition:var(--transition-theme);
}
.bg-orb{
  position:fixed;border-radius:50%;filter:blur(140px);
  pointer-events:none;z-index:0;
  transition:var(--transition-theme);
}
.orb-a{width:700px;height:700px;background:var(--orb1);top:-250px;left:-200px;animation:drift 25s ease-in-out infinite}
.orb-b{width:600px;height:600px;background:var(--orb2);bottom:-200px;right:-150px;animation:drift 30s ease-in-out infinite reverse}
.orb-c{width:400px;height:400px;background:var(--orb1);top:45%;left:55%;animation:drift 20s ease-in-out infinite 5s}
@keyframes drift{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(50px,-40px) scale(1.06)}
  66%{transform:translate(-30px,50px) scale(0.94)}
}

/* ═══════════════════════════════════════
   SCAN LINE
═══════════════════════════════════════ */
.scan-line{
  position:fixed;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--accent),transparent);
  opacity:0.15;pointer-events:none;z-index:999;
  animation:scan 10s linear infinite;
}
@keyframes scan{0%{top:-2px}100%{top:100vh}}

/* ═══════════════════════════════════════
   NAVIGATION
═══════════════════════════════════════ */
#topnav{
  position:sticky;top:0;z-index:200;
  display:flex;align-items:center;gap:0;
  padding:0 32px;height:64px;
  background:var(--nav-bg);
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  border-bottom:1px solid var(--border);
  transition:var(--transition-theme);
}
.nav-logo{
  font-weight:900;font-size:1.45rem;letter-spacing:-0.04em;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;white-space:nowrap;flex-shrink:0;
  margin-right:auto;
}
.nav-links{
  display:flex;gap:4px;align-items:center;margin-right:20px;
}
.nav-links a{
  color:var(--text2);font-size:0.875rem;font-weight:500;
  padding:6px 14px;border-radius:8px;
  transition:all 0.2s;white-space:nowrap;
}
.nav-links a:hover,.nav-links a.active{
  color:var(--text);background:var(--surface3);
}
.nav-actions{display:flex;gap:10px;align-items:center}
.theme-btn{
  width:40px;height:40px;border-radius:10px;
  border:1px solid var(--border-md);
  background:var(--surface);
  color:var(--text2);font-size:1rem;
  display:flex;align-items:center;justify-content:center;
  transition:all 0.2s;
}
.theme-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--surface3)}
.btn-outline{
  padding:8px 18px;border:1px solid var(--border-md);
  border-radius:10px;background:transparent;
  color:var(--text2);font-size:0.85rem;font-weight:500;
  transition:all 0.2s;
}
.btn-outline:hover{border-color:var(--accent);color:var(--accent)}
.btn-primary{
  padding:8px 20px;border:none;border-radius:10px;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  color:#fff!important;
  -webkit-text-fill-color:#fff!important;
  font-size:0.85rem;font-weight:600;
  transition:all 0.25s;box-shadow:0 0 20px var(--glow);
  text-decoration:none;
}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 0 30px var(--glow),0 4px 16px rgba(0,0,0,0.3);color:#fff!important;-webkit-text-fill-color:#fff!important}
.hamburger{
  display:none;flex-direction:column;gap:5px;
  background:none;border:none;padding:8px;
}
.hamburger span{
  display:block;width:22px;height:2px;
  background:var(--text2);border-radius:2px;transition:all 0.3s;
}
.mobile-menu{
  display:none;position:fixed;top:64px;left:0;right:0;
  background:var(--nav-bg);backdrop-filter:blur(24px);
  border-bottom:1px solid var(--border);z-index:199;
  padding:16px;flex-direction:column;gap:4px;
  transition:var(--transition-theme);
}
.mobile-menu.open{display:flex}
.mobile-menu a{
  padding:12px 16px;border-radius:10px;color:var(--text2);
  font-weight:500;transition:all 0.2s;
}
.mobile-menu a:hover{background:var(--surface3);color:var(--text)}

/* ═══════════════════════════════════════
   HERO SECTION
═══════════════════════════════════════ */
.hero{
  padding:90px 32px 64px;text-align:center;
  position:relative;z-index:10;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 18px;margin-bottom:28px;
  border:1px solid var(--border-md);
  border-radius:100px;font-size:0.75rem;font-weight:600;
  color:var(--accent);letter-spacing:0.08em;
  background:color-mix(in srgb,var(--accent) 8%,transparent);
  font-family:'JetBrains Mono',monospace;
  animation:eyebrowPulse 3s ease-in-out infinite;
}
.live-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--green);animation:blink 1.4s ease-in-out infinite;
}
@keyframes eyebrowPulse{
  0%,100%{box-shadow:0 0 0 0 color-mix(in srgb,var(--accent) 20%,transparent)}
  50%{box-shadow:0 0 0 8px transparent}
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0.3}}
.hero h1{
  font-size:clamp(2.6rem,6vw,5.2rem);font-weight:900;
  letter-spacing:-0.045em;line-height:1.05;
  margin-bottom:22px;
}
.hero h1 em{
  font-style:normal;
  background:linear-gradient(135deg,var(--accent) 0%,var(--accent2) 55%,var(--accent3) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.hero-sub{
  max-width:580px;margin:0 auto 48px;
  color:var(--text2);font-size:1.05rem;font-weight:400;line-height:1.75;
}

/* SEARCH */
.search-wrap{max-width:680px;margin:0 auto;position:relative;z-index:500}
.search-ring{
  position:relative;border-radius:18px;padding:2px;
  background:linear-gradient(135deg,var(--accent),var(--accent2),var(--accent3),var(--accent));
  background-size:300% 300%;
  animation:ringGlow 5s ease infinite;
  box-shadow:0 0 50px var(--glow),0 0 100px var(--glow2);
}
@keyframes ringGlow{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}
.search-box{
  display:flex;align-items:center;gap:12px;
  background:var(--bg2);border-radius:16px;
  padding:8px 8px 8px 22px;
  transition:var(--transition-theme);
}
.search-ic{color:var(--text3);font-size:1.05rem;flex-shrink:0;line-height:1}
.search-box input{
  flex:1;background:transparent;border:none;outline:none;
  color:var(--text);font-size:1rem;font-weight:400;
  transition:color 0.2s;
}
.search-box input::placeholder{color:var(--text3)}
.search-submit{
  padding:11px 26px;border:none;border-radius:12px;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  color:#fff;font-size:0.9rem;font-weight:600;
  transition:all 0.25s;white-space:nowrap;
  box-shadow:0 4px 16px var(--glow);
}
.search-submit:hover{transform:scale(1.03);box-shadow:0 4px 24px var(--glow)}
.search-hints{
  display:flex;flex-wrap:wrap;justify-content:center;gap:8px;
  margin-top:14px;font-size:0.78rem;color:var(--text3);
}
.hint-chip{
  padding:4px 12px;border-radius:100px;
  border:1px solid var(--border);background:var(--surface);
  cursor:pointer;transition:all 0.2s;color:var(--text2);font-size:0.75rem;
}
.hint-chip:hover{border-color:var(--accent);color:var(--accent);background:var(--surface3)}
.search-dropdown{
  position:absolute;top:calc(100% + 10px);left:0;right:0;
  border:1px solid var(--border-md);
  border-radius:16px;overflow:hidden;
  z-index:501;
  box-shadow:0 8px 48px rgba(0,0,0,0.75), 0 0 0 1px color-mix(in oklab, var(--accent) 15%, transparent);
  display:none;
  isolation:isolate;
  -webkit-backdrop-filter:blur(32px) saturate(180%);
  backdrop-filter:blur(32px) saturate(180%);
}
[data-theme="dark"] .search-dropdown{background:rgba(11,14,24,0.97);}
[data-theme="light"] .search-dropdown{background:rgba(248,250,255,0.97);}
.search-dropdown::before{
  content:'';position:absolute;inset:0;border-radius:16px;background:inherit;z-index:-1;
}
.search-dropdown.open{display:block}
.sd-item{
  display:flex;align-items:center;gap:14px;
  padding:13px 20px;cursor:pointer;
  border-bottom:1px solid var(--border);transition:background 0.15s;
}
.sd-item:last-child{border-bottom:none}
.sd-item:hover{background:var(--card-hover-bg)}
.sd-icon{width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;}
.sd-name{font-weight:600;font-size:0.9rem;color:var(--text)}
.sd-cat{font-size:0.72rem;color:var(--text3);font-family:'JetBrains Mono',monospace;margin-top:1px}
.sd-empty{padding:24px;text-align:center;color:var(--text3);font-size:0.85rem}

/* STATS */
.stats-bar{
  display:flex;justify-content:center;flex-wrap:nowrap;gap:0;
  padding:48px 32px 0;position:relative;z-index:0;
  max-width:900px;margin:0 auto;
}
.stat-item{
  text-align:center;padding:0 32px;
  border-right:1px solid var(--border);
  flex:1;min-width:0;
}
.stat-item:last-child{border-right:none}
.stat-n{
  font-size:2.2rem;font-weight:900;letter-spacing:-0.04em;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;display:block;line-height:1.1;
}
.stat-l{font-size:0.72rem;font-weight:600;color:var(--text3);letter-spacing:0.1em;font-family:'JetBrains Mono',monospace;margin-top:4px}

/* ═══════════════════════════════════════
   SECTION SYSTEM
═══════════════════════════════════════ */
.section{padding:64px 32px;max-width:1380px;margin:0 auto;position:relative;z-index:1;}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:36px;gap:16px;}
.section-label{font-size:0.68rem;font-family:'JetBrains Mono',monospace;letter-spacing:0.14em;color:var(--accent);margin-bottom:6px;}
.section-title{font-size:clamp(1.6rem,2.5vw,2.1rem);font-weight:800;letter-spacing:-0.04em;color:var(--text);}
.section-sub{font-size:0.88rem;color:var(--text2);margin-top:6px;}
.see-all{font-size:0.8rem;font-family:'JetBrains Mono',monospace;color:var(--accent);cursor:pointer;white-space:nowrap;border:none;background:none;transition:color 0.2s;}
.see-all:hover{color:var(--accent2)}

/* CATEGORY PILLS */
.cats-wrap{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:36px;}
.cat-pill{
  display:inline-flex;align-items:center;gap:7px;
  padding:8px 18px;border-radius:100px;
  border:1px solid var(--border-md);background:var(--surface);
  color:var(--text2);font-size:0.82rem;font-weight:500;
  cursor:pointer;transition:all 0.2s;
}
.cat-pill:hover,.cat-pill.active{
  border-color:var(--border-hi);color:var(--accent);
  background:color-mix(in srgb,var(--accent) 8%,var(--surface));
}
.cat-cnt{
  font-size:0.68rem;font-family:'JetBrains Mono',monospace;
  color:var(--text3);padding:1px 7px;border-radius:100px;
  background:var(--surface3);
}

/* ═══════════════════════════════════════
   TOOL CARDS
═══════════════════════════════════════ */
.tools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;}
.tools-grid.featured-layout{
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:auto;
}
/* ── CARD RING WRAPPER ── */
/* Cards need a wrapper div for the animated ring.
   We achieve it pure-CSS with a pseudo on the card itself,
   but we need overflow:visible so the glow escapes the box. */
.card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:20px;padding:24px;
  display:flex;flex-direction:column;gap:14px;
  cursor:pointer;position:relative;overflow:visible;
  transition:transform 0.28s cubic-bezier(0.23,1,0.32,1),
              box-shadow 0.28s cubic-bezier(0.23,1,0.32,1),
              border-color 0.28s,
              background 0.35s;
  isolation:isolate;
}
/* Animated gradient border ring — same technique as search bar */
.card::before{
  content:'';
  position:absolute;
  inset:-2px;
  border-radius:22px;
  background:linear-gradient(135deg,var(--accent),var(--accent2),var(--accent3),var(--accent));
  background-size:300% 300%;
  opacity:0;
  z-index:-1;
  transition:opacity 0.3s ease;
  animation:ringGlow 4s ease infinite;
  box-shadow:0 0 32px var(--glow), 0 0 64px var(--glow2);
}
/* Inner bg layer that clips to card shape — keeps content bg solid */
.card::after{
  content:'';
  position:absolute;
  inset:1px;
  border-radius:19px;
  background:var(--surface);
  z-index:-1;
  transition:background 0.35s;
}
.card:hover{
  transform:translateY(-6px);
  box-shadow:0 0 40px var(--glow), 0 0 80px var(--glow2), var(--shadow-lg);
  border-color:transparent;
}
.card:hover::before{opacity:1}
.card>*{position:relative;z-index:1}
.card.featured{grid-column:1;grid-row:1 / 3;}
.featured-mark{
  font-size:0.65rem;font-family:'JetBrains Mono',monospace;
  letter-spacing:0.14em;color:var(--gold);
  margin-bottom:-4px;
}
.card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;}
.tool-icon{
  width:52px;height:52px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;font-size:1.7rem;
  flex-shrink:0;transition:transform 0.3s;
}
.card:hover .tool-icon{transform:scale(1.08) rotate(-2deg)}
.tool-name{font-weight:700;font-size:1.05rem;letter-spacing:-0.02em;color:var(--text);}
.tool-cat{font-size:0.65rem;color:var(--text3);font-family:'JetBrains Mono',monospace;letter-spacing:0.1em;margin-top:2px;}
.badges{display:flex;flex-direction:column;gap:5px;align-items:flex-end;}
.badge{font-size:0.6rem;font-family:'JetBrains Mono',monospace;font-weight:700;letter-spacing:0.12em;padding:3px 9px;border-radius:6px;white-space:nowrap;}
.b-best{background:color-mix(in srgb,var(--gold) 15%,transparent);color:var(--gold);border:1px solid color-mix(in srgb,var(--gold) 30%,transparent);}
.b-new{background:color-mix(in srgb,var(--accent2) 15%,transparent);color:var(--accent2);border:1px solid color-mix(in srgb,var(--accent2) 30%,transparent);}
.b-free{background:color-mix(in srgb,var(--green) 15%,transparent);color:var(--green);border:1px solid color-mix(in srgb,var(--green) 30%,transparent);}
.b-freemium{background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 25%,transparent);}
.b-paid{background:color-mix(in srgb,var(--orange) 15%,transparent);color:var(--orange);border:1px solid color-mix(in srgb,var(--orange) 30%,transparent);}
.tool-desc{font-size:0.84rem;color:var(--text2);line-height:1.68;flex:1;}
.stars-row{display:flex;align-items:center;gap:7px}
.stars{color:var(--gold);font-size:0.82rem;letter-spacing:-0.5px}
.stars-num{font-size:0.76rem;color:var(--text2);font-family:'JetBrains Mono',monospace}
.tags-row{display:flex;flex-wrap:wrap;gap:6px;min-width:0}
.tag{
  font-size:0.68rem;padding:3px 10px;border-radius:6px;
  background:var(--surface3);color:var(--text3);
  border:1px solid var(--border);font-family:'JetBrains Mono',monospace;
  transition:all 0.2s;white-space:nowrap;flex-shrink:0;
}
.card:hover .tag{border-color:var(--border-md);color:var(--text2)}
.card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid var(--border);}
.alt-hint{font-size:0.74rem;color:var(--text3);font-family:'JetBrains Mono',monospace}
.alt-hint span{color:var(--green)}
.card-btn{
  padding:7px 18px;border-radius:9px;border:1px solid var(--border-md);
  background:transparent;color:var(--text2);font-size:0.8rem;font-weight:500;
  transition:all 0.22s;
}
.card-btn:hover{
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  border-color:transparent;color:#fff;box-shadow:0 4px 16px var(--glow);
}

/* ═══════════════════════════════════════
   COMPARE TABLE
═══════════════════════════════════════ */
.compare-wrap{
  background:var(--surface);border:1px solid var(--border);
  border-radius:20px;overflow:hidden;position:relative;
  transition:var(--transition-theme);
}
.compare-wrap::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--accent),var(--accent2),var(--accent3));
}
.compare-head{display:flex;align-items:center;justify-content:space-between;padding:22px 28px;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:12px;}
.compare-title{font-weight:700;font-size:1.05rem;color:var(--text)}
.compare-tabs{display:flex;gap:8px}
.ctab{
  padding:6px 14px;border-radius:8px;font-size:0.78rem;font-weight:500;
  border:1px solid var(--border);background:transparent;color:var(--text2);transition:all 0.2s;
}
.ctab.active,.ctab:hover{background:var(--surface3);color:var(--accent);border-color:var(--border-md)}
.t-scroll{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:0.855rem}
thead th{
  padding:13px 20px;text-align:left;
  font-family:'JetBrains Mono',monospace;font-size:0.66rem;
  letter-spacing:0.12em;color:var(--text3);
  border-bottom:1px solid var(--border);font-weight:500;white-space:nowrap;
}
tbody tr{border-bottom:1px solid color-mix(in srgb,var(--border) 60%,transparent);transition:background 0.18s}
tbody tr:last-child{border-bottom:none}
tbody tr:hover{background:var(--card-hover-bg)}
td{padding:16px 20px;color:var(--text2);vertical-align:middle}
td:first-child{color:var(--text);font-weight:600}
.td-name{display:flex;align-items:center;gap:12px}
.mini-ico{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;}
.tick{color:var(--green);font-weight:700}
.cross{color:var(--red);opacity:0.65}
.part{color:var(--gold)}
.price-free{color:var(--green);font-family:'JetBrains Mono',monospace;font-size:0.78rem}
.price-paid{color:var(--gold);font-family:'JetBrains Mono',monospace;font-size:0.78rem}
.best-row{background:color-mix(in srgb,var(--accent) 4%,transparent)!important}
.best-row:hover{background:color-mix(in srgb,var(--accent) 7%,transparent)!important}

/* ═══════════════════════════════════════
   TRENDING
═══════════════════════════════════════ */
.trending-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;}
.trend-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:14px;padding:18px 18px;
  display:flex;align-items:center;gap:14px;cursor:pointer;
  transition:transform 0.24s, box-shadow 0.24s, border-color 0.24s;
  position:relative;overflow:visible;isolation:isolate;
}
/* Same animated ring as search bar */
.trend-card::before{
  content:'';
  position:absolute;
  inset:-2px;
  border-radius:16px;
  background:linear-gradient(135deg,var(--accent),var(--accent2),var(--accent3),var(--accent));
  background-size:300% 300%;
  opacity:0;
  z-index:-1;
  transition:opacity 0.3s ease;
  animation:ringGlow 4s ease infinite;
  box-shadow:0 0 28px var(--glow), 0 0 56px var(--glow2);
}
/* Solid bg so content doesn't show through ring */
.trend-card::after{
  content:'';
  position:absolute;
  inset:1px;
  border-radius:13px;
  background:var(--surface);
  z-index:-1;
  transition:background 0.35s;
}
.trend-card:hover::before{opacity:1}
.trend-card:hover{
  border-color:transparent;
  transform:translateY(-4px);
  box-shadow:0 0 32px var(--glow), 0 0 64px var(--glow2), 0 12px 32px rgba(0,0,0,0.25);
}
.trend-n{font-size:1.1rem;font-weight:800;color:var(--text4);font-family:'JetBrains Mono',monospace;min-width:26px;}
.trend-info{flex:1}
.trend-name{font-weight:600;font-size:0.9rem;color:var(--text)}
.trend-cat{font-size:0.68rem;color:var(--text3);font-family:'JetBrains Mono',monospace;margin-top:2px;}
.trend-up{font-size:0.72rem;color:var(--green);font-family:'JetBrains Mono',monospace;white-space:nowrap;}

/* ═══════════════════════════════════════
   ARTICLES
═══════════════════════════════════════ */
.articles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;}
.article-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:18px;overflow:hidden;cursor:pointer;
  transition:all 0.28s;display:flex;flex-direction:column;
}
.article-card:hover{transform:translateY(-4px);border-color:var(--border-md);box-shadow:0 16px 40px rgba(0,0,0,0.2);}
.article-thumb{height:155px;display:flex;align-items:center;justify-content:center;font-size:2.8rem;position:relative;overflow:hidden;}
.article-thumb::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,transparent 60%,var(--surface));}
.article-body{padding:20px;flex:1;display:flex;flex-direction:column}
.article-meta{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.article-tag{
  font-size:0.64rem;font-family:'JetBrains Mono',monospace;
  color:var(--accent);padding:2px 10px;border-radius:5px;
  border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);letter-spacing:0.06em;
}
.article-date{font-size:0.72rem;color:var(--text3)}
.article-title{font-weight:700;font-size:0.98rem;letter-spacing:-0.02em;color:var(--text);margin-bottom:8px;line-height:1.4;flex:1;}
.article-excerpt{font-size:0.83rem;color:var(--text2);line-height:1.65}

/* ═══════════════════════════════════════
   AD UNITS — HIDDEN (re-enable when ready)
═══════════════════════════════════════ */
.ad-unit{display:none!important;}
.ad-leaderboard{display:none!important;}
.ad-rectangle{display:none!important;}
.ad-unit small{font-size:0.6rem;opacity:0.5;display:block;margin-top:2px}

/* ═══════════════════════════════════════
   NEWSLETTER
═══════════════════════════════════════ */
.newsletter-block{
  position:relative;z-index:1;
  max-width:1380px;margin:0 auto;padding:0 32px 64px;
}
/* Wrapper handles the ring — inner is the content box */
.newsletter-inner{
  background:var(--surface);
  border-radius:24px;
  padding:56px 80px;
  text-align:center;
  position:relative;
  /* Ring via box-shadow + pseudo on parent */
  /* We use a wrapping technique: gradient border via outline trick */
  isolation:isolate;
  overflow:visible;
  transition:var(--transition-theme);
}
/* Animated gradient ring — identical to search bar */
.newsletter-inner::before{
  content:'';
  position:absolute;
  inset:-2px;
  border-radius:26px;
  background:linear-gradient(135deg,var(--accent),var(--accent2),var(--accent3),var(--accent));
  background-size:300% 300%;
  animation:ringGlow 5s ease infinite;
  box-shadow:0 0 50px var(--glow), 0 0 100px var(--glow2);
  z-index:-1;
}
/* Solid inner layer so content bg stays clean */
.newsletter-inner::after{
  content:'';
  position:absolute;
  inset:1px;
  border-radius:23px;
  background:var(--surface);
  z-index:-1;
  transition:background 0.35s;
}
.newsletter-glow{position:absolute;inset:0;border-radius:24px;background:radial-gradient(ellipse at 50% 0%,var(--glow) 0%,transparent 65%);pointer-events:none;z-index:1;}
.newsletter-inner h2{font-size:2rem;font-weight:800;letter-spacing:-0.04em;margin-bottom:12px;position:relative;color:var(--text);z-index:2;}
.newsletter-inner p{color:var(--text2);font-size:0.95rem;margin-bottom:32px;position:relative;z-index:2;}
.nl-form{display:flex;gap:12px;max-width:440px;margin:0 auto;position:relative;z-index:2;}
.nl-form{display:flex;gap:12px;max-width:440px;margin:0 auto;position:relative;}
.nl-form input{
  flex:1;padding:13px 18px;
  background:var(--input-bg);border:1px solid var(--border-md);
  border-radius:11px;color:var(--text);font-size:0.9rem;outline:none;transition:all 0.2s;
}
.nl-form input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--glow)}
.nl-form input::placeholder{color:var(--text3)}

/* ═══════════════════════════════════════
   MODAL
═══════════════════════════════════════ */
.modal-bg{
  position:fixed;inset:0;background:rgba(0,0,0,0.75);
  backdrop-filter:blur(12px);z-index:500;
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity 0.3s;padding:20px;
}
.modal-bg.open{opacity:1;pointer-events:all}
.modal-box{
  background:var(--surface2);border:1px solid var(--border-md);
  border-radius:22px;padding:36px;max-width:620px;width:100%;
  position:relative;max-height:88vh;overflow-y:auto;
  transform:translateY(24px) scale(0.97);transition:transform 0.3s;
  transition:var(--transition-theme);
}
.modal-bg.open .modal-box{transform:translateY(0) scale(1)}
.modal-box::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent2),var(--accent3));border-radius:22px 22px 0 0;}
.modal-close{
  position:absolute;top:16px;right:16px;width:34px;height:34px;border-radius:9px;
  border:1px solid var(--border-md);background:var(--surface3);color:var(--text2);font-size:1rem;
  display:flex;align-items:center;justify-content:center;transition:all 0.2s;z-index:2;
}
.modal-close:hover{border-color:var(--accent);color:var(--accent)}
.modal-logo-row{display:flex;align-items:center;gap:16px;margin-bottom:20px}
.modal-icon{width:58px;height:58px;border-radius:15px;display:flex;align-items:center;justify-content:center;font-size:1.9rem;flex-shrink:0;}
.modal-box h2{font-size:1.4rem;font-weight:800;letter-spacing:-0.03em;color:var(--text);margin-bottom:4px}
.modal-sub{font-size:0.75rem;font-family:'JetBrains Mono',monospace;color:var(--text3)}
.modal-desc{color:var(--text2);font-size:0.88rem;line-height:1.72;margin-bottom:20px}
.modal-stitle{font-size:0.64rem;font-family:'JetBrains Mono',monospace;letter-spacing:0.14em;color:var(--text3);margin:20px 0 10px;}
.modal-feature{display:flex;gap:10px;font-size:0.85rem;color:var(--text2);margin-bottom:8px;align-items:flex-start;}
.modal-feature::before{content:'✦';color:var(--accent);font-size:0.65rem;flex-shrink:0;margin-top:4px}
.modal-alt{display:flex;align-items:center;justify-content:space-between;padding:11px 15px;border:1px solid var(--border);border-radius:10px;margin-bottom:8px;background:var(--surface3);transition:all 0.2s;}
.modal-alt:hover{border-color:var(--border-md)}
.modal-alt-name{font-weight:600;font-size:0.88rem;color:var(--text)}
.modal-rating-row{display:flex;align-items:center;gap:16px;padding:16px 0;margin-top:4px}
.modal-rating-num{font-size:2.2rem;font-weight:900;letter-spacing:-0.04em;color:var(--accent);line-height:1;}
.modal-btn-row{display:flex;gap:12px;margin-top:24px}
.modal-btn-p{
  flex:1;padding:13px;border:none;border-radius:11px;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  color:#fff;font-weight:600;font-size:0.9rem;transition:all 0.22s;box-shadow:0 4px 16px var(--glow);
}
.modal-btn-p:hover{box-shadow:0 4px 24px var(--glow);transform:translateY(-1px)}
.modal-btn-s{padding:13px 22px;border:1px solid var(--border-md);border-radius:11px;background:var(--surface3);color:var(--text2);font-size:0.9rem;transition:all 0.22s;}
.modal-btn-s:hover{border-color:var(--border-hi);color:var(--text)}

/* ═══════════════════════════════════════
   STATIC PAGES
═══════════════════════════════════════ */
.static-page{max-width:800px;margin:0 auto;padding:64px 32px}
.static-page h1{font-size:2.2rem;font-weight:900;letter-spacing:-0.04em;margin-bottom:12px;color:var(--text)}
.static-page h2{font-size:1.3rem;font-weight:700;letter-spacing:-0.02em;margin:32px 0 12px;color:var(--text)}
.static-page p{color:var(--text2);line-height:1.78;margin-bottom:16px;font-size:0.95rem}
.static-page ul{color:var(--text2);line-height:1.78;margin-bottom:16px;padding-left:20px}
.static-page ul li{margin-bottom:6px;font-size:0.95rem;list-style:disc}
.static-page a{color:var(--accent)}
.page-hero{padding:64px 32px 0;max-width:1380px;margin:0 auto;position:relative;z-index:1;}
.page-badge{display:inline-block;font-size:0.68rem;font-family:'JetBrains Mono',monospace;letter-spacing:0.12em;color:var(--accent);margin-bottom:12px;}

/* SELECT dark mode fix */
select.form-input{
  appearance:none;-webkit-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='%238899bb' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;cursor:pointer;
}
select.form-input option{background:var(--surface2);color:var(--text);}
[data-theme="dark"] select.form-input{color-scheme:dark}
[data-theme="light"] select.form-input{color-scheme:light}

/* ═══════════════════════════════════════
   CATEGORY PAGE
═══════════════════════════════════════ */
.cat-page-back{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--text3);font-size:0.82rem;font-family:'JetBrains Mono',monospace;
  letter-spacing:0.05em;margin-bottom:24px;cursor:pointer;
  transition:color 0.2s;border:none;background:none;padding:0;
}
.cat-page-back:hover{color:var(--accent)}
.cat-page-hero{display:flex;align-items:center;gap:24px;margin-bottom:32px;padding-bottom:32px;border-bottom:1px solid var(--border);}
.cat-hero-icon{width:80px;height:80px;border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:2.4rem;flex-shrink:0;background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 20%,var(--surface)),var(--surface));border:1px solid var(--border-md);}
.cat-hero-title{font-size:clamp(1.6rem,3vw,2.4rem);font-weight:900;letter-spacing:-0.04em;color:var(--text);margin-bottom:6px}
.cat-hero-sub{color:var(--text2);font-size:0.92rem}
.pricing-filter{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:32px}
.pf-btn{padding:8px 18px;border-radius:100px;font-size:0.82rem;font-weight:500;border:1px solid var(--border-md);background:var(--surface);color:var(--text2);cursor:pointer;transition:all 0.2s;}
.pf-btn.active,.pf-btn:hover{border-color:var(--border-hi);color:var(--accent);background:var(--surface3)}

/* ═══════════════════════════════════════
   ARTICLE FULL PAGE
═══════════════════════════════════════ */
.article-full{max-width:760px;margin:0 auto;padding:48px 32px 80px}
.article-full-back{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--text3);font-size:0.82rem;font-family:'JetBrains Mono',monospace;
  letter-spacing:0.05em;margin-bottom:32px;cursor:pointer;
  transition:color 0.2s;border:none;background:none;padding:0;
}
.article-full-back:hover{color:var(--accent)}
.article-hero-thumb{height:280px;border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:5rem;margin-bottom:36px;position:relative;overflow:hidden;border:1px solid var(--border);}
.article-hero-meta{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.article-full h1{font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:900;letter-spacing:-0.04em;line-height:1.15;color:var(--text);margin-bottom:20px;}
.article-byline{display:flex;align-items:center;gap:14px;padding:18px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:36px;}
.author-av{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;flex-shrink:0;}
.author-name{font-weight:600;font-size:0.9rem;color:var(--text)}
.author-role{font-size:0.72rem;color:var(--text3);font-family:'JetBrains Mono',monospace}
.article-read-time{margin-left:auto;font-size:0.75rem;color:var(--text3);font-family:'JetBrains Mono',monospace}
.article-body-content h2{font-size:1.4rem;font-weight:800;letter-spacing:-0.03em;color:var(--text);margin:36px 0 14px;border-top:1px solid var(--border);padding-top:12px;}
.article-body-content h3{font-size:1.1rem;font-weight:700;color:var(--text);margin:24px 0 10px;}
.article-body-content p{color:var(--text2);font-size:0.96rem;line-height:1.82;margin-bottom:18px;}
.article-body-content ul{color:var(--text2);font-size:0.96rem;line-height:1.82;margin-bottom:18px;padding-left:22px;}
.article-body-content ul li{list-style:disc;margin-bottom:7px}
.article-callout{background:color-mix(in srgb,var(--accent) 7%,var(--surface));border:1px solid color-mix(in srgb,var(--accent) 25%,transparent);border-left:3px solid var(--accent);border-radius:0 12px 12px 0;padding:18px 22px;margin:24px 0;}
.article-callout p{color:var(--text);margin-bottom:0}
.article-lead{font-size:1.05rem;line-height:1.85;color:var(--text);border-left:3px solid var(--accent);padding-left:18px;margin-bottom:28px;font-weight:400;}
.article-toc{background:var(--surface2);border:1px solid var(--border-md);border-radius:14px;padding:20px 24px;margin:24px 0 32px;}
.article-toc-title{font-size:0.7rem;font-family:'JetBrains Mono',monospace;color:var(--accent);letter-spacing:0.12em;font-weight:700;margin-bottom:12px;}
.article-toc ul{display:flex;flex-direction:column;gap:6px;padding-left:16px}
.article-toc ul li{list-style:disc;color:var(--text2);font-size:0.88rem}
.article-toc ul li a{color:var(--accent);text-decoration:none;border-bottom:1px solid transparent;transition:border-color 0.2s}
.article-toc ul li a:hover{border-color:var(--accent)}
.article-tags-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:36px;padding-top:28px;border-top:1px solid var(--border)}
.related-articles{margin-top:48px;padding-top:36px;border-top:1px solid var(--border)}
.related-articles h3{font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:20px}
.related-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.related-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden;cursor:pointer;transition:all 0.24s;}
.related-card:hover{border-color:var(--border-md);transform:translateY(-3px)}
.related-thumb{height:90px;display:flex;align-items:center;justify-content:center;font-size:2rem;}
.related-body{padding:14px}
.related-title{font-size:0.85rem;font-weight:600;color:var(--text);line-height:1.4}

/* ═══════════════════════════════════════
   COMPARE BUILDER
═══════════════════════════════════════ */
.compare-builder{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:28px;margin-bottom:32px;position:relative;overflow:hidden;}
.compare-builder::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent2),var(--accent3));}
.builder-title{font-weight:700;font-size:1.05rem;color:var(--text);margin-bottom:6px}
.builder-sub{font-size:0.83rem;color:var(--text2);margin-bottom:20px}
.tool-selector-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;margin-bottom:20px;}
.tool-select-chip{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:12px;border:1px solid var(--border);background:var(--surface3);cursor:pointer;transition:all 0.2s;}
.tool-select-chip.selected{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,var(--surface));}
.tool-select-chip:hover{border-color:var(--border-md)}
.chip-ico{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:0.9rem;flex-shrink:0}
.chip-name{font-size:0.82rem;font-weight:600;color:var(--text);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chip-check{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--border-md);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:0.7rem;color:transparent;transition:all 0.2s}
.tool-select-chip.selected .chip-check{background:var(--accent);border-color:var(--accent);color:#fff}
.builder-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.compare-result{background:var(--surface);border:1px solid var(--border);border-radius:20px;overflow:hidden;transition:var(--transition-theme);display:none;}
.compare-result.visible{display:block}
.compare-result-head{display:flex;align-items:center;justify-content:space-between;padding:20px 28px;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:12px;}
.compare-result-title{font-weight:700;font-size:1rem;color:var(--text)}
.clear-btn{font-size:0.78rem;color:var(--text3);border:none;background:none;cursor:pointer;font-family:'JetBrains Mono',monospace;transition:color 0.2s}
.clear-btn:hover{color:var(--red)}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}
.contact-form{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:32px;transition:var(--transition-theme);}
.contact-form h3{font-size:1.2rem;font-weight:700;margin-bottom:20px;color:var(--text)}
.form-group{margin-bottom:18px}
.form-label{display:block;font-size:0.8rem;font-weight:600;color:var(--text2);margin-bottom:7px;letter-spacing:0.02em;}
.form-input{width:100%;padding:12px 16px;background:var(--input-bg);border:1px solid var(--border-md);border-radius:10px;color:var(--text);font-size:0.9rem;outline:none;transition:all 0.2s;font-family:'Outfit',sans-serif;}
.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--glow)}
textarea.form-input{resize:vertical;min-height:120px;line-height:1.6}
.contact-info-card{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:28px;transition:var(--transition-theme);}
.contact-info-card h3{font-size:1.1rem;font-weight:700;margin-bottom:20px;color:var(--text)}
.contact-item{display:flex;gap:14px;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--border);}
.contact-item:last-child{border-bottom:none}
.contact-ic{width:38px;height:38px;border-radius:10px;background:var(--surface3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;}
.contact-label{font-size:0.72rem;color:var(--text3);font-family:'JetBrains Mono',monospace;margin-bottom:3px}
.contact-val{font-size:0.9rem;color:var(--text);font-weight:500}

/* ABOUT */
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px;margin-top:32px}
.team-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px;text-align:center;transition:all 0.24s;}
.team-card:hover{border-color:var(--border-md);transform:translateY(-3px)}
.team-avatar{width:72px;height:72px;border-radius:50%;margin:0 auto 14px;font-size:2rem;display:flex;align-items:center;justify-content:center;}
.team-name{font-weight:700;font-size:0.95rem;color:var(--text);margin-bottom:4px}
.team-role{font-size:0.75rem;color:var(--text3);font-family:'JetBrains Mono',monospace}
.values-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px;margin-top:24px}
.value-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px;transition:all 0.24s;}
.value-card:hover{border-color:var(--border-md);transform:translateY(-2px)}
.value-ic{font-size:1.8rem;margin-bottom:12px}
.value-title{font-weight:700;font-size:0.95rem;color:var(--text);margin-bottom:8px}
.value-desc{font-size:0.83rem;color:var(--text2);line-height:1.65}

/* ═══════════════════════════════════════
   FOOTER
═══════════════════════════════════════ */
footer{position:relative;z-index:1;border-top:1px solid var(--border);padding:56px 32px 24px;max-width:1380px;margin:0 auto;transition:var(--transition-theme);}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px;}
.footer-brand .nav-logo{display:inline-block;margin-bottom:14px}
.footer-brand p{color:var(--text3);font-size:0.83rem;line-height:1.75;max-width:270px}
.footer-socials{display:flex;gap:10px;margin-top:18px}
.social-btn{width:36px;height:36px;border-radius:9px;border:1px solid var(--border-md);background:var(--surface);color:var(--text3);font-size:0.9rem;display:flex;align-items:center;justify-content:center;transition:all 0.2s;}
.social-btn:hover{border-color:var(--accent);color:var(--accent)}
.footer-col h4{font-family:'JetBrains Mono',monospace;font-size:0.66rem;letter-spacing:0.14em;color:var(--text3);margin-bottom:18px;font-weight:500;}
.footer-col a{display:block;color:var(--text2);font-size:0.85rem;margin-bottom:11px;transition:color 0.2s;font-weight:400;}
.footer-col a:hover{color:var(--accent)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid var(--border);font-size:0.75rem;font-family:'JetBrains Mono',monospace;color:var(--text3);flex-wrap:wrap;gap:12px;}

/* ═══════════════════════════════════════
   TOAST
═══════════════════════════════════════ */
.toast{
  position:fixed;bottom:24px;right:24px;z-index:600;
  background:var(--surface2);border:1px solid var(--border-md);
  border-radius:12px;padding:14px 20px;
  color:var(--text);font-size:0.88rem;font-weight:500;
  box-shadow:var(--shadow-lg);
  transform:translateY(80px);opacity:0;
  transition:all 0.35s cubic-bezier(.23,1,.32,1);
  display:flex;align-items:center;gap:10px;max-width:320px;
}
.toast.show{transform:translateY(0);opacity:1}
.toast-ic{font-size:1.1rem}

/* ═══════════════════════════════════════
   SCROLLBAR
═══════════════════════════════════════ */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--border-hi)}

/* ═══════════════════════════════════════
   ANIMATIONS
═══════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(22px);transition:opacity 0.65s ease,transform 0.65s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.stagger-1{transition-delay:0.08s}
.stagger-2{transition-delay:0.16s}
.stagger-3{transition-delay:0.24s}

/* ═══════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════ */
@media(max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
  .tools-grid.featured-layout{grid-template-columns:1fr 1fr}
  .card.featured{grid-column:1 / -1;grid-row:auto}
}

@media(max-width:768px){
  /* ── NAV ── */
  #topnav{padding:0 14px;height:56px;gap:8px}
  .nav-logo{font-size:1.2rem;margin-right:0}
  .nav-links{display:none}
  .nav-actions{gap:6px}
  .nav-actions .btn-outline,
  .nav-actions .btn-primary{display:none} /* hide on mobile — in hamburger menu */
  .hamburger{display:flex;padding:6px;margin-left:auto}
  .hamburger span{width:20px}
  .mobile-menu{
    top:56px;padding:12px;gap:4px;
    max-height:calc(100vh - 56px);overflow-y:auto;
  }
  .mobile-menu a{
    padding:13px 14px;font-size:0.95rem;
    border-radius:10px;display:flex;align-items:center;gap:10px;
  }

  /* ── HERO ── */
  .hero{padding:40px 16px 28px}
  .hero-eyebrow{font-size:0.68rem;padding:5px 11px}
  .hero h1{font-size:1.9rem;letter-spacing:-0.03em;margin-bottom:14px;line-height:1.08}
  .hero-sub{font-size:0.88rem;line-height:1.65;margin-bottom:24px;padding:0 2px}

  /* ── SEARCH ── */
  .search-wrap{padding:0 2px}
  .search-ring{border-radius:14px}
  .search-box{padding:5px 5px 5px 14px;gap:6px;border-radius:12px}
  .search-box input{font-size:0.9rem;min-width:0;flex:1}
  .search-submit{padding:9px 14px;font-size:0.82rem;border-radius:10px}
  .search-hints{gap:6px;margin-top:10px;flex-wrap:wrap;justify-content:center;padding:0 4px}
  .hint-chip{
    padding:5px 11px;font-size:0.73rem;
    white-space:nowrap;flex-shrink:0;
  }

  /* ── STATS — 2×2 grid on mobile ── */
  .stats-bar{
    flex-wrap:wrap;gap:0;
    padding:28px 16px 0;
    max-width:100%;
  }
  .stat-item{
    flex:1 1 48%;
    padding:14px 10px;
    border-right:none;
    border-bottom:1px solid var(--border);
    text-align:center;
  }
  /* Remove bottom border from last row */
  .stat-item:nth-child(3),
  .stat-item:nth-child(4){border-bottom:none}
  /* Right border on first of each row */
  .stat-item:nth-child(1),
  .stat-item:nth-child(3){border-right:1px solid var(--border)}
  .stat-n{font-size:1.6rem}
  .stat-l{font-size:0.66rem}

  /* ── SECTIONS ── */
  .section{padding:36px 14px}
  .section-title{font-size:1.5rem;letter-spacing:-0.02em}
  .section-sub{font-size:0.88rem}
  .section-head{flex-direction:row;align-items:flex-start;gap:8px}
  .see-all{font-size:0.75rem;white-space:nowrap;padding-top:4px}

  /* ── TOOL CARDS ── */
  .tools-grid,.featured-layout{grid-template-columns:1fr;gap:14px}
  .card{
    padding:18px;
    overflow:hidden; /* clip the ring glow so it doesn't bleed */
    border-radius:16px;
  }
  .card::before{border-radius:18px}
  .card::after{border-radius:15px}
  .card.featured{padding:20px}
  .card-top{gap:10px}
  .tool-icon{width:44px;height:44px;font-size:1.4rem;border-radius:12px}
  .tool-name{font-size:0.95rem}
  .badges{gap:4px}
  .badge{font-size:0.58rem;padding:2px 7px}
  .tags-row{gap:5px;flex-wrap:wrap}
  .tag{font-size:0.62rem;padding:2px 8px}

  /* ── TRENDING ── */
  .trending-grid{grid-template-columns:1fr 1fr;gap:10px}
  .trend-card{padding:13px 12px;border-radius:12px}
  .trend-card::before{border-radius:14px}
  .trend-card::after{border-radius:11px}
  .trend-n{font-size:0.95rem;min-width:22px}
  .trend-name{font-size:0.82rem}
  .trend-cat{font-size:0.62rem}
  .trend-up{font-size:0.66rem}

  /* ── ARTICLES ── */
  .articles-grid{grid-template-columns:1fr;gap:14px}
  .article-thumb{height:120px;font-size:2.2rem}

  /* ── CATEGORIES ── */
  .cats-wrap{
    gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;
    flex-wrap:nowrap;padding:4px 14px 10px;
    margin-left:-14px;margin-right:-14px;
    scrollbar-width:none;
  }
  .cats-wrap::-webkit-scrollbar{display:none}
  .cat-pill{flex-shrink:0;font-size:0.8rem;padding:7px 13px;white-space:nowrap}

  /* ── NEWSLETTER ── */
  .newsletter-block{padding:0 14px 48px}
  .newsletter-inner{padding:32px 20px}
  .newsletter-inner h2{font-size:1.4rem}
  .nl-form{flex-direction:column;gap:10px}
  .nl-form input,.nl-form button{width:100%;font-size:0.92rem}

  /* ── COMPARE ── */
  .compare-tabs{display:none}
  .compare-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .compare-head{flex-direction:column;align-items:flex-start;gap:8px}
  .compare-builder{padding:16px}
  .compare-result{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .compare-result table{min-width:520px;font-size:0.82rem}

  /* ── MODAL ── */
  .modal-bg{padding:0;align-items:flex-end}
  .modal-box{
    padding:20px;max-height:88vh;overflow-y:auto;
    border-radius:20px 20px 0 0;width:100%;margin:0;
  }
  .modal-box h2{font-size:1.15rem}
  .modal-btn-row{flex-direction:column;gap:8px}
  .modal-btn-row a,.modal-btn-row button{width:100%;text-align:center;justify-content:center}

  /* ── FOOTER ── */
  .footer-grid{grid-template-columns:1fr;gap:24px}
  footer{padding:40px 14px 20px}

  /* ── STATIC PAGES ── */
  .static-page{padding:40px 16px 60px}
  .team-grid{grid-template-columns:1fr 1fr;gap:12px}
  .values-grid{grid-template-columns:1fr;gap:12px}
  .contact-grid{grid-template-columns:1fr}

  /* ── ARTICLE PAGES ── */
  .article-full{padding:32px 16px 60px}
  .article-hero-thumb{height:200px;font-size:4rem;border-radius:14px}
  .article-full h1{font-size:1.65rem;line-height:1.18}
  .related-grid{grid-template-columns:1fr}
  .article-body-content h2{font-size:1.2rem}
  .article-body-content p{font-size:0.92rem}

  /* ── ADS — hide all on mobile ── */
  .ad-unit{display:none!important}
}

@media(max-width:480px){
  .hero{padding:32px 14px 24px}
  .hero h1{font-size:1.65rem;line-height:1.07}
  .hero-sub{font-size:0.85rem;margin-bottom:20px}
  .hero-eyebrow{font-size:0.65rem;padding:4px 10px}
  .section{padding:28px 12px}
  .section-title{font-size:1.3rem}
  .stat-n{font-size:1.4rem}
  .stat-l{font-size:0.63rem}
  .card{padding:16px;border-radius:14px}
  .tool-icon{width:40px;height:40px;font-size:1.25rem;border-radius:10px}
  .modal-box{padding:16px}
  .nav-logo{font-size:1.1rem}
  .search-box{padding:4px 4px 4px 12px}
  .search-box input{font-size:0.85rem}
  .search-submit{padding:8px 11px;font-size:0.78rem}
  .hint-chip{font-size:0.7rem;padding:4px 9px}
  .trending-grid{grid-template-columns:1fr;gap:8px}
}

@media(max-width:600px){.related-grid{grid-template-columns:1fr}}

