#projects-intro:where(.astro-aid3sr62){padding-bottom:.5rem;padding-top:1.5rem;text-align:center}#projects-intro:where(.astro-aid3sr62) h1:where(.astro-aid3sr62){font-size:1.875rem;line-height:2.25rem;font-weight:600}@media (min-width: 640px){#projects-intro:where(.astro-aid3sr62) h1:where(.astro-aid3sr62){font-size:2.25rem;line-height:2.5rem}}.filters:where(.astro-aid3sr62){margin-left:auto;margin-right:auto;margin-top:1rem;max-width:48rem;padding-left:.75rem;padding-right:.75rem;display:flex;flex-direction:column;gap:8px}@media (min-width: 640px){.filters:where(.astro-aid3sr62){flex-direction:row;align-items:center;justify-content:space-between}}.filter-pills:where(.astro-aid3sr62){display:flex;flex-wrap:wrap;gap:6px}.pill:where(.astro-aid3sr62){border-radius:9999px;font-size:.75rem;line-height:1rem;font-weight:500;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}@media (min-width: 640px){.pill:where(.astro-aid3sr62){font-size:.875rem;line-height:1.25rem}}.pill:where(.astro-aid3sr62){padding:4px 12px;border:1px solid rgb(var(--color-border));background:transparent;color:rgb(var(--color-text-base));cursor:pointer}.pill:where(.astro-aid3sr62):hover{border-color:rgb(var(--color-accent));color:rgb(var(--color-accent))}.pill:where(.astro-aid3sr62).active{background-color:rgb(var(--color-accent));border-color:rgb(var(--color-accent));color:rgb(var(--color-fill))}.search-wrap:where(.astro-aid3sr62){position:relative;display:flex;align-items:center}.search-icon:where(.astro-aid3sr62){position:absolute;left:10px;opacity:.5;pointer-events:none}.search-input:where(.astro-aid3sr62){border-radius:.375rem;font-size:.875rem;line-height:1.25rem;padding:6px 12px 6px 32px;border:1px solid rgb(var(--color-border));background:transparent;color:rgb(var(--color-text-base));width:100%;min-width:0}@media (min-width: 640px){.search-input:where(.astro-aid3sr62){width:220px}}.search-input:where(.astro-aid3sr62):focus{outline:none;border-color:rgb(var(--color-accent))}.empty-state:where(.astro-aid3sr62){margin-left:auto;margin-right:auto;margin-top:1.5rem;max-width:48rem;padding-left:.75rem;padding-right:.75rem;text-align:center;font-size:.875rem;line-height:1.25rem;opacity:.7}.domain-section:where(.astro-aid3sr62)[hidden]{display:none}.project-card-wrap:where(.astro-aid3sr62)[hidden]{display:none}.domain-list:where(.astro-aid3sr62){margin-left:auto;margin-right:auto;margin-top:1rem;margin-bottom:2.5rem;max-width:48rem;padding-left:.75rem;padding-right:.75rem}.domain-section:where(.astro-aid3sr62){margin-top:2rem}.domain-section:where(.astro-aid3sr62):first-child{margin-top:1rem}.domain-title:where(.astro-aid3sr62){font-size:1rem;line-height:1.5rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;opacity:.6;margin-bottom:8px}.project-list:where(.astro-aid3sr62){display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:.75rem;list-style:none;padding:0}.project-card-wrap:where(.astro-aid3sr62){list-style:none}.project-card:where(.astro-aid3sr62){display:flex;width:100%;flex-direction:row;align-items:center;gap:.75rem;border-radius:.5rem;border-width:1px;--tw-border-opacity: 1;border-color:rgba(var(--color-border),var(--tw-border-opacity, 1));padding:.5rem;text-align:left}@media (min-width: 640px){.project-card:where(.astro-aid3sr62){gap:1rem;padding:.75rem}}.project-card:where(.astro-aid3sr62){background-color:rgb(var(--color-card) / .4);cursor:pointer;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.project-card:where(.astro-aid3sr62):hover{transform:translateY(-1px);border-color:rgb(var(--color-accent));box-shadow:0 4px 16px #00000014}.project-card:where(.astro-aid3sr62):focus-visible{outline:2px solid rgb(var(--color-accent));outline-offset:2px}.project-media:where(.astro-aid3sr62){position:relative;overflow:hidden;border-radius:.375rem;width:4.5rem;flex-shrink:0;aspect-ratio:var(--project-aspect, 1 / 1);background:#111}@media (min-width: 640px){.project-media:where(.astro-aid3sr62){width:7rem}}.project-poster:where(.astro-aid3sr62){height:100%;width:100%;-o-object-fit:cover;object-fit:cover;display:block}.project-media:where(.astro-aid3sr62) video:where(.astro-aid3sr62){position:absolute;inset:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover;opacity:0;pointer-events:none;transition:opacity .18s ease}.project-media:where(.astro-aid3sr62)[data-active=true][data-video-ready=true] video:where(.astro-aid3sr62),.project-media:where(.astro-aid3sr62)[data-autoplaying=true][data-video-ready=true] video:where(.astro-aid3sr62){opacity:1}.play-indicator:where(.astro-aid3sr62){position:absolute;display:flex;align-items:center;justify-content:center;border-radius:9999px;width:28px;height:28px;bottom:6px;right:6px;background:#0009;color:#fff;border:1px solid rgba(255,255,255,.85);transition:transform .15s ease,background .15s ease}.project-card:where(.astro-aid3sr62):hover .play-indicator:where(.astro-aid3sr62){background:#000c;transform:scale(1.06)}.project-media:where(.astro-aid3sr62)[data-active=true] .play-indicator:where(.astro-aid3sr62),.project-media:where(.astro-aid3sr62)[data-autoplaying=true] .play-indicator:where(.astro-aid3sr62){opacity:0;transform:scale(.94)}.play-indicator:where(.astro-aid3sr62) svg:where(.astro-aid3sr62){margin-left:1px}.project-body:where(.astro-aid3sr62){display:flex;width:100%;min-width:0px;flex-direction:column}.project-title:where(.astro-aid3sr62){font-size:.875rem;line-height:1.25rem;font-weight:600}@media (min-width: 640px){.project-title:where(.astro-aid3sr62){font-size:1rem;line-height:1.5rem}}.project-title:where(.astro-aid3sr62){display:flex;align-items:center;flex-wrap:wrap;gap:6px;margin:0}.coming-pill:where(.astro-aid3sr62){font-size:.75rem;line-height:1rem;font-weight:500;text-transform:uppercase;letter-spacing:.025em;padding:2px 8px;border-radius:999px;background:rgb(var(--color-card));border:1px solid rgb(var(--color-border));opacity:.7}.platform-list:where(.astro-aid3sr62){display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.platform-pill:where(.astro-aid3sr62){font-size:.75rem;line-height:1rem;font-weight:500;border-radius:999px;border:1px solid rgb(var(--color-border));background:rgb(var(--color-card) / .72);color:rgb(var(--color-text-base));line-height:1;padding:4px 8px}.project-subtitle:where(.astro-aid3sr62){margin-top:.125rem;font-size:.75rem;line-height:1rem;opacity:.7}@media (min-width: 640px){.project-subtitle:where(.astro-aid3sr62){font-size:.875rem;line-height:1.25rem}}.project-subtitle:where(.astro-aid3sr62){margin-block:2px 0;display:none}@media (min-width: 640px){.project-subtitle:where(.astro-aid3sr62){display:block}}.project-description:where(.astro-aid3sr62){margin-top:.375rem;font-size:.75rem;line-height:1rem;line-height:1.625}@media (min-width: 640px){.project-description:where(.astro-aid3sr62){font-size:.875rem;line-height:1.25rem}}.project-description:where(.astro-aid3sr62){display:none}@media (min-width: 640px){.project-description:where(.astro-aid3sr62){display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}}.project-links:where(.astro-aid3sr62){margin-top:.5rem;display:flex;flex-wrap:wrap;gap:.375rem}.btn:where(.astro-aid3sr62){display:inline-block;border-radius:.375rem;border-width:1px;--tw-border-opacity: 1;border-color:rgba(var(--color-border),var(--tw-border-opacity, 1));padding:.25rem .625rem;font-size:.75rem;line-height:1rem;font-weight:500;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}@media (min-width: 640px){.btn:where(.astro-aid3sr62){padding:.375rem .75rem;font-size:.875rem;line-height:1.25rem}}.btn:where(.astro-aid3sr62):hover{--tw-text-opacity: 1;color:rgba(var(--color-accent),var(--tw-text-opacity, 1));border-color:rgb(var(--color-accent))}.btn:where(.astro-aid3sr62).primary{--tw-text-opacity: 1;color:rgba(var(--color-fill),var(--tw-text-opacity, 1));background-color:rgb(var(--color-accent));border-color:rgb(var(--color-accent))}.btn:where(.astro-aid3sr62).primary:hover{--tw-text-opacity: 1;color:rgba(var(--color-fill),var(--tw-text-opacity, 1));opacity:.9}body.modal-open{overflow:hidden}body.modal-open header{opacity:0;pointer-events:none}.modal[hidden]{display:none}.modal{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;pointer-events:none;transition:opacity .22s ease}.modal[data-open=true]{opacity:1;pointer-events:auto}.modal-backdrop{position:absolute;inset:0;z-index:0;background:#080c18c7;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.modal-shell{position:relative;z-index:1;width:min(640px,100%);max-height:calc(100vh - 32px);transform:translateY(8px) scale(.985);transition:transform .24s ease}.modal[data-open=true] .modal-shell{transform:translateY(0) scale(1)}.modal-panel{width:100%;max-height:calc(100vh - 32px);overflow-y:auto;background:rgb(var(--color-card));border:1px solid rgb(var(--color-border));border-radius:12px;box-shadow:0 20px 60px #00000059;display:flex;flex-direction:column}.modal-close{position:absolute;top:8px;right:8px;z-index:5;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:999px;background:#070a12d6;color:#fff;border:1px solid rgba(255,255,255,.24);box-shadow:0 8px 22px #00000047;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);cursor:pointer;transition:background .15s ease,border-color .15s ease}.modal-close:hover{background:#070a12f5;border-color:#ffffff6b}.modal-video-wrap{width:100%;background:#000;border-top-left-radius:12px;border-top-right-radius:12px;overflow:hidden;aspect-ratio:1 / 1;max-height:70vh;flex-shrink:0}.modal-video-wrap video{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;background:#000;display:block}.modal-body{padding:18px 20px 22px}.modal-title{font-size:1.25rem;font-weight:600;margin:0}.modal-platforms{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.modal-platforms .platform-pill{border-radius:999px;border:1px solid rgb(var(--color-border));background:rgb(var(--color-fill) / .3);color:rgb(var(--color-text-base));font-size:.75rem;font-weight:500;line-height:1;padding:5px 9px}.modal-subtitle{margin-top:4px;font-size:.875rem;opacity:.7}.modal-description{margin-top:12px;font-size:.95rem;line-height:1.6}.modal-links{margin-top:16px;display:flex;flex-wrap:wrap;gap:8px}.modal-links .btn{display:inline-block;border-radius:6px;border:1px solid rgb(var(--color-border));padding:6px 12px;font-size:.875rem;font-weight:500;transition:color .15s ease,background .15s ease,border-color .15s ease;text-decoration:none;color:rgb(var(--color-text-base))}.modal-links .btn:hover{color:rgb(var(--color-accent));border-color:rgb(var(--color-accent))}.modal-links .btn.primary{color:rgb(var(--color-fill));background-color:rgb(var(--color-accent));border-color:rgb(var(--color-accent))}.modal-links .btn.primary:hover{opacity:.9;color:rgb(var(--color-fill))}@media (max-width: 640px){.modal{padding:0}.modal-shell{width:100%;max-height:100vh;height:100vh}.modal-panel{max-height:100vh;height:100vh;border-radius:0;border:0}.modal-close{top:calc(env(safe-area-inset-top,0px) + 10px);right:calc(env(safe-area-inset-right,0px) + 10px)}.modal-video-wrap{border-radius:0}.modal-body{flex:1;overflow-y:auto}}
