@font-face{font-family:Space Grotesk;font-style:normal;font-weight:400 700;font-display:swap;src:url(/fonts/space-grotesk-latin-ext.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:400 700;font-display:swap;src:url(/fonts/space-grotesk-latin.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Doto;font-style:normal;font-weight:400 700;font-display:swap;src:url(/fonts/doto-latin-ext.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Doto;font-style:normal;font-weight:400 700;font-display:swap;src:url(/fonts/doto-latin.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{line-height:1.5;overflow-x:hidden}img,picture,video,canvas,svg{max-width:100%;display:block}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}button{cursor:pointer;background:0 0;border:none}a{color:inherit;text-decoration:none}#root{isolation:isolate;width:100%;height:100%}:root{--color-bg-primary:#0a0a0a;--color-bg-secondary:#111;--color-bg-elevated:#1a1a1a;--color-bg-overlay:#0a0a0af2;--color-text-primary:#fff;--color-text-secondary:#a0a0a0;--color-text-tertiary:#666;--color-accent-1:#ff6b6b;--color-accent-2:#4ecdc4;--color-accent-3:#ffe66d;--color-border:#2a2a2a;--color-border-hover:#3a3a3a;--font-display:"Space Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-pixel:"Doto", monospace;--font-system:-apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"SF Mono", "Consolas", "Monaco", monospace;--font-okay:"Okay", var(--font-display);--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--text-5xl:3rem;--text-6xl:3.75rem;--text-7xl:4.5rem;--text-8xl:6rem;--spacing-1:4px;--spacing-2:8px;--spacing-3:12px;--spacing-4:16px;--spacing-5:20px;--spacing-6:24px;--spacing-8:32px;--spacing-10:40px;--spacing-12:48px;--spacing-16:64px;--spacing-20:80px;--spacing-24:96px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-smooth:.3s cubic-bezier(.4, 0, .2, 1);--transition-slow:.5s cubic-bezier(.4, 0, .2, 1);--shadow-sm-dark:0 1px 2px #00000080;--shadow-md-dark:0 4px 6px #00000080;--shadow-lg-dark:0 10px 15px #0009;--shadow-xl-dark:0 20px 25px #000000b3;--shadow-sm-light:0 1px 2px #00000014;--shadow-md-light:0 4px 6px #0000001a;--shadow-lg-light:0 10px 15px #0000001f;--shadow-xl-light:0 20px 25px #00000026;--shadow-sm:var(--shadow-sm-dark);--shadow-md:var(--shadow-md-dark);--shadow-lg:var(--shadow-lg-dark);--shadow-xl:var(--shadow-xl-dark);--z-base:0;--z-dropdown:100;--z-sticky:200;--z-overlay:300;--z-modal:400;--z-toast:500;--z-article-toc:100;--z-article-media:200}.demo-article{--art-font-headings:var(--font-display);--art-font-body:var(--font-system);--art-font-ui:var(--font-mono);--art-lh-headings:1.2;--art-lh-body:1.75;--art-shadow-sm:var(--shadow-sm);--art-shadow-md:var(--shadow-md);--art-shadow-lg:var(--shadow-lg);--art-shadow-xl:var(--shadow-xl);--art-accent:var(--color-accent-1)}.demo-article{--col-content:min(65ch, 100%);--col-margin-note:16rem;--col-margin-gap:var(--spacing-8);max-width:1440px;padding-inline:max(1rem, env(safe-area-inset-left));grid-template-columns:[full-start wide-start] minmax(clamp(1rem, 6vw, 6rem), 1fr) [content-start] var(--col-content) [content-end] minmax(clamp(1rem, 6vw, 6rem), 1fr) [wide-end full-end];justify-content:center;margin-inline:auto;display:grid}@media (width>=900px){.demo-article{grid-template-columns:[full-start] minmax(clamp(1rem, 6vw, 6rem), 1fr) [wide-start] minmax(clamp(.5rem, 2vw, 2rem), 1fr) [content-start] var(--col-content) [content-end] var(--col-margin-gap) [note-start] var(--col-margin-note) [note-end wide-end] minmax(clamp(1rem, 6vw, 6rem), 1fr) [full-end]}}.demo-article>*{grid-column:content}.demo-article>.wide{z-index:var(--z-article-media);grid-column:wide;position:relative}.demo-article>.full{margin-inline:calc(-1 * max(1rem, env(safe-area-inset-left)));z-index:var(--z-article-media);grid-column:full;position:relative}.demo-article h1,.demo-article .as-h1,.demo-article h2,.demo-article .as-h2,.demo-article h3,.demo-article .as-h3,.demo-article h4,.demo-article .as-h4,.demo-article h5,.demo-article .as-h5,.demo-article h6,.demo-article .as-h6{font-family:var(--art-font-headings);line-height:var(--art-lh-headings)}.demo-article h1,.demo-article .as-h1{margin-block:var(--spacing-16) var(--spacing-6)}.demo-article h2,.demo-article .as-h2{margin-block:var(--spacing-12) var(--spacing-4)}.demo-article h3,.demo-article .as-h3{margin-block:var(--spacing-8) var(--spacing-3)}.demo-article p{font-family:var(--art-font-body);line-height:var(--art-lh-body);color:var(--color-text-secondary);margin-block-end:var(--spacing-6)}.demo-article p+p{margin-block-start:0}.demo-article ol,.demo-article ul{gap:var(--spacing-2);flex-direction:column;margin-block-end:var(--spacing-6);padding-inline-start:1.5em;display:flex}.demo-article li{font-family:var(--art-font-body);line-height:var(--art-lh-body);color:var(--color-text-secondary)}.demo-article a{color:var(--color-accent-2);text-underline-offset:3px;transition:text-decoration-color var(--transition-fast);-webkit-text-decoration:underline #0000;text-decoration:underline #0000}.demo-article a:hover{-webkit-text-decoration-color:var(--color-accent-2);text-decoration-color:var(--color-accent-2)}.demo-article code{font-family:var(--art-font-ui);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:.1em .35em;font-size:.875em}.demo-article>aside{font-size:var(--text-sm);color:var(--color-text-tertiary);border-inline-start:1px solid var(--color-border);padding-inline:var(--spacing-4);padding-block:var(--spacing-4);margin-block:var(--spacing-2) var(--spacing-8);line-height:1.7;font-family:var(--art-font-ui);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.demo-article>aside a{color:var(--color-accent-2);text-underline-offset:3px;transition:text-decoration-color var(--transition-fast);-webkit-text-decoration:underline #0000;text-decoration:underline #0000}.demo-article>aside a:hover{-webkit-text-decoration-color:var(--color-accent-2);text-decoration-color:var(--color-accent-2)}@media (width>=900px){.demo-article>aside{grid-column:note;align-self:start;margin-block-start:0;margin-block-end:var(--spacing-2)}}.demo-article>hr{border:none;border-block-start:1px solid var(--color-border);margin-block:var(--spacing-12)}.demo-article input{accent-color:var(--color-text-primary)}.article-toc{display:none}@media (width>=900px){.article-toc{top:var(--spacing-8);z-index:var(--z-article-toc);border-inline-start:1px solid var(--color-border);-webkit-backdrop-filter:none;backdrop-filter:none;grid-column:note;align-self:start;margin-block-start:0;margin-block-end:var(--spacing-2);padding-block:0;padding-inline-start:var(--spacing-4);display:block;position:sticky}}.article-toc .article-toc__heading{font-family:var(--art-font-ui);font-size:var(--text-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-tertiary);margin:0 0 var(--spacing-3);font-weight:700}.article-toc .article-toc__list{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.article-toc .article-toc__link{font-family:var(--art-font-ui);font-size:var(--text-xs);color:var(--color-text-tertiary);padding:3px var(--spacing-3);border-radius:var(--radius-sm);transition:color var(--transition-fast), border-color var(--transition-fast), background-color var(--transition-fast);border-inline-start:2px solid #0000;line-height:1.6;text-decoration:none;display:block}.article-toc .article-toc__link:hover{color:var(--color-text-primary);background-color:#80808014}.article-toc .article-toc__link--active{color:var(--color-text-primary);border-inline-start-color:var(--art-accent);font-weight:600}.media-frame{--aspect:16 / 9;gap:var(--spacing-3);margin-block:var(--spacing-8);flex-direction:column;max-width:100%;display:flex}.media-frame .media-frame__scene{aspect-ratio:var(--aspect);border-radius:var(--radius-lg);background:var(--color-bg-secondary);transition:box-shadow var(--transition-smooth);position:relative;overflow:hidden}.media-frame:not(:has(.media-frame__scene))>:not(figcaption){aspect-ratio:var(--aspect);border-radius:var(--radius-lg);background:var(--color-bg-secondary);transition:box-shadow var(--transition-smooth);position:relative;overflow:hidden}.media-frame:not(:has(.media-frame__scene))>:not(figcaption):hover{box-shadow:var(--art-shadow-md)}.media-frame:not(:has(.media-frame__scene))>:not(figcaption)>*,.media-frame:not(:has(.media-frame__scene))>:not(figcaption) canvas{position:absolute;inset:0;width:100%!important;height:100%!important}.media-frame .media-frame__scene:hover{box-shadow:var(--art-shadow-md)}.media-frame .media-frame__scene>*,.media-frame .media-frame__scene canvas{position:absolute;inset:0;width:100%!important;height:100%!important}.media-frame.media-frame--square{--aspect:1 / 1}.media-frame.media-frame--tall{--aspect:4 / 3}.media-frame.media-frame--cinema{--aspect:21 / 9}.media-frame.media-frame--portrait{--aspect:3 / 4}.media-frame figcaption{font-family:var(--art-font-ui);font-size:var(--text-xs);color:var(--color-text-tertiary);padding-inline:var(--spacing-1);line-height:1.6}figure:not(.media-frame){margin:0;margin-block:var(--spacing-8);gap:var(--spacing-3);flex-direction:column;display:flex}figure:not(.media-frame) figcaption{font-family:var(--art-font-ui);font-size:var(--text-xs);color:var(--color-text-tertiary);border-block-start:1px solid var(--color-border);padding-block-start:var(--spacing-3);line-height:1.6}.demo-hero{width:100%;height:75svh;position:relative}.demo-hero canvas{position:absolute;inset:0;width:100%!important;height:100%!important}.demo-hero:after{content:"";pointer-events:none;background:linear-gradient(to top, var(--art-bg,var(--color-bg-primary)), transparent);height:40%;position:absolute;inset-block-end:0;inset-inline:0}body{font-family:var(--font-system);font-size:var(--text-base);color:var(--color-text-primary);background-color:var(--color-bg-primary)}h1,h2,h3,h4,h5,h6,.as-h1,.as-h2,.as-h3,.as-h4,.as-h5,.as-h6{font-family:var(--font-display);font-weight:600;line-height:1.2}h1,.as-h1{font-size:var(--text-6xl);letter-spacing:-.02em;font-weight:700}h2,.as-h2{font-size:var(--text-4xl);letter-spacing:-.01em;font-weight:600}h3,.as-h3{font-size:var(--text-2xl);font-weight:600}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.fade-in{animation:fadeIn var(--transition-smooth) ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-out{animation:fadeOut var(--transition-smooth) ease-out}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-primary)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-border-hover)}html:has(.demo-container.light){scrollbar-color:#0000002e #ebebeb}html:has(.demo-container.light)::-webkit-scrollbar-track{background:#ebebeb}html:has(.demo-container.light)::-webkit-scrollbar-thumb{background:#0000002e}html:has(.demo-container.light)::-webkit-scrollbar-thumb:hover{background:#00000052}::selection{background-color:var(--color-accent-2);color:var(--color-bg-primary)}.demo-container{width:100%;height:100dvh;animation:.2s ease-out both demo-appear;position:relative;overflow:hidden}@keyframes demo-appear{0%{opacity:0}to{opacity:1}}.demo-error{background:var(--color-bg,#0a0a0a);color:var(--color-text,#e8e8e8);flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:2rem;display:flex;position:absolute;inset:0}.demo-error__label{letter-spacing:.14em;text-transform:uppercase;opacity:.35;margin:0;font-size:.7rem}.demo-error__message{font-family:var(--font-mono);color:#ff6b6b;text-align:center;word-break:break-word;background:#ff646412;border:1px solid #ff64642e;border-radius:6px;max-width:520px;margin:0;padding:.65rem 1.1rem;font-size:clamp(.8rem,1.8vw,.95rem)}.demo-error__stack{color:#666;white-space:pre-wrap;word-break:break-all;text-align:left;background:#111;border:1px solid #1e1e1e;border-radius:6px;max-width:680px;max-height:220px;margin:0;padding:.85rem 1rem;font-size:.68rem;overflow:auto}.demo-error__actions{flex-wrap:wrap;justify-content:center;gap:.5rem;display:flex}.demo-error-button{color:#e8e8e899;letter-spacing:.06em;cursor:pointer;background:0 0;border:1px solid #2a2a2a;border-radius:5px;margin-top:.25rem;padding:.4rem 1.1rem;font-size:.78rem;transition:border-color .15s,color .15s}.demo-error-button:hover{color:#e8e8e8;border-color:#444}.nav-overlay{padding:var(--spacing-6) var(--spacing-8);background:linear-gradient(180deg, var(--color-bg-overlay) 0%, transparent 100%);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:var(--z-overlay);opacity:0;pointer-events:none;transition:opacity var(--transition-smooth);justify-content:space-between;align-items:center;display:flex;position:fixed;top:0;left:0;right:0;-webkit-mask:linear-gradient(#fff 70%,#0000 100%);mask:linear-gradient(#fff 70%,#0000 100%)}.demo-container.light .nav-overlay{background-color:#fff3;-webkit-mask:none;mask:none}.demo-container.light .nav-overlay .nav-title{color:var(--color-text-primary)}.nav-overlay.visible{opacity:1;pointer-events:all}.nav-back{align-items:center;gap:var(--spacing-2);color:var(--color-text-secondary);font-family:var(--font-system);font-size:var(--text-sm);padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-sm);transition:all var(--transition-fast);border:1px solid #0000;display:flex}.nav-back:hover{color:var(--color-text-primary);background-color:var(--color-bg-elevated);border-color:var(--color-border)}.nav-back svg{transition:transform var(--transition-fast)}.nav-back:hover svg{transform:translate(-2px)}.nav-title{font-family:var(--font-display);font-size:var(--text-lg);color:var(--color-text-primary);white-space:nowrap;font-weight:600;position:absolute;left:50%;transform:translate(-50%)}.nav-arrows{align-items:center;gap:var(--spacing-2);display:flex}.nav-arrow{color:var(--color-text-secondary);padding:var(--spacing-2);border-radius:var(--radius-sm);transition:all var(--transition-fast);border:1px solid #0000;justify-content:center;align-items:center;display:flex}.nav-arrow:not(.nav-arrow-disabled):hover{color:var(--color-text-primary);background-color:var(--color-bg-elevated);border-color:var(--color-border)}.nav-arrow.nav-arrow-disabled{opacity:.25;cursor:default}.nav-counter{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-tertiary);text-align:center;min-width:2.5rem}.nav-mobile-buttons{pointer-events:none;gap:var(--spacing-2);top:var(--spacing-4);right:var(--spacing-4);z-index:var(--z-overlay);display:flex;position:fixed}.nav-mobile-back-pill{align-items:center;gap:var(--spacing-1);padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-full);-webkit-backdrop-filter:blur(12px);color:#ffffffb3;font-family:var(--font-system);font-size:var(--text-sm);cursor:pointer;opacity:0;pointer-events:none;background:#0a0a0a99;border:1px solid #ffffff1a;transition:opacity .3s cubic-bezier(.4,0,.2,1),transform .3s cubic-bezier(.4,0,.2,1);display:flex;transform:translateY(-4px);box-shadow:0 2px 12px #00000059}.nav-mobile-back-pill--visible{opacity:1;pointer-events:auto;transform:translateY(0)}.nav-mobile-back-pill:active{color:var(--color-text-primary);background:#1e1e1ed9}@media (width<=768px){.nav-overlay{padding:var(--spacing-4)}.nav-title{font-size:var(--text-base)}.nav-counter{display:none}}.dev-layout{background:var(--color-bg-primary);min-height:100dvh;color:var(--color-text-primary);font-family:var(--font-sans)}.dev-layout button{font-family:var(--font-mono);background-color:var(--color-bg-secondary);color:var(--color-text-secondary);cursor:pointer;border:none;border-radius:3px;padding:.5rem 1rem;transition:background-color .15s,color .15s}.dev-layout button:hover{background-color:var(--color-bg-primary);color:var(--color-accent-2)}.dev-layout button:active{background-color:var(--color-accent-1);color:var(--color-bg-primary)}.dev-layout button:disabled{background-color:var(--color-bg-secondary);color:var(--color-text-secondary);cursor:not-allowed}.dev-nav{border-bottom:1px solid var(--color-border);flex-wrap:wrap;align-items:center;gap:1.5rem;padding:1rem 1.5rem;font-size:.8rem;display:flex}.dev-nav__label{letter-spacing:.12em;text-transform:uppercase;color:var(--color-accent-3);font-size:1.3rem;font-family:var(--font-pixel);margin-right:.5rem}.dev-nav__link{color:var(--color-text-secondary);text-transform:uppercase;text-decoration:none;transition:color .15s}.dev-nav__link:before{content:"🡾";content:"🞴";content:"🞴";content:"☲";color:currentColor;opacity:.5;margin-right:.25rem}.dev-nav__link:hover,.dev-nav__link--active{color:var(--color-text-primary)}:is(.dev-nav__link:hover,.dev-nav__link--active):before{opacity:1}.dev-nav__link--home{color:var(--color-accent-2);font-family:var(--font-pixel);margin-left:auto}.dev-nav__link--home:before{display:none}.dev-main{max-width:900px;padding:2rem 5vw}.dev-main.dev-pixel-edit{max-width:none}.dev-main:has(.demo-article){max-width:none}.dev-section{margin-bottom:2.5rem}.dev-section__heading{letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-primary);font-family:var(--font-pixel);margin:0 0 3rem}.dev-section__title{letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-secondary);font-family:var(--font-pixel);margin:3rem 0 1rem}h2.dev-section__title{margin:5rem 0 1rem}h3.dev-section__title{margin:4rem 0 rem 0;color:var(--color-accent-1)}h4.dev-section__title{margin-top:1rem}.dev-link-list{font-family:var(--font-mono);flex-direction:column;gap:.4rem;margin:0;padding:0;list-style:none;display:flex}.dev-link-list a{color:var(--color-accent-2);background-color:var(--color-bg-secondary);border-radius:3px;padding:.25rem .5rem;font-size:.9rem;text-decoration:none}.dev-link-list a:after{content:"↗";opacity:.5;margin-left:.5em;padding:.1em}.dev-link-list a:hover{background-color:var(--color-accent-2);color:var(--color-bg-secondary);text-decoration:underline}.dev-link-list__note{color:var(--color-text-tertiary);margin-left:.5rem;font-size:.75rem}.stats-tiles{flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem;display:flex}.stats-tile{background:var(--color-bg-secondary);border-radius:4px;flex-direction:column;flex:auto;gap:.3rem;min-width:8.3em;padding:.75rem 1rem;display:flex}.stats-tile:not(:has(svg)){padding-bottom:2rem}.stats-tile__label{text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-tertiary);font-size:.7rem}.stats-tile__value{color:var(--stats-tile-color,var(--color-text-primary));font-size:1.75rem;font-weight:700;line-height:1}.stats-tile--good{--stats-tile-color:var(--color-accent-2)}.stats-tile--ok{--stats-tile-color:var(--color-accent-3)}.stats-tile--bad{--stats-tile-color:var(--color-accent-1)}.stats-meta{color:var(--color-text-tertiary);margin-top:.5rem;font-size:.75rem}.stats-notice{background:var(--color-bg-secondary);color:var(--color-text-secondary);border-radius:4px;padding:1rem 1.25rem;font-size:.85rem;line-height:1.6}.stats-table-label{text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-tertiary);margin-bottom:.5rem}.stats-table-group{margin-bottom:2rem}.stats-table-wrap{overflow-x:auto}.stats-table-wrap--spaced{margin-bottom:2rem}.stats-table{border-collapse:collapse;table-layout:fixed;width:100%;font-size:.82rem;font-family:var(--font-mono)}.stats-table th{text-align:left;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-tertiary);border-bottom:1px solid var(--color-border);white-space:nowrap;padding:.35rem .75rem;font-size:.7rem}.stats-table th.num,.stats-table td.num{text-align:right}.stats-table td{border-bottom:1px solid var(--color-border);color:var(--color-text-secondary);padding:.35rem .75rem}.stats-table td.num{color:var(--color-text-primary)}.stats-page-link{color:var(--color-accent-2);text-decoration:none}.stats-page-link:hover{text-decoration:underline}.stats-error{color:var(--color-accent-1);background:var(--color-bg-secondary);border-radius:4px;padding:.75rem 1rem;font-size:.85rem}.gallery{min-height:100dvh;padding:var(--spacing-16) var(--spacing-8);justify-content:center;align-items:center;gap:var(--spacing-16);background:radial-gradient(circle at top,#e1fff508 0%,#fff0 100%);flex-direction:column;display:flex}.gallery-header{text-align:center;max-width:800px}.gallery-title{font-size:var(--text-8xl);letter-spacing:-.03em;margin-bottom:var(--spacing-4);background:linear-gradient(115deg, white 0%, var(--color-text-secondary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:700}.gallery-subtitle{font-size:var(--text-lg);color:var(--color-text-secondary);font-family:var(--font-display)}.gallery-grid{gap:var(--spacing-6);grid-template-columns:repeat(auto-fit,minmax(400px,1fr));width:100%;max-width:1200px;display:grid}.gallery-grid--in-progress{opacity:.8}.gallery-section-divider{align-items:center;gap:var(--spacing-4);width:100%;max-width:1200px;color:var(--color-text-tertiary);font-size:var(--text-xs);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;display:flex}.gallery-section-divider:before,.gallery-section-divider:after{content:"";background-image:linear-gradient(to right, transparent, var(--color-border), transparent);flex:1;height:1px}.demo-card{border-radius:var(--radius-lg);padding:var(--spacing-8);transition:all var(--transition-smooth);flex-direction:column;display:flex;position:relative;overflow:hidden}.demo-card:before{content:"";opacity:0;transition:opacity var(--transition-smooth);pointer-events:none;background:linear-gradient(135deg,#0000 0%,#ffffff08 100%);position:absolute;inset:0}.demo-card:hover,.demo-card:focus-within{border-color:var(--color-border-hover);box-shadow:var(--shadow-xl);text-decoration:none;transform:translateY(-4px)}:is(.demo-card:hover,.demo-card:focus-within) .demo-card-imgid{transform:scale(1.07)}:is(.demo-card:hover,.demo-card:focus-within) .demo-card-imgid:after{-webkit-backdrop-filter:blur();backdrop-filter:blur();filter:grayscale(0)}.demo-card:hover:before,.demo-card:focus-within:before{opacity:1}.demo-card-imgid{margin:calc(0px - var(--spacing-8));margin-bottom:calc(var(--spacing-8) * -2);transition:all .8s;position:relative;transform:scale(1);-webkit-mask:linear-gradient(#fff,#0000);mask:linear-gradient(#fff,#0000)}.demo-card-imgid:after{content:"";filter:grayscale(.33);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:radial-gradient(ellipse at 0 0, transparent 0%, var(--color-bg-elevated) 80%);transition:all .3s;position:absolute;inset:0}.demo-card-imgid .demo-card-img{aspect-ratio:6/2}.demo-card-content{gap:var(--spacing-4);z-index:1;flex-direction:column;flex:1;display:flex}.demo-title{font-size:var(--text-4xl);color:var(--color-text-primary);margin-bottom:var(--spacing-2);justify-content:space-between;font-weight:600;display:flex;margin-top:0!important}.demo-description,.demo-long-description{font-size:var(--text-base);color:var(--color-text-secondary);line-height:1.6;font-family:var(--font-system)}.demo-long-description{font-size:var(--text-xs);color:var(--color-text-tertiary);margin-bottom:.4em}.demo-tech{gap:var(--spacing-2);flex-wrap:wrap;margin-top:auto;display:flex}.demo-status{font-size:var(--text-sm);padding:var(--spacing-1) var(--spacing-3);border-radius:var(--radius-sm);text-transform:uppercase;color:var(--color-accent-3);top:var(--spacing-4);right:var(--spacing-4);align-items:center;gap:.35em;font-weight:600;display:inline-flex;position:absolute}.demo-status.demo-status-wip{color:var(--color-accent-2)}.demo-status.demo-status-idea{color:var(--color-accent-1)}.tech-badge{font-size:var(--text-xs);font-family:var(--font-mono);color:var(--color-text-tertiary);padding:var(--spacing-1) var(--spacing-3);border-radius:var(--radius-sm);background-color:#ffffff08}.gallery-filters{align-items:center;gap:var(--spacing-3);flex-direction:column;display:flex}.gallery-filters div{gap:var(--spacing-2);flex-wrap:wrap;justify-content:center;display:flex}.filter-btn{font-family:var(--font-display);font-size:var(--text-xs);padding:var(--spacing-2) var(--spacing-4);border-radius:var(--radius-sm);border:1px solid var(--color-border);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;text-transform:uppercase;color:var(--color-text-primary);background:0 0}.gallery-filters .filter-tag{max-height:calc(var(--spacing-24) * 1.5);max-width:min(90%,50em);-webkit-mask:linear-gradient(to bottom, #0000, #fff var(--top-fade) calc(100% - var(--bottom-fade)), #0000);mask:linear-gradient(to bottom, #0000, #fff var(--top-fade) calc(100% - var(--bottom-fade)), #0000);scroll-timeline:--scrollfade y;animation:scrollfade;animation-timeline:--scrollfade;position:relative;overflow-y:auto}.gallery-filters .filter-tag .filter-btn{font-family:var(--font-mono);text-transform:none;font-size:var(--text-xs);padding:var(--spacing-2);opacity:.6;color:var(--color-text-tertiary)}.filter-btn:hover{color:var(--color-text-secondary);border-color:var(--color-border-hover)}.filter-btn.active{color:var(--color-accent-3);background-color:var(--color-bg-elevated);border-color:var(--color-border-hover)}.no-results{text-align:center}.clear-filters{justify-content:center;align-items:center;display:flex}.clear-filters .filter-btn{font-size:var(--text-xs);opacity:.6}.demo-card.status-wip,.demo-card.status-idea{opacity:.75}:is(.demo-card.status-wip,.demo-card.status-idea):hover{opacity:.85}.demo-card.status-archived{opacity:.25}.demo-card.status-archived:hover{opacity:.5}.gallery-cta{text-align:center;padding-block:var(--spacing-8);width:100%;max-width:1200px;position:relative}.gallery-cta:before{content:"";background-image:linear-gradient(to right, transparent, var(--color-border), transparent);height:1px;position:absolute;top:0;left:0;right:0}.gallery-cta__copy{font-size:var(--text-base);color:var(--color-text-tertiary);font-family:var(--font-display);margin:0}.gallery-cta__link{color:var(--color-text-secondary);border-bottom:1px solid var(--color-border-hover);transition:color var(--transition-fast), border-color var(--transition-fast);text-decoration:none}.gallery-cta__link:hover{color:var(--color-text-primary);border-bottom-color:var(--color-text-primary)}.gallery-footer{text-align:center;margin-top:var(--spacing-4)}.keyboard-hint{font-size:var(--text-sm);color:var(--color-text-tertiary);font-family:var(--font-mono)}.keyboard-hint kbd{padding:var(--spacing-1) var(--spacing-2);background-color:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:var(--text-xs);margin:0 var(--spacing-1);color:var(--color-text-primary);display:inline-block}.gallery-backlink{margin-top:var(--spacing-3);font-size:var(--text-xs);color:var(--color-text-tertiary);font-family:var(--font-mono)}.gallery-backlink a{color:inherit;transition:border-color var(--transition-fast), color var(--transition-fast);border-bottom:1px solid #0000;text-decoration:none}.gallery-backlink a:hover{color:var(--color-text-secondary);border-bottom-color:currentColor}@media (width<=768px){.gallery{padding:var(--spacing-8) var(--spacing-4)}.gallery-title{font-size:var(--text-5xl)}.gallery-grid{gap:var(--spacing-4);grid-template-columns:1fr}.demo-card{min-height:250px}.demo-title{font-size:var(--text-3xl)}}@property --top-fade{syntax:"<length>";inherits:false;initial-value:0}@property --bottom-fade{syntax:"<length>";inherits:false;initial-value:0}@keyframes scrollfade{0%{--top-fade:0}10%,to{--top-fade:3rem}0%,90%{--bottom-fade:3rem}to{--bottom-fade:0}}.demo-container:has(.demo-article):not(.fisheye){--art-bg:var(--color-bg-primary);background-color:var(--color-bg-primary);height:auto;overflow:clip visible}.demo-container.light{--color-bg-primary:#f3f3f3;--color-bg-secondary:#ddd;--color-bg-elevated:#fff;--color-bg-overlay:#e8f4f8f2;--color-text-primary:#1a1a1a;--color-text-secondary:#3a3a3a;--color-text-tertiary:#666;--color-border:#0000001a;--color-border-hover:#00000038;color:var(--color-text-primary);background-color:var(--color-bg-primary)}.demo-container.light .demo-article{--art-shadow-sm:var(--shadow-sm-light);--art-shadow-md:var(--shadow-md-light);--art-shadow-lg:var(--shadow-lg-light);--art-shadow-xl:var(--shadow-xl-light)}.demo-article{--col-content:min(65ch, 100%);--col-margin-note:16rem;--col-margin-gap:var(--spacing-8);max-width:1440px;padding-inline:max(1rem, env(safe-area-inset-left));grid-template-columns:[full-start wide-start] minmax(clamp(1rem, 6vw, 6rem), 1fr) [content-start] var(--col-content) [content-end] minmax(clamp(1rem, 6vw, 6rem), 1fr) [wide-end full-end];justify-content:center;margin-inline:auto;display:grid}@media (width>=900px){.demo-article{grid-template-columns:[full-start] minmax(clamp(1rem, 6vw, 6rem), 1fr) [wide-start] minmax(clamp(.5rem, 2vw, 2rem), 1fr) [content-start] var(--col-content) [content-end] var(--col-margin-gap) [note-start] var(--col-margin-note) [note-end wide-end] minmax(clamp(1rem, 6vw, 6rem), 1fr) [full-end]}}.demo-article>*{grid-column:content}.demo-article>.wide{z-index:var(--z-article-media);grid-column:wide;position:relative}.demo-article>.full{margin-inline:calc(-1 * max(1rem, env(safe-area-inset-left)));z-index:var(--z-article-media);grid-column:full;position:relative}.demo-article h1,.demo-article .as-h1,.demo-article h2,.demo-article .as-h2,.demo-article h3,.demo-article .as-h3,.demo-article h4,.demo-article .as-h4,.demo-article h5,.demo-article .as-h5,.demo-article h6,.demo-article .as-h6{font-family:var(--art-font-headings);line-height:var(--art-lh-headings)}.demo-article h1,.demo-article .as-h1{margin-block:var(--spacing-16) var(--spacing-6)}.demo-article h2,.demo-article .as-h2{margin-block:var(--spacing-12) var(--spacing-4)}.demo-article h3,.demo-article .as-h3{margin-block:var(--spacing-8) var(--spacing-3)}.demo-article p{font-family:var(--art-font-body);line-height:var(--art-lh-body);color:var(--color-text-secondary);margin-block-end:var(--spacing-6)}.demo-article p+p{margin-block-start:0}.demo-article ol,.demo-article ul{gap:var(--spacing-2);flex-direction:column;margin-block-end:var(--spacing-6);padding-inline-start:1.5em;display:flex}.demo-article li{font-family:var(--art-font-body);line-height:var(--art-lh-body);color:var(--color-text-secondary)}.demo-article a{color:var(--color-accent-2);text-underline-offset:3px;transition:text-decoration-color var(--transition-fast);-webkit-text-decoration:underline #0000;text-decoration:underline #0000}.demo-article a:hover{-webkit-text-decoration-color:var(--color-accent-2);text-decoration-color:var(--color-accent-2)}.demo-article code{font-family:var(--art-font-ui);background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:.1em .35em;font-size:.875em}.demo-article>aside{font-size:var(--text-sm);color:var(--color-text-tertiary);border-inline-start:1px solid var(--color-border);padding-inline:var(--spacing-4);padding-block:var(--spacing-4);margin-block:var(--spacing-2) var(--spacing-8);line-height:1.7;font-family:var(--art-font-ui);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.demo-article>aside a{color:var(--color-accent-2);text-underline-offset:3px;transition:text-decoration-color var(--transition-fast);-webkit-text-decoration:underline #0000;text-decoration:underline #0000}.demo-article>aside a:hover{-webkit-text-decoration-color:var(--color-accent-2);text-decoration-color:var(--color-accent-2)}@media (width>=900px){.demo-article>aside{grid-column:note;align-self:start;margin-block-start:0;margin-block-end:var(--spacing-2)}}.demo-article>hr{border:none;border-block-start:1px solid var(--color-border);margin-block:var(--spacing-12)}.demo-article input{accent-color:var(--color-text-primary)}.article-toc{display:none}@media (width>=900px){.article-toc{top:var(--spacing-8);z-index:var(--z-article-toc);border-inline-start:1px solid var(--color-border);-webkit-backdrop-filter:none;backdrop-filter:none;grid-column:note;align-self:start;margin-block-start:0;margin-block-end:var(--spacing-2);padding-block:0;padding-inline-start:var(--spacing-4);display:block;position:sticky}}.article-toc .article-toc__heading{font-family:var(--art-font-ui);font-size:var(--text-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-tertiary);margin:0 0 var(--spacing-3);font-weight:700}.article-toc .article-toc__list{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.article-toc .article-toc__link{font-family:var(--art-font-ui);font-size:var(--text-xs);color:var(--color-text-tertiary);padding:3px var(--spacing-3);border-radius:var(--radius-sm);transition:color var(--transition-fast), border-color var(--transition-fast), background-color var(--transition-fast);border-inline-start:2px solid #0000;line-height:1.6;text-decoration:none;display:block}.article-toc .article-toc__link:hover{color:var(--color-text-primary);background-color:#80808014}.article-toc .article-toc__link--active{color:var(--color-text-primary);border-inline-start-color:var(--art-accent);font-weight:600}.media-frame{--aspect:16 / 9;gap:var(--spacing-3);margin-block:var(--spacing-8);flex-direction:column;max-width:100%;display:flex}.media-frame .media-frame__scene{aspect-ratio:var(--aspect);border-radius:var(--radius-lg);background:var(--color-bg-secondary);transition:box-shadow var(--transition-smooth);position:relative;overflow:hidden}.media-frame:not(:has(.media-frame__scene))>:not(figcaption){aspect-ratio:var(--aspect);border-radius:var(--radius-lg);background:var(--color-bg-secondary);transition:box-shadow var(--transition-smooth);position:relative;overflow:hidden}.media-frame:not(:has(.media-frame__scene))>:not(figcaption):hover{box-shadow:var(--art-shadow-md)}.media-frame:not(:has(.media-frame__scene))>:not(figcaption)>*,.media-frame:not(:has(.media-frame__scene))>:not(figcaption) canvas{position:absolute;inset:0;width:100%!important;height:100%!important}.media-frame .media-frame__scene:hover{box-shadow:var(--art-shadow-md)}.media-frame .media-frame__scene>*,.media-frame .media-frame__scene canvas{position:absolute;inset:0;width:100%!important;height:100%!important}.media-frame.media-frame--square{--aspect:1 / 1}.media-frame.media-frame--tall{--aspect:4 / 3}.media-frame.media-frame--cinema{--aspect:21 / 9}.media-frame.media-frame--portrait{--aspect:3 / 4}.media-frame figcaption{font-family:var(--art-font-ui);font-size:var(--text-xs);color:var(--color-text-tertiary);padding-inline:var(--spacing-1);line-height:1.6}figure:not(.media-frame){margin:0;margin-block:var(--spacing-8);gap:var(--spacing-3);flex-direction:column;display:flex}figure:not(.media-frame) figcaption{font-family:var(--art-font-ui);font-size:var(--text-xs);color:var(--color-text-tertiary);border-block-start:1px solid var(--color-border);padding-block-start:var(--spacing-3);line-height:1.6}.demo-hero{width:100%;height:75svh;position:relative}.demo-hero canvas{position:absolute;inset:0;width:100%!important;height:100%!important}.demo-hero:after{content:"";pointer-events:none;background:linear-gradient(to top, var(--art-bg,var(--color-bg-primary)), transparent);height:40%;position:absolute;inset-block-end:0;inset-inline:0}.demo-hero--content{padding-block-start:clamp(5rem,14svh,9rem);padding-block-end:clamp(var(--spacing-6), 5svh, var(--spacing-12));padding-inline:max(var(--spacing-6), env(safe-area-inset-left), calc((100% - 72rem) / 2));flex-direction:column;justify-content:flex-end;align-items:flex-start;display:flex}.notfound{min-height:100dvh;padding:var(--spacing-8);justify-content:center;align-items:center;display:flex}.notfound-inner{text-align:center;align-items:center;gap:var(--spacing-4);flex-direction:column;display:flex}.notfound-code{font-family:var(--font-mono);font-size:var(--text-7xl);letter-spacing:-.04em;color:var(--color-border-hover);font-weight:700;line-height:1}.notfound-title{font-size:var(--text-4xl);letter-spacing:-.02em;color:var(--color-text-primary);margin:0;font-weight:700}.notfound-body{font-family:var(--font-system);font-size:var(--text-base);color:var(--color-text-tertiary);margin:0}.notfound-link{margin-top:var(--spacing-4);font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);transition:color var(--transition-fast), border-color var(--transition-fast);padding-bottom:2px;text-decoration:none}.notfound-link:hover{color:var(--color-text-primary);border-color:var(--color-text-primary)}
