*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#fafafa;--text:#111;--text-muted:#444;--text-dim:#777;--border:#00000014;--border-hover:#0003;--font:"M PLUS 1p",sans-serif;--ease:cubic-bezier(.16,1,.3,1);--ease-out:cubic-bezier(.33,1,.68,1)}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font);background:var(--bg);color:var(--text);cursor:none;-webkit-font-smoothing:antialiased;line-height:1.6;overflow-x:hidden}a{color:var(--text);cursor:none;text-decoration:none}::selection{color:var(--text);background:#0a0a0a1f}.cursor{border:1.5px solid var(--text);pointer-events:none;z-index:9999;width:16px;height:16px;transition:width .4s var(--ease),height .4s var(--ease),border-color .3s,background .3s,transform .1s;border-radius:50%;position:fixed;transform:translate(-50%,-50%)}.cursor.hover{background:#0a0a0a0d;border-color:#0a0a0a4d;width:56px;height:56px}.cursor-dot{background:var(--text);pointer-events:none;z-index:10000;border-radius:50%;width:4px;height:4px;transition:opacity .3s;position:fixed;transform:translate(-50%,-50%)}.nav{z-index:1000;justify-content:space-between;align-items:center;width:100%;padding:2rem 3.5rem;display:flex;position:fixed;top:0;left:0}.nav-logo{letter-spacing:.2em;text-transform:uppercase;font-size:.9rem;font-weight:700}.nav-links{gap:3rem;list-style:none;display:flex}.nav-links a{letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted);transition:color .5s var(--ease);font-size:.75rem;font-weight:400;position:relative}.nav-links a:after{content:"";background:var(--text);width:0;height:1px;transition:width .5s var(--ease);position:absolute;bottom:-6px;left:0}.nav-links a:hover{color:var(--text)}.nav-links a:hover:after{width:100%}.hero{text-align:center;flex-direction:column;justify-content:center;align-items:center;height:100vh;display:flex;position:relative;overflow:hidden}.hero-name{letter-spacing:-.02em;perspective:500px;font-size:clamp(5rem,15vw,14rem);font-weight:800;line-height:.9}.hero-char{will-change:transform,opacity;display:inline-block}.hero-sub{letter-spacing:.4em;text-transform:uppercase;color:var(--text-muted);margin-top:1.5rem;font-size:clamp(.85rem,1.5vw,1rem);font-weight:300}.hero-typing-wrap{min-height:1.5em;margin-top:1rem}.hero-typing{color:var(--text-dim);letter-spacing:.05em;font-size:.85rem;font-weight:400}.typing-cursor{background:var(--text-muted);vertical-align:text-bottom;width:1.5px;height:1em;margin-left:2px;animation:1s step-end infinite blink;display:inline-block}.hero-socials{justify-content:center;gap:1.5rem;margin-top:1.5rem;display:flex}.social-icon{color:var(--text-dim);transition:all .4s var(--ease);justify-content:center;align-items:center;display:flex}.social-icon:hover{color:var(--white);filter:drop-shadow(0 0 10px #ffffff4d);transform:translateY(-4px)scale(1.1)}.social-icon svg{width:24px;height:24px}.hero-cta{gap:1.5rem;margin-top:3rem;display:flex}.cta-btn{border:1px solid var(--border);font-size:.7rem;font-weight:500;font-family:var(--font);letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted);cursor:none;transition:all .5s var(--ease);background:0 0;padding:.7rem 2rem}.cta-btn:hover{color:#fff;background:var(--text);border-color:var(--text)}.hero-scroll-line{width:1px;height:80px;position:absolute;bottom:0;left:50%;overflow:hidden;transform:translate(-50%)}.hero-scroll-line:after{content:"";background:linear-gradient(to bottom,transparent,var(--text-muted));width:1px;height:100%;animation:scrollLine 2s var(--ease)infinite;display:block}.orbs{z-index:-1;pointer-events:none;position:fixed;inset:0;overflow:hidden}.orb{filter:blur(80px);opacity:1;border-radius:50%;animation:20s ease-in-out infinite alternate orbFloat;position:absolute;background:#0a0a0a08!important}.orb-1{background:#0a0a0a08;width:600px;height:600px;animation-duration:25s;top:-200px;right:-100px}.orb-2{background:#0a0a0a08;width:400px;height:400px;animation-duration:20s;animation-delay:-5s;bottom:-100px;left:-100px}.orb-3{background:#0a0a0a08;width:300px;height:300px;animation-duration:30s;animation-delay:-10s;top:50%;left:50%}.section{max-width:1200px;margin:0 auto;padding:10rem 3.5rem}.section-label{letter-spacing:.35em;text-transform:uppercase;color:var(--text-dim);align-items:center;gap:1rem;margin-bottom:2rem;font-size:.65rem;font-weight:500;display:flex}.section-label:before{content:"";background:var(--text-dim);width:30px;height:1px}.section-title{letter-spacing:-.01em;margin-bottom:1.5rem;font-size:clamp(2.2rem,5vw,3.8rem);font-weight:700;line-height:1.15}.section-desc{color:var(--text-muted);max-width:550px;margin-bottom:4rem;font-size:.95rem;line-height:1.9}.divider{background:var(--border);width:100%;max-width:1200px;height:1px;margin:0 auto}.about-grid{grid-template-columns:1fr 1fr;gap:6rem;display:grid}.about-text{color:var(--text-muted);font-size:.95rem;line-height:2}.about-text strong{color:var(--text);font-weight:600}.about-stats{grid-template-columns:1fr 1fr;gap:3rem;margin-top:3rem;display:grid}.stat{padding-top:1.5rem;position:relative}.stat:before{content:"";background:var(--text-dim);width:24px;height:1px;position:absolute;top:0;left:0}.stat-num{margin-bottom:.5rem;font-size:2.5rem;font-weight:700;line-height:1}.stat-label{color:var(--text-dim);letter-spacing:.15em;text-transform:uppercase;font-size:.7rem}.about-detail-list{flex-direction:column;gap:1rem;padding-top:1rem;display:flex}.about-detail-item{color:var(--text-muted);padding-left:1.5rem;font-size:.9rem;line-height:1.7;position:relative}.about-detail-item:before{content:"";background:var(--text-dim);width:6px;height:1px;position:absolute;top:.6em;left:0}.about-detail-item strong{color:var(--text)}.marquee-wrap{border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin:0 -3.5rem;padding:2.5rem 0;overflow:hidden}.marquee{gap:3rem;width:max-content;animation:25s linear infinite marquee;display:flex}.marquee:hover{animation-play-state:paused}.marquee-item{letter-spacing:.1em;color:var(--text-muted);white-space:nowrap;align-items:center;gap:.5rem;font-size:.85rem;font-weight:500;transition:color .4s;display:flex}.marquee-item:hover{color:var(--text)}.marquee-sep{color:var(--text-dim);font-size:.5rem}.skills-grid{background:var(--border);grid-template-columns:repeat(3,1fr);gap:1px;margin-top:4rem;display:grid}.skill-group{background:var(--bg);transition:background .5s var(--ease);padding:2.5rem}.skill-group:hover{background:#0a0a0a05}.skill-group-title{letter-spacing:.25em;text-transform:uppercase;color:var(--text-dim);margin-bottom:1.5rem;font-size:.65rem;font-weight:500}.skill-group-list{flex-direction:column;gap:.6rem;display:flex}.skill-group-item{color:var(--text-muted);transition:color .3s,transform .3s var(--ease);font-size:.85rem}.skill-group-item:hover{color:var(--text);transform:translate(8px)}.project-list{flex-direction:column;display:flex}.project-item{border-bottom:1px solid var(--border);transition:all .5s var(--ease);color:var(--text);cursor:none;grid-template-columns:48px auto 1fr auto;align-items:center;gap:2rem;padding:3rem 0;text-decoration:none;display:grid}.project-img{object-fit:cover;border:1px solid var(--border);width:48px;height:48px;transition:transform .4s var(--ease);border-radius:10px}.project-item:hover .project-img{transform:scale(1.1)}.project-item:first-child{border-top:1px solid var(--border)}.project-item:hover{padding-left:1.5rem}.project-item:hover .project-title{opacity:1}.project-item:hover .project-arrow{opacity:1;transform:translate(8px)}.project-num{color:var(--text-dim);letter-spacing:.15em;min-width:30px;font-size:.7rem;font-weight:500}.project-info{flex-direction:column;gap:.3rem;display:flex}.project-title{opacity:.8;transition:opacity .5s var(--ease);font-size:clamp(1.5rem,3vw,2.5rem);font-weight:700;line-height:1.1}.project-sub{color:var(--text-muted);font-size:.85rem}.project-tags{flex-wrap:wrap;gap:.5rem;margin-top:.5rem;display:flex}.project-tag{letter-spacing:.1em;color:var(--text-dim);text-transform:uppercase;border:1px solid var(--border);padding:.25rem .6rem;font-size:.6rem}.project-right{flex-direction:column;align-items:flex-end;gap:.5rem;display:flex}.project-meta{color:var(--text-dim);letter-spacing:.1em;text-align:right;font-size:.65rem}.project-arrow{opacity:.3;transition:all .5s var(--ease);font-size:1.5rem;font-weight:300}.timeline{padding-left:4rem;position:relative}.timeline:before{content:"";background:var(--border);width:1px;position:absolute;top:0;bottom:0;left:0}.tl-item{padding-bottom:5rem;position:relative}.tl-content-wrapper{align-items:flex-start;gap:3rem;margin-top:1rem;display:flex}.tl-info{flex:1}.tl-img-wrapper{aspect-ratio:16/9;border:1px solid var(--border);cursor:zoom-in;border-radius:12px;flex:0 0 35%;max-width:400px;overflow:hidden;box-shadow:0 10px 30px #0000000d}.tl-img-static{object-fit:cover;width:100%;height:100%;transition:transform .6s var(--ease)}.tl-item:hover .tl-img-static{transform:scale(1.05)}@media (max-width:768px){.tl-content-wrapper{flex-direction:column;gap:1.5rem}.tl-img-wrapper{flex:none;width:100%;margin-top:.5rem}}.tl-item:last-child{padding-bottom:0}.tl-dot{border:1.5px solid var(--text-dim);background:var(--bg);width:8px;height:8px;transition:all .5s var(--ease);border-radius:50%;position:absolute;top:.4rem;left:-4rem;transform:translate(-3.5px)}.lightbox{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:99999;cursor:zoom-out;animation:fadeIn .3s var(--ease);background:#0a0a0ad9;justify-content:center;align-items:center;padding:2rem;display:flex;position:fixed;inset:0}.lightbox-content{max-width:90vw;max-height:90vh;position:relative}.lightbox-content img{object-fit:contain;border-radius:8px;width:auto;max-width:100%;height:auto;max-height:90vh;animation:.4s cubic-bezier(.16,1,.3,1) zoomIn;box-shadow:0 20px 50px #00000080}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes zoomIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.tl-item:hover .tl-dot{border-color:var(--text);background:var(--text);box-shadow:0 0 12px #0a0a0a26}.tl-dot.active{border-color:var(--text);background:var(--text);animation:2.5s infinite pulse;box-shadow:0 0 0 4px #0a0a0a1a}.tl-era{letter-spacing:.3em;text-transform:uppercase;color:var(--text-dim);margin-bottom:.8rem;font-size:.65rem;font-weight:500}.tl-title{margin-bottom:.6rem;font-size:1.6rem;font-weight:700}.tl-badge{border:1px solid var(--border-hover);letter-spacing:.1em;margin-bottom:1rem;padding:.3rem .8rem;font-size:.65rem;font-weight:500;display:inline-block}.tl-desc{color:var(--text-muted);max-width:480px;font-size:.85rem;line-height:1.9}.tl-tech{color:var(--text-dim);letter-spacing:.08em;margin-top:.8rem;font-size:.7rem}.footer{border-top:1px solid var(--border);padding:6rem 3.5rem}.footer-inner{justify-content:space-between;align-items:flex-end;max-width:1200px;margin:0 auto;display:flex}.footer-left{flex-direction:column;gap:.8rem;display:flex}.footer-title{font-size:1.8rem;font-weight:700}.footer-email{color:var(--text-muted);letter-spacing:.05em;font-size:.8rem;transition:color .3s}.footer-email:hover{color:var(--text)}.footer-right{gap:2rem;display:flex}.footer-link{letter-spacing:.15em;text-transform:uppercase;color:var(--text-dim);font-size:.7rem;transition:color .4s}.footer-link:hover{color:var(--text)}.footer-huge-text{letter-spacing:-.06em;color:var(--text);text-align:center;-webkit-user-select:none;user-select:none;white-space:nowrap;margin-top:6rem;margin-bottom:2rem;font-size:clamp(6rem,28vw,30rem);font-weight:900;line-height:.75;overflow:hidden}.footer-copy{max-width:1200px;color:var(--text-dim);letter-spacing:.1em;margin:3rem auto 0;font-size:.65rem}@keyframes blink{50%{opacity:0}}@keyframes marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes scrollLine{0%{transform:translateY(-100%)}to{transform:translateY(100%)}}@keyframes orbFloat{0%{transform:translate(0)}to{transform:translate(40px,-40px)}}@keyframes pulse{0%,to{box-shadow:0 0 0 4px #0a0a0a1a}50%{box-shadow:0 0 0 8px #0a0a0a0a}}.timeline:before{transform-origin:top;transition:transform 1.5s var(--ease);transform:scaleY(0)}.timeline.tl-animate:before{transform:scaleY(1)}@media (max-width:768px){body,a{cursor:auto}.cta-btn,.project-item{cursor:pointer}.cursor,.cursor-dot{display:none}.nav{padding:1.2rem 1.5rem}.nav-links{gap:1.5rem}.nav-links a{font-size:.65rem}.section{padding:6rem 1.5rem}.about-grid{grid-template-columns:1fr;gap:3rem}.about-stats{gap:2rem}.skills-grid{grid-template-columns:1fr}.marquee-wrap{margin:0 -1.5rem}.project-item{grid-template-columns:1fr;gap:1rem;padding:2rem 0}.project-num{display:none}.project-right{flex-direction:row;align-items:center}.timeline{padding-left:2.5rem}.tl-dot{left:-2.5rem}.hero-cta{flex-direction:column;align-items:center}.footer-inner{flex-direction:column;align-items:flex-start;gap:2rem}}@media (max-width:480px){.hero-name{font-size:3.5rem}.section-title{font-size:1.8rem}.about-stats{grid-template-columns:1fr}}
