:root{--cyan:#44d9e6;--green:#3ddc97;--hero-clr-audio:#e68a00;--hero-clr-game:#3ddc97;--section-web:#e1772c;--section-audio:#3b83f6;--section-games:#10b981;--section-music:#8b5cf6}html,body,#root{-webkit-user-select:none;user-select:none;min-height:100%;margin:0;padding:0;overflow-x:clip}body{background:var(--bg);color:var(--text);margin:0;font-family:Inter,sans-serif;font-weight:700;transition:background .3s}.App{flex-direction:column;min-height:100vh;display:flex;overflow-x:hidden}[data-theme=dark]{--header-bgr:#ffffff05;--header-scroll-bgr:#0a0e171a;--header-border:#ffffff1a;--bg:#0a0e17;--bg2:#111827;--panel:#1b2432;--contrast:#000;--text:#f4f4f5;--text-secondary:#a0aec0;--text-glow_1:#24105680;--text-glow_2:#5c381240;--hover-bgr:#ffffff0d;--accent:#ffb84d;--projects-bgr:#0d0d0de6;--hero-clr-web:#cfcfcf}[data-theme=light]{--header-bgr:#00000005;--header-scroll-bgr:#ffffff1a;--header-border:#0505051a;--bg:#f7f8fc;--bg2:#edf2f7;--panel:#fff;--contrast:#fff;--text:#1f2937;--text-secondary:#6b7280;--text-glow_1:#cac0e480;--text-glow_2:#ebdecf40;--hover-bgr:#0000000d;--accent:#e68a00;--projects-bgr:#eef3ffc5;--hero-clr-web:#1f2937}.page-content{z-index:1;flex-direction:column;display:flex;position:relative}.page-content *{z-index:999}.title{margin-top:30px}section .title{color:#fff;font-size:40px;font-weight:400}section .content{margin:20px;font-size:16px}.footer{box-sizing:border-box;background:var(--header-bgr);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid var(--header-border);width:100%;padding:28px 20px}.footer-inner{flex-wrap:wrap;justify-content:center;gap:14px;width:min(1000px,100%);margin:0 auto;display:flex}.footer-link{min-width:150px;color:var(--text);background:var(--hover-bgr);border:1px solid var(--header-border);border-radius:999px;justify-content:center;align-items:center;gap:10px;padding:12px 16px;text-decoration:none;transition:transform .2s,border-color .2s;display:flex}.footer-icon{object-fit:contain;width:22px;height:22px}.footer-link:hover{border-color:var(--accent);transform:translateY(-3px)}@media (width<=700px){.footer-inner{grid-template-columns:1fr 1fr;display:grid}.footer-link{min-width:0}}.switch-button{pointer-events:all;cursor:pointer;width:50px;height:25px;position:relative;top:0;left:0}.switch-button .background{background:var(--text);border-radius:20px;width:50px;height:25px;transition:background .3s;position:absolute}.switch-button{position:relative}.switch-button .switch-icon{background:var(--contrast);z-index:999;border-radius:50%;width:23px;height:23px;transition:transform .3s,background .3s;position:absolute;top:1px;left:1px}.switch-icon>img{z-index:999;width:18px;height:18px;position:absolute;top:2.5px;left:2px}.switch-button .switch-icon.on{transform:translate(25px)}header{z-index:99999;border-bottom:none;justify-content:center;align-items:center;width:100%;height:72px;display:flex;position:fixed;top:0}.header-top{pointer-events:none;position:absolute;inset:0}.header-title,.header-theme-toggle{pointer-events:auto}.header-title{width:80px;height:100%;color:var(--text);cursor:pointer;white-space:nowrap;text-align:center;letter-spacing:.12em;text-transform:uppercase;justify-content:center;align-items:center;font-family:Bebas Neue,sans-serif;font-size:24px;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.header-title:hover{background-color:#00000005}.header-theme-toggle{position:absolute;top:50%;right:40px;transform:translateY(-50%)}.header-content{-webkit-backdrop-filter:blur(32px);backdrop-filter:blur(32px);border-bottom:1px solid var(--header-border);justify-content:center;align-items:center;width:100%;height:72px;transition:width .3s,height .3s,border-radius .3s,background .3s,transform .3s;display:flex;position:relative}.header-content.scrolling{background:var(--header-scroll-bgr);height:58px;transform:translateY(-8px)}.header-content nav{border-radius:inherit;height:100%;display:flex;overflow:hidden}.header-button{color:var(--text);cursor:pointer;background:0 0;border:none;height:100%;padding:0 22px;font-size:15px;font-weight:700;transition:background .3s,color .3s;position:relative}.header-button:not(:last-child):after{content:"";background:var(--text);opacity:.2;width:1px;height:60%;transition:height .3s,top .3s,opacity .3s;position:absolute;top:20%;right:0}.header-button:not(:last-child):hover:after{opacity:1;height:80%;top:10%}.header-button:hover{background:var(--hover-bgr);color:var(--accent)}.header-theme-toggle{position:absolute;right:40px}@media (width<=700px){header{align-items:flex-start;height:120px;top:0;overflow:visible}.header-content{flex-direction:column;justify-content:flex-start;height:120px;padding:0;transform:none}.header-content.scrolling{background:var(--header-scroll-bgr);height:64px;transform:none}.header-top{box-sizing:border-box;pointer-events:auto;justify-content:space-between;align-items:center;width:100%;height:56px;min-height:56px;padding:0 16px;transition:height .3s,min-height .3s,opacity .2s,transform .3s;display:flex;position:static}.header-content.scrolling .header-top{opacity:0;pointer-events:none;height:0;min-height:0;overflow:hidden;transform:translateY(-56px)}.header-title,.header-theme-toggle{position:static;transform:none}.header-content nav{border-bottom:1px solid var(--border);width:100%;height:64px;min-height:64px}.header-button{flex:1;padding:0;font-size:13px}}.skills-panel{border-radius:20px;grid-template-columns:repeat(5,1fr);gap:20px;width:50%;margin:0 auto;padding:12px;display:grid}.skill{aspect-ratio:1;justify-content:center;align-items:center;display:flex}.skill img{object-fit:contain;width:95%;height:95%}@media (width<=700px){.skills-panel{width:300px}}.about-section{box-sizing:border-box;-webkit-user-select:text;user-select:text;justify-content:center;width:100%;padding:140px 24px 20px;display:flex}.about-card{border:1px solid var(--header-border);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#ffffff0e;border-radius:28px;width:min(860px,100%);padding:42px;box-shadow:0 24px 80px #00000038}.about-kicker{color:var(--accent);text-transform:uppercase;letter-spacing:.16em;margin-bottom:18px;font-family:JetBrains Mono,monospace;font-size:.85rem}.about-card h2{color:var(--text);letter-spacing:-.05em;margin:0 0 24px;font-size:clamp(2rem,5vw,4rem);line-height:1}.about-card p{max-width:720px;color:var(--text-secondary);font-size:1.05rem;line-height:1.75}@media (width<=700px){.about-card{width:calc(100% - 32px);padding:28px}}.contact-section{box-sizing:border-box;justify-content:center;align-items:center;width:100%;min-height:400px;padding:120px 24px;display:flex}.contact-section h2{color:var(--text)}.contact-card{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#0c101eb8;border:1px solid #ffffff24;border-radius:28px;width:min(400px,100%);padding:36px;box-shadow:0 24px 80px #0006}.contact-header{text-align:center;margin-bottom:28px}.contact-header h2{margin:0;font-size:clamp(2rem,5vw,3.5rem)}.contact-header p{max-width:480px;color:var(--text-secondary);margin:12px auto 0;line-height:1.6}.contact-form{flex-direction:column;gap:18px;display:flex}.form-field{flex-direction:column;gap:8px;display:flex}.form-field label{color:var(--text-secondary);letter-spacing:.04em;text-transform:uppercase;font-size:.85rem;font-weight:800}.form-field input,.form-field textarea{box-sizing:border-box;width:100%;color:var(--text);font:inherit;background:#ffffff0f;border:1px solid #ffffff24;border-radius:14px;outline:none;padding:14px 16px;transition:border-color .2s,background .2s,box-shadow .2s}.form-field textarea{resize:vertical;min-height:150px}.form-field input:focus,.form-field textarea:focus{border-color:var(--accent);background:#ffffff17;box-shadow:0 0 0 4px #ffb84d1f}.contact-form button{cursor:pointer;background:var(--accent);color:#0a0e17;border:none;border-radius:999px;margin-top:8px;padding:14px 20px;font-size:1rem;font-weight:900;transition:transform .2s,box-shadow .2s}.contact-form button:hover{transform:translateY(-2px);box-shadow:0 12px 30px #ffb84d40}.contact-success>h3{margin-top:358px}@media (width<=700px){.contact-card{background:#5c7ae7b8;border:1px solid #00000024;box-shadow:0 24px 80px #fff6}}.hero-section{text-align:center;flex-direction:row;justify-content:center;height:calc(100vh - 340px);margin-top:73px;padding:20px;display:flex}.hero-section>div{flex:1}.hero-section .left{flex-direction:column;justify-content:center;align-items:center;font-family:Space Grotesk,sans-serif;font-size:120px;font-weight:700;display:flex}.left>:first-child{color:var(--hero-clr-web);text-underline-offset:-8px;text-decoration:underline;transition:color .3s}.left>:nth-child(2){color:var(--hero-clr-audio);transition:color .3s}.right>:first-child{color:var(--hero-clr-web);transition:color .3s}.right>:nth-child(2){color:var(--hero-clr-audio);transition:color .3s}.right>:nth-child(3){color:var(--hero-clr-game);transition:color .3s}.right>div{cursor:pointer;transition:transform .3s}.hero-section .right{flex-direction:column;justify-content:center;align-items:center;font-family:JetBrains Mono,monospace;font-size:40px;font-weight:500;display:flex}.hero-name,.hero-job{text-shadow:0 0 8px var(--text-glow_1), 0 0 24px var(--text-glow_2);line-height:1.25;transition:text-shadow 2s;display:block}.hero-job{display:inline-block;position:relative}.hero-section:not(.animating) .hero-job:hover:after{content:"";background:currentColor;height:1px;position:absolute;bottom:6px;left:0;right:0}.hero-job{letter-spacing:.04em}.char-line{overflow:visible}.char{transform-origin:bottom;will-change:transform, opacity;display:inline-block}@media (width<=700px){.hero-section{flex-direction:column;margin-top:200px}.hero-section .left{font-size:60px}.hero-section{height:calc(100vh - 450px)}.hero-section .right{margin-top:20px;font-size:30px}}.spotify-section{width:60%;height:100%}.spotify-container{flex-direction:row;gap:40px;height:400px;margin-top:30px;display:flex}.spotify-container>*{flex:1 1 0;min-width:0;min-height:0}@media (width<=700px){.spotify-container{flex-direction:column;gap:10px}.spotify-section{width:90%}}.overlay h3{margin:0;font-size:2rem}.overlay p{max-width:620px;color:var(--text);margin:0;line-height:1.6}.overlay .label{width:fit-content;color:var(--accent);pointer-events:none;flex:1;margin:0 0 5px;font-size:2rem;font-weight:800;text-decoration:none}.open-button{background:var(--accent);color:#0a0e17;cursor:pointer;border:none;padding:8px 14px}.open-button:hover{filter:brightness(1.1);transform:translateY(-1px)}.demo-button{color:#fff;cursor:pointer;background:0 0;border:1px solid #ffffff40;padding:8px 14px}.demo-button:hover{background:#ffffff1a}.project-meta,.project-tags{flex-wrap:wrap;gap:8px;display:flex}.pill{letter-spacing:.02em;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:999px;width:fit-content;padding:6px 10px;font-size:.78rem;font-weight:800}.pill.language{color:#0a0e17;background:var(--accent)}.pill.tag{color:#fff;background:#ffffff1f;border:1px solid #ffffff29}.project-header{justify-content:space-between;align-items:flex-start;gap:24px;display:flex}.project-title{flex-direction:column;display:flex}.project-tech{flex-direction:column;align-items:flex-end;gap:8px;display:flex}.project-languages,.project-tags{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}@media (width<=700px){.carousel{height:460px}.entry{height:370px}.overlay{padding:22px}}.entry{background:#ffffff0a;border:1px solid #ffffff1f;border-radius:24px;width:min(720px,78vw);height:450px;transition:transform .45s,opacity .45s,box-shadow .45s;position:absolute;overflow:hidden;box-shadow:0 20px 70px #00000059}.entry.active{box-shadow:0 30px 100px #0000008c}.entry img{object-fit:cover;transition:transform .45s}.entry>img:not(.close-button),.entry-video{object-fit:cover;width:100%;height:100%;display:block}.overlay{opacity:0;background:linear-gradient(#0a0e170d,#0a0e174d,#0a0e17f5);flex-direction:column;justify-content:flex-end;gap:12px;padding:32px;transition:opacity .25s;display:flex;position:absolute;inset:0}.entry.active:hover:not(.transitioning) .overlay{opacity:1}.entry.transitioning .overlay,.entry.transitioning:hover .overlay,.entry.active.transitioning:hover .overlay,.entry.video-open .overlay{opacity:0;pointer-events:none}.entry.video-open{cursor:default;border-radius:0}.entry:not(.active):hover{cursor:pointer;filter:brightness(1.2)}.right-corner{z-index:20;box-sizing:border-box;pointer-events:none;background:radial-gradient(circle at 100% 0,#0a0e17d9 0%,#0a0e1773 42%,#0a0e1700 72%);justify-content:flex-end;align-items:flex-start;width:64px;height:64px;padding:6px;display:flex;position:absolute;top:0;right:0}.close-button{object-fit:contain;opacity:.45;cursor:pointer;pointer-events:auto;width:30px;height:30px;transition:opacity .2s,transform .2s}.close-button:hover{opacity:.9;transform:scale(1.15)}@media (width<=700px){.entry{touch-action:pan-y;-webkit-user-select:none;user-select:none}.right-corner{background:0 0;justify-content:center;align-items:flex-start;padding-top:4px;top:0;left:50%;transform:translate(-50%)}}.carousel-section{flex-direction:column;align-items:center;width:100%;display:flex}.carousel-info{box-sizing:border-box;background:#ffffff1a;border-radius:5px;padding:20px}.carousel-description{width:min(900px,82vw);color:var(--contrast);opacity:.8;margin-top:2rem;margin-bottom:0;font-size:clamp(.95rem,1.4vw,1.15rem);line-height:1.6}.carousel-description.left{text-align:left}.carousel-description.center{text-align:center}.carousel-description.right{text-align:right}.carousel-content{justify-content:center;align-items:center;width:100%;height:540px;display:flex;position:relative}.carousel-track{justify-content:center;align-items:center;width:min(900px,82vw);height:100%;display:flex;position:relative}.projects-section{width:100%;min-height:100vh;color:var(--text);flex-direction:column;align-items:center;padding:80px 0;display:flex;position:relative;overflow:hidden}.projects-content{flex-direction:column;align-items:center;gap:300px;width:100%;min-height:100vh;display:flex;overflow:hidden}.projects-section .sub-title{letter-spacing:.08em;text-transform:uppercase;color:var(--text);align-self:center;margin-bottom:0;font-family:Space Grotesk,sans-serif;font-size:clamp(1.4rem,2.5vw,2.5rem);font-weight:700;display:inline-block;position:relative}.projects-section .sub-title:after{content:"";background:var(--text);border-radius:999px;width:70px;height:3px;position:absolute;bottom:-10px;left:0}.projects-intro{cursor:pointer;color:var(--contrast);border-radius:5px;flex-direction:row;align-items:center;gap:18px;margin:48px 0 80px;padding:15px;display:flex}.projects-intro:hover{color:var(--text);background:#0000001a}.projects-title{letter-spacing:.18em;text-transform:uppercase;text-align:center;font-family:Space Grotesk,sans-serif;font-size:clamp(2rem,4vw,3.2rem);font-weight:300}.projects-arrow{opacity:.8;-webkit-user-select:none;user-select:none;width:42px;height:auto}@media (width<=700px){.projects-section .sub-title{text-align:center;align-self:center;width:fit-content;max-width:90%}.carousel-section .sub-title:after,.projects-section .sub-title:after{right:auto;transform:translate(-50%);left:50%!important}.projects-intro{color:var(--text);margin-top:30px;margin-bottom:100px}.projects-content{gap:120px}}.wave-bg{opacity:1;width:100%;position:absolute;left:0}.sliding-element{z-index:1;pointer-events:none;will-change:transform;width:128px;height:128px;position:absolute;top:0;left:0}.sliding-element-inner{box-sizing:border-box;background:0 0;border:24px groove #ffffff4d;border-radius:50%;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative;overflow:hidden}@media (width<=700px){.sliding-element{width:64px;height:64px}.sliding-element-inner{border:12px groove #ffffff4d}}
