.cpg-hero{background:linear-gradient(180deg,#f8fafc,#fff);padding-block:clamp(2rem,4.5vw,4rem);border-bottom:1px solid rgba(148,163,184,.14)}.cpg-hero-inner{display:grid;gap:2rem;align-items:center}@media(min-width:860px){.cpg-hero-inner{grid-template-columns:1fr auto}}.cpg-cat-badge{display:inline-flex;align-items:center;gap:.4rem;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:#4f46e5;background:#4f46e512;border:1px solid rgba(79,70,229,.18);border-radius:999px;padding:.22rem .7rem}.cpg-h1{margin-top:.75rem;font-size:clamp(1.75rem,3.5vw,2.75rem);font-weight:900;line-height:1.1;letter-spacing:-.02em;color:#0f172a}.cpg-lead{margin-top:.8rem;font-size:1rem;line-height:1.7;color:#475569;max-width:36rem}.cpg-meta-strip{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid rgba(148,163,184,.2)}.cpg-meta-item{display:inline-flex;align-items:center;gap:.35rem;font-size:.8rem;font-weight:700;color:#475569}.cpg-meta-item svg{color:#4f46e5}.cpg-meta-sep{width:3px;height:3px;border-radius:50%;background:#94a3b880}.cpg-hero-right{display:none}@media(min-width:860px){.cpg-hero-right{display:flex}}.cpg-hero-icon-card{width:6rem;height:6rem;border-radius:1.25rem;background:#f8fafc;border:1.5px solid rgba(148,163,184,.2);display:grid;place-items:center;box-shadow:0 8px 24px #0f172a12}.cpg-hero-icon{width:3rem;height:3rem}.cpg-grid-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.cpg-section-h2{font-size:clamp(1.25rem,2.2vw,1.65rem);font-weight:900;color:#0f172a;letter-spacing:-.01em}.cpg-empty{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:3rem 1rem;text-align:center;border:1.5px dashed rgba(148,163,184,.35);border-radius:1rem}.cpg-empty-icon{width:3rem;height:3rem;border-radius:.75rem;background:#f8fafc;border:1px solid #e2e8f0;display:grid;place-items:center;color:#94a3b8}.cpg-empty-text{font-size:.92rem;color:#64748b;max-width:24rem}.cpg-empty-link{font-size:.87rem;font-weight:700;color:#4f46e5;text-decoration:none}.cpg-tool-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.cpg-tool-card{display:flex;flex-direction:column;gap:.5rem;padding:1.25rem;border-radius:.875rem;border:1.5px solid rgba(148,163,184,.22);background:#fff;text-decoration:none;color:inherit;transition:box-shadow .18s,border-color .18s,transform .18s}.cpg-tool-card:hover{box-shadow:0 10px 32px #0f172a17;border-color:#4f46e54d;transform:translateY(-2px);color:inherit}.cpg-tool-card-top{display:flex;align-items:center;justify-content:space-between}.cpg-tool-badge{display:inline-block;font-size:.67rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;border-radius:999px;padding:.16rem .55rem}.cpg-tool-badge--browser{color:#065f46;background:#d1fae5;border:1px solid #a7f3d0}.cpg-tool-badge--server{color:#1e40af;background:#dbeafe;border:1px solid #bfdbfe}.cpg-tool-card-arrow{color:#94a3b8;transition:color .14s,transform .14s}.cpg-tool-card:hover .cpg-tool-card-arrow{color:#4f46e5;transform:translate(3px)}.cpg-tool-name{font-size:.95rem;font-weight:900;color:#0f172a;margin:.1rem 0 0}.cpg-tool-desc{font-size:.82rem;line-height:1.55;color:#64748b;flex:1;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.cpg-tool-cta{display:inline-flex;align-items:center;gap:.3rem;font-size:.77rem;font-weight:800;color:#4f46e5;margin-top:.4rem;transition:gap .14s}.cpg-tool-card:hover .cpg-tool-cta{gap:.5rem}.cpg-about-grid{display:grid;gap:2.5rem}@media(min-width:860px){.cpg-about-grid{grid-template-columns:1fr 1fr}}.cpg-about-body{margin-top:.75rem;font-size:.95rem;line-height:1.75;color:#475569}.cpg-related-list{display:flex;flex-direction:column;gap:.5rem;margin-top:.75rem}.cpg-related-item{display:flex;align-items:center;gap:.65rem;padding:.75rem 1rem;border-radius:.625rem;border:1.5px solid rgba(148,163,184,.22);background:#fff;text-decoration:none;color:#0f172a;font-size:.88rem;font-weight:700;transition:border-color .14s,background .14s}.cpg-related-item:hover{border-color:#4f46e54d;background:#f5f3ff}.cpg-related-item img{flex-shrink:0;opacity:.7}.cpg-related-item span{flex:1}.cpg-related-item svg{flex-shrink:0;color:#94a3b8}
