@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700&family=Sora:wght@500;600;700&display=swap";:root{--font-heading: "Sora", "Segoe UI", sans-serif;--font-body: "Manrope", "Segoe UI", sans-serif;font-family:var(--font-body);line-height:1.5;font-weight:400;color:#e6e9f2;background-color:#0a0c12;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg-0: #0a0c12;--bg-1: #0f1220;--bg-2: #151a2d;--text-0: #e6e9f2;--text-1: #a8b0c3;--accent-0: #5fb5ff;--accent-1: #7ee0ff;--accent-2: #7f7cff;--stroke: rgba(255, 255, 255, .08)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);min-width:320px;min-height:100vh;background-color:var(--bg-0);color:var(--text-0)}h1,h2,h3,h4,h5,h6,.brand,.nav a,.primary-button,.ghost-button,.section-title,.experience-title,.projects-title,.hero-title,.certificate-title{font-family:var(--font-heading)}#root{min-height:100vh}a{color:inherit;text-decoration:none}button{font-family:inherit}img{max-width:100%;display:block}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.loader-screen{position:fixed;inset:0;display:grid;place-items:center;background:radial-gradient(700px 500px at 50% 20%,#78b4ff47,#0a0c1200),radial-gradient(500px 500px at 80% 80%,#72ffdc1f,#0a0c1200),linear-gradient(160deg,#0a0c12,#0d1020,#0a0c12);z-index:20;transform-origin:center;transition:opacity .22s ease,visibility 0s linear .22s}.loader-screen.is-visible{opacity:1;visibility:visible}.loader-screen.is-hidden{opacity:0;visibility:hidden;pointer-events:none}.loader-screen.is-hidden .loader-logo-wrap,.loader-screen.is-hidden .loader-text,.loader-screen.is-hidden .loader-progress{opacity:0}.loader-frame{display:grid;gap:18px;text-align:center;align-items:center}.loader-logo-wrap{width:112px;height:112px;margin:0 auto;display:grid;place-items:center;transform:scale(1)}.loader-logo{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 0 20px rgba(126,224,255,.45))}.loader-text{display:grid;gap:6px;transition:opacity .22s ease,transform .22s ease}.loader-kicker{text-transform:uppercase;letter-spacing:.3em;font-size:11px;color:#e6e9f299}.loader-title{font-size:32px;font-weight:600;color:#e8edf9}.loader-subtitle{color:#e6e9f2b3;font-size:14px}.loader-screen.is-revealing .loader-logo-wrap{animation:loader-logo-zoom-reveal .9s cubic-bezier(.2,.8,.2,1) forwards}.loader-screen.is-revealing .loader-text{opacity:0;transform:translateY(-8px)}.loader-progress{width:200px;height:3px;background:#ffffff21;border-radius:99px;overflow:hidden;margin:2px auto 0;transition:opacity .22s ease,transform .22s ease}.loader-progress span{display:block;height:100%;width:40%;border-radius:inherit;background:linear-gradient(90deg,#7ee0ff,#7f7cff,#7ee0ff);animation:loader-sweep 1.4s ease-in-out infinite}.loader-screen.is-revealing .loader-progress{opacity:0;transform:translateY(-8px)}@keyframes loader-logo-zoom-reveal{0%{transform:scale(1);opacity:1}to{transform:scale(22);opacity:0}}@keyframes loader-sweep{0%{transform:translate(-100%)}50%{transform:translate(140%)}to{transform:translate(240%)}}.hero{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:48px;padding-top:80px;align-items:center}.hero-content{display:grid;gap:24px}.hero-kicker{text-transform:uppercase;letter-spacing:.4em;font-size:11px;color:var(--text-1)}.hero-title{font-size:clamp(2.4rem,4vw,4.2rem);line-height:1.05;font-weight:600}.hero-accent{display:inline-block;background:linear-gradient(90deg,#7ee0ff,#7f7cff);-webkit-background-clip:text;color:transparent}.hero-subtitle{color:var(--text-1);max-width:520px}.hero-actions{display:flex;flex-wrap:wrap;gap:12px}.hero-panel{position:relative;border-radius:24px;border:1px solid var(--stroke);background:#0b0f1ccc;overflow:hidden}.panel-glow{position:absolute;inset:-30% 10% auto auto;width:240px;height:240px;background:radial-gradient(circle,#7ee0ff59,#0b0f1c00 70%);filter:blur(4px)}.panel-inner{position:relative;padding:32px;display:grid;gap:18px;min-height:320px;align-content:center}.panel-label{text-transform:uppercase;letter-spacing:.2em;font-size:11px;color:var(--text-1)}.panel-line{height:1px;background:linear-gradient(90deg,#7ee0ff00,#7ee0ff80,#7ee0ff00)}.welcome-line{color:#e9efff;font-size:clamp(1.2rem,2.8vw,1.8rem);line-height:1.35;font-weight:600}.typing-line{color:#c8d2ea;font-size:clamp(1rem,2.4vw,1.3rem);font-weight:500;line-height:1.4}.typing-word{color:#9edfff;font-weight:700;position:relative;display:inline-flex;align-items:center;min-height:1.4em}.typing-cursor{width:2px;height:1.05em;margin-left:5px;border-radius:3px;background:#86d9ff;animation:caret-blink 1s steps(1,end) infinite}@keyframes caret-blink{0%,50%{opacity:1}50.1%,to{opacity:0}}.experience{display:grid;gap:32px}.experience-head{display:grid;gap:12px}.experience-title{font-size:clamp(1.8rem,3vw,2.6rem);font-weight:600}.experience-subtitle{color:var(--text-1);max-width:560px}.experience-timeline{position:relative;display:grid;gap:22px}.experience-timeline:before{content:"";position:absolute;left:10px;top:8px;bottom:8px;width:1px;background:linear-gradient(180deg,#7f7cffa6,#7f7cff26)}.experience-item{position:relative;padding-left:36px}.experience-dot{position:absolute;left:0;top:24px;width:20px;height:20px;border-radius:50%;border:1px solid rgba(127,124,255,.5);background:radial-gradient(circle,#7ee0ff,#5f86ff 65%,#203056);box-shadow:0 0 0 4px #5f86ff26}.experience-card{padding:24px;border-radius:20px;border:1px solid var(--stroke);background:#0c101ed1;display:grid;gap:18px}.experience-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.experience-card-head h3{font-size:20px;font-weight:600}.experience-company{margin-top:4px;color:var(--text-1);font-size:16px}.experience-meta{display:grid;justify-items:end;gap:8px}.role-type-pill{padding:4px 10px;border-radius:999px;border:1px solid rgba(126,224,255,.3);background:#7ee0ff1a;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:#d8eeff}.experience-date{color:var(--text-1);font-size:14px}.experience-highlights{display:grid;gap:12px;list-style:none;padding-left:0;color:#d6deef;font-size:15.5px;line-height:1.6}.experience-highlights li{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:start}.experience-highlight-icon{width:24px;height:24px;border-radius:8px;display:grid;place-items:center;background:#7ee0ff24;border:1px solid rgba(126,224,255,.35);color:#9edfff;margin-top:1px}.experience-tech-list{display:flex;flex-wrap:wrap;gap:10px}.experience-tech-chip{display:inline-flex;align-items:center;gap:8px;padding:7px 10px;border-radius:999px;border:1px solid var(--stroke);background:#10182cbf;color:#d9e3f7;font-size:13px}.experience-tech-logo,.experience-tech-logo-fallback{width:16px;height:16px;border-radius:4px;flex-shrink:0}.experience-tech-logo{object-fit:cover}.experience-tech-logo-fallback{display:grid;place-items:center;font-size:9px;font-weight:700;color:#f6f9ff;background:linear-gradient(130deg,#5f86ff,#46c1ff)}.experience-empty{color:var(--text-1);font-size:14px}@media(max-width:760px){.experience-card-head{flex-direction:column;align-items:flex-start}.experience-meta{justify-items:start}.experience-highlights{font-size:15px}}.projects{display:grid;gap:32px}.projects-head{display:grid;gap:12px}.projects-title{font-size:clamp(1.8rem,3vw,2.6rem);font-weight:600}.projects-subtitle{color:var(--text-1);max-width:560px}.projects-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}.project-card{border-radius:22px;border:1px solid var(--stroke);background:#0c101ed1;overflow:hidden;display:grid}.project-image-wrap{aspect-ratio:16 / 9;border-bottom:1px solid var(--stroke);background:#101628cc}.project-image{width:100%;height:100%;object-fit:cover}.project-content{display:grid;gap:10px;padding:20px 20px 16px}.project-content h3{font-size:20px;font-weight:600}.project-content p{color:var(--text-1);font-size:14px}.project-tech-list{display:flex;flex-wrap:wrap;gap:10px;padding:0 20px 18px}.project-tech-chip{display:inline-flex;align-items:center;gap:8px;padding:7px 10px;border-radius:999px;border:1px solid var(--stroke);background:#10182cbf;color:#d9e3f7;font-size:13px}.project-tech-logo,.project-tech-logo-fallback{width:16px;height:16px;border-radius:4px;flex-shrink:0}.project-tech-logo{object-fit:cover}.project-tech-logo-fallback{display:grid;place-items:center;font-size:9px;font-weight:700;color:#f6f9ff;background:linear-gradient(130deg,#5f86ff,#46c1ff)}.project-links{margin-top:auto;padding:14px 20px 20px;border-top:1px solid var(--stroke);display:flex;gap:12px}.project-links a{display:inline-flex;align-items:center;justify-content:center;min-width:88px;padding:9px 14px;border-radius:999px;border:1px solid rgba(155,196,255,.35);background:#121a30a6;color:#e4edff;font-size:13px;font-weight:600;transition:transform .18s ease,box-shadow .22s ease,background .22s ease,border-color .22s ease,color .22s ease}.project-links a:hover{color:#f6f9ff;background:linear-gradient(135deg,#5f86ff,#46c1ff);border-color:transparent;box-shadow:0 0 0 1px #5c90ff59,0 8px 24px #46a7ff73;transform:translateY(-1px)}.project-empty{padding:24px;color:var(--text-1);font-size:14px}@media(max-width:900px){.projects-grid{grid-template-columns:1fr}}.contact{display:grid}.contact-card{display:grid;grid-template-columns:7fr 3fr;gap:24px;border:1px solid var(--stroke);border-radius:24px;background:#0b0f1cb8;padding:26px}.contact-form-pane{display:grid;gap:14px}.contact-title{font-size:clamp(1.8rem,3vw,2.6rem);font-weight:600}.contact-subtitle{color:var(--text-1);max-width:620px;margin-bottom:6px}.contact-form{display:grid;gap:10px}.contact-form label{font-size:13px;color:var(--text-1)}.contact-form input,.contact-form textarea{width:100%;border:1px solid var(--stroke);border-radius:14px;padding:12px 14px;background:#0f1629bf;color:var(--text-0);outline:none;transition:border-color .2s ease,box-shadow .2s ease}.contact-form input:focus,.contact-form textarea:focus{border-color:#7ee0ff73;box-shadow:0 0 0 1px #7ee0ff33}.contact-form textarea{resize:vertical;min-height:140px}.contact-form button{width:fit-content;margin-top:8px}.contact-meta-pane{border-left:1px solid var(--stroke);padding-left:18px;display:grid;align-content:start;gap:8px}.contact-meta-label{margin-top:10px;color:var(--text-1);font-size:12px;letter-spacing:.09em;text-transform:uppercase}.contact-meta-pane a,.contact-meta-pane p{color:#dbe5fb;font-size:15px;line-height:1.5}.contact-meta-pane a:hover{color:#f3f8ff;text-decoration:underline}@media(max-width:900px){.contact-card{grid-template-columns:1fr}.contact-meta-pane{border-left:0;border-top:1px solid var(--stroke);padding-left:0;padding-top:14px}}.site-shell{position:relative;z-index:2;padding:32px 6vw 28px;transition:none}.site-shell.is-loading{opacity:1;transform:none;filter:none}.site-shell.is-ready{opacity:1;transform:translateY(0) scale(1);filter:none}.site-header{position:sticky;top:10px;z-index:14;display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:24px;padding:12px 14px;border-radius:16px;background:#0a0e183d;border:1px solid transparent;transition:background .22s ease,border-color .22s ease,backdrop-filter .22s ease,box-shadow .22s ease}.site-header.is-scrolled{background:#080b1485;border-color:#ffffff12;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 8px 24px #060a1438}.brand{justify-self:start;color:var(--text-0)}.brand-logo{width:44px;height:44px;border:0;background:transparent;display:grid;place-items:center}.brand-logo img{width:100%;height:100%;object-fit:contain}.nav{justify-self:center;display:flex;gap:18px;font-size:14px;color:var(--text-1)}.site-header .primary-button{justify-self:end}.mobile-menu-button,.mobile-resume-link{display:none}.nav a{padding:8px 12px;border-radius:999px;border:1px solid transparent;transition:border-color .2s ease,color .2s ease}.nav a:hover{border-color:var(--stroke);color:var(--text-0)}.primary-button,.ghost-button{border-radius:999px;padding:10px 18px;font-size:14px;border:1px solid var(--stroke);background:#121422b3;color:var(--text-0);transition:transform .2s ease,box-shadow .2s ease}.primary-button{background:linear-gradient(135deg,#6f8cff,#7ee0ff);color:#0a0c12;border-color:transparent}.primary-button:hover,.ghost-button:hover{transform:translateY(-1px);box-shadow:0 10px 30px #508cff40}main{display:grid;gap:120px}.social-footer{margin-top:84px;padding:22px 24px;border-radius:24px;border:1px solid var(--stroke);background:#0b0f1cb3;display:flex;align-items:center;justify-content:space-between;gap:16px}.social-links{display:inline-flex;align-items:center;gap:12px}.social-links a{display:inline-flex;align-items:center;justify-content:center;min-width:92px;padding:9px 14px;border-radius:999px;border:1px solid rgba(155,196,255,.3);background:#121a30a6;color:#dce8ff;font-size:13px;font-weight:600;transition:transform .18s ease,box-shadow .22s ease,background .22s ease,border-color .22s ease,color .22s ease}.social-links a:hover{color:#f6f9ff;background:linear-gradient(135deg,#5f86ff,#46c1ff);border-color:transparent;box-shadow:0 0 0 1px #5c90ff59,0 8px 24px #46a7ff73;transform:translateY(-1px)}.social-copyright{color:var(--text-1);font-size:13px;text-align:right}@media(max-width:900px){.site-header{grid-template-columns:auto 1fr auto;align-items:center;gap:12px;top:0;padding:10px 12px;border-radius:12px;background:#080b1473;border:1px solid rgba(255,255,255,.06);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.brand-logo{grid-column:1;grid-row:1}.nav{grid-column:1 / -1;grid-row:2;width:100%;display:grid;gap:8px;max-height:0;overflow:hidden;opacity:0;transform:translateY(-8px);pointer-events:none;transition:max-height .24s ease,opacity .22s ease,transform .22s ease}.nav.is-open{max-height:260px;opacity:1;transform:translateY(0);pointer-events:auto}.nav a{width:100%;border-radius:10px;padding:10px 12px}.mobile-resume-link{display:block;border:1px solid rgba(155,196,255,.35)!important;background:#121a30a6;color:#e4edff;font-weight:600}.site-header .primary-button{display:none}.mobile-menu-button{display:inline-grid;grid-column:3;grid-row:1;justify-self:end;width:38px;height:38px;border-radius:10px;border:1px solid var(--stroke);background:#121624bf;color:var(--text-0);padding:9px;gap:5px;align-content:center;justify-content:center}.mobile-menu-button span{width:16px;height:2px;border-radius:2px;background:currentColor;transition:transform .2s ease,opacity .2s ease}.mobile-menu-button.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.mobile-menu-button.is-open span:nth-child(2){opacity:0}.mobile-menu-button.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.social-footer{flex-direction:column;align-items:center;justify-content:center;text-align:center}.social-copyright{text-align:center}}.app{--scroll-progress: 0;position:relative;isolation:isolate;min-height:100vh;background:radial-gradient(1200px 600px at 20% -10%,#5894ff33,#0a0c1200),radial-gradient(1000px 600px at 90% 0%,#61d6ff26,#0a0c1200),linear-gradient(160deg,#0a0c12,#0f1220 40%,#0b0e18)}.app>.site-shell{position:relative;z-index:2}.app>.loader-screen{position:fixed;z-index:30}.app:before{content:"";position:absolute;inset:-20% -20% auto -10%;width:70vw;height:70vw;background:radial-gradient(circle,#70baff47,#0a0c1200 68%),radial-gradient(circle at 75% 40%,#7f7cff3b,#0a0c1200 70%);opacity:calc(.24 + (var(--scroll-progress) * .55));filter:blur(calc(8px + (var(--scroll-progress) * 20px)));transform:translateY(calc(var(--scroll-progress) * -36px));pointer-events:none;z-index:0;transition:opacity .18s linear,filter .18s linear,transform .18s linear}.app:after{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(152,214,255,.42) 2.7px,transparent 1.8px),radial-gradient(rgba(126,224,255,.32) 2.5px,transparent 1.6px),radial-gradient(rgba(255,255,255,.14) 1.5px,transparent 1.4px);background-size:124px 124px,86px 86px,52px 52px;background-position:0 0,30px 20px,8px 14px;opacity:calc(.34 + (var(--scroll-progress) * .3));animation:float-dots 10s linear infinite;pointer-events:none;z-index:1;mix-blend-mode:screen}@keyframes float-dots{0%{background-position:0 0,30px 20px,8px 14px}50%{background-position:-30px 42px,60px -24px,-18px 48px}to{background-position:-60px 84px,90px -48px,-36px 96px}}@media(prefers-reduced-motion:reduce){.app:before{transform:none;filter:blur(10px)}.app:after{animation:none}}
