:root{--bg-color:#121212;--surface-color:#1e1e1e;--surface-hover-color:#2a2a2a;--text-primary-color:#e0e0e0;--text-secondary-color:#a0a0a0;--border-color:#333;--border-focus-color:#4f4f4f;--accent-color:#a3e635;--accent-hover-color:#bef264;--accent-text-color-on-accent-bg:#121212;--accent-color-rgb:163,230,53;--my-score-color:#a3e635;--friend-score-color:#4caf50;--average-score-color:#555a5e;--danger-color:#ff4d4d;--success-color:var(--accent-color);--font-family-heading:"Montserrat",sans-serif;--font-family-main:"Roboto",sans-serif;--border-radius:4px;--padding-small:0.5rem;--padding-base:1rem;--padding-large:1.5rem;--margin-base:1rem;--header-height:60px;--transition-speed:0.2s;--transition-ease:ease-in-out;--shadow-color-soft:rgba(0,0,0,.3);--surface-hover-color-rgb:42,42,42}*{box-sizing:border-box;margin:0;padding:0}body{color:var(--text-primary-color);font-family:var(--font-family-main);font-weight:400;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#050505;display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden;padding-top:var(--header-height-new);position:relative}body.modal-open{perspective:none}@keyframes grid-scroll{0%{background-position:0 0}to{background-position:0 400px}}body:before{animation:grid-scroll 8s linear infinite;background-image:linear-gradient(90deg,rgba(163,230,53,.2) 1px,transparent 0),linear-gradient(180deg,rgba(163,230,53,.2) 1px,transparent 0);background-size:50px 50px;content:"";height:100%;left:0;mask-image:linear-gradient(0deg,transparent,#000 50%);-webkit-mask-image:linear-gradient(0deg,transparent,#000 50%);position:fixed;top:0;transform:rotateX(70deg);transform-origin:50% 100%;width:100%;z-index:-1}h1,h2,h3,h4,h5,h6{color:var(--text-primary-color);font-family:var(--font-family-heading);font-weight:700;line-height:1.3;margin-bottom:var(--margin-base)}h1{font-size:2.2rem;font-weight:800;letter-spacing:-.03em}h2{font-size:1.7rem}h3{font-size:1.4rem}h4{color:var(--text-secondary-color);font-size:1.1rem;font-weight:600;margin-bottom:var(--padding-small)}a{color:var(--accent-color);text-decoration:none;transition:color var(--transition-speed) var(--transition-ease)}a:hover{color:var(--accent-hover-color)}main:not(.landing-main-v2){margin:var(--margin-base) auto;max-width:1200px;padding:var(--padding-large);width:100%}main.landing-main-v2{margin:0;padding:0;width:100%}main{flex-grow:1}header{background:var(--bg-color);border-bottom:1px solid var(--border-color);height:var(--header-height);justify-content:space-between;left:0;padding:0 var(--padding-large);position:fixed;top:0;width:100%;z-index:1000}header,header nav{align-items:center;display:flex}header nav{color:var(--text-secondary-color);font-size:.9rem;font-weight:600;gap:1.5rem;letter-spacing:.05em;margin-left:var(--margin-base);text-transform:uppercase}header .logo a,header nav{font-family:var(--font-family-heading)}header .logo a{color:var(--text-primary-color);font-size:1.6em;font-weight:800;letter-spacing:-.04em}header .logo a:hover{color:var(--accent-color)}header nav a{border-radius:var(--border-radius);color:var(--text-secondary-color);font-family:var(--font-family-heading);font-size:.9rem;font-weight:600;letter-spacing:.05em;margin-left:var(--margin-base);padding:var(--padding-small) var(--padding-base);text-transform:uppercase;transition:background-color var(--transition-speed) var(--transition-ease),color var(--transition-speed) var(--transition-ease)}header nav a.active,header nav a:hover{color:var(--accent-color)}.language-switcher{align-items:center;display:flex;gap:.5rem;margin-left:auto}.button,button{background-color:transparent;border:2px solid var(--accent-color);border-radius:var(--border-radius);color:var(--accent-color);cursor:pointer;display:inline-block;font-family:var(--font-family-heading);font-size:.9rem;font-weight:700;letter-spacing:.05em;padding:.7rem 1.3rem;text-align:center;text-decoration:none;text-transform:uppercase;transition:all var(--transition-speed) var(--transition-ease)}.button:hover,button:hover{background-color:var(--accent-color);border-color:var(--accent-color);color:var(--accent-text-color-on-accent-bg)}.button:active,button:active{transform:scale(.98)}.button-primary{background-color:var(--accent-color);color:var(--accent-text-color-on-accent-bg)}.button-primary:hover{background-color:var(--accent-hover-color);border-color:var(--accent-hover-color)}.button-edit{color:var(--text-secondary-color)}.button-edit,.button-edit:hover{border-color:var(--text-secondary-color)}.button-edit:hover{background-color:var(--text-secondary-color);color:var(--bg-color)}.button-delete{border-color:var(--danger-color);color:var(--danger-color)}.button-delete:hover{background-color:var(--danger-color);border-color:var(--danger-color);color:var(--text-primary-color)}.button:disabled,button:disabled{background-color:transparent!important;border-color:var(--text-secondary-color)!important;color:var(--text-secondary-color)!important;cursor:not-allowed;opacity:.5}.score-circle{align-items:center;border-radius:50%;box-shadow:0 1px 3px rgba(0,0,0,.2);cursor:default;display:flex;font-family:var(--font-family-heading);font-size:1.2em;font-weight:700;height:60px;justify-content:center;position:relative;transition:transform .2s ease-in-out,box-shadow .2s ease-in-out;width:60px}.score-circle:not(.perfect-score-circle):hover{box-shadow:0 3px 7px rgba(0,0,0,.3);transform:scale(1.1)}.my-score-circle{background-color:var(--my-score-color);color:var(--accent-text-color-on-accent-bg)}@keyframes spin-gradient{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.friend-score-circle{background-color:var(--friend-score-color);color:var(--accent-text-color-on-accent-bg)}.footer-column-title{color:var(--accent-color);font-family:var(--font-family-heading);font-size:.9rem;font-weight:700;letter-spacing:.1em;margin-bottom:1.25rem;text-shadow:0 0 5px rgba(0,0,0,.5);text-transform:uppercase}.average-score-circle{background-color:var(--average-score-color);color:var(--text-primary-color)}.perfect-score-circle{color:#fff;overflow:hidden;text-shadow:0 0 5px rgba(0,0,0,.5);transform:translateZ(0)}.perfect-score-circle:before{animation:spin-gradient 4s linear infinite;background:conic-gradient(from 90deg,#a3e635,#4dd8ff,#7a4dff,#ff4ddc,#ff4d4d,#ffc700,#a3e635);content:"";height:200%;left:-50%;position:absolute;top:-50%;width:200%;will-change:transform;z-index:-1}.score-circle .tooltip-text{background-color:var(--surface-hover-color);border:1px solid var(--border-color);border-radius:var(--border-radius);bottom:120%;box-shadow:0 4px 12px rgba(0,0,0,.5);color:var(--text-primary-color);left:50%;line-height:1.4;opacity:0;padding:12px;position:absolute;text-align:left;transform:translateX(-50%);transition:opacity .2s ease-in-out,visibility .2s ease-in-out;visibility:hidden;white-space:normal;width:240px;z-index:10}.score-circle .tooltip-text:after{border-color:var(--surface-hover-color) transparent transparent transparent;border-style:solid;border-width:5px;content:"";left:50%;margin-left:-5px;position:absolute;top:100%}.score-circle:hover .tooltip-text{opacity:1;visibility:visible}.gemini-info-section{background-color:var(--bg-color);border:1px solid var(--border-color);border-radius:var(--border-radius);margin-bottom:var(--padding-large);margin-top:var(--padding-large);padding:var(--padding-base)}.gemini-info-section h2{border-bottom:1px solid var(--accent-color);color:var(--accent-color);display:inline-block;font-size:1.4em;padding-bottom:var(--padding-small)}.gemini-info-item,.gemini-info-section h2{margin-bottom:var(--margin-base)}.gemini-info-item:last-child{margin-bottom:0}.gemini-info-item h4{color:var(--text-secondary-color);font-family:var(--font-family-heading);font-size:.95em;font-weight:600;letter-spacing:.03em;margin-bottom:.3rem;text-transform:uppercase}.gemini-info-item p,.gemini-info-item ul{color:var(--text-primary-color);font-size:.95em;line-height:1.7}.gemini-info-item ul{list-style:disc;padding-left:var(--padding-base)}.gemini-info-item ul li{margin-bottom:var(--padding-small)}.streaming-links-container{border:1px solid var(--border-color);border-radius:var(--border-radius);margin-top:1.5rem;padding:1.5rem;text-align:center}.streaming-links-container h4{margin-bottom:1rem;margin-top:0}.streaming-links-grid{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.streaming-link{align-items:center;border-width:1px;display:inline-flex;gap:.6rem;justify-content:center;min-width:150px;padding:.6rem 1.2rem}.streaming-link svg{height:20px;width:20px}.streaming-link.spotify{border-color:#1db954;color:#1db954}.streaming-link.spotify:hover{background-color:#1db9549a;color:#fff}.streaming-link.apple{border-color:#fc3c44;color:#fc3c44}.streaming-link.apple:hover{background-color:#fc3c429b;color:#fff}.streaming-link.youtube{border-color:red;color:red}.streaming-link.youtube:hover{background-color:#ff00008f;color:#fff}@media (max-width:768px){h1{font-size:1.8rem}h2{font-size:1.5rem}header{padding:0 var(--padding-base)}header .logo a{font-size:1.3em}header nav{display:none}.gemini-info-section{padding:var(--padding-base)}.gemini-info-section h2{font-size:1.2em}}.tooltip-score-list{list-style:none;margin:0;padding:0}.tooltip-score-list li{align-items:center;display:flex;font-size:14px;justify-content:space-between;padding:8px 0}.tooltip-score-list li:not(:last-child){border-bottom:1px solid var(--border-color)}.tooltip-score-list span{color:var(--text-secondary-color);padding-right:1rem}.tooltip-score-list strong{color:var(--text-primary-color);flex-shrink:0;font-family:var(--font-family-heading);font-weight:700;white-space:nowrap}.tooltip-score-list li span{white-space:normal}@keyframes modal-animate{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}#disclaimer-overlay{align-items:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background-color:hsla(0,0%,7%,.8);display:flex;display:none;height:100%;justify-content:center;left:0;padding:1rem;position:fixed;top:0;width:100%;z-index:2000}#disclaimer-modal{animation:modal-animate .3s ease-out forwards;background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--border-radius);border-top:4px solid var(--accent-color);box-shadow:0 15px 40px rgba(0,0,0,.4);max-height:90vh;max-width:550px;overflow-y:auto;padding:2.5rem;text-align:center}#disclaimer-modal h3{color:var(--text-primary-color);font-family:var(--font-family-heading);font-size:1.75rem;margin-bottom:1rem;margin-top:0}#disclaimer-modal p{color:var(--text-secondary-color);font-size:1.05em;line-height:1.7;margin-bottom:2rem}#disclaimer-modal .button{transition:transform .2s ease}#disclaimer-modal .button:hover{transform:scale(1.05)}@keyframes pulse{0%{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.disclaimer-icon{color:var(--danger-color);height:60px;margin:0 auto 1.5rem;width:60px}.disclaimer-icon svg{animation:pulse 1.5s cubic-bezier(.66,0,0,1) infinite;height:100%;width:100%}#disclaimer-modal h3{margin-bottom:1.5rem}.button-support{background-color:rgba(var(--accent-color-rgb),.1);border-color:transparent;color:var(--accent-color);font-size:.85rem;padding:.5rem 1rem}.button-support:hover{background-color:var(--accent-color);border-color:var(--accent-color);color:var(--accent-text-color-on-accent-bg)}.logo{align-items:center;display:inline-flex;gap:.75rem;text-decoration:none}.header-logo-icon{display:block;height:38px;width:auto}.header-logo-text{color:var(--text-primary-color);font-family:var(--font-family-heading);font-size:1.6em;font-weight:800;letter-spacing:-.04em;transition:color .2s ease}.logo:hover .header-logo-text{color:var(--accent-color)}.plexus-footer{background-color:#050508;margin-top:auto;overflow:hidden;padding:4rem 0;position:relative}#plexus-canvas{height:100%;left:0;position:absolute;top:0;width:100%;z-index:1}.plexus-footer .footer-content{margin:0 auto;max-width:1200px;padding:0 2rem;position:relative;z-index:2}.plexus-footer .footer-grid{backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);background-color:hsla(0,0%,4%,.3);border:1px solid hsla(0,0%,100%,.05);border-radius:var(--border-radius);display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin:0 auto;max-width:1200px;padding:3rem 1.5rem;width:100%}.plexus-footer .footer-column h4{color:var(--accent-color);font-size:.9rem;letter-spacing:.1em;margin-bottom:1.25rem;text-transform:uppercase}.plexus-footer .footer-column h4,.plexus-footer .footer-copyright,.plexus-footer .footer-description,.plexus-footer .footer-links a,.plexus-footer .footer-logo-text{text-shadow:0 0 5px rgba(0,0,0,.5)}.plexus-footer .footer-links{list-style:none}.plexus-footer .footer-links li{margin-bottom:.75rem}.plexus-footer .footer-links a{color:var(--text-secondary-color);text-decoration:none;transition:color .2s}.plexus-footer .footer-links a:hover{color:var(--accent-hover-color)}.plexus-footer .footer-brand .footer-logo-link{align-items:center;display:inline-flex;gap:.75rem;margin-bottom:1rem;text-decoration:none}.plexus-footer .footer-brand .footer-logo-icon{height:32px;width:auto}.plexus-footer .footer-brand .footer-logo-text{color:var(--text-primary-color);font-family:var(--font-family-heading);font-size:1.5rem;font-weight:700}.plexus-footer .footer-brand .footer-description{color:var(--text-secondary-color);font-size:.9em;line-height:1.6}.plexus-footer .footer-bottom{border-top:1px solid hsla(0,0%,100%,.1);flex-direction:column;margin-top:2rem;padding-top:2rem;text-align:center}.plexus-footer .footer-copyright{color:var(--text-secondary-color);font-size:.85em}.footer-contacts{display:flex;gap:1.5rem;justify-content:center;margin-bottom:1.5rem}.contact-link{color:var(--text-secondary-color);transition:color .2s ease,transform .2s ease}.contact-link:hover{color:var(--accent-color);transform:scale(1.1)}.contact-link svg{height:24px;width:24px}body.is-pinning{perspective:none}.nav-dropdown{position:relative}.nav-dropdown-toggle{align-items:center;background-color:transparent;border:none;border-radius:var(--border-radius);color:var(--text-secondary-color);cursor:pointer;display:flex;font-family:var(--font-family-heading);font-size:.9rem;font-weight:600;gap:.5rem;letter-spacing:.05em;padding:.5rem 1rem;text-transform:uppercase;transition:color .2s ease,background-color .2s ease}.nav-dropdown-toggle svg{transition:transform .2s ease-in-out}.nav-dropdown.is-active .nav-dropdown-toggle svg{transform:rotate(180deg)}.nav-dropdown-menu{align-items:stretch;background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:0 10px 30px rgba(0,0,0,.4);clip-path:inset(0 0 100% 0);display:flex;flex-direction:column;gap:0;left:50%;opacity:0;padding:.3rem;position:absolute;top:110%;transform:translateX(-50%);transition:all .4s cubic-bezier(.23,1,.32,1);visibility:hidden;width:170px;z-index:10}.nav-dropdown.is-active .nav-dropdown-menu{clip-path:inset(0 0 0 0);opacity:1;transform:translateX(-50%) translateY(10px);visibility:visible}.nav-dropdown-menu a{border-radius:var(--border-radius);color:var(--text-secondary-color);display:block;margin:0;opacity:0;padding:.75rem 0;text-align:center;text-decoration:none;transform:translateY(15px);transition:opacity .3s ease,transform .3s ease,background-color .2s ease,color .2s ease;width:100%}.nav-dropdown-menu a.active,.nav-dropdown-menu a:hover{background-color:var(--surface-hover-color);color:var(--accent-color)}.nav-dropdown-menu a:after{display:none}.nav-dropdown.is-active .nav-dropdown-menu a{opacity:1;transform:translateY(0)}.nav-dropdown.is-active .nav-dropdown-menu a:first-child{transition-delay:.15s}.nav-dropdown.is-active .nav-dropdown-menu a:nth-child(2){transition-delay:.2s}.nav-dropdown.is-active .nav-dropdown-menu a:nth-child(3){transition-delay:.25s}.artist-card-image-container{aspect-ratio:1/1;background-color:var(--bg-color);position:relative;width:100%}.artist-card-score{align-items:center;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background-color:hsla(0,0%,7%,.8);border:1px solid var(--border-focus-color);border-radius:50%;color:var(--accent-color);display:flex;font-family:var(--font-family-heading);font-size:1.1rem;font-weight:700;height:44px;justify-content:center;position:absolute;right:8px;top:8px;width:44px}.visually-hidden{height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;clip:rect(0,0,0,0);border:0}.loader{align-items:center;display:flex;justify-content:center;padding:2rem;text-align:center}.loader-content{align-items:baseline;display:flex}.loader-text{color:var(--accent-color);font-size:1.2rem;font-weight:700;margin-right:4px}.loader-dots{display:inline-flex}.loader-dots span{animation-duration:1.4s;animation-iteration-count:infinite;animation-name:dot-jump;animation-timing-function:ease-in-out;color:var(--accent-color);font-size:1.2rem;font-weight:700}.loader-dots span:first-child{animation-delay:0s}.loader-dots span:nth-child(2){animation-delay:.2s}.loader-dots span:nth-child(3){animation-delay:.4s}@keyframes dot-jump{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-8px)}}@media (max-width:768px){.footer-grid{gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));padding:2rem 1rem}.footer-column.footer-brand{grid-column:1/-1;text-align:center}.footer-bottom{flex-direction:column-reverse;text-align:center}}.notification{border-radius:var(--border-radius);color:#fff;font-weight:500;left:50%;opacity:0;padding:1rem 1.5rem;position:fixed;top:80px;top:60px;transform:translateX(-50%);transition:opacity .3s ease,visibility .3s ease,top .3s ease;visibility:hidden;z-index:1000}.notification:not(.is-hidden){opacity:1;top:80px;visibility:visible}.notification.is-error{background-color:var(--danger-color);box-shadow:0 4px 15px rgba(220,53,69,.4)}.notification.is-success{background-color:#28a745;box-shadow:0 4px 15px rgba(40,167,69,.4)}.notification.is-info{background-color:#17a2b8;box-shadow:0 4px 15px rgba(23,162,184,.4)}.confirm-modal{align-items:center;display:flex;height:100%;justify-content:center;left:0;opacity:0;position:fixed;top:0;transition:opacity .3s ease,visibility 0s linear .3s;visibility:hidden;width:100%;z-index:2000}.confirm-modal.is-open{opacity:1;transition:opacity .3s ease,visibility 0s linear 0s;visibility:visible}.confirm-modal__overlay{backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);background-color:rgba(0,0,0,.6);height:100%;left:0;position:absolute;top:0;width:100%;z-index:2001}.confirm-modal__container{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:0 15px 30px rgba(0,0,0,.4);color:var(--text-primary-color);max-width:500px;opacity:0;padding:var(--padding-large);transform:translateY(20px);transition:transform .3s cubic-bezier(.25,.46,.45,.94),opacity .3s cubic-bezier(.25,.46,.45,.94);width:calc(100% - 2rem);z-index:2002}.confirm-modal.is-open .confirm-modal__container{opacity:1;transform:translateY(0)}@keyframes slide-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.confirm-modal__header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--margin-base)}.confirm-modal__title{color:var(--text-primary-color);font-family:var(--font-family-heading);font-size:1.5rem;font-weight:700}.confirm-modal__close{background:transparent;border:none;color:var(--text-secondary-color);cursor:pointer;margin:-.5rem;padding:.5rem;transition:color .2s ease}.confirm-modal__close:hover{color:var(--text-primary-color)}.confirm-modal__close svg{height:24px;width:24px}.confirm-modal__content{font-size:1rem;line-height:1.6;margin-bottom:1.5rem}.confirm-modal__footer{display:flex;gap:1rem;justify-content:flex-end}.confirm-modal .button-delete{background-color:var(--danger-color);border-color:var(--danger-color);color:#fff}.confirm-modal .button-delete:hover{background-color:#ff2d2d;border-color:#ff2d2d}.confirm-modal{display:none}@media (max-width:768px){.button.button-primary.reviews-suggest-btn{font-size:10px;padding:12px 20px}}.modal h3{font-size:1.5rem;margin-top:0}.modal p{margin-bottom:2rem}.modal-actions{display:flex;gap:1rem;justify-content:center}body.lite-mode *,body.lite-mode :after,body.lite-mode :before{animation-duration:0s!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:0s!important}body.lite-mode #flask-canvas-container,body.lite-mode #header-canvas,body.lite-mode #hero-canvas-container{display:none!important}body.lite-mode footer a{transition-duration:0s!important}.modal-overlay{align-items:center;backdrop-filter:blur(8px);background-color:rgba(12,15,22,.8);bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:fixed;right:0;top:0;transition:opacity .3s ease,visibility .3s ease;visibility:hidden;z-index:1000}.modal-overlay:not(.is-hidden){opacity:1;visibility:visible}.modal{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:16px;max-width:420px;padding:1.5rem;position:relative;transform:scale(.95);transition:transform .3s ease;width:90%}.modal-overlay:not(.is-hidden) .modal{transform:scale(1)}.modal h2{font-size:1.5rem;margin:0;text-align:center}.language-list{display:flex;flex-direction:column;gap:.75rem;margin-top:1.5rem}.language-option{align-items:center;background-color:var(--bg-color);border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary-color);display:flex;gap:1rem;padding:.75rem 1rem;text-decoration:none;transition:all .2s ease}.language-option:hover{color:var(--text-primary-color)}.language-option.active,.language-option:hover{background-color:var(--accent-color-light);border-color:var(--accent-color)}.language-option.active{color:var(--accent-color);font-weight:600}.language-flag{font-size:1.5rem}.language-name{flex-grow:1}.icon-checkmark{color:var(--accent-color);height:20px;width:20px}