:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#0a0a0a;color:#fafafa;min-height:100vh}.app{max-width:900px;margin:0 auto;padding:2rem}header{text-align:center;margin-bottom:3rem}header h1{font-size:2.5rem;margin-bottom:.5rem;background:linear-gradient(135deg,#646cff,#9d4edd);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}header p{color:#888;font-size:1.1rem}.recommendation-form form{display:flex;flex-direction:column;gap:.75rem}.recommendation-form label{font-size:1rem;color:#ccc}.input-group{display:flex;gap:.75rem}.recommendation-form input{flex:1;padding:1rem;font-size:1rem;border:1px solid #333;border-radius:8px;background:#1a1a1a;color:#fafafa;outline:none;transition:border-color .2s}.recommendation-form input:focus{border-color:#646cff}.recommendation-form input::placeholder{color:#666}.recommendation-form button{padding:1rem 2rem;font-size:1rem;font-weight:600;border:none;border-radius:8px;background:#646cff;color:#fff;cursor:pointer;transition:background .2s;white-space:nowrap}.recommendation-form button:hover:not(:disabled){background:#535bf2}.recommendation-form button:disabled{opacity:.6;cursor:not-allowed}.error{padding:1rem;background:#3a1a1a;border:1px solid #662222;border-radius:8px;color:#ff6b6b;margin-top:1rem}.loading{display:flex;flex-direction:column;align-items:center;padding:3rem;color:#888}.spinner{width:40px;height:40px;border:3px solid #333;border-top-color:#646cff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.hint{text-align:center;color:#666;margin-top:2rem}.concert-list{margin-top:2rem}.results-header{margin-bottom:1.5rem}.results-header h2{font-size:1.5rem;margin-bottom:.5rem}.results-summary{color:#888;font-size:.95rem}.searched-adjectives{color:#646cff;font-weight:500}.concerts{display:flex;flex-direction:column;gap:1rem}.concert-card{display:flex;gap:1rem;padding:1.25rem;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:12px;transition:border-color .2s,transform .2s}.concert-card:hover{border-color:#3a3a3a;transform:translate(4px)}.concert-rank{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:#252525;border-radius:8px;font-size:1.1rem;font-weight:700;color:#646cff;flex-shrink:0}.concert-image{width:80px;height:80px;flex-shrink:0;border-radius:8px;overflow:hidden;background:#252525}.concert-image img{width:100%;height:100%;object-fit:cover}.concert-image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#555}.concert-image-placeholder svg{width:36px;height:36px}.concert-details{flex:1;min-width:0}.concert-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.5rem}.concert-title{font-size:1.1rem;font-weight:600;margin:0;color:#fafafa}.concert-title a{color:inherit;text-decoration:none;transition:color .2s}.concert-title a:hover{color:#646cff;text-decoration:underline}.concert-match{display:flex;flex-direction:column;align-items:flex-end;flex-shrink:0}.match-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:#666}.match-value{font-size:1.25rem;font-weight:700;color:#646cff}.concert-meta{display:flex;flex-wrap:wrap;gap:1rem;color:#888;font-size:.9rem}.concert-meta span{display:flex;align-items:center;gap:.4rem}.icon{width:16px;height:16px}.no-results{text-align:center;padding:3rem 1rem;color:#888}.no-results p:first-child{font-size:1.1rem;margin-bottom:.5rem}@media(max-width:600px){.input-group{flex-direction:column}.concert-image{width:60px;height:60px}.concert-image-placeholder svg{width:28px;height:28px}.concert-header{flex-direction:column;gap:.5rem}.concert-match{flex-direction:row;align-items:center;gap:.5rem}.match-value{font-size:1rem}}
