:root{--bg-color:#0b0710;--surface-color:#1a1025;--surface-hover:#2a1b38;--primary-color:#9d4edd;--primary-hover:#7b2cbf;--accent-color:#e0aaff;--text-main:#f8f9fa;--text-muted:#adb5bd;--glow-color:rgba(157,78,221,0.5);--border-radius:16px;--transition:all 0.3s cubic-bezier(0.25,0.8,0.25,1)}*{box-sizing:border-box;margin:0;padding:0;font-family:Segoe UI,Roboto,Helvetica,Arial,sans-serif}body{background-color:var(--bg-color);color:var(--text-main);min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden;background-image:radial-gradient(circle at 15% 50%,rgba(157,78,221,.08),transparent 25%),radial-gradient(circle at 85% 30%,rgba(224,170,255,.05),transparent 25%)}h1,h2,h3{font-weight:700;letter-spacing:.5px}h1{font-size:2.5rem;text-align:center;margin-bottom:.5rem;background:linear-gradient(to right,var(--accent-color),var(--primary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 0 20px rgba(157,78,221,.3)}p.subtitle{text-align:center;color:var(--text-muted);margin-bottom:2rem}header{padding:1.5rem;align-items:center;border-bottom:1px solid rgba(255,255,255,.05);background:rgba(26,16,37,.8);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:sticky;top:0;z-index:100}header,nav{display:flex;justify-content:center}nav{gap:1rem;flex-wrap:wrap}.nav-btn{background:transparent;color:var(--text-muted);border:none;padding:.5rem 1rem;border-radius:20px;cursor:pointer;font-weight:600;transition:var(--transition);text-decoration:none}.nav-btn.active,.nav-btn:hover{color:var(--text-main);background:rgba(157,78,221,.2);box-shadow:0 0 10px rgba(157,78,221,.2)}main{flex:1 1;padding:2rem;max-width:1200px;margin:0 auto;width:100%}.spin-container{flex-direction:column;margin-bottom:3rem}.spin-btn,.spin-container{display:flex;align-items:center}.spin-btn{background:linear-gradient(135deg,var(--primary-color),#5a189a);color:white;border:none;border-radius:50px;padding:1.2rem 3rem;font-size:1.5rem;font-weight:700;cursor:pointer;box-shadow:0 0 20px var(--glow-color);transition:var(--transition);position:relative;overflow:hidden;gap:10px}.spin-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:.5s}.spin-btn:hover{transform:scale(1.05) translateY(-2px);box-shadow:0 0 30px var(--glow-color),0 0 10px var(--accent-color)}.spin-btn:hover:before{left:100%}.spin-btn:active{transform:scale(.98)}.spin-btn.spinning{animation:pulse-glow 1s infinite alternate,spin-shake .5s infinite;pointer-events:none}@keyframes pulse-glow{0%{box-shadow:0 0 20px var(--glow-color)}to{box-shadow:0 0 40px var(--accent-color),0 0 20px var(--primary-color)}}@keyframes spin-shake{0%{transform:translate(1px,1px) rotate(0deg)}25%{transform:translate(-1px,-2px) rotate(-1deg)}50%{transform:translate(-3px) rotate(1deg)}75%{transform:translate(3px,2px) rotate(0deg)}to{transform:translate(1px,-1px) rotate(-1deg)}}.add-form,.card,.filters-section{background:var(--surface-color);border-radius:var(--border-radius);padding:2rem;box-shadow:0 10px 30px rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.05)}.filter-group{margin-bottom:1.5rem}.filter-group h3{margin-bottom:.8rem;font-size:1.1rem;color:var(--accent-color);display:flex;align-items:center;gap:8px}.chip-container{display:flex;flex-wrap:wrap;gap:.6rem}.chip{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);color:var(--text-muted);padding:.5rem 1rem;border-radius:20px;cursor:pointer;font-size:.9rem;transition:var(--transition);-webkit-user-select:none;user-select:none}.chip:hover{background:rgba(255,255,255,.1);color:var(--text-main)}.chip.selected{background:rgba(157,78,221,.3);border-color:var(--primary-color);color:var(--accent-color);box-shadow:0 0 10px rgba(157,78,221,.2)}.results-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:2rem}.card{padding:1.5rem;position:relative;display:flex;flex-direction:column;overflow:hidden}.card,.card:before{transition:var(--transition)}.card:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,var(--primary-color),var(--accent-color));opacity:0}.card:hover{transform:translateY(-5px);box-shadow:0 15px 30px rgba(0,0,0,.6),0 0 15px rgba(157,78,221,.2);border-color:rgba(157,78,221,.3)}.card:hover:before{opacity:1}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.card-title{font-size:1.4rem;color:var(--text-main);margin-right:1rem}.fav-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1.5rem;transition:var(--transition)}.fav-btn:hover{color:#ff4d6d;transform:scale(1.1)}.fav-btn.favorited{color:#ff4d6d;text-shadow:0 0 10px rgba(255,77,109,.5)}.card-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1rem}.card-tag{background:rgba(0,0,0,.3);color:var(--accent-color);font-size:.75rem;padding:.2rem .6rem;border-radius:12px;border:1px solid rgba(157,78,221,.3)}.card-desc{color:var(--text-muted);font-size:.95rem;line-height:1.5;flex-grow:1;margin-bottom:1.5rem}.card-link{display:inline-block;background:rgba(157,78,221,.1);color:var(--accent-color);text-decoration:none;padding:.6rem 1rem;border-radius:8px;text-align:center;font-weight:600;border:1px solid rgba(157,78,221,.3);transition:var(--transition)}.card-link:hover{background:var(--primary-color);color:white;box-shadow:0 0 15px var(--glow-color)}.action-container{display:flex;justify-content:center;gap:1rem;margin-top:2rem}.btn{padding:.8rem 1.5rem;border-radius:8px;border:none;font-weight:600;cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;gap:8px;text-decoration:none}.btn-primary{background:var(--primary-color);color:white}.btn-primary:hover{background:var(--primary-hover);box-shadow:0 0 15px var(--glow-color)}.btn-secondary{background:rgba(255,255,255,.1);color:var(--text-main)}.btn-secondary:hover{background:rgba(255,255,255,.2)}.btn-danger{background:#d90429;color:white}.btn-danger:hover{background:#ef233c;box-shadow:0 0 15px rgba(239,35,60,.5)}.add-form{max-width:600px;margin:0 auto}.form-group{margin-bottom:1.2rem;display:flex;flex-direction:column}.form-group label{margin-bottom:.5rem;color:var(--accent-color);font-weight:600}.form-control{width:100%;padding:.8rem;background:rgba(0,0,0,.2);border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--text-main);transition:var(--transition)}.form-control:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 10px rgba(157,78,221,.2)}select.form-control[multiple]{height:100px}.empty-state{text-align:center;padding:3rem;color:var(--text-muted);font-style:italic}@media (max-width:768px){h1{font-size:2rem}.results-grid{grid-template-columns:1fr}.nav-btn{padding:.4rem .8rem;font-size:.9rem}}.table{width:100%;border-collapse:collapse;margin-top:1rem}.table td,.table th{padding:1rem;text-align:left;border-bottom:1px solid rgba(255,255,255,.05)}.table th{color:var(--accent-color);font-weight:600}.flex-between{display:flex;justify-content:space-between;align-items:center}.card-action-btn{background:none;border:none;cursor:pointer;font-size:1.1rem;transition:var(--transition);opacity:.6;display:inline-flex;align-items:center;justify-content:center}.card-action-btn:hover{opacity:1;transform:scale(1.2)}.card-action-btn.edit:hover{filter:drop-shadow(0 0 5px var(--accent-color))}.card-action-btn.delete:hover{filter:drop-shadow(0 0 5px #ff4d6d)}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(11,7,16,.75);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:flex;justify-content:center;align-items:center}.modal-content{background:var(--surface-color);border-radius:var(--border-radius);padding:2.5rem;max-width:650px;width:90%;max-height:85vh;overflow-y:auto;box-shadow:0 20px 50px rgba(0,0,0,.8),0 0 30px rgba(157,78,221,.25);border:1px solid rgba(157,78,221,.3);animation:modal-fadeIn .3s ease-out}@keyframes modal-fadeIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;border-bottom:1px solid rgba(255,255,255,.05);padding-bottom:.8rem}.modal-header h2{font-size:1.6rem;background:linear-gradient(to right,var(--accent-color),var(--primary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.close-btn{background:none;border:none;color:var(--text-muted);font-size:2rem;cursor:pointer;line-height:1;transition:var(--transition)}.close-btn:hover{color:var(--text-main);transform:scale(1.1)}.card-attributes-groups{margin-bottom:1rem;display:flex;flex-direction:column;gap:.8rem}.attribute-category-name{font-size:.75rem;color:var(--accent-color);font-weight:600;margin-bottom:.3rem;text-transform:uppercase;letter-spacing:.5px;opacity:.9}.card-tag.highlight-match{background:rgba(255,215,0,.12)!important;border-color:#ffd700!important;color:#ffd700!important;box-shadow:0 0 10px rgba(255,215,0,.35);text-shadow:0 0 5px rgba(255,215,0,.2);font-weight:600;animation:tag-pulse 2s ease-in-out infinite alternate}.match-sparkle{color:#ffd700;font-size:.8rem;animation:sparkle-glow 1.5s ease-in-out infinite alternate}@keyframes tag-pulse{0%{box-shadow:0 0 6px rgba(255,215,0,.25);border-color:rgba(255,215,0,.7)}to{box-shadow:0 0 14px rgba(255,215,0,.55);border-color:rgba(255,215,0,1)}}@keyframes sparkle-glow{0%{opacity:.7;transform:scale(.9)}to{opacity:1;transform:scale(1.1)}}.card-result-badge{align-self:flex-start;background:linear-gradient(135deg,#ffd700,#ff007f);color:#0b0710;font-size:.7rem;font-weight:800;text-transform:uppercase;padding:.25rem .6rem;border-radius:4px;margin-bottom:.8rem;letter-spacing:1px;box-shadow:0 0 10px rgba(255,215,0,.4);display:inline-flex;align-items:center;gap:4px;animation:pulse-badge 2s ease-in-out infinite alternate}@keyframes pulse-badge{0%{transform:scale(1);box-shadow:0 0 5px rgba(255,215,0,.3)}to{transform:scale(1.03);box-shadow:0 0 15px rgba(255,215,0,.6),0 0 10px rgba(255,0,127,.4)}}.card.is-result{animation:card-appear .6s cubic-bezier(.175,.885,.32,1.15) both;border-color:rgba(255,215,0,.2)}@keyframes card-appear{0%{opacity:0;transform:translateY(24px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}