@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@300;400;500;600&display=swap);*{box-sizing:border-box;margin:0;padding:0;scroll-behavior:smooth}:root{--primary-color:#0a192f;--header-color:#112240;--primary-text-color:#ccd6f6;--primary-text-color-hover:#64ffda;--footer-version-color:#8892b0;--hover-color:#64ffda;--hover-color-transparent:#64ffdb6c;--hover-color-transparent-2:#64ffdb33;--background-hover-color:rgba(100,255,219,.212);--font-main:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-mono:"JetBrains Mono","Fira Code","Consolas",monospace}section[id]{scroll-margin-top:50px}.header{align-items:center;animation:headerSlideDown .5s ease-out forwards;background-color:var(--header-color);box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;min-height:70px;opacity:0;padding:1rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-left{animation:slideInLeft .8s ease-out forwards;animation-delay:.3s;flex:1 1;opacity:0;transform:translateX(-50px)}.header-title{color:var(--primary-text-color);cursor:pointer;font-family:var(--font-mono);font-size:1.8rem;font-weight:700;overflow:hidden;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1)}.header-title:hover{color:var(--hover-color);text-shadow:0 0 20px #64ffda66;transform:scale(1.05)}.header-title:before{background:linear-gradient(90deg,#0000,#64ffda4d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .8s ease;width:100%}.header-title:hover:before{left:100%}.header-middle{animation:fadeInUp .8s ease-out forwards;animation-delay:.5s;display:flex;flex:4 1;justify-content:center;opacity:0}.toc-container{width:100%}.toc-list{display:flex;justify-content:space-around;list-style:none;margin:0;padding:0}.toc-item{animation:slideInUp .6s ease-out forwards;margin:0;opacity:0;transform:translateY(20px)}.toc-item a{border-radius:8px;color:var(--primary-text-color);font-family:var(--font-main);font-size:1rem;font-weight:500;overflow:hidden;padding:.5rem 1rem;position:relative;text-decoration:none;transition:all .4s cubic-bezier(.4,0,.2,1)}.toc-item a:hover{background-color:var(--background-hover-color);box-shadow:0 4px 12px #64ffda33;color:var(--hover-color);transform:translateY(-2px) scale(1.05)}.toc-item a:after{background:linear-gradient(90deg,var(--hover-color),#1ed760);border-radius:1px;bottom:-5px;content:"";height:2px;left:50%;position:absolute;transform:translateX(-50%);transition:all .4s cubic-bezier(.4,0,.2,1);width:0}.toc-item a:hover:after{width:100%}.toc-item:first-child{animation-delay:.7s}.toc-item:nth-child(2){animation-delay:.8s}.toc-item:nth-child(3){animation-delay:.9s}.toc-item:nth-child(4){animation-delay:1s}.toc-item:nth-child(5){animation-delay:1.1s}.toc-item:nth-child(6){animation-delay:1.2s}.toc-item:nth-child(7){animation-delay:1.3s}.toc-item:nth-child(8){animation-delay:1.4s}.header-right{align-items:center;animation:slideInRight .8s ease-out forwards;animation-delay:.4s;display:flex;flex:1 1;gap:1rem;justify-content:flex-end;opacity:0;transform:translateX(50px)}.CV-container{margin-bottom:2rem;text-align:center}.CV-link{display:inline-block;position:relative}.CV-link a{align-items:center;background:linear-gradient(135deg,var(--hover-color),#64ffda);box-shadow:0 4px 15px #64ffda4d,0 2px 8px #0000001a;color:var(--primary-color);display:inline-flex;font-family:var(--font-mono);font-size:1.1rem;font-weight:600;gap:.5rem;justify-content:center;min-width:180px;overflow:hidden;padding:1rem 2rem;position:relative;text-decoration:none;transition:all .4s cubic-bezier(.4,0,.2,1)}.CV-link a:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .6s ease;width:100%}.CV-link a:hover:before{left:100%}.CV-link a:after{content:"📄";font-size:1.2rem;margin-left:.5rem;transition:transform .3s ease}.CV-link a:hover{background:linear-gradient(135deg,#64ffda,var(--hover-color));box-shadow:0 8px 30px #64ffda66,0 4px 15px #0003;transform:translateY(-3px) scale(1.02)}.CV-link a:hover:after{transform:rotate(10deg) scale(1.1)}.CV-link a:active{transform:translateY(-1px) scale(.98);transition:transform .1s ease}@keyframes cvPulse{0%{box-shadow:0 4px 15px #64ffda4d}50%{box-shadow:0 4px 20px #64ffda80}to{box-shadow:0 4px 15px #64ffda4d}}.CV-link a{animation:cvPulse 3s ease-in-out infinite}.CV-link a:hover{animation:none}@media (max-width:768px){.CV-container{margin-bottom:1.5rem}.CV-link a{min-width:160px;padding:.8rem 1.5rem}.CV-link a,.CV-link a:after{font-size:1rem}}@media (max-width:480px){.CV-link a{font-size:.9rem;min-width:140px;padding:.7rem 1.2rem}.CV-link a:after{font-size:.9rem;margin-left:.3rem}}.CV-link{background:linear-gradient(135deg,var(--hover-color),#64ffda);background-clip:initial;border-radius:14px;padding:2px}.CV-link a{background:var(--header-color);border:none;border-radius:12px;color:var(--hover-color)}.CV-link a:hover{background:linear-gradient(135deg,var(--hover-color),#64ffda);color:var(--primary-color)}.mobile-menu-btn{animation:slideInRight .8s ease-out forwards;background:#0000;border:none;cursor:pointer;display:none;flex-direction:column;height:30px;justify-content:space-around;padding:0;width:30px;z-index:101}.mobile-menu-btn span{background:var(--primary-text-color);border-radius:2px;height:3px;transform-origin:center;transition:all .3s ease;width:100%}.mobile-menu-btn.active span:first-child{background:var(--hover-color);transform:rotate(45deg) translate(8px,8px)}.mobile-menu-btn.active span:nth-child(2){opacity:0}.mobile-menu-btn.active span:nth-child(3){background:var(--hover-color);transform:rotate(-45deg) translate(8px,-8px)}.mobile-nav-overlay{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0a192ffa;height:100vh;left:0;opacity:0;position:fixed;top:0;transition:all .3s ease;visibility:hidden;width:100%;z-index:99}.mobile-nav-overlay.active{opacity:1;visibility:visible}.mobile-nav{align-items:center;display:flex;height:100%;justify-content:center;width:100%}.mobile-nav-list{list-style:none;margin:0;padding:0;text-align:center}.mobile-nav-item{margin:1.5rem 0;opacity:0;transform:translateY(30px);transition:all .3s ease}.mobile-nav-overlay.active .mobile-nav-item{opacity:1;transform:translateY(0)}.mobile-nav-overlay.active .mobile-nav-item:first-child{transition-delay:.1s}.mobile-nav-overlay.active .mobile-nav-item:nth-child(2){transition-delay:.2s}.mobile-nav-overlay.active .mobile-nav-item:nth-child(3){transition-delay:.3s}.mobile-nav-overlay.active .mobile-nav-item:nth-child(4){transition-delay:.4s}.mobile-nav-overlay.active .mobile-nav-item:nth-child(5){transition-delay:.5s}.mobile-nav-overlay.active .mobile-nav-item:nth-child(6){transition-delay:.6s}.mobile-nav-overlay.active .mobile-nav-item:nth-child(7){transition-delay:.7s}.mobile-nav-overlay.active .mobile-nav-item:nth-child(8){transition-delay:.8s}.mobile-nav-item a{border-radius:8px;color:var(--primary-text-color);display:block;font-family:var(--font-main);font-size:1.5rem;font-weight:500;padding:1rem 2rem;position:relative;text-decoration:none;transition:all .3s ease}.mobile-nav-item a:hover{background:#64ffda1a;color:var(--hover-color);transform:scale(1.05)}.close-mobile-nav{align-items:center;animation:closeButtonSlideIn .5s ease-out forwards;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0000;background:#64ffda1a;border:2px solid #64ffda4d;border-radius:50%;box-shadow:0 4px 20px #0000004d;cursor:pointer;display:flex;height:50px;justify-content:center;opacity:0;position:absolute;right:2rem;top:2rem;transform:scale(0) rotate(180deg);transition:all .4s cubic-bezier(.4,0,.2,1);width:50px;z-index:102}.mobile-nav-overlay.active .close-mobile-nav{animation-delay:.3s;opacity:1;transform:scale(1) rotate(0deg)}.close-icon{color:var(--primary-text-color);display:block;font-size:1.8rem;font-weight:300;line-height:1;text-align:center;transform:rotate(0deg);transition:all .3s ease}.close-mobile-nav:hover{background:#64ffda33;border-color:var(--hover-color);box-shadow:0 6px 30px #64ffda4d,0 0 0 4px #64ffda1a;transform:scale(1.1) rotate(90deg)}.close-mobile-nav:hover .close-icon{color:var(--hover-color);text-shadow:0 0 10px #64ffda80;transform:rotate(90deg) scale(1.1)}.close-mobile-nav:active{transform:scale(.95) rotate(45deg);transition:transform .1s ease}.close-mobile-nav:before{animation:rotateBorder 3s linear infinite;background:linear-gradient(45deg,var(--hover-color),#0000,var(--hover-color));border-radius:50%;bottom:-2px;content:"";left:-2px;opacity:0;position:absolute;right:-2px;top:-2px;transition:opacity .3s ease;z-index:-1}.close-mobile-nav:hover:before{opacity:.6}.close-mobile-nav:after{background:#64ffda4d;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:all .3s ease;width:0}.close-mobile-nav:active:after{height:60px;opacity:0;width:60px}@keyframes closeButtonSlideIn{0%{opacity:0;transform:scale(0) rotate(180deg)}60%{transform:scale(1.2) rotate(-20deg)}to{opacity:1;transform:scale(1) rotate(0deg)}}@keyframes rotateBorder{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:768px){.close-mobile-nav{height:45px;right:1.5rem;top:1.5rem;width:45px}.close-icon{font-size:1.6rem}}@media (max-width:480px){.close-mobile-nav{height:40px;right:1rem;top:1rem;width:40px}.close-icon{font-size:1.4rem}}.close-mobile-nav.minimal{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff1a;border:none}.close-mobile-nav.minimal:hover{background:#64ffda26;border:1px solid #64ffda4d}.close-mobile-nav.neon{background:#0000;border:2px solid var(--hover-color);box-shadow:0 0 20px #64ffda4d,inset 0 0 20px #64ffda1a}.close-mobile-nav.neon:hover{background:#64ffda1a;box-shadow:0 0 30px #64ffda99,inset 0 0 30px #64ffda33}.close-mobile-nav:focus{border-color:var(--hover-color);box-shadow:0 0 0 3px #64ffda4d;outline:none}.mobile-nav-overlay:not(.active) .close-mobile-nav{opacity:0;pointer-events:none;transform:scale(0) rotate(180deg)}.mobile-nav-overlay.active .close-mobile-nav{animation:closeButtonSlideIn .6s cubic-bezier(.68,-.55,.265,1.55) forwards;animation-delay:.2s}.contact-button,.contact-container{position:relative}.contact-button{align-items:center;animation:slideInRight .6s cubic-bezier(.68,-.55,.265,1.55) forwards;animation-delay:1.4s;background:#0000;border:2px solid var(--hover-color);border-radius:50px;color:var(--hover-color);cursor:pointer;display:flex;font-family:var(--font-mono);font-size:.95rem;font-weight:600;justify-content:center;overflow:hidden;padding:.75rem 1.5rem;transform:scale(0);transition:all .4s cubic-bezier(.4,0,.2,1)}.contact-button:before{background:linear-gradient(90deg,#0000,#64ffda4d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .6s ease;width:100%}.contact-button:hover:before{left:100%}.contact-button:hover{background:var(--hover-color);border-color:var(--hover-color);box-shadow:0 8px 25px #64ffda4d;color:var(--primary-color);transform:translateY(-3px) scale(1.05)}.contact-modal{align-items:center;animation:modalFadeIn .4s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0a192ff2;bottom:0;display:flex;height:100vh;justify-content:center;left:0;padding:2rem;position:fixed;right:0;top:0;width:100vw;z-index:1000}.contact-content{animation:modalSlideIn .4s ease-out;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(145deg,var(--header-color),#112240f2);border:1px solid #64ffda33;border-radius:20px;box-shadow:0 20px 60px #0006,0 0 0 1px #64ffda1a;max-width:500px;padding:3rem;position:relative;width:100%}.contact-content:before{animation:shimmer 3s ease-in-out infinite;background:linear-gradient(90deg,var(--hover-color),#64ffda,var(--hover-color));background-size:200% 100%;border-radius:20px 20px 0 0;content:"";height:4px;left:0;position:absolute;right:0;top:0}.contact-content h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--primary-text-color),var(--hover-color));-webkit-background-clip:text;background-clip:text;color:var(--primary-text-color);font-family:var(--font-mono);font-size:1.8rem;font-weight:700;margin-bottom:1rem;position:relative;text-align:center}.contact-content h3{color:var(--hover-color);font-family:var(--font-main);font-size:1.3rem;font-weight:600;margin-bottom:2rem;opacity:.9;text-align:center}.contact-content p{align-items:center;background:#64ffda0d;border:1px solid #64ffda1a;border-radius:12px;color:var(--primary-text-color);display:flex;font-family:var(--font-main);font-size:1.1rem;gap:.5rem;line-height:1.6;margin-bottom:1.5rem;padding:1rem;transition:all .3s ease}.contact-content p:hover{background:#64ffda1a;border-color:#64ffda4d;transform:translateX(4px)}.contact-content p:last-child{margin-bottom:0}.contact-content a{color:var(--hover-color);font-weight:600;position:relative;text-decoration:none;transition:all .3s ease}.contact-content a:after{background:var(--hover-color);bottom:-2px;content:"";height:2px;left:0;position:absolute;transition:width .3s ease;width:0}.contact-content a:hover{color:#fff;text-shadow:0 0 8px var(--hover-color)}.contact-content a:hover:after{width:100%}.contact-content:after{align-items:center;background:#64ffda1a;border:1px solid #64ffda33;border-radius:50%;color:var(--primary-text-color);content:"×";cursor:pointer;display:flex;font-size:2rem;height:40px;justify-content:center;position:absolute;right:1.5rem;top:1rem;transition:all .3s ease;width:40px}.contact-content:after:hover{background:#64ffda33;color:var(--hover-color);transform:rotate(90deg)}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-50px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@media (max-width:1200px){.header{gap:0;padding:.75rem 1rem}.header-title{flex:1 1;font-size:1.4rem}.toc-item a{font-size:1rem;margin:0;padding:0}.contact-button{font-size:.9rem;padding:.5rem .8rem}}@media (max-width:1335px){.header{min-height:60px;padding:.75rem 1rem}.header-title{font-size:1.5rem}.desktop-nav{display:none}.mobile-menu-btn{display:flex}.contact-text{display:none}.contact-button{border-radius:50%;font-size:0;height:45px;padding:.6rem;position:relative;width:45px}.contact-button:after{content:"✉";font-size:1.2rem;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.contact-modal{padding:1rem}.contact-content{max-width:90%;padding:2rem}.contact-content h2{font-size:1.5rem}.contact-content h3{font-size:1.1rem}.contact-content p{flex-direction:column;font-size:1rem;gap:.25rem;text-align:center}}@media (max-width:480px){.header{min-height:55px;padding:.5rem 1rem}.header-title{font-size:1.3rem}.mobile-menu-btn{height:25px;width:25px}.mobile-menu-btn span{height:2px}.contact-button{height:40px;padding:.5rem;width:40px}.contact-button:after{font-size:1rem}.mobile-nav-item a{font-size:1.3rem;padding:.8rem 1.5rem}.contact-content{border-radius:15px;padding:1.5rem}.contact-content h2{font-size:1.3rem}.contact-content p{font-size:.75rem;padding:.8rem}}@media screen and (max-width:300px){.contact-content{padding:1rem .5rem}.contact-content p{font-size:.65rem;overflow:hidden;padding:.8rem}.CV-container .CV-link a{font-size:.8rem;margin:0;padding:.5rem 0}.CV-container{overflow:hidden;padding:0}}@keyframes headerSlideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-50px)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(50px)}to{opacity:1;transform:translateX(0)}}.about{align-items:center;background-color:var(--primary-color);contain:layout style;display:flex;justify-content:center;min-height:100vh;padding:4rem 2rem}.about-container{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 1fr;max-width:1200px;width:100%}.about-left{display:flex;flex-direction:column;justify-content:center}.about-left-title-name{color:var(--primary-text-color);font-family:var(--font-mono);font-size:3.5rem;font-weight:700;letter-spacing:-1px;line-height:1.1;margin-bottom:1rem}.about-left-title-description{color:var(--hover-color);font-family:var(--font-main);font-size:1.5rem;font-weight:400;line-height:1.4;margin-bottom:2rem}.about-left-title-content{animation:none;color:#8892b0;font-family:var(--font-main);font-size:1.1rem;font-weight:400;line-height:1.6;max-width:500px;opacity:1;transform:none}.about-left-title-content,.about-left-title-name{animation:slideRight .8s ease-out forwards;opacity:0}.about-left-title-content{animation-delay:.6s}.about-left-title-description{animation:slideRight .8s ease-out forwards;animation-delay:.4s;opacity:0}.about-right{align-items:center;display:flex;justify-content:center}.about-right-container{align-items:center;display:flex;flex-direction:column;gap:2rem}.avatar-container{height:300px;position:relative;width:300px}.avatar{animation:scaleToMax .8s ease-out forwards;border:3px solid var(--hover-color);border-radius:50%;box-shadow:0 0 30px #64ffda4d;height:100%;object-fit:cover;transition:all .3s ease;width:100%}.avatar:hover{box-shadow:0 0 40px #64ffda80;cursor:pointer;transform:scale(1.05) rotate(2deg)}.social-links-container{max-width:400px;width:100%}.social-links{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.linkUnit{align-items:center;animation:fadeInUp .6s ease-out;animation-delay:0s;animation-delay:var(--animation-delay,0s);background-color:#11224099;border:1px solid #0000;border-radius:8px;display:flex;flex-direction:column;overflow:hidden;padding:1rem .5rem;position:relative;text-decoration:none;transition:all .3s ease}.linkUnit:before{border-radius:8px;content:"";height:100%;left:-100%;opacity:0;position:absolute;top:0;transition:all .4s cubic-bezier(.25,.8,.25,1);width:100%}.linkUnit:before,.linkUnit:hover{background-color:var(--background-hover-color)}.linkUnit:hover{border-color:var(--hover-color);transform:translateY(-2px)}.linkUnit:hover:before{left:0;opacity:1}.socialIcon{aspect-ratio:1;height:32px;margin-bottom:.5rem;object-fit:contain;transition:all .3s ease;width:32px}.linkUnit:hover .socialIcon{transform:scale(1.2)}.socialLabel{color:var(--primary-text-color);font-family:var(--font-main);font-size:.85rem;font-weight:500;text-align:center;transition:color .3s ease}.linkUnit:hover .socialLabel{color:var(--hover-color);font-weight:800}.HCMUT{color:var(--hover-color);display:inline-block;font-weight:600;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.HCMUT:after{background:linear-gradient(90deg,var(--hover-color),var(--hover-color-transparent));border-radius:1px;bottom:-2px;content:"";height:4px;left:0;position:absolute;transition:width .4s cubic-bezier(.4,0,.2,1);width:0}.HCMUT:hover{cursor:pointer;transform:translateY(-2px)}.HCMUT:hover:after{width:100%}@media (max-width:768px){.about{min-height:auto;padding:2rem 1rem}.about-container{gap:3rem;grid-template-columns:1fr;text-align:center}.about-left-title-name{font-size:2.5rem}.about-left-title-description{font-size:1.2rem}.about-left-title-content{font-size:1rem;max-width:100%}.avatar-container{height:250px;width:250px}.social-links{gap:.8rem;grid-template-columns:repeat(2,1fr);min-width:60vw}.linkUnit{padding:.8rem .4rem}.socialIcon{height:28px;width:28px}.socialLabel{font-size:.8rem}}@media (max-width:480px){.about{padding:1.5rem .5rem}.about-container{gap:2rem}.about-left-title-name{font-size:2rem}.about-left-title-description{font-size:1rem;margin-bottom:1.5rem}.about-left-title-content{font-size:.9rem}.avatar-container{height:200px;width:200px}.social-links{gap:.6rem;grid-template-columns:repeat(2,1fr);min-width:80vw}.linkUnit{padding:.6rem .3rem}.socialIcon{height:24px;width:24px}.socialLabel{font-size:.75rem}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideRight{0%{opacity:0;transform:translateX(-100%)}to{opacity:1;transform:translateX(0)}}@keyframes scaleToMax{0%{opacity:0;rotate:-180deg;transform:scale(0)}to{opacity:1;rotate:0deg;transform:scale(1)}}@media (prefers-reduced-motion:no-preference){.about-left-title-content{animation:slideRight .6s ease-out forwards;animation-delay:.3s;opacity:0}}.loading-spinner-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:200px;padding:2rem}.loading-spinner-container.small{min-height:100px;padding:1rem}.loading-spinner-container.large{min-height:400px;padding:4rem}.spinner-ring{display:inline-block;height:64px;position:relative;width:64px}.loading-spinner-container.small .spinner-ring{height:32px;width:32px}.loading-spinner-container.large .spinner-ring{height:96px;width:96px}.spinner-ring div{animation:spinner-ring 1.2s cubic-bezier(.5,0,.5,1) infinite;border:6px solid var(--hover-color);border-color:var(--hover-color) #0000 #0000 #0000;border-radius:50%;box-sizing:border-box;display:block;height:51px;margin:6px;position:absolute;width:51px}.loading-spinner-container.small .spinner-ring div{border-width:3px;height:26px;margin:3px;width:26px}.loading-spinner-container.large .spinner-ring div{border-width:9px;height:77px;margin:9px;width:77px}.spinner-ring div:first-child{animation-delay:-.45s}.spinner-ring div:nth-child(2){animation-delay:-.3s}.spinner-ring div:nth-child(3){animation-delay:-.15s}@keyframes spinner-ring{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-text{animation:pulse 2s ease-in-out infinite;color:var(--primary-text-color);font-family:var(--font-mono);font-size:.9rem;margin-top:1rem;opacity:.8}.loading-spinner-container.small .loading-text{font-size:.8rem;margin-top:.5rem}.loading-spinner-container.large .loading-text{font-size:1.1rem;margin-top:1.5rem}@keyframes pulse{0%,to{opacity:.8}50%{opacity:.4}}.loading-spinner.dots{display:flex;gap:.5rem}.loading-spinner.dots div{animation:dots-bounce 1.4s ease-in-out infinite both;background:var(--hover-color);border-radius:50%;height:12px;width:12px}.loading-spinner.dots div:first-child{animation-delay:-.32s}.loading-spinner.dots div:nth-child(2){animation-delay:-.16s}@keyframes dots-bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.error-boundary{align-items:center;background:#ff453a1a;border:1px solid #ff453a4d;border-radius:12px;display:flex;justify-content:center;margin:2rem 0;min-height:300px;padding:2rem}.error-content{color:var(--primary-text-color);text-align:center}.error-content h2{color:#ff453a;font-family:var(--font-mono);margin-bottom:1rem}.error-content p{margin-bottom:1.5rem;opacity:.8}.retry-button{background:var(--hover-color);border:none;border-radius:8px;color:var(--primary-color);cursor:pointer;font-weight:600;padding:.8rem 1.5rem;transition:all .3s ease}.retry-button:hover{background:#64ffda;transform:translateY(-2px)}
/*# sourceMappingURL=main.3498ae05.css.map*/