@font-face{font-family:Haffer;src:url(/assets/HafferStandardUprights-VF-DH_wIJtI.woff2) format("woff2");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: #141416;--color-neutral-900: #0a0a0c;--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: #8b5cf6;--color-coral: #f43f5e;--color-cyan: #22d3ee;--color-amber: #f59e0b;--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)));--font-display: "HafferXH", sans-serif;--font-mono: "HafferMono", monospace;--font-body: "Haffer", sans-serif;--prose-width: 42em}[data-theme=light]{--color-neutral-100: var(--palette-text, #18181b);--color-neutral-200: var(--palette-text, #18181b);--color-neutral-300: #3f3f46;--color-neutral-400: #52525b;--color-neutral-450: #71717a;--color-neutral-475: #a1a1aa;--color-neutral-500: #a1a1aa;--color-neutral-525: #d4d4d8;--color-neutral-550: #e4e4e7;--color-neutral-600: #f4f4f5;--color-neutral-700: rgba(0,0,0,.06);--color-neutral-800: var(--palette-surface, #f4f4f5);--color-neutral-900: var(--palette-bg, #fafafa);--color-neutral-950: var(--palette-bg, #fafafa);--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: #16a34a;--color-purple: #7c3aed;--color-coral: #e11d48;--color-cyan: #0891b2;--color-amber: #d97706}[data-theme=light-warm]{--color-neutral-100: var(--palette-text, #2d2016);--color-neutral-200: var(--palette-text, #2d2016);--color-neutral-300: #4a4040;--color-neutral-400: #6a5a50;--color-neutral-450: #806a60;--color-neutral-475: #907a70;--color-neutral-500: #a09080;--color-neutral-525: #b8a898;--color-neutral-550: #d0c4b8;--color-neutral-600: #e0d8d0;--color-neutral-700: rgba(0,0,0,.08);--color-neutral-800: var(--palette-surface, #f0ebe4);--color-neutral-900: var(--palette-bg, #faf5ef);--color-neutral-950: var(--palette-bg, #faf5ef)}[data-theme=light-warm] body{background-color:var(--palette-bg, #faf5ef);color:var(--palette-text, #2d2016)}[data-theme=light-warm] body:before{background:none}[data-theme=light-warm] .hero__title{background:none;-webkit-text-fill-color:var(--palette-text);color:var(--palette-text)}[data-theme=light-warm] .eyebrow{color:var(--palette-accent)}[data-theme=light-warm] .btn-primary{background:var(--palette-accent);color:#fff;box-shadow:0 4px 16px #0000001a}[data-theme=light-warm] .btn-secondary{background:transparent;border-color:#00000026;color:var(--palette-text)}[data-theme=light-warm] .nav-bar{background:#fffc;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-color:#00000014;box-shadow:0 2px 16px #0000000f}[data-theme=light-warm] .project-card,[data-theme=light-warm] .pin-card{background:#fff9;border-color:#0000000f;box-shadow:0 1px 8px #0000000a}[data-theme=light-warm] .project-card:hover,[data-theme=light-warm] .pin-card:hover{background:#fffc;box-shadow:0 4px 20px #00000014}[data-theme=light-warm] .nav-bar__column,[data-theme=light-warm] .nav-bar__featured{background:var(--palette-surface);border-color:#0000000f}[data-theme=light-warm] .nav-bar__theme-toggle{background:#0000000d;border-color:#0000001a}[data-theme=light-warm] .pins-search{background:#fff9;border-color:#0000001a;color:var(--palette-text)}[data-theme=light-warm] .site-footer,[data-theme=light-warm] .article-item{border-color:#0000000f}[data-theme=light-warm] .project-card:before{background:none}[data-theme=light-warm] .article-content .article-code{background:var(--palette-surface);border-color:#00000014;color:var(--palette-text)}[data-theme=light-warm] .article-content .article-inline-code{background:#0000000f;color:var(--palette-accent)}[data-theme=light] body{background-color:var(--palette-bg, #1e3ae0);color:var(--palette-text, #ffffff)}[data-theme=light] body:before{background:radial-gradient(ellipse 80% 60% at 20% 10%,rgba(100,140,255,.4) 0%,transparent 50%),radial-gradient(ellipse 60% 80% at 80% 20%,rgba(80,120,255,.3) 0%,transparent 45%),radial-gradient(ellipse 100% 50% at 50% 60%,rgba(60,100,240,.25) 0%,transparent 50%),radial-gradient(ellipse 70% 70% at 75% 85%,rgba(100,150,255,.3) 0%,transparent 45%),radial-gradient(ellipse 50% 80% at 10% 70%,rgba(70,110,255,.2) 0%,transparent 40%);filter:blur(60px);animation:blueGlow 20s ease-in-out infinite alternate}@keyframes blueGlow{0%{background-position:20% 10%,80% 20%,50% 60%,75% 85%,10% 70%}50%{background-position:30% 20%,70% 30%,45% 50%,65% 75%,20% 80%}to{background-position:15% 15%,85% 15%,55% 55%,80% 80%,15% 65%}}[data-theme=light] .hero__title{background:linear-gradient(135deg,#fff,#c8d0f0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}[data-theme=light] .btn-primary{background:#fff;color:#1e3ae0;box-shadow:0 4px 16px #00000026}[data-theme=light] .btn-primary:hover{background:#f0f2ff;box-shadow:0 6px 24px #0003}[data-theme=light] .btn-secondary{background:#ffffff1f;border-color:#ffffff40;color:#fff}[data-theme=light] .eyebrow{color:#ffffffb3}[data-theme=light] .nav-bar{background:#ffffff1a;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-color:#ffffff26;box-shadow:0 4px 24px #0000001a,inset 0 1px #ffffff26}[data-theme=light] .pin-card,[data-theme=light] .project-card{background:#ffffff1a;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-color:#fff3;box-shadow:0 2px 12px #0000001f}[data-theme=light] .pin-card:hover,[data-theme=light] .project-card:hover{background:#ffffff2e;border-color:#ffffff59;box-shadow:0 8px 32px #0000002e;transform:translateY(-3px)}[data-theme=light] .project-card:before{background:linear-gradient(180deg,rgba(255,255,255,.06) 0%,transparent 100%)}[data-theme=light] .nav--open .nav-bar{background:linear-gradient(135deg,#0f1eb4d9,#0a1496eb);border-color:#ffffff1f;box-shadow:0 8px 40px #00000040,inset 0 1px #ffffff1a}[data-theme=light] .nav-bar__column,[data-theme=light] .nav-bar__featured{background:#0005288c;border-color:#ffffff1a}[data-theme=light] .nav-bar__nav-link{color:#fff!important;opacity:1!important;transform:none!important}[data-theme=light] .nav-bar__nav-link:hover{color:#fbbf24!important}[data-theme=light] .nav-bar__column-label,[data-theme=light] .nav-bar__featured-label{color:#ffffffd9}[data-theme=light] .nav-bar__social,[data-theme=light] .nav-bar__featured-btn{color:#fff;border-color:#fff6;background:#ffffff1a}[data-theme=light] .nav-bar__menu-btn{color:#fff}[data-theme=light] .article-content .article-code{background:#000a3c4d;border-color:#ffffff1a;color:#e8ecff}[data-theme=light] .article-content .article-inline-code{background:#ffffff1f;border-color:#fff3;color:#67e8f9}[data-theme=light] .site-footer,[data-theme=light] .article-item{border-color:#ffffff1a}[data-theme=light] .link-row{border-color:#ffffff14}[data-theme=light] .pins-search{background:#000a3c40;border-color:#ffffff26;color:#fff}[data-theme=light] .pins-search::-moz-placeholder{color:#ffffff80}[data-theme=light] .pins-search::placeholder{color:#ffffff80}[data-theme=light] .pins-search:focus{border-color:#fff6;box-shadow:0 0 0 3px #ffffff1a}[data-theme=light] .pins-cat-btn{background:#ffffff14;border-color:#ffffff26;color:#ffffffb3}[data-theme=light] .pins-cat-btn:hover{background:#ffffff26}[data-theme=light] .nav-bar__theme-toggle{background:#ffffff1a;border-color:#fff3}@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(--palette-bg, #0a0a0c);color:var(--palette-text, #f4f4f4);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;background:radial-gradient(ellipse 80% 60% at 10% 20%,rgba(34,211,238,.12) 0%,transparent 55%),radial-gradient(ellipse 60% 80% at 85% 15%,rgba(139,92,246,.1) 0%,transparent 50%),radial-gradient(ellipse 70% 50% at 50% 80%,rgba(20,184,166,.08) 0%,transparent 45%),radial-gradient(ellipse 50% 70% at 80% 70%,rgba(244,63,94,.07) 0%,transparent 45%),radial-gradient(ellipse 90% 40% at 30% 50%,rgba(161,255,98,.05) 0%,transparent 55%);animation:meshDrift 25s ease-in-out infinite alternate;pointer-events:none}@keyframes meshDrift{0%{background-position:0% 0%,100% 0%,50% 100%,80% 70%,30% 50%;filter:blur(60px)}25%{background-position:20% 30%,70% 20%,40% 70%,60% 80%,50% 40%;filter:blur(70px)}50%{background-position:40% 10%,90% 40%,30% 90%,70% 50%,20% 60%;filter:blur(65px)}75%{background-position:10% 40%,80% 30%,60% 60%,50% 90%,40% 30%;filter:blur(75px)}to{background-position:30% 20%,60% 50%,50% 80%,90% 60%,10% 70%;filter:blur(60px)}}.skip-to-content{position:fixed;top:-100%;left:50%;transform:translate(-50%);z-index:9999;padding:.75em 1.5em;background:var(--color-electric);color:var(--color-neutral-900);font-family:HafferMono,monospace;font-size:.8em;border-radius:0 0 .5em .5em;text-decoration:none;transition:top .2s ease}.skip-to-content:focus{top:0;outline:none}.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;color:var(--color-neutral-500)}.eyebrow--accent{color:var(--palette-accent, var(--color-cyan))}.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)}.mono{font-family:var(--font-mono)}.prose-container{max-width:var(--prose-width);padding:0 var(--container-padding)}.section-header{display:flex;justify-content:space-between;align-items:center;padding:var(--gap-s) 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:100%;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:#0000000d;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:linear-gradient(135deg,#201d1dbf,#151313d9);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border:1px solid rgba(255,255,255,.12);box-shadow:0 4px 24px #0000004d,inset 0 1px #ffffff1a;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:linear-gradient(135deg,#201d1dcc,#0a0a0ceb);backdrop-filter:blur(28px) saturate(180%);-webkit-backdrop-filter:blur(28px) saturate(180%);border-color:#ffffff1a;border-radius:1em;box-shadow:0 8px 40px #00000059,inset 0 1px #ffffff14}.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-icon{width:auto;color:var(--color-neutral-200);transition:opacity .3s var(--cubic-default)}.nav-bar__logo-icon:hover{opacity:.8}[data-theme=light-warm] .nav-bar__logo-icon,[data-theme=light] .nav-bar__logo-icon{color:var(--palette-text, #1a1a1a)}.nav-bar__logo-collapsed{display:block;height:2.25em}.nav-bar__logo-expanded,.nav--open .nav-bar__logo-collapsed{display:none}.nav--open .nav-bar__logo-expanded{display:block;height:3.5em}.nav-bar__links{display:flex;align-items:center;gap:.125em;margin-left:auto}.palette-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(14em,1fr));gap:var(--gap-s);padding:0 var(--container-padding)}.palette-card{display:flex;flex-direction:column;padding:0;border:2px solid rgba(255,255,255,.08);border-radius:.75em;overflow:hidden;cursor:pointer;background:#ffffff0a;transition:all .25s var(--cubic-default);position:relative}.palette-card:hover{border-color:var(--palette-accent, var(--color-cyan));transform:translateY(-2px);box-shadow:0 8px 24px #00000026}.palette-card--active{border-color:var(--palette-accent, var(--color-cyan));box-shadow:0 0 0 1px var(--palette-accent, var(--color-cyan)),0 4px 16px #0000001a}.palette-card__swatches{display:flex;height:4em}.palette-card__swatch{flex:1}.palette-card__info{padding:.6em .75em;display:flex;justify-content:space-between;align-items:center}.palette-card__name{font-family:Haffer,sans-serif;font-variation-settings:"wght" 500;font-size:.85em}.palette-card__type{font-family:HafferMono,monospace;font-size:.55em;text-transform:uppercase;letter-spacing:.08em;color:var(--color-neutral-500)}.palette-card__check{position:absolute;top:.4em;right:.4em;background:var(--palette-accent, var(--color-cyan));color:#000;width:1.4em;height:1.4em;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7em;font-weight:700}.nav-bar__theme-toggle{display:flex;align-items:center;justify-content:center;width:2.75em;height:2.75em;border:1px solid rgba(255,255,255,.1);border-radius:50%;background:#ffffff0f;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);cursor:pointer;font-size:.85em;margin-left:auto;transition:all .3s var(--cubic-default);box-shadow:0 2px 8px #0000001f;line-height:1}.nav-bar__theme-toggle:hover{transform:scale(1.1);box-shadow:0 4px 16px #0003}[data-theme=light] .nav-bar__theme-toggle{background:#0000000a;border-color:#00000014;box-shadow:0 2px 8px #0000000f}.glass{background:linear-gradient(135deg,#ffffff1a,#ffffff08);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,255,255,.15);box-shadow:0 4px 20px #0003,inset 0 1px #ffffff26,inset 0 -1px #00000014;position:relative;transition:all .3s var(--cubic-default)}.glass:before{content:"";position:absolute;top:0;left:10%;right:10%;height:40%;background:linear-gradient(180deg,rgba(255,255,255,.15) 0%,transparent 100%);border-radius:inherit;pointer-events:none;z-index:0}.glass:hover{background:linear-gradient(135deg,#ffffff24,#ffffff0d);border-color:#ffffff38;box-shadow:0 8px 32px #00000040,inset 0 1px #fff3,inset 0 -1px #00000014}[data-theme=light] .glass{background:linear-gradient(135deg,#fff9,#ffffff4d);border-color:#ffffff80;box-shadow:0 4px 20px #0000000f,inset 0 1px #fffc,inset 0 -1px #00000008}[data-theme=light] .glass:before{background:linear-gradient(180deg,rgba(255,255,255,.5) 0%,transparent 100%)}[data-theme=light] .glass:hover{background:linear-gradient(135deg,#ffffffb3,#fff6);border-color:#ffffffb3}.glass-toggle{display:flex;align-items:center;gap:0;width:100%;height:100%;padding:.2em;border:1px solid rgba(255,255,255,.18);border-radius:10em;background:linear-gradient(135deg,#ffffff1a,#ffffff0a);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);cursor:pointer;position:relative;box-shadow:0 4px 16px #00000040,inset 0 1px #ffffff26,inset 0 -1px #0000001a;transition:all .35s var(--cubic-default);overflow:hidden}.glass-toggle:before{content:"";position:absolute;top:0;left:10%;right:10%;height:45%;background:linear-gradient(180deg,rgba(255,255,255,.2) 0%,transparent 100%);border-radius:10em 10em 50% 50%;pointer-events:none}.glass-toggle:hover{border-color:#ffffff47;box-shadow:0 6px 24px #0000004d,inset 0 1px #fff3,inset 0 -1px #0000001a;transform:scale(1.05)}.glass-toggle__thumb{position:absolute;left:.2em;width:1.3em;height:1.3em;border-radius:50%;background:linear-gradient(145deg,#ffffff59,#ffffff1a);border:1px solid rgba(255,255,255,.3);box-shadow:0 2px 10px #0000004d,0 0 20px #8cb4ff14,inset 0 1px #ffffff80,inset 0 -1px 2px #00000026;transition:transform .4s cubic-bezier(.34,1.56,.64,1),background .35s ease,box-shadow .35s ease}.glass-toggle--light .glass-toggle__thumb{transform:translate(1.7em);background:linear-gradient(145deg,#ffdc5080,#ffb42833);border-color:#ffc83280;box-shadow:0 2px 12px #ffa0004d,0 0 24px #ffb43226,inset 0 1px #ffffff80,inset 0 -1px 2px #0000001a}.glass-toggle__icon{position:relative;z-index:1;flex-shrink:0;transition:color .3s ease,filter .3s ease}.glass-toggle__sun{margin-left:.2em;color:#ffffff40}.glass-toggle__moon{margin-left:auto;margin-right:.2em;color:#a0beffd9;filter:drop-shadow(0 0 3px rgba(140,180,255,.4))}.glass-toggle--light .glass-toggle__sun{color:#ffa000f2;filter:drop-shadow(0 0 4px rgba(255,160,0,.5))}.glass-toggle--light .glass-toggle__moon{color:#0003;filter:none}[data-theme=light] .glass-toggle{background:linear-gradient(135deg,#0000000f,#00000005);border-color:#0000001f;box-shadow:0 4px 16px #00000014,inset 0 1px #fff9,inset 0 -1px #00000008}[data-theme=light] .glass-toggle:before{background:linear-gradient(180deg,rgba(255,255,255,.5) 0%,transparent 100%)}[data-theme=light] .glass-toggle:hover{background:linear-gradient(135deg,#00000017,#0000000a);border-color:#0000002e}.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:linear-gradient(135deg,#ffffff12,#ffffff05);backdrop-filter:blur(16px) saturate(160%);-webkit-backdrop-filter:blur(16px) saturate(160%);border:1px solid rgba(255,255,255,.08);border-radius:.75em;padding:1.5em 1.5em 1.75em;box-shadow:inset 0 1px #ffffff14;position:relative}.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;opacity:0;transform:translateY(8px);transition:color var(--duration-default) var(--cubic-default),opacity .4s var(--cubic-default),transform .4s var(--cubic-default)}.nav-bar__nav-link:last-child{border-bottom:none}.nav--open .nav-bar__nav-link{opacity:1;transform:translateY(0)}.nav--open .nav-bar__column:first-child .nav-bar__nav-link:nth-child(1){transition-delay:.08s}.nav--open .nav-bar__column:first-child .nav-bar__nav-link:nth-child(2){transition-delay:.12s}.nav--open .nav-bar__column:first-child .nav-bar__nav-link:nth-child(3){transition-delay:.16s}.nav--open .nav-bar__column:first-child .nav-bar__nav-link:nth-child(4){transition-delay:.2s}.nav--open .nav-bar__column:first-child .nav-bar__nav-link:nth-child(5){transition-delay:.24s}.nav--open .nav-bar__column:first-child .nav-bar__nav-link:nth-child(6){transition-delay:.28s}.nav--open .nav-bar__column:first-child .nav-bar__nav-link:nth-child(7){transition-delay:.32s}.nav--open .nav-bar__column:nth-child(2) .nav-bar__nav-link:nth-child(1){transition-delay:.14s}.nav--open .nav-bar__column:nth-child(2) .nav-bar__nav-link:nth-child(2){transition-delay:.18s}.nav--open .nav-bar__column:nth-child(2) .nav-bar__nav-link:nth-child(3){transition-delay:.22s}.nav-bar__nav-link:hover{color:var(--color-white)}.nav-bar__featured{background:linear-gradient(135deg,#ffffff12,#ffffff05);backdrop-filter:blur(16px) saturate(160%);-webkit-backdrop-filter:blur(16px) saturate(160%);border:1px solid rgba(255,255,255,.08);border-radius:.75em;padding:1.5em;display:flex;flex-direction:column;box-shadow:inset 0 1px #ffffff14}.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)}.section,.page-header,.hero,.article-list,.projects-grid{opacity:0;transform:translateY(30px);transition:opacity .8s var(--cubic-default),transform .8s var(--cubic-default)}.section.in-view,.page-header.in-view,.hero.in-view,.article-list.in-view,.projects-grid.in-view{opacity:1;transform:translateY(0)}.hero{will-change:transform}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(18em,1fr));gap:var(--gap-m);padding:0 var(--container-padding)}.project-card{background:linear-gradient(135deg,#ffffff0f,#ffffff05);backdrop-filter:blur(12px) saturate(150%);-webkit-backdrop-filter:blur(12px) saturate(150%);border:1px solid rgba(255,255,255,.1);border-radius:.75em;overflow:hidden;text-decoration:none;color:inherit;display:block;position:relative;box-shadow:0 4px 16px #00000026,inset 0 1px #ffffff14;transition:all .3s var(--cubic-default)}.project-card:before{content:"";position:absolute;top:0;left:10%;right:10%;height:35%;background:linear-gradient(180deg,rgba(255,255,255,.08) 0%,transparent 100%);border-radius:.75em .75em 50% 50%;pointer-events:none;z-index:1}.project-card:hover{border-color:#fff3;transform:translateY(-4px);box-shadow:0 12px 40px #00000040,0 0 0 1px #a1ff620f,inset 0 1px #ffffff1f}.project-card__cover{height:10em;display:flex;align-items:center;justify-content:center;overflow:hidden}.project-card__image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .4s var(--cubic-default)}.project-card:hover .project-card__image{transform:scale(1.05)}.project-card__refract{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.project-card__logo-bg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover;opacity:.15;filter:grayscale(1);transition:opacity .4s var(--cubic-default)}.project-card:hover .project-card__logo-bg{opacity:.25}.project-card__monogram{position:relative;z-index:1;font-family:var(--font-display, "HafferXH", sans-serif);font-size:1.5em;color:#fff6;letter-spacing:-.03em}.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}.article-content{color:var(--color-neutral-400);line-height:1.8;font-size:1em}.article-content p{margin-bottom:1.25em}.article-content .article-h1{display:none}.article-content .article-h2{font-family:HafferXH,sans-serif;font-size:1.4em;letter-spacing:-.02em;color:var(--color-neutral-200);margin:2em 0 .75em}.article-content .article-h3{font-family:Haffer,sans-serif;font-variation-settings:"wght" 600;font-size:1.15em;color:var(--color-neutral-300);margin:1.5em 0 .5em}.article-content .article-code{background:linear-gradient(135deg,#ffffff0d,#ffffff03);backdrop-filter:blur(12px) saturate(140%);-webkit-backdrop-filter:blur(12px) saturate(140%);border:1px solid rgba(255,255,255,.08);border-radius:.75em;padding:1.25em 1.5em;overflow-x:auto;margin:1.25em 0;font-family:HafferMono,SF Mono,monospace;font-size:.85em;line-height:1.6;color:var(--color-neutral-300);box-shadow:inset 0 1px #ffffff0f}.article-content .article-inline-code{background:var(--color-neutral-800);border:1px solid var(--color-neutral-700);border-radius:.25em;padding:.15em .4em;font-family:HafferMono,monospace;font-size:.88em;color:var(--color-electric)}.article-content .article-list{margin:1em 0;padding-left:1.5em;list-style:disc}.article-content .article-list li{margin-bottom:.4em}.article-content strong{color:var(--color-neutral-200);font-variation-settings:"wght" 600}.article-content em{font-style:italic;color:var(--color-neutral-350, var(--color-neutral-400))}.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;background:linear-gradient(135deg,var(--color-neutral-100) 0%,var(--color-neutral-400) 50%,var(--color-cyan) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.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:linear-gradient(135deg,var(--color-electric) 0%,var(--color-cyan) 100%);color:#0a0a0c;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;box-shadow:0 4px 16px #a1ff6226;transition:all .3s var(--cubic-default)}.btn-primary:hover{box-shadow:0 6px 24px #a1ff6240;transform:translateY(-2px);background:var(--color-electric);color:var(--color-neutral-900)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:linear-gradient(135deg,#ffffff14,#ffffff05);backdrop-filter:blur(12px) saturate(150%);-webkit-backdrop-filter:blur(12px) saturate(150%);color:var(--color-neutral-200);border:1px solid rgba(255,255,255,.12);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;box-shadow:0 2px 10px #0000001f,inset 0 1px #ffffff1a;transition:all .3s var(--cubic-default);text-decoration:none;position:relative;overflow:hidden}.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-electric);outline-offset:2px}.nav-bar__nav-link:focus-visible,.nav-bar__social:focus-visible{outline:2px solid var(--color-electric);outline-offset:2px;border-radius:.25em}.sp-book:focus-visible{outline:2px solid var(--color-electric);outline-offset:-2px;background:#a1ff6214}.form-error{color:var(--color-coral);font-family:HafferMono,monospace;font-size:.8125em}.sp-hero{padding:0 var(--container-padding) var(--gap-l);max-width:60em;margin:0 auto}.sp-hero__label{font-family:HafferMono,monospace;font-size:.6875em;text-transform:uppercase;letter-spacing:.08em;color:var(--color-neutral-400);margin-bottom:var(--gap-s)}.sp-hero-reading__row{display:flex;gap:var(--gap-m);max-width:60em;margin:0 auto;position:relative;justify-content:center}.sp-hero-reading__card{flex:1;min-width:220px;max-width:300px;display:flex;flex-direction:column;align-items:center;text-align:center;padding:1em 1em 1.25em;background:none;border:none;cursor:pointer;position:relative;z-index:2;animation:sp-float var(--float-duration, 4s) var(--float-delay, 0s) ease-in-out infinite}.sp-hero-reading__card:hover{animation-play-state:paused}.sp-hero-reading__book-slot{width:150px;height:210px}.sp-hero-reading__title{font-family:Georgia,Times New Roman,serif;font-size:1.0625em;color:var(--palette-text, #f4f4f4);margin:.75em 0 0}.sp-hero-reading__author{font-family:Georgia,Times New Roman,serif;font-style:italic;font-size:.75em;color:var(--palette-text, #f4f4f4);opacity:.55;margin:.2em 0 0}.sp-hero-want{padding-top:var(--gap-m);border-top:1px solid rgba(255,255,255,.06)}.sp-hero-want__scatter{display:flex;gap:var(--gap-l);padding:var(--gap-l) 0;max-width:100%;overflow-x:auto;position:relative;min-height:260px;align-items:center;justify-content:center;scrollbar-width:none}.sp-hero-want__scatter::-webkit-scrollbar{display:none}.sp-hero-want__item{display:flex;flex-direction:column;align-items:center;flex-shrink:0;background:none;border:none;cursor:pointer;padding:0;position:relative;z-index:2;animation:sp-float var(--float-duration, 4s) var(--float-delay, 0s) ease-in-out infinite}.sp-hero-want__item:hover{animation-play-state:paused;transform:translateY(-8px) scale(1.05)}@keyframes sp-float{0%,to{transform:translateY(var(--scatter-offset, 0))}25%{transform:translateY(calc(var(--scatter-offset, 0) - 12px)) translate(3px)}50%{transform:translateY(calc(var(--scatter-offset, 0) - 20px))}75%{transform:translateY(calc(var(--scatter-offset, 0) - 8px)) translate(-3px)}}.sp-hero-want__book-slot{width:88px;height:123px}.sp-hero-want__label{display:flex;flex-direction:column;align-items:center;margin-top:.5em}.sp-hero-want__title{font-family:HafferMono,monospace;font-size:.625em;color:var(--palette-text, #e8e8e8);opacity:.7;text-align:center;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sp-hero-want__author{font-family:HafferMono,monospace;font-size:.5625em;color:var(--palette-text, #e8e8e8);opacity:.45}.sp-library-cta{padding:var(--gap-xl) var(--container-padding);text-align:center}.sp-library-cta__link{display:inline-flex;align-items:center;gap:.5em;font-family:HafferMono,monospace;font-size:.9375em;color:var(--color-neutral-200);text-decoration:none;padding:.75em 1.5em;border:1px solid rgba(255,255,255,.15);border-radius:.5em;transition:border-color .4s var(--cubic-default, ease),background .4s var(--cubic-default, ease)}.sp-library-cta__link:hover{border-color:#ffffff4d;background:#ffffff0a}.sp-library-cta__arrow{transition:transform .3s var(--cubic-default, ease)}.sp-library-cta__link:hover .sp-library-cta__arrow{transform:translate(4px)}.sp-library-cta__sub{font-family:HafferMono,monospace;font-size:.75em;color:var(--color-neutral-500);margin-top:var(--gap-xs)}.sp-library-back{color:var(--color-neutral-400);text-decoration:none;transition:color .3s var(--cubic-default, ease)}.sp-library-back:hover{color:var(--color-neutral-200)}.sp-book__badge--want{background:#6440ff40;color:#a1ff62d9}.sp-timeline{padding:var(--gap-m) var(--container-padding);max-width:100%;position:relative}.sp-timeline__scroll{display:flex;gap:0;overflow-x:auto;scroll-snap-type:x proximity;padding-top:3.5em;padding-bottom:.5em;scrollbar-width:thin;scrollbar-color:var(--color-neutral-700) transparent}.sp-timeline__scroll::-webkit-scrollbar{height:4px}.sp-timeline__scroll::-webkit-scrollbar-thumb{background:var(--color-neutral-700);border-radius:2px}.sp-timeline__month{display:flex;flex-direction:column;align-items:center;min-width:32px;flex-shrink:0;position:relative;scroll-snap-align:start}.sp-timeline__month--january{border-left:2px solid var(--color-neutral-600);padding-left:4px}.sp-timeline__month--even-year{background:#ffffff05}.sp-timeline__year-header{position:absolute;top:-2.6em;left:0;display:flex;align-items:center;gap:.4em;white-space:nowrap;cursor:default}.sp-timeline__year-header:before{content:"";display:block;width:2px;height:1.6em;background:var(--color-neutral-600);border-radius:1px;flex-shrink:0}.sp-timeline__year{font-family:HafferMono,monospace;font-size:1.5em;font-weight:700;color:var(--color-neutral-300);letter-spacing:-.02em;line-height:1}.sp-timeline__blocks{display:flex;flex-direction:column;align-items:center;gap:2px;min-height:40px;justify-content:flex-end}.sp-timeline__block{width:24px;border:none;border-radius:3px;cursor:pointer;padding:0;transition:transform .15s ease,opacity .15s ease}.sp-timeline__block:hover{transform:scaleX(1.2);opacity:.85}.sp-timeline__block--current{animation:sp-pulse 2s ease-in-out infinite}@keyframes sp-pulse{0%,to{box-shadow:0 0 #ffffff26}50%{box-shadow:0 0 8px 2px #ffffff40}}.sp-timeline__tick{font-family:HafferMono,monospace;font-size:.5em;color:var(--color-neutral-500);margin-top:.5em;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.sp-timeline__month:not(:has(.sp-timeline__tick)){padding-bottom:1.4em}.sp-timeline__tooltip{position:fixed;transform:translate(-50%,-100%);background:#14141659;border:1px solid rgba(255,255,255,.15);border-radius:.75em;padding:.625em .875em;display:flex;flex-direction:column;gap:.2em;z-index:20;pointer-events:none;font-size:.8125em;max-width:240px;box-shadow:0 8px 32px #00000040,inset 0 1px #ffffff14}.sp-timeline__tooltip strong{font-family:Georgia,Times New Roman,serif;color:var(--color-neutral-100)}.sp-timeline__tooltip span{font-family:HafferMono,monospace;font-size:.8em;color:var(--color-neutral-400)}.sp-timeline__tooltip em{font-family:Georgia,Times New Roman,serif;font-size:.875em;color:var(--color-neutral-300);line-height:1.4;margin-top:.25em}.sp-timeline__sparse-msg{font-family:HafferMono,monospace;font-size:.6875em;color:var(--color-neutral-600);text-align:center;margin-top:var(--gap-xs)}.sp-timeline--sparse .sp-timeline__scroll{justify-content:center}.sp-cover-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap-xs);max-width:44em;margin:0 auto;padding:0 var(--container-padding) var(--gap-l)}.sp-cover-grid__cell{aspect-ratio:2 / 3;border:none;border-radius:.375em;overflow:hidden;cursor:pointer;background:var(--cell-accent, var(--color-neutral-800));padding:0;transition:transform .2s var(--cubic-default, ease),box-shadow .2s var(--cubic-default, ease)}.sp-cover-grid__cell:hover{transform:scale(1.03);box-shadow:0 8px 24px #0000004d}.sp-cover-grid__img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.sp-cover-grid__fallback{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1em;text-align:center;gap:.25em}.sp-cover-grid__fallback-title{font-family:Georgia,Times New Roman,serif;font-size:.8125em;line-height:1.3;font-weight:600}.sp-cover-grid__fallback-author{font-family:Georgia,Times New Roman,serif;font-size:.6875em;opacity:.7}.sp-view-toggle{display:flex;gap:.25em;padding:0 var(--container-padding);max-width:44em;margin:0 auto var(--gap-xs)}.sp-view-toggle__btn{font-family:HafferMono,monospace;font-size:.6875em;color:var(--color-neutral-600);background:transparent;border:1px solid var(--color-neutral-800);border-radius:.25em;padding:.35em .7em;cursor:pointer;transition:color .2s ease,border-color .2s ease}.sp-view-toggle__btn--active{color:var(--color-neutral-200);border-color:#fff3;background:#ffffff0f;backdrop-filter:blur(12px) saturate(1.2);-webkit-backdrop-filter:blur(12px) saturate(1.2)}.sp-search{display:flex;align-items:center;gap:.5em;padding:0 var(--container-padding);max-width:44em;margin:0 auto var(--gap-s)}.sp-search__input{flex:1;font-family:HafferMono,monospace;font-size:.8125em;color:var(--color-neutral-200);background:var(--color-neutral-850, rgba(255,255,255,.04));border:1px solid var(--color-neutral-800);border-radius:.375em;padding:.625em 1em;outline:none;transition:border-color .2s ease}.sp-search__input:focus{border-color:var(--color-neutral-600)}.sp-search__input::-moz-placeholder{color:var(--color-neutral-600)}.sp-search__input::placeholder{color:var(--color-neutral-600)}.sp-search__kbd{font-family:HafferMono,monospace;font-size:.625em;color:var(--color-neutral-600);background:var(--color-neutral-850, rgba(255,255,255,.04));border:1px solid var(--color-neutral-800);border-radius:.25em;padding:.3em .5em;flex-shrink:0}.sp-search-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;background:#0009;display:flex;align-items:flex-start;justify-content:center;padding-top:20vh}.sp-search-modal__box{width:90%;max-width:36em;background:#0a0a0cb3;backdrop-filter:blur(20px) saturate(1.3) brightness(1.05);-webkit-backdrop-filter:blur(20px) saturate(1.3) brightness(1.05);border:1px solid rgba(255,255,255,.12);border-radius:.5em;padding:.25em;box-shadow:0 16px 48px #0006,inset 0 1px #ffffff0f}.sp-search-modal__input{width:100%;font-family:HafferMono,monospace;font-size:1em;color:var(--color-neutral-100);background:transparent;border:none;padding:.875em 1em;outline:none}.sp-search-modal__input::-moz-placeholder{color:var(--color-neutral-600)}.sp-search-modal__input::placeholder{color:var(--color-neutral-600)}.sp-sort{font-family:HafferMono,monospace;font-size:.7em;color:var(--color-neutral-400);background:#ffffff0a;backdrop-filter:blur(12px) saturate(1.2);-webkit-backdrop-filter:blur(12px) saturate(1.2);border:1px solid var(--color-neutral-800);border-radius:10em;padding:.45em 1em;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none}.sp-sort:focus{outline:2px solid var(--color-electric, #a1ff62);outline-offset:2px}.sp-collections{padding:var(--gap-m) var(--container-padding);max-width:100%}.sp-collection{margin-bottom:var(--gap-m)}.sp-collection__header{margin-bottom:var(--gap-xs)}.sp-collection__title{font-family:Georgia,Times New Roman,serif;font-size:1.125em;color:var(--color-neutral-200);margin:0}.sp-collection__desc{font-family:Georgia,Times New Roman,serif;font-size:.8125em;color:var(--color-neutral-500);margin:.25em 0 0}.sp-collection__scroll{display:flex;gap:var(--gap-xs);overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:.5em;scrollbar-width:none}.sp-collection__scroll::-webkit-scrollbar{display:none}.sp-collection__item{flex-shrink:0;width:90px;border:none;padding:0;cursor:pointer;background:transparent;scroll-snap-align:start;transition:transform .2s var(--cubic-default, ease)}.sp-collection__item:hover{transform:scale(1.05)}.sp-collection__cover{width:90px;height:120px;-o-object-fit:cover;object-fit:cover;border-radius:.25em;background:var(--coll-accent, var(--color-neutral-800))}.sp-collection__cover-fallback{width:90px;height:120px;border-radius:.25em;background:var(--coll-accent, var(--color-neutral-800));display:flex;align-items:center;justify-content:center;padding:.5em;font-family:Georgia,Times New Roman,serif;font-size:.5625em;color:#ffffffb3;text-align:center;line-height:1.3}.sp-collection__book-title{font-family:HafferMono,monospace;font-size:.5625em;color:var(--color-neutral-400);margin-top:.4em;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left}.sp-page{color:var(--palette-text, #f4f4f4);position:relative}.sp-page .page-header{padding-top:2em}.sp-canvas{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:3;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 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:#0a0a0c99;display:grid;grid-template-columns:1fr 1fr;align-items:stretch;transition:grid-template-columns .4s cubic-bezier(.625,.05,0,1)}@media screen and (max-width:899px){.sp-detail{grid-template-columns:1fr;grid-template-rows:45vh 1fr;overflow-y:auto}.sp-detail__book-area{min-height:200px}.sp-detail__info{padding:1.5em;max-height:none}.sp-detail__title{font-size:1.75em}}.sp-detail__book-area{display:flex;align-items:center;justify-content:center;height:100%;min-height:300px}.sp-detail__info{display:flex;flex-direction:column;justify-content:center;gap:.75em;padding:3em;max-width:32em;overflow-y:auto;background:#ffffff08;border-left:1px solid rgba(255,255,255,.1);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-detail__nav{display:flex;gap:.5em;margin-top:.75em}.sp-detail__nav-btn{font-size:1.25em;width:2.5em;height:2.5em;border-radius:50%;border:1px solid rgba(255,255,255,.15);background:transparent;color:#fff9;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .2s ease,color .2s ease}.sp-detail__nav-btn:hover{border-color:#ffffff59;color:#ffffffe6}.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__title{font-size:1.25em}.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}.sp-hero-reading__row{flex-wrap:wrap;gap:var(--gap-s)}.sp-hero-reading__card{min-width:140px;flex:1 1 45%;padding:1.25em 1em 1em}.sp-hero-reading__book-slot{width:100px;height:140px}.sp-hero-want__scatter{gap:var(--gap-m)}.sp-collection__item{width:72px}.sp-collection__cover,.sp-collection__cover-fallback{width:72px;height:100px}.sp-timeline{padding:var(--gap-s) 0}.sp-timeline__scroll{padding:0 var(--container-padding)}.sp-timeline__block{width:20px}.sp-cover-grid{grid-template-columns:repeat(2,1fr);gap:var(--gap-xxs)}.sp-search__kbd{display:none}.sp-search-modal{padding-top:0;align-items:stretch}.sp-search-modal__box{width:100%;max-width:none;border-radius:0;border:none;border-bottom:1px solid var(--color-neutral-700)}}.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}}.pins-toolbar{display:flex;align-items:center;gap:var(--gap-s);padding:0 var(--container-padding) var(--gap-s)}.pins-search{flex:1;min-width:12em;padding:.6em 1em;background:#ffffff0d;backdrop-filter:blur(12px) saturate(150%);-webkit-backdrop-filter:blur(12px) saturate(150%);border:1px solid rgba(255,255,255,.08);border-radius:10em;color:var(--color-neutral-200);font-family:Haffer,sans-serif;font-size:.85em;outline:none;box-shadow:0 2px 8px #00000014,inset 0 1px #ffffff0d;transition:all .25s var(--cubic-default)}.pins-search:focus{border-color:var(--color-electric);background:#ffffff14;box-shadow:0 0 0 3px #a1ff6214,0 4px 16px #0000001f}.pins-search::-moz-placeholder{color:var(--color-neutral-500)}.pins-search::placeholder{color:var(--color-neutral-500)}.pins-filters{padding:0 var(--container-padding) var(--gap-xs);display:flex;flex-wrap:wrap;gap:.4em;align-items:center}.pins-categories{display:flex;gap:.3em;flex-wrap:wrap}.pins-cat-btn{display:flex;align-items:center;gap:.35em;padding:.35em .7em;background:#ffffff0d;backdrop-filter:blur(12px) saturate(150%);-webkit-backdrop-filter:blur(12px) saturate(150%);border:1px solid rgba(255,255,255,.08);border-radius:10em;color:var(--color-neutral-400);font-size:.65em;font-family:Haffer,sans-serif;cursor:pointer;transition:all .25s var(--cubic-default);text-transform:capitalize;box-shadow:0 2px 8px #00000014,inset 0 1px #ffffff0f}.pins-cat-btn:hover{border-color:var(--cat-color);color:var(--color-neutral-200);background:#ffffff1a;box-shadow:0 4px 16px #00000026,inset 0 1px #ffffff1a;transform:translateY(-1px)}.pins-cat-btn--active{background:color-mix(in srgb,var(--cat-color) 25%,transparent);border-color:var(--cat-color);color:var(--color-neutral-100);box-shadow:0 4px 20px color-mix(in srgb,var(--cat-color) 20%,transparent),inset 0 1px #ffffff26}.pins-cat-btn__dot{width:6px;height:6px;border-radius:50%;background:var(--cat-color)}.pins-cat-btn--active .pins-cat-btn__dot{background:#000}.pins-tags{display:flex;gap:.25em;flex-wrap:wrap;margin-left:.5em;padding-left:.5em;border-left:1px solid var(--color-neutral-700)}.pins-tag{padding:.25em .5em;background:transparent;border:none;color:var(--color-neutral-500);font-size:.55em;font-family:HafferMono,monospace;cursor:pointer;border-radius:4px;transition:background .15s,color .15s}.pins-tag:hover{background:var(--color-neutral-800);color:var(--color-neutral-300)}.pins-tag--active{background:var(--color-neutral-200);color:var(--color-neutral-900)}.pins-clear{background:none;border:none;color:var(--color-neutral-500);font-size:.6em;cursor:pointer;text-decoration:underline;margin-left:.5em}.pins-count{padding:0 var(--container-padding);font-family:HafferMono,monospace;font-size:.6em;color:var(--color-neutral-500);margin-bottom:var(--gap-s)}.pins-masonry{padding:0 var(--container-padding) var(--gap-xl);-moz-column-count:4;column-count:4;-moz-column-gap:1em;column-gap:1em}.pin-card{display:inline-block;width:100%;margin-bottom:1em;-moz-column-break-inside:avoid;break-inside:avoid;background:#ffffff0a;backdrop-filter:blur(12px) saturate(140%);-webkit-backdrop-filter:blur(12px) saturate(140%);border:1px solid rgba(255,255,255,.07);border-radius:.75em;text-decoration:none;color:inherit;position:relative;overflow:hidden;box-shadow:0 2px 12px #0000001a,inset 0 1px #ffffff0d;transition:transform .3s var(--cubic-default),box-shadow .3s var(--cubic-default),border-color .25s ease,background .25s ease;animation:pinFadeIn .4s var(--cubic-default) both}@keyframes pinFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.pin-card:hover{transform:translateY(-4px);background:#ffffff12;border-color:#ffffff26;box-shadow:0 16px 48px #00000040,0 0 0 1px var(--pin-accent, rgba(255,255,255,.1)),inset 0 1px #ffffff1a;z-index:2}.pin-card__thumb{width:100%;aspect-ratio:16 / 9;overflow:hidden;background:var(--color-neutral-700);border-bottom:1px solid var(--color-neutral-700);border-radius:.75em .75em 0 0}.pin-card__thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;opacity:0;transition:opacity .4s ease}.pin-card__thumb img[src]{opacity:1}.pin-card:hover .pin-card__thumb img{transform:scale(1.03);transition:opacity .4s ease,transform .4s var(--cubic-default)}.pin-card__gh-icon{display:flex;align-items:center;justify-content:center;padding:1.5em 0;color:var(--color-neutral-525);background:#ffffff05;border-bottom:1px solid rgba(255,255,255,.06)}.pin-card:hover .pin-card__gh-icon{color:var(--color-neutral-400)}.pin-card__stripe{height:3px;background:var(--pin-accent);opacity:.8;transition:opacity .2s}.pin-card:hover .pin-card__stripe{opacity:1}.pin-card:hover{box-shadow:0 16px 48px #00000040,0 0 30px color-mix(in srgb,var(--pin-accent) 12%,transparent),inset 0 1px #ffffff1a}.pin-card--pinned{border-color:var(--color-neutral-600)}.pin-card__pin{font-size:.75em}.pin-card__header{display:flex;align-items:center;justify-content:space-between;padding:.75em .85em 0}.pin-card__cat{font-size:.6em;color:var(--color-neutral-500);text-transform:uppercase;letter-spacing:.06em}.pin-card__title{padding:.4em .85em 0;font-family:HafferXH,sans-serif;font-size:.95em;letter-spacing:-.01em;color:var(--color-neutral-200);line-height:1.35}.pin-card__desc{padding:.3em .85em 0;font-size:.7em;color:var(--color-neutral-500);line-height:1.5}.pin-card__desc--long{display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.pin-card__tags{display:flex;flex-wrap:wrap;gap:.25em;padding:.5em .85em 0}.pin-card__tag{font-family:HafferMono,monospace;font-size:.55em;color:var(--color-neutral-475);cursor:pointer;padding:.15em .3em;border-radius:3px;transition:background .15s,color .15s}.pin-card__tag:hover{background:var(--color-neutral-700);color:var(--color-electric)}.pin-card__footer{display:flex;align-items:center;justify-content:space-between;padding:.6em .85em;margin-top:.4em;border-top:1px solid rgba(255,255,255,.06)}.pin-card__domain{font-family:HafferMono,monospace;font-size:.55em;color:var(--color-neutral-475)}.pin-card__via{font-size:.5em;color:var(--color-neutral-525);font-style:italic}.tag-pill--sm{font-size:.5em;padding:.3em .6em}.tag-pill--active{background:var(--color-neutral-200)!important;color:var(--color-neutral-900)!important}@media screen and (max-width:1200px){.pins-masonry{-moz-column-count:3;column-count:3}}@media screen and (max-width:900px){.pins-masonry{-moz-column-count:2;column-count:2}}@media screen and (max-width:550px){.pins-masonry{-moz-column-count:1;column-count:1}.pins-tags{margin-left:0;padding-left:0;border-left:none;margin-top:.3em}}.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}
