@import "https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Orbitron:wght@400..900&family=Space+Grotesk:wght@300..700&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-base:#f7f3ee;--bg-surface:#fefcf8;--bg-elevated:#f0ebe3;--accent:#6366f1;--accent-2:#ec4899;--text-primary:#1e1b4b;--text-secondary:#4338ca;--border:#e8e1d9;--shadow-navbar:0 25px 50px -12px #0000001f, 0 15px 25px -15px #00000014;--transition:.3s cubic-bezier(.4, 0, .2, 1)}body.dark{--bg-base:#0f0f12;--bg-surface:#1a1a1e;--bg-elevated:#222228;--accent:#a855f7;--accent-2:#ec4899;--text-primary:#f8fafc;--text-secondary:#a1a1aa;--border:#a855f733;--shadow-navbar:0 30px 60px -15px #000c, 0 0 15px -5px #a855f766}body{background-color:var(--bg-base);color:var(--text-primary);font-family:Inter,sans-serif;overflow-x:hidden}.loader-container{background:var(--bg-base);z-index:9999;flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.loader-percentage{background:linear-gradient(135deg, var(--accent), var(--accent-2));-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-family:Orbitron,sans-serif;font-size:clamp(3rem,6vw,5rem);font-weight:900}.orbs-layer{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.orb{filter:blur(100px);opacity:.12;border-radius:50%;position:absolute;transform:translate(0,0)}body.dark .orb{opacity:.09}.orb--1{background:var(--accent);width:520px;height:520px;animation:34s ease-in-out infinite orbFloat;top:-200px;right:-200px}.orb--2{background:var(--accent-2);width:420px;height:420px;animation:38s ease-in-out -10s infinite reverse orbFloat;bottom:-180px;left:-180px}.orb--3{background:var(--accent);opacity:.05;width:280px;height:280px;animation:42s ease-in-out infinite orbPulse;top:50%;left:50%;transform:translate(-50%,-50%)}body.dark .orb--3{opacity:.03}@keyframes orbFloat{0%{transform:translate(0)scale(1)}50%{transform:translate(20px,-15px)scale(1.04)}to{transform:translate(-15px,20px)scale(.99)}}@keyframes orbPulse{0%{opacity:.04;transform:translate(-50%,-50%)scale(1)}50%{opacity:.07;transform:translate(calc(15px - 50%),calc(-50% - 10px))scale(1.06)}to{opacity:.04;transform:translate(calc(-50% - 10px),calc(10px - 50%))scale(.98)}}.tracking-in-expand{animation:1.4s cubic-bezier(.215,.61,.355,1) both tracking-in-expand}@keyframes tracking-in-expand{0%{letter-spacing:-.5em;opacity:0}40%{opacity:.6}to{opacity:1}}@keyframes tagFloat{0%,to{transform:translateY(0);box-shadow:0 8px 25px #00000014}50%{transform:translateY(-20px);box-shadow:0 18px 45px #0000001f}}@media (width<=768px){.orb{filter:blur(85px);opacity:.08}.orb--3{display:none}body.dark .orb{opacity:.06}}.navbar{z-index:1000;opacity:0;width:95%;max-width:1000px;transition:all .6s cubic-bezier(.2,1,.3,1);position:fixed;top:25px;left:50%;transform:translate(-50%)translateY(-20px)}.navbar.visible{opacity:1;transform:translate(-50%)translateY(0)}.navbar-container{background:var(--bg-surface);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);box-shadow:var(--shadow-navbar);border-radius:999px;justify-content:space-between;align-items:center;padding:.6rem 1.2rem;display:flex}.logo{background:linear-gradient(135deg, var(--accent), #ec4899);-webkit-text-fill-color:transparent;z-index:1001;-webkit-background-clip:text;font-family:Orbitron,sans-serif;font-size:1.4rem;font-weight:800;text-decoration:none;position:relative}.desktop-menu{align-items:center;gap:.5rem;list-style:none;display:flex}.nav-link{color:var(--text-secondary);transition:var(--transition);border-radius:999px;padding:.6rem 1.2rem;font-size:.9rem;font-weight:600;text-decoration:none}.nav-link:hover{color:var(--accent);background:#6366f114}.theme-toggle{background:var(--bg-elevated);border:1px solid var(--border);color:var(--accent);cursor:pointer;width:38px;height:38px;transition:var(--transition);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.theme-toggle:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.lang-toggle{border:1px solid var(--border);background:var(--bg-elevated);cursor:pointer;border-radius:999px;justify-content:space-between;align-items:center;width:74px;height:38px;padding:4px;display:flex;position:relative;overflow:hidden}.lang-toggle:hover{border-color:color-mix(in srgb, var(--accent) 40%, var(--border));box-shadow:0 0 0 4px color-mix(in srgb, var(--accent) 10%, transparent)}.lang-toggle:before{content:"";background:var(--accent);border-radius:999px;width:30px;height:30px;transition:left .28s cubic-bezier(.2,1,.3,1);position:absolute;top:50%;left:5px;transform:translateY(-50%)}.lang-toggle:has(.active:last-child):before{left:38px}.lang-toggle span{z-index:2;width:50%;color:var(--text-secondary);justify-content:center;align-items:center;font-size:.72rem;font-weight:700;display:flex;position:relative}.lang-toggle span.active{color:#fff}.mobile-controls{z-index:1001;align-items:center;gap:.5rem;display:none;position:relative}.hamburger{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary);cursor:pointer;width:38px;height:38px;transition:var(--transition);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.hamburger:hover{border-color:var(--accent);color:var(--accent)}.fullscreen-menu{z-index:999;background:var(--bg-base);opacity:0;pointer-events:none;transition:opacity .35s cubic-bezier(.4,0,.2,1);display:none;position:fixed;inset:0}.fullscreen-menu.open{opacity:1;pointer-events:all}.fullscreen-menu-inner{flex-direction:column;justify-content:center;align-items:center;gap:0;width:100%;height:100%;padding:6rem 2rem 3rem;display:flex}.mobile-nav-menu{flex-direction:column;gap:.5rem;width:100%;max-width:400px;list-style:none;display:flex}.mobile-nav-menu li{opacity:0;transform:translateY(24px)}.fullscreen-menu.open .mobile-nav-menu li{animation:.45s cubic-bezier(.34,1.56,.64,1) forwards menuItemIn}.mobile-nav-menu li:first-child{animation-delay:80ms}.mobile-nav-menu li:nth-child(2){animation-delay:.15s}.mobile-nav-menu li:nth-child(3){animation-delay:.22s}@keyframes menuItemIn{to{opacity:1;transform:translateY(0)}}.mobile-nav-link{width:100%;color:var(--text-primary);letter-spacing:.04em;border:1px solid #0000;border-radius:16px;justify-content:space-between;align-items:center;padding:1.4rem 1.6rem;font-family:Orbitron,sans-serif;font-size:1.6rem;font-weight:900;text-decoration:none;transition:all .2s;display:flex}.mobile-nav-link:hover{border-color:var(--border);color:var(--accent);background:#6366f112;padding-left:2rem}.mobile-nav-link:after{content:"→";opacity:0;font-family:monospace;font-size:1.2rem;transition:all .2s;transform:translate(-8px)}.mobile-nav-link:hover:after{opacity:1;transform:translate(0)}.mobile-nav-menu li+li{border-top:1px solid var(--border)}.mobile-link-index{color:var(--accent);opacity:.6;letter-spacing:.1em;margin-right:.8rem;font-family:Orbitron,sans-serif;font-size:.65rem}@media (width<=640px){.desktop-menu{display:none}.mobile-controls,.fullscreen-menu{display:flex}}.hero{justify-content:center;align-items:center;height:100vh;padding:0 2rem;display:flex;position:relative;overflow:hidden}.tags-layer{pointer-events:none;z-index:5;width:100%;max-width:1400px;height:80%;position:absolute}.floating-tag{background:var(--bg-surface);border:1.5px solid var(--border);border-left:3px solid var(--accent);color:var(--text-primary);opacity:.85;letter-spacing:.08em;border-radius:10px;padding:9px 18px;font-family:Orbitron,sans-serif;font-size:.72rem;font-weight:700;animation:6s ease-in-out infinite tagFloat;position:absolute;box-shadow:0 8px 32px #6366f126,0 2px 8px #0000001a,inset 0 1px #ffffffb3}body.dark .floating-tag{box-shadow:0 8px 32px #a855f733,0 2px 8px #0006,inset 0 1px #ffffff0d}.hero-content{z-index:10;align-items:center;gap:5rem;width:100%;max-width:1100px;display:flex}.hero-text{flex:1}.hero-eyebrow{color:var(--accent);letter-spacing:2px;margin-bottom:10px;font-family:Orbitron,sans-serif;font-size:.8rem;font-weight:700}.hero-name{margin-bottom:1.5rem;font-family:Orbitron,sans-serif;font-size:3.8rem;font-weight:900;line-height:1.1}.hero-name span{background:linear-gradient(135deg, var(--accent), #ec4899);-webkit-text-fill-color:transparent;-webkit-background-clip:text}.hero-desc{max-width:500px;margin-bottom:1.2rem;font-size:1.1rem;line-height:1.6}.hero-location{color:var(--text-secondary);margin-bottom:1.8rem;font-family:Orbitron,sans-serif;font-size:.8rem}.cv-btn{background:linear-gradient(135deg, var(--accent), #ec4899);color:#fff;cursor:pointer;border:none;border-radius:999px;align-items:center;gap:.5rem;padding:.7rem 1.4rem;font-size:.9rem;font-weight:700;text-decoration:none;transition:all .3s;display:inline-flex;box-shadow:0 4px 20px #6366f159}.cv-btn:hover{transform:translateY(-2px);box-shadow:0 8px 30px #6366f180}.hero-image-stack{cursor:pointer;flex-shrink:0;width:420px;height:440px;margin-top:40px;position:relative}.img-container{border:1.5px solid var(--border);border-radius:24px;width:300px;height:360px;transition:all .5s cubic-bezier(.4,0,.2,1);position:absolute;top:0;left:0;overflow:hidden;box-shadow:0 25px 60px #0000002e,0 8px 20px #6366f11a}.portrait-box{z-index:2;opacity:1;filter:grayscale(0);transform:translate(0)scale(1)}.raccoon-box{z-index:1;opacity:.5;filter:grayscale();transform:translate(120px,80px)scale(.82)}.hero-image-stack:hover .portrait-box{transform:translate(0)scale(1)rotate(-1deg)translate(6px)}.hero-image-stack:hover .raccoon-box{opacity:.7;filter:grayscale(.5);transform:translate(114px,76px)scale(.85)}.hero-image-stack.flipped .portrait-box{opacity:.5;filter:grayscale();z-index:1;transform:translate(120px,80px)scale(.82)}.hero-image-stack.flipped .raccoon-box{opacity:1;filter:grayscale(0);z-index:2;transform:translate(0)scale(1)}.hero-image-stack:active{transform:scale(.97)}.img-container img{object-fit:cover;width:100%;height:100%}.img-label{background:var(--accent);color:#fff;letter-spacing:.06em;border-radius:4px;padding:4px 10px;font-family:Orbitron,sans-serif;font-size:.6rem;position:absolute;top:12px;left:12px}.face-action{cursor:pointer;letter-spacing:.1em;color:#fff;opacity:0;-webkit-backdrop-filter:blur(14px);background:#08081285;border:none;border-radius:999px;outline:1px solid #6366f173;align-items:center;gap:6px;padding:9px 22px;font-family:Orbitron,sans-serif;font-size:.62rem;font-weight:700;transition:all .25s;display:inline-flex;position:absolute;bottom:16px;left:50%;transform:translate(-50%)translateY(10px);box-shadow:0 4px 24px #0006,inset 0 1px #ffffff1a,inset 0 -1px #0003}.face-action:after{content:"→";opacity:.8;font-size:.7rem;transition:transform .2s}.img-container:hover .face-action{opacity:1;transform:translate(-50%)translateY(0)}.face-action:hover{background:#6366f159;outline-color:#6366f1cc;box-shadow:0 8px 32px #6366f159,inset 0 1px #ffffff26;transform:translate(-50%)translateY(-2px)!important}.face-action:hover:after{transform:translate(3px)}@media (width<=1024px){.hero-content{gap:3rem}.hero-name{font-size:3rem}.hero-image-stack{width:360px;height:380px}.img-container{width:255px;height:310px}.raccoon-box,.hero-image-stack.flipped .portrait-box{transform:translate(105px,70px)scale(.82)}}@media (width<=900px){.hero{height:auto;min-height:100vh;padding:6rem 2rem 4rem}.hero-content{text-align:center;flex-direction:column;align-items:center;gap:3rem}.hero-desc{margin:0 auto 1.2rem}.tags-layer{display:none}.hero-image-stack{width:320px;height:345px;margin-top:0}.img-container{width:230px;height:280px}.raccoon-box,.hero-image-stack.flipped .portrait-box{transform:translate(90px,65px)scale(.82)}}@media (width<=480px){.hero{padding:8rem 1.2rem 3rem}.hero-name{font-size:2.2rem}.hero-image-stack{width:290px;height:315px}.img-container{width:205px;height:250px}.raccoon-box,.hero-image-stack.flipped .portrait-box{transform:translate(85px,65px)scale(.82)}}@media (width<=360px){.hero-name{font-size:1.8rem}.hero-image-stack{width:255px;height:280px}.img-container{width:180px;height:220px}.raccoon-box,.hero-image-stack.flipped .portrait-box{transform:translate(75px,60px)scale(.82)}}.services{flex-direction:column;align-items:center;min-height:auto;padding:7rem 2rem 5rem;display:flex;position:relative}.services-header{text-align:center;opacity:0;margin-bottom:4rem;transition:opacity .6s,transform .6s;transform:translateY(30px)}.services-header--visible{opacity:1;transform:translateY(0)}.services-eyebrow{letter-spacing:3px;color:var(--accent);margin-bottom:.8rem;font-family:Orbitron,sans-serif;font-size:.75rem;font-weight:700}.services-title{color:var(--text-primary);margin-bottom:1rem;font-family:Orbitron,sans-serif;font-size:3rem;font-weight:900;line-height:1.1}.services-title span{background:linear-gradient(135deg, var(--accent), #ec4899);-webkit-text-fill-color:transparent;-webkit-background-clip:text}.services-subtitle{color:var(--text-secondary);max-width:520px;margin:0 auto;font-size:1rem;line-height:1.6}.services-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;width:100%;max-width:1100px;display:grid}.service-card{background:var(--bg-surface);border:1px solid var(--border);opacity:0;border-radius:20px;flex-direction:column;gap:0;padding:2rem;transition:opacity .5s,transform .5s,box-shadow .3s,border-color .3s;display:flex;transform:translateY(40px);box-shadow:0 4px 24px #0000000f}.service-card--visible{opacity:1;transform:translateY(0)}.service-card:hover{box-shadow:var(--shadow-navbar);border-color:color-mix(in srgb, var(--accent) 40%, var(--border) 60%);transform:translateY(-5px)}.service-card__top{justify-content:space-between;align-items:center;margin-bottom:1.4rem;display:flex}.service-card__number{letter-spacing:2px;color:var(--accent);opacity:.6;font-family:Orbitron,sans-serif;font-size:.65rem;font-weight:900}.service-card__icon{background:var(--bg-elevated);border:1px solid var(--border);width:42px;height:42px;color:var(--accent);transition:var(--transition);border-radius:12px;justify-content:center;align-items:center;display:flex}.service-card:hover .service-card__icon{background:color-mix(in srgb, var(--accent) 12%, transparent);border-color:color-mix(in srgb, var(--accent) 40%, var(--border))}.service-card__title{color:var(--text-primary);margin-bottom:.8rem;font-family:Space Grotesk,sans-serif;font-size:1.15rem;font-weight:800;line-height:1.3}.service-card__desc{color:var(--text-primary);opacity:.75;flex:1;margin-bottom:1.4rem;font-size:.9rem;line-height:1.75}.service-card__tags{flex-wrap:wrap;gap:.4rem;margin-top:auto;display:flex}.service-tag{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary);transition:var(--transition);cursor:default;border-radius:999px;padding:3px 11px;font-size:.72rem;font-weight:600}.service-tag:hover{background:color-mix(in srgb, var(--accent) 12%, transparent);border-color:var(--accent);color:var(--accent)}@media (width<=1024px){.services-title{font-size:2.4rem}.services-grid{grid-template-columns:repeat(2,1fr)}.service-card:last-child{grid-column:1/-1;justify-self:center;width:100%;max-width:560px}}@media (width<=768px){.services{padding:5rem 1.2rem 4rem}.services-title{font-size:2rem}.services-grid{grid-template-columns:1fr}.service-card:last-child{grid-column:unset;justify-self:unset;max-width:none}}@media (width<=480px){.services-title{font-size:1.7rem}.services-subtitle{font-size:.9rem}.service-card{padding:1.5rem}}.about{flex-direction:column;align-items:center;min-height:100vh;padding:8rem 2rem 6rem;display:flex;position:relative}.about-header{text-align:center;opacity:0;margin-bottom:4rem;transition:opacity .6s,transform .6s;transform:translateY(30px)}.about-header--visible{opacity:1;transform:translateY(0)}.about-eyebrow{letter-spacing:3px;color:var(--accent);margin-bottom:.8rem;font-family:Orbitron,sans-serif;font-size:.75rem;font-weight:700}.about-title{color:var(--text-primary);margin-bottom:1rem;font-family:Orbitron,sans-serif;font-size:3rem;font-weight:900;line-height:1.1}.about-title span{background:linear-gradient(135deg, var(--accent), #ec4899);-webkit-text-fill-color:transparent;-webkit-background-clip:text}.about-subtitle{color:var(--text-secondary);max-width:520px;margin:0 auto;font-size:1rem;line-height:1.6}.about-grid{grid-template-columns:1fr 1fr;gap:1.5rem;width:100%;max-width:1100px;margin-bottom:5rem;display:grid}.about-card{background:var(--bg-surface);border:1px solid var(--border);opacity:0;border-radius:20px;padding:2rem;transition:opacity .5s,transform .5s,box-shadow .3s;transform:translateY(40px);box-shadow:0 4px 24px #0000000f}.about-card--visible{opacity:1;transform:translateY(0)}.about-card:hover{box-shadow:var(--shadow-navbar);transform:translateY(-4px)}.about-card__icon{background:var(--bg-elevated);border:1px solid var(--border);width:42px;height:42px;color:var(--accent);border-radius:10px;justify-content:center;align-items:center;margin-bottom:1rem;display:flex}.about-card__title{letter-spacing:2px;color:var(--accent);text-transform:uppercase;margin-bottom:1.2rem;font-family:Orbitron,sans-serif;font-size:.78rem;font-weight:700}.about-card__body{flex-direction:column;gap:.9rem;display:flex}.about-card__body p{color:var(--text-primary);opacity:.85;font-size:.95rem;line-height:1.75}.about-card__body p strong{color:var(--text-primary);opacity:1;font-weight:700}.skill-groups{flex-direction:column;gap:1rem;margin-bottom:1.2rem;display:flex}.skill-group{align-items:flex-start;gap:.8rem;display:flex}.skill-group__label{letter-spacing:1.5px;color:var(--text-secondary);text-transform:uppercase;min-width:72px;padding-top:5px;font-family:Orbitron,sans-serif;font-size:.6rem;font-weight:700}.skill-group__tags{flex-wrap:wrap;gap:.4rem;display:flex}.skill-tag{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary);transition:var(--transition);cursor:default;border-radius:999px;padding:4px 12px;font-size:.78rem;font-weight:600}.skill-tag:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.about-stack-note{color:var(--text-primary);opacity:.8;border-left:3px solid var(--accent);padding-left:1rem;font-size:.9rem;line-height:1.7}.about-stack-note strong{opacity:1;font-weight:700}.about-timeline{width:100%;max-width:800px}.timeline-item{opacity:0;grid-template-columns:90px 32px 1fr;align-items:start;gap:0 1.2rem;transition:opacity .5s,transform .5s;display:grid;transform:translate(-20px)}.timeline-item--visible{opacity:1;transform:translate(0)}.timeline-year{color:var(--accent);letter-spacing:1px;text-align:right;word-break:break-word;padding-top:4px;font-family:Orbitron,sans-serif;font-size:.62rem;font-weight:700}.timeline-connector{flex-direction:column;align-items:center;display:flex}.timeline-dot{background:var(--bg-elevated);border:2px solid var(--accent);width:24px;height:24px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.timeline-line{background:var(--border);flex:1;width:2px;min-height:30px;margin:5px 0}.timeline-content{padding-bottom:2.2rem}.timeline-label{color:var(--text-primary);margin-bottom:.4rem;font-family:Space Grotesk,sans-serif;font-size:1rem;font-weight:700;line-height:1.3}.timeline-detail{color:var(--text-primary);opacity:.7;font-size:.88rem;line-height:1.65}@media (width<=1024px){.about-title{font-size:2.4rem}}@media (width<=768px){.about{padding:6rem 1.2rem 4rem}.about-title{font-size:2rem}.about-grid{grid-template-columns:1fr;gap:1rem}.about-card{padding:1.5rem}.timeline-item{grid-template-columns:64px 28px 1fr;gap:0 .8rem}.timeline-year{font-size:.55rem}}@media (width<=480px){.about-title{font-size:1.7rem}.about-subtitle{font-size:.9rem}.timeline-item{grid-template-columns:52px 24px 1fr;gap:0 .6rem}.timeline-label{font-size:.9rem}}.projects{flex-direction:column;align-items:center;min-height:100vh;padding:8rem 2rem 6rem;display:flex;position:relative}.projects-header{text-align:center;opacity:0;margin-bottom:4.5rem;transition:opacity .6s,transform .6s;transform:translateY(30px)}.projects-header--visible{opacity:1;transform:translateY(0)}.projects-eyebrow{letter-spacing:3px;color:var(--accent);margin-bottom:.8rem;font-family:Orbitron,sans-serif;font-size:.75rem;font-weight:700}.projects-title{color:var(--text-primary);margin-bottom:1rem;font-family:Orbitron,sans-serif;font-size:3rem;font-weight:900;line-height:1.1}.projects-title span{background:linear-gradient(135deg, var(--accent), #ec4899);-webkit-text-fill-color:transparent;-webkit-background-clip:text}.projects-subtitle{color:var(--text-secondary);max-width:520px;margin:0 auto;font-size:1rem;line-height:1.6}.projects-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem;width:100%;max-width:1100px;display:grid}.project-card{background:var(--bg-surface);border:1px solid var(--border);opacity:0;border-radius:20px;flex-direction:column;gap:0;padding:2rem;transition:opacity .55s,transform .55s,box-shadow .3s,border-color .3s;display:flex;position:relative;transform:translateY(40px)}.project-card--visible{opacity:1;transform:translateY(0)}.project-card:hover{box-shadow:0 25px 50px -12px #00000024, 0 0 0 1px color-mix(in srgb, var(--project-accent) 30%, transparent), 0 0 30px -8px color-mix(in srgb, var(--project-accent) 25%, transparent);border-color:color-mix(in srgb, var(--project-accent) 50%, var(--border) 50%);transform:translateY(-5px)}.project-card--wip{border-style:dashed}.project-card__glow{pointer-events:none;border-radius:inherit;opacity:.6;transition:opacity .4s;position:absolute;inset:0}.project-card:hover .project-card__glow{opacity:1}.project-screenshot{border-bottom:1px solid var(--border);border-radius:20px 20px 0 0;width:calc(100% + 4rem);height:200px;margin:-2rem -2rem 1.5rem;position:relative;overflow:hidden}.project-screenshot__img{object-fit:cover;object-position:top;width:100%;height:100%;transition:transform .5s;display:block}.project-card:hover .project-screenshot__img{transform:scale(1.04)}.project-screenshot__overlay{pointer-events:none;position:absolute;inset:0}.project-card__header{justify-content:space-between;align-items:center;margin-bottom:1.1rem;display:flex}.project-card__meta{align-items:center;gap:.6rem;display:flex}.project-index{letter-spacing:1px;font-family:Orbitron,sans-serif;font-size:.7rem;font-weight:900}.project-category{letter-spacing:1.5px;color:var(--text-secondary);text-transform:uppercase;font-family:Orbitron,sans-serif;font-size:.6rem;font-weight:600}.project-badge{letter-spacing:1.5px;border-radius:999px;align-items:center;gap:4px;padding:3px 10px;font-family:Orbitron,sans-serif;font-size:.55rem;font-weight:800;display:inline-flex}.project-badge--live{color:#10b981;background:#10b9811f;border:1px solid #10b9814d}.project-badge--wip{color:#f59e0b;background:#f59e0b1f;border:1px solid #f59e0b4d}.project-name{margin-bottom:.25rem;font-family:Space Grotesk,sans-serif;font-size:1.55rem;font-weight:800;line-height:1.2;transition:text-shadow .3s,letter-spacing .3s;display:inline-block}.project-card:hover .project-name{text-shadow:0 0 20px color-mix(in srgb, var(--project-accent) 60%, transparent), 0 0 40px color-mix(in srgb, var(--project-accent) 30%, transparent);letter-spacing:.02em}.project-tagline{letter-spacing:1.5px;color:var(--text-secondary);text-transform:uppercase;margin-bottom:1rem;font-family:Orbitron,sans-serif;font-size:.62rem;font-weight:600}.project-description-wrapper{flex-direction:column;flex:1;margin-bottom:1.2rem;display:flex}.project-description{color:var(--text-primary);opacity:.75;font-size:.9rem;line-height:1.72}.project-tags{flex-wrap:wrap;gap:.4rem;margin-bottom:1.5rem;display:flex}.project-tag{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary);transition:var(--transition);cursor:default;white-space:nowrap;border-radius:999px;flex-shrink:0;padding:3px 11px;font-size:.72rem;font-weight:600}.project-tag:hover{background:color-mix(in srgb, var(--tag-accent,var(--accent)) 15%, transparent);border-color:var(--tag-accent,var(--accent));color:var(--tag-accent,var(--accent))}.project-tag--more{background:color-mix(in srgb, var(--tag-accent,var(--accent)) 10%, transparent);border-color:color-mix(in srgb, var(--tag-accent,var(--accent)) 35%, transparent);color:var(--tag-accent,var(--accent));letter-spacing:.5px;cursor:default;font-family:Orbitron,sans-serif;font-size:.65rem}.project-tag-more-wrapper{align-items:center;display:inline-flex;position:relative}.tags-tooltip{background:var(--bg-elevated);border:1px solid var(--border);z-index:200;border-radius:10px;flex-wrap:wrap;gap:5px;width:max-content;max-width:220px;padding:8px 10px;display:flex;box-shadow:0 8px 24px #0000002e}.tags-tooltip__item{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-primary);white-space:nowrap;border-radius:999px;padding:2px 9px;font-size:.7rem;font-weight:600}.tags-tooltip__arrow{background:var(--bg-elevated);border-right:1px solid var(--border);border-bottom:1px solid var(--border);width:8px;height:8px;position:absolute;bottom:-5px;left:50%;transform:translate(-50%)rotate(45deg)}.project-actions{gap:.7rem;margin-top:auto;display:flex}.project-btn{cursor:pointer;border:none;border-radius:999px;align-items:center;gap:6px;padding:.55rem 1.1rem;font-family:Space Grotesk,sans-serif;font-size:.8rem;font-weight:700;text-decoration:none;transition:all .25s;display:inline-flex}.project-btn--ghost{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary)}.project-btn--ghost:hover{border-color:var(--project-accent);color:var(--project-accent);background:color-mix(in srgb, var(--project-accent) 8%, transparent)}.project-btn--solid{color:#fff;box-shadow:0 4px 16px #0003}.project-btn--solid:hover{box-shadow:0 8px 28px color-mix(in srgb, var(--project-accent) 40%, transparent);filter:brightness(1.1);transform:translateY(-2px)}.project-btn--disabled{background:var(--bg-elevated);border:1px dashed var(--border);color:var(--text-secondary);opacity:.5;cursor:not-allowed;border-radius:999px;align-items:center;gap:6px;padding:.55rem 1.1rem;font-family:Space Grotesk,sans-serif;font-size:.8rem;font-weight:700;display:inline-flex}.project-desc-toggle{display:none}@media (width<=1024px){.projects-title{font-size:2.4rem}.project-screenshot{height:180px}}@media (width<=768px){.projects{padding:6rem 1.2rem 4rem}.projects-title{font-size:2rem}.projects-grid{grid-template-columns:1fr;gap:1rem}.project-card{padding:1.5rem}.project-name{font-size:1.3rem}.project-screenshot{width:calc(100% + 3rem);height:160px;margin:-1.5rem -1.5rem 1.2rem}.project-description{font-size:.88rem;line-height:1.6}}@media (width<=480px){.projects{padding:5rem 1rem 3rem}.projects-title{font-size:1.7rem}.projects-subtitle{font-size:.9rem}.project-card{padding:1.2rem}.project-screenshot{width:calc(100% + 2.4rem);height:140px;margin:-1.2rem -1.2rem 1rem}.project-name{font-size:1.2rem}.project-description{-webkit-line-clamp:4;-webkit-box-orient:vertical;font-size:.85rem;transition:all .3s;display:-webkit-box;overflow:hidden}.project-description--expanded{-webkit-line-clamp:unset;display:block;overflow:visible}.project-desc-toggle{color:var(--accent);cursor:pointer;letter-spacing:.05em;background:0 0;border:none;margin-top:.4rem;padding:0;font-family:Orbitron,sans-serif;font-size:.75rem;font-weight:700;display:inline-block}.project-actions{flex-wrap:wrap;gap:.5rem}.project-btn{padding:.5rem .9rem;font-size:.75rem}}.contact{flex-direction:column;align-items:center;padding:8rem 2rem 0;display:flex;position:relative;overflow:hidden}.contact-header{text-align:center;opacity:0;z-index:1;margin-bottom:4.5rem;transition:opacity .6s,transform .6s;position:relative;transform:translateY(30px)}.contact-header--visible{opacity:1;transform:translateY(0)}.contact-eyebrow{letter-spacing:3px;color:var(--accent);margin-bottom:.8rem;font-family:Orbitron,sans-serif;font-size:.75rem;font-weight:700}.contact-title{color:var(--text-primary);margin-bottom:1rem;font-family:Orbitron,sans-serif;font-size:3rem;font-weight:900;line-height:1.1}.contact-title span{background:linear-gradient(135deg, var(--accent), #ec4899);-webkit-text-fill-color:transparent;-webkit-background-clip:text}.contact-subtitle{color:var(--text-secondary);max-width:500px;margin:0 auto;font-size:1rem;line-height:1.6}.contact-layout{z-index:1;grid-template-columns:1fr 1.5fr;align-items:start;gap:2.5rem;width:100%;max-width:1100px;margin-bottom:2rem;display:grid;position:relative}.contact-info{flex-direction:column;gap:1.2rem;display:flex}.contact-email-block{background:var(--bg-surface);border:1px solid var(--border);opacity:0;border-radius:16px;align-items:center;gap:1rem;padding:1.2rem 1.4rem;transition:opacity .5s .1s,transform .5s .1s,box-shadow .3s;display:flex;transform:translate(-20px)}.contact-email-block--visible{opacity:1;transform:translate(0)}.contact-email-block:hover{box-shadow:var(--shadow-navbar)}.contact-email-icon{background:var(--bg-elevated);border:1px solid var(--border);width:40px;height:40px;color:var(--accent);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.contact-email-label{letter-spacing:2px;color:var(--text-secondary);margin-bottom:.2rem;font-family:Orbitron,sans-serif;font-size:.55rem;font-weight:700}.contact-email-value{color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-size:.9rem;font-weight:600}.contact-copy-btn{background:var(--bg-elevated);border:1px solid var(--border);width:34px;height:34px;color:var(--text-secondary);cursor:pointer;transition:var(--transition);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;display:flex}.contact-copy-btn:hover{border-color:var(--accent);color:var(--accent);background:#6366f114}.contact-copy-btn--copied{color:#10b981;background:#10b9811a;border-color:#10b981}.contact-socials{flex-direction:column;gap:.8rem;display:flex}.social-card{background:var(--bg-surface);border:1px solid var(--border);opacity:0;border-radius:14px;align-items:center;gap:1rem;padding:1rem 1.2rem;text-decoration:none;transition:opacity .5s,transform .5s,box-shadow .3s,border-color .3s;display:flex;transform:translate(-20px)}.social-card--visible{opacity:1;transform:translate(0)}.social-card:hover{border-color:color-mix(in srgb, var(--card-accent) 50%, var(--border) 50%);box-shadow:0 8px 24px #00000014, 0 0 0 1px color-mix(in srgb, var(--card-accent) 20%, transparent);transform:translate(4px)}.social-card__icon{background:color-mix(in srgb, var(--card-accent) 12%, var(--bg-elevated));border:1px solid color-mix(in srgb, var(--card-accent) 25%, var(--border));width:38px;height:38px;color:var(--card-accent);transition:var(--transition);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.social-card:hover .social-card__icon{background:color-mix(in srgb, var(--card-accent) 18%, transparent)}.social-card__text{flex-direction:column;flex:1;gap:.1rem;display:flex}.social-card__label{letter-spacing:1.5px;color:var(--text-secondary);font-family:Orbitron,sans-serif;font-size:.58rem;font-weight:700}.social-card__handle{color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-size:.88rem;font-weight:600}.social-card__arrow{color:var(--text-secondary);opacity:0;transition:var(--transition);font-size:1rem;transform:translate(-4px)}.social-card:hover .social-card__arrow{opacity:1;transform:translate(0)}.contact-availability{opacity:0;background:linear-gradient(135deg,#10b9811f 0%,#10b9810f 100%);border:1.5px solid #10b98173;border-radius:16px;align-items:center;gap:1rem;width:100%;padding:1rem 1.4rem;transition:opacity .5s .3s,transform .5s .3s;display:flex;transform:translateY(10px);box-shadow:0 4px 20px #10b9811f,inset 0 1px #10b98126}.contact-availability--visible{opacity:1;transform:translateY(0)}.availability-inner{flex-shrink:0;justify-content:center;align-items:center;width:14px;height:14px;display:flex;position:relative}.availability-dot{z-index:1;background:#10b981;border-radius:50%;flex-shrink:0;width:10px;height:10px;position:relative}.availability-pulse-ring{border:2px solid #10b98166;border-radius:50%;animation:2.5s ease-in-out infinite pulse-ring;position:absolute;inset:-4px}@keyframes pulse-ring{0%{opacity:1;transform:scale(.8)}to{opacity:0;transform:scale(1.8)}}.availability-content{flex-direction:column;gap:.1rem;display:flex}.availability-title{letter-spacing:1.5px;color:#059669;text-transform:uppercase;font-family:Orbitron,sans-serif;font-size:.75rem;font-weight:800}.availability-sub{color:#059669;opacity:.8;font-family:Space Grotesk,sans-serif;font-size:.8rem;font-weight:500}body.dark .availability-title,body.dark .availability-sub{color:#10b981}.contact-form-wrapper{background:var(--bg-surface);border:1px solid var(--border);opacity:0;border-radius:24px;padding:2.5rem;transition:opacity .6s .15s,transform .6s .15s;transform:translateY(30px);box-shadow:0 4px 24px #0000000f}.contact-form-wrapper--visible{opacity:1;transform:translateY(0)}.contact-form{flex-direction:column;gap:1.4rem;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.form-field{flex-direction:column;gap:.5rem;display:flex}.form-label{letter-spacing:2px;color:var(--accent);font-family:Orbitron,sans-serif;font-size:.58rem;font-weight:700}.form-input{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary);resize:none;border-radius:12px;outline:none;width:100%;padding:.8rem 1.1rem;font-family:Space Grotesk,sans-serif;font-size:.9rem;font-weight:500;transition:border-color .25s,box-shadow .25s,background .25s}.form-input::placeholder{color:var(--text-secondary);opacity:.5}.form-input:focus{border-color:var(--accent);background:var(--bg-surface);box-shadow:0 0 0 3px #6366f11f}body.dark .form-input:focus{box-shadow:0 0 0 3px #a855f726}.form-textarea{min-height:130px;line-height:1.65}.contact-form-error{color:#f87171;background:#f8717114;border:1px solid #f8717140;border-radius:10px;padding:.6rem 1rem;font-family:Space Grotesk,sans-serif;font-size:.82rem}.contact-submit{background:linear-gradient(135deg, var(--accent), #ec4899);color:#fff;cursor:pointer;border:none;border-radius:999px;justify-content:center;align-self:flex-start;align-items:center;gap:.5rem;padding:.85rem 1.8rem;font-family:Space Grotesk,sans-serif;font-size:.95rem;font-weight:700;transition:all .3s;display:inline-flex;box-shadow:0 4px 20px #6366f159}.contact-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 30px #6366f180}.contact-submit:disabled{opacity:.7;cursor:not-allowed}.contact-submit--loading{pointer-events:none}.submit-spinner{border:2px solid #ffffff59;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:15px;height:15px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.contact-success{text-align:center;flex-direction:column;align-items:center;gap:1rem;padding:2rem 1rem;display:flex}.contact-success__icon{color:#10b981;background:#10b9811f;border:2px solid #10b98159;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;font-size:1.6rem;animation:.4s cubic-bezier(.34,1.56,.64,1) both pop-in;display:flex}@keyframes pop-in{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.contact-success__title{color:var(--text-primary);font-family:Orbitron,sans-serif;font-size:1.3rem;font-weight:900}.contact-success__desc{color:var(--text-secondary);max-width:320px;font-size:.92rem;line-height:1.6}.contact-success__reset{border:1px solid var(--border);letter-spacing:1px;color:var(--text-secondary);cursor:pointer;transition:var(--transition);background:0 0;border-radius:999px;margin-top:.5rem;padding:.55rem 1.2rem;font-family:Orbitron,sans-serif;font-size:.62rem;font-weight:700}.contact-success__reset:hover{border-color:var(--accent);color:var(--accent)}.contact-footer{z-index:1;border-top:1px solid var(--border);text-align:center;opacity:0;width:100%;max-width:1100px;padding-top:1.2rem;padding-bottom:1.2rem;transition:opacity .6s .4s;position:relative}.contact-footer--visible{opacity:1}.contact-footer__text{letter-spacing:2px;color:var(--text-secondary);opacity:.6;font-family:Orbitron,sans-serif;font-size:.62rem;font-weight:600}.contact-footer__text span{color:var(--accent);opacity:1}.contact-success-msg{color:#10b981;margin-top:1rem;font-size:.9rem;font-weight:500}.contact-error-msg{color:#ef4444;margin-top:1rem;font-size:.9rem;font-weight:500}@media (width<=1024px){.contact-title{font-size:2.4rem}}@media (width<=900px){.contact-layout{grid-template-columns:1fr;gap:2rem}.contact-info{flex-flow:wrap}.contact-email-block{flex:100%}.contact-socials{flex-direction:row;flex:100%}.social-card{flex:1}}@media (width<=768px){.contact{padding:6rem 1.2rem 3rem}.contact-title{font-size:2rem}.contact-form-wrapper{padding:1.8rem}.contact-info,.contact-socials{flex-direction:column}}@media (width<=580px){.form-row{grid-template-columns:1fr}}@media (width<=480px){.contact-title{font-size:1.7rem}.contact-subtitle{font-size:.9rem}.contact-form-wrapper{padding:1.4rem}.contact-submit{justify-content:center;width:100%}}
