:root{color-scheme:light;--bg: #f3f4f2;--bg-2: #eceeea;--surface: #ffffff;--surface-soft: #f6f7f5;--text: #1f2a23;--muted: #5f6a63;--line: #d9ddd7;--brand: #5a6d45;--brand-strong: #3f5031;--chip-bg: #eef2ea;--chip-text: #445736;--shadow: 0 12px 24px rgba(31, 42, 35, .08);--motion-ease: cubic-bezier(.2, .75, .3, 1);--motion-duration: .7s}:root[data-theme=dark]{color-scheme:dark;--bg: #121714;--bg-2: #171d19;--surface: #1b221d;--surface-soft: #232c25;--text: #e8eee8;--muted: #aeb9af;--line: #344038;--brand: #b7cb94;--brand-strong: #7f9661;--chip-bg: #2f3a31;--chip-text: #d8e6c7;--shadow: 0 16px 30px rgba(0, 0, 0, .34)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:IBM Plex Sans,sans-serif;color:var(--text);line-height:1.62;background:linear-gradient(180deg,var(--bg),var(--bg-2));min-height:100vh}a{color:var(--brand);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3{margin:0 0 .72rem;line-height:1.2;font-family:Plus Jakarta Sans,sans-serif}h1{font-size:clamp(2.15rem,4.5vw,3.6rem);letter-spacing:-.02em}h2{font-size:clamp(1.45rem,2.8vw,2rem);margin-bottom:1.15rem}h3{font-size:1.03rem}p{margin:0 0 .8rem}.container{width:min(1120px,calc(100% - 2rem));margin:0 auto}.section{padding:clamp(3.2rem,6vw,4.8rem) 0}.site-header{position:sticky;top:0;z-index:40;border-bottom:1px solid var(--line);background:color-mix(in srgb,var(--bg) 84%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.nav-shell{min-height:4.2rem;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1rem}.brand{color:var(--text);font-family:Plus Jakarta Sans,sans-serif;font-weight:800;font-size:1rem}.nav-wrap{justify-self:center}.nav-list{list-style:none;margin:0;padding:0;display:flex;align-items:center;gap:.9rem}.nav-list a{color:var(--muted);font-weight:600;font-size:.93rem;padding:.28rem .42rem;border-radius:.35rem}.nav-list a:hover{color:var(--text);background:color-mix(in srgb,var(--brand) 9%,transparent);text-decoration:none}.header-controls{display:flex;align-items:center;gap:.45rem}.menu-toggle,.theme-toggle{font:inherit;color:var(--text);background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:.35rem .76rem;min-height:2.15rem;font-weight:600;cursor:pointer}.menu-toggle{display:none}.theme-toggle{display:inline-flex;align-items:center;gap:.44rem}.theme-toggle strong{font-size:.88rem;color:var(--brand)}.hero{padding-top:clamp(2rem,5vw,3.4rem)}.hero-grid{display:grid;grid-template-columns:1fr;gap:1.15rem;align-items:center}.hero-copy,.panel,.timeline-item,.project-card,.contact-card{border:1px solid var(--line);border-radius:1rem;background:var(--surface);box-shadow:var(--shadow)}.hero-name-row{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.55rem;margin-bottom:.45rem}.hero-name-text{text-align:center}.portrait-wrap{padding:0;position:relative;overflow:hidden;width:clamp(110px,15vw,148px);aspect-ratio:1 / 1;border-radius:50%;border:2px solid var(--line);background:var(--surface-soft);flex-shrink:0}.profile-photo{width:100%;height:100%;border-radius:inherit;display:block;object-fit:cover;object-position:center 20%}.hero-copy{padding:clamp(1rem,2.8vw,1.65rem);text-align:center}.eyebrow{margin-bottom:.45rem;margin-top:1rem;color:var(--brand);text-transform:uppercase;letter-spacing:.11em;font-size:.84rem;font-weight:700}.tagline{color:var(--muted);max-width:62ch;margin-inline:auto;font-size:1.1rem}.hero-social-chips{margin-top:1.05rem;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.55rem}.social-chip{display:inline-flex;align-items:center;gap:.46rem;border:1px solid var(--line);border-radius:999px;background:var(--surface-soft);color:var(--text);padding:.4rem .72rem;font-size:.86rem;font-weight:600}.social-chip:hover{text-decoration:none;border-color:color-mix(in srgb,var(--brand) 34%,var(--line))}.social-chip-logo{width:.95rem;height:.95rem;display:block;opacity:.9}.hero-actions{margin:1.2rem 0 1rem;display:flex;justify-content:center;flex-wrap:wrap;gap:.64rem}.button{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:.66rem 1.08rem;border:1px solid transparent;font-weight:700}.button:hover{text-decoration:none}.button.primary{color:#fff;background:var(--brand)}.button.ghost{color:var(--text);border-color:var(--line);background:var(--surface-soft)}.panel{padding:1.2rem}.summary-grid{display:grid;grid-template-columns:1.15fr 1fr;gap:1rem}.stack{display:grid;gap:1rem}.meta-list{list-style:none;margin:0;padding:0}.meta-list li{padding:.18rem 0}.chip-grid{display:flex;flex-wrap:wrap;gap:.45rem}.chip{display:inline-block;border-radius:999px;border:1px solid color-mix(in srgb,var(--brand) 16%,var(--line));background:var(--chip-bg);color:var(--chip-text);padding:.3rem .67rem;font-size:.82rem;font-weight:600}.timeline{display:grid;gap:.85rem}.timeline-item{padding:1.05rem;position:relative;overflow:hidden}.experience-toggle{width:100%;display:flex;align-items:flex-start;justify-content:space-between;gap:.7rem;padding:0;border:0;background:transparent;color:inherit;font:inherit;text-align:left;cursor:pointer}.experience-toggle:focus-visible{outline:2px solid color-mix(in srgb,var(--brand) 48%,var(--line));outline-offset:3px;border-radius:.5rem}.timeline-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.8rem;flex:1}.timeline-head h3{margin-bottom:.28rem}.timeline-org{margin:0;color:var(--muted);font-size:.9rem;font-weight:600}.timeline-meta-wrap{margin-left:auto;text-align:right}.timeline-meta{margin:0;white-space:nowrap}.timeline-meta-location{margin-top:.14rem;font-size:.84rem}.experience-chevron{margin-top:.2rem;color:var(--muted);font-size:1.1rem;line-height:1;transform:rotate(-90deg);transition:transform .24s ease}.experience-chevron.open{transform:rotate(0)}.experience-panel{display:grid;grid-template-rows:0fr;opacity:.45;transition:grid-template-rows .28s ease,opacity .2s ease}.experience-panel.open{grid-template-rows:1fr;opacity:1}.experience-panel-inner{overflow:hidden}.timeline-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:1rem 0 0 1rem;background:color-mix(in srgb,var(--brand) 78%,var(--brand-strong))}.meta{color:var(--muted);font-size:.9rem}.experience-panel ul,.panel ul{margin:.8rem 0 0;padding-left:1.05rem}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(265px,1fr));gap:1rem}.project-card,.project-feature{overflow:hidden}.project-media{height:170px;background:color-mix(in srgb,var(--surface-soft) 84%,var(--bg-2));border-bottom:1px solid var(--line)}:root[data-theme=dark] .project-media{background:color-mix(in srgb,var(--surface-soft) 88%,var(--bg))}.project-media img{width:100%;height:100%;object-fit:cover}.project-fallback{height:100%;display:grid;place-items:center;font-family:Plus Jakarta Sans,sans-serif;font-weight:700;color:var(--muted)}.project-body{padding:.95rem}.project-body p{color:var(--muted)}.project-body a{font-weight:700}.muted{color:var(--muted);font-size:.9rem}.github-panel{display:grid;gap:.85rem}.github-panel a{display:block;border-radius:.6rem;overflow-x:auto;-webkit-overflow-scrolling:touch}.github-panel img{width:100%;border:1px solid var(--line);border-radius:.6rem;display:block}.education-grid,.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1rem}.extra-space{margin-top:1rem}.contact-copy{color:var(--muted)}.contact-card{padding:.88rem;display:grid;gap:.22rem;transition:border-color .2s ease,transform .2s ease}.contact-card:hover{border-color:color-mix(in srgb,var(--brand) 38%,var(--line));transform:translateY(-2px);text-decoration:none}.contact-type{text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;color:var(--brand);font-weight:700}.site-footer{border-top:1px solid var(--line);padding:1.25rem 0 1.8rem;color:var(--muted)}.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.footer-theme-toggle{background:var(--surface-soft);position:relative;z-index:1}.floating-blog{position:fixed;right:0;bottom:5.2rem;z-index:90;display:flex;flex-direction:column;align-items:flex-end;gap:.55rem;overflow:visible;width:fit-content}.floating-blog-toggle{font:inherit;color:#fff;background:var(--brand);border:1px solid var(--brand-strong);border-radius:999px;width:3.4rem;height:2.6rem;padding:0;font-weight:700;cursor:pointer;box-shadow:var(--shadow);display:inline-flex;align-items:center;justify-content:center;overflow:hidden;transform:translate(48%);transition:transform .24s ease,box-shadow .24s ease,width .24s ease,padding .24s ease}.floating-blog-icon{display:inline-block;width:1rem;text-align:center;font-size:1.28rem;line-height:1;font-weight:700;transform:translate(-.35rem);transition:opacity .16s ease,max-width .16s ease;max-width:1rem}.floating-blog-panel{position:absolute;right:0;bottom:calc(100% + .5rem);width:min(380px,calc(100vw - 1.2rem));max-height:68vh;overflow:hidden;visibility:hidden;opacity:0;pointer-events:none;transform:translate(16px);transition:visibility 0s linear .24s,opacity .24s ease,transform .24s ease;border:1px solid var(--line);border-radius:.9rem;background:var(--surface);box-shadow:var(--shadow);padding:.7rem}.floating-blog.open .floating-blog-toggle{transform:translate(0);width:8.6rem;padding:0 .8rem}.floating-blog-label{max-width:0;opacity:0;white-space:nowrap;overflow:hidden;font-size:.86rem;transition:max-width .2s ease,opacity .16s ease}.floating-blog.open .floating-blog-icon{max-width:0;opacity:0}.floating-blog.open .floating-blog-label{max-width:7rem;opacity:1}.floating-blog.open .floating-blog-panel{visibility:visible;opacity:1;pointer-events:auto;transform:translate(0);transition-delay:0s}.floating-blog-source{display:inline-block;margin-bottom:.55rem;font-size:.84rem;font-weight:700}.floating-blog-list{list-style:none;margin:0;padding:0;display:grid;gap:.45rem;max-height:calc(68vh - 2.2rem);overflow:auto}.floating-blog-list li a{display:block;padding:.52rem .6rem;border:1px solid var(--line);border-radius:.6rem;background:var(--surface-soft);color:var(--text);font-size:.86rem;line-height:1.45}.floating-blog-list li a:hover{text-decoration:none;border-color:color-mix(in srgb,var(--brand) 36%,var(--line))}.section,.reveal{opacity:0;transform:translateY(14px);transition:opacity var(--motion-duration) var(--motion-ease),transform var(--motion-duration) var(--motion-ease)}.section.in-view,.reveal.in-view{opacity:1;transform:translateY(0)}.section{transition-duration:.85s}.delay-1{transition-delay:.1s}.delay-2{transition-delay:.2s}@media (max-width: 960px){.menu-toggle{display:inline-flex;align-items:center;justify-content:center}.nav-wrap{grid-column:1 / -1;width:100%;max-height:0;overflow:hidden;transition:max-height .24s ease}.nav-wrap.open{max-height:260px;padding-bottom:.35rem}.nav-list{flex-direction:column;align-items:stretch;gap:0;border:1px solid var(--line);border-radius:.7rem;background:var(--surface);padding:.28rem}.nav-list a{display:block;padding:.55rem .52rem}.hero-grid,.summary-grid{grid-template-columns:1fr}.portrait-wrap{width:clamp(105px,28vw,138px);max-width:none;margin-inline:0}.header-controls{justify-self:end}}@media (max-width: 700px){html{font-size:15px}h1{font-size:clamp(1.9rem,8.5vw,2.25rem)}h2{font-size:clamp(1.28rem,6.2vw,1.6rem);margin-bottom:.95rem}h3{font-size:.98rem}p,li{font-size:.95rem}.tagline{font-size:1rem}.meta,.muted{font-size:.84rem}.button{font-size:.92rem}.social-chip{font-size:.82rem}.section{padding:3.2rem 0}.container{width:min(1120px,calc(100% - 1.2rem))}.theme-toggle,.menu-toggle{padding:.3rem .62rem;min-height:2rem;font-size:.87rem}.portrait-wrap{width:106px}.hero-actions{flex-direction:column}.button{width:100%}.footer-inner{flex-direction:column;align-items:flex-start}.hero-social-chips{gap:.5rem}.social-chip{width:100%;justify-content:center}.project-media{height:185px}.github-panel img{min-width:720px;max-width:none}.floating-blog{right:0;bottom:5rem}.floating-blog-panel{width:min(360px,calc(100vw - 1.2rem))}.floating-blog-toggle{transform:translate(44%)}.timeline-head{gap:.5rem}.timeline-head>div:first-child{min-width:0;flex:1}.timeline-head h3{font-size:.94rem;line-height:1.25;margin-bottom:.2rem}.timeline-org{font-size:.82rem;line-height:1.3}.timeline-meta-wrap{flex-shrink:0;max-width:46%}.timeline-meta,.timeline-meta-location{font-size:.78rem;line-height:1.25;white-space:nowrap}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}
