@font-face{font-family:"JetBrains Mono";src:url("/fonts/JetBrainsMono-Regular.woff2") format("woff2");font-weight:400;font-display:optional;font-style:normal}:root{--brand-blue: #1e2650;--brand-orange: #d34516;--bg: #f8fafc;--bg-alt: #ffffff;--bg-elevated: #f1f5f9;--bg-surface: #ffffff;--border: #e2e8f0;--border-hover: #cbd5e1;--fg: #1e2650;--fg-bright: #050a1f;--fg-dim: #475569;--link: #b13a12;--accent: #c13d11;--accent-alt: #a1320e;--accent-glow: rgba(193, 61, 17, 0.08);--success: #10b981;--error: #ef4444;--keyword: #ff8f40;--string: #aad94c;--func: #39bae6;--max-width: 75rem;--content-width: 50rem;--font-sans: "Noto Sans", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--radius-sm: 0.375rem;--radius: 0.625rem;--radius-lg: 0.875rem;--radius-xl: 1.25rem;--shadow-sm: 0 0.0625rem 0.125rem 0 rgba(0, 0, 0, 0.05);--shadow: 0 0.25rem 0.375rem -0.0625rem rgba(0, 0, 0, 0.1), 0 0.125rem 0.25rem -0.125rem rgba(0, 0, 0, 0.1);--shadow-lg: 0 0.625rem 0.9375rem -0.1875rem rgba(0, 0, 0, 0.1), 0 0.25rem 0.375rem -0.25rem rgba(0, 0, 0, 0.1);--transition: 0.2s cubic-bezier(0.4, 0, 0.2, 1);--transition-slow: 0.3s cubic-bezier(0.4, 0, 0.2, 1);--nav-height: 4rem}html.dark-mode{--bg: #0b0e1d;--bg-alt: #141935;--bg-elevated: #1e2650;--bg-surface: #273167;--border: #2e3b7b;--border-hover: #3b4ba0;--fg: #f2f7fb;--fg-bright: #ffffff;--fg-dim: #9aaec7;--link: #f55f28;--accent: #f55f28;--accent-alt: #ff7c4d;--accent-glow: rgba(245, 95, 40, 0.15);--shadow-sm: 0 0.0625rem 0.125rem 0 rgb(0 0 0 / 0.05);--shadow: 0 0.25rem 0.375rem -0.0625rem rgb(0 0 0 / 0.1), 0 0.125rem 0.25rem -0.125rem rgb(0 0 0 / 0.1);--shadow-lg: 0 0.625rem 0.9375rem -0.1875rem rgb(0 0 0 / 0.1), 0 0.25rem 0.375rem -0.25rem rgb(0 0 0 / 0.1)}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{background:var(--bg);scroll-behavior:smooth;scrollbar-gutter:stable}html::-webkit-scrollbar{width:0;height:0}html{scrollbar-width:none;-ms-overflow-style:none;}.page-progress{position:fixed;top:0;left:0;width:0;height:3px;background:linear-gradient(90deg, var(--accent), var(--accent-alt));z-index:9999;pointer-events:none;transform:translateZ(0);will-change:width;transition:none;}html,body{overflow-x:hidden;overscroll-behavior-x:none}body{font-family:var(--font-sans);background:var(--bg);color:var(--fg);line-height:1.7;font-size:1rem;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;hyphens:auto;}:focus-visible{outline:2px solid var(--accent);outline-offset:4px;border-radius:var(--radius-sm)}.control-btn:focus-visible,.nav-link:focus-visible,.tag:focus-visible{border-radius:var(--radius)}body.menu-open{overflow:hidden;touch-action:none}.container{max-width:var(--max-width);margin:0 auto;padding:0 2rem}@media (prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}html{scroll-behavior:auto}.page-progress{transition:none}}a{color:var(--link);text-decoration:underline;text-underline-offset:.1875rem;text-decoration-thickness:.0625rem;transition:color var(--transition),text-decoration-color var(--transition)}a:hover{color:var(--accent)}header{position:sticky;top:0;z-index:1500;background:var(--bg-alt);border-bottom:.0625rem solid var(--border)}@supports (backdrop-filter: blur(1rem)){header{background:rgba(248,250,252,.85);backdrop-filter:blur(.75rem) saturate(180%);-webkit-backdrop-filter:blur(.75rem) saturate(180%)}html.dark-mode header{background:rgba(11,14,29,.85)}}nav{display:flex;align-items:center;justify-content:space-between;height:var(--nav-height)}.nav-brand a{font-weight:700;font-size:1.125rem;color:var(--fg-bright);letter-spacing:-.03125rem;text-decoration:none;transition:color var(--transition)}.nav-brand a:hover{color:var(--accent)}.nav-actions{display:flex;align-items:center;gap:1.5rem}.nav-links{display:flex;align-items:center;gap:.25rem;list-style:none;margin:0;padding:0}.nav-link{font-size:.875rem;font-weight:500;color:var(--fg-dim);text-decoration:none;padding:.5rem .875rem;border-radius:var(--radius);transition:all var(--transition);position:relative;white-space:nowrap}.nav-link::after{content:"";position:absolute;bottom:.25rem;left:50%;width:0;height:.125rem;background:var(--accent);border-radius:1rem;transition:all var(--transition);transform:translateX(-50%)}.nav-link:hover{color:var(--fg-bright)}.nav-link:hover::after{width:50%}.nav-link.active{color:var(--accent);font-weight:600}.nav-link.active::after{width:50%}.header-controls{display:flex;align-items:center;gap:.375rem}.control-btn{width:2.25rem;height:2.25rem;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0);border:none;color:var(--fg-dim);border-radius:var(--radius);cursor:pointer;transition:all var(--transition);text-decoration:none}.control-btn:hover{color:var(--fg-bright);background:var(--bg-elevated)}.menu-toggle{display:none;flex-direction:column;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;background:none;border:none;cursor:pointer;position:relative;z-index:1500;transition:all var(--transition)}.hamburger-line{display:block;width:1.25rem;height:.125rem;background:var(--fg);border-radius:1rem;transition:all .4s cubic-bezier(.16, 1, .3, 1)}.hamburger-line:nth-child(2){margin:.3125rem 0}.menu-toggle.open .hamburger-line:nth-child(1){transform:translateY(.4375rem) rotate(45deg);background:var(--accent)}.menu-toggle.open .hamburger-line:nth-child(2){opacity:0;transform:scaleX(0)}.menu-toggle.open .hamburger-line:nth-child(3){transform:translateY(-.4375rem) rotate(-45deg);background:var(--accent)}.sun-icon{display:none}.moon-icon{display:block}html.dark-mode .sun-icon{display:block}html.dark-mode .moon-icon{display:none}.hero-section{padding:6.25rem 0 3.75rem;margin:0;position:relative}.hero-section::before{content:"";position:absolute;top:-10%;right:-5%;width:25rem;height:25rem;background:radial-gradient(circle, var(--accent-glow) 0%, rgba(0,0,0,0) 60%);z-index:-1;pointer-events:none;opacity:.2;filter:blur(6rem)}.hero-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:3.75rem;align-items:center;position:relative;z-index:1}.hero-text{max-width:100%;min-height:8rem;}.hero-visual{display:flex;justify-content:center;position:relative}.profile-frame{position:relative;width:100%;max-width:20rem;aspect-ratio:320/380;height:auto;border-radius:2rem;background:var(--bg-surface);border:.0625rem solid var(--border);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);transition:transform .4s cubic-bezier(.34, 1.56, .64, 1)}.profile-frame:hover{transform:translateY(-.3125rem)}.profile-img{width:100%;height:100%;object-fit:cover;border-radius:1.5rem}@media (max-width: 60.5rem){.hero-grid{grid-template-columns:1fr;gap:2.5rem;text-align:center}.hero-visual{order:-1;margin:0 auto 1.25rem}.profile-frame{max-width:12rem;margin:0 auto}}.smart-greeting{font-size:3.5rem;font-weight:400;color:var(--fg-bright);margin-bottom:1rem;line-height:1.1;letter-spacing:-.09375rem;}.hero-tagline{font-size:1.25rem;color:var(--fg-dim);font-weight:400;max-width:35rem;line-height:1.5}@media (max-width: 48rem){.hero-tagline{font-size:1.125rem;margin:0 auto}}@media (max-width: 48rem){.hero-section{padding:2.5rem 0 3.75rem}.smart-greeting{font-size:2.5rem}.profile-frame{max-width:10rem}}main{padding:3rem 0;min-height:calc(100vh - 12.5rem)}.page-header{margin-bottom:3rem;padding-bottom:2rem;border-bottom:.0625rem solid var(--border)}.page-header h1{font-size:2.25rem;font-weight:700;color:var(--fg-bright);margin-bottom:.5rem;letter-spacing:-.03125rem}.page-header p,.section-description{font-size:1.0625rem;color:var(--fg-dim);max-width:37.5rem;margin-bottom:1.5rem}main>h1:first-child{font-size:2.25rem;font-weight:700;color:var(--fg-bright);margin-bottom:.75rem;letter-spacing:-.03125rem}section{margin:2.5rem 0}#latest-posts{margin-top:1.5rem}section h2{font-size:1.5rem;font-weight:600;color:var(--fg-bright);margin-bottom:1.25rem;letter-spacing:-.01875rem;display:flex;align-items:center;gap:.75rem}section h2::after{content:"";flex:1;height:.0625rem;background:var(--border)}.posts-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:1.25rem}.post-card{background:var(--bg-alt);border:.0625rem solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;transition:all var(--transition);display:flex;flex-direction:column;position:relative;overflow:hidden}.post-card::before{content:"";position:absolute;top:0;left:0;right:0;height:.1875rem;background:linear-gradient(90deg, var(--accent), var(--link));opacity:0;transition:opacity var(--transition)}.post-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow);transform:translateY(-.1875rem)}.post-card:hover::before{opacity:1}.post-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;font-size:.8125rem;color:var(--fg-dim)}.post-card h3{font-size:1.125rem;font-weight:600;margin-bottom:.5rem;line-height:1.4}.post-card h3 a{color:var(--fg-bright);text-decoration:none;transition:color var(--transition)}.post-card h3 a:hover{color:var(--accent)}.post-card-excerpt{font-size:.875rem;color:var(--fg);line-height:1.6;margin-bottom:1rem;flex:1;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.post-card-tags{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:1rem}.post-card-link{font-size:.875rem;font-weight:500;color:var(--link);margin-top:auto;display:flex;align-items:center;gap:.25rem}.post-card-link:hover{color:var(--accent)}@media (max-width: 48rem){.posts-grid{grid-template-columns:1fr}}.post-list{list-style:none;display:grid;gap:1rem}.post-item{display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem;background:var(--bg-alt);border:.0625rem solid var(--border);border-radius:var(--radius-lg);padding:1.5rem 1.75rem;transition:all var(--transition)}.post-item:hover{border-color:var(--border-hover);box-shadow:var(--shadow);transform:translateY(-.125rem)}.post-content-left{flex:1;min-width:0}.post-content-left h2,.post-content-left h3{font-size:1.125rem;font-weight:600;line-height:1.4;margin-bottom:.25rem}.post-content-left h2 a,.post-content-left h3 a{color:var(--fg-bright);text-decoration:none;transition:color var(--transition)}.post-content-left h2 a:hover,.post-content-left h3 a:hover{color:var(--accent)}.post-excerpt{font-size:.875rem;color:var(--fg-dim);margin-top:.375rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.post-meta-right{display:flex;flex-direction:column;align-items:flex-end;gap:.375rem;flex-shrink:0;text-align:right;min-width:8.75rem}.post-date{font-size:.8125rem;color:var(--fg-dim);white-space:nowrap}.post-reading{font-size:.75rem;color:var(--fg-dim);opacity:.8}.post-tags{display:flex;flex-wrap:wrap;gap:.25rem;justify-content:flex-end;margin-top:.25rem}.tag{display:inline-flex;align-items:center;padding:.25rem .75rem;font-size:.75rem;font-weight:500;color:var(--accent);background:var(--accent-glow);border:.0625rem solid var(--accent-glow);border-radius:6.25rem;white-space:nowrap;transition:all var(--transition)}.tag:hover{background:rgba(211,69,22,.2);border-color:var(--accent)}.post-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--fg-dim);margin-bottom:.5rem}.post-tags{display:flex;flex-wrap:wrap;gap:.5rem}.post-tag{font-size:.75rem;font-weight:600;color:#fff;background:rgba(211,69,22,.2);padding:.25rem .75rem;border-radius:6.25rem;border:.0625rem solid rgba(211,69,22,.3);transition:all var(--transition)}.post-tag:hover{background:var(--accent);border-color:var(--accent);transform:translateY(-.0625rem)}html.light-mode .post-tag{background:#fee2e2;color:#b91c1c;border-color:#fecaca}html.light-mode .post-tag:hover{background:var(--accent);color:#fff}.view-all{display:inline-flex;align-items:center;gap:.375rem;margin-top:1.5rem;padding:.75rem 1.25rem;font-size:.875rem;font-weight:600;color:var(--link);background:var(--bg-alt);border:.0625rem solid var(--border);border-radius:var(--radius);transition:all var(--transition)}.view-all:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-glow)}.filters,.gallery-categories{display:flex;flex-wrap:wrap;gap:.625rem;margin-bottom:2rem;margin-top:3rem}.filter-tag{padding:.625rem 1.125rem;font-size:.875rem;font-weight:500;background:var(--bg-alt);border:.0625rem solid var(--border);color:var(--fg-dim);border-radius:6.25rem;cursor:pointer;font-family:inherit;transition:all var(--transition)}.filter-tag:hover{color:var(--fg-bright);border-color:var(--fg-dim)}.filter-tag.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(20rem, 1fr));gap:1.25rem}.project-card{background:var(--bg-alt);border:.0625rem solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;transition:all var(--transition);position:relative;overflow:hidden;display:flex;flex-direction:column;height:100%}.project-card::before{content:"";position:absolute;top:0;left:0;right:0;height:.1875rem;background:linear-gradient(90deg, var(--accent), var(--link));opacity:0;transition:opacity var(--transition)}.project-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow);transform:translateY(-.1875rem)}.project-card:hover::before{opacity:1}.project-type{display:inline-flex;align-items:center;padding:.25rem .75rem;font-size:.75rem;font-weight:600;color:var(--accent);background:var(--accent-glow);border:.0625rem solid var(--accent-glow);border-radius:6.25rem;margin-bottom:1rem;align-self:flex-start;text-transform:uppercase;letter-spacing:.05em}.project-card h3{font-size:1.25rem;font-weight:600;margin-bottom:.625rem;line-height:1.3}.project-card h3 a{color:var(--fg-bright);text-decoration:none}.project-card h3 a:hover{color:var(--accent)}.project-card>p{font-size:.9375rem;color:var(--fg-dim);margin-bottom:1.25rem;line-height:1.6;flex-grow:1}.tech-stack{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:1.25rem}.tech-badge{font-size:.75rem;padding:.25rem .625rem;background:var(--bg-alt);color:var(--fg);border-radius:var(--radius-sm);border:.0625rem solid var(--border);transition:all var(--transition)}.project-card:hover .tech-badge{border-color:var(--border-hover);color:var(--fg-bright)}.project-links{display:flex;gap:1rem;margin-top:auto;padding-top:1rem;border-top:.0625rem solid var(--border)}.project-links a{display:inline-flex;align-items:center;gap:.375rem;font-size:.875rem;font-weight:500;color:var(--accent);transition:color var(--transition)}.project-links a:hover{color:var(--accent-alt);text-decoration:underline}.project-badge{position:absolute;top:.75rem;right:.75rem;padding:.375rem .875rem;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:var(--accent);color:#fff;border-radius:6.25rem;box-shadow:0 .25rem .75rem var(--accent-glow)}.project-card h2{font-size:1.125rem;font-weight:600;margin-bottom:.625rem}.project-card h2 a{color:var(--fg-bright);text-decoration:none}.project-card h2 a:hover{color:var(--accent)}.gallery-grid{display:grid;gap:1.75rem}.gallery-album{background:var(--bg-alt);border:.0625rem solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition)}.gallery-album:hover{border-color:var(--border-hover);box-shadow:var(--shadow)}.album-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.75rem;background:var(--bg-surface);border-bottom:.0625rem solid var(--border)}.album-header h2{font-size:1.25rem;margin:0}.album-header h2::after{display:none}.album-meta{font-size:.8125rem;color:var(--fg-dim);padding:.25rem .75rem;background:var(--bg-elevated);border-radius:6.25rem}.album-desc{font-size:.9375rem;color:var(--fg);padding:1.25rem 1.75rem;border-top:.0625rem solid var(--border)}.carousel{position:relative;background:var(--bg);overflow:hidden}.search-empty-tags{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;margin-top:1.5rem;max-width:30rem;margin-left:auto;margin-right:auto}.carousel-track{display:flex;transition:transform .4s cubic-bezier(.4, 0, .2, 1);height:100%;touch-action:pan-y;will-change:transform}.carousel-slide{flex:0 0 100%;position:relative;aspect-ratio:16/9;background:var(--bg-surface)}.carousel-slide img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;opacity:1;transition:opacity .3s ease}.carousel-slide img[src=""],.carousel-slide img:not([src]){visibility:hidden}.carousel-slide::before{content:"";position:absolute;inset:0;background:var(--bg-surface);z-index:-1}.carousel-slide img.error{opacity:0}.carousel-slide.error::after{content:"Image unavailable";position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);color:var(--fg-dim);font-size:.875rem}.carousel-caption{position:absolute;bottom:0;left:0;right:0;padding:1.5rem 1.75rem;background:linear-gradient(to top, rgba(0,0,0,.85) 0%, rgba(0,0,0,.4) 60%, rgba(0,0,0,0) 100%);color:#fff;font-size:.9375rem;font-weight:500;z-index:2}.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.6);color:#fff;border:none;width:3rem;height:3rem;border-radius:50%;font-size:1.5rem;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(.25rem);z-index:3}.carousel-btn:hover{background:rgba(0,0,0,.8);transform:translateY(-50%) scale(1.05)}.carousel-btn:disabled{opacity:.3;cursor:not-allowed}.carousel-prev{left:1rem}.carousel-next{right:1rem}.carousel-dots{position:absolute;bottom:1rem;left:50%;transform:translateX(-50%);display:flex;gap:.625rem;padding:.5rem 1rem;background:rgba(0,0,0,.5);border-radius:6.25rem;backdrop-filter:blur(.25rem);z-index:3}.carousel-dot{width:.625rem;height:.625rem;border-radius:50%;background:rgba(255,255,255,.4);border:none;cursor:pointer;transition:all var(--transition);padding:0}.carousel-dot.active,.carousel-dot:hover{background:#fff;transform:scale(1.2)}@media (max-width: 48rem){.carousel-slide{aspect-ratio:4/3}.carousel-btn{width:2.5rem;height:2.5rem;font-size:1.25rem}.carousel-prev{left:.5rem}.carousel-next{right:.5rem}.carousel-caption{padding:1rem 1.25rem;font-size:.875rem}}@media (max-width: 30rem){.carousel-slide{aspect-ratio:1/1}}.search-container{margin-bottom:2rem}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:1.125rem;color:var(--fg-dim);pointer-events:none}#search-input{width:100%;padding:1rem 3rem;font-size:1rem;background:var(--bg-alt);border:.125rem solid var(--border);border-radius:var(--radius-lg);color:var(--fg-bright);font-family:inherit;transition:all var(--transition)}#search-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 .25rem var(--accent-glow)}#search-input::placeholder{color:var(--fg-dim)}.search-clear{position:absolute;right:.75rem;display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:var(--bg-surface);border:.0625rem solid var(--border);border-radius:var(--radius);color:var(--fg-dim);cursor:pointer;transition:all var(--transition)}.search-clear:hover{color:var(--fg-bright);border-color:var(--fg-dim)}#search-stats{font-size:.875rem;color:var(--fg-dim);margin-top:1rem;padding-left:.25rem}.search-result-item{display:block;padding:1.5rem;margin-bottom:.75rem;background:var(--bg-alt);border:.0625rem solid var(--border);border-radius:var(--radius-lg);transition:all var(--transition);text-decoration:none}.search-result-item:hover,.search-result-item.selected{border-color:var(--border-hover);box-shadow:var(--shadow);transform:translateY(-.125rem)}.search-result-item.selected{border-color:var(--accent)}.search-result-item h3{font-size:1.0625rem;font-weight:600;color:var(--fg-bright);margin-bottom:.5rem}.search-result-item p{font-size:.9375rem;color:var(--fg);line-height:1.6}.search-result-item mark{background:rgba(99,102,241,.2);color:var(--accent);padding:.0625rem .25rem;border-radius:.25rem;font-weight:500}.search-hint{padding:1.75rem;background:var(--bg-alt);border:.0625rem solid var(--border);border-radius:var(--radius-lg);font-size:.9375rem;color:var(--fg)}.search-hint ul{margin:1rem 0 0 1.5rem}.search-hint li{margin-bottom:.5rem}.search-hint kbd{padding:.25rem .625rem;background:var(--bg-surface);border:.0625rem solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:.8125rem;color:var(--fg);box-shadow:0 .125rem 0 var(--border)}.search-empty{text-align:center;padding:4rem;color:var(--fg-dim)}.search-empty-hint{font-size:.875rem;margin-top:.5rem;opacity:.7}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.75rem;font-size:.9375rem;font-weight:600;border-radius:var(--radius);transition:all var(--transition);cursor:pointer;border:none;font-family:inherit}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 .25rem .75rem var(--accent-glow)}.btn-primary:hover{background:var(--accent-alt);transform:translateY(-.125rem);box-shadow:var(--shadow)}.btn-secondary{background:rgba(0,0,0,0);color:var(--fg-bright);border:.0625rem solid var(--border)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}pre{background:var(--bg-alt);border:.0625rem solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;overflow-x:auto;font-family:var(--font-mono);font-size:.875rem;line-height:1.7;margin:1.5rem 0;position:relative;width:fit-content;max-width:100%}pre code{background:none;padding:0;font-size:inherit}code{font-family:var(--font-mono);font-size:.875rem;background:var(--bg-surface);padding:.1875rem .5rem;border-radius:var(--radius-sm);color:var(--keyword)}.copy-button{position:absolute;top:.75rem;right:.75rem;padding:.5rem .875rem;font-size:.75rem;font-weight:500;background:var(--bg-surface);border:.0625rem solid var(--border);color:var(--fg-dim);border-radius:var(--radius);cursor:pointer;opacity:0;transition:all var(--transition);font-family:inherit}pre:hover .copy-button{opacity:1}.copy-button:hover{color:var(--fg-bright);border-color:var(--fg-dim)}.copy-button.copied{color:var(--success);border-color:var(--success)}.post{max-width:var(--content-width);margin:0 auto}.post-header{margin-bottom:3rem;padding-top:3rem;}.post-header h1{font-size:2.25rem;font-weight:700;line-height:1.3;color:var(--fg-bright);margin-bottom:1rem}.post-meta{margin-bottom:1.5rem;}.post-content{max-width:var(--content-width);line-height:1.8;color:var(--fg);font-size:1.0625rem;}.post-content h2,.post-content h3,.post-content h4{color:var(--fg-bright);margin-top:3rem;margin-bottom:1.25rem;font-weight:700;letter-spacing:-.02em;line-height:1.3}.post-content h2{font-size:1.75rem;border-bottom:.0625rem solid var(--border);padding-bottom:.5rem}.post-content h3{font-size:1.375rem}.post-content h4{font-size:1.125rem}.post-content p{margin-bottom:1.5rem}.post-content table{width:fit-content;max-width:100%;border-collapse:collapse;margin:2.5rem 0;font-size:.9375rem;background:var(--bg-alt);border-radius:var(--radius-lg);overflow:hidden;display:block;overflow-x:auto;border:.0625rem solid var(--border)}.post-content th,.post-content td{padding:.875rem 1.125rem;border:.0625rem solid var(--border);text-align:left;min-width:7.5rem}.post-content th{background:var(--bg-surface);color:var(--fg-bright);font-weight:700;text-transform:uppercase;font-size:.8125rem;letter-spacing:.05em}html.light-mode .post-content th{background:var(--bg-elevated)}.post-content tr:nth-child(even){background:rgba(255,255,255,.03)}html.light-mode .post-content tr:nth-child(even){background:rgba(0,0,0,.02)}.post-content tr:hover td{background:rgba(var(--accent), .05)}.post-content ul,.post-content ol{padding-left:1.5rem;margin:1.5rem 0}.post-content li{margin-bottom:.75rem;line-height:1.7}.post-content li::marker{color:var(--accent);font-weight:700}.post-content blockquote{border-left:.25rem solid var(--accent);background:var(--bg-alt);padding:1.5rem 2rem;margin:2.5rem 0;font-style:italic;color:var(--fg);border-radius:0 var(--radius) var(--radius) 0;box-shadow:var(--shadow-sm)}.post-content blockquote p:last-child{margin-bottom:0}.post-content img{max-width:100%;height:auto;border-radius:var(--radius-lg);margin:2.5rem 0;border:.0625rem solid var(--border);box-shadow:var(--shadow)}.post-content hr{border:none;border-top:.125rem solid var(--border);margin:4rem 0;opacity:.5}.post-content a{text-decoration:underline;text-underline-offset:.25rem;text-decoration-thickness:.0625rem;color:var(--link);transition:all var(--transition)}.post-content a:hover{color:var(--accent);text-decoration-thickness:.125rem}footer{margin-top:5rem;padding:2.5rem 0;border-top:.0625rem solid var(--border);text-align:center}.social-links{display:flex;justify-content:center;gap:1.25rem;margin-bottom:1.25rem}.social-links a{color:var(--fg-dim);padding:.625rem;border-radius:var(--radius);transition:all var(--transition)}.social-links a:hover{color:var(--accent);background:var(--bg-surface)}footer p{font-size:.875rem;color:var(--fg-dim)}#reading-progress{position:fixed;top:0;left:0;height:.1875rem;background:linear-gradient(90deg, var(--accent), var(--link));z-index:101;width:0}.floating-action-group{position:fixed !important;bottom:2rem !important;right:2rem !important;display:flex;flex-direction:column;gap:.75rem;z-index:200 !important;opacity:0;pointer-events:none;transition:opacity var(--transition)}.floating-action-group.visible{opacity:1;pointer-events:auto}.fab-btn{width:3rem;height:3rem;border-radius:50%;background:var(--bg-alt);border:.0625rem solid var(--border);color:var(--fg-dim);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition);box-shadow:var(--shadow);padding:0;}.fab-btn:hover{color:var(--accent);border-color:var(--accent);transform:translateY(-.125rem)}.post-header{position:static !important}@media (max-width: 48rem){.container{padding:0 1.25rem}.floating-action-group{bottom:5rem !important;right:1.25rem !important;gap:.5rem}.fab-btn{width:2.5rem;height:2.5rem}.fab-btn svg{width:1.125rem;height:1.125rem}nav{height:3.5rem}.nav-brand a{font-size:1rem}.nav-links a,.nav-links button{padding:.5rem .75rem;font-size:.8125rem}main{padding:2rem 0}main>h1:first-child,.page-header h1,.post-header h1{font-size:1.75rem}section h2{font-size:1.25rem}.projects-grid{grid-template-columns:1fr}.post-item{flex-direction:column;gap:.75rem;padding:1.25rem}.post-meta-right{align-items:flex-start;text-align:left;flex-direction:row;flex-wrap:wrap;gap:.5rem;min-width:auto}.post-tags{justify-content:flex-start;margin-top:0}.project-card{padding:1.25rem}}@media (max-width: 30rem){.filters,.gallery-categories{gap:.5rem}.filter-tag{padding:.5rem .875rem;font-size:.8125rem}}.empty-state,.carousel-empty{padding:3rem 1.5rem;text-align:center;color:var(--fg-dim);background:var(--bg-surface);border-radius:var(--radius)}.carousel-empty{padding:4rem 1.5rem}::-webkit-scrollbar{width:.625rem;height:.625rem}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:.3125rem}::-webkit-scrollbar-thumb:hover{background:var(--fg-dim)}:focus-visible{outline:.125rem solid var(--accent);outline-offset:.1875rem}::selection{background:var(--accent);color:var(--bg)}@keyframes fadeIn{from{opacity:0;transform:translateY(.5rem)}to{opacity:1;transform:translateY(0)}}.post-item,.project-card,.search-result-item,.gallery-album{animation:fadeIn .4s ease forwards}body.reading-mode header,body.reading-mode footer,body.reading-mode .share-actions,body.reading-mode .post-nav,body.reading-mode #scroll-to-top,body.reading-mode #reading-progress{display:none !important}body.reading-mode main{padding-top:2.5rem;max-width:50rem;margin:0 auto}body.reading-mode .post-header{text-align:center;margin-bottom:4rem}body.reading-mode .post-content{font-size:1.125rem;line-height:1.8}body.reading-mode .floating-action-group{opacity:1 !important;pointer-events:auto !important}.btn-icon{background:none;border:none;color:var(--fg-dim);cursor:pointer;padding:.5rem;border-radius:var(--radius);transition:all var(--transition);display:inline-flex;align-items:center;justify-content:center}.btn-icon:hover{color:var(--accent);background:var(--bg-surface)}.error-page{text-align:center;padding:5rem 1.25rem}.error-page h1{font-size:7.5rem;font-weight:800;color:var(--accent);line-height:1;margin-bottom:1rem}.error-message{font-size:1.5rem;color:var(--fg-bright);margin-bottom:.5rem}.error-hint{font-size:1rem;color:var(--fg-dim);margin-bottom:2rem;max-width:25rem;margin-left:auto;margin-right:auto}.error-actions{display:flex;gap:.75rem;justify-content:center}.tag-cloud{display:flex;flex-wrap:wrap;gap:.75rem}.tag-cloud-item{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:var(--bg-alt);border:.0625rem solid var(--border);border-radius:6.25rem;color:var(--fg);transition:all var(--transition)}.tag-cloud-item:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-.125rem)}.tag-cloud-item .tag-name{font-weight:500}.tag-cloud-item .tag-count{font-size:.75rem;padding:.125rem .5rem;background:var(--bg-surface);border-radius:6.25rem;color:var(--fg-dim)}.post-footer{margin-top:3rem;padding-top:2rem;border-top:.0625rem solid var(--border)}.post-tags-footer{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:1.5rem}.post-tags-footer .label{color:var(--fg-dim);font-size:.875rem}.post-tags-inline{display:inline-flex;flex-wrap:wrap;gap:.375rem}.post-nav{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.post-nav-link{display:block;padding:1rem 1.25rem;background:var(--bg-alt);border:.0625rem solid var(--border);border-radius:var(--radius);color:var(--fg);font-size:.875rem;transition:all var(--transition)}.post-nav-link:hover{border-color:var(--accent);color:var(--accent)}.post-nav-link.prev{text-align:left}.post-nav-link.next{text-align:right;grid-column:2}.post-subtitle{font-size:1.125rem;color:var(--fg-dim);margin-top:1rem;font-style:italic;line-height:1.6}.nav-links a.active{color:var(--accent);background:rgba(230,180,80,.1)}.theme-transitioning,.theme-transitioning *{transition:background-color .3s ease,color .3s ease,border-color .3s ease !important}.external-link::after{content:"";display:inline-block;width:.75rem;height:.75rem;margin-left:.25rem;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2339bae6' stroke-width='2'%3E%3Cpath d='M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6'/%3E%3Cpolyline points='15 3 21 3 21 9'/%3E%3Cline x1='10' y1='14' x2='21' y2='3'/%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat;vertical-align:middle}.toc a.active{color:var(--accent);font-weight:500}img{opacity:1;transition:opacity .3s ease}img.loaded{opacity:1}img.error{opacity:.3}@media print{header,footer,.toc,#scroll-to-top,#reading-progress,.copy-button{display:none !important}body{background:#fff;color:#000;font-size:12pt}.container{max-width:100%;padding:0}a{color:#000;text-decoration:underline}pre,code{background:#f5f5f5;border:.0625rem solid #ddd}}@media (prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}html{scroll-behavior:auto}}.skip-link{position:fixed;top:-100%;left:50%;transform:translateX(-50%);padding:.75rem 1.5rem;background:var(--accent);color:var(--bg);font-weight:600;border-radius:var(--radius);z-index:200;transition:top .2s ease}.skip-link:focus{top:1rem}.noscript-warning{background:var(--accent);color:var(--bg);text-align:center;padding:.625rem;font-size:.875rem;font-weight:500}.mobile-menu{display:none}@media (max-width: 48rem){:root{--nav-height: 3.5rem}.nav-brand{z-index:1500}.menu-toggle{display:flex}.nav-links{visibility:hidden;pointer-events:none;position:absolute;opacity:0}.header-controls{gap:.25rem;padding-left:0;border:none}.mobile-menu{position:fixed;inset:0;background:var(--bg);z-index:1400;padding:calc(var(--nav-height) + 2rem) 2rem 2rem;display:flex;flex-direction:column;gap:1.5rem;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .3s ease,visibility .3s ease;will-change:opacity}@supports (backdrop-filter: blur(1rem)){.mobile-menu{background:rgba(248,250,252,.95);backdrop-filter:blur(1.25rem)}html.dark-mode .mobile-menu{background:rgba(11,14,29,.95)}}.mobile-menu.open{opacity:1;visibility:visible;pointer-events:auto}.mobile-nav-link{font-size:1.75rem;font-weight:600;color:var(--fg-dim);text-decoration:none;transform:translate3d(0, 1rem, 0);opacity:0;transition:transform .3s ease,opacity .3s ease,color .2s ease;will-change:transform,opacity}.mobile-menu.open .mobile-nav-link{transform:translate3d(0, 0, 0);opacity:1}.mobile-nav-link:nth-child(1){transition-delay:.03s}.mobile-nav-link:nth-child(2){transition-delay:.06s}.mobile-nav-link:nth-child(3){transition-delay:.09s}.mobile-nav-link:nth-child(4){transition-delay:.12s}.mobile-nav-link:nth-child(5){transition-delay:.15s}.mobile-nav-link:nth-child(6){transition-delay:.18s}.mobile-nav-link:nth-child(7){transition-delay:.21s}.mobile-nav-link:nth-child(8){transition-delay:.24s}.mobile-nav-link:nth-child(9){transition-delay:.27s}.mobile-nav-link:nth-child(10){transition-delay:.3s}.mobile-nav-link:hover,.mobile-nav-link.active{color:var(--accent)}.mobile-menu-footer{margin-top:auto;padding-top:2rem;border-top:.0625rem solid var(--border);display:flex;justify-content:space-between;align-items:center;transform:translate3d(0, 1rem, 0);opacity:0;transition:transform .3s ease .25s,opacity .3s ease .25s;font-size:.875rem;color:var(--fg-dim)}.mobile-menu.open .mobile-menu-footer{transform:translate3d(0, 0, 0);opacity:1}}.share-actions{display:flex;gap:.75rem;margin-top:1.5rem;padding-top:1.5rem;border-top:.0625rem solid var(--border)}.share-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.625rem 1rem;font-size:.875rem;font-weight:500;background:var(--bg-alt);border:.0625rem solid var(--border);border-radius:var(--radius);color:var(--fg);cursor:pointer;transition:all var(--transition)}.share-btn:hover{border-color:var(--accent);color:var(--accent)}.share-btn.copied{border-color:var(--success);color:var(--success)}#share-post{display:none}.project-type{display:inline-block;padding:.25rem .625rem;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.03125rem;background:var(--bg-surface);color:var(--fg-dim);border-radius:6.25rem;margin-bottom:.75rem}.word-count{display:inline-flex;align-items:center;gap:.25rem;font-size:.8125rem;color:var(--fg-dim)}a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:.125rem solid var(--accent);outline-offset:.125rem}.post-content a:not(.tag){text-decoration-color:var(--link);text-decoration-thickness:.125rem;text-underline-offset:.1875rem;transition:text-decoration-color .2s ease}.post-content a:not(.tag):hover{text-decoration-color:var(--accent)}.project-card:hover,.post-item:hover,.search-result-item:hover{box-shadow:0 .625rem 2.5rem -.625rem var(--accent-glow),var(--shadow-lg);border-color:var(--accent)}html.dark-mode .project-card:hover,html.dark-mode .post-item:hover,html.dark-mode .search-result-item:hover{box-shadow:0 .625rem 2.5rem -.625rem var(--accent-glow),var(--shadow-lg)}.embed-container{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;max-width:100%;background:var(--bg-alt);margin:2rem 0;border-radius:var(--radius-lg);border:.0625rem solid var(--border);box-shadow:var(--shadow)}.embed-container.shorts{padding-bottom:70%;max-width:20rem;margin:2rem auto;}.embed-container iframe,.embed-container object,.embed-container embed{position:absolute;top:0;left:0;width:100%;height:100%;border:0}.embed-container:has(iframe[src*="linkedin.com"]){padding-bottom:0;height:37.5rem}.callout{display:flex;gap:1rem;padding:1.5rem;margin:2.5rem 0;border-radius:var(--radius-lg);background:var(--bg-alt);border:.0625rem solid var(--border);position:relative;overflow:hidden}.callout::before{content:"";position:absolute;left:0;top:0;bottom:0;width:.25rem;background:var(--fg-dim)}.callout-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:var(--radius);background:var(--bg-surface);color:var(--fg-dim)}.callout-content{flex:1;font-size:1rem;line-height:1.6}.callout-content p{margin-bottom:.75rem}.callout-content p:last-child{margin-bottom:0}.callout-info::before{background:var(--func)}.callout-info .callout-icon{color:var(--func);background:rgba(57,186,230,.1)}.callout-warning::before{background:var(--error)}.callout-warning .callout-icon{color:var(--error);background:rgba(239,68,68,.1)}.callout-tip::before{background:var(--success)}.callout-tip .callout-icon{color:var(--success);background:rgba(16,185,129,.1)}.callout-rust::before{background:var(--brand-orange)}.callout-rust .callout-icon{color:var(--brand-orange);background:var(--accent-glow)}html.light-mode .callout{background:var(--bg-elevated);border-color:var(--border)}@view-transition{navigation:auto}::view-transition-group(root){animation-duration:.3s}::view-transition-old(root),::view-transition-new(root){animation-timing-function:cubic-bezier(.4, 0, .2, 1)}html{background:var(--bg)}@media (prefers-reduced-motion: reduce){::view-transition-group(root),::view-transition-old(root),::view-transition-new(root){animation:none}}.post-footer{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:2rem}.share-actions{display:flex;justify-content:center;align-items:center;gap:1rem}.share-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--bg-alt);border:1px solid var(--border);border-radius:var(--radius);color:var(--fg);font-weight:600;cursor:pointer;transition:all var(--transition)}.share-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-glow);transform:translateY(-2px)}#copy-url{display:none !important}.post-nav{display:flex;justify-content:space-between;gap:1rem;margin-top:1rem}.post-nav-link{flex:1;padding:1rem;background:var(--bg-alt);border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;color:var(--fg);font-weight:500;transition:all var(--transition);display:flex;align-items:center}.post-nav-link:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}.post-nav-link.prev{justify-content:flex-start}.post-nav-link.next{justify-content:flex-end;text-align:right}@media (max-width: 768px){.post-nav{flex-direction:column}.post-nav-link{width:100%;justify-content:center !important;text-align:center !important}}