@import "https://fonts.googleapis.com/css2?family=Caveat:wght@500;700&display=swap";:root{--line-height-body:1.65;--line-height-relaxed:1.7;--line-height-tight:1.35;--type-body:clamp(1rem, .65vw + .875rem, 1.125rem);--type-body-sm:clamp(.8125rem, .2vw + .75rem, .875rem);--type-page-title:clamp(1.625rem, 2.5vw + 1rem, 2.25rem);--type-section-title:clamp(1.375rem, 1.75vw + .875rem, 2rem);--type-card-title:clamp(1.125rem, 1.25vw + .875rem, 1.75rem);--type-hero-tagline:clamp(1.375rem, 4.5vw + .5rem, 2.625rem);--type-hero-greeting:clamp(1.0625rem, 2vw + .75rem, 1.75rem);--type-company-name:clamp(1.25rem, 2.5vw + .5rem, 1.75rem)}@font-face{font-family:Inter;src:url(/assets/InterVariable-DEKF4JyX.ttf)format("truetype");font-weight:100 900;font-display:swap;font-style:normal;font-feature-settings:"dlig" 1, "calt" 1, "ordn" 1, "salt" 1, "ss01" 1, "ss02" 1, "ss03" 1, "ss04" 1, "cv13" 1, "tnum" 1}h1,h2{font-family:"IBM Plex Serif", var(--serif)}:root{--sans:"Inter", system-ui, -apple-system, sans-serif;--serif:"IBM Plex Serif", Georgia, serif;--bg:#fff;--text-main:#111;--text-muted:#666;--text-light:#999;--border:#eaeaea;--divider-color:#f2f2f2;--sidebar-bg:#fdfdfd;--window-bg:#f9f9f9;--code-bg:#f5f5f5;--note-bg:#fffceb;--accent-blue:#2e6ff2;--accent-blue-bg:#eef3fe;--accent-purple:#7a3ee8;--accent-purple-bg:#f4ecfe;--pill-1:#ec4899;--pill-2:#10b981;--pill-3:#8b5cf6;--pill-4:#38bdf8;--button-color:#491cff;--button-color-hover:#2900cf;--btn-secondary-surface:#f5f7fa;--btn-secondary-text:#111;--faq-item-bg:#f9f9f9;--faq-item-hover:#f3f3f3;--polaroid-bg:#fff;--polaroid-caption:#111;--polaroid-link:#333;--polaroid-photo-bg:#e0e0e0;--polaroid-shadow:0 .625rem 1.875rem #0000001a, 0 .125rem .5rem #0000000f;--polaroid-shadow-hover:0 1.25rem 2.5rem #0003, 0 .5rem 1rem #0000001a;--shadow-sm:0 1px .125rem #0000000d;--shadow-md:0 .25rem .75rem #00000014;--shadow-lg:0 .75rem 1.5rem #0000001f;--radius-sm:.25rem;--radius:.5rem;--radius-md:.75rem;--radius-lg:1rem;--radius-xl:1.25rem;--radius-pill:999px;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-14:3.5rem;--space-16:4rem;--space-20:5rem;--band-bg:linear-gradient(180deg, #f7f5ff 80%, #fff 100%);--band-stroke:linear-gradient(90deg, var(--bg) 10%, #491cff7a 50%, var(--bg) 90%);--testimonials-text:var(--text-main);--testimonials-text-muted:var(--text-muted);--sidebar-w:200px;--content-main-max:1024px;--content-main-width:min(1024px, 84vw);--content-home-max:1024px;--content-home-width:min(1024px, 90vw);--content-shell-width:calc(var(--content-home-width) + var(--content-x-padding) * 2);--content-about-width:960px;--content-gallery-max:1440px;--content-gallery-width:min(1440px, 94vw);--content-project-prose-width:calc(1120px * .6);--content-aside-width:0px;--page-media-max-width:1600px;--content-top-offset:40px;--content-x-padding:48px;--nav-pill-bg:#fff;--nav-pill-shadow:0 .25rem .75rem #0000000f, 0 .0625rem .1875rem #0000000a;--nav-pill-shadow-hover:0 .375rem 1rem #00000014, 0 .125rem .25rem #0000000d}:root[data-theme=dark],.page-lower-zone[data-theme=dark],.top-nav[data-theme=dark]{--bg:#222120;--text-main:#dfddd9;--text-muted:#9a9895;--text-light:#706f6e;--border:#333230;--divider-color:#2e2d2b;--sidebar-bg:#222120;--window-bg:#282725;--code-bg:#2a2927;--note-bg:#ffeb3b0d;--accent-blue:#6b9cff;--accent-blue-bg:#2e6ff226;--accent-purple:#a78bfa;--accent-purple-bg:#7a3ee826;--button-color:#e67300;--button-color-hover:#d97706;--btn-secondary-surface:#262523;--btn-secondary-text:#f3f2ef;--faq-item-bg:#2a2927;--faq-item-hover:#333230;--polaroid-bg:#e8e8e8;--polaroid-caption:#1a1a1a;--polaroid-link:#2a2a2a;--polaroid-photo-bg:#d4d4d4;--polaroid-shadow:0 .625rem 1.875rem #00000059, 0 .125rem .5rem #0003;--polaroid-shadow-hover:0 1.25rem 2.5rem #00000073, 0 .5rem 1rem #00000040;--band-bg:linear-gradient(180deg, #2a2838 80%, var(--bg) 100%);--band-stroke:linear-gradient(90deg, var(--bg) 10%, #7a3ee873 50%, var(--bg) 90%);--nav-pill-bg:#2e2d2b;--nav-pill-shadow:0 .25rem .75rem #00000047, 0 .0625rem .1875rem #0000002e;--nav-pill-shadow-hover:0 .375rem 1rem #00000059, 0 .125rem .25rem #0003}*{box-sizing:border-box}body{font-family:var(--sans);background:var(--bg);color:var(--text-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0}#root{flex-direction:column;width:100%;min-height:100vh;display:flex}.main-layout{flex-direction:column;flex:1;justify-content:flex-start;align-items:center;width:100%;display:flex}.page-wrapper{width:100%;max-width:var(--content-main-width);flex-direction:column;flex:none;min-width:0;margin-inline:auto;display:flex}.page-content-wrapper{flex-direction:column;align-items:stretch;width:100%;display:flex}:is(.page-wrapper:has(.main-content--wide),.page-wrapper:has(.main-content--home)){max-width:var(--content-shell-width)}.page-wrapper:has(.project-page-layout--gallery){max-width:var(--content-gallery-width)}.page-wrapper:has(.project-page-aside){max-width:calc(var(--content-main-width) + var(--sidebar-w))}.page-media-grid-section{box-sizing:border-box;width:100%;max-width:100%;margin-left:0;margin-right:0;padding:0 0 3rem}.page-media-grid{column-count:1;column-gap:1rem}@media (width>=769px){.page-media-grid-section--cols-2 .page-media-grid{column-count:2}}.page-media-grid__item{break-inside:avoid;vertical-align:top;width:100%;margin-bottom:1rem;display:inline-block}.page-media-grid__item .media-card{height:auto}.project-page-layout--compact-aside{align-items:flex-start}.project-page-layout--compact-aside .toc-sidebar{align-self:flex-start;min-height:0;max-height:calc(100vh - 3rem);height:auto!important}.main-content--wide,.main-content--home{flex:auto;width:100%;max-width:100%;padding-inline:0}.main-content{width:100%;max-width:100%;padding:var(--content-top-offset) var(--content-x-padding) 3rem;box-sizing:border-box;flex:auto}.project-page-layout{width:100%;max-width:100%;margin-inline:auto;display:flex}.project-page-layout:has(.project-page-aside){max-width:100%}.page-header{margin-bottom:1.5rem}.page-title{font-family:var(--serif);font-size:var(--type-page-title);letter-spacing:-.02em;color:var(--text-main);max-width:30ch;margin:0 0 1rem;font-weight:500;line-height:1.2}.page-description{font-size:var(--type-body);color:var(--text-main);opacity:.9;line-height:var(--line-height-body);max-width:65ch;margin:0 0 .5rem}.section-title{font-family:var(--serif);font-size:var(--type-section-title);letter-spacing:-.01em;color:var(--text-main);margin:0 0 .5rem;font-weight:500;line-height:1.3}.section-desc{font-size:var(--type-body);color:var(--text-muted);line-height:var(--line-height-body);margin:0}.highlight-text{font-family:var(--serif);font-style:italic;font-weight:400;display:inline-block;position:relative}.highlight-text:after{content:"";background-color:var(--accent-purple);opacity:.6;z-index:-1;border-radius:.125rem;width:100%;height:.25rem;position:absolute;bottom:.125rem;left:0}@media (width<=1024px){.page-wrapper{flex:auto;width:100%}.project-page-layout{max-width:100%}.main-content{width:100%;padding:var(--content-top-offset) var(--content-x-padding) 2.5rem;flex:auto}}@media (width<=768px){html{font-size:15px}:root{--content-top-offset:1.5rem;--content-x-padding:1.25rem}.main-content--wide,.main-content--home{padding-inline:var(--content-x-padding)}#root{flex-direction:column}.main-layout{flex-direction:column;justify-content:flex-start;overflow-x:clip}.page-content-wrapper{align-items:stretch;overflow-x:clip}.main-content{padding:var(--content-top-offset) var(--content-x-padding) 1.75rem;width:100%}.testimonials-section{padding:3.5rem 1.25rem 4rem}.project-page-layout .toc-sidebar{display:none}.page-media-grid-section{width:100%;max-width:none;margin-left:0;margin-right:0;padding-bottom:3rem;padding-left:0;padding-right:0}.page-media-grid{column-gap:.75rem}.page-media-grid__item{max-width:100%;margin-bottom:.75rem}.page-media-grid__item .media-card{min-width:0;max-width:100%}.page-media-grid__item .media-card--tilted{transform:none!important}.page-media-grid__item .media-card--compact .project-card-inner{padding:.5rem .65rem .65rem}.page-media-grid__item .project-card-img{width:100%;max-width:100%}}@media (width<=480px){html{font-size:14px}:root{--content-x-padding:1rem}}.topic-pill{white-space:nowrap;border:1px solid #0000;border-radius:.75rem;padding:.25rem .625rem;font-size:.6875em;font-weight:500;display:inline-flex}.topic-pill:nth-child(4n+1){color:#c90076;background:#fdf2f8;border-color:#fbcfe8}.topic-pill:nth-child(4n+2){color:#047857;background:#ecfdf5;border-color:#a7f3d0}.topic-pill:nth-child(4n+3){color:#6d28d9;background:#f5f3ff;border-color:#ddd6fe}.topic-pill:nth-child(4n){color:#0284c7;background:#e0f2fe;border-color:#bae6fd}:root[data-theme=dark] .topic-pill{background:0 0!important}:root[data-theme=dark] .topic-pill:nth-child(4n+1){border-color:var(--pill-1);color:var(--pill-1)}:root[data-theme=dark] .topic-pill:nth-child(4n+2){border-color:var(--pill-2);color:var(--pill-2)}:root[data-theme=dark] .topic-pill:nth-child(4n+3){border-color:var(--pill-3);color:var(--pill-3)}:root[data-theme=dark] .topic-pill:nth-child(4n){border-color:var(--pill-4);color:var(--pill-4)}.testimonials-section{background:var(--band-bg);color:var(--testimonials-text);border:none;padding:5rem 1.5rem 5.5rem;position:relative}.testimonials-section:before{content:"";background:var(--band-stroke);-webkit-mask-composite:xor;pointer-events:none;z-index:0;padding:.1875rem 0;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;mask-position:0 0,0 0;-webkit-mask-size:auto,auto;mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.testimonials-section>*{z-index:1;position:relative}.testimonials-section h2,.testimonials-section .section-title{color:var(--testimonials-text)}:root[data-theme=dark] .testimonials-section{background:var(--band-bg);color:var(--text-main)}:root[data-theme=dark] .testimonials-section h2,:root[data-theme=dark] .testimonials-section .section-title{color:var(--text-main)}.btn{font-family:var(--sans);cursor:pointer;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;gap:.5rem;font-weight:600;line-height:1;text-decoration:none;transition:background-image .2s,color .2s,border-color .2s,transform .2s;display:inline-flex}.btn__label{display:inline-block}.btn--md{font-size:var(--type-body-sm);padding:.625rem 1.25rem}.btn--sm{font-size:var(--type-body-sm);padding:.5rem 1rem}.btn--primary{background-image:linear-gradient(180deg, var(--button-color) 0%, color-mix(in srgb, var(--button-color) 70%, #000 30%) 100%), linear-gradient(180deg, #2600c4 0%, #cfc4ff 100%);color:#fff;background-origin:border-box;background-clip:padding-box,border-box;border:1px solid #0000}.btn--primary:hover:not(:disabled){background-image:linear-gradient(180deg, var(--button-color-hover) 0%, color-mix(in srgb, var(--button-color-hover) 70%, #000 30%) 100%), linear-gradient(180deg, #cfc4ff 0%, #2600c4 100%);transform:translateY(-1px)}.btn--secondary{background-image:linear-gradient(180deg, var(--btn-secondary-surface) 0%, color-mix(in srgb, var(--btn-secondary-surface) 70%, #000 10%) 100%);border:1px solid var(--border);color:var(--btn-secondary-text)}.btn--secondary:hover:not(:disabled){background-image:linear-gradient(180deg, var(--btn-secondary-surface) 0%, color-mix(in srgb, var(--btn-secondary-surface) 50%, #000 5%) 100%);transform:translateY(-1px)}.btn--solid-dark{background:var(--text-main);color:var(--bg);border:1px solid #0000}.btn--solid-dark:hover:not(:disabled){opacity:.8;transform:none}.btn--outline-dark{background-image:linear-gradient(180deg, var(--btn-secondary-surface) 0%, color-mix(in srgb, var(--btn-secondary-surface) 70%, #000 10%) 100%);border:1px solid var(--border);color:var(--btn-secondary-text)}.btn--outline-dark:hover:not(:disabled){background-image:linear-gradient(180deg, var(--btn-secondary-surface) 0%, color-mix(in srgb, var(--btn-secondary-surface) 50%, #000 5%) 100%);transform:translateY(-1px)}.btn--ghost{color:var(--text-muted);background:0 0;border:none;border-radius:0;padding:0;font-weight:400}.btn--ghost:hover:not(:disabled){color:var(--text-main);transform:none}.btn--unstyled{color:inherit;background:0 0;border:none;border-radius:.5rem;padding:0}.btn--unstyled:hover:not(:disabled){transform:none}.btn--icon-only{border-radius:.5rem;padding:.5rem}.btn:disabled{opacity:.5;cursor:not-allowed}.project-container{color:inherit;background:var(--window-bg);border:1px solid var(--border);z-index:1;border-radius:1.5rem;flex-direction:column;align-items:center;padding:.5rem .5rem 0;text-decoration:none;transition:transform .25s ease-in-out,background .2s linear;display:flex;position:relative}.project-container:hover{cursor:pointer;background:var(--window-bg)}.project-card-img{object-fit:cover;transform-origin:50%;border-radius:1rem;width:100%;height:auto;transition:border-radius .2s;display:block}.project-card-inner{flex-direction:column;justify-content:space-between;align-items:center;gap:.5rem;width:100%;padding:2rem;display:flex}.title-details-group{flex-direction:row;justify-content:space-between;align-items:flex-start;gap:.2rem;width:100%;display:flex}.project-card-title{font-family:var(--sans);font-size:var(--type-card-title);font-weight:550;line-height:var(--line-height-tight);letter-spacing:-.025em;color:var(--text-main);flex:1;min-width:0;max-width:50ch;margin:0}.project-card-meta{font-family:var(--sans);font-size:var(--type-body-sm);color:var(--text-main);opacity:.6;white-space:nowrap;flex-shrink:0;margin:0;font-weight:400}.desc-btn-group{flex-direction:row;justify-content:space-between;align-items:flex-end;gap:1rem;width:100%;display:flex}.project-card-desc{font-family:var(--sans);font-size:var(--type-body);font-weight:400;line-height:var(--line-height-body);color:var(--text-muted);flex:auto;min-width:0;max-width:60ch;margin:0}.button-container{flex:none}.project-container:hover .btn--primary{background-image:linear-gradient(180deg, var(--button-color-hover) 0%, color-mix(in srgb, var(--button-color-hover) 70%, #000 30%) 100%), linear-gradient(180deg, #cfc4ff 0%, #2600c4 100%)}@media (width<=900px){.project-card-inner{flex-direction:column;align-items:flex-end;gap:.2rem}.title-details-group{flex-direction:column-reverse;align-items:flex-start;gap:.5rem}}@media (width<=767px){.project-container{padding:.5rem .5rem 0}.project-card-img{aspect-ratio:5/4;border-radius:0}.project-card-inner{flex-direction:column;align-items:flex-start;padding:1.125rem}.desc-btn-group .btn__label{display:none}.desc-btn-group .btn{padding:.5rem .625rem}}:root[data-theme=dark] .project-container{background:var(--code-bg)}:root[data-theme=dark] .project-container:hover{border-color:var(--text-light)}.project-more--scroll{margin:0 -.25rem;position:relative}.project-more--scroll:before,.project-more--scroll:after{content:"";pointer-events:none;z-index:1;width:2rem;position:absolute;top:0;bottom:.5rem}.project-more--scroll:before{background:linear-gradient(to right, var(--bg), transparent);left:0}.project-more--scroll:after{background:linear-gradient(to left, var(--bg), transparent);right:0}.project-more__scroll-track{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--border) transparent;gap:1.25rem;width:max-content;max-width:100%;margin-inline:auto;padding:.25rem .25rem 1rem;scroll-padding-inline:.25rem;display:flex;overflow-x:auto}.project-more__scroll-track::-webkit-scrollbar{height:.375rem}.project-more__scroll-track::-webkit-scrollbar-thumb{background:var(--border);border-radius:.1875rem}.project-more__scroll-card{scroll-snap-align:start;color:inherit;flex-direction:column;flex:0 0 21.25rem;gap:.875rem;text-decoration:none;transition:opacity .2s;display:flex}.project-more__scroll-card:hover,.home-more-projects-shell.is-visible .project-more__scroll-card:hover{opacity:.78}.project-more__scroll-thumb{aspect-ratio:16/10;object-fit:cover;border-radius:var(--radius);border:1px solid var(--border);width:100%;box-shadow:var(--shadow-sm);display:block}.project-more__scroll-title{font-size:var(--type-body);letter-spacing:-.01em;color:var(--text-main);-webkit-line-clamp:3;-webkit-box-orient:vertical;margin:0;font-weight:500;line-height:1.45;display:-webkit-box;overflow:hidden}@media (width<=900px){.project-more__scroll-card{flex:0 0 18.75rem}}@media (width<=640px){.project-more__scroll-card{flex:0 0 min(17.5rem,82vw)}}.hero-section{text-align:center;flex-direction:column;align-items:center;margin-bottom:4rem;display:flex;position:relative}.hero-intro{width:100%;max-width:90%ch;flex-direction:column;align-items:center;gap:1rem;margin-bottom:.75rem;margin-left:auto;margin-right:auto;display:flex}.hero-avatar{object-fit:cover;border:1px solid var(--border);width:8rem;height:auto;box-shadow:var(--shadow-sm);border-radius:50%;display:block}.hero-greeting{font-family:var(--serif);font-size:var(--type-hero-greeting);letter-spacing:-.02em;color:var(--text-muted);margin:0;font-weight:500;line-height:1.2}.hero-tagline{font-family:var(--serif);font-size:var(--type-hero-tagline);letter-spacing:-.025em;color:var(--text-main);max-width:22em;margin:0 auto;font-weight:500;line-height:1.2}.hero-tags{flex-wrap:wrap;justify-content:center;align-items:center;gap:.625rem;margin:0;padding:0;list-style:none;display:flex}.hero-logos{flex-wrap:wrap;justify-content:center;align-items:center;gap:.75rem;width:100%;margin-top:1rem;display:flex}.hero-logos img{object-fit:contain;opacity:.6;filter:invert();width:auto;height:2.25rem;transition:opacity .2s,filter .2s}:root[data-theme=dark] .hero-logos img{filter:grayscale()invert();opacity:.7}:root[data-theme=dark] .hero-logos img:hover{opacity:1;filter:grayscale()invert()brightness(1.2)}.content-section{border-top:1px solid var(--border);margin-bottom:2rem;padding-top:2rem}.section-header-container{margin-bottom:2rem}#projects .section-header-container{text-align:center;flex-direction:column;align-items:center;max-width:52ch;margin-left:auto;margin-right:auto;display:flex}#projects .section-desc{max-width:42ch}.projects-grid{flex-direction:column;gap:3rem;display:flex}.home-more-projects-trigger{pointer-events:none;visibility:hidden;width:100%;height:1px;margin:0}.home-more-projects-shell{--more-projects-ease:cubic-bezier(.16, 1, .3, 1);transition:grid-template-rows 1.25s var(--more-projects-ease), margin-top 1.25s var(--more-projects-ease);grid-template-rows:0fr;margin-top:0;display:grid}.home-more-projects-shell.is-visible{grid-template-rows:1fr;margin-top:3.5rem}.home-more-projects{text-align:center;border-top:1px solid #0000;flex-direction:column;align-items:center;width:100%;min-height:0;padding-top:2.5rem;display:flex;overflow:hidden}.home-more-projects>.section-title{text-align:center;width:100%;max-width:52ch;margin-left:auto;margin-right:auto}.home-more-projects .project-more--scroll{text-align:left;justify-content:center;align-self:stretch;width:100%;display:flex}.home-more-projects-shell.is-visible .home-more-projects{border-top-color:var(--border);transition:border-color .7s .35s}.home-more-projects__title{font-size:var(--type-body);color:var(--text-main);letter-spacing:-.01em;opacity:0;transition:opacity .85s var(--more-projects-ease) .28s, transform 1s var(--more-projects-ease) .22s;margin:0 0 1.25rem;font-weight:600;transform:translateY(.875rem)}.home-more-projects-shell.is-visible .home-more-projects__title{opacity:1;transform:translateY(0)}.home-more-projects-shell .project-more__scroll-card{opacity:0;transition:opacity .75s var(--more-projects-ease), transform .9s var(--more-projects-ease);transform:translateY(1.125rem)}.home-more-projects-shell.is-visible .project-more__scroll-card:first-child{opacity:1;transition-delay:.48s;transform:translateY(0)}.home-more-projects-shell.is-visible .project-more__scroll-card:nth-child(2){opacity:1;transition-delay:.58s;transform:translateY(0)}.home-more-projects-shell.is-visible .project-more__scroll-card:nth-child(3){opacity:1;transition-delay:.68s;transform:translateY(0)}.home-more-projects-shell.is-visible .project-more__scroll-card:nth-child(n+4){opacity:1;transition-delay:.78s;transform:translateY(0)}@media (prefers-reduced-motion:reduce){.home-more-projects-shell{grid-template-rows:1fr;margin-top:3.5rem;transition:none}.home-more-projects{border-top-color:var(--border)}.home-more-projects__title,.home-more-projects-shell .project-more__scroll-card{opacity:1;transition:none;transform:none}}@media (width<=768px){.hero-section{margin-bottom:2.5rem}.hero-intro{gap:.75rem}.hero-avatar{width:6.5rem;height:auto}.hero-logos img{height:2.75rem}.content-section{margin-bottom:3rem}.section-header-container{margin-bottom:1.25rem}}.home-craft-portal{width:100%;max-width:var(--content-shell-width);padding:0 var(--content-x-padding) 4rem;box-sizing:border-box;margin:0 auto}.home-craft-portal .craft-home-section{border-top:none;margin-bottom:0;padding-top:0}.testimonials-section{margin-bottom:0;overflow:hidden}.testimonial-loud-card{background:var(--code-bg);border:1px solid var(--border);border-radius:1rem;flex-direction:column;flex:0 0 18.75rem;justify-content:space-between;min-height:17.5rem;padding:1.75rem 1.5rem 1.25rem;transition:transform .2s,box-shadow .2s;display:flex;position:relative}.testimonial-loud-card:hover{transform:translateY(-.25rem);box-shadow:0 .75rem 1.5rem #0000000d}.testimonial-quote-mark{color:#4353ff;margin-bottom:1.5rem;font-family:Georgia,serif;font-size:3.5rem;font-weight:700;line-height:.8;display:block}.testimonial-loud-text{font-size:var(--type-body-sm);color:#222;flex-grow:1;margin:0 0 1.5rem;line-height:1.6}.testimonial-loud-footer{align-items:center;gap:.625rem;display:flex}.testimonial-loud-avatar{object-fit:cover;background-color:var(--code-bg);border:.125rem solid #ffffffb3;border-radius:50%;flex-shrink:0;width:2.25rem;height:2.25rem}.fallback-avatar{font-weight:600;font-size:var(--type-body-sm);color:var(--text-main);background-color:var(--border);box-sizing:border-box;justify-content:center;align-items:center;display:flex}.testimonial-loud-meta{flex-wrap:wrap;align-items:baseline;gap:.125rem;display:flex}.testimonial-loud-name{font-size:var(--type-body-sm);text-transform:uppercase;letter-spacing:.03em;color:#111;font-weight:700}.testimonial-loud-role{font-size:var(--type-body-sm);text-transform:uppercase;letter-spacing:.04em;color:#555;font-weight:500}@media (width<=768px){.testimonial-loud-card{flex:0 0 80vw}}.tc-root{width:100%;max-width:var(--content-main-width);font-family:var(--sans);color:inherit;margin:0 auto;padding:0 1.5rem}.testimonials-section--home .tc-root,.testimonials-section--wide .tc-root{max-width:var(--content-shell-width);padding-inline:0}.tc-header{text-align:center;margin-bottom:2.5rem}.tc-header .section-title{text-align:center;margin-left:auto;margin-right:auto}.tc-header .section-desc{max-width:50ch;color:var(--testimonials-text-muted);opacity:1;margin-left:auto;margin-right:auto}.tc-body{text-align:center;flex-direction:column;align-items:center;gap:1.5rem;display:flex}.tc-summary-title{text-align:center;max-width:52ch;margin-left:auto;margin-right:auto;animation:.45s both tc-fade-in}.tc-summary{max-width:52ch;font-family:var(--serif);font-size:var(--type-card-title);letter-spacing:-.02em;color:var(--text-main);margin:0;font-weight:500;line-height:1.35;animation:.45s both tc-fade-in}.tc-quote{max-width:52ch;font-family:var(--sans);font-size:var(--type-body);font-style:normal;font-weight:400;line-height:var(--line-height-body);color:var(--testimonials-text-muted);opacity:1;border:none;margin:0;padding:0;animation:.45s both tc-fade-in}.tc-quote__inner strong{color:var(--testimonials-text);font-style:normal;font-weight:600}.tc-attribution{animation:.45s 50ms both tc-fade-in}.tc-attribution-name{font-size:var(--type-body);color:var(--testimonials-text);opacity:1;margin:0 0 .25rem;font-weight:600}.tc-attribution-role{font-size:var(--type-body-sm);color:var(--testimonials-text-muted);margin:0}@keyframes tc-fade-in{0%{opacity:0}to{opacity:1}}.tc-avatar-strip{flex-wrap:wrap;justify-content:center;align-items:center;gap:.625rem;width:100%;padding-top:.5rem;display:flex}.tc-strip-btn{cursor:pointer;transform:scale(calc(1 - var(--tc-distance,0) * .14));opacity:calc(1 - var(--tc-distance,0) * .32);filter:grayscale(calc(var(--tc-distance,0) * .35));background:0 0;border:none;border-radius:50%;flex-shrink:0;padding:0;transition:transform .45s cubic-bezier(.22,1,.36,1),opacity .45s,filter .45s;position:relative}.tc-strip-btn.is-active{opacity:1;filter:none;z-index:2;transform:scale(1)}.tc-strip-btn:hover:not(.is-active){opacity:calc(.65 - var(--tc-distance,0) * .1);transform:scale(calc(1.02 - var(--tc-distance,0) * .1))}.tc-strip-btn:focus-visible{outline:.125rem solid var(--accent-blue);outline-offset:.1875rem}.tc-avatar-inner{z-index:1;justify-content:center;align-items:center;display:flex;position:relative}.tc-ring-svg{pointer-events:none;z-index:2;width:4.5rem;height:4.5rem;margin:-2.25rem 0 0 -2.25rem;position:absolute;top:50%;left:50%;transform:rotate(-90deg)}.tc-ring-track{fill:none;stroke:#0000001f;stroke-width:2.5px}.tc-ring-progress{fill:none;stroke:var(--accent-blue);stroke-width:2.5px;stroke-linecap:round}.tc-strip-avatar{object-fit:cover;border-radius:50%;width:3rem;height:3rem;transition:width .45s cubic-bezier(.22,1,.36,1),height .45s cubic-bezier(.22,1,.36,1);display:block}.tc-strip-btn.is-active .tc-strip-avatar{width:3.5rem;height:3.5rem}.tc-strip-avatar--fallback{background:var(--border);color:var(--testimonials-text-muted);font-size:var(--type-body);justify-content:center;align-items:center;font-weight:600;display:flex}@media (width<=768px){.tc-avatar-strip{gap:.375rem}.tc-summary-title{font-size:var(--type-card-title)}.tc-strip-avatar{width:2.5rem;height:2.5rem}.tc-strip-btn.is-active .tc-strip-avatar{width:3rem;height:3rem}.tc-ring-svg{width:4rem;height:4rem;margin:-2rem 0 0 -2rem}}:root[data-theme=dark] .testimonials-section .tc-header .section-desc,:root[data-theme=dark] .testimonials-section .tc-quote,:root[data-theme=dark] .testimonials-section .tc-attribution-role{color:var(--text-muted)}:root[data-theme=dark] .testimonials-section .tc-quote__inner strong,:root[data-theme=dark] .testimonials-section .tc-summary,:root[data-theme=dark] .testimonials-section .tc-summary-title,:root[data-theme=dark] .testimonials-section .tc-attribution-name{color:var(--text-main)}:root[data-theme=dark] .testimonials-section .tc-ring-track{stroke:#ffffff1f}:root[data-theme=dark] .testimonials-section .tc-strip-avatar--fallback{background:var(--code-bg);color:var(--text-muted)}.tag-pill{white-space:nowrap;font-family:var(--sans);font-size:var(--type-body-sm);border:1px solid var(--border);background:var(--window-bg);border-radius:.75rem;justify-content:center;align-items:center;padding:.25rem .625rem;font-weight:500;line-height:1.2;display:inline-flex}.tag-pill--orange{color:#ea580c}.tag-pill--blue{color:#2563eb}.tag-pill--green{color:#16a34a}.tag-pill--purple{color:#7c3aed}:root[data-theme=dark] .tag-pill{background:var(--code-bg)}:root[data-theme=dark] .tag-pill--orange{color:#fb923c}:root[data-theme=dark] .tag-pill--blue{color:#60a5fa}:root[data-theme=dark] .tag-pill--green{color:#4ade80}:root[data-theme=dark] .tag-pill--purple{color:#a78bfa}.mobile-section-nav{display:none}@media (width<=768px){.mobile-section-nav{display:block}.mobile-section-nav__backdrop{z-index:199;opacity:0;visibility:hidden;pointer-events:none;cursor:default;background:#00000059;border:none;margin:0;padding:0;transition:opacity .25s,visibility .25s;position:fixed;inset:0}.mobile-section-nav__backdrop--open{opacity:1;visibility:visible;pointer-events:auto}.mobile-section-nav__dock{left:50%;bottom:calc(1rem + env(safe-area-inset-bottom,0));z-index:200;flex-direction:column;align-items:center;max-width:calc(100vw - 1.5rem);display:flex;position:fixed;transform:translate(-50%)}.mobile-section-nav__switcher-row{align-items:center;gap:.625rem;display:flex}.mobile-section-nav__step-btn{border:1px solid var(--border);background:var(--bg);width:2.125rem;height:2.125rem;color:var(--text-main);box-shadow:var(--shadow-sm);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;display:inline-flex}.mobile-section-nav__sheet{background:var(--bg);border:1px solid var(--border);width:min(23.75rem,100vw - 1.5rem);max-height:min(66vh,28.75rem);box-shadow:var(--shadow-lg);transform-origin:bottom;opacity:0;visibility:hidden;pointer-events:none;border-radius:1rem;flex-direction:column;transition:transform .32s cubic-bezier(.32,.72,0,1),opacity .22s,visibility .22s;display:flex;position:absolute;bottom:calc(100% + .625rem);left:50%;overflow:hidden;transform:translate(-50%)translateY(.875rem)scale(.92)}.mobile-section-nav__sheet--open{opacity:1;visibility:visible;pointer-events:auto;transform:translate(-50%)translateY(0)scale(1)}.mobile-section-nav__sheet-inner{-webkit-overflow-scrolling:touch;max-height:min(66vh,28.75rem);padding:1.25rem 1.125rem 1rem;overflow-y:auto}.mobile-section-nav__sheet-title{font-size:var(--type-body-sm);text-transform:uppercase;letter-spacing:.06em;color:var(--text-main);border-left:1px solid var(--border);margin:0 0 .75rem;padding-left:.75rem;font-weight:600}.mobile-section-nav__projects-list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.mobile-section-nav__project-link{border:1px solid var(--border);background:var(--bg);text-align:left;cursor:pointer;border-radius:.625rem;align-items:center;gap:.625rem;width:100%;padding:.5rem;display:flex}.mobile-section-nav__project-thumb{object-fit:cover;border:1px solid var(--border);border-radius:.375rem;flex-shrink:0;width:2.25rem;height:2.25rem}.mobile-section-nav__project-title{font-size:var(--type-body-sm);color:var(--text-main);-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.35;display:-webkit-box;overflow:hidden}.mobile-section-nav__pill{border:1px solid var(--border);background:var(--bg);-webkit-backdrop-filter:blur(.75rem);min-width:10rem;max-width:min(17.5rem,100vw - 8rem);box-shadow:var(--shadow-md);font-size:var(--type-body-sm);color:var(--text-main);cursor:pointer;touch-action:manipulation;border-radius:6.25rem;flex-shrink:0;justify-content:center;align-items:center;gap:.5rem;padding:.625rem .875rem;font-weight:600;display:flex}.mobile-section-nav__pill--grab{border-color:var(--accent-blue);touch-action:none;box-shadow:0 0 0 .1875rem var(--accent-blue-bg), var(--shadow-md);transform:scale(1.04)}.mobile-section-nav__pill-label{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.mobile-section-nav__pill-chevron{opacity:.5;flex-shrink:0;transition:transform .25s}.mobile-section-nav__pill--open .mobile-section-nav__pill-chevron{transform:rotate(180deg)}}.toc-sidebar{width:var(--sidebar-w);padding:var(--content-top-offset) 1.5rem 5rem 0;z-index:10;flex-shrink:0;height:calc(100vh - 3rem);position:sticky;top:1.5rem;overflow-y:auto}@media (width<=1024px){.project-page-layout{flex-direction:column;align-items:stretch}.project-page-aside.toc-sidebar{border-left:none;border-top:1px solid var(--border);width:100%;height:auto;margin-top:2rem;padding:2rem 0 3rem;position:static}}.project-page-layout{align-items:flex-start}.project-breadcrumb{margin:0 0 1.75rem}.project-breadcrumb__list{font-size:var(--type-body-sm);flex-wrap:wrap;align-items:center;gap:.35rem .5rem;margin:0;padding:0;line-height:1.4;list-style:none;display:flex}.project-breadcrumb__item{align-items:center;min-width:0;display:inline-flex}.project-breadcrumb__item:not(:first-child):before{content:"/";color:var(--text-light);margin-right:.5rem;font-weight:400}.project-breadcrumb__link{color:var(--text-muted);font-weight:500;text-decoration:none;transition:color .2s}.project-breadcrumb__link:hover{color:var(--accent-purple)}.project-breadcrumb__item--current{color:var(--text-main);font-weight:500}.project-page-aside{width:var(--sidebar-w);flex-shrink:0}.project-page-aside .toc-title{margin:0 0 .75rem}.project-sidebar-toc{margin:0}.project-sidebar-toc__list{flex-direction:column;gap:.5rem;display:flex}.project-sidebar-toc__item{grid-template-columns:2.75rem 1fr;align-items:start;column-gap:.25rem;display:grid}.project-sidebar-toc__item--plain{grid-template-columns:1fr}.project-sidebar-toc__index{font-family:var(--sans);color:var(--accent-purple);letter-spacing:.04em;padding-top:.2em;font-size:.8125em;font-weight:600;line-height:1.4}.project-sidebar-toc__item .toc-list a,.project-sidebar-toc__item a{padding:.2em 0}@media (width<=768px){.project-page-aside{display:none}.project-page-layout .main-content{padding-bottom:6.25rem}.markdown-content{line-height:var(--line-height-body)}.markdown-section{grid-template-columns:1.75rem minmax(0,1fr);gap:.5rem .625rem;margin-top:1.75rem}.markdown-section:first-of-type{margin-top:1.5rem}.markdown-section-heading__index{font-size:var(--type-body-sm);padding-top:.15em}.markdown-content img,.markdown-content .custom-video-wrapper{margin:1.25rem 0}.markdown-content p:has(>img:only-child){margin:1.25rem 0}.markdown-section>p:has(>img:only-child){margin:1.25rem 0}.more-projects-section{padding:2.5rem 0}.project-sidebar-toc__item{grid-template-columns:2rem 1fr;column-gap:.75rem}}.toc-list{margin:0;padding:0;list-style:none}.toc-list li{margin-bottom:.5rem}.toc-list a{color:var(--text-muted);font-size:.8125em;line-height:1.4;text-decoration:none;transition:color .2s}.project-sidebar-toc__item a{font-size:.8125em;display:block}.toc-list a:hover{color:var(--text-main)}.toc-list a.active{color:var(--accent-blue);font-weight:500}.project-header-tags{flex-wrap:wrap;align-items:center;gap:.625rem;margin:0 0 .75rem;padding:0;list-style:none;display:flex}.divider,.markdown-content hr{border:0;border-bottom:1px solid var(--divider-color);margin:3.5rem 0 2rem}.markdown-content{font-family:var(--sans);color:var(--text-main);line-height:var(--line-height-relaxed);font-size:var(--type-body)}.markdown-content h1,.markdown-content h2:not(.markdown-section-heading),.markdown-content h3:not(.markdown-section-heading){color:var(--text-main);letter-spacing:-.01em;margin-top:2.5rem;margin-bottom:.75rem;font-weight:600}.markdown-content h1{font-family:var(--serif);font-size:var(--type-section-title);max-width:60ch;margin-top:0;margin-bottom:0;font-weight:500;line-height:1.35}.markdown-content h2:not(.markdown-section-heading){font-family:var(--serif);font-size:var(--type-card-title);padding-bottom:0;font-weight:500}.markdown-content h3:not(.markdown-section-heading){font-size:var(--type-body);margin-top:1.5rem;margin-bottom:.5rem;font-weight:600}.markdown-section{grid-template-columns:2.75rem minmax(0,1fr);gap:.625rem 1.25rem;margin-top:2.5rem;scroll-margin-top:5rem;display:grid}.markdown-section:first-of-type{margin-top:0}.markdown-section-heading{display:contents}.markdown-section-heading__index{font-family:var(--sans);font-size:var(--type-body-sm);color:var(--accent-purple);letter-spacing:.04em;grid-area:1/1;padding-top:.2em;font-weight:600;line-height:1.35}.markdown-section-heading__title{font-family:var(--serif);font-size:var(--type-section-title);letter-spacing:-.02em;color:var(--text-main);grid-area:1/2;margin:0;font-weight:500;line-height:1.25}.markdown-section>:not(.markdown-section-heading){max-width:var(--content-project-prose-width);grid-column:2;margin-top:0}.markdown-section>p:first-of-type{margin-top:.125rem}.markdown-section>img,.markdown-section>.markdown-figure,.markdown-section>.custom-video-wrapper{grid-column:1/-1;width:100%;max-width:100%}.markdown-section>p:has(>img:only-child){grid-column:1/-1;width:100%;max-width:100%}.markdown-section>p:has(>.markdown-figure:only-child){grid-column:1/-1;width:100%;max-width:100%}.markdown-section>p:has(>.custom-video-wrapper:only-child){grid-column:1/-1;width:100%;max-width:100%}.markdown-section>p:has(>img:only-child){margin:1.75rem 0}.markdown-content>h2:not(.markdown-section-heading),.markdown-content>h3:not(.markdown-section-heading){scroll-margin-top:5rem}.markdown-content h4{font-size:var(--type-body);color:var(--text-main);opacity:.9;margin-top:1.25rem;margin-bottom:.5rem;font-weight:600}.markdown-content p{color:var(--text-main);opacity:.95;font-size:inherit;margin-bottom:.875rem}.markdown-content ul,.markdown-content ol{color:var(--text-main);opacity:.95;font-size:inherit;margin-bottom:1.25rem;padding-left:1.25rem}.markdown-content li{margin-bottom:.375rem}.markdown-content img,.markdown-content .markdown-figure,.markdown-content .custom-video-wrapper{border-radius:var(--radius);border:1px solid var(--border);width:100%;max-width:100%;height:auto;box-shadow:var(--shadow-sm);box-sizing:border-box;margin:1.75rem 0;display:block;position:relative;overflow:hidden}.markdown-content .markdown-figure{box-shadow:none;background:0 0;border:none;margin:1.75rem 0;padding:0;overflow:visible}.markdown-content .markdown-figure__media{border-radius:var(--radius);border:1px solid var(--border);width:100%;height:auto;box-shadow:var(--shadow-sm);margin:0;display:block}.markdown-content .custom-video-wrapper{background:#000}.markdown-content .custom-video{vertical-align:top;cursor:pointer;width:100%;height:auto;display:block}.markdown-content p:has(>img:only-child){margin:1.75rem 0}.markdown-content p:has(>img:only-child) img{margin:0}.markdown-content .play-pause-btn{color:#fff;cursor:pointer;z-index:10;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;width:2rem;height:2rem;transition:background .2s,transform .2s;display:flex;position:absolute;bottom:.75rem;left:.75rem}.markdown-content .play-pause-btn:hover{background:#000c;transform:scale(1.05)}.markdown-content .media-caption,.markdown-content .video-caption{text-align:center;font-size:var(--type-body-sm);color:var(--text-muted);line-height:var(--line-height-body);margin:.625rem 0 0}.markdown-content code{background:var(--code-bg);color:var(--text-main);border-radius:.25rem;padding:.125rem .375rem;font-family:monospace;font-size:.8125em}.markdown-content ul li{position:relative}.markdown-content strong{color:var(--text-main);font-weight:600}.more-projects-section{padding:3.5rem 0}.more-projects-section .section-title{font-size:var(--type-section-title);margin-bottom:1rem;font-weight:500}.tldr-container{background:var(--window-bg);z-index:1;border-radius:1.5rem;margin:3rem 0;transition:transform .3s,box-shadow .3s;position:relative;overflow:hidden}.tldr-container:before{content:"";background:conic-gradient(transparent, var(--accent-blue) 10%, #6dff6d 25%, #f65c8f 100%);z-index:-2;pointer-events:none;width:400%;height:400%;animation:7s linear forwards borderRotate;position:absolute;top:-150%;left:-150%}@keyframes borderRotate{0%{transform:rotate(0)}to{transform:rotate(720deg)}}.tldr-container:after{content:"";background:var(--window-bg);z-index:-1;pointer-events:none;border-radius:1.4062rem;position:absolute;inset:.0938rem}.tldr-container-border-static{border:.0938rem solid var(--accent-blue);opacity:0;pointer-events:none;z-index:0;border-radius:1.5rem;animation:.5s 8s forwards borderFadeIn;position:absolute;inset:0}@keyframes borderFadeIn{to{opacity:.15}}.tldr-container summary,.tldr-content{z-index:10;position:relative}.tldr-container:hover{transform:translateY(-.25rem);box-shadow:0 .75rem 1.5rem #2e6ff214}.tldr-container summary{cursor:pointer;outline:none;padding:1.5em;list-style:none}.tldr-container summary::-webkit-details-marker{display:none}.tldr-container h3{font-size:var(--type-body)!important;color:var(--accent-blue)!important;margin-top:0!important}.tldr-container ul{margin-bottom:1rem!important}.tldr-container .read-more-btn{font-size:var(--type-body-sm);color:var(--accent-blue);background:rgba(var(--accent-blue-rgb), .1);border-radius:1.25rem;align-items:center;gap:.5rem;margin-top:.5rem;padding:.375rem .875rem;font-weight:600;transition:all .2s;display:inline-flex}.tldr-container[open] .read-more-btn{display:none}.tldr-content{border-top:1px solid var(--border);background:var(--bg);padding:0 1.5rem 1.5rem;animation:.3s ease-out slideDown}@keyframes slideDown{0%{opacity:0;transform:translateY(-.625rem)}to{opacity:1;transform:translateY(0)}}.tldr-content h3,.tldr-content h4{margin-top:1.5rem!important}.markdown-content blockquote,blockquote{border-left:.1875rem solid var(--accent-blue);font-size:var(--type-body);font-style:italic;line-height:var(--line-height-body);color:var(--text-muted);margin:1.25rem 0;padding-left:1rem}.media-card:not(.media-card--tilted){cursor:default;height:100%;transform:none!important}.media-card--tilted{cursor:default;height:100%;transition:transform .25s}.media-card:not(.media-card--tilted):hover,.media-card--tilted:hover{cursor:default}.media-card--tilted:hover{transform:rotate(0)!important}.media-card .project-card-inner{align-items:flex-start;padding:1.25rem 1.5rem 1.5rem}.media-card--compact .project-card-inner{padding:.65rem .85rem .85rem}.media-card--compact .project-card-title{font-size:var(--type-body-sm);max-width:none;font-weight:500;line-height:1.35}.media-card--compact .project-card-meta{font-size:var(--type-body-sm)}.media-card .title-details-group{flex-direction:column;align-items:flex-start;gap:.25rem}.media-card--video .project-card-img{background:#000}.media-card--tall .project-card-img{aspect-ratio:4/5;object-fit:cover;min-height:17.5rem}@media (width<=767px){.media-card .project-card-inner{padding:1.25rem 1.5rem 1.5rem}.media-card--tall .project-card-img{min-height:0}}.gallery-header{margin-bottom:0}.gallery-main{width:var(--content-gallery-width);flex:none;max-width:100%}.project-page-layout--gallery{width:var(--content-gallery-width);max-width:100%}.gallery-photos-section{margin-top:2rem}@media (width<=768px){.gallery-photos-section{margin-top:1.5rem}}.figma-top-header{margin-bottom:0}.figma-hero-title{max-width:none;line-height:1.15;font-size:var(--type-hero-tagline);flex-wrap:wrap;align-items:baseline;gap:.2em .35em;margin-bottom:1.25rem;display:flex}.figma-hero-title__lead,.figma-hero-title__slot{display:inline}.figma-hero-desc{max-width:52ch;margin-bottom:0}.figma-hero-title .slot-machine-container{vertical-align:bottom;height:1.15em;line-height:1.15;display:inline-block;overflow:hidden}.figma-hero-title .slot-machine-track{flex-direction:column;animation:5s cubic-bezier(.85,0,.15,1) infinite figma-slot-scroll;display:flex}.figma-hero-title .slot-item{white-space:nowrap;align-items:center;height:1.15em;display:flex}@keyframes figma-slot-scroll{0%,12.5%{transform:translateY(0)}16.6%,29.1%{transform:translateY(-1.15em)}33.3%,45.8%{transform:translateY(-2.3em)}50%,62.5%{transform:translateY(-3.45em)}66.6%,79.1%{transform:translateY(-4.6em)}83.3%,95.8%{transform:translateY(-5.75em)}to{transform:translateY(-5.75em)}}.training-photos-section{margin-top:2rem}@media (width<=768px){.figma-hero-title .slot-item{white-space:normal}.figma-hero-title .slot-machine-container{max-width:100%}.training-photos-section,.training-logos{margin-top:1.5rem}.training-logos img{height:1.75rem}}.training-logos{opacity:.6;margin-top:2.5rem}.text-main{color:var(--text-main);font-weight:600}.text-center{text-align:center}.mx-auto{margin-left:auto;margin-right:auto}.figma-book-btn{margin-top:1rem}.giant-footer{background-color:var(--bg);text-align:center;width:100%;padding:0 0 3.75rem;position:relative;overflow:hidden}.contact-form-container{background:var(--band-bg);border:none;flex-direction:column;justify-content:center;align-items:center;gap:1em;width:100%;max-width:-webkit-fill-available;margin:auto;padding:5em 2em 7em;display:flex;position:relative}.contact-form-container:before{content:"";background:var(--band-stroke);-webkit-mask-composite:xor;pointer-events:none;z-index:0;padding-top:.1875rem;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;mask-position:0 0,0 0;-webkit-mask-size:auto,auto;mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.contact-form-container>*{z-index:1;position:relative}.contact-form-container .footer-big-title{text-align:center;margin-bottom:0}.contact-form-container .giant-footer-sub{margin-bottom:0}.contact-form-container .giant-footer-sub p{text-align:center;max-width:40ch;margin-left:auto;margin-right:auto}.contact-form-container .cta-row{flex-flow:wrap;justify-content:center;gap:1em;margin-top:1em;margin-bottom:.5em;display:flex}.contact-form-container .tags-row{flex-flow:wrap;justify-content:center;gap:.5em;max-width:80ch;margin-top:1em;display:flex}.giant-footer-title{flex-direction:column;justify-content:center;align-items:center;margin-bottom:1.5rem;display:flex}.polaroid-gallery{flex-wrap:wrap;justify-content:center;align-items:center;gap:2rem;padding-bottom:4rem;display:flex}.polaroid-card{background:var(--polaroid-bg,#fff);box-shadow:var(--polaroid-shadow,0 .625rem 1.875rem #0000001a, 0 .125rem .5rem #0000000f);color:var(--polaroid-link,#333);z-index:1;border-radius:.5rem;flex-direction:column;width:15rem;padding:.25rem;text-decoration:none;transition:transform .3s cubic-bezier(.175,.885,.32,1.275),box-shadow .55s cubic-bezier(.4,0,.2,1),background-color .55s cubic-bezier(.4,0,.2,1),color .55s cubic-bezier(.4,0,.2,1);display:flex;position:relative}.polaroid-card:hover{box-shadow:var(--polaroid-shadow-hover,0 1.25rem 2.5rem #0003, 0 .5rem 1rem #0000001a);z-index:10;transform:translateY(-1rem)scale(1.05)rotate(0)!important}.polaroid-photo{aspect-ratio:1;background:var(--polaroid-photo-bg,#e0e0e0);border-radius:.25rem;width:100%;transition:background-color .55s cubic-bezier(.4,0,.2,1);overflow:hidden}.polaroid-photo img{object-fit:cover;width:100%;height:100%}.polaroid-photo.has-loop{position:relative}.polaroid-photo .default-img{z-index:2;transition:opacity .3s;position:relative}.polaroid-card:hover .polaroid-photo .default-img{opacity:0}.loop-imgs{pointer-events:none;z-index:1;width:100%;height:100%;position:absolute;top:0;left:0}.loop-imgs img{object-fit:cover;opacity:0;width:100%;height:100%;position:absolute;top:0;left:0}.polaroid-card:hover .loop-imgs img:first-child{animation:2s step-end infinite slide-1}.polaroid-card:hover .loop-imgs img:nth-child(2){animation:2s step-end infinite slide-2}.polaroid-card:hover .loop-imgs img:nth-child(3){animation:2s step-end infinite slide-3}.polaroid-card:hover .loop-imgs img:nth-child(4){animation:2s step-end infinite slide-4}@keyframes slide-1{0%{opacity:1}25%{opacity:0}to{opacity:0}}@keyframes slide-2{0%{opacity:0}25%{opacity:1}50%{opacity:0}to{opacity:0}}@keyframes slide-3{0%{opacity:0}50%{opacity:1}75%{opacity:0}to{opacity:0}}@keyframes slide-4{0%{opacity:0}75%{opacity:1}to{opacity:0}}.polaroid-caption{height:1.875rem;font-family:Architects Daughter,serif;font-size:var(--type-body);color:var(--polaroid-caption,#111);justify-content:center;align-items:center;font-weight:500;transition:color .55s cubic-bezier(.4,0,.2,1);display:flex}.tilt-left{transform:rotate(-6deg)}.tilt-right{transform:rotate(5deg)}.tilt-left-slight{transform:rotate(-2deg)}.push-down{margin-top:2.5rem}.push-up{margin-top:-1.25rem}.giant-footer-sub{font-size:var(--type-body);font-family:var(--sans);color:var(--text-muted);line-height:1.5}.giant-footer-sub strong{color:var(--text-main);font-weight:600}.footer-sub-container{max-width:37.5rem}.giant-footer-sub p{margin:0}.giant-footer-actions{justify-content:center;gap:1rem;display:flex}.btn-solid-dark{background:var(--text-main);color:var(--bg);font-weight:500;font-size:var(--type-body-sm);border-radius:2.5rem;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:opacity .2s;display:inline-flex}.btn-solid-dark:hover{opacity:.8}.btn-outline-dark{color:var(--text-main);font-weight:500;font-size:var(--type-body-sm);border:1px solid var(--border);background:0 0;border-radius:2.5rem;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:border-color .2s;display:inline-flex}.btn-outline-dark:hover{border-color:var(--text-muted)}.footer-big-title{margin-bottom:0}.footer-bottom-links{margin-top:7.5rem}.footer-decorations{justify-content:center;height:16.25rem;margin-top:2.5rem;display:flex;position:relative}.footer-decor-card{font-size:var(--type-section-title);font-family:var(--sans);transform-origin:bottom;white-space:nowrap;border-radius:.75rem;padding:2rem 2.5rem;font-weight:700;line-height:1.2;position:absolute;bottom:-3.75rem;box-shadow:0 .625rem 2.5rem #00000026}.decor-1{color:#7d8ded;z-index:3;background:#3c1204;transform:rotate(-8deg)translate(-17.5rem,-2.5rem)}.decor-2{color:#fff;z-index:1;font-family:var(--serif);background:#000aff;font-size:3.375rem;font-style:italic;transform:rotate(-4deg)translate(-3.75rem,-6.875rem)}.decor-3{color:#fb3663;z-index:4;background:#4a003f;padding-bottom:5rem;font-weight:500;transform:rotate(-2deg)translate(13.75rem,-1.875rem)}.decor-4{color:#d946ef;z-index:2;font-family:var(--serif);background:#fdf2f8;font-size:2.25rem;transform:rotate(4deg)translate(17.5rem,-6.25rem)}.footer-contact-form-wrapper{text-align:left;max-width:25rem;margin:0 auto 2.5rem}.footer-contact-form{flex-direction:column;gap:.75rem;display:flex}.footer-contact-input{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text-main);font-family:inherit;font-size:var(--type-body-sm);box-sizing:border-box;border-radius:.5rem;padding:.75rem}.footer-contact-textarea{resize:none}.footer-submit-btn{cursor:pointer;width:100%}.status-message-banner{font-size:var(--type-body-sm);text-align:center;border-radius:.375rem;margin-bottom:.75rem;padding:.625rem;font-weight:500}.status-message-banner.success{color:#1a7f37;background:#e6f4ea}.status-message-banner.error{color:#d32f2f;background:#fdeaea}@media (width<=800px){.contact-form-container{padding:3rem 1.25rem 4rem}.contact-form-container .cta-row{gap:.75em}}@media (width<=768px){.giant-footer{padding:0 0 3.75rem}.contact-form-container .cta-row{box-sizing:border-box;flex-direction:column;gap:.75rem;width:100%;padding:0 1rem}.contact-form-container .cta-row .btn{width:100%}.polaroid-gallery{flex-wrap:wrap;justify-content:center;gap:1rem;padding:0 .5rem;display:flex}.polaroid-card{width:calc(50% - .75rem);min-width:8.75rem;margin-top:0!important;transform:none!important}.polaroid-caption{font-size:var(--type-body-sm)}.footer-mobile-info{text-align:left;border-top:1px solid var(--border);margin-top:5rem;padding:2.5rem 1rem 0;display:block}.footer-mobile-section{margin-bottom:2rem}.footer-mobile-links{flex-direction:column;align-items:flex-start;gap:.75rem;display:flex}.footer-link-btn{font-size:var(--type-body-sm);color:var(--text-muted);text-align:left;cursor:pointer;font-family:var(--sans);background:0 0;border:none;padding:0;text-decoration:none;transition:color .2s}.footer-link-btn:hover{color:var(--text-main)}.footer-mobile-status{font-size:var(--type-body-sm);color:var(--text-muted);align-items:center;gap:.75rem;display:flex}}@media (width>=769px){.footer-mobile-info{display:none}}.craft-page{padding-bottom:4rem}.craft-intro{text-align:center;flex-direction:column;align-items:center;max-width:52ch;margin:0 auto;display:flex}.craft-intro__title{margin-left:auto;margin-right:auto}.craft-intro__desc{max-width:42ch;margin-left:auto;margin-right:auto}.craft-intro__tags{flex-wrap:wrap;justify-content:center;align-items:center;gap:.625rem;margin-bottom:1.5em;padding:0;list-style:none;display:flex}.craft-section{margin-top:3rem}.craft-section--figma{margin-top:6rem}.craft-figma-intro{text-align:center;flex-direction:column;align-items:center;max-width:52ch;margin:0 auto 2rem;display:flex}.craft-figma-intro__title{width:100%;margin:0}.craft-grid{gap:2rem;display:grid}.experiments-grid{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}@media (width<=768px){.experiments-grid{grid-template-columns:1fr}}.experiment-figure{flex-direction:column;gap:.625rem;margin:0;display:flex}.experiment-caption{font-size:var(--type-body-sm);color:var(--text-muted);text-align:center;margin:0;padding:0 .25rem;line-height:1.45}.experiment-card{background-color:var(--code-bg);border:1px solid var(--border);border-radius:1.5rem;padding:.5rem;transition:transform .3s ease-out}.experiment-card:hover{transform:translateY(0)rotate(0)!important}.experiment-image-container{aspect-ratio:1;border-radius:1rem;position:relative;overflow:hidden}.experiment-image-container .experiment-gif{object-fit:cover;border-radius:1rem;width:100%;height:100%;display:block}.figma-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}@media (width<=768px){.figma-grid{grid-template-columns:1fr}}.figma-card{background:var(--bg);border:1px solid var(--border);border-radius:.75rem;flex-direction:column;transition:transform .3s,box-shadow .3s;display:flex;overflow:hidden}.figma-card:hover{transform:translateY(-.25rem);box-shadow:0 .5rem 1.5rem #00000014}.figma-thumb-wrapper{aspect-ratio:16/10;background:var(--code-bg);border-bottom:1px solid var(--border);width:100%;overflow:hidden}.figma-thumb{object-fit:cover;width:100%;height:100%;transition:transform .3s}.figma-card:hover .figma-thumb{transform:scale(1.03)}.figma-card-footer{background:var(--sidebar-bg);justify-content:space-between;align-items:center;padding:1rem;display:flex}.figma-downloads{font-size:var(--type-body-sm);color:var(--text-muted);align-items:center;gap:.375rem;font-weight:500;display:flex}.figma-btn{font-size:var(--type-body-sm)!important;border-radius:.375rem!important;padding:.375rem 1rem!important}.faq-container{width:100%;max-width:var(--content-main-width);padding:5rem var(--content-x-padding) 5.5rem;box-sizing:border-box;background:var(--bg);text-align:center;margin:0 auto}.faq-container--home,.faq-container--training{max-width:var(--content-shell-width);padding-inline:0}.faq-container--training{border-top:1px solid var(--border)}.faq-container .section-title{text-align:center;margin-bottom:2.5rem}.faq-list{width:100%;max-width:var(--content-about-width);text-align:left;flex-direction:column;gap:.75rem;margin:0 auto;display:flex}.faq-item{background:var(--faq-item-bg,var(--window-bg));border-radius:.75rem;transition:background-color .35s;overflow:hidden}.faq-item:hover{background:var(--faq-item-hover,#f3f3f3)}:root[data-theme=dark] .faq-item{--faq-item-bg:var(--code-bg);--faq-item-hover:var(--window-bg)}.faq-question,.faq-question.btn{cursor:pointer;width:100%;font:inherit;text-align:left;color:inherit;background:0 0;border:none;border-radius:0;justify-content:space-between;align-items:center;gap:1rem;margin:0;padding:1.25rem 1.5rem;display:flex}.faq-question__text{color:var(--text-main);font-size:clamp(1.0625rem,.65vw + .95rem,1.1875rem);font-weight:500;line-height:1.35}.faq-icon{color:var(--text-muted);flex-shrink:0;justify-content:center;align-items:center;display:flex}.faq-answer{opacity:0;max-height:0;padding:0 1.5rem;transition:max-height .35s cubic-bezier(.4,0,.2,1),opacity .3s,padding .35s;overflow:hidden}.faq-answer.open{opacity:1;max-height:20rem;padding:0 1.5rem 1.25rem}.faq-answer p{color:var(--text-muted);font-size:clamp(1.0625rem,.65vw + .95rem,1.1875rem);line-height:var(--line-height-body);margin:0}@media (width<=768px){.faq-container{padding:3.5rem var(--content-x-padding) 4rem}.faq-container--home,.faq-container--training{padding-inline:var(--content-x-padding)}.faq-container .section-title{margin-bottom:1.75rem}.faq-question,.faq-question.btn{padding:.875rem 1rem}.faq-answer.open{padding:0 1.125rem 1rem}.faq-answer{padding:0 1.125rem}}.top-nav{z-index:1000;width:100%;padding:1.25rem var(--content-x-padding) .875rem;pointer-events:none;background:0 0;border:none;position:sticky;top:0}.top-nav__inner{width:100%;max-width:var(--content-shell-width);pointer-events:auto;justify-content:space-between;align-items:center;gap:.875rem;margin-left:auto;margin-right:auto;display:flex}.top-nav__pill{background:var(--nav-pill-bg,#fff);border-radius:var(--radius-pill);box-shadow:var(--nav-pill-shadow,0 .25rem .75rem #0000000f, 0 .0625rem .1875rem #0000000a);align-items:center;transition:background-color .55s cubic-bezier(.4,0,.2,1),box-shadow .55s cubic-bezier(.4,0,.2,1),color .2s,transform .2s;display:inline-flex}.top-nav__pill--main{gap:.75rem;min-width:0;padding:.5rem 1.25rem .5rem .5rem}.top-nav__pill--icon{width:3rem;height:3rem;color:var(--text-muted);flex-shrink:0;justify-content:center;padding:0;text-decoration:none}.top-nav__pill--icon:hover{color:var(--accent-purple);box-shadow:var(--nav-pill-shadow-hover,0 .375rem 1rem #00000014, 0 .125rem .25rem #0000000d);transform:translateY(-1px)}.top-nav__avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;line-height:0;text-decoration:none;display:inline-flex;overflow:hidden}.top-nav__avatar--back{width:2.25rem;height:2.25rem;color:var(--text-muted);transition:color .2s}.top-nav__avatar--back:hover{color:var(--accent-purple)}.top-nav__avatar img{object-fit:cover;width:2.25rem;height:2.25rem;display:block}.top-nav__tabs{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;align-items:center;gap:.5rem 1.75rem;min-width:0;display:flex;overflow-x:auto}.top-nav__tabs::-webkit-scrollbar{display:none}.top-nav__tab{font-size:var(--type-body);color:var(--text-muted);white-space:nowrap;flex-shrink:0;align-items:center;gap:.5rem;padding:.4375rem .25rem;font-weight:500;text-decoration:none;transition:color .2s;display:inline-flex}.top-nav__tab svg{color:inherit;flex-shrink:0}.top-nav__tab:hover{color:var(--text-main)}.top-nav__tab--active{color:var(--accent-purple)}.top-nav__actions{flex-shrink:0;align-items:center;gap:.75rem;display:flex}.top-nav__cta.btn{font-size:var(--type-body-sm);white-space:nowrap;padding:.6875rem 1.375rem;font-weight:600}@media (width<=900px){.top-nav{padding-top:1rem;padding-bottom:.625rem}.top-nav__inner{flex-wrap:wrap;row-gap:.75rem}.top-nav__pill--main{flex:100%;max-width:100%}.top-nav__actions{margin-left:auto}}@media (width<=520px){.top-nav__cta.btn{padding:.625rem 1rem;font-size:.8125rem}.top-nav__pill--icon{width:2.75rem;height:2.75rem}.top-nav__tab{font-size:var(--type-body-sm);gap:.4375rem}.top-nav__tabs{gap:.375rem 1.25rem}}@media (prefers-reduced-motion:reduce){.top-nav__pill{transition:none}.top-nav__pill--icon:hover{transform:none}}.theme-scroll-sentinel{pointer-events:none;visibility:hidden;border:0;width:100%;height:1px;margin:0;padding:0}.page-lower-zone{background-color:var(--bg);color:var(--text-main);transition:background-color .55s cubic-bezier(.4,0,.2,1),color .55s cubic-bezier(.4,0,.2,1)}.top-nav{color:var(--text-main);background-color:#0000;transition:background-color .55s cubic-bezier(.4,0,.2,1),color .55s cubic-bezier(.4,0,.2,1)}.page-lower-zone .faq-container,.page-lower-zone .home-craft-portal,.page-lower-zone .craft-home-section,.page-lower-zone .giant-footer,.page-lower-zone .contact-form-container,.page-lower-zone .figma-card-footer{transition:background .55s cubic-bezier(.4,0,.2,1),background-color .55s cubic-bezier(.4,0,.2,1),color .55s cubic-bezier(.4,0,.2,1),border-color .55s cubic-bezier(.4,0,.2,1)}.page-lower-zone .contact-form-container:before{transition:background .55s cubic-bezier(.4,0,.2,1)}.page-lower-zone .faq-item{background:var(--faq-item-bg);transition:background-color .35s}.page-lower-zone .faq-item:hover{background:var(--faq-item-hover)}.page-lower-zone .experiment-card{transition:transform .3s ease-out,background-color .55s cubic-bezier(.4,0,.2,1),border-color .55s cubic-bezier(.4,0,.2,1)}.page-lower-zone .figma-card{transition:transform .3s,box-shadow .3s,background-color .55s cubic-bezier(.4,0,.2,1),border-color .55s cubic-bezier(.4,0,.2,1)}.page-lower-zone[data-theme=dark] .figma-card:hover{box-shadow:0 .5rem 1.5rem #00000059}.page-lower-zone .polaroid-card{transition:transform .3s cubic-bezier(.175,.885,.32,1.275),box-shadow .55s cubic-bezier(.4,0,.2,1),background-color .55s cubic-bezier(.4,0,.2,1),color .55s cubic-bezier(.4,0,.2,1)}.page-lower-zone .polaroid-card:hover{box-shadow:var(--polaroid-shadow-hover)}.page-lower-zone .polaroid-caption{transition:color .55s cubic-bezier(.4,0,.2,1)}.page-lower-zone .polaroid-photo{transition:background-color .55s cubic-bezier(.4,0,.2,1)}.page-lower-zone[data-theme=dark] .topic-pill{background:0 0!important}.page-lower-zone[data-theme=dark] .topic-pill:nth-child(4n+1){border-color:var(--pill-1);color:var(--pill-1)}.page-lower-zone[data-theme=dark] .topic-pill:nth-child(4n+2){border-color:var(--pill-2);color:var(--pill-2)}.page-lower-zone[data-theme=dark] .topic-pill:nth-child(4n+3){border-color:var(--pill-3);color:var(--pill-3)}.page-lower-zone[data-theme=dark] .topic-pill:nth-child(4n){border-color:var(--pill-4);color:var(--pill-4)}.page-lower-zone .footer-link-btn{color:var(--text-muted);transition:color .2s}.page-lower-zone .footer-link-btn:hover{color:var(--text-main)}@media (prefers-reduced-motion:reduce){.page-lower-zone,.top-nav,.page-lower-zone .faq-container,.page-lower-zone .faq-item,.page-lower-zone .home-craft-portal,.page-lower-zone .craft-home-section,.page-lower-zone .giant-footer,.page-lower-zone .contact-form-container,.page-lower-zone .experiment-card,.page-lower-zone .figma-card,.page-lower-zone .polaroid-card{transition:none}}
