:root{--bg: #0a0c12;--bg-alt: #0e1119;--surface: #151a24;--surface-hover: #1c2330;--border: rgba(232, 224, 210, .08);--border-strong: rgba(232, 224, 210, .16);--text: #ede8e0;--text-secondary: #a8a098;--text-muted: #6b6860;--accent: #e07a5f;--accent-soft: #e07a5f33;--accent-glow: rgba(224, 122, 95, .25);--teal: #4a9e8e;--teal-soft: rgba(74, 158, 142, .15);--font-serif: "Instrument Serif", Georgia, serif;--font-sans: "Outfit", system-ui, sans-serif;--font-mono: "IBM Plex Mono", ui-monospace, monospace;--max-w: 1120px;--header-h: 68px;--section-pad: clamp(5rem, 10vw, 7rem);--radius: 8px;--radius-lg: 12px;--ease: cubic-bezier(.25, .1, .25, 1);--ease-out: cubic-bezier(.16, 1, .3, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;scroll-padding-top:var(--header-h);-webkit-font-smoothing:antialiased}.hero[id],.section[id]{scroll-margin-top:var(--header-h)}body{font-family:var(--font-sans);font-size:16px;line-height:1.6;color:var(--text);background:var(--bg);overflow-x:hidden}a{color:inherit;text-decoration:none}button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}ul{list-style:none}img,svg{display:block}.app{position:relative}.ambient{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}.ambient-orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:.45}.ambient-orb--1{width:55vw;height:55vw;top:-15%;right:-10%;background:radial-gradient(circle,var(--accent-glow),transparent 70%);animation:drift 22s ease-in-out infinite alternate}.ambient-orb--2{width:40vw;height:40vw;bottom:10%;left:-12%;background:radial-gradient(circle,var(--teal-soft),transparent 70%);animation:drift 28s ease-in-out infinite alternate-reverse}.ambient-grid{position:absolute;inset:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:72px 72px;mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,black 20%,transparent 80%);-webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,black 20%,transparent 80%)}@keyframes drift{0%{transform:translate(0) scale(1)}to{transform:translate(4%,6%) scale(1.08)}}.app>main,.app>footer{position:relative;z-index:1}.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 clamp(1.25rem,4vw,2rem)}.section{padding:var(--section-pad) 0}.section--alt{background:var(--bg-alt)}.section-header{display:flex;align-items:flex-start;gap:1.5rem;margin-bottom:3rem}.section-number{font-family:var(--font-serif);font-size:clamp(3rem,8vw,5rem);font-weight:400;line-height:.85;color:var(--border-strong);-webkit-user-select:none;user-select:none;flex-shrink:0}.section-title{font-family:var(--font-serif);font-size:clamp(1.75rem,4vw,2.5rem);font-weight:400;letter-spacing:-.01em;line-height:1.15}.section-description{margin-top:.75rem;max-width:50ch;color:var(--text-secondary);font-size:1.05rem;line-height:1.7}.btn{display:inline-flex;align-items:center;gap:.45rem;padding:.7rem 1.35rem;font-size:.875rem;font-weight:500;letter-spacing:.01em;border-radius:var(--radius);transition:all .25s var(--ease);white-space:nowrap}.btn svg{width:14px;height:14px}.btn--primary{background:var(--accent);color:#fff}.btn--primary:hover{background:#e89078;transform:translateY(-1px);box-shadow:0 8px 24px var(--accent-glow)}.btn--ghost{border:1px solid var(--border-strong);color:var(--text-secondary)}.btn--ghost:hover{color:var(--text);border-color:var(--text-muted);background:var(--surface)}.header{position:fixed;top:0;left:0;right:0;z-index:200;height:var(--header-h);background:#0a0c12e6;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border)}.header-inner{display:flex;align-items:center;justify-content:space-between;height:100%;max-width:var(--max-w);margin:0 auto;padding:0 clamp(1.25rem,4vw,2rem)}.header-logo{font-family:var(--font-serif);font-size:1.05rem;font-weight:400;letter-spacing:.01em;transition:color .2s var(--ease)}.header-logo:hover{color:var(--accent)}.header-nav{display:flex;align-items:center;gap:.15rem;padding:.3rem;background:#151a2499;border:1px solid var(--border);border-radius:100px}.header-nav-link{display:flex;align-items:center;gap:.35rem;padding:.4rem .85rem;font-size:.8rem;font-weight:500;color:var(--text-muted);border-radius:100px;transition:all .2s var(--ease)}.header-nav-num{font-family:var(--font-mono);font-size:.65rem;opacity:.5}.header-nav-link:hover{color:var(--text-secondary);background:var(--surface)}.header-nav-link--active{color:var(--text);background:var(--surface-hover)}.header-nav-link--active .header-nav-num{color:var(--accent);opacity:1}.header-nav-link--resume{color:var(--accent);margin-left:.15rem}.header-nav-link--resume:hover{background:var(--accent-soft);color:var(--accent)}.header-menu-btn{display:none;flex-direction:column;justify-content:center;gap:6px;width:36px;height:36px;padding:8px}.header-menu-btn span{display:block;height:2px;background:var(--text);border-radius:1px;transition:transform .25s var(--ease)}.header-menu-btn--open span:first-child{transform:translateY(4px) rotate(45deg)}.header-menu-btn--open span:last-child{transform:translateY(-4px) rotate(-45deg)}.header-mobile-nav{display:none}.hero{position:relative;display:flex;flex-direction:column;justify-content:center;min-height:100svh;padding:calc(var(--header-h) + 2rem) clamp(1.25rem,4vw,2rem) 4rem}.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,6vw,5rem);align-items:end;max-width:var(--max-w);margin:0 auto;width:100%}.hero-greeting{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted);margin-bottom:1.25rem}.hero-greeting-word{color:var(--accent);font-size:.95rem}.hero-greeting-sep{opacity:.3}.hero-name{font-family:var(--font-serif);font-weight:400;line-height:.92;letter-spacing:-.02em}.hero-name-line{display:block;font-size:clamp(3.5rem,11vw,7.5rem)}.hero-name-line--accent{font-style:italic;color:var(--accent)}.hero-role-wrap{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem}.hero-role{font-family:var(--font-mono);font-size:.85rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--teal);white-space:nowrap}.hero-role-rule{flex:1;height:1px;background:linear-gradient(to right,var(--teal),transparent)}.hero-tagline{font-size:clamp(1rem,2vw,1.15rem);color:var(--text-secondary);line-height:1.75;margin-bottom:1.75rem}.hero-stack{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1rem}.hero-stack-item{font-family:var(--font-mono);font-size:.72rem;padding:.3rem .65rem;border-radius:4px;background:var(--surface);border:1px solid var(--border);color:var(--text-secondary)}.hero-interests{display:flex;flex-wrap:wrap;gap:.5rem 1rem;margin-bottom:2rem}.hero-interest{font-size:.8rem;color:var(--text-muted)}.hero-interest:before{content:"·";margin-right:.5rem;color:var(--accent)}.hero-interest:first-child:before{content:none}.hero-actions{display:flex;flex-wrap:wrap;gap:.65rem}.about-layout{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,4rem);align-items:start}.about-quote{position:relative;padding-left:1.5rem;border-left:2px solid var(--accent)}.about-quote p{font-family:var(--font-serif);font-size:clamp(1.35rem,3vw,1.75rem);font-style:italic;line-height:1.45;color:var(--text)}.about-text{font-size:1.05rem;color:var(--text-secondary);line-height:1.85;margin-bottom:2rem}.about-edu{padding-top:1.75rem;border-top:1px solid var(--border)}.about-edu-label{display:block;font-family:var(--font-mono);font-size:.7rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.6rem}.about-edu-school{display:block;font-family:var(--font-serif);font-size:1.2rem;margin-bottom:.35rem;transition:color .2s var(--ease)}.about-edu-school:hover{color:var(--accent)}.about-edu p{font-size:.9rem;color:var(--text-secondary)}.about-edu-meta{margin-top:.25rem;color:var(--text-muted)!important;font-family:var(--font-mono);font-size:.8rem!important}.exp-timeline{position:relative;padding-left:2rem}.exp-timeline:before{content:"";position:absolute;left:5px;top:8px;bottom:8px;width:1px;background:linear-gradient(to bottom,var(--accent),var(--teal) 60%,transparent)}.exp-item{position:relative;padding-bottom:2.5rem}.exp-item:last-child{padding-bottom:0}.exp-marker{position:absolute;left:-2rem;top:6px;width:11px;height:11px;border-radius:50%;background:var(--bg-alt);border:2px solid var(--accent);box-shadow:0 0 12px var(--accent-glow)}.exp-content{padding:1.5rem 1.75rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color .25s var(--ease),transform .25s var(--ease)}.exp-content:hover{border-color:var(--border-strong);transform:translate(4px)}.exp-company{font-family:var(--font-serif);font-size:1.25rem;margin-bottom:.2rem}.exp-company a{transition:color .2s var(--ease)}.exp-company a:hover{color:var(--accent)}.exp-title{font-size:1rem;font-weight:500;margin-bottom:.3rem}.exp-meta{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted);margin-bottom:.1rem}.exp-desc{font-size:.95rem;color:var(--text-secondary);line-height:1.75;margin-top:.75rem}.exp-role{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--border)}.exp-role-top{display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:.5rem}.exp-dates{font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted)}.exp-duration{font-size:.75rem;color:var(--teal);margin-bottom:.5rem}.projects-toolbar{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:2rem}.filter-btn{padding:.45rem 1rem;font-size:.8rem;font-weight:500;color:var(--text-muted);border:1px solid var(--border);border-radius:100px;transition:all .2s var(--ease)}.filter-btn:hover{color:var(--text-secondary);border-color:var(--border-strong)}.filter-btn--active{color:var(--text);background:var(--surface);border-color:var(--accent);box-shadow:0 0 20px var(--accent-soft)}.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.project-card{display:flex;flex-direction:column;padding:1.5rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color .25s var(--ease),transform .25s var(--ease)}.project-card:hover{border-color:var(--border-strong);transform:translateY(-3px)}.project-card--featured{grid-column:1 / -1;padding:2rem;background:linear-gradient(135deg,var(--surface) 0%,rgba(224,122,95,.06) 100%);border-color:#e07a5f33}.project-card--featured .project-title{font-size:1.5rem}.project-card-head{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.project-index{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted);flex-shrink:0}.project-badges{display:flex;flex-wrap:wrap;gap:.3rem;flex:1}.badge{font-size:.68rem;font-weight:500;padding:.18rem .5rem;border-radius:4px;background:var(--teal-soft);color:var(--teal)}.project-note{font-family:var(--font-mono);font-size:.65rem;color:var(--text-muted);margin-left:auto}.project-title{font-family:var(--font-serif);font-size:1.2rem;margin-bottom:.5rem}.project-desc{font-size:.9rem;color:var(--text-secondary);line-height:1.65;flex:1;margin-bottom:1rem}.project-tech{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:1.25rem}.tech-tag{font-family:var(--font-mono);font-size:.68rem;padding:.2rem .45rem;border-radius:4px;background:var(--bg);color:var(--text-muted);border:1px solid var(--border)}.project-link{display:inline-flex;align-items:center;gap:.35rem;font-size:.82rem;font-weight:500;color:var(--accent);margin-top:auto;transition:gap .2s var(--ease),color .2s var(--ease)}.project-link svg{width:13px;height:13px}.project-link:hover{gap:.55rem;color:#e89078}.skills-board{display:flex;flex-direction:column;gap:0;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.skill-row{display:grid;grid-template-columns:160px 1fr;gap:1.5rem;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);background:var(--surface);transition:background .2s var(--ease)}.skill-row:last-child{border-bottom:none}.skill-row:hover{background:var(--surface-hover)}.skill-row-title{font-family:var(--font-mono);font-size:.75rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--accent);padding-top:.15rem}.skill-row-items{display:flex;flex-wrap:wrap;gap:.35rem .75rem}.skill-row-items li{font-size:.88rem;color:var(--text-secondary)}.skill-row-items li:after{content:",";color:var(--text-muted)}.skill-row-items li:last-child:after{content:none}.contact-layout{display:flex;flex-direction:column;gap:2rem}.contact-email{display:flex;flex-direction:column;gap:.35rem;padding-bottom:2rem;border-bottom:1px solid var(--border);transition:color .2s var(--ease)}.contact-email:hover .contact-email-address{color:var(--accent)}.contact-email-label{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.contact-email-address{font-family:var(--font-serif);font-size:clamp(1.75rem,5vw,3rem);line-height:1.2;transition:color .2s var(--ease);word-break:break-all}.contact-social{display:flex;flex-wrap:wrap;gap:1.5rem}.contact-social-link{display:inline-flex;align-items:center;gap:.4rem;font-size:.95rem;font-weight:500;color:var(--text-secondary);transition:color .2s var(--ease),gap .2s var(--ease)}.contact-social-link svg{width:14px;height:14px}.contact-social-link:hover{color:var(--accent);gap:.6rem}.footer{padding:2rem 0 2.5rem;border-top:1px solid var(--border)}.footer-inner{max-width:var(--max-w);margin:0 auto;padding:0 clamp(1.25rem,4vw,2rem);text-align:center}.footer-copy{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted)}@media(max-width:900px){.hero-grid{grid-template-columns:1fr;gap:2.5rem}.hero-name-block{order:1}.hero-detail-block{order:2}.about-layout{grid-template-columns:1fr}.about-quote{padding-left:0;border-left:none;padding-top:0}}@media(max-width:768px){.header-nav{display:none}.header-menu-btn{display:flex}.header-mobile-nav{display:flex;flex-direction:column;position:fixed;inset:var(--header-h) 0 0 0;background:#0a0c12f7;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:1.5rem clamp(1.25rem,4vw,2rem);gap:0;z-index:199}.header-mobile-link{display:flex;align-items:center;gap:.75rem;padding:1rem 0;font-size:1.15rem;font-family:var(--font-serif);color:var(--text-secondary);border-bottom:1px solid var(--border);text-align:left;transition:color .2s var(--ease)}.header-mobile-link--active{color:var(--accent)}.header-mobile-link:hover{color:var(--text)}.projects-grid{grid-template-columns:1fr}.project-card--featured{grid-column:auto}.skill-row{grid-template-columns:1fr;gap:.75rem}.section-header{gap:1rem}.section-number{font-size:2.5rem}}@media(max-width:480px){.hero-actions{flex-direction:column;align-items:stretch}.btn{justify-content:center}.projects-toolbar{gap:.3rem}.filter-btn{font-size:.72rem;padding:.4rem .75rem}}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}.ambient-orb{animation:none}.btn--primary:hover,.project-card:hover,.exp-content:hover{transform:none}}
