*{box-sizing:border-box;margin:0;padding:0}:root{--primary:#6366f1;--primary-dark:#4f46e5;--primary-light:#818cf8;--secondary:#f59e0b;--dark:#1e1b4b;--dark-light:#312e81;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-500:#6b7280;--gray-700:#374151;--gray-900:#111827;--white:#ffffff;--success:#10b981;--error:#ef4444}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:linear-gradient(135deg,var(--dark) 0,var(--dark-light) 100%);min-height:100vh;color:var(--gray-900)}.navbar{background:rgba(30,27,75,.95);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1rem 2rem;z-index:100;border-bottom:1px solid rgba(255,255,255,.1)}.navbar-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.logo{font-size:1.75rem;font-weight:800;background:linear-gradient(135deg,var(--primary-light),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-decoration:none}.nav-links{display:flex;gap:2rem;list-style:none}.nav-links a{color:var(--gray-200);text-decoration:none;font-weight:500;transition:color .2s}.nav-links a.active,.nav-links a:hover{color:var(--primary-light)}.hero{background:linear-gradient(135deg,var(--dark) 0,var(--dark-light) 100%);padding:4rem 2rem;text-align:center;color:var(--white)}.hero h1{font-size:3rem;font-weight:800;margin-bottom:1rem;background:linear-gradient(135deg,var(--white),var(--primary-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero p{font-size:1.25rem;color:var(--gray-300);max-width:600px;margin:0 auto 2rem}.search-section{background:var(--white);padding:2rem;border-radius:1rem;max-width:900px;margin:-2rem auto 2rem;box-shadow:0 20px 60px rgba(0,0,0,.3);position:relative;z-index:10}.search-bar{display:flex;gap:1rem;margin-bottom:1rem}.search-input{flex:1 1;padding:1rem 1.5rem;border:2px solid var(--gray-200);border-radius:.5rem;font-size:1rem;transition:border-color .2s}.search-input:focus{outline:none;border-color:var(--primary)}.search-btn{padding:1rem 2rem;background:var(--primary);color:var(--white);border:none;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.search-btn:hover{background:var(--primary-dark)}.filters{display:flex;gap:1rem;flex-wrap:wrap}.filter-select{padding:.75rem 1rem;border:2px solid var(--gray-200);border-radius:.5rem;font-size:.9rem;background:var(--white);cursor:pointer;min-width:150px}.filter-select:focus{outline:none;border-color:var(--primary)}.main-content{max-width:1400px;margin:0 auto;padding:2rem}.dj-grid{display:grid;grid-template-columns:repeat(4,280px);grid-gap:1.5rem;gap:1.5rem;margin-top:2rem;justify-content:center}.dj-card-image{height:200px}.dj-card-content{padding:1.25rem}.dj-card-name{font-size:1.15rem;font-weight:700;color:var(--gray-900);margin-bottom:.5rem}.dj-card-location{color:var(--gray-500);font-size:.85rem;align-items:center}.dj-card-genres,.dj-card-location{margin-bottom:1rem;display:flex;gap:.5rem}.dj-card-genres{flex-wrap:wrap}.genre-tag{background:var(--gray-100);color:var(--gray-700);padding:.25rem .75rem;border-radius:1rem;font-size:.8rem;font-weight:500}.dj-card-footer{justify-content:space-between;padding-top:1rem;border-top:1px solid rgba(255,255,255,.2)}.aura-score,.dj-card-footer{display:flex;align-items:center}.aura-score{gap:.5rem}.score-badge{background:linear-gradient(135deg,var(--secondary),#f97316);color:var(--white);padding:.25rem .75rem;border-radius:.5rem;font-weight:700;font-size:1rem}.score-label{font-size:.8rem;color:var(--gray-500)}.review-count{color:var(--gray-300);font-size:.85rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.modal{background:var(--white);border-radius:1rem;max-width:700px;width:100%;max-height:90vh;overflow-y:auto}.modal-header{background:linear-gradient(135deg,var(--primary),var(--primary-dark));padding:2rem;color:var(--white);position:relative}.modal-close{position:absolute;top:1rem;right:1rem;background:rgba(255,255,255,.2);border:none;color:var(--white);width:40px;height:40px;border-radius:50%;font-size:1.5rem;cursor:pointer;transition:background .2s}.modal-close:hover{background:rgba(255,255,255,.3)}.modal-dj-name{font-size:2rem;font-weight:700;margin-bottom:.5rem}.modal-dj-location{opacity:.9}.modal-body{padding:2rem}.modal-section{margin-bottom:1.5rem}.modal-section-title{font-size:.9rem;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.75rem}.modal-genres{display:flex;flex-wrap:wrap;gap:.5rem}.modal-genre-tag{background:var(--primary);color:var(--white);padding:.5rem 1rem;border-radius:2rem;font-size:.9rem;font-weight:500}.modal-bio{color:var(--gray-700);line-height:1.7}.modal-stats{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:1rem;gap:1rem;padding:1.5rem;background:var(--gray-100);border-radius:.75rem}.modal-stat{text-align:center}.modal-stat-value{font-size:1.5rem;font-weight:700;color:var(--primary)}.modal-stat-label{font-size:.8rem;color:var(--gray-500)}.book-btn{width:100%;padding:1rem;background:linear-gradient(135deg,var(--secondary),#f97316);color:var(--white);border:none;border-radius:.5rem;font-size:1.1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.book-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px rgba(245,158,11,.4)}.rankings-container{background:var(--white);border-radius:1rem;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.1)}.rankings-header{background:linear-gradient(135deg,var(--primary),var(--primary-dark));padding:2rem;color:var(--white)}.rankings-title{font-size:1.75rem;font-weight:700}.rankings-list{list-style:none}.ranking-item{display:flex;align-items:center;padding:1.25rem 2rem;border-bottom:1px solid var(--gray-100);transition:background .2s;cursor:pointer}.ranking-item:hover{background:var(--gray-50)}.ranking-position{font-size:1.5rem;font-weight:700;color:var(--primary);width:50px}.ranking-position.gold{color:#fbbf24}.ranking-position.silver{color:#9ca3af}.ranking-position.bronze{color:#d97706}.ranking-info{flex:1 1}.ranking-name{font-weight:600;color:var(--gray-900)}.ranking-location{font-size:.85rem;color:var(--gray-500)}.ranking-score{font-size:1.25rem;font-weight:700;color:var(--secondary)}.page-header{text-align:center;padding:3rem 2rem;color:var(--white)}.page-header h1{font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.page-header p{color:var(--gray-300);font-size:1.1rem}.stats-bar{display:flex;justify-content:center;gap:3rem;padding:1.5rem;background:rgba(255,255,255,.05);border-radius:.75rem;margin-top:1.5rem}.stat-item{text-align:center}.stat-number{font-size:2rem;font-weight:700;color:var(--secondary)}.stat-text{font-size:.9rem;color:var(--gray-300)}.loading{text-align:center;padding:4rem 2rem;color:var(--white)}.loading-spinner{width:50px;height:50px;border:3px solid rgba(255,255,255,.2);border-top:3px solid var(--primary-light);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.empty-state{text-align:center;padding:4rem 2rem;color:var(--gray-500)}.empty-state-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.footer{background:var(--dark);color:var(--gray-400);padding:3rem 2rem;margin-top:4rem;text-align:center}.footer-content{max-width:1200px;margin:0 auto}.footer-logo{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,var(--primary-light),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:1rem}.dj-card{background:var(--white);border-radius:1rem;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.1);transition:transform .3s,box-shadow .3s;cursor:pointer;border:2px solid rgba(255,255,255,.8)}.dj-card:hover{transform:translateY(-5px);box-shadow:0 12px 40px rgba(0,0,0,.15)}.dj-card-image{height:180px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));display:flex;align-items:center;justify-content:center;position:relative}.dj-card-image-placeholder{font-size:4rem;color:rgba(255,255,255,.3)}@media (max-width:768px){.hero h1{font-size:2rem}.filters,.search-bar{flex-direction:column}.filter-select{width:100%}.nav-links{display:none}.dj-grid,.modal-stats{grid-template-columns:1fr}.stats-bar{flex-direction:column;gap:1.5rem}}.user-dropdown-container{position:relative;z-index:1000}.user-dropdown-menu{position:absolute;top:100%;right:0;margin-top:.5rem;min-width:220px;background:#1e293b;border:1px solid rgba(255,255,255,.1);border-radius:.75rem;box-shadow:0 10px 40px rgba(0,0,0,.3);overflow:hidden;z-index:1001}.dropdown-header{padding:1rem;border-bottom:1px solid rgba(255,255,255,.1);background:rgba(15,23,42,.5)}.dropdown-header .user-name{display:block;font-weight:600;color:white;font-size:.95rem;margin-bottom:.125rem}.dropdown-header .user-email{display:block;font-size:.75rem;color:rgba(255,255,255,.5);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rankings-tab-active{background:linear-gradient(135deg,#6366f1,#8b5cf6)!important;color:white!important}.rankings-tab-inactive{background:#e5e7eb!important;color:#374151!important}.rankings-tab-inactive:hover{background:#d1d5db!important}.rank-gold{background:linear-gradient(135deg,#FFD700,#FFA500);color:#000;box-shadow:0 2px 4px rgba(255,215,0,.3)}.rank-silver{background:linear-gradient(135deg,#C0C0C0,#A8A8A8);color:#000;box-shadow:0 2px 4px rgba(192,192,192,.3)}.rank-bronze{background:linear-gradient(135deg,#CD7F32,#B87333);color:#fff;box-shadow:0 2px 4px rgba(205,127,50,.3)}.ranking-item{transition:background-color .2s ease,transform .1s ease}.ranking-item:hover{background-color:#f9fafb}.ranking-item:active{transform:scale(.995)}.aura-score-badge{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:white;padding:.5rem 1rem;border-radius:8px;font-weight:700;font-size:1.1rem;min-width:60px;text-align:center;transition:transform .2s ease}.aura-score-badge:hover{transform:scale(1.05)}.aura-score-na{background:#e5e7eb;color:#9ca3af}.review-count-badge{display:inline-flex;align-items:center;gap:.375rem;background:#f3f4f6;padding:.375rem .75rem;border-radius:9999px;font-size:.875rem;color:#4b5563}.rankings-search:focus{border-color:#6366f1!important;box-shadow:0 0 0 3px rgba(99,102,241,.1);outline:none}.rankings-filter-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem}.rankings-filter-select:focus{border-color:#6366f1;box-shadow:0 0 0 3px rgba(99,102,241,.1);outline:none}.rankings-empty-state{padding:4rem;text-align:center;color:#6b7280}.rankings-empty-icon{font-size:3rem;margin-bottom:1rem}.rankings-info-box{background:linear-gradient(135deg,#EEF2FF,#E0E7FF);border:1px solid #c7d2fe;border-radius:12px;padding:1.5rem;margin-top:2rem}.rankings-info-title{font-size:1rem;font-weight:600;color:#4338CA;margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.rankings-info-text{font-size:.875rem;color:#4B5563;line-height:1.6;margin:0}@keyframes rankings-spin{to{transform:rotate(1turn)}}.rankings-spinner{width:50px;height:50px;border:4px solid #e5e7eb;border-top-color:#6366f1;border-radius:50%;animation:rankings-spin 1s linear infinite}@media (max-width:768px){.rankings-grid-header,.rankings-grid-item{grid-template-columns:60px 1fr 80px}.rankings-review-col{display:none}.rankings-tabs{flex-direction:column;gap:.5rem}.rankings-tab{width:100%;text-align:center}.rankings-filters{flex-direction:column}.rankings-filter-select,.rankings-search{width:100%}}.ranking-link{text-decoration:none;color:inherit;display:grid;grid-template-columns:80px 1fr 150px 100px;padding:1rem 1.5rem;align-items:center;border-bottom:1px solid #f3f4f6;transition:background .2s}.ranking-link:hover{background:#f9fafb}.ranking-link:focus{outline:2px solid #6366f1;outline-offset:-2px}@media (max-width:768px){.ranking-link{grid-template-columns:50px 1fr 70px;padding:.75rem 1rem}}@keyframes spin{to{transform:rotate(1turn)}}.navbar{background-color:#1e1b4b;position:-webkit-sticky;position:sticky;top:0;z-index:1000;box-shadow:0 2px 4px rgba(0,0,0,.1);width:100%}.navbar-container{max-width:1280px;margin:0 auto;padding:0 1.5rem;justify-content:space-between;height:64px}.navbar-container,.navbar-logo{display:flex;align-items:center}.navbar-logo{text-decoration:none;z-index:1001}.navbar-logo svg{width:240px;height:60px}.navbar-links{display:flex;align-items:center;gap:2rem}.navbar-link{color:white;text-decoration:none;font-size:.95rem;font-weight:500;transition:color .2s ease}.navbar-link:hover{color:#a5b4fc}.navbar-auth{display:flex;align-items:center;gap:1rem}.btn-login{color:white;background:none;border:1px solid rgba(255,255,255,.3);padding:.5rem 1rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;text-decoration:none;transition:all .2s ease}.btn-login:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.5)}.btn-signup{color:white;background:linear-gradient(90deg,#7c3aed,#6d28d9);border:none;padding:.5rem 1rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;text-decoration:none;transition:all .2s ease}.btn-signup:hover{background:linear-gradient(90deg,#8b5cf6,#7c3aed)}.hamburger-btn{display:none;flex-direction:column;justify-content:space-around;width:28px;height:24px;background:transparent;border:none;cursor:pointer;padding:0;z-index:1001}.hamburger-btn span{width:100%;height:3px;background-color:white;border-radius:2px;transition:all .3s ease}.hamburger-btn.open span:first-child{transform:rotate(45deg) translate(6px,6px)}.hamburger-btn.open span:nth-child(2){opacity:0}.hamburger-btn.open span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}.mobile-menu-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:998}.mobile-menu-overlay.open{display:block}.mobile-menu{display:none;position:fixed;top:0;right:-100%;width:280px;height:100vh;background:#1e1b4b;z-index:999;padding:80px 1.5rem 2rem;transition:right .3s ease;overflow-y:auto;-webkit-overflow-scrolling:touch;box-shadow:-4px 0 20px rgba(0,0,0,.3)}.mobile-menu.open{right:0}.mobile-menu-links{display:flex;flex-direction:column;gap:.75rem;padding:1.5rem 1.5rem 1rem}.mobile-menu-link{color:white;text-decoration:none;font-size:1rem;font-weight:500;padding:1rem 1.5rem;border-radius:1rem;transition:all .3s ease;display:flex;align-items:center;gap:.875rem;background:rgba(139,92,246,.08);border:1px solid rgba(139,92,246,.2)}.mobile-menu-link:active,.mobile-menu-link:hover{background:linear-gradient(135deg,rgba(139,92,246,.15),rgba(236,72,153,.15));border-color:rgba(139,92,246,.4);transform:translateX(4px)}.mobile-menu-link svg{width:20px;height:20px;opacity:.9;flex-shrink:0}.mobile-menu-divider{height:1px;background:rgba(255,255,255,.1);margin:1rem 0}.mobile-menu-auth{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.mobile-btn-login{color:white;background:transparent;border:1px solid rgba(255,255,255,.3);padding:.875rem 1rem;border-radius:.5rem;font-size:1rem;font-weight:500;text-align:center;text-decoration:none;transition:all .2s ease}.mobile-btn-login:hover{background:rgba(255,255,255,.1)}.mobile-btn-signup{color:white;background:linear-gradient(90deg,#7c3aed,#6d28d9);border:none;padding:.875rem 1rem;border-radius:.5rem;font-size:1rem;font-weight:500;text-align:center;text-decoration:none;transition:all .2s ease}.mobile-btn-signup:hover{background:linear-gradient(90deg,#8b5cf6,#7c3aed)}.mobile-user-section{padding:0;margin-bottom:1rem}.mobile-user-name{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:linear-gradient(135deg,rgba(139,92,246,.15),rgba(236,72,153,.12));border:1px solid rgba(139,92,246,.3);border-radius:.875rem;color:white;font-size:1rem;font-weight:600;margin-bottom:.5rem}.mobile-user-name svg{width:20px;height:20px;opacity:.9}.mobile-user-links{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem;border-top:1px solid rgba(255,255,255,.1);padding:1rem 0 1.5rem;max-height:calc(100vh - 400px);overflow-y:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.mobile-user-links::-webkit-scrollbar{display:none}.mobile-user-link{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.25rem;background:transparent;border:1px solid rgba(255,255,255,.08);border-radius:.875rem;color:rgba(255,255,255,.9);font-size:.95rem;font-weight:500;text-decoration:none;cursor:pointer;transition:all .25s ease}.mobile-user-link:hover{background:rgba(139,92,246,.1);border-color:rgba(139,92,246,.3);color:white;transform:translateX(3px)}.mobile-user-link:active{transform:translateX(3px) scale(.98)}.mobile-user-link svg{width:18px;height:18px;opacity:.8;flex-shrink:0}.mobile-user-link.logout{margin-top:.5rem;border-color:rgba(239,68,68,.2);color:#ef4444}.mobile-user-link.logout:hover{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.4);color:#ef4444}@media (max-width:968px){.desktop-nav-links{display:none!important}.hamburger-btn{display:flex}.mobile-menu{display:block}.navbar-logo svg{width:180px;height:45px}}@media (max-width:480px){.navbar-container{padding:0 1rem;height:56px}.navbar-logo svg{width:150px;height:38px}.mobile-menu{width:100%;right:-100%}.mobile-menu.open{right:0}}@media (min-width:969px){.hamburger-btn,.mobile-menu,.mobile-menu-overlay{display:none!important}.desktop-nav-links{display:flex!important}}body.mobile-menu-open{overflow:hidden}.mobile-menu::-webkit-scrollbar{width:6px}.mobile-menu::-webkit-scrollbar-track{background:rgba(255,255,255,.05)}.mobile-menu::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:3px}.mobile-menu::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.3)}