.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}@font-face{font-family:"Source Serif";src:url(/fonts/SourceSerif4-Regular.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:"Source Serif";src:url(/fonts/SourceSerif4-Italic.woff2) format("woff2");font-weight:400;font-style:italic;font-display:swap}@font-face{font-family:"Source Serif";src:url(/fonts/SourceSerif4-Bold.woff2) format("woff2");font-weight:700;font-style:normal;font-display:swap}:root{--bg: #263238;--bg-subtle: #2e3d44;--text: #ffffff;--text-muted: oklch(75% 0 0);--accent: #ffffff;--border: #37474f}*{box-sizing:border-box}html{font-family:"Source Serif",Charter,Bitstream Charter,Cambria,serif;background:var(--bg);color:var(--text);font-size:18px;line-height:1.7;letter-spacing:normal;accent-color:var(--accent);scroll-behavior:smooth}body{max-width:900px;margin:0 auto;padding:2rem 1rem}@media (max-width: 600px){html{font-size:16px}h1{font-size:1.6rem}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}a{color:var(--accent);text-decoration:none;display:inline-block;padding:.1em .3em;letter-spacing:.05em;margin:-.1em -.3em;border-radius:4px;transition:all .2s ease}a:hover{background:oklch(25% .05 220);color:oklch(90% .12 220);transform:scale(1.05) rotate(var(--tilt, -1deg))}a:nth-child(odd){--tilt: -1.5deg}a:nth-child(2n){--tilt: 1.5deg}a:nth-child(3n){--tilt: -2deg}a:nth-child(5n){--tilt: 2deg}a:focus-visible{outline:2px solid var(--accent);outline-offset:2px}::selection{background:oklch(45% .15 220);color:#fff}h1,h2,h3{font-weight:300;letter-spacing:.02em}h1{font-size:2rem;border-bottom:1px solid var(--border);padding-bottom:.5rem;margin-bottom:1.5rem}h2{font-size:1.4rem;color:var(--text-muted);margin-top:3rem;margin-bottom:1rem;word-spacing:.3em}section{margin-bottom:2rem}.intro{font-size:1.1rem;color:var(--text-muted);max-width:40ch}article>header{margin-bottom:2rem}article>header time{color:var(--text-muted)}footer{margin-top:4rem;padding-top:2rem;border-top:1px solid var(--border);color:var(--text-muted);font-size:.9rem;text-align:center}.project-links{display:flex;gap:1rem;margin-bottom:2rem}hr{border:none;border-top:1px solid var(--border);margin:1rem 0}details{margin:1.5rem 0}details summary{cursor:pointer;color:var(--text-muted);display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:1px solid var(--border);border-radius:6px;font-size:.9rem;transition:all .2s ease;list-style:none}details summary::-webkit-details-marker{display:none}details summary:before{content:"▸";transition:transform .2s ease}details[open] summary:before{transform:rotate(90deg)}details summary:hover{color:var(--accent);border-color:var(--accent);background:#030d11}details[open] summary{margin-bottom:1rem;border-color:var(--accent);color:var(--accent)}details[open]>*:not(summary){animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}img{border-radius:6px;border:2px solid var(--border);box-shadow:0 2px 8px #0006}.lang-switch:where(.astro-bzi5jpwk){font-size:1.2rem;transition:transform .2s ease}.lang-switch:where(.astro-bzi5jpwk):hover{transform:scale(1.15);background:transparent}.a-matias-quezada:where(.astro-2dpizvyk){white-space:nowrap}.a-matias-quezada:where(.astro-2dpizvyk)>abbr:where(.astro-2dpizvyk){display:inline-flex;width:.65em;overflow:hidden;transition:width .2s ease;text-decoration:none}.a-matias-quezada:where(.astro-2dpizvyk)>.dot:where(.astro-2dpizvyk){display:inline-block;width:.3em;transition:opacity .15s ease,width .15s ease}.a-matias-quezada:where(.astro-2dpizvyk):hover>abbr:where(.astro-2dpizvyk){width:3.3em}.a-matias-quezada:where(.astro-2dpizvyk):hover>.dot:where(.astro-2dpizvyk){opacity:0;width:0}header:where(.astro-np5jgbit){display:grid;grid-template-columns:1fr auto;grid-template-areas:"title icons" "nav nav";align-items:center;gap:1rem 0;padding-bottom:.5rem}header:where(.astro-np5jgbit) .site-title{grid-area:title;font-weight:500;font-size:1.1rem}nav:where(.astro-np5jgbit){grid-area:nav;display:flex;align-items:center;justify-content:space-between;gap:.6rem;font-size:.95rem}nav:where(.astro-np5jgbit) a:not(:last-child):after{content:"·";margin-left:.6rem;color:var(--text-muted);pointer-events:none}.nav-icons:where(.astro-np5jgbit){grid-area:icons;display:flex;align-items:center;gap:.75rem}@media (min-width: 601px){header:where(.astro-np5jgbit){grid-template-columns:auto 1fr auto;grid-template-areas:"title nav icons";gap:1.5rem;padding-bottom:0}nav:where(.astro-np5jgbit){justify-content:center}}.icon-link:where(.astro-np5jgbit){display:inline-flex;align-items:center;color:var(--text-muted)}.icon-link:where(.astro-np5jgbit):hover{color:var(--text);background:transparent;transform:scale(1.1)}.icon-link:where(.astro-np5jgbit) svg:where(.astro-np5jgbit){vertical-align:middle}
