*{margin:0;padding:0;box-sizing:border-box}body{background:#0d1117;color:#e6edf3;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow-x:hidden}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-thumb{background:#30363d;border-radius:3px}.app-root{min-height:100vh;position:relative}.loading{display:flex;justify-content:center;align-items:center;height:60vh;font-size:1.2rem;color:#8b949e}.no-results{text-align:center;padding:40px;color:#8b949e;font-size:1.1rem}.champion-grid-page{max-width:900px;margin:0 auto;padding:20px 16px 100px}.grid-header{text-align:center;padding:24px 0 8px}.grid-header h1{font-size:1.8rem;background:linear-gradient(135deg,#58a6ff,#bc8cff);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.subtitle{color:#8b949e;margin-top:4px;font-size:.9rem}.search-bar{margin:16px 0}.search-bar input{width:100%;padding:12px 16px;border-radius:12px;border:1px solid #30363d;background:#161b22;color:#e6edf3;font-size:1rem;outline:none;transition:border-color .2s}.search-bar input:focus{border-color:#58a6ff}.tier-tabs{display:flex;gap:8px;margin-bottom:16px;overflow-x:auto;padding-bottom:4px}.tier-tab{padding:8px 18px;border-radius:20px;border:1px solid #30363d;background:transparent;color:#8b949e;font-size:.9rem;cursor:pointer;white-space:nowrap;transition:all .2s}.tier-tab:hover{border-color:#58a6ff;color:#58a6ff}.tier-tab.active{background:#58a6ff;color:#fff;border-color:#58a6ff}.tier-tab.active.tier-t1{background:#f59e0b;border-color:#f59e0b}.tier-tab.active.tier-t2{background:#94a3b8;border-color:#94a3b8}.tier-tab.active.tier-t3{background:#b45309;border-color:#b45309}.tier-tab.active.tier-t4{background:#64748b;border-color:#64748b}.tier-tab.active.tier-t5{background:#dc2626;border-color:#dc2626}.champion-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}@media(max-width:768px){.champion-grid{grid-template-columns:repeat(4,1fr);gap:8px}}@media(max-width:480px){.champion-grid{grid-template-columns:repeat(3,1fr);gap:8px}}.champion-card{display:flex;flex-direction:column;align-items:center;padding:12px 4px;border-radius:12px;background:#161b22;border:1px solid #21262d;cursor:pointer;transition:all .2s ease}.champion-card:hover{transform:translateY(-4px);border-color:#58a6ff;box-shadow:0 8px 24px #58a6ff26}.card-avatar-wrap{position:relative;margin-bottom:8px}.card-avatar{width:60px;height:60px;border-radius:50%;border:2px solid #30363d;object-fit:cover}.champion-card:hover .card-avatar{border-color:#58a6ff}.tier-badge{position:absolute;bottom:-4px;right:-4px;font-size:.65rem;font-weight:700;padding:1px 6px;border-radius:8px}.tier-badge.t1{background:#f59e0b;color:#000}.tier-badge.t2{background:#94a3b8;color:#000}.tier-badge.t3{background:#b45309;color:#fff}.tier-badge.t4{background:#64748b;color:#fff}.card-name{font-size:.8rem;font-weight:500;text-align:center;line-height:1.2;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.card-winrate{font-size:.85rem;font-weight:700}.page-container{width:100%}.detail-page{position:fixed;top:0;left:0;right:0;bottom:0;background:#0d1117;z-index:50;overflow-y:auto;animation:slideIn .3s ease}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.detail-page-content{max-width:700px;margin:0 auto;padding:16px 16px 100px}.back-btn{background:none;border:1px solid #30363d;color:#58a6ff;padding:8px 16px;border-radius:8px;cursor:pointer;font-size:.95rem;margin-bottom:16px;transition:all .2s}.back-btn:hover{background:#161b22}.detail-hero{display:flex;gap:16px;align-items:center;margin-bottom:24px}.detail-avatar{width:90px;height:90px;border-radius:50%;border:3px solid #58a6ff}.detail-info h1{font-size:1.5rem}.detail-title{color:#8b949e;font-size:.9rem}.detail-stats{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.tier-badge-lg{padding:4px 12px;border-radius:8px;font-weight:700;font-size:.85rem}.tier-badge-lg.t1{background:#f59e0b;color:#000}.tier-badge-lg.t2{background:#94a3b8;color:#000}.tier-badge-lg.t3{background:#b45309;color:#fff}.tier-badge-lg.t4{background:#64748b;color:#fff}.tier-badge-lg.t5{background:#dc2626;color:#fff}.stat-pill{background:#161b22;padding:4px 10px;border-radius:8px;font-size:.85rem;border:1px solid #21262d}.detail-section{margin-bottom:20px;background:#161b22;border-radius:12px;padding:16px;border:1px solid #21262d}.detail-section h2{font-size:1.1rem;margin-bottom:12px;color:#58a6ff}.build-row{margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid #21262d}.build-row:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.items-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.item-icon-wrap{display:flex;flex-direction:column;align-items:center;gap:4px}.item-icon{width:32px;height:32px;border-radius:8px;border:1px solid #30363d}.item-name{font-size:.65rem;color:#8b949e;max-width:56px;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pick-info{font-size:.75rem;color:#8b949e;margin-top:4px;display:block}.rune-set{margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid #21262d}.rune-set:last-child{border-bottom:none}.rune-trees{display:flex;align-items:center;gap:8px;margin-bottom:6px}.rune-tree{display:flex;align-items:center;gap:6px;min-width:80px}.tree-icon{width:24px;height:24px}.rune-icons{display:flex;gap:6px}.rune-icon{width:32px;height:32px;border-radius:50%;border:1px solid #30363d}.skill-order{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.skill-priority{font-size:1.1rem;font-weight:700;color:#58a6ff}.skill-seq{display:flex;gap:4px}.skill-badge{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;font-weight:700;font-size:.8rem}.skill-Q{background:#3b82f6}.skill-W{background:#10b981}.skill-E{background:#f59e0b}.skill-R{background:#ef4444}.chat-fab{position:fixed;bottom:24px;right:24px;width:60px;height:60px;border-radius:50%;border:none;background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;font-size:1.6rem;cursor:pointer;z-index:100;box-shadow:0 4px 20px #3b82f666;animation:breathe 3s ease-in-out infinite;display:flex;align-items:center;justify-content:center}@keyframes breathe{0%,to{box-shadow:0 4px 20px #3b82f666}50%{box-shadow:0 4px 30px #8b5cf699}}.chat-fab:hover{transform:scale(1.1)}.chat-overlay-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:199;opacity:0;pointer-events:none;transition:opacity .3s}.chat-overlay-backdrop.show{opacity:1;pointer-events:auto}.chat-overlay{position:fixed;bottom:0;left:0;right:0;height:80vh;background:#161b22;border-radius:20px 20px 0 0;z-index:200;transform:translateY(100%);transition:transform .35s cubic-bezier(.32,.72,0,1);display:flex;flex-direction:column}.chat-overlay.show{transform:translateY(0)}.overlay-handle{display:flex;justify-content:center;padding:10px;cursor:pointer}.handle-bar{width:40px;height:4px;background:#30363d;border-radius:2px}.overlay-header{display:flex;align-items:center;gap:8px;padding:0 16px 12px;border-bottom:1px solid #21262d}.overlay-header h2{font-size:1.1rem}.overlay-body{flex:1;overflow-y:auto}.overlay-input{border-top:1px solid #21262d}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.status-dot.connected{background:#4ade80}.status-dot.disconnected{background:#f87171}.chat-window{flex:1;overflow-y:auto;padding:16px}.welcome{text-align:center;color:#8b949e;padding:40px 16px}.message{max-width:80%;padding:10px 14px;border-radius:16px;margin-bottom:8px;font-size:.95rem;line-height:1.5;word-wrap:break-word;white-space:pre-wrap}.message.user{background:#1f6feb;color:#fff;margin-left:auto;border-bottom-right-radius:4px}.message.ai{background:#21262d;color:#e6edf3;margin-right:auto;border-bottom-left-radius:4px}.message.typing:after{content:"▊";animation:blink 1s step-end infinite}@keyframes blink{50%{opacity:0}}.chat-input-container{display:flex;gap:8px;padding:12px 16px}.chat-input-container input{flex:1;padding:10px 14px;border-radius:20px;border:1px solid #30363d;background:#0d1117;color:#e6edf3;font-size:.95rem;outline:none}.chat-input-container input:focus{border-color:#58a6ff}.chat-input-container button{width:40px;height:40px;border-radius:50%;border:none;background:#1f6feb;color:#fff;font-size:1.1rem;cursor:pointer}.chat-input-container button:disabled{opacity:.4;cursor:not-allowed}.hex-builds-list{display:flex;flex-direction:column;gap:12px}.hex-build-card{background:#161b22;border:1px solid #21262d;border-radius:12px;padding:14px 16px}.hex-build-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.hex-rating{font-weight:800;font-size:1.1rem;min-width:28px}.hex-build-name{font-weight:600;font-size:.95rem;color:#e6edf3}.hex-runes-row,.hex-items-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.hex-label{font-size:.75rem;color:#8b949e;min-width:32px;flex-shrink:0}.hex-runes{display:flex;gap:6px;flex-wrap:wrap}.hex-playstyle{font-size:.8rem;color:#8b949e;margin-top:4px;line-height:1.4}.augment-icon-wrap{display:flex;flex-direction:column;align-items:center;gap:2px;border:2px solid #30363d;border-radius:10px;padding:4px 6px;min-width:52px;position:relative;transition:all .2s}.augment-icon-wrap:hover{transform:scale(1.08)}.augment-icon-wrap.optional{opacity:.65;border-style:dashed}.augment-icon{width:32px;height:32px;border-radius:6px;object-fit:contain}.augment-icon.placeholder{width:32px;height:32px;border-radius:6px;background:#21262d;display:flex;align-items:center;justify-content:center;font-size:.6rem;color:#8b949e}.augment-name{font-size:.6rem;color:#c9d1d9;text-align:center;max-width:56px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.augment-tier-dot{position:absolute;top:3px;right:3px;width:6px;height:6px;border-radius:50%}.items-row.compact .item-icon-wrap{gap:1px}.items-row.compact .item-icon{width:28px;height:28px}.items-row.compact .item-name{font-size:.55rem}.item-icon-wrap.small{gap:1px}.item-icon-wrap.small .item-icon{width:28px;height:28px}.item-icon-wrap.small .item-name{font-size:.6rem;max-width:48px}.item-icon.placeholder{width:32px;height:32px;border-radius:8px;background:#21262d;display:flex;align-items:center;justify-content:center;font-size:.65rem;color:#8b949e}.voice-btn{width:40px;height:40px;border-radius:50%;border:none;background:transparent;color:#8b949e;font-size:1.2rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.voice-btn:hover{background:#21262d;color:#e6edf3}.voice-btn.listening{background:#f87171;color:#fff;animation:pulse-voice 1.5s ease-in-out infinite}@keyframes pulse-voice{0%,to{box-shadow:0 0 #f8717166}50%{box-shadow:0 0 0 10px #f8717100}}.chat-input-container{display:flex;gap:8px;padding:12px;align-items:center}
