:root{color:#f8fafc;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#05070e;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:#05070e;min-width:320px;min-height:100vh;margin:0}button,input,textarea{font:inherit}a{color:inherit}svg{display:block}.portfolio-shell{color:#f8fafc;background:linear-gradient(#0a1020f2,#05070e 42%),#05070e;min-height:100vh;overflow-x:hidden}.hero-section{text-align:center;background:radial-gradient(circle at 50% 48%,#141f3a52,#0000 34%),#080c17;place-items:center;min-height:100svh;padding:96px 24px 84px;display:grid;position:relative;overflow:hidden}.hero-content{z-index:1;width:min(860px,100%);position:relative;transform:translateY(clamp(28px,6vh,72px))}.hero-profile{object-fit:cover;object-position:center top;border:3px solid #60a5fa7a;border-radius:50%;width:clamp(118px,12vw,156px);height:clamp(118px,12vw,156px);margin:0 auto 34px;display:block;box-shadow:0 0 0 10px #2563eb14,0 20px 58px #2563eb3d}.constellation-field{color:#3b82f6;opacity:.9;pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.constellation-field__group{transform-box:fill-box;transform-origin:50%;animation:13s ease-in-out infinite alternate constellation-drift,4.8s ease-in-out infinite constellation-pulse}.constellation-field__group polyline{fill:none;stroke:currentColor;stroke-width:1.35px;stroke-linecap:round;stroke-linejoin:round;opacity:.45}.constellation-field__group circle,.constellation-field__sparks circle{fill:#4f8cff}.constellation-field__sparks{animation:8s ease-in-out infinite alternate spark-drift}.constellation-field__shards{fill:#0000007a;opacity:.72;animation:19s ease-in-out infinite alternate shard-drift}.field-b{animation-delay:-2.6s,-1.2s}.field-c{animation-delay:-5.4s,-2.8s}.field-d{animation-delay:-7.2s,-3.6s}.field-e{animation-delay:-9.4s,-.8s}.field-f{animation-delay:-4.4s,-4s}.field-g{animation-delay:-8.8s,-2.1s}.field-h{animation-delay:-6.6s,-1.7s}.field-i{animation-delay:-10.4s,-2.9s}.field-j{animation-delay:-3.4s,-4.2s}.field-k{animation-delay:-11.6s,-1.5s}.field-l{animation-delay:-5.9s,-3.1s}.field-m{animation-delay:-8.1s,-4.5s}.field-n{animation-delay:-12.3s,-2.3s}.field-o{animation-delay:-1.8s,-3.9s}.field-p{animation-delay:-7.7s,-.6s}.hero-kicker{color:#fff;margin:18px 0 0;font-size:clamp(2.05rem,3vw,2.55rem);font-weight:800;line-height:1.2}.hero-section h1{text-transform:uppercase;letter-spacing:.055em;white-space:normal;text-wrap:balance;color:#0000;background-image:linear-gradient(90deg,#5b8cff 0%,#a855f7 32%,#ec4899 66%,#a855f7 100%);-webkit-background-clip:text;background-clip:text;max-width:min(1120px,100vw - 48px);margin:0 auto;font-size:clamp(3.7rem,5.4vw,4.85rem);font-weight:800;line-height:1.02}.hero-subtitle{color:#cbd5e1;margin:28px auto 42px;font-size:clamp(1.12rem,1.8vw,1.32rem)}.hero-icons{justify-content:center;gap:26px;margin-bottom:42px;display:flex}.hero-icons span{color:#60a5fa;background:#1e2a5cb8;border:1px solid #60a5fa73;border-radius:50%;place-items:center;width:74px;height:74px;animation:5.8s ease-in-out infinite hero-icon-orbit;display:grid;box-shadow:inset 0 0 18px #60a5fa29,0 0 26px #60a5fa38}.hero-icons span:nth-child(2){animation-delay:-1.9s}.hero-icons span:nth-child(3){animation-delay:-3.8s}.hero-icons svg{stroke-width:1.8px;filter:drop-shadow(0 0 18px #60a5fa47);width:36px;height:36px;animation:7.5s linear infinite hero-icon-spin}.hero-icons span:nth-child(2) svg{animation-duration:8.8s;animation-direction:reverse}.hero-icons span:nth-child(3) svg{animation-duration:6.9s}.hero-role p{color:#9ca3af;margin:0 0 10px;font-size:1.03rem}.hero-role span{color:#1e88ff;font-size:.94rem;display:block}@keyframes constellation-drift{0%{transform:translate(-10px,-8px)rotate(-1deg)scale(.98)}to{transform:translate(18px,14px)rotate(2deg)scale(1.04)}}@keyframes constellation-pulse{0%,to{opacity:.36}50%{opacity:1}}@keyframes spark-drift{0%{opacity:.35;transform:translate(-14px,10px)}to{opacity:.95;transform:translate(18px,-16px)}}@keyframes shard-drift{0%{transform:translate(-18px,-10px)rotate(-1deg)}to{transform:translate(22px,18px)rotate(1deg)}}@keyframes hero-icon-orbit{0%,to{transform:translateY(0)scale(1)rotate(0)}50%{transform:translateY(-8px)scale(1.12)rotate(10deg)}}@keyframes hero-icon-spin{to{transform:rotate(360deg)}}.section{width:min(1120px,100% - 48px);margin:0 auto;padding:74px 0}.gradient-title{text-align:center;color:#0000;-webkit-background-clip:text;background-clip:text;margin:0;font-size:clamp(2rem,4vw,3rem);font-weight:800;line-height:1.1}.gradient-blue{background-image:linear-gradient(90deg,#60a5fa,#c084fc)}.gradient-purple{background-image:linear-gradient(90deg,#c084fc,#f472b6)}.gradient-green{background-image:linear-gradient(90deg,#4ade80,#60a5fa)}.gradient-pink{background-image:linear-gradient(90deg,#f472b6,#c084fc)}.gradient-contact{background-image:linear-gradient(90deg,#60a5fa,#4ade80)}.section-heading{text-align:center;margin-bottom:40px}.section-heading p{color:#9ca3af;max-width:660px;margin:18px auto 0;font-size:1.08rem;line-height:1.55}.about-grid{margin-inline:auto;max-width:760px;margin-top:6px}.about-copy{color:#d1d5db}.about-copy h3{color:#fff;margin:0 0 24px;font-size:1.55rem;line-height:1.2}.about-copy p{margin:0 0 22px;font-size:1.05rem;line-height:1.8}.about-highlights{color:#fff;gap:12px;margin:30px 0 28px;padding-left:0;font-weight:700;line-height:1.35;list-style:none;display:grid}.about-highlights li{padding-left:4px}blockquote{color:#fff;text-align:left;margin:0;padding:4px 0 0;font-style:italic;font-weight:700}.project-grid,.skill-grid,.certificate-grid,.contact-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:28px;display:grid}.project-card,.skill-card,.certificate-card,.contact-card,.connect-panel,.timeline-card{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#11182794;border:1px solid #4b556394;border-radius:8px;box-shadow:0 22px 60px #00000038}.project-card{flex-direction:column;min-height:238px;padding:22px;transition:transform .18s,border-color .18s,background .18s;display:flex}.project-card:hover{background:#111827bd;border-color:#60a5fa80;transform:translateY(-5px)}.project-top,.job-heading,.contact-card h3{align-items:center;display:flex}.project-top{justify-content:space-between;min-height:42px;margin-bottom:26px}.project-top>svg{color:#60a5fa;width:26px;height:26px}.project-actions{gap:8px;display:flex}.project-actions a{color:#d1d5db;background:0 0;border-radius:6px;place-items:center;width:32px;height:28px;transition:color .18s,background .18s;display:grid}.project-actions a:hover,.project-actions a:focus-visible{color:#fff;background:#60a5fa29}.project-actions svg{width:17px;height:17px}.project-card h3{color:#fff;margin:0 0 10px;font-size:1rem}.project-card h4{color:#e5e7eb;margin:0 0 12px;font-size:.95rem;line-height:1.35}.project-card p{color:#9ca3af;flex:auto;margin:0;line-height:1.5}.tag-list{flex-wrap:wrap;gap:8px;margin-top:20px;display:flex}.tag-list span{color:#93c5fd;white-space:normal;background:#2563eb29;border-radius:999px;align-items:center;min-height:27px;padding:4px 11px;font-size:.82rem;line-height:1.15;display:inline-flex}.experience-section{width:min(1180px,100% - 48px)}.timeline{grid-template-columns:repeat(3,minmax(0,1fr));align-items:stretch;gap:28px;padding:6px 0;display:grid;position:relative}.timeline:before{content:"";background:linear-gradient(90deg,#0000,#60a5faa6,#0000);height:2px;position:absolute;top:41px;left:0;right:0}.timeline-card{z-index:1;flex-direction:column;padding:24px;display:flex;position:relative}.timeline-card:nth-child(odd),.timeline-card:nth-child(2n){justify-self:stretch}.job-heading{gap:16px;margin-bottom:14px}.job-heading>svg{color:#60a5fa;flex:none;width:24px;height:24px}.job-heading h3{color:#fff;margin:0;font-size:1.22rem;line-height:1.25}.job-heading p{color:#60a5fa;margin:2px 0 0}.timeline-card time{color:#d8b4fe;margin-bottom:14px;font-size:.9rem;display:block}.timeline-card>p{color:#d1d5db;flex:auto;margin:0;line-height:1.55}.timeline-card .tag-list{margin-top:22px}.skill-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.skill-card{padding:26px 22px 22px}.skill-card h3{color:#fff;text-align:center;margin:0 0 26px;font-size:1.25rem}.skill-list{gap:20px;display:grid}.skill-label{color:#e5e7eb;grid-template-columns:28px minmax(0,1fr) auto;align-items:center;gap:12px;margin-bottom:8px;display:grid}.skill-label svg{color:#93c5fd;width:22px;height:22px}.skill-label span{min-width:0}.skill-label strong{color:#d1d5db;font-size:.85rem}.skill-track{background:#374151cc;border-radius:999px;height:8px;overflow:hidden}.skill-track span{border-radius:inherit;will-change:width;background:linear-gradient(90deg,#3b82f6,#a855f7);height:100%;transition:width 1.2s cubic-bezier(.22,1,.36,1);display:block}.stack-section.is-visible .skill-track span{box-shadow:0 0 16px #60a5fa38}.certificate-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.certificate-card{--certificate-accent:#60a5fa;min-height:236px;color:inherit;flex-direction:column;padding:22px;text-decoration:none;transition:transform .18s,border-color .18s,background .18s;display:flex;position:relative;overflow:hidden}.certificate-card:before{content:"";border-top:3px solid var(--certificate-accent);opacity:.86;pointer-events:none;position:absolute;inset:0}.certificate-card:hover,.certificate-card:focus-visible{border-color:color-mix(in srgb, var(--certificate-accent) 62%, transparent);background:#111827bd;transform:translateY(-5px)}.certificate-provider{color:#e5e7eb;align-items:center;gap:12px;margin-bottom:26px;font-weight:700;display:flex}.certificate-logo{border:1px solid color-mix(in srgb, var(--certificate-accent) 54%, transparent);background:color-mix(in srgb, var(--certificate-accent) 16%, transparent);width:44px;height:44px;box-shadow:0 0 22px color-mix(in srgb, var(--certificate-accent) 18%, transparent);border-radius:8px;flex:none;place-items:center;display:grid}.certificate-logo svg{width:24px;height:24px;color:var(--certificate-accent)}.certificate-card h3{color:#fff;margin:0 0 14px;font-size:1rem;line-height:1.35}.certificate-card p{color:#9ca3af;flex:auto;margin:0;line-height:1.5}.certificate-link{color:#93c5fd;align-items:center;gap:8px;margin-top:24px;font-size:.88rem;font-weight:700;display:inline-flex}.certificate-link svg{width:15px;height:15px}.contact-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:start;gap:clamp(34px,8vw,92px)}.contact-card{padding:22px}.contact-card h3{color:#fff;gap:10px;margin:0 0 24px;font-size:1rem}.contact-card h3 svg{color:#60a5fa;width:22px;height:22px}.contact-card label{margin-bottom:18px;display:block}.contact-card label span{clip:rect(0, 0, 0, 0);width:1px;height:1px;position:absolute;overflow:hidden}.contact-card input,.contact-card textarea{box-sizing:border-box;color:#fff;width:100%;font:inherit;background:#1f29378c;border:1px solid #4b5563;border-radius:7px;outline:none;font-size:.94rem;transition:border-color .16s,box-shadow .16s}.contact-card input{min-height:38px;padding:8px 12px}.contact-card textarea{resize:vertical;min-height:68px;padding:11px 12px}.contact-card input::placeholder,.contact-card textarea::placeholder{color:#9ca3af}.contact-card input:focus,.contact-card textarea:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa26}.contact-card button{color:#fff;width:100%;min-height:38px;font:inherit;cursor:pointer;background:linear-gradient(90deg,#3b82f6,#a855f7);border:0;border-radius:7px;justify-content:center;align-items:center;gap:8px;font-size:.9rem;font-weight:700;transition:filter .16s,transform .16s;display:inline-flex}.contact-card button:hover,.contact-card button:focus-visible{filter:brightness(1.08);transform:translateY(-1px)}.contact-card button:disabled{cursor:progress;filter:grayscale(.25)brightness(.82);transform:none}.contact-card button svg{width:16px;height:16px}.form-note{color:#93c5fd;text-align:center;margin:14px 0 0;font-size:.88rem}.form-error{color:#fca5a5}.connect-panel{box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;background:0 0;border:0;padding:0}.bot-callout{text-align:center;justify-items:center;gap:18px;min-height:170px;margin-bottom:28px;display:grid}.bot-callout svg{color:#60a5fa;stroke-width:1.3px;filter:drop-shadow(0 0 20px #60a5fa47);width:132px;height:132px}.bot-callout p{color:#d1d5db;margin:0;font-size:1.08rem}.connect-links h3{color:#fff;text-align:center;margin:0 0 24px;font-size:1.28rem}.connect-links{gap:10px;display:grid}.connect-links a{color:#f8fafc;background:#1118278c;border:1px solid #4b55638c;border-radius:8px;align-items:center;gap:18px;min-height:62px;padding:14px 22px;text-decoration:none;transition:border-color .16s,background .16s,transform .16s;display:flex}.connect-links a:hover,.connect-links a:focus-visible{background:#111827c7;border-color:#60a5fa80;transform:translate(3px)}.connect-links svg{color:#60a5fa;flex:none;width:20px;height:20px}.connect-links span{overflow-wrap:anywhere;min-width:0}footer{color:#6b7280;text-align:center;margin-top:84px}.references-section{width:min(1120px,100% - 48px);margin:0 auto;padding:74px 0;overflow:hidden}.references-heading{margin-bottom:40px}.references-carousel{justify-content:center;align-items:center;min-height:420px;display:flex;position:relative}.reference-card{--card-offset:0px;--card-scale:1;--card-blur:0px;--card-opacity:1;--card-z:3;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);width:min(380px,78vw);min-height:180px;color:inherit;font:inherit;text-align:left;cursor:pointer;transform:translate(calc(-50% + var(--card-offset)), -50%) scale(var(--card-scale));filter:blur(var(--card-blur));opacity:var(--card-opacity);z-index:var(--card-z);pointer-events:var(--card-opacity-0,auto);background:#11182794;border:1px solid #4b556394;border-radius:8px;flex-direction:column;justify-content:space-between;padding:24px 22px 20px;transition:transform .6s cubic-bezier(.22,1,.36,1),filter .6s cubic-bezier(.22,1,.36,1),opacity .6s cubic-bezier(.22,1,.36,1),border-color .6s,background .6s,box-shadow .6s;display:flex;position:absolute;top:50%;left:50%;box-shadow:0 22px 60px #00000038}.reference-card.is-active{background:#111827c7;border-color:#60a5fa80;box-shadow:0 22px 60px #00000038,0 0 40px #60a5fa24}.reference-text{color:#d1d5db;margin:0 0 8px;font-size:.93rem;line-height:1.75}.reference-author{color:#60a5fa;text-align:right;border-top:1px solid #60a5fa59;padding-top:16px;font-size:.88rem;font-weight:700;display:block}.carousel-dots{justify-content:center;gap:10px;margin-top:20px;display:flex}.carousel-dots span{background:#4b556399;border-radius:50%;width:8px;height:8px;transition:background .3s,transform .3s}.carousel-dots span.is-active{background:#60a5fa;transform:scale(1.4)}@media (width<=900px){.references-carousel{height:380px}.reference-card{width:min(340px,74vw)}}@media (width<=560px){.references-section{width:calc(100% - 40px);padding:56px 0}.references-carousel{height:360px}.reference-card{width:min(300px,82vw);padding:20px 18px 16px}}@media (width<=900px){.section,.experience-section{width:min(100% - 42px,720px);padding:64px 0}.hero-section{min-height:100svh;padding-top:96px}.hero-section h1{letter-spacing:.13em}.about-grid,.project-grid,.skill-grid,.certificate-grid,.contact-grid{grid-template-columns:1fr}.about-grid{gap:48px}.about-copy{text-align:left}.timeline{grid-template-columns:1fr;gap:28px;padding-left:28px}.timeline:before{background:linear-gradient(#0000,#60a5faa6,#0000);width:2px;height:auto;inset:0 auto 0 9px;transform:none}.timeline-card,.timeline-card:nth-child(odd),.timeline-card:nth-child(2n){justify-self:stretch;width:auto}}@media (width<=560px){.section,.experience-section{width:calc(100% - 40px);padding:56px 0}.hero-section{min-height:100svh;padding:82px 20px 58px}.hero-content{transform:translateY(12px)}.hero-profile{width:104px;height:104px;margin-bottom:28px}.hero-kicker{font-size:1.45rem}.hero-section h1{letter-spacing:.11em;white-space:normal;overflow-wrap:anywhere;max-width:350px;margin-inline:auto;font-size:3.2rem}.hero-subtitle{margin-bottom:36px}.hero-icons{gap:34px;margin-bottom:34px}.hero-icons span{width:48px;height:48px}.hero-icons svg{width:28px;height:28px}.hero-role span{max-width:320px;margin:0 auto;line-height:1.55}.project-card,.skill-card,.certificate-card,.contact-card,.timeline-card{padding:22px}blockquote{text-align:left}.contact-grid{gap:38px}.bot-callout svg{width:108px;height:108px}.connect-links a{padding:14px 16px}footer{margin-top:62px;line-height:1.5}}@media (prefers-reduced-motion:reduce){.constellation-field__group,.constellation-field__sparks,.constellation-field__shards,.hero-icons span,.hero-icons svg,.skill-track span{transition:none;animation:none}}
