@import"https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,500;12..96,600;12..96,700;12..96,800&family=Plus+Jakarta+Sans:ital,wght@0,400;0,500;0,600;0,700;0,800;1,500&family=Space+Mono:ital,wght@0,400;0,700;1,400&display=swap";:root{--paper: #f4f4f4;--paper-2: #ffffff;--paper-3: #efeeea;--ink: #221a2e;--ink-2: #322745;--ink-soft: #6e6580;--ink-faint: #a79eb6;--line: rgba(34, 26, 46, .16);--line-2: rgba(34, 26, 46, .85);--coral: #ff5470;--blue: #3b6cff;--yellow: #ffc93c;--mint: #16c79a;--purple: #9a6cff;--accent: var(--coral);--accent-ink: #e23457;--accent-wash: rgba(255, 84, 112, .14);--pop: 4px 4px 0 var(--ink);--pop-lg: 6px 6px 0 var(--ink);--pop-sm: 3px 3px 0 var(--ink);--code-bg: #1e1830;--code-line: rgba(255, 255, 255, .09);--code-text: #ede9f5;--code-dim: #8c84a0;--c-key: #ff8fa8;--c-str: #ffd56b;--c-fn: #74b7ff;--c-num: #ffb07a;--c-com: #7d7592;--c-tag: #6be0bd;--display: "Bricolage Grotesque", sans-serif;--body: "Plus Jakarta Sans", sans-serif;--mono: "Space Mono", monospace;--container: 1180px;--gut: clamp(20px, 5vw, 64px);--radius: 18px;--radius-sm: 11px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--body);background-color:var(--paper);color:var(--ink);line-height:1.6;font-size:17px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;background-image:radial-gradient(rgba(34,26,46,.05) 1.4px,transparent 1.4px);background-size:22px 22px}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}::selection{background:var(--yellow);color:var(--ink)}.wrap{max-width:var(--container);margin-inline:auto;padding-inline:var(--gut)}.rule{border:0;border-top:2px dashed var(--line)}.rule-2{border:0;border-top:3px solid var(--ink)}.label{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);background:var(--yellow);border:2px solid var(--ink);padding:5px 12px;border-radius:100px;box-shadow:var(--pop-sm)}.label .idx{color:var(--accent-ink)}.h-hero{font-family:var(--display);font-weight:800;line-height:.9;letter-spacing:-.035em;font-size:clamp(3.2rem,11vw,9.5rem);font-optical-sizing:auto}.h-sec{font-family:var(--display);font-weight:700;line-height:.98;letter-spacing:-.025em;font-size:clamp(2rem,5vw,3.4rem)}.h-card{font-family:var(--display);font-weight:700;letter-spacing:-.02em;line-height:1.04;font-size:1.55rem}.serif-accent{font-style:italic;font-weight:600;color:var(--accent)}.nav{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--paper) 90%,transparent);backdrop-filter:blur(10px);border-bottom:3px solid var(--ink)}.nav-inner{display:flex;align-items:center;justify-content:space-between;height:74px}.brand{display:flex;align-items:center;gap:11px;font-family:var(--display);font-weight:800;font-size:1.2rem;letter-spacing:-.02em}.brand .mark{width:32px;height:32px;display:grid;place-items:center;background:var(--coral);color:#fff;font-family:var(--mono);font-size:16px;font-weight:700;border:2px solid var(--ink);border-radius:9px;box-shadow:var(--pop-sm);transform:rotate(-6deg);transition:transform .2s}.brand:hover .mark{transform:rotate(6deg) scale(1.05)}.nav-links{display:flex;align-items:center;gap:clamp(12px,2.5vw,30px)}.nav-link{font-family:var(--mono);font-size:13px;font-weight:700;letter-spacing:.02em;color:var(--ink-soft);position:relative;padding:5px 2px;transition:color .2s}.nav-link:after{content:"";position:absolute;left:0;bottom:0;height:3px;width:0;background:var(--accent);border-radius:2px;transition:width .25s ease}.nav-link:hover,.nav-link[aria-current=page]{color:var(--ink)}.nav-link:hover:after,.nav-link[aria-current=page]:after{width:100%}.nav-cta{font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#fff;background:var(--blue);padding:11px 18px;border:2px solid var(--ink);border-radius:100px;box-shadow:var(--pop-sm);transition:transform .18s,box-shadow .18s}.nav-cta:hover{transform:translate(-1px,-1px);box-shadow:var(--pop)}.nav-cta:active{transform:translate(2px,2px);box-shadow:0 0 0 var(--ink)}.sec-head{display:flex;align-items:center;justify-content:space-between;gap:24px;padding-bottom:18px;margin-bottom:40px;border-bottom:3px solid var(--ink)}.sec-head .more{font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);background:var(--mint);border:2px solid var(--ink);border-radius:100px;padding:7px 14px;box-shadow:var(--pop-sm);display:inline-flex;align-items:center;gap:7px;white-space:nowrap;transition:transform .18s,box-shadow .18s}.sec-head .more:hover{transform:translate(-1px,-1px);box-shadow:var(--pop)}.proj-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.proj{background:var(--paper-2);padding:clamp(22px,3vw,32px);display:flex;flex-direction:column;gap:15px;position:relative;min-height:248px;border:2.5px solid var(--ink);border-radius:var(--radius);box-shadow:var(--pop);transition:transform .2s,box-shadow .2s}.proj:hover{transform:translate(-3px,-3px);box-shadow:var(--pop-lg)}.proj:before{content:"";position:absolute;top:-2.5px;left:26px;width:56px;height:8px;border-radius:0 0 8px 8px;background:var(--coral)}.proj:nth-child(5n+2):before{background:var(--blue)}.proj:nth-child(5n+3):before{background:var(--yellow)}.proj:nth-child(5n+4):before{background:var(--mint)}.proj:nth-child(5n+5):before{background:var(--purple)}.proj-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.proj-num{font-family:var(--mono);font-weight:700;font-size:12px;color:var(--ink-faint);letter-spacing:.08em}.proj-arrow{width:40px;height:40px;border-radius:50%;border:2.5px solid var(--ink);display:grid;place-items:center;color:var(--ink);background:var(--paper);transition:all .22s;flex-shrink:0}.proj:hover .proj-arrow{background:var(--accent);color:#fff;transform:rotate(-45deg)}.proj-desc{color:var(--ink-soft);font-size:.97rem;flex-grow:1}.tags{display:flex;flex-wrap:wrap;gap:8px}.tag{font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.02em;color:var(--ink);background:var(--paper-3);padding:5px 11px;border:2px solid var(--ink);border-radius:100px;transition:transform .15s,background .2s}.tags .tag:nth-child(5n+1){background:#ffd9e0}.tags .tag:nth-child(5n+2){background:#d6e2ff}.tags .tag:nth-child(5n+3){background:#fff0c2}.tags .tag:nth-child(5n+4){background:#c7f4e7}.tags .tag:nth-child(5n+5){background:#e8dcff}a.tag:hover{transform:translateY(-2px) rotate(-2deg)}.proj-links{display:flex;gap:10px;padding-top:4px}.proj-link{font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:var(--ink);display:inline-flex;align-items:center;gap:6px;background:var(--paper);border:2px solid var(--ink);border-radius:100px;padding:7px 14px;box-shadow:var(--pop-sm);transition:transform .16s,box-shadow .16s,background .2s,color .2s}.proj-link:hover{background:var(--ink);color:var(--paper);transform:translate(-1px,-1px);box-shadow:var(--pop)}.post-row{display:grid;grid-template-columns:auto 1fr auto;gap:clamp(16px,4vw,48px);align-items:center;padding:22px 24px;margin-bottom:16px;background:var(--paper-2);border:2.5px solid var(--ink);border-radius:var(--radius);box-shadow:var(--pop);position:relative;overflow:hidden;transition:transform .2s,box-shadow .2s}.post-row:hover{transform:translate(-3px,-3px);box-shadow:var(--pop-lg)}.post-row:hover .post-title{color:var(--accent)}.post-row:after{content:"";position:absolute;left:0;top:0;bottom:0;width:8px;background:var(--blue);transform:translate(-8px);transition:transform .22s}.post-row:hover:after{transform:translate(0)}.post-row:nth-child(4n+1):after{background:var(--coral)}.post-row:nth-child(4n+2):after{background:var(--blue)}.post-row:nth-child(4n+3):after{background:var(--mint)}.post-row:nth-child(4n+4):after{background:var(--purple)}.post-date{font-family:var(--mono);font-weight:700;font-size:13px;color:var(--ink-soft);white-space:nowrap}.post-mid{display:flex;flex-direction:column;gap:10px}.post-title{font-family:var(--display);font-weight:700;font-size:clamp(1.4rem,3vw,2rem);letter-spacing:-.025em;line-height:1.05;transition:color .2s}.post-meta{font-family:var(--mono);font-weight:700;font-size:12px;color:#fff;background:var(--ink);border-radius:100px;padding:5px 12px;white-space:nowrap}.footer{background:var(--ink);color:var(--paper);margin-top:100px;border-top:3px solid var(--ink)}.footer a{color:var(--paper)}.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-block:clamp(48px,7vw,88px)}.footer .big{font-family:var(--display);font-weight:800;letter-spacing:-.025em;font-size:clamp(2rem,5vw,3.2rem);line-height:.98}.footer .big:after{content:" ✺";color:var(--yellow)}.footer-col h4{font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--yellow);margin-bottom:16px}.footer-col a{display:flex;align-items:center;justify-content:space-between;font-family:var(--mono);font-weight:700;font-size:14px;padding:10px 0;border-bottom:2px solid rgba(255,244,230,.14);color:var(--paper);transition:color .2s,padding .2s}.footer-col a:hover{color:var(--yellow);padding-left:8px}.footer-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-block:22px;border-top:2px solid rgba(255,244,230,.14);font-family:var(--mono);font-size:12px;color:var(--ink-faint)}.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-weight:700;font-size:13px;letter-spacing:.03em;text-transform:uppercase;padding:14px 24px;border-radius:100px;cursor:pointer;border:2.5px solid var(--ink);box-shadow:var(--pop);transition:transform .18s,box-shadow .18s,background .2s,color .2s}.btn:hover{transform:translate(-2px,-2px);box-shadow:var(--pop-lg)}.btn:active{transform:translate(3px,3px);box-shadow:0 0 0 var(--ink)}.btn-solid{background:var(--coral);color:#fff}.btn-ghost{background:var(--paper-2);color:var(--ink)}.pill{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:.04em;padding:8px 15px;background:var(--mint);border:2.5px solid var(--ink);border-radius:100px;color:var(--ink);box-shadow:var(--pop-sm);transform:rotate(-2deg)}.dot{width:8px;height:8px;border-radius:50%;background:var(--ink);animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.5);opacity:.55}}.prose{font-size:1.13rem;line-height:1.75;color:var(--ink-2)}.prose>*+*{margin-top:1.45em}.prose h2{font-family:var(--display);font-weight:700;font-size:1.95rem;letter-spacing:-.025em;color:var(--ink);margin-top:2.2em;line-height:1.1}.prose h2:before{content:"#";color:var(--accent);margin-right:.3em}.prose h3{font-family:var(--display);font-weight:700;font-size:1.4rem;color:var(--ink);margin-top:1.8em}.prose p{text-wrap:pretty}.prose a{color:var(--accent-ink);font-weight:700;border-bottom:2px solid var(--accent)}.prose a:hover{background:var(--accent-wash)}.prose strong{font-weight:800;color:var(--ink)}.prose ul,.prose ol{padding-left:1.3em}.prose li{margin-top:.5em}.prose li::marker{color:var(--accent);font-weight:800}.prose blockquote{border:2.5px solid var(--ink);border-left:8px solid var(--yellow);background:var(--paper-2);border-radius:var(--radius);padding:18px 24px;box-shadow:var(--pop);font-style:italic;color:var(--ink);font-size:1.16rem}.prose code:not(pre code){font-family:var(--mono);font-weight:700;font-size:.84em;background:var(--paper-3);padding:2px 7px;border:2px solid var(--ink);border-radius:7px;color:var(--accent-ink)}.codeblock{background:var(--code-bg);border-radius:var(--radius);overflow:hidden;border:2.5px solid var(--ink);box-shadow:var(--pop-lg)}.codeblock-bar{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--code-line)}.codeblock-bar .fname{font-family:var(--mono);font-size:12px;color:var(--code-dim);margin-left:8px}.cdot{width:12px;height:12px;border-radius:50%}.cdot:nth-child(1){background:#ff5f57}.cdot:nth-child(2){background:#febc2e}.cdot:nth-child(3){background:#28c840}.codeblock pre{margin:0;padding:20px 22px;overflow-x:auto}.codeblock code{font-family:var(--mono);font-size:13.5px;line-height:1.7;color:var(--code-text)}.prose pre.astro-code{background:var(--code-bg)!important;border-radius:var(--radius);overflow-x:auto;border:2.5px solid var(--ink);box-shadow:var(--pop-lg);padding:22px;margin-top:1.6em}.prose pre.astro-code code{font-family:var(--mono);font-size:13.5px;line-height:1.7;background:none;border:0;padding:0;color:var(--code-text);font-weight:400}.tok-key{color:var(--c-key)}.tok-str{color:var(--c-str)}.tok-fn{color:var(--c-fn)}.tok-num{color:var(--c-num)}.tok-com{color:var(--c-com);font-style:italic}.tok-tag{color:var(--c-tag)}.tok-dim{color:var(--code-dim)}@media(prefers-reduced-motion:no-preference){.reveal{opacity:0;transform:translateY(20px);animation:rise .7s cubic-bezier(.2,.8,.2,1) forwards}@keyframes rise{to{opacity:1;transform:none}}}@media(max-width:820px){.proj-grid{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr;gap:28px}.post-row{grid-template-columns:1fr;gap:12px;align-items:start}.post-meta{justify-self:start}.post-date,.post-meta{font-size:12px}.nav-cta{display:none}}@media(max-width:560px){.nav-links .nav-link{font-size:12px}}@media(max-width:720px){.about-grid{grid-template-columns:1fr!important}}
