@media (pointer:fine){body,a,button,input,textarea,[role=button]{cursor:none!important}}.cursor-glow{pointer-events:none;z-index:9998;will-change:transform;mix-blend-mode:screen;background:radial-gradient(circle,#64ffda1a 0%,#64ffda0f 30%,#64ffda05 55%,#0000 75%);border-radius:50%;width:600px;height:600px;position:fixed;top:0;left:0;transform:translate(-9999px,-9999px)}.cursor-dot{pointer-events:none;z-index:9999;will-change:transform;background:#64ffda;border-radius:50%;width:8px;height:8px;transition:width .25s,height .25s,box-shadow .25s;position:fixed;top:0;left:0;transform:translate(-9999px,-9999px);box-shadow:0 0 6px #64ffdacc,0 0 12px #64ffda80,0 0 24px #64ffda4d,0 0 48px #64ffda26}.cursor-dot.cursor-hover{background:#64ffda26;border:1.5px solid #64ffdab3;width:40px;height:40px;box-shadow:0 0 10px #64ffda99,0 0 20px #64ffda4d,0 0 40px #64ffda26}@media (hover:none) and (pointer:coarse){.cursor-glow,.cursor-dot{display:none!important}body{cursor:auto!important}}.navbar{z-index:1000;background-color:#0000;align-items:center;width:100%;height:70px;padding:0 50px;transition:background-color .3s,box-shadow .3s;display:flex;position:fixed;top:0;left:0}.navbar--scrolled{-webkit-backdrop-filter:blur(10px);background-color:#0a192fd9;box-shadow:0 10px 30px -10px #020c1bb3}.navbar-inner{justify-content:space-between;align-items:center;width:100%;max-width:1200px;margin:0 auto;display:flex}.navbar-logo{cursor:none;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;transition:background-color .2s;display:flex}.navbar-logo:hover{background:#64ffda14}.navbar-logo svg{display:block}.navbar-links{gap:6px;list-style:none;display:flex}.navbar-link{color:#ccd6f6;cursor:none;letter-spacing:.3px;background:0 0;border:none;border-radius:4px;padding:8px 14px;font-family:Inter,sans-serif;font-size:13px;font-weight:500;transition:color .2s,background-color .2s}.navbar-link:hover{color:#64ffda;background:#64ffda0f}.navbar-link--active{color:#64ffda;position:relative}.navbar-link--active:after{content:"";background:#64ffda;border-radius:1px;height:2px;position:absolute;bottom:2px;left:14px;right:14px}.navbar-link-num{color:#64ffda;margin-right:4px;font-family:Inter,sans-serif;font-size:11px;font-weight:600}@media (width<=768px){.navbar{height:60px;padding:0 20px}.navbar-links{gap:2px}.navbar-link{padding:6px 8px;font-size:12px}.navbar-link-num{display:none}}.hero{align-items:center;min-height:100vh;padding:0;display:flex;position:relative}.hero-inner{max-width:var(--max-width);flex-direction:column;gap:18px;width:100%;margin:0 auto;padding:80px 0 60px;display:flex}.hero-greeting{color:var(--accent);letter-spacing:1px;margin:0;font-size:13px;font-weight:500}.hero-name{color:#e6f1ff;letter-spacing:-1.5px;margin:0;font-size:clamp(36px,6vw,64px);font-weight:800;line-height:1.05}.hero-role{color:var(--text-secondary);letter-spacing:-.5px;min-height:1.2em;margin:0;font-size:clamp(20px,3.5vw,40px);font-weight:700}.role-text{color:var(--accent);transition:opacity .3s;display:inline-block}.role-text.fade-in{opacity:1}.role-text.fade-out{opacity:0}.hero-desc{color:var(--text-secondary);max-width:520px;margin:0;font-size:15px;line-height:1.75}.hero-cta{flex-wrap:wrap;gap:14px;margin-top:8px;display:flex}.btn-primary{color:var(--accent);border:1px solid var(--accent);letter-spacing:.5px;cursor:pointer;background:0 0;border-radius:4px;align-items:center;padding:12px 28px;font-size:13px;font-weight:600;text-decoration:none;transition:background .2s,color .2s;display:inline-flex}.btn-primary:hover{color:var(--accent);background:#64ffda1a}.btn-secondary{color:var(--text-secondary);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:4px;align-items:center;padding:12px 28px;font-size:13px;font-weight:500;text-decoration:none;transition:background .2s,color .2s,border-color .2s;display:inline-flex}.btn-secondary:hover{color:var(--accent);border-color:var(--accent)}.mini-player{background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;flex-wrap:wrap;align-items:center;gap:14px;width:fit-content;max-width:100%;margin-top:12px;padding:14px 18px;display:flex}.mp-play{color:var(--accent);cursor:pointer;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;padding:6px;transition:background .2s;display:flex}.mp-play:hover{background:var(--accent-dim)}.mp-details{flex-direction:column;gap:5px;min-width:180px;display:flex}.mp-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.mp-row--title{gap:6px}.mp-station-name{color:var(--text-primary);font-size:14px;font-weight:600}.mp-station-sub{color:var(--text-secondary);font-size:12px;font-weight:500}.mp-row--meta{gap:6px}.mp-location{color:var(--text-tertiary);align-items:center;gap:3px;font-size:11px;display:inline-flex}.mp-sep{color:var(--text-tertiary);opacity:.5;font-size:11px}.mp-online{color:var(--text-tertiary);align-items:center;gap:4px;font-size:11px;display:inline-flex}.mp-online.online{color:#64ffda}.mp-dot{background:#64ffda;border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite pulse-dot;display:inline-block}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.mp-votes{color:var(--text-tertiary);font-size:11px}.mp-row--tech{gap:5px}.mp-tag{color:var(--accent);background:#64ffda1a;border:1px solid #64ffda33;border-radius:10px;padding:2px 8px;font-size:10px;font-weight:500}.mp-format{color:var(--text-tertiary);align-items:center;gap:3px;font-size:11px;display:inline-flex}.mp-bitrate{color:var(--text-tertiary);font-size:11px}.mp-controls{flex-shrink:0;align-items:center;gap:8px;display:flex}.mp-mute,.mp-next{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:5px;transition:color .2s,background .2s;display:flex}.mp-mute:hover,.mp-next:hover{color:var(--accent);background:var(--accent-dim)}.mp-vol{color:var(--text-tertiary);flex-shrink:0;align-items:center;gap:5px;display:flex}.mp-slider{-webkit-appearance:none;background:var(--text-tertiary);cursor:pointer;border-radius:2px;outline:none;width:60px;height:3px}.mp-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent);cursor:pointer;border-radius:50%;width:10px;height:10px}.mp-visit{color:var(--accent);border:1px solid var(--accent);background:0 0;border-radius:4px;flex-shrink:0;align-items:center;padding:7px 14px;font-size:12px;font-weight:500;text-decoration:none;transition:background .2s;display:inline-flex}.mp-visit:hover{background:#64ffda1a}.hero-contact{color:var(--text-tertiary);flex-wrap:wrap;align-items:center;gap:10px;margin-top:6px;font-size:12.5px;display:flex}.contact-link{color:var(--text-secondary);transition:color .2s}.contact-link:hover{color:var(--accent)}.contact-sep,.contact-text{color:var(--text-tertiary)}.hero-scroll{flex-direction:column;align-items:center;gap:8px;display:flex;position:absolute;bottom:40px;right:40px}.scroll-text{letter-spacing:2px;color:var(--accent);writing-mode:vertical-rl;font-size:10px;font-weight:600}.scroll-line{background:var(--accent);opacity:.4;width:1px;height:60px;animation:2s ease-in-out infinite scroll-pulse}@keyframes scroll-pulse{0%,to{opacity:.4;transform:scaleY(1)}50%{opacity:.8;transform:scaleY(1.3)}}@media (width<=768px){.hero-inner{padding:60px 0 40px}.hero-scroll{display:none}.hero-cta{flex-direction:column}.btn-primary,.btn-secondary{text-align:center;justify-content:center}.mini-player{flex-direction:column;align-items:flex-start;gap:10px;width:100%}.mp-controls{justify-content:space-between;width:100%}}.about-section{max-width:900px;margin:0 auto;padding:100px 0}.about-grid{grid-template-columns:3fr 2fr;align-items:start;gap:50px;display:grid}.about-text p{color:#8892b0;margin-bottom:16px;font-size:15px;line-height:1.7}.about-text a{color:#64ffda;text-decoration:none;transition:color .2s;position:relative}.about-text a:hover{color:#4cdbb8}.about-text a:after{content:"";background:#64ffda;width:0%;height:1px;transition:width .3s;position:absolute;bottom:-2px;left:0}.about-text a:hover:after{width:100%}.about-skills{flex-wrap:wrap;gap:8px;margin-top:20px;padding:0;list-style:none;display:flex}.about-skills li{color:#64ffda;background:#64ffda0f;border:1px solid #64ffda26;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:500}.about-code-wrap{justify-content:center;display:flex;position:relative}.about-code{background:#112240;border-radius:6px;width:100%;max-width:300px;position:relative;overflow:hidden;box-shadow:0 10px 30px -15px #020c1bb3}.code-header{background:#0d1b2a;border-bottom:1px solid #64ffda14;align-items:center;gap:6px;padding:10px 14px;display:flex}.code-dot{border-radius:50%;width:10px;height:10px}.code-dot.red{background:#ff5f56}.code-dot.yellow{background:#ffbd2e}.code-dot.green{background:#27c93f}.code-filename{color:#8892b0;margin-left:8px;font-family:Fira Code,Consolas,monospace;font-size:11px}.code-body{color:#8892b0;white-space:pre;margin:0;padding:14px;font-family:Fira Code,Consolas,monospace;font-size:12px;line-height:1.7;overflow-x:auto}.code-body .code-keyword{color:#c792ea}.code-body .code-string{color:#c3e88d}.code-body .code-type{color:#ffcb6b}.code-body .code-prop{color:#82aaff}@media (width<=768px){.about-grid{grid-template-columns:1fr;gap:40px}.about-code-wrap{order:-1}.about-code{max-width:100%}}.exp-section{max-width:900px;margin:0 auto;padding:100px 0}.exp-grid{grid-template-columns:auto 1fr;align-items:start;gap:30px;display:grid}.exp-tabs{border-left:2px solid #233554;flex-direction:column;min-width:160px;margin:0;padding:0;list-style:none;display:flex}.exp-tab{color:#8892b0;cursor:none;text-align:left;white-space:nowrap;background:0 0;border:none;border-left:2px solid #0000;margin-left:-2px;padding:12px 20px;font-family:Inter,sans-serif;font-size:13px;font-weight:500;transition:color .2s,background-color .2s}.exp-tab:hover{color:#64ffda;background:#64ffda0a}.exp-tab--active{color:#64ffda;background:#64ffda0a;border-left-color:#64ffda}.exp-detail{padding-top:4px}.exp-role{color:#ccd6f6;margin-bottom:6px;font-size:18px;font-weight:700}.exp-company{color:#64ffda;font-weight:600}.exp-period{color:#8892b0;margin-bottom:18px;font-family:Inter,sans-serif;font-size:13px;display:block}.exp-desc{color:#8892b0;margin-bottom:18px;font-size:14px;line-height:1.75}.exp-tech{flex-wrap:wrap;gap:8px;padding:0;list-style:none;display:flex}.exp-tech li{color:#64ffda;background:#64ffda0f;border:1px solid #64ffda26;border-radius:12px;padding:3px 10px;font-size:12px;font-weight:500}@media (width<=768px){.exp-grid{grid-template-columns:1fr;gap:20px}.exp-tabs{border-bottom:2px solid #233554;border-left:none;flex-direction:row;gap:0;padding-bottom:0;overflow-x:auto}.exp-tab{white-space:nowrap;border-bottom:2px solid #0000;border-left:none;margin-bottom:-2px;margin-left:0;padding:10px 14px;font-size:12px}.exp-tab--active{border-bottom-color:#64ffda;border-left-color:#0000}}.projects-section{max-width:900px;margin:0 auto;padding:100px 0}.projects-list{flex-direction:column;gap:80px;margin-top:40px;display:flex}.project-item{grid-template-columns:repeat(12,1fr);align-items:center;gap:0;display:grid}.project-item--even .project-img-wrap{grid-area:1/1/auto/8}.project-item--even .project-info{text-align:right;grid-area:1/7/auto/-1}.project-item:not(.project-item--even) .project-img-wrap{grid-area:1/7/auto/-1}.project-item:not(.project-item--even) .project-info{text-align:left;grid-area:1/1/auto/8}.project-img-wrap{z-index:1;border-radius:4px;position:relative;overflow:hidden}.project-item:nth-child(2) .project-img-wrap{justify-self:end;max-width:260px}.project-img{object-fit:cover;width:100%;height:100%;transition:filter .3s;display:block}.project-img-placeholder{aspect-ratio:16/9;color:#64ffda;background:linear-gradient(135deg,#112240,#233554);border-radius:4px;justify-content:center;align-items:center;width:100%;font-size:32px;font-weight:800;display:flex}.project-img-overlay{z-index:2;background:#64ffda26;border-radius:4px;transition:background-color .3s;position:absolute;inset:0}.project-item:hover .project-img-overlay{background-color:#0000}.project-info{z-index:3;padding:20px;position:relative}.project-overline{color:#64ffda;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:8px;font-family:Inter,sans-serif;font-size:11px;font-weight:600;display:block}.project-title{color:#ccd6f6;align-items:center;gap:10px;margin-bottom:6px;font-size:22px;font-weight:700;line-height:1.3;display:flex}.project-logo{object-fit:cover;border-radius:6px;flex-shrink:0;width:32px;height:32px}.project-title-text{color:#ccd6f6}.project-subtitle{color:#8892b0;margin-bottom:14px;font-family:Inter,sans-serif;font-size:13px}.project-desc-box{background:#112240;border-radius:4px;margin-bottom:16px;padding:18px 20px;box-shadow:0 10px 30px -15px #020c1bb3}.project-desc-box p{color:#8892b0;margin:0;font-size:13px;line-height:1.7}.project-tech{flex-wrap:wrap;gap:6px;margin-bottom:12px;padding:0;list-style:none;display:flex}.project-item--even .project-tech,.project-item--even .project-status,.project-item--even .project-links,.project-item--even .project-soon-hint{justify-content:flex-end}.project-tech li{color:#8892b0;font-family:Inter,sans-serif;font-size:11px}.project-tech li+li:before{content:" · ";color:#64ffda;margin:0 4px}.project-links{flex-wrap:wrap;gap:8px;margin-bottom:10px;display:flex}.project-link{border:1px solid #0000;border-radius:4px;align-items:center;gap:6px;padding:8px 16px;font-size:12px;font-weight:500;text-decoration:none;transition:background .2s,color .2s;display:inline-flex}.project-link--web{color:#64ffda;background:#64ffda1a;border-color:#64ffda4d}.project-link--web:hover{background:#64ffda33}.project-link--ios{color:#64ffda;background:#64ffda1a;border-color:#64ffda4d}.project-link--ios:hover{background:#64ffda33}.project-link--android{color:#64ffda;background:#64ffda1a;border-color:#64ffda4d}.project-link--android:hover{background:#64ffda33}.project-status{border-radius:10px;padding:3px 10px;font-family:Inter,sans-serif;font-size:11px;font-weight:600;display:inline-block}.project-status--live{color:#64ffda;background:#64ffda1a;border:1px solid #64ffda4d}.project-status--dev{color:#ffab40;background:#ffab401a;border:1px solid #ffab404d}.project-status--plan{color:#8892b0;background:#8892b01a;border:1px solid #8892b04d}.project-soon-hint{color:#8892b0;opacity:.8;margin-top:8px;margin-bottom:0;font-size:11px}@media (width<=768px){.projects-list{gap:50px}.project-item,.project-item--even{flex-direction:column;gap:20px;display:flex}.project-item--even .project-img-wrap,.project-item:not(.project-item--even) .project-img-wrap{grid-area:auto}.project-item--even .project-info,.project-item:not(.project-item--even) .project-info{text-align:left;grid-area:auto;padding:0}.project-item--even .project-tech,.project-item--even .project-status,.project-item--even .project-links,.project-item--even .project-soon-hint{justify-content:flex-start}.project-desc-box{padding:14px 16px}}.carousel{width:100%}.carousel-viewport{background:#112240;border-radius:4px;position:relative;overflow:hidden}.carousel-slide{object-fit:cover;object-position:top;opacity:0;width:100%;height:100%;transition:opacity .35s;display:block;position:absolute;inset:0}.carousel-slide.active{opacity:1}.carousel-arrow{color:#64ffda;cursor:pointer;opacity:0;z-index:2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0a192fb3;border:1px solid #64ffda33;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:opacity .2s,background .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.carousel-viewport:hover .carousel-arrow{opacity:1}.carousel-arrow:hover{background:#64ffda26}.carousel-arrow--prev{left:10px}.carousel-arrow--next{right:10px}.carousel-dots{flex-wrap:wrap;justify-content:center;gap:8px;margin-top:10px;display:flex}.carousel-dot{cursor:pointer;opacity:.5;background:#112240;border:2px solid #0000;border-radius:3px;flex-shrink:0;width:44px;height:32px;padding:0;transition:opacity .2s,border-color .2s;overflow:hidden}.carousel-dot img{object-fit:cover;width:100%;height:100%;display:block}.carousel-dot:hover{opacity:.8}.carousel-dot.active{opacity:1;border-color:#64ffda}@media (width<=768px){.carousel-arrow{opacity:1;width:32px;height:32px}.carousel-dot{width:36px;height:26px}}.contact-section{text-align:center;max-width:700px;margin:0 auto;padding:120px 0 80px}.contact-overline{color:#64ffda;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:12px;font-family:Inter,sans-serif;font-size:11px;font-weight:600;display:block}.contact-title{color:#e6f1ff;margin-bottom:16px;font-size:clamp(28px,4vw,42px);font-weight:800;line-height:1.2}.contact-desc{color:#8892b0;margin-bottom:36px;font-size:15px;line-height:1.7}.contact-links{flex-wrap:wrap;justify-content:center;gap:14px;margin-bottom:32px;display:flex}.contact-btn{cursor:none;letter-spacing:.3px;border-radius:4px;align-items:center;gap:8px;padding:12px 28px;font-family:Inter,sans-serif;font-size:13px;font-weight:600;text-decoration:none;transition:background-color .2s,color .2s,box-shadow .2s;display:inline-flex}.contact-btn:not(.contact-btn--outline){color:#0a192f;background:#64ffda;border:none}.contact-btn:not(.contact-btn--outline):hover{box-shadow:0 0 20px #64ffda4d}.contact-btn--outline{color:#64ffda;background:0 0;border:1px solid #64ffda66}.contact-btn--outline:hover{background:#64ffda0f}.contact-info{color:#495670;justify-content:center;gap:12px;font-family:Inter,sans-serif;font-size:12px;display:flex}.contact-sep{color:#64ffda}@media (width<=768px){.contact-section{padding:80px 0 60px}.contact-links{flex-direction:column;align-items:center}.contact-info{flex-direction:column;gap:4px}.contact-sep{display:none}}.footer{border-top:1px solid var(--border);margin-top:40px;padding:40px 0 32px}.footer-inner{max-width:var(--max-width);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;width:100%;margin:0 auto;padding:0 24px;display:flex}.footer-left{color:var(--text-tertiary);flex-wrap:wrap;align-items:center;gap:10px;font-size:12px;display:flex}.footer-copy,.footer-sep{color:var(--text-tertiary)}.footer-link{color:var(--text-secondary);font-size:12px;transition:color .2s}.footer-link:hover{color:var(--accent)}.footer-right{color:var(--text-tertiary);flex-wrap:wrap;align-items:center;gap:10px;font-size:12px;display:flex}.footer-top{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:0;font-size:12px;transition:color .2s}.footer-top:hover{color:var(--accent)}@media (width<=640px){.footer-inner{flex-direction:column;align-items:flex-start;gap:12px}}:root{--bg-primary:#0a192f;--bg-secondary:#112240;--bg-tertiary:#1d2d50;--text-primary:#ccd6f6;--text-secondary:#8892b0;--text-tertiary:#495670;--accent:#64ffda;--accent-hover:#4cdbb8;--accent-dim:#64ffda14;--border:#64ffda14;--radius-sm:4px;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--max-width:1000px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);font-size:15px;line-height:1.65}a{color:var(--accent);text-decoration:none;transition:color .2s}a:hover{color:var(--accent-hover)}::selection{background:var(--accent-dim);color:var(--text-primary)}.app{flex-direction:column;min-height:100vh;display:flex}.main-content{max-width:var(--max-width);flex:1;width:100%;margin:0 auto;padding:0 24px}.section{padding:100px 0}[data-scroll-reveal]{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(30px)}[data-scroll-reveal].revealed{opacity:1;transform:translateY(0)}.section-header{align-items:center;gap:14px;margin-bottom:40px;display:flex;position:relative}.section-dot{background:var(--accent);border-radius:2px;flex-shrink:0;width:10px;height:10px}.section-title{color:var(--accent);letter-spacing:1.5px;text-transform:uppercase;font-size:11px;font-weight:600}.section-header:after{content:"";background:var(--border);flex:1;width:120px;height:1px;margin-left:14px;display:block}@media (width<=768px){.main-content{padding:0 16px}.section{padding:64px 0}.section-header{margin-bottom:28px}.section-header:after{width:60px}}
