@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.typing-cursor:after{content:"|";display:inline;margin-left:.05em;color:var(--color-ink);animation:blink .7s steps(1,end) infinite}@keyframes ticker{0%{transform:translate(0)}to{transform:translate(-50%)}}.ticker-track{display:flex;white-space:nowrap;animation:ticker 30s linear infinite}.ticker-track:hover{animation-play-state:paused}.fade-in{opacity:0;transform:translateY(12px);transition:opacity .5s ease,transform .5s ease}.fade-in.visible{opacity:1;transform:none}.tab-link{position:relative}.tab-link:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:2px;background-color:var(--color-accent);transition:width .2s ease}.tab-link:hover:after,.tab-link[aria-selected=true]:after{width:100%}@media(prefers-reduced-motion:reduce){.typing-cursor:after{animation:none;opacity:1}.ticker-track{animation:none}.fade-in{opacity:1;transform:none;transition:none}.tab-link:after{transition:none}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;tab-size:4}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}:root{--color-bg: #E8E4DC;--color-ink: #1A1A18;--color-accent: #2D5A8E;--color-muted: #8B8B83;--color-border: #C4C0B8;--color-surface: #F0EDE7;--text-xs: .65rem;--text-sm: .8rem;--text-base: 1rem;--text-lg: 1.25rem;--text-xl: 2rem;--text-hero: clamp(5rem, 12vw, 10rem);--font-display: "Playfair Display", Georgia, serif;--font-mono: "IBM Plex Mono", "Courier New", monospace;--font-ui: "Inter", system-ui, sans-serif;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-6: 1.5rem;--space-8: 2rem;--space-12: 3rem;--space-16: 4rem;--space-24: 6rem}html.dark{--color-bg: #1A1A18;--color-ink: #E8E4DC;--color-accent: #5B9BD5;--color-muted: #6B6B63;--color-border: #2E2E2B;--color-surface: #222220}html,body{height:100%}body{font-family:var(--font-mono);font-size:var(--text-base);background-color:var(--color-bg);color:var(--color-ink);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}a:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:2px}ul,ol{list-style:none}.theme-toggle[data-astro-cid-x3pjskd3]{display:flex;align-items:center;font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:.06em;color:var(--color-muted);background:none;border:none;cursor:pointer;padding:0;transition:color .15s ease}.theme-toggle[data-astro-cid-x3pjskd3]:hover,.theme-toggle[data-astro-cid-x3pjskd3][data-active=true]{color:var(--color-ink)}.t-off[data-astro-cid-x3pjskd3]{display:inline}.t-on[data-astro-cid-x3pjskd3],.theme-toggle[data-astro-cid-x3pjskd3][data-active=true] .t-off[data-astro-cid-x3pjskd3]{display:none}.theme-toggle[data-astro-cid-x3pjskd3][data-active=true] .t-on[data-astro-cid-x3pjskd3]{display:inline}.t-sep[data-astro-cid-x3pjskd3]{color:var(--color-border);user-select:none}.theme-toggle[data-astro-cid-x3pjskd3]:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px;border-radius:2px}@media(prefers-reduced-motion:reduce){.theme-toggle[data-astro-cid-x3pjskd3]{transition:none}}.site-header[data-astro-cid-5hce7sga]{position:fixed;top:0;left:0;right:0;z-index:100;height:40px;background:var(--color-bg);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid var(--color-border)}.header-inner[data-astro-cid-5hce7sga]{display:flex;align-items:center;justify-content:space-between;height:100%;padding:0 2rem}@media(max-width:640px){.header-inner[data-astro-cid-5hce7sga]{padding:0 1rem}}.header-left[data-astro-cid-5hce7sga]{display:flex;align-items:center;gap:.75rem}.header-brand[data-astro-cid-5hce7sga]{font-family:var(--font-ui);font-weight:500;font-size:var(--text-sm);color:var(--color-ink)}.header-sep[data-astro-cid-5hce7sga]{font-size:var(--text-sm);color:var(--color-border);user-select:none}.header-right[data-astro-cid-5hce7sga]{display:flex;align-items:center;gap:.75rem}.header-version[data-astro-cid-5hce7sga]{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-muted)}body{padding-top:40px;padding-bottom:calc(1.5rem + 72px)}.hero[data-astro-cid-bbe6dxrz]{display:flex;flex-direction:column;justify-content:center;padding:var(--space-12) var(--space-8) var(--space-8)}.hero-name[data-astro-cid-bbe6dxrz]{font-family:var(--font-display);line-height:.88;margin-bottom:0}.name-juank[data-astro-cid-bbe6dxrz]{display:block;font-size:var(--text-hero);font-weight:900;font-style:normal;color:var(--color-ink)}.name-ca[data-astro-cid-bbe6dxrz]{display:block;font-size:var(--text-hero);font-weight:900;font-style:italic;color:transparent;-webkit-text-stroke:1px var(--color-border)}.hero-divider[data-astro-cid-bbe6dxrz]{border:none;border-top:1px solid var(--color-border);width:60%;margin:var(--space-6) 0}.hero-label[data-astro-cid-bbe6dxrz]{font-family:var(--font-ui);font-weight:500;font-size:var(--text-sm);color:var(--color-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-6)}.hero-bio[data-astro-cid-bbe6dxrz]{font-family:var(--font-mono);font-size:var(--text-base);line-height:1.7;display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-8)}.hero-email[data-astro-cid-bbe6dxrz]{color:var(--color-accent);text-decoration:none}.hero-email[data-astro-cid-bbe6dxrz]:hover{text-decoration:underline}.hero-meta[data-astro-cid-bbe6dxrz]{display:flex;flex-direction:column;gap:var(--space-2);padding-bottom:2rem}.hero-meta[data-astro-cid-bbe6dxrz] p[data-astro-cid-bbe6dxrz]{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-muted)}.hero-meta-link[data-astro-cid-bbe6dxrz]{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-accent);text-decoration:none}.hero-meta-link[data-astro-cid-bbe6dxrz]:hover{text-decoration:underline}.social-link[data-astro-cid-bbe6dxrz]{display:inline-flex;align-items:center;gap:6px}.about-block[data-astro-cid-bbe6dxrz]{margin-top:2rem;border-top:1px solid var(--color-border);padding-top:1rem}.about-block[data-astro-cid-bbe6dxrz] summary[data-astro-cid-bbe6dxrz]{font-family:var(--font-ui);font-size:var(--text-sm);font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--color-muted);cursor:pointer;list-style:none;display:flex;align-items:center;gap:.5rem;user-select:none}.about-block[data-astro-cid-bbe6dxrz] summary[data-astro-cid-bbe6dxrz]::-webkit-details-marker{display:none}.about-block[data-astro-cid-bbe6dxrz] summary[data-astro-cid-bbe6dxrz]:before{content:"+";font-family:var(--font-mono);font-size:var(--text-base);line-height:1;color:var(--color-accent)}.about-block[data-astro-cid-bbe6dxrz][open] summary[data-astro-cid-bbe6dxrz]:before{content:"−"}.about-content[data-astro-cid-bbe6dxrz]{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-muted);line-height:1.8;margin-top:1rem}.about-content[data-astro-cid-bbe6dxrz] p[data-astro-cid-bbe6dxrz]{margin-bottom:1rem}.about-content[data-astro-cid-bbe6dxrz] p[data-astro-cid-bbe6dxrz]:last-child{margin-bottom:0}.project-card[data-astro-cid-mspuyifq]{border:1px solid var(--color-border);padding:1.5rem;display:flex;flex-direction:column;gap:var(--space-4)}.card-header[data-astro-cid-mspuyifq]{display:flex;align-items:flex-start;gap:var(--space-4)}.card-number[data-astro-cid-mspuyifq]{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-muted);writing-mode:vertical-lr;transform:rotate(180deg);align-self:center;flex-shrink:0;letter-spacing:.05em}.card-title-group[data-astro-cid-mspuyifq]{display:flex;align-items:baseline;gap:var(--space-3);flex-wrap:wrap}.card-name[data-astro-cid-mspuyifq]{font-family:var(--font-display);font-size:2.5rem;font-weight:700;line-height:1;color:var(--color-ink)}.card-context[data-astro-cid-mspuyifq]{font-family:var(--font-ui);font-size:var(--text-sm);color:var(--color-muted)}.card-category[data-astro-cid-mspuyifq]{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--color-border);padding-bottom:.5rem}.card-preview[data-astro-cid-mspuyifq]{position:relative;aspect-ratio:16 / 9;background:var(--color-surface);border:1px solid var(--color-border);overflow:hidden}.card-preview-placeholder[data-astro-cid-mspuyifq]{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-muted);letter-spacing:.04em}.card-preview-img[data-astro-cid-mspuyifq]{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.9;transition:transform .35s ease,opacity .35s ease}.card-preview[data-astro-cid-mspuyifq]:hover .card-preview-img[data-astro-cid-mspuyifq]{transform:scale(1.03);opacity:1}.card-preview-hint[data-astro-cid-mspuyifq]{position:absolute;bottom:.5rem;right:.5rem;font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-muted);background:var(--color-bg);padding:2px 6px;opacity:0;transition:opacity .2s ease;pointer-events:none}.card-preview[data-astro-cid-mspuyifq]:hover .card-preview-hint[data-astro-cid-mspuyifq]{opacity:1}.card-role[data-astro-cid-mspuyifq]{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:500;color:var(--color-ink)}.card-description[data-astro-cid-mspuyifq]{font-family:var(--font-mono);font-size:var(--text-base);color:var(--color-muted);line-height:1.6}.card-footer[data-astro-cid-mspuyifq]{display:flex;flex-direction:column;gap:var(--space-3);margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--color-border)}.card-stack[data-astro-cid-mspuyifq]{display:flex;flex-wrap:wrap;gap:var(--space-2)}.stack-tag[data-astro-cid-mspuyifq]{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-muted);border:1px solid var(--color-border);padding:2px 8px}.card-actions[data-astro-cid-mspuyifq]{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.card-status[data-astro-cid-mspuyifq]{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-accent);letter-spacing:.06em;margin-right:auto}.card-links[data-astro-cid-mspuyifq]{display:flex;align-items:center;gap:.5rem}.link-btn[data-astro-cid-mspuyifq]{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-muted);border:1px solid var(--color-border);padding:4px 10px;text-decoration:none;letter-spacing:.05em;transition:color .15s ease,border-color .15s ease}.link-btn[data-astro-cid-mspuyifq]:hover{color:var(--color-ink);border-color:var(--color-ink)}@media(prefers-reduced-motion:reduce){.card-preview-img[data-astro-cid-mspuyifq],.card-preview-hint[data-astro-cid-mspuyifq],.link-btn[data-astro-cid-mspuyifq]{transition:none}}.project-grid[data-astro-cid-2wkm2a2e]{display:flex;flex-direction:column;gap:var(--space-6);padding:var(--space-12) var(--space-8) var(--space-8)}.grid-heading[data-astro-cid-2wkm2a2e]{font-family:var(--font-display);font-size:var(--text-xl);font-weight:400;color:var(--color-ink)}.tabs-list[data-astro-cid-2wkm2a2e]{display:flex}.tab-btn[data-astro-cid-2wkm2a2e]{position:relative;display:flex;flex-direction:column;gap:.2rem;border:1px solid var(--color-border);padding:.75rem 1rem;background:none;cursor:pointer;text-align:left;flex:1;min-width:0;transition:border-color .15s ease}.tab-btn[data-astro-cid-2wkm2a2e]+.tab-btn[data-astro-cid-2wkm2a2e]{border-left:none}.tab-btn[data-astro-cid-2wkm2a2e].is-active{border:1px solid var(--color-ink);z-index:1}.tab-btn[data-astro-cid-2wkm2a2e].is-active+.tab-btn[data-astro-cid-2wkm2a2e]{border-left:none}.tab-meta[data-astro-cid-2wkm2a2e]{display:flex;justify-content:space-between;align-items:center;gap:var(--space-1)}.tab-number[data-astro-cid-2wkm2a2e],.tab-context[data-astro-cid-2wkm2a2e]{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-muted);white-space:nowrap}.tab-name[data-astro-cid-2wkm2a2e]{font-family:var(--font-ui);font-size:var(--text-base);font-weight:500;color:var(--color-muted);transition:color .15s ease;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tab-btn[data-astro-cid-2wkm2a2e].is-active .tab-name[data-astro-cid-2wkm2a2e]{color:var(--color-ink)}.card-panel[data-astro-cid-2wkm2a2e]{display:none;opacity:0;transition:opacity .2s ease}.card-panel[data-astro-cid-2wkm2a2e].is-active{display:block}.card-panel[data-astro-cid-2wkm2a2e] .fade-in{opacity:1;transform:none;transition:none}@media(max-width:640px){.tabs-list[data-astro-cid-2wkm2a2e]{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs-list[data-astro-cid-2wkm2a2e]::-webkit-scrollbar{display:none}.tab-btn[data-astro-cid-2wkm2a2e]{flex-shrink:0;min-width:90px;padding:.6rem .75rem}.tab-name[data-astro-cid-2wkm2a2e]{font-size:var(--text-sm)}}@media(prefers-reduced-motion:reduce){.tab-btn[data-astro-cid-2wkm2a2e],.tab-name[data-astro-cid-2wkm2a2e],.card-panel[data-astro-cid-2wkm2a2e]{transition:none}}.ticker-footer[data-astro-cid-kofmyqso]{position:fixed;bottom:0;left:0;right:0;z-index:100;background:var(--color-bg);padding-top:1.5rem}.ticker-bar[data-astro-cid-kofmyqso]{height:44px;overflow:hidden;display:flex;align-items:center;border-top:1px solid var(--color-border);background:var(--color-bg)}.ticker-content[data-astro-cid-kofmyqso]{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-muted);white-space:nowrap;padding-right:0}.ticker-dot[data-astro-cid-kofmyqso]{color:var(--color-accent)}.status-bar[data-astro-cid-kofmyqso]{height:28px;display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--color-border);padding:0 2rem}@media(max-width:640px){.status-bar[data-astro-cid-kofmyqso]{padding:0 1rem}}.status-left[data-astro-cid-kofmyqso],.status-tz[data-astro-cid-kofmyqso]{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-muted)}.status-email[data-astro-cid-kofmyqso]{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-muted);text-decoration:none;transition:color .15s ease}.status-email[data-astro-cid-kofmyqso]:hover{color:var(--color-accent)}@media(prefers-reduced-motion:reduce){.status-email[data-astro-cid-kofmyqso]{transition:none}}.site-main[data-astro-cid-j7pv25f6]{display:grid;grid-template-columns:40fr 60fr;gap:0;height:calc(100vh - 40px)}.col-hero[data-astro-cid-j7pv25f6]{overflow-y:auto;padding-bottom:80px}.col-works[data-astro-cid-j7pv25f6]{border-left:1px solid var(--color-border);overflow-y:auto;padding-bottom:80px}@media(max-width:768px){.site-main[data-astro-cid-j7pv25f6]{grid-template-columns:1fr;height:auto}.col-works[data-astro-cid-j7pv25f6]{border-left:none}.col-hero[data-astro-cid-j7pv25f6],.col-works[data-astro-cid-j7pv25f6]{padding-bottom:80px}}
