@charset "UTF-8";@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@300;400;500&family=Space+Grotesk:wght@300;400;500;600;700&display=swap";@keyframes ethereal-glow-pulse{0%,to{box-shadow:0 0 20px #6ee7b74d,0 0 40px #8b5cf626;filter:brightness(1)}50%{box-shadow:0 0 30px #6ee7b766,0 0 60px #8b5cf640,0 0 90px #ff00c41a;filter:brightness(1.1)}}.loading-screen{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:2rem;background:#0a0a1a;z-index:200;overflow:hidden}.loading-screen__title{font-size:2.5rem;font-weight:300;letter-spacing:.2em;color:#e8f0ff;display:flex;font-family:JetBrains Mono,Fira Code,monospace}@media(min-width:768px){.loading-screen__title{font-size:4rem;letter-spacing:.3em}}.loading-screen__letter{display:inline-block;min-width:.8em;text-align:center}.loading-screen__letter--glitch{color:#e8f0ffcc;text-shadow:0 0 4px rgba(110,231,183,.6),2px 0 0 rgba(255,0,196,.5),-2px 0 0 rgba(110,231,183,.5)}.loading-screen__letter--resolved{color:#e8f0ff;text-shadow:0 0 15px rgba(110,231,183,.5),0 0 30px rgba(139,92,246,.3)}.loading-screen__status-container{height:48px;display:flex;align-items:center;justify-content:center}.loading-screen__status{font-size:.875rem;color:#e8f0ff;letter-spacing:.05em;font-family:JetBrains Mono,Fira Code,monospace}@media(min-width:768px){.loading-screen__status{font-size:1rem}}.loading-screen__status--typewriter{color:#e8f0ff}.loading-screen__dots{display:inline-block;width:1.5em;text-align:left}.loading-screen__cursor{display:inline-block;color:#e8f0ff;animation:blink .8s step-end infinite;margin-left:2px}.loading-screen__enter-button{display:flex;align-items:center;justify-content:center;padding:.5rem 1rem;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;font-family:inherit}.loading-screen__enter-button:hover{transform:scale(1.05)}.loading-screen__enter-button:active{transform:scale(.98)}.loading-screen__enter-button{position:relative;padding:1rem 2rem;background:transparent;border:none;color:#e8f0ff;font-size:1rem;font-family:JetBrains Mono,Fira Code,monospace;letter-spacing:.1em;pointer-events:none;transition:transform .2s ease}.loading-screen__enter-button span{position:relative;z-index:1}.loading-screen__enter-button--ready{pointer-events:auto;cursor:pointer}.loading-screen__enter-button--ready:hover{transform:scale(1.05)}.loading-screen__enter-button--ready:hover .loading-screen__button-border rect{stroke:#6ee7b7;filter:drop-shadow(0 0 6px rgba(110,231,183,.8)) drop-shadow(0 0 12px rgba(110,231,183,.5)) drop-shadow(0 0 20px rgba(139,92,246,.3))}.loading-screen__enter-button--ready:active{transform:scale(.98)}.loading-screen__enter-button--ready:active .loading-screen__button-border rect{stroke:#6ee7b7b3}.loading-screen__button-border{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.loading-screen__button-border rect{stroke:#6ee7b780;filter:drop-shadow(0 0 4px rgba(110,231,183,.3));transition:all .3s ease}.loading-screen__timeout{display:flex;flex-direction:column;align-items:center;gap:1rem}.loading-screen__timeout-message{font-size:.875rem;color:#e8f0ff;letter-spacing:.05em;text-align:center;font-family:JetBrains Mono,Fira Code,monospace}@media(min-width:768px){.loading-screen__timeout-message{font-size:1rem}}.loading-screen__retry-button{display:flex;align-items:center;justify-content:center;padding:.5rem 1rem;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;font-family:inherit}.loading-screen__retry-button:hover{transform:scale(1.05)}.loading-screen__retry-button:active{transform:scale(.98)}.loading-screen__retry-button{position:relative;padding:1rem 2rem;background:transparent;border:none;color:#e8f0ff;font-size:1rem;font-family:JetBrains Mono,Fira Code,monospace;letter-spacing:.1em;cursor:pointer;text-shadow:0 0 8px rgba(110,231,183,.4)}.loading-screen__retry-button span{position:relative;z-index:1}.loading-screen__retry-button:hover{color:#0a0a1a;text-shadow:none}.loading-screen__retry-button:hover .loading-screen__button-border rect{fill:#6ee7b7;stroke:#6ee7b7}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.error-screen{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;flex-direction:column;background:#0a0a1a;z-index:200;overflow:hidden}.error-screen__bg-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 50% 40%,rgba(110,231,183,.08) 0%,rgba(139,92,246,.04) 30%,transparent 60%);pointer-events:none}.error-screen__content{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1.5rem;text-align:center;padding:2rem}.error-screen__title{font-size:2.5rem;font-weight:300;letter-spacing:.1em;color:#e8f0ff;text-shadow:0 0 15px rgba(110,231,183,.5),0 0 30px rgba(139,92,246,.3)}@media(min-width:768px){.error-screen__title{font-size:3.5rem}}.error-screen__message{font-size:.9rem;color:#a8b4d4;max-width:300px;line-height:1.6}@media(min-width:768px){.error-screen__message{font-size:1rem;max-width:400px}}.error-screen__button{display:flex;align-items:center;justify-content:center;padding:.5rem 1rem;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;font-family:inherit}.error-screen__button:hover{transform:scale(1.05)}.error-screen__button:active{transform:scale(.98)}.error-screen__button{margin-top:1rem;padding:1rem 2rem;background:transparent;border:1px solid rgba(110,231,183,.4);color:#e8f0ff;font-size:1rem;letter-spacing:.1em;box-shadow:0 0 10px #6ee7b733,0 0 20px #8b5cf61a;transition:all .3s ease}.error-screen__button:hover{background:#6ee7b726;border-color:#6ee7b799;box-shadow:0 0 20px #6ee7b74d,0 0 40px #8b5cf626}.nav-buttons--top-right{position:fixed;top:1.5rem;right:1.5rem;z-index:11}@media(min-width:768px){.nav-buttons--top-right{top:2rem;right:2rem}}.nav-buttons--bottom-right{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;flex-direction:column;align-items:flex-end;gap:.5rem;z-index:11}@media(min-width:768px){.nav-buttons--bottom-right{bottom:2rem;right:2rem;gap:1rem}}.icon-button{position:relative;display:flex;align-items:center;justify-content:center;width:48px;height:48px;padding:0;border:1px solid rgba(110,231,183,.15);border-radius:9999px;cursor:pointer;font-family:inherit;color:#e8f0ff;background:linear-gradient(135deg,#6ee7b70d,#8b5cf614,#0a0a1af2);box-shadow:0 0 10px #6ee7b733,0 0 20px #8b5cf61a,inset 0 1px #ffffff0d,inset 0 -1px #0003;overflow:hidden;transition:box-shadow .3s ease,border-color .3s ease,transform .3s ease;touch-action:manipulation;-webkit-tap-highlight-color:transparent;min-width:48px;min-height:48px}@media(min-width:768px){.icon-button{width:52px;height:52px}}.icon-button:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:radial-gradient(ellipse at 30% 20%,rgba(110,231,183,.15) 0%,transparent 50%);opacity:1;transition:opacity .3s ease;pointer-events:none}.icon-button:after{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:inherit;background:radial-gradient(circle,#6ee7b780,#8b5cf64d,#ff00c433);opacity:0;z-index:-1;transition:opacity .3s ease;filter:blur(12px)}.icon-button:hover{border-color:#6ee7b766;box-shadow:0 0 20px #6ee7b74d,0 0 40px #8b5cf626}.icon-button:hover:after{opacity:1;animation:ethereal-glow-pulse 2s ease-in-out infinite}.icon-button:hover:before{background:radial-gradient(ellipse at 30% 20%,rgba(110,231,183,.25) 0%,rgba(139,92,246,.1) 40%,transparent 60%)}@media(prefers-reduced-motion:reduce){.icon-button:hover:after{animation:none}}.icon-button svg{width:22px;height:22px;filter:drop-shadow(0 0 4px rgba(110,231,183,.3))}@media(min-width:768px){.icon-button svg{width:24px;height:24px}}.icon-button--active{border-color:#6ee7b766;background:linear-gradient(135deg,#6ee7b714,#8b5cf61a,#0a0a1af2)}.icon-button--active:before{background:radial-gradient(ellipse at 30% 20%,rgba(110,231,183,.2) 0%,rgba(139,92,246,.1) 40%,transparent 60%)}.icon-button--disabled{opacity:.5;cursor:not-allowed;pointer-events:auto}.icon-button--disabled:hover{box-shadow:0 0 10px #6ee7b733,0 0 20px #8b5cf61a;border-color:#6ee7b71a}.icon-button:active{transform:scale(.95);box-shadow:0 0 8px #6ee7b733,inset 0 1px #ffffff0d,inset 0 -1px #0003}.projects-modal{position:relative;display:flex;flex-direction:column;color:#fffffff2;background:linear-gradient(135deg,#6ee7b70a,#1a1535f7,#0a0a1afc);border:1px solid rgba(110,231,183,.15);box-shadow:0 0 10px #6ee7b733,0 0 20px #8b5cf61a,inset 0 1px #ffffff0d,inset 0 -1px #0003;overflow:hidden}.projects-modal:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:radial-gradient(ellipse at 30% 20%,rgba(110,231,183,.1) 0%,rgba(139,92,246,.05) 30%,transparent 60%);pointer-events:none;z-index:0}.projects-modal__header{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1.5rem;position:relative;z-index:1;width:100%}@media(min-width:768px){.projects-modal__header{padding:1rem 2rem}}.projects-modal__title{display:flex;align-items:center;gap:.5rem}.projects-modal__icon{width:18px;height:18px;filter:drop-shadow(0 0 4px rgba(110,231,183,.3))}@media(min-width:768px){.projects-modal__icon{width:20px;height:20px}}.projects-modal__title-text{font-size:.875rem;font-weight:500;letter-spacing:.02em;white-space:nowrap}@media(min-width:768px){.projects-modal__title-text{font-size:1rem}}.projects-modal__actions{display:flex;gap:.25rem}.projects-modal__action-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;min-width:44px;min-height:44px;padding:0;border:none;border-radius:9999px;cursor:pointer;background:#6ee7b71a;color:#ffffffe6;transition:all .2s ease;touch-action:manipulation;-webkit-tap-highlight-color:transparent}@media(min-width:768px){.projects-modal__action-btn{width:32px;height:32px;min-width:32px;min-height:32px}}.projects-modal__action-btn:hover{background:#6ee7b740;box-shadow:0 0 15px #6ee7b74d}.projects-modal__action-btn svg{width:18px;height:18px}@media(min-width:768px){.projects-modal__action-btn svg{width:16px;height:16px}}.projects-modal__content{position:relative;z-index:1;border-top:1px solid rgba(110,231,183,.1);overflow:hidden}.projects-modal__list{list-style:none;max-height:300px;overflow-x:hidden;overflow-y:auto}.projects-modal__list::-webkit-scrollbar{width:6px}.projects-modal__list::-webkit-scrollbar-track{background:#6ee7b70d;border-radius:3px}.projects-modal__list::-webkit-scrollbar-thumb{background:#6ee7b740;border-radius:3px}.projects-modal__list::-webkit-scrollbar-thumb:hover{background:#6ee7b766}.projects-modal__list{scrollbar-width:thin;scrollbar-color:rgba(110,231,183,.25) rgba(110,231,183,.05)}@media(min-width:768px){.projects-modal__list{max-height:400px}}.projects-modal__item{padding:1rem 1.5rem;cursor:pointer;transition:background .2s ease;border-bottom:1px solid rgba(110,231,183,.05)}@media(min-width:768px){.projects-modal__item{padding:1rem 2rem}}.projects-modal__item:last-child{border-bottom:none}.projects-modal__item:hover{background:#6ee7b70d}.projects-modal__item-title{font-size:.9rem;font-weight:500;color:#e8f0ff;margin-bottom:.25rem;transition:text-shadow .2s ease}.projects-modal__item:hover .projects-modal__item-title{text-shadow:0 0 8px rgba(110,231,183,.4)}.projects-modal__item-tags{display:flex;gap:.25rem;flex-wrap:wrap}.projects-modal__tag{font-size:.7rem;padding:2px 8px;background:#8b5cf633;border:1px solid rgba(139,92,246,.3);border-radius:4px;color:#6ee7b7e6}.projects-modal--open{box-shadow:0 0 20px #6ee7b74d,0 0 40px #8b5cf626,inset 0 1px #ffffff0d,inset 0 -1px #0003}.projects-modal:not(.projects-modal--open){align-items:center;justify-content:center}.projects-modal:not(.projects-modal--open):before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:radial-gradient(ellipse at 30% 20%,rgba(110,231,183,.15) 0%,transparent 50%);opacity:1;transition:opacity .3s ease;pointer-events:none}.projects-modal:not(.projects-modal--open):after{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:inherit;background:radial-gradient(circle,#6ee7b780,#8b5cf64d,#ff00c433);opacity:0;z-index:-1;transition:opacity .3s ease;filter:blur(12px)}.projects-modal:not(.projects-modal--open):hover{border-color:#6ee7b766;box-shadow:0 0 20px #6ee7b74d,0 0 40px #8b5cf626}.projects-modal:not(.projects-modal--open):hover:after{opacity:1;animation:ethereal-glow-pulse 2s ease-in-out infinite}.projects-modal:not(.projects-modal--open):hover:before{background:radial-gradient(ellipse at 30% 20%,rgba(110,231,183,.25) 0%,rgba(139,92,246,.1) 40%,transparent 60%)}@media(prefers-reduced-motion:reduce){.projects-modal:not(.projects-modal--open):hover:after{animation:none}}.projects-modal:not(.projects-modal--open) .projects-modal__header{width:auto;padding:0;justify-content:center}.projects-modal:not(.projects-modal--open) .projects-modal__title{gap:0}.help-modal{position:relative;display:flex;flex-direction:column;color:#fffffff2;background:linear-gradient(135deg,#6ee7b70a,#1a1535f7,#0a0a1afc);border:1px solid rgba(110,231,183,.15);box-shadow:0 0 10px #6ee7b733,0 0 20px #8b5cf61a,inset 0 1px #ffffff0d,inset 0 -1px #0003;overflow:hidden;margin-left:auto;margin-top:auto;justify-content:flex-end}.help-modal:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:radial-gradient(ellipse at 70% 80%,rgba(110,231,183,.1) 0%,rgba(139,92,246,.05) 30%,transparent 60%);pointer-events:none;z-index:0}.help-modal__header{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1.5rem;position:relative;z-index:1;flex-shrink:0;width:100%}@media(min-width:768px){.help-modal__header{padding:1rem 2rem}}.help-modal__title{display:flex;align-items:center;gap:.5rem}.help-modal__icon{width:22px;height:22px;filter:drop-shadow(0 0 4px rgba(110,231,183,.3));flex-shrink:0}@media(min-width:768px){.help-modal__icon{width:24px;height:24px}}.help-modal__title-text{font-size:.875rem;font-weight:500;letter-spacing:.02em;white-space:nowrap;overflow:hidden}@media(min-width:768px){.help-modal__title-text{font-size:1rem}}.help-modal__actions{display:flex;gap:.25rem}.help-modal__action-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;min-width:44px;min-height:44px;padding:0;border:none;border-radius:9999px;cursor:pointer;background:#6ee7b71a;color:#ffffffe6;transition:all .2s ease;touch-action:manipulation;-webkit-tap-highlight-color:transparent}@media(min-width:768px){.help-modal__action-btn{width:32px;height:32px;min-width:32px;min-height:32px}}.help-modal__action-btn:hover{background:#6ee7b740;box-shadow:0 0 15px #6ee7b74d}.help-modal__action-btn svg{width:18px;height:18px}@media(min-width:768px){.help-modal__action-btn svg{width:16px;height:16px}}.help-modal__content{position:relative;z-index:1;border-bottom:1px solid rgba(110,231,183,.1);overflow:visible;flex:1;min-height:0}.help-modal__list{list-style:none;overflow-x:hidden;overflow-y:auto;padding:.25rem 0 1rem;max-height:162px}.help-modal__list::-webkit-scrollbar{width:6px}.help-modal__list::-webkit-scrollbar-track{background:#6ee7b70d;border-radius:3px}.help-modal__list::-webkit-scrollbar-thumb{background:#6ee7b740;border-radius:3px}.help-modal__list::-webkit-scrollbar-thumb:hover{background:#6ee7b766}.help-modal__list{scrollbar-width:thin;scrollbar-color:rgba(110,231,183,.25) rgba(110,231,183,.05)}@media(min-width:768px){.help-modal__list{overflow-y:hidden;max-height:none;padding:.25rem 0}}.help-modal--scrollable .help-modal__list{max-height:252px;overflow-y:auto}.help-modal--scrollable .help-modal__list::-webkit-scrollbar{width:6px}.help-modal--scrollable .help-modal__list::-webkit-scrollbar-track{background:#6ee7b70d;border-radius:3px}.help-modal--scrollable .help-modal__list::-webkit-scrollbar-thumb{background:#6ee7b740;border-radius:3px}.help-modal--scrollable .help-modal__list::-webkit-scrollbar-thumb:hover{background:#6ee7b766}.help-modal--scrollable .help-modal__list{scrollbar-width:thin;scrollbar-color:rgba(110,231,183,.25) rgba(110,231,183,.05)}.help-modal__item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1.5rem;border-bottom:1px solid rgba(110,231,183,.05)}@media(min-width:768px){.help-modal__item{padding:.5rem 2rem}}.help-modal__item:last-child{border-bottom:none}.help-modal__action{font-size:.8rem;font-weight:600;color:#6ee7b7;padding:2px 8px;background:#6ee7b71a;border:1px solid rgba(110,231,183,.2);border-radius:4px;white-space:nowrap}@media(min-width:768px){.help-modal__action{font-size:.85rem}}.help-modal__description{font-size:.8rem;color:#a8b4d4;text-align:right}@media(min-width:768px){.help-modal__description{font-size:.85rem}}.help-modal--open{box-shadow:0 0 20px #6ee7b74d,0 0 40px #8b5cf626,inset 0 1px #ffffff0d,inset 0 -1px #0003}.help-modal:not(.help-modal--open){align-items:center;justify-content:center}.help-modal:not(.help-modal--open):before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:radial-gradient(ellipse at 30% 20%,rgba(110,231,183,.15) 0%,transparent 50%);opacity:1;transition:opacity .3s ease;pointer-events:none}.help-modal:not(.help-modal--open):after{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:inherit;background:radial-gradient(circle,#6ee7b780,#8b5cf64d,#ff00c433);opacity:0;z-index:-1;transition:opacity .3s ease;filter:blur(12px)}.help-modal:not(.help-modal--open):hover{border-color:#6ee7b766;box-shadow:0 0 20px #6ee7b74d,0 0 40px #8b5cf626}.help-modal:not(.help-modal--open):hover:after{opacity:1;animation:ethereal-glow-pulse 2s ease-in-out infinite}.help-modal:not(.help-modal--open):hover:before{background:radial-gradient(ellipse at 30% 20%,rgba(110,231,183,.25) 0%,rgba(139,92,246,.1) 40%,transparent 60%)}@media(prefers-reduced-motion:reduce){.help-modal:not(.help-modal--open):hover:after{animation:none}}.help-modal:not(.help-modal--open) .help-modal__header{width:auto;padding:0;justify-content:center}.help-modal:not(.help-modal--open) .help-modal__title{gap:0}.modal-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;position:fixed;background:#0a0a1acc;z-index:100;display:flex;align-items:center;justify-content:center}.modal{position:relative;background:linear-gradient(135deg,#6ee7b70a,#1a1535f7,#0a0a1afc);border:1px solid rgba(110,231,183,.15);border-radius:16px;max-width:90vw;max-height:80vh;overflow:hidden;z-index:101;box-shadow:0 0 20px #6ee7b74d,0 0 40px #8b5cf626,inset 0 1px #ffffff0d}@media(max-width:768px)and (orientation:landscape){.modal{max-height:85vh}}.modal:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:radial-gradient(ellipse at 30% 10%,rgba(110,231,183,.08) 0%,rgba(139,92,246,.04) 30%,transparent 60%);pointer-events:none;z-index:0}@media(min-width:768px){.modal{max-width:600px}}.modal__header{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid rgba(110,231,183,.1)}.modal__title{font-size:1.25rem;font-weight:500;color:#e8f0ff;text-shadow:0 0 8px rgba(110,231,183,.4)}.modal__close{display:flex;align-items:center;justify-content:center;padding:.5rem 1rem;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;font-family:inherit}.modal__close:hover{transform:scale(1.05)}.modal__close:active{transform:scale(.98)}.modal__close{background:transparent;padding:.25rem;color:#a8b4d4;transition:all .2s ease}.modal__close:hover{color:#6ee7b7;filter:drop-shadow(0 0 8px rgba(110,231,183,.5))}.modal__content{position:relative;z-index:1;padding:1.5rem;overflow-y:auto;max-height:calc(80vh - 60px);-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;scroll-behavior:smooth}.modal__content::-webkit-scrollbar{width:6px}.modal__content::-webkit-scrollbar-track{background:#6ee7b70d;border-radius:3px}.modal__content::-webkit-scrollbar-thumb{background:#6ee7b740;border-radius:3px}.modal__content::-webkit-scrollbar-thumb:hover{background:#6ee7b766}.modal__content{scrollbar-width:thin;scrollbar-color:rgba(110,231,183,.25) rgba(110,231,183,.05)}@media(max-width:768px)and (orientation:landscape){.modal__content{max-height:calc(85vh - 60px)}}.modal--confirm{text-align:center;padding:2rem;max-width:400px}.modal__icon{display:flex;justify-content:center;margin-bottom:1rem;color:#6ee7b7;filter:drop-shadow(0 0 8px rgba(110,231,183,.4))}.modal__message{color:#e8f0ff;margin-bottom:1.5rem;line-height:1.5}.modal__actions{display:flex;gap:1rem;justify-content:center}.modal__button{display:flex;align-items:center;justify-content:center;padding:.5rem 1rem;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;font-family:inherit}.modal__button:hover{transform:scale(1.05)}.modal__button:active{transform:scale(.98)}.modal__button{padding:.5rem 1.5rem;font-size:.9rem;font-weight:500;border-radius:8px;transition:all .15s ease;touch-action:manipulation;-webkit-tap-highlight-color:transparent;min-height:44px}.modal__button--secondary{background:#6ee7b71a;border:1px solid rgba(110,231,183,.2);color:#a8b4d4}.modal__button--secondary:hover{background:#6ee7b726;border-color:#6ee7b74d;color:#e8f0ff}.modal__button--primary{background:linear-gradient(135deg,#6ee7b733,#8b5cf64d);border:1px solid rgba(110,231,183,.4);box-shadow:0 0 10px #6ee7b733,0 0 20px #8b5cf61a}.modal__button--primary:hover{background:linear-gradient(135deg,#6ee7b74d,#8b5cf666);border-color:#6ee7b799;box-shadow:0 0 20px #6ee7b74d,0 0 40px #8b5cf626;transform:translateY(-1px)}.modal__button--primary{color:#e8f0ff}.modal--version-history{width:90vw;max-width:500px}@media(min-width:768px){.modal--version-history{width:500px}}.modal--version-history .modal__content{height:50vh;max-height:400px;overflow-y:auto}.modal--version-history .modal__content::-webkit-scrollbar{width:6px}.modal--version-history .modal__content::-webkit-scrollbar-track{background:#6ee7b70d;border-radius:3px}.modal--version-history .modal__content::-webkit-scrollbar-thumb{background:#6ee7b740;border-radius:3px}.modal--version-history .modal__content::-webkit-scrollbar-thumb:hover{background:#6ee7b766}.modal--version-history .modal__content{scrollbar-width:thin;scrollbar-color:rgba(110,231,183,.25) rgba(110,231,183,.05)}@media(max-width:768px)and (orientation:landscape){.modal--version-history .modal__content{height:70vh;max-height:280px}}@media(min-width:768px){.modal--version-history .modal__content{height:600px;max-height:600px}}.version-history__entry{margin-bottom:1.5rem}.version-history__entry:last-child{margin-bottom:0}.version-history__header{display:flex;align-items:center;gap:1rem;background:transparent;border:none;padding:0;margin-bottom:.5rem;cursor:pointer}.version-history__version-number{font-size:1rem;font-weight:600;color:#6ee7b7;text-shadow:0 0 8px rgba(110,231,183,.3);transition:text-shadow .2s ease}.version-history__version-number:hover{text-shadow:0 0 12px rgba(110,231,183,.5)}.version-history__date{font-size:.8rem;color:#a8b4d4}.version-history__chevron{color:#a8b4d4;transition:color .2s ease;flex-shrink:0}.version-history__header[aria-expanded=true] .version-history__chevron{color:#6ee7b7}.version-history__changes{list-style:disc;padding-left:1.5rem;margin:0;color:#e8f0ff;overflow:hidden}.version-history__changes li{margin-bottom:.25rem;font-size:.9rem;line-height:1.6;word-wrap:break-word}.version-history__changes li:last-child{margin-bottom:0}.project-details__description{margin-bottom:1.5rem;line-height:1.6;color:#e8f0ff}.project-details__links{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;margin-bottom:1rem}.project-details__link{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:4px;text-decoration:none;font-size:.875rem;transition:all .15s ease;cursor:pointer}.project-details__link--icon{width:36px;height:36px;padding:0;justify-content:center;background:#6ee7b71a;border:1px solid rgba(110,231,183,.2);color:#a8b4d4;border-radius:9999px}.project-details__link--icon:hover{background:#6ee7b733;border-color:#6ee7b766;color:#6ee7b7;box-shadow:0 0 12px #6ee7b74d;transform:translateY(-2px)}.project-details__link--demo{background:linear-gradient(135deg,#6ee7b71a,#8b5cf626);border:1px solid rgba(110,231,183,.3)}.project-details__link--demo:hover{background:linear-gradient(135deg,#6ee7b733,#8b5cf640);border-color:#6ee7b780;box-shadow:0 0 12px #6ee7b74d;transform:translateY(-2px)}.project-details__link--demo{color:#e8f0ff;padding:.25rem 1rem}.project-details__link--demo svg{flex-shrink:0}.project-details__tags{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(110,231,183,.1)}.project-details__tag{font-size:.75rem;padding:.25rem .5rem;background:#8b5cf61a;border:1px solid rgba(139,92,246,.2);border-radius:4px;color:#a8b4d4}.project-details__tag--category{background:#6ee7b726;border-color:#6ee7b74d;color:#6ee7b7;font-weight:500}.modal--about-me{width:90vw;max-width:500px}@media(min-width:768px){.modal--about-me{width:500px}}.modal--about-me .modal__content{display:flex;flex-direction:column;height:50vh;max-height:400px;overflow:hidden;padding-bottom:0}@media(max-width:768px)and (orientation:landscape){.modal--about-me .modal__content{height:70vh;max-height:280px}}@media(min-width:768px){.modal--about-me .modal__content{height:600px;max-height:600px}}.about-me{display:flex;flex-direction:column;height:100%}.about-me__scrollable{flex:1;overflow-y:auto;padding-bottom:1rem}.about-me__scrollable::-webkit-scrollbar{width:6px}.about-me__scrollable::-webkit-scrollbar-track{background:#6ee7b70d;border-radius:3px}.about-me__scrollable::-webkit-scrollbar-thumb{background:#6ee7b740;border-radius:3px}.about-me__scrollable::-webkit-scrollbar-thumb:hover{background:#6ee7b766}.about-me__scrollable{scrollbar-width:thin;scrollbar-color:rgba(110,231,183,.25) rgba(110,231,183,.05)}.about-me__intro{font-size:1.1rem;line-height:1.6;color:#e8f0ff;text-shadow:0 0 8px rgba(110,231,183,.4);margin-bottom:1.5rem}.about-me__description{font-size:.95rem;line-height:1.7;color:#e8f0ff;margin-bottom:2rem}.about-me__section{margin-bottom:1.5rem}.about-me__section:last-child{margin-bottom:0}.about-me__footer{flex-shrink:0;padding:1rem 1.5rem;margin:0 -1.5rem;border-top:1px solid rgba(110,231,183,.1)}.about-me__section-title{font-size:.9rem;font-weight:600;color:#6ee7b7;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.05em;text-shadow:0 0 8px rgba(110,231,183,.3)}.about-me__tags{display:flex;flex-wrap:wrap;gap:.5rem}.about-me__tag{display:inline-block;padding:.25rem 1rem;font-size:.85rem;border-radius:9999px;cursor:default;transition:all .15s ease;font-weight:500}.about-me__tag--language{background:#6366f126;color:#d8d9fc;border:1px solid rgba(99,102,241,.4)}.about-me__tag--frontend{background:#22c55e26;color:#7ee9a5;border:1px solid rgba(34,197,94,.4)}.about-me__tag--backend{background:#eab30826;color:#fada77;border:1px solid rgba(234,179,8,.4)}.about-me__tag--cloud{background:#f9731626;color:#fcaf79;border:1px solid rgba(249,115,22,.4)}.about-me__tag--devops{background:#0ea5e926;color:#7fd2f7;border:1px solid rgba(14,165,233,.4)}.about-me__tag--database{background:#a855f726;color:#dab6fc;border:1px solid rgba(168,85,247,.4)}.about-me__tag--tools{background:#f43f5e26;color:#fbb8c3;border:1px solid rgba(244,63,94,.4)}.about-me__tag:hover{filter:brightness(1.1)}.about-me__social{display:flex;gap:1rem}.about-me__social-button{display:flex;align-items:center;justify-content:center;padding:.5rem 1rem;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;font-family:inherit}.about-me__social-button:hover{transform:scale(1.05)}.about-me__social-button:active{transform:scale(.98)}.about-me__social-button{background:#6ee7b71a;border:1px solid rgba(110,231,183,.2);padding:.5rem;border-radius:9999px;color:#a8b4d4;transition:all .15s ease}.about-me__social-button:hover{background:#6ee7b733;border-color:#6ee7b766;color:#6ee7b7;box-shadow:0 0 12px #6ee7b74d}.toast{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);z-index:50;display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:linear-gradient(135deg,#6ee7b70a,#1a1535f7,#0a0a1afc);border:1px solid rgba(110,231,183,.15);border-radius:9999px;box-shadow:0 0 10px #6ee7b733,0 0 20px #8b5cf61a,inset 0 0 20px #6ee7b70d;color:#e8f0ff;font-size:.875rem;font-weight:500;white-space:nowrap}.toast__icon{width:18px;height:18px;color:#6ee7b7;filter:drop-shadow(0 0 4px rgba(110,231,183,.5))}.toast__message{padding-right:.25rem}.tooltip-wrapper{position:relative;display:inline-flex}.tooltip{position:absolute;z-index:50;padding:.25rem .5rem;font-size:.75rem;font-weight:500;letter-spacing:.02em;white-space:nowrap;pointer-events:none;color:#e8f0ff;background:linear-gradient(135deg,#6ee7b70a,#1a1535f7,#0a0a1afc);border-radius:16px;box-shadow:0 0 10px #6ee7b733,0 0 20px #8b5cf61a,inset 0 1px #ffffff0d;border:1px solid rgba(110,231,183,.15)}.tooltip__arrow{position:absolute;width:8px;height:8px;background:linear-gradient(135deg,#8b5cf61a,#0a0a1af2);border:1px solid rgba(110,231,183,.15);border-top:none;border-left:none}.tooltip--left{right:calc(100% + 10px);top:50%;transform:translateY(-50%)}.tooltip--left .tooltip__arrow{right:-5px;top:50%;transform:translateY(-50%) rotate(-45deg)}.tooltip--right{left:calc(100% + 10px);top:50%;transform:translateY(-50%)}.tooltip--right .tooltip__arrow{left:-5px;top:50%;transform:translateY(-50%) rotate(135deg)}.tooltip--top{bottom:calc(100% + 10px);left:50%;transform:translate(-50%)}.tooltip--top .tooltip__arrow{bottom:-5px;left:50%;transform:translate(-50%) rotate(45deg)}.tooltip--bottom{top:calc(100% + 10px);left:50%;transform:translate(-50%)}.tooltip--bottom .tooltip__arrow{top:-5px;left:50%;transform:translate(-50%) rotate(-135deg)}.tutorial{position:fixed;top:0;left:0;right:0;bottom:0;z-index:111;pointer-events:none}.tutorial__blocker{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:auto;background:transparent}.tutorial__overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0a0a1abf;pointer-events:none;transition:backdrop-filter .4s ease}.tutorial__overlay--blur{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.tutorial__spotlight{position:absolute;border-radius:16px;box-shadow:0 0 0 3px #6ee7b780,0 0 20px #6ee7b766,0 0 40px #8b5cf633,inset 0 0 15px #6ee7b71a;pointer-events:none}.tutorial__card{position:absolute;width:320px;padding:1.5rem;background:linear-gradient(135deg,#6ee7b70a,#1a1535f7,#0a0a1afc);border-radius:16px;box-shadow:0 0 20px #6ee7b74d,0 0 40px #8b5cf626,inset 0 1px #ffffff0d;border:1px solid rgba(110,231,183,.15);pointer-events:auto;z-index:10}@media(min-width:768px){.tutorial__card{width:380px;padding:2rem}}.tutorial__content{margin-bottom:1.5rem}.tutorial__title{font-size:1.25rem;font-weight:600;color:#e8f0ff;text-shadow:0 0 8px rgba(110,231,183,.4);margin-bottom:.5rem}@media(min-width:768px){.tutorial__title{font-size:1.4rem}}.tutorial__description{font-size:.9rem;line-height:1.6;color:#a8b4d4}@media(min-width:768px){.tutorial__description{font-size:1rem}}.tutorial__footer{display:flex;align-items:center;justify-content:space-between}.tutorial__dots{display:flex;gap:.25rem}.tutorial__dot{width:8px;height:8px;border-radius:9999px;background:#6ee7b733;transition:all .3s ease}.tutorial__dot--active{background:#6ee7b7;box-shadow:0 0 10px #6ee7b799}.tutorial__dot--completed{background:#6ee7b780}.tutorial__actions{display:flex;align-items:center;gap:1rem}.tutorial__skip{padding:.25rem .5rem;background:none;border:none;color:#a8b4d4;font-size:.85rem;cursor:pointer;transition:color .2s ease}.tutorial__skip:hover:not(:disabled){color:#e8f0ff}.tutorial__skip:disabled{opacity:.5;cursor:not-allowed}.tutorial__next{background:linear-gradient(135deg,#6ee7b733,#8b5cf64d);border:1px solid rgba(110,231,183,.4);box-shadow:0 0 10px #6ee7b733,0 0 20px #8b5cf61a}.tutorial__next:hover{background:linear-gradient(135deg,#6ee7b74d,#8b5cf666);border-color:#6ee7b799;box-shadow:0 0 20px #6ee7b74d,0 0 40px #8b5cf626;transform:translateY(-1px)}.tutorial__next{padding:.5rem 1.5rem;border-radius:8px;color:#e8f0ff;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.tutorial__next:active:not(:disabled){transform:translateY(0)}.tutorial__next:disabled{opacity:.5;cursor:not-allowed}.gesture-hints{position:fixed;top:0;right:0;bottom:0;left:0;z-index:101;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#0a0a1acc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);cursor:pointer}.gesture-hints__content{display:flex;gap:4rem;margin-bottom:2rem}.gesture-hints__dismiss{font-size:.8rem;color:#a8b4d4;letter-spacing:.05em}.gesture-hint__item{display:flex;flex-direction:column;align-items:center;gap:1rem}.gesture-hint__hand{width:48px;height:48px;color:#6ee7b7;filter:drop-shadow(0 0 8px rgba(110,231,183,.4))}.gesture-hint__hand svg{width:100%;height:100%}.gesture-hint__pinch{position:relative;width:48px;height:48px;color:#6ee7b7;filter:drop-shadow(0 0 8px rgba(110,231,183,.4))}.gesture-hint__pinch svg{width:100%;height:100%}.gesture-hint__pinch-dot{position:absolute;width:10px;height:10px;background:#6ee7b7;border-radius:50%;box-shadow:0 0 6px #6ee7b799}.gesture-hint__pinch-dot--left,.gesture-hint__pinch-dot--right{top:50%;left:50%;transform:translate(-50%,-50%)}.gesture-hint__label{font-size:.8rem;color:#e8f0ff;letter-spacing:.05em;white-space:nowrap}.touch-controls{position:fixed;bottom:2rem;left:1.5rem;z-index:12;pointer-events:none;touch-action:none;-webkit-tap-highlight-color:transparent}.touch-controls__left{display:flex;flex-direction:column;align-items:flex-start;gap:.5rem;pointer-events:auto}.touch-controls__left .touch-controls__dpad{margin-top:1rem}.touch-controls__dpad{position:relative;width:160px;height:160px;touch-action:none}.touch-controls__btn{position:absolute;display:flex;align-items:center;justify-content:center;width:54px;height:54px;padding:0;border:2px solid rgba(139,92,246,.4);border-radius:50%;background:radial-gradient(ellipse at 30% 30%,#1a1a2ef2,#0a0a1afa);color:#e8f0ffb3;cursor:pointer;touch-action:none;pointer-events:auto;-webkit-tap-highlight-color:transparent;box-shadow:0 0 15px #8b5cf626,0 4px 8px #0006,inset 0 1px #ffffff14,inset 0 -2px 4px #0000004d;transition:all .1s ease}.touch-controls__btn svg{width:22px;height:22px;filter:drop-shadow(0 0 2px rgba(110,231,183,.3));transition:all .1s ease}.touch-controls__btn--up{top:0;left:50%;transform:translate(-50%)}.touch-controls__btn--down{bottom:0;left:50%;transform:translate(-50%)}.touch-controls__btn--left{left:0;top:50%;transform:translateY(-50%)}.touch-controls__btn--right{right:0;top:50%;transform:translateY(-50%)}.touch-controls__btn--active,.touch-controls__btn:active{border-color:#6ee7b7b3;background:radial-gradient(ellipse at 30% 30%,#6ee7b726,#8b5cf61a,#0a0a1af2);color:#e8f0ff;box-shadow:0 0 20px #6ee7b766,0 0 40px #8b5cf633,0 2px 4px #0000004d,inset 0 1px #ffffff1a,inset 0 -1px 2px #0003;transform:translate(-50%) scale(.95)}.touch-controls__btn--active svg,.touch-controls__btn:active svg{filter:drop-shadow(0 0 6px rgba(110,231,183,.6))}.touch-controls__btn--active.touch-controls__btn--left,.touch-controls__btn--active.touch-controls__btn--right,.touch-controls__btn:active.touch-controls__btn--left,.touch-controls__btn:active.touch-controls__btn--right{transform:translateY(-50%) scale(.95)}.touch-controls__btn--active.touch-controls__btn--up,.touch-controls__btn--active.touch-controls__btn--down,.touch-controls__btn:active.touch-controls__btn--up,.touch-controls__btn:active.touch-controls__btn--down{transform:translate(-50%) scale(.95)}.touch-controls__action,.touch-controls__pause-exit{display:flex;align-items:center;justify-content:center;gap:.25rem;width:128px;height:40px;padding:0 1rem;border-radius:16px;font-family:JetBrains Mono,Fira Code,monospace;font-size:.7rem;font-weight:700;letter-spacing:.05em;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:all .1s ease}.touch-controls__action svg,.touch-controls__pause-exit svg{width:14px;height:14px}.touch-controls__action{border:2px solid rgba(110,231,183,.5);background:radial-gradient(ellipse at 30% 30%,#6ee7b71a,#0a0a1af2);color:#6ee7b7;box-shadow:0 0 20px #6ee7b740,0 4px 8px #0006,inset 0 1px #ffffff1a,inset 0 -2px 4px #0000004d;text-shadow:0 0 10px rgba(110,231,183,.5)}.touch-controls__action:active{border-color:#6ee7b7cc;background:radial-gradient(ellipse at 30% 30%,#6ee7b740,#8b5cf61a,#0a0a1af2);box-shadow:0 0 30px #6ee7b780,0 0 60px #8b5cf633,0 2px 4px #0000004d,inset 0 1px #ffffff26,inset 0 -1px 2px #0003;transform:scale(.97);text-shadow:0 0 15px rgba(110,231,183,.8)}.touch-controls__pause-exit{border:2px solid rgba(139,92,246,.4);background:radial-gradient(ellipse at 30% 30%,#8b5cf614,#0a0a1af2);color:#e8f0ffe6;box-shadow:0 0 15px #8b5cf633,0 4px 8px #0006,inset 0 1px #ffffff14,inset 0 -2px 4px #0000004d}.touch-controls__pause-exit:active{background:radial-gradient(ellipse at 30% 30%,#8b5cf633,#0a0a1af2);border-color:#8b5cf699;transform:scale(.97)}.touch-controls__pause-exit--exit{border-color:#ff444480;background:radial-gradient(ellipse at 30% 30%,#ff444414,#0a0a1af2);color:#ff6b6b;box-shadow:0 0 15px #f443,0 4px 8px #0006,inset 0 1px #ffffff14,inset 0 -2px 4px #0000004d}.touch-controls__pause-exit--exit:active{background:radial-gradient(ellipse at 30% 30%,#f443,#0a0a1af2);border-color:#ff4444b3}.radio-playlist-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;position:fixed;background:#0a0a1ab3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100}.radio-playlist{position:fixed;background:linear-gradient(135deg,#6ee7b70a,#1a1535f7,#0a0a1afc);border:1px solid rgba(110,231,183,.15);border-radius:16px;box-shadow:0 0 20px #6ee7b74d,0 0 40px #8b5cf626,inset 0 1px #ffffff0d;z-index:101;overflow:hidden;display:flex;flex-direction:column}.radio-playlist:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:radial-gradient(ellipse at 30% 10%,rgba(110,231,183,.08) 0%,rgba(139,92,246,.04) 30%,transparent 60%);pointer-events:none;z-index:0}.radio-playlist--compact{bottom:1rem;right:calc(52px + 2rem);width:280px;height:auto;max-height:380px}@media(min-width:768px){.radio-playlist--compact{right:calc(52px + 3rem);width:300px;max-height:400px}}@media(max-width:768px){.radio-playlist--compact{top:0;left:0;right:0;bottom:0;margin:auto;width:calc(100vw - 4rem);max-width:300px;height:fit-content;max-height:calc(100vh - 6rem);max-height:calc(100dvh - 6rem)}}.radio-playlist--full{top:0;left:0;right:0;bottom:0;margin:auto;width:calc(100vw - 3rem);max-width:800px;height:fit-content;max-height:calc(100vh - 6rem);max-height:calc(100dvh - 6rem);background:linear-gradient(135deg,#6ee7b70f,#1a1535,#0a0a1a)}@media(min-width:768px){.radio-playlist--full{max-width:860px}}.radio-playlist__content{position:relative;z-index:1;display:flex;flex-direction:row;align-items:stretch;gap:2rem;padding:2rem;height:460px}.radio-playlist__left{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:1rem;flex-shrink:0;width:260px;padding:.5rem 0 2rem;height:100%}@media(min-width:768px){.radio-playlist__left{width:300px}}.radio-playlist__album-wrapper{display:flex;align-items:flex-start;flex-shrink:0}.radio-playlist__left-spacer{flex:1;min-height:1rem}.radio-playlist__right{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px;height:100%}.radio-playlist__album-art{width:220px;height:220px;border-radius:8px;overflow:hidden;background:#12122a4d;border:1px solid rgba(110,231,183,.15);box-shadow:0 4px 20px #0000004d,0 0 30px #6ee7b71a;flex-shrink:0}@media(min-width:768px){.radio-playlist__album-art{width:260px;height:260px}}.radio-playlist__album-art img{width:100%;height:100%;object-fit:cover}.radio-playlist__album-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#6ee7b71a,#8b5cf60d,#3b82f61a)}.radio-playlist__album-placeholder svg{width:80px;height:80px;color:#6ee7b766;animation:spin-slow 8s linear infinite}.radio-playlist__track-details{display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center;width:100%;padding:.25rem 0;margin-top:auto}.radio-playlist__genre-tag{display:inline-block;font-size:10px;color:#6ee7b7e6;background:#6ee7b71a;border:1px solid rgba(110,231,183,.2);border-radius:4px;padding:2px 8px;text-transform:uppercase;letter-spacing:.5px;margin-top:.25rem}.radio-playlist__track-info{display:flex;flex-direction:column;align-items:center;gap:.25rem;text-align:center;width:100%}.radio-playlist__track-title{font-size:.9rem;font-weight:600;color:#6ee7b7;text-shadow:0 0 8px rgba(110,231,183,.4);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}@media(min-width:768px){.radio-playlist__track-title{font-size:1rem}}.radio-playlist__track-artist{font-size:.8rem;color:#a8b4d4;margin:0}.radio-playlist__track-tag{display:inline-block;font-size:9px;color:#8b5cf6e6;background:#8b5cf61a;border:1px solid rgba(139,92,246,.2);border-radius:4px;padding:1px 5px;margin-left:auto;flex-shrink:0;text-transform:uppercase;letter-spacing:.3px}.radio-playlist__track-name{font-size:.8rem;color:#e8f0ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0;transition:color .15s ease}.radio-playlist__close--floating{position:absolute;top:.5rem;right:.5rem;z-index:2}.radio-playlist__tracks--full{flex:3;min-height:180px;overflow-y:auto;border:1px solid rgba(110,231,183,.1);border-radius:8px;background:#0a0a1a4d;padding:.25rem 0}.radio-playlist__tracks--full::-webkit-scrollbar{width:6px}.radio-playlist__tracks--full::-webkit-scrollbar-track{background:#6ee7b70d;border-radius:3px}.radio-playlist__tracks--full::-webkit-scrollbar-thumb{background:#6ee7b740;border-radius:3px}.radio-playlist__tracks--full::-webkit-scrollbar-thumb:hover{background:#6ee7b766}.radio-playlist__tracks--full{scrollbar-width:thin;scrollbar-color:rgba(110,231,183,.25) rgba(110,231,183,.05)}.radio-playlist--full .radio-playlist__progress{padding:.5rem 0;flex-shrink:0}.radio-playlist--full .radio-playlist__controls{padding:.25rem 0;flex-shrink:0}.radio-playlist--full .radio-playlist__volume{padding:0;padding-right:1.5rem;flex-shrink:0}.radio-playlist__header{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.5rem 1.5rem;border-bottom:1px solid rgba(110,231,183,.1);flex-shrink:0}.radio-playlist__header-info{flex:1;min-width:0;display:flex;align-items:center}.radio-playlist__title{font-size:.9rem;font-weight:500;color:#6ee7b7;text-shadow:0 0 8px rgba(110,231,183,.4);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.radio-playlist__close{display:flex;align-items:center;justify-content:center;padding:.5rem 1rem;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;font-family:inherit}.radio-playlist__close:hover{transform:scale(1.05)}.radio-playlist__close:active{transform:scale(.98)}.radio-playlist__close{width:32px;height:32px;padding:0;background:transparent;color:#a8b4d4;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s ease}.radio-playlist__close svg{width:18px;height:18px}.radio-playlist__close:hover{color:#6ee7b7;filter:drop-shadow(0 0 8px rgba(110,231,183,.5))}.radio-playlist__controls{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem .5rem;flex-shrink:0}.radio-playlist__controls-main{display:flex;align-items:center;gap:.5rem}.radio-playlist__control-btn{display:flex;align-items:center;justify-content:center;padding:.5rem 1rem;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;font-family:inherit}.radio-playlist__control-btn:hover{transform:scale(1.05)}.radio-playlist__control-btn:active{transform:scale(.98)}.radio-playlist__control-btn{width:36px;height:36px;padding:0;background:#12122a80;border:1px solid rgba(110,231,183,.1);border-radius:9999px;color:#e8f0ff;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.radio-playlist__control-btn svg{width:16px;height:16px}.radio-playlist__control-btn:hover{background:#6ee7b71a;border-color:#6ee7b74d;color:#6ee7b7;box-shadow:0 0 10px #6ee7b733,0 0 20px #8b5cf61a}.radio-playlist__control-btn:active{transform:scale(.95)}.radio-playlist__control-btn--play{width:48px;height:48px;background:linear-gradient(135deg,#6ee7b733,#8b5cf61a);border-color:#6ee7b74d}.radio-playlist__control-btn--play svg{width:20px;height:20px}.radio-playlist__control-btn--play:hover{background:linear-gradient(135deg,#6ee7b74d,#8b5cf633);box-shadow:0 0 20px #6ee7b74d,0 0 40px #8b5cf626}.radio-playlist__control-btn--secondary{width:32px;height:32px;background:transparent;border-color:transparent;color:#a8b4d4}.radio-playlist__control-btn--secondary svg{width:14px;height:14px;transition:filter .2s ease}.radio-playlist__control-btn--secondary:hover{color:#e8f0ff}.radio-playlist__control-btn--secondary.active{color:#6ee7b7}.radio-playlist__control-btn--secondary.active svg{filter:drop-shadow(0 0 4px rgba(110,231,183,.6))}.radio-playlist__progress{position:relative;z-index:1;display:flex;flex-direction:column;gap:.25rem;padding:.5rem 1.5rem 0;flex-shrink:0}.radio-playlist__progress-bar{width:100%;height:20px;display:flex;align-items:center;cursor:pointer;touch-action:none}.radio-playlist__progress-times{display:flex;justify-content:space-between;padding:0 2px}.radio-playlist__time{font-size:.7rem;color:#a8b4d4;font-variant-numeric:tabular-nums}.radio-playlist__progress-track{position:relative;width:100%;height:4px;background:#a8b4d433;border-radius:9999px;overflow:visible}.radio-playlist__progress-fill{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,#6ee7b7,#3b82f6);border-radius:9999px;box-shadow:0 0 8px #6ee7b766;transition:width .1s linear}.radio-playlist__progress-thumb{position:absolute;top:50%;width:12px;height:12px;background:#e8f0ff;border:2px solid #6ee7b7;border-radius:9999px;transform:translate(-50%,-50%);box-shadow:0 0 8px #6ee7b780;opacity:0;transition:opacity .15s ease,transform .15s ease}.radio-playlist__progress-bar:hover .radio-playlist__progress-thumb{opacity:1}.radio-playlist__progress-bar:active .radio-playlist__progress-thumb{opacity:1;transform:translate(-50%,-50%) scale(1.2)}.radio-playlist__volume{position:relative;z-index:1;display:flex;align-items:center;gap:.5rem;padding:0 1.5rem 1rem;padding-right:calc(1.5rem + 32px);flex-shrink:0}.radio-playlist__volume-btn{display:flex;align-items:center;justify-content:center;padding:.5rem 1rem;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;font-family:inherit}.radio-playlist__volume-btn:hover{transform:scale(1.05)}.radio-playlist__volume-btn:active{transform:scale(.98)}.radio-playlist__volume-btn{width:32px;height:32px;padding:0;background:transparent;color:#a8b4d4;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s ease}.radio-playlist__volume-btn svg{width:18px;height:18px}.radio-playlist__volume-btn:hover{color:#6ee7b7}.radio-playlist__volume-slider-container{flex:1;height:20px;display:flex;align-items:center}.radio-playlist__volume-slider{width:100%;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border-radius:9999px;outline:none;cursor:pointer;position:relative}.radio-playlist__volume-slider:before{content:"";position:absolute;top:50%;left:0;right:0;height:4px;background:#a8b4d433;border-radius:9999px;transform:translateY(-50%);pointer-events:none}.radio-playlist__volume-slider::-webkit-slider-runnable-track{height:4px;background:linear-gradient(to right,#6ee7b7 0%,#6ee7b7 var(--volume-percent, 50%),rgba(168,180,212,.2) var(--volume-percent, 50%),rgba(168,180,212,.2) 100%);border-radius:9999px;box-shadow:0 0 6px #6ee7b74d}.radio-playlist__volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;background:#e8f0ff;border:2px solid #6ee7b7;border-radius:9999px;cursor:pointer;box-shadow:0 0 8px #6ee7b780;transition:transform .15s ease,box-shadow .15s ease;margin-top:-5px}.radio-playlist__volume-slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 12px #6ee7b7b3}.radio-playlist__volume-slider::-moz-range-track{height:4px;background:#a8b4d433;border-radius:9999px}.radio-playlist__volume-slider::-moz-range-progress{height:4px;background:#6ee7b7;border-radius:9999px;box-shadow:0 0 6px #6ee7b74d}.radio-playlist__volume-slider::-moz-range-thumb{width:14px;height:14px;background:#e8f0ff;border:2px solid #6ee7b7;border-radius:9999px;cursor:pointer;box-shadow:0 0 8px #6ee7b780}.radio-playlist__tracks{position:relative;z-index:1;flex:1;overflow-y:auto;padding:.5rem 0;border-top:1px solid rgba(110,231,183,.1)}.radio-playlist__tracks::-webkit-scrollbar{width:6px}.radio-playlist__tracks::-webkit-scrollbar-track{background:#6ee7b70d;border-radius:3px}.radio-playlist__tracks::-webkit-scrollbar-thumb{background:#6ee7b740;border-radius:3px}.radio-playlist__tracks::-webkit-scrollbar-thumb:hover{background:#6ee7b766}.radio-playlist__tracks{scrollbar-width:thin;scrollbar-color:rgba(110,231,183,.25) rgba(110,231,183,.05)}.radio-playlist--compact.radio-playlist--mobile .radio-playlist__tracks{min-height:120px}.radio-playlist__list{list-style:none;margin:0;padding:0}.radio-playlist__track{display:flex;align-items:center;gap:1rem;padding:.5rem 1.5rem;cursor:pointer;transition:background-color .15s ease;border-left:2px solid transparent}.radio-playlist__track:hover{background:#6ee7b70d}.radio-playlist__track--active{background:#6ee7b714;border-left-color:#6ee7b7}.radio-playlist__track--active .radio-playlist__track-title{color:#6ee7b7}.radio-playlist__track-index{width:24px;font-size:.8rem;color:#a8b4d4;text-align:center;flex-shrink:0}.radio-playlist__track-title{font-size:.8rem;color:#e8f0ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .15s ease}.radio-playlist__playing-indicator{display:flex;align-items:flex-end;justify-content:center;gap:2px;height:14px}.radio-playlist__playing-indicator span{width:3px;background:#6ee7b7;border-radius:1px;animation:equalizer .8s ease-in-out infinite}.radio-playlist__playing-indicator span:nth-child(1){height:60%;animation-delay:0s}.radio-playlist__playing-indicator span:nth-child(2){height:100%;animation-delay:.2s}.radio-playlist__playing-indicator span:nth-child(3){height:40%;animation-delay:.4s}@keyframes equalizer{0%,to{transform:scaleY(.3)}50%{transform:scaleY(1)}}@keyframes spin-slow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden;overscroll-behavior:none}html{position:fixed;width:100%;height:100%}body{font-family:Space Grotesk,system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#0a0a1a;color:#e8f0ff}::selection{background:#6ee7b74d;color:#e8f0ff}:focus-visible{outline:2px solid rgba(110,231,183,.6);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.canvas-container{position:absolute;top:0;left:0;right:0;bottom:0;z-index:0;touch-action:none;user-select:none;-webkit-user-select:none}.ui-overlay{position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:10}.ui-overlay>*{pointer-events:auto}.webgl-fallback{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 50% 30%,#6ee7b708,#0a0a1a 60%);color:#e8f0ff;padding:2rem;text-align:center}.webgl-fallback__content{max-width:500px}.webgl-fallback__content h1{font-size:1.75rem;font-weight:600;margin-bottom:1rem;color:#e8f0ff;text-shadow:0 0 15px rgba(110,231,183,.5),0 0 30px rgba(139,92,246,.3)}.webgl-fallback__content p{font-size:1rem;line-height:1.6;margin-bottom:1rem;color:#a8b4d4}.webgl-fallback__content p:last-child{margin-bottom:0}.webgl-fallback__content p strong{color:#e8f0ff}.webgl-fallback__apology{font-size:1.1rem;color:#e8f0ff!important;margin-bottom:1.5rem}.webgl-fallback__button{display:flex;align-items:center;justify-content:center;padding:.5rem 1rem;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;font-family:inherit}.webgl-fallback__button:hover{transform:scale(1.05)}.webgl-fallback__button:active{transform:scale(.98)}.webgl-fallback__button{margin-top:1.5rem;padding:1rem 2rem;background:transparent;border:1px solid rgba(110,231,183,.25);color:#6ee7b7;font-size:1rem;letter-spacing:.05em;cursor:pointer;transition:all .3s ease;box-shadow:0 0 10px #6ee7b733,0 0 20px #8b5cf61a}.webgl-fallback__button:hover{background:#6ee7b726;border-color:#6ee7b780;box-shadow:0 0 20px #6ee7b74d,0 0 40px #8b5cf626}.webgl-fallback__browser-list{list-style:none;padding:0;margin:0 0 1rem;text-align:left;display:inline-block}.webgl-fallback__browser-list li{font-size:.9rem;line-height:1.8;color:#a8b4d4;padding-left:1.2em;position:relative}.webgl-fallback__browser-list li:before{content:"›";position:absolute;left:0;color:#6ee7b7;text-shadow:0 0 8px rgba(110,231,183,.5)}.webgl-fallback__link{display:inline-block;margin-top:1rem;padding:.5rem 1.5rem;border:1px solid rgba(110,231,183,.25);color:#6ee7b7;text-decoration:none;font-size:.9rem;letter-spacing:.03em;transition:all .3s ease;box-shadow:0 0 10px #6ee7b733,0 0 20px #8b5cf61a}.webgl-fallback__link:hover{background:#6ee7b726;border-color:#6ee7b780;box-shadow:0 0 20px #6ee7b74d,0 0 40px #8b5cf626}
