:root{--bg: #fafaf9;--bg-secondary: #f5f5f4;--text-primary: #1c1917;--text-secondary: #78716c;--text-tertiary: #a8a29e;--accent: #df2f6a;--accent-hover: #e51058;--border: #e7e5e4;--border-light: #f5f5f4;--code-bg: #f5f5f4;--card-bg: #ffffff;--card-hover: #fafaf9;--link-color: #1c1917;--link-hover: #f383a8;--shadow: 0 1px 3px rgba(0,0,0,.04);--focus-ring: #df2f6a;--max-width: 640px;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--font-serif: "Source Serif 4", "Georgia", serif;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 2rem;--leading-tight: 1.25;--leading-normal: 1.6;--leading-relaxed: 1.75;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease}[data-theme=dark]{--bg: #0c0a09;--bg-secondary: #1c1917;--text-primary: #fafaf9;--text-secondary: #a8a29e;--text-tertiary: #78716c;--accent: #df2f6a;--accent-hover: #e51058;--border: #292524;--border-light: #1c1917;--code-bg: #1c1917;--card-bg: #1c1917;--card-hover: #292524;--link-color: #fafaf9;--link-hover: #f383a8;--shadow: 0 1px 3px rgba(0,0,0,.2);--focus-ring: #f383a8}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background-color:var(--bg);color:var(--text-primary);line-height:var(--leading-normal);transition:background-color var(--transition-base),color var(--transition-base);min-height:100vh}a{color:var(--link-color);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--link-hover)}img{max-width:100%;height:auto;display:block}ul,ol{list-style:none}button{background:none;border:none;cursor:pointer;font-family:inherit;color:inherit}::selection{background:var(--accent);color:#fff}:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px;border-radius:2px}:focus:not(:focus-visible){outline:none}.skip-link{position:absolute;top:-100%;left:var(--spacing-md);z-index:10000;padding:var(--spacing-sm) var(--spacing-md);background:var(--accent);color:#fff;font-size:var(--text-sm);font-weight:600;border-radius:0 0 6px 6px;text-decoration:none;transition:top var(--transition-fast)}.skip-link:focus{top:0;color:#fff}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.container{max-width:var(--max-width);margin:0 auto;padding:0 var(--spacing-lg)}.page-wrapper{min-height:100vh;display:flex;flex-direction:column}main{flex:1;padding:var(--spacing-3xl) 0}.site-header{padding:var(--spacing-xl) 0;position:sticky;top:0;z-index:100;background:var(--bg);transition:background-color var(--transition-base)}.site-header .container{display:flex;align-items:center;justify-content:space-between}.site-logo{font-family:var(--font-mono);font-size:var(--text-base);font-weight:600;color:var(--text-primary);letter-spacing:-.02em}.site-logo:hover{color:var(--accent)}.header-actions{display:flex;align-items:center;gap:var(--spacing-md)}.theme-toggle{width:44px;height:44px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:background-color var(--transition-fast);color:var(--text-secondary)}.theme-toggle:hover{background:var(--bg-secondary);color:var(--text-primary)}.theme-toggle svg{width:18px;height:18px}.cmd-hint{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);padding:4px 8px;min-height:44px;border:1px solid var(--border);border-radius:6px;display:flex;align-items:center;gap:4px;cursor:pointer;transition:all var(--transition-fast)}.cmd-hint:hover{border-color:var(--text-tertiary);color:var(--text-secondary)}.section{margin-bottom:var(--spacing-3xl);opacity:0;transform:translateY(16px);animation:fadeInUp .6s ease forwards}.section:nth-child(1){animation-delay:.05s}.section:nth-child(2){animation-delay:.1s}.section:nth-child(3){animation-delay:.15s}.section:nth-child(4){animation-delay:.2s}.section:nth-child(5){animation-delay:.25s}.section:nth-child(6){animation-delay:.3s}.section:nth-child(7){animation-delay:.35s}.section:nth-child(8){animation-delay:.4s}.section:nth-child(9){animation-delay:.45s}@media(prefers-reduced-motion:reduce){.section{opacity:1;transform:none;animation:none}}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}.section-label{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--spacing-lg)}.hero-name{font-size:var(--text-2xl);font-weight:700;letter-spacing:-.03em;margin-bottom:var(--spacing-sm);line-height:var(--leading-tight)}.hero-name .encrypted-text{display:inline-block;transition:color .2s ease}.hero-name .encrypted-text.is-scrambling{color:var(--text-secondary)}.hero-bio{font-size:var(--text-base);color:var(--text-secondary);line-height:var(--leading-relaxed)}.hero-bio a{color:var(--text-primary);text-decoration:underline;text-decoration-color:var(--border);text-underline-offset:3px;transition:text-decoration-color var(--transition-fast),color var(--transition-fast)}.hero-bio a:hover{text-decoration-color:var(--accent);color:var(--accent)}.project-item{display:flex;align-items:baseline;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.project-item a{font-weight:500;text-decoration:underline;text-decoration-color:var(--border);text-underline-offset:3px}.project-item a:hover{text-decoration-color:var(--accent);color:var(--accent)}.project-item .separator{color:var(--text-tertiary)}.project-item .description{color:var(--text-secondary);font-size:var(--text-sm)}.writing-list{display:flex;flex-direction:column;gap:2px}.writing-item{display:flex;align-items:baseline;gap:var(--spacing-md);padding:var(--spacing-sm) 0;transition:color var(--transition-fast);border-radius:4px;min-height:44px}.writing-item:hover{color:var(--accent)}.writing-item .date{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);white-space:nowrap;min-width:80px;transition:color var(--transition-fast)}.writing-item:hover .date{color:var(--accent)}.writing-item .title{font-size:var(--text-sm);font-weight:450}.writing-item .title-row{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.view-all-link{display:inline-flex;align-items:center;gap:6px;margin-top:var(--spacing-md);font-size:var(--text-sm);color:var(--text-secondary);transition:color var(--transition-fast)}.view-all-link:hover{color:var(--accent)}.view-all-link svg{width:14px;height:14px;transition:transform var(--transition-fast)}.view-all-link:hover svg{transform:translate(3px)}.projects-year{margin-bottom:var(--spacing-lg)}.projects-year-header{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;padding:var(--spacing-sm) 0;font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-secondary);transition:color var(--transition-fast);-webkit-user-select:none;user-select:none}.projects-year-header:hover{color:var(--text-primary)}.projects-year-header .chevron{width:14px;height:14px;transition:transform var(--transition-fast)}.projects-year-header.open .chevron{transform:rotate(90deg)}.projects-year-content{display:none;padding-left:var(--spacing-lg);padding-top:var(--spacing-sm)}.projects-year-content.open{display:block}.project-entry{padding:var(--spacing-xs) 0;margin-bottom:var(--spacing-sm)}.project-entry a{font-weight:500;font-size:var(--text-sm)}.project-entry .project-desc{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:2px}.talks-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.talk-item{display:flex;align-items:baseline;gap:var(--spacing-md)}.talk-item .talk-type{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);white-space:nowrap;min-width:60px}.talk-item a{font-size:var(--text-sm);font-weight:450}.social-links{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.social-link{font-size:var(--text-sm);color:var(--text-secondary);padding:4px 0;transition:color var(--transition-fast)}.social-link:hover{color:var(--accent)}.social-link:not(:last-child):after{content:"·";margin-left:var(--spacing-sm);color:var(--text-tertiary)}.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-sm)}.photo-grid-item{aspect-ratio:1;background:var(--bg-secondary);border-radius:8px;overflow:hidden;cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.photo-grid-item:hover{transform:scale(1.02);box-shadow:0 4px 20px #0000001a}.photo-grid-item img{width:100%;height:100%;object-fit:cover}.photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);font-size:var(--text-xs);font-family:var(--font-mono)}.site-footer{padding:var(--spacing-xl) 0;border-top:1px solid var(--border)}.site-footer .container{display:flex;align-items:center;justify-content:space-between}.footer-text{font-size:var(--text-xs);color:var(--text-tertiary);font-family:var(--font-mono)}.footer-kbd{font-size:var(--text-xs);color:var(--text-tertiary);font-family:var(--font-mono);display:flex;align-items:center;gap:4px}.footer-kbd kbd{display:inline-flex;align-items:center;justify-content:center;padding:2px 6px;border:1px solid var(--border);border-radius:4px;font-family:var(--font-mono);font-size:11px;background:var(--bg-secondary)}.page-back{display:inline-flex;align-items:center;gap:6px;font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--spacing-xl);transition:color var(--transition-fast);min-height:44px}.page-back:hover{color:var(--accent)}.page-back svg{width:14px;height:14px}.page-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-2xl)}.page-title{font-size:var(--text-2xl);font-weight:700;letter-spacing:-.03em}.rss-link{color:var(--text-tertiary);transition:color var(--transition-fast)}.rss-link:hover{color:var(--accent)}.rss-link svg{width:18px;height:18px}.posts-year-group{margin-bottom:var(--spacing-2xl)}.posts-year-label{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:600;color:var(--text-tertiary);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border)}.posts-list{display:flex;flex-direction:column;gap:0}.post-list-item{display:flex;align-items:baseline;gap:var(--spacing-md);padding:var(--spacing-sm) 0;transition:color var(--transition-fast);border-bottom:1px solid transparent;min-height:44px}.post-list-item:hover{color:var(--accent)}.post-list-item .post-number{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);min-width:28px;transition:color var(--transition-fast)}.post-list-item:hover .post-number{color:var(--accent)}.post-list-item .post-date{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);white-space:nowrap;min-width:52px;transition:color var(--transition-fast)}.post-list-item:hover .post-date{color:var(--accent)}.post-list-item .post-info{flex:1}.post-title-row{display:flex;align-items:center;gap:8px}.post-list-item .post-title{font-size:var(--text-sm);font-weight:500}.post-badge{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 45%,var(--border));background:color-mix(in srgb,var(--accent) 12%,transparent);padding:2px 6px;border-radius:999px;white-space:nowrap}.post-list-item .post-subtitle{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:2px;transition:color var(--transition-fast)}.post-list-item:hover .post-subtitle{color:var(--accent);opacity:.7}.post-header{margin-bottom:var(--spacing-2xl)}.post-meta{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);margin-bottom:var(--spacing-md);display:flex;align-items:center;gap:6px}.post-meta .meta-separator{color:var(--border)}.post-detail-title{font-size:var(--text-3xl);font-weight:700;letter-spacing:-.04em;line-height:var(--leading-tight);margin-bottom:var(--spacing-sm)}.post-detail-subtitle{font-size:var(--text-lg);color:var(--text-secondary);line-height:var(--leading-relaxed)}.prose{font-family:var(--font-serif);font-size:var(--text-xl);line-height:var(--leading-relaxed);color:var(--text-primary)}.prose h2{font-family:var(--font-sans);font-size:var(--text-2xl);font-weight:700;letter-spacing:-.02em;margin-top:var(--spacing-2xl);margin-bottom:var(--spacing-md)}.prose h3{font-family:var(--font-sans);font-size:var(--text-lg);font-weight:600;margin-top:var(--spacing-xl);margin-bottom:var(--spacing-sm)}.prose p{margin-bottom:var(--spacing-lg)}.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}.prose a:hover{color:var(--accent-hover)}.prose strong{font-weight:600;color:var(--text-primary)}.prose ul,.prose ol{margin-bottom:var(--spacing-lg);padding-left:var(--spacing-lg)}.prose ul{list-style:disc}.prose ol{list-style:decimal}.prose li{margin-bottom:var(--spacing-sm)}.prose blockquote{border-left:3px solid var(--accent);padding-left:var(--spacing-lg);margin:var(--spacing-xl) 0;color:var(--text-secondary);font-style:italic}.prose code{font-family:var(--font-mono);font-size:.875em;background:var(--code-bg);padding:2px 6px;border-radius:4px;color:var(--accent)}.prose pre{background:var(--code-bg);border:1px solid var(--border);border-radius:8px;padding:var(--spacing-lg);margin:var(--spacing-xl) 0;overflow-x:auto}.prose pre code{background:none;padding:0;font-size:var(--text-sm);color:var(--text-primary)}.prose hr{border:none;border-top:1px solid var(--border);margin:var(--spacing-2xl) 0}.prose img{border-radius:8px;margin:var(--spacing-xl) 0}.post-footer{margin-top:var(--spacing-3xl);padding-top:var(--spacing-xl);border-top:1px solid var(--border)}.post-footer-back{display:inline-flex;align-items:center;gap:6px;font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--spacing-lg);transition:color var(--transition-fast)}.post-footer-back:hover{color:var(--accent)}.share-buttons{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.share-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border:1px solid var(--border);border-radius:6px;font-size:var(--text-xs);font-family:var(--font-mono);color:var(--text-secondary);transition:all var(--transition-fast);min-height:44px}.share-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--bg-secondary)}.cmd-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:none;align-items:flex-start;justify-content:center;padding-top:20vh;opacity:0;transition:opacity var(--transition-fast)}.cmd-overlay.active{display:flex;opacity:1}.cmd-palette{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;width:100%;max-width:480px;box-shadow:0 20px 60px #00000026;overflow:hidden}.cmd-input-wrapper{display:flex;align-items:center;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border);gap:var(--spacing-sm)}.cmd-input-wrapper svg{width:16px;height:16px;color:var(--text-tertiary);flex-shrink:0}.cmd-input{flex:1;border:none;outline:none;background:none;font-family:var(--font-sans);font-size:var(--text-sm);color:var(--text-primary)}.cmd-input::placeholder{color:var(--text-tertiary)}.cmd-results{padding:var(--spacing-sm);max-height:300px;overflow-y:auto}.cmd-group-label{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;padding:var(--spacing-sm) var(--spacing-sm)}.cmd-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-sm);border-radius:6px;font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);min-height:44px}.cmd-item:hover,.cmd-item.active,.cmd-item[aria-selected=true]{background:var(--bg-secondary);color:var(--text-primary)}.cmd-item svg{width:14px;height:14px;flex-shrink:0}.cmd-item .cmd-shortcut{margin-left:auto;font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary)}.not-found{width:min(680px,100%)}.not-found-page{min-height:100vh;display:grid;place-items:center;padding:var(--spacing-xl)}.terminal-window{border:1px solid var(--border);border-radius:14px;overflow:hidden;background:var(--card-bg);box-shadow:var(--shadow)}.terminal-bar{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--bg-secondary);border-bottom:1px solid var(--border)}.dot{width:10px;height:10px;border-radius:999px}.dot-red{background:#ff5f56}.dot-yellow{background:#ffbd2e}.dot-green{background:#27c93f}.terminal-title{margin-left:8px;font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary)}.terminal-body{padding:var(--spacing-lg);font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-secondary);line-height:1.8}.terminal-body p{margin-bottom:var(--spacing-sm)}.prompt{color:var(--accent);margin-right:8px}.terminal-error{color:#ff7d73}.terminal-link{display:inline-block;margin-top:var(--spacing-sm);color:var(--text-primary);text-decoration:none;border-bottom:1px dashed var(--accent);transition:color var(--transition-fast),border-color var(--transition-fast)}.terminal-link:hover{color:var(--accent);border-color:var(--accent)}.streaming-ui{margin:var(--spacing-xl) 0;border:1px solid var(--border);border-radius:12px;background:var(--card-bg);box-shadow:var(--shadow);overflow:hidden}.streaming-ui-header{display:flex;align-items:center;gap:8px;padding:10px 14px;font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-secondary);border-bottom:1px solid var(--border);background:var(--bg-secondary)}.stream-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:streamPulse 1.1s ease-in-out infinite}.streaming-ui-body{min-height:70px;padding:0;font-family:var(--font-mono);font-size:var(--text-sm);line-height:1.7;color:var(--text-primary);white-space:pre-wrap}.stream-status-text{display:inline-block;animation:streamStatusSwap .35s ease}.stream-status-text:after{content:"...";margin-left:1px;letter-spacing:.08em;animation:streamDots 1s steps(3,end) infinite}.stream-cursor{display:inline-block;width:8px;height:1em;margin-left:2px;background:var(--accent);vertical-align:-2px;animation:streamBlink .9s steps(1,end) infinite}@keyframes streamStatusSwap{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes streamDots{0%{content:"."}33%{content:".."}66%{content:"..."}to{content:"..."}}@keyframes streamBlink{0%,49%{opacity:1}50%,to{opacity:0}}@keyframes streamPulse{0%,to{transform:scale(1);opacity:.6}50%{transform:scale(1.2);opacity:1}}@media(max-width:640px){:root{--text-3xl: 1.625rem;--text-2xl: 1.25rem}main{padding:var(--spacing-xl) 0}.section{margin-bottom:var(--spacing-2xl)}.writing-item{flex-direction:column;gap:2px}.writing-item .date{min-width:unset}.writing-item .title-row{gap:6px}.post-list-item{flex-direction:column;gap:4px}.post-list-item .post-number,.post-list-item .post-date{min-width:unset}.post-title-row{flex-wrap:wrap}.post-meta-row{display:flex;gap:var(--spacing-sm)}.photo-grid{grid-template-columns:repeat(2,1fr)}.share-buttons{flex-wrap:wrap}.post-detail-title{font-size:var(--text-2xl)}.cmd-palette{margin:0 var(--spacing-md)}}
