*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.6;color:#333;background:#f5f5f5;min-height:100vh;padding:20px}#app{max-width:1200px;margin:0 auto;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}header{background:#1b2838;color:#fff;padding:30px;text-align:center}header h1{font-size:2em;margin-bottom:10px;color:#fff}header p{color:#ffffffd9;font-size:1em;margin-bottom:20px}.header-actions{display:flex;gap:15px;align-items:center;justify-content:center;flex-wrap:wrap}.steam-login-button{background:none;border:none;padding:0;cursor:pointer;transition:transform .2s}.steam-login-button:hover{transform:scale(1.05);box-shadow:none}.steam-login-button img{display:block;height:35px}.user-info{display:flex;align-items:center;gap:12px;background:#ffffff1a;padding:8px 16px;border-radius:6px;border:1px solid rgba(255,255,255,.2)}.user-avatar{width:32px;height:32px;border-radius:4px;border:2px solid rgba(255,255,255,.2)}.user-name{color:#fff;font-weight:500;font-size:14px}.logout-button{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:6px 12px;font-size:13px;border-radius:4px;cursor:pointer}.logout-button:hover{background:#fff3;box-shadow:none;transform:none}.demo-button{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:8px 16px;font-size:14px;border-radius:4px;cursor:pointer}.demo-button:hover{background:#fff3;box-shadow:none}main{padding:24px}.import-section,.results-section{margin-bottom:24px;padding:18px;background:#f7f9fc;border-radius:6px;border:1px solid #e1e8ed}h2{color:#1b2838;margin-bottom:10px;font-size:1.1em;font-weight:600}p{margin-bottom:12px;color:#666;font-size:.9em}.help-section{margin-bottom:15px;border:2px solid #e1e8ed;border-radius:6px;background:#fff}.help-section summary{cursor:pointer;padding:12px 15px;font-weight:600;color:#2a475e;-webkit-user-select:none;user-select:none;list-style:none;display:flex;align-items:center}.help-section summary::-webkit-details-marker{display:none}.help-section summary:before{content:"▶";margin-right:10px;transition:transform .2s;display:inline-block}.help-section[open] summary:before{transform:rotate(90deg)}.help-section summary:hover{background:#f7f9fc}.help-content{padding:5px;border-top:1px solid #e1e8ed}.help-content ol{margin-left:20px;line-height:1.8}.help-content li{margin-bottom:10px}.help-content code{background:#1b2838;color:#66c0f4;padding:2px 6px;border-radius:3px;font-family:Courier New,monospace;font-size:13px}.code-block{display:block;margin:10px 0;padding:12px;background:#1b2838;color:#66c0f4;border-radius:6px;overflow-x:auto;word-break:break-all;white-space:pre-wrap;font-size:10px;line-height:1.4;max-height:120px;overflow-y:auto;font-family:Monaco,Menlo,Ubuntu Mono,Consolas,Courier New,monospace}.friends-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;margin-top:15px;margin-bottom:20px;max-height:400px;overflow-y:auto;padding:12px;border:1px solid #e1e8ed;border-radius:6px;background:#fff}.friend-item{display:flex;align-items:center;gap:8px;padding:10px;background:#fff;border:2px solid #e1e8ed;border-radius:8px;transition:border-color .2s;min-width:0}.friend-avatar-container{position:relative;flex-shrink:0;width:32px;height:32px}.friend-avatar{width:32px;height:32px;border-radius:50%;border:2px solid #e1e8ed;flex-shrink:0}.friend-item .friend-name{flex:1;font-weight:500;color:#2a475e;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.friend-game-badge{position:absolute;bottom:-5px;right:-10px;display:inline-flex;align-items:center;justify-content:center;background:#4caf50;color:#fff;font-size:10px;font-weight:600;padding:2px;border-radius:10px;min-width:20px;box-shadow:0 1px 3px #0000004d;border:2px solid white}.fetch-friend-wishlist,.import-friend-wishlist{background:#1b2838;color:#fff;border:none;padding:6px 10px;border-radius:6px;font-size:11px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .2s;flex-shrink:0;display:flex;align-items:center;justify-content:center}.import-friend-wishlist{font-size:14px;padding:6px 8px;min-width:32px}.fetch-friend-wishlist:hover,.import-friend-wishlist:hover{background:#2a475e}.fetch-friend-wishlist:disabled{opacity:.6;cursor:not-allowed}.fetch-friend-wishlist:disabled:hover{background:#1b2838}.fetch-friend-wishlist.update{background:#6b8ba4}.fetch-friend-wishlist.update:hover{background:#7a9bb5}textarea{width:100%;min-height:150px;padding:15px;border:2px solid #ddd;border-radius:6px;font-family:Courier New,monospace;font-size:14px;resize:vertical;margin-bottom:15px;transition:border-color .3s}textarea:focus{outline:none;border-color:#1b2838}.match-buttons{display:flex;gap:12px;margin-bottom:20px}button{background:#1b2838;color:#fff;border:none;padding:10px 20px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}button:hover{background:#2a475e}button:disabled{opacity:.5;cursor:not-allowed}button:disabled:hover{background:#1b2838}#findFuzzyMatches{background:#5c7a99}#findFuzzyMatches:hover{background:#6d8aaa}#findFuzzyMatches:disabled:hover{background:#5c7a99}#gamesCount,#wishlistCount{margin-top:15px;padding:10px;background:#fff;border-radius:6px;font-weight:600;color:#1b2838}#results{margin-top:20px}.match-group{background:#fff;padding:14px;margin-bottom:12px;border-radius:6px;border-left:3px solid #1b2838;box-shadow:0 1px 4px #00000014}.match-group .friend-name{font-size:1em;font-weight:600;color:#1b2838;margin-bottom:8px}.game-match{padding:8px 10px;margin:6px 0;background:#f0f4f8;border-radius:4px;display:flex;justify-content:space-between;align-items:center}.game-title-container{display:flex;align-items:center;gap:8px;flex:1}.game-title{font-weight:500;color:#2a475e;font-size:.9em}.match-badge{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;font-size:12px;font-weight:600;cursor:help;transition:transform .2s}.match-badge:hover{transform:scale(1.2)}.match-badge-exact{background:#4caf50;color:#fff}.match-badge-fuzzy{background:#ff9800;color:#fff}.match-info-text{font-size:.85em;color:#666;font-style:italic;margin-left:4px}.key-container{display:flex;align-items:center;gap:6px;margin-left:12px}.game-key{font-family:Courier New,monospace;background:#1b2838;color:#66c0f4;padding:4px 8px;border-radius:3px;font-size:.85em}.copy-btn{background:#2a475e;color:#66c0f4;border:none;padding:4px 6px;border-radius:3px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;min-width:28px;height:28px}.copy-btn:hover{background:#3a5770}.copy-btn.copied{background:#4caf50;color:#fff}.copy-btn.copied:after{content:"✓";position:absolute;font-size:11px}.no-matches{text-align:center;padding:40px;color:#999;font-style:italic}.match-count{display:inline-block;background:#1b2838;color:#fff;padding:2px 8px;border-radius:10px;font-size:.85em;margin-left:8px}.humble-auth-form{display:flex;gap:10px;margin:15px 0;align-items:center}.humble-auth-form input{flex:1;padding:10px 12px;border:2px solid #e1e8ed;border-radius:6px;font-size:14px;font-family:Courier New,monospace}.humble-auth-form input:focus{outline:none;border-color:#ff6b6b}.humble-button{background:#1b2838;color:#fff;border:none;padding:10px 20px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap}.humble-button:hover{background:#2a475e}.humble-button:disabled{opacity:.6;cursor:not-allowed}.humble-button-secondary{background:#666;color:#fff;padding:8px 16px;border-radius:6px;font-size:13px;cursor:pointer;transition:background .2s}.humble-button-secondary:hover{background:#555}.status-message{margin:15px 0;font-weight:600;color:#2a475e}.status-success{color:#4caf50;font-weight:700}.status-error{color:#f44336;font-weight:700}.help-note{font-size:13px;color:#666;font-style:italic;margin-top:10px}.help-content a{color:#c00;text-decoration:none;font-weight:600}.help-content a:hover{text-decoration:underline}#humbleKeysStatus{margin-top:15px;padding:5px;border-radius:6px;font-size:14px}#humbleKeysStatus.success{background:#e8f5e9;color:#2e7d32;border:1px solid #4caf50}#humbleKeysStatus.error{background:#ffebee;color:#c62828;border:1px solid #f44336}#humbleKeysStatus.loading{background:#e3f2fd;color:#1565c0;border:1px solid #2196f3}
