*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'Inter',sans-serif;background:#f5f7fa;color:#333;font-size:14.5px;line-height:1.6;}
a{text-decoration:none;color:inherit;}
img{max-width:100%;display:block;}
button,input,select{font:inherit;}
.header{background:linear-gradient(135deg,#1a7a45,#27ae60,#2ecc71);box-shadow:0 3px 16px rgba(39,174,96,0.35);position:sticky;top:0;z-index:100;}
.header-inner{max-width:1380px;margin:0 auto;display:flex;align-items:center;padding:8px 24px;gap:12px;position:relative;}
.header-logo-col{flex:1;display:flex;align-items:center;}
.logo-top{display:flex;align-items:center;gap:8px;font-size:23px;font-weight:700;color:#fff;font-family:'Poppins',sans-serif;}
.logo-crown{color:#fff;font-size:26px;}
.header-nav-col{flex:none;display:flex;justify-content:center;}
.header-nav{display:flex;align-items:center;gap:2px;overflow-x:auto;scrollbar-width:none;}
.header-nav::-webkit-scrollbar{display:none;}
.nav-link{display:flex;align-items:center;padding:7px 14px;border-radius:10px;color:#fff;font-size:13.5px;font-weight:600;white-space:nowrap;transition:.18s;}
.nav-link:hover,.nav-link.active{background:#fff;color:#27ae60;}
.header-right-col{flex:1;display:flex;align-items:center;justify-content:flex-end;gap:10px;}
.btn-login{background:rgba(255,255,255,.15);border:1.5px solid rgba(255,255,255,.6);padding:8px 22px;border-radius:20px;color:#fff;}
.btn-signup{background:#fff;color:#27ae60;border:none;padding:9px 22px;border-radius:20px;font-weight:700;}
.wrapper{max-width:1380px;margin:0 auto;padding:24px 20px;}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:#7dba9a;margin-bottom:18px;flex-wrap:wrap;}
.breadcrumb a{color:#27ae60;font-weight:600;}
.category-hero{background:linear-gradient(135deg,#ffffff 0%,#f0faf5 55%,#e2f7ea 100%);border-radius:18px;box-shadow:0 4px 24px rgba(0,0,0,.08);padding:28px;display:grid;grid-template-columns:1.2fr .8fr;gap:24px;margin-bottom:24px;position:relative;overflow:hidden;}
.category-kicker{display:inline-flex;align-items:center;gap:8px;background:#edfbf3;color:#27ae60;border-radius:999px;padding:6px 14px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;margin-bottom:10px;}
.category-title{font-family:'Poppins',sans-serif;font-size:34px;line-height:1.15;color:#1a1a2e;margin-bottom:10px;}
.category-desc{font-size:15px;color:#555;max-width:62ch;margin-bottom:18px;}
.category-meta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:18px;}
.category-pill{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1.5px solid #d6ead6;color:#1a5c34;padding:9px 14px;border-radius:999px;font-size:13px;font-weight:600;box-shadow:0 2px 8px rgba(39,174,96,.06);}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;}
.hero-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border-radius:14px;font-size:14px;font-weight:700;}
.hero-btn.primary{background:linear-gradient(135deg,#1a7a45,#27ae60);color:#fff;}
.hero-btn.ghost{background:#fff;border:1.5px solid #dbe7dc;color:#1a5c34;}
.category-hero-side{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-content:start;}
.hero-stat-card{background:#fff;border:1.5px solid #e4efe6;border-radius:16px;padding:16px;box-shadow:0 6px 18px rgba(0,0,0,.04);}
.hero-stat-number{font-family:'Poppins',sans-serif;font-size:24px;font-weight:800;color:#1a5c34;line-height:1.1;margin-bottom:4px;}
.hero-stat-label{font-size:12px;color:#7dba9a;font-weight:600;}
.hero-stat-sub{font-size:11px;color:#999;margin-top:6px;}
.two-col{display:grid;grid-template-columns:1fr 340px;gap:24px;align-items:start;}
.left-col,.right-col{display:flex;flex-direction:column;gap:24px;}
.box{background:#fff;border-radius:16px;box-shadow:0 2px 12px rgba(0,0,0,.06);padding:24px;overflow:hidden;}
.box-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap;}
.box-title{font-size:17px;font-weight:800;color:#1a1a2e;font-family:'Poppins',sans-serif;}
.box-sub{font-size:12px;color:#7dba9a;margin-top:2px;}
.filters-row{display:grid;grid-template-columns:1.1fr .7fr .7fr .7fr;gap:14px;margin-bottom:18px;}
.filter-field{background:#f9fbff;border:1.5px solid #e0e7ef;border-radius:14px;padding:10px 14px;display:flex;align-items:center;gap:10px;min-height:48px;}
.filter-field input,.filter-field select{border:none;background:none;outline:none;width:100%;font-size:13.5px;color:#1a1a2e;}
.soft-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.soft-card{background:#f9fbff;border:1.5px solid #eaecf5;border-radius:14px;padding:15px 14px;display:flex;align-items:center;gap:14px;transition:.2s;position:relative;overflow:hidden;}
.soft-card:hover{box-shadow:0 6px 20px rgba(46,204,113,.12);border-color:#b8ead0;transform:translateY(-2px);}
.soft-card:nth-child(4n+2),.soft-card:nth-child(4n+3){background:#f0faf5;}
.soft-card-top{display:flex;align-items:center;gap:14px;flex:1;min-width:0;}
.soft-icon{width:52px;height:52px;border-radius:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden;background:linear-gradient(135deg,#27ae60,#1a7a45);}
.soft-icon img{width:100%;height:100%;object-fit:cover;}
.soft-info{flex:1;min-width:0;}
.soft-name{font-size:16px;font-weight:700;color:#1a5c34;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.soft-desc{font-size:12px;color:#7dba9a;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.soft-dlcount{font-size:10.5px;color:#aaa;margin-top:4px;}
.soft-card-right{display:flex;flex-direction:column;align-items:flex-start;gap:10px;flex-shrink:0;}
.soft-cat,.soft-size{font-size:11px;font-weight:600;color:#27ae60;}
.soft-size{color:#7dba9a;font-weight:500;}
.soft-badge{position:absolute;top:10px;right:10px;font-size:10px;font-weight:700;padding:4px 8px;border-radius:999px;background:#edfbf3;color:#27ae60;text-transform:uppercase;}
.sidebar-card{background:linear-gradient(145deg,#edfbf3 0%,#f4fff8 60%,#e6f7ed 100%);border-left:4px solid #27ae60;border-radius:16px;padding:18px;box-shadow:0 2px 12px rgba(0,0,0,.05);}
.sidebar-title h3{font-size:16px;font-weight:800;color:#1a5c34;font-family:'Poppins',sans-serif;}
.sidebar-list{display:flex;flex-direction:column;gap:12px;margin-top:14px;}
.sidebar-item{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid #e4efe6;border-radius:14px;padding:12px;transition:.18s;}
.sidebar-rank{width:26px;height:26px;border-radius:50%;background:#27ae60;color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;flex-shrink:0;}
.sidebar-app{flex:1;min-width:0;}
.sidebar-app-name{font-size:13px;font-weight:700;color:#1a5c34;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sidebar-app-meta{font-size:11px;color:#7dba9a;}
.cat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;}
.cat-card{background:#fff;border:1.5px solid #e4efe6;border-radius:16px;padding:16px;display:flex;align-items:center;gap:12px;transition:.2s;}
.cat-card:hover{background:#edfbf3;border-color:#b8ead0;}
.cat-icon-wrap{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,#2ecc71,#27ae60);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;font-size:18px;font-weight:700;}
.cat-name{font-size:13px;font-weight:700;color:#1a1a2e;}
.cat-count{font-size:11px;color:#7dba9a;}
.empty-note{padding:18px;border:1px dashed #cfe8d6;background:#f8fffb;border-radius:14px;color:#5d7f68;}
.footer-main{background:#fff;border-top:1px solid #eee;padding:32px;margin-top:40px;text-align:center;color:#666;}
@media (max-width:1100px){.two-col{grid-template-columns:1fr;}.category-hero{grid-template-columns:1fr;}}
@media (max-width:860px){.filters-row,.soft-grid,.cat-grid,.category-hero-side{grid-template-columns:1fr;}}
@media (max-width:640px){.wrapper{padding:18px 14px;}.header-inner{padding:10px 14px;flex-wrap:wrap;}.header-logo-col,.header-nav-col,.header-right-col{flex:1 1 100%;justify-content:center;}.category-title{font-size:28px;}.hero-actions{flex-direction:column;}.hero-btn{width:100%;}}