@import"https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=Outfit:wght@300;400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap";:root{--bg: #08080a;--bg-surface: #111114;--bg-card: #141417;--bg-card-hover: #1a1a1e;--border: rgba(255, 255, 255, .06);--border-strong: rgba(255, 255, 255, .12);--text: #e8e5e0;--text-muted: #8a8880;--text-dim: #4a4940;--accent: #56b8e6;--accent-dim: rgba(86, 184, 230, .08);--font-mono: "IBM Plex Mono", "Fira Code", monospace;--font-display: "Syne", sans-serif;--font-body: "Outfit", sans-serif}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth;color-scheme:dark;font-size:110%}body{margin:0;font-family:var(--font-body);background-color:var(--bg);background-image:radial-gradient(130% 80% at 50% -25%,rgba(86,184,230,.13) 0%,rgba(86,184,230,.05) 24%,transparent 60%);background-repeat:no-repeat;background-attachment:fixed;color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}body:after{content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.028;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:200px 200px}a{color:inherit;text-decoration:none}button{font-family:inherit}.container{max-width:1100px;margin:0 auto;padding:0 2rem}@keyframes fadeUp{0%{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideRight{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes growWidth{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.navbar{position:sticky;top:0;z-index:50;display:flex;justify-content:center;padding:1rem 1rem 0;pointer-events:none}.nav-island{pointer-events:auto;display:flex;align-items:center;gap:.6rem;width:100%;max-width:720px;padding:.45rem .5rem .45rem 1.15rem;border-radius:999px;border:1px solid var(--border-strong);background:#101014b8;backdrop-filter:blur(20px) saturate(1.6);-webkit-backdrop-filter:blur(20px) saturate(1.6);box-shadow:0 10px 34px #00000073,inset 0 1px #ffffff0d}.navbar-logo{font-family:var(--font-display);font-weight:700;font-size:1rem;letter-spacing:-.02em;margin-right:auto;white-space:nowrap}.navbar-logo span{color:var(--accent)}.navbar-links{display:flex;align-items:center;gap:.1rem}.nav-link{font-size:.84rem;font-weight:500;color:var(--text-muted);padding:.4rem .8rem;border-radius:999px;white-space:nowrap;transition:color .2s ease,background .2s ease,box-shadow .2s ease}.nav-link:hover{color:var(--text);background:#ffffff0d}.nav-link.is-active{color:var(--text);background:var(--accent-dim);box-shadow:inset 0 0 0 1px #56b8e638}.nav-link:focus-visible,.nav-cta:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.nav-cta{font-size:.82rem;font-weight:600;color:#0a0a0a;background:var(--accent);padding:.45rem 1.05rem;border-radius:999px;white-space:nowrap;transition:transform .2s ease,box-shadow .2s ease,opacity .2s ease}.nav-cta:hover{transform:translateY(-1px);box-shadow:0 6px 18px #56b8e64d;opacity:.95}@media(max-width:640px){.navbar{padding:.75rem .75rem 0}.nav-island{gap:.5rem;padding:.4rem .5rem .4rem 1rem}.navbar-links{display:none}}.hero-section{padding:5rem 0 4rem}.hero-label{font-family:var(--font-mono);font-size:.7rem;color:var(--accent);letter-spacing:.12em;text-transform:uppercase;margin-bottom:1.5rem;display:block;opacity:0;animation:slideRight .5s ease .15s forwards}.hero-top{display:grid;grid-template-columns:1fr auto;align-items:end;gap:3rem;margin-bottom:1.75rem}.hero-title{font-family:var(--font-display);font-size:clamp(2.2rem,5vw,3.8rem);font-weight:700;letter-spacing:-.01em;line-height:1.1;margin:0;color:var(--text);opacity:0;animation:fadeUp .6s ease .25s forwards}.hero-photo-wrap{width:clamp(130px,16vw,200px);flex-shrink:0;align-self:flex-end;opacity:0;animation:scaleIn .5s ease .4s forwards}.hero-photo{width:100%;aspect-ratio:1 / 1;object-fit:cover;display:block;border-radius:8px;filter:grayscale(20%) contrast(1.08);box-shadow:0 8px 32px #0006}.hero-divider{height:1px;background:var(--border-strong);margin-bottom:1.75rem;transform-origin:left;animation:growWidth .6s ease .5s both}.hero-bottom{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;opacity:0;animation:fadeUp .5s ease .6s forwards}.hero-desc{font-size:1.05rem;color:var(--text-muted);max-width:440px;line-height:1.7;margin:0;font-weight:400}.hero-ctas{display:flex;gap:.75rem;flex-shrink:0;align-items:center}@media(max-width:760px){.hero-section{padding:3.5rem 0 2.5rem}.hero-top{grid-template-columns:1fr;gap:1.25rem;text-align:center}.hero-photo-wrap{width:120px;order:-1;justify-self:center}.hero-bottom{flex-direction:column;align-items:flex-start;gap:1.5rem}.hero-title{font-size:clamp(2rem,10vw,3.2rem)}}.btn-primary{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1.35rem;background:var(--accent);color:#0a0a0a;font-weight:700;font-size:.85rem;border-radius:6px;border:none;cursor:pointer;transition:opacity .2s ease,transform .2s ease,box-shadow .2s ease;letter-spacing:-.01em;white-space:nowrap;font-family:var(--font-body)}.btn-primary:hover{opacity:.9;transform:translateY(-2px);box-shadow:0 6px 24px #56b8e640,0 0 0 1px #56b8e61a}.btn-ghost{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1.35rem;background:transparent;color:var(--text-muted);font-weight:500;font-size:.85rem;border-radius:6px;border:1px solid var(--border-strong);cursor:pointer;transition:color .2s ease,border-color .2s ease,transform .2s ease;letter-spacing:-.01em;white-space:nowrap;font-family:var(--font-body)}.btn-ghost:hover{color:var(--text);border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 16px #56b8e614}.section-label{font-family:var(--font-mono);font-size:.68rem;color:var(--accent);text-transform:uppercase;letter-spacing:.15em;margin-bottom:.6rem;display:block;opacity:.85}.section-heading{font-family:var(--font-display);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:700;letter-spacing:-.01em;margin:0 0 2.25rem;line-height:1.1;text-transform:uppercase}.skills-section{padding:5rem 0;border-top:1px solid var(--border)}.skills-rows{display:flex;flex-direction:column}.skills-row{display:grid;grid-template-columns:160px 1fr;align-items:start;padding:1.5rem 0;border-top:1px solid var(--border);gap:2.5rem}.skills-row:last-child{border-bottom:1px solid var(--border)}.skills-category{font-size:.68rem;font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin:0;padding-top:.3rem;font-family:var(--font-mono)}.skills-items{display:flex;flex-wrap:wrap;gap:.4rem .5rem}.skill-item{display:flex;align-items:center;gap:.4rem;padding:.3rem .7rem;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;font-size:.88rem;font-weight:500;color:var(--text-muted);transition:color .25s ease,border-color .25s ease,background .25s ease,transform .25s ease,box-shadow .25s ease}.skill-item:hover{color:var(--text);border-color:#56b8e64d;background:var(--bg-surface);transform:translateY(-2px);box-shadow:0 4px 12px #0003,0 0 0 1px #56b8e614}.skill-icon{font-size:.95rem;line-height:1;display:flex;align-items:center}@media(max-width:700px){.skills-row{grid-template-columns:1fr;gap:1rem;padding:1.25rem 0}}.experience-section{padding:3.5rem 0;border-top:1px solid var(--border)}.experience-list{display:flex;flex-direction:column}.experience-entry{display:grid;grid-template-columns:168px 1fr;gap:2rem;padding:1.25rem 1rem;margin:0 -1rem;border-top:1px solid var(--border);border-radius:8px;transition:background .3s ease}.experience-entry:hover{background:#ffffff04}.experience-entry:last-child{border-bottom:1px solid var(--border)}.exp-company-block{padding-top:.05rem}.exp-company-name{font-family:var(--font-display);font-size:1rem;font-weight:700;margin:0 0 .2rem;color:var(--text);letter-spacing:0}.exp-company-link{display:inline-block;transition:color .2s ease}.exp-company-link:hover{color:var(--accent)}.exp-duration{font-family:var(--font-mono);font-size:.72rem;color:var(--accent);margin:0 0 .15rem;opacity:.85}.exp-location{font-size:.78rem;color:var(--text-dim);margin:0}.exp-roles{display:flex;flex-direction:column;gap:.7rem}.exp-role{display:flex;flex-direction:column;gap:.3rem}.exp-role-head{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;flex-wrap:wrap}.exp-role-title{font-size:.92rem;font-weight:600;margin:0;color:var(--text)}.exp-role-date{font-family:var(--font-mono);font-size:.66rem;color:var(--text-muted);margin:0;white-space:nowrap}.exp-skills{display:flex;gap:.3rem;flex-wrap:wrap}.exp-skill-tag{font-size:.64rem;padding:.1rem .5rem;border-radius:4px;background:var(--accent-dim);color:var(--accent);font-weight:500;font-family:var(--font-mono);border:1px solid rgba(86,184,230,.15)}@media(max-width:640px){.experience-entry{grid-template-columns:1fr;gap:.75rem;padding:1.25rem 1rem;margin:0 -1rem}.exp-role-head{gap:.5rem}}.projects-section{padding:5rem 0;border-top:1px solid var(--border)}.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.75rem}.project-card{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;overflow:hidden;transition:transform .35s cubic-bezier(.4,0,.2,1),border-color .35s ease,box-shadow .35s ease}.project-card:hover{transform:translateY(-6px);border-color:#56b8e659;box-shadow:0 18px 44px #00000059,0 0 0 1px #56b8e61f}.project-card:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.project-frame-bar{display:flex;align-items:center;gap:.4rem;padding:.6rem .9rem;background:var(--bg-surface);border-bottom:1px solid var(--border)}.project-dot{width:9px;height:9px;border-radius:50%;background:var(--text-dim);opacity:.6;flex-shrink:0}.project-dot:first-child{background:var(--accent);opacity:.55}.project-url{margin-left:.6rem;flex:1;min-width:0;font-family:var(--font-mono);font-size:.68rem;color:var(--text-muted);background:var(--bg);padding:.22rem .7rem;border-radius:999px;border:1px solid var(--border);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-shot{position:relative;aspect-ratio:16 / 10;background:linear-gradient(135deg,#15151b,#0b0b0e);overflow:hidden}.project-shot img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;transition:transform .5s cubic-bezier(.4,0,.2,1)}.project-card:hover .project-shot img{transform:scale(1.04)}.project-visit{position:absolute;left:50%;bottom:1rem;transform:translate(-50%,8px);display:inline-flex;align-items:center;gap:.4rem;font-family:var(--font-body);font-weight:600;font-size:.78rem;color:#0a0a0a;background:var(--accent);padding:.45rem 1rem;border-radius:999px;opacity:0;box-shadow:0 6px 18px #56b8e659;transition:opacity .3s ease,transform .3s ease}.project-card:hover .project-visit{opacity:1;transform:translate(-50%)}.project-body{display:flex;flex-direction:column;gap:.6rem;padding:1.25rem 1.3rem 1.4rem;flex:1}.project-head{display:flex;align-items:center;justify-content:space-between;gap:1rem}.project-title{font-family:var(--font-display);font-size:1.15rem;font-weight:700;margin:0;color:var(--text);transition:color .2s ease}.project-card:hover .project-title{color:var(--accent)}.project-arrow{display:flex;flex-shrink:0;color:var(--text-dim);font-size:1.05rem;transition:color .2s ease,transform .2s ease}.project-card:hover .project-arrow{color:var(--accent);transform:translate(2px,-2px)}.project-desc{font-size:.88rem;color:var(--text-muted);line-height:1.6;margin:0;flex:1}.project-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.2rem}.project-tag{font-family:var(--font-mono);font-size:.64rem;padding:.18rem .55rem;border-radius:4px;color:var(--text-muted);border:1px solid var(--border)}.project-badge{font-family:var(--font-mono);font-size:.64rem;padding:.18rem .55rem;border-radius:4px;color:var(--accent);background:var(--accent-dim);border:1px solid rgba(86,184,230,.18);font-weight:600}@media(max-width:760px){.projects-grid{grid-template-columns:1fr;gap:1.5rem}}.contact-section{padding:5rem 0;border-top:1px solid var(--border)}.contact-desc{font-size:1.05rem;color:var(--text-muted);max-width:480px;line-height:1.7;margin:0 0 2rem}.contact-ctas{display:flex;gap:.75rem;align-items:center}.footer{padding:2.5rem 0;border-top:1px solid var(--border);margin-top:1rem}.footer-inner{display:flex;justify-content:space-between;align-items:center;gap:2rem}.footer-links{display:flex;gap:.2rem;flex-wrap:wrap}.footer-link{display:inline-flex;align-items:center;gap:.4rem;font-size:.88rem;font-weight:500;color:var(--text-dim);padding:.3rem .65rem;border-radius:6px;transition:color .25s ease,background .25s ease,transform .25s ease}.footer-link-icon{font-size:.95rem;display:flex;align-items:center}.footer-link:hover{color:var(--accent);background:#ffffff08;transform:translateY(-1px)}.footer-copy{font-size:.72rem;color:var(--text-dim);font-family:var(--font-mono);white-space:nowrap;margin:0}@media(max-width:600px){.footer-inner{flex-direction:column;text-align:center;gap:1rem}.footer-links{justify-content:center}}@supports (animation-timeline: view()){.skills-section,.experience-section,.projects-section{animation:fadeUp .8s ease both;animation-timeline:view();animation-range:entry 0% entry 25%}}
