*{box-sizing:border-box;margin:0;padding:0}:root{--blue-deep:#020818;--blue-mid:#0a1f4e;--blue-accent:#1a4fd6;--blue-bright:#2d6fff;--blue-glow:#4d8fff;--blue-neon:#0af;--white:#f0f4ff;--white-muted:#89c;--mono:"Space Mono", monospace;--sans:"Syne", sans-serif}*{box-sizing:border-box;scroll-behavior:smooth;margin:0;padding:0}html,body{scrollbar-width:none;-ms-overflow-style:none}html::-webkit-scrollbar{display:none}body::-webkit-scrollbar{display:none}body{font-family:var(--sans);background-color:var(--blue-deep);color:var(--white);overflow-x:hidden}.app{min-height:100vh;position:relative;overflow-x:hidden}.app:before{content:"";background-color:var(--blue-deep);z-index:-2;background-image:linear-gradient(#2d6fff14 1px,#0000 1px),linear-gradient(90deg,#2d6fff14 1px,#0000 1px);background-size:80px 65px;position:fixed;inset:0}.app-content{z-index:1;min-height:100vh;position:relative}.orb{filter:blur(120px);opacity:.25;z-index:-1;border-radius:50%;position:fixed}.orb-1{background:#0a2fff;width:600px;height:600px;top:-200px;right:-100px}.orb-2{background:#029;width:400px;height:400px;bottom:10%;left:-100px}.orb-3{background:#004dff;width:300px;height:300px;top:50%;right:20%}.about{max-width:1300px;min-height:100vh;margin:0 auto;padding:0 60px 80px}.about-grid{grid-template-columns:1fr 1fr;align-items:center;gap:60px;display:grid}.about-text p{color:var(--white-muted);margin-bottom:20px;font-size:1rem;line-height:1.6}.about-text p strong{color:var(--white)}.about-highlights{flex-direction:column;gap:14px;display:flex}.highlight-item{background:#0a1f4e66;border:1px solid #2d6fff26;border-radius:10px;align-items:flex-start;gap:12px;padding:14px;transition:border-color .3s,background .3s;display:flex}.highlight-item:hover{background:#0a1f4eb3;border-color:#2d6fff66}.highlight-icon{background:#2d6fff26;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.1rem;display:flex}.highlight-text h4{margin-bottom:4px;font-size:.9rem;font-weight:700}.highlight-text p{font-family:var(--mono);color:var(--white-muted);font-size:.72rem;line-height:1.5}@media (width<=1024px){.about{min-height:auto;padding:0 32px 72px}.about-grid{gap:40px}}@media (width<=768px){.about{padding:0 20px 64px}.section-header{gap:12px;margin-bottom:28px}.section-line{max-width:56px}.section-title{margin-bottom:28px;font-size:clamp(1.8rem,8vw,2.5rem)}.about-grid{grid-template-columns:1fr;gap:32px}.about-text p{margin-bottom:18px;font-size:.96rem}.highlight-item{padding:16px}}@media (width<=480px){.about{padding:0 16px 56px}.section-header{align-items:center}.section-label{font-size:.72rem}.section-title{font-size:clamp(1.6rem,9vw,2.1rem);line-height:1.15}.about-grid{gap:24px}.highlight-item{gap:10px;padding:14px}.highlight-icon{width:36px;height:36px;font-size:1rem}.highlight-text h4{font-size:.85rem}.highlight-text p{font-size:.68rem}}._contact_n6306_1{text-align:center;max-width:1300px;margin:0 auto;padding:0 60px 80px}._section-contact_n6306_8{margin-bottom:20px}._section-label_n6306_12{text-transform:uppercase;font-family:var(--mono);color:var(--blue-glow)}._contact-card_n6306_18{background:#040f2acc;border:1px solid #2d6fff33;border-radius:20px;max-width:900px;margin:0 auto;padding:60px;position:relative;overflow:hidden}._contact-card_n6306_18:before{content:"";background:linear-gradient(90deg, transparent, var(--blue-accent), var(--blue-neon), transparent);height:2px;position:absolute;top:0;left:0;right:0}._contact-title_n6306_44{letter-spacing:-.02em;margin-bottom:16px;font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800}._contact-sub_n6306_50{color:var(--white-muted);margin-bottom:40px;font-size:.95rem;line-height:1.7}._social-links_n6306_56{flex-wrap:wrap;justify-content:center;gap:16px;display:flex}._social-link_n6306_56{color:var(--white);font-family:var(--mono);letter-spacing:.08em;background:#0a1f4e80;border:1px solid #2d6fff33;border-radius:8px;align-items:center;gap:8px;padding:12px 24px;font-size:.75rem;text-decoration:none;transition:all .25s;display:flex}._social-link_n6306_56:hover{border-color:var(--blue-neon);transform:translateY(-2px);box-shadow:0 0 20px #0af3}@media (width<=1024px){._contact_n6306_1{padding:0 32px 72px}._contact-card_n6306_18{padding:48px 40px}}@media (width<=768px){._contact_n6306_1{padding:0 20px 64px}._contact-card_n6306_18{border-radius:18px;padding:36px 24px}._contact-sub_n6306_50{margin-bottom:32px;font-size:.92rem}._social-links_n6306_56{gap:12px}._social-link_n6306_56{padding:12px 18px;font-size:.72rem}}@media (width<=480px){._contact_n6306_1{padding:0 16px 56px}._contact-card_n6306_18{border-radius:16px;padding:28px 16px}._section-label_n6306_12{font-size:.72rem}._contact-title_n6306_44{margin-bottom:12px;font-size:clamp(1.6rem,9vw,2.1rem)}._contact-sub_n6306_50{margin-bottom:24px;font-size:.88rem}._social-links_n6306_56{flex-direction:column;align-items:stretch}._social-link_n6306_56{justify-content:center;width:100%;padding:13px 16px;font-size:.7rem}}.cursor{pointer-events:none;z-index:9999;background:#0af;border-radius:50%;width:12px;height:12px;transition:transform .1s,opacity .2s;position:fixed;top:0;left:0;transform:translate(-50%,-50%)}.cursor-ring{pointer-events:none;z-index:9998;border:1px solid #0af6;border-radius:50%;width:36px;height:36px;transition:transform .18s;position:fixed;top:0;left:0;transform:translate(-50%,-50%)}@media (width>=1025px){body{cursor:none}}footer{z-index:2;border-top:1px solid #2d6fff14;justify-content:space-between;align-items:center;padding:30px 60px;display:flex;position:relative}footer p{font-family:var(--mono);color:#8899cca6;letter-spacing:.08em;font-size:.7rem}@media (width<=1024px){footer{padding:28px 32px}}@media (width<=768px){footer{flex-direction:column;align-items:flex-start;gap:10px;padding:24px 20px 32px}footer p{font-size:.68rem}}@media (width<=480px){footer{gap:8px;padding:22px 16px 28px}footer p{font-size:.64rem;line-height:1.5}}.header{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#01040db3;justify-content:space-between;align-items:center;padding:20px 40px;display:flex;position:fixed;top:0;left:0;right:0}.nav-logo{font-family:var(--mono);color:var(--blue-neon);letter-spacing:.1em;font-size:1rem}.nav-logo a{color:inherit;text-decoration:none}.nav-logo span{color:var(--white)}.nav-links{gap:30px;list-style:none;display:flex}.nav-links li a{font-family:var(--mono);color:var(--white-muted);text-transform:uppercase;transform:color .3s ease;font-size:.75rem;text-decoration:none;position:relative}.nav-links li a:after{content:"";background:var(--blue-neon);transform-origin:100%;width:0;height:2px;transition:width .3s;position:absolute;bottom:-5px;left:0;transform:scaleX(0)}.nav-links li a:hover:after{transform-origin:0;width:100%;transform:scaleX(1)}.nav-links li a:hover{color:var(--white)}.menu-toggle,.menu-overlay,.mobile-menu{display:none}@media (width<=1024px){.header{padding:18px 28px}.nav-links{gap:22px}}@media (width<=820px){.header{padding:18px 20px}.nav-links{display:none}.menu-toggle{cursor:pointer;background:#071129d9;border:1px solid #2d6fff33;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:48px;height:48px;transition:border-color .25s,transform .25s,background .25s;display:inline-flex}.menu-toggle:hover{border-color:#2d6fff80;transform:translateY(-1px)}.menu-toggle span{background:var(--white);border-radius:999px;width:18px;height:2px;transition:transform .25s,opacity .25s}.menu-toggle.is-open span:first-child{transform:translateY(7px)rotate(45deg)}.menu-toggle.is-open span:nth-child(2){opacity:0}.menu-toggle.is-open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.menu-overlay{opacity:0;pointer-events:none;background:#01040d8c;transition:opacity .25s;display:block;position:fixed;inset:0}.menu-overlay.is-visible{opacity:1;pointer-events:auto}.mobile-menu{background:linear-gradient(#091635fa,#020818fa);border-left:1px solid #2d6fff33;flex-direction:column;gap:28px;width:min(86vw,360px);height:100vh;padding:24px;transition:transform .3s;display:flex;position:fixed;top:0;right:0;transform:translate(100%);box-shadow:-20px 0 60px #00000059}.mobile-menu.is-open{transform:translate(0)}.mobile-menu__header{justify-content:space-between;align-items:center;display:flex}.mobile-menu__eyebrow{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--blue-neon);font-size:.7rem}.mobile-menu__close{width:40px;height:40px;color:var(--white);font-family:var(--mono);cursor:pointer;background:#ffffff08;border:1px solid #2d6fff33;border-radius:10px;font-size:1rem}.mobile-menu__logo{font-family:var(--mono);color:var(--blue-neon);letter-spacing:.1em;margin-bottom:16px;font-size:1rem;display:inline-block}.mobile-menu__logo span{color:var(--white)}.mobile-menu__title{color:var(--white);font-size:1.5rem;font-weight:800}.mobile-menu__subtitle{font-family:var(--mono);color:var(--blue-bright);text-transform:uppercase;letter-spacing:.08em;margin-top:8px;font-size:.8rem}.mobile-menu__description{color:var(--white-muted);margin-top:14px;font-size:.92rem;line-height:1.6}.mobile-menu__nav{flex-direction:column;gap:12px;display:flex}.mobile-menu__nav a{color:var(--white);font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;background:#ffffff05;border:1px solid #2d6fff1a;border-radius:14px;padding:14px 16px;font-size:.78rem;text-decoration:none;transition:border-color .25s,background .25s,transform .25s}.mobile-menu__nav a:hover{background:#0a1f4e73;border-color:#2d6fff66;transform:translate(4px)}}@media (width<=480px){.header{padding:16px}.nav-logo{font-size:.9rem}.mobile-menu{width:100vw;padding:20px 16px 24px}.mobile-menu__brand{padding:18px}.mobile-menu__title{font-size:1.3rem}.mobile-menu__description{font-size:.88rem}}.hero{flex-wrap:wrap;gap:80px;max-width:1300px;min-height:100vh;margin:0 auto;padding:140px 60px 80px;display:flex}.hero-content{flex:1}.hero-name{font-family:var(--sans);letter-spacing:-.03em;font-size:50px;font-weight:800;line-height:1;animation:.8s .2s both fadeUp}.line-1{display:block}.line-2{background:linear-gradient(135deg, var(--blue-bright), var(--blue-neon));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;display:block}.hero-role{color:var(--white-muted);margin-top:20px}.hero-role span{color:var(--blue-bright);font-weight:500}.hero-description{color:var(--white-muted);margin-top:30px;padding:0}.hero-cta{gap:16px;margin-top:44px;animation:.8s .4s both fadeUp;display:flex}.btn-primary{background:var(--blue-accent);color:var(--white);font-size:.8rem;font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;cursor:none;border:none;border-radius:6px;padding:12px 24px;text-decoration:none;transition:background .2s,transform .2s,box-shadow .2s;box-shadow:0 0 30px #1a4fd666}.btn-primary:hover{background-color:var(--blue-bright);color:var(--white);transform:translate(-2px,-2px)}.btn-secondary{color:var(--white);font-size:.8rem;font-family:var(--mono);border:1px solid var(--blue-bright);letter-spacing:.1em;text-transform:uppercase;cursor:none;border-radius:6px;padding:12px 24px;text-decoration:none;transition:background .2s,transform .2s,box-shadow .2s;box-shadow:0 0 30px #1a4fd666}.btn-secondary:hover{border-color:var(--blue-neon);color:var(--white);transform:translate(-2px,-2px)}.hero-photo-frame{width:280px;height:360px;position:relative}.hero-photo-frame:before{content:"";z-index:-1;background:linear-gradient(135deg,#1a4fd6,#0af,#0000 60%);border-radius:14px;position:absolute;inset:-2px}.photo-placeholder{border:1px solid #2d6fff26;border-radius:12px;width:100%;height:100%;overflow:hidden}.hero-photo-wrap{z-index:0;flex:0 280px;position:relative}.hero-photo-frame{z-index:0;width:280px;height:360px;position:relative}.hero-photo-frame:before{content:"";z-index:2;pointer-events:none;background:linear-gradient(135deg,#1a4fd6,#0af3,#0000 50%);border-radius:14px;position:absolute;inset:-2px}.hero-photo-frame:after{content:"";z-index:-1;border:1px solid #2d6fff4d;border-radius:14px;position:absolute;inset:16px -16px -16px 16px}.photo-placeholder{z-index:1;border-radius:12px;width:100%;height:100%;position:relative;overflow:hidden}.hero-photo{object-fit:cover;object-position:top;border-radius:12px;width:100%;height:100%;display:block}.hero-stats{background:#040f2a;border:1px solid #2d6fff4d;border-radius:12px;gap:24px;padding:12px 22px;display:flex;position:absolute;bottom:-28px;left:-28px}.stat{text-align:center}.stat-number{font-family:var(--mono);color:var(--blue-neon);font-size:1.2rem;font-weight:700}.stat-label{color:var(--white-muted);text-transform:uppercase;margin-top:2px;font-size:.55rem;left:.08em}.scroll-hint{flex-direction:column;align-items:center;gap:8px;width:100%;margin-top:-110px;display:flex}.scroll-hint span{font-family:var(--mono);color:var(--white-muted);letter-spacing:.15em;text-transform:uppercase;font-size:.65rem}.scroll-line{background:linear-gradient(to bottom, var(--blue-neon), transparent);width:1px;height:48px;animation:2s infinite AnimationScrollLine}@keyframes AnimationScrollLine{0%{transform-origin:top;transform:scaleY(0)}50%{transform-origin:top;transform:scaleY(1)}51%{transform-origin:bottom;transform:scaleY(1)}to{transform-origin:bottom;transform:scaleY(0)}}@media (width<=1024px){.hero{gap:56px;padding:130px 32px 72px}.hero-name{font-size:44px}}@media (width<=768px){.hero{text-align:center;flex-direction:column;align-items:center;gap:40px;padding:116px 20px 64px}.hero-photo-wrap{flex-direction:column;flex:none;order:-1;align-items:center;width:100%;display:flex}.hero-photo-frame{aspect-ratio:14/18;width:min(280px,78vw);height:auto}.hero-content{width:100%;max-width:640px}.hero-name{font-size:40px}.hero-role,.hero-description{margin-left:auto;margin-right:auto}.hero-description{max-width:34rem}.hero-cta{flex-wrap:wrap;justify-content:center}.hero-stats{flex-wrap:wrap;justify-content:center;margin-top:18px;position:static}.scroll-hint{margin-top:0}}@media (width<=480px){.hero{gap:32px;padding:104px 16px 56px}.hero-name{font-size:34px}.hero-role{margin-top:16px}.hero-description{margin-top:22px;font-size:.95rem}.hero-cta{flex-direction:column;width:100%;margin-top:32px}.btn-primary,.btn-secondary{text-align:center;width:100%}.hero-photo-frame{width:min(250px,82vw)}.hero-stats{gap:14px;width:100%;padding:12px 16px}.stat{flex:30%}}.card{width:250px;font-family:var(--mono);text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0a1f4e4d;border:1px solid #4d8fff2e;border-radius:18px;margin:0;padding:14px}.card a{color:inherit;text-decoration:none}.card-title{color:var(--white);margin-bottom:10px;font-size:20px}.card-img{aspect-ratio:1;border-radius:12px;width:100%;display:block}.card-description{color:var(--white-muted);margin-top:10px;font-size:.88rem;line-height:1.5}.card-subtitle-container{flex-wrap:wrap;justify-content:center;align-items:center;gap:6px;margin-top:10px;display:flex}.card-subtitle{text-transform:uppercase;color:var(--white);letter-spacing:.04em;background:#2d6fff2e;border:1px solid #f0f4ff1f;border-radius:999px;padding:5px 10px;font-size:.7rem;font-weight:700}@media (width<=768px){.card{border-radius:16px;width:220px;padding:12px}.card-title{font-size:18px}.card-description{font-size:.82rem}}@media (width<=480px){.card{border-radius:14px;width:190px;padding:10px}.card-img{border-radius:10px}.card-title{margin-bottom:8px;font-size:16px}.card-subtitle-container{gap:5px;margin-top:8px}.card-subtitle{padding:4px 8px;font-size:.62rem}.card-description{margin-top:8px;font-size:.78rem;line-height:1.4}}.project{max-width:1300px;min-height:100vh;margin:0 auto;padding:0 60px 80px}.section-title{text-transform:uppercase;font-size:clamp(2rem,2vw,3.2rem);font-weight:800;line-height:1.1;font-family:var(--sans);color:var(--white)}.project p{max-width:640px;color:var(--white-muted);line-height:1.7}.project-grid{background:#0a1f4e33;border:1px dashed #2d6fff33;border-radius:18px;grid-template-columns:repeat(4,minmax(0,1fr));place-items:start center;gap:12px;min-height:220px;margin-top:40px;padding:28px;display:grid}@media (width<=1024px){.project{min-height:auto;padding:0 32px 72px}.project-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=768px){.project{padding:0 20px 64px}.section-header{gap:12px;margin-bottom:28px}.section-line{max-width:56px}.section-title{margin-bottom:20px;font-size:clamp(1.8rem,8vw,2.5rem)}.project p{font-size:.95rem}.project-grid{border-radius:16px;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;min-height:180px;margin-top:32px;padding:20px}}@media (width<=480px){.project{padding:0 16px 56px}.section-label{font-size:.72rem}.section-title{font-size:clamp(1.6rem,9vw,2.1rem)}.project p{font-size:.9rem}.project-grid{border-radius:14px;gap:8px;min-height:160px;margin-top:24px;padding:16px}}.tech{max-width:1300px;min-height:100vh;margin:0 auto;padding:0 60px 80px}.section-header{align-items:center;gap:16px;margin-bottom:40px;display:flex}.section-label{text-transform:uppercase;font-family:var(--mono);color:var(--blue-glow)}.section-line{background:linear-gradient(to right, var(--blue-neon), transparent);flex:1;max-width:80px;height:1px}.section-title{text-transform:uppercase;font-size:clamp(2rem,2vw,3.2rem);font-weight:800;line-height:1.1;font-family:var(--sans);color:var(--white);margin-bottom:40px}.section-title em{background:linear-gradient(135deg, var(--blue-bright), var(--blue-neon));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-style:normal}.tech-categories{flex-direction:column;gap:40px;display:flex}.tech-category-title{font-family:var(--mono);color:var(--blue-neon);text-transform:uppercase;align-items:center;gap:8px;font-size:.7rem;display:flex}.tech-category-title:after{content:"";background:#2d6fff33;flex:1;height:1px}.tech-grid{flex-wrap:wrap;gap:12px;display:flex}.tech-card{font-family:var(--mono);letter-spacing:.05em;background:#0a1f4e59;border:1px solid #2d6fff26;border-radius:8px;align-items:center;gap:10px;margin-top:10px;padding:12px 20px;font-size:.8rem;transition:all .25s;display:flex;position:relative}.skill{flex-direction:column;gap:20px;width:600px;margin-top:60px;display:flex}.skill-bars{flex-direction:column;gap:15px;display:flex}.skill-bar{justify-content:space-between;margin-bottom:8px;display:flex}.skill-name{font-family:var(--mono);color:var(--white-muted);margin-bottom:5px;font-size:.9rem}.skill-percentage{font-family:var(--mono);color:var(--blue-neon);margin-top:5px;font-size:.8rem}.skill-track{background:#2d6fff33;border-radius:2px;height:3px;overflow:hidden}.skill-fill{background:linear-gradient(135deg, var(--blue-bright), var(--blue-neon));transform-origin:0;border-radius:2px;height:100%;animation:1.5s both barFill}@media (width<=1024px){.tech{min-height:auto;padding:0 32px 72px}.skill{width:100%;max-width:600px}}@media (width<=768px){.tech{padding:0 20px 64px}.section-header{gap:12px;margin-bottom:28px}.section-line{max-width:56px}.section-title{margin-bottom:28px;font-size:clamp(1.8rem,8vw,2.5rem)}.tech-categories{gap:28px}.tech-grid{gap:10px}.tech-card{padding:11px 16px;font-size:.74rem}.skill{gap:18px;margin-top:40px}.skill-name{font-size:.82rem}.skill-percentage{font-size:.74rem}}@media (width<=480px){.tech{padding:0 16px 56px}.section-label{font-size:.72rem}.section-title{margin-bottom:24px;font-size:clamp(1.6rem,9vw,2.1rem)}.tech-category-title{font-size:.66rem}.tech-card{justify-content:flex-start;width:100%;padding:12px 14px;font-size:.72rem}.skill{margin-top:32px}.skill-bar{align-items:center;gap:10px}.skill-name{font-size:.78rem}.skill-percentage{font-size:.7rem}}
