@keyframes shiny-text-wipe{0%{background-position:-150%}to{background-position:100%}}.home-page{padding-top:4rem;padding-left:1rem;padding-right:1rem;min-height:100vh;width:100%;background-color:var(--card-bg);color:var(--text-color);transition:background .3s,color .3s}@media(min-width:768px){.home-page{padding-left:2rem;padding-right:2rem}}@media(min-width:1024px){.home-page{padding-left:4rem;padding-right:4rem}}.home-content{max-width:1200px;margin:0 auto;width:100%;display:flex;flex-direction:column;gap:2rem}.hero-title,.section-title{font-size:3rem;font-weight:400;line-height:1.1;background-color:#000;background-size:300% auto;background-clip:text;-webkit-background-clip:text;color:rgba(0,0,0,0);opacity:0;transform:translateY(-20px);animation:smooth-slide-up .8s ease-out forwards;animation-delay:.3s;color:var(--text-color)}.hero-title{margin-bottom:0}.section-title{margin-bottom:1.5rem}.home-page p,.resume-section{font-size:1.2rem;opacity:0;transform:translateY(20px);animation:smooth-slide-up 1.2s ease-out forwards;animation-delay:.3s;padding-top:0}.hero-visual{width:min(600px,45vw);height:min(600px,45vw);position:absolute;left:60%;top:6rem;transform:translateX(-40%);z-index:0;pointer-events:none;opacity:0;animation:visual-warp-in 2s ease-out forwards}.hero-visual canvas{width:100%!important;height:100%!important}@media(max-width:1024px){.hero-visual{left:55%;transform:translateX(-50%)}}@media(max-width:768px){.hero-visual{position:relative;top:1rem;left:auto;transform:none;margin:0 auto .5rem;width:clamp(160px,40vw,240px);height:clamp(160px,40vw,240px);opacity:1}}@keyframes visual-warp-in{0%{opacity:0;transform:translateY(100px) scale(.3) rotateX(25deg);filter:blur(4px) brightness(1.1)}60%{opacity:1;transform:translateY(-10px) scale(1.05) rotateX(0deg);filter:blur(.5px) brightness(1)}to{opacity:1;transform:translateY(0) scale(1) rotateX(0deg);filter:blur(0)}}.hero-section{position:relative;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.25rem;margin:0;max-width:1000px!important}@media(min-width:768px){.hero-section{align-items:flex-start;text-align:left;padding-top:8rem}}@media(max-width:768px){.home-content{padding:0 1.25rem;gap:1.5rem}.hero-section{gap:.5rem;margin-bottom:1.25rem}.hero-visual{width:clamp(160px,38vw,240px);height:clamp(160px,38vw,240px);margin:.25rem auto -.5rem;transform:translateY(30px) scale(.7) rotateX(12deg)}.hero-title{font-size:3.5rem;line-height:1.1;margin-top:0}.hero-description{font-size:1.05rem;line-height:1.4;margin-top:.25rem}.section-title{font-size:1.8rem;margin-bottom:1rem}}.i-section-divider{position:relative;width:100%;height:2px;margin:50px 40px 0 0;background:var(--divider-bg);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:smooth-slide-up 1.2s cubic-bezier(.25,.8,.25,1) forwards}.i-section-divider:before{inset:0 0 0 0;background:linear-gradient(to right,transparent 0,var(--divider-line) 48%,var(--divider-glow) 50%,var(--divider-line) 52%,transparent 100%)}.i-section-divider:after,.i-section-divider:before{content:"";position:absolute;pointer-events:none;z-index:1}.i-section-divider:after{top:-20px;left:50%;transform:translateX(-50%);width:50vw;height:60px;background:radial-gradient(ellipse at center,var(--divider-spotlight) 0,transparent 60%)}@media(max-width:768px){.section-divider{margin:8px 0 30px!important}}.section-divider{position:relative;width:100%;height:2px;margin:570px 40px 0 0;background:var(--divider-bg);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:smooth-slide-up 1.2s cubic-bezier(.25,.8,.25,1) forwards}.section-divider:before{inset:0 0 0 0;background:linear-gradient(to right,transparent 0,var(--divider-line) 48%,var(--divider-glow) 50%,var(--divider-line) 52%,transparent 100%)}.section-divider:after,.section-divider:before{content:"";position:absolute;pointer-events:none;z-index:1}.section-divider:after{top:-20px;left:50%;transform:translateX(-50%);width:50vw;height:60px;background:radial-gradient(ellipse at center,var(--divider-spotlight) 0,transparent 60%)}body[data-theme=light]{--stripe-default-bg:#ffffff;--stripe-alt-bg:linear-gradient(135deg,#dfe9f3,#ffffff)}body[data-theme=dark]{--stripe-default-bg:#0d0d0d;--stripe-alt-bg:#141417}.project-page{width:100%;overflow-x:hidden;background:var(--card-bg)}.stripe{width:100vw;margin-left:calc(-50vw + 50%);padding:4rem 2rem;border-top:1px solid var(--divider-line);border-bottom:1px solid var(--divider-line);color:var(--text-color);display:flex;justify-content:center;opacity:0;transform:translateY(40px);transition:transform .3s ease,opacity .3s ease}.stripe,.stripe.default{background:var(--stripe-default-bg)}.stripe.grey{background:var(--stripe-alt-bg)}.stripe-inner{max-width:1000px;width:100%;display:flex;flex-direction:column;gap:1.75rem}.project-bar-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:1rem}.project-bar-header .project-title{font-size:clamp(1.75rem,2vw + 1rem,2.5rem);font-weight:600;line-height:1.2;max-width:800px;color:var(--text-color);margin-bottom:0!important}.project-bar-header .project-date{font-size:.95rem;color:var(--muted-text-color);font-weight:400;white-space:nowrap}.project-links{flex-wrap:wrap}.pill{margin-top:0!important;padding:.5rem 1rem;font-size:.85rem;font-weight:500;border-radius:8px;background:var(--primary-accent);color:#fff;text-decoration:none;transition:background .3s ease}.pill:hover{background:rgba(43,134,197,.8)}@media(prefers-color-scheme:dark){.pill{background:rgba(138,180,248,.2);color:rgba(138,180,248,.9)}.pill:hover{background:rgba(138,180,248,.3)}}.project-bullets{list-style:disc;padding-left:1.5rem}.project-bullets li{margin-bottom:.75rem;line-height:1.6;max-width:800px;font-size:.95rem}@media(max-width:768px){.stripe{padding:3rem 1.5rem}.project-title{font-size:1.5rem}.pill{font-size:.8rem;padding:.4rem .85rem}.project-bar-header{flex-direction:column;align-items:flex-start}}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.contact-main,.home-page,.page-content{background-color:var(--bg-color)}body,html{margin:0;padding:0;width:100vw;min-height:100vh;overflow-x:hidden;background-color:var(--card-bg);color:var(--text-color);box-sizing:border-box}*,:after,:before{box-sizing:inherit}.desktop-nav{display:block}@media(max-width:768px){.desktop-nav{display:none}}.mobile-nav{display:none}@media(max-width:768px){.mobile-nav{display:block}}a{font-weight:500;text-decoration:inherit}a,h1{color:var(--text-color)}h1{font-size:3.2em;line-height:1.1}button{z-index:3;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;cursor:pointer;transition:border-color .25s}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:var(--card-bg)}a:hover{color:#747bff}button{background-color:#f9f9f9}}.action-btn{background-color:rgba(0,0,0,0);color:#000;font-size:16px;padding:10px 20px;border:2px solid #000;border-radius:4px;cursor:pointer;transition:all .3s ease;font-weight:700;margin-right:10px}.edit-btn{border-color:#606f80;color:#47688c}.edit-btn:hover{color:#0056b3;border-color:#0056b3}.delete-btn{border-color:#875a5e;color:#5f363b}.delete-btn:hover{color:#c82333;border-color:#c82333}.action-btn:hover{transform:none}.action-btn:disabled{border-color:#ccc;color:#ccc;cursor:not-allowed;opacity:.7}.modal{display:none;z-index:3;position:fixed;top:0;left:0;width:100%;height:100%;background-color:rgba(0,0,0,.4);z-index:1000;justify-content:center;align-items:center;animation:fadeIn .3s ease-out forwards}.modal.show{display:flex}.modal-content{background-color:var(--card-bg);padding:60px 60px 70px;border-radius:8px;width:80%;max-width:500px;box-shadow:0 4px 8px rgba(0,0,0,.2);position:relative;z-index:3}.modal-content h2{font-size:1.4rem;font-weight:500}.modal-header{font-size:1.5rem;font-weight:600;margin-bottom:10px}.modal-body{display:flex;flex-direction:column;gap:1rem;padding-bottom:15px}.modal-body input,.modal-body select{width:100%;padding:.9rem 1rem;font-size:1rem;border:1px solid #c7c7cc;border-radius:10px;background:#fff;color:#000;z-index:3;transition:border .2s ease}.modal-body input:focus,.modal-body select:focus{border-color:#51677d;outline:none}.modal-footer{display:flex;justify-content:flex-end;gap:10px;background-color:var(--card-bg)}.back-modal-button{position:relative;overflow:hidden;z-index:3;width:100%;margin-top:1rem;max-width:200px;border-radius:4px;padding:.7rem;background:#000;color:#fff;font-weight:400;font-size:1rem;border:none;cursor:pointer;align-self:flex-start;transition:background .3s ease}.back-modal-button:before{content:"";position:absolute;top:0;left:-150%;width:300%;height:100%;background:linear-gradient(120deg,transparent 30%,#ff3cac 45%,#784ba0 50%,#2b86c5 55%,transparent 70%);opacity:0;transition:none;pointer-events:none;z-index:2}.back-modal-button:hover:before{animation:shiny-wipe 1.2s ease-out forwards;opacity:1}.back-modal-button:hover{background-color:#000}.book-modal-button{margin-top:1rem;background-color:var(--primary-accent);color:#fff;border:none;z-index:4;border-radius:8px;cursor:pointer;font-weight:500;transition:background-color .3s ease;align-self:center;width:100%!important;max-width:600px!important;border-radius:4px;padding:.7rem}.book-modal-button:hover{background-color:var(--primary-accent-dark)}.book-modal-button,.modal-button{margin-bottom:10px;position:relative;overflow:hidden;z-index:4;width:100%;max-width:200px;border-radius:4px;padding:.7rem;background:#000;color:#fff;font-weight:400;font-size:1rem;border:none;cursor:pointer;align-self:flex-start;transition:background .3s ease}.book-modal-button:before,.modal-button:before{content:"";position:absolute;top:0;left:-150%;width:300%;height:100%;background:linear-gradient(120deg,transparent 30%,#ff3cac 45%,#784ba0 50%,#2b86c5 55%,transparent 70%);opacity:0;transition:none;pointer-events:none;z-index:2}.book-modal-button:hover:before,.modal-button:hover:before{animation:shiny-wipe 1.2s ease-out forwards;opacity:1}.book-modal-button:hover,.modal-button:hover{background-color:#000}.modal-close{position:absolute;top:10px;right:10px;font-size:18px;cursor:pointer;color:#000}.checkout-button:hover:before,.reg-button:hover:before,.return-button:hover:before,.sign-button:hover:before{animation:shiny-wipe 1.2s ease-out forwards;opacity:1}@keyframes slide_up{0%{transform:translateY(60px)}to{transform:translateY(0)}}@keyframes disney_fade_inner{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes double_flash{0%{color:rgba(0,0,0,0);background:linear-gradient(90deg,#ff3cac,#784ba0,#2b86c5);background-clip:text;-webkit-background-clip:text;background-position:-120% 0}40%{background-position:100% 0}70%{background-position:-80% 0}90%{background-position:0 0}to{color:#fff;background:none}}@keyframes shiny-wipe{0%{left:-150%;opacity:1}50%{left:100%;opacity:1}to{left:100%;opacity:0}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.contact-main{display:flex;justify-content:center;align-items:top;min-height:100vh;background:var(--bg-color);background-size:cover;background-position:50%;color:var(--text-color);transition:background-color .3s ease}.contact-main .contact{margin-right:20px;height:100%;margin-left:20px;margin-top:10rem;opacity:0;display:flex;flex-direction:column;align-items:flex-start;background:rgba(0,0,0,0);border-radius:6px;backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);box-shadow:0 8px 32px rgba(0,0,0,.2);border:1px solid hsla(0,0%,100%,.1);padding:40px 70px 80px;width:600px;max-width:90%;transform:translateY(40px);animation:fade_slide .6s ease-out .2s forwards;transition:all .3s ease-in-out,color .3s ease,background-color .3s ease}.contact-main .contact section{width:100%}.contact-main .contact .contact-instr{padding-bottom:12px}.contact-main .contact .contact-instr h4{font-weight:400;font-size:1.2rem;color:var(--text-color);transition:color .3s ease}.contact-main .contact h3{font-size:1.8rem;font-weight:400;margin-bottom:1.5rem;color:var(--text-color);transition:color .3s ease}.contact-main .contact .contact-form{width:100%;display:flex;flex-direction:column}.contact-main .contact input,.contact-main .contact textarea{width:100%;padding:12px;font-size:1rem;border-radius:4px;border:1px solid rgba(0,0,0,.092);background:hsla(0,0%,100%,.2);color:var(--text-color);margin-bottom:16px;outline:none;transition:border .2s ease,background .2s ease,color .3s ease}.contact-main .contact input::placeholder,.contact-main .contact textarea::placeholder{color:var(--text-color);opacity:.6;transition:color .3s ease}.contact-main .contact input:focus,.contact-main .contact textarea:focus{border-color:var(--primary-accent);background:hsla(0,0%,100%,.3)}.contact-main .contact textarea{height:10rem;margin-bottom:1rem}.contact-main .contact label{margin-bottom:1rem;color:var(--text-color);transition:color .3s ease}.contact-main .contact button{width:100%;max-width:700px;padding:1rem 2rem;border:none;border-radius:4px;background:rgba(0,0,0,0);font-size:1.1rem;color:var(--text-color);font-weight:400;cursor:pointer;backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border:1px solid var(--primary-accent);position:relative;overflow:hidden;transition:background 1s ease,color .3s ease}.contact-main .contact button:hover{background-color:var(--search)}@keyframes fade_slide{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.contact-main{padding:2rem 1rem;min-height:auto}.contact-main .contact{background:rgba(0,0,0,0);border:none;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none;padding:0;margin:2rem 0;width:100%;max-width:100%}.contact-main .contact .contact-instr h4,.contact-main .contact h3{text-align:center}.contact-main .contact input,.contact-main .contact textarea{font-size:.95rem;padding:.85rem;width:100%}.contact-main .contact textarea{height:8rem}.contact-main .contact button{font-size:1rem;padding:.85rem 1.5rem}}.app-footer{background:var(--bg-color);color:var(--text-color);font-size:.85rem;padding:3rem 0 2rem;border-top:1px solid var(--border-color);display:flex;flex-direction:column;align-items:center;z-index:5}.app-footer .footer-inner{max-width:1000px;margin:0 auto;padding:0 2rem;text-align:center;position:relative;z-index:20}.app-footer .footer-top{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:2rem;gap:2rem;padding-bottom:2rem;border-bottom:1px solid var(--border-color);justify-items:center;background:var(--bg-color);color:var(--text-color);position:relative;z-index:20}.app-footer .footer-section{text-align:center;position:relative;z-index:20}.app-footer .footer-section h4{font-weight:600;font-size:.85rem;margin-bottom:.75rem;color:var(--text-color);position:relative;z-index:20}.app-footer .footer-section .footer-links{display:flex;flex-direction:column;gap:.5rem;align-items:center;z-index:5}.app-footer .footer-section .footer-links a{text-decoration:none;font-size:.75rem;color:var(--text-color);z-index:5}.app-footer .footer-section .footer-links a:hover{text-decoration:underline;color:var(--primary-accent)}.app-footer .footer-bottom{text-align:center;font-size:.7rem;opacity:.6;margin-top:2rem;color:var(--text-color);z-index:5}.app-footer .footer-bottom p{margin:0}@media(max-width:768px){.footer-top{grid-template-columns:repeat(2,1fr);z-index:5;gap:2rem 2rem;background:rgba(0,0,0,0)}}.navbar{height:60px;position:fixed;max-width:1196;top:0;z-index:100;padding:0 20px;justify-content:center;animation:shiny-text-wipe 2s ease-out forwards,fade-slide-down 1.2s ease forwards;background-color:var(--card-bg) 0,0,0,.4;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid hsla(0,0%,100%,.06);box-shadow:none;transition:background-color .3s ease,-webkit-backdrop-filter .3s ease;transition:background-color .3s ease,backdrop-filter .3s ease;transition:background-color .3s ease,backdrop-filter .3s ease,-webkit-backdrop-filter .3s ease}.nav-container,.navbar{width:100%;display:flex;align-items:center}.nav-container{max-width:1196px;justify-content:space-between;position:relative}.logo{width:80px;transition:filter .3s ease}body[data-theme=light] .logo{filter:none}body[data-theme=dark] .logo{filter:invert(1)}.nav-logo{font-size:20px;color:var(--text-color)}.nav-links{display:flex;align-items:center;gap:20px}.nav-item{font-size:14px;color:var(--text-color);text-decoration:none;transition:opacity .3s ease;margin-right:10px}.nav-item:hover{opacity:.7}.hamburger{display:none;font-size:32px;background:none;border:none;cursor:pointer;color:var(--text-color);padding-right:24px;z-index:1001;outline:none;-webkit-tap-highlight-color:rgba(0,0,0,0);-webkit-touch-callout:none}.hamburger:active,.hamburger:focus{outline:none;box-shadow:none;background:none}.mobile-menu{position:fixed;top:60px;left:0;width:100vw;height:calc(100vh - 60px);background:var(--bg-color);display:none;flex-direction:column;justify-content:center;align-items:center;gap:24px;padding:0 2rem;z-index:1000;animation:fadeSlideDown .25s ease;text-align:center}.mobile-menu.open{display:flex}.mobile-menu-item{font-size:24px;color:var(--text-color);text-decoration:none;transition:opacity .3s ease}.mobile-menu-item:hover{opacity:.7}@keyframes fadeSlideDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.nav-links{display:none}.hamburger{display:block}}.desktop-only{display:flex}@media(max-width:768px){.desktop-only{display:none!important}}.mobile-only{display:none}@media(max-width:768px){.mobile-only{display:block!important}}.theme-toggle-button{color:var(--text-color);background-color:rgba(0,0,0,0);border:none;cursor:pointer;font-size:24px;align-items:center;justify-content:center;display:row;justify-items:center}.theme-toggle-buttonhover{color:var(--text-hover)}body[data-theme=light]{--bg-color:#f3f3f6;--text-color:#111111;--card-bg:linear-gradient(135deg,#dfe9f3,#ffffff);--primary-accent:#007fba;--glass-button-text:#f5f5f5;--border-color:rgba(0,0,0,0.05);--shadow-color:rgba(0,0,0,0.1);--input-bg:#ffffff;--placeholder-color:rgba(0,0,0,0.5);--accent-grad:linear-gradient(135deg,#2a2a2c,#1b1b1c);--grid:black;--nav:white;--hover:grey;--text-hover:#444;--admin-text-hover:#fafafa;--but:transparent;--search:rgba(0,0,0,0.08);--divider-bg:rgba(0,0,0,0.025);--divider-line:rgba(0,0,0,0.06);--divider-glow:rgba(0,0,0,0.08);--divider-spotlight:rgba(0,0,0,0.05)}body[data-theme=dark]{--bg-color:#000000;--text-color:#f5f5f5;--card-bg:rgba(0,0,0,0);--primary-accent:#5dc6ff;--glass-button-text:#f5f5f5;--border-color:rgba(255,255,255,0.08);--shadow-color:rgba(0,0,0,0.6);--input-bg:#111111;--placeholder-color:rgba(255,255,255,0.4);--accent-grad:none;--grid:rgba(255,255,255,0.05);--nav:#0a0a0a;--hover:#1e1e1e;--text-hover:#eaeaea;--admin-text-hover:#ffffff;--but:rgba(255,255,255,0.06);--search:rgba(255,255,255,0.05);--glow-accent:0 0 20px rgba(255,255,255,0.15);--divider-bg:rgba(255,255,255,0.025);--divider-line:rgba(255,255,255,0.06);--divider-glow:rgba(255,255,255,0.08);--divider-spotlight:rgba(255,255,255,0.05)}.wave-bg{position:fixed;bottom:0;left:0;width:100%;height:24vh;overflow:hidden;z-index:2}.bubble-layer,.bubble-layer *,.wave-bg,.wave-bg *{pointer-events:none}.wave-svg{width:200%;height:100%}.bubble-layer{position:absolute;inset:0;z-index:1}.pixel-bubble{position:absolute;bottom:-10px;left:var(--left);width:var(--size);height:var(--size);background:hsla(0,0%,100%,.22);border-radius:1px;box-shadow:0 0 3px hsla(0,0%,100%,.5);animation:bubble-rise var(--duration) ease-in infinite;animation-delay:var(--delay)}@keyframes bubble-rise{0%{transform:translateX(0) translateY(0) scale(1);opacity:.7}70%{transform:translateX(calc(var(--drift) / 2)) translateY(-70vh) scale(1.1);opacity:.4}to{transform:translateX(var(--drift)) translateY(-90vh) scale(1.25);opacity:0}}.skills-section{margin-bottom:1rem;text-align:center!important;padding-right:15px;padding-left:15px;max-width:1100px;color:var(--text-color);justify-content:center!important;align-items:center!important}.skills-section .skills-title{font-size:clamp(1.8rem,2.8vw + 1rem,2.4rem);font-weight:500;margin-bottom:2.5rem;letter-spacing:.02em;opacity:0;visibility:hidden;transform:translateY(20px);animation:smooth-slide-up .8s ease-out forwards;animation-delay:.2s}.skills-section .skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(60px,max-content));grid-gap:1rem 1rem;gap:1rem 1rem;list-style:none;padding:0;margin:0 auto;max-width:1100px;align-items:center;justify-items:center;justify-content:center}@media(max-width:768px){.skills-section .skills-grid{grid-template-columns:repeat(2,auto);justify-content:center;column-gap:8rem;row-gap:1rem}}.skills-section .skill-item{display:flex;align-items:center;justify-content:center}.skills-section .skill-icon{width:60px;height:auto;filter:brightness(0) invert(1);opacity:0;visibility:hidden;transform:translateY(20px);animation:smooth-slide-up .8s ease-out forwards;animation-delay:.4s;transition:opacity .25s ease,transform .25s ease}.skills-section .skill-icon:hover{opacity:1;transform:translateY(-4px)}@media(max-width:600px){.skills-section .skill-icon{width:48px}}.skills-section .skills-subline{font-size:1rem;opacity:.75;max-width:680px;margin:0 auto}body[data-theme=light] .skills-section .skill-icon{filter:none}@media(max-width:768px){.about-facts .facts-container{flex-direction:column;align-items:center;padding:2rem}.about-facts .facts-list{max-width:100%;width:100%;text-align:center}.about-facts .facts-list p{white-space:normal}.about-facts .facts-badges{max-width:100%;justify-content:center}}@media(min-width:769px){.skills-grid{place-content:center;grid-auto-flow:row}}.about-page{padding:3rem 1.5rem;margin:0 auto;color:var(--text-color);background:var(--bg-color);background-size:cover;background-position:50%;background-repeat:no-repeat;background-color:var(--bg-color);font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;min-height:100vh}.about-container{max-width:60rem;align-items:center;margin:0 auto}.about-hero{margin-bottom:0;text-align:center}.about-hero h1{font-weight:450;line-height:1.15;font-size:clamp(2.75rem,5vw + 1rem,3.75rem);color:var(--text-color)}.about-hero h1 .accent{color:var(--primary-accent)}.about-hero p{max-width:36rem;margin:1rem auto 2.5rem;font-size:1.125rem;color:var(--placeholder-color)}.about-story h2{font-weight:600;font-size:clamp(1.75rem,4vw + 1rem,2.75rem);margin-bottom:1.5rem;color:var(--text-color)}.about-story p{font-size:1.125rem;line-height:1.6;margin-bottom:1.25rem;color:var(--placeholder-color)}.about-story .hero-line{padding:0;margin-top:0}.about-values{background-color:rgba(33,33,33,.75);border-radius:.75rem;padding:2rem 2.5rem;color:#fafafa;max-width:40rem;margin:0 auto 5rem}.about-values h2{font-weight:600;font-size:clamp(1.75rem,4vw + 1rem,2.75rem);margin-bottom:1.5rem;text-align:center;color:var(--text-color)}.about-values ul{list-style-type:disc;padding-left:1.5rem;font-size:1.125rem;line-height:1.6}.about-values ul li{margin-bottom:.75rem;color:var(--placeholder-color)}.about-persona{margin-bottom:5rem;text-align:center}.about-persona img{width:12rem;height:12rem;border-radius:9999px;object-fit:cover;margin:0 auto 1.5rem;box-shadow:0 0 15px rgba(255,174,51,.5)}.about-persona p{font-style:italic;font-size:1.125rem;color:var(--placeholder-color)}.about-cta,.about-persona p{max-width:30rem;margin:0 auto}.about-cta{text-align:center;padding-top:0}.about-cta p{font-size:1.125rem;margin-bottom:1.5rem;color:var(--placeholder-color)}.about-cta .contact-button{background:var(--primary-accent);padding:.6rem 1rem;border-radius:.5rem;color:#fff;font-weight:600;font-size:1.125rem;text-decoration:none;display:inline-block;transition:background .8s ease}.about-cta .contact-button:hover{background:var(--primary-accent);border:1px solid var(--text-color);color:var(--primary-accent)}.about-extension{text-align:left;color:var(--text-color)}.about-extension .about-extension-bio{max-width:42rem}.about-extension .about-extension-bio .extension-title{font-weight:600;font-size:clamp(1.75rem,4vw + 1rem,2.75rem);text-align:center;color:var(--text-color)}.about-extension .about-extension-bio p{font-size:1.125rem;line-height:1.6;color:var(--placeholder-color);text-align:center}.about-facts{margin-bottom:5rem;padding:10px;text-align:left;align-items:center;margin-top:0!important}.about-facts .facts-container{display:flex;gap:2rem;justify-content:space-between;align-items:stretch;background:rgba(0,0,0,0);border-radius:4px;padding:3rem;width:100%;max-width:100%;margin:0 auto;transform:translateY(40px);animation:fade_slide .6s ease-out .2s forwards;opacity:0;transition:all .3s ease-in-out}.about-facts .facts-left{flex:1 1;min-width:250px}.about-facts .facts-left .about-photo{margin:0 auto 1.5rem}.about-facts .facts-left p{text-align:center;font-size:1.1rem;color:var(--placeholder-color)}.about-facts .facts-right{flex:2 1;display:flex;flex-direction:column;gap:1.5rem}.about-facts .facts-right .facts-title{font-size:clamp(1.75rem,4vw + 1rem,2.5rem);font-weight:600;color:var(--text-color)}.about-facts .facts-right .facts-grid{display:sticky;flex-wrap:wrap;gap:1rem;font-size:1.125rem;color:var(--text-color)}.about-facts .facts-right .tools-block p{font-weight:600;margin-bottom:1rem}.about-facts .facts-right .facts-badges{flex:1 1;max-width:300px;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-start}.about-facts .facts-right .facts-badges .badge-icon{height:26px;opacity:.9;transition:transform .2s ease}.about-facts .facts-right .facts-badges .badge-icon:hover{transform:translateY(-2px) scale(1.05)}.about-photo{width:160px;height:160px;display:flex;border-radius:50%;object-fit:cover;margin:0 auto 1.5rem;box-shadow:0 8px 20px rgba(0,0,0,.3);border:3px solid var(--primary-accent);transition:transform .3s ease;cursor:pointer}.about-photo:hover{transform:scale(1.05) rotate(2deg);box-shadow:0 12px 30px rgba(0,0,0,.4)}.facts-list{flex:2 1;display:flex;flex-direction:column;max-width:70%;min-width:350px;text-align:right}.facts-list p{font-size:1.125rem;margin-bottom:1rem;margin-top:0;color:var(--text-color);white-space:normal}.facts-list h3{margin-top:2rem;margin-bottom:1rem;font-size:1.25rem;font-weight:600}@media(max-width:640px){.about-hero h1{font-size:clamp(2rem,5vw + 1rem,3rem)}.resume-link{display:flex;justify-content:center;align-items:center;margin:1.5rem auto 0}}@media(max-width:640px)and (max-width:640px){.i-section-divider{margin:2rem auto;display:block;width:100%;text-align:center}}@media(max-width:640px){.i-section-divider{width:100%;max-width:100%;height:1px;background:var(--border-color);margin:2rem auto;display:block}.about-story h2,.about-values h2{font-size:clamp(1.5rem,4vw + 1rem,2rem)}.facts-list{text-align:center;align-items:center;margin:0 auto;min-width:unset;max-width:100%}.facts-list h3,.facts-list p{text-align:center;margin-left:auto;margin-right:auto}.facts-container{flex-direction:column;padding:2rem 1rem;gap:2rem}.facts-container,.facts-right{align-items:center}.facts-right .facts-badges{justify-content:center}}.resume-link{display:flex;justify-content:center;align-items:center;margin:.5em auto 0;max-width:220px;border-radius:6px;padding:.75rem 1rem;background:rgba(0,0,0,0);border:1px solid var(--text-color);color:var(--text-color);font-weight:500;font-size:1rem;cursor:pointer;transition:background .3s ease;transition:color .3s ease;text-align:center}.resume-link:hover{background:var(--border-color)}.badge-group-heading{padding-top:0;margin-top:0;padding-bottom:0;margin-bottom:0}.badge-group{padding-bottom:20px}.beveled-icon{display:block;margin:50px auto 0;cursor:default;-webkit-user-select:none;-moz-user-select:none;user-select:none;position:relative;animation:smooth-slide-up 1.2s cubic-bezier(.25,.8,.25,1) forwards;overflow:hidden}.beveled-icon .shine{animation:shine-slide 3.5s ease-in-out infinite;transform-origin:left center}@keyframes shine-slide{0%{transform:translateX(-120%)}to{transform:translateX(220%)}}.project-grid{display:flex;gap:1.5rem;overflow-x:auto;padding-bottom:.5rem;scroll-snap-type:x mandatory;margin-top:3rem;margin-bottom:5rem}.project-card{scroll-snap-align:start;z-index:0;position:relative;display:flex;flex-direction:column;width:600px!important;height:680px;border-radius:2px;overflow:hidden;background:var(--input-bg);box-shadow:0 2px 6px rgba(0,0,0,.18);transition:transform .2s,box-shadow .2s}.project-card:hover{transform:translateY(-9px);box-shadow:0 8px 22px rgba(0,0,0,.12)}.project-card:before{content:"";position:absolute;inset:0 auto 0 0;width:6px;background:linear-gradient(to bottom,var(--primary-accent),var(--secondary-accent));z-index:2;border-radius:20px 0 0 20px}.project-image-wrapper{position:fixed;width:100%;height:100%}.project-image-wrapper img{width:100%;height:100%;object-fit:cover;display:block}.project-image-wrapper:after,.project-image-wrapper:before{content:"";position:absolute;left:0;right:0;height:160px;pointer-events:none;z-index:1}.project-content{position:relative;z-index:2;padding:1.5rem 1.5rem .5rem;display:flex;flex-direction:column;gap:.75rem;flex:1 1}.project-header{display:flex;justify-content:space-between;align-items:flex-start}.project-title{font-size:1.6rem;font-weight:500;color:#fff;margin-top:0}.project-m-title{font-size:1.4rem;font-weight:500;color:#000;margin-top:0}.project-date{font-size:1rem;color:#fff}.project-description{font-size:1rem;line-height:1.4;color:var(--text-color)}.project-tech{display:flex;flex-wrap:wrap;gap:.45rem .6rem;margin-top:auto}.tech-badge{height:20px;object-fit:contain}.project-links{display:flex;gap:1rem;margin-top:.75rem}.project-link-button{flex:1 1;padding:.55rem 1rem;font-size:.9rem;border-radius:6px;background:var(--link-color);color:#000;border:none;font-weight:500;cursor:pointer;transition:background .3s}.project-link-button:hover{background:var(--secondary-accent)}.animate-slide-up{opacity:0;transform:translateY(40px);visibility:hidden;animation:smooth-slide-up 1.2s cubic-bezier(.25,.8,.25,1) forwards;animation-fill-mode:forwards}@keyframes smooth-slide-up{0%{opacity:0;transform:translateY(40px);visibility:hidden}to{opacity:1;transform:translateY(0);visibility:visible}}@media(max-width:1024px){.project-card{width:450px!important;height:520px}.project-title{font-size:1.3rem}.project-date,.project-description{font-size:.9rem}}@media(max-width:600px){.project-card{width:320px!important;height:380px;border-radius:6px}.project-title{font-size:1.1rem}.project-date,.project-description{font-size:.85rem}.tech-badge{height:22px}.project-link-button{padding:.45rem .75rem;font-size:.8rem}}.project-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;background:var(--input-bg);color:var(--text-color);padding:4rem 1.5rem;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen}.project-hero{position:relative;max-width:960px;width:100%;border-radius:24px;overflow:hidden;margin-bottom:3rem;box-shadow:0 12px 32px rgba(0,0,0,.12)}.project-hero img{width:100%;height:auto;display:block;object-fit:cover}.project-hero:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.04) 0,rgba(0,0,0,0) 30%,rgba(0,0,0,0) 70%,rgba(0,0,0,.04));z-index:1}.project-details{max-width:720px;text-align:center}.project-details h1{font-size:2.6rem;font-weight:600;margin-bottom:1rem;color:var(--text-color)}.project-details .project-description{font-size:1.15rem;line-height:1.6;margin-bottom:2rem;color:var(--text-color)}.project-details .project-links{display:flex;justify-content:center;gap:1rem;margin-bottom:2rem}.project-details .project-links .project-link-button{padding:.75rem 1.5rem;font-size:1rem;font-weight:500;border-radius:8px;color:var(--text-color);border:none;transition:background .25s ease;cursor:pointer}.project-details .project-links .project-link-button:hover{color:var(--primary-accent);text-decoration:underline}.project-details .back-link{display:inline-block;margin-top:1rem;font-size:.95rem;color:var(--link-color);text-decoration:none;transition:color .25s ease}.project-details .back-link:hover{color:var(--primary-accent)}@media(max-width:768px){.project-details h1{font-size:2rem}.project-description{font-size:1rem}.project-links .project-link-button{font-size:.9rem;padding:.6rem 1.2rem}}.chat-widget{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9999}.chat-widget .chat-toggle{background:rgba(0,0,0,0);padding:.3rem .5rem;border:none;font-size:1.8rem;cursor:pointer}.chat-widget .chat-close{background:rgba(0,0,0,0);background-color:rgba(0,0,0,0);color:var(--text-color);border:none}.chat-widget .chat-box{position:absolute;bottom:0;right:0;width:300px;height:400px;background:rgba(20,20,30,.9);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--text-color);background-color:var(--bg-color);border-radius:4px;display:flex;flex-direction:column;box-shadow:0 .5px 1px var(--text-color);overflow:hidden;transition:all .3s ease}.chat-widget .chat-box header{background:var(--card-bg);padding:.8rem 1rem;font-weight:700;display:flex;justify-content:space-between}.chat-widget .chat-box .chat-messages{flex:1 1;padding:1rem;overflow-y:auto}.chat-widget .chat-box .chat-messages .chat-msg{margin-bottom:1rem;line-height:1.4}.chat-widget .chat-box .chat-messages .chat-msg.user{text-align:right;color:var(--primary-accent)}.chat-widget .chat-box .chat-messages .chat-msg.assistant{text-align:left;color:var(--text-color)}.chat-widget .chat-box .chat-messages .chat-msg.typing{font-weight:700}.chat-widget .chat-box .chat-messages .chat-msg.typing .dot{display:inline-block;animation:blink 1.4s infinite;font-size:1.2rem}.chat-widget .chat-box .chat-messages .chat-msg.typing .dot:nth-child(2){animation-delay:.2s}.chat-widget .chat-box .chat-messages .chat-msg.typing .dot:nth-child(3){animation-delay:.4s}.chat-widget .chat-box footer{display:flex;border-top:1px solid hsla(0,0%,100%,.1);padding:.5rem}.chat-widget .chat-box footer input{flex:1 1;background:rgba(0,0,0,0);border:none;outline:none;color:var(--text-color);font-size:1rem;padding:.5rem}.chat-widget .chat-box footer input::placeholder{color:var(--text-color)}.chat-widget .chat-box footer button{background:none;border:none;color:var(--primary-accent);font-size:1.25rem;cursor:pointer;padding:0 .5rem}@media(max-width:480px){.chat-widget{bottom:0;right:0}.chat-widget .chat-box{position:fixed;bottom:0;left:0;right:0;width:100%;height:100%;border-radius:0;box-shadow:none;max-height:100%;animation:slideUp .3s ease-out}.chat-widget .chat-toggle{font-size:1.4rem;padding:1.4rem 1.5rem}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes blink{0%,to{opacity:0}50%{opacity:1}}@keyframes fade-slide-down{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.code-tabs .tab-list{display:flex;gap:.75rem;padding:.75rem;margin-bottom:0;border:1px solid rgba(128,128,128,.37);border-radius:4px 4px 0 0;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;animation:fade-slide-down .3s ease-out forwards}.code-tabs .tab-list>.tab-trigger{opacity:0;transform:translateY(-10px);will-change:opacity,transform;animation:fade-slide-down .3s ease-out forwards}.code-tabs .tab-list>.tab-trigger:first-child{animation-delay:.05s}.code-tabs .tab-list>.tab-trigger:nth-child(2){animation-delay:.1s}.code-tabs .tab-list>.tab-trigger:nth-child(3){animation-delay:.15s}.code-tabs .tab-list>.tab-trigger:nth-child(4){animation-delay:.2s}.code-tabs .tab-list>.tab-trigger:nth-child(5){animation-delay:.25s}.code-tabs .tab-list>.tab-trigger:nth-child(6){animation-delay:.3s}.code-tabs .tab-list>.tab-trigger:nth-child(7){animation-delay:.35s}.code-tabs .tab-list>.tab-trigger:nth-child(8){animation-delay:.4s}.code-tabs .tab-list>.tab-trigger:nth-child(9){animation-delay:.45s}.code-tabs .tab-list>.tab-trigger:nth-child(10){animation-delay:.5s}.code-tabs .tab-list::-webkit-scrollbar{height:6px}.code-tabs .tab-list::-webkit-scrollbar-thumb{background:rgba(128,128,128,.37);border-radius:3px}.code-tabs .tab-trigger{flex:0 0 auto;width:2.5rem;height:2.5rem;background:rgba(0,0,0,0);border:none;border-radius:.5rem;cursor:pointer;box-sizing:border-box;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .2s}.code-tabs .tab-trigger img{width:1.25rem;height:1.25rem;filter:grayscale(100%) opacity(.6);transition:filter .2s,transform .2s}.code-tabs .tab-trigger.active img,.code-tabs .tab-trigger:hover img{filter:brightness(0) drop-shadow(0 0 0 var(--primary-accent));transform:scale(1.1)}.code-tabs .code-panel pre{background:var(--bg-color);border:1px solid rgba(128,128,128,.37);border-radius:.75rem;margin-top:0!important;overflow-x:auto;white-space:pre;text-align:left;font-size:.9rem;margin-left:0!important;padding:15px 1rem 2rem 0!important;opacity:0;animation:fade-slide-down .3s ease-out forwards;animation-delay:.4s}.code-tabs .doc-link{text-align:right;margin-top:.5rem;font-size:.875rem}.code-tabs .doc-link a{color:var(--link-color)}@media(max-width:600px){.code-tabs .tab-list{gap:.5rem;padding:.5rem}.code-tabs .tab-trigger{width:2rem;height:2rem}.code-tabs .tab-trigger img{width:1rem;height:1rem}.code-tabs .code-panel pre{padding:1rem!important;font-size:.8rem}.code-tabs .doc-link{font-size:.75rem}}body[data-theme=dark] .code-tabs .tab-trigger img{filter:brightness(0) invert(1) opacity(.6)}body[data-theme=dark] .code-tabs .tab-trigger.active img,body[data-theme=dark] .code-tabs .tab-trigger:hover img{filter:brightness(0) invert(1) drop-shadow(0 0 0 var(--primary-accent)) opacity(1);transform:scale(1.1)}