body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--bg:#0a0a0f;--bg3:#18181f;--accent:#6c63ff;--accent2:#ff6584;--text:#f0eeff;--muted:#8b87aa;--border:#6c63ff2e;--card:#ffffff08}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:#0a0a0f;background:var(--bg);color:#f0eeff;color:var(--text);font-family:DM Sans,sans-serif;line-height:1.7;overflow-x:hidden}.divider{background:linear-gradient(90deg,#0000,#6c63ff2e,#0000);background:linear-gradient(90deg,#0000,var(--border),#0000);height:.5px;margin:0 3rem;max-width:calc(100% - 6rem)}@media (max-width:768px){.divider{margin:0 1.5rem;max-width:calc(100% - 3rem)}}.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}.revealed{opacity:1;transform:none}section{margin:0 auto;max-width:1100px;padding:5rem 3rem}@media (max-width:768px){section{padding:5rem 1.5rem 3rem}}.section-label{align-items:center;color:#6c63ff;color:var(--accent);display:flex;font-size:.7rem;font-weight:500;gap:.5rem;letter-spacing:.18em;margin-bottom:.6rem;text-transform:uppercase}.section-label:before{background:#6c63ff;background:var(--accent);content:"";display:inline-block;height:1px;width:20px}h2{color:#f0eeff;color:var(--text);font-family:Syne,sans-serif;font-size:clamp(1.8rem,4vw,2.6rem);font-weight:700;letter-spacing:-.025em;margin-bottom:2.5rem}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#0a0a0f;background:var(--bg)}::-webkit-scrollbar-thumb{background:#6c63ff;background:var(--accent);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ff6584;background:var(--accent2)}nav{align-items:center;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#0a0a0fe6;border-bottom:.5px solid var(--border);display:flex;justify-content:space-between;left:0;padding:1rem 3rem;position:fixed;right:0;top:0;transition:all .3s ease;z-index:100}nav.scrolled{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0a0a0ff2;padding:.7rem 3rem}.nav-logo{color:var(--text);font-family:Syne,sans-serif;font-size:1.2rem;font-weight:800;text-decoration:none;transition:color .2s}.nav-logo span,.nav-logo:hover{color:var(--accent)}.nav-links{display:flex;gap:1.8rem;list-style:none}.nav-links a{color:var(--muted);font-size:.82rem;font-weight:500;letter-spacing:.05em;position:relative;text-decoration:none;text-transform:uppercase;transition:color .2s}.nav-links a:after{background:var(--accent);bottom:-5px;content:"";height:2px;left:0;position:absolute;transition:width .3s ease;width:0}.nav-links a:hover:after{width:100%}.nav-links a:hover{color:var(--text)}.burger{background:none;border:none;cursor:pointer;display:none;flex-direction:column;gap:5px;padding:4px;z-index:200}.burger span{background:var(--text);border-radius:2px;display:block;height:2px;transition:transform .3s,opacity .3s;width:22px}.burger.open span:first-child{transform:translateY(7px) rotate(45deg)}.burger.open span:nth-child(2){opacity:0}.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.mobile-menu{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0a0a0ff7;bottom:0;display:none;flex-direction:column;gap:2.5rem;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:99}.mobile-menu.open{display:flex}.mobile-menu a{color:var(--muted);font-family:Syne,sans-serif;font-size:1.5rem;font-weight:700;letter-spacing:.1em;text-decoration:none;text-transform:uppercase;transition:color .2s,transform .2s}.mobile-menu a:hover{color:var(--accent);transform:translateX(5px)}@media (max-width:768px){nav{padding:1rem 1.5rem}nav.scrolled{padding:.7rem 1.5rem}.nav-links{display:none}.burger{display:flex}}#hero{align-items:center;display:flex;min-height:100vh;overflow:hidden;padding:7rem 3rem 4rem;position:relative}.hero-bg{background:radial-gradient(ellipse 60% 50% at 70% 50%,#6c63ff1f 0,#0000 70%),radial-gradient(ellipse 30% 30% at 85% 20%,#ff658412 0,#0000 60%);inset:0;pointer-events:none;position:absolute}.hero-grid{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 360px;margin:0 auto;max-width:1100px;width:100%}.hero-eyebrow{align-items:center;color:var(--accent);display:flex;font-size:.76rem;font-weight:500;gap:.6rem;letter-spacing:.15em;margin-bottom:1rem;text-transform:uppercase}.hero-eyebrow:before{background:var(--accent);content:"";display:inline-block;height:1px;width:28px}h1{color:var(--text);font-family:Syne,sans-serif;font-size:clamp(2.6rem,5.5vw,4.8rem);font-weight:800;letter-spacing:-.03em;line-height:1.05;margin-bottom:1.5rem}h1 .outline{-webkit-text-stroke:1.5px var(--accent);color:#0000}.hero-desc{color:var(--muted);font-size:1rem;font-weight:300;line-height:1.85;margin-bottom:2.5rem;max-width:480px}.hero-ctas{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}.btn-primary{align-items:center;background:var(--accent);border:none;border-radius:50px;color:#fff;cursor:pointer;display:inline-flex;font-family:DM Sans,sans-serif;font-size:.88rem;font-weight:500;gap:.5rem;padding:.75rem 1.75rem;text-decoration:none;transition:opacity .2s,transform .2s}.btn-primary:hover{opacity:.88;transform:translateY(-2px)}.btn-outline{align-items:center;background:#0000;border:1px solid var(--border);border-radius:50px;color:var(--text);cursor:pointer;display:inline-flex;font-family:DM Sans,sans-serif;font-size:.88rem;font-weight:500;gap:.5rem;padding:.75rem 1.75rem;text-decoration:none;transition:border-color .2s,transform .2s}.btn-outline:hover{border-color:var(--accent);transform:translateY(-2px)}.hero-socials{display:flex;gap:1rem}.social-btn{align-items:center;background:var(--card);border:.5px solid var(--border);border-radius:50%;color:var(--muted);display:inline-flex;font-size:.95rem;height:38px;justify-content:center;text-decoration:none;transition:border-color .2s,color .2s,transform .2s;width:38px}.social-btn:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}.hero-photo-wrap{display:flex;justify-content:center;position:relative}.hero-photo-bg{animation:morph 8s ease-in-out infinite alternate;background:linear-gradient(135deg,#6c63ff40,#ff65841f);border-radius:30% 70% 70% 30%/30% 30% 70% 70%;inset:-20px;position:absolute}@keyframes morph{0%{border-radius:30% 70% 70% 30%/30% 30% 70% 70%}50%{border-radius:60% 40% 30% 70%/60% 30% 70% 40%}to{border-radius:40% 60% 60% 40%/40% 60% 40% 60%}}.hero-photo{border:1px solid #6c63ff4d;border-radius:24px;filter:grayscale(15%);height:360px;object-fit:cover;object-position:top center;position:relative;width:300px;z-index:1}@media (max-width:768px){#hero{padding:5rem 1.5rem 3rem}.hero-grid{gap:2rem;grid-template-columns:1fr}.hero-photo-wrap{display:none}.hero-desc{font-size:.95rem}.hero-ctas{gap:.8rem}.btn-outline,.btn-primary{font-size:.85rem;padding:.6rem 1.4rem}}.about-grid{grid-gap:3rem;align-items:start;display:grid;gap:3rem;grid-template-columns:240px 1fr}.about-photo{aspect-ratio:3/4;border:1px solid var(--border);border-radius:20px;filter:grayscale(15%);object-fit:cover;object-position:top;width:100%}.about-text{color:var(--muted);font-size:.95rem;line-height:1.9}.about-text span{color:var(--accent);font-weight:500}.about-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:1.5rem}.about-tag{background:var(--card);border:.5px solid var(--border);border-radius:50px;color:var(--muted);font-size:.76rem;font-weight:500;padding:4px 12px}@media (max-width:768px){.about-grid{grid-template-columns:1fr}.about-photo{margin:0 auto;max-width:180px}}.edu-list{display:flex;flex-direction:column;gap:1rem}.edu-card{align-items:center;background:var(--card);border:.5px solid var(--border);border-radius:14px;display:flex;gap:1.5rem;padding:1.25rem 1.5rem;transition:border-color .2s,transform .2s}.edu-card:hover{border-color:#6c63ff66;transform:translateX(4px)}.edu-year{background:#6c63ff14;border-radius:8px;color:var(--accent);font-family:Syne,sans-serif;font-size:.82rem;font-weight:700;min-width:52px;padding:6px 8px;text-align:center}.edu-info{flex:1 1}.edu-degree{color:var(--text);font-size:.95rem;font-weight:500;margin-bottom:2px}.edu-school{color:var(--muted);font-size:.82rem}.edu-uni{color:#6c63ffb3;font-size:.74rem;margin-top:2px}.edu-score{color:#4ade80;font-family:Syne,sans-serif;font-size:1rem;font-weight:700;white-space:nowrap}@media (max-width:768px){.edu-card{align-items:flex-start;flex-direction:column;gap:.8rem}.edu-score,.edu-year{align-self:flex-start}}.skills-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.skill-card{background:var(--card);border:.5px solid var(--border);border-radius:14px;padding:1.25rem;transition:border-color .2s,transform .2s}.skill-card:hover{border-color:#6c63ff80;transform:translateY(-3px)}.skill-card.highlight{background:#6c63ff0d;border-color:#6c63ff59}.skill-cat{align-items:center;color:var(--accent);display:flex;font-size:.68rem;font-weight:500;gap:.4rem;letter-spacing:.12em;margin-bottom:.7rem;text-transform:uppercase}.skill-cat .star{color:#4ade80;font-size:.62rem}.skill-tags{display:flex;flex-wrap:wrap;gap:6px}.skill-tag{background:#6c63ff1a;border:.5px solid #6c63ff33;border-radius:50px;color:#c4c0ff;font-size:.76rem;padding:3px 10px}.skill-tag.green{background:#4ade8014;border-color:#4ade8033;color:#86efac}@media (max-width:768px){.skills-grid{grid-template-columns:1fr}}.exp-list{display:flex;flex-direction:column;gap:1.5rem}.exp-card{background:var(--card);border:.5px solid var(--border);border-left:3px solid var(--accent);border-radius:0 14px 14px 0;padding:1.5rem 1.75rem;transition:transform .2s,border-left-color .2s}.exp-card:hover{border-left-color:var(--accent2);transform:translateX(4px)}.exp-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:space-between;margin-bottom:.3rem}.exp-title{color:var(--text);font-family:Syne,sans-serif;font-size:1.05rem;font-weight:700;margin-bottom:.25rem}.exp-company{color:var(--accent);font-size:.85rem;font-weight:500;margin-bottom:.2rem}.exp-period{background:#6c63ff14;border:.5px solid var(--border);border-radius:50px;color:var(--muted);font-size:.73rem;padding:3px 10px;white-space:nowrap}.exp-bullets{color:var(--muted);font-size:.88rem;margin-top:.75rem;padding-left:1.2rem}.exp-bullets li{line-height:1.6;margin-bottom:.35rem}@media (max-width:768px){.exp-card{padding:1.2rem}.exp-header{flex-direction:column}.exp-period{align-self:flex-start}.exp-bullets{padding-left:1rem}.exp-bullets li{font-size:.85rem}}.proj-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.proj-card{background:var(--card);border:.5px solid var(--border);border-radius:18px;display:flex;flex-direction:column;gap:.75rem;overflow:hidden;padding:1.75rem;position:relative;transition:border-color .2s,transform .2s}.proj-card:before{background:linear-gradient(90deg,var(--accent),var(--accent2));content:"";height:3px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .2s}.proj-card:hover{border-color:#6c63ff66;transform:translateY(-4px)}.proj-card:hover:before{opacity:1}.proj-subtitle{color:var(--accent);font-size:.82rem;font-weight:500;letter-spacing:.02em}.proj-name{color:var(--text);font-family:Syne,sans-serif;font-size:1.05rem;font-weight:700}.proj-desc{color:var(--muted);font-size:.87rem;line-height:1.7;margin:.25rem 0}.proj-tech{display:flex;flex-wrap:wrap;gap:6px;margin-top:.25rem}.tech-tag{background:#ff658414;border:.5px solid #ff658433;border-radius:50px;color:#ffb3c4;font-size:.72rem;font-weight:500;padding:2px 9px;transition:all .2s}.tech-tag:hover{background:#ff658426;transform:translateY(-1px)}.proj-links{display:flex;gap:.75rem;margin-top:.5rem}.proj-link{border:.5px solid;border-radius:50px;font-size:.78rem;font-weight:500;padding:4px 12px;text-decoration:none;transition:opacity .2s,transform .2s}.proj-link.demo{background:#6c63ff26;border-color:#6c63ff4d;color:#c4c0ff}.proj-link.code{background:#ffffff0a;border-color:var(--border);color:var(--muted)}.proj-link:hover{opacity:.75;transform:translateY(-1px)}@media (max-width:768px){.proj-grid{gap:1.2rem;grid-template-columns:1fr}.proj-card{padding:1.4rem}}.cert-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.cert-card{align-items:flex-start;background:var(--card);border:.5px solid var(--border);border-radius:14px;color:var(--text);display:flex;gap:1rem;padding:1.25rem;text-decoration:none;transition:border-color .2s,transform .2s}.cert-card:hover{border-color:#6c63ff66;transform:translateY(-2px)}.cert-icon{align-items:center;border-radius:10px;display:flex;flex-shrink:0;font-size:1.2rem;height:42px;justify-content:center;width:42px}.cert-icon.g{background:#4285f426}.cert-icon.o{background:#ff50001a}.cert-icon.u{background:#ea5b0c26}.cert-name{color:var(--text);font-size:.88rem;font-weight:500;line-height:1.4}.cert-issuer{color:var(--muted);font-size:.74rem;margin-top:3px}.cert-link{color:var(--accent);display:inline-block;font-size:.72rem;margin-top:5px}.contact-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.contact-card{align-items:center;background:var(--card);border:.5px solid var(--border);border-radius:14px;color:var(--text);display:flex;gap:1rem;padding:1.25rem 1.5rem;text-decoration:none;transition:border-color .2s,transform .2s}.contact-card:hover{border-color:#6c63ff80;transform:translateY(-2px)}.contact-icon{align-items:center;background:#6c63ff1f;border-radius:10px;color:var(--accent);display:flex;flex-shrink:0;font-size:1.1rem;height:40px;justify-content:center;width:40px}.contact-label{color:var(--muted);font-size:.7rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase}.contact-val{color:var(--text);font-size:.88rem}@media (max-width:768px){.contact-grid{grid-template-columns:1fr}}footer{border-top:.5px solid var(--border);color:var(--muted);font-size:.8rem;padding:2.5rem 3rem;text-align:center}footer span{color:var(--accent);font-weight:500}@media (max-width:768px){footer{font-size:.75rem;padding:2rem 1.5rem}}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.8f07e1a5.css.map*/