.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}[data-astro-cid-3ef6ksr2][data-theme=dark] .theme-icon-sun[data-astro-cid-3ef6ksr2]{display:block}[data-astro-cid-3ef6ksr2][data-theme=dark] .theme-icon-moon[data-astro-cid-3ef6ksr2],.theme-icon-sun[data-astro-cid-3ef6ksr2]{display:none}.theme-icon-moon[data-astro-cid-3ef6ksr2]{display:block}.search-label[data-astro-cid-3ef6ksr2]{font-size:11px;font-family:inherit;font-weight:500;color:inherit;line-height:1;pointer-events:none;letter-spacing:.02em}.mobile-menu-btn[data-astro-cid-3ef6ksr2],.menu-icon-close[data-astro-cid-3ef6ksr2],.mobile-menu-btn[data-astro-cid-3ef6ksr2][aria-expanded=true] .menu-icon-open[data-astro-cid-3ef6ksr2]{display:none}.mobile-menu-btn[data-astro-cid-3ef6ksr2][aria-expanded=true] .menu-icon-close[data-astro-cid-3ef6ksr2]{display:block}.mobile-nav-panel[data-astro-cid-3ef6ksr2]{display:none}@media(max-width:640px){.mobile-menu-btn[data-astro-cid-3ef6ksr2]{display:flex;z-index:201;position:relative}.mobile-nav-panel[data-astro-cid-3ef6ksr2]{display:block;position:fixed;top:56px;right:24px;left:24px;max-width:300px;margin-left:auto;z-index:200;background:var(--bg-alt);border-radius:12px;box-shadow:0 20px 40px #00000026;transform:translateY(-120%);opacity:0;visibility:hidden;transition:transform .7s cubic-bezier(.32,.72,0,1),opacity .5s ease,visibility 0s .7s;pointer-events:none;overflow:hidden}.mobile-nav-panel[data-astro-cid-3ef6ksr2].open{transform:translateY(0);opacity:1;visibility:visible;transition:transform .7s cubic-bezier(.32,.72,0,1),opacity .5s ease,visibility 0s;pointer-events:auto}.mobile-nav-inner[data-astro-cid-3ef6ksr2]{display:flex;flex-direction:column}.mobile-nav-link[data-astro-cid-3ef6ksr2]{display:block;padding:18px 24px;font-size:16px;font-weight:500;color:var(--ink-sub);text-decoration:none;position:relative;z-index:2;border-left:6px solid;box-sizing:border-box;opacity:0;transform:translateY(-16px);transition:opacity .4s ease,transform .4s ease,color .2s ease;transition-delay:calc(.15s + var(--i, 0) * .08s)}.mobile-nav-panel[data-astro-cid-3ef6ksr2].open .mobile-nav-link[data-astro-cid-3ef6ksr2]{opacity:1;transform:translateY(0)}.mobile-nav-link[data-astro-cid-3ef6ksr2]:after{content:"";position:absolute;height:100%;left:0;top:0;width:0;z-index:-1;transition:width .3s ease}.mobile-nav-link[data-astro-cid-3ef6ksr2]:hover:after,.mobile-nav-link[data-astro-cid-3ef6ksr2]:active:after{width:100%}.mobile-nav-link[data-astro-cid-3ef6ksr2]:hover,.mobile-nav-link[data-astro-cid-3ef6ksr2]:active,.mobile-nav-link[data-astro-cid-3ef6ksr2][aria-current=page]:hover,.mobile-nav-link[data-astro-cid-3ef6ksr2][aria-current=page]:active{color:#fff}.mobile-nav-link[data-astro-cid-3ef6ksr2]:nth-child(1){border-left-color:#3498db}.mobile-nav-link[data-astro-cid-3ef6ksr2]:nth-child(2){border-left-color:#ffd071}.mobile-nav-link[data-astro-cid-3ef6ksr2]:nth-child(3){border-left-color:#f0776c}.mobile-nav-link[data-astro-cid-3ef6ksr2]:nth-child(4){border-left-color:#1abc9c}.mobile-nav-link[data-astro-cid-3ef6ksr2]:nth-child(1):after{background:#3498db}.mobile-nav-link[data-astro-cid-3ef6ksr2]:nth-child(2):after{background:#ffd071}.mobile-nav-link[data-astro-cid-3ef6ksr2]:nth-child(3):after{background:#f0776c}.mobile-nav-link[data-astro-cid-3ef6ksr2]:nth-child(4):after{background:#1abc9c}.mobile-nav-link[data-astro-cid-3ef6ksr2][aria-current=page]{color:var(--accent-ink);font-weight:600}}.cmd-palette-overlay{position:fixed;inset:0;z-index:500;background:#0006;backdrop-filter:blur(4px);display:flex;align-items:flex-start;justify-content:center;padding-top:min(20vh,140px);opacity:0;visibility:hidden;transition:opacity .15s ease,visibility 0s .15s}.cmd-palette-overlay.open{opacity:1;visibility:visible;transition:opacity .15s ease,visibility 0s}.cmd-palette{width:min(560px,calc(100vw - 32px));background:var(--bg);border:1px solid var(--border);border-radius:14px;box-shadow:0 24px 64px #0003;overflow:hidden;transform:scale(.96) translateY(-8px);transition:transform .15s ease}.cmd-palette-overlay.open .cmd-palette{transform:scale(1) translateY(0)}.cmd-input-wrap{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border);color:var(--ink-sub)}#cmd-input{flex:1;border:none;background:none;font-size:15px;font-family:inherit;color:var(--ink);outline:none}#cmd-input::placeholder{color:var(--ink-sub);opacity:.5}.cmd-esc{font-size:11px;padding:2px 6px;border:1px solid var(--border);border-radius:5px;color:var(--ink-sub);opacity:.6;font-family:inherit;line-height:1}.cmd-results{max-height:min(400px,50vh);overflow-y:auto;overscroll-behavior:contain}.cmd-empty{display:none;padding:32px 16px;text-align:center;color:var(--ink-sub);font-size:14px;opacity:.6}::view-transition-old(root){animation:fade-out .2s ease-out}::view-transition-new(root){animation:fade-in .2s ease-in}@keyframes fade-out{0%{opacity:1}to{opacity:0}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}:root{--font-sans: "Geist Sans", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--font-serif: "Instrument Serif", Georgia, serif;--font-mono: "JetBrains Mono", monospace;--max: 700px;--r: 8px;--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--ease-elastic: cubic-bezier(.68, -.6, .32, 1.6);--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-smooth: cubic-bezier(.4, 0, .2, 1);--bg: #fafaf9;--bg-alt: #f5f5f4;--bg-elevated: #ffffff;--ink: #1c1917;--ink-sub: #44403c;--ink-muted: #78716c;--ink-faint: #d6d3d1;--border: #e7e5e4;--accent: #0d9488;--accent-hover: #0f766e;--accent-soft: rgba(13, 148, 136, .06);--accent-ink: #0f766e;--tag-bg: rgba(13, 148, 136, .06);--tag-ink: #0f766e;--tag-shadow: 0 1px 2px rgba(13, 148, 136, .08);--card-hover-bg: rgba(0, 0, 0, .02);--card-hover-shadow: inset 0 1px 0 rgba(0, 0, 0, .03), 0 2px 8px rgba(0, 0, 0, .05);--pill-shadow: 0 1px 3px rgba(0, 0, 0, .06), 0 0 0 1px rgba(0, 0, 0, .03);--pill-shadow-hover: 0 4px 12px rgba(13, 148, 136, .12), 0 0 0 1px rgba(13, 148, 136, .15);--btn-shadow: 0 1px 3px rgba(0, 0, 0, .08), 0 0 0 1px rgba(0, 0, 0, .04);--photo-shadow: 0 8px 32px rgba(0, 0, 0, .1);--selection-bg: #5eead4;--selection-ink: #134e4a;--glow-color: rgba(13, 148, 136, .07);--glow-size: 550px;--accent-on: #ffffff;--dim: .35}[data-theme=dark]{--bg: #0f172a;--bg-alt: #1e293b;--bg-elevated: #1e293b;--ink: #e2e8f0;--ink-sub: #94a3b8;--ink-muted: #64748b;--ink-faint: #334155;--border: #1e293b;--accent: #5eead4;--accent-hover: #2dd4bf;--accent-soft: rgba(94, 234, 212, .1);--accent-ink: #7dd3c4;--tag-bg: rgba(94, 234, 212, .08);--tag-ink: #7dd3c4;--tag-shadow: 0 1px 2px rgba(0, 0, 0, .2);--card-hover-bg: rgba(30, 41, 59, .5);--card-hover-shadow: inset 0 1px 0 rgba(148, 163, 184, .1), 0 4px 16px rgba(0, 0, 0, .2);--pill-shadow: 0 1px 3px rgba(0, 0, 0, .3), 0 0 0 1px rgba(148, 163, 184, .06);--pill-shadow-hover: 0 4px 12px rgba(94, 234, 212, .15), 0 0 0 1px rgba(94, 234, 212, .2);--btn-shadow: 0 1px 3px rgba(0, 0, 0, .4), 0 0 0 1px rgba(148, 163, 184, .06);--photo-shadow: 0 8px 32px rgba(0, 0, 0, .3);--accent-on: #042f2e;--glow-color: rgba(29, 78, 216, .15);--glow-size: 600px;--dim: .4}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}::selection{background:var(--selection-bg);color:var(--selection-ink)}html{scroll-behavior:smooth}body{font-family:var(--font-sans);font-size:16px;line-height:1.6;background:var(--bg);color:var(--ink-sub);-webkit-font-smoothing:antialiased;transition:background .4s ease,color .3s ease}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--ink-faint);border:3px solid var(--bg);border-radius:10px}:focus-visible{outline:2px dashed var(--accent);outline-offset:3px}:focus:not(:focus-visible){outline:none}.spotlight{pointer-events:none;position:fixed;inset:0;z-index:1;background:radial-gradient(var(--glow-size) circle at var(--mx, 50%) var(--my, 50%),var(--glow-color),transparent 60%);transition:opacity .3s}.reveal{opacity:0;transform:translateY(14px);transition:opacity .6s var(--ease-out),transform .6s var(--ease-out)}.reveal.visible{opacity:1;transform:translateY(0)}.container{max-width:var(--max);margin:0 auto;padding:0 24px}.site-header{border-bottom:1px solid var(--border);position:relative;z-index:202}.header-inner{max-width:var(--max);margin:0 auto;padding:0 24px;height:52px;display:flex;align-items:center;justify-content:space-between}.logo{font-weight:700;font-size:15px;color:var(--ink);letter-spacing:-.03em;transition:color .2s}.logo:hover{color:var(--accent-ink)}.nav-links{display:flex;align-items:center;gap:24px}.nav-links a{font-size:13px;font-weight:500;color:var(--ink-muted);text-decoration:none;transition:color .45s;display:inline-block;padding-bottom:6px;position:relative;overflow:hidden}.nav-links a:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:50px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='390' height='50' viewBox='0 0 390 50'%3E%3Cpath fill='none' stroke='%230d9488' stroke-width='1.5' stroke-miterlimit='10' d='M0,47.585c0,0,97.5,0,130,0c13.75,0,28.74-38.778,46.168-19.416C192.669,46.5,243.603,47.585,260,47.585c31.821,0,130,0,130,0'/%3E%3C/svg%3E");background-repeat:no-repeat;background-size:390px 50px;background-position:left bottom;transform:translate(-110%);pointer-events:none}[data-theme=dark] .nav-links a:after{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='390' height='50' viewBox='0 0 390 50'%3E%3Cpath fill='none' stroke='%235eead4' stroke-width='1.5' stroke-miterlimit='10' d='M0,47.585c0,0,97.5,0,130,0c13.75,0,28.74-38.778,46.168-19.416C192.669,46.5,243.603,47.585,260,47.585c31.821,0,130,0,130,0'/%3E%3C/svg%3E")}.nav-links a:hover,.nav-links a[aria-current=page]{color:var(--accent-ink)}.nav-links a:hover:after,.nav-links a[aria-current=page]:after{animation:nav-wave 2.5s forwards}@keyframes nav-wave{0%{transform:translate(110%)}to{transform:translate(-110%)}}.header-right{display:flex;align-items:center;gap:6px}.icon-btn{height:30px;padding:0 10px;border-radius:6px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--ink-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;font-family:var(--font-sans);box-shadow:var(--btn-shadow);transition:all .3s var(--ease-spring)}.icon-btn:hover{color:var(--ink);border-color:var(--accent);transform:translateY(-1px);box-shadow:var(--pill-shadow-hover)}.section-divider{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding-top:56px}.section-label{font-family:var(--font-sans);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-sub);white-space:nowrap}.section-divider:after{content:"";flex:1;height:1px;background:var(--border)}.section-more{margin-left:auto;font-size:12px;font-weight:600;color:var(--accent-ink);display:flex;align-items:center;gap:4px;padding:4px 12px;border-radius:20px;border:1px solid color-mix(in srgb,var(--accent) 25%,transparent);background:var(--accent-soft);transition:all .35s var(--ease-spring);white-space:nowrap}.section-more:hover{gap:8px;background:var(--accent);color:var(--accent-on);border-color:var(--accent);transform:translateY(-1px);box-shadow:var(--pill-shadow-hover)}.hover-card{position:relative;transition:opacity .35s var(--ease-out),transform .35s var(--ease-out)}.hover-card .card-bg{position:absolute;inset:-10px -14px;z-index:0;border-radius:var(--r);transition:background .35s var(--ease-out),box-shadow .35s var(--ease-out);background:transparent;box-shadow:none}.hover-card:hover .card-bg{background:var(--card-hover-bg);box-shadow:var(--card-hover-shadow)}.hover-card>*:not(.card-bg){position:relative;z-index:1}.card-group:hover .hover-card{opacity:var(--dim);transform:scale(.99)}.card-group:hover .hover-card:hover{opacity:1;transform:scale(1)}.exp-item{display:grid;grid-template-columns:100px 1fr;gap:16px;padding:14px 0;cursor:pointer}.exp-period{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-muted);padding-top:3px;white-space:nowrap}.exp-title{font-size:15px;font-weight:600;color:var(--ink);line-height:1.35;transition:color .2s}.exp-title .arrow{display:inline-block;font-size:12px;margin-left:3px;transition:transform .4s var(--ease-spring)}.hover-card:hover .exp-title .arrow{transform:translate(3px,-3px)}.hover-card:hover .exp-title{color:var(--accent-ink)}.exp-desc{font-size:14px;line-height:1.65;color:var(--ink-sub);margin-top:6px}.tech-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.tech-tag{font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;background:var(--tag-bg);color:var(--tag-ink);box-shadow:var(--tag-shadow);transition:all .3s var(--ease-spring)}.tech-tag:hover{box-shadow:var(--pill-shadow-hover);transform:translateY(-1px);background:var(--accent);color:var(--accent-on)}.project-item{padding:14px 0;cursor:pointer}.project-title{font-size:15px;font-weight:600;color:var(--ink);line-height:1.35;transition:color .2s}.project-title .arrow{display:inline-block;font-size:12px;margin-left:3px;transition:transform .4s var(--ease-spring)}.hover-card:hover .project-title .arrow{transform:translate(3px,-3px)}.hover-card:hover .project-title{color:var(--accent-ink)}.project-desc{font-size:14px;line-height:1.65;color:var(--ink-sub);margin-top:6px}.view-more{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:var(--ink);margin-top:28px;border-bottom:1px solid transparent;transition:all .25s var(--ease-out)}.view-more:hover{color:var(--accent-ink);border-bottom-color:var(--accent)}.view-more .vm-arrow{transition:transform .4s var(--ease-spring)}.view-more:hover .vm-arrow{transform:translate(6px)}.post-item{display:grid;grid-template-columns:1fr auto;gap:12px;padding:14px 0;cursor:pointer}.post-item-cat{font-size:11px;font-weight:600;color:var(--accent-ink);text-transform:uppercase;letter-spacing:.04em}.post-item-title{font-size:15px;font-weight:600;color:var(--ink);line-height:1.4;margin-top:3px;transition:color .2s}.hover-card:hover .post-item-title{color:var(--accent-ink)}.post-item-meta{font-size:12px;color:var(--ink-muted);white-space:nowrap;padding-top:4px}.card-group .hover-card.post-item+.hover-card.post-item{border-top:1px solid var(--border)}.blog-full-item{display:block;padding:20px 0;border-bottom:1px solid var(--border);cursor:pointer}.blog-full-item:first-child{border-top:1px solid var(--border)}.blog-full-cat{font-size:11px;font-weight:600;color:var(--accent-ink);text-transform:uppercase;letter-spacing:.04em;display:flex;align-items:center;gap:6px}.featured-badge{font-size:10px;font-weight:600;color:var(--ink);background:var(--border);padding:1px 6px;border-radius:3px;text-transform:uppercase;letter-spacing:.03em}.blog-full-title{font-size:17px;font-weight:700;color:var(--ink);line-height:1.4;margin-top:4px;transition:color .2s}.blog-full-item:hover .blog-full-title{color:var(--accent-ink)}.blog-full-excerpt{font-size:14px;color:var(--ink-sub);line-height:1.6;margin-top:6px}.blog-full-meta{font-size:12px;color:var(--ink-muted);margin-top:8px}.filter-bar{display:flex;gap:6px;flex-wrap:wrap;padding:20px 0 24px}.filter-pill{font-family:var(--font-sans);font-size:12px;font-weight:500;padding:5px 12px;border-radius:20px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--ink-muted);cursor:pointer;box-shadow:var(--pill-shadow);transition:all .3s var(--ease-spring)}.filter-pill:hover{border-color:var(--accent);color:var(--accent-ink);box-shadow:var(--pill-shadow-hover);transform:translateY(-1px)}.filter-pill.active{background:var(--accent);color:var(--accent-on);border-color:var(--accent);box-shadow:var(--pill-shadow-hover)}.pagination{display:flex;justify-content:center;align-items:center;gap:6px;padding:40px 0}.pagination a,.pagination span{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 6px;border-radius:var(--r);font-size:13px;font-weight:500;color:var(--ink-sub);text-decoration:none;transition:all .2s ease}.pagination a:hover{color:var(--accent-ink);background:var(--accent-soft)}.pagination .current{background:var(--accent);color:#fff;font-weight:600}.pagination .ellipsis{border:none;color:var(--ink-muted);pointer-events:none}.pagination .pag-prev,.pagination .pag-next{min-width:auto;padding:0 12px;font-size:13px;color:var(--ink-muted)}.pagination .pag-prev:hover,.pagination .pag-next:hover{color:var(--accent-ink);background:transparent}.hero{padding:72px 0 24px;display:grid;grid-template-columns:1fr auto;gap:48px;align-items:center}.hero-greeting{font-size:13px;font-weight:600;color:var(--accent-ink);display:inline-flex;align-items:center;gap:8px;margin-bottom:16px;padding:4px 12px 4px 8px;background:var(--accent-soft);border-radius:20px;border:1px solid color-mix(in srgb,var(--accent) 15%,transparent)}.hero-greeting .dot{width:7px;height:7px;background:#22c55e;border-radius:50%;box-shadow:0 0 6px #22c55e66;animation:pulse 2s ease infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}.hero h1{font-family:var(--font-serif);font-weight:400;font-size:clamp(32px,5vw,46px);line-height:1.12;letter-spacing:-.02em;color:var(--ink);margin-bottom:18px}.hero h1 strong{color:var(--accent-ink);font-weight:400}.hero-bio{font-size:15.5px;line-height:1.7;color:var(--ink-sub);max-width:460px}.hero-bio a{color:var(--ink);font-weight:600;text-decoration:underline;text-decoration-color:color-mix(in srgb,var(--accent) 30%,transparent);text-decoration-thickness:1.5px;text-underline-offset:3px;transition:text-decoration-color .3s,color .3s}.hero-bio a:hover{text-decoration-color:var(--accent);color:var(--accent-ink)}.hero-cube-wrap{width:150px;height:150px;flex-shrink:0;display:flex;justify-content:center;align-items:center;transform-style:preserve-3d;perspective:1000px;transform:rotate(-3deg)}.hero-cube{width:150px;height:150px;position:relative;transform-style:preserve-3d;transition:transform 2.5s cubic-bezier(.25,.1,.25,1);cursor:pointer}.hero-cube-wrap:hover .hero-cube{animation:cube-rotate 8s infinite linear}.cube-face{position:absolute;width:100%;height:100%;display:flex;justify-content:center;align-items:center;font-size:1rem;font-weight:700;backface-visibility:visible;border-radius:12px;background:linear-gradient(145deg,var(--bg-alt),var(--bg-elevated));border:2px solid var(--accent);transition:all .3s ease;overflow:hidden}.cube-face:before{content:"";position:absolute;width:100%;height:100%;background:linear-gradient(45deg,transparent,color-mix(in srgb,var(--accent) 25%,transparent),transparent);top:-100%;left:-100%;transition:all .5s ease;transform:translateZ(20px)}.cube-face:after{content:"";position:absolute;inset:0;background:color-mix(in srgb,var(--accent) 8%,transparent);opacity:0;transition:opacity .3s ease}.cube-face:hover:before{top:100%;left:100%}.cube-face:hover:after{opacity:1}.cube-face img{width:100%;height:100%;object-fit:cover;filter:grayscale(60%) contrast(1.05)}.cube-label{font-size:13px;font-weight:700;letter-spacing:.5px;color:var(--accent-ink);text-transform:uppercase}.cube-front{transform:translateZ(75px)}.cube-back{transform:translateZ(-75px) rotateY(180deg)}.cube-right{transform:translate(75px) rotateY(90deg)}.cube-left{transform:translate(-75px) rotateY(-90deg)}.cube-top{transform:translateY(-75px) rotateX(90deg)}.cube-bottom{transform:translateY(75px) rotateX(-90deg)}@keyframes cube-rotate{0%{transform:rotateX(0) rotateY(0)}25%{transform:rotateX(90deg) rotateY(90deg)}50%{transform:rotateX(180deg) rotateY(180deg)}75%{transform:rotateX(270deg) rotateY(270deg)}to{transform:rotateX(360deg) rotateY(360deg)}}.social-row{display:flex;gap:16px;margin-top:16px;flex-wrap:wrap}.social-row a{font-size:13px;font-weight:500;color:var(--ink-muted);transition:color .2s,transform .3s var(--ease-spring)}.social-row a:hover{color:var(--accent-ink);transform:translateY(-1px)}.domain-note{font-size:12px;color:var(--ink-muted);margin-top:12px;line-height:1.6}.domain-note s{opacity:.4}.site-footer{border-top:1px solid var(--border);margin-top:48px;padding:20px 0}.footer-inner{max-width:var(--max);margin:0 auto;padding:0 24px;display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--ink-sub)}.footer-links{display:flex;gap:16px}.footer-links a{color:var(--ink-sub);transition:color .2s;font-size:12px}.footer-links a:hover{color:var(--ink)}.page-title{padding:56px 0 8px}.page-title h1{font-family:var(--font-serif);font-size:clamp(28px,4vw,38px);color:var(--ink);font-weight:400}.page-title p{font-size:15px;color:var(--ink-sub);margin-top:6px}.back-to-blog{display:inline-flex;align-items:center;gap:4px;margin-top:12px;padding:8px 16px;font-size:14px;font-weight:500;color:var(--accent);background:var(--bg-alt);border:1px solid var(--border);border-radius:8px;text-decoration:none;transition:all .2s ease}.back-to-blog:hover{background:var(--accent);color:var(--accent-on);border-color:var(--accent)}.progress-bar{position:fixed;top:0;left:0;height:2px;z-index:100;background:var(--accent);width:0%;transition:width .1s}.post-page-header{padding:56px 0 32px}.post-page-header .post-cat{font-size:12px;font-weight:600;color:var(--accent-ink);text-transform:uppercase;letter-spacing:.05em}.post-page-header h1{font-family:var(--font-serif);font-weight:400;font-size:clamp(28px,4.5vw,38px);line-height:1.2;letter-spacing:-.01em;color:var(--ink);margin-top:12px}.post-page-header .post-meta{font-size:13px;color:var(--ink-muted);margin-top:16px;display:flex;gap:12px}.prose{font-size:16.5px;line-height:1.8;color:var(--ink-sub)}.prose h2{font-family:var(--font-serif);font-size:24px;font-weight:400;color:var(--ink);margin:48px 0 16px;line-height:1.3}.prose h3{font-size:17px;font-weight:700;color:var(--ink);margin:32px 0 12px}.prose h4{font-size:15px;font-weight:700;color:var(--ink);margin:24px 0 8px}.prose p{margin-bottom:20px}.prose a{color:var(--accent-ink);font-weight:500;text-decoration:underline;text-decoration-color:color-mix(in srgb,var(--accent) 30%,transparent);text-decoration-thickness:1.5px;text-underline-offset:3px;transition:text-decoration-color .3s}.prose a:hover{text-decoration-color:var(--accent)}.prose strong{font-weight:600;color:var(--ink)}.prose blockquote{border-left:3px solid var(--accent);padding:2px 0 2px 18px;margin:24px 0;font-style:italic}.prose pre{background:#1e293b;border-radius:10px;padding:18px 20px;overflow-x:auto;font-family:var(--font-mono);font-size:14px;line-height:1.7;margin:24px 0;color:#cdd6f4;border:1px solid var(--border);max-width:100%;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word}.prose code{font-family:var(--font-mono);font-size:.88em;background:var(--bg-alt);padding:2px 5px;border-radius:4px}.prose pre code{background:none;padding:0}.prose ul,.prose ol{padding-left:20px;margin-bottom:20px}.prose li{margin-bottom:8px}.prose hr{border:none;border-top:1px solid var(--border);margin:40px 0}.prose img{border-radius:var(--r);margin:24px 0}.post-tags-row{display:flex;gap:6px;flex-wrap:wrap;margin-top:36px}.ptag{font-size:12px;font-weight:500;padding:3px 10px;border-radius:20px;background:var(--tag-bg);color:var(--tag-ink);box-shadow:var(--tag-shadow);transition:all .3s var(--ease-spring);cursor:pointer}.ptag:hover{background:var(--accent);color:var(--accent-on);box-shadow:var(--pill-shadow-hover);transform:translateY(-1px)}.share-row{display:flex;align-items:center;gap:8px;padding:20px 0;margin-top:16px;border-top:1px solid var(--border);font-size:13px;color:var(--ink-muted)}.share-btn{font-family:var(--font-sans);padding:5px 12px;border-radius:6px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--ink-sub);font-size:12px;font-weight:500;cursor:pointer;box-shadow:var(--btn-shadow);transition:all .3s var(--ease-spring)}.share-btn:hover{border-color:var(--accent);color:var(--accent-ink);box-shadow:var(--pill-shadow-hover);transform:translateY(-1px)}.post-nav{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:24px 0;border-top:1px solid var(--border)}.pn-item{padding:14px;border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--btn-shadow);transition:all .35s var(--ease-spring);cursor:pointer}.pn-item:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--pill-shadow-hover)}.pn-label{font-size:11px;color:var(--ink-muted);margin-bottom:4px}.pn-title{font-size:14px;font-weight:600;color:var(--ink)}.pn-item.next{text-align:right}.related-section{padding:36px 0}.related-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.related-card{padding:18px;border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--btn-shadow);transition:all .35s var(--ease-spring);cursor:pointer}.related-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--pill-shadow-hover)}.related-card .rc-cat{font-size:11px;font-weight:600;color:var(--accent-ink);text-transform:uppercase;letter-spacing:.04em}.related-card h3{font-size:14px;font-weight:600;color:var(--ink);margin-top:4px;line-height:1.4}.related-card .rc-meta{font-size:12px;color:var(--ink-muted);margin-top:6px}.about-header{padding:56px 0 16px;display:flex;align-items:center;gap:24px}.about-avatar{width:72px;height:72px;border-radius:50%;flex-shrink:0;overflow:hidden;box-shadow:var(--photo-shadow);border:2px solid var(--border);transition:transform .4s var(--ease-spring),border-color .3s}.about-avatar:hover{transform:scale(1.06);border-color:var(--accent)}.about-avatar img{width:100%;height:100%;object-fit:cover;filter:grayscale(80%);transition:filter .4s}.about-avatar:hover img{filter:grayscale(0%)}.about-header-text h1{font-family:var(--font-serif);font-size:clamp(26px,4vw,32px);color:var(--ink);font-weight:400}.about-header-text p{font-size:14px;color:var(--ink-sub);margin-top:2px}.about-body{padding:24px 0 0}.about-body .prose{font-size:16px}.skills-section{padding:40px 0 0}.skills-section h2{font-family:var(--font-serif);font-size:22px;color:var(--ink);margin-bottom:16px;font-weight:400}.skills-grid{display:flex;flex-wrap:wrap;gap:6px}.skill-pill{padding:6px 14px;border:1px solid var(--border);border-radius:20px;font-size:13px;font-weight:500;color:var(--ink-sub);background:var(--bg-elevated);box-shadow:var(--pill-shadow);transition:all .35s var(--ease-spring);cursor:default}.skill-pill:hover{border-color:var(--accent);color:var(--accent-ink);background:var(--accent-soft);box-shadow:var(--pill-shadow-hover);transform:translateY(-2px)}.domains-section{padding:40px 0 0}.domains-section h2{font-family:var(--font-serif);font-size:22px;color:var(--ink);margin-bottom:16px;font-weight:400}.domain-item{display:flex;align-items:center;gap:10px;padding:12px 16px;margin-bottom:8px;background:var(--bg-alt);border-radius:var(--r);font-size:13px;border:1px solid transparent;transition:border-color .2s}.domain-item:hover{border-color:var(--border)}.d-old{font-family:var(--font-mono);color:var(--ink-muted);text-decoration:line-through}.d-arrow{color:var(--ink-faint)}.d-new{font-family:var(--font-mono);font-weight:600;color:var(--accent-ink)}.d-label{font-size:11px;color:var(--ink-muted);margin-left:auto}.contact-methods{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:24px}@media(max-width:640px){.contact-methods{grid-template-columns:repeat(2,1fr)}}.contact-card{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:16px 18px;text-decoration:none;color:var(--ink);white-space:nowrap;border:1px solid var(--border);border-radius:var(--r);transition:border-color .2s ease,transform .2s ease}.contact-card:hover{border-color:var(--accent);transform:translateY(-2px)}.contact-card h2{font-size:14px;font-weight:600;margin:0}.contact-card .arrow{font-size:13px;color:var(--ink-muted);transition:color .2s ease;flex-shrink:0}.contact-card:hover .arrow{color:var(--accent-ink)}.not-found{text-align:center;padding:80px 0 60px}.not-found-code{font-size:clamp(80px,20vw,160px);font-weight:800;line-height:1;color:var(--border);letter-spacing:-4px;user-select:none}.not-found h1{font-family:var(--font-serif);font-size:clamp(24px,4vw,36px);font-weight:400;color:var(--ink);margin-top:12px}.not-found-desc{font-size:15px;line-height:1.7;color:var(--ink-sub);max-width:480px;margin:16px auto 0}.not-found-desc s{color:var(--ink-muted)}.not-found-actions{display:flex;gap:12px;justify-content:center;margin-top:32px}.not-found-btn{padding:10px 24px;border-radius:var(--r);font-size:14px;font-weight:500;text-decoration:none;border:1px solid var(--border);color:var(--ink);transition:all .2s ease}.not-found-btn:hover{border-color:var(--accent);color:var(--accent-ink)}.not-found-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.not-found-btn.primary:hover{opacity:.9}.now-updated{font-size:13px;color:var(--ink-muted);margin-top:8px}.gh-activity{border:1px solid var(--border);border-radius:var(--r);padding:24px;background:var(--bg-alt)}.gh-activity-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.gh-activity h2{font-family:var(--font-serif);font-size:18px;font-weight:400;color:var(--ink);margin:0;display:flex;align-items:center;gap:10px}.gh-profile-link{font-size:13px;font-weight:500;color:var(--ink-muted);text-decoration:none;transition:color .15s ease}.gh-profile-link:hover{color:var(--accent-ink)}.gh-activity h2 svg{color:var(--ink-muted);flex-shrink:0}.gh-events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.gh-event-card{display:flex;flex-direction:column;gap:6px;padding:14px 16px;border:1px solid var(--border);border-radius:8px;text-decoration:none;transition:border-color .2s ease,transform .2s ease}.gh-event-card:hover{border-color:var(--accent);transform:translateY(-1px)}.gh-event-desc{font-size:13px;line-height:1.5;color:var(--ink);word-break:break-word}.gh-event-card time{font-size:12px;color:var(--ink-muted)}.gh-empty{font-size:13px;color:var(--ink-sub);line-height:1.6}.gh-empty a{color:var(--accent-ink)}.post-newsletter{margin-top:36px;padding:32px 28px 24px;border:1px solid var(--border);border-radius:12px;background:var(--bg-alt);text-align:center;position:relative;overflow:hidden}.post-newsletter:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent-hover),var(--accent));background-size:200% 100%;animation:shimmer 3s ease infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.nl-icon{margin-bottom:12px;color:var(--accent)}.nl-icon svg{display:block;margin:0 auto}.post-newsletter h2{font-family:var(--font-serif);font-size:22px;font-weight:400;color:var(--ink);margin-bottom:8px}.post-newsletter p{font-size:14px;color:var(--ink-sub);margin-bottom:16px;max-width:340px;margin-left:auto;margin-right:auto;line-height:1.6}.nl-note{display:block;font-size:11px;color:var(--ink-muted);margin-top:10px}.nl-form{display:flex;gap:8px;max-width:380px;margin:0 auto}.nl-form input{flex:1;padding:10px 14px;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--ink);font-family:var(--font-sans);font-size:14px;transition:border-color .2s}.nl-form input::placeholder{color:var(--ink-muted)}.nl-form input:focus{border-color:var(--accent);outline:none}.nl-form button{padding:8px 18px;border:none;border-radius:6px;background:var(--accent);color:var(--accent-on);font-family:var(--font-sans);font-size:14px;font-weight:600;cursor:pointer;transition:all .3s var(--ease-spring);white-space:nowrap}.nl-form button:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--pill-shadow-hover)}.prose .cta-button{text-align:center;margin:32px 0}.prose .cta-button a{display:inline-block;padding:12px 28px;background:var(--accent);color:var(--accent-on);font-family:var(--font-sans);font-size:15px;font-weight:600;border-radius:8px;text-decoration:none;transition:all .3s var(--ease-spring);box-shadow:0 2px 8px color-mix(in srgb,var(--accent) 25%,transparent)}.prose .cta-button a:hover{transform:translateY(-2px);box-shadow:0 4px 16px color-mix(in srgb,var(--accent) 35%,transparent);background:var(--accent-hover)}.prose .cta-button.left{text-align:left}.post-kofi{margin-top:16px;padding:18px 22px;border-radius:var(--r);border:1px dashed color-mix(in srgb,var(--accent) 30%,var(--border));display:flex;align-items:flex-start;gap:14px;transition:border-color .3s}.post-kofi:hover{border-color:var(--accent)}.kofi-icon{flex-shrink:0;color:var(--accent);display:flex;align-items:center}.kofi-icon svg{display:block}.post-kofi:hover .kofi-icon svg line{animation:steam 1.2s ease-in-out infinite}.post-kofi:hover .kofi-icon svg line:nth-child(4){animation-delay:.15s}.post-kofi:hover .kofi-icon svg line:nth-child(5){animation-delay:.3s}@keyframes steam{0%,to{transform:translateY(0);opacity:.6}50%{transform:translateY(-3px);opacity:1}}.post-kofi p{font-size:14px;color:var(--ink-sub);line-height:1.6}.post-kofi strong{color:var(--ink)}.post-kofi a{color:var(--accent-ink);font-weight:600;text-decoration:underline;text-decoration-color:color-mix(in srgb,var(--accent) 30%,transparent);text-underline-offset:3px;transition:text-decoration-color .3s}.post-kofi a:hover{text-decoration-color:var(--accent)}.code-copy-btn{position:absolute;top:8px;right:8px;padding:4px 10px;border:1px solid rgba(148,163,184,.2);border-radius:5px;background:#1e293bcc;color:var(--ink-muted);font-family:var(--font-sans);font-size:11px;font-weight:500;cursor:pointer;opacity:0;transition:opacity .2s,background .2s,color .2s}pre:hover .code-copy-btn{opacity:1}.code-copy-btn:hover{background:var(--accent);color:var(--accent-on);border-color:var(--accent)}.post-comments{padding-bottom:24px}.comments-intro{font-size:14px;color:var(--ink-sub);margin-bottom:20px}.comments-note{font-size:11px;color:var(--ink-muted);margin-top:12px;text-align:center}.comments-note a{color:var(--accent-ink)}.giscus,.giscus-frame{width:100%}.giscus-frame{border:none;color-scheme:auto}@media(max-width:640px){.hero{grid-template-columns:1fr;gap:24px}.hero-cube-wrap{width:120px;height:120px;order:-1;align-self:center;justify-self:center;margin:20px 0}.hero-cube{width:120px;height:120px}.cube-front{transform:translateZ(60px)}.cube-back{transform:translateZ(-60px) rotateY(180deg)}.cube-right{transform:translate(60px) rotateY(90deg)}.cube-left{transform:translate(-60px) rotateY(-90deg)}.cube-top{transform:translateY(-60px) rotateX(90deg)}.cube-bottom{transform:translateY(60px) rotateX(-90deg)}.exp-item{grid-template-columns:1fr;gap:2px}.nav-links{display:none}.related-grid,.post-nav{grid-template-columns:1fr}.container,.header-inner{padding:0 16px}.about-header{flex-direction:column;text-align:center}.prose pre{margin:20px 0}.nl-form{flex-direction:column}.footer-inner{flex-direction:column;gap:8px;text-align:center}}.kairo-actions{display:flex;gap:12px;flex-wrap:wrap;padding:8px 0 0}.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 24px;border-radius:var(--r);font-family:var(--font-sans);font-size:14px;font-weight:500;text-decoration:none;border:1px solid var(--border);color:var(--ink);transition:all .2s ease}.btn:hover{border-color:var(--accent);color:var(--accent-ink)}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{opacity:.9;color:#fff}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.reveal{opacity:1;transform:none}}
