:root{--bg-color:#0f1115;--bg-gradient:radial-gradient(circle at top right, #1a1e26, #0f1115);--card-bg:#ffffff08;--card-border:#ffffff0d;--text-primary:#f0f2f5;--text-secondary:#a0a5b1;--accent-color:#2563eb;--accent-text:#60a5fa;--accent-hover:#1d4ed8;--success-color:#10b981}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-color);background-image:var(--bg-gradient);min-height:100vh;color:var(--text-primary);font-family:Inter,sans-serif;line-height:1.5}#app{max-width:1200px;margin:0 auto;padding:2rem}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.app-header{text-align:center;margin-bottom:3rem;animation:.8s ease-out fadeInDown}.app-header h1{background:linear-gradient(90deg,#60a5fa,#3b82f6);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:.5rem;font-size:3rem;font-weight:700}@media (width<=768px){.app-header h1{font-size:2.25rem}}.app-header p{color:var(--text-secondary);margin-bottom:1rem;font-size:1.125rem}@media (width<=768px){.app-header p{font-size:1rem}}.header-stats{justify-content:center;align-items:center;gap:1.5rem;font-size:.95rem;font-weight:500;transition:opacity .5s ease-in-out;display:flex}@media (width<=576px){.header-stats{flex-direction:column;gap:.5rem}}.header-stats.hidden{opacity:0;pointer-events:none}.header-stats .stat-item{color:var(--text-primary);align-items:center;gap:.5rem;display:flex}.header-stats .stat-item svg{width:18px;height:18px}.header-stats .stat-item svg.star{fill:#f59e0b}.header-stats .stat-item svg.download{fill:#3b82f6}.header-stats .stat-separator{color:var(--card-border);font-weight:300}@media (width<=576px){.header-stats .stat-separator{display:none}}.filter-tabs{justify-content:center;gap:.5rem;margin-bottom:1.5rem;animation:1s ease-out fadeIn;display:flex}@media (width<=576px){.filter-tabs{flex-wrap:wrap}}.filter-tab{cursor:pointer;border:1px solid var(--card-border);background:var(--card-bg);color:var(--text-secondary);border-radius:9999px;padding:.6rem 1.25rem;font-size:.9rem;font-weight:600;transition:all .2s}.filter-tab:hover{color:var(--text-primary);background:#ffffff0d}.filter-tab.active{border-color:var(--accent-color);background:var(--accent-color);color:#fff;box-shadow:0 4px 12px #2563eb4d}.controls-container{flex-wrap:wrap;justify-content:center;align-items:center;gap:1rem;margin-bottom:2rem;animation:1s ease-out fadeIn;display:flex}.input-group{display:contents}.search-input{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--card-border);background:var(--card-bg);max-width:400px;height:48px;color:var(--text-primary);border-radius:9999px;outline:none;flex:1;padding:0 1.5rem;font-size:1rem;transition:all .3s}.search-input:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #3b82f633}.sort-select{appearance:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;border:1px solid var(--card-border);background:var(--card-bg);height:48px;color:var(--text-primary);border-radius:9999px;outline:none;padding:0 1.5rem;font-size:1rem}.sort-select:focus{border-color:var(--accent-color)}.sort-select option{background:var(--bg-color)}.grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin:-1rem;padding:1rem;animation:.8s ease-out fadeInUp;display:grid}@media (width<=576px){.grid{grid-template-columns:1fr;gap:1rem}}.card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--card-border);background:var(--card-bg);backface-visibility:hidden;will-change:transform, box-shadow;contain:layout paint;isolation:isolate;height:100%;color:inherit;border-radius:1.25rem;flex-direction:column;padding:0;text-decoration:none;transition:transform .3s cubic-bezier(.4,0,.2,1),border-color .3s,background-color .3s,box-shadow .3s;display:flex;position:relative;overflow:hidden;transform:translate(0,0)}.card:hover,.card:focus-within{z-index:10;background:#ffffff0f;border-color:#ffffff26;outline:none;transform:translateY(-8px);box-shadow:0 20px 40px #00000080}.card:hover .card-screenshot,.card:focus-within .card-screenshot{transform:scale(1.05)translate(0,0)}.card:hover .tag,.card:focus-within .tag{color:var(--text-primary);border-color:#3b82f64d}.card.hidden{display:none}.card-image-wrapper{background:#1a1e26;width:100%;height:160px;position:relative;overflow:hidden;-webkit-mask-image:-webkit-radial-gradient(#fff,#000)}.card-screenshot{object-fit:cover;width:100%;height:100%;transition:transform .6s cubic-bezier(.4,0,.2,1);transform:translate(0,0)}.card-content{flex-direction:column;flex-grow:1;padding:1.5rem;display:flex}.card-header{align-items:flex-start;gap:1rem;margin-bottom:1.25rem;display:flex}.card-icon-img{object-fit:cover;border-radius:14px;flex-shrink:0;width:64px;height:64px;box-shadow:0 4px 12px #0000004d}.card-title-group{flex-direction:column;gap:.25rem;min-width:0;display:flex}.badge-group{flex-wrap:wrap;gap:.4rem;margin-top:.25rem;display:flex}.badge{letter-spacing:.05em;text-transform:uppercase;border-radius:6px;width:fit-content;padding:.2rem .6rem;font-size:.65rem;font-weight:700}.badge.lovelace{color:#60a5fa;background:#3b82f633}.badge.integration{color:#34d399;background:#10b98133}.badge.other{color:#9ca3af;background:#9ca3af33}.badge.updated{color:#fff;background:linear-gradient(135deg,#3b82f6cc,#2563ebcc);animation:2s ease-in-out infinite alternate badge-glow;box-shadow:0 0 12px #3b82f666}@keyframes badge-glow{0%{box-shadow:0 0 10px #3b82f64d}to{box-shadow:0 0 20px #3b82f699}}.card-title-link,.card-developer-link{width:fit-content;text-decoration:none}.card-title-link:hover .card-title,.card-title-link:focus .card-title{color:var(--accent-text)}.card-developer-link:hover .card-developer,.card-developer-link:focus .card-developer{color:var(--accent-hover);text-decoration:underline}.card-title{color:var(--text-primary);font-size:1.15rem;font-weight:700;line-height:1.2}.card-title mark.highlight{color:inherit;background:#3b82f64d;border-radius:2px;padding:0 2px}.card-developer{color:var(--accent-text);margin-bottom:.25rem;font-size:.85rem;font-weight:500}.view-btn{box-shadow:none;border:1px solid var(--card-border);color:var(--text-primary);background:#ffffff0d}.view-btn:hover,.view-btn:focus{background:#ffffff1a;box-shadow:0 4px 12px #0003}.card-description{-webkit-line-clamp:3;color:var(--text-secondary);-webkit-box-orient:vertical;flex-grow:1;margin-bottom:1rem;font-size:.875rem;display:-webkit-box;overflow:hidden}.card-description mark.highlight{color:var(--text-primary);background:#3b82f64d;border-radius:2px}.card-tags{flex-wrap:wrap;gap:.4rem;margin-bottom:1.25rem;display:flex}.tag{border:1px solid var(--card-border);color:var(--text-secondary);background:#ffffff0d;border-radius:4px;padding:.2rem .5rem;font-size:.7rem;transition:all .2s}.card-footer{color:var(--text-secondary);flex-wrap:wrap;justify-content:flex-start;align-items:center;gap:.5rem;margin-top:auto;padding-top:1rem;font-size:.75rem;font-weight:500;display:flex}.stat{border:1px solid var(--card-border);background:#ffffff08;border-radius:9999px;align-items:center;gap:.35rem;padding:.25rem .6rem;display:flex}.stat:last-child{margin-left:auto}.stat svg{width:14px;height:14px}.stat svg.star{fill:#f59e0b}.stat svg.download{fill:#3b82f6}.card-actions{justify-content:stretch;gap:.5rem;margin-top:1.25rem;display:flex}.install-btn{background:var(--accent-color);color:#fff;border:none;border-radius:9999px;flex:1;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1rem;font-size:.9rem;font-weight:700;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 4px 12px #3b82f64d}.install-btn:hover,.install-btn:focus{background:var(--accent-hover);outline:none;transform:scale(1.02);box-shadow:0 6px 16px #3b82f666}.install-btn:active{transform:scale(.98)}.copy-btn{cursor:pointer;border:1px solid var(--card-border);background:var(--card-bg);width:48px;height:48px;color:var(--text-secondary);border-radius:9999px;flex-shrink:0;justify-content:center;align-items:center;transition:all .2s;display:flex}.copy-btn svg{fill:currentColor;width:18px;height:18px}.copy-btn:hover{color:var(--text-primary);background:#ffffff0d}.copy-btn.success{border-color:var(--success-color);background:var(--success-color);color:#fff;box-shadow:0 0 12px #10b9814d}.progress-container{text-align:center;width:100%;max-width:400px}.progress-bar-wrapper{background:var(--card-border);border-radius:2px;height:4px;margin-bottom:.5rem;overflow:hidden}.progress-bar{background:var(--accent-color);height:100%;transition:width .3s}.progress-text{color:#ffffff80;font-size:.8rem}.skeleton{background:linear-gradient(90deg,#ffffff08 25%,#ffffff0f 50%,#ffffff08 75%) 0 0/200% 100%;border-radius:4px;animation:1.5s ease-in-out infinite pulse}@keyframes pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.card.skeleton-card{pointer-events:none}.card.skeleton-card .skeleton-image{width:100%;height:160px}.card.skeleton-card .skeleton-icon{border-radius:14px;width:64px;height:64px}.card.skeleton-card .skeleton-title{width:70%;height:1.25rem;margin-bottom:.5rem}.card.skeleton-card .skeleton-developer{width:40%;height:.85rem;margin-bottom:.5rem}.card.skeleton-card .skeleton-text{width:100%;height:.875rem;margin-bottom:.5rem}.card.skeleton-card .skeleton-text.short{width:60%}.card.skeleton-card .skeleton-footer{gap:.5rem;margin-top:auto;padding-top:1rem;display:flex}.card.skeleton-card .skeleton-footer .skeleton-stat{border-radius:9999px;width:60px;height:1.5rem}
