/* HERO */
.cat-hero { padding:60px 48px 50px; border-bottom:var(--border); }
.cat-hero-inner { max-width:700px; }
.cat-breadcrumb { font-size:.75rem; color:var(--muted); margin-bottom:20px; }
.cat-breadcrumb a { color:var(--muted); text-decoration:none; }
.cat-breadcrumb a:hover { color:var(--ink); }
.cat-hero-emoji { font-size:3rem; margin-bottom:12px; }
.cat-hero-inner h1 { font-family:'Syne',sans-serif; font-size:clamp(2rem,5vw,3.5rem); font-weight:800; letter-spacing:-2px; line-height:1.05; margin-bottom:12px; }
.cat-hero-inner p { font-size:.95rem; color:#666; line-height:1.65; margin-bottom:20px; max-width:560px; }
.cat-stats { display:flex; gap:24px; flex-wrap:wrap; }
.cat-stat { font-size:.82rem; color:var(--muted); }
.cat-stat strong { color:var(--ink); font-weight:700; }

/* SEO INTRO */
.cat-intro { padding:32px 48px; border-bottom:var(--border); background:var(--soft); }
.cat-intro-inner { max-width:900px; }
.cat-intro-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:16px; margin-top:20px; }
.cat-intro-title { font-family:'Syne',sans-serif; font-size:1.1rem; font-weight:800; margin-bottom:8px; }
.cat-fact { background:var(--white); border:var(--border); border-radius:12px; padding:16px 18px; }
.cat-fact-icon { font-size:1.4rem; margin-bottom:8px; }
.cat-fact-label { font-size:.78rem; font-weight:700; margin-bottom:3px; }
.cat-fact-text { font-size:.76rem; color:#666; line-height:1.5; }

/* TOOLS */
.cat-tools-section { padding:36px 48px 60px; max-width:1200px; margin:0 auto; }
.cat-tools-header { display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-bottom:28px; }
.cat-sort { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.cat-sort-label { font-size:.75rem; font-weight:600; color:var(--muted); }
.cat-sort-btn { background:none; border:var(--border); border-radius:100px; padding:6px 14px; font-size:.78rem; font-weight:600; font-family:'Inter',sans-serif; cursor:pointer; color:var(--ink); transition:all .15s; }
.cat-sort-btn.active, .cat-sort-btn:hover { background:var(--ink); color:var(--bg); border-color:var(--ink); }
.cat-filter-precio { display:flex; gap:6px; flex-wrap:wrap; }
.cat-fp-btn { background:none; border:var(--border); border-radius:100px; padding:5px 12px; font-size:.76rem; font-weight:600; font-family:'Inter',sans-serif; cursor:pointer; color:var(--muted); transition:all .15s; }
.cat-fp-btn.active { color:var(--ink); border-color:var(--ink); }
.cat-fp-btn:hover { border-color:var(--ink); color:var(--ink); }

.cat-tools-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:20px; }

/* TOOL CARD */
.cat-tool-card {
  background:var(--white); border:var(--border); border-radius:16px;
  padding:22px; display:flex; flex-direction:column; gap:12px;
  transition:all .2s; position:relative;
}
.cat-tool-card:hover { transform:translate(-3px,-3px); box-shadow:5px 5px 0 var(--ink); }
.ctc-head { display:flex; align-items:flex-start; justify-content:space-between; gap:10px; }
.ctc-icon-name { display:flex; align-items:center; gap:10px; }
.ctc-icon { font-size:1.6rem; width:42px; height:42px; background:var(--bg); border:var(--border); border-radius:10px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.ctc-name { font-family:'Syne',sans-serif; font-size:1rem; font-weight:800; }
.ctc-empresa { font-size:.72rem; color:var(--muted); }
.ctc-fav { background:none; border:none; cursor:pointer; font-size:1.1rem; padding:4px; transition:transform .15s; flex-shrink:0; }
.ctc-fav:hover { transform:scale(1.2); }
.ctc-desc { font-size:.82rem; color:#555; line-height:1.55; flex:1; }
.ctc-tags { display:flex; gap:6px; flex-wrap:wrap; }
.ctc-tag { background:var(--bg); border:var(--border); border-radius:100px; padding:3px 9px; font-size:.68rem; font-weight:600; color:var(--muted); }
.ctc-footer { display:flex; align-items:center; justify-content:space-between; margin-top:auto; }
.ctc-btn { background:var(--accent); color:#fff; border:2px solid var(--ink); border-radius:9px; padding:8px 16px; font-size:.78rem; font-weight:700; text-decoration:none; box-shadow:2px 2px 0 var(--ink); transition:all .15s; display:inline-block; }
.ctc-btn:hover { transform:translate(-1px,-1px); box-shadow:3px 3px 0 var(--ink); }

/* OTRAS CATEGORÍAS */
.cat-otras { padding:40px 48px; border-top:var(--border); }
.cat-otras-title { font-size:.72rem; text-transform:uppercase; letter-spacing:2px; font-weight:700; color:var(--muted); margin-bottom:20px; }
.cat-otras-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); gap:12px; }
.cat-otra-card { background:var(--white); border:var(--border); border-radius:12px; padding:18px 16px; text-decoration:none; color:var(--ink); transition:all .15s; display:block; }
.cat-otra-card:hover { border-color:var(--ink); transform:translateY(-2px); box-shadow:3px 3px 0 var(--ink); }
.cat-otra-emoji { font-size:1.6rem; margin-bottom:8px; }
.cat-otra-name { font-family:'Syne',sans-serif; font-size:.9rem; font-weight:800; margin-bottom:3px; }
.cat-otra-count { font-size:.72rem; color:var(--muted); }

/* CTA */
.cat-cta { background:var(--ink); color:var(--bg); text-align:center; padding:56px 24px; }
.cat-cta-inner { max-width:480px; margin:0 auto; }
.cat-cta h3 { font-family:'Syne',sans-serif; font-size:clamp(1.4rem,3vw,2rem); font-weight:800; margin-bottom:8px; }
.cat-cta p { font-size:.88rem; color:rgba(245,242,235,.6); margin-bottom:24px; line-height:1.6; }
.cat-cta-btns { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.cat-cta-btn { border-radius:10px; padding:12px 22px; font-size:.85rem; font-weight:700; text-decoration:none; transition:all .15s; font-family:'Inter',sans-serif; border:1.5px solid rgba(255,255,255,.2); color:rgba(245,242,235,.7); display:inline-block; }
.cat-cta-btn.primary { background:var(--accent); border-color:var(--accent); color:#fff; }
.cat-cta-btn:hover { background:rgba(255,255,255,.1); color:#fff; }
.cat-cta-btn.primary:hover { background:#ff3a00; }

@media (max-width:768px) {
  .cat-hero { padding:40px 20px; }
  .cat-intro { padding:24px 20px; }
  .cat-tools-section { padding:24px 20px 48px; }
  .cat-otras { padding:32px 20px; }
  .cat-tools-header { flex-direction:column; align-items:flex-start; }
}
