:root{--color-bg-primary: #000000;--color-bg-secondary: #111111;--color-accent-cyan: #00f0ff;--color-accent-purple: #8b5cf6;--color-accent-rose: #f43f5e;--color-text-primary: #e8e8e8;--color-text-muted: #666666;--font-display: "Space Grotesk", sans-serif;--font-body: "Geist", "Inter", sans-serif;--font-mono: "JetBrains Mono", monospace}*{margin:0;padding:0;box-sizing:border-box}img{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;-webkit-user-drag:none;-khtml-user-drag:none;-moz-user-drag:none;-o-user-drag:none;user-drag:none}body{background-color:var(--color-bg-primary);color:var(--color-text-primary);font-family:var(--font-body);overflow-x:hidden;cursor:none;-webkit-font-smoothing:antialiased}body *,body a,body button{cursor:none!important}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--color-bg-primary)}::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:5px;border:2px solid var(--color-bg-primary)}::-webkit-scrollbar-thumb:hover{background:var(--color-accent-cyan)}.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:99999;transform:translate(-50%,-50%);border-radius:50%}.cursor-dot{width:6px;height:6px;background-color:var(--color-text-primary)}.cursor-ring{width:40px;height:40px;border:1px solid rgba(255,255,255,.5);mix-blend-mode:difference;transition:width .3s cubic-bezier(.16,1,.3,1),height .3s cubic-bezier(.16,1,.3,1),background-color .3s ease}.cursor-ring.hover{width:80px;height:80px;background-color:var(--color-text-primary);border-color:transparent}.header{position:fixed;top:0;left:0;right:0;padding:2rem 4rem;display:flex;justify-content:space-between;z-index:1000;font-family:var(--font-mono);text-transform:uppercase;font-size:.9rem;letter-spacing:.1em;transition:backdrop-filter .3s,background .3s}.header.scrolled{backdrop-filter:blur(16px);background:#0a0a0acc;border-bottom:1px solid rgba(255,255,255,.05)}canvas#webgl-canvas{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:-1;pointer-events:none}.section{position:relative;width:100%}.section-label{font-family:var(--font-mono);font-size:.8rem;letter-spacing:.2em;color:var(--color-accent-cyan);margin-bottom:2rem;text-transform:uppercase}.section-label.center{text-align:center}.projects-label{position:sticky;left:4rem;top:0;z-index:50;width:fit-content}.hero{height:100vh;display:flex;flex-direction:column;justify-content:center;padding:0 4rem}.hero-title{font-family:var(--font-display);font-size:clamp(4rem,12vw,14rem);line-height:1;letter-spacing:-.04em;margin-bottom:1rem;margin-left:-.05em}.hero-title .char{display:inline-block}.hero-subtitle{font-family:var(--font-mono);font-size:clamp(1rem,2vw,1.5rem);color:var(--color-text-muted);letter-spacing:.1em}.hero-line{margin-top:2rem;width:200px;height:1px;background-color:var(--color-accent-cyan)}.scroll-indicator{position:absolute;bottom:4rem;left:4rem;font-family:var(--font-mono);font-size:.8rem;letter-spacing:.1em;text-align:center;color:var(--color-text-muted);animation:bounce 2s infinite ease-in-out}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(10px)}}.about{min-height:100vh;padding:8rem 4rem;display:flex;align-items:center}.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;width:100%}.about-heading{font-family:var(--font-display);font-size:clamp(2rem,4vw,5rem);line-height:1.1;margin-bottom:2rem}.about-heading .line{overflow:hidden}.about-body{font-size:1.25rem;line-height:1.6;color:var(--color-text-muted)}.about-canvas-container{width:100%;aspect-ratio:3/2;background:#ffffff05;border:1px solid rgba(255,255,255,.05)}.projects-container{overflow-x:auto;overflow-y:hidden;position:relative;-webkit-overflow-scrolling:touch;margin-top:8rem;padding-top:8rem}.projects-container::-webkit-scrollbar{display:none}.projects-container{-ms-overflow-style:none;scrollbar-width:none}.projects-track{display:flex;width:max-content;height:80vh}.project-card{width:70vw;height:80vh;padding:8rem 3rem 2rem 12vw;display:flex;flex-direction:column;justify-content:flex-end;position:relative}.project-card[data-project-id] .project-image-wrapper,.project-card[data-project-id] .project-title,.project-card[data-project-id] .project-meta{pointer-events:auto}.project-image-wrapper{position:absolute;top:41%;left:50%;transform:translate(-50%,-50%);width:50vw;height:65vh;background:#ffffff03;z-index:0}.project-title{font-family:var(--font-display);font-size:clamp(2.5rem,7vw,8rem);line-height:.8;letter-spacing:-.04em;-webkit-text-stroke:1px var(--color-text-primary);color:transparent;z-index:10;transition:color .4s;cursor:none}.project-title:hover{color:var(--color-text-primary)}.project-meta{font-family:var(--font-mono);font-size:.85rem;color:var(--color-accent-purple);margin-top:.3rem;margin-bottom:8vh;z-index:10}.projects-arrows-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:20}.projects-scroll-arrow{position:fixed;top:50%;transform:translateY(-50%);width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:var(--color-text-primary);opacity:0;pointer-events:none;transition:opacity .3s}.projects-scroll-arrow.visible{opacity:.7}.projects-arrow-left{left:1.5rem}.projects-arrow-right{right:1.5rem}.projects-progress{position:absolute;bottom:0;left:0;height:2px;background:var(--color-accent-cyan);width:0%;z-index:20}.skills{padding:8rem 4rem;min-height:100vh}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:4rem}.skill-card{background:#ffffff05;border:1px solid rgba(255,255,255,.05);padding:2rem;border-radius:8px;backdrop-filter:blur(12px);transition:transform .3s,box-shadow .3s;transform-style:preserve-3d}.skill-card:hover{box-shadow:0 0 30px #00f0ff1a;border-color:#00f0ff4d}.skill-card h3{font-family:var(--font-display);font-size:1.5rem;margin-bottom:2rem}.skill-bar{width:100%;height:2px;background:#ffffff1a}.skill-fill{height:100%;background:var(--color-accent-purple);transform-origin:left;transform:scaleX(0)}.experience{padding:8rem 4rem 2rem;position:relative}.timeline-container{position:relative;max-width:1000px;margin:4rem auto}.timeline-line{position:absolute;left:50%;top:0;bottom:0;width:2px;background:#ffffff1a;transform:translate(-50%)}.timeline-item{width:50%;padding:.75rem 3rem;position:relative}.timeline-item.right{margin-left:50%}.timeline-node{position:absolute;top:50%;width:16px;height:16px;background:var(--color-bg-primary);border:2px solid var(--color-accent-cyan);border-radius:50%;transform:translateY(-50%)}.timeline-item.left .timeline-node{right:-8px}.timeline-item.right .timeline-node{left:-8px}.timeline-header{display:flex;flex-direction:column;align-items:flex-start;gap:1rem;margin-bottom:.5rem}.timeline-logo{height:50px;max-width:200px;object-fit:contain;flex-shrink:0}.timeline-content h3{font-family:var(--font-display);font-size:1.7rem;line-height:1.1}.timeline-content h4{color:var(--color-accent-purple);margin:.25rem 0 .5rem;font-size:.9rem}.timeline-date{font-family:var(--font-mono);font-size:.85rem;color:var(--color-text-muted);margin-bottom:.75rem}.contact{padding:4rem 2rem;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center}.contact-title{font-family:var(--font-display);font-size:clamp(4rem,10vw,12rem);line-height:.9;margin-bottom:2rem}.contact-email{font-family:var(--font-mono);font-size:clamp(1rem,3vw,2rem);color:var(--color-text-primary);text-decoration:none;border-bottom:2px solid transparent;padding-bottom:.5rem;transition:border-color .3s}.contact-email:hover{border-color:var(--color-accent-cyan)}.socials{margin-top:4rem;display:flex;gap:2rem}.socials a{color:var(--color-text-primary);text-decoration:none;font-family:var(--font-mono);font-size:.9rem}.footer{padding:2rem 4rem;display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:.8rem;color:var(--color-text-muted);border-top:1px solid rgba(255,255,255,.05)}.project-modal{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0a0a0afa;backdrop-filter:blur(15px);z-index:9999;display:block;overflow-y:auto;overflow-x:hidden;padding:10vh 0;pointer-events:none;visibility:hidden;opacity:0}.project-modal.is-open{pointer-events:auto}.modal-close{position:sticky;top:2rem;z-index:10;display:block;width:fit-content;margin-left:auto;margin-right:4rem;font-family:var(--font-mono);font-size:.85rem;letter-spacing:.1em;color:var(--color-text-muted);cursor:pointer;pointer-events:auto;transition:color .3s ease}.modal-close:hover{color:var(--color-text-primary)}.modal-content{width:85%;max-width:700px;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem;opacity:0;transform:translateY(20px)}.modal-gallery{position:relative;width:100%;aspect-ratio:16/9;background:#ffffff05;border:1px solid rgba(255,255,255,.05);flex-shrink:0}.modal-gallery img{width:100%;height:100%;object-fit:cover;pointer-events:none}.modal-controls{position:absolute;top:50%;left:0;width:100%;transform:translateY(-50%);display:flex;justify-content:space-between;padding:0 1rem;pointer-events:none}.modal-arrow{display:flex;align-items:center;justify-content:center;width:38px;height:38px;background:#0a0a0a80;backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.1);border-radius:50%;color:var(--color-text-primary);cursor:pointer;pointer-events:auto;transition:all .3s ease}.modal-arrow:hover{background:#ffffff1a;color:var(--color-accent-cyan)}.modal-info{display:flex;flex-direction:column;justify-content:center}.modal-info h2{font-size:2.5rem;font-weight:700;margin-bottom:.4rem;text-transform:uppercase}.modal-meta{font-family:var(--font-mono);font-size:.8rem;color:var(--color-accent-cyan);margin-bottom:1.5rem;letter-spacing:.05em;text-transform:uppercase}.modal-info p{font-size:.95rem;line-height:1.6;color:var(--color-text-muted)}.modal-info p strong{display:block;font-family:var(--font-mono);font-size:.75rem;letter-spacing:.1em;color:var(--color-accent-cyan);text-transform:uppercase;margin-top:1rem;margin-bottom:.3rem}.modal-info p strong:first-child{margin-top:0}.modal-info p ul{list-style:none;padding:0;margin:0 0 .5rem}.modal-info p ul li{position:relative;padding-left:1.2rem;font-size:.85rem;line-height:1.7;color:var(--color-text-muted)}.modal-info p ul li:before{content:"▹";position:absolute;left:0;color:var(--color-accent-cyan)}.mobile-projects-cta{display:none}.view-projects-btn{display:inline-flex;align-items:center;gap:1rem;font-family:var(--font-display);font-size:1.5rem;font-weight:600;color:var(--color-text-primary);text-decoration:none;padding:1.5rem 3rem;border:1px solid rgba(0,240,255,.3);background:#00f0ff0d;transition:all .4s ease;letter-spacing:.05em}.view-projects-btn:hover{background:#00f0ff1a;border-color:var(--color-accent-cyan);color:var(--color-accent-cyan)}.btn-arrow{font-size:1.2rem;transition:transform .3s ease}.view-projects-btn:hover .btn-arrow{transform:translate(4px)}body.projects-page{overflow:hidden;height:100vh;height:100dvh;touch-action:pan-x;cursor:none}.projects-back-btn{position:fixed;top:2rem;left:2rem;font-family:var(--font-mono);font-size:.85rem;letter-spacing:.1em;color:var(--color-text-muted);text-decoration:none;z-index:100;transition:color .3s ease}.projects-back-btn:hover{color:var(--color-accent-cyan)}.projects-counter{position:fixed;top:2rem;right:2rem;font-family:var(--font-mono);font-size:.85rem;letter-spacing:.1em;color:var(--color-text-muted);z-index:100}.projects-counter .counter-current{color:var(--color-accent-cyan)}.projects-viewport{position:fixed;top:0;left:0;width:100vw;height:100vh;height:100dvh;overflow:hidden}.projects-page .projects-track{display:flex;flex-direction:row;width:500vw;height:100vh;height:100dvh}.projects-page .project-card{width:100vw;height:100vh;height:100dvh;padding:6rem 1.5rem 4rem;display:flex;flex-direction:column;justify-content:flex-end;position:relative}.projects-page .project-image-wrapper{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:85vw;height:55vh;height:55dvh}.projects-page-progress{position:fixed;bottom:0;left:0;height:2px;width:0%;background:var(--color-accent-cyan);z-index:100}body.projects-page .project-modal{touch-action:pan-y}@media (max-width: 768px){.about-grid{grid-template-columns:1fr}.header{padding:1.5rem}.hero{padding:0 1.5rem}.about,.projects-container{padding:4rem 1.5rem}.scroll-indicator{bottom:6rem;left:1.5rem}.mobile-projects-cta{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;padding:4rem 1.5rem;text-align:center}.mobile-projects-cta .section-label{margin-bottom:3rem}.projects-container{display:none}.project-title{font-size:clamp(1.75rem,6vw,3rem)}.timeline-container{margin:2rem auto}.timeline-line{left:0;transform:none}.timeline-item{width:100%;padding-left:2rem;padding-right:0;margin-left:0}.timeline-item.right{margin-left:0;text-align:left}.timeline-item.right .timeline-header{align-items:flex-start}.timeline-item.left .timeline-node,.timeline-item.right .timeline-node{left:-8px;right:auto}.timeline-content h3{font-size:1.4rem}.experience{padding:4rem 1.5rem}.project-modal{padding:1rem 0 6vh}.modal-content{width:92%;gap:1.25rem}.modal-close{top:0;margin-right:1rem;padding:.75rem 0;font-size:.85rem}.modal-info h2{font-size:1.6rem}.modal-arrow{width:30px;height:30px}.modal-arrow svg{width:16px;height:16px}.contact{padding:4rem 1.5rem}.socials{margin-top:2rem}.footer{padding:2rem 1.5rem}}html.lenis,html.lenis body{height:auto}.scroll-top{position:fixed;bottom:2rem;right:2rem;width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.1);background:#0a0a0a99;backdrop-filter:blur(8px);color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:100;opacity:0;pointer-events:none;transition:opacity .3s ease,color .3s ease,border-color .3s ease}.scroll-top.visible{opacity:1;pointer-events:auto}.scroll-top:hover{color:var(--color-accent-cyan);border-color:var(--color-accent-cyan)}.lenis.lenis-smooth{scroll-behavior:auto!important}.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}.lenis.lenis-stopped{overflow:hidden}.lenis.lenis-smooth iframe{pointer-events:none}
