.navbar{position:fixed;top:0;left:0;right:0;z-index:100;background:var(--nav-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:border-color .3s ease,background .3s ease}.navbar--scrolled{border-bottom-color:var(--border)}.navbar__name{font-family:var(--font-serif);font-size:.9rem;font-weight:500;color:var(--text);text-decoration:none;white-space:nowrap;flex-shrink:0;letter-spacing:-.01em;transition:opacity .2s ease}.navbar__name:hover{opacity:.6}.navbar__resume-btn{font-family:var(--font-sans);font-size:.75rem;font-weight:500;color:var(--text-secondary);text-decoration:none;border:1px solid var(--border);border-radius:6px;padding:.3rem .65rem;letter-spacing:.02em;transition:color .2s ease,border-color .2s ease,background .2s ease;white-space:nowrap}.navbar__resume-btn:hover{color:var(--text);border-color:var(--text-secondary);background:var(--tag-bg)}.navbar__inner{max-width:calc(var(--max-width) + 3rem);margin:0 auto;padding:0 1.5rem;height:var(--nav-height);display:flex;align-items:center;justify-content:space-between;gap:1rem}.navbar__links{display:flex;align-items:center;gap:.25rem;list-style:none}.navbar__link{font-size:.825rem;font-weight:500;color:var(--text-secondary);padding:.4rem .65rem;border-radius:6px;transition:color .2s ease,background .2s ease;letter-spacing:.01em}.navbar__link:hover{color:var(--text);background:var(--tag-bg)}.navbar__right{display:flex;align-items:center;gap:.5rem}.navbar__social{display:flex;align-items:center;gap:.25rem}.navbar__icon-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;transition:color .2s ease,background .2s ease;text-decoration:none}.navbar__icon-btn:hover{color:var(--text);background:var(--tag-bg)}.navbar__theme-toggle{margin-left:.25rem;border-left:1px solid var(--border);border-radius:0;padding-left:.75rem;width:auto}.navbar__hamburger{display:none;flex-direction:column;gap:4px;background:none;border:none;cursor:pointer;padding:4px}.bar{display:block;width:18px;height:1.5px;background:var(--text);border-radius:2px;transition:transform .25s ease,opacity .25s ease}.bar--mid{width:14px}.navbar__mobile-extras{display:none}.navbar__mobile-social{display:flex;align-items:center;gap:.25rem;flex-wrap:wrap}.navbar__resume-mobile{display:inline-block;margin-top:.5rem}@media (max-width: 640px){.navbar__social{display:none}.navbar__resume-btn:not(.navbar__resume-mobile){display:none}.navbar__hamburger{display:flex}.navbar__mobile-extras{display:block;width:100%;border-top:1px solid var(--border);margin-top:.5rem;padding-top:.75rem}.navbar__links{display:none;position:absolute;top:var(--nav-height);left:0;right:0;background:var(--nav-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);flex-direction:column;align-items:flex-start;padding:1rem 1.5rem 1.25rem;gap:.25rem}.navbar__links--open{display:flex}.navbar__link{width:100%;padding:.6rem .5rem}}.about{padding-top:calc(var(--nav-height) + 5rem);padding-bottom:5rem;min-height:60vh;display:flex;align-items:center}.about__layout{display:grid;grid-template-columns:1fr 168px;gap:3rem;align-items:center}.about__text{display:flex;flex-direction:column}.about__hero{margin-bottom:2rem;line-height:1.15}.about__hero em{font-style:italic;color:var(--text-secondary)}.about__intro{display:flex;flex-direction:column;gap:.75rem;margin-bottom:3rem}.about__intro p{font-size:1.05rem;line-height:1.75}.about__photo-wrap{display:flex;justify-content:flex-end;align-items:flex-start;padding-top:.5rem}.about__photo{width:168px;aspect-ratio:4 / 5;object-fit:cover;object-position:center top;border-radius:4px;filter:grayscale(100%);transition:filter .4s ease;display:block;border:1px solid var(--border);-webkit-user-select:none;user-select:none}.about__photo:hover{filter:grayscale(0%)}.about__music{display:flex;flex-direction:column;align-items:flex-start;gap:.75rem}.about__music-toggle{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--font-sans);font-size:.75rem;font-weight:500;letter-spacing:.06em;color:var(--text-secondary);background:none;border:1px solid var(--border);border-radius:20px;padding:.35rem .85rem;cursor:pointer;transition:color .2s ease,border-color .2s ease}.about__music-toggle:hover{color:var(--text);border-color:var(--text-secondary)}.about__music-content{animation:fadeSlide .25s ease forwards}.about__music-link{font-size:.875rem;color:var(--accent);transition:opacity .2s ease}.about__music-link:hover{opacity:.75}@keyframes fadeSlide{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 560px){.about__layout{grid-template-columns:1fr;gap:2rem}.about__photo-wrap{justify-content:flex-start}.about__photo{width:120px}}.work__grid{display:grid;grid-template-columns:1fr;gap:1.5rem}.project-card{display:grid;grid-template-columns:88px 1fr;gap:1.25rem;padding:1.5rem;border:1px solid var(--border);border-radius:12px;background:var(--card-bg);transition:border-color .2s ease,transform .2s ease,box-shadow .2s ease}.project-card:hover{border-color:var(--text-secondary);transform:translateY(-2px);box-shadow:0 4px 24px #0000000f}[data-theme=dark] .project-card:hover{box-shadow:0 4px 24px #0000004d}.project-card__thumb{width:88px;height:88px;border-radius:8px;overflow:hidden;flex-shrink:0;border:1px solid var(--border)}.project-card__thumb img{width:100%;height:100%;object-fit:cover}.project-card__thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--tag-bg);font-family:var(--font-serif);font-size:2rem;color:var(--text-secondary);font-style:italic}.project-card__body{display:flex;flex-direction:column;gap:.5rem}.project-card__title{font-family:var(--font-serif);font-size:1.05rem;font-weight:500;color:var(--text);margin:0}.project-card__desc{font-size:.875rem;line-height:1.6;color:var(--text-secondary);max-width:none;margin:0}.project-card__tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.25rem}.project-card__tag{font-size:.7rem;font-weight:500;letter-spacing:.04em;color:var(--tag-text);background:var(--tag-bg);padding:.2rem .55rem;border-radius:20px}.project-card__actions{display:flex;gap:.5rem;margin-top:.5rem}.project-card__btn{display:inline-flex;align-items:center;gap:.35rem;font-size:.775rem;font-weight:500;padding:.35rem .75rem;border-radius:6px;border:1px solid var(--border);transition:background .2s ease,color .2s ease,border-color .2s ease;cursor:pointer;text-decoration:none}.project-card__btn--primary{background:var(--accent);color:#fff;border-color:var(--accent)}.project-card__btn--primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.project-card__btn--ghost{background:transparent;color:var(--text-secondary)}.project-card__btn--ghost:hover{background:var(--tag-bg);color:var(--text)}@media (max-width: 480px){.project-card{grid-template-columns:1fr}.project-card__thumb{width:64px;height:64px}}.writing__list{display:flex;flex-direction:column}@keyframes shimmer{0%{opacity:.4}50%{opacity:.9}to{opacity:.4}}.blog-item--skeleton{pointer-events:none;cursor:default}.blog-item--skeleton:hover{opacity:1}.skeleton{display:block;border-radius:4px;background:var(--border);animation:shimmer 1.4s ease-in-out infinite}.skeleton--date{width:60px;height:10px;margin-bottom:8px}.skeleton--title{width:70%;height:16px;margin-bottom:8px}.skeleton--preview{width:90%;height:12px}.blog-item{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1.25rem 0;border-bottom:1px solid var(--border);text-decoration:none;transition:opacity .2s ease}.blog-item:first-child{border-top:1px solid var(--border)}.blog-item:hover{opacity:.7}.blog-item:hover .blog-item__arrow{transform:translate(2px,-2px)}.blog-item__content{display:flex;flex-direction:column;gap:.3rem;flex:1;min-width:0}.blog-item__date{font-size:.72rem;font-weight:500;letter-spacing:.08em;color:var(--text-secondary);text-transform:uppercase}.blog-item__title{font-family:var(--font-serif);font-size:1.05rem;font-weight:500;color:var(--text);line-height:1.35}.blog-item__preview{font-size:.875rem;color:var(--text-secondary);line-height:1.55;max-width:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.blog-item__arrow{color:var(--text-secondary);flex-shrink:0;margin-top:.2rem;transition:transform .2s ease}.writing__footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-top:1.75rem}.writing__see-more{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font-sans);font-size:.825rem;font-weight:500;color:var(--text);background:none;border:1px solid var(--border);border-radius:8px;padding:.45rem .9rem;cursor:pointer;transition:border-color .2s ease,background .2s ease}.writing__see-more:hover{border-color:var(--text-secondary);background:var(--tag-bg)}.writing__see-more-count{font-size:.7rem;font-weight:400;color:var(--text-secondary);letter-spacing:.04em}.writing__substack{display:flex}.writing__substack-link{display:inline-flex;align-items:center;gap:.3rem;font-size:.85rem;font-weight:500;color:var(--accent);text-decoration:none;transition:opacity .2s ease}.writing__substack-link:hover{opacity:.7}.writing__substack-link svg{transition:transform .2s ease}.writing__substack-link:hover svg{transform:translate(2px,-2px)}.notes__feed{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.tweet-card{display:flex;flex-direction:column;gap:.85rem;padding:1.25rem 1.4rem;border:1px solid var(--border);border-radius:12px;background:var(--card-bg);text-decoration:none;transition:border-color .2s ease,transform .2s ease,box-shadow .2s ease;cursor:pointer}.tweet-card:hover{border-color:var(--text-secondary);transform:translateY(-2px);box-shadow:0 4px 20px #0000000f}[data-theme=dark] .tweet-card:hover{box-shadow:0 4px 20px #0000004d}.tweet-card__header{display:flex;align-items:center;justify-content:space-between}.tweet-card__author{display:flex;flex-direction:column;gap:.1rem}.tweet-card__name{font-size:.8rem;font-weight:600;color:var(--text);letter-spacing:.01em}.tweet-card__handle{font-size:.72rem;color:var(--text-secondary)}.tweet-card__header svg{color:var(--text-secondary);flex-shrink:0;transition:color .2s ease}.tweet-card:hover .tweet-card__header svg{color:var(--text)}.tweet-card__text{font-size:.9rem;line-height:1.65;color:var(--text);max-width:none;flex:1}.tweet-card__footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto}.tweet-card__date{font-size:.7rem;font-weight:500;letter-spacing:.06em;color:var(--text-secondary);text-transform:uppercase}.tweet-card__cta{display:inline-flex;align-items:center;gap:.25rem;font-size:.72rem;font-weight:500;color:var(--text-secondary);transition:color .2s ease}.tweet-card:hover .tweet-card__cta{color:var(--accent)}.tweet-card__cta svg{transition:transform .2s ease}.tweet-card:hover .tweet-card__cta svg{transform:translate(2px,-2px)}.notes__footer{margin-top:1.75rem}.notes__all-link{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;font-weight:500;color:var(--accent);text-decoration:none;transition:opacity .2s ease}.notes__all-link:hover{opacity:.7}.notes__all-link svg:last-child{transition:transform .2s ease}.notes__all-link:hover svg:last-child{transform:translate(2px,-2px)}@media (max-width: 600px){.notes__feed{grid-template-columns:1fr}}.book__layout{display:grid;grid-template-columns:160px 1fr;gap:2.5rem;align-items:center}.book__cover{width:160px;aspect-ratio:2 / 3;border-radius:8px;overflow:hidden;border:1px dashed var(--border);flex-shrink:0}.book__cover--soon{background:var(--tag-bg)}.book__cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.book__info{display:flex;flex-direction:column;gap:.85rem}.book__badge{display:inline-flex;align-items:center;font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);border:1px solid var(--border);border-radius:20px;padding:.25rem .7rem;width:fit-content}.book__title{font-size:clamp(1.3rem,3vw,1.7rem);line-height:1.25;color:var(--text);margin:0}.book__description{font-size:.9rem;line-height:1.75;color:var(--text-secondary);max-width:52ch;margin:0}.book__btn{display:inline-flex;align-items:center;gap:.4rem;font-size:.825rem;font-weight:500;padding:.5rem 1rem;border-radius:8px;border:1px solid var(--border);text-decoration:none;width:fit-content;margin-top:.25rem;transition:background .2s ease,color .2s ease,border-color .2s ease}.book__btn--ghost{background:transparent;color:var(--text-secondary)}.book__btn--ghost:hover{background:var(--tag-bg);color:var(--text);border-color:var(--text-secondary)}@media (max-width: 560px){.book__layout{grid-template-columns:1fr}.book__cover{width:110px}}.contact__layout{display:flex;flex-direction:column;gap:1rem}.contact__heading{font-size:clamp(1.8rem,4vw,2.6rem);color:var(--text);margin:0}.contact__sub{font-size:1rem;line-height:1.7;color:var(--text-secondary);max-width:48ch;margin:0}.contact__btn{display:inline-flex;align-items:center;width:fit-content;margin-top:.5rem;font-family:var(--font-sans);font-size:.9rem;font-weight:500;color:var(--text);text-decoration:none;border-bottom:1px solid var(--border);padding-bottom:2px;transition:border-color .2s ease,color .2s ease;letter-spacing:.01em}.contact__btn:hover{color:var(--accent);border-color:var(--accent)}.footer{padding:2.5rem 0;border-top:1px solid var(--border)}.footer__inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}.footer__copy{font-size:.8rem;color:var(--text-secondary);max-width:none}.footer__right{display:flex;align-items:center;gap:1.5rem}.footer__email{font-size:.8rem;color:var(--text-secondary);text-decoration:none;transition:color .2s ease}.footer__email:hover{color:var(--text)}.footer__back{font-size:.8rem;color:var(--text-secondary);text-decoration:none;transition:color .2s ease}.footer__back:hover{color:var(--text)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #FAFAFA;--text: #111111;--text-secondary: #555555;--border: #E5E5E5;--accent: #1a3a5c;--accent-hover: #142e4a;--card-bg: #FFFFFF;--nav-bg: rgba(250, 250, 250, .92);--tag-bg: #F0F0F0;--tag-text: #444444;--font-serif: "Playfair Display", Georgia, serif;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--max-width: 720px;--nav-height: 64px;--ease: cubic-bezier(.25, .46, .45, .94)}[data-theme=dark]{--bg: #0F0F0F;--text: #EAEAEA;--text-secondary: #AAAAAA;--border: #2A2A2A;--accent: #6b9fd4;--accent-hover: #88b3de;--card-bg: #1A1A1A;--nav-bg: rgba(15, 15, 15, .92);--tag-bg: #222222;--tag-text: #AAAAAA}html{scroll-behavior:smooth}body{font-family:var(--font-sans);background-color:var(--bg);color:var(--text);font-size:16px;line-height:1.7;transition:background-color .3s var(--ease),color .3s var(--ease);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4{font-family:var(--font-serif);font-weight:500;line-height:1.2;letter-spacing:-.01em}h1{font-size:clamp(2.4rem,5vw,3.6rem)}h2{font-size:clamp(1.6rem,3vw,2rem)}h3{font-size:1.2rem}p{max-width:65ch;color:var(--text-secondary)}a{color:inherit;text-decoration:none}.container{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}section{padding:5rem 0}section+section{border-top:1px solid var(--border)}.section-label{font-family:var(--font-sans);font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:2.5rem}.fade-in{opacity:0;transform:translateY(16px);transition:opacity .6s var(--ease),transform .6s var(--ease)}.fade-in.visible{opacity:1;transform:translateY(0)}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
