@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(ellipse at 12% 25%,rgba(86,184,230,.045) 0%,transparent 55%),radial-gradient(ellipse at 88% 75%,rgba(86,184,230,.025) 0%,transparent 50%);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}.bg-lines{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}.bg-line{position:absolute;top:0;width:1px;height:100%;background:#ffffff08}.bg-line:after{content:"";position:absolute;top:-20vh;left:0;width:100%;height:12vh;background:linear-gradient(180deg,transparent 0%,var(--accent) 50%,transparent 100%);opacity:.15;animation:lineFall var(--line-duration, 8s) linear var(--line-delay, 0s) infinite}@keyframes lineFall{0%{top:-12vh}to{top:110vh}}@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;border-bottom:1px solid var(--border);backdrop-filter:blur(24px) saturate(1.4);-webkit-backdrop-filter:blur(24px) saturate(1.4);background:#08080acc}.navbar-inner{display:flex;justify-content:space-between;align-items:center;height:4rem}.navbar-logo{font-family:var(--font-display);font-weight:700;font-size:1.05rem;letter-spacing:-.02em}.navbar-logo span{color:var(--accent)}.navbar-links{display:flex;align-items:center;gap:.15rem}.nav-link{font-size:.88rem;font-weight:500;color:var(--text-muted);padding:.4rem .85rem;border-radius:6px;transition:color .25s ease,background .25s ease;position:relative}.nav-link:after{content:"";position:absolute;bottom:4px;left:.85rem;right:.85rem;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:right;transition:transform .3s cubic-bezier(.4,0,.2,1)}.nav-link:hover{color:var(--text);background:#ffffff0a}.nav-link:hover:after{transform:scaleX(1);transform-origin:left}@media(max-width:600px){.navbar-inner{justify-content:center}.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);border-left:3px solid var(--accent);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:5rem 0;border-top:1px solid var(--border)}.experience-list{display:flex;flex-direction:column}.experience-entry{display:grid;grid-template-columns:190px 1fr;gap:2.5rem;padding:2rem 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:.1rem}.exp-company-name{font-family:var(--font-display);font-size:1.05rem;font-weight:700;margin:0 0 .3rem;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:.75rem;color:var(--accent);margin:0 0 .25rem;opacity:.85}.exp-location{font-size:.82rem;color:var(--text-dim);margin:0}.exp-roles{display:flex;flex-direction:column;gap:1.25rem}.exp-role{display:flex;flex-direction:column;gap:.25rem}.exp-role-title{font-size:.98rem;font-weight:600;margin:0;color:var(--text)}.exp-role-date{font-family:var(--font-mono);font-size:.68rem;color:var(--text-muted);margin:0}.exp-skills{display:flex;gap:.35rem;flex-wrap:wrap;margin-top:.3rem}.exp-skill-tag{font-size:.68rem;padding:.15rem .55rem;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:1rem;padding:1.5rem 1rem;margin:0 -1rem}}.projects-section{padding:5rem 0;border-top:1px solid var(--border)}.projects-list{display:flex;flex-direction:column}.project-link-wrap{text-decoration:none;color:inherit;display:block}.project-row{display:grid;grid-template-columns:3rem 1fr auto;align-items:center;gap:2.5rem;padding:2rem 1rem;border-top:1px solid var(--border);border-radius:8px;margin:0 -1rem;transition:background .3s ease,border-color .3s ease,box-shadow .3s ease;position:relative}.project-row:before{content:"";position:absolute;top:0;left:0;width:2px;height:100%;background:var(--accent);border-radius:1px;transform:scaleY(0);transform-origin:top;transition:transform .35s cubic-bezier(.4,0,.2,1)}.projects-list>*:last-child .project-row{border-bottom:1px solid var(--border)}.project-link-wrap:hover .project-row{background:#ffffff06;box-shadow:0 4px 20px #00000026}.project-link-wrap:hover .project-row:before{transform:scaleY(1)}.project-link-wrap:hover .project-row-title{color:var(--accent)}.project-num{font-family:var(--font-mono);font-size:.68rem;color:var(--text-dim);align-self:start;padding-top:3px}.project-info{display:flex;flex-direction:column;gap:.5rem}.project-row-title{font-family:var(--font-display);font-size:1.15rem;font-weight:700;margin:0;color:var(--text);letter-spacing:0;transition:color .2s ease}.project-row-desc{font-size:.9rem;color:var(--text-muted);line-height:1.6;margin:0}.project-meta{display:flex;align-items:center;gap:1.5rem;flex-shrink:0}.project-tags{display:flex;gap:.35rem;flex-wrap:wrap;justify-content:flex-end}.project-tag{font-size:.65rem;padding:.18rem .55rem;border-radius:4px;background:transparent;color:var(--text-dim);font-weight:500;font-family:var(--font-mono);border:1px solid var(--border)}.project-arrow{color:var(--text-dim);font-size:1rem;flex-shrink:0;transition:color .2s ease,transform .2s ease;line-height:1}.project-link-wrap:hover .project-arrow{color:var(--accent);transform:translate(2px,-2px)}.project-badge{display:inline-flex;align-items:center;gap:.3rem;font-size:.65rem;padding:.18rem .6rem;border-radius:4px;background:var(--accent-dim);color:var(--accent);font-weight:600;font-family:var(--font-mono);border:1px solid rgba(86,184,230,.18);white-space:nowrap;flex-shrink:0}@media(max-width:700px){.project-row{grid-template-columns:2.5rem 1fr;gap:1.25rem;row-gap:.75rem;padding:1.75rem 1rem;margin:0 -1rem}.project-meta{grid-column:2;justify-content:flex-start;gap:1rem}}@media(max-width:480px){.project-num{display:none}.project-row{grid-template-columns:1fr;padding:1.75rem 1rem;margin:0 -1rem}.project-meta{grid-column:1}.project-tag.hide-mobile{display:none}}.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%}}
