@charset "UTF-8";@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes neonPulse{0%,to{opacity:1;filter:brightness(1)}50%{opacity:.8;filter:brightness(1.2)}}@keyframes glowPulse{0%,to{box-shadow:0 0 20px #00e5ff1a,0 0 40px #00e5ff0d}50%{box-shadow:0 0 30px #00e5ff33,0 0 60px #00e5ff1a}}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes glitchFlicker{0%{opacity:1}3%{opacity:0}6%{opacity:1}7%{opacity:0}10%{opacity:1}50%{opacity:1}52%{opacity:.8}53%{opacity:1}to{opacity:1}}@keyframes glitchShift{0%{transform:translate(0)}20%{transform:translate(-2px,2px)}40%{transform:translate(-2px,-2px)}60%{transform:translate(2px,2px)}80%{transform:translate(2px,-2px)}to{transform:translate(0)}}@keyframes scanlineMove{0%{transform:translateY(-100%)}to{transform:translateY(100vh)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes typewriter{0%{width:0}to{width:100%}}@keyframes blink{0%,50%{border-color:#00e5ff}51%,to{border-color:transparent}}@keyframes koreanFloat{0%,to{transform:translateY(0) rotate(0);opacity:.03}50%{transform:translateY(-15px) rotate(2deg);opacity:.06}}.anim-fade-in-up{animation:fadeInUp .6s ease forwards}.anim-fade-in{animation:fadeIn .4s ease forwards}.anim-delay-1{animation-delay:.1s;opacity:0;animation-fill-mode:forwards}.anim-delay-2{animation-delay:.2s;opacity:0;animation-fill-mode:forwards}.anim-delay-3{animation-delay:.3s;opacity:0;animation-fill-mode:forwards}.anim-delay-4{animation-delay:.4s;opacity:0;animation-fill-mode:forwards}.anim-delay-5{animation-delay:.5s;opacity:0;animation-fill-mode:forwards}.anim-delay-6{animation-delay:.6s;opacity:0;animation-fill-mode:forwards}.anim-delay-7{animation-delay:.7s;opacity:0;animation-fill-mode:forwards}.anim-delay-8{animation-delay:.8s;opacity:0;animation-fill-mode:forwards}.anim-delay-9{animation-delay:.9s;opacity:0;animation-fill-mode:forwards}.anim-delay-10{animation-delay:1s;opacity:0;animation-fill-mode:forwards}body{font-family:Noto Sans KR,Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:400;font-size:1rem;line-height:1.6;color:#e8e8f0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2;color:#e8e8f0}h1{font-size:2.25rem}h2{font-size:1.875rem}h3{font-size:1.5rem}h4{font-size:1.25rem}@media (min-width: 768px){h1{font-size:3rem}h2{font-size:2.25rem}h3{font-size:1.875rem}}a{color:#00e5ff;text-decoration:none;transition:color .15s ease}a:hover{color:#33ebff}a:focus-visible{outline:2px solid rgba(0,229,255,.6);outline-offset:2px}code{font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:.9em;background:#a855f71a;padding:.25rem .5rem;border-radius:.375rem}.section-title{font-size:1.875rem;font-weight:700;margin-bottom:.5rem;position:relative;display:inline-block}@media (min-width: 768px){.section-title{font-size:2.25rem}}.section-title:after{content:"";position:absolute;bottom:-4px;left:0;width:60px;height:3px;background:linear-gradient(90deg,#00e5ff,#ff00e5);border-radius:2px}.section-subtitle{color:#9898b0;font-size:1.125rem;margin-bottom:2.5rem}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:#0a0a0f;min-height:100vh;overflow-x:hidden}#root{min-height:100vh;display:flex;flex-direction:column}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1.5rem}@media (min-width: 1024px){.container{padding:0 2rem}}.container{position:relative;z-index:1}.main-content{flex:1;padding-top:72px}.section{padding:2.5rem 0}@media (min-width: 768px){.section{padding:3rem 0}}.section{position:relative}.section-header{margin-bottom:2rem;text-align:center}.grid-2{display:grid;gap:1.5rem;grid-template-columns:1fr}@media (min-width: 768px){.grid-2{grid-template-columns:repeat(2,1fr)}}.grid-3{display:grid;gap:1.5rem;grid-template-columns:1fr}@media (min-width: 768px){.grid-3{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.grid-3{grid-template-columns:repeat(3,1fr)}}.flex-center{display:flex;align-items:center;justify-content:center}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.navbar{position:fixed;top:0;left:0;right:0;z-index:100;height:72px;background:#16161fcc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.06)}.navbar__inner{width:100%;max-width:1200px;margin:0 auto;padding:0 1.5rem}@media (min-width: 1024px){.navbar__inner{padding:0 2rem}}.navbar__inner{height:100%;display:flex;align-items:center;justify-content:space-between}.navbar__logo{font-size:1.25rem;font-weight:700;color:#e8e8f0;text-decoration:none;letter-spacing:-.5px}.navbar__logo:focus-visible{outline:2px solid rgba(0,229,255,.6);outline-offset:2px}.navbar__logo span{color:#00e5ff;text-shadow:0 0 10px rgba(0,229,255,.3),0 0 20px rgba(0,229,255,.12),0 0 40px rgba(0,229,255,.06)}.navbar__links{display:none;list-style:none;gap:.25rem;align-items:center}@media (min-width: 768px){.navbar__links{display:flex}}.navbar__link{display:inline-flex;align-items:center;padding:.5rem 1rem;border-radius:.5rem;color:#9898b0;text-decoration:none;font-size:.875rem;font-weight:500;line-height:1;transition:all .15s ease}.navbar__link:focus-visible{outline:2px solid rgba(0,229,255,.6);outline-offset:2px}.navbar__link:hover{color:#e8e8f0;background:#00e5ff0f}.navbar__link--active{color:#00e5ff;background:#00e5ff14}.navbar__link--cv{gap:.25rem}.navbar__link svg{display:block}.navbar__hamburger{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:none;border:1px solid rgba(255,255,255,.06);border-radius:.5rem;color:#e8e8f0;cursor:pointer;transition:all .15s ease}.navbar__hamburger:focus-visible{outline:2px solid rgba(0,229,255,.6);outline-offset:2px}@media (min-width: 768px){.navbar__hamburger{display:none}}.navbar__hamburger:hover{border-color:#00e5ff4d;color:#00e5ff}.mobile-drawer__overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:200;animation:fadeIn .2s ease}.mobile-drawer__panel{position:fixed;top:0;right:0;bottom:0;width:300px;max-width:85vw;background:#111119;border-left:1px solid rgba(255,255,255,.06);z-index:201;padding:2rem 1.5rem;animation:slideInRight .3s ease;overflow-y:auto}.mobile-drawer__close{position:absolute;top:1rem;right:1rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid rgba(255,255,255,.06);border-radius:.5rem;color:#9898b0;cursor:pointer}.mobile-drawer__close:focus-visible{outline:2px solid rgba(0,229,255,.6);outline-offset:2px}.mobile-drawer__close:hover{color:#e8e8f0;border-color:#00e5ff4d}.mobile-drawer__links{list-style:none;margin-top:2.5rem;display:flex;flex-direction:column;gap:.5rem}.mobile-drawer__link{display:block;padding:.75rem 1rem;border-radius:.5rem;color:#9898b0;text-decoration:none;font-size:1.125rem;font-weight:500;transition:all .15s ease}.mobile-drawer__link:focus-visible{outline:2px solid rgba(0,229,255,.6);outline-offset:2px}.mobile-drawer__link:hover{color:#e8e8f0;background:#00e5ff0f}.mobile-drawer__link--active{color:#00e5ff;background:#00e5ff14}.mobile-drawer__cv-btn{display:flex;align-items:center;gap:.75rem;margin-top:1.5rem;padding:1rem;border-radius:.75rem;text-decoration:none;background:#00e5ff0f;border:1px solid rgba(0,229,255,.2);color:#00e5ff;transition:all .25s ease;position:relative;overflow:hidden}.mobile-drawer__cv-btn:focus-visible{outline:2px solid rgba(0,229,255,.6);outline-offset:2px}.mobile-drawer__cv-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#00e5ff14,#ff00e50f);opacity:0;transition:opacity .25s ease}.mobile-drawer__cv-btn:hover{border-color:#00e5ff;box-shadow:0 0 20px #00e5ff26,0 0 40px #00e5ff0b}.mobile-drawer__cv-btn:hover:before{opacity:1}.mobile-drawer__cv-btn svg{flex-shrink:0;position:relative;z-index:1}.mobile-drawer__cv-label{font-size:.75rem;font-weight:700;letter-spacing:2px;opacity:.5;position:relative;z-index:1}.mobile-drawer__cv-text{font-size:1.125rem;font-weight:600;position:relative;z-index:1;margin-left:auto}.mobile-drawer__decor{margin-top:2.5rem;text-align:center;color:#5a5a72;font-size:1.5rem;opacity:.15;letter-spacing:4px}.navbar{width:100vw!important}.navbar__inner{width:100%;max-width:100%;min-width:0;padding-left:1rem;padding-right:1rem}.hero{position:relative;min-height:auto;display:flex;align-items:center}.hero__bg{position:absolute;top:-20%;right:-10%;bottom:-60%;left:-10%;z-index:0;pointer-events:none}.hero__bg:before{content:"";position:absolute;top:0;left:0;width:800px;height:800px;background:radial-gradient(circle,rgba(0,229,255,.07) 0%,transparent 60%);border-radius:50%;animation:float 8s ease-in-out infinite}.hero__bg:after{content:"";position:absolute;bottom:0;right:0;width:700px;height:700px;background:radial-gradient(circle,rgba(255,0,229,.05) 0%,transparent 60%);border-radius:50%;animation:float 10s ease-in-out infinite reverse}.hero__content{width:100%;max-width:1200px;margin:0 auto;padding:0 1.5rem}@media (min-width: 1024px){.hero__content{padding:0 2rem}}.hero__content{position:relative;z-index:2;padding-top:2.5rem;padding-bottom:2rem}.hero__row{display:flex;flex-direction:column;gap:2rem}@media (min-width: 768px){.hero__row{flex-direction:row;align-items:center;justify-content:space-between;gap:2.5rem}}.hero__text{flex:1;min-width:0}.hero__avatar{display:flex;justify-content:center;flex-shrink:0;animation:fadeIn .8s ease .3s forwards;opacity:0}@media (min-width: 768px){.hero__avatar{justify-content:flex-end}}.hero__avatar-img{width:180px;height:180px;border-radius:50%;object-fit:cover;border:3px solid rgba(0,229,255,.3);box-shadow:0 0 30px #00e5ff26,0 0 60px #00e5ff0d}@media (min-width: 640px){.hero__avatar-img{width:220px;height:220px}}@media (min-width: 768px){.hero__avatar-img{width:260px;height:260px}}.hero__pretitle{font-size:.875rem;font-weight:500;color:#00e5ff;text-transform:uppercase;letter-spacing:3px;margin-bottom:1rem;animation:fadeInUp .6s ease forwards}.hero__name{font-size:1.875rem;font-weight:700;line-height:1.1;margin-bottom:.75rem;word-break:break-word}@media (min-width: 640px){.hero__name{font-size:3rem}}.hero__name{animation:fadeInUp .6s ease .1s forwards;opacity:0}@media (min-width: 768px){.hero__name{font-size:3.75rem}}.hero__name .neon-accent{background:linear-gradient(135deg,#00e5ff,#ff00e5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero__title{font-size:1rem;font-weight:500;color:#9898b0;margin-bottom:.5rem}@media (min-width: 640px){.hero__title{font-size:1.25rem;margin-bottom:.75rem}}.hero__title{animation:fadeInUp .6s ease .2s forwards;opacity:0}@media (min-width: 768px){.hero__title{font-size:1.5rem}}.hero__tagline{font-size:1.125rem;color:#5a5a72;max-width:600px;margin-bottom:1.5rem;animation:fadeInUp .6s ease .3s forwards;opacity:0}.hero__cta{display:flex;gap:1rem;animation:fadeInUp .6s ease .4s forwards;opacity:0;flex-wrap:wrap}.hero__korean-float{position:absolute;z-index:1;font-size:3rem;font-weight:700;color:#e8e8f0;opacity:.03;-webkit-user-select:none;user-select:none;pointer-events:none;display:none}@media (min-width: 640px){.hero__korean-float{display:block;font-size:6rem}}.hero__korean-float--1{top:15%;right:10%;animation:koreanFloat 12s ease-in-out infinite}.hero__korean-float--2{bottom:20%;right:25%;font-size:4rem;animation:koreanFloat 15s ease-in-out infinite 3s}.hero__korean-float--3{top:40%;left:60%;font-size:3rem;animation:koreanFloat 10s ease-in-out infinite 6s}@media (min-width: 768px){.hero__korean-float--3{left:70%}}.project-card{background:#16161f;border:1px solid rgba(255,255,255,.06);border-radius:.75rem;padding:1.5rem;transition:all .25s ease}.project-card:hover{background:#1c1c28;border-color:#00e5ff26;box-shadow:0 0 20px #00e5ff14,0 0 40px #00e5ff06;transform:translateY(-2px)}.project-card{display:flex;flex-direction:column;gap:1rem;cursor:pointer}.project-card:focus-visible{outline:2px solid rgba(0,229,255,.6);outline-offset:2px}.project-card:hover{border-color:#00e5ff33}.project-card__name{font-size:1.25rem;font-weight:600;color:#e8e8f0}.project-card__desc{color:#9898b0;font-size:.875rem;line-height:1.6;flex:1}.project-card__stack{display:flex;flex-wrap:wrap;gap:.5rem}.project-card__tags{display:flex;flex-wrap:wrap;gap:.25rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.06)}.project-card__more{display:inline-flex;align-items:center;gap:.25rem;margin-top:auto;margin-left:auto;color:#00e5ff;font-size:.875rem;font-weight:500;transition:all .15s ease}.project-card:hover .project-card__more{color:#33ebff;gap:.5rem}.badge{display:inline-flex;align-items:center;padding:.25rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:500;line-height:1;border:1px solid transparent}.badge--tech{background:#a855f71a;color:#a855f7;border-color:#a855f726}.badge--tag{background:#00e5ff14;color:#00e5ffcc;border-color:#00e5ff1a;font-size:.65rem;text-transform:uppercase;letter-spacing:.5px}.experience-card{background:#16161f;border:1px solid rgba(255,255,255,.06);border-radius:.75rem;padding:1.5rem;transition:all .25s ease}.experience-card:hover{background:#1c1c28;border-color:#00e5ff26;box-shadow:0 0 20px #00e5ff14,0 0 40px #00e5ff06;transform:translateY(-2px)}.experience-card{display:flex;gap:1rem;position:relative;cursor:pointer}.experience-card:focus-visible{outline:2px solid rgba(0,229,255,.6);outline-offset:2px}.experience-card:hover{border-color:#00e5ff33}.experience-card__timeline{display:none;flex-direction:column;align-items:center;padding-top:.25rem}@media (min-width: 768px){.experience-card__timeline{display:flex}}.experience-card__dot{width:12px;height:12px;border-radius:50%;background:#00e5ff;box-shadow:0 0 10px #00e5ff66;flex-shrink:0}.experience-card__line{width:2px;flex:1;background:linear-gradient(to bottom,rgba(0,229,255,.3),transparent);margin-top:.5rem}.experience-card__body{flex:1;display:flex;flex-direction:column}.experience-card__header{margin-bottom:.75rem}.experience-card__role{font-size:1.125rem;font-weight:600;color:#e8e8f0}@media (min-width: 640px){.experience-card__role{font-size:1.25rem}}.experience-card__meta{display:flex;flex-wrap:wrap;gap:.25rem .5rem;align-items:center;margin-top:.25rem;font-size:.875rem;color:#9898b0}.experience-card__company{color:#00e5ff;font-weight:500}.experience-card__location,.experience-card__dates{color:#5a5a72;font-size:.75rem}@media (min-width: 640px){.experience-card__location,.experience-card__dates{font-size:.875rem}}.experience-card__dot-sep{width:3px;height:3px;border-radius:50%;background:#5a5a72}@media (max-width: 640px){.experience-card__dot-sep{display:none}}.experience-card__summary{color:#9898b0;font-size:.875rem;margin-bottom:.75rem}.experience-card__bullets{list-style:none;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.experience-card__bullets li{font-size:.875rem;color:#9898b0;padding-left:1.25rem;position:relative;line-height:1.5}.experience-card__bullets li:before{content:"›";position:absolute;left:.25rem;color:#ff00e5;font-weight:700}.experience-card__stack{display:flex;flex-wrap:wrap;gap:.5rem}.experience-card__more{display:inline-flex;align-items:center;gap:.25rem;margin-top:1rem;margin-left:auto;color:#00e5ff;font-size:.875rem;font-weight:500;transition:all .15s ease}.experience-card:hover .experience-card__more{color:#33ebff;gap:.5rem}.skill-card{background:#16161f;border:1px solid rgba(255,255,255,.06);border-radius:.75rem;padding:1.5rem;transition:all .25s ease}.skill-card:hover{background:#1c1c28;border-color:#00e5ff26;box-shadow:0 0 20px #00e5ff14,0 0 40px #00e5ff06;transform:translateY(-2px)}.skill-card__title{font-size:1.125rem;font-weight:600;margin-bottom:1rem;color:#e8e8f0;display:flex;align-items:center;gap:.5rem}.skill-card__title:before{content:"";width:4px;height:20px;background:linear-gradient(to bottom,#00e5ff,#ff00e5);border-radius:2px}.skill-card__items{display:flex;flex-wrap:wrap;gap:.5rem}.skill-card__item{display:inline-flex;align-items:center;padding:.5rem .75rem;background:#00e5ff0d;border:1px solid rgba(0,229,255,.1);border-radius:.5rem;font-size:.875rem;color:#9898b0;transition:all .15s ease}.skill-card__item:hover{color:#00e5ff;border-color:#00e5ff40;background:#00e5ff14}.contact-section__grid{display:grid;gap:1rem;grid-template-columns:1fr}@media (min-width: 640px){.contact-section__grid{grid-template-columns:repeat(2,1fr)}}.contact-card{background:#16161f;border:1px solid rgba(255,255,255,.06);border-radius:.75rem;padding:1.5rem;transition:all .25s ease}.contact-card:hover{background:#1c1c28;border-color:#00e5ff26;box-shadow:0 0 20px #00e5ff14,0 0 40px #00e5ff06;transform:translateY(-2px)}.contact-card{display:flex;align-items:center;gap:.75rem;text-decoration:none;min-width:0}@media (min-width: 640px){.contact-card{gap:1rem}}.contact-card__icon{width:40px;height:40px}@media (min-width: 640px){.contact-card__icon{width:48px;height:48px}}.contact-card__icon{display:flex;align-items:center;justify-content:center;border-radius:.75rem;background:#00e5ff14;color:#00e5ff;flex-shrink:0;transition:all .25s ease}.contact-card:hover .contact-card__icon{background:#00e5ff26;box-shadow:0 0 20px #00e5ff1f,0 0 40px #00e5ff09}.contact-card__info{min-width:0}.contact-card__label{font-size:.75rem;color:#5a5a72;text-transform:uppercase;letter-spacing:1px;margin-bottom:.25rem}.contact-card__value{font-size:.875rem;color:#e8e8f0;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.section--about{margin-top:2rem}@media (min-width: 768px){.section--about{margin-top:3rem}}.about-section__content{max-width:800px;margin:0 auto;text-align:center}.about-section__text{font-size:1.125rem;color:#9898b0;line-height:1.8}@media (min-width: 768px){.about-section__text{font-size:1.25rem}}.about-section__divider{width:80px;height:2px;background:linear-gradient(90deg,transparent,#00e5ff,transparent);margin:2rem auto;border:none}.korean-decor{position:absolute;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:0}.korean-decor__char{position:absolute;font-weight:700;color:#e8e8f0;opacity:.03;line-height:1;animation:koreanFloat 15s ease-in-out infinite}.korean-decor__char:nth-child(2){animation-delay:3s}.korean-decor__char:nth-child(3){animation-delay:6s}.korean-decor__char:nth-child(4){animation-delay:9s}.section--korean-bg{position:relative;overflow:hidden}.korean-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:0}.korean-bg__char{position:absolute;font-size:5rem;font-weight:700;color:#e8e8f0;opacity:.03;line-height:1}@media (min-width: 640px){.korean-bg__char{font-size:7rem}}@media (min-width: 768px){.korean-bg__char{font-size:9rem}}.korean-bg__char--1{top:10%;right:5%;animation:koreanFloat 12s ease-in-out infinite}.korean-bg__char--2{bottom:10%;left:5%;animation:koreanFloat 15s ease-in-out infinite 4s}.notfound{position:relative;min-height:calc(100vh - 72px);display:flex;align-items:center;justify-content:center;overflow:hidden}.notfound__bg{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#0a0a0f,#ff00e508,#0a0a0f,#00e5ff08,#0a0a0f);background-size:400% 400%;animation:gradientShift 15s ease infinite;z-index:0}.notfound__bg:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,0,0,.08) 3px,rgba(0,0,0,.08) 6px);pointer-events:none}.notfound__scanline{position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,transparent,rgba(0,229,255,.15),transparent);animation:scanlineMove 6s linear infinite;z-index:1;pointer-events:none}.notfound__content{position:relative;z-index:2;text-align:center;padding:2rem}.notfound__code{font-size:5rem;font-weight:700;line-height:1;margin-bottom:1rem;position:relative;display:inline-block}@media (min-width: 640px){.notfound__code{font-size:8rem}}@media (min-width: 768px){.notfound__code{font-size:12rem}}.notfound__code{background:linear-gradient(135deg,#00e5ff,#ff00e5,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:neonPulse 3s ease-in-out infinite}.notfound__code:before,.notfound__code:after{content:"404";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#00e5ff,#ff00e5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.notfound__code:before{animation:glitchShift 3s infinite;clip-path:polygon(0 0,100% 0,100% 33%,0 33%);opacity:.8}.notfound__code:after{animation:glitchShift 3s infinite reverse;clip-path:polygon(0 66%,100% 66%,100% 100%,0 100%);opacity:.8}.notfound__text{font-size:1.25rem;color:#9898b0;margin-bottom:.5rem}@media (min-width: 768px){.notfound__text{font-size:1.5rem}}.notfound__subtext{font-size:1rem;color:#5a5a72;margin-bottom:2rem}.notfound__korean{font-size:1.875rem;color:#5a5a72;opacity:.08;margin-bottom:2rem;letter-spacing:8px;-webkit-user-select:none;user-select:none}@media (min-width: 768px){.notfound__korean{font-size:3rem}}.notfound__btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 2rem;background:transparent;color:#00e5ff;border:1px solid rgba(0,229,255,.4);border-radius:.5rem;font-size:1rem;font-weight:500;text-decoration:none;cursor:pointer;transition:all .25s ease}.notfound__btn:focus-visible{outline:2px solid rgba(0,229,255,.6);outline-offset:2px}.notfound__btn:hover{background:#00e5ff14;border-color:#00e5ff;box-shadow:0 0 20px #00e5ff26,0 0 40px #00e5ff0b;color:#00e5ff}.notfound__float{position:absolute;font-weight:700;color:#e8e8f0;opacity:.02;-webkit-user-select:none;user-select:none;pointer-events:none;animation:koreanFloat 12s ease-in-out infinite}.notfound__float--1{top:10%;left:10%;font-size:5rem;animation-delay:0s}.notfound__float--2{top:60%;right:15%;font-size:4rem;animation-delay:4s}.notfound__float--3{bottom:15%;left:20%;font-size:6rem;animation-delay:2s}.notfound__float--4{top:25%;right:30%;font-size:3rem;animation-delay:6s}.notfound__glow{position:absolute;border-radius:50%;pointer-events:none;filter:blur(60px);animation:glowPulse 5s ease-in-out infinite}.notfound__glow--1{top:20%;left:20%;width:200px;height:200px;background:#00e5ff0d}.notfound__glow--2{bottom:20%;right:20%;width:250px;height:250px;background:#ff00e50a;animation-delay:2.5s}.admin-login{min-height:calc(100vh - 72px);display:flex;align-items:center;justify-content:center;padding:1.5rem}.admin-login__card{background:#16161f;border:1px solid rgba(255,255,255,.06);border-radius:.75rem;padding:1.5rem;transition:all .25s ease}.admin-login__card:hover{background:#1c1c28;border-color:#00e5ff26;box-shadow:0 0 20px #00e5ff14,0 0 40px #00e5ff06;transform:translateY(-2px)}.admin-login__card{width:100%;max-width:420px;padding:2rem;text-align:center}.admin-login__card:hover{transform:none}.admin-login__title{font-size:1.5rem;font-weight:700;margin-bottom:.5rem;color:#e8e8f0}.admin-login__subtitle{font-size:.875rem;color:#5a5a72;margin-bottom:2rem}.admin-login__form{display:flex;flex-direction:column;gap:1rem}.admin-login__input{width:100%;padding:.75rem 1rem;background:#0a0a0f;border:1px solid rgba(255,255,255,.06);border-radius:.5rem;color:#e8e8f0;font-size:1rem;font-family:Noto Sans KR,Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;transition:border-color .15s ease}.admin-login__input:focus-visible{outline:2px solid rgba(0,229,255,.6);outline-offset:2px}.admin-login__input::placeholder{color:#5a5a72}.admin-login__input:focus{border-color:#00e5ff66}.admin-login__error{font-size:.875rem;color:#ef4444;text-align:left}.admin-dashboard{width:100%;max-width:1200px;margin:0 auto;padding:0 1.5rem}@media (min-width: 1024px){.admin-dashboard{padding:0 2rem}}.admin-dashboard{padding-top:2rem;padding-bottom:3rem}.admin-dashboard__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.admin-dashboard__title{font-size:1.5rem;font-weight:700;color:#e8e8f0}.admin-dashboard__controls{display:flex;gap:.5rem}.admin-dashboard__range-btn{padding:.5rem 1rem;background:transparent;border:1px solid rgba(255,255,255,.06);border-radius:.5rem;color:#9898b0;font-size:.875rem;font-family:Noto Sans KR,Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;cursor:pointer;transition:all .15s ease}.admin-dashboard__range-btn:focus-visible{outline:2px solid rgba(0,229,255,.6);outline-offset:2px}.admin-dashboard__range-btn:hover{border-color:#00e5ff4d;color:#e8e8f0}.admin-dashboard__range-btn--active{background:#00e5ff1a;border-color:#00e5ff4d;color:#00e5ff}.admin-dashboard__logout{padding:.5rem 1rem;background:transparent;border:1px solid rgba(239,68,68,.3);border-radius:.5rem;color:#ef4444;font-size:.875rem;font-family:Noto Sans KR,Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;cursor:pointer;transition:all .15s ease}.admin-dashboard__logout:focus-visible{outline:2px solid rgba(0,229,255,.6);outline-offset:2px}.admin-dashboard__logout:hover{background:#ef444414}.stats-grid{display:grid;gap:1rem;grid-template-columns:repeat(2,1fr);margin-bottom:2rem}@media (min-width: 768px){.stats-grid{grid-template-columns:repeat(4,1fr)}}.stat-card{background:#16161f;border:1px solid rgba(255,255,255,.06);border-radius:.75rem;padding:1.5rem;transition:all .25s ease}.stat-card:hover{background:#1c1c28;border-color:#00e5ff26;box-shadow:0 0 20px #00e5ff14,0 0 40px #00e5ff06;transform:translateY(-2px)}.stat-card{text-align:center;padding:1.25rem}.stat-card:hover{transform:none}.stat-card__value{font-size:1.875rem;font-weight:700;color:#00e5ff;text-shadow:0 0 10px rgba(0,229,255,.2),0 0 20px rgba(0,229,255,.08),0 0 40px rgba(0,229,255,.04)}.stat-card__label{font-size:.75rem;color:#5a5a72;text-transform:uppercase;letter-spacing:1px;margin-top:.25rem}.stats-section{margin-bottom:2rem}.stats-section__title{font-size:1.125rem;font-weight:600;color:#e8e8f0;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.stats-section__title:before{content:"";width:3px;height:16px;background:#ff00e5;border-radius:2px}.stats-list{background:#16161f;border:1px solid rgba(255,255,255,.06);border-radius:.75rem;padding:1.5rem;transition:all .25s ease}.stats-list:hover{background:#1c1c28;border-color:#00e5ff26;box-shadow:0 0 20px #00e5ff14,0 0 40px #00e5ff06;transform:translateY(-2px)}.stats-list{padding:0;overflow:hidden}.stats-list:hover{transform:none}.stats-list__item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.06)}.stats-list__item:last-child{border-bottom:none}.stats-list__name{font-size:.875rem;color:#9898b0;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:1rem}.stats-list__count{font-size:.875rem;font-weight:600;color:#00e5ff;flex-shrink:0}.timeline-chart{background:#16161f;border:1px solid rgba(255,255,255,.06);border-radius:.75rem;padding:1.5rem;transition:all .25s ease}.timeline-chart:hover{background:#1c1c28;border-color:#00e5ff26;box-shadow:0 0 20px #00e5ff14,0 0 40px #00e5ff06;transform:translateY(-2px)}.timeline-chart{padding:1.25rem}.timeline-chart:hover{transform:none}.timeline-chart__bars{display:flex;align-items:flex-end;gap:2px;height:120px;padding-top:1rem}.timeline-chart__bar{flex:1;background:linear-gradient(to top,#00e5ff4d,#00e5ff99);border-radius:2px 2px 0 0;min-height:4px;transition:all .25s ease;position:relative}.timeline-chart__bar--magenta{background:linear-gradient(to top,#ff00e54d,#ff00e599)}.timeline-chart__bar--magenta:hover{background:linear-gradient(to top,#ff00e580,#ff00e5)}.timeline-chart__bar:hover{background:linear-gradient(to top,#00e5ff80,#00e5ff)}.timeline-chart__bar:hover .timeline-chart__tooltip{opacity:1;visibility:visible}.timeline-chart__tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:.25rem .5rem;background:#16161f;border:1px solid rgba(255,255,255,.06);border-radius:.375rem;font-size:.75rem;color:#e8e8f0;white-space:nowrap;opacity:0;visibility:hidden;transition:all .15s ease;margin-bottom:.25rem}.timeline-chart__labels{display:flex;justify-content:space-between;margin-top:.5rem;font-size:.75rem;color:#5a5a72}.sessions-table{background:#16161f;border:1px solid rgba(255,255,255,.06);border-radius:.75rem;padding:1.5rem;transition:all .25s ease}.sessions-table:hover{background:#1c1c28;border-color:#00e5ff26;box-shadow:0 0 20px #00e5ff14,0 0 40px #00e5ff06;transform:translateY(-2px)}.sessions-table{padding:0;overflow-x:auto}.sessions-table:hover{transform:none}.sessions-table__header,.sessions-table__row{display:grid;grid-template-columns:110px 1fr 80px 90px 70px 1fr;gap:.5rem;padding:.75rem 1rem;align-items:center;min-width:600px}.sessions-table__header{background:#00e5ff0a;border-bottom:1px solid rgba(255,255,255,.06);font-size:.75rem;font-weight:600;color:#5a5a72;text-transform:uppercase;letter-spacing:.5px}.sessions-table__row{border-bottom:1px solid rgba(255,255,255,.06);font-size:.875rem}.sessions-table__row:last-child{border-bottom:none}.sessions-table__row:hover{background:#00e5ff05}.sessions-table__date{color:#5a5a72;font-size:.75rem}.sessions-table__ua{color:#9898b0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sessions-table__device{color:#a855f7;font-size:.75rem;font-weight:500}.sessions-table__pages{color:#9898b0;font-size:.75rem}.sessions-table__duration{color:#00e5ff;font-weight:500;font-size:.75rem}.sessions-table__entry{color:#5a5a72;font-size:.75rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sessions-table__row--expanded{background:#00e5ff08}.sessions-table__detail{padding:1rem 1.25rem;background:#00e5ff05;border-bottom:1px solid rgba(255,255,255,.06);min-width:600px}.sessions-table__detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem 1.5rem}@media (min-width: 768px){.sessions-table__detail-grid{grid-template-columns:repeat(4,1fr)}}.sessions-table__detail-grid>div{display:flex;flex-direction:column;gap:2px}.sessions-table__detail-grid>div strong{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:#5a5a72;font-weight:600}.sessions-table__detail-grid>div span{font-size:.75rem;color:#9898b0;word-break:break-all}.dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:300;animation:fadeIn .2s ease}.dialog-content{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:301;width:calc(100% - 2rem);max-width:640px;max-height:85vh;overflow-y:auto;background:#111119;border:1px solid rgba(255,255,255,.06);border-radius:1rem;padding:2rem;animation:modalAppear .2s ease}@media (min-width: 768px){.dialog-content{padding:2.5rem}}@keyframes modalAppear{0%{opacity:0;transform:translate(-50%,-50%) scale(.96)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.dialog-close{position:absolute;top:1rem;right:1rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid rgba(255,255,255,.06);border-radius:.5rem;color:#5a5a72;cursor:pointer;transition:all .15s ease}.dialog-close:focus-visible{outline:2px solid rgba(0,229,255,.6);outline-offset:2px}.dialog-close:hover{color:#e8e8f0;border-color:#00e5ff4d}.dialog-header{margin-bottom:1.5rem;padding-right:2rem}.dialog-title{font-size:1.25rem;font-weight:700;color:#e8e8f0;margin-bottom:.5rem}@media (min-width: 768px){.dialog-title{font-size:1.5rem}}.dialog-description{font-size:.875rem;color:#9898b0}.experience-modal__role{font-size:1.25rem}@media (min-width: 768px){.experience-modal__role{font-size:1.5rem}}.experience-modal__meta{font-size:.875rem;color:#9898b0}.experience-modal__company{color:#00e5ff;font-weight:500}.experience-modal__body{display:flex;flex-direction:column;gap:1.25rem}.experience-modal__summary{color:#9898b0;font-size:.875rem;line-height:1.6}.experience-modal__detailed{padding:1rem;background:#00e5ff08;border:1px solid rgba(0,229,255,.1);border-radius:.5rem;border-left:3px solid #00e5ff}.experience-modal__detailed p{color:#9898b0;font-size:.875rem;line-height:1.7}.experience-modal__section-title{font-size:.875rem;font-weight:600;color:#5a5a72;text-transform:uppercase;letter-spacing:1px}.experience-modal__bullets{list-style:none;display:flex;flex-direction:column;gap:.5rem}.experience-modal__bullets li{font-size:.875rem;color:#9898b0;padding-left:1.25rem;position:relative;line-height:1.5}.experience-modal__bullets li:before{content:"›";position:absolute;left:.25rem;color:#ff00e5;font-weight:700}.experience-modal__stack{display:flex;flex-wrap:wrap;gap:.5rem}.project-modal__name{font-size:1.25rem}@media (min-width: 768px){.project-modal__name{font-size:1.5rem}}.project-modal__desc{font-size:.875rem;color:#9898b0;line-height:1.6}.project-modal__body{display:flex;flex-direction:column;gap:1.25rem}.project-modal__detailed{padding:1rem;background:#ff00e508;border:1px solid rgba(255,0,229,.1);border-radius:.5rem;border-left:3px solid #ff00e5}.project-modal__detailed p{color:#9898b0;font-size:.875rem;line-height:1.7}.project-modal__section-title{font-size:.875rem;font-weight:600;color:#5a5a72;text-transform:uppercase;letter-spacing:1px}.project-modal__highlights{list-style:none;display:flex;flex-direction:column;gap:.5rem}.project-modal__highlights li{font-size:.875rem;color:#9898b0;padding-left:1.25rem;position:relative;line-height:1.5}.project-modal__highlights li:before{content:"▸";position:absolute;left:.25rem;color:#00e5ff;font-weight:700}.project-modal__stack{display:flex;flex-wrap:wrap;gap:.5rem}.project-modal__tags{display:flex;flex-wrap:wrap;gap:.25rem}.project-modal__links{display:flex;gap:.75rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.06)}.cv-preview{display:flex;flex-direction:column;height:calc(100vh - 72px)}.cv-preview__toolbar{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.06);background:#16161fcc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}@media (min-width: 768px){.cv-preview__toolbar{padding:.75rem 2rem}}.cv-preview__back{display:inline-flex;align-items:center;gap:.5rem;color:#9898b0;text-decoration:none;font-size:.875rem;font-weight:500;padding:.5rem .75rem;border-radius:.5rem;transition:all .15s ease}.cv-preview__back:focus-visible{outline:2px solid rgba(0,229,255,.6);outline-offset:2px}.cv-preview__back:hover{color:#00e5ff;background:#00e5ff0f}.cv-preview__viewer{margin:0 1vw;flex:1;background:#111119;overflow:hidden}.cv-preview__iframe{width:100%;height:100%;border:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:.5rem;font-size:.875rem;font-weight:500;font-family:Noto Sans KR,Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;cursor:pointer;transition:all .25s ease;text-decoration:none;border:1px solid transparent}.btn:focus-visible{outline:2px solid rgba(0,229,255,.6);outline-offset:2px}.btn--primary{background:#00e5ff1f;color:#00e5ff;border-color:#00e5ff4d}.btn--primary:hover{background:#00e5ff33;border-color:#00e5ff;box-shadow:0 0 20px #00e5ff1f,0 0 40px #00e5ff09}.btn--secondary{background:transparent;color:#9898b0;border-color:#ffffff0f}.btn--secondary:hover{color:#e8e8f0;border-color:#ff00e54d}.btn--ghost{background:transparent;color:#9898b0}.btn--ghost:hover{color:#e8e8f0;background:#ffffff0a}.page-enter{animation:fadeInUp .4s ease forwards}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#0a0a0f}::-webkit-scrollbar-thumb{background:#1a1a26;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#5a5a72}::selection{background:#00e5ff33;color:#e8e8f0}
