@import"https://fonts.googleapis.com/css2?family=Orbitron:wght@400;700;900&family=Inter:wght@300;400;500;600;700&display=swap";:root{--color-bg: #060610;--color-bg-dark: #0a0a14;--color-bg-card: rgba(12, 20, 30, .85);--color-neon-pink: #e0407a;--color-neon-cyan: #00d4e6;--color-neon-green: #22c55e;--color-neon-yellow: #f0d000;--color-text: #e2e8f0;--color-text-dim: #94a3b8;--color-text-bright: #f8fafc;--color-grid: #0a3040;--color-border: rgba(0, 212, 230, .25);--color-border-hover: rgba(224, 64, 122, .5);--font-title: "Orbitron", monospace;--font-body: "Inter", sans-serif}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-body);font-weight:400;color:var(--color-text);background:var(--color-bg);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6}#canvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1;display:block}.nav-header{position:fixed;top:0;left:0;width:100%;z-index:100;padding:1.2rem 0;background:linear-gradient(180deg,#060610eb,#06061000);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.nav-content{max-width:1200px;margin:0 auto;display:flex;justify-content:center;align-items:center;gap:1rem;padding:0 2rem}.nav-link{font-family:var(--font-title);font-size:.75rem;font-weight:600;color:var(--color-text-dim);text-decoration:none;letter-spacing:.15em;padding:.5rem 1.1rem;border:1px solid transparent;background:transparent;position:relative;transition:color .3s,border-color .3s,text-shadow .3s}.nav-link.active,.nav-link:hover{color:var(--color-neon-cyan);border-color:var(--color-border);text-shadow:0 0 8px rgba(0,212,230,.4)}.section{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;z-index:10;padding:6rem 2rem}.section-content{max-width:1200px;width:100%;text-align:center}.section-title{font-family:var(--font-title);font-size:clamp(1.8rem,4vw,2.6rem);color:var(--color-neon-cyan);text-shadow:0 0 10px rgba(0,212,230,.4);margin-bottom:3rem;letter-spacing:.15em}.section-subtitle{font-family:var(--font-body);font-size:clamp(.9rem,1.4vw,1.05rem);color:var(--color-text-dim);margin-top:-2rem;margin-bottom:3rem;font-weight:300;font-style:italic}#hero{height:100vh;padding:2rem}.hero-content{text-align:center}.glitch{font-family:var(--font-title);font-size:clamp(3rem,10vw,7rem);font-weight:900;text-transform:uppercase;color:var(--color-neon-cyan);position:relative;letter-spacing:.1em;text-shadow:0 0 6px var(--color-neon-cyan),0 0 12px rgba(0,212,230,.4);animation:textGlow 3s ease-in-out infinite alternate}@keyframes textGlow{0%{text-shadow:0 0 6px var(--color-neon-cyan),0 0 12px rgba(0,212,230,.4)}to{text-shadow:0 0 10px var(--color-neon-cyan),0 0 20px rgba(0,212,230,.5),0 0 40px rgba(224,64,122,.15)}}.glitch:before,.glitch:after{content:attr(data-text);position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;pointer-events:none}.glitch:before{animation:glitchBefore 6s infinite;color:var(--color-neon-pink);text-shadow:-2px 0 var(--color-neon-pink);clip-path:polygon(0 0,100% 0,100% 45%,0 45%)}.glitch:after{animation:glitchAfter 6s infinite;color:var(--color-neon-cyan);text-shadow:2px 0 var(--color-neon-cyan);clip-path:polygon(0 55%,100% 55%,100% 100%,0 100%)}@keyframes glitchBefore{0%,96%,to{opacity:0;transform:translate(0)}97%{opacity:.5;transform:translate(-2px,1px)}98%{opacity:0;transform:translate(0)}}@keyframes glitchAfter{0%,96%,to{opacity:0;transform:translate(0)}97%{opacity:.5;transform:translate(2px,-1px)}98%{opacity:0;transform:translate(0)}}.subtitle{font-family:var(--font-title);font-size:clamp(.85rem,2.5vw,1.2rem);color:var(--color-neon-pink);text-shadow:0 0 8px rgba(224,64,122,.4);letter-spacing:.3em;margin-top:1rem}.hero-tagline{font-family:var(--font-body);font-size:clamp(.9rem,1.5vw,1.1rem);color:var(--color-text-dim);margin-top:1.5rem;letter-spacing:.05em;font-weight:300}.hero-motto{font-family:var(--font-body);font-size:clamp(.8rem,1.2vw,.95rem);color:var(--color-neon-cyan);margin-top:1.2rem;font-style:italic;font-weight:300;letter-spacing:.04em;opacity:.7}.hero-hint{position:absolute;bottom:3rem;left:50%;transform:translate(-50%);text-align:center;opacity:.5;animation:hintFloat 2.5s ease-in-out infinite}.hint-text{display:block;font-family:var(--font-title);font-size:.75rem;color:var(--color-text-dim);letter-spacing:.2em;margin-bottom:.5rem}.hint-arrow{display:block;font-size:1.2rem;color:var(--color-text-dim);animation:arrowBounce 1.2s ease-in-out infinite}@keyframes hintFloat{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(-8px)}}@keyframes arrowBounce{0%,to{transform:translateY(0)}50%{transform:translateY(4px)}}#projects-container,#external-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem;max-width:1200px;margin:0 auto;padding:0 1rem;text-align:left}.project-card{position:relative;border:none;border-radius:10px;overflow:visible;transition:transform .3s}.project-card:hover{transform:translateY(-4px)}.card-content{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:10px;overflow:hidden;position:relative;z-index:2;transition:border-color .3s;height:100%}.project-card:hover .card-content{border-color:transparent}.electric-border{position:absolute;inset:-2px;border:1px solid var(--color-neon-cyan);border-radius:12px;filter:url(#electric);pointer-events:none;opacity:.8;transition:opacity .3s}.electric-glow{position:absolute;inset:-3px;border:1px solid var(--color-neon-cyan);border-radius:13px;filter:url(#electric) blur(3px);pointer-events:none;opacity:.3;transition:opacity .3s}.electric-glow-bg{position:absolute;inset:-5px;border:2px solid var(--color-neon-cyan);border-radius:15px;filter:blur(12px);pointer-events:none;opacity:.08;transition:opacity .3s;z-index:-1}.project-card:hover .electric-border{opacity:1}.project-card:hover .electric-glow{opacity:.45}.project-card:hover .electric-glow-bg{opacity:.25}.project-thumbnail,.project-thumbnail-placeholder{width:100%;height:220px;object-fit:cover;background:linear-gradient(135deg,#00d4e614,#e0407a14);display:block}.project-info{padding:1.5rem}.project-name{font-family:var(--font-title);font-size:1.1rem;color:var(--color-text-bright);margin-bottom:.6rem;letter-spacing:.03em}.project-description{color:var(--color-text-dim);font-size:.9rem;line-height:1.7;margin-bottom:1rem}.tech-stack{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1rem}.tech-tag{font-family:var(--font-body);font-size:.7rem;font-weight:500;color:var(--color-neon-cyan);background:#00d4e614;border:1px solid rgba(0,212,230,.2);padding:.25rem .55rem;border-radius:4px;letter-spacing:.02em}.project-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1rem}.project-tag{font-size:.65rem;color:var(--color-neon-green);background:#22c55e14;border:1px solid rgba(34,197,94,.2);padding:.2rem .5rem;border-radius:4px}.project-links{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1rem}.project-link{font-family:var(--font-body);font-size:.8rem;font-weight:500;color:var(--color-neon-cyan);text-decoration:none;padding:.45rem .9rem;border:1px solid var(--color-border);border-radius:4px;transition:all .25s}.project-link:hover{color:var(--color-text-bright);border-color:var(--color-neon-cyan);background:#00d4e61a}.project-link-download{color:var(--color-neon-pink);border-color:#e0407a4d}.project-link-download:hover{border-color:var(--color-neon-pink);background:#e0407a1a;color:var(--color-text-bright)}.project-link-external{color:var(--color-neon-green);border-color:#22c55e4d}.project-link-external:hover{border-color:var(--color-neon-green);background:#22c55e1a;color:var(--color-text-bright)}.no-projects{text-align:center;color:var(--color-text-dim);padding:3rem;grid-column:1 / -1}.spin-up-notice{margin-top:.85rem;font-size:.72rem;color:var(--color-text-dim);opacity:.7;font-style:italic;line-height:1.4}#featured-container{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;max-width:1200px;margin:0 auto;padding:0 1rem;text-align:left}@media (max-width: 900px){#featured-container{grid-template-columns:1fr;max-width:520px}}.featured-card{transform-style:preserve-3d;transition:none;will-change:transform}.featured-card:hover{transform:none;transition:none}.featured-card .card-content{display:flex;flex-direction:column}.featured-thumbnail-wrap{position:relative;overflow:hidden}.featured-thumbnail{width:100%;height:auto;aspect-ratio:16 / 9;object-fit:cover;display:block}.featured-label{position:absolute;top:.75rem;left:.75rem;font-family:var(--font-title);font-size:.6rem;color:var(--color-neon-green);border:1px solid rgba(34,197,94,.4);background:#060610d1;padding:.2rem .6rem;border-radius:3px;letter-spacing:.1em;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.featured-glare{position:absolute;inset:0;pointer-events:none;opacity:0;transition:opacity .35s ease;border-radius:10px;z-index:10}.featured-card .electric-border{border-color:#f0a020;opacity:.9;inset:-3px}.featured-card .electric-glow{border-color:#f0a020;opacity:.45;inset:-4px}.featured-card .electric-glow-bg{border-color:#f0a020;border-width:3px;filter:blur(18px);opacity:.14;inset:-7px}.featured-card:hover .electric-border{opacity:1}.featured-card:hover .electric-glow{opacity:.75}.featured-card:hover .electric-glow-bg{opacity:.45}.external-label{display:inline-block;font-family:var(--font-title);font-size:.65rem;color:var(--color-neon-green);border:1px solid rgba(34,197,94,.3);background:#22c55e14;padding:.2rem .6rem;border-radius:3px;letter-spacing:.1em;margin-bottom:.6rem}.about-bio{font-size:1.05rem;line-height:1.9;color:var(--color-text);max-width:750px;margin:0 auto 3rem}.about-bio .highlight{color:var(--color-neon-cyan);font-weight:500}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;max-width:1000px;margin:0 auto;text-align:left}.skill-category{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:8px;padding:1.3rem;transition:border-color .3s}.skill-category:hover{border-color:var(--color-border-hover)}.skill-category-title{font-family:var(--font-title);font-size:.7rem;color:var(--color-neon-pink);letter-spacing:.12em;margin-bottom:.8rem;text-transform:uppercase}.skill-items{display:flex;flex-wrap:wrap;gap:.4rem}.skill-item{font-size:.75rem;font-weight:500;color:var(--color-text);background:#00d4e60f;border:1px solid rgba(0,212,230,.15);padding:.25rem .55rem;border-radius:4px}.contact-wrapper{max-width:550px;margin:0 auto}.contact-form{display:flex;flex-direction:column;gap:1rem;text-align:left;margin-bottom:2rem}.contact-form label{font-family:var(--font-title);font-size:.7rem;color:var(--color-text-dim);letter-spacing:.1em;margin-bottom:.3rem;display:block}.contact-form input,.contact-form textarea{width:100%;padding:.8rem 1rem;font-family:var(--font-body);font-size:.9rem;color:var(--color-text);background:#00d4e60a;border:1px solid var(--color-border);border-radius:6px;outline:none;transition:border-color .3s}.contact-form input:focus,.contact-form textarea:focus{border-color:var(--color-neon-cyan)}.contact-form textarea{min-height:120px;resize:vertical}.contact-form button{font-family:var(--font-title);font-size:.8rem;font-weight:600;letter-spacing:.1em;color:var(--color-bg);background:var(--color-neon-cyan);border:none;padding:.8rem 2rem;border-radius:6px;cursor:pointer;transition:background .3s,box-shadow .3s;align-self:flex-start}.contact-form button:hover{background:#00bcd4;box-shadow:0 0 20px #00d4e64d}.contact-form .form-status{font-size:.85rem;margin-top:.5rem}.contact-form .form-status.success{color:#4ade80}.contact-form .form-status.error{color:var(--color-neon-pink)}.contact-email{font-family:var(--font-body);font-size:.9rem;color:var(--color-text-dim);text-decoration:none;transition:color .3s}.contact-email:hover{color:var(--color-neon-cyan)}.contact-divider{color:var(--color-text-dim);font-size:.8rem;margin:1rem 0}.loading-screen{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--color-bg);display:flex;align-items:center;justify-content:center;z-index:9999;transition:opacity .5s ease}.loading-screen.hidden{opacity:0;pointer-events:none}.loading-content{text-align:center}.loading-text{font-family:var(--font-title);font-size:1.5rem;color:var(--color-neon-cyan);text-shadow:0 0 8px rgba(0,212,230,.4);letter-spacing:.3em;margin-bottom:1.5rem;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.loading-bar{width:260px;height:3px;background:var(--color-bg-dark);border:1px solid rgba(0,212,230,.3);overflow:hidden;border-radius:2px}.loading-progress{height:100%;background:var(--color-neon-cyan);animation:loadingProgress 2s ease-in-out infinite}@keyframes loadingProgress{0%{width:0%}50%{width:100%}to{width:0%}}.site-footer{position:relative;z-index:10;text-align:center;padding:2rem;color:var(--color-text-dim);font-size:.75rem;letter-spacing:.05em;border-top:1px solid var(--color-border)}.contact-form button:disabled{opacity:.5;cursor:not-allowed}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(to bottom,transparent 50%,rgba(0,212,230,.006) 50%);background-size:100% 4px;pointer-events:none;z-index:9998;opacity:.4}.reveal{opacity:0;transform:translateY(30px)}.glitch,.glitch:before,.glitch:after,.subtitle,.section-title{will-change:transform,opacity}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.reveal{opacity:1;transform:none}.electric-border,.electric-glow,.electric-glow-bg{display:none}.project-card:hover .card-content{border-color:var(--color-border-hover)}}@media (max-width: 768px){.section{padding:4rem 1rem}.glitch{font-size:2.5rem}.glitch:before,.glitch:after{display:none}.nav-content{gap:.4rem;padding:0 .8rem}.nav-link{font-size:.65rem;padding:.4rem .7rem}#projects-container,#external-container{grid-template-columns:1fr}.skills-grid{grid-template-columns:1fr 1fr}.contact-email{font-size:.85rem}.about-bio{font-size:.95rem}}@media (max-width: 480px){.skills-grid{grid-template-columns:1fr}.nav-content{justify-content:center;flex-wrap:wrap;gap:.2rem;padding:.2rem .5rem}.nav-link{font-size:.55rem;padding:.3rem .55rem;letter-spacing:.07em}}html.lenis,html.lenis body{height:auto}.lenis:not(.lenis-autoToggle).lenis-stopped{overflow:clip}.lenis [data-lenis-prevent],.lenis [data-lenis-prevent-wheel],.lenis [data-lenis-prevent-touch]{overscroll-behavior:contain}.lenis.lenis-smooth iframe{pointer-events:none}.lenis.lenis-autoToggle{transition-property:overflow;transition-duration:1ms;transition-behavior:allow-discrete}
