*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-size:16px}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0}img,video{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}ul,ol{list-style:none}:root{--bg:#f3f1ed;--bg-elevated:#eae7e0;--bg-alt:#fbf9f6;--ink:#1d1b1b;--ink-soft:#4f4d4a;--muted:#8a8580;--border:#c5c1bb;--border-light:#e5e1d9;--accent:#57c5c8;--accent-dark:#204f56;--card-bg:#faf8f4;--code-bg:#e8e4db;--code-fg:#2a2825;--selection-bg:#e8dcc8;--ylw:#ffdc6459;--font-mono:"IBM Plex Mono", "SFMono-Regular", Menlo, Consolas, monospace;--font-sans:"IBM Plex Mono", "SFMono-Regular", Menlo, Consolas, monospace;--font-serif:"Playfair Display", Georgia, "Noto Serif SC", serif;--page-max-width:800px;--content-padding:32px;--card-radius:8px;--spacing-xs:8px;--spacing-sm:16px;--spacing-md:24px;--spacing-lg:48px;--spacing-xl:64px;--spacing-xxl:80px;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.4s cubic-bezier(.4, 0, .2, 1)}body{background:var(--bg);color:var(--ink);font-family:var(--font-sans);font-size:14px;line-height:1.55}::selection{background:var(--selection-bg)}.page-container{max-width:var(--page-max-width);padding:24px var(--content-padding) 80px;gap:54px;margin:0 auto;display:grid}.topbar{max-width:var(--page-max-width);padding:32px var(--content-padding) 0;justify-content:space-between;align-items:center;margin:0 auto;display:flex}.topbar-title{font-family:var(--font-mono);letter-spacing:.01em;color:var(--ink);transition:opacity var(--transition-fast);font-size:22px;font-weight:700;text-decoration:none}.topbar-title:hover{opacity:.7}.lang-toggle{border:1px solid var(--border);background:var(--bg-alt);color:var(--ink);cursor:pointer;transition:background var(--transition-fast), border-color var(--transition-fast);border-radius:10px;padding:8px 18px;font-family:inherit;font-size:16px}.lang-toggle:hover{background:var(--bg-elevated);border-color:var(--ink-soft)}.section-header{align-items:center;gap:10px;margin-bottom:18px;display:flex}.section-label{letter-spacing:.08em;text-transform:uppercase;color:#3a3a39;white-space:nowrap;font-size:13px;font-weight:600}.section-rule{background:var(--border-light);flex:1;height:1px}.hero{margin-top:80px;margin-bottom:8px}.hero-title{font-family:var(--font-mono);color:var(--ink);letter-spacing:.01em;margin:0 0 28px;font-size:24px;font-weight:600;line-height:1.3}.hero-desc{font-family:var(--font-sans);color:var(--ink-soft);max-width:560px;margin:0 0 40px;font-size:15px;line-height:1.8}.social-links{align-items:center;gap:16px;display:inline-flex}.social-link{font-size:14px;font-family:var(--font-mono);color:var(--ink-soft);cursor:pointer;transition:color var(--transition-fast);align-items:center;gap:6px;text-decoration:none;display:inline-flex}.social-link:hover{color:var(--ink)}.social-name{text-decoration:underline;-webkit-text-decoration-color:var(--border);text-decoration-color:var(--border);text-underline-offset:4px;transition:text-decoration-color var(--transition-fast)}.social-link:hover .social-name{-webkit-text-decoration-color:var(--ink);text-decoration-color:var(--ink)}.social-divider{color:var(--border);-webkit-user-select:none;user-select:none;font-size:12px}.footer{text-align:center;padding:var(--spacing-lg) var(--content-padding);color:var(--muted);border-top:1px solid var(--border-light);max-width:var(--page-max-width);margin:var(--spacing-xl) auto 0;font-size:13px}.footer a{color:var(--ink-soft);text-decoration:underline;-webkit-text-decoration-color:var(--border);text-decoration-color:var(--border);text-underline-offset:3px}.footer a:hover{color:var(--ink);-webkit-text-decoration-color:var(--ink);text-decoration-color:var(--ink)}.link-underline{color:var(--ink);text-decoration:underline;-webkit-text-decoration-color:var(--border);text-decoration-color:var(--border);text-underline-offset:3px;transition:text-decoration-color var(--transition-fast)}.link-underline:hover{-webkit-text-decoration-color:var(--ink);text-decoration-color:var(--ink)}.loading{text-align:center;color:var(--muted);padding:60px 0;font-size:14px}.not-found{text-align:center;padding:100px 0}.not-found h1{font-family:var(--font-mono);letter-spacing:.01em;color:var(--ink);margin-bottom:18px;font-size:17px;font-weight:500}.not-found p{color:var(--ink-soft);margin-bottom:24px}.view-all{font-size:13px;font-family:var(--font-mono);color:var(--muted);text-decoration:underline;-webkit-text-decoration-color:var(--border-light);text-decoration-color:var(--border-light);text-underline-offset:3px;transition:color var(--transition-fast), text-decoration-color var(--transition-fast)}.view-all:hover{color:var(--ink);-webkit-text-decoration-color:var(--ink);text-decoration-color:var(--ink)}.contact-links{align-items:center;gap:10px;display:inline-flex}.contact-link{font-size:13px;font-family:var(--font-mono);color:var(--ink-soft);text-decoration:underline;-webkit-text-decoration-color:var(--border);text-decoration-color:var(--border);text-underline-offset:3px;transition:color var(--transition-fast), text-decoration-color var(--transition-fast)}.contact-link:hover{color:var(--ink);-webkit-text-decoration-color:var(--ink);text-decoration-color:var(--ink)}.contact-divider{color:var(--border);-webkit-user-select:none;user-select:none;font-size:12px}.contact-block{flex-direction:column;gap:8px;display:flex}.contact-text{color:var(--ink-soft);margin:0;font-size:14px}.module-section{animation:.5s both fadeUp}.module-section:nth-child(2){animation-delay:.1s}.module-section:nth-child(3){animation-delay:.2s}.module-section:nth-child(4){animation-delay:.3s}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.update-notice{background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:6px;align-items:baseline;gap:8px;padding:10px 16px;animation:.5s both fadeUp;display:flex}.update-date{font-family:var(--font-mono);color:var(--muted);flex-shrink:0;font-size:11px}.update-text{font-family:var(--font-mono);color:var(--ink-soft);font-size:13px}.update-link{color:var(--ink);text-decoration:underline;-webkit-text-decoration-color:var(--border-light);text-decoration-color:var(--border-light);text-underline-offset:3px;transition:text-decoration-color var(--transition-fast)}.update-link:hover{-webkit-text-decoration-color:var(--ink);text-decoration-color:var(--ink)}.card-list{flex-direction:column;gap:4px;display:flex}.card-preview{transition:background var(--transition-fast);border-radius:6px;align-items:center;gap:16px;padding:14px 16px;text-decoration:none;display:flex}.card-preview:hover{background:var(--bg-elevated)}.card-preview-text{flex:1;min-width:0}.card-preview-title{font-family:var(--font-mono);color:var(--ink);transition:color var(--transition-fast);margin:0 0 4px;font-size:15px;font-weight:500;line-height:1.4}.card-preview:hover .card-preview-title{color:var(--accent-dark)}.card-preview-author{font-family:var(--font-mono);color:var(--muted);margin:0 0 4px;font-size:12px}.card-preview-excerpt{font-family:var(--font-sans);color:var(--muted);margin:0 0 6px;font-size:13px;line-height:1.55}.card-preview-date{font-family:var(--font-mono);color:var(--muted);font-size:12px}.card-preview-thumb{background:var(--bg-elevated);border-radius:4px;flex-shrink:0;width:90px;height:64px;overflow:hidden}.card-preview-thumb img{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-normal)}.card-preview:hover .card-preview-thumb img{transform:scale(1.05)}.photo-grid-small{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}@media (width<=600px){.photo-grid-small{grid-template-columns:repeat(2,1fr)}}.photo-preview-sm{aspect-ratio:4/3;border-radius:6px;text-decoration:none;display:block;position:relative;overflow:hidden}.photo-preview-sm img{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-slow)}.photo-preview-sm:hover img{transform:scale(1.03)}.photo-preview-overlay-sm{opacity:0;transition:opacity var(--transition-normal);background:linear-gradient(#0000 30%,#0000008c);flex-direction:column;justify-content:flex-end;padding:10px;display:flex;position:absolute;inset:0}.photo-preview-sm:hover .photo-preview-overlay-sm{opacity:1}.photo-preview-title-sm{color:#fff;font-size:12px;font-weight:500;font-family:var(--font-mono)}.photo-preview-location-sm{color:#ffffffbf;font-size:10px;font-family:var(--font-mono);margin-top:2px}.photo-grid-large{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}@media (width<=600px){.photo-grid-large{grid-template-columns:1fr}}.photo-preview{border-radius:var(--card-radius);aspect-ratio:4/3;text-decoration:none;display:block;position:relative;overflow:hidden}.photo-preview img{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-slow)}.photo-preview:hover img{transform:scale(1.03)}.photo-preview-overlay{opacity:0;transition:opacity var(--transition-normal);background:linear-gradient(#0000 40%,#0000008c);flex-direction:column;justify-content:flex-end;padding:16px;display:flex;position:absolute;inset:0}.photo-preview:hover .photo-preview-overlay{opacity:1}.photo-preview-title{color:#fff;font-size:14px;font-weight:500;font-family:var(--font-mono)}.photo-preview-location{color:#ffffffbf;font-size:12px;font-family:var(--font-mono);margin-top:2px}.photo-preview-placeholder{background:linear-gradient(135deg, var(--bg-elevated), var(--border-light));width:100%;height:100%}.footer-nav{padding:24px var(--content-padding) 40px;max-width:var(--page-max-width);border-top:1px solid var(--border-light);justify-content:center;gap:24px;margin:0 auto;display:flex}.footer-nav-link{font-family:var(--font-mono);color:var(--muted);transition:color var(--transition-fast);font-size:12px;text-decoration:none}.footer-nav-link:hover{color:var(--ink)}.footer-nav-link.active{color:var(--ink);font-weight:600}.back-link{color:var(--muted);transition:color var(--transition-fast);margin-bottom:40px;font-size:13px;text-decoration:none;display:inline-block}.back-link:hover{color:var(--ink)}.detail-article{max-width:100%}.detail-header{border-bottom:1px solid var(--border);margin-bottom:40px;padding-bottom:24px}.detail-title{font-family:var(--font-mono);color:var(--ink);letter-spacing:-.02em;margin:0 0 16px;font-size:24px;font-weight:600;line-height:1.3}.detail-meta{color:var(--muted);flex-wrap:wrap;align-items:baseline;gap:16px;font-size:13px;display:flex}.detail-excerpt{color:var(--ink-soft);margin:24px 0 32px;font-size:15px;line-height:1.7}.tag{color:var(--code-fg);background:var(--accent);letter-spacing:.04em;border-radius:4px;margin-bottom:4px;margin-right:8px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-block}.ai-summary{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.separator{background:var(--border);width:40px;height:1px;margin:32px 0}@media (width<=600px){.photo-preview-overlay-sm,.photo-preview-overlay{opacity:1;background:linear-gradient(#0000 50%,#0000008c)}:root{--content-padding:16px}body{font-size:14px}.page-container{gap:32px;padding:32px 16px 50px}.topbar{padding:16px 16px 0}.topbar-title{font-size:18px}.hero-title{font-size:20px}.hero-desc{margin-bottom:28px;font-size:14px}.update-notice{flex-wrap:wrap;gap:4px;padding:8px 12px}.photo-grid-small{grid-template-columns:repeat(2,1fr);gap:6px}.photo-grid-large{grid-template-columns:1fr;gap:8px}.card-preview{gap:12px;padding:12px}.card-preview-thumb{width:72px;height:54px}.card-preview-title{font-size:14px}.card-preview-excerpt{-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:12px;display:-webkit-box;overflow:hidden}.detail-title{font-size:20px}.detail-body{margin-bottom:48px}.markdown-body{font-size:15px;line-height:1.8}.markdown-body h1{font-size:20px}.markdown-body h2{font-size:18px}.markdown-body h3{font-size:15px}.markdown-body pre{-webkit-overflow-scrolling:touch;padding:12px 14px;font-size:12px;overflow-x:auto}.markdown-body table{-webkit-overflow-scrolling:touch;display:block;overflow-x:auto}.section-header{margin-bottom:14px}.section-label{font-size:12px}.footer-nav{flex-wrap:wrap;gap:16px;padding:20px 16px 32px}.footer-nav-link{font-size:11px}.detail-tags{gap:6px}.detail-tag{padding:2px 6px;font-size:11px}.contact-links{flex-wrap:wrap;gap:6px}.contact-link{font-size:12px}}@media (width<=400px){.page-container{padding:24px 12px 40px}.topbar{padding:12px 12px 0}.topbar-title{font-size:16px}.hero-title{font-size:18px}.hero-desc{font-size:13px}.card-preview{flex-direction:column;align-items:flex-start}.card-preview-thumb{width:100%;height:80px}.photo-grid-small{grid-template-columns:repeat(2,1fr)}.detail-title{font-size:18px}.footer-nav{gap:12px;padding:16px 12px 24px}}.gallery-card{aspect-ratio:3/4;background:var(--ink);color:#ededed;--out:0;--hov:0;--bit:calc(var(--out) * (1 - var(--hov)));border-radius:.75em;width:12em;text-decoration:none;transition:transform .5s cubic-bezier(.4,0,.2,1),filter .5s cubic-bezier(.4,0,.2,1),box-shadow .5s cubic-bezier(.4,0,.2,1);display:block;position:relative;overflow:hidden}.gallery-card:before{content:"";background:linear-gradient(transparent 40%, #0009), var(--card-image,transparent);background-position:50%;background-size:cover;transition:transform .5s cubic-bezier(.4,0,.2,1);position:absolute;inset:0}.gallery-card:hover:before{transform:scale(1.1)}.gallery-card-content{translate:0 calc((1 - var(--hov)) * 10px);opacity:var(--hov);padding:.5em .75em .75em;transition:translate .5s cubic-bezier(.4,0,.2,1),opacity .5s cubic-bezier(.4,0,.2,1);position:absolute;bottom:0;left:0;right:0}.gallery-card h3{font-family:var(--font-mono);color:#fff;letter-spacing:normal;margin:.125em 0;font-size:1.1em;font-weight:700}.gallery-card p{font-family:var(--font-mono);color:#fffc;margin:0;font-size:.85em;font-weight:300}.gallery-card:hover{--hov:1;box-shadow:0 20px 40px -12px #00000059}.gallery{--out:0;flex-wrap:wrap;justify-content:center;place-self:center;gap:1.25em;padding:20px 0;display:flex}.gallery:has(.gallery-card:hover){--out:1}.photo-card{aspect-ratio:4/3;border-radius:var(--card-radius);cursor:pointer;position:relative;overflow:hidden}.photo-card img{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-slow)}.photo-card:hover img{transform:scale(1.03)}.photo-card-overlay{opacity:0;transition:opacity var(--transition-normal);background:linear-gradient(#0000 50%,#00000080);align-items:flex-end;padding:16px;display:flex;position:absolute;inset:0}.photo-card:hover .photo-card-overlay{opacity:1}.photo-card-title{color:#fff;font-size:13px;font-weight:500}.photo-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}@media (width<=600px){.photo-grid{grid-template-columns:repeat(2,1fr)}.detail-title{font-size:20px}.photo-card-overlay{opacity:1;background:linear-gradient(#0000 50%,#00000080)}}@media (width<=400px){.photo-grid{grid-template-columns:1fr}.detail-title{font-size:18px}}.detail-page{max-width:680px}.detail-header{margin-bottom:32px}.detail-body{margin-bottom:80px}.detail-title{font-family:var(--font-mono);letter-spacing:.01em;color:var(--ink);margin:0 0 12px;font-size:24px;font-weight:600;line-height:1.4}.detail-author{font-family:var(--font-mono);color:var(--ink-muted);margin:0 0 12px;font-size:14px}.detail-excerpt{font-family:var(--font-sans);color:var(--ink-muted);margin:0 0 24px;font-size:14px;line-height:1.55}.detail-date{font-family:var(--font-mono);color:var(--ink-muted);margin:0 0 24px;font-size:12px}.detail-tags{flex-wrap:wrap;gap:8px;margin-bottom:32px;display:flex}.detail-tag{color:var(--code-fg);background:var(--accent);border-radius:4px;padding:2px 8px;font-size:12px;font-weight:600}.markdown-body{font-family:var(--font-serif);color:var(--ink-soft);font-size:16px;line-height:1.85}.markdown-body p{margin-bottom:16px}.markdown-body p:last-child{margin-bottom:0}.markdown-body h1,.markdown-body h2,.markdown-body h3{font-family:var(--font-mono);color:var(--ink);letter-spacing:-.01em;margin-top:40px;margin-bottom:16px;font-weight:600}.markdown-body h1{font-size:24px}.markdown-body h2{font-size:20px}.markdown-body h3{font-size:17px}.markdown-body a{color:var(--ink);text-decoration:underline;-webkit-text-decoration-color:var(--border);text-decoration-color:var(--border);text-underline-offset:4px;transition:text-decoration-color var(--transition-fast)}.markdown-body a:hover{-webkit-text-decoration-color:var(--ink);text-decoration-color:var(--ink)}.markdown-body strong{color:var(--ink);font-weight:600}.markdown-body em{color:var(--ink)}.markdown-body ul{margin:8px 0 16px;padding-left:0;list-style:none}.markdown-body ul li{margin-bottom:8px;padding-left:16px;position:relative}.markdown-body ul li:before{content:"·";color:var(--accent);font-weight:700;position:absolute;left:0}.markdown-body ol{margin:8px 0 16px 24px;padding-left:0}.markdown-body ol li{margin-bottom:8px}.markdown-body blockquote{border-left:2.5px solid var(--border);font-family:var(--font-serif);color:var(--ink-soft);margin:20px 0 20px 28px;padding:2px 0 2px 20px;font-size:16px;font-style:italic;line-height:1.85;position:relative}.markdown-body blockquote:before{content:"“";color:var(--border);font-family:Georgia,Times New Roman,serif;font-size:28px;font-style:normal;line-height:1;position:absolute;top:-2px;left:-28px}.markdown-body blockquote p{color:var(--ink-soft);margin-bottom:8px}.markdown-body blockquote p:last-child{margin-bottom:0}.markdown-body code{font-family:var(--font-mono);background:var(--code-bg);color:var(--code-fg);border-radius:3px;padding:2px 6px;font-size:.85em}.markdown-body pre{color:#e0e0e0;background:#1c1c1c;border-radius:6px;margin-bottom:16px;padding:16px 20px;font-size:13px;line-height:1.6;overflow-x:auto}.markdown-body pre code{color:inherit;font-size:inherit;background:0 0;padding:0}.markdown-body img{border-radius:6px;max-width:100%;margin:20px 0}.markdown-body hr{border:none;border-top:1px solid var(--border-light);margin:36px 0}.markdown-body table{border-collapse:collapse;width:100%;margin:16px 0;font-size:14px}.markdown-body th,.markdown-body td{border:1px solid var(--border);text-align:left;padding:8px 12px}.markdown-body th{background:var(--bg-elevated);font-weight:600}
