@font-face{font-family:Haffer;src:url(/assets/HafferStandardUprights-VF-BuAWY3uP.ttf) format("truetype");font-weight:100 900;font-style:normal;font-display:swap}@font-face{font-family:HafferXH;src:url(/assets/HafferXHRegular-wtvj0Gwh.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:HafferMono;src:url(/assets/HafferMonoRegular-CdXMmhoD.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:HafferMono;src:url(/assets/HafferMonoMedium-DeJVG9mc.woff2) format("woff2");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:BrisaPro;src:url(/assets/BrisaPro-Regular-Dsi_d2FE.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}:root{--color-neutral-100: white;--color-neutral-200: #f4f4f4;--color-neutral-300: #eaeaea;--color-neutral-400: #e1e1e1;--color-neutral-450: #d8d8d8;--color-neutral-475: #b8b8b8;--color-neutral-500: #817f7f;--color-neutral-525: #4f4c4c;--color-neutral-550: #393636;--color-neutral-600: #312e2e;--color-neutral-700: #2a2727;--color-neutral-800: #201d1d;--color-neutral-900: #151313;--color-neutral-950: black;--color-dark: var(--color-neutral-800);--color-black: var(--color-neutral-900);--color-white: var(--color-neutral-100);--color-light: var(--color-neutral-200);--color-electric: #a1ff62;--color-purple: #6840ff;--color-coral: #f84131;--container-padding: 1.875em;--padding-xl: 12.5em;--padding-l: 10em;--padding-m: 7.5em;--padding-s: 5em;--padding-xs: 3.75em;--gap-xxl: 2.5em;--gap-xl: 2em;--gap-l: 1.875em;--gap-m: 1.5em;--gap-s: 1em;--gap-sm: 1.25em;--gap-xs: .75em;--gap-xxs: .5em;--stroke-weight: 1px;--btn-height: 2.5em;--nav-bar-height: 4.625em;--nav-bar-max-width-small: 38em;--cubic-default: cubic-bezier(.625, .05, 0, 1);--cubic-bounce: linear(0, .5737 7.6%, .8382 11.87%, .9463 14.19%, 1.0292 16.54%, 1.0886 18.97%, 1.1258 21.53%, 1.137 22.97%, 1.1424 24.48%, 1.1423 26.1%, 1.1366 27.86%, 1.1165 31.01%, 1.0507 38.62%, 1.0219 42.57%, .9995 46.99%, .9872 51.63%, .9842 58.77%, 1.0011 81.26%, 1);--duration-default: .6s;--duration-default-half: .3s;--duration-default-onehalf: .9s;--duration-default-double: 1.2s;--animation-default: var(--duration-default) var(--cubic-default);--animation-default-half: var(--duration-default-half) var(--cubic-default);--animation-default-onehalf: var(--duration-default-onehalf) var(--cubic-default);--animation-default-double: var(--duration-default-double) var(--cubic-default);--animation-ease: .2s ease;--size-unit: 16;--size-container-ideal: 1440;--size-container-min: 992px;--size-container-max: 1920px;--size-container: clamp(var(--size-container-min), 100vw, var(--size-container-max));--size-font: calc(var(--size-container) / (var(--size-container-ideal) / var(--size-unit)))}[data-theme=light]{--color-neutral-100: #151313;--color-neutral-200: #201d1d;--color-neutral-300: #2a2727;--color-neutral-400: #312e2e;--color-neutral-450: #393636;--color-neutral-475: #4f4c4c;--color-neutral-500: #817f7f;--color-neutral-525: #b8b8b8;--color-neutral-550: #d8d8d8;--color-neutral-600: #e1e1e1;--color-neutral-700: #eaeaea;--color-neutral-800: #f4f4f4;--color-neutral-900: white;--color-neutral-950: white;--color-dark: var(--color-neutral-800);--color-black: var(--color-neutral-900);--color-white: var(--color-neutral-100);--color-light: var(--color-neutral-200)}@media screen and (max-width:991px){:root{--size-container-ideal: 850;--size-container-min: 768px;--size-container-max: 991px}}@media screen and (max-width:767px){:root{--size-container-ideal: 390;--size-container-min: 320px;--size-container-max: 767px;--btn-height: 3em;--padding-xl: 5em;--padding-l: 3.75em;--padding-m: 2.5em;--padding-s: 1.875em;--padding-xs: 1.5em;--container-padding: 1em}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}*,*:before,*:after{box-sizing:border-box}html{font-size:var(--size-font);scroll-behavior:smooth}body{margin:0;font-family:Haffer,Inter,sans-serif;font-variation-settings:"wght" 460;background-color:var(--color-neutral-900);color:var(--color-neutral-200);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .3s ease,color .3s ease}.h-display{font-family:HafferXH,sans-serif;font-size:7em;letter-spacing:-.04em;line-height:1}.h-xl{font-family:HafferXH,sans-serif;font-size:5em;letter-spacing:-.04em;line-height:1.05}.h-l{font-family:HafferXH,sans-serif;font-size:3.875em;letter-spacing:-.03em;line-height:1.1}.h-m{font-family:HafferXH,sans-serif;font-size:2.5em;letter-spacing:-.02em;line-height:1.15}.h-s{font-family:HafferXH,sans-serif;font-size:1.875em;letter-spacing:-.01em;line-height:1.2}.p-l{font-size:1.1875em;font-variation-settings:"wght" 420;line-height:1.6}.p-m{font-size:1em;font-variation-settings:"wght" 430;line-height:1.65}.eyebrow{font-family:HafferMono,monospace;font-size:.6875em;text-transform:uppercase;letter-spacing:.05em}.scribble{font-family:BrisaPro,serif;font-size:1.5625em}[data-underline-link]{position:relative}[data-underline-link]:before{content:"";position:absolute;bottom:-.1em;left:0;width:100%;height:1px;background:currentColor;transform:scaleX(0);transform-origin:right center;transition:transform var(--animation-default)}[data-underline-link]:hover:before,a:hover [data-underline-link]:before{transform:scaleX(1);transform-origin:left center}.page-container{max-width:var(--size-container);margin:0 auto;padding:0 var(--container-padding)}canvas{-webkit-user-select:none;-moz-user-select:none;user-select:none;background:transparent;outline:none;border:none;pointer-events:none}.canvas-container{pointer-events:auto;background:transparent;cursor:auto}.canvas-container:hover{cursor:auto}.canvas-container canvas{pointer-events:none;cursor:auto}button,button:hover{cursor:pointer!important}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.relative{position:relative}.absolute{position:absolute}.w-screen{width:100vw}.h-screen{height:100vh}.w-full{width:100%}.h-full{height:100%}.top-0{top:0}.left-0{left:0}.top-4{top:1rem}.right-4{right:1rem}.bottom-0{bottom:0}.p-4{padding:1rem}.p-2{padding:.5rem}.px-4{padding-left:1rem;padding-right:1rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.mb-4{margin-bottom:1rem}.z-5{z-index:5}.z-10{z-index:10}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.bg-gray-900{background-color:#111827}.bg-black{background-color:#000}.bg-opacity-30{background-color:#0000004d}.bg-opacity-50{background-color:#00000080}.text-white{color:#fff}.text-opacity-70{color:#ffffffb3}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.font-semibold{font-weight:600}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.shadow-lg{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.pointer-events-none{pointer-events:none}.transition-all{transition:all .2s}.duration-200{transition-duration:.2s}.backdrop-blur-sm{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.hover\:bg-opacity-50:hover{background-color:#00000080}.gap-2{gap:.5rem}.right-click-overlay{pointer-events:auto;background:transparent;z-index:0}@keyframes tvShutdown{0%{transform:scale(1);opacity:1}50%{transform:scale(.8);opacity:.8}80%{transform:scale(.1,.8);opacity:.5}90%{transform:scale(.05,.4);opacity:.3}to{transform:scale(0,.02);opacity:0}}@keyframes tvShutdownAlt{0%{transform:scaleY(1) scaleX(1);opacity:1}60%{transform:scaleY(.6) scaleX(.8);opacity:.8}80%{transform:scaleY(.2) scaleX(.6);opacity:.4}95%{transform:scaleY(.02) scaleX(.3);opacity:.1}to{transform:scaleY(0) scaleX(0);opacity:0}}.app-content-wrapper{position:relative;width:100vw;height:100vh;overflow:hidden;transition:none}.app-content-wrapper.tv-shutting-down{animation:tv-shutdown .5s ease-out forwards;transform-origin:center center}.app-content-wrapper.tv-starting-up{animation:tv-startup .2s ease-out forwards;transform-origin:center center}@keyframes tv-shutdown{0%{transform:scaleY(1) scaleX(1);opacity:1}70%{transform:scaleY(.002) scaleX(1);opacity:1}95%{transform:scaleY(.002) scaleX(.1);opacity:1}to{transform:scaleY(0) scaleX(0);opacity:0}}@keyframes tv-startup{0%{transform:scaleY(0) scaleX(0);opacity:0}5%{transform:scaleY(.002) scaleX(.1);opacity:1}30%{transform:scaleY(.002) scaleX(1);opacity:1}to{transform:scaleY(1) scaleX(1);opacity:1}}@keyframes tv-shutdown{0%{opacity:1;transform:scaleY(1) scaleX(1)}68%{opacity:1;transform:scaleY(.001) scaleX(1)}99%{opacity:1;transform:scaleY(.001) scaleX(0)}to{opacity:0;transform:scaleY(0) scaleX(0);display:none}}@keyframes tv-startup{0%{opacity:0;transform:scaleY(0) scaleX(0)}20%{opacity:1;transform:scaleY(.001) scaleX(0)}40%{opacity:1;transform:scaleY(.001) scaleX(1)}to{opacity:1;transform:scaleY(1) scaleX(1)}}.system-toggle-button{transition:all .2s ease;transform:scale(1)}.system-toggle-button:hover{transform:scale(1.1);background-color:#0009!important}.system-toggle-button:active{transform:scale(.95)}.system-toggle-button.shutting-down{animation:button-shutdown .3s ease-out}.system-toggle-button.starting-up{animation:button-startup .3s ease-out}@keyframes button-shutdown{0%{transform:scale(1)}50%{transform:scale(.9);opacity:.7}to{transform:scale(1)}}@keyframes button-startup{0%{transform:scale(1)}50%{transform:scale(1.1);opacity:.8}to{transform:scale(1)}}@media(min-width:640px){.sm\:text-sm{font-size:.875rem}}:root{--nav-ease: cubic-bezier(.165, .84, .44, 1);--nav-duration: .45s}.nav{z-index:100;position:fixed;top:0;left:0;right:0;pointer-events:none;padding:1.25em var(--container-padding);display:flex;justify-content:center}.nav__backdrop{pointer-events:auto;position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;background:#00000080;opacity:0;transition:opacity var(--nav-duration) var(--nav-ease)}.nav--open .nav__backdrop{opacity:1}.nav-bar{pointer-events:auto;position:relative;width:100%;max-width:var(--nav-bar-max-width-small);border-radius:.75em;color:var(--color-neutral-200);background:var(--color-neutral-800);border:1px solid rgba(244,244,244,.08);transition:max-width var(--nav-duration) var(--nav-ease),border-radius var(--nav-duration) var(--nav-ease),background-color var(--nav-duration) var(--nav-ease),border-color var(--nav-duration) var(--nav-ease)}.nav--open .nav-bar{max-width:calc(100vw - 2.5em);background:var(--color-neutral-900);border-color:#f4f4f40f;border-radius:1em}.nav-bar__header{position:relative;display:flex;align-items:center;height:3.25em;padding:0 .625em;gap:.375em}.nav-bar__logo{position:absolute;left:50%;transform:translate(-50%);display:flex;align-items:center;font-family:Haffer,sans-serif;font-variation-settings:"wght" 600;font-size:.9375em;color:var(--color-neutral-200);text-decoration:none;letter-spacing:-.01em;white-space:nowrap}.nav-bar__logo-full{display:none}.nav-bar__logo-short,.nav--open .nav-bar__logo-full{display:inline}.nav--open .nav-bar__logo-short{display:none}.nav-bar__links{display:flex;align-items:center;gap:.125em;margin-left:auto}.nav-bar__theme-toggle{display:flex;align-items:center;justify-content:center;width:2em;height:2em;border:none;border-radius:50%;background:transparent;color:var(--color-neutral-475);cursor:pointer;transition:color .3s ease,background-color .3s ease;margin-left:auto}.nav-bar__theme-toggle:hover{color:var(--color-neutral-200);background:var(--color-neutral-700)}.nav-bar__link{font-family:HafferMono,monospace;font-size:.625em;text-transform:uppercase;letter-spacing:.05em;color:var(--color-neutral-475);text-decoration:none;padding:.5em .75em;border-radius:.25em;transition:color var(--animation-ease),background var(--animation-ease)}.nav-bar__link:hover,.nav-bar__link[aria-current=page]{color:var(--color-neutral-200);background:#ffffff12}.nav-bar__menu-btn{background:none;border:none;color:var(--color-neutral-475);cursor:pointer;display:flex;align-items:center;gap:.5em;padding:.5em .625em;font-family:HafferMono,monospace;font-size:.625em;text-transform:uppercase;letter-spacing:.05em;transition:color var(--animation-ease)}.nav-bar__menu-btn:hover{color:var(--color-neutral-200)}.nav-bar__hamburger{display:flex;flex-direction:column;gap:.25em;width:1.125em}.nav-bar__hamburger span{display:block;height:1.5px;background:currentColor;border-radius:1px;transition:transform .35s var(--nav-ease),opacity .35s var(--nav-ease)}.nav--open .nav-bar__hamburger span:nth-child(1){transform:translateY(.375em) rotate(45deg)}.nav--open .nav-bar__hamburger span:nth-child(2){opacity:0}.nav--open .nav-bar__hamburger span:nth-child(3){transform:translateY(-.375em) rotate(-45deg)}.nav-bar__body{display:grid;grid-template-rows:0fr;transition:grid-template-rows var(--nav-duration) var(--nav-ease)}.nav--open .nav-bar__body{grid-template-rows:1fr}.nav-bar__body-inner{overflow:hidden;opacity:0;transform:translateY(-.25em);transition:opacity .25s ease 0s,transform .25s ease 0s}.nav--open .nav-bar__body-inner{opacity:1;transform:translateY(0);transition:opacity .3s ease .1s,transform .3s var(--nav-ease) .1s}.nav-bar__columns{display:grid;grid-template-columns:1fr 1fr 1.3fr;gap:.75em;padding:.5em .75em 0}.nav-bar__column{background:var(--color-neutral-800);border-radius:.75em;padding:1.5em 1.5em 1.75em}.nav-bar__column-label{font-family:HafferMono,monospace;font-size:.5625em;text-transform:uppercase;letter-spacing:.08em;color:var(--color-neutral-500);display:block;margin-bottom:1.25em}.nav-bar__column-links{display:flex;flex-direction:column}.nav-bar__nav-link{font-family:Haffer,sans-serif;font-variation-settings:"wght" 460;font-size:1.1875em;color:var(--color-neutral-300);text-decoration:none;padding:.625em 0;border-bottom:1px solid var(--color-neutral-700);display:block;transition:color var(--animation-ease)}.nav-bar__nav-link:last-child{border-bottom:none}.nav-bar__nav-link:hover{color:var(--color-white)}.nav-bar__featured{background:var(--color-neutral-800);border-radius:.75em;padding:1.5em;display:flex;flex-direction:column}.nav-bar__featured-label{font-family:HafferMono,monospace;font-size:.5625em;text-transform:uppercase;letter-spacing:.08em;color:var(--color-neutral-500);display:flex;align-items:center;gap:.75em;margin-bottom:1em}.nav-bar__featured-label:after{content:"NEW";font-size:.8em;background:var(--color-electric);color:var(--color-neutral-900);padding:.2em .5em;border-radius:.25em;font-weight:600}.nav-bar__featured-card{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center;gap:.875em}.nav-bar__featured-title{font-family:Haffer,sans-serif;font-variation-settings:"wght" 600;font-size:2em;letter-spacing:-.03em;line-height:1.1;color:var(--color-neutral-200);margin:0}.nav-bar__featured-img{width:100%;aspect-ratio:4/3;background:var(--color-neutral-700);border-radius:.5em;display:flex;align-items:center;justify-content:center;font-family:HafferMono,monospace;font-size:.625em;text-transform:uppercase;letter-spacing:.05em;color:var(--color-neutral-500);overflow:hidden}.nav-bar__featured-btn{font-family:HafferMono,monospace;font-size:.6875em;text-transform:uppercase;letter-spacing:.05em;color:var(--color-neutral-300);text-decoration:none;border:1px solid var(--color-neutral-600);border-radius:.375em;padding:.625em 1.5em;transition:background var(--animation-ease),color var(--animation-ease),border-color var(--animation-ease)}.nav-bar__featured-btn:hover{background:var(--color-neutral-700);border-color:var(--color-neutral-500);color:var(--color-white)}.nav-bar__footer{padding:1.125em .75em 1em;display:flex;align-items:center}.nav-bar__socials{display:flex;gap:.5em}.nav-bar__social{width:2.75em;height:2.75em;border-radius:50%;border:1px solid var(--color-neutral-600);display:flex;align-items:center;justify-content:center;color:var(--color-neutral-400);text-decoration:none;font-family:Haffer,sans-serif;font-size:.75em;font-variation-settings:"wght" 600;transition:background var(--animation-ease),color var(--animation-ease),border-color var(--animation-ease)}.nav-bar__social:hover{background:var(--color-neutral-700);border-color:var(--color-neutral-500);color:var(--color-white)}@media screen and (max-width:767px){.nav-bar__links{display:none}.nav-bar__columns{grid-template-columns:1fr}.nav-bar__featured{display:none}.nav-bar__header{height:3em}}.site-footer{border-top:1px solid var(--color-neutral-700);padding:var(--gap-xl) var(--container-padding);display:flex;justify-content:space-between;align-items:center;gap:var(--gap-m);flex-wrap:wrap}.site-footer__left{font-family:HafferMono,monospace;font-size:.6875em;color:var(--color-neutral-500);text-transform:uppercase;letter-spacing:.05em}.site-footer__links{display:flex;gap:var(--gap-s);flex-wrap:wrap}.site-footer__link{font-family:HafferMono,monospace;font-size:.6875em;color:var(--color-neutral-500);text-decoration:none;text-transform:uppercase;letter-spacing:.05em;transition:color var(--animation-ease)}.site-footer__link:hover{color:var(--color-neutral-200)}.page{padding-top:calc(var(--nav-bar-height) + var(--gap-xl));min-height:100vh}.page-header{padding:var(--padding-xs) var(--container-padding) var(--gap-xl);border-bottom:1px solid var(--color-neutral-700);margin-bottom:var(--gap-xl)}.page-header__eyebrow{margin-bottom:var(--gap-xs);color:var(--color-neutral-500)}.page-header__title{color:var(--color-neutral-200)}.section{padding:var(--gap-xl) var(--container-padding)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(18em,1fr));gap:var(--gap-m);padding:0 var(--container-padding)}.project-card{border:1px solid var(--color-neutral-700);border-radius:.5em;overflow:hidden;text-decoration:none;color:inherit;display:block;transition:border-color var(--animation-ease),transform var(--animation-ease)}.project-card:hover{border-color:var(--color-neutral-500);transform:translateY(-.125em)}.project-card__cover{height:10em;display:flex;align-items:center;justify-content:center}.project-card__body{padding:var(--gap-s)}.project-card__tags{display:flex;gap:var(--gap-xxs);flex-wrap:wrap;margin-top:var(--gap-xs)}.tag-pill{font-family:HafferMono,monospace;font-size:.6em;text-transform:uppercase;letter-spacing:.05em;color:var(--color-neutral-500);border:1px solid var(--color-neutral-600);border-radius:10em;padding:.4em .75em}.article-list{display:flex;flex-direction:column;padding:0 var(--container-padding)}.article-item{display:flex;justify-content:space-between;align-items:baseline;gap:var(--gap-m);padding:var(--gap-s) 0;border-bottom:1px solid var(--color-neutral-700);text-decoration:none;color:inherit;transition:color var(--animation-ease)}.article-item:hover{color:var(--color-electric)}.article-item__meta{font-family:HafferMono,monospace;font-size:.6875em;color:var(--color-neutral-500);white-space:nowrap}.uses-category{padding:var(--gap-m) var(--container-padding);border-bottom:1px solid var(--color-neutral-700)}.uses-items{display:flex;flex-direction:column;gap:var(--gap-xs);margin-top:var(--gap-s)}.uses-item{display:flex;gap:var(--gap-m)}.uses-item__name{font-variation-settings:"wght" 600;min-width:12em}.uses-item__desc{color:var(--color-neutral-500)}.hero{padding:var(--padding-m) var(--container-padding) var(--gap-xl);display:flex;flex-direction:column;gap:var(--gap-m)}.hero__title{font-family:HafferXH,sans-serif;font-size:clamp(3em,8vw,7em);letter-spacing:-.04em;line-height:1;color:var(--color-neutral-200)}.hero__subtitle{font-size:1.1875em;color:var(--color-neutral-500);max-width:32em;font-variation-settings:"wght" 420;line-height:1.6}.contact-form{display:flex;flex-direction:column;gap:var(--gap-s);max-width:32em;padding:0 var(--container-padding)}.form-field{display:flex;flex-direction:column;gap:var(--gap-xxs)}.form-label{font-family:HafferMono,monospace;font-size:.6875em;text-transform:uppercase;letter-spacing:.05em;color:var(--color-neutral-500)}.form-input,.form-textarea{background:var(--color-neutral-800);border:1px solid var(--color-neutral-600);border-radius:.375em;color:var(--color-neutral-200);font-family:Haffer,sans-serif;font-size:1em;padding:.75em 1em;width:100%;outline:none;transition:border-color var(--animation-ease)}.form-input:focus,.form-textarea:focus{border-color:var(--color-neutral-475)}.form-textarea{min-height:8em;resize:vertical}.btn-primary{background:var(--color-neutral-200);color:var(--color-neutral-900);border:none;border-radius:10em;font-family:Haffer,sans-serif;font-variation-settings:"wght" 600;font-size:.9375em;padding:.75em 2em;cursor:pointer;align-self:flex-start;transition:background var(--animation-ease),color var(--animation-ease)}.btn-primary:hover{background:var(--color-electric);color:var(--color-neutral-900)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:transparent;color:var(--color-neutral-200);border:1px solid var(--color-neutral-600);border-radius:10em;font-family:Haffer,sans-serif;font-variation-settings:"wght" 600;font-size:.9375em;padding:.75em 2em;cursor:pointer;align-self:flex-start;transition:border-color var(--animation-ease),color var(--animation-ease);text-decoration:none}.btn-secondary:hover{border-color:var(--color-neutral-200);color:var(--color-neutral-100)}.tag-pill:focus-visible,.btn-primary:focus-visible,.btn-secondary:focus-visible,.nav-bar__link:focus-visible,.project-card:focus-visible,.article-item:focus-visible,.sp-book:focus-visible,a:focus-visible{outline:2px solid var(--color-neutral-500);outline-offset:2px}.form-error{color:var(--color-coral);font-family:HafferMono,monospace;font-size:.8125em}.sp-page{background:var(--color-neutral-900);color:var(--color-neutral-200);position:relative}.sp-page .page-header{padding-top:2em}.sp-canvas{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:1;pointer-events:none}.sp-overlay{position:relative;z-index:2}.sp-jump-nav{display:flex;gap:.4em;padding:0 var(--container-padding);margin-bottom:var(--gap-l);flex-wrap:wrap;align-items:center}.sp-jump-nav__pill{font-family:HafferMono,monospace;font-size:.7em;text-transform:uppercase;letter-spacing:.06em;color:var(--color-neutral-500);background:transparent;border:1px solid var(--color-neutral-800);border-radius:10em;padding:.45em 1.1em;cursor:pointer;transition:color .3s ease,border-color .3s ease,background .3s ease;white-space:nowrap}.sp-jump-nav__pill:hover{color:var(--color-neutral-300);border-color:var(--color-neutral-600)}.sp-jump-nav__pill--active{color:var(--color-neutral-100);border-color:var(--color-neutral-400);background:#ffffff0f}.sp-jump-nav__count{margin-left:.5em;opacity:.45}.sp-section{margin-bottom:1em}.sp-section__header{position:sticky;top:0;z-index:4;display:flex;align-items:center;justify-content:space-between;padding:.75em 0;margin-bottom:.5em;background:var(--color-neutral-900);border-bottom:1px solid var(--color-neutral-850, rgba(255,255,255,.06))}.sp-section__name{font-family:HafferMono,monospace;font-size:.6875em;text-transform:uppercase;letter-spacing:.08em;color:var(--color-neutral-400)}.sp-section__count{font-family:HafferMono,monospace;font-size:.625em;color:var(--color-neutral-600);letter-spacing:.04em}.sp-section__books{display:flex;flex-direction:column;gap:1.75em}.sp-stack{max-width:44em;margin:0 auto;padding:0 var(--container-padding) 4em;display:flex;flex-direction:column;gap:0}.sp-book{display:flex;align-items:center;width:100%;padding:1em 1.5em;min-height:3.5em;background:transparent;border:none;border-radius:.25em;cursor:pointer;color:var(--color);text-align:left;position:relative;z-index:2}.sp-book--fallback{background:var(--bg);box-shadow:0 4px 16px #0003;border-radius:.25em}.sp-book__author{font-family:Georgia,Times New Roman,serif;font-size:.8125em;flex-shrink:0;width:10em;letter-spacing:-.01em;color:var(--sub)}.sp-book__title{font-family:Georgia,Times New Roman,serif;font-size:.9375em;flex:1;letter-spacing:-.01em}.sp-book__badge{font-family:HafferMono,monospace;font-size:.5em;text-transform:uppercase;letter-spacing:.06em;border:1px solid var(--sub);color:var(--sub);border-radius:10em;padding:.35em .9em;margin-right:.75em;flex-shrink:0}.sp-book__icon{flex-shrink:0;width:2em;height:2em;border-radius:50%;border:1px solid var(--sub);color:var(--sub);display:flex;align-items:center;justify-content:center;margin-left:.75em;font-size:.875em;transition:transform .3s var(--cubic-default, ease)}.sp-book:hover .sp-book__icon{transform:rotate(45deg)}.sp-book__author,.sp-book__title,.sp-book__badge,.sp-book__icon{display:none}.sp-page--detail .sp-canvas{z-index:5}.sp-overlay--hidden{visibility:hidden;pointer-events:none}.sp-detail{position:fixed;top:0;right:0;bottom:0;left:0;z-index:4;background:var(--detail-bg, var(--color-neutral-900));display:grid;grid-template-columns:1fr 1fr;align-items:center}.sp-detail__book-area{pointer-events:none}.sp-detail__info{display:flex;flex-direction:column;gap:.75em;padding:3em;max-width:32em;overflow-y:auto;max-height:100vh;box-sizing:border-box}.sp-detail__title{font-family:Georgia,Times New Roman,serif;font-size:2.25em;line-height:1.15;letter-spacing:-.02em;margin:0}.sp-detail__author{font-family:Georgia,Times New Roman,serif;font-style:italic;font-size:.9375em;margin:0}.sp-detail__tags{display:flex;flex-wrap:wrap;gap:.375em;margin-top:.5em}.sp-detail__tag{font-family:HafferMono,monospace;font-size:.625em;text-transform:uppercase;letter-spacing:.04em;background:transparent;border:1px solid;border-radius:.25em;padding:.35em .7em}.sp-detail__desc{font-family:Georgia,Times New Roman,serif;font-size:.9375em;line-height:1.75;margin:.75em 0 0}.sp-detail__meta{display:flex;align-items:center;gap:1em;flex-wrap:wrap;margin-top:1em;padding-top:1em;border-top:1px solid}.sp-detail__meta-item{font-family:HafferMono,monospace;font-size:.6875em}.sp-detail__close{font-family:HafferMono,monospace;font-size:.75em;letter-spacing:.04em;background:transparent;border:1px solid;border-radius:10em;padding:.6em 1.5em;cursor:pointer;margin-top:1.5em;align-self:flex-start;transition:opacity .3s ease}.sp-detail__close:hover{opacity:.7}.sp-stars{display:inline-flex;gap:.125em;font-size:.875em}.sp-star--filled{color:var(--color-electric)}.sp-star--empty{color:var(--color-neutral-700)}.sp-end{max-width:36em;margin:0 auto;padding:2em var(--container-padding) 2em;text-align:center}.sp-end__blurb{font-size:.875em;line-height:1.7;color:var(--color-neutral-600);margin:0}.sp-end__blurb a{color:var(--color-neutral-475);text-decoration:underline}.sp-scrollbar{position:fixed;left:.5em;top:50%;transform:translateY(-50%);z-index:10;display:flex;flex-direction:column;align-items:flex-start;gap:4px;pointer-events:none;transition:top .3s ease-out,opacity .3s ease-out}.sp-scrollbar__tick{pointer-events:auto;display:flex;align-items:center;height:3px;border:none;padding:0;cursor:pointer;background:var(--tick-color, var(--color-neutral-600));opacity:.25;border-radius:1px;transition:opacity .25s,width .25s,height .25s;position:relative}.sp-scrollbar__tick:hover{opacity:.6}.sp-scrollbar__tick--active{opacity:.9;height:4px}.sp-scrollbar__label{position:absolute;left:calc(100% + 8px);white-space:nowrap;font-family:HafferMono,monospace;font-size:.625em;color:var(--color-neutral-400);pointer-events:none;letter-spacing:.01em;background:color-mix(in srgb,var(--color-neutral-900) 85%,transparent);padding:2px 6px;border-radius:3px;z-index:11}@media screen and (max-width:767px),screen and (max-height:600px){.sp-scrollbar,.sp-canvas{display:none}.sp-page--detail .sp-canvas{display:block}.sp-book{background:var(--bg);box-shadow:0 4px 16px #0003;color:var(--color);padding:.875em 1.25em;min-height:3em}.sp-book__title,.sp-book__icon{display:flex}.sp-book__title{display:block;flex:1;font-size:.8125em}.sp-book__badge{display:inline-block}.sp-book__author{display:none}.sp-stack{gap:1em}.sp-detail{grid-template-columns:1fr;grid-template-rows:auto 1fr;overflow-y:auto}.sp-detail__book-area{height:40vh;min-height:200px}.sp-detail__info{padding:1.5em;max-height:none}.sp-detail__title{font-size:1.5em}.sp-jump-nav{gap:.3em;padding:0 var(--container-padding)}.sp-jump-nav__pill{font-size:.6em;padding:.4em .8em}.sp-section__header{padding:.6em 0}.sp-section__books{gap:1em}}.grid-2col{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap-xl)}.grid-2col-wide{display:grid;grid-template-columns:2fr 1fr;gap:var(--gap-xl)}@media screen and (max-width:767px){.grid-2col,.grid-2col-wide{grid-template-columns:1fr}.h-display{font-size:3.5em}.h-xl{font-size:3em}.h-l{font-size:2.25em}.h-m{font-size:1.75em}.hero__title{font-size:clamp(2.5em,10vw,5em)}.uses-item{flex-direction:column;gap:var(--gap-xxs)}.uses-item__name{min-width:unset}.article-item{flex-direction:column;gap:var(--gap-xxs)}.projects-grid{grid-template-columns:1fr}}.aid-page{background:var(--color-neutral-100)}.aid-container{max-width:52em;margin:0 auto;padding:0 var(--container-padding) var(--gap-xl)}.aid-input-section{margin-bottom:var(--gap-l)}.aid-textarea-wrap{position:relative}.aid-textarea{width:100%;min-height:14em;padding:1.25em;font-family:HafferMono,monospace;font-size:.875em;line-height:1.7;color:var(--color-neutral-900);background:var(--color-neutral-200);border:1px solid var(--color-neutral-300);border-radius:.5em;resize:vertical;transition:border-color .2s ease;box-sizing:border-box}.aid-textarea:focus{outline:none;border-color:var(--color-neutral-500)}.aid-textarea:disabled{opacity:.5;cursor:not-allowed}.aid-textarea::-moz-placeholder{color:var(--color-neutral-400)}.aid-textarea::placeholder{color:var(--color-neutral-400)}.aid-char-count{position:absolute;bottom:.75em;right:1em;font-size:.75em;font-family:HafferMono,monospace;color:var(--color-neutral-400)}.aid-char-count[data-low]{color:#ef4444}.aid-actions{display:flex;align-items:center;gap:var(--gap-xs);margin-top:var(--gap-xs)}.aid-submit{min-width:10em}.aid-clear{background:none;border:1px solid var(--color-neutral-300);color:var(--color-neutral-600);padding:.6em 1.2em;border-radius:.375em;font-size:.875em;cursor:pointer;transition:border-color .2s ease,color .2s ease}.aid-clear:hover{border-color:var(--color-neutral-500);color:var(--color-neutral-800)}.aid-hint{margin-left:auto;font-size:.75em;font-family:HafferMono,monospace;color:var(--color-neutral-400)}.aid-error{margin-top:var(--gap-xs);padding:.75em 1em;font-size:.875em;color:#ef4444;background:#ef444414;border-radius:.375em}.aid-loading{display:flex;flex-direction:column;align-items:center;gap:var(--gap-xs);padding:var(--gap-l) 0;color:var(--color-neutral-500);font-size:.875em}.aid-spinner{width:2em;height:2em;border:2px solid var(--color-neutral-300);border-top-color:var(--color-neutral-700);border-radius:50%;animation:aid-spin .8s linear infinite}@keyframes aid-spin{to{transform:rotate(360deg)}}.aid-results{display:flex;flex-direction:column;gap:var(--gap-m)}.aid-verdict-card{background:var(--color-neutral-950);color:#fff;border-radius:.75em;padding:2em}.aid-verdict-main{display:flex;flex-direction:column;gap:.25em;margin-bottom:1.5em}.aid-verdict-label{font-size:.75em;font-family:HafferMono,monospace;text-transform:uppercase;letter-spacing:.08em;color:#ffffff80}.aid-verdict-text{font-family:HafferXH,sans-serif;font-size:2em;font-weight:700;letter-spacing:-.02em;line-height:1.1}.aid-verdict-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1em}.aid-stat{display:flex;flex-direction:column;gap:.25em}.aid-stat-label{font-size:.7em;font-family:HafferMono,monospace;text-transform:uppercase;letter-spacing:.06em;color:#fff6}.aid-stat-value{font-size:1.25em;font-weight:600;color:#ffffffe6}.aid-scores-card,.aid-heatmap-card{background:#fff;border:1px solid var(--color-neutral-200);border-radius:.75em;padding:2em}.aid-section-title{font-family:HafferXH,sans-serif;font-size:1.125em;font-weight:600;letter-spacing:-.02em;margin:0 0 .25em}.aid-section-sub{font-size:.8em;color:var(--color-neutral-500);margin:0 0 1.5em}.aid-scores-list{display:flex;flex-direction:column;gap:.75em}.aid-score-row{display:grid;grid-template-columns:11em 1fr 3em;gap:.75em;align-items:center}.aid-score-label{display:flex;justify-content:space-between;font-size:.8125em;color:var(--color-neutral-700)}.aid-score-weight{font-family:HafferMono,monospace;font-size:.85em;color:var(--color-neutral-400)}.aid-score-track{height:.5em;background:var(--color-neutral-200);border-radius:.25em;overflow:hidden}.aid-score-fill{height:100%;border-radius:.25em}.aid-score-value{font-family:HafferMono,monospace;font-size:.8125em;text-align:right;color:var(--color-neutral-600)}.aid-heatmap-iframe{width:100%;min-height:200px;border:none;border-radius:.5em;background:#fafafa}@media(max-width:640px){.aid-verdict-stats{grid-template-columns:repeat(2,1fr)}.aid-score-row{grid-template-columns:1fr;gap:.25em}.aid-score-label{font-size:.75em}.aid-hint{display:none}}.admin-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;animation:adminFadeIn .2s ease}@keyframes adminFadeIn{0%{opacity:0}to{opacity:1}}.admin-login{background:var(--color-neutral-900);border:1px solid var(--color-neutral-800);border-radius:8px;padding:2em;width:100%;max-width:360px}.admin-login h2{font-family:HafferXH,sans-serif;font-size:1.25em;letter-spacing:-.02em;margin-bottom:1em}.admin-login input{width:100%;padding:.75em 1em;background:var(--color-neutral-950);border:1px solid var(--color-neutral-800);border-radius:6px;color:var(--color-neutral-200);font-family:HafferMono,monospace;font-size:.875em;outline:none;transition:border-color .2s}.admin-login input:focus{border-color:var(--color-neutral-600)}.admin-login__actions{display:flex;gap:.75em;margin-top:1em}.admin-login__error{color:var(--color-coral);font-size:.8em;margin-top:.5em;font-family:HafferMono,monospace}.admin-btn{padding:.6em 1.2em;border:none;border-radius:6px;font-family:HafferMono,monospace;font-size:.8em;cursor:pointer;transition:background .15s,color .15s}.admin-btn--primary{background:var(--color-neutral-200);color:var(--color-neutral-950)}.admin-btn--primary:hover{background:var(--color-neutral-100)}.admin-btn--ghost{background:transparent;color:var(--color-neutral-500)}.admin-btn--ghost:hover{color:var(--color-neutral-300)}.admin-toolbar{position:fixed;top:0;left:0;right:0;height:36px;background:var(--color-neutral-950);border-bottom:1px solid var(--color-neutral-800);display:flex;align-items:center;justify-content:space-between;padding:0 1em;z-index:9998;font-family:HafferMono,monospace;font-size:.7em;color:var(--color-neutral-500)}.admin-toolbar__status{display:flex;align-items:center;gap:.5em}.admin-toolbar__dot{width:6px;height:6px;border-radius:50%;background:var(--color-electric)}.admin-toolbar__dot--deploying{background:var(--color-coral);animation:adminPulse 1s infinite}@keyframes adminPulse{50%{opacity:.4}}.admin-toolbar__actions{display:flex;gap:.75em;align-items:center}body.admin-active{padding-top:36px}.admin-edit-btn{position:absolute;top:.5em;right:.5em;background:var(--color-neutral-900);border:1px solid var(--color-neutral-700);color:var(--color-neutral-400);width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .15s,background .15s;z-index:10;font-size:.75em}.project-card:hover .admin-edit-btn,.article-item:hover .admin-edit-btn,.uses-category:hover .admin-edit-btn,.admin-edit-btn:focus-visible{opacity:1}.admin-edit-btn:hover{background:var(--color-neutral-800);color:var(--color-neutral-200)}.editor-panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:9999}.editor-panel{position:fixed;top:0;right:0;bottom:0;width:480px;max-width:90vw;background:var(--color-neutral-900);border-left:1px solid var(--color-neutral-800);z-index:10000;display:flex;flex-direction:column;animation:editorSlideIn .25s var(--cubic-default)}@keyframes editorSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.editor-panel__header{display:flex;align-items:center;justify-content:space-between;padding:1em 1.5em;border-bottom:1px solid var(--color-neutral-800)}.editor-panel__header h3{font-family:HafferXH,sans-serif;font-size:1em;letter-spacing:-.02em}.editor-panel__body{flex:1;overflow-y:auto;padding:1.5em;display:flex;flex-direction:column;gap:1.25em}.editor-panel__footer{padding:1em 1.5em;border-top:1px solid var(--color-neutral-800);display:flex;gap:.75em;justify-content:flex-end}.editor-field label{display:block;font-family:HafferMono,monospace;font-size:.7em;color:var(--color-neutral-500);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.4em}.editor-field input,.editor-field textarea,.editor-field select{width:100%;padding:.6em .8em;background:var(--color-neutral-950);border:1px solid var(--color-neutral-800);border-radius:6px;color:var(--color-neutral-200);font-family:inherit;font-size:.875em;outline:none;transition:border-color .2s}.editor-field input:focus,.editor-field textarea:focus,.editor-field select:focus{border-color:var(--color-neutral-600)}.editor-field textarea{min-height:120px;resize:vertical;font-family:HafferMono,monospace;font-size:.8em;line-height:1.6}.admin-toast{position:fixed;bottom:1.5em;right:1.5em;padding:.75em 1.25em;border-radius:8px;font-family:HafferMono,monospace;font-size:.8em;z-index:10001;animation:adminFadeIn .2s ease}.admin-toast--success{background:#1a2e1a;color:var(--color-electric);border:1px solid #2a3e2a}.admin-toast--error{background:#2e1a1a;color:var(--color-coral);border:1px solid #3e2a2a}.admin-add-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5em;border:2px dashed var(--color-neutral-700);border-radius:8px;background:transparent;color:var(--color-neutral-500);font-family:HafferMono,monospace;font-size:.8em;cursor:pointer;padding:2em;min-height:180px;transition:border-color .15s,color .15s}.admin-add-card:hover{border-color:var(--color-neutral-500);color:var(--color-neutral-300)}.admin-add-card__icon{font-size:1.5em;line-height:1}.admin-add-card--row{flex-direction:row;min-height:auto;padding:1em 1.5em;width:100%}.admin-dashboard-card{background:var(--color-neutral-900);border-radius:.5em;padding:var(--gap-m)}@media(max-width:768px){.admin-dashboard-layout{grid-template-columns:1fr!important}}.mg-wrap{position:relative}.mg-comp-group{margin-bottom:var(--gap-m)}.mg-comp-label{font-family:HafferMono,monospace;font-size:.7em;color:var(--color-neutral-500);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.4em}.mg-grid{display:grid;grid-template-columns:repeat(auto-fill,18px);gap:3px}.mg-cell{width:18px;height:18px;border-radius:3px;border:2px solid transparent;cursor:pointer;padding:0;transition:transform .15s var(--cubic-default),opacity .15s}.mg-cell:hover:not(:disabled){transform:scale(1.4);z-index:2}.mg-cell:disabled{cursor:default;opacity:.4}.mg-cell--active{transform:scale(1.4);outline:2px solid var(--color-neutral-400);outline-offset:1px;z-index:2}.mg-popover{position:absolute;top:-.5em;right:0;background:var(--color-neutral-900);border:1px solid var(--color-neutral-700);border-radius:8px;padding:1em 1.25em;min-width:180px;z-index:10;animation:mgFadeIn .15s ease}@keyframes mgFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.mg-popover__comp{font-family:HafferMono,monospace;font-size:.65em;color:var(--color-neutral-500);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.25em}.mg-popover__opponent{font-family:HafferXH,sans-serif;font-size:1em;color:var(--color-neutral-100);letter-spacing:-.02em;margin-bottom:.35em}.mg-popover__meta{display:flex;gap:.75em;font-size:.8em;color:var(--color-neutral-500);margin-bottom:.5em}.mg-popover__score{font-family:HafferMono,monospace;font-size:1.5em;line-height:1;margin-bottom:.25em}.mg-popover__watched{font-family:HafferMono,monospace;font-size:.7em;color:var(--color-neutral-500)}.mg-legend{display:flex;gap:1em;margin-top:var(--gap-m);flex-wrap:wrap}.mg-legend__item{display:flex;align-items:center;gap:.35em;font-size:.75em;color:var(--color-neutral-500)}.mg-legend__dot{width:10px;height:10px;border-radius:2px;flex-shrink:0}
