@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@200;400;700;900&family=IBM+Plex+Mono:wght@300;400&family=Syne:wght@300;400;700;800&display=swap');

*{margin:0;padding:0;box-sizing:border-box}

:root{
  --black:#000000;
  --deep:#0a0f1a;
  --cyan:#00f0ff;
  --magenta:#ff00aa;
  --white:#f0f4ff;
  --muted:#a0a8c0;
  --glass:rgba(255,255,255,0.03);
  --glass-border:rgba(255,255,255,0.07);
}

body{
  background:var(--black);
  color:var(--white);
  font-family:'Syne',sans-serif;
  overflow-x:hidden;
  cursor:none;
}

#cursor{position:fixed;width:8px;height:8px;background:var(--cyan);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:transform 0.1s;mix-blend-mode:screen}
#cursor-trail{position:fixed;pointer-events:none;z-index:9998;top:0;left:0;width:100%;height:100%}

.noise{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1000;pointer-events:none;opacity:0.04;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:150px}

#particles{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none}

nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  padding:20px 40px;
  display:flex;justify-content:space-between;align-items:center;
  opacity:0;transform:translateY(-10px);
  transition:opacity 0.8s ease,transform 0.8s ease;
  background:linear-gradient(180deg,rgba(0,0,0,0.6) 0%,transparent 100%);
  backdrop-filter:blur(2px);
}
nav.visible{opacity:1;transform:translateY(0)}
.nav-logo{font-family:'Orbitron',monospace;font-weight:200;font-size:11px;letter-spacing:6px;color:var(--muted);text-transform:uppercase}
.nav-links{display:flex;gap:32px}
.nav-links a{font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:3px;color:var(--muted);text-decoration:none;text-transform:uppercase;transition:color 0.3s}
.nav-links a:hover{color:var(--cyan)}
.nav-dot{width:4px;height:4px;border-radius:50%;background:var(--cyan);display:inline-block;margin-right:8px;opacity:0.6}

section{position:relative;z-index:2;min-height:100vh;padding:120px 8vw}

#hero{
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  min-height:100vh;padding:0;
  background:radial-gradient(ellipse 80% 60% at 50% 40%,rgba(0,15,30,0.8) 0%,var(--black) 100%);
}
.hero-surname{
  font-family:'Orbitron',monospace;
  font-weight:200;
  font-size:clamp(80px,13vw,200px);
  letter-spacing:-0.02em;
  line-height:0.9;
  text-align:center;
  color:var(--white);
  position:relative;
  animation:heroReveal 1.8s cubic-bezier(0.16,1,0.3,1) forwards;
  opacity:0;
  transform:translateY(40px);
}
.hero-surname::after{
  content:attr(data-text);
  position:absolute;left:0;top:0;width:100%;
  background:linear-gradient(180deg,transparent 60%,rgba(0,240,255,0.08) 100%);
  -webkit-background-clip:text;background-clip:text;
  filter:blur(0px);
  color:transparent;
  pointer-events:none;
}
.hero-glow{
  position:absolute;bottom:-20px;left:50%;transform:translateX(-50%);
  width:60%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(0,240,255,0.3),transparent);
  filter:blur(4px);
}
.hero-tagline{
  font-family:'IBM Plex Mono',monospace;
  font-weight:300;
  font-size:clamp(10px,1.2vw,13px);
  letter-spacing:5px;
  color:var(--muted);
  margin-top:32px;
  text-transform:uppercase;
  animation:fadeUp 2s 0.8s cubic-bezier(0.16,1,0.3,1) forwards;
  opacity:0;
  transform:translateY(20px);
}
.hero-scroll{
  position:absolute;
  bottom:48px;
  left:0;
  right:0;
  margin:0 auto;
  width:max-content;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  gap:8px;
  animation:fadeUp 2s 1.5s ease forwards;
  opacity:0;
}
.hero-scroll span{font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:4px;color:rgba(160,168,192,0.4);text-transform:uppercase}
.scroll-line{width:1px;height:40px;background:linear-gradient(180deg,var(--cyan),transparent);animation:scrollPulse 2s infinite}

@keyframes heroReveal{to{opacity:1;transform:translateY(0)}}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}
@keyframes scrollPulse{0%,100%{opacity:0.3}50%{opacity:1}}

#about{
  display:grid;grid-template-columns:1fr 1fr;gap:8vw;align-items:start;
  padding-top:160px;
}
.about-visual{
  position:relative;
}
.about-photo-frame{
  width:100%;
  aspect-ratio:3/4;
  background:linear-gradient(135deg,rgba(0,15,30,1) 0%,rgba(0,30,50,0.8) 100%);
  border:1px solid var(--glass-border);
  border-radius:2px;
  position:relative;
  overflow:hidden;
  backdrop-filter:blur(12px);
}
.photo-inner{
  width:100%;height:100%;
  background:
    repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,240,255,0.015) 2px,rgba(0,240,255,0.015) 4px),
    linear-gradient(135deg,#050d18 0%,#0a1520 40%,#060d18 100%);
  display:flex;align-items:center;justify-content:center;
  position:relative;
}
.photo-scanlines{position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,0,0,0.15) 3px,rgba(0,0,0,0.15) 4px);pointer-events:none}
.photo-chromatic{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(0,240,255,0.03) 0%,transparent 50%,rgba(255,0,170,0.02) 100%);
  mix-blend-mode:screen;
}
.photo-label{
  font-family:'IBM Plex Mono',monospace;
  font-size:9px;letter-spacing:4px;color:var(--muted);
  opacity:0.4;
  position:absolute;bottom:16px;left:16px;
  text-transform:uppercase;
}
.about-content{padding-top:40px}
.section-label{
  font-family:'IBM Plex Mono',monospace;
  font-size:9px;letter-spacing:5px;color:var(--cyan);
  opacity:0.7;text-transform:uppercase;margin-bottom:40px;
  display:flex;align-items:center;gap:12px;
}
.section-label::before{content:'';display:block;width:24px;height:1px;background:var(--cyan);opacity:0.5}
.about-headline{
  font-family:'Syne',sans-serif;font-weight:300;
  font-size:clamp(28px,3vw,42px);
  line-height:1.3;color:var(--white);
  margin-bottom:40px;
  letter-spacing:-0.01em;
}
.about-bio{
  font-family:'Syne',sans-serif;font-weight:300;
  font-size:14px;line-height:2;color:var(--muted);
  margin-bottom:48px;column-count:1;
}
.achievements{display:flex;flex-direction:column;gap:0}
.achievement{
  display:flex;align-items:center;gap:16px;
  padding:16px 0;
  border-bottom:1px solid var(--glass-border);
  opacity:0;transform:translateX(-20px);
  transition:all 0.6s cubic-bezier(0.16,1,0.3,1);
}
.achievement.visible{opacity:1;transform:translateX(0)}
.ach-num{font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:2px;color:rgba(0,240,255,0.4)}
.ach-text{font-size:13px;color:var(--white);letter-spacing:0.5px}

#work{padding-top:160px}
.work-header{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-bottom:80px;
}
.section-title{
  font-family:'Syne',sans-serif;font-weight:800;
  font-size:clamp(40px,6vw,80px);
  line-height:0.9;letter-spacing:-0.02em;
  color:var(--white);
}
.work-count{
  font-family:'IBM Plex Mono',monospace;
  font-size:9px;letter-spacing:4px;color:var(--muted);opacity:0.5;
  align-self:flex-end;padding-bottom:8px;
}
.bento-grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  grid-template-rows:auto;
  gap:12px;
}
.project-card{
  border:1px solid var(--glass-border);
  border-radius:2px;
  position:relative;overflow:hidden;
  cursor:none;
  transition:transform 0.6s cubic-bezier(0.16,1,0.3,1),border-color 0.4s;
  background:var(--deep);
}
.project-card:hover{
  transform:translateY(-4px) scale(1.01);
  border-color:rgba(0,240,255,0.2);
}
.project-card:nth-child(1){grid-column:span 7;aspect-ratio:16/9}
.project-card:nth-child(2){grid-column:span 5;aspect-ratio:1}
.project-card:nth-child(3){grid-column:span 4;aspect-ratio:1}
.project-card:nth-child(4){grid-column:span 8;aspect-ratio:16/9}
.card-bg{
  position:absolute;inset:0;
  transition:transform 0.8s cubic-bezier(0.16,1,0.3,1);
}
.project-card:hover .card-bg{transform:scale(1.03)}
.card-bg-1{background:linear-gradient(135deg,#050d18,#0a1f30,#051520)}
.card-bg-2{background:linear-gradient(135deg,#100510,#1a0518,#0d0312)}
.card-bg-3{background:linear-gradient(135deg,#050d12,#0a1a20,#030d18)}
.card-bg-4{background:linear-gradient(135deg,#0d0f05,#151a08,#080a03)}
.card-grid-accent{
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(0,240,255,0.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,240,255,0.03) 1px,transparent 1px);
  background-size:40px 40px;
  opacity:0;transition:opacity 0.4s;
}
.project-card:hover .card-grid-accent{opacity:1}
.card-bloom{
  position:absolute;inset:0;
  background:radial-gradient(ellipse at 30% 50%,rgba(0,240,255,0.06) 0%,transparent 60%);
  opacity:0;transition:opacity 0.4s;
}
.project-card:hover .card-bloom{opacity:1}
.card-info{
  position:absolute;bottom:0;left:0;right:0;
  padding:20px;
  background:linear-gradient(0deg,rgba(0,0,0,0.8) 0%,transparent 100%);
  display:flex;justify-content:space-between;align-items:flex-end;
}
.card-title{
  font-family:'Syne',sans-serif;font-weight:700;
  font-size:clamp(14px,1.5vw,18px);
  letter-spacing:-0.01em;color:var(--white);
}
.card-meta{
  text-align:right;
  display:flex;flex-direction:column;gap:4px;align-items:flex-end;
}
.card-year{font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:2px;color:var(--muted);opacity:0.6}
.card-tag{
  font-family:'IBM Plex Mono',monospace;font-size:8px;letter-spacing:2px;
  color:var(--cyan);text-transform:uppercase;
  border:1px solid rgba(0,240,255,0.2);padding:2px 6px;
}
.card-isometric{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  opacity:0.15;
}

#lab{padding-top:160px}
.lab-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
  gap:8px;margin-top:80px;
}
.lab-item{
  aspect-ratio:1;
  border:1px solid var(--glass-border);
  border-radius:2px;
  position:relative;overflow:hidden;
  cursor:none;
  background:var(--deep);
  transition:border-color 0.3s;
}
.lab-item:hover{border-color:rgba(0,240,255,0.3)}
.lab-item:hover .lab-glitch{opacity:1}
.lab-bg{
  position:absolute;inset:0;
  transition:transform 0.6s;
  display:flex;align-items:center;justify-content:center;
}
.lab-item:hover .lab-bg{transform:scale(1.05)}
.lab-glitch{
  position:absolute;inset:0;opacity:0;
  background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,240,255,0.05) 2px,rgba(0,240,255,0.05) 4px);
  transition:opacity 0.2s;
}
.lab-num{
  position:absolute;top:12px;left:12px;
  font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:2px;
  color:rgba(0,240,255,0.4);
}
.lab-label{
  position:absolute;bottom:12px;left:12px;right:12px;
  font-size:11px;font-weight:300;letter-spacing:0.5px;color:var(--muted);
}
.lab-icon{
  font-size:28px;opacity:0.15;
  font-family:'IBM Plex Mono',monospace;
  color:var(--cyan);
  font-size:32px;
  font-weight:300;
}
.services-dropdown{
  margin-top:20px;
  border-top:1px solid var(--glass-border);
}

.service-item{
  border-bottom:1px solid var(--glass-border);
  cursor:pointer;
  padding:16px 0;
}

.service-title{
  font-family:'IBM Plex Mono',monospace;
  font-size:11px;
  letter-spacing:2px;
  color:var(--white);
  display:flex;
  justify-content:space-between;
}

.service-content{
  max-height:0;
  overflow:hidden;
  transition:max-height 0.4s ease;
  font-size:13px;
  color:var(--muted);
  line-height:1.6;
  margin-top:8px;
}

.service-item.active .service-content{
  max-height:120px;
}

#contact{
  padding-top:160px;padding-bottom:120px;
  display:grid;grid-template-columns:1fr 1fr;
  gap:8vw;align-items:start;
}
.contact-left{}
.contact-heading{
  font-family:'Syne',sans-serif;font-weight:800;
  font-size:clamp(50px,7vw,100px);
  line-height:0.85;letter-spacing:-0.03em;
  color:var(--white);margin-bottom:48px;
}
.contact-heading em{
  font-style:normal;
  color:transparent;
  -webkit-text-stroke:1px rgba(255,255,255,0.15);
}
.social-links{display:flex;gap:24px;margin-top:60px}
.social-btn{
  width:40px;height:40px;
  border:1px solid var(--glass-border);
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;
  cursor:none;
  transition:all 0.6s cubic-bezier(0.34,1.56,0.64,1);
  color:var(--muted);font-family:'IBM Plex Mono',monospace;font-size:10px;
  text-decoration:none;
}
.social-btn:hover{
  border-color:rgba(0,240,255,0.4);
  color:var(--cyan);
  transform:rotate(360deg);
  background:rgba(0,240,255,0.05);
}
.contact-form{padding-top:20px}
.form-field{
  position:relative;margin-bottom:32px;
}
.form-field input,.form-field textarea{
  width:100%;
  background:transparent;
  border:none;border-bottom:1px solid var(--glass-border);
  color:var(--white);
  font-family:'Syne',sans-serif;font-weight:300;font-size:14px;
  padding:16px 0;
  outline:none;
  transition:border-color 0.4s;
  resize:none;
}
.form-field input:focus,.form-field textarea:focus{border-color:rgba(0,240,255,0.3)}
.form-field label{
  position:absolute;top:16px;left:0;
  font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:3px;
  color:var(--muted);text-transform:uppercase;
  transition:all 0.4s cubic-bezier(0.16,1,0.3,1);
  pointer-events:none;
}
.form-field input:focus~label,.form-field input:not(:placeholder-shown)~label,
.form-field textarea:focus~label,.form-field textarea:not(:placeholder-shown)~label{
  top:-8px;font-size:8px;color:var(--cyan);letter-spacing:4px;
}
.form-field textarea{min-height:80px}
.send-btn{
  display:flex;align-items:center;gap:16px;
  background:transparent;border:1px solid rgba(0,240,255,0.2);
  color:var(--cyan);cursor:none;
  padding:16px 32px;
  font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:4px;
  text-transform:uppercase;
  transition:all 0.4s;
  position:relative;overflow:hidden;
  animation:pulseBorder 3s infinite;
}
.send-btn:hover{background:rgba(0,240,255,0.05);border-color:rgba(0,240,255,0.5)}
.send-btn::before{
  content:'';position:absolute;top:50%;left:50%;
  width:0;height:0;
  background:rgba(0,240,255,0.08);
  border-radius:50%;transform:translate(-50%,-50%);
  transition:width 0.6s,height 0.6s;
}
.send-btn:hover::before{width:300px;height:300px}
@keyframes pulseBorder{0%,100%{box-shadow:0 0 0 0 rgba(0,240,255,0)}50%{box-shadow:0 0 12px 2px rgba(0,240,255,0.08)}}

.section-divider{
  height:1px;
  background:linear-gradient(90deg,transparent,var(--glass-border),transparent);
  margin:0 8vw;
  position:relative;z-index:2;
}

footer{
  position:relative;z-index:2;
  padding:40px 8vw;
  display:flex;justify-content:space-between;align-items:center;
  border-top:1px solid var(--glass-border);
}
.footer-copy{font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:3px;color:rgba(160,168,192,0.3);text-transform:uppercase}

.card-svg{position:absolute;inset:0;width:100%;height:100%;opacity:0.08}

@media (max-width: 1024px){
  nav{
    padding:18px 24px;
  }

  .nav-logo{
    font-size:10px;
    letter-spacing:4px;
  }

  .nav-links{
    gap:18px;
  }

  .nav-links a{
    font-size:9px;
    letter-spacing:2px;
  }

  section{
    padding:100px 6vw;
  }

  #about,
  #contact{
    grid-template-columns:1fr;
    gap:48px;
  }

  .about-content{
    padding-top:0;
  }

  .work-header{
    gap:24px;
    align-items:flex-start;
    flex-direction:column;
  }

  .bento-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .project-card:nth-child(1),
  .project-card:nth-child(2),
  .project-card:nth-child(3),
  .project-card:nth-child(4){
    grid-column:span 1;
    aspect-ratio:1.15/1;
  }

  .lab-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  .contact-form{
    padding-top:0;
  }

  .contact-heading{
    margin-bottom:32px;
  }
}

@media (max-width: 768px){
  body{
    cursor:auto;
  }

  #cursor,
  #cursor-trail{
    display:none;
  }

  nav{
    padding:16px 18px;
    flex-direction:column;
    align-items:flex-start;
    gap:14px;
  }

  .nav-logo{
    font-size:9px;
    letter-spacing:3px;
    line-height:1.5;
  }

  .nav-links{
    width:100%;
    flex-wrap:wrap;
    gap:10px 16px;
  }

  .nav-links a{
    font-size:9px;
    letter-spacing:2px;
  }

  section{
    min-height:auto;
    padding:92px 18px;
  }

  #hero{
    min-height:100vh;
    padding:0 18px;
  }

  .hero-surname{
    font-size:clamp(52px,18vw,92px);
    line-height:0.95;
    word-break:break-word;
  }

  .hero-tagline{
    font-size:10px;
    letter-spacing:3px;
    margin-top:22px;
    text-align:center;
  }

  .hero-scroll{
    bottom:28px;
  }

  .hero-scroll span{
    font-size:8px;
    letter-spacing:3px;
  }

  #about{
    padding-top:110px;
    grid-template-columns:1fr;
    gap:36px;
  }

  .about-photo-frame{
    aspect-ratio:4/5;
  }

  .section-label{
    font-size:8px;
    letter-spacing:4px;
    margin-bottom:24px;
  }

  .about-headline{
    font-size:clamp(24px,8vw,34px);
    margin-bottom:24px;
  }

  .about-bio{
    font-size:13px;
    line-height:1.8;
    margin-bottom:28px;
  }

  .service-item{
    padding:14px 0;
  }

  .service-title{
    font-size:10px;
    letter-spacing:1.5px;
    gap:12px;
  }

  .service-content{
    font-size:12px;
    line-height:1.6;
  }

  #work,
  #lab,
  #contact{
    padding-top:110px;
  }

  .work-header{
    margin-bottom:36px;
    flex-direction:column;
    align-items:flex-start;
    gap:14px;
  }

  .section-title{
    font-size:clamp(34px,12vw,56px);
    line-height:0.95;
  }

  .work-count{
    font-size:8px;
    letter-spacing:3px;
    padding-bottom:0;
  }

  .bento-grid{
    grid-template-columns:1fr;
    gap:10px;
  }

  .project-card:nth-child(1),
  .project-card:nth-child(2),
  .project-card:nth-child(3),
  .project-card:nth-child(4){
    grid-column:span 1;
    aspect-ratio:16/10;
  }

  .card-info{
    padding:16px;
  }

  .card-title{
    font-size:14px;
  }

  .card-year{
    font-size:8px;
  }

  .card-tag{
    font-size:7px;
    letter-spacing:1.5px;
  }

  .lab-grid{
    grid-template-columns:1fr 1fr;
    gap:8px;
    margin-top:36px;
  }

  .lab-num{
    font-size:8px;
  }

  .lab-label{
    font-size:10px;
  }

  #contact{
    grid-template-columns:1fr;
    gap:40px;
    padding-bottom:80px;
  }

  .contact-heading{
    font-size:clamp(40px,14vw,68px);
    margin-bottom:24px;
  }

  .social-links{
    gap:14px;
    margin-top:32px;
  }

  .social-btn{
    width:36px;
    height:36px;
    font-size:9px;
  }

  .form-field{
    margin-bottom:24px;
  }

  .form-field input,
  .form-field textarea{
    font-size:13px;
    padding:14px 0;
  }

  .form-field label{
    font-size:9px;
    letter-spacing:2px;
  }

  .send-btn{
    width:100%;
    justify-content:center;
    padding:15px 20px;
    font-size:10px;
    letter-spacing:3px;
  }

  .section-divider{
    margin:0 18px;
  }

  footer{
    padding:24px 18px;
    flex-direction:column;
    align-items:flex-start;
    gap:10px;
  }

  .footer-copy{
    font-size:8px;
    letter-spacing:2px;
  }
}

@media (max-width: 480px){
  nav{
    padding:14px 14px;
  }

  section{
    padding:88px 14px;
  }

  .hero-surname{
    font-size:clamp(44px,17vw,72px);
  }

  .hero-tagline{
    font-size:9px;
    letter-spacing:2px;
  }

  .about-headline{
    font-size:clamp(22px,8vw,30px);
  }

  .about-bio{
    font-size:12px;
  }

  .lab-grid{
    grid-template-columns:1fr;
  }

  .project-card:nth-child(1),
  .project-card:nth-child(2),
  .project-card:nth-child(3),
  .project-card:nth-child(4){
    aspect-ratio:1.2/1;
  }

  .contact-heading{
    font-size:clamp(34px,13vw,54px);
  }

  .section-divider{
    margin:0 14px;
  }

  footer{
    padding:22px 14px;
  }
}
.photo-inner{
  position:relative;
  width:100%;
  height:100%;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
}

.about-img{
  position:relative;
  width:80%;
  height:auto;
  max-height:80%;
  object-fit:contain;
  z-index:1;
}
@media (max-width: 768px){
  #about{
    grid-template-columns:1fr;
    gap:36px;
    padding-top:110px;
  }

  .about-visual{
    display:flex;
    justify-content:center;
    align-items:center;
  }

  .about-photo-frame{
    width:100%;
    max-width:420px;
    aspect-ratio:4/5;
    margin:0 auto;
  }

  .photo-inner{
    position:relative;
    width:100%;
    height:100%;
    overflow:hidden;
  }

  .about-img{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center;
  }
}