@import"https://fonts.googleapis.com/css2?family=Lato:wght@400;500;700;900&display=swap";:root{color-scheme:dark;--bg: rgb(18, 17, 15);--bg-soft: rgb(24, 22, 19);--surface: rgb(33, 31, 27);--surface-strong: rgb(40, 37, 32);--line: rgba(244, 240, 234, .12);--text: rgb(244, 240, 234);--muted: rgba(244, 240, 234, .72);--muted-strong: rgba(244, 240, 234, .88);--accent: rgb(244, 240, 234);--heading-font: "Cinzel Decorative", serif;--radius: 10px;--radius-soft: 8px;--shadow: 0 10px 28px rgba(0, 0, 0, .2);--max-width: 1240px}:root.light-mode{color-scheme:light;--bg: rgb(230, 228, 220);--bg-soft: rgb(197, 219, 130);--surface: rgb(240, 240, 240);--surface-strong: rgb(230, 230, 230);--line: rgba(0, 0, 0, .1);--text: rgb(18, 17, 15);--muted: rgba(18, 17, 15, .6);--muted-strong: rgba(18, 17, 15, .85);--accent: rgb(18, 17, 15);--shadow: 0 10px 28px rgba(0, 0, 0, .1)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-height:100vh;background:radial-gradient(circle at top,rgba(244,240,234,.04),transparent 38%),linear-gradient(180deg,#f4f0ea05,#f4f0ea00),var(--bg);color:var(--text);font-family:Lato,Segoe UI,Tahoma,sans-serif;line-height:1.6;display:grid;grid-template-columns:280px 1fr;grid-template-rows:1fr}::selection{background:var(--surface);color:var(--text)}a{color:inherit;text-decoration:none}a:hover{color:var(--accent)}img{max-width:100%}.container{width:min(calc(100% - 2rem),var(--max-width));margin:0 auto}.site-header .container{width:100%;margin:0;display:contents}.site-header{position:fixed;left:0;top:0;height:100vh;width:280px;z-index:10;backdrop-filter:blur(14px);background:var(--bg);border-right:1px solid var(--line);overflow-y:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;padding:3rem 0 1rem;color:var(--text)}.site-header::-webkit-scrollbar{width:0;height:0}.site-header::-webkit-scrollbar-track{background:transparent}.site-header::-webkit-scrollbar-thumb{background:transparent}.header-row{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:.5rem;padding:0 2.5rem}.brand{font-size:1.3rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.sidebar-profile{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%;text-align:center}.profile-avatar{width:130px;height:130px;border-radius:50%;border:2px solid rgba(244,240,234,.2);background:linear-gradient(#0000002e,#0000002e),url(/avatar.png) center/cover no-repeat,var(--surface-strong);flex-shrink:0}.profile-info{width:100%}.profile-name{margin:0 0 .5rem;font-size:1.5rem;font-weight:700;letter-spacing:-.01em}.profile-subheading{margin:0;color:var(--muted);font-size:.95rem;letter-spacing:.01em}.primary-nav{position:relative;width:100%}.nav-list{display:flex;flex-direction:column;gap:.2rem;list-style:none;margin:0;padding:0;position:relative;z-index:1;width:100%}.nav-list a{color:var(--muted);padding:.65rem .5rem;border-radius:6px;transition:color .16s ease,background-color .16s ease,box-shadow .16s ease;display:block;text-align:center;font-size:1.1rem}.nav-indicator{position:absolute;left:0;top:0;height:100%;transform:translate(0);border-radius:5px;background:#e5e7eb46;opacity:0;pointer-events:none;transition:transform .22s cubic-bezier(.2,.8,.2,1),width .22s cubic-bezier(.2,.8,.2,1),opacity .18s ease,background-color .16s ease,box-shadow .16s ease}.nav-list a:hover{color:var(--text)}.nav-list a.nav-active{color:var(--text);background:transparent;box-shadow:none}.nav-list a.nav-active:hover{background:transparent}.social-links{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:.5rem;border-bottom:1px solid var(--line)}.social-links a{color:var(--muted);padding:.26rem .52rem;border:1px solid var(--line);border-radius:6px;font-size:.84rem}.icon-link{display:inline-flex;align-items:center;justify-content:center;width:3.5rem;height:3.5rem;padding:0;border:1px solid var(--line);border-radius:6px;color:var(--muted);transition:all .16s ease}.icon-link:hover{color:var(--text);border-color:var(--muted)}.icon-link svg{width:1.3rem;height:1.3rem;fill:currentColor}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:8rem;height:4rem;padding:0;background:none;border:1px solid var(--line);border-radius:5px;cursor:pointer;color:var(--muted);transition:all .16s ease}.theme-toggle:hover{color:var(--text);border-color:var(--muted)}.theme-toggle-button{display:flex;align-items:center;justify-content:center;gap:.5rem;width:fit-content;margin:2rem auto 0;background:var(--surface);border:1px solid var(--line);border-radius:8px;cursor:pointer;color:var(--text);transition:all .16s ease}.theme-toggle svg{width:3.3rem;height:3.3rem;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;position:absolute;transition:opacity .2s ease,transform .2s ease}.theme-toggle .sun-icon{opacity:1}.theme-toggle .moon-icon{opacity:0}:root.light-mode .theme-toggle .sun-icon{opacity:0}:root.light-mode .theme-toggle .moon-icon{opacity:1}.theme-toggle-button svg{width:3.8rem;height:3.8rem;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:opacity .2s ease,transform .2s ease;position:absolute}.theme-toggle-button .sun-icon{opacity:1;transform:rotate(0);stroke:#0086f4}.theme-toggle-button .sun-icon circle{fill:none;stroke:#0086f4}.theme-toggle-button .sun-icon line{stroke:#0086f4;stroke-linecap:round}.theme-toggle-button .moon-icon{opacity:0;transform:rotate(180deg)}:root.light-mode .theme-toggle-button .sun-icon{opacity:0;transform:rotate(180deg)}:root.light-mode .theme-toggle-button .moon-icon{opacity:1;transform:rotate(0)}.sun-label,.moon-label{opacity:0;display:none;transition:opacity .2s ease}:root.light-mode .moon-label{opacity:0;display:none}.theme-toggle-button:hover{opacity:.8}main{padding:3rem 4rem;grid-column:2}.banner-section{margin:0 0 1rem;padding:2rem 0;background:url(/banner.png) center/cover no-repeat;border-radius:5px;overflow:hidden;height:auto;min-height:300px}.banner-caption{margin:-.25rem 0 0;color:var(--muted);font-size:.9rem;font-style:italic;letter-spacing:.01em;text-align:right}.about-section{margin-top:2rem}.section-title{margin:0 0 1.5rem;font-family:Cormorant Garamond,Georgia,serif;font-size:3.5rem;font-weight:600;letter-spacing:.02em}.section-content{max-width:65ch;margin:1rem;color:var(--muted-strong);font-size:1.4rem;line-height:1.7}.hero-copy{min-width:0}.experience{margin-top:1.25rem}.experience h3{margin:0 0 .5rem;font-size:1rem;font-weight:700}.experience-list{list-style:none;margin:0;padding:0;display:grid;gap:.9rem}.experience-item{display:flex;align-items:center;justify-content:space-between;padding:.65rem 0;border-top:1px solid rgba(255,255,255,.03)}.exp-left{min-width:0}.exp-left strong{display:block;font-weight:700}.muted{color:var(--muted);font-size:.92rem}.exp-details{color:var(--muted-strong);font-size:.9rem;margin-top:.25rem}.exp-right{color:var(--muted);font-size:.9rem;white-space:nowrap;margin-left:1rem}.experience-section .section-heading{margin-bottom:.75rem}.timeline-container{padding-top:.5rem}.timeline{list-style:none;margin:0;padding:0 0 0 2.5rem;position:relative}.timeline:before{content:"";position:absolute;left:3rem;top:.25rem;bottom:0;width:2px;background:#f4f0ea2e}.timeline-item{position:relative;padding:.3rem 0 1rem 2.1rem;display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;border-bottom:1px solid rgba(0,0,0,.03)}.timeline-dot{position:absolute;left:.25rem;top:.82rem;width:12px;height:12px;border-radius:50%;background:var(--bg);border:2px solid var(--accent);box-shadow:0 2px 6px #000;border-color:var(--accent);background:var(--surface)}.timeline-content{min-width:0}.timeline-date{white-space:nowrap;color:var(--muted);font-size:.95rem}@media(max-width:860px){.timeline{padding-left:1rem}.timeline:before{left:.75rem}.timeline-dot{left:.05rem;top:.78rem}.timeline-item{padding-left:1.8rem;padding-top:.65rem}}.eyebrow,.card-meta,.tag-list,.section-heading p{letter-spacing:.01em}.eyebrow{margin:0 0 .75rem;color:var(--muted);text-transform:uppercase;font-size:.82rem}h1,h2,h3,p{margin-top:0}.section-heading h2{font-family:Cormorant Garamond,Georgia,serif;font-weight:600;letter-spacing:.02em}h1{max-width:14ch;margin-bottom:1rem;font-size:clamp(2rem,4.2vw,3.15rem);font-weight:700;line-height:1.03;letter-spacing:-.035em}.lead{max-width:62ch;color:var(--muted-strong);font-size:1.4rem}.section{margin-top:3rem}.section-heading{display:flex;align-items:end;justify-content:space-between;gap:1rem;margin-bottom:1rem}.section-heading h2{margin-bottom:0;font-size:3.5rem;font-weight:700}.section-heading p{margin-bottom:0;color:var(--muted);font-size:.9rem}.section-heading .section-actions{display:flex;align-items:center}.section-heading .view-all{display:inline-flex;align-items:center;gap:.5rem;padding:.45rem .9rem;color:var(--muted-strong);background:transparent;border:1px solid rgba(244,240,234,.06);border-radius:999px;font-size:.95rem;text-decoration:none;transition:transform .16s ease,background-color .16s ease,color .16s ease}.section-heading .view-all:hover{transform:translateY(-2px);background:#ffffff05;color:var(--text)}.grid{display:grid;gap:1rem;grid-template-columns:repeat(12,minmax(0,1fr))}.card{grid-column:span 6;padding:1.25rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.card.slim{grid-column:span 4;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease,background-color .18s ease}.card.slim:hover,.card.slim:focus-within{transform:translateY(-8px);box-shadow:0 28px 50px #00000059}.card-top h3{margin:.35rem 0 .65rem;font-size:1.5rem}.card-meta-row{display:inline-flex;align-items:center;gap:.75rem}.card-year{font-weight:700;letter-spacing:.01em}.card-category{padding:.16rem .56rem;border:1px solid var(--line);border-radius:999px;color:var(--muted-strong);line-height:1.1;font-size:.76rem}.card p{color:var(--muted-strong);font-size:1.3rem;color:#b1b1b1}.tag-list{display:flex;flex-wrap:wrap;gap:.5rem;list-style:none;margin:1rem 0 0;padding:0}.tag-list li{padding:.2rem .45rem;border:1px solid var(--line);border-radius:6px;color:var(--muted);font-size:.68rem}.wide-stack{display:grid;gap:1.2rem}.wide-card{width:100%}.project-list{display:grid;gap:1rem;width:100%}.project-list--page{margin-top:.25rem}.project-list .card{width:100%;display:flex;flex-direction:column;padding:1.1rem 1.25rem;background:linear-gradient(180deg,#ffffff05,#fff0),var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease,background-color .18s ease}[data-project-card][hidden]{display:none!important}.project-list .card:last-child{border-bottom:1px solid var(--line)}.project-list .tag-list li,.project-topic-list li,.wide-card .tag-list li{font-size:.66rem;padding:.22rem .5rem}.project-list .tag-list,.project-topic-list,.wide-card .tag-list{gap:.65rem}.media-card{display:grid;grid-template-columns:280px 1fr;gap:1.25rem;align-items:start;width:100%}.wide-stack .media-card{padding:1rem 1.25rem 1.15rem;border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(180deg,#f4f0ea05,#f4f0ea00),var(--surface);box-shadow:var(--shadow);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease,background-color .18s ease}.wide-stack .media-card:last-child{border-bottom:1px solid var(--line)}.project-list .card:hover,.project-list .card:focus-within,.wide-stack .media-card:hover,.wide-stack .media-card:focus-within{transform:translateY(-8px);border-color:var(--line);box-shadow:0 28px 50px #00000059}.project-list .card-top h3,.media-card .card-top h3{max-width:100%}.wide-stack .card{width:100%}.media-card .card-top h3{margin-bottom:.55rem;font-size:1.12rem}.media-thumb{display:block;width:100%;aspect-ratio:16 / 9;overflow:hidden;border:1px solid var(--line);border-radius:10px;background:var(--surface-strong);transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.media-thumb:hover,.media-thumb:focus-visible{transform:translateY(-2px);border-color:#e5e7eb73;box-shadow:0 12px 22px #0003}.media-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .22s ease}.media-thumb:hover img,.media-thumb:focus-visible img{transform:scale(1.03)}.media-body{min-width:0}.media-card .card-links{margin-top:.75rem}.card-links{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:1rem}.project-detail-links{margin-top:1rem}.project-meta-row{display:flex;align-items:center;flex-wrap:wrap;gap:.75rem 1rem;margin-bottom:.85rem}.project-meta-row .eyebrow,.project-stack-tags{margin:0}.project-stack-tags li{padding:.18rem .45rem;font-size:.64rem}.project-links-panel{display:inline-flex;align-items:center;gap:.55rem;width:fit-content;padding:.35rem;border:none;border-radius:12px;background:transparent}.project-links-panel a{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem .9rem;border-radius:999px;background:transparent;border:1px solid var(--line);color:var(--text);transition:background .16s ease,border-color .16s ease,transform .16s ease}.project-links-panel a:hover{background:var(--surface);border-color:var(--muted);transform:translateY(-3px)}.project-links-panel svg{width:.95rem;height:.95rem;fill:currentColor;flex:0 0 auto}.card-links a{color:var(--text);border-bottom:1px solid transparent;transition:color .16s ease,border-color .16s ease,transform .16s ease}.card-links a:hover{border-bottom-color:var(--accent);transform:translateY(-1px)}.page-intro{padding:1rem 0 2rem}.project-summary-2{margin:-.35rem 0 1.15rem;color:var(--muted-strong)}.project-controls{display:flex;flex-wrap:wrap;gap:.9rem;margin:0 0 1.1rem}.project-filter-note{margin:0 0 1rem;color:var(--muted);font-size:.98rem;max-width:60ch}.project-controls label{display:flex;flex-direction:column;gap:.35rem;color:var(--muted);font-size:.95rem}.project-controls select{min-width:190px;padding:.7rem .9rem;font-size:1rem;color:var(--text);background:var(--surface);border:1px solid var(--line);border-radius:8px;cursor:pointer;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease,background-color .16s ease}.project-controls select:hover,.project-controls select:focus-visible{transform:translateY(-1px);border-color:#e5e7eb8c;box-shadow:0 10px 22px #0000002e;background:var(--surface-strong)}.project-controls select:focus-visible{outline:none}.project-topic-list{margin-top:.75rem}.project-empty{margin:0 0 1rem;color:var(--muted)}.page-intro h1{max-width:14ch;font-size:clamp(2.6rem,6vw,4.5rem)}.prose{max-width:74ch}.prose p,.prose li{color:var(--muted-strong)}.prose h2,.prose h3{margin-top:2rem}.site-footer{color:var(--muted);border-top:1px solid rgba(244,240,234,.08)}.footer-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}@media(max-width:860px){body{grid-template-columns:1fr}.site-header{position:sticky;top:0;height:auto;width:100%;border-right:none;border-bottom:1px solid rgba(244,240,234,.08);padding:1rem 0}.header-row{flex-direction:row;align-items:center;justify-content:space-between;gap:1rem;padding:0 1rem}.sidebar-profile{display:none}.nav-list{flex-direction:row;gap:1rem}.social-links{border-top:none;padding-top:0;justify-content:center}main{grid-column:1}.banner-section{margin:-3.25rem -1rem 2rem;padding:2rem 1rem}.banner-title{font-size:2rem}.banner-description{font-size:1rem}.hero{grid-template-columns:1fr;gap:1rem}.hero-avatar{width:102px;height:102px;margin-top:0}.footer-row,.section-heading{align-items:flex-start;flex-direction:column}.grid,.media-card{grid-template-columns:1fr}.media-thumb{aspect-ratio:21 / 10}.card,.card.slim{grid-column:auto}h1{max-width:13ch}}
