.project-page.svelte-9da364{width:100%;min-height:100vh;background-color:var(--color-bg);position:relative}.hero-image-wrapper.svelte-9da364{width:100%;height:60vh;overflow:hidden}.hero-image.svelte-9da364{width:100%;height:100%;object-fit:cover;display:block}.content-container.svelte-9da364{max-width:120rem;margin:0 auto;padding:6rem 3rem;background-color:var(--color-bg);position:relative;z-index:10}@media only screen and (max-width: 768px){.content-container.svelte-9da364{padding:4rem 1.5rem}}.project-header.svelte-9da364{margin-bottom:4rem}.project-header.svelte-9da364 h1:where(.svelte-9da364){font-size:5rem;font-weight:700;margin-bottom:1rem;display:inline-flex;align-items:center;gap:1.2rem;word-break:break-word;-webkit-hyphens:auto;hyphens:auto}@media (max-width: 768px){.project-header.svelte-9da364 h1:where(.svelte-9da364){font-size:3rem}}.project-header.svelte-9da364 p:where(.svelte-9da364){font-size:2rem;color:#555;font-family:var(--font-sans-serif)}.project-demo-link.svelte-9da364{display:inline-flex;align-items:center;justify-content:center;width:3.2rem;height:3.2rem;border-radius:999px;background:#0000000d;color:inherit;text-decoration:none;transition:transform .2s ease,background .2s ease,opacity .2s ease;flex:0 0 auto}.project-demo-link.svelte-9da364 svg:where(.svelte-9da364){width:1.6rem;height:1.6rem;fill:currentColor}.project-demo-link.svelte-9da364:hover{background:#0000001f;transform:translateY(-1px)}.project-demo-link.svelte-9da364:focus-visible{outline:2px solid currentColor;outline-offset:3px}.project-description.svelte-9da364{font-size:1.8rem;line-height:1.6;max-width:80rem}.rich-content.svelte-9da364{font-family:var(--font-serif);font-size:1.8rem;line-height:1.75;margin-bottom:4rem;color:var(--color-text)}.rich-content.svelte-9da364 p{margin-bottom:1.5em}.rich-content.svelte-9da364 h1{font-size:3rem;font-weight:700;margin:1.5em 0 .5em}.rich-content.svelte-9da364 h2{font-size:2.4rem;font-weight:700;margin:1.5em 0 .5em}.rich-content.svelte-9da364 h3{font-size:2rem;font-weight:600;margin:1.2em 0 .4em}.rich-content.svelte-9da364 h4,.rich-content.svelte-9da364 h5,.rich-content.svelte-9da364 h6{font-size:1.7rem;font-weight:600;margin:1em 0 .4em}.rich-content.svelte-9da364 ul{list-style:disc;padding-left:2em;margin-bottom:1.5em}.rich-content.svelte-9da364 ol{list-style:decimal;padding-left:2em;margin-bottom:1.5em}.rich-content.svelte-9da364 li{margin-bottom:.4em}.rich-content.svelte-9da364 blockquote{border-left:3px solid color-mix(in srgb,var(--color-text) 25%,white);padding-left:1.5em;margin:1.5em 0;font-style:italic;color:color-mix(in srgb,var(--color-text) 70%,white)}.rich-content.svelte-9da364 pre{background:color-mix(in srgb,var(--color-text) 6%,white);border-radius:.5rem;padding:1.2em 1.5em;overflow-x:auto;margin-bottom:1.5em;font-size:1.4rem}.rich-content.svelte-9da364 code{font-family:var(--font-mono, monospace);font-size:.9em;background:color-mix(in srgb,var(--color-text) 8%,white);padding:.15em .4em;border-radius:.25rem}.rich-content.svelte-9da364 pre code{background:none;padding:0}.rich-content.svelte-9da364 hr{border:none;border-top:1px solid #ddd;margin:2.5em 0}.rich-content.svelte-9da364 strong{font-weight:700}.rich-content.svelte-9da364 em{font-style:italic}.rich-content.svelte-9da364 u{text-decoration:underline;text-underline-offset:3px}.rich-content.svelte-9da364 s{text-decoration:line-through}.rich-content.svelte-9da364 a{color:var(--color-text);text-decoration:underline}.rich-content.svelte-9da364 a:hover{opacity:.7}.details-grid.svelte-9da364{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:4rem;padding-top:4rem;border-top:1px solid #ddd}@media (max-width: 600px){.details-grid.svelte-9da364{grid-template-columns:1fr}}.details-grid.svelte-9da364 h4:where(.svelte-9da364){font-size:1.2rem;text-transform:uppercase;letter-spacing:.1em;color:#888;margin-bottom:.5rem;word-wrap:break-word;word-break:break-word;-webkit-hyphens:auto;hyphens:auto}.details-grid.svelte-9da364 span:where(.svelte-9da364){font-size:1.6rem}
