:root{--c-primary:#6366f1;--c-primary-hover:#4f46e5;--c-primary-light:rgba(99,102,241,.1);--c-primary-lighter:rgba(99,102,241,.06);--c-bg:#f8f9fc;--c-bg-card:#fff;--c-bg-sidebar:#f1f3f9;--c-bg-hover:rgba(0,0,0,.03);--c-bg-input:#f1f3f9;--c-bg-hero:linear-gradient(135deg,#eef2ff 0%,#e0e7ff 50%,#ede9fe 100%);--c-text:#1e293b;--c-text-secondary:#64748b;--c-text-muted:#94a3b8;--c-text-on-primary:#fff;--c-border:#e2e8f0;--c-border-light:#f1f5f9;--r-sm:.375rem;--r-md:.5rem;--r-lg:.75rem;--r-xl:1rem;--r-2xl:1.25rem;--r-full:9999px;--s-sm:0 1px 2px rgba(0,0,0,.05);--s-md:0 4px 6px -1px rgba(0,0,0,.07),0 2px 4px -2px rgba(0,0,0,.05);--s-lg:0 10px 15px -3px rgba(0,0,0,.08),0 4px 6px -4px rgba(0,0,0,.04);--s-xl:0 20px 25px -5px rgba(0,0,0,.08),0 8px 10px -6px rgba(0,0,0,.04);--sp-1:.25rem;--sp-2:.5rem;--sp-3:.75rem;--sp-4:1rem;--sp-5:1.25rem;--sp-6:1.5rem;--sp-8:2rem;--sp-10:2.5rem;--sp-12:3rem;--sp-16:4rem;--f-xs:.75rem;--f-sm:.875rem;--f-base:1rem;--f-lg:1.125rem;--f-xl:1.25rem;--f-2xl:1.5rem;--f-3xl:1.875rem;--f-4xl:2.25rem;--font-sans:'Noto Sans SC',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;--font-mono:'JetBrains Mono',ui-monospace,monospace;--container-max:1280px;--container-sm:768px;--transition:.2s ease;--transition-slow:.3s ease;--c-error:#ef4444;--c-error-light:rgba(239,68,68,.1);--c-success:#22c55e;--c-success-light:rgba(34,197,94,.1);--c-warning:#f59e0b;--c-info:#3b82f6}[data-theme=dark]{--c-primary:#818cf8;--c-primary-hover:#6366f1;--c-primary-light:rgba(129,140,248,.15);--c-primary-lighter:rgba(129,140,248,.08);--c-bg:#0f172a;--c-bg-card:#1e293b;--c-bg-sidebar:#1e293b;--c-bg-hover:rgba(255,255,255,.05);--c-bg-input:#334155;--c-bg-hero:linear-gradient(135deg,#1e1b4b 0%,#312e81 50%,#2e1065 100%);--c-text:#f1f5f9;--c-text-secondary:#94a3b8;--c-text-muted:#64748b;--c-text-on-primary:#fff;--c-border:#334155;--c-border-light:#1e293b;--s-sm:0 1px 2px rgba(0,0,0,.3);--s-md:0 4px 6px -1px rgba(0,0,0,.3),0 2px 4px -2px rgba(0,0,0,.2);--s-lg:0 10px 15px -3px rgba(0,0,0,.3),0 4px 6px -4px rgba(0,0,0,.2);--s-xl:0 20px 25px -5px rgba(0,0,0,.3),0 8px 10px -6px rgba(0,0,0,.2)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);font-size:var(--f-base);line-height:1.6;color:var(--c-text);background-color:var(--c-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--c-primary);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--c-primary-hover)}img{max-width:100%;height:auto;display:block}ul,ol{list-style:none}button,input,select,textarea{font-family:inherit;font-size:inherit;line-height:inherit}button{cursor:pointer;border:none;background:0 0}.container{max-width:var(--container-max);margin:0 auto;padding:0 var(--sp-4)}.container-sm{max-width:var(--container-sm);margin:0 auto;padding:0 var(--sp-4)}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:var(--sp-1)}.gap-2{gap:var(--sp-2)}.gap-3{gap:var(--sp-3)}.gap-4{gap:var(--sp-4)}.gap-6{gap:var(--sp-6)}.gap-8{gap:var(--sp-8)}.grid{display:grid}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.hidden{display:none !important}.block{display:block}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.w-full{width:100%}.h-full{height:100%}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-x-auto{overflow-x:auto}.relative{position:relative}.absolute{position:absolute}.sticky{position:sticky}.mt-1{margin-top:var(--sp-1)}.mt-2{margin-top:var(--sp-2)}.mt-3{margin-top:var(--sp-3)}.mt-4{margin-top:var(--sp-4)}.mt-6{margin-top:var(--sp-6)}.mt-8{margin-top:var(--sp-8)}.mt-12{margin-top:var(--sp-12)}.mb-1{margin-bottom:var(--sp-1)}.mb-2{margin-bottom:var(--sp-2)}.mb-3{margin-bottom:var(--sp-3)}.mb-4{margin-bottom:var(--sp-4)}.mb-6{margin-bottom:var(--sp-6)}.mb-8{margin-bottom:var(--sp-8)}.ml-1{margin-left:var(--sp-1)}.ml-2{margin-left:var(--sp-2)}.mr-1{margin-right:var(--sp-1)}.mr-2{margin-right:var(--sp-2)}.mx-auto{margin-left:auto;margin-right:auto}.p-2{padding:var(--sp-2)}.p-3{padding:var(--sp-3)}.p-4{padding:var(--sp-4)}.p-6{padding:var(--sp-6)}.p-8{padding:var(--sp-8)}.px-2{padding-left:var(--sp-2);padding-right:var(--sp-2)}.px-3{padding-left:var(--sp-3);padding-right:var(--sp-3)}.px-4{padding-left:var(--sp-4);padding-right:var(--sp-4)}.px-5{padding-left:var(--sp-5);padding-right:var(--sp-5)}.px-6{padding-left:var(--sp-6);padding-right:var(--sp-6)}.py-1{padding-top:var(--sp-1);padding-bottom:var(--sp-1)}.py-2{padding-top:var(--sp-2);padding-bottom:var(--sp-2)}.py-3{padding-top:var(--sp-3);padding-bottom:var(--sp-3)}.py-4{padding-top:var(--sp-4);padding-bottom:var(--sp-4)}.py-6{padding-top:var(--sp-6);padding-bottom:var(--sp-6)}.py-8{padding-top:var(--sp-8);padding-bottom:var(--sp-8)}.py-12{padding-top:var(--sp-12);padding-bottom:var(--sp-12)}.py-16{padding-top:var(--sp-16);padding-bottom:var(--sp-16)}.text-xs{font-size:var(--f-xs)}.text-sm{font-size:var(--f-sm)}.text-base{font-size:var(--f-base)}.text-lg{font-size:var(--f-lg)}.text-xl{font-size:var(--f-xl)}.text-2xl{font-size:var(--f-2xl)}.text-3xl{font-size:var(--f-3xl)}.text-4xl{font-size:var(--f-4xl)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-primary{color:var(--c-primary)}.text-secondary{color:var(--c-text-secondary)}.text-muted{color:var(--c-text-muted)}.text-on-primary{color:var(--c-text-on-primary)}.text-error{color:var(--c-error)}.text-success{color:var(--c-success)}.text-body{color:var(--c-text)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.bg-primary{background-color:var(--c-primary)}.bg-primary-light{background-color:var(--c-primary-light)}.bg-primary-lighter{background-color:var(--c-primary-lighter)}.bg-card{background-color:var(--c-bg-card)}.bg-sidebar{background-color:var(--c-bg-sidebar)}.bg-body{background-color:var(--c-bg)}.bg-hero{background:var(--c-bg-hero)}.bg-hover:hover{background-color:var(--c-bg-hover)}.bg-input{background-color:var(--c-bg-input)}.border{border:1px solid var(--c-border)}.border-light{border:1px solid var(--c-border-light)}.border-b{border-bottom:1px solid var(--c-border)}.border-t{border-top:1px solid var(--c-border)}.border-none{border:none}.border-primary{border-color:var(--c-primary)}.border-error{border-color:var(--c-error)}.rounded-sm{border-radius:var(--r-sm)}.rounded{border-radius:var(--r-md)}.rounded-lg{border-radius:var(--r-lg)}.rounded-xl{border-radius:var(--r-xl)}.rounded-2xl{border-radius:var(--r-2xl)}.rounded-full{border-radius:var(--r-full)}.shadow-sm{box-shadow:var(--s-sm)}.shadow{box-shadow:var(--s-md)}.shadow-lg{box-shadow:var(--s-lg)}.shadow-xl{box-shadow:var(--s-xl)}.shadow-none{box-shadow:none}.transition{transition:all var(--transition)}.transition-slow{transition:all var(--transition-slow)}.site-header{position:sticky;top:0;z-index:100;background:var(--c-bg-card);border-bottom:1px solid var(--c-border);backdrop-filter:blur(12px);background:rgba(255,255,255,.85)}[data-theme=dark] .site-header{background:rgba(30,41,59,.85)}.header-inner{max-width:var(--container-max);margin:0 auto;padding:0 var(--sp-4);display:flex;align-items:center;justify-content:space-between;height:64px}.header-logo{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--f-xl);font-weight:700;color:var(--c-text);text-decoration:none}.header-logo:hover{color:var(--c-primary)}.header-nav{display:flex;align-items:center;gap:var(--sp-1)}.header-nav a{display:flex;align-items:center;gap:var(--sp-1);padding:var(--sp-2) var(--sp-3);border-radius:var(--r-md);color:var(--c-text-secondary);font-size:var(--f-sm);font-weight:500;transition:all var(--transition);text-decoration:none}.header-nav a:hover,.header-nav a.active{color:var(--c-primary);background:var(--c-primary-light)}.header-nav a svg{width:18px;height:18px;flex-shrink:0}.header-actions{display:flex;align-items:center;gap:var(--sp-2)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--r-md);color:var(--c-text-secondary);transition:all var(--transition);cursor:pointer;border:none;background:0 0}.btn-icon:hover{color:var(--c-text);background:var(--c-bg-hover)}.btn-icon svg{width:20px;height:20px}.menu-toggle{display:none}.search-engine-bar{display:flex;align-items:center;gap:var(--sp-1);padding:var(--sp-1);background:var(--c-bg-input);border-radius:var(--r-full)}.search-engine-btn{padding:var(--sp-1) var(--sp-3);border-radius:var(--r-full);font-size:var(--f-xs);font-weight:500;color:var(--c-text-secondary);cursor:pointer;border:none;background:0 0;transition:all var(--transition);white-space:nowrap}.search-engine-btn:hover{color:var(--c-text)}.search-engine-btn.active{background:var(--c-bg-card);color:var(--c-primary);box-shadow:var(--s-sm)}.hero-section{background:var(--c-bg-hero);padding:var(--sp-16) 0 var(--sp-12);text-align:center;position:relative;overflow:hidden}.hero-section:before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 30% 50%,rgba(99,102,241,.08) 0%,transparent 50%),radial-gradient(circle at 70% 30%,rgba(168,85,247,.06) 0%,transparent 50%);pointer-events:none}[data-theme=dark] .hero-section:before{background:radial-gradient(circle at 30% 50%,rgba(99,102,241,.15) 0%,transparent 50%),radial-gradient(circle at 70% 30%,rgba(168,85,247,.1) 0%,transparent 50%)}.hero-title{font-size:var(--f-4xl);font-weight:700;color:var(--c-text);margin-bottom:var(--sp-2);position:relative}.hero-title span{background:linear-gradient(135deg,var(--c-primary),#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-desc{font-size:var(--f-lg);color:var(--c-text-secondary);margin-bottom:var(--sp-8);position:relative}.search-box{max-width:640px;margin:0 auto;position:relative}.search-box input{width:100%;padding:var(--sp-4) var(--sp-12) var(--sp-4) var(--sp-12);border-radius:var(--r-2xl);border:2px solid var(--c-border);background:var(--c-bg-card);font-size:var(--f-lg);color:var(--c-text);outline:none;transition:all var(--transition);box-shadow:var(--s-lg)}.search-box input:focus{border-color:var(--c-primary);box-shadow:var(--s-lg),0 0 0 4px var(--c-primary-light)}.search-box input::placeholder{color:var(--c-text-muted)}.search-box .search-icon{position:absolute;left:var(--sp-4);top:50%;transform:translateY(-50%);color:var(--c-text-muted);pointer-events:none}.search-box .search-icon svg{width:20px;height:20px}.search-box .search-clear{position:absolute;right:var(--sp-4);top:50%;transform:translateY(-50%);color:var(--c-text-muted);cursor:pointer;display:none;background:0 0;border:none;padding:var(--sp-1)}.search-box .search-clear:hover{color:var(--c-text)}.search-box .search-clear svg{width:18px;height:18px}.search-engines{display:flex;align-items:center;justify-content:center;gap:var(--sp-2);margin-top:var(--sp-4);position:relative}.main-layout{max-width:var(--container-max);margin:0 auto;padding:var(--sp-8) var(--sp-4);display:grid;grid-template-columns:240px 1fr;gap:var(--sp-8)}.main-content{min-width:0}.category-sidebar{position:sticky;top:80px;align-self:start}.category-sidebar h3{font-size:var(--f-sm);font-weight:600;color:var(--c-text-muted);text-transform:uppercase;letter-spacing:.05em;padding:var(--sp-2) var(--sp-3);margin-bottom:var(--sp-1)}.category-sidebar a{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);border-radius:var(--r-md);color:var(--c-text-secondary);font-size:var(--f-sm);transition:all var(--transition);text-decoration:none}.category-sidebar a:hover,.category-sidebar a.active{color:var(--c-primary);background:var(--c-primary-light)}.category-sidebar a svg{width:18px;height:18px;flex-shrink:0}.category-sidebar .cat-count{margin-left:auto;font-size:var(--f-xs);color:var(--c-text-muted);background:var(--c-bg-input);padding:1px 6px;border-radius:var(--r-full)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-6)}.section-title{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--f-xl);font-weight:700;color:var(--c-text)}.section-title svg{width:22px;height:22px;color:var(--c-primary)}.section-more{display:flex;align-items:center;gap:var(--sp-1);font-size:var(--f-sm);color:var(--c-text-secondary);transition:color var(--transition);text-decoration:none}.section-more:hover{color:var(--c-primary)}.section-more svg{width:16px;height:16px}.tool-card{display:flex;flex-direction:column;background:var(--c-bg-card);border:1px solid var(--c-border);border-radius:var(--r-xl);padding:var(--sp-5);transition:all var(--transition-slow);text-decoration:none;color:inherit;position:relative;overflow:hidden}.tool-card:hover{border-color:var(--c-primary);box-shadow:var(--s-lg);transform:translateY(-2px)}.tool-card-header{display:flex;align-items:flex-start;gap:var(--sp-3);margin-bottom:var(--sp-3)}.tool-card-icon{width:48px;height:48px;border-radius:var(--r-lg);overflow:hidden;flex-shrink:0;background:var(--c-primary-light);display:flex;align-items:center;justify-content:center}.tool-card-icon img{width:100%;height:100%;object-fit:cover}.tool-card-icon svg{width:24px;height:24px;color:var(--c-primary)}.tool-card-info{flex:1;min-width:0}.tool-card-name{font-size:var(--f-base);font-weight:600;color:var(--c-text);margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tool-card-desc{font-size:var(--f-sm);color:var(--c-text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.tool-card-badge{position:absolute;top:var(--sp-3);right:var(--sp-3);padding:2px 8px;border-radius:var(--r-full);font-size:var(--f-xs);font-weight:600;background:linear-gradient(135deg,var(--c-primary),#a855f7);color:#fff}.tool-card-tags{display:flex;flex-wrap:wrap;gap:var(--sp-1);margin-top:var(--sp-3)}.tool-card-tag{padding:2px 8px;border-radius:var(--r-full);font-size:var(--f-xs);background:var(--c-primary-lighter);color:var(--c-primary);transition:background var(--transition)}.tool-card-tag:hover{background:var(--c-primary-light)}.tool-card-stats{display:flex;align-items:center;gap:var(--sp-3);margin-top:auto;padding-top:var(--sp-3);border-top:1px solid var(--c-border-light);font-size:var(--f-xs);color:var(--c-text-muted)}.tool-card-stats span{display:flex;align-items:center;gap:3px}.tool-card-stats svg{width:14px;height:14px}.featured-scroll{display:flex;gap:var(--sp-4);overflow-x:auto;padding-bottom:var(--sp-2);scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.featured-scroll::-webkit-scrollbar{height:4px}.featured-scroll::-webkit-scrollbar-track{background:var(--c-bg-input);border-radius:2px}.featured-scroll::-webkit-scrollbar-thumb{background:var(--c-border);border-radius:2px}.featured-scroll .tool-card{min-width:300px;max-width:300px;scroll-snap-align:start;flex-shrink:0}.tool-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--sp-4)}.tool-grid-sm{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--sp-3)}.tool-detail-header{background:var(--c-bg-hero);padding:var(--sp-12) 0;position:relative;overflow:hidden}.tool-detail-header:before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 50% 0%,rgba(99,102,241,.1) 0%,transparent 60%);pointer-events:none}[data-theme=dark] .tool-detail-header:before{background:radial-gradient(circle at 50% 0%,rgba(99,102,241,.2) 0%,transparent 60%)}.tool-detail-info{max-width:var(--container-max);margin:0 auto;padding:0 var(--sp-4);position:relative}.tool-detail-top{display:flex;align-items:flex-start;gap:var(--sp-6)}.tool-detail-icon{width:80px;height:80px;border-radius:var(--r-xl);overflow:hidden;flex-shrink:0;background:var(--c-bg-card);box-shadow:var(--s-md)}.tool-detail-icon img{width:100%;height:100%;object-fit:cover}.tool-detail-meta{flex:1}.tool-detail-name{font-size:var(--f-3xl);font-weight:700;color:var(--c-text);margin-bottom:var(--sp-2)}.tool-detail-short-desc{font-size:var(--f-lg);color:var(--c-text-secondary);margin-bottom:var(--sp-4);line-height:1.6}.tool-detail-actions{display:flex;align-items:center;gap:var(--sp-3);flex-wrap:wrap}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-5);border-radius:var(--r-lg);font-size:var(--f-sm);font-weight:600;cursor:pointer;border:none;transition:all var(--transition);text-decoration:none;white-space:nowrap}.btn svg{width:18px;height:18px}.btn-primary{background:var(--c-primary);color:var(--c-text-on-primary)}.btn-primary:hover{background:var(--c-primary-hover);color:var(--c-text-on-primary);box-shadow:var(--s-md)}.btn-outline{background:0 0;border:1px solid var(--c-border);color:var(--c-text-secondary)}.btn-outline:hover{border-color:var(--c-primary);color:var(--c-primary);background:var(--c-primary-lighter)}.btn-ghost{background:0 0;color:var(--c-text-secondary)}.btn-ghost:hover{color:var(--c-primary);background:var(--c-primary-lighter)}.btn-lg{padding:var(--sp-3) var(--sp-8);font-size:var(--f-base);border-radius:var(--r-xl)}.btn-sm{padding:var(--sp-1) var(--sp-3);font-size:var(--f-xs)}.btn-icon-only{width:40px;height:40px;padding:0;border-radius:var(--r-lg)}.breadcrumb{display:flex;align-items:center;gap:var(--sp-1);font-size:var(--f-sm);color:var(--c-text-muted);margin-bottom:var(--sp-4)}.breadcrumb a{color:var(--c-text-secondary);text-decoration:none;transition:color var(--transition)}.breadcrumb a:hover{color:var(--c-primary)}.breadcrumb .separator{color:var(--c-text-muted)}.breadcrumb .current{color:var(--c-text)}.detail-body{max-width:var(--container-max);margin:0 auto;padding:var(--sp-8) var(--sp-4);display:grid;grid-template-columns:1fr 320px;gap:var(--sp-8)}.detail-main{min-width:0}.detail-sidebar{position:sticky;top:80px;align-self:start}.content-card{background:var(--c-bg-card);border:1px solid var(--c-border);border-radius:var(--r-xl);padding:var(--sp-6);margin-bottom:var(--sp-6)}.content-card-title{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--f-lg);font-weight:700;color:var(--c-text);margin-bottom:var(--sp-4);padding-bottom:var(--sp-3);border-bottom:1px solid var(--c-border-light)}.content-card-title svg{width:20px;height:20px;color:var(--c-primary)}.feature-list{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-3)}.feature-item{display:flex;align-items:flex-start;gap:var(--sp-2);font-size:var(--f-sm);color:var(--c-text-secondary)}.feature-item svg{width:18px;height:18px;color:var(--c-success);flex-shrink:0;margin-top:2px}.step-list{counter-reset:step}.step-item{display:flex;gap:var(--sp-3);padding:var(--sp-3) 0;border-bottom:1px solid var(--c-border-light);counter-increment:step}.step-item:last-child{border-bottom:none}.step-number{width:28px;height:28px;border-radius:var(--r-full);background:var(--c-primary-light);color:var(--c-primary);font-size:var(--f-sm);font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.step-number:before{content:counter(step)}.step-text{font-size:var(--f-sm);color:var(--c-text-secondary);line-height:1.6;padding-top:4px}.screenshot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--sp-3)}.screenshot-item{border-radius:var(--r-lg);overflow:hidden;cursor:pointer;border:1px solid var(--c-border);transition:all var(--transition)}.screenshot-item:hover{border-color:var(--c-primary);box-shadow:var(--s-md)}.screenshot-item img{width:100%;aspect-ratio:16/10;object-fit:cover}.lightbox-overlay{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.85);display:none;align-items:center;justify-content:center;padding:var(--sp-4)}.lightbox-overlay.active{display:flex}.lightbox-overlay img{max-width:90%;max-height:90vh;border-radius:var(--r-lg)}.lightbox-close{position:absolute;top:var(--sp-4);right:var(--sp-4);color:#fff;cursor:pointer;background:rgba(0,0,0,.5);border:none;border-radius:var(--r-full);width:40px;height:40px;display:flex;align-items:center;justify-content:center}.lightbox-close svg{width:24px;height:24px}.tags-cloud{display:flex;flex-wrap:wrap;gap:var(--sp-2)}.tag-item{display:inline-flex;align-items:center;gap:var(--sp-1);padding:var(--sp-2) var(--sp-4);border-radius:var(--r-full);background:var(--c-bg-card);border:1px solid var(--c-border);color:var(--c-text-secondary);font-size:var(--f-sm);transition:all var(--transition);text-decoration:none}.tag-item:hover{border-color:var(--c-primary);color:var(--c-primary);background:var(--c-primary-lighter)}.tag-item svg{width:16px;height:16px}.tag-item .tag-count{font-size:var(--f-xs);color:var(--c-text-muted)}.rank-item{display:flex;align-items:center;gap:var(--sp-4);padding:var(--sp-4);background:var(--c-bg-card);border:1px solid var(--c-border);border-radius:var(--r-lg);margin-bottom:var(--sp-3);transition:all var(--transition);text-decoration:none;color:inherit}.rank-item:hover{border-color:var(--c-primary);box-shadow:var(--s-md)}.rank-number{width:32px;height:32px;border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;font-size:var(--f-sm);font-weight:700;flex-shrink:0}.rank-number.top-1{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff}.rank-number.top-2{background:linear-gradient(135deg,#94a3b8,#64748b);color:#fff}.rank-number.top-3{background:linear-gradient(135deg,#d97706,#b45309);color:#fff}.rank-number.normal{background:var(--c-bg-input);color:var(--c-text-muted)}.rank-icon{width:40px;height:40px;border-radius:var(--r-md);overflow:hidden;flex-shrink:0}.rank-icon img{width:100%;height:100%;object-fit:cover}.rank-info{flex:1;min-width:0}.rank-name{font-weight:600;color:var(--c-text);margin-bottom:2px}.rank-desc{font-size:var(--f-sm);color:var(--c-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rank-stats{display:flex;align-items:center;gap:var(--sp-4);font-size:var(--f-sm);color:var(--c-text-muted);flex-shrink:0}.rank-stats span{display:flex;align-items:center;gap:4px}.rank-stats svg{width:16px;height:16px}.sort-tabs{display:flex;gap:var(--sp-2);margin-bottom:var(--sp-6)}.sort-tab{padding:var(--sp-2) var(--sp-4);border-radius:var(--r-full);font-size:var(--f-sm);font-weight:500;color:var(--c-text-secondary);background:var(--c-bg-card);border:1px solid var(--c-border);cursor:pointer;transition:all var(--transition)}.sort-tab:hover{border-color:var(--c-primary);color:var(--c-primary)}.sort-tab.active{background:var(--c-primary);color:var(--c-text-on-primary);border-color:var(--c-primary)}.submit-form{max-width:720px;margin:0 auto}.form-group{margin-bottom:var(--sp-5)}.form-label{display:block;font-size:var(--f-sm);font-weight:600;color:var(--c-text);margin-bottom:var(--sp-2)}.form-label .required{color:var(--c-error);margin-left:2px}.form-input{width:100%;padding:var(--sp-3) var(--sp-4);border-radius:var(--r-lg);border:1px solid var(--c-border);background:var(--c-bg-card);font-size:var(--f-base);color:var(--c-text);outline:none;transition:all var(--transition)}.form-input:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px var(--c-primary-light)}.form-input::placeholder{color:var(--c-text-muted)}textarea.form-input{min-height:120px;resize:vertical}.form-hint{font-size:var(--f-xs);color:var(--c-text-muted);margin-top:var(--sp-1)}.search-result-item{display:flex;gap:var(--sp-4);padding:var(--sp-5);background:var(--c-bg-card);border:1px solid var(--c-border);border-radius:var(--r-lg);margin-bottom:var(--sp-3);transition:all var(--transition);text-decoration:none;color:inherit}.search-result-item:hover{border-color:var(--c-primary);box-shadow:var(--s-md)}.error-page{text-align:center;padding:var(--sp-16) 0}.error-code{font-size:120px;font-weight:700;color:var(--c-primary);line-height:1;opacity:.3}.error-message{font-size:var(--f-2xl);font-weight:600;color:var(--c-text);margin-top:var(--sp-4)}.error-desc{font-size:var(--f-base);color:var(--c-text-secondary);margin-top:var(--sp-2)}.site-footer{background:var(--c-bg-sidebar);border-top:1px solid var(--c-border);padding:var(--sp-12) 0 var(--sp-6);margin-top:var(--sp-12)}.footer-inner{max-width:var(--container-max);margin:0 auto;padding:0 var(--sp-4)}.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--sp-8);margin-bottom:var(--sp-8)}.footer-brand p{font-size:var(--f-sm);color:var(--c-text-secondary);line-height:1.8;margin-top:var(--sp-3)}.footer-col h4{font-size:var(--f-sm);font-weight:600;color:var(--c-text);margin-bottom:var(--sp-3)}.footer-col a{display:block;font-size:var(--f-sm);color:var(--c-text-secondary);padding:var(--sp-1) 0;transition:color var(--transition);text-decoration:none}.footer-col a:hover{color:var(--c-primary)}.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:var(--sp-6);border-top:1px solid var(--c-border);font-size:var(--f-sm);color:var(--c-text-muted)}.mobile-drawer{position:fixed;top:0;right:-300px;width:300px;height:100vh;background:var(--c-bg-card);z-index:200;transition:right var(--transition-slow);box-shadow:var(--s-xl);padding:var(--sp-6);overflow-y:auto}.mobile-drawer.open{right:0}.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:199;display:none}.drawer-overlay.active{display:block}.mobile-drawer .drawer-close{position:absolute;top:var(--sp-4);right:var(--sp-4)}.mobile-drawer nav{margin-top:var(--sp-8)}.mobile-drawer nav a{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-radius:var(--r-lg);color:var(--c-text-secondary);font-size:var(--f-base);transition:all var(--transition);text-decoration:none;margin-bottom:var(--sp-1)}.mobile-drawer nav a:hover,.mobile-drawer nav a.active{color:var(--c-primary);background:var(--c-primary-light)}.mobile-drawer nav a svg{width:20px;height:20px}.category-header{background:var(--c-bg-hero);padding:var(--sp-12) 0;text-align:center}.category-header h1{font-size:var(--f-3xl);font-weight:700;color:var(--c-text);margin-bottom:var(--sp-2)}.category-header p{font-size:var(--f-lg);color:var(--c-text-secondary)}.pagination{display:flex;align-items:center;justify-content:center;gap:var(--sp-2);margin-top:var(--sp-8)}.pagination a,.pagination span{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 var(--sp-2);border-radius:var(--r-md);font-size:var(--f-sm);border:1px solid var(--c-border);color:var(--c-text-secondary);transition:all var(--transition);text-decoration:none}.pagination a:hover{border-color:var(--c-primary);color:var(--c-primary)}.pagination .current{background:var(--c-primary);color:var(--c-text-on-primary);border-color:var(--c-primary)}.pagination .dots{border:none;color:var(--c-text-muted)}.stat-item{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--f-sm);color:var(--c-text-secondary)}.stat-item svg{width:18px;height:18px;color:var(--c-text-muted)}.back-to-top{position:fixed;bottom:var(--sp-8);right:var(--sp-8);width:44px;height:44px;border-radius:var(--r-full);background:var(--c-primary);color:var(--c-text-on-primary);display:none;align-items:center;justify-content:center;cursor:pointer;border:none;box-shadow:var(--s-lg);transition:all var(--transition);z-index:50}.back-to-top.visible{display:flex}.back-to-top:hover{background:var(--c-primary-hover);transform:translateY(-2px)}.back-to-top svg{width:20px;height:20px}@media (max-width:1024px){.main-layout{grid-template-columns:1fr}.category-sidebar{position:static;display:flex;flex-wrap:wrap;gap:var(--sp-2);padding:var(--sp-4);background:var(--c-bg-card);border-radius:var(--r-xl);border:1px solid var(--c-border);margin-bottom:var(--sp-6)}.category-sidebar h3{display:none}.category-sidebar a{padding:var(--sp-2) var(--sp-3);border:1px solid var(--c-border);border-radius:var(--r-full)}.category-sidebar .cat-count{display:none}.detail-body{grid-template-columns:1fr}.detail-sidebar{position:static}.footer-grid{grid-template-columns:1fr 1fr}}@media (max-width:768px){.header-nav{display:none}.menu-toggle{display:inline-flex}.hero-title{font-size:var(--f-2xl)}.hero-desc{font-size:var(--f-base)}.search-box input{padding:var(--sp-3) var(--sp-10) var(--sp-3) var(--sp-10);font-size:var(--f-base)}.tool-grid{grid-template-columns:1fr}.feature-list{grid-template-columns:1fr}.tool-detail-top{flex-direction:column;align-items:center;text-align:center}.tool-detail-actions{justify-content:center}.footer-grid{grid-template-columns:1fr;gap:var(--sp-6)}.footer-bottom{flex-direction:column;gap:var(--sp-2);text-align:center}.rank-item{flex-wrap:wrap}.rank-stats{width:100%;justify-content:flex-end}.search-result-item{flex-direction:column}}@media (max-width:480px){.hero-section{padding:var(--sp-8) 0 var(--sp-6)}.container{padding:0 var(--sp-3)}.content-card{padding:var(--sp-4)}}.ranking-item{display:flex;align-items:center;gap:var(--sp-4);padding:var(--sp-4);background:var(--c-bg-card);border:1px solid var(--c-border);border-radius:var(--r-lg);text-decoration:none;color:var(--c-text);transition:all var(--transition)}.ranking-item:hover{border-color:var(--c-primary);box-shadow:var(--s-md);transform:translateY(-1px)}.ranking-number{width:32px;height:32px;border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--f-sm);flex-shrink:0;background:var(--c-bg-input);color:var(--c-text-secondary)}.ranking-number-gold{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff}.ranking-number-silver{background:linear-gradient(135deg,#9ca3af,#6b7280);color:#fff}.ranking-number-bronze{background:linear-gradient(135deg,#d97706,#b45309);color:#fff}.ranking-logo-wrap{width:40px;height:40px;border-radius:var(--r-md);overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--c-bg-input)}.ranking-logo-wrap img{width:100%;height:100%;object-fit:contain}.ranking-info{flex:1;min-width:0}.ranking-name{font-weight:600;font-size:var(--f-base);color:var(--c-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ranking-desc{font-size:var(--f-sm);color:var(--c-text-secondary);margin-top:var(--sp-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ranking-stats{display:flex;gap:var(--sp-3);font-size:var(--f-xs);color:var(--c-text-tertiary);flex-shrink:0}.ranking-stats span{display:inline-flex;align-items:center;gap:var(--sp-1)}[data-theme=dark] .ranking-item{background:var(--c-bg-card)}.tag-cloud{display:flex;flex-wrap:wrap;gap:var(--sp-3)}.tag-item{display:inline-flex;align-items:center;gap:var(--sp-1);padding:var(--sp-2) var(--sp-4);background:var(--c-bg-card);border:1px solid var(--c-border);border-radius:var(--r-full);color:var(--c-text-secondary);font-size:var(--f-sm);text-decoration:none;transition:all var(--transition)}.tag-item:hover{border-color:var(--c-primary);color:var(--c-primary);background:var(--c-primary-lighter)}.tag-count{font-size:var(--f-xs);color:var(--c-text-tertiary);background:var(--c-bg-input);padding:0 var(--sp-1);border-radius:var(--r-full)}.detail-screenshot{cursor:pointer;border-radius:var(--r-lg);transition:all var(--transition);max-width:100%;height:auto}.detail-screenshot:hover{box-shadow:var(--s-lg);transform:scale(1.02)}.detail-screenshots{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--sp-4);margin-top:var(--sp-4)}.btn-secondary{display:inline-flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-5);background:var(--c-bg-input);color:var(--c-text);border:1px solid var(--c-border);border-radius:var(--r-md);font-size:var(--f-sm);font-weight:500;cursor:pointer;text-decoration:none;transition:all var(--transition)}.btn-secondary:hover{border-color:var(--c-primary);color:var(--c-primary)}.ranking-tabs{display:flex;gap:var(--sp-2);margin-bottom:var(--sp-6);border-bottom:2px solid var(--c-border)}.ranking-tab{padding:var(--sp-3) var(--sp-5);font-size:var(--f-sm);font-weight:500;color:var(--c-text-secondary);border:none;background:0 0;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all var(--transition)}.ranking-tab:hover{color:var(--c-text)}.ranking-tab.active{color:var(--c-primary);border-bottom-color:var(--c-primary)}.ranking-list{display:flex;flex-direction:column;gap:var(--sp-3)}