@font-face{font-family:HankenGrotesk;src:url(/font/HankenGrotesk.ttf) format("truetype");font-weight:1 999;font-style:normal}.proj-page{--accent: #5113a3}.proj-hero{position:relative;min-height:40vh;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;background-color:#0f0f0f}.proj-hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.3) blur(8px);transform:scale(1.06)}.proj-hero__gradient{position:absolute;inset:0;background:linear-gradient(to top,#0f0f0f,#0f0f0f80 55%,#0f0f0f0d)}.proj-hero__inner{position:relative;z-index:2;max-width:1280px;margin:0 auto;width:100%;padding:120px 24px 48px}@media(max-width:680px){.proj-hero__inner{padding:104px 16px 32px}}.proj-hero:not(:has(.proj-hero__bg)){background-color:#f4f4f5;border-bottom:1px solid rgba(0,0,0,.08)}.proj-hero:not(:has(.proj-hero__bg)) .proj-hero__bread a,.proj-hero:not(:has(.proj-hero__bg)) .proj-hero__bread span{color:#6b6b6b}.proj-hero:not(:has(.proj-hero__bg)) .proj-hero__title{color:#0f0f0f}.proj-hero:not(:has(.proj-hero__bg)) .proj-hero__meta{color:#6b6b6b}.proj-hero:not(:has(.proj-hero__bg)) .proj-hero__tag{color:var(--accent);border-color:#5113a333;background:#f0e8ff}.proj-hero__bread{display:flex;align-items:center;gap:8px;font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#ffffff59;margin-bottom:32px}.proj-hero__bread a{color:inherit;text-decoration:none;transition:color .15s cubic-bezier(0,0,.2,1)}.proj-hero__bread a:hover{color:#ffffffbf}.proj-hero__content{display:flex;flex-direction:column;gap:20px}.proj-hero__tags{display:flex;flex-wrap:wrap;gap:8px}.proj-hero__tag{display:inline-flex;align-items:center;padding:4px 16px;font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#ffffffb3;border:1px solid rgba(255,255,255,.15);border-radius:9999px;background:#ffffff0f}.proj-hero__title{font-size:clamp(2.25rem,7vw,6rem);font-weight:800;letter-spacing:-.04em;line-height:.95;color:#fff;margin:0;max-width:900px}.proj-hero__meta{display:flex;align-items:center;gap:12px;font-size:.75rem;color:#fff6;font-weight:500;letter-spacing:.06em}.proj-hero__meta-dot{width:6px;height:6px;border-radius:9999px;background:var(--accent);flex-shrink:0}.proj-hero__meta-sep{opacity:.3}.proj-body{display:grid;grid-template-columns:1fr 300px;gap:32px;align-items:start;max-width:1280px;margin:0 auto;padding:48px 24px 80px}@media(max-width:900px){.proj-body{grid-template-columns:1fr;padding:32px 16px 48px}}.proj-main{display:flex;flex-direction:column;gap:40px;min-width:0}.prose{color:#0f0f0fbf;font-size:1rem;line-height:1.8}.prose h2{font-size:1.25rem;font-weight:700;letter-spacing:-.02em;color:#0f0f0f;margin:40px 0 16px;padding-top:40px;border-top:1px solid rgba(0,0,0,.08)}.prose h3{font-size:1.125rem;font-weight:600;color:#0f0f0f;margin:32px 0 12px}.prose p{margin:0 0 20px}.prose .lead{font-size:clamp(1rem,1.4vw,1.125rem);line-height:1.75;color:#0f0f0fe6;max-width:64ch;font-weight:400}.prose blockquote{margin:24px 0;padding:20px 24px;border-left:3px solid var(--accent);border-radius:0 12px 12px 0;background:#f0e8ff;color:#0f0f0fd9;font-style:normal}.prose ul,.prose ol{padding-left:0;margin:0 0 20px;display:flex;flex-direction:column;gap:8px;list-style:none}.prose ul li,.prose ol li{padding-left:20px;position:relative}.prose ul li:before,.prose ol li:before{content:"";position:absolute;left:0;top:10px;width:5px;height:5px;border-radius:9999px;background:var(--accent)}.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}.prose a:hover{opacity:.75}.prose img{width:100%;border-radius:12px;margin:24px 0}.prose code{font-size:.875em;background:#f4f4f5;border:1px solid rgba(0,0,0,.08);border-radius:4px;padding:2px 6px;color:#5113a3}.prose pre{background:#f4f4f5;border:1px solid rgba(0,0,0,.08);border-radius:12px;padding:20px;overflow-x:auto;margin:24px 0}.prose pre code{background:none;border:none;padding:0;color:#0f0f0f}.prose hr{border:none;border-top:1px solid rgba(0,0,0,.08);margin:32px 0}.rich-embed{width:100%;border:1px solid rgba(0,0,0,.08);border-radius:16px;overflow:hidden;margin:32px 0;background:#f4f4f5}.rich-embed--flush{margin-top:0}.rich-embed__head{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid rgba(0,0,0,.08)}.rich-embed__label{font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);flex-shrink:0}.rich-embed__title{font-size:.875rem;font-weight:600;color:#0f0f0f;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rich-embed__frame{position:relative;width:100%;overflow:hidden;background:#0f0f0f}.rich-embed__frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}.rich-embed__frame--video{aspect-ratio:16/9}.rich-embed__frame--figma{aspect-ratio:16/10}.external-site-embed{display:flex;flex-direction:column;width:100%;border:1px solid rgba(0,0,0,.08);border-radius:16px;overflow:hidden;background:#f4f4f5;text-decoration:none;margin:24px 0;transition:transform .25s cubic-bezier(0,0,.2,1),border-color .25s cubic-bezier(0,0,.2,1),box-shadow .25s cubic-bezier(0,0,.2,1)}.external-site-embed:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 12px 32px #0f0f0f14}.external-site-embed:hover .external-site-embed__title{color:var(--accent)}.external-site-embed__frame{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;background:#f4f4f5;border-bottom:1px solid rgba(0,0,0,.08)}.external-site-embed__frame iframe{position:absolute;inset:0;width:128%;height:128%;border:0;transform:scale(.78);transform-origin:top left;pointer-events:none}.external-site-embed__shield{position:absolute;inset:0;background:linear-gradient(to top,rgba(244,244,245,.3),transparent 50%);pointer-events:none}.external-site-embed__body{display:flex;flex-direction:column;gap:4px;padding:16px 20px}.external-site-embed__meta{display:flex;align-items:center;justify-content:space-between;gap:12px}.external-site-embed__title{font-size:.875rem;font-weight:700;color:#0f0f0f;transition:color .15s cubic-bezier(0,0,.2,1)}.external-site-embed__url{font-size:.75rem;color:#9a9a9a;white-space:nowrap}.external-site-embed__label,.external-site-embed__description{font-size:.75rem;color:#6b6b6b;margin:0}.proj-sidebar{display:flex;flex-direction:column;gap:12px;position:sticky;top:96px}@media(max-width:900px){.proj-sidebar{position:static;order:-1}}.proj-card{background:#f4f4f5;border:1px solid rgba(0,0,0,.08);border-radius:16px;padding:20px}.proj-card__title{font-size:.75rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#6b6b6b;margin-bottom:20px;margin-top:0}.proj-card__rows{display:flex;flex-direction:column;gap:0}.proj-card__row{display:flex;justify-content:space-between;align-items:baseline;gap:12px;font-size:.75rem;padding:12px 0;border-bottom:1px solid rgba(0,0,0,.08)}.proj-card__row:first-child{padding-top:0}.proj-card__row:last-child{border-bottom:none;padding-bottom:0}.proj-card__row-label{color:#9a9a9a;flex-shrink:0}.proj-card__row-value{color:#0f0f0f;font-weight:600;text-align:right}.proj-site-link{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:#5113a3;color:#fff;border-radius:16px;text-decoration:none;font-size:.875rem;font-weight:600;transition:background .15s cubic-bezier(0,0,.2,1),transform .15s cubic-bezier(.34,1.56,.64,1)}.proj-site-link:hover{background:#7c3fd6;transform:translateY(-1px)}.proj-back{display:inline-flex;align-items:center;gap:8px;font-size:.75rem;font-weight:600;color:#6b6b6b;text-decoration:none;letter-spacing:.04em;padding:12px 4px;transition:color .15s cubic-bezier(0,0,.2,1)}.proj-back:hover{color:#0f0f0f}
