.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}:root{--c-bg: #FFFFFF;--c-surface: #FAFAFA;--c-border: #E5E7EB;--c-border-2: #D1D5DB;--c-ink: #111827;--c-muted: #6B7280;--c-subtle: #9CA3AF;--c-brand: #7C3AED;--c-brand-h: #6D28D9;--c-success: #059669;--c-warning: #D97706;--c-danger: #DC2626;--font-sans: "Geist", "Inter", system-ui, sans-serif;--font-mono: "Geist Mono", "JetBrains Mono", ui-monospace, monospace}*{box-sizing:border-box}html,body{margin:0;padding:0}html{background:var(--c-bg);color:var(--c-ink);font-family:var(--font-sans);font-size:15px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body{min-height:100vh}h1,h2,h3,h4{font-family:var(--font-sans);font-weight:600;letter-spacing:-.02em;color:var(--c-ink);margin:0;line-height:1.25}p{margin:0;line-height:1.6}a{color:var(--c-brand);text-decoration:none}a:hover{color:var(--c-brand-h);text-decoration:underline;text-underline-offset:3px}::selection{background:#7c3aed2e;color:var(--c-ink)}.container{max-width:1200px;margin:0 auto;padding:0 1.25rem}@media(min-width:768px){.container{padding:0 1.5rem}}.reading{max-width:760px;margin:0 auto;padding:0 1.25rem}@media(min-width:768px){.reading{padding:0 1.5rem}}.site-header{border-bottom:1px solid var(--c-border);background:#ffffffeb;backdrop-filter:blur(8px);position:sticky;top:0;z-index:20}.brand{font-family:var(--font-sans);font-weight:700;font-size:1rem;color:var(--c-ink);letter-spacing:-.015em;text-decoration:none;display:inline-flex;align-items:center;gap:.45rem}.brand:hover{color:var(--c-brand);text-decoration:none}.brand-dot{display:inline-block;width:6px;height:6px;background:var(--c-brand);border-radius:50%}.nav-link{font-size:.875rem;font-weight:500;color:var(--c-muted);text-decoration:none;padding:.5rem 0}.nav-link:hover{color:var(--c-ink);text-decoration:none}.nav-link[aria-current=page]{color:var(--c-brand)}.tool-card{display:block;padding:1.25rem 1.5rem;background:var(--c-bg);border:1px solid var(--c-border);border-radius:10px;text-decoration:none;color:inherit;transition:border-color .15s,box-shadow .15s,transform .15s}.tool-card:hover{border-color:var(--c-brand);box-shadow:0 2px 8px #7c3aed0f,0 0 0 4px #7c3aed0a;color:inherit;text-decoration:none;transform:translateY(-1px)}.tool-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.85rem}.tool-card h3{font-size:1.05rem;font-weight:600;margin-bottom:.45rem;letter-spacing:-.015em}.tool-card .excerpt{font-size:.875rem;line-height:1.55;color:var(--c-muted);margin-bottom:.85rem}.tool-card .meta-row{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}.badge{display:inline-flex;align-items:center;padding:.15rem .55rem;border-radius:999px;font-family:var(--font-mono);font-size:.7rem;font-weight:600;letter-spacing:.02em;border:1px solid var(--c-border);background:var(--c-bg);color:var(--c-muted);white-space:nowrap}.badge--free{color:var(--c-success);border-color:var(--c-success);background:#0596690f}.badge--freemium{color:#2563eb;border-color:#2563eb;background:#2563eb0d}.badge--paid{color:var(--c-warning);border-color:var(--c-warning);background:#d977060f}.badge--enterprise{color:var(--c-bg);background:var(--c-brand);border-color:var(--c-brand)}.verdict{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .55rem;border-radius:4px;font-family:var(--font-sans);font-size:.72rem;font-weight:600;letter-spacing:.02em}.verdict--recommended{color:var(--c-success);background:#05966914}.verdict--conditional{color:var(--c-warning);background:#d9770614}.verdict--skip{color:var(--c-danger);background:#dc262614}.verdict--watch{color:var(--c-brand);background:#7c3aed14}.chip{display:inline-flex;align-items:center;padding:.2rem .6rem;background:var(--c-bg);border:1px solid var(--c-border);border-radius:999px;font-size:.73rem;font-weight:500;color:var(--c-muted)}.chip--filter{cursor:pointer;user-select:none;transition:background .15s;color:var(--c-ink)}.chip--filter:hover{background:var(--c-surface)}.chip--filter[aria-pressed=true]{background:var(--c-ink);color:var(--c-bg);border-color:var(--c-ink)}.rating{display:inline-flex;align-items:center;gap:.5rem}.rating-dots{display:inline-flex;gap:4px}.rating-dot{width:8px;height:8px;border-radius:50%;background:var(--c-border-2)}.rating-dot--on{background:var(--c-brand)}.rating-score{font-family:var(--font-mono);font-size:.78rem;font-weight:600;color:var(--c-ink)}.tool-body{font-family:var(--font-sans);font-size:1rem;line-height:1.7;color:var(--c-ink)}.tool-body p{margin:0 0 1.1rem}.tool-body h2{font-size:1.4rem;font-weight:600;margin:2.25rem 0 1rem;letter-spacing:-.015em}.tool-body h3{font-size:1.1rem;font-weight:600;margin:1.5rem 0 .6rem}.tool-body ul,.tool-body ol{padding-left:1.4rem;margin:0 0 1.1rem}.tool-body li{margin-bottom:.4rem}.tool-body code{font-family:var(--font-mono);font-size:.85em;padding:.12em .4em;background:var(--c-surface);border:1px solid var(--c-border);border-radius:4px}.tool-body blockquote{margin:1.5rem 0;padding:.85rem 1.25rem;background:#7c3aed0a;border-left:3px solid var(--c-brand);border-radius:0 6px 6px 0;color:var(--c-ink)}.tool-body blockquote p{margin:0}.cmp-table-wrap{overflow-x:auto;border:1px solid var(--c-border);border-radius:10px;margin:1.5rem 0}.cmp-table{width:100%;border-collapse:collapse;font-size:.875rem;background:var(--c-bg)}.cmp-table th,.cmp-table td{padding:.7rem 1rem;text-align:left;border-bottom:1px solid var(--c-border);white-space:nowrap}.cmp-table th{background:var(--c-surface);font-weight:600;font-size:.78rem;color:var(--c-muted);text-transform:uppercase;letter-spacing:.04em;position:sticky;top:0}.cmp-table tr:last-child td{border-bottom:none}.cmp-table td.feat{font-weight:500;color:var(--c-ink)}.cmp-table .yes{color:var(--c-success);font-weight:600}.cmp-table .no{color:var(--c-danger)}.cmp-table .maybe{color:var(--c-warning)}.proscons{display:grid;grid-template-columns:1fr;gap:1rem;margin:1.5rem 0}@media(min-width:768px){.proscons{grid-template-columns:1fr 1fr}}.proscons-block{padding:1rem 1.25rem;border-radius:8px;border:1px solid var(--c-border);background:var(--c-bg)}.proscons-block h4{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin:0 0 .75rem}.proscons-block ul{padding-left:0;margin:0;list-style:none}.proscons-block li{padding-left:1.4rem;position:relative;margin-bottom:.45rem;font-size:.9rem;line-height:1.55}.proscons-block--pros{border-left:3px solid var(--c-success)}.proscons-block--pros h4{color:var(--c-success)}.proscons-block--pros li:before{content:"✓";position:absolute;left:0;top:0;color:var(--c-success);font-weight:700}.proscons-block--cons{border-left:3px solid var(--c-danger)}.proscons-block--cons h4{color:var(--c-danger)}.proscons-block--cons li:before{content:"✗";position:absolute;left:0;top:0;color:var(--c-danger);font-weight:700}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1rem;font-family:var(--font-sans);font-size:.875rem;font-weight:500;text-decoration:none;border-radius:6px;transition:background .15s,border-color .15s,color .15s;min-height:40px}.btn-primary{background:var(--c-brand);color:#fff;border:1px solid var(--c-brand)}.btn-primary:hover{background:var(--c-brand-h);border-color:var(--c-brand-h);color:#fff;text-decoration:none}.btn-ghost{background:var(--c-bg);color:var(--c-ink);border:1px solid var(--c-border)}.btn-ghost:hover{border-color:var(--c-brand);color:var(--c-brand);text-decoration:none;background:var(--c-bg)}.featured-banner{background:linear-gradient(135deg,#7c3aed0f,#7c3aed03);border:1px solid rgba(124,58,237,.18);border-radius:12px;padding:1.75rem}.tool-grid{display:grid;grid-template-columns:1fr;gap:.85rem}@media(min-width:640px){.tool-grid{grid-template-columns:repeat(2,1fr);gap:1rem}}@media(min-width:1024px){.tool-grid{grid-template-columns:repeat(3,1fr)}}.kategori-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}@media(min-width:768px){.kategori-grid{grid-template-columns:repeat(4,1fr)}}.kategori-card{display:block;padding:1rem 1.1rem;background:var(--c-bg);border:1px solid var(--c-border);border-radius:8px;text-decoration:none;color:inherit;transition:border-color .15s,transform .15s}.kategori-card:hover{border-color:var(--c-brand);transform:translateY(-1px);color:inherit;text-decoration:none}.kategori-card .name{font-size:.95rem;font-weight:600;margin-bottom:.3rem}.kategori-card .count{font-family:var(--font-mono);font-size:.75rem;color:var(--c-muted)}@media(prefers-reduced-motion:reduce){.tool-card,.kategori-card,.btn{transition:none}.tool-card:hover,.kategori-card:hover,.btn:hover{transform:none}}
