:root{--black:#000;--white:#fff;--light-gray:#f5f5f5;--border-gray:#e0e0e0;--medium-gray:#ccc;--text-gray:#666;--hover-gray:#333;--text-primary:#fff;--text-secondary:#fffffff2;--text-muted:#ffffffe0;--orbit-z-index:-1;--orbit-background-opacity:.3;--home-max-width:70vw;--home-section-gap:2rem;--home-padding-x:clamp(1.5rem,4vw,3rem);--home-padding-y:clamp(2rem,5vw,4rem);--glass-bg:linear-gradient(165deg,#121628e0 0%,#080a18eb 50%,#0c1020e6 100%);--glass-border:1px solid #ffffff38;--glass-shadow:0 8px 32px #0006,inset 0 1px 0 #ffffff1f;--glass-blur:blur(24px)saturate(1.2)}html{scroll-behavior:smooth}html,body{max-width:100vw;overflow-x:hidden}body{color:var(--text-primary);background:var(--gradient-hero-bg);font-family:var(--font-roboto),sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-shadow:0 1px 2px #0006;scroll-behavior:smooth;background-attachment:fixed;margin:0;line-height:1.6}#projects,#contact,#about,#writings{scroll-margin-top:var(--header-height,64px)}*{box-sizing:border-box;margin:0;padding:0}a{color:inherit;text-decoration:none;transition:color .2s}a:hover{color:var(--text-secondary)}.App{text-align:center;z-index:0;min-height:100vh;padding-top:var(--header-height);flex-direction:column;display:flex;position:relative}.App__main{flex:1}.wip-banner{color:var(--text-primary);font-family:var(--font-roboto),sans-serif;text-align:center;letter-spacing:.05em;text-transform:uppercase;background:0 0;padding:.75rem;font-size:clamp(.8rem,2.5vw,.9rem);font-weight:500}.layout-stats{max-width:420px;margin:0 auto;padding:.75rem 1.5rem}.orbitBackground{width:100vw;height:100vh;z-index:var(--orbit-z-index);pointer-events:none;position:fixed;top:0;left:0}.orbitBackground canvas{cursor:default;width:100%;height:100%;display:block;pointer-events:auto!important}
.header{z-index:var(--z-sticky);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border-bottom:var(--glass-border);box-shadow:var(--glass-shadow);color:var(--text-primary);position:fixed;top:0;left:0;right:0}.header__container{max-width:var(--container-2xl);padding:var(--header-padding-y)var(--header-padding-x);justify-content:space-between;align-items:center;gap:var(--space-lg);margin:0 auto;display:flex}.header__logo{font-size:var(--text-xl);font-weight:var(--font-light);color:var(--text-primary);transition:var(--transition-fast);text-decoration:none}.header__logo:hover{color:var(--color-primary)}.header__nav{align-items:center;gap:clamp(.75rem,2vw,1.5rem);display:flex}.header__link{font-size:var(--text-sm);color:var(--text-secondary);padding:var(--space-sm)var(--space-md);border-radius:var(--radius-md);transition:var(--transition-fast);text-decoration:none}.header__link:hover{color:var(--text-primary);background:#ffffff0d}.header__link--active{color:var(--color-primary);font-weight:var(--font-medium)}.header__link--cta{color:var(--color-primary);font-weight:var(--font-medium);background:#00d9ff1a;border:1px solid #00d9ff4d}.header__link--cta:hover{background:var(--color-primary);color:#000;transform:translateY(-2px)}.header__back{margin-left:var(--space-md);padding:var(--space-sm)var(--space-md);border-radius:var(--radius-md);color:#000;font-size:var(--text-sm);font-weight:var(--font-medium);transition:var(--transition-fast);white-space:nowrap;background:#fff;text-decoration:none}.header__back:hover{opacity:.95;background:#fffffff2}@media (max-width:1023px){.header__nav{gap:var(--space-sm)}.header__link{font-size:var(--text-xs);padding:var(--space-xs)var(--space-sm)}}@media (max-width:767px){.header__container{gap:var(--space-sm);flex-direction:column}.header__nav{justify-content:center;width:100%}}
.footer{background-color:#0000;border-top:1px solid #ffffff4d;flex-wrap:wrap;justify-content:center;gap:.5rem 2rem;margin-top:auto;padding:1.25rem 1rem;display:flex}.footer a{color:var(--text-primary);font-family:var(--font-roboto),sans-serif;letter-spacing:.03em;text-transform:uppercase;padding:.5rem .75rem;font-size:clamp(.85rem,2.5vw,.95rem);font-weight:500;text-decoration:none;transition:color .2s}.footer a:hover{color:var(--text-secondary)}.footer a:active{color:var(--text-primary)}.footer .navbar__auth{color:#22c55e;justify-content:center;align-items:center;padding:.5rem .75rem;font-size:1.25rem;animation:.35s ease-out nav-auth-pop;display:inline-flex}.footer .navbar__auth--loading{color:var(--text-primary);font-size:1rem;animation:none}@keyframes nav-auth-pop{0%{opacity:0;transform:scale(0)}60%{opacity:1;transform:scale(1.15)}to{opacity:1;transform:scale(1)}}@media (max-width:480px){.footer{gap:.25rem 1rem;padding:1rem .5rem}.footer a{padding:.4rem .5rem}}
.home-section{width:100%;max-width:100%;margin:0 auto}.hero-section{min-height:var(--hero-min-height);width:100%;padding:var(--space-4xl)var(--home-padding-x);z-index:var(--z-base);justify-content:center;align-items:center;display:flex;position:relative}.hero-section__container{max-width:var(--container-2xl);gap:var(--space-4xl);grid-template-columns:1fr 1fr;align-items:center;width:100%;display:grid}.hero-section__content{max-width:var(--hero-content-max-width);text-align:left;z-index:1}.hero-section__title{font-size:var(--text-4xl);font-weight:var(--font-light);color:var(--text-primary);margin:0 0 var(--space-md)0;letter-spacing:var(--tracking-tight);line-height:1.2;font-family:var(--font-roboto),sans-serif;text-shadow:0 0 30px #00d9ff4d}.hero-section__subtitle{font-size:var(--text-lg);font-weight:var(--font-normal);color:var(--text-secondary);margin:0 0 var(--space-xl)0;line-height:var(--leading-relaxed);font-family:var(--font-roboto),sans-serif}.hero-section__description{font-size:var(--text-base);color:var(--text-muted);line-height:var(--leading-loose);margin:0 0 var(--space-2xl)0;font-family:var(--font-roboto),sans-serif}.hero-section__actions{gap:var(--space-lg);flex-wrap:wrap;display:flex}.hero-button{padding:var(--space-md)var(--space-2xl);font-size:var(--text-base);font-weight:var(--font-medium);border-radius:var(--radius-lg);transition:var(--transition-base);cursor:pointer;white-space:nowrap;font-family:var(--font-roboto),sans-serif;justify-content:center;align-items:center;text-decoration:none;display:inline-flex}.hero-button--primary{background:var(--button-primary-bg);color:#000;box-shadow:var(--glow-button);border:none}.hero-button--primary:hover{background:var(--button-primary-hover);transform:translateY(-3px);box-shadow:0 6px 30px #00d9ff80,0 0 50px #00d9ff4d}.hero-button--secondary{background:var(--button-secondary-bg);color:var(--color-primary);border:2px solid var(--button-secondary-border);-webkit-backdrop-filter:blur(10px)}.hero-button--secondary:hover{background:var(--button-secondary-hover-bg);border-color:var(--color-primary);transform:translateY(-3px);box-shadow:0 4px 20px #00d9ff4d}.hero-section__visual{width:100%;height:var(--hero-visual-size);justify-content:center;align-items:center;display:flex;position:relative}.hero-section__avatar{width:var(--hero-visual-size);height:var(--hero-visual-size);object-fit:cover;object-position:center;z-index:1;border-radius:50%;position:relative}.hero-section__visual-glow{width:var(--hero-visual-size);height:var(--hero-visual-size);filter:blur(40px);background:radial-gradient(circle,#00d9ff33 0%,#a78bfa26 50%,#0000 70%);border-radius:50%;animation:4s ease-in-out infinite heroPulse;position:absolute}@keyframes heroPulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}@media (max-width:1023px){.hero-section{padding:var(--space-3xl)var(--space-xl)}.hero-section__container{gap:var(--space-3xl);text-align:center;grid-template-columns:1fr}.hero-section__content{text-align:center;order:2;max-width:100%}.hero-section__visual{order:1}.hero-section__title{font-size:var(--text-3xl)}.hero-section__subtitle{font-size:var(--text-base)}.hero-section__description{font-size:var(--text-sm)}}@media (max-width:767px){.hero-section{min-height:auto;padding:var(--space-2xl)var(--space-md)}.hero-section__container{gap:var(--space-2xl)}.hero-section__visual{height:250px}.hero-section__title{display:none}.hero-section__subtitle{font-size:var(--text-sm)}.hero-section__description{font-size:var(--text-xs)}.hero-section__actions{flex-direction:column;justify-content:center;align-items:stretch}.hero-button{width:100%}.hero-section__avatar,.hero-section__visual-glow{width:250px;height:250px}}@media (max-width:480px){.hero-section{padding:var(--space-xl)var(--space-sm)}.hero-button{padding:var(--space-sm)var(--space-lg);font-size:var(--text-sm)}}.home-section .projects-section,.home-section .about-section,.home-section .resume-section,.home-section .contact-section,.home-section .writings-section,.home-section #about,.home-section #writings,.home-section #resume,.home-section #contact{padding:var(--home-padding-y)var(--home-padding-x);padding-bottom:var(--home-section-gap);max-width:var(--container-2xl);margin-left:auto;margin-right:auto}.home-section .about-section,.home-section .resume-section,.home-section .contact-section{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);box-shadow:var(--glass-shadow);margin-top:0;margin-bottom:var(--home-section-gap);text-align:left;border-radius:16px;padding:clamp(1.5rem,4vw,2.5rem)}.home-section .resume-section,.home-section .contact-section{text-align:center}.about-section{text-align:left}.about-section h2{font-family:var(--font-roboto),sans-serif;color:var(--text-primary);text-align:center;margin:0 0 2rem;font-size:clamp(1.5rem,3.5vw,2rem);font-weight:400}.about-section h2:after{content:"";background:var(--text-primary);width:40px;height:1px;margin:1rem auto 0;display:block}.about-section__heading{font-family:var(--font-geist-sans),var(--font-roboto),sans-serif;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-cyan,#00d9ff);opacity:.92;margin:2.5rem 0 1rem;font-size:clamp(1rem,2.25vw,1.2rem);font-weight:600}.about-section__heading:first-child{margin-top:0}.about-section__paragraph{font-family:var(--font-roboto),sans-serif;letter-spacing:.02em;color:var(--text-secondary);margin:.6rem 0;font-size:clamp(1rem,2.2vw,1.125rem);line-height:1.85}.about-section__list{margin:1.25rem 0;padding:0;list-style:none}.about-section__item{color:var(--text-secondary);letter-spacing:.02em;border-bottom:1px solid #ffffff2e;margin:0;padding:1rem 0;font-size:clamp(1rem,2.2vw,1.1rem);line-height:1.7;transition:color .2s}.about-section__item:last-child{border-bottom:none}.about-section__item:hover{color:var(--text-primary)}.about-section__item strong{color:var(--text-primary);font-weight:600}.pop-in-word{opacity:0;display:inline-block;transform:scale(.88)translateY(8px)}.pop-in-word--visible{animation:.55s cubic-bezier(.34,1.56,.64,1) forwards aboutWordPop}@keyframes aboutWordPop{0%{opacity:0;transform:scale(.88)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}@media (prefers-reduced-motion:reduce){.pop-in-word{opacity:1;transform:none}.pop-in-word--visible{animation:none}}.projects-section{width:100%;margin:0 auto var(--home-section-gap)}.projects-section__title{font-family:var(--font-roboto),sans-serif;letter-spacing:-.02em;color:var(--text-primary);text-align:center;margin:0 0 1rem;font-size:clamp(2.25rem,6vw,3.25rem);font-weight:300}.projects-carousel{width:100%;padding:0}.projects-carousel .ant-carousel,.projects-carousel .slick-slider,.projects-carousel .slick-list,.projects-carousel .slick-track{width:100%!important}.projects-carousel .slick-slide>div{width:100%}.projects-carousel .ant-carousel .slick-dots li button{opacity:.4;background:#000!important}.projects-carousel .ant-carousel .slick-dots li button:after{background:0 0!important}.projects-carousel .ant-carousel .slick-dots li.slick-active button{opacity:1;background:#000!important}.projects-carousel .ant-carousel .slick-dots li.slick-active button:after{background:#000!important}.home-section .writings-section{min-height:auto;margin-bottom:var(--home-section-gap);padding:0}.home-section .writings-section__card{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);box-shadow:var(--glass-shadow);border-radius:16px;max-width:100%;margin-bottom:0;padding:clamp(1.5rem,4vw,2.5rem)}.home-section .writings-title{font-family:var(--font-roboto),sans-serif;letter-spacing:-.02em;color:var(--text-primary);text-align:center;margin:0 0 clamp(2rem,4vw,3rem);font-size:clamp(2rem,5vw,2.5rem);font-weight:300}.contact-section{text-align:center}.contact-section .MuiGrid-container{align-items:stretch}.contact-section .MuiGrid-item{display:flex}.contact-section h2{font-family:var(--font-roboto),sans-serif;color:var(--text-primary);margin:0 0 2rem;font-size:clamp(1.5rem,3.5vw,2rem);font-weight:400}.contact-section h2:after{content:"";background:var(--text-primary);width:40px;height:1px;margin:1rem auto 0;display:block}.contact-links{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.contact-links-box .contact-links{flex-direction:column;flex:1;align-items:stretch;gap:.75rem;min-height:0;display:flex}.contact-links-box .contact-links a,.contact-links-box .contact-links p{justify-content:center;margin:0}.contact-links a{color:var(--text-primary,#fff);font-family:var(--font-roboto),sans-serif;letter-spacing:.03em;text-transform:uppercase;background:0 0;border:1px solid #ffffff80;border-radius:8px;align-items:center;gap:.5rem;padding:.75rem 1.75rem;font-size:clamp(.85rem,2vw,.9rem);font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.contact-links a:hover{color:var(--text-primary);background:#ffffff26}.contact-form-box{text-align:left;box-sizing:border-box;background:#ffffff0f;border:1px solid #fff3;border-radius:12px;width:100%;min-height:100%;padding:clamp(1.25rem,3vw,1.75rem)}.contact-links-box{flex-direction:column;display:flex}.contact-form{flex-direction:column;gap:.75rem;display:flex}.contact-form label{font-family:var(--font-roboto),sans-serif;color:var(--text-primary);font-size:.9rem;font-weight:500}.contact-form input,.contact-form textarea{font-family:var(--font-roboto),sans-serif;color:var(--text-primary);box-sizing:border-box;background:#ffffff14;border:1px solid #ffffff40;border-radius:8px;width:100%;padding:.65rem .85rem;font-size:1rem}.contact-form input::placeholder,.contact-form textarea::placeholder{color:var(--text-secondary);opacity:.8}.contact-form textarea{resize:vertical;min-height:5rem}.contact-form button{font-family:var(--font-roboto),sans-serif;text-transform:uppercase;letter-spacing:.04em;color:var(--text-primary);cursor:pointer;background:#ffffff1f;border:1px solid #fff6;border-radius:8px;margin-top:.25rem;padding:.75rem 1.5rem;font-size:.9rem;font-weight:500;transition:background .2s,border-color .2s}.contact-form button:hover:not(:disabled){background:#fff3;border-color:#ffffff80}.contact-form button:disabled{opacity:.7;cursor:not-allowed}.contact-form-message{margin:0;font-size:.9rem}.contact-form-success{color:var(--text-primary)}.contact-form-error{color:#f87171}@media (max-width:768px){.home-section{width:100%;max-width:100%;padding:clamp(1rem,4vw,2rem) clamp(1rem,4vw,1.5rem)}.home-section .about-section,.home-section .resume-section,.home-section .contact-section{border-radius:0;padding:clamp(1.25rem,4vw,2rem)}.about-section h2{font-size:clamp(1.35rem,4.5vw,1.75rem)}.about-section__heading{letter-spacing:.1em;font-size:clamp(.9rem,2.5vw,1.05rem)}.about-section__paragraph,.about-section__item{font-size:clamp(.95rem,2.5vw,1.05rem)}.contact-section h2{font-size:clamp(1.35rem,4.5vw,1.75rem)}.contact-links a{padding:clamp(.6rem,2.5vw,.75rem) clamp(1.25rem,4vw,1.75rem);font-size:clamp(.8rem,2.5vw,.9rem)}.home-section .projects-section{width:100%;max-width:100%;margin-left:0;margin-right:0;padding-left:0;padding-right:0}.projects-section__title{padding:0 clamp(1rem,4vw,1.5rem);font-size:clamp(1.5rem,6vw,2rem)}.projects-carousel{width:100%}.home-section .writings-section__card{border-radius:0;padding:clamp(1.25rem,4vw,2rem)}.home-section .writings-title{font-size:clamp(1.5rem,5vw,2rem)}}.hero-section__content{animation:.8s ease-out fadeInUp}.hero-section__visual{animation:1s ease-out .3s both fadeIn}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.hero-button:active{transform:translateY(-1px)scale(.98)}.hero-section__title,.hero-section__subtitle,.hero-section__description{transition:color var(--transition-base)}.hero-section__title:hover{text-shadow:0 0 40px #00d9ff80}
.resume-button{color:var(--text-primary);font-family:var(--font-roboto),sans-serif;letter-spacing:.03em;text-transform:uppercase;cursor:pointer;background:0 0;border:1px solid #ffffff80;border-radius:0;align-items:center;gap:.5rem;padding:1rem 2rem;font-size:clamp(.85rem,2vw,.9rem);font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.resume-button:hover{background:#ffffff26;border-color:#fff9}.resume-viewer{max-width:800px;margin:0 auto;padding:clamp(2rem,4vw,3rem)}.resume-back-button{color:var(--text-primary);cursor:pointer;font-family:var(--font-roboto),sans-serif;letter-spacing:.02em;background:0 0;border:1px solid #ffffff80;border-radius:0;align-items:center;gap:.5rem;margin-bottom:2rem;padding:.6rem 1.2rem;font-size:clamp(.8rem,2vw,.85rem);font-weight:500;transition:all .2s;display:inline-flex}.resume-back-button:hover{background:#ffffff1a;border-color:#fff9}.resume-title{font-family:var(--font-roboto),sans-serif;color:var(--text-primary);margin-bottom:2rem;font-size:clamp(1.5rem,3.5vw,2rem);font-weight:400}.resume-pdf-container{background:0 0;border:1px solid #ffffff4d;border-radius:0;width:100%;max-width:100%;max-height:80vh;margin:0 auto;padding:0;overflow:hidden}.resume-pdf-iframe{border:none;width:100%;min-height:75vh;display:block}
.writings-section{padding:var(--home-padding-y)var(--home-padding-x);flex-direction:column;justify-content:center;width:100%;min-height:100vh;display:flex}.writings-section__card{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);box-shadow:var(--glass-shadow);max-width:var(--container-2xl);border-radius:16px;margin:0 auto;padding:clamp(1.5rem,4vw,2.5rem)}.writings-title{font-family:var(--font-roboto),sans-serif;color:var(--text-primary);letter-spacing:-.02em;text-align:center;margin-bottom:clamp(2rem,4vw,3rem);font-size:clamp(2rem,5vw,2.5rem);font-weight:300;line-height:1.2}.carousel-container{-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;width:100%;overflow:auto hidden}.carousel-container::-webkit-scrollbar{display:none}.essays-track{gap:clamp(1.5rem,3vw,2rem);width:max-content;padding:1rem clamp(1rem,3vw,2rem);display:flex}.essay-card{cursor:pointer;flex:none;width:clamp(280px,50vw,400px);transition:transform .3s,box-shadow .3s,opacity .5s}.essay-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #ffffff26}.essay-card.fade-out{opacity:0;pointer-events:none;transform:scale(.95)}.essay-card.selected{opacity:1;z-index:10;transform:scale(1.05)}.essay-card-cover{object-fit:cover;border:1px solid #ffffff4d;width:100%;height:auto;display:block}.writings-title.fade-out{opacity:0;transition:opacity .4s}.writings-title.fade-in{animation:.4s fadeIn}.writings-section.transitioning{pointer-events:none}.essay-card.fade-in{animation:.5s forwards cardFadeIn}.essay-card.selected-reverse{opacity:1;animation:.5s forwards cardDeselect;transform:scale(1)}@keyframes cardFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes cardDeselect{0%{transform:scale(1.05)}to{transform:scale(1)}}.writings-reader{max-width:var(--container-2xl);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);box-shadow:var(--glass-shadow);border-radius:16px;margin:0 auto;padding:5rem clamp(2rem,4vw,3rem) clamp(2rem,4vw,3rem)}.writings-reader .cover-back-button{z-index:var(--z-sticky);margin-bottom:0;position:fixed;bottom:2rem;left:50%;transform:translate(-50%)}.writings-reader .cover-back-button:hover{transform:translate(-50%,-3px)}.writings-reader.fade-in{animation:.5s fadeIn}.writings-reader.fade-out{animation:.4s forwards fadeOut}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.reader-cover-container{justify-content:center;margin-bottom:2rem;display:flex}.reader-cover{border:1px solid #ffffff4d;width:clamp(200px,40vw,300px);height:auto;animation:.6s slideDown;box-shadow:0 8px 32px #ffffff1a}.fade-in-delayed{animation:.5s .3s both fadeIn}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.writings-reader-title{font-family:var(--font-roboto),sans-serif;color:var(--text-primary);margin-bottom:1.5rem;font-size:clamp(1.5rem,3.5vw,2rem);font-weight:400}.essay-title{font-family:var(--font-roboto),sans-serif;color:var(--text-primary);margin-bottom:1.5rem;font-size:clamp(1.25rem,3vw,1.5rem);font-weight:500}.writings-reader.docx-reader{max-width:1000px;padding:clamp(2rem,5vw,4rem)}.docx-container{text-align:left;background:0 0;max-width:100%;margin:0 auto;padding:0;overflow:hidden visible}.docx-content{font-family:var(--font-roboto),sans-serif;letter-spacing:.02em;color:var(--text-secondary);max-width:75ch;font-size:clamp(1rem,2.2vw,1.125rem);line-height:1.85}.docx-content p{margin-bottom:1.5rem}.docx-content h1,.docx-content h2,.docx-content h3{font-family:var(--font-geist-sans),var(--font-roboto),sans-serif;letter-spacing:.02em;color:var(--text-primary);margin-top:2.5rem;margin-bottom:1rem;font-weight:600}.docx-content h1{font-size:clamp(1.5rem,4vw,2rem)}.docx-content h2{font-size:clamp(1.3rem,3.5vw,1.6rem)}.docx-content strong{color:var(--text-primary)}.docx-content em{color:var(--text-secondary);font-style:italic}.docx-loading,.docx-error{font-family:var(--font-roboto),sans-serif;color:var(--text-primary);text-align:center;padding:2rem;font-size:clamp(.95rem,2vw,1rem)}
.chat-fab{-webkit-backdrop-filter:blur(12px);color:#fffffff2;cursor:pointer;z-index:1000;background:#ffffff14;border:1px solid #ffffff40;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;transition:transform .2s,box-shadow .2s,background .2s;display:flex;position:fixed;bottom:24px;right:24px}.chat-fab:hover{background:#ffffff24;transform:scale(1.08);box-shadow:0 8px 24px #00000040}.chat-window{-webkit-backdrop-filter:blur(20px);z-index:1000;background:#0c0e12d9;border:1px solid #ffffff1f;border-radius:16px;flex-direction:column;width:360px;height:480px;animation:.25s ease-out chatSlideIn;display:flex;position:fixed;bottom:24px;right:24px;overflow:hidden;box-shadow:0 12px 40px #0006}@keyframes chatSlideIn{0%{opacity:0;transform:translateY(12px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.chat-header{font-family:var(--font-geist-sans),var(--font-roboto),sans-serif;background:#ffffff08;border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;display:flex}.chat-personas{flex:1;gap:6px;min-width:0;display:flex}.chat-persona{color:#ffffffb3;font-family:var(--font-geist-sans),var(--font-roboto),sans-serif;letter-spacing:.06em;cursor:pointer;white-space:nowrap;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:6px;min-width:0;padding:8px 12px;font-size:.85rem;font-weight:500;transition:all .18s;display:flex}.chat-persona:hover{color:#fffffff2;background:#ffffff1a;border-color:#fff3}.chat-persona.active{color:#fff;background:#ffffff24;border-color:#ffffff4d;box-shadow:0 2px 8px #00000026}.chat-persona span{text-overflow:ellipsis;overflow:hidden}.chat-header-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.chat-expand,.chat-close{color:#ffffffb3;cursor:pointer;background:0 0;border:1px solid #ffffff1a;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:all .18s;display:flex}.chat-expand:hover,.chat-close:hover{color:#fff;background:#ffffff1a;border-color:#fff3}.chat-messages{scroll-behavior:smooth;min-height:0;font-family:var(--font-roboto),sans-serif;flex-direction:column;flex:1;justify-content:flex-start;align-items:flex-start;gap:12px;padding:16px;display:flex;overflow-y:auto}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:0 0}.chat-messages::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:#ffffff40}.chat-message{word-wrap:break-word;border-radius:14px;flex-direction:column;gap:4px;width:fit-content;max-width:88%;padding:12px 14px;animation:.2s ease-out messageFadeIn;display:flex}@keyframes messageFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.chat-message.user{color:#fff;background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%);border-bottom-right-radius:4px;align-self:flex-end;box-shadow:0 2px 8px #2563eb59}.chat-message.compositor{color:#fffffff2;background:#ffffff14;border:1px solid #ffffff1a;border-bottom-left-radius:4px;align-self:flex-start}.chat-message-text{font-family:var(--font-roboto),sans-serif;letter-spacing:.02em;color:var(--text-primary,#fff);margin:0;font-size:.95rem;line-height:1.7}.chat-markdown{font-family:var(--font-roboto),sans-serif;letter-spacing:.02em;width:100%;color:var(--text-primary,#fff);font-size:.95rem;line-height:1.7}.chat-markdown__p{margin:0 0 .6em}.chat-markdown__p:last-child{margin-bottom:0}.chat-markdown__strong{color:var(--text-primary,#fff);text-shadow:0 0 16px #00d9ff80,0 0 4px #00d9ff4d;font-weight:600}.chat-markdown__em{letter-spacing:.02em;color:var(--text-secondary,#fffffff2);opacity:.95;text-shadow:0 0 12px #a78bfa40;font-style:italic;font-weight:500}.chat-markdown__ul,.chat-markdown__ol{margin:.5em 0;padding-left:1.4em}.chat-markdown__ul{list-style-type:disc}.chat-markdown__ol{list-style-type:decimal}.chat-markdown__li{margin:.25em 0}.chat-markdown__code-inline{font-size:.9em;font-family:var(--font-geist-mono),monospace;color:#fffffff2;background:#00d9ff26;border:1px solid #00d9ff59;border-radius:4px;padding:.15em .4em}.chat-markdown__pre{background:#00d9ff14;border:1px solid #00d9ff4d;border-radius:8px;margin:.6em 0;padding:.75em 1em;font-size:.85em;overflow-x:auto}.chat-markdown__code-block{font-family:var(--font-geist-mono),monospace;color:var(--text-primary,#fff);background:0 0;padding:0}.chat-markdown__a{color:var(--accent-cyan,#00d9ff);text-underline-offset:2px;-webkit-text-decoration:underline #00d9ffb3;text-decoration:underline #00d9ffb3}.chat-markdown__a:hover{text-shadow:0 0 12px #00d9ff66;-webkit-text-decoration-color:var(--accent-cyan,#00d9ff);text-decoration-color:var(--accent-cyan,#00d9ff)}.chat-markdown__h1,.chat-markdown__h2,.chat-markdown__h3{color:var(--text-primary,#fff);text-shadow:0 0 20px #00d9ff73,0 0 6px #00d9ff40;margin:.8em 0 .4em;font-weight:600;line-height:1.3}.chat-markdown__h1{font-size:1.15em}.chat-markdown__h2{font-size:1.08em}.chat-markdown__h3{font-size:1em}.chat-markdown__blockquote{opacity:.98;background:#00d9ff0a;border-left:3px solid #00d9ff99;border-radius:0 6px 6px 0;margin:.5em 0;padding:.5em .75em .5em 1em}.chat-message-time{font-family:var(--font-roboto),sans-serif;letter-spacing:.03em;opacity:.75;align-self:flex-end;font-size:.7rem}.chat-message--loading .chat-message-time{display:none}.chat-input-wrap{background:#ffffff08;border-top:1px solid #ffffff14;gap:8px;padding:14px 16px;display:flex}.chat-input,.chat-send{font-family:var(--font-roboto),sans-serif}.chat-input{color:#fff;letter-spacing:.02em;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:12px;flex:1;min-width:0;padding:12px 16px;font-size:16px;line-height:1.5;transition:border-color .2s,background .2s}.chat-input::placeholder{color:#ffffff73;letter-spacing:.02em}.chat-input:hover{background:#ffffff14;border-color:#ffffff2e}.chat-input:focus{border-color:#ffffff59;outline:none;box-shadow:0 0 0 2px #ffffff14}.chat-send{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%);border:none;border-radius:12px;justify-content:center;align-items:center;width:44px;min-width:44px;height:44px;padding:0;transition:transform .15s,box-shadow .15s,opacity .15s;display:flex}.chat-send:hover{opacity:.95;transform:scale(1.04);box-shadow:0 4px 14px #2563eb73}.chat-send:active{transform:scale(.98)}.chat-send:disabled{opacity:.6;cursor:not-allowed;transform:none}.chat-window--fullscreen{z-index:9999;border-radius:0;width:100vw!important;min-width:100vw!important;max-width:none!important;height:100dvh!important;min-height:100dvh!important;max-height:none!important;position:fixed!important;inset:0!important}.chat-window--fullscreen .chat-header{box-sizing:border-box;width:100%;min-width:0;padding-left:24px;padding-right:24px;padding-top:max(14px,env(safe-area-inset-top));flex-shrink:0}.chat-window--fullscreen .chat-input-wrap{box-sizing:border-box;width:100%;min-width:0;padding:14px 24px max(14px,env(safe-area-inset-bottom));flex-shrink:0}.chat-window--fullscreen .chat-messages{box-sizing:border-box;text-align:left;flex:1;justify-content:flex-start;align-items:flex-start;width:100%;min-width:0;min-height:0;padding-left:24px;padding-right:24px}.chat-window--fullscreen .chat-message{width:fit-content;max-width:85%}
.navbar{background-color:#0000;border-bottom:1px solid #ffffff4d;flex-wrap:wrap;justify-content:center;gap:.5rem 2rem;padding:1.25rem 1rem;display:flex}.navbar a{color:var(--text-primary);font-family:var(--font-roboto),sans-serif;letter-spacing:.03em;text-transform:uppercase;padding:.5rem .75rem;font-size:clamp(.85rem,2.5vw,.95rem);font-weight:500;text-decoration:none;transition:color .2s}.navbar a:hover{color:var(--text-secondary)}.navbar a:active{color:var(--text-primary)}.navbar__auth{color:#22c55e;justify-content:center;align-items:center;padding:.5rem .75rem;font-size:1.25rem;animation:.35s ease-out nav-auth-pop;display:inline-flex}.navbar__auth--loading{color:var(--text-primary);font-size:1rem;animation:none}@keyframes nav-auth-pop{0%{opacity:0;transform:scale(0)}60%{opacity:1;transform:scale(1.15)}to{opacity:1;transform:scale(1)}}@media (max-width:480px){.navbar{gap:.25rem 1rem;padding:1rem .5rem}.navbar a{padding:.4rem .5rem}}
