@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;600;800&display=swap";:root{--bg-main: #0f172a;--bg-card: #1e293b;--bg-card-hover: #334155;--text-main: #f8fafc;--text-muted: #94a3b8;--accent-primary: #ec4899;--accent-secondary: #8b5cf6;--type-normal: #A8A77A;--type-fire: #EE8130;--type-water: #6390F0;--type-electric: #F7D02C;--type-grass: #7AC74C;--type-ice: #96D9D6;--type-fighting: #C22E28;--type-poison: #A33EA1;--type-ground: #E2BF65;--type-flying: #A98FF3;--type-psychic: #F95587;--type-bug: #A6B91A;--type-rock: #B6A136;--type-ghost: #735797;--type-dragon: #6F35FC;--type-dark: #705746;--type-steel: #B7B7CE;--type-fairy: #D685AD;--radius-md: 12px;--radius-lg: 20px;--transition-fast: .2s ease;--transition-smooth: .4s cubic-bezier(.16, 1, .3, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Outfit,sans-serif;background-color:var(--bg-main);color:var(--text-main);line-height:1.5;-webkit-font-smoothing:antialiased;min-height:100vh}#root{display:flex;flex-direction:column;min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:800;letter-spacing:-.02em}.glass{background:#1e293bb3;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.05)}.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.btn-primary{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;border:none;padding:.75rem 1.5rem;border-radius:var(--radius-md);font-weight:600;font-family:inherit;font-size:1rem;cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.btn-primary:hover,.btn-primary:focus{transform:translateY(-2px);box-shadow:0 4px 12px #ec489966;outline:none}.pokemon-grid-container{padding:2rem 0}.pokemon-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.5rem;padding:1.5rem 0}.pokemon-card{display:flex;flex-direction:column;align-items:center;padding:1.5rem;border-radius:var(--radius-lg);text-decoration:none;color:inherit;transition:transform var(--transition-smooth),background-color var(--transition-fast);cursor:pointer;position:relative;overflow:hidden;height:100%}.pokemon-card:hover,.pokemon-card:focus-visible{transform:translateY(-8px);background-color:var(--bg-card-hover);outline:none;box-shadow:0 8px 24px #0006}.pokemon-card-image-container{width:100%;aspect-ratio:1;display:flex;justify-content:center;align-items:center;margin-bottom:1rem}.pokemon-card-image{max-width:80%;max-height:80%;object-fit:contain;transition:transform var(--transition-fast);filter:drop-shadow(0 4px 6px rgba(0,0,0,.5))}.pokemon-card:hover .pokemon-card-image{transform:scale(1.1)}.pokemon-card-info{display:flex;flex-direction:column;align-items:center;width:100%;flex-grow:1;justify-content:flex-start;min-height:110px}.pokemon-id{font-size:.875rem;color:var(--text-muted);font-weight:600}.pokemon-name{font-size:1.25rem;text-transform:capitalize;margin:.25rem 0 .75rem;width:100%;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pokemon-types{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;margin-top:auto}.type-badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.4);box-shadow:inset 0 0 0 1px #fff3}.loading-badge{background-color:var(--text-muted);opacity:.5}.pagination-container{display:flex;justify-content:center;align-items:center;gap:.5rem;margin-top:3rem;padding-bottom:2rem;flex-wrap:wrap}.page-btn{background:var(--bg-card);color:var(--text-main);border:1px solid rgba(255,255,255,.1);width:40px;height:40px;border-radius:var(--radius-md);display:flex;justify-content:center;align-items:center;cursor:pointer;font-weight:600;transition:all var(--transition-fast)}.page-btn:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--accent-primary)}.page-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.page-btn:disabled{opacity:.5;cursor:not-allowed}.type-filter-container{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;margin-top:1rem;margin-bottom:2rem}.type-filter-btn{padding:.4rem 1rem;border-radius:9999px;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#fff;cursor:pointer;border:2px solid transparent;transition:all var(--transition-fast);opacity:.6}.type-filter-btn:hover{opacity:.8;transform:translateY(-2px)}.type-filter-btn.active{opacity:1;border-color:#fff;box-shadow:0 4px 12px #0000004d;transform:scale(1.05)}.search-input{width:100%;padding:1rem 1.5rem;border-radius:var(--radius-md);border:1px solid rgba(255,255,255,.1);background-color:var(--bg-main);color:var(--text-main);font-family:inherit;font-size:1rem;transition:all var(--transition-fast)}.search-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #ec489933}.pokemon-detail-page{padding:2rem 1.5rem 4rem}.btn-back{display:inline-block;margin-bottom:2rem;color:var(--text-muted);text-decoration:none;font-weight:600;transition:color var(--transition-fast)}.btn-back:hover{color:var(--text-main)}.pokemon-detail-header{display:flex;flex-direction:column;gap:2rem;padding:2.5rem;border-radius:var(--radius-lg);margin-bottom:2rem}@media(min-width:768px){.pokemon-detail-header{flex-direction:row;align-items:center}}.pokemon-detail-image-wrapper{flex:1;display:flex;justify-content:center;align-items:center;background:radial-gradient(circle,rgba(255,255,255,.05) 0%,transparent 70%);border-radius:50%;padding:1rem}.pokemon-detail-image{max-width:300px;width:100%;height:auto;filter:drop-shadow(0 10px 20px rgba(0,0,0,.4));animation:float 6s ease-in-out infinite}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-15px)}to{transform:translateY(0)}}.pokemon-detail-info{flex:1.5}.pokemon-detail-id{font-size:1.25rem;font-weight:800;color:var(--text-muted)}.pokemon-detail-name{font-size:3.5rem;text-transform:capitalize;margin:.5rem 0 1rem;background:linear-gradient(to right,var(--text-main),var(--text-muted));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.pokemon-description{font-size:1.1rem;line-height:1.6;color:var(--text-muted);margin-bottom:2rem;max-width:600px}.pokemon-physical-stats{display:flex;gap:2rem;flex-wrap:wrap}.stat-box{display:flex;flex-direction:column;gap:.25rem}.stat-label{font-size:.875rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.stat-value{font-size:1.25rem;font-weight:600}.pokemon-base-stats{padding:2.5rem;border-radius:var(--radius-lg)}.pokemon-base-stats h2{font-size:1.5rem;margin-bottom:1.5rem}.stats-container{display:flex;flex-direction:column;gap:1rem}.stat-bar-container{display:flex;align-items:center;gap:1rem}.stat-bar-label{width:140px;font-weight:600;text-transform:capitalize;color:var(--text-muted)}.stat-bar-number{width:40px;font-weight:800;text-align:right}.stat-bar-track{flex:1;height:8px;background-color:#ffffff1a;border-radius:9999px;overflow:hidden}.stat-bar-fill{height:100%;border-radius:9999px;transition:width 1s cubic-bezier(.16,1,.3,1)}@keyframes skeleton-pulse{0%,to{opacity:.15}50%{opacity:.3}}.skeleton-card{pointer-events:none;min-height:320px}.skeleton-pulse{background:linear-gradient(90deg,#ffffff14,#ffffff2e,#ffffff14);background-size:200% 100%;animation:skeleton-pulse 1.8s ease-in-out infinite;border-radius:var(--radius-md)}.skeleton-image{width:120px;height:120px;border-radius:50%;margin:1.5rem auto}.skeleton-id{width:50px;height:14px;margin:0 auto .5rem}.skeleton-name{width:100px;height:20px;margin:0 auto .75rem}.skeleton-badge{width:50px;height:22px;border-radius:9999px;display:inline-block;margin:0 .2rem}.pokemon-card{position:relative}.favorite-btn{position:absolute;top:.6rem;right:.6rem;z-index:10;background:#0000004d;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.9rem;transition:transform .2s ease,background .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.favorite-btn:hover{transform:scale(1.2);background:#00000080}.favorite-btn.active{animation:heartPop .3s ease}@keyframes heartPop{0%{transform:scale(1)}50%{transform:scale(1.4)}to{transform:scale(1)}}.filter-controls-row{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;max-width:800px;margin:1.5rem auto;padding:0 1rem}.filter-chip{padding:.4rem 1rem;border-radius:20px;border:1px solid rgba(255,255,255,.15);background:#ffffff0d;color:var(--text-muted);cursor:pointer;font-size:.8rem;font-weight:600;font-family:inherit;transition:all .2s ease;white-space:nowrap}.filter-chip:hover{background:#ffffff1a;border-color:#ffffff4d;color:var(--text-main)}.filter-chip.active{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border-color:transparent;color:#fff;box-shadow:0 2px 10px #ec48994d}[data-theme=light]{--bg-main: #f1f5f9;--bg-card: #ffffff;--bg-card-hover: #f8fafc;--text-main: #0f172a;--text-muted: #64748b}[data-theme=light] .glass{background:#ffffffd9;border:1px solid rgba(0,0,0,.08)}[data-theme=light] .search-input{background:#fff;color:#0f172a;border-color:#ec489933}[data-theme=light] .filter-chip{border-color:#0000001f;background:#0000000a;color:#475569}[data-theme=light] .filter-chip:hover{background:#00000014;color:#0f172a}[data-theme=light] .favorite-btn{background:#ffffffb3}[data-theme=light] .page-btn{background:#0000000d;color:#334155;border-color:#0000001a}[data-theme=light] .page-btn.active{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff}
