:root{--bg:#0b1220;--bg-2:#0f1a30;--text:#eaf2ff;--muted:#a9b6d3;--card:#ffffff0f;--card-2:#ffffff14;--border:#ffffff1f;--shadow:#00000059;--accent:#22c1f1;--accent-2:#60a5fa;--accent-soft:#60a5fa38;--radius:14px;--mx:50vw;--my:50vh;--section-gap:clamp(48px,6.5vh,120px)}[data-theme=green]{--accent:#10b981;--accent-2:#34d399;--accent-soft:#10b98138}*{box-sizing:border-box}body,html{margin:0;padding:0}body{background:radial-gradient(1200px circle at 10% -10%,#162341,#0000 35%),radial-gradient(1000px circle at 100% 10%,#0f2036,#0000 30%),linear-gradient(180deg,#0b1220,#0f1a30);background:radial-gradient(1200px circle at 10% -10%,#162341,#0000 35%),radial-gradient(1000px circle at 100% 10%,#0f2036,#0000 30%),linear-gradient(180deg,var(--bg),var(--bg-2));color:#eaf2ff;color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji,sans-serif;line-height:1.6;overflow-x:hidden}.bg-light{background:radial-gradient(450px circle at 50vw 50vh,#60a5fa2e,#0000 60%),radial-gradient(650px circle at calc(50vw + 80px) calc(50vh + 60px),#60a5fa38,#0000 70%);background:radial-gradient(450px circle at var(--mx) var(--my),#60a5fa2e,#0000 60%),radial-gradient(650px circle at calc(var(--mx) + 80px) calc(var(--my) + 60px),var(--accent-soft),#0000 70%);inset:0;pointer-events:none;position:fixed;transition:background .12s linear;z-index:0}.wrap{margin:0 auto;max-width:1360px;padding:0 20px}.hero>.wrap{grid-gap:32px;align-items:center;display:grid;gap:32px;grid-template-columns:1.2fr .8fr}.nav-row{align-items:center;display:flex;height:64px;justify-content:space-between}header.nav{background:linear-gradient(180deg,#0a102099,#0a102066);border-bottom:1px solid #ffffff1f;border-bottom:1px solid var(--border);position:-webkit-sticky;position:sticky;top:0;transition:background .22s ease,border-color .22s ease,box-shadow .22s ease;z-index:80}header.nav.scrolled{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:linear-gradient(180deg,#0a1020fa,#0a1020f5);border-bottom-color:#ffffff0a;box-shadow:0 6px 30px #03060d73}.menu-btn{-webkit-appearance:none;appearance:none;background:#0000;border:0;cursor:pointer;display:none;padding:6px}.menu-btn .hamburger{display:inline-block;position:relative}.menu-btn .hamburger,.menu-btn .hamburger:after,.menu-btn .hamburger:before{background:#eaf2ff;background:var(--text);border-radius:2px;height:2px;width:22px}.menu-btn .hamburger:after,.menu-btn .hamburger:before{content:"";left:0;position:absolute;transition:transform .18s ease,opacity .18s ease}.menu-btn .hamburger:before{top:-7px}.menu-btn .hamburger:after{top:7px}.menu-btn.open .hamburger{background:#0000}.menu-btn.open .hamburger:before{transform:translateY(7px) rotate(45deg)}.menu-btn.open .hamburger:after{transform:translateY(-7px) rotate(-45deg)}@media (max-width:720px){.menu-btn{align-items:center;display:inline-flex;justify-content:center;position:absolute;right:16px;top:50%;transform:translateY(-50%);z-index:120}header.nav nav{display:none}header.nav.menu-open nav{background:linear-gradient(180deg,#ffffff05,#ffffff03);border:1px solid #ffffff1f;border:1px solid var(--border);border-radius:12px;box-shadow:0 12px 40px #00000059;display:block;min-width:180px;padding:12px;position:absolute;right:12px;top:calc(100% + 8px);z-index:115}header.nav.menu-open nav ul{display:flex;flex-direction:column;gap:8px}header.nav.menu-open nav a{display:block;padding:8px 10px}header.nav .wrap{padding-left:20px;padding-right:64px}}@media (max-width:960px){.hero>.wrap{grid-gap:18px;align-items:center;display:grid;gap:18px;grid-template-columns:1fr;padding:20px}.hero{padding-top:48px}.portrait-wrapper{margin:0 auto}}header.nav .brand{left:20px;position:absolute;top:50%;transform:translateY(-50%);z-index:90}header.nav .wrap{padding-left:96px}@media (max-width:720px){header.nav .brand{position:static;transform:none}header.nav .wrap{padding-left:20px}}header.nav nav{position:absolute;right:20px;top:50%;transform:translateY(-50%);z-index:90}@media (max-width:720px){header.nav nav{margin-top:12px;position:static;transform:none}}.brand{align-items:center;display:flex;font-weight:800;gap:12px;letter-spacing:.2px}.brand .logo{background:linear-gradient(135deg,#22c1f1,#60a5fa);background:linear-gradient(135deg,var(--accent),var(--accent-2));border-radius:12px;box-shadow:0 8px 18px #00000059;box-shadow:0 8px 18px var(--shadow);color:#0a1020;display:grid;font-weight:900;height:36px;place-items:center;width:36px}nav ul{display:flex;gap:18px;list-style:none;margin:0;padding:0}nav a{border-radius:8px;color:#eaf2ff;color:var(--text);font-weight:500;opacity:.9;padding:6px 10px;text-decoration:none}nav a:hover{background:#ffffff0f;background:var(--card)}.actions{align-items:center;display:flex;gap:10px}.btn{-webkit-appearance:none;appearance:none;background:#ffffff0f;background:var(--card);border:1px solid #ffffff1f;border:1px solid var(--border);border-radius:10px;color:#eaf2ff;color:var(--text);cursor:pointer;font-weight:600;padding:10px 14px;transition:transform .15s ease,background .15s ease,border-color .15s ease,box-shadow .15s ease}.btn:hover{background:#ffffff14;background:var(--card-2);transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn.primary{background:linear-gradient(135deg,#22c1f1,#60a5fa);background:linear-gradient(135deg,var(--accent),var(--accent-2));border-color:#0000;box-shadow:0 8px 24px #2090ff3d;color:#0a1020}.btn.primary:hover{filter:brightness(1.03)}.btn.ghost{background:#0000;border-color:#60a5fa38;border-color:var(--accent-soft);color:#eaf2ff;color:var(--text)}main{position:relative;z-index:1}section{padding:72px 0;scroll-margin-top:80px}section#about{padding-bottom:clamp(18px,3vh,36px);padding-top:clamp(40px,6vh,72px)}section#skills{padding-bottom:clamp(12px,2.5vh,28px);padding-top:clamp(12px,2.5vh,28px)}footer,section#activities,section#contact,section#education,section#uiux{padding-bottom:calc(clamp(48px, 6.5vh, 120px)/2);padding-bottom:calc(var(--section-gap)/2);padding-top:calc(clamp(48px, 6.5vh, 120px)/2);padding-top:calc(var(--section-gap)/2)}.hero{align-items:center;display:flex;justify-content:center;min-height:90vh;padding:0;position:relative}.title{font-size:clamp(34px,5vw,56px);font-weight:900;letter-spacing:-.5px;line-height:1.05;margin:0 0 14px}.sub{color:#a9b6d3;color:var(--muted);font-size:clamp(16px,2.4vw,22px);margin:0 0 16px}.tagline{color:#c8d6f9;font-size:16px;margin-bottom:22px;max-width:820px;opacity:.95}.cta{gap:10px;margin:18px 0 10px}.contact-row,.cta{display:flex;flex-wrap:wrap}.contact-row{color:#a9b6d3;color:var(--muted);font-size:14px;gap:14px;margin-top:12px}.contact-pill{align-items:center;background:#ffffff0a;border:1px solid #ffffff1f;border:1px solid var(--border);border-radius:999px;display:inline-flex;gap:8px;padding:8px 12px}.contact-pill a{color:#eaf2ff;color:var(--text);text-decoration:none}.hero-socials{display:flex;flex-wrap:wrap;gap:12px;margin-top:12px}.social-link{align-items:center;background:#ffffff08;border:1px solid #ffffff1f;border:1px solid var(--border);border-radius:999px;color:#eaf2ff;color:var(--text);display:inline-flex;font-weight:600;gap:8px;padding:8px 12px;text-decoration:none;transition:background .15s ease,transform .12s ease,box-shadow .12s ease}.social-link .i{border-radius:6px;height:18px;width:18px}.social-link:hover{background:#ffffff14;background:var(--card-2);box-shadow:0 8px 20px #0003;transform:translateY(-2px)}.social-link:active{transform:translateY(0)}@media (max-width:960px){.hero-socials{justify-content:center}}.stat{align-items:center;background:#0000002e;border:1px dashed #60a5fa38;border:1px dashed var(--accent-soft);border-radius:10px;color:#cfe8ff;display:inline-flex;font-weight:600;gap:8px;margin-top:14px;padding:8px 12px}.hero-visual{display:grid;min-height:clamp(280px,40vh,520px);place-items:center;position:relative}.portrait-container{align-items:center;display:flex;justify-content:center}.portrait-wrapper{background:linear-gradient(135deg,#ffffff05,#ffffff03);border:6px solid #ffffff0f;border-radius:9999px;box-shadow:0 10px 30px #00000059;display:inline-block;height:clamp(140px,20vw,260px);overflow:hidden;position:relative;width:clamp(140px,20vw,260px)}.portrait-image{display:block;height:100%;object-fit:cover;width:100%}.portrait-glow{box-shadow:inset 0 0 40px #60a5fa1f;inset:0;pointer-events:none;position:absolute}.hero{padding-bottom:clamp(140px,14vh,200px)}.hero-skills{bottom:clamp(18px,4vh,36px);display:flex;flex-wrap:wrap;gap:10px;justify-content:center;left:0;padding:0 20px;pointer-events:auto;position:absolute;right:0;z-index:30}.skill-chip{align-items:center;animation:slideUpFade .42s cubic-bezier(.2,.8,.25,1) forwards;animation-delay:0ms;animation-delay:calc(var(--i, 0)*80ms);animation-delay:0ms,.52s;animation-delay:calc(var(--i, 0)*80ms),calc(var(--i, 0)*80ms + .52s);animation-duration:.42s,4.2s;animation-fill-mode:forwards,both;animation-name:slideUpFade,floatX;animation-timing-function:cubic-bezier(.2,.8,.25,1),ease-in-out;background:#ffffff08;border:1px solid #ffffff0a;border-radius:0;color:#eaf2ff;color:var(--text);display:inline-flex;font-size:13px;font-weight:700;justify-content:center;opacity:0;padding:8px 12px;transform:translateY(18px)}.skill-chip:hover{animation-play-state:paused;box-shadow:0 10px 28px #00000047;transform:translateY(0) scale(1.03)}@keyframes slideUpFade{to{opacity:1;transform:translateY(0)}}@keyframes floatX{0%{transform:translateX(-6px)}50%{transform:translateX(6px)}to{transform:translateX(-6px)}}.skill-marquee{bottom:clamp(12px,3.5vh,28px);left:0;overflow:hidden;pointer-events:none;position:absolute;right:0;z-index:30}.marquee-track{align-items:center;animation:marquee-left 18s linear infinite;display:flex;gap:12px;padding:6px 20px;white-space:nowrap;will-change:transform}.marquee-item{align-items:center;background:#ffffff08;border:1px solid #ffffff0a;border-radius:0;color:#eaf2ff;color:var(--text);display:inline-flex;flex:0 0 auto;font-size:13px;font-weight:700;justify-content:center;padding:8px 14px;pointer-events:auto}.marquee-item:hover{animation-play-state:paused;box-shadow:0 10px 28px #00000047;transform:scale(1.04)}.m-icon{background:linear-gradient(135deg,#22c1f1,#60a5fa);background:linear-gradient(135deg,var(--accent),var(--accent-2));border-radius:6px;box-shadow:0 6px 18px #00000038;color:#071022;display:inline-grid;font-size:11px;font-weight:900;height:20px;margin-right:8px;min-width:28px;place-items:center;width:28px}.m-icon-img,.m-label{display:inline-block}.m-icon-img{border-radius:6px;height:20px;margin-right:8px;min-width:28px;object-fit:cover;width:28px}@keyframes marquee-left{0%{transform:translateX(0)}to{transform:translateX(-50%)}}.glass{background:linear-gradient(180deg,#ffffff0f,#ffffff08);border:1px solid #ffffff1f;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius);box-shadow:0 12px 40px #00000059;box-shadow:0 12px 40px var(--shadow);padding:20px}.id-card{width:min(100%,400px)}.id-card .name{align-items:center;border-bottom:1px dashed #ffffff1f;border-bottom:1px dashed var(--border);display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:10px}.id-card .name h3{font-size:22px;letter-spacing:.3px;margin:0}.id-card .badge{background:#ffffff0f;background:var(--card);border:1px solid #60a5fa38;border:1px solid var(--accent-soft);border-radius:22px;color:#dff5ff;font-family:JetBrains Mono,monospace;font-size:12px;padding:6px 10px}.id-grid{grid-gap:10px;color:#a9b6d3;color:var(--muted);display:grid;font-size:14px;gap:10px;grid-template-columns:1fr 1fr}.id-grid div{background:#ffffff0a;border:1px solid #ffffff1f;border:1px solid var(--border);border-radius:10px;padding:10px}.id-grid strong{color:#eaf2ff;color:var(--text);display:block;font-weight:700;margin-bottom:4px}.float-layer{inset:0;pointer-events:none;position:absolute}.tech-bubble{background:#ffffff0f;border:1px solid #60a5fa38;border:1px solid var(--accent-soft);border-radius:999px;box-shadow:0 8px 22px #00000038;color:#dff8ff;display:none!important;font-size:13px;font-weight:700;padding:10px 12px;position:absolute;text-shadow:0 2px 6px #00000059;transform:translate(-50%,-50%);-webkit-user-select:none;user-select:none;white-space:nowrap}h2.section-title{font-size:clamp(22px,2.6vw,28px);letter-spacing:.2px;margin:0 0 18px}.section-desc{color:#a9b6d3;color:var(--muted);margin:0 0 22px}.grid{grid-gap:16px;display:grid;gap:16px}.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}@media (max-width:960px){.hero{align-items:flex-start;grid-template-columns:1fr;padding-top:48px}.portrait-container{margin:18px 0 0;position:static;transform:none}.grid.cols-4{grid-template-columns:repeat(2,1fr)}.grid.cols-2,.grid.cols-3{grid-template-columns:repeat(1,1fr)}}.card{background:linear-gradient(180deg,#ffffff0f,#ffffff05);border:1px solid #ffffff1f;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius);padding:18px;transition:transform .18s ease,box-shadow .18s ease,background .18s ease}.card:hover{background:linear-gradient(180deg,#ffffff14,#ffffff08);box-shadow:0 14px 40px #00000047;transform:translateY(-3px)}.card h3{font-size:18px;margin:0 0 8px}.card .meta{color:#a9b6d3;color:var(--muted);font-size:14px;margin-bottom:10px}.chip{align-items:center;background:#ffffff0a;border:1px solid #60a5fa38;border:1px solid var(--accent-soft);border-radius:999px;color:#d6f3ff;display:inline-flex;font-size:12px;gap:6px;margin:6px 6px 0 0;padding:6px 10px}.skills-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(3,minmax(0,1fr));margin-top:8px}.skill-tile{align-items:center;background:linear-gradient(180deg,#ffffff05,#ffffff03);border:1px solid #ffffff08;border-radius:10px;display:flex;gap:8px;padding:6px 8px;transition:transform .18s ease,box-shadow .18s ease,background .12s ease}.skill-tile:hover{box-shadow:0 14px 30px #00000047;transform:translateY(-6px)}.skill-icon{border-radius:8px;display:inline-block;height:24px;object-fit:cover;width:36px}.skill-name{font-size:14px;font-weight:700}@media (max-width:960px){.skills-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:520px){.skills-grid{grid-template-columns:repeat(1,minmax(0,1fr))}}.project-image{border-radius:10px;height:clamp(160px,26vh,320px);margin-bottom:12px;object-fit:cover;width:100%}section#projects{padding-bottom:clamp(18px,3vh,36px);padding-top:clamp(40px,6.5vh,88px)}details{background:#ffffff0a;border:1px solid #ffffff1f;border:1px solid var(--border);border-radius:12px;padding:12px 14px}details summary{cursor:pointer;font-weight:700;list-style:none}details[open]{background:#ffffff0f}.timeline{padding-left:22px;position:relative}.timeline:before{background:linear-gradient(#22c1f1,#0000);background:linear-gradient(var(--accent),#0000);border-radius:2px;bottom:0;content:"";left:8px;opacity:.55;position:absolute;top:0;width:2px}.t-item{margin-bottom:20px;position:relative}.t-item:before{display:none}.t-item h3{margin:0 0 6px}.t-item .when{color:#a9b6d3;color:var(--muted);font-size:14px}.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s cubic-bezier(.2,.7,.3,1),transform .6s cubic-bezier(.2,.7,.3,1)}.reveal.inview{opacity:1;transform:translateY(0)}footer{background:linear-gradient(180deg,#0000,#00000040);border-top:1px solid #ffffff1f;border-top:1px solid var(--border);color:#a9b6d3;color:var(--muted);padding:18px 0 28px}.footer-grid{grid-gap:16px;align-items:center;display:grid;gap:16px;grid-template-columns:1fr}@media (max-width:720px){.footer-grid{grid-template-columns:1fr}}.footer-grid>div{justify-self:center;text-align:center}.brand{gap:10px}.brand .logo{border-radius:10px;font-size:18px;height:44px;width:44px}.to-top{bottom:16px;opacity:0;pointer-events:none;position:fixed;right:16px;transform:translateY(10px);transition:all .2s ease;z-index:60}.to-top.show{opacity:1;pointer-events:auto;transform:translateY(0)}a.link{border-bottom:1px dashed #60a5fa38;border-bottom:1px dashed var(--accent-soft);color:#dff2ff;text-decoration:none}a.link:hover{border-bottom-style:solid}.i{background:linear-gradient(135deg,#22c1f1,#60a5fa);background:linear-gradient(135deg,var(--accent),var(--accent-2));border-radius:4px;display:inline-block;height:16px;margin-right:6px;vertical-align:-3px;width:16px}.sr-only{height:1px;left:-9999px;overflow:hidden;position:absolute;width:1px}@media (max-width:720px){.wrap{padding:0 12px}section{padding:48px 0;scroll-margin-top:68px}.hero{min-height:70vh;padding-bottom:clamp(90px,12vh,140px)}.project-image{height:auto;max-height:240px}.nav-row{height:56px}}@media (max-width:520px){.wrap{padding:0 6px}section{padding:36px 0;scroll-margin-top:64px}.hero{min-height:60vh;padding-bottom:80px}.portrait-wrapper{height:clamp(100px,36vw,160px);width:clamp(100px,36vw,160px)}.marquee-item,.skill-chip{font-size:12px;padding:6px 8px}nav ul{gap:12px}nav a{padding:6px 8px}}@media (max-width:420px){header.nav .brand{left:8px}header.nav .brand .logo{height:32px;width:32px}header.nav .wrap{padding-left:8px;padding-right:48px}header.nav .brand div>div{font-size:13px;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hero>.wrap{grid-gap:12px;align-items:start;display:grid;gap:12px;grid-template-columns:1fr;padding:12px}.hero{min-height:64vh;padding-bottom:80px;padding-top:28px}.title{font-size:clamp(24px,6.4vw,36px);line-height:1.05}.sub,.tagline{font-size:14px}.cta{gap:8px;justify-content:flex-start}.btn{font-size:14px;padding:8px 10px}.hero-socials{gap:8px;justify-content:flex-start;margin-top:6px}.social-link{border-radius:8px;padding:6px 8px}.skill-marquee{display:none}.portrait-wrapper{border-width:5px;height:clamp(100px,34vw,140px);margin:6px auto 0;width:clamp(100px,34vw,140px)}.project-image{height:auto;max-height:220px}}@media (max-width:960px){.grid.cols-4{grid-template-columns:repeat(2,1fr)}.grid.cols-2,.grid.cols-3{grid-template-columns:repeat(1,1fr)}}.card h3,.card p{word-break:break-word}
/*# sourceMappingURL=main.c2c63a55.css.map*/