.site-account{position:relative;flex-shrink:0}.site-account-trigger{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:1px solid var(--color-border);border-radius:999px;background:#fff;color:var(--color-muted);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.site-account-trigger:hover,.site-account-trigger[aria-expanded=true]{color:var(--color-primary);border-color:#2563eb59;background:#2563eb0f}.site-account-trigger-icon{display:block}.site-account-trigger-avatar{width:40px;height:40px;border-radius:999px;object-fit:cover;display:block}.site-account-dropdown{position:absolute;right:0;top:calc(100% + 8px);min-width:240px;padding:8px 0;background:#fff;border:1px solid var(--color-border);border-radius:12px;box-shadow:0 12px 40px #0f172a1f;z-index:120}.site-account-item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 16px;border:none;background:none;font:inherit;font-size:.92rem;font-weight:500;color:var(--color-text);text-decoration:none;text-align:left;cursor:pointer;transition:background .12s}.site-account-item:hover{background:var(--color-bg)}.site-account-item.active{color:var(--color-primary);background:#2563eb0f}.site-account-item-icon{flex-shrink:0;opacity:.85}.site-account-item--logout{border-top:1px solid var(--color-border);margin-top:4px;padding-top:12px;color:#b91c1c}.site-account-item--logout:hover{background:#fef2f2}.site-account-item--logout .site-account-item-icon{opacity:1}@media(max-width:768px){.site-account-dropdown{right:0;left:auto;max-width:min(280px,calc(100vw - 24px))}}.site{min-height:100vh;display:flex;flex-direction:column;background:var(--color-bg)}.site-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--color-border);box-shadow:0 1px #0000000a}.site-header-inner{max-width:var(--page-content-max-width, 1440px);margin:0 auto;padding:0 20px;height:60px;display:flex;align-items:center;gap:16px;flex-wrap:nowrap}.site-nav-search{display:flex;align-items:center;width:min(100%,280px);margin-left:auto;border:1px solid #e2e8f0;border-radius:999px;overflow:hidden;background:#fff;flex-shrink:0}.site-nav-search input{flex:1;min-width:0;border:0;outline:none;padding:8px 12px;font-size:.88rem;color:var(--color-text)}.site-nav-search input::placeholder{color:#94a3b8}.site-nav-search button{width:36px;height:34px;border:0;background:#6d5ce8;color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.site-nav-search button:hover{background:#5a47dd}.site-logo{display:flex;align-items:center;gap:8px;text-decoration:none;color:var(--color-text);font-weight:700;font-size:1.05rem;flex-shrink:0}.site-logo-mark{background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:.85rem}.site-logo-mark-image{width:36px;height:36px;border-radius:10px;display:block;object-fit:cover;flex-shrink:0}.site-logo-text{letter-spacing:-.02em}.site-nav-toggle{display:none;align-items:center;justify-content:center;width:44px;height:44px;margin-left:auto;padding:0;border:1px solid var(--color-border);border-radius:10px;background:#fff;color:var(--color-text);cursor:pointer;flex-shrink:0}.site-nav-toggle:hover{background:var(--color-bg)}.site-nav-toggle-icon{display:block}.site-nav{display:flex;align-items:center;gap:4px;flex:1;min-width:0}.site-nav-backdrop,.site-nav-mobile-panel{display:none}.site-nav-mobile-inner{padding:8px 0 16px;max-height:min(70vh,calc(100dvh - 60px));overflow-y:auto}.site-nav-mobile-item{border-bottom:1px solid var(--color-border)}.site-nav-mobile-item:last-child{border-bottom:none}.site-nav-mobile-link{display:block;padding:14px 20px;text-decoration:none;color:var(--color-text);font-size:.95rem;font-weight:500}.site-nav-mobile-link.active{color:var(--color-primary);background:#2563eb0f}.site-nav-mobile-parent-row{display:flex;align-items:center;gap:8px;padding:10px 16px 10px 20px;min-height:48px}.site-nav-mobile-parent-label{flex:1;font-size:.95rem;font-weight:600;color:var(--color-text)}.site-nav-mobile-parent-link{flex:1;text-decoration:none;color:var(--color-muted);font-size:.95rem;font-weight:500;min-width:0}.site-nav-mobile-parent-link.active{color:var(--color-primary)}.site-nav-mobile-expand{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border:none;border-radius:10px;background:transparent;cursor:pointer;color:var(--color-muted)}.site-nav-mobile-expand:hover{background:var(--color-bg);color:var(--color-text)}.site-nav-mobile-chevron{display:inline-block;width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid currentColor;transition:transform .15s ease}.site-nav-mobile-chevron.is-open{transform:rotate(180deg)}.site-nav-mobile-sub{padding:0 12px 10px 16px;background:#f8fafc}.site-nav-mobile-dd-link{display:flex;align-items:center;gap:10px;padding:10px 12px;text-decoration:none;color:var(--color-text);font-size:.92rem;font-weight:500;border-radius:8px}.site-nav-mobile-dd-link.active{color:var(--color-primary);background:#2563eb14}.site-nav-item{position:relative;display:flex;align-items:center}.site-nav-item>a{padding:8px 14px;border-radius:8px;text-decoration:none;color:var(--color-muted);font-size:.95rem;font-weight:500;transition:background .15s,color .15s}.site-nav-item>a:hover{color:var(--color-text);background:var(--color-bg)}.site-nav-item>a.active{color:var(--color-primary);background:#2563eb14}.site-nav-trigger{display:inline-flex;align-items:center;gap:2px;padding:8px 14px;border-radius:8px;text-decoration:none;color:var(--color-muted);font-size:.95rem;font-weight:500;transition:background .15s,color .15s;background:none;border:none;font:inherit;cursor:pointer;white-space:nowrap}.site-nav-trigger:hover,.site-nav-item.has-dropdown:hover>.site-nav-trigger{color:var(--color-text);background:var(--color-bg)}.site-nav-trigger.active{color:var(--color-primary);background:#2563eb14}.site-nav-chevron{display:inline-block;width:0;height:0;margin-left:4px;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid currentColor;opacity:.55;vertical-align:middle}.site-nav-dropdown{position:absolute;top:calc(100% + 4px);left:0;min-width:240px;padding:8px 0;background:#fff;border:1px solid var(--color-border);border-radius:12px;box-shadow:0 12px 40px #0f172a1f;z-index:200;opacity:0;visibility:hidden;transform:translateY(-6px);pointer-events:none;transition:opacity .18s ease,transform .18s ease,visibility .18s}.site-nav-item.has-dropdown:hover .site-nav-dropdown,.site-nav-item.has-dropdown:focus-within .site-nav-dropdown{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto}.site-nav-dd-link{display:flex;align-items:center;gap:10px;padding:10px 16px;text-decoration:none;color:var(--color-text);font-size:.92rem;font-weight:500;transition:background .12s}.site-nav-dd-link:hover{background:var(--color-bg)}.site-nav-dd-link.active{color:var(--color-primary);background:#2563eb0f}.site-nav-dd-text{flex:1}.site-nav-dd-icon-img{width:22px;height:22px;object-fit:contain;flex-shrink:0}.site-nav-dd-icon-slot{display:flex;align-items:center;justify-content:center;width:28px;height:28px;flex-shrink:0;color:#7c3aed;background:#7c3aed1a;border-radius:8px}.site-nav-dd-icon-slot svg{display:block}.site-nav-dd-icon-emoji{display:flex;align-items:center;justify-content:center;width:28px;height:28px;flex-shrink:0;font-size:1rem;line-height:1;background:#7c3aed14;border-radius:8px}.site-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.site-account-trigger--guest{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--color-border);border-radius:999px;background:#fff;color:#334155;text-decoration:none;transition:background .15s,color .15s,border-color .15s}.site-account-trigger--guest:hover{color:var(--color-primary);border-color:#2563eb59;background:#2563eb0f}.site-link-subtle{font-size:.9rem;color:var(--color-muted);text-decoration:none;padding:6px 10px}.site-link-subtle:hover{color:var(--color-primary)}.site-main{flex:1;width:100%}.site-footer{margin-top:auto;border-top:1px solid var(--color-border);background:#fff;padding:40px 20px}.site-footer-inner{max-width:var(--page-content-max-width, 1440px);margin:0 auto;text-align:center}.site-footer-brand{font-weight:700;margin:0 0 8px;color:var(--color-text)}.site-footer-copy{color:var(--color-muted);font-size:.9rem;max-width:480px;margin:0 auto 16px}.site-footer-links{display:flex;justify-content:center;gap:20px}.site-footer-links a{color:var(--color-primary);text-decoration:none;font-size:.9rem}.site-footer-links a:hover{text-decoration:underline}@media(max-width:768px){.site-header-inner{height:56px;padding:0 14px;gap:10px}.site-nav-toggle{display:inline-flex;margin-left:auto}.site-nav--desktop{display:none!important}.site-nav-backdrop{display:block;position:fixed;right:0;bottom:0;left:0;top:56px;z-index:45;background:#0f172a59}.site-nav-mobile-panel{display:none;position:fixed;left:0;right:0;top:56px;z-index:46;background:#fff;border-bottom:1px solid var(--color-border);box-shadow:0 12px 32px #0f172a1f}.site-nav-mobile-panel.is-open{display:block}.site-actions{margin-left:0;flex-shrink:0}}:root{--page-content-max-width: 1440px;--color-bg: #f4f6f9;--color-card: #ffffff;--color-border: #e8ecf1;--color-text: #111827;--color-muted: #6b7280;--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--radius: 12px;--shadow: 0 1px 3px rgba(0, 0, 0, .06);--shadow-md: 0 4px 14px rgba(0, 0, 0, .07);font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.5;color:var(--color-text);background:var(--color-bg)}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-width:320px}#root{min-height:100vh}a{color:var(--color-primary)}.container{max-width:var(--page-content-max-width);margin:0 auto;padding:0 20px}.page-section{padding:32px 0 48px;text-align:justify}.hero{background:linear-gradient(180deg,#eef2ff 0%,var(--color-bg) 55%);padding:48px 0 40px;border-bottom:1px solid var(--color-border)}.hero-inner{max-width:720px;margin:0 auto;text-align:center;padding:0 20px}.hero h1{margin:0 0 12px;font-size:clamp(1.75rem,4vw,2.25rem);font-weight:800;letter-spacing:-.03em;color:var(--color-text)}.hero p{margin:0 0 24px;color:var(--color-muted);font-size:1.05rem}.search-bar{display:flex;max-width:560px;margin:0 auto;background:#fff;border:1px solid var(--color-border);border-radius:999px;padding:4px 4px 4px 16px;box-shadow:var(--shadow-md)}.search-bar input{flex:1;border:none;outline:none;font-size:1rem;padding:10px 8px;background:transparent}.search-bar button{border:none;background:var(--color-primary);color:#fff;padding:10px 20px;border-radius:999px;font-weight:600;cursor:pointer;font-size:.95rem}.search-bar button:hover{background:var(--color-primary-hover)}.section-title{margin:0 0 8px;font-size:1.35rem;font-weight:700;letter-spacing:-.02em}.section-desc{margin:0 0 20px;color:var(--color-muted);font-size:.95rem}.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.card-tool{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius);padding:20px;text-decoration:none;color:inherit;transition:box-shadow .2s,border-color .2s;display:block;box-shadow:var(--shadow)}.card-tool:hover{box-shadow:var(--shadow-md);border-color:#2563eb40}.card-tool h3{margin:0 0 8px;font-size:1.05rem;font-weight:600;color:var(--color-text)}.card-tool-avatar{width:44px;height:44px;border-radius:12px;border:1px solid var(--color-border);margin-bottom:10px;object-fit:cover}.card-tool-avatar-ph{display:inline-flex;align-items:center;justify-content:center;font-size:.88rem;font-weight:700;color:var(--color-primary);background:#eef2ff}.card-tool p{margin:0;font-size:.9rem;color:var(--color-muted);line-height:1.45;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.card-meta{margin-top:12px;font-size:.8rem;color:var(--color-muted)}.pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;justify-content:center}.pill{display:inline-block;padding:6px 14px;border-radius:999px;background:#fff;border:1px solid var(--color-border);color:var(--color-text);text-decoration:none;font-size:.875rem;font-weight:500;transition:border-color .15s,background .15s}.pill:hover{border-color:var(--color-primary);background:#2563eb0f}.page-hero{padding:28px 0 8px}.page-hero h1{margin:0 0 8px;font-size:1.75rem;font-weight:800;letter-spacing:-.02em}.page-hero p{margin:0;color:var(--color-muted)}.article-body{margin:0 auto;padding:24px 20px 48px;text-align:justify}.article-body.prose{line-height:1.75;color:#374151}.article-body.prose h1{font-size:1.75rem;margin-top:0}.article-body.prose p{margin:1em 0}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;border-radius:10px;font-weight:600;font-size:.95rem;text-decoration:none;border:none;cursor:pointer;transition:background .15s,color .15s}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-hover);color:#fff}.btn-ghost{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}.btn-ghost:hover{background:var(--color-bg)}.btn-google{display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;box-sizing:border-box;text-decoration:none}.btn-google-icon{display:inline-flex;flex-shrink:0}.auth-card{max-width:420px;margin:40px auto;padding:36px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-md)}.auth-card h1{margin:0 0 8px;font-size:1.5rem;font-weight:800}.auth-card .sub{margin:0 0 24px;color:var(--color-muted);font-size:.95rem}.profile-settings-page{max-width:560px}.profile-settings-card{margin-top:20px;padding:24px;background:#fff;border:1px solid var(--color-border);border-radius:12px;box-shadow:var(--shadow)}.profile-avatar-row{display:flex;flex-wrap:wrap;align-items:center;gap:20px;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--color-border)}.profile-avatar-preview{flex-shrink:0}.profile-avatar-img{width:96px;height:96px;border-radius:999px;object-fit:cover;border:1px solid var(--color-border);display:block}.profile-avatar-ph{width:96px;height:96px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;color:var(--color-primary);background:#eef2ff;border:1px solid var(--color-border)}.profile-avatar-upload-label{position:relative;display:inline-block;cursor:pointer}.profile-avatar-file-input{position:absolute;left:0;top:0;width:100%;height:100%;opacity:0;cursor:pointer}.profile-avatar-hint{margin:8px 0 0;font-size:.82rem;color:var(--color-muted)}.profile-settings-h2{font-size:1.15rem;margin:0 0 16px}.form-field{margin-bottom:16px}.form-field label{display:block;font-size:.875rem;font-weight:500;margin-bottom:6px;color:var(--color-text)}.form-field input{width:100%;padding:10px 12px;border:1px solid var(--color-border);border-radius:8px;font-size:1rem}.form-field input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb26}.combo{position:relative;width:100%}.combo__control{display:flex;align-items:center;gap:8px;min-height:44px;padding:4px 10px 4px 12px;border:1px solid var(--color-border);border-radius:8px;background:#fff;transition:border-color .15s,box-shadow .15s}.combo--open .combo__control,.combo__control:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb26}.combo__input{flex:1;min-width:0;border:none;padding:6px 0;font-size:1rem;background:transparent;outline:none}.combo__input::placeholder{color:var(--color-muted)}.combo__icon{flex-shrink:0;display:flex;align-items:center;color:#94a3b8;pointer-events:none}.combo__list{position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:40;margin:0;padding:6px 0;list-style:none;max-height:280px;overflow-y:auto;background:#fff;border:1px solid var(--color-border);border-radius:8px;box-shadow:0 10px 40px #0f172a1f}.combo__option{padding:10px 14px;font-size:.95rem;cursor:pointer;line-height:1.35}.combo__option:hover,.combo__option--hl{background:#eff6ff}.combo__option--selected{font-weight:600;color:var(--color-primary)}.combo__option--clear{color:var(--color-muted);font-size:.9rem}.combo__empty{padding:12px 14px;font-size:.9rem;color:var(--color-muted)}.combo__control--multi{align-items:flex-start;min-height:44px;padding-top:6px;padding-bottom:6px}.combo__chips{flex:1;min-width:0;display:flex;flex-wrap:wrap;align-items:center;gap:6px}.combo__chip{display:inline-flex;align-items:center;gap:4px;max-width:100%;padding:2px 4px 2px 8px;border-radius:6px;background:#eef2ff;border:1px solid #c7d2fe;font-size:.82rem;line-height:1.3}.combo__chip--legacy{background:#fffbeb;border-color:#fde68a}.combo__chip-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.combo__chip-remove{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;padding:0;border:none;border-radius:4px;background:transparent;color:var(--color-muted);font-size:1.1rem;line-height:1;cursor:pointer}.combo__chip-remove:hover{background:#0000000f;color:var(--color-text)}.combo__input--embedded{flex:1;min-width:120px;padding:4px 0}.form-field-label-block{display:block;font-size:.875rem;font-weight:500;margin-bottom:6px;color:var(--color-text)}.form-field-hint{margin:0 0 10px;font-size:.82rem;color:var(--color-muted)}.form-field-occupation{margin-bottom:20px}.form-error{color:#dc2626;font-size:.875rem;margin-top:8px}.form-footer{margin-top:20px;font-size:.9rem;color:var(--color-muted)}.form-footer a{font-weight:500}.tool-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:20px}.badge{text-transform:capitalize;display:inline-block;padding:6px 14px;border-radius:999px;border:1px solid rgba(205,196,242,1);font-size:.75rem;font-weight:600;background:#f9f7ff!important;color:#51418c;text-decoration:none;transition:background-color .2s ease,color .2s ease,border-color .2s ease}a.badge:hover{background:#5b4dc9!important;color:#fff!important;border-color:#5b4dc9!important}a.badge:focus-visible{outline:2px solid #5b4dc9;outline-offset:2px}.badge-primary{background:#2563eb1a;color:var(--color-primary)}.news-list{display:flex;flex-direction:column;gap:12px}.news-row{display:grid;grid-template-columns:88px minmax(0,1fr);gap:16px;align-items:center;padding:20px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius);text-decoration:none;color:inherit;transition:box-shadow .2s}.news-row:hover{box-shadow:var(--shadow-md)}.news-row-thumb{width:88px;height:88px;border-radius:18px;object-fit:cover;background:linear-gradient(145deg,#2563eb2e,#0f172a14),#eef4ff}.news-row-thumb-fallback{display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:800;color:#1747a6;text-transform:uppercase}.news-row-body{min-width:0}.news-row h2{margin:0 0 8px;font-size:1.1rem;font-weight:600}.news-row span{font-size:.85rem;color:var(--color-muted)}.news-pagination{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:24px}.news-page-button{min-width:104px;padding:10px 14px;border:1px solid var(--color-border);border-radius:999px;background:#fff;color:var(--color-text);font:inherit;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.news-page-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md);border-color:#2563eb59}.news-page-button:disabled{opacity:.5;cursor:not-allowed}.news-pagination-status{font-size:.95rem;color:var(--color-muted)}.empty-state{text-align:center;padding:48px 20px;color:var(--color-muted)}.directory-layout{display:grid;grid-template-columns:280px 1fr;gap:20px}.directory-main{display:flex;flex-direction:column;gap:28px}.directory-side{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius);padding:14px;height:fit-content;position:sticky;top:72px}.directory-side h3{margin:0 0 10px}.side-tool{display:flex;align-items:center;gap:8px;padding:8px;border-radius:10px;text-decoration:none;color:var(--color-text)}.side-tool img,.side-placeholder{width:28px;height:28px;border-radius:8px;border:1px solid var(--color-border);object-fit:cover;display:inline-flex;align-items:center;justify-content:center}@media(max-width:1000px){.directory-layout{grid-template-columns:1fr}.directory-side{position:static}}.home-3col{display:grid;grid-template-columns:minmax(240px,280px) minmax(0,1fr) minmax(220px,300px);gap:24px;align-items:start}.home-col-title{margin:0 0 14px;font-size:1.05rem;font-weight:700;letter-spacing:-.02em}.home-col-features .home-col-title{padding-left:2px}.home-featured-stack{display:flex;flex-direction:column;gap:12px}.featured-tool-card{position:relative;display:block;padding:14px;background:var(--color-card);border:1px solid #dbeafe;border-radius:var(--radius);text-decoration:none;color:inherit;overflow:hidden;box-shadow:var(--shadow);transition:box-shadow .2s,border-color .2s}.featured-tool-card:hover{box-shadow:var(--shadow-md);border-color:#2563eb47}.featured-tool-badge{position:absolute;top:10px;right:10px;z-index:2;font-size:.7rem;font-weight:700;padding:3px 8px;border-radius:6px;background:#f3f4f6;color:var(--color-muted)}.featured-tool-watermark{position:absolute;right:-8px;bottom:-12px;width:120px;height:120px;background-repeat:no-repeat;background-position:right bottom;background-size:contain;opacity:.09;pointer-events:none}.featured-tool-top{position:relative;z-index:1;display:flex;align-items:center;gap:10px;margin-bottom:8px}.featured-tool-avatar{width:40px;height:40px;border-radius:10px;border:1px solid var(--color-border);object-fit:cover;flex-shrink:0}.featured-tool-avatar-ph{display:inline-flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:var(--color-muted);background:#f3f4f6}.featured-tool-name{font-weight:700;font-size:.95rem;line-height:1.25}.featured-tool-desc{position:relative;z-index:1;margin:0;font-size:.82rem;color:var(--color-muted);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.home-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px;padding-bottom:4px;border-bottom:1px solid var(--color-border)}.home-tab{border:none;background:transparent;color:var(--color-muted);font-size:.88rem;font-weight:600;padding:8px 12px;border-radius:8px;cursor:pointer;font-family:inherit;transition:background .15s,color .15s}.home-tab:hover{color:var(--color-text);background:#0000000a}.home-tab.is-active{color:var(--color-text);background:#eef2f6}.home-tab-panel{min-height:120px}.home-tab-loading{padding:12px 0;font-size:.9rem}.home-tool-list{list-style:none;margin:0;padding:0}.home-tool-row{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--color-border);text-decoration:none;color:inherit;align-items:flex-start;transition:background .12s}.home-tool-list li:last-child .home-tool-row{border-bottom:none}.home-tool-row:hover .home-tool-row-name{color:var(--color-primary)}.home-tool-row-avatar{width:56px;height:56px;border-radius:14px;border:1px solid var(--color-border);object-fit:cover;flex-shrink:0}.home-tool-row-avatar-ph{display:inline-flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:var(--color-muted);background:#f3f4f6}.home-tool-row-body{min-width:0;flex:1}.home-tool-row-titleline{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:4px}.home-tool-row-name{font-weight:700;font-size:1rem;letter-spacing:-.02em}.home-tool-row-desc{margin:0 0 8px;font-size:.9rem;color:var(--color-muted);line-height:1.45}.home-tool-row-tags{display:flex;flex-wrap:wrap;gap:8px}.home-tool-tag{font-size:.78rem;color:var(--color-primary);font-weight:500}.home-badge{font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:6px}.home-badge-free,.home-badge-muted{background:#f3f4f6;color:var(--color-muted)}.home-col-news{position:sticky;top:72px}.home-news-card{background:#f4f6f8;border:1px solid var(--color-border);border-radius:var(--radius);padding:16px 16px 14px;box-shadow:var(--shadow)}.home-news-heading{margin:0 0 14px;font-size:1.05rem;font-weight:700;display:flex;align-items:center;gap:8px}.home-news-icon{font-size:1.1rem}.home-news-list{margin:0;padding:0;list-style:none;counter-reset:none}.home-news-item{display:flex;gap:10px;align-items:flex-start;margin-bottom:10px;font-size:.88rem;line-height:1.35}.home-news-item:last-child{margin-bottom:0}.home-news-num{flex-shrink:0;width:1.4rem;font-weight:800;font-size:.95rem;color:#9ca3af}.home-news-num.is-top{color:#b45309}.home-news-link{color:var(--color-text);text-decoration:none;font-weight:500}.home-news-link:hover{color:var(--color-primary)}.home-news-more{display:inline-block;margin-top:14px;font-size:.88rem;font-weight:600}.home-empty-inline{padding:20px 0;text-align:left}.home-github-below{margin-top:40px;padding-top:8px;border-top:1px solid var(--color-border)}.category-directory-hero{padding:10px 0 20px}.category-directory-hero h1{margin:0 0 8px;font-size:clamp(1.5rem,3vw,2rem);font-weight:800;letter-spacing:-.02em}.category-directory-hero p{margin:0;color:var(--color-muted)}.category-directory-layout{display:grid;grid-template-columns:250px minmax(0,1fr);gap:22px}.category-directory-side{padding-right:8px;border-right:1px solid var(--color-border)}.category-directory-side h2{margin:0 0 14px;font-size:1.05rem}.category-directory-side-list{display:flex;flex-direction:column;gap:8px}.category-directory-side-item{display:block;text-decoration:none;color:var(--color-text);font-size:.95rem;padding:5px 6px;border-radius:8px}.category-directory-side-item:hover{background:#f2f5f8}.category-directory-main{display:flex;flex-direction:column;gap:24px;min-width:0}.category-directory-section{min-width:0}.category-directory-title{margin:0 0 12px;font-size:1.7rem;font-weight:800;letter-spacing:-.02em}.category-featured-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.category-featured-card{display:block;text-decoration:none;color:inherit;background:var(--color-card);border:1px solid #dae8ff;border-radius:12px;padding:14px;box-shadow:var(--shadow)}.category-featured-head{margin-bottom:8px}.category-featured-avatar{width:36px;height:36px;border-radius:10px;object-fit:cover;border:1px solid var(--color-border);display:inline-flex;align-items:center;justify-content:center}.category-featured-avatar-ph{background:#eef2ff;color:var(--color-primary);font-size:.8rem;font-weight:700}.category-featured-card:hover{box-shadow:var(--shadow-md)}.category-featured-name{display:block;font-weight:700;margin-bottom:4px}.category-featured-desc{display:block;font-size:.87rem;color:var(--color-muted)}.category-directory-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px 12px}.category-directory-cell{display:flex;align-items:center;justify-content:space-between;gap:10px;text-decoration:none;color:var(--color-text);background:#fff;border:1px solid var(--color-border);border-radius:9px;padding:10px 12px;font-size:.92rem}.category-directory-cell:hover{border-color:#c8d7f1;box-shadow:var(--shadow)}.category-directory-cell-cta{font-size:.78rem;color:var(--color-muted)}.category-tools-hero{padding:8px 0 18px}.category-tools-hero-image-wrap{width:100%;height:clamp(170px,22vw,260px);border-radius:14px;overflow:hidden;margin-bottom:12px;border:1px solid var(--color-border);background:#f4f6f8}.category-tools-hero-image{width:100%;height:100%;object-fit:cover;display:block}.category-tools-hero-image-ph{width:100%;height:100%;background:linear-gradient(135deg,#e5ecff,#f4f6fb,#e9f3ff)}.category-tools-hero h1{margin:auto;font-size:clamp(1.5rem,3vw,2.1rem);font-weight:800;text-align:center}.category-tools-hero p{margin:auto;color:var(--color-muted);text-align:center;width:60%}.category-tools-toolbar{margin-top:14px;display:flex;flex-wrap:wrap;gap:10px 12px;align-items:center}.category-tools-toolbar label{display:flex;align-items:center;gap:8px;font-size:.86rem;color:var(--color-muted)}.category-tools-toolbar select{border:1px solid var(--color-border);border-radius:8px;padding:7px 10px;background:#fff;color:var(--color-text)}.category-tools-back-link{text-decoration:none;color:var(--color-primary);font-weight:600;margin-left:auto}.category-tools-layout{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:20px;align-items:start}.category-tools-section-title{margin:0 0 12px;font-size:1.4rem;font-weight:800}.category-tools-list{display:flex;flex-direction:column;gap:12px}.category-tools-item{background:#fff;border:1px solid var(--color-border);border-radius:12px;padding:14px 14px 12px}.category-tools-item-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.category-tools-item-name{display:inline-flex;align-items:center;gap:10px;color:var(--color-text);text-decoration:none;font-weight:700}.category-tools-item-avatar{width:34px;height:34px;border-radius:9px;object-fit:cover;border:1px solid var(--color-border)}.category-tools-item-avatar-ph{display:inline-flex;align-items:center;justify-content:center;font-size:.76rem;font-weight:700;color:var(--color-primary);background:#eef2ff}.category-tools-visit-btn{text-decoration:none;border:1px solid #d8dff0;border-radius:8px;padding:7px 11px;font-size:.84rem;color:var(--color-primary);font-weight:600;white-space:nowrap}.category-tools-item-desc{margin:10px 0 8px;color:var(--color-muted);font-size:.92rem;line-height:1.5}.category-tools-item-meta{display:flex;flex-wrap:wrap;gap:8px 14px;font-size:.82rem;color:var(--color-muted)}.category-tools-featured{position:sticky;top:82px}.category-tools-featured-list{display:flex;flex-direction:column;gap:10px}.category-tools-featured-card{display:flex;flex-direction:column;gap:5px;text-decoration:none;color:var(--color-text);background:#fff;border:1px solid #dae8ff;border-radius:11px;padding:12px}.category-tools-featured-head{margin-bottom:2px}.category-tools-featured-avatar{width:34px;height:34px;border-radius:9px;object-fit:cover;border:1px solid var(--color-border);display:inline-flex;align-items:center;justify-content:center}.category-tools-featured-avatar-ph{background:#eef2ff;color:var(--color-primary);font-size:.78rem;font-weight:700}.tool-detail-avatar-ph{width:84px;height:84px;border-radius:18px;border:1px solid #e5e7eb;margin-bottom:12px;display:inline-flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;color:var(--color-primary);background:#eef2ff}.tool-detail-hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,460px);gap:26px;margin-bottom:18px;align-items:start}.tool-detail-hero>*{min-width:0}.tool-detail-title-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:8px;width:100%}.tool-detail-title{margin:0;font-size:clamp(1.6rem,2.5vw,2.2rem);font-weight:800;letter-spacing:-.02em}.tool-detail-rating-line{margin:0 0 14px;color:var(--color-muted);font-size:.95rem}.tool-detail-meta-grid{display:grid;grid-template-columns:130px 1fr;gap:8px 10px;margin:0 0 14px}.tool-detail-meta-grid dt{color:var(--color-text);font-weight:700}.tool-detail-meta-grid dd{margin:0;color:#374151}.tool-detail-tags{display:flex;flex-wrap:wrap;gap:8px}.tool-detail-preview{overflow:hidden;min-height:260px}.tool-detail-preview-wrap{position:relative;margin-top:22px}.tool-detail-cover-social{top:10px;right:10px;z-index:2;display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;max-width:calc(100% - 20px);margin-bottom:10px}.tool-detail-cover-social-btn{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:999px;background:#fffffff0;border:1px solid rgba(15,23,42,.08);color:var(--color-primary);box-shadow:0 2px 8px #00000014;transition:transform .15s,box-shadow .15s}.tool-detail-cover-social-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000001a;color:var(--color-primary-hover)}.tool-detail-toolbar{margin-bottom:4px}.tool-detail-toolbar .tool-actions{margin-top:0}.tool-detail-preview-image{width:100%;height:100%;min-height:260px;object-fit:cover;display:block}.tool-detail-preview-ph{width:100%;min-height:260px;margin:0;border:none;border-radius:0;font-size:3rem}.tool-detail-tabs{display:flex;flex-wrap:wrap;gap:2px;border-bottom:1px solid var(--color-border);margin-bottom:18px}.tool-detail-tab{border:none;background:transparent;color:var(--color-muted);font-size:.93rem;font-weight:700;padding:11px 14px;cursor:pointer;font-family:inherit;text-decoration:none}.tool-detail-tab.is-active{color:var(--color-primary);border-bottom:2px solid var(--color-primary)}.tool-detail-content{margin:0;padding:8px 0 48px;max-width:none}.tool-detail-title-with-avatar{display:flex;align-items:center;gap:12px;min-width:0;flex:1}.tool-detail-title-row>.btn{flex-shrink:0;margin-left:auto}.tool-detail-inline-avatar{width:48px;height:48px;border-radius:12px;object-fit:cover;border:1px solid var(--color-border);flex-shrink:0}.tool-detail-inline-avatar-ph{width:48px;height:48px;border-radius:12px;border:1px solid var(--color-border);display:inline-flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:800;color:var(--color-primary);background:#eef2ff;flex-shrink:0}.tool-detail-rating-text{color:var(--color-muted);font-size:.92rem}.tool-detail-preview-fallback{width:100%;min-height:260px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#eef2ff,#f8fafc,#e8f0fe)}.tool-detail-preview-fallback-img{width:100%;height:100%;min-height:260px;object-fit:cover;display:block}.tool-detail-section{scroll-margin-top:88px;margin-bottom:28px}.tool-detail-section-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius);padding:22px 22px 20px;box-shadow:var(--shadow);min-width:0;max-width:100%}.tool-detail-h2{margin:0 0 16px;font-size:1.35rem;font-weight:700;letter-spacing:-.02em;padding-bottom:8px;border-bottom:1px solid var(--color-border)}.tool-detail-h3{margin:0 0 12px;font-size:1.15rem;font-weight:600}.tool-detail-md{padding-top:4px;max-width:100%;overflow-x:auto}.tool-detail-md img,.tool-detail-md video,.tool-detail-md svg:not([width]):not([height]){max-width:100%;height:auto}.tool-detail-md table{border-collapse:collapse;width:100%;max-width:100%}.tool-detail-md pre{max-width:100%;overflow-x:auto;white-space:pre-wrap;word-break:break-word}.tool-detail-md h1{font-size:1.5rem;font-weight:700;margin:.6em 0 .4em}.tool-detail-md h2{font-size:1.25rem;font-weight:600;margin:1em 0 .5em;padding-bottom:.25em;border-bottom:1px solid var(--color-border)}.tool-detail-md h3{font-size:1.1rem;font-weight:600;margin:.9em 0 .4em}.tool-detail-md p{margin:.75em 0}.tool-detail-md ul,.tool-detail-md ol{margin:.5em 0 .75em 1.2em}.tool-detail-actions-row{margin-top:18px}.tool-detail-social-row{margin-top:10px;display:flex;gap:8px;flex-wrap:wrap}.tool-detail-muted{color:var(--color-muted);margin:0}.tool-detail-review-summary{display:flex;flex-wrap:wrap;align-items:center;gap:12px 16px;margin-bottom:14px}.tool-detail-review-prompt{margin:0 0 14px;font-weight:600}.tool-detail-stars{display:inline-flex;align-items:center;gap:2px}.tool-detail-stars.is-interactive .tool-detail-star-btn{cursor:pointer}.tool-detail-star-btn{border:none;background:transparent;padding:0 2px;line-height:1}.tool-detail-review-form{border:1px solid #fecaca;border-radius:12px;padding:16px;background:#fff;margin-bottom:22px}.tool-detail-guest-name{margin:12px 0 10px}.tool-detail-guest-name label{display:block;font-size:.85rem;font-weight:600;margin-bottom:6px}.tool-detail-input{width:100%;max-width:320px;padding:8px 12px;border-radius:8px;border:1px solid var(--color-border);font-size:.95rem}.tool-detail-review-compose-row{display:flex;gap:12px;align-items:flex-start;margin-top:10px}.tool-detail-guest-avatar{width:40px;height:40px;border-radius:999px;background:#ede9fe;color:var(--color-primary);font-weight:700;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.95rem}.tool-detail-textarea-wrap{position:relative;flex:1;min-width:0}.tool-detail-textarea{width:100%;border-radius:10px;border:1px solid #f87171;padding:10px 10px 28px;font-size:.95rem;font-family:inherit;resize:vertical;min-height:120px}.tool-detail-char-count{position:absolute;right:10px;bottom:8px;font-size:.78rem;color:var(--color-muted)}.tool-detail-turnstile{margin-top:12px;min-height:65px}.tool-detail-review-actions{margin-top:14px;display:flex;flex-wrap:wrap;gap:10px;align-items:center}.tool-detail-hint{margin-top:10px;font-size:.88rem}.tool-detail-review-item{border:1px solid var(--color-border);border-radius:10px;padding:12px 14px;margin-bottom:10px;background:#fff}.tool-detail-review-item-head{display:flex;justify-content:space-between;gap:10px;margin-bottom:6px;font-size:.92rem}.tool-detail-review-body{margin:0;white-space:pre-wrap;line-height:1.5}.category-tools-featured-card span{color:var(--color-muted);font-size:.84rem;line-height:1.45}@media(max-width:1100px){.home-3col{grid-template-columns:1fr}.home-col-news{position:static}.category-directory-layout{grid-template-columns:1fr;gap:16px}.category-directory-side{border-right:none;border-bottom:1px solid var(--color-border);padding-right:0;padding-bottom:12px}.category-tools-layout{grid-template-columns:1fr}.category-tools-featured{position:static}.tool-detail-hero{grid-template-columns:1fr}.category-tools-back-link{margin-left:0}.category-featured-grid,.category-directory-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:700px){.category-featured-grid,.category-directory-grid{grid-template-columns:1fr}.category-directory-title{font-size:1.35rem}}@media(max-width:768px){.news-row{grid-template-columns:64px minmax(0,1fr);gap:12px;padding:16px}.news-row-thumb{width:64px;height:64px;border-radius:14px}.news-row-thumb-fallback{font-size:1.5rem}.news-pagination{flex-wrap:wrap}.category-directory-side{display:none}.category-directory-layout{grid-template-columns:minmax(0,1fr)}.category-directory-section--all{order:1}.category-directory-section--featured{order:2}}.github-home-section{margin-top:8px}.github-home-section .section-title{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}.github-home-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.github-home-card{display:block;padding:14px 16px;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius);text-decoration:none;color:var(--color-text);box-shadow:var(--shadow);transition:box-shadow .15s ease}.github-home-card:hover{box-shadow:var(--shadow-md)}.github-home-card h3{margin:0 0 6px;font-size:1rem;font-weight:600}.github-home-card .meta{font-size:.85rem;color:var(--color-muted);margin-bottom:8px}.github-home-card p{margin:0;font-size:.9rem;color:var(--color-muted);line-height:1.45}.github-repos-toolbar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px;align-items:center}.github-repos-search{flex:1;min-width:200px;max-width:360px;padding:10px 14px;border:1px solid var(--color-border);border-radius:10px;font-size:.95rem}.github-repos-select{padding:10px 12px;border:1px solid var(--color-border);border-radius:10px;font-size:.9rem;background:#fff;min-width:140px}.github-repo-list{list-style:none;margin:0;padding:0}.github-repo-row{padding:16px 0;border-bottom:1px solid var(--color-border)}.github-repo-row-inner{display:flex;gap:12px;align-items:flex-start}.github-repo-avatar{width:40px;height:40px;border-radius:50%;flex-shrink:0;object-fit:cover;background:var(--color-border)}.github-repo-name{font-weight:600;font-size:1.05rem}.github-repo-meta{display:block;font-size:.85rem;color:var(--color-muted);margin-top:4px}.github-repo-desc{margin:8px 0 0;font-size:.9rem;color:var(--color-muted)}.github-repo-pager{display:flex;align-items:center;gap:16px;margin-top:24px}.github-repo-stats{font-size:.95rem;color:var(--color-muted)}.github-detail-section{margin:28px 0;min-width:0;max-width:100%}.github-detail-section h2{font-size:1.1rem;margin:0 0 10px}.github-pill-row{display:flex;flex-wrap:wrap;gap:8px}.github-pill{display:inline-block;padding:4px 10px;border-radius:999px;background:#eef2ff;color:var(--color-primary);font-size:.85rem;text-decoration:none}.github-pill:hover{background:#e0e7ff}.github-lang-bar{display:flex;height:10px;border-radius:6px;overflow:hidden;background:var(--color-border);margin-bottom:10px}.github-lang-bar-seg{height:100%;min-width:2px}.github-lang-legend{display:flex;flex-wrap:wrap;gap:12px;font-size:.9rem}.github-lang-item .muted,.muted{color:var(--color-muted)}.github-detail-section .github-readme-md{min-width:0}.github-readme-md{text-align:left;font-size:.95rem;line-height:1.65;padding:16px;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius);overflow-x:auto;max-width:100%;box-sizing:border-box}.github-readme-md img,.github-readme-md video{max-width:100%;height:auto;vertical-align:middle}.github-readme-md h1,.github-readme-md h2{margin-top:1.2em;margin-bottom:.5em;font-weight:600;border-bottom:1px solid var(--color-border);padding-bottom:.3em}.github-readme-md h1:first-child,.github-readme-md h2:first-child,.github-readme-md h3:first-child{margin-top:0}.github-readme-md table{border-collapse:collapse}.github-readme-md th,.github-readme-md td{border:1px solid var(--color-border);padding:6px 10px}.github-readme-md a{color:var(--color-primary)}.github-readme-md pre{background:#f6f8fa;padding:12px;border-radius:8px;overflow:auto}.github-readme-md code{background:#afb8c140;padding:.1em .35em;border-radius:4px;font-size:.9em}.github-readme-md pre code{background:none;padding:0}.github-readme-pre-wrap{position:relative;margin:.85em 0}.github-readme-pre-wrap .github-readme-copy-icon{position:absolute;top:6px;right:6px;z-index:2;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;margin:0;padding:0;border:1px solid var(--color-border);border-radius:6px;background:var(--color-card);color:var(--color-text);cursor:pointer;box-shadow:0 1px 2px #0000000f;opacity:0;transition:opacity .12s ease}.github-readme-pre-wrap:hover .github-readme-copy-icon,.github-readme-pre-wrap:focus-within .github-readme-copy-icon{opacity:1}@media(hover:none){.github-readme-pre-wrap .github-readme-copy-icon{opacity:.72}}.github-readme-pre-wrap .github-readme-copy-icon.is-copied{border-color:var(--color-primary);color:var(--color-primary)}.github-readme-codespan-wrap{display:inline-flex;align-items:center;gap:3px;max-width:100%;vertical-align:middle}.github-readme-codespan-wrap .github-readme-copy-icon{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;margin:0;padding:0;border:none;border-radius:4px;background:transparent;color:var(--color-muted);cursor:pointer;opacity:0;transition:opacity .12s ease}.github-readme-codespan-wrap:hover .github-readme-copy-icon,.github-readme-codespan-wrap:focus-within .github-readme-copy-icon{opacity:1}@media(hover:none){.github-readme-codespan-wrap .github-readme-copy-icon{opacity:.55}}.github-readme-codespan-wrap .github-readme-copy-icon.is-copied{color:var(--color-primary)}.github-repo-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,300px);gap:28px;align-items:start}.github-repo-layout>*{min-width:0}@media(max-width:1000px){.github-repo-layout{grid-template-columns:1fr}}.github-repo-hero{background:var(--color-card);border:1px solid var(--color-border);border-radius:12px;padding:22px 24px;box-shadow:var(--shadow)}.github-repo-hero-title{margin:0;font-size:1.55rem;font-weight:700;letter-spacing:-.02em;line-height:1.25}.github-repo-hero-title-link{display:inline-flex;align-items:center;gap:10px;color:inherit;text-decoration:none}.github-repo-hero-title-link:hover{color:var(--color-primary)}.github-repo-ext-icon{flex-shrink:0;opacity:.55}.github-repo-hero-title-link:hover .github-repo-ext-icon{opacity:1;color:var(--color-primary)}.github-repo-hero-desc{margin:12px 0 0;font-size:1rem;line-height:1.55;color:var(--color-muted)}.github-repo-meta-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px 20px;margin-top:18px;font-size:.9rem;color:var(--color-muted)}.github-repo-meta-item{display:inline-flex;align-items:center;gap:6px}.github-repo-meta-item a{color:var(--color-primary);text-decoration:none;font-weight:500}.github-repo-meta-item a:hover{text-decoration:underline}.github-repo-meta-icon{flex-shrink:0;opacity:.75;color:var(--color-primary)}.github-repo-doc-card{margin-top:22px;border:1px solid var(--color-border);border-radius:12px;overflow:hidden;background:var(--color-card);box-shadow:var(--shadow)}.github-repo-tabbar{display:flex;align-items:stretch;gap:0;padding:0 18px;border-bottom:1px solid var(--color-border);background:linear-gradient(180deg,#fafbff,#f4f6fb)}.github-repo-tab{padding:14px 4px;margin-right:28px;font-weight:700;font-size:.95rem;color:var(--color-muted);border-bottom:3px solid transparent;margin-bottom:-1px}.github-repo-tab.is-active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.github-repo-readme-panel{padding:0}.github-repo-readme-toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;padding:12px 18px;border-bottom:1px solid var(--color-border);font-size:.88rem}.github-repo-zip-link{font-weight:600;color:var(--color-primary);text-decoration:none}.github-repo-zip-link:hover{text-decoration:underline}.github-readme-md--in-panel{border:none;border-radius:0;box-shadow:none;padding:20px 22px 24px}.github-readme-md--empty{min-height:120px}.github-lang-bar--compact{height:8px;margin-bottom:8px}.github-lang-legend--compact{gap:8px;font-size:.82rem}.github-repo-sidebar{display:flex;flex-direction:column;gap:20px}.github-repo-side-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:12px;padding:18px 18px 16px;box-shadow:var(--shadow)}.github-repo-side-title{margin:0 0 14px;font-size:.72rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--color-muted)}.github-repo-side-block{margin-bottom:16px}.github-repo-side-block:last-child{margin-bottom:0}.github-repo-side-label{font-size:.78rem;font-weight:700;color:var(--color-muted);margin-bottom:8px}.github-repo-side-tags{display:flex;flex-wrap:wrap;gap:8px}.github-repo-side-pill{display:inline-block;padding:5px 10px;border-radius:8px;background:#eef2ff;color:var(--color-primary);font-size:.82rem;font-weight:600;text-decoration:none;border:1px solid rgba(37,99,235,.15)}.github-repo-side-pill:hover{background:#e0e7ff}.github-repo-side-pill--muted{background:#f3f4f6;color:var(--color-text);border-color:var(--color-border)}.github-repo-side-pill--muted:hover{background:#e5e7eb}.github-repo-side-stats{margin:0;padding:0 0 0 18px;font-size:.88rem;line-height:1.65;color:var(--color-text)}.github-repo-side-stats li{margin-bottom:4px}.github-repo-side-card--features .home-featured-stack{max-height:min(70vh,720px);overflow-y:auto;padding-right:4px}.github-repos-directory{--github-dir-accent: #6366f1;--github-dir-accent-hover: #4f46e5;padding-top:8px;padding-bottom:48px}.github-repos-hero{text-align:center;margin-bottom:28px}.github-repos-hero-breadcrumb{margin:0 0 16px;font-size:.9rem;color:var(--color-muted)}.github-repos-hero-breadcrumb a{color:var(--color-muted);text-decoration:none}.github-repos-hero-breadcrumb a:hover{color:var(--github-dir-accent)}.github-repos-hero-bc-sep{margin:0 8px}.github-repos-hero-title{margin:0 auto 14px;max-width:920px;font-size:clamp(1.45rem,3.5vw,2rem);font-weight:800;letter-spacing:-.03em;line-height:1.2;color:var(--color-text)}.github-repos-hero-lead{margin:0 auto 18px;max-width:640px;font-size:1rem;line-height:1.6;color:var(--color-muted)}.github-repos-hero-share{display:flex;justify-content:center;gap:10px;margin-bottom:22px}.github-repos-share-link{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid var(--color-border);background:linear-gradient(180deg,#fff,#f9fafb);color:var(--color-muted);text-decoration:none;font-weight:700;font-size:.85rem;transition:border-color .15s,color .15s}.github-repos-share-link:hover{border-color:var(--github-dir-accent);color:var(--github-dir-accent)}.github-repos-hero-search{display:flex;max-width:720px;margin:0 auto;align-items:stretch;gap:0;border-radius:14px;overflow:hidden;border:1px solid var(--color-border);box-shadow:0 8px 28px #0f172a14;background:#fff}.github-repos-hero-search-input{flex:1;min-width:0;padding:16px 20px;border:none;font-size:1.05rem;outline:none}.github-repos-hero-search-input::placeholder{color:#9ca3af}.github-repos-hero-search-btn{display:inline-flex;align-items:center;justify-content:center;width:64px;flex-shrink:0;border:none;background:var(--github-dir-accent);color:#fff;cursor:pointer;transition:background .15s}.github-repos-hero-search-btn:hover{background:var(--github-dir-accent-hover)}.github-repos-filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:22px;align-items:center}.github-repos-select--grow{flex:1;min-width:140px}.github-repos-section-title{margin:0 0 18px;font-size:1.05rem;font-weight:700;letter-spacing:-.02em}.github-repos-section-title-link{color:inherit;text-decoration:none}.github-repos-section-title-link:hover{color:var(--github-dir-accent)}.github-repos-section-chevron{margin-left:4px;font-weight:600;color:var(--github-dir-accent)}.github-repos-section-sub{font-weight:500}.github-repo-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:20px}@media(max-width:1100px){.github-repo-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:820px){.github-repo-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:520px){.github-repo-grid{grid-template-columns:1fr}}.github-repo-card{display:flex;flex-direction:column;padding:18px 18px 16px;background:var(--color-card);border:1px solid var(--color-border);border-radius:12px;box-shadow:var(--shadow);transition:box-shadow .2s,border-color .2s;min-height:200px}.github-repo-card:hover{box-shadow:var(--shadow-md);border-color:#6366f147}.github-repo-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}.github-repo-card-title{font-weight:700;font-size:1rem;line-height:1.3;color:var(--color-text);text-decoration:none;letter-spacing:-.02em}.github-repo-card-title:hover{color:var(--github-dir-accent)}.github-repo-card-stats{display:flex;align-items:center;gap:10px;flex-shrink:0;font-size:.82rem;font-weight:600;color:var(--color-muted)}.github-repo-card-stat{display:inline-flex;align-items:center;gap:4px}.github-repo-card-stat-icon{opacity:.85;color:var(--github-dir-accent)}.github-repo-card-desc{margin:0 0 14px;font-size:.88rem;line-height:1.5;color:var(--color-muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}.github-repo-card-author{display:flex;align-items:center;gap:8px;margin-top:auto;margin-bottom:12px;font-size:.84rem;color:var(--color-muted)}.github-repo-card-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;background:var(--color-border)}.github-repo-card-avatar-ph{display:inline-flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:var(--color-muted);background:#f3f4f6}.github-repo-card-by{font-weight:500}.github-repo-card-by-link{color:var(--color-text);text-decoration:none;font-weight:600}.github-repo-card-by-link:hover{color:var(--github-dir-accent)}.github-repo-card-tags{display:flex;flex-wrap:wrap;gap:8px}.github-repo-card-tag{display:inline-block;padding:4px 10px;border-radius:999px;font-size:.72rem;font-weight:600;background:#f3f4f6;color:#6b7280;text-decoration:none;border:1px solid #e5e7eb}.github-repo-card-tag:hover{border-color:var(--github-dir-accent);color:var(--github-dir-accent)}.github-repo-card-tag--muted{cursor:default}.github-repo-card-tag--muted:hover{border-color:#e5e7eb;color:#6b7280}.github-repos-loading,.github-repos-empty{text-align:center;padding:24px 0}.github-repo-pager--grid{justify-content:center;margin-top:28px}button.github-repo-tab,a.github-repo-tab{font:inherit;font-weight:700;font-size:.95rem;background:transparent;border:none;border-bottom:3px solid transparent;margin-bottom:-1px;cursor:pointer;font-family:inherit;color:var(--color-muted);padding:14px 4px;margin-right:28px}button.github-repo-tab:hover,a.github-repo-tab:hover{color:var(--color-text)}button.github-repo-tab.is-active,a.github-repo-tab.is-active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.openclaw-skill-install-grid{display:grid;gap:1.25rem;padding:1.25rem 1.25rem 1.5rem;grid-template-columns:1fr}@media(min-width:900px){.openclaw-skill-install-grid{grid-template-columns:repeat(3,1fr)}}.openclaw-skill-install-col{display:flex;flex-direction:column;gap:.75rem;min-width:0}.openclaw-skill-install-col-lead{margin:0;font-size:.9rem;color:var(--color-muted);line-height:1.45}.openclaw-skill-install-col-title{margin:0 0 8px;font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--color-muted)}.openclaw-skill-codebox{position:relative;display:flex;align-items:flex-start;gap:8px;padding:12px 14px;border-radius:10px;background:#f1f3f7;border:1px solid var(--color-border);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.82rem;line-height:1.45}.openclaw-skill-codebox pre{margin:0;flex:1;min-width:0;white-space:pre-wrap;word-break:break-word;font:inherit}.openclaw-skill-codebox--prompt{background:linear-gradient(180deg,#f3f0ff,#eef2ff);border-color:#e0e7ff}.openclaw-skill-codebox-copy{flex-shrink:0;min-width:32px;height:32px;border:none;border-radius:8px;background:transparent;cursor:pointer;color:var(--color-muted);display:inline-flex;align-items:center;justify-content:center}.openclaw-skill-codebox-copy:hover{color:var(--color-primary);background:#2563eb14}.openclaw-skill-path-row{display:flex;align-items:flex-start;gap:8px;padding:12px 14px;border-radius:10px;background:#f1f3f7;border:1px solid var(--color-border);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.82rem;line-height:1.45}.openclaw-skill-path-label{flex-shrink:0;font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--color-muted);min-width:4.75rem}.openclaw-skill-path-text{flex:1;min-width:0;word-break:break-all}.openclaw-skill-install-footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;padding:12px 18px;border-top:1px solid var(--color-border);background:#fafbff;font-size:.9rem}.openclaw-skill-install-dl-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:999px;font-weight:600;font-size:.9rem;background:linear-gradient(180deg,#6366f1,#4f46e5);color:#fff!important;text-decoration:none;border:none;cursor:pointer;box-shadow:0 2px 8px #4f46e559}.openclaw-skill-install-dl-btn:hover{filter:brightness(1.05)}.openclaw-skill-meta-timeline{margin:0;padding:0;list-style:none}.openclaw-skill-meta-timeline li{position:relative;padding-left:14px;margin-bottom:0;border-left:2px solid var(--color-border)}.openclaw-skill-section{scroll-margin-top:88px;min-width:0;max-width:100%}.openclaw-skill-section-divider{height:1px;margin:0;border:none;background:var(--color-border)}a.github-repo-tab{text-decoration:none}.openclaw-skill-side-dl{margin:0;font-size:.88rem;line-height:1.45}.openclaw-skill-side-dl dt{margin:0 0 4px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--color-muted)}.openclaw-skill-side-dl dd{margin:0 0 14px;word-break:break-word}.openclaw-skill-side-dl dd:last-child{margin-bottom:0}.openclaw-skill-meta-json{margin:0;padding:10px 12px;max-height:220px;overflow:auto;font-size:.75rem;line-height:1.4;border-radius:8px;background:#f6f7f9;border:1px solid var(--color-border);white-space:pre-wrap;word-break:break-word}.openclaw-skill-side-block--meta{margin-bottom:22px}.openclaw-skill-side-block--meta:last-of-type{margin-bottom:0}.openclaw-skill-side-heading{display:flex;align-items:center;gap:8px;margin:0 0 10px;font-size:.88rem;font-weight:600;color:var(--color-text)}.openclaw-skill-side-heading-icon,.openclaw-skill-side-heading .github-repo-meta-icon{flex-shrink:0;color:var(--color-muted)}.openclaw-skill-release-list{margin:0;padding:0;list-style:none;border-left:2px solid var(--color-border)}.openclaw-skill-release-item{position:relative;padding:0 0 18px 16px;margin:0}.openclaw-skill-release-item:last-child{padding-bottom:0}.openclaw-skill-release-dot{position:absolute;left:-5px;top:5px;width:8px;height:8px;border-radius:50%;background:#c8cdd8}.openclaw-skill-release-dot--latest{background:linear-gradient(135deg,#6366f1,#4f46e5);box-shadow:0 0 0 2px #6366f138}.openclaw-skill-release-row{display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:8px;font-size:.88rem}.openclaw-skill-release-ver{font-weight:600}.openclaw-skill-release-latest{font-weight:600;color:#4f46e5;font-size:.75rem;margin-left:.35rem}.openclaw-skill-release-date{font-size:.82rem;color:var(--color-muted);flex-shrink:0}.openclaw-skill-release-commit{display:block;margin-top:6px;font-size:.78rem;line-height:1.4;word-break:break-all;color:var(--color-primary);text-decoration:none}.openclaw-skill-release-commit:hover{text-decoration:underline}.legal-page{max-width:920px}.legal-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px 24px}.legal-card h1{margin:0 0 6px;font-size:clamp(1.4rem,2.2vw,1.85rem);letter-spacing:-.02em}.legal-card h2{margin:22px 0 10px;font-size:1.05rem}.legal-card p{margin:0 0 12px;line-height:1.7;color:#334155}.legal-card ul{margin:0 0 12px;padding-left:20px}.legal-card li{margin-bottom:8px;color:#334155}.legal-updated{margin:0 0 14px;color:var(--color-muted)!important;font-size:.9rem}@media(max-width:640px){.legal-card{padding:20px 16px}}.pricing-page-hero{padding:32px 0 0}.pricing-page-hero-inner{max-width:680px}.pricing-page-hero h1{margin:12px 0 8px;font-size:clamp(1.6rem,3.5vw,2.1rem);font-weight:800;letter-spacing:-.025em;color:var(--color-text)}.pricing-page-hero p{margin:0 0 20px;color:var(--color-muted);font-size:1rem;line-height:1.6}.pricing-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 14px;border-radius:999px;font-size:.8rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.pricing-badge--free{background:#dcfce7;color:#16a34a;border:1px solid #bbf7d0}.pricing-badge--freemium{background:#fef9c3;color:#ca8a04;border:1px solid #fde68a}.pricing-badge--paid{background:#ede9fe;color:#7c3aed;border:1px solid #ddd6fe}.pricing-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}.pricing-tab{padding:8px 18px;border-radius:999px;font-size:.9rem;font-weight:500;text-decoration:none;border:1px solid var(--color-border);color:var(--color-muted);background:#fff;transition:border-color .15s,background .15s,color .15s,box-shadow .15s}.pricing-tab:hover{border-color:var(--color-primary);color:var(--color-primary);background:#2563eb0d}.pricing-tab--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff!important;box-shadow:0 2px 8px #2563eb4d}.pricing-tab--active:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.pricing-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;padding:16px 0 20px;border-bottom:1px solid var(--color-border);margin-bottom:24px}.pricing-toolbar-count{font-size:.9rem;color:var(--color-muted);font-weight:500}.pricing-sort-links{display:flex;align-items:center;gap:4px}.pricing-sort-label{font-size:.875rem;color:var(--color-muted);margin-right:6px}.pricing-sort-link{padding:6px 14px;border-radius:999px;font-size:.875rem;font-weight:500;text-decoration:none;color:var(--color-muted);transition:background .15s,color .15s}.pricing-sort-link:hover{background:#2563eb12;color:var(--color-primary)}.pricing-sort-link--active{background:#2563eb1a;color:var(--color-primary);font-weight:600}.pricing-card-meta{display:flex;gap:12px;margin-top:10px;font-size:.78rem;color:var(--color-muted)}.pricing-skeleton-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.pricing-skeleton-card{height:148px;border-radius:var(--radius);background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:pricing-shimmer 1.4s infinite}@keyframes pricing-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.pricing-pagination{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:36px;flex-wrap:wrap}.pricing-page-numbers{display:flex;align-items:center;gap:4px}.pricing-page-btn{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 6px;border-radius:8px;font-size:.9rem;font-weight:500;text-decoration:none;color:var(--color-text);border:1px solid var(--color-border);background:#fff;transition:border-color .15s,background .15s,color .15s}.pricing-page-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:#2563eb0d}.pricing-page-btn--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff!important;font-weight:700;box-shadow:0 2px 6px #2563eb40}.pricing-page-ellipsis{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:36px;font-size:.9rem;color:var(--color-muted)}@media(max-width:640px){.pricing-tabs{gap:6px}.pricing-tab{padding:7px 14px;font-size:.85rem}.pricing-toolbar{flex-direction:column;align-items:flex-start}.pricing-sort-links{flex-wrap:wrap}.pricing-page-numbers{gap:2px}.pricing-page-btn{min-width:32px;height:32px;font-size:.82rem}}.infinite-sentinel{height:1px;width:100%}.infinite-load-more{display:flex;align-items:center;justify-content:center;gap:10px;padding:28px 0 8px;color:var(--color-muted);font-size:.9rem}.infinite-spinner{width:22px;height:22px;border:2.5px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:infinite-spin .75s linear infinite;flex-shrink:0}@keyframes infinite-spin{to{transform:rotate(360deg)}}.infinite-end-label{display:flex;align-items:center;justify-content:center;padding:24px 0 4px;font-size:.85rem;color:var(--color-muted);gap:8px}.infinite-end-label:before,.infinite-end-label:after{content:"";flex:1;max-width:80px;height:1px;background:var(--color-border)}.category-faq-section{margin-top:48px}.category-faq-container{display:flex;flex-direction:column;gap:12px;margin-top:16px}.category-faq-container p{margin:0}.category-faq-item{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-card);overflow:hidden;transition:border-color .2s,box-shadow .2s;margin-bottom:10px}.category-faq-item:hover{border-color:#2563eb66}.category-faq-question{padding:16px 20px;font-weight:600;font-size:1.05rem;color:var(--color-text);cursor:pointer;position:relative;-webkit-user-select:none;user-select:none;display:flex;justify-content:space-between;align-items:center}.category-faq-question:after{content:"+";font-size:1.4rem;font-weight:400;color:var(--color-muted);transition:transform .3s ease}.category-faq-answer{padding:0 20px;max-height:0;overflow:hidden;color:var(--color-muted);line-height:1.6;opacity:0;transition:all .3s ease}.category-faq-item.is-open .category-faq-question:after{content:"−"}.category-faq-item.is-open .category-faq-answer{padding:0 20px 20px;max-height:1200px;opacity:1}.category-more-section{margin-top:48px}.category-more-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:16px}.category-more-card{display:flex;align-items:center;justify-content:center;padding:10px 18px;background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text);text-decoration:none;font-weight:500;font-size:.95rem;transition:border-color .15s,box-shadow .15s,transform .15s;text-align:center}.category-more-card:hover{background:#f8fafc;border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb14}@media(max-width:800px){.category-more-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:500px){.category-more-grid{grid-template-columns:1fr}}.tool-detail-related{margin:32px 0;padding:0}.tool-detail-related-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}.tool-detail-related-card{display:block;text-decoration:none;color:inherit;background:#ffffffb3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(218,232,255,.8);border-radius:12px;padding:16px;box-shadow:0 4px 12px #00000008;transition:all .25s ease;position:relative;overflow:hidden}.tool-detail-related-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--color-primary),#a5b4fc);opacity:0;transition:opacity .25s}.tool-detail-related-card:hover{transform:translateY(-4px);box-shadow:0 10px 20px #2563eb14;border-color:var(--color-primary);background:#fff}.tool-detail-related-card:hover:before{opacity:1}.tool-detail-related-head{margin-bottom:12px;display:flex;align-items:center}.tool-detail-related-avatar{width:44px;height:44px;border-radius:10px;object-fit:cover;border:1px solid rgba(0,0,0,.05);background:#fff}.tool-detail-related-avatar-ph{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:10px;background:#eef2ff;color:var(--color-primary);font-weight:700;font-size:1.1rem}.tool-detail-related-name{display:block;font-weight:700;font-size:1rem;margin-bottom:6px;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tool-detail-related-desc{display:block;font-size:.82rem;color:var(--color-muted);line-height:1.5;height:2.5rem;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}@media(max-width:1100px){.tool-detail-related-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.tool-detail-related-grid{display:flex;overflow-x:auto;gap:12px;padding-bottom:8px;scrollbar-width:none}.tool-detail-related-grid::-webkit-scrollbar{display:none}.tool-detail-related-card{flex:0 0 240px}}.home-github-below,.tool-detail-related,.category-more-section{content-visibility:auto;contain-intrinsic-size:1px 640px}
