@property --gradient-fade-end{syntax: "<color>"; inherits: true; initial-value: #fdfdff;}@property --gradient-fade-start{syntax: "<color>"; inherits: true; initial-value: rgba(253,253,255,0);}@property --shimmer-x{syntax: "<percentage>"; inherits: false; initial-value: 50%;}@property --shimmer-width{syntax: "<percentage>"; inherits: false; initial-value: 0%;}@property --shimmer-base{syntax: "<color>"; inherits: true; initial-value: #1f1a14;}@property --shimmer-accent{syntax: "<color>"; inherits: true; initial-value: #0f7363;}@property --shimmer-highlight{syntax: "<color>"; inherits: true; initial-value: rgba(255,255,255,.5);}@property --shimmer-shadow-1{syntax: "<color>"; inherits: true; initial-value: rgba(31,26,20,.12);}@property --shimmer-shadow-2{syntax: "<color>"; inherits: true; initial-value: rgba(31,26,20,.08);}@property --shimmer-shadow-3{syntax: "<color>"; inherits: true; initial-value: rgba(31,26,20,.04);}@property --reveal-size{syntax: "<percentage>"; inherits: false; initial-value: 0%;}@property --reveal-opacity{syntax: "<number>"; inherits: false; initial-value: 0;}:root{color-scheme:light;--safe-area-inset-top: env(safe-area-inset-top, 0px);--safe-area-inset-right: env(safe-area-inset-right, 0px);--safe-area-inset-bottom: env(safe-area-inset-bottom, 0px);--safe-area-inset-left: env(safe-area-inset-left, 0px);--cream: #f8f9fc;--ink: #1f1a14;--line: #dfe2e8;--muted: #5d6169;--aero: #2c8f7a;--pine: #0f7363;--clay: #c45b37;--color-bg: var(--cream);--color-text: var(--ink);--color-text-muted: var(--muted);--color-border: var(--line);--color-border-subtle: rgba(31, 26, 20, .08);--color-surface: #fdfdff;--color-surface-elevated: #fafbfd;--color-surface-glass: rgba(253, 253, 255, .82);--color-surface-glass-solid: rgba(253, 253, 255, .96);--color-surface-active: #e0f2f1;--color-surface-hover: #fafbfd;--color-surface-warning: #fbe9e7;--color-surface-success: #e8f5e9;--color-surface-muted: #f2f5f8;--color-code-bg: #111827;--color-code-text: #e5e7eb;--color-code-header: #f5f6f9;--color-code-hover: #eef0f4;--color-selection: #e2eef5;--color-overlay: rgba(248, 249, 252, .92);--color-badge: #e8eaee;--color-panel-border-inner: rgba(31, 26, 20, .04);--color-fade-start: rgba(253, 253, 255, 0);--color-fade-end: #fdfdff;--gradient-fade-end: #fdfdff;--gradient-fade-start: rgba(253, 253, 255, 0);--shimmer-base: #1f1a14;--shimmer-accent: #0a8a6e;--shimmer-highlight: rgba(255, 255, 255, .5);--shimmer-shadow-1: rgba(31, 26, 20, .12);--shimmer-shadow-2: rgba(31, 26, 20, .08);--shimmer-shadow-3: rgba(31, 26, 20, .04);--shadow-color: rgba(31, 26, 20, .15);--shadow-color-medium: rgba(31, 26, 20, .6);--shadow-color-strong: rgba(31, 26, 20, .7);--shadow-color-muted: rgba(62, 52, 42, .9);--avatar-ring: 0 0 0 1px rgba(31, 26, 20, .12);--avatar-shadow-contact: 0 3px 6px rgba(31, 26, 20, .35);--avatar-shadow-ambient: 0 12px 28px rgba(31, 26, 20, .28);--avatar-shadow-hover-contact: 0 2px 4px rgba(31, 26, 20, .38);--avatar-shadow-hover-ambient: 0 6px 16px rgba(31, 26, 20, .22);--avatar-shadow-active-contact: 0 1px 2px rgba(31, 26, 20, .42);--avatar-shadow-active-ambient: 0 3px 8px rgba(31, 26, 20, .16);--card-shadow-contact: 0 2px 4px rgba(31, 26, 20, .18);--card-shadow-ambient: 0 8px 16px rgba(31, 26, 20, .12);--card-shadow-edge: 0 0 0 1px rgba(31, 26, 20, .06);--card-shadow-hover-contact: 0 8px 12px rgba(31, 26, 20, .18);--card-shadow-hover-ambient: 0 24px 48px rgba(31, 26, 20, .16);--card-shadow-hover-edge: 0 0 0 1px rgba(31, 26, 20, .08);--card-shadow-active-contact: 0 2px 3px rgba(31, 26, 20, .22);--card-shadow-active-ambient: 0 4px 8px rgba(31, 26, 20, .14);--card-shadow-active-edge: 0 0 0 1px rgba(31, 26, 20, .1);--color-pill-glass-bg: rgba(255, 255, 255, .65);--color-pill-glass-border: rgba(255, 255, 255, .2);--color-ghost-bg: rgba(31, 26, 20, .04);--color-reset-text: #9a4a2e;--color-reset-border: rgba(196, 91, 55, .35);--color-reset-hover-bg: #f5dcd4;--color-reset-hover-text: #7a3a22;--color-reset-active-bg: #f0cec3;--color-reset-active-text: #6a3018;--shadow-retro: 4px 4px 0px var(--ink);--shadow-retro-sm: 2px 2px 0px var(--ink);--shadow-retro-lg: 5px 5px 0px var(--ink);--shadow-soft: 0 12px 30px rgba(31, 26, 20, .08);--shadow-soft-lg: 0 20px 50px rgba(31, 26, 20, .08);--shadow-hover: 5px 11px 10px var(--shadow-color-strong);--shadow-container: 0 1px 2px rgba(31, 26, 20, .08), 0 3px 6px rgba(31, 26, 20, .06), 0 8px 16px rgba(31, 26, 20, .06), 0 16px 32px rgba(31, 26, 20, .04);--shadow-container-lg: 0 1px 2px rgba(31, 26, 20, .1), 0 4px 8px rgba(31, 26, 20, .07), 0 12px 24px rgba(31, 26, 20, .08), 0 24px 48px rgba(31, 26, 20, .05);--shadow-container-scrolled: 0 1px 2px rgba(31, 26, 20, .12), 0 4px 8px rgba(31, 26, 20, .08), 0 12px 24px rgba(31, 26, 20, .1), 0 24px 40px rgba(31, 26, 20, .06);--shadow-container-expanded: 0 2px 4px rgba(31, 26, 20, .14), 0 6px 12px rgba(31, 26, 20, .1), 0 16px 32px rgba(31, 26, 20, .12), 0 32px 56px rgba(31, 26, 20, .08);--border-retro: 1.5px solid var(--ink);--retro-shadow-color: var(--ink);--retro-border-color: var(--ink);--panel-bg: #fdfdff;--bg-card: var(--color-surface);--bg-white: #ffffff;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 999px;--space-2xs: 4px;--space-xs: 6px;--space-sm: 8px;--space-md: 10px;--space-base: 12px;--space-lg: 14px;--space-xl: 16px;--space-2xl: 18px;--space-3xl: 22px;--space-4xl: 28px;--font-display: "DM Serif Display", serif;--font-body: "Newsreader", serif;--font-mono: "JetBrains Mono", "Fira Code", "SF Mono", Consolas, monospace;--text-xs: .68rem;--text-sm: .78rem;--text-base: .95rem;--text-md: 1rem;--text-lg: 1.1rem;--text-xl: 1.3rem;--text-2xl: 1.5rem;--text-3xl: clamp(2rem, 5vw, 2.8rem);--text-4xl: clamp(2.4rem, 6vw, 3.4rem);--leading-tight: 1.1;--leading-snug: 1.3;--leading-normal: 1.45;--leading-relaxed: 1.6;--leading-loose: 1.65;--tracking-tight: .01em;--tracking-normal: 0;--tracking-wide: .08em;--tracking-wider: .16em;--ease-out: cubic-bezier(.25, .46, .45, .94);--ease-bounce: cubic-bezier(.34, 1.56, .64, 1);--ease-snap: cubic-bezier(.4, 0, .2, 1);--ease-spring-out: cubic-bezier(.34, 1.4, .64, 1);--ease-spring-settle: cubic-bezier(.25, .1, .25, 1);--duration-fast: .1s;--duration-normal: .2s;--duration-slow: .3s;--duration-slower: .4s;--theme-transition-duration: .2s;--theme-transition-ease: ease;--z-base: 1;--z-dropdown: 10;--z-sticky: 20;--z-fixed: 100;--z-modal: 1000;--max-width-content: 860px;--header-height-mobile: 95px;--header-height-desktop: 105px;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}[data-theme=dark]{color-scheme:dark;--color-bg: #1a1816;--color-text: #f0ebe3;--color-text-muted: #a39e96;--color-border: #3a3530;--color-border-subtle: rgba(255, 255, 255, .06);--color-surface: #24221e;--color-surface-elevated: #2c2a25;--color-surface-glass: rgba(36, 34, 30, .92);--color-surface-glass-solid: rgba(44, 42, 37, .96);--color-surface-active: #1a3330;--color-surface-hover: #2c2a25;--color-surface-warning: #3a2a26;--color-surface-success: #1a3324;--color-surface-muted: #282826;--color-code-bg: #0c0c0b;--color-code-text: #e5e7eb;--color-code-header: #1c1b18;--color-code-hover: #2a2824;--color-selection: #1a3330;--color-overlay: rgba(26, 24, 22, .94);--color-badge: #3a3530;--color-panel-border-inner: rgba(255, 255, 255, .04);--color-fade-start: rgba(36, 34, 30, 0);--color-fade-end: #24221e;--gradient-fade-end: #24221e;--gradient-fade-start: rgba(36, 34, 30, 0);--shimmer-base: #f0ebe3;--shimmer-accent: #2c8f7a;--shimmer-highlight: rgba(255, 255, 255, .12);--shimmer-shadow-1: rgba(0, 0, 0, .25);--shimmer-shadow-2: rgba(0, 0, 0, .18);--shimmer-shadow-3: rgba(0, 0, 0, .1);--shadow-color: rgba(0, 0, 0, .3);--shadow-color-medium: rgba(0, 0, 0, .5);--shadow-color-strong: rgba(0, 0, 0, .6);--shadow-color-muted: rgba(0, 0, 0, .4);--avatar-ring: 0 0 0 1px rgba(255, 255, 255, .1);--avatar-shadow-contact: 0 3px 8px rgba(0, 0, 0, .5);--avatar-shadow-ambient: 0 14px 32px rgba(0, 0, 0, .45);--avatar-shadow-hover-contact: 0 2px 5px rgba(0, 0, 0, .55);--avatar-shadow-hover-ambient: 0 8px 18px rgba(0, 0, 0, .38);--avatar-shadow-active-contact: 0 1px 3px rgba(0, 0, 0, .6);--avatar-shadow-active-ambient: 0 3px 10px rgba(0, 0, 0, .28);--card-shadow-contact: 0 2px 4px rgba(0, 0, 0, .35);--card-shadow-ambient: 0 8px 16px rgba(0, 0, 0, .28);--card-shadow-edge: 0 0 0 1px rgba(255, 255, 255, .06);--card-shadow-hover-contact: 0 8px 12px rgba(0, 0, 0, .38);--card-shadow-hover-ambient: 0 24px 48px rgba(0, 0, 0, .35);--card-shadow-hover-edge: 0 0 0 1px rgba(255, 255, 255, .1);--card-shadow-active-contact: 0 2px 3px rgba(0, 0, 0, .42);--card-shadow-active-ambient: 0 4px 8px rgba(0, 0, 0, .28);--card-shadow-active-edge: 0 0 0 1px rgba(255, 255, 255, .12);--color-pill-glass-bg: rgba(44, 42, 37, .75);--color-pill-glass-border: rgba(255, 255, 255, .1);--color-ghost-bg: rgba(255, 255, 255, .06);--color-reset-text: #d4836a;--color-reset-border: rgba(196, 91, 55, .4);--color-reset-hover-bg: #4a3530;--color-reset-hover-text: #e8a08a;--color-reset-active-bg: #5a403a;--color-reset-active-text: #f0b8a5;--shadow-soft: 0 12px 30px rgba(0, 0, 0, .25);--shadow-soft-lg: 0 20px 50px rgba(0, 0, 0, .3);--shadow-hover: 5px 11px 10px rgba(0, 0, 0, .5);--shadow-container: 0 1px 2px rgba(0, 0, 0, .18), 0 3px 6px rgba(0, 0, 0, .14), 0 8px 16px rgba(0, 0, 0, .14), 0 16px 32px rgba(0, 0, 0, .1);--shadow-container-lg: 0 1px 2px rgba(0, 0, 0, .22), 0 4px 8px rgba(0, 0, 0, .16), 0 12px 24px rgba(0, 0, 0, .18), 0 24px 48px rgba(0, 0, 0, .12);--shadow-container-scrolled: 0 1px 2px rgba(0, 0, 0, .26), 0 4px 8px rgba(0, 0, 0, .18), 0 12px 24px rgba(0, 0, 0, .22), 0 24px 40px rgba(0, 0, 0, .14);--shadow-container-expanded: 0 2px 4px rgba(0, 0, 0, .3), 0 6px 12px rgba(0, 0, 0, .22), 0 16px 32px rgba(0, 0, 0, .26), 0 32px 56px rgba(0, 0, 0, .16);--panel-bg: #24221e;--bg-card: var(--color-surface);--bg-white: #24221e;--cream: #1a1816;--ink: #f0ebe3;--line: #3a3530;--muted: #a39e96;--retro-shadow-color: #0e0e0c;--retro-border-color: #3a3530;--shadow-retro: 4px 4px 0px var(--retro-shadow-color);--shadow-retro-sm: 2px 2px 0px var(--retro-shadow-color);--shadow-retro-lg: 5px 5px 0px var(--retro-shadow-color);--border-retro: 1.5px solid var(--retro-border-color)}*,*:before,*:after{box-sizing:border-box}html:not(.theme-ready) *,html:not(.theme-ready) *:before,html:not(.theme-ready) *:after{transition:none!important}*,*:before,*:after{transition-property:background-color,border-color,box-shadow,filter,outline-color;transition-duration:var(--theme-transition-duration, .2s);transition-timing-function:var(--theme-transition-ease, ease)}a,button,.pill,.btn,[role=button]{transition-property:background-color,border-color,box-shadow,filter,outline-color,color,fill,stroke,text-decoration-color,transform,-webkit-text-fill-color;transition-duration:var(--theme-transition-duration, .2s);transition-timing-function:var(--theme-transition-ease, ease)}html{min-height:100%;background:var(--color-bg);transition:background-color var(--duration-normal) ease}body{margin:0;min-height:100vh;min-height:100dvh;font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);line-height:var(--leading-relaxed);transition:background-color var(--duration-normal) ease}#root{min-height:100vh;min-height:100svh;min-height:100dvh}a{color:var(--aero);text-decoration:none}@media(hover:hover){a:hover{color:var(--clay)}}a,button{-webkit-tap-highlight-color:transparent;touch-action:manipulation}.tap-feedback{transition:transform .08s ease-out,color .08s ease-out,background-color .08s ease-out,box-shadow .08s ease-out}button{font-family:inherit;-webkit-appearance:none;appearance:none;background:none;border:none;color:inherit;cursor:pointer}h1,h2,h3,h4{font-family:var(--font-display);color:var(--color-text);margin:0 0 .35em;letter-spacing:var(--tracking-tight)}.eyebrow{font-size:var(--text-sm);font-weight:700;letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--color-text-muted)}.muted{color:var(--color-text-muted)}::selection{background:var(--color-selection);color:var(--color-text)}.app{position:relative;min-height:100vh;min-height:100svh;min-height:100dvh;padding:18px 10px 64px}.frame{max-width:var(--max-width-content);margin:0 auto;position:relative;display:flex;flex-direction:column;gap:var(--space-2xl);z-index:var(--z-base)}.empty-state{padding:1rem;border:1.5px dashed var(--color-border);border-radius:var(--radius-sm);text-align:center;color:var(--color-text-muted);background:var(--color-surface-glass)}@media(min-width:840px){.app{padding:28px 28px 72px}.frame{gap:var(--space-3xl)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);border:var(--border-retro);border-radius:var(--radius-sm);padding:.65rem 1rem .55rem;font-weight:600;font-size:var(--text-md);line-height:1;background:var(--bg-white);color:var(--ink);-webkit-text-fill-color:var(--ink);box-shadow:var(--shadow-retro-sm);cursor:pointer;transition:transform var(--duration-fast) ease,box-shadow var(--theme-transition-duration) var(--theme-transition-ease),background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease),color var(--duration-slow) var(--ease-out),-webkit-text-fill-color var(--duration-slow) var(--ease-out)}.btn.small{padding:.45rem .8rem .35rem;font-size:var(--text-base)}.btn.outline{background:var(--bg-white)}.btn.ghost{background:var(--color-ghost-bg);border:2px solid transparent}.btn.primary{background:var(--aero);color:var(--bg-white);-webkit-text-fill-color:var(--bg-white)}@media(hover:hover){.btn:hover{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--retro-shadow-color);color:var(--pine);-webkit-text-fill-color:var(--pine)}.btn.primary:hover{color:var(--bg-white);-webkit-text-fill-color:var(--bg-white)}.btn:disabled:hover{transform:none;box-shadow:var(--shadow-retro-sm);color:var(--ink);-webkit-text-fill-color:var(--ink)}}.btn:active{transform:translate(2px,2px);box-shadow:0 0 0 var(--retro-shadow-color)}.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.btn:focus-visible{outline:2px dashed var(--clay);outline-offset:4px}.btn.active{background:var(--color-surface-active);border-color:var(--pine);color:var(--pine);-webkit-text-fill-color:var(--pine)}.btn.clear-tags{background:var(--color-surface-warning);border-color:var(--color-reset-border);color:var(--color-reset-text);-webkit-text-fill-color:var(--color-reset-text)}@media(hover:hover){.btn.clear-tags:hover{background:var(--color-reset-hover-bg);border-color:var(--clay);color:var(--color-reset-hover-text);-webkit-text-fill-color:var(--color-reset-hover-text);transform:translate(1px,1px);box-shadow:1px 1px 0 var(--shadow-color)}}.btn.clear-tags:active,.btn.clear-tags.tap-active{background:var(--color-reset-active-bg);border-color:var(--clay);color:var(--color-reset-active-text);-webkit-text-fill-color:var(--color-reset-active-text);transform:translate(2px,2px);box-shadow:none;transition:transform .06s ease-out,background-color .06s ease-out,color .06s ease-out}.pill{display:inline-flex;align-items:center;gap:var(--space-xs);padding:.38rem .68rem .2rem;border:var(--border-retro);border-radius:var(--radius-sm);background:var(--bg-white);box-shadow:2px 2px 0 var(--shadow-color);font-weight:600;font-size:.82rem;line-height:1;color:var(--ink);-webkit-text-fill-color:var(--ink);cursor:pointer;transition:transform var(--duration-fast) ease,box-shadow var(--theme-transition-duration) var(--theme-transition-ease),background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease),color var(--duration-slow) var(--ease-out),-webkit-text-fill-color var(--duration-slow) var(--ease-out)}.pill.small{padding:.3rem .4rem .15rem;font-size:.7rem}@media(hover:hover){.pill:hover{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--shadow-color);background:var(--color-surface-hover);color:var(--pine);-webkit-text-fill-color:var(--pine)}.pill:hover .tag-count{color:var(--pine)}}.pill:active{transform:translate(2px,2px);box-shadow:none}.pill.active{background:var(--color-surface-active);border-color:var(--pine);color:var(--pine);-webkit-text-fill-color:var(--pine)}.pill.reset{background:var(--color-surface-warning);border-color:var(--color-reset-border);color:var(--color-reset-text);-webkit-text-fill-color:var(--color-reset-text)}@media(hover:hover){.pill.reset:hover{background:var(--color-reset-hover-bg);border-color:var(--clay);color:var(--color-reset-hover-text);-webkit-text-fill-color:var(--color-reset-hover-text);transform:translate(1px,1px);box-shadow:1px 1px 0 var(--shadow-color)}}.pill.reset:active,.pill.reset.tap-active{background:var(--color-reset-active-bg);border-color:var(--clay);color:var(--color-reset-active-text);-webkit-text-fill-color:var(--color-reset-active-text);transform:translate(2px,2px);box-shadow:none;transition:transform .06s ease-out,background-color .06s ease-out,color .06s ease-out}.pill.disabled{cursor:default;opacity:1;background:var(--bg-white)}@media(hover:hover){.pill.disabled:hover{transform:none;box-shadow:2px 2px 0 var(--shadow-color);background:var(--bg-white);color:var(--ink);-webkit-text-fill-color:var(--ink)}.pill.disabled:hover .tag-count{color:var(--color-text-muted)}}.pill.icon-btn{padding:0;width:34px;height:34px;justify-content:center;border-radius:50%;color:var(--muted);border-color:transparent;background:transparent;box-shadow:none;transition:transform var(--duration-normal) ease,box-shadow var(--theme-transition-duration) var(--theme-transition-ease),background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease),color var(--duration-slow) var(--ease-out),-webkit-text-fill-color var(--duration-slow) var(--ease-out)}@media(hover:hover){.pill.icon-btn:hover{color:var(--pine);background:var(--bg-white);border-color:var(--color-border);box-shadow:2px 2px 0 var(--shadow-color);transform:translateY(-1px)}}.pill.icon-btn:active,.pill.icon-btn.tap-active{color:var(--pine);background:var(--color-surface-hover);border-color:var(--color-border);transform:scale(.92);box-shadow:none;transition:transform .06s ease-out,background-color .06s ease-out,color .06s ease-out}.pill.project-link-pill{padding:.5rem .85rem .4rem;font-size:.88rem;box-shadow:var(--shadow-retro-sm);border-radius:var(--radius-sm)}@media(hover:hover){.pill.project-link-pill:hover{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--retro-shadow-color);color:var(--pine);-webkit-text-fill-color:var(--pine)}}.pill.project-link-pill:active{transform:translate(2px,2px);box-shadow:none}.pill-icon{width:14px;height:14px;flex-shrink:0;display:block;position:relative;top:-1px}.tag-count{color:var(--color-text-muted);font-weight:500;margin-left:.25em;transition:color var(--duration-slow) var(--ease-out),-webkit-text-fill-color var(--duration-slow) var(--ease-out)}.pill.active .tag-count{color:var(--pine);opacity:.7}.pill.tag-scaled{--font-min: .78;--font-range: .3;--computed-font: calc(var(--font-min) * 1rem + var(--font-range) * var(--tag-scale) * 1rem);--pad-h-min: .45;--pad-h-range: .2;--pad-v-top-min: .26;--pad-v-top-range: .08;--pad-v-bot-min: .12;--pad-v-bot-range: .06;font-size:var(--computed-font);padding:calc(var(--pad-v-top-min) * 1rem + var(--pad-v-top-range) * var(--tag-scale) * 1rem) calc(var(--pad-h-min) * 1rem + var(--pad-h-range) * var(--tag-scale) * 1rem) calc(var(--pad-v-bot-min) * 1rem + var(--pad-v-bot-range) * var(--tag-scale) * 1rem)}.pill:focus-visible{outline:2px dashed var(--clay);outline-offset:4px}.panel{position:relative;background:var(--panel-bg);border:.5px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:1.4rem 1.35rem;box-shadow:var(--shadow-container-lg);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);transition:background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease),box-shadow var(--theme-transition-duration) var(--theme-transition-ease)}.panel:before{content:"";position:absolute;inset:8px;border-radius:calc(var(--radius-lg) - 8px);pointer-events:none;border:1px dashed var(--color-panel-border-inner)}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:var(--space-base);flex-wrap:wrap}.hero h1{font-size:var(--text-4xl);margin-top:.4rem}.hero .muted{max-width:680px}.posts-panel{display:flex;flex-direction:column;gap:var(--space-base)}.posts-panel .panel-head:has(.panel-head-main){flex-direction:column;align-items:stretch;gap:var(--space-sm)}.panel-head-main{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-base);min-height:34px}.panel-head-main .eyebrow{transition:transform .26s cubic-bezier(.33,0,.2,1)}.panel-head-main:has(.btn) .eyebrow{transform:translateY(9px)}.panel-head-main .btn{align-self:center}.post-list{display:flex;flex-direction:column;gap:0;position:relative}.posts-panel.filter-transitioning{pointer-events:none}.post-list.visible{opacity:1}.post-list.transitioning{pointer-events:none}.posts-panel.pagination-transitioning .post-list.transitioning{opacity:0;transition:opacity .25s cubic-bezier(.4,0,.6,1)}.posts-panel.pagination-transitioning .post-list.visible{opacity:1;transition:opacity .4s cubic-bezier(.2,0,.2,1)}.post-list.transitioning.filter-changed>.post-card.card-entering{opacity:0}.post-list.transitioning.filter-changed>.post-card.card-stable{opacity:1}@keyframes filterCardReveal{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.post-list.visible.filter-changed>.post-card.card-entering{opacity:0;animation:filterCardReveal var(--fade-in-duration, .28s) cubic-bezier(.33,0,.2,1) both;animation-delay:calc(var(--card-index, 0) * var(--stagger-delay, 50ms))}.post-list.visible.filter-changed>.post-card.card-stable{opacity:1;animation:none}.post-list.visible.filter-changed>.empty-state{opacity:0;animation:filterCardReveal .32s cubic-bezier(.33,0,.2,1) both}@media(prefers-reduced-motion:reduce){.post-list.transitioning,.post-list.visible{transition:none}.post-list.visible.filter-changed>.post-card.card-entering,.post-list.visible.filter-changed>.post-card.card-stable,.post-list.visible.filter-changed>.empty-state{animation:none;opacity:1;transform:none}}.featured-project-panel{display:flex;flex-direction:column;gap:var(--space-lg)}.featured-project-panel .panel-head,.recent-posts-panel .panel-head{display:flex;align-items:center;justify-content:space-between;gap:var(--space-base);flex-wrap:wrap}.see-all-link{font-size:.9rem;font-weight:600;color:var(--color-text-muted);transition:color var(--theme-transition-duration) var(--theme-transition-ease),transform var(--duration-normal) ease;flex-shrink:0}@media(hover:hover){.see-all-link:hover{color:var(--aero);transform:translate(4px)}}.see-all-link:active,.see-all-link.tap-active{color:var(--aero);transform:translate(2px);transition:transform .06s ease-out,color .06s ease-out}@media(min-width:840px){.panel{padding:1.8rem 1.6rem}}@media(max-width:640px){.panel{padding:1.1rem .85rem}.panel:before{inset:5px}}.top-bar{display:flex;flex-direction:column;align-items:stretch;gap:0;position:fixed;top:18px;left:10px;right:10px;max-width:var(--max-width-content);margin:0 auto;padding:12px;background:var(--color-surface-glass);border:.5px solid var(--color-border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-container);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:var(--z-fixed);transition:padding var(--duration-normal) ease,opacity .32s ease-in-out,transform .32s ease-in-out,box-shadow var(--theme-transition-duration) var(--theme-transition-ease),background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease);overflow-anchor:none}.top-bar.scrolled{box-shadow:var(--shadow-container-scrolled)}.top-bar+*:not(.mobile-fab){margin-top:var(--header-height-mobile)}.top-bar+.mobile-fab+*{margin-top:var(--header-height-mobile)}.top-bar.expanded{box-shadow:var(--shadow-container-expanded)}.top-bar.flyout.expanded{box-shadow:var(--shadow-container)}.top-bar.flyout{overflow:visible}.top-bar-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);position:relative;z-index:5;pointer-events:none;min-width:0}.top-bar-row>*{pointer-events:auto}.header-actions{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.theme-toggle{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:var(--border-retro);border-radius:var(--radius-full);background:var(--bg-white);color:var(--ink);cursor:pointer;box-shadow:var(--shadow-retro-sm);opacity:1;transition:transform var(--duration-fast) ease,box-shadow var(--theme-transition-duration) var(--theme-transition-ease),background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease),color var(--duration-fast) ease,opacity var(--collapse-duration) var(--collapse-ease)}@media(hover:hover){.theme-toggle:hover{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--retro-shadow-color);color:var(--pine)}}.theme-toggle:active{transform:translate(2px,2px);box-shadow:0 0 0 var(--retro-shadow-color)}.theme-toggle:focus-visible{outline:2px dashed var(--clay);outline-offset:4px}.theme-toggle-icon-wrap{position:relative;display:flex;align-items:center;justify-content:center;width:18px;height:18px}.theme-icon{position:absolute;opacity:0;transform:scale(.5) rotate(-90deg);transition:opacity var(--duration-normal) ease-out,transform var(--duration-slow) var(--ease-snap)}.theme-icon.visible{opacity:1;transform:scale(1) rotate(0);transition:opacity var(--duration-normal) ease-out,transform var(--duration-slower) var(--ease-bounce)}.theme-icon.sun{transform:scale(.5) rotate(90deg)}.theme-icon.sun.visible{transform:scale(1) rotate(0)}.theme-icon.moon{transform:scale(.5) rotate(-90deg)}.theme-icon.moon.visible{transform:scale(1) rotate(0)}.top-bar.collapsed .theme-toggle{opacity:0;pointer-events:none;transition:opacity var(--collapse-duration) var(--collapse-ease)}.brand{display:inline-flex;align-items:center;gap:var(--space-xl);border:none;background:none;padding:0;margin:0;cursor:pointer;color:var(--ink);font-family:var(--font-display);font-size:clamp(1.4rem,4.5vw,2.2rem);letter-spacing:var(--tracking-tight);transition:color var(--theme-transition-duration) var(--theme-transition-ease);min-width:0;flex:1 1 0}@media(hover:hover){.brand:hover{color:var(--pine)}}.brand:active,.brand.tap-active{color:var(--pine);transition:color .06s ease-out}.brand:focus-visible{outline:2px dashed var(--clay);outline-offset:4px}.brand-mark{position:relative;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.brand-mark-inner{width:48px;height:48px;border-radius:var(--radius-full);border:1.5px solid var(--retro-border-color);background:var(--color-bg);box-shadow:none;display:grid;place-items:center;overflow:hidden;transition:border-color .2s ease,box-shadow .2s ease,transform .15s ease,background-color var(--theme-transition-duration) var(--theme-transition-ease)}.brand-mark img{width:100%;height:100%;object-fit:contain}.brand-mark:after{content:"";position:absolute;inset:-2px;border-radius:50%;border:2px solid var(--pine);opacity:0;pointer-events:none;animation:ring-pulse 4s ease-out 2s infinite}@keyframes ring-pulse{0%,80%,to{transform:scale(1);opacity:0}5%{transform:scale(1);opacity:.5}25%{transform:scale(1.2);opacity:0}}@media(hover:hover){.brand-mark:hover:after{border-color:transparent}.brand-mark:hover .brand-mark-inner{border-color:var(--pine);box-shadow:0 0 0 1px var(--pine),0 0 12px #0a8a6e59;transition:border-color .2s ease,box-shadow .2s ease,transform .15s ease,background-color var(--theme-transition-duration) var(--theme-transition-ease)}}@media(hover:none){.brand-mark:active .brand-mark-inner{border-color:var(--pine);box-shadow:0 0 8px #0a8a6e66}}.brand-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;position:relative;padding-right:.15em}@media(hover:none){.top-bar .brand-name{color:var(--shimmer-base);filter:drop-shadow(-.5px -.5px 0 var(--shimmer-highlight)) drop-shadow(.5px .5px 0 var(--shimmer-shadow-1)) drop-shadow(1px 1px 0 var(--shimmer-shadow-2));transition:color .2s ease,filter var(--theme-transition-duration) var(--theme-transition-ease),opacity var(--collapse-duration) var(--collapse-ease)}.top-bar .brand-name:active{color:var(--pine);filter:drop-shadow(-.5px -.5px 0 var(--shimmer-highlight)) drop-shadow(.5px .5px 0 var(--shimmer-accent)) drop-shadow(.5px .5px 0 transparent)}}@media(hover:hover){.top-bar .brand-name.shimmer-text{--shimmer-x: 50%;--shimmer-width: 0%;background:linear-gradient(90deg,var(--shimmer-base) 0%,var(--shimmer-base) calc(var(--shimmer-x) - var(--shimmer-width) * 1.8),color-mix(in srgb,var(--shimmer-accent) 3%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * 1.6),color-mix(in srgb,var(--shimmer-accent) 8%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * 1.4),color-mix(in srgb,var(--shimmer-accent) 18%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * 1.2),color-mix(in srgb,var(--shimmer-accent) 35%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * 1),color-mix(in srgb,var(--shimmer-accent) 65%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * .5),color-mix(in srgb,var(--shimmer-accent) 90%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * .15),var(--shimmer-accent) var(--shimmer-x),color-mix(in srgb,var(--shimmer-accent) 90%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * .15),color-mix(in srgb,var(--shimmer-accent) 65%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * .5),color-mix(in srgb,var(--shimmer-accent) 35%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * 1),color-mix(in srgb,var(--shimmer-accent) 18%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * 1.2),color-mix(in srgb,var(--shimmer-accent) 8%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * 1.4),color-mix(in srgb,var(--shimmer-accent) 3%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * 1.6),var(--shimmer-base) calc(var(--shimmer-x) + var(--shimmer-width) * 1.8),var(--shimmer-base) 100%);background-size:100% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;filter:drop-shadow(-.5px -.5px 0 var(--shimmer-highlight)) drop-shadow(.5px .5px 0 var(--shimmer-shadow-1)) drop-shadow(1px 1px 0 var(--shimmer-shadow-2));transition:--shimmer-width .3s cubic-bezier(.4,0,.2,1),--shimmer-base var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-accent var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-highlight var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-1 var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-2 var(--theme-transition-duration) var(--theme-transition-ease),filter var(--theme-transition-duration) var(--theme-transition-ease),opacity var(--collapse-duration) var(--collapse-ease)}.top-bar .brand:hover .brand-name.shimmer-text{filter:drop-shadow(-.5px -.5px 0 var(--shimmer-highlight)) drop-shadow(.5px .5px 0 var(--shimmer-accent)) drop-shadow(.5px .5px 0 transparent)}.top-bar .brand-name.shimmer-text.shimmer-sweeping{transition:--shimmer-width .4s cubic-bezier(.4,0,.2,1),--shimmer-base var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-accent var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-highlight var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-1 var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-2 var(--theme-transition-duration) var(--theme-transition-ease),filter var(--theme-transition-duration) var(--theme-transition-ease),opacity var(--collapse-duration) var(--collapse-ease)}.top-bar .brand-name.shimmer-text.shimmer-hidden{background:var(--shimmer-base)!important;-webkit-background-clip:text!important;background-clip:text!important;-webkit-text-fill-color:transparent!important}}.brand-name:after{content:"";position:absolute;right:0;top:.15em;bottom:.15em;width:2px;background:var(--pine);border-radius:1px;opacity:0;transition:opacity .15s ease}@keyframes cursor-blink{0%,to{opacity:1}50%{opacity:0}}@keyframes cursor-fade-in-then-blink{0%{opacity:0}15%{opacity:1}40%{opacity:1}50%{opacity:0}60%{opacity:0}70%{opacity:1}to{opacity:1}}@media(hover:hover){.brand:hover .brand-name:after{animation:cursor-fade-in-then-blink 1.4s ease-out 1,cursor-blink 1s ease-in-out 1.4s infinite}.brand:active .brand-name:after,.brand.tap-active .brand-name:after{opacity:1;animation:cursor-blink .5s ease-in-out 1}}.top-bar.collapsed .brand-name:after{display:none}.menu-toggle{min-width:62px;font-weight:800;letter-spacing:var(--tracking-wide)}.menu-toggle.active{background:var(--color-surface-muted)}.toggle-icon-wrap{position:relative;display:flex;align-items:center;justify-content:center;width:18px;height:18px}.toggle-icon{position:absolute;opacity:0;fill:currentColor;-webkit-transition:opacity .18s ease-out,-webkit-transform .32s cubic-bezier(.25,.46,.45,.94);transition:opacity .18s ease-out,transform .32s cubic-bezier(.25,.46,.45,.94)}.toggle-icon.visible{opacity:1;-webkit-transition:opacity .22s ease-out,-webkit-transform .38s cubic-bezier(.34,1.4,.64,1);transition:opacity .22s ease-out,transform .38s cubic-bezier(.34,1.4,.64,1)}.toggle-icon.ellipsis{-webkit-transform:scale(.6) translateY(-6px);transform:scale(.6) translateY(-6px)}.toggle-icon.ellipsis.visible{-webkit-transform:scale(1) translateY(0);transform:scale(1) translateY(0)}.toggle-icon.chevron-up{-webkit-transform:scale(.6) rotate(180deg);transform:scale(.6) rotate(180deg)}.toggle-icon.chevron-up.visible{-webkit-transform:scale(1) rotate(0deg);transform:scale(1) rotate(0)}.toggle-icon.chevron-right{-webkit-transform:scale(.5) rotate(-90deg);transform:scale(.5) rotate(-90deg)}.toggle-icon.chevron-right.visible{-webkit-transform:scale(1) rotate(0deg);transform:scale(1) rotate(0)}.icon{width:18px;height:18px;display:block}.top-menu.instant-hide,.top-menu.instant-hide .btn,.top-menu.instant-hide .top-menu-content{transition:none!important;-webkit-transition:none!important;opacity:0!important;visibility:hidden!important;pointer-events:none!important}.top-menu{position:absolute;top:calc(100% + 8px);right:12px;display:flex;flex-direction:column;gap:var(--space-xs);background:var(--color-surface-glass-solid);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 12px 30px var(--shadow-color);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:var(--space-sm);opacity:0;pointer-events:none;transform:translateY(-12px) scale(.92);transform-origin:top right;transition:opacity var(--duration-normal) ease,transform var(--duration-slower) var(--ease-bounce),background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease),box-shadow var(--theme-transition-duration) var(--theme-transition-ease);z-index:var(--z-sticky);min-width:140px}.top-menu.visible{opacity:1;pointer-events:auto;transform:translateY(0) scale(1)}.top-menu-content{display:flex;flex-direction:column;width:100%;gap:var(--space-xs)}.top-menu .btn.active{border-color:var(--pine);color:var(--pine)}@media(hover:hover){.top-menu.visible .btn:hover{transform:translate(1.5px,1.5px);box-shadow:1.5px 1.5px 0 var(--retro-shadow-color);color:var(--pine);-webkit-text-fill-color:var(--pine);transition:transform .12s ease-out,box-shadow .12s ease-out,color var(--duration-slow) var(--ease-out),-webkit-text-fill-color var(--duration-slow) var(--ease-out)}}.top-menu.visible .btn:active,.top-menu.visible .btn.touch-pressed{transform:translate(3px,3px);box-shadow:0 0 0 var(--retro-shadow-color);transition:transform .06s ease-out,box-shadow .06s ease-out}.top-menu.desktop{position:absolute;top:calc(100% - 5px);right:12px;background:transparent;border:none;box-shadow:none;padding:0;min-width:auto;gap:var(--space-md);backdrop-filter:none;-webkit-backdrop-filter:none;flex-direction:column;align-items:flex-end;transform:none;opacity:1;transition:none;pointer-events:none}.top-menu.desktop.visible{pointer-events:auto}.top-menu.desktop.closing{pointer-events:none}.top-menu.desktop .top-menu-content{flex-direction:column;width:auto;gap:var(--space-md);align-items:flex-end}.top-menu.desktop .btn{min-width:auto;padding-left:.9rem;padding-right:.9rem;opacity:0;-webkit-transform:translateY(-12px) scale(.88) rotate(-2deg);transform:translateY(-12px) scale(.88) rotate(-2deg);-webkit-transform-origin:right center;transform-origin:right center;box-shadow:1px 1px 0 var(--retro-shadow-color);-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-transition:opacity .28s var(--ease-out),-webkit-transform var(--duration-slower) var(--ease-bounce),box-shadow .32s var(--ease-bounce);transition:opacity .28s var(--ease-out),transform var(--duration-slower) var(--ease-bounce),box-shadow .32s var(--ease-bounce);-webkit-transition-delay:var(--btn-stagger, 0ms);transition-delay:var(--btn-stagger, 0ms)}.top-menu.desktop.visible .btn{opacity:1;-webkit-transform:translateY(0) scale(1) rotate(0deg);transform:translateY(0) scale(1) rotate(0);box-shadow:3px 3px 0 var(--retro-shadow-color)}.top-menu.desktop .btn:nth-child(1){--btn-stagger: 20ms}.top-menu.desktop .btn:nth-child(2){--btn-stagger: 70ms}.top-menu.desktop .btn:nth-child(3){--btn-stagger: .12s}.top-menu.desktop .btn:nth-child(4){--btn-stagger: .17s}@media(hover:hover){.top-menu.desktop.visible .btn:hover{transform:translate(1.5px,1.5px);box-shadow:1.5px 1.5px 0 var(--retro-shadow-color);color:var(--pine);-webkit-text-fill-color:var(--pine);transition:transform .12s ease-out,box-shadow .12s ease-out,color var(--duration-slow) var(--ease-out),-webkit-text-fill-color var(--duration-slow) var(--ease-out)}}.top-menu.desktop.visible .btn:active,.top-menu.desktop.visible .btn.touch-pressed{transform:translate(3px,3px);box-shadow:0 0 0 var(--retro-shadow-color);transition:transform .06s ease-out,box-shadow .06s ease-out}.top-menu.desktop.visible.closing .btn{opacity:0;-webkit-transform:translateY(-14px) scale(.85) rotate(3deg);transform:translateY(-14px) scale(.85) rotate(3deg);box-shadow:0 0 0 var(--retro-shadow-color);-webkit-transition:opacity .18s cubic-bezier(.4,0,1,1),-webkit-transform .24s var(--ease-snap),box-shadow .18s ease-out;transition:opacity .18s cubic-bezier(.4,0,1,1),transform .24s var(--ease-snap),box-shadow .18s ease-out;-webkit-transition-delay:var(--btn-stagger-close, 0ms);transition-delay:var(--btn-stagger-close, 0ms)}.top-menu.desktop.visible.closing .btn:nth-child(1){--btn-stagger-close: .12s}.top-menu.desktop.visible.closing .btn:nth-child(2){--btn-stagger-close: 80ms}.top-menu.desktop.visible.closing .btn:nth-child(3){--btn-stagger-close: 40ms}.top-menu.desktop.visible.closing .btn:nth-child(4){--btn-stagger-close: 0ms}.top-menu.mobile{background:transparent;border:none;box-shadow:none;padding:0;min-width:auto;right:12px;top:calc(100% - 5px);gap:var(--space-md);backdrop-filter:none;-webkit-backdrop-filter:none;align-items:flex-end;transform:none;opacity:1;transition:none}.top-menu.mobile.closing{pointer-events:none}.top-menu.mobile .top-menu-content{width:auto;gap:var(--space-md);align-items:flex-end}.top-menu.mobile .btn{min-width:auto;padding-left:.9rem;padding-right:.9rem;opacity:0;-webkit-transform:translateY(-12px) scale(.88) rotate(-2deg);transform:translateY(-12px) scale(.88) rotate(-2deg);-webkit-transform-origin:right center;transform-origin:right center;box-shadow:1px 1px 0 var(--retro-shadow-color);-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-transition:opacity .28s var(--ease-out),-webkit-transform var(--duration-slower) var(--ease-bounce),box-shadow .32s var(--ease-bounce);transition:opacity .28s var(--ease-out),transform var(--duration-slower) var(--ease-bounce),box-shadow .32s var(--ease-bounce);-webkit-transition-delay:var(--btn-stagger, 0ms);transition-delay:var(--btn-stagger, 0ms)}.top-menu.mobile.visible .btn{opacity:1;-webkit-transform:translateY(0) scale(1) rotate(0deg);transform:translateY(0) scale(1) rotate(0);box-shadow:3px 3px 0 var(--retro-shadow-color)}.top-menu.mobile .btn:nth-child(1){--btn-stagger: 20ms}.top-menu.mobile .btn:nth-child(2){--btn-stagger: 70ms}.top-menu.mobile .btn:nth-child(3){--btn-stagger: .12s}.top-menu.mobile .btn:nth-child(4){--btn-stagger: .17s}@media(hover:hover){.top-menu.mobile.visible .btn:hover{transform:translate(1.5px,1.5px);box-shadow:1.5px 1.5px 0 var(--retro-shadow-color);color:var(--pine);-webkit-text-fill-color:var(--pine);transition:transform .12s ease-out,box-shadow .12s ease-out,color var(--duration-slow) var(--ease-out),-webkit-text-fill-color var(--duration-slow) var(--ease-out)}}.top-menu.mobile.visible .btn:active,.top-menu.mobile.visible .btn.touch-pressed{transform:translate(3px,3px);box-shadow:0 0 0 var(--retro-shadow-color);transition:transform .06s ease-out,box-shadow .06s ease-out}.top-menu.mobile.visible.closing .btn{opacity:0;-webkit-transform:translateY(-14px) scale(.85) rotate(3deg);transform:translateY(-14px) scale(.85) rotate(3deg);box-shadow:0 0 0 var(--retro-shadow-color);-webkit-transition:opacity .18s cubic-bezier(.4,0,1,1),-webkit-transform .24s var(--ease-snap),box-shadow .18s ease-out;transition:opacity .18s cubic-bezier(.4,0,1,1),transform .24s var(--ease-snap),box-shadow .18s ease-out;-webkit-transition-delay:var(--btn-stagger-close, 0ms);transition-delay:var(--btn-stagger-close, 0ms)}.top-menu.mobile.visible.closing .btn:nth-child(1){--btn-stagger-close: .12s}.top-menu.mobile.visible.closing .btn:nth-child(2){--btn-stagger-close: 80ms}.top-menu.mobile.visible.closing .btn:nth-child(3){--btn-stagger-close: 40ms}.top-menu.mobile.visible.closing .btn:nth-child(4){--btn-stagger-close: 0ms}[data-theme=dark] .top-menu.mobile .btn{background:#32302cf7;backdrop-filter:blur(16px) saturate(1.3);-webkit-backdrop-filter:blur(16px) saturate(1.3);border-color:#fff8f02e;box-shadow:1px 1px #0006,0 0 0 1px #fff8f00f,0 2px 8px #0000004d}[data-theme=dark] .top-menu.mobile.visible .btn{box-shadow:3px 3px #0006,0 0 0 1px #fff8f00f,0 2px 8px #0000004d}[data-theme=dark] .top-menu.mobile .btn.active{border-color:#0a8a6e99;color:var(--pine);box-shadow:3px 3px #0006,0 0 0 1px #0a8a6e33,0 0 12px #0a8a6e33}@media(hover:hover){[data-theme=dark] .top-menu.mobile.visible .btn:hover{background:#3c3934fa;border-color:#fff8f040;box-shadow:1.5px 1.5px #00000059,0 0 0 1px #fff8f014,0 2px 8px #00000040}}[data-theme=dark] .top-menu.mobile.visible .btn:active,[data-theme=dark] .top-menu.mobile.visible .btn.touch-pressed{background:#373430fc;box-shadow:0 0 #0006,0 0 0 1px #fff8f01a}[data-theme=dark] .top-menu.mobile.visible.closing .btn{box-shadow:0 0 #0000004d}[data-theme=dark] .top-menu.mobile .btn.home-link{background:#32302cf7;border-color:#fff8f02e}@media(min-width:840px){.top-bar{padding:14px 18px;top:28px;left:28px;right:28px}.top-bar+*:not(.mobile-fab){margin-top:var(--header-height-desktop)}.top-bar+.mobile-fab+*{margin-top:var(--header-height-desktop)}.brand{font-size:2.2rem;gap:var(--space-lg)}.top-menu.desktop{right:18px}}@media(max-width:640px){.top-bar{top:20px;left:10px;right:10px}.top-bar+*:not(.mobile-fab){margin-top:var(--header-height-mobile)}.top-bar+.mobile-fab+*{margin-top:var(--header-height-mobile)}.brand{font-size:2.05rem;gap:var(--space-lg)}}@media(max-width:480px){.brand{font-size:1.8rem;gap:var(--space-md)}.top-bar{padding:11px 12px}}@media(max-width:400px){.brand{font-size:1.85rem;gap:var(--space-sm)}}@media(max-width:360px){.brand{gap:var(--space-sm);font-size:1.75rem}.brand-mark-inner{width:40px;height:40px}.top-bar{padding:10px}.header-actions{gap:var(--space-xs)}.menu-toggle{min-width:48px;padding-left:.5rem;padding-right:.5rem}.theme-toggle{width:32px;height:32px}}@media(max-width:320px){.brand{font-size:1.35rem;gap:var(--space-xs)}.brand-mark-inner{width:36px;height:36px}.top-bar{padding:8px}.menu-toggle{min-width:44px;padding-left:.4rem;padding-right:.4rem}.theme-toggle{width:30px;height:30px}}.top-bar{--collapse-duration: .18s;--collapse-ease: cubic-bezier(.2, 0, .1, 1)}body.pagination-active .top-bar{--collapse-duration: 0s}.top-bar .brand-name,.top-bar .menu-toggle{transition:opacity var(--collapse-duration) var(--collapse-ease),background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease),box-shadow var(--theme-transition-duration) var(--theme-transition-ease),color var(--theme-transition-duration) var(--theme-transition-ease)}.top-bar{transition:background-color var(--collapse-duration) var(--collapse-ease),border-color var(--collapse-duration) var(--collapse-ease),box-shadow var(--collapse-duration) var(--collapse-ease),backdrop-filter var(--collapse-duration) var(--collapse-ease),-webkit-backdrop-filter var(--collapse-duration) var(--collapse-ease),opacity .32s ease-in-out,transform .32s ease-in-out}.top-bar.collapsed,.top-bar.collapsed.expanded,.top-bar.collapsed.flyout.expanded{background:transparent;border-color:transparent;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none;pointer-events:none}.top-bar.collapsed .brand-name,.top-bar.collapsed .menu-toggle{opacity:0;pointer-events:none}.top-bar.collapsed .header-actions{pointer-events:none}.top-bar.collapsed .brand-mark-inner{box-shadow:var(--avatar-ring),var(--avatar-shadow-contact),var(--avatar-shadow-ambient)}.top-bar.collapsed .brand-mark.clickable{cursor:pointer}.top-bar.collapsed .brand{pointer-events:none}.top-bar.collapsed .brand-mark{pointer-events:auto}@media(hover:hover){.top-bar.collapsed .brand-mark:hover .brand-mark-inner{transform:translateY(2px);box-shadow:var(--avatar-ring),var(--avatar-shadow-hover-contact),var(--avatar-shadow-hover-ambient)}}.top-bar.collapsed .brand-mark:active .brand-mark-inner{transform:translateY(4px);box-shadow:var(--avatar-ring),var(--avatar-shadow-active-contact),var(--avatar-shadow-active-ambient);transition:transform .08s ease,box-shadow .08s ease}.brand-mark.draggable .brand-mark-inner{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;-webkit-user-drag:none}.brand-mark.draggable .brand-mark-inner img{-webkit-user-drag:none;pointer-events:none}@media(hover:none){.brand-mark.draggable .brand-mark-inner{touch-action:none;-webkit-tap-highlight-color:transparent}}.top-bar.collapsed .brand-mark.dragging .brand-mark-inner{box-shadow:var(--avatar-ring),0 8px 16px #1f1a1466,0 20px 40px #1f1a144d;transition:box-shadow .15s ease}[data-theme=dark] .top-bar.collapsed .brand-mark.dragging .brand-mark-inner{box-shadow:var(--avatar-ring),0 8px 18px #0000008c,0 22px 44px #00000073}.top-bar.collapsed .brand-mark.snapping .brand-mark-inner{box-shadow:var(--avatar-ring),var(--avatar-shadow-contact),var(--avatar-shadow-ambient);transition:box-shadow .45s cubic-bezier(.175,.885,.32,1.275)}.top-bar:not(.collapsed) .brand-mark.dragging .brand-mark-inner{box-shadow:0 0 0 1px #1f1a141a,0 4px 12px #1f1a1440,0 12px 28px #1f1a1433;transition:box-shadow .15s ease}[data-theme=dark] .top-bar:not(.collapsed) .brand-mark.dragging .brand-mark-inner{box-shadow:0 0 0 1px #ffffff14,0 4px 14px #00000073,0 14px 32px #00000059}.top-bar:not(.collapsed) .brand-mark.snapping .brand-mark-inner{box-shadow:none;transition:box-shadow .45s cubic-bezier(.175,.885,.32,1.275)}@media(hover:hover){.top-bar:not(.collapsed) .brand-mark:hover .brand-mark-inner{box-shadow:var(--avatar-ring),var(--avatar-shadow-hover-contact),var(--avatar-shadow-hover-ambient);transition:border-color .2s ease,box-shadow .2s ease,transform .15s ease}}.top-bar:not(.collapsed) .brand-mark:active .brand-mark-inner{transform:translateY(2px) scale(.97);box-shadow:var(--avatar-ring),var(--avatar-shadow-active-contact),var(--avatar-shadow-active-ambient);transition:transform .08s ease,box-shadow .08s ease}.top-menu.desktop.from-collapsed,.top-menu.mobile.from-collapsed{position:absolute;top:calc(100% + 8px);left:12px;right:auto;background:transparent;border:none;box-shadow:none;padding:0;min-width:auto;gap:var(--space-sm);backdrop-filter:none;-webkit-backdrop-filter:none;align-items:flex-start;transform:none;opacity:1;transition:none;pointer-events:none}.top-menu.from-collapsed.visible{pointer-events:auto}.top-menu.from-collapsed.closing{pointer-events:none}.top-menu.from-collapsed .top-menu-content{flex-direction:column;width:auto;gap:var(--space-sm);align-items:flex-start}.top-menu.from-collapsed .btn{min-width:auto;padding:.45rem .9rem .35rem;font-size:var(--text-base);font-weight:600;background:var(--bg-white);border-color:var(--retro-border-color);color:var(--ink);opacity:0;-webkit-transform:translateY(-12px) scale(.88) rotate(-2deg);transform:translateY(-12px) scale(.88) rotate(-2deg);-webkit-transform-origin:left center;transform-origin:left center;box-shadow:1px 1px 0 var(--retro-shadow-color);-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-transition:opacity .28s var(--ease-out),-webkit-transform var(--duration-slower) var(--ease-bounce),box-shadow .32s var(--ease-bounce);transition:opacity .28s var(--ease-out),transform var(--duration-slower) var(--ease-bounce),box-shadow .32s var(--ease-bounce);-webkit-transition-delay:var(--btn-stagger, 0ms);transition-delay:var(--btn-stagger, 0ms)}.top-menu.from-collapsed.visible .btn{opacity:1;-webkit-transform:translateY(0) scale(1) rotate(0deg);transform:translateY(0) scale(1) rotate(0);box-shadow:2px 2px 0 var(--retro-shadow-color)}.top-menu.from-collapsed .btn:nth-child(1){--btn-stagger: 20ms}.top-menu.from-collapsed .btn:nth-child(2){--btn-stagger: 70ms}.top-menu.from-collapsed .btn:nth-child(3){--btn-stagger: .12s}.top-menu.from-collapsed .btn:nth-child(4){--btn-stagger: .17s}@media(hover:hover){.top-menu.from-collapsed.visible .btn:hover{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--retro-shadow-color);color:var(--pine);-webkit-text-fill-color:var(--pine);transition:transform .12s ease-out,box-shadow .12s ease-out,color var(--duration-slow) var(--ease-out),-webkit-text-fill-color var(--duration-slow) var(--ease-out)}}.top-menu.from-collapsed.visible .btn:active,.top-menu.from-collapsed.visible .btn.touch-pressed{transform:translate(2px,2px);box-shadow:0 0 0 var(--retro-shadow-color);transition:transform .06s ease-out,box-shadow .06s ease-out}.top-menu.from-collapsed.visible.closing .btn{opacity:0;-webkit-transform:translateY(-14px) scale(.85) rotate(3deg);transform:translateY(-14px) scale(.85) rotate(3deg);box-shadow:0 0 0 var(--retro-shadow-color);-webkit-transition:opacity .18s cubic-bezier(.4,0,1,1),-webkit-transform .24s var(--ease-snap),box-shadow .18s ease-out;transition:opacity .18s cubic-bezier(.4,0,1,1),transform .24s var(--ease-snap),box-shadow .18s ease-out;-webkit-transition-delay:var(--btn-stagger-close, 0ms);transition-delay:var(--btn-stagger-close, 0ms)}.top-menu.from-collapsed.visible.closing .btn:nth-child(1){--btn-stagger-close: 90ms}.top-menu.from-collapsed.visible.closing .btn:nth-child(2){--btn-stagger-close: 60ms}.top-menu.from-collapsed.visible.closing .btn:nth-child(3){--btn-stagger-close: 30ms}.top-menu.from-collapsed.visible.closing .btn:nth-child(4){--btn-stagger-close: 0ms}.top-menu.from-collapsed .btn.home-link{background:var(--bg-white);border-color:var(--retro-border-color);color:var(--ink)}.top-menu.from-collapsed .btn.active{border-color:var(--pine);color:var(--pine)}[data-theme=dark] .top-menu.from-collapsed .btn{background:#32302c;backdrop-filter:blur(16px) saturate(1.3);-webkit-backdrop-filter:blur(16px) saturate(1.3);border-color:#fff8f02e;box-shadow:1px 1px #0006,0 0 0 1px #fff8f00f,0 2px 8px #0000004d}[data-theme=dark] .top-menu.from-collapsed.visible .btn{box-shadow:3px 3px #0006,0 0 0 1px #fff8f00f,0 2px 8px #0000004d}[data-theme=dark] .top-menu.from-collapsed .btn.active{border-color:#0a8a6e99;color:var(--pine);box-shadow:3px 3px #0006,0 0 0 1px #0a8a6e33,0 0 12px #0a8a6e33}@media(hover:hover){[data-theme=dark] .top-menu.from-collapsed.visible .btn:hover{background:#3c3934fa;border-color:#fff8f040;box-shadow:1.5px 1.5px #00000059,0 0 0 1px #fff8f014,0 2px 8px #00000040}}[data-theme=dark] .top-menu.from-collapsed.visible .btn:active,[data-theme=dark] .top-menu.from-collapsed.visible .btn.touch-pressed{background:#373430fc;box-shadow:0 0 #0006,0 0 0 1px #fff8f01a}[data-theme=dark] .top-menu.from-collapsed.visible.closing .btn{box-shadow:0 0 #0000004d}[data-theme=dark] .top-menu.from-collapsed .btn.home-link{background:#32302cf7;border-color:#fff8f02e}@media(min-width:840px){.top-menu.desktop.from-collapsed,.top-menu.mobile.from-collapsed{left:18px}}@media(max-width:380px){.top-menu.desktop.from-collapsed,.top-menu.mobile.from-collapsed{left:12px}}@media(min-width:1100px){.top-bar .brand-name,.top-bar .menu-toggle{transition:opacity .12s ease-out,background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease),box-shadow var(--theme-transition-duration) var(--theme-transition-ease),color var(--theme-transition-duration) var(--theme-transition-ease)}.top-bar .brand{transition:color var(--theme-transition-duration) var(--theme-transition-ease),transform var(--collapse-duration) var(--collapse-ease) .08s}.top-bar.collapsed .brand,.top-bar.collapsed .brand:active,.top-bar.collapsed .brand.tap-active{transform:translate(-86px)}.top-menu.from-collapsed .btn{-webkit-transform:translateX(16px) scale(.92);transform:translate(16px) scale(.92);-webkit-transform-origin:right center;transform-origin:right center}.top-menu.from-collapsed.visible .btn{-webkit-transform:translateX(0) scale(1);transform:translate(0) scale(1)}.top-menu.from-collapsed.visible.closing .btn{-webkit-transform:translateX(18px) scale(.88);transform:translate(18px) scale(.88)}.top-menu.from-collapsed .top-menu-content{align-items:flex-end}.top-bar:not(.collapsed) .top-menu.from-collapsed{top:14px;left:auto;right:calc(100% + 20px)}.top-bar.collapsed .top-menu.from-collapsed{left:auto;right:calc(100% + 20px)}.top-menu.from-collapsed.closing{top:calc(100% + 8px);left:auto;right:calc(100% + 20px)}.top-bar:not(.collapsed) .brand{transform:translate(0)}}@media(max-width:1099px){.top-bar.collapsed .brand-mark{opacity:0;pointer-events:none;transition:opacity .25s ease-out}.top-bar.collapsed .brand-mark:after{animation:none}.top-bar.collapsed .brand-mark-inner{box-shadow:none}}.mobile-fab{position:fixed;--fab-base-bottom: calc(20px + var(--safe-area-inset-bottom));bottom:var(--fab-base-bottom);right:30px;z-index:var(--z-fixed);display:flex;flex-direction:column;align-items:flex-end;will-change:transform,opacity;opacity:0;pointer-events:none;--dock-offset-x: 0px;--dock-offset-y: 0px;transform:translate3d(var(--dock-offset-x),var(--dock-offset-y),0);transition:opacity .2s cubic-bezier(.4,0,1,1)}.mobile-fab.visible{opacity:1;pointer-events:auto}.mobile-fab.exiting{opacity:1;pointer-events:none}.mobile-fab.pagination-frozen{opacity:0!important;pointer-events:none}.mobile-fab.docking:not(.exiting){transition:none}.mobile-fab.docked:not(.exiting){position:absolute;right:20px;top:50%;bottom:auto;transform:translateY(-50%);transition:none;pointer-events:auto}.fab-photo-wrapper{position:relative;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transform:scale(0) translateY(8px);opacity:0;will-change:transform,opacity;transition:transform .28s cubic-bezier(.4,0,.7,.2),opacity .22s cubic-bezier(.4,0,1,1)}@keyframes fabSpringIn{0%{transform:scale(0) translateY(8px);opacity:0}50%{transform:scale(1.1) translateY(-3px);opacity:1}75%{transform:scale(.97) translateY(1px)}to{transform:scale(1) translateY(0);opacity:1}}@keyframes fabSpringOut{0%{transform:scale(1) translateY(0);opacity:1}25%{transform:scale(1.06) translateY(-2px);opacity:1}to{transform:scale(0) translateY(8px);opacity:0}}.mobile-fab.visible:not(.bouncing):not(.exiting) .fab-photo-wrapper{transform:scale(1) translateY(0);opacity:1}.mobile-fab.visible.bouncing .fab-photo-wrapper{animation:fabSpringIn .42s cubic-bezier(.34,1.4,.64,1) both}.mobile-fab.exiting .fab-photo-wrapper{animation:fabSpringOut .28s cubic-bezier(.4,0,.7,.2) forwards}.mobile-fab.docking:not(.exiting):not(.bouncing) .fab-photo-wrapper,.mobile-fab.docked:not(.exiting):not(.bouncing) .fab-photo-wrapper{animation:none;transform:scale(1) translateY(0);opacity:1;transition:none}.fab-photo{width:48px;height:48px;border-radius:var(--radius-full);border:1.5px solid var(--retro-border-color);background:var(--color-bg);display:grid;place-items:center;overflow:hidden;box-shadow:0 0 0 1px #1f1a141f,0 2px 4px #1f1a1440,0 4px 12px -2px #1f1a1433;transition:border-color .2s ease,box-shadow .2s ease,background-color var(--theme-transition-duration) var(--theme-transition-ease);touch-action:none;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.fab-photo img{width:100%;height:100%;object-fit:contain;-webkit-user-drag:none;pointer-events:none}.fab-photo-wrapper:after{content:"";position:absolute;inset:-2px;border-radius:50%;border:2px solid var(--pine);opacity:0;pointer-events:none;animation:ring-pulse 4s ease-out 2s infinite}.fab-photo-wrapper:active .fab-photo{border-color:var(--pine);box-shadow:0 0 6px #0a8a6e59,0 1px 2px #1f1a144d,0 2px 6px #1f1a1426;transform:scale(.96);transition:transform .08s ease,box-shadow .08s ease,border-color .08s ease}.mobile-fab.dragging .fab-photo{box-shadow:0 0 0 1px #1f1a141a,0 4px 8px #1f1a144d,0 8px 20px -4px #1f1a1440;transition:box-shadow .15s ease}[data-theme=dark] .fab-photo{box-shadow:0 0 0 1px #ffffff14,0 2px 4px #00000059,0 4px 12px -2px #0000004d}[data-theme=dark] .mobile-fab.dragging .fab-photo{box-shadow:0 0 0 1px #ffffff14,0 4px 10px #00000073,0 10px 24px -4px #0006}.mobile-fab.snapping .fab-photo{box-shadow:0 0 0 1px #1f1a141f,0 2px 4px #1f1a1440,0 4px 12px -2px #1f1a1433;transition:box-shadow .45s cubic-bezier(.175,.885,.32,1.275)}[data-theme=dark] .mobile-fab.snapping .fab-photo{box-shadow:0 0 0 1px #ffffff14,0 2px 4px #00000059,0 4px 12px -2px #0000004d}.fab-menu.instant-hide,.fab-menu.instant-hide .btn,.fab-menu.instant-hide .fab-menu-content{transition:none!important;-webkit-transition:none!important;opacity:0!important;visibility:hidden!important;pointer-events:none!important}.fab-menu{position:absolute;bottom:calc(100% + 12px);right:0;display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-sm);background:transparent;border:none;box-shadow:none;padding:0;min-width:auto;opacity:1;pointer-events:none}.fab-menu.visible{pointer-events:auto}.fab-menu.closing{pointer-events:none}.fab-menu-content{display:flex;flex-direction:column;width:auto;gap:var(--space-sm);align-items:flex-end}.fab-menu .btn{min-width:auto;padding:.45rem .9rem .35rem;font-size:var(--text-base);font-weight:600;background:var(--bg-white);border-color:var(--retro-border-color);color:var(--ink);opacity:0;-webkit-transform:translateY(12px) scale(.88) rotate(2deg);transform:translateY(12px) scale(.88) rotate(2deg);-webkit-transform-origin:right center;transform-origin:right center;box-shadow:1px 1px 0 var(--retro-shadow-color);-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-transition:opacity .28s var(--ease-out),-webkit-transform var(--duration-slower) var(--ease-bounce),box-shadow .32s var(--ease-bounce);transition:opacity .28s var(--ease-out),transform var(--duration-slower) var(--ease-bounce),box-shadow .32s var(--ease-bounce);-webkit-transition-delay:var(--btn-stagger, 0ms);transition-delay:var(--btn-stagger, 0ms)}.fab-menu.visible .btn{opacity:1;-webkit-transform:translateY(0) scale(1) rotate(0deg);transform:translateY(0) scale(1) rotate(0);box-shadow:2px 2px 0 var(--retro-shadow-color)}.fab-menu .btn:nth-child(1){--btn-stagger: .17s}.fab-menu .btn:nth-child(2){--btn-stagger: .12s}.fab-menu .btn:nth-child(3){--btn-stagger: 70ms}.fab-menu .btn:nth-child(4){--btn-stagger: 20ms}.fab-menu.visible .btn:active,.fab-menu.visible .btn.touch-pressed{transform:translate(2px,2px);box-shadow:0 0 0 var(--retro-shadow-color);transition:transform .06s ease-out,box-shadow .06s ease-out}.fab-menu .btn.active{border-color:var(--pine);color:var(--pine)}.fab-menu .btn.home-link{background:var(--bg-white);border-color:var(--retro-border-color);color:var(--ink)}.fab-menu.visible.closing .btn{opacity:0;-webkit-transform:translateY(14px) scale(.85) rotate(-3deg);transform:translateY(14px) scale(.85) rotate(-3deg);box-shadow:0 0 0 var(--retro-shadow-color);-webkit-transition:opacity .18s cubic-bezier(.4,0,1,1),-webkit-transform .24s var(--ease-snap),box-shadow .18s ease-out;transition:opacity .18s cubic-bezier(.4,0,1,1),transform .24s var(--ease-snap),box-shadow .18s ease-out;-webkit-transition-delay:var(--btn-stagger-close, 0ms);transition-delay:var(--btn-stagger-close, 0ms)}.fab-menu.visible.closing .btn:nth-child(1){--btn-stagger-close: 0ms}.fab-menu.visible.closing .btn:nth-child(2){--btn-stagger-close: 40ms}.fab-menu.visible.closing .btn:nth-child(3){--btn-stagger-close: 80ms}.fab-menu.visible.closing .btn:nth-child(4){--btn-stagger-close: .12s}[data-theme=dark] .fab-menu .btn{background:#37342f;backdrop-filter:blur(16px) saturate(1.3);-webkit-backdrop-filter:blur(16px) saturate(1.3);border-color:#fff8f02e;box-shadow:2px 2px #0006,0 0 0 1px #fff8f00f,0 2px 8px #0000004d}[data-theme=dark] .fab-menu.visible .btn{box-shadow:2px 2px #0006,0 0 0 1px #fff8f00f,0 2px 8px #0000004d}[data-theme=dark] .fab-menu .btn.active{border-color:#0a8a6e99;color:var(--pine);box-shadow:2px 2px #0006,0 0 0 1px #0a8a6e33,0 0 12px #0a8a6e33}@media(hover:hover){[data-theme=dark] .fab-menu.visible .btn:hover{background:#46433cf2;border-color:#fff8f040;box-shadow:1px 1px #00000059,0 0 0 1px #fff8f014,0 2px 8px #00000040}}[data-theme=dark] .fab-menu.visible .btn:active,[data-theme=dark] .fab-menu.visible .btn.touch-pressed{background:#413e39f7;box-shadow:0 0 #0006,0 0 0 1px #fff8f01a}[data-theme=dark] .fab-menu.visible.closing .btn{box-shadow:0 0 #0000004d}[data-theme=dark] .fab-menu .btn.home-link{background:#37342feb;border-color:#fff8f02e}@media(max-width:360px){.fab-photo{width:40px;height:40px}.mobile-fab{--fab-base-bottom: calc(16px + var(--safe-area-inset-bottom))}}@media(max-width:320px){.fab-photo{width:36px;height:36px}.mobile-fab{--fab-base-bottom: calc(12px + var(--safe-area-inset-bottom))}}@media(prefers-reduced-motion:reduce){.fab-photo-wrapper{transition:opacity .1s ease}.mobile-fab.visible.bouncing .fab-photo-wrapper,.mobile-fab.exiting .fab-photo-wrapper{animation:none}.mobile-fab.visible.bouncing .fab-photo-wrapper{transform:scale(1) translateY(0);opacity:1}.mobile-fab.exiting .fab-photo-wrapper{transform:scale(0) translateY(8px);opacity:0}}.carousel-container{position:relative;margin-top:24px;width:100%;overflow:visible;mask-image:linear-gradient(to right,transparent 0%,black 10%,black 90%,transparent 100%);-webkit-mask-image:linear-gradient(to right,transparent 0%,black 10%,black 90%,transparent 100%)}.carousel-track{display:flex;gap:var(--space-xl);overflow-x:auto;scroll-behavior:auto;padding:20px 5vw;align-items:center;scrollbar-width:none;-ms-overflow-style:none}.carousel-track::-webkit-scrollbar{display:none}.carousel-item-wrapper{display:flex;flex-direction:column;align-items:center;align-self:flex-start;flex:0 0 auto}.carousel-item{position:relative;flex:0 0 auto;height:320px;width:auto;border:var(--border-retro);border-radius:var(--radius-sm);overflow:hidden;padding:0;background:var(--bg-card);cursor:pointer;box-shadow:var(--shadow-retro-sm);display:inline-flex;align-items:center;justify-content:center;transform:translateY(0) scale(1);transition:transform .42s var(--ease-out),box-shadow var(--theme-transition-duration) var(--theme-transition-ease),background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease)}.carousel-item img{height:100%;width:auto;min-width:1px;object-fit:contain;display:block}.carousel-item.is-active{transform:translateY(-8px) scale(1.01);box-shadow:4px 6px 3px var(--retro-shadow-color)}.carousel-item:active{transform:translateY(2px) scale(.98);box-shadow:1px 2px 0 var(--retro-shadow-color);transition:transform .09s ease-out,box-shadow .09s ease-out}.gif-badge{position:absolute;top:10px;right:10px;background:var(--color-badge);color:var(--ink);font-size:.64rem;font-weight:900;line-height:1;padding:.2rem .28rem .02rem;border:var(--border-retro);border-radius:var(--radius-sm);pointer-events:none}.carousel-item-caption{margin:.5rem 0 0;padding:0 .25rem;font-size:.8rem;font-style:italic;line-height:1.3;color:var(--color-text-muted);text-align:center;max-width:280px;transition:color var(--theme-transition-duration) var(--theme-transition-ease)}.carousel-caption{text-align:center;font-size:.9rem;font-style:italic;color:var(--color-text-muted);margin:0}.about-carousel{margin-top:.75rem;margin-bottom:0}@media(max-width:720px){.carousel-item{height:220px}.carousel-container{mask-image:linear-gradient(to right,transparent 0%,black 5%,black 95%,transparent 100%);-webkit-mask-image:linear-gradient(to right,transparent 0%,black 5%,black 95%,transparent 100%)}.carousel-item-caption{font-size:.75rem;max-width:200px}}@media(max-width:720px)and (hover:none){.carousel-track{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.carousel-item{scroll-snap-align:center}}.footnote-trigger{display:inline-flex;align-items:center;justify-content:center;vertical-align:super;position:relative;top:-.15em;margin:0 .06em;width:1em;height:1em;min-width:15px;min-height:15px;background:var(--aero);color:#fff;border:1px solid var(--pine);border-radius:50%;box-shadow:.5px .5px 0 var(--retro-shadow-color);font-family:var(--font-mono);font-size:.55em;font-weight:700;line-height:1;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;transition:transform var(--duration-fast) var(--ease-out),background-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out),border-color var(--theme-transition-duration) var(--theme-transition-ease)}.footnote-trigger-number{position:relative;top:-.5px}@media(pointer:coarse){.footnote-trigger:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;border-radius:50%}}@media(hover:hover){.footnote-trigger:hover{background:var(--pine);transform:scale(1.15) translateY(-1px);box-shadow:1px 1px 0 var(--retro-shadow-color)}}.footnote-trigger:active,.footnote-trigger.tap-active{transform:scale(.95);box-shadow:0 0 0 var(--retro-shadow-color);transition:transform .06s ease-out,box-shadow .06s ease-out}.footnote-trigger--active{background:var(--clay);border-color:var(--clay);transform:scale(1.2);box-shadow:1px 1px 0 var(--retro-shadow-color)}@media(hover:hover){.footnote-trigger--active:hover{background:var(--clay);border-color:var(--clay)}}.footnote-trigger:focus-visible{outline:2px dashed var(--clay);outline-offset:3px}.footnote-popup{position:fixed;z-index:var(--z-modal);max-width:320px;background:var(--panel-bg);border:1.5px solid var(--retro-border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-retro-sm),0 8px 24px var(--shadow-color);animation:footnote-popIn .25s var(--ease-bounce);overflow:hidden}.footnote-popup--below{transform-origin:top center}.footnote-popup--above{transform:translateY(-100%);transform-origin:bottom center}.footnote-popup-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-base);border-bottom:1px dashed var(--color-border);background:var(--color-surface-elevated)}.footnote-popup-number{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:var(--aero);color:#fff;border:1.5px solid var(--pine);border-radius:50%;font-family:var(--font-mono);font-size:.7rem;font-weight:700;line-height:1;box-shadow:1px 1px 0 var(--retro-shadow-color)}.footnote-popup-close{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--color-ghost-bg);border:1px solid var(--color-border);border-radius:50%;color:var(--color-text-muted);font-size:1.1rem;line-height:1;cursor:pointer;box-shadow:1px 1px #00000040;transition:background-color var(--duration-fast) ease,color var(--duration-fast) ease,transform var(--duration-fast) ease,box-shadow var(--duration-fast) ease}@media(hover:hover){.footnote-popup-close:hover{background:var(--color-surface-warning);color:var(--clay);transform:scale(1.1)}}.footnote-popup-close:active{transform:scale(.85);background:var(--color-surface-warning);color:var(--clay)}.footnote-popup-close--pressed{transform:scale(.8)!important;background:var(--clay)!important;color:#fff!important;transition:transform .08s ease-out,background-color .08s ease-out,color .08s ease-out!important}.footnote-popup-close:focus-visible{outline:2px dashed var(--clay);outline-offset:2px}.footnote-popup-content{padding:var(--space-base) var(--space-lg);font-family:var(--font-body);font-size:.88rem;line-height:var(--leading-relaxed);color:var(--color-text)}.footnote-popup-content em{font-style:italic}.footnote-popup-content strong{font-weight:600}.footnote-popup-content code{font-family:var(--font-mono);font-size:.85em;color:var(--pine);background:var(--color-ghost-bg);padding:.1em .35em;border-radius:3px;border:1px solid var(--line)}.footnote-popup-content a{color:var(--aero);text-decoration:underline;text-decoration-color:var(--line);text-underline-offset:2px;transition:color var(--duration-fast) ease,text-decoration-color var(--duration-fast) ease}@media(hover:hover){.footnote-popup-content a:hover{color:var(--clay);text-decoration-color:var(--clay)}}@keyframes footnote-popIn{0%{opacity:0;transform:scale(.85)}50%{opacity:1}to{opacity:1;transform:scale(1)}}.footnote-popup--above{animation-name:footnote-popInAbove}@keyframes footnote-popInAbove{0%{opacity:0;transform:translateY(-100%) scale(.85)}50%{opacity:1}to{opacity:1;transform:translateY(-100%) scale(1)}}.footnote-popup--closing{animation:footnote-popOut .15s ease-out forwards}.footnote-popup--closing.footnote-popup--above{animation-name:footnote-popOutAbove}@keyframes footnote-popOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.9)}}@keyframes footnote-popOutAbove{0%{opacity:1;transform:translateY(-100%) scale(1)}to{opacity:0;transform:translateY(-100%) scale(.9)}}[data-theme=dark] .footnote-trigger{color:#fff;box-shadow:1px 1px 2px #00000080}[data-theme=dark] .footnote-popup-number{color:#fff}[data-theme=dark] .footnote-popup-close{color:var(--color-text-muted);box-shadow:1px 1px 2px #00000080}[data-theme=dark] .footnote-popup-close--pressed{background:var(--clay)!important;color:#000!important}@media(max-width:480px){.footnote-popup-content{font-size:.9rem;padding:var(--space-base)}}@media(prefers-reduced-motion:reduce){.footnote-trigger{transition:none}.footnote-popup{animation:none}.footnote-popup-close{transition:none}}.lightbox-overlay{position:fixed;inset:0;z-index:var(--z-modal);display:grid;place-items:center;padding:max(20px,env(safe-area-inset-top,20px)) max(20px,env(safe-area-inset-right,20px)) max(20px,env(safe-area-inset-bottom,20px)) max(20px,env(safe-area-inset-left,20px));animation:none}.lightbox-backdrop{position:fixed;top:50%;left:50%;width:200vw;height:200vh;height:200lvh;transform:translate(-50%,-50%) translateZ(0);-webkit-transform:translate(-50%,-50%) translateZ(0);background:var(--color-overlay);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:none!important;will-change:opacity;backface-visibility:hidden;-webkit-backface-visibility:hidden;contain:strict;opacity:0;animation:lightbox-backdropFadeIn .18s ease-out forwards}@keyframes lightbox-backdropFadeIn{0%{opacity:0}to{opacity:1}}.lightbox-frame{position:relative;z-index:1;max-width:calc(100vw - 40px - env(safe-area-inset-left,0px) - env(safe-area-inset-right,0px));max-height:calc(100vh - 40px - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px));max-height:calc(100dvh - 40px - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px));animation:lightbox-contentPopIn var(--duration-slow) var(--ease-bounce)}.lightbox-content{border:2px solid var(--retro-border-color);border-radius:var(--radius-sm);background:var(--color-bg);padding:var(--space-sm);box-shadow:8px 8px 0 var(--retro-shadow-color);overflow:hidden}.lightbox-content img,.lightbox-content .progressive-image__img{max-width:min(calc(100vw - 60px),800px);max-height:min(calc(100vh - 60px),700px);max-height:min(calc(100dvh - 60px),700px);width:auto;height:auto;display:block;border-radius:4px;object-fit:contain}.lightbox-content .progressive-image{display:block;max-width:100%;max-height:100%;border-radius:4px}.lightbox-close{position:absolute;top:-16px;right:-16px;z-index:10;width:32px;height:32px;border-radius:50%;background:var(--clay);color:#fff;border:2px solid var(--retro-border-color);font-size:1.2rem;line-height:1;display:grid;place-items:center;cursor:pointer;box-shadow:var(--shadow-retro-sm);transition:transform var(--duration-fast) ease,color var(--theme-transition-duration) var(--theme-transition-ease),background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease),box-shadow var(--theme-transition-duration) var(--theme-transition-ease)}[data-theme=dark] .lightbox-close{color:#000}@media(hover:hover){.lightbox-close:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--retro-shadow-color)}}.lightbox-close:active{transform:translate(2px,2px);box-shadow:0 0 0 var(--retro-shadow-color)}@keyframes lightbox-contentPopIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.code-block{border:var(--border-retro);border-radius:var(--radius-sm);background:var(--bg-white);box-shadow:var(--shadow-retro-sm);overflow:hidden;margin:1.5rem 0;font-family:var(--font-mono)}.code-block-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:6px 10px;background:var(--color-code-header);border-bottom:1px solid var(--color-border)}.code-block-lang{font-size:var(--text-xs);font-weight:600;letter-spacing:.05em;color:var(--ink);padding:.25rem .5rem .2rem;background:var(--bg-white);border-radius:var(--radius-sm);border:var(--border-retro);box-shadow:1px 1px 0 var(--shadow-color);line-height:1}.code-block-actions{display:flex;align-items:center;gap:var(--space-base)}.code-block-lines{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:500}.code-block-copy{display:inline-flex;align-items:center;gap:5px;padding:.2rem .5rem;font-size:.7rem;font-weight:600;font-family:var(--font-body);color:var(--ink);-webkit-text-fill-color:var(--ink);background:var(--bg-white);border:var(--border-retro);border-radius:4px;cursor:pointer;transition:background-color var(--theme-transition-duration) var(--theme-transition-ease),transform var(--duration-fast) ease,box-shadow var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease),color var(--duration-fast) ease,-webkit-text-fill-color var(--duration-fast) ease;box-shadow:1.5px 1.5px 0 var(--retro-shadow-color);min-width:64px;height:24px;justify-content:center}@media(hover:hover){.code-block-copy:hover{background:var(--color-surface-hover);transform:translate(1px,1px);box-shadow:1px 1px 0 var(--retro-shadow-color);color:var(--pine);-webkit-text-fill-color:var(--pine)}}.code-block-copy:active{transform:translate(2px,2px);box-shadow:0 0 0 var(--retro-shadow-color)}.code-block-copy svg{flex-shrink:0}.code-block-copy .copy-icon,.code-block-copy .copy-text{transition:opacity var(--duration-normal) ease,transform .25s var(--ease-bounce)}.code-block-copy.copied{background:var(--color-surface-success);border-color:var(--pine);color:var(--pine)}.code-block-copy.copied .copy-icon{animation:code-checkPop .35s var(--ease-bounce)}@keyframes code-checkPop{0%{transform:scale(.5) rotate(-10deg);opacity:0}50%{transform:scale(1.15) rotate(5deg)}to{transform:scale(1) rotate(0);opacity:1}}.code-block-wrap{display:inline-flex;align-items:center;gap:5px;padding:.2rem .5rem;font-size:.7rem;font-weight:600;font-family:var(--font-body);color:var(--ink);-webkit-text-fill-color:var(--ink);background:var(--bg-white);border:var(--border-retro);border-radius:4px;cursor:pointer;transition:background-color var(--theme-transition-duration) var(--theme-transition-ease),transform var(--duration-fast) ease,box-shadow var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease),color var(--duration-fast) ease,-webkit-text-fill-color var(--duration-fast) ease;box-shadow:1.5px 1.5px 0 var(--retro-shadow-color);min-width:64px;height:24px;justify-content:center}@media(hover:hover){.code-block-wrap:hover{background:var(--color-surface-hover);transform:translate(1px,1px);box-shadow:1px 1px 0 var(--retro-shadow-color);color:var(--pine);-webkit-text-fill-color:var(--pine)}}.code-block-wrap:active{transform:translate(2px,2px);box-shadow:0 0 0 var(--retro-shadow-color)}.code-block-wrap svg{flex-shrink:0}.code-block-wrap.active{background:var(--color-surface-success);border-color:var(--pine);color:var(--pine);-webkit-text-fill-color:var(--pine)}.code-block-content{position:relative;max-height:none;overflow:hidden;background:var(--bg-card)}.code-block-content.truncated{max-height:280px}.code-block-content pre{margin:0;padding:var(--space-xl);background:transparent;border-radius:0;overflow-x:auto;font-size:.78rem;line-height:var(--leading-relaxed)}.code-block-content code{color:var(--code-text);font-family:inherit;white-space:pre;display:block}.code-block-content code.wrapped{white-space:pre-wrap;word-break:break-word}:root{--code-text: #403931;--code-bg: var(--bg-card);--code-comment: #728a6e;--code-string: #a85d3b;--code-number: #0f7363;--code-keyword: #8b4049;--code-function: #3d7a5c;--code-operator: #6b5d53;--code-punctuation: #7d7067;--code-property: #7c5a3c;--code-class: #6b5b8c;--code-tag: #9a4a4a;--code-attr-name: #6b7353;--code-attr-value: #a85d3b;--code-regex: #8b6b8c;--code-important: #5c4033;--code-variable: #4a4039;--code-deleted: #9e4a4a;--code-deleted-bg: rgba(158, 74, 74, .1);--code-inserted: #3d7a5c;--code-inserted-bg: rgba(61, 122, 92, .1);--code-selection: rgba(15, 115, 99, .15)}[data-theme=dark]{--code-text: #d4cfc7;--code-bg: var(--bg-card);--code-comment: #7a9a74;--code-string: #d4956a;--code-number: #4ec9b0;--code-keyword: #d19a9a;--code-function: #7cc9a0;--code-operator: #b0a89e;--code-punctuation: #9a9284;--code-property: #d4b47a;--code-class: #b4a4d4;--code-tag: #d49a9a;--code-attr-name: #a4b48c;--code-attr-value: #d4956a;--code-regex: #c4a4c4;--code-important: #f0e8dc;--code-variable: #c4bcb0;--code-deleted: #d49a9a;--code-deleted-bg: rgba(212, 154, 154, .12);--code-inserted: #7cc9a0;--code-inserted-bg: rgba(124, 201, 160, .12);--code-selection: rgba(78, 201, 176, .2)}.code-block-content code .token{transition:color var(--theme-transition-duration) var(--theme-transition-ease)}.code-block-content code .token.comment,.code-block-content code .token.prolog,.code-block-content code .token.doctype,.code-block-content code .token.cdata{color:var(--code-comment);font-style:italic}.code-block-content code .token.punctuation{color:var(--code-punctuation)}.code-block-content code .token.namespace{opacity:.8}.code-block-content code .token.property,.code-block-content code .token.symbol{color:var(--code-property)}.code-block-content code .token.tag{color:var(--code-tag)}.code-block-content code .token.deleted{color:var(--code-deleted);background:var(--code-deleted-bg)}.code-block-content code .token.boolean,.code-block-content code .token.number,.code-block-content code .token.constant{color:var(--code-number)}.code-block-content code .token.selector,.code-block-content code .token.attr-name{color:var(--code-attr-name)}.code-block-content code .token.string,.code-block-content code .token.char,.code-block-content code .token.attr-value,.code-block-content code .token.builtin{color:var(--code-string)}.code-block-content code .token.inserted{color:var(--code-inserted);background:var(--code-inserted-bg)}.code-block-content code .token.operator,.code-block-content code .token.entity,.code-block-content code .token.url,.code-block-content code .language-css .token.string,.code-block-content code .style .token.string{color:var(--code-operator)}.code-block-content code .token.atrule,.code-block-content code .token.keyword,.code-block-content code .token.control,.code-block-content code .token.directive,.code-block-content code .token.unit{color:var(--code-keyword)}.code-block-content code .token.function,.code-block-content code .token.function-variable{color:var(--code-function)}.code-block-content code .token.class-name{color:var(--code-class)}.code-block-content code .token.regex{color:var(--code-regex)}.code-block-content code .token.important,.code-block-content code .token.bold{color:var(--code-important);font-weight:600}.code-block-content code .token.italic{font-style:italic}.code-block-content code .token.variable{color:var(--code-variable)}.code-block-content code .token.entity{cursor:help}.code-block-content code.language-markdown .token.title,.code-block-content code.language-markdown .token.title .token.punctuation{color:var(--code-keyword);font-weight:600}.code-block-content code.language-markdown .token.blockquote,.code-block-content code.language-markdown .token.blockquote .token.punctuation{color:var(--code-comment);font-style:italic}.code-block-content code.language-markdown .token.code,.code-block-content code.language-markdown .token.code-snippet{color:var(--code-string)}.code-block-content code.language-markdown .token.bold .token.content{color:var(--code-important);font-weight:600}.code-block-content code.language-markdown .token.italic .token.content{color:var(--code-property);font-style:italic}.code-block-content code.language-markdown .token.strike .token.content{text-decoration:line-through}.code-block-content code.language-markdown .token.url,.code-block-content code.language-markdown .token.url-reference .token.url{color:var(--code-function);text-decoration:underline}.code-block-content code.language-markdown .token.list.punctuation{color:var(--code-keyword)}.code-block-content code.language-markdown .token.hr{color:var(--code-punctuation)}.code-block-content code.language-json .token.property{color:var(--code-property)}.code-block-content code.language-json .token.operator{color:var(--code-punctuation)}.code-block-content code.language-yaml .token.key{color:var(--code-property)}.code-block-content code.language-yaml .token.tag{color:var(--code-keyword)}.code-block-content code.language-css .token.selector{color:var(--code-tag)}.code-block-content code.language-css .token.property{color:var(--code-property)}.code-block-content code.language-css .token.function{color:var(--code-function)}.code-block-content code.language-css .token.important{color:var(--code-keyword)}.code-block-content code.language-bash .token.function,.code-block-content code.language-shell .token.function{color:var(--code-function)}.code-block-content code.language-bash .token.builtin,.code-block-content code.language-shell .token.builtin{color:var(--code-keyword)}.code-block-content code.language-bash .token.shebang,.code-block-content code.language-shell .token.shebang{color:var(--code-comment);font-style:italic}.code-block-content code.language-diff .token.deleted{color:var(--code-deleted);background:var(--code-deleted-bg);display:inline-block;width:100%}.code-block-content code.language-diff .token.inserted{color:var(--code-inserted);background:var(--code-inserted-bg);display:inline-block;width:100%}.code-block-content code.language-diff .token.coord{color:var(--code-class)}.code-block-content code.language-git .token.commit_sha1{color:var(--code-number)}.code-block-content code.language-graphql .token.type-def{color:var(--code-class)}.code-block-content code.language-graphql .token.directive{color:var(--code-keyword)}.code-block-content code.language-jsx .token.tag .token.tag,.code-block-content code.language-tsx .token.tag .token.tag{color:var(--code-tag)}.code-block-content code.language-jsx .token.tag .token.class-name,.code-block-content code.language-tsx .token.tag .token.class-name{color:var(--code-class)}.code-block-content code.language-jsx .token.attr-name,.code-block-content code.language-tsx .token.attr-name{color:var(--code-attr-name)}.code-block-content code.language-jsx .token.attr-value,.code-block-content code.language-tsx .token.attr-value{color:var(--code-attr-value)}.code-block-content code.language-typescript .token.type,.code-block-content code.language-tsx .token.type{color:var(--code-class)}.code-block-content code.language-typescript .token.generic-function,.code-block-content code.language-tsx .token.generic-function{color:var(--code-function)}.code-block-content code.language-python .token.decorator,.code-block-content code.language-python .token.decorator .token.function{color:var(--code-class)}.code-block-content code.language-python .token.triple-quoted-string{color:var(--code-comment);font-style:italic}.code-block-content code.language-rust .token.lifetime{color:var(--code-class)}.code-block-content code.language-rust .token.macro{color:var(--code-function)}.code-block-content code.language-go .token.builtin{color:var(--code-keyword)}.code-block-content code.language-sql .token.keyword{color:var(--code-keyword);text-transform:uppercase}.code-block-content code.language-docker .token.instruction{color:var(--code-keyword)}.code-block-content code::selection,.code-block-content code *::selection{background:var(--code-selection)}.code-block-content code::-moz-selection,.code-block-content code *::-moz-selection{background:var(--code-selection)}.code-block-fade{position:absolute;bottom:0;left:0;right:0;height:80px;pointer-events:none;background:linear-gradient(to top,var(--gradient-fade-end) 0%,var(--gradient-fade-end) 20%,transparent 100%);transition:--gradient-fade-end var(--theme-transition-duration) var(--theme-transition-ease)}html:not(.theme-ready) .code-block-fade{transition:none}.code-block-expand{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);width:100%;padding:10px var(--space-xl);font-size:.85rem;font-weight:600;font-family:var(--font-body);color:var(--ink);background:var(--color-code-header);border:none;border-top:1px solid var(--color-border);cursor:pointer;transition:background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease),color var(--theme-transition-duration) var(--theme-transition-ease)}@media(hover:hover){.code-block-expand:hover{background:var(--color-code-hover);color:var(--pine)}}.code-block-expand svg{flex-shrink:0}.post-body .code-block{margin:1rem 0 1.5rem}.post-body .code-block pre{background:transparent;color:var(--ink);border:none;box-shadow:none;padding:var(--space-xl);border-radius:0}.toast{position:absolute;right:0;transform:translateY(0);bottom:calc(100% + 10px);background:var(--bg-white);color:var(--ink);border:var(--border-retro);padding:.34rem .72rem .26rem;border-radius:var(--radius-sm);font-size:.77rem;font-weight:600;white-space:nowrap;pointer-events:none;text-align:center;z-index:var(--z-dropdown);box-shadow:2px 2px 0 var(--shadow-color);animation:toast-pop var(--duration-slower) var(--ease-bounce) forwards,toast-fade .32s ease forwards 1.5s;display:flex;align-items:center;justify-content:center}.toast:after{display:none}@keyframes toast-pop{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toast-fade{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(6px) scale(.99)}}.post-card{position:relative;will-change:transform,opacity}.post-card+.post-card{margin-top:var(--space-3xl);padding-top:var(--space-3xl)}.post-card+.post-card:before{content:"◆";position:absolute;top:0;left:50%;transform:translate(-50%);font-size:.6rem;color:var(--pine);background:var(--panel-bg);padding:0 .75rem;z-index:1}.post-card+.post-card:after{content:"";position:absolute;top:.35rem;left:0;right:0;border-top:1px dashed var(--line)}.post-card h3{margin:0;line-height:var(--leading-snug)}.post-head{display:grid;grid-template-columns:1fr auto;grid-template-areas:"meta link" "summary summary";column-gap:var(--space-base);row-gap:var(--space-sm);align-items:flex-start;position:relative;cursor:pointer}.post-meta{grid-area:meta;min-width:0}.post-meta .eyebrow{margin-bottom:4px;font-size:.72rem;font-weight:600;letter-spacing:.08em;transition:color var(--duration-normal) var(--ease-out)}.eyebrow-dot{color:var(--pine);margin:0 .35em;font-size:1em;position:relative;top:-.1em;-webkit-text-fill-color:var(--pine);background:none!important}.post-meta h3{margin:0;font-size:var(--text-2xl)}.post-excerpt{grid-area:summary;margin:0;font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text-muted);max-height:calc(4 * var(--leading-normal) * 1em);overflow:hidden;position:relative;transition:color var(--duration-normal) var(--ease-out)}.post-excerpt.has-overflow:after{content:"";position:absolute;bottom:0;right:0;width:50%;height:calc(var(--leading-normal) * 1em);pointer-events:none;z-index:1;background:linear-gradient(to right,var(--gradient-fade-start) 0%,var(--gradient-fade-end) 100%);transition:--gradient-fade-start var(--theme-transition-duration) var(--theme-transition-ease),--gradient-fade-end var(--theme-transition-duration) var(--theme-transition-ease)}html:not(.theme-ready) .post-excerpt.has-overflow:after{transition:none}.link-btn-wrapper{grid-area:link;display:inline-flex;align-items:center;justify-content:center;position:relative;justify-self:end;align-self:start;z-index:2}.post-title-link{color:var(--ink);text-decoration:none;transition:color var(--theme-transition-duration) var(--theme-transition-ease),transform .08s ease-out;display:inline-block}.post-title-link.title-style-shimmer:not(.touch-title),.title-style-shimmer .post-title-link:not(.touch-title){--shimmer-x: 50%;--shimmer-width: 0%;background:linear-gradient(90deg,var(--shimmer-base) 0%,var(--shimmer-base) calc(var(--shimmer-x) - var(--shimmer-width) * 1.8),color-mix(in srgb,var(--shimmer-accent) 3%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * 1.6),color-mix(in srgb,var(--shimmer-accent) 8%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * 1.4),color-mix(in srgb,var(--shimmer-accent) 18%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * 1.2),color-mix(in srgb,var(--shimmer-accent) 35%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * 1),color-mix(in srgb,var(--shimmer-accent) 65%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * .5),color-mix(in srgb,var(--shimmer-accent) 90%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * .15),var(--shimmer-accent) var(--shimmer-x),color-mix(in srgb,var(--shimmer-accent) 90%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * .15),color-mix(in srgb,var(--shimmer-accent) 65%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * .5),color-mix(in srgb,var(--shimmer-accent) 35%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * 1),color-mix(in srgb,var(--shimmer-accent) 18%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * 1.2),color-mix(in srgb,var(--shimmer-accent) 8%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * 1.4),color-mix(in srgb,var(--shimmer-accent) 3%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * 1.6),var(--shimmer-base) calc(var(--shimmer-x) + var(--shimmer-width) * 1.8),var(--shimmer-base) 100%);background-size:100% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(-.5px -.5px 0 var(--shimmer-highlight)) drop-shadow(1px 1px 0 var(--shimmer-shadow-1)) drop-shadow(1px 1px 0 var(--shimmer-shadow-2));transition:--shimmer-width .35s cubic-bezier(.16,1,.3,1),--shimmer-base var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-accent var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-highlight var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-1 var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-2 var(--theme-transition-duration) var(--theme-transition-ease),filter var(--theme-transition-duration) var(--theme-transition-ease),transform .08s ease-out}.post-title-link.shimmer-hidden,.title-style-shimmer .post-title-link.shimmer-hidden,.eyebrow.eyebrow-shimmer.shimmer-hidden{background:var(--shimmer-base)!important;-webkit-background-clip:text!important;background-clip:text!important;-webkit-text-fill-color:transparent!important}@media(hover:hover){.post-title-link.title-style-shimmer:not(.touch-title):hover,.title-style-shimmer .post-title-link:not(.touch-title):hover,.title-style-shimmer .post-head:hover .post-title-link:not(.touch-title){filter:drop-shadow(-.5px -.5px 0 var(--shimmer-highlight)) drop-shadow(.5px .5px 0 var(--shimmer-accent)) drop-shadow(.5px .5px 0 transparent);transition:--shimmer-width .25s cubic-bezier(.34,1.56,.64,1),--shimmer-base var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-accent var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-highlight var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-1 var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-2 var(--theme-transition-duration) var(--theme-transition-ease),filter var(--theme-transition-duration) var(--theme-transition-ease),transform .08s ease-out}}.post-title-link.title-style-shimmer.shimmer-sweeping:not(.touch-title),.title-style-shimmer .post-title-link.shimmer-sweeping:not(.touch-title){transition:--shimmer-width .4s cubic-bezier(.4,0,.2,1),--shimmer-base var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-accent var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-highlight var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-1 var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-2 var(--theme-transition-duration) var(--theme-transition-ease),filter var(--theme-transition-duration) var(--theme-transition-ease),transform .08s ease-out}@media(hover:hover){.post-meta .eyebrow.eyebrow-shimmer{--shimmer-x: 50%;--shimmer-width: 0%;background:linear-gradient(90deg,var(--shimmer-base) 0%,var(--shimmer-base) calc(var(--shimmer-x) - var(--shimmer-width) * 1.8),color-mix(in srgb,var(--shimmer-accent) 3%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * 1.6),color-mix(in srgb,var(--shimmer-accent) 8%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * 1.4),color-mix(in srgb,var(--shimmer-accent) 18%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * 1.2),color-mix(in srgb,var(--shimmer-accent) 35%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * 1),color-mix(in srgb,var(--shimmer-accent) 65%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * .5),color-mix(in srgb,var(--shimmer-accent) 90%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * .15),var(--shimmer-accent) var(--shimmer-x),color-mix(in srgb,var(--shimmer-accent) 90%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * .15),color-mix(in srgb,var(--shimmer-accent) 65%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * .5),color-mix(in srgb,var(--shimmer-accent) 35%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * 1),color-mix(in srgb,var(--shimmer-accent) 18%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * 1.2),color-mix(in srgb,var(--shimmer-accent) 8%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * 1.4),color-mix(in srgb,var(--shimmer-accent) 3%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * 1.6),var(--shimmer-base) calc(var(--shimmer-x) + var(--shimmer-width) * 1.8),var(--shimmer-base) 100%);background-size:100% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(-.3px -.3px 0 var(--shimmer-highlight)) drop-shadow(.5px .5px 0 var(--shimmer-shadow-1)) drop-shadow(.5px .5px 0 var(--shimmer-shadow-2));transition:--shimmer-width .35s cubic-bezier(.16,1,.3,1),--shimmer-base var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-accent var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-highlight var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-1 var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-2 var(--theme-transition-duration) var(--theme-transition-ease),filter var(--theme-transition-duration) var(--theme-transition-ease)}.post-head:hover .eyebrow.eyebrow-shimmer{filter:drop-shadow(-.3px -.3px 0 var(--shimmer-highlight)) drop-shadow(.3px .3px 0 var(--shimmer-accent)) drop-shadow(.3px .3px 0 transparent);transition:--shimmer-width .25s cubic-bezier(.34,1.56,.64,1),--shimmer-base var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-accent var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-highlight var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-1 var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-2 var(--theme-transition-duration) var(--theme-transition-ease),filter var(--theme-transition-duration) var(--theme-transition-ease)}}@media(hover:hover){.post-title-link:hover,.post-head:hover .post-title-link{color:var(--pine)}.post-head:hover .eyebrow:not(.eyebrow-shimmer){color:var(--pine)}}.post-title-link:active,.post-title-link.tap-active{color:var(--pine);transform:scale(.99);transition:transform .06s ease-out,color .06s ease-out}@media(hover:none){.post-title-link.touch-title{color:var(--shimmer-base);filter:drop-shadow(-.5px -.5px 0 var(--shimmer-highlight)) drop-shadow(1px 1px 0 var(--shimmer-shadow-1)) drop-shadow(1px 1px 0 var(--shimmer-shadow-2));transition:color .2s ease,filter var(--theme-transition-duration) var(--theme-transition-ease),transform .08s ease-out}.post-title-link.touch-title:active,.post-head:active .post-title-link.touch-title{color:var(--pine);filter:drop-shadow(-.5px -.5px 0 var(--shimmer-highlight)) drop-shadow(.5px .5px 0 var(--shimmer-accent)) drop-shadow(.5px .5px 0 transparent)}}.post-head:active .post-title-link{color:var(--pine)}.post-head:active .eyebrow:not(.eyebrow-shimmer){color:var(--pine)}.post-title-link:focus-visible{color:var(--pine);outline:2px dashed var(--clay);outline-offset:3px;border-radius:2px}.post-head:has(.post-title-link:focus-visible) .eyebrow:not(.eyebrow-shimmer){color:var(--pine)}.tag-row{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin:var(--space-md) 0}.post-card>.tag-row:last-child{margin-bottom:0}.post-body{border-top:1px dashed var(--line);padding-top:var(--space-base)}.post-body img{max-width:50%;display:block;margin:0 auto;border:var(--border-retro);border-radius:var(--radius-sm);background:var(--bg-card);box-shadow:var(--shadow-retro-sm);cursor:default;transition:transform var(--duration-slower) ease,box-shadow var(--theme-transition-duration) var(--theme-transition-ease),background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease)}.post-body video,.post-body iframe{max-width:100%;border:var(--border-retro);border-radius:var(--radius-sm);box-shadow:var(--shadow-retro-sm)}.post-body pre{background:var(--color-code-bg);color:var(--color-code-text);padding:var(--space-base);border-radius:var(--radius-sm);overflow:auto}@media(hover:hover)and (pointer:fine){.post-body img:hover{transform:translateY(-4px);box-shadow:4px 12px 8px var(--shadow-color-strong)}.post-body img:active{transform:translateY(-1px);box-shadow:4px 5px 2px var(--shadow-color)}}.post-body img.touch-hover{transform:translateY(-4px);box-shadow:12px 16px 14px var(--shadow-color-medium)}.post-body.full-content{font-size:1rem;line-height:1.5;border-top:none;margin-top:0;padding-top:0}.post-body.full-content p{margin-bottom:.85rem}.post-body.full-content h2{font-size:var(--text-2xl);margin-top:1.8rem;margin-bottom:.6rem}.post-body.full-content h3{font-size:1.2rem;margin-top:1.4rem;margin-bottom:.5rem}.post-body blockquote{position:relative;margin:1.25rem 0;padding:0 0 0 1.25rem;border-left:3px solid var(--pine);color:var(--color-text-muted);transition:transform var(--duration-normal) var(--ease-out),border-color var(--theme-transition-duration) var(--theme-transition-ease),color var(--theme-transition-duration) var(--theme-transition-ease)}.post-body blockquote p{margin:0}.post-body blockquote p+p{margin-top:.6rem}.post-body blockquote cite{display:block;margin-top:.5rem;font-size:.85em;font-weight:600;color:var(--pine);transition:color var(--theme-transition-duration) var(--theme-transition-ease)}.post-body blockquote cite:before{content:"— "}@media(hover:hover)and (pointer:fine){.post-body blockquote:not(.attributed-quote):hover{transform:translate(4px);border-color:var(--clay)}.post-body blockquote:not(.attributed-quote):hover cite{color:var(--clay)}}.post-body blockquote.attributed-quote{position:relative;margin:1.5rem 0;padding:0 0 0 1.5rem;border-left:3px solid var(--pine);background:transparent;transition:transform var(--duration-normal) var(--ease-out),border-color var(--theme-transition-duration) var(--theme-transition-ease)}.post-body blockquote.attributed-quote:before{content:'"';position:absolute;top:-.4em;left:-.08em;font-family:var(--font-display);font-size:4rem;line-height:1;color:var(--pine);opacity:.12;pointer-events:none;-webkit-user-select:none;user-select:none;transition:opacity var(--duration-normal) var(--ease-out),color var(--theme-transition-duration) var(--theme-transition-ease)}.post-body blockquote.attributed-quote .quote-text{position:relative}.post-body blockquote.attributed-quote .quote-text p{font-family:var(--font-body);font-size:1rem;line-height:var(--leading-relaxed);color:var(--color-text-muted);margin:0;transition:color var(--theme-transition-duration) var(--theme-transition-ease)}.post-body blockquote.attributed-quote .quote-text p+p{margin-top:.6rem}.post-body blockquote.attributed-quote .quote-attribution{display:block;margin-top:.75rem;font-family:var(--font-body);font-size:.85rem;font-style:italic;color:var(--pine);transition:color var(--theme-transition-duration) var(--theme-transition-ease)}.post-body blockquote.attributed-quote .quote-author,.post-body blockquote.attributed-quote .quote-source,.post-body blockquote.attributed-quote .quote-context{display:inline;font-size:inherit;font-style:inherit;font-weight:inherit;color:inherit}.post-body blockquote.attributed-quote .quote-author:before{content:"— "}.post-body blockquote.attributed-quote .quote-source:before{content:", "}.post-body blockquote.attributed-quote .quote-context:before{content:", "}@media(hover:hover)and (pointer:fine){.post-body blockquote.attributed-quote:hover{transform:translate(4px);border-color:var(--clay)}.post-body blockquote.attributed-quote:hover:before{opacity:.2;color:var(--clay)}.post-body blockquote.attributed-quote:hover .quote-attribution{color:var(--clay)}}@media(max-width:480px){.post-body blockquote.attributed-quote:before{font-size:3rem;top:-.3em}.post-body blockquote.attributed-quote{padding-left:1.25rem}}.post-body.full-content img{max-width:100%;margin:0;cursor:pointer}.footnote-inline{display:inline-flex;position:relative;vertical-align:super;margin-left:.35rem}.footnote-bubble{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:999px;border:1px solid var(--color-border-strong);background:var(--bg-card);color:var(--pine);font-size:.7rem;font-weight:700;box-shadow:var(--shadow-retro-sm);cursor:pointer;transition:transform var(--duration-normal) var(--ease-out),box-shadow var(--theme-transition-duration) var(--theme-transition-ease),background-color var(--theme-transition-duration) var(--theme-transition-ease),color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease)}.footnote-bubble-inner{line-height:1;transform:translateY(-1px)}@media(hover:hover){.footnote-bubble:hover{transform:translateY(-2px);box-shadow:var(--shadow-retro-md);color:var(--aero);border-color:var(--aero)}}.footnote-bubble:active,.footnote-bubble.tap-active,.footnote-bubble.open{transform:translateY(-1px) scale(.98);background:var(--aero-soft);border-color:var(--aero);color:var(--ink)}.footnote-popover{position:absolute;top:-.35rem;left:50%;transform:translate(-50%,-110%) scale(.97);min-width:220px;max-width:min(320px,80vw);padding:.65rem .75rem;background:var(--bg-surface);color:var(--color-text);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);box-shadow:var(--shadow-retro-md);opacity:0;pointer-events:none;transition:opacity var(--duration-normal) ease,transform var(--duration-normal) ease;z-index:4}.footnote-popover:after{content:"";position:absolute;bottom:-7px;left:50%;transform:translate(-50%);width:12px;height:12px;background:var(--bg-surface);border-left:1px solid var(--color-border-strong);border-bottom:1px solid var(--color-border-strong);transform:translate(-50%) rotate(45deg);box-shadow:3px 3px 6px var(--shadow-color-strong);z-index:-1}.footnote-popover.visible{opacity:1;transform:translate(-50%,-118%) scale(1);pointer-events:auto}.footnote-popover-content{font-size:.9rem;line-height:1.4}.footnote-popover-content p{margin:0}.footnote-popover-content a{color:var(--aero);font-weight:600}@media(max-width:540px){.footnote-popover{left:0;transform:translate(-10%,-112%) scale(.97)}.footnote-popover.visible{transform:translate(-10%,-118%) scale(1)}}.post-body figure{margin:1.25rem 0;padding:0;text-align:center}.post-body figure img{margin-bottom:0}.post-body figcaption{margin-top:.5rem;font-size:.85rem;font-style:italic;line-height:1.4;color:var(--color-text-muted);transition:color var(--theme-transition-duration) var(--theme-transition-ease)}.post-body.full-content figure{margin:1.5rem 0}.post-body.full-content figure img{max-width:100%}.post-image{margin:1.5rem 0;padding:0;text-align:center}.post-image img{max-width:100%;display:block;margin:0 auto;border:var(--border-retro);border-radius:var(--radius-sm);background:var(--bg-card);box-shadow:var(--shadow-retro-sm);cursor:pointer;transition:transform var(--duration-slower) ease,box-shadow var(--theme-transition-duration) var(--theme-transition-ease),background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease)}@media(hover:hover)and (pointer:fine){.post-image img:hover{transform:translateY(-4px);box-shadow:4px 12px 8px var(--shadow-color-strong)}.post-image img:active{transform:translateY(-1px);box-shadow:4px 5px 2px var(--shadow-color)}}.post-image img.touch-hover{transform:translateY(-4px);box-shadow:12px 16px 14px var(--shadow-color-medium)}.post-image img:focus-visible{outline:2px dashed var(--clay);outline-offset:4px}.post-image-caption{margin-top:.75rem;padding:0 1rem;font-size:.85rem;font-style:italic;line-height:1.5;color:var(--color-text-muted);transition:color var(--theme-transition-duration) var(--theme-transition-ease)}.post-body a{color:var(--aero);text-decoration:underline;text-decoration-color:var(--line);text-decoration-thickness:1px;text-underline-offset:2px;transition:color var(--theme-transition-duration) var(--theme-transition-ease),text-decoration-color var(--theme-transition-duration) var(--theme-transition-ease),text-decoration-thickness var(--duration-normal) ease}@media(hover:hover){.post-body a:hover{color:var(--clay);text-decoration-color:var(--clay);text-decoration-thickness:2px}}.post-body a:active{color:var(--clay);text-decoration-color:var(--clay)}.post-body a:focus-visible{outline:2px dashed var(--clay);outline-offset:3px;border-radius:2px;text-decoration-color:var(--clay);text-decoration-thickness:2px}.post-body code{font-family:var(--font-mono);font-size:.85em;color:var(--pine);background:var(--color-ghost-bg);padding:.15em .45em .18em;border-radius:4px;border:1px solid var(--line);box-shadow:inset 0 1px 2px #0000000a;white-space:nowrap;transition:background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease),color var(--theme-transition-duration) var(--theme-transition-ease),box-shadow var(--theme-transition-duration) var(--theme-transition-ease)}.post-body code::selection{background:#c45b3726;color:var(--clay)}.post-body pre code{font-size:inherit;color:inherit;background:transparent;padding:0;border:none;border-radius:0;box-shadow:none;white-space:pre}.post-body a code{color:inherit;border-color:currentColor;opacity:.9}.post-body hr{position:relative;border:none;margin:1rem 0;height:1rem;background:transparent;display:flex;align-items:center;justify-content:center}.post-body hr:before{content:"◆";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-size:.55rem;color:var(--pine);background:var(--panel-bg);padding:0 .6rem;z-index:2;line-height:1;transition:color var(--theme-transition-duration) var(--theme-transition-ease),background-color var(--theme-transition-duration) var(--theme-transition-ease)}.post-body hr:after{content:"";position:absolute;left:25%;right:25%;top:50%;transform:translateY(-50%);height:0;border-top:1px solid var(--line);z-index:1;transition:border-color var(--theme-transition-duration) var(--theme-transition-ease)}@media(max-width:640px){.post-body img{max-width:100%}}.post-card--mini .post-head{cursor:default}.mini-post-flow{line-height:var(--leading-normal);position:relative;max-height:9rem;overflow:clip;transition:max-height .35s cubic-bezier(.4,0,.2,1)}.post-card--mini.expanded .mini-post-flow{max-height:none}.post-card--mini.has-overflow .mini-post-flow:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3.5rem;background:linear-gradient(to bottom,var(--gradient-fade-start) 0%,var(--gradient-fade-end) 85%);pointer-events:none;opacity:1;transition:--gradient-fade-start var(--theme-transition-duration) var(--theme-transition-ease),--gradient-fade-end var(--theme-transition-duration) var(--theme-transition-ease),opacity .25s ease-out}html:not(.theme-ready) .post-card--mini.has-overflow .mini-post-flow:after{transition:opacity .25s ease-out}.post-card--mini.expanded .mini-post-flow:after{opacity:0}.post-card--mini .post-title-mini{font-size:var(--text-lg);font-weight:600;color:var(--ink);display:inline;margin-right:.35em}.post-card--mini .post-title-mini.touch-title{color:var(--shimmer-base);filter:drop-shadow(-.5px -.5px 0 var(--shimmer-highlight)) drop-shadow(1px 1px 0 var(--shimmer-shadow-1)) drop-shadow(1px 1px 0 var(--shimmer-shadow-2));transition:color .2s ease,filter var(--theme-transition-duration) var(--theme-transition-ease)}@media(hover:hover){.post-card--mini .post-title-mini:not(.touch-title){--shimmer-x: 50%;--shimmer-width: 0%;background:linear-gradient(90deg,var(--shimmer-base) 0%,var(--shimmer-base) calc(var(--shimmer-x) - var(--shimmer-width) * 1.8),color-mix(in srgb,var(--shimmer-accent) 3%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * 1.6),color-mix(in srgb,var(--shimmer-accent) 8%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * 1.4),color-mix(in srgb,var(--shimmer-accent) 18%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * 1.2),color-mix(in srgb,var(--shimmer-accent) 35%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * 1),color-mix(in srgb,var(--shimmer-accent) 65%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * .5),color-mix(in srgb,var(--shimmer-accent) 90%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * .15),var(--shimmer-accent) var(--shimmer-x),color-mix(in srgb,var(--shimmer-accent) 90%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * .15),color-mix(in srgb,var(--shimmer-accent) 65%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * .5),color-mix(in srgb,var(--shimmer-accent) 35%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * 1),color-mix(in srgb,var(--shimmer-accent) 18%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * 1.2),color-mix(in srgb,var(--shimmer-accent) 8%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * 1.4),color-mix(in srgb,var(--shimmer-accent) 3%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * 1.6),var(--shimmer-base) calc(var(--shimmer-x) + var(--shimmer-width) * 1.8),var(--shimmer-base) 100%);background-size:100% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(-.5px -.5px 0 var(--shimmer-highlight)) drop-shadow(1px 1px 0 var(--shimmer-shadow-1)) drop-shadow(1px 1px 0 var(--shimmer-shadow-2));transition:--shimmer-width .35s cubic-bezier(.16,1,.3,1),--shimmer-base var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-accent var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-highlight var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-1 var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-2 var(--theme-transition-duration) var(--theme-transition-ease),filter var(--theme-transition-duration) var(--theme-transition-ease)}.post-card--mini .post-head:hover .post-title-mini:not(.touch-title){filter:drop-shadow(-.5px -.5px 0 var(--shimmer-highlight)) drop-shadow(.5px .5px 0 var(--shimmer-accent)) drop-shadow(.5px .5px 0 transparent);transition:--shimmer-width .25s cubic-bezier(.34,1.56,.64,1),--shimmer-base var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-accent var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-highlight var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-1 var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-2 var(--theme-transition-duration) var(--theme-transition-ease),filter var(--theme-transition-duration) var(--theme-transition-ease)}.post-card--mini .post-title-mini.shimmer-hidden{background:var(--shimmer-base)!important;-webkit-background-clip:text!important;background-clip:text!important;-webkit-text-fill-color:transparent!important}}.mini-post-body{display:inline;border-top:none;transition:color var(--theme-transition-duration) var(--theme-transition-ease)}.mini-post-body>p:first-child,.mini-post-body>span:first-child>p:first-child{display:inline}.mini-post-body>*:not(:first-child),.mini-post-body>span:not(:first-child)>*{display:block;margin-top:.75em}.mini-post-body pre,.mini-post-body .code-block,.mini-post-body ul,.mini-post-body ol{display:block;margin-top:.75em}.mini-post-body>span:not(:first-child)>blockquote,.mini-post-body blockquote{display:block;margin-top:1.25em}.mini-post-body p{margin-bottom:0}.mini-post-body ul,.mini-post-body ol,.mini-post-body pre,.mini-post-body .code-block{margin-bottom:.75em}.mini-post-body>span:not(:first-child)>blockquote,.mini-post-body blockquote{margin-bottom:1.25em}.post-card--mini .link-btn-wrapper .pill svg{transition:transform .25s var(--ease-bounce)}.post-card--mini.expanded .link-btn-wrapper .pill svg{transform:rotate(180deg)}.mini-post-body .footnote-marker{font-size:.75em;color:var(--aero);cursor:help;margin-left:.1em;vertical-align:super;line-height:0}.post-card--mini .post-head{display:block;position:relative}.post-card--mini .link-btn-wrapper{float:right;margin-left:var(--space-sm);margin-bottom:var(--space-xs)}.post-card--mini .mini-post-flow{max-height:13rem}@media(max-width:640px){.post-card--mini .mini-post-flow{max-height:16rem}}@media(prefers-reduced-motion:reduce){.mini-post-flow{transition:none}.post-card--mini.has-overflow .mini-post-flow:after{transition:none}.post-card--mini .link-btn-wrapper .pill svg{transition:none}}.progressive-image{position:relative;overflow:hidden;background:var(--bg-card);display:block}.progressive-image picture{display:block}.progressive-image__placeholder{position:absolute;inset:0;background:linear-gradient(110deg,var(--bg-card) 0%,var(--bg-card) 40%,var(--shimmer-highlight, rgba(255, 255, 255, .12)) 50%,var(--bg-card) 60%,var(--bg-card) 100%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;z-index:1;pointer-events:none;opacity:1;transition:opacity .4s ease-out}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.progressive-image.is-loaded .progressive-image__placeholder{opacity:0;animation:none}.progressive-image__blur{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;filter:blur(20px);transform:scale(1.1);z-index:1;pointer-events:none;opacity:1;transition:opacity .4s ease-out}.progressive-image.is-loaded .progressive-image__blur{opacity:0}.progressive-image.has-blur .progressive-image__placeholder{display:none}.progressive-image__img{display:block;width:auto;height:auto;max-width:100%;object-fit:inherit;image-orientation:from-image;opacity:0;transform:scale(1.02);filter:blur(8px);transition:opacity .5s ease-out,transform .5s ease-out,filter .5s ease-out;z-index:2}.progressive-image.is-loaded .progressive-image__img{opacity:1;transform:scale(1);filter:blur(0)}.progressive-image__error{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:var(--bg-card);color:var(--color-text-muted);z-index:3}.progressive-image__error svg{opacity:.5}:root{--shimmer-highlight: rgba(255, 255, 255, .08)}[data-theme=light]{--shimmer-highlight: rgba(0, 0, 0, .04)}.carousel-item .progressive-image{height:100%;width:auto}.carousel-item .progressive-image picture{height:100%}.carousel-item .progressive-image__img{height:100%;width:auto;max-width:none;object-fit:contain}.featured-project-media .progressive-image{width:100%}.featured-project-media .progressive-image__img{width:100%;height:auto;max-height:420px;object-fit:cover;object-position:center top}@media(max-width:640px){.featured-project-media .progressive-image__img{max-height:280px}}.lightbox-content .progressive-image{width:fit-content;height:fit-content;max-width:min(75vw,800px);max-height:min(75vh,700px)}.lightbox-content .progressive-image__img{max-width:min(75vw,800px);max-height:min(75vh,700px);width:auto;height:auto;object-fit:contain;transition:opacity .3s ease-out,transform .3s ease-out,filter .3s ease-out}@media(prefers-reduced-motion:reduce){.progressive-image__placeholder{animation:none;background:var(--bg-card)}.progressive-image__blur{filter:blur(10px);transform:none;transition:opacity .2s ease-out}.progressive-image__img{transform:none;filter:none;transition:opacity .2s ease-out}.progressive-image.is-loaded .progressive-image__img{transform:none}}.page-transition{contain:layout}.app-transition-init .top-bar{opacity:0;pointer-events:none;will-change:opacity}.app-transition-ready .top-bar{opacity:1;pointer-events:auto;will-change:auto}.app-transition-ready .top-bar.collapsed{pointer-events:none}@media(prefers-reduced-motion:reduce){.app-transition-init .top-bar{opacity:0}.app-transition-ready .top-bar{opacity:1}}.app-transition-init .frame>section,.app-transition-init .frame>article,.app-transition-init .post-list>article,.app-transition-init .moodboard-column,.app-transition-init .moodboard-column .project-card,.app-transition-init .about-content>*,.app-transition-init .featured-project-card,.app-transition-init .post-page .post-page-head,.app-transition-init .post-page .post-body,.app-transition-init .post-page .post-tags,.app-transition-init .post-page .post-footer,.app-transition-init .project-page .project-hero,.app-transition-init .project-page .project-content,.app-transition-init .panel-head,.app-transition-init .filter-row .tag-cloud .pill{opacity:0;transform:translateY(10px)}@keyframes staggerFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes simpleFadeIn{0%{opacity:0}to{opacity:1}}.app-transition-ready .frame>section,.app-transition-ready .frame>article{animation:staggerFadeIn .32s ease-in-out both}.app-transition-ready .frame>section:nth-of-type(1),.app-transition-ready .frame>article:nth-of-type(1){animation-delay:0s}.app-transition-ready .frame>section:nth-of-type(2),.app-transition-ready .frame>article:nth-of-type(2){animation-delay:.05s}.app-transition-ready .frame>section:nth-of-type(3),.app-transition-ready .frame>article:nth-of-type(3){animation-delay:.1s}.app-transition-ready .frame>section:nth-of-type(4),.app-transition-ready .frame>article:nth-of-type(4){animation-delay:.15s}.app-transition-ready .frame>section:nth-of-type(5),.app-transition-ready .frame>article:nth-of-type(5){animation-delay:.2s}.app-transition-ready .moodboard-column{animation:staggerFadeIn .32s ease-in-out both}.app-transition-ready .moodboard-column:nth-child(1){animation-delay:0s}.app-transition-ready .moodboard-column:nth-child(2){animation-delay:.04s}.app-transition-ready .moodboard-column:nth-child(3){animation-delay:.08s}.app-transition-ready .moodboard-column .project-card{animation:staggerFadeIn .32s ease-in-out both}.app-transition-ready .moodboard-column:nth-child(1) .project-card:nth-child(1){animation-delay:.02s}.app-transition-ready .moodboard-column:nth-child(1) .project-card:nth-child(2){animation-delay:.06s}.app-transition-ready .moodboard-column:nth-child(1) .project-card:nth-child(3){animation-delay:.1s}.app-transition-ready .moodboard-column:nth-child(2) .project-card:nth-child(1){animation-delay:.05s}.app-transition-ready .moodboard-column:nth-child(2) .project-card:nth-child(2){animation-delay:.09s}.app-transition-ready .moodboard-column:nth-child(2) .project-card:nth-child(3){animation-delay:.13s}.app-transition-ready .moodboard-column:nth-child(3) .project-card:nth-child(1){animation-delay:.08s}.app-transition-ready .moodboard-column:nth-child(3) .project-card:nth-child(2){animation-delay:.12s}.app-transition-ready .moodboard-column:nth-child(3) .project-card:nth-child(3){animation-delay:.16s}.app-transition-ready .about-content>*{animation:staggerFadeIn .32s ease-in-out both}.app-transition-ready .about-content>*:nth-child(1){animation-delay:0s}.app-transition-ready .about-content>*:nth-child(2){animation-delay:.04s}.app-transition-ready .about-content>*:nth-child(3){animation-delay:.08s}.app-transition-ready .about-content>*:nth-child(4){animation-delay:.12s}.app-transition-ready .about-content>*:nth-child(5){animation-delay:.16s}.app-transition-ready .featured-project-card{animation:staggerFadeIn .32s ease-in-out both;animation-delay:.05s}.app-transition-ready .post-page .post-page-head{animation:staggerFadeIn .32s ease-in-out both;animation-delay:0s}.app-transition-ready .post-page .post-body{animation:staggerFadeIn .32s ease-in-out both;animation-delay:.05s}.app-transition-ready .post-page .post-tags{animation:staggerFadeIn .32s ease-in-out both;animation-delay:.1s}.app-transition-ready .post-page .post-footer{animation:staggerFadeIn .32s ease-in-out both;animation-delay:.15s}.app-transition-ready .project-page .project-hero{animation:staggerFadeIn .32s ease-in-out both;animation-delay:0s}.app-transition-ready .project-page .project-content{animation:staggerFadeIn .32s ease-in-out both;animation-delay:.05s}.app-transition-ready .panel-head{animation:staggerFadeIn .32s ease-in-out both;animation-delay:0s}.app-transition-ready .filter-row .tag-cloud .pill{animation:staggerFadeIn .32s ease-in-out both}.app-transition-ready .filter-row .tag-cloud .pill:nth-child(1){animation-delay:.08s}.app-transition-ready .filter-row .tag-cloud .pill:nth-child(2){animation-delay:.09s}.app-transition-ready .filter-row .tag-cloud .pill:nth-child(3){animation-delay:.1s}.app-transition-ready .filter-row .tag-cloud .pill:nth-child(4){animation-delay:.11s}.app-transition-ready .filter-row .tag-cloud .pill:nth-child(5){animation-delay:.12s}.app-transition-ready .filter-row .tag-cloud .pill:nth-child(6){animation-delay:.13s}.app-transition-ready .filter-row .tag-cloud .pill:nth-child(7){animation-delay:.14s}.app-transition-ready .filter-row .tag-cloud .pill:nth-child(8){animation-delay:.15s}.app-transition-ready .filter-row .tag-cloud .pill:nth-child(n+9){animation-delay:.16s}@media(prefers-reduced-motion:reduce){.app-transition-ready .frame>section,.app-transition-ready .frame>article,.app-transition-ready .moodboard-column,.app-transition-ready .moodboard-column .project-card,.app-transition-ready .about-content>*,.app-transition-ready .featured-project-card,.app-transition-ready .post-page .post-page-head,.app-transition-ready .post-page .post-body,.app-transition-ready .post-page .post-tags,.app-transition-ready .post-page .post-footer,.app-transition-ready .project-page .project-hero,.app-transition-ready .project-page .project-content,.app-transition-ready .panel-head,.app-transition-ready .filter-row .tag-cloud .pill{animation:simpleFadeIn .2s ease both;animation-delay:0s}}.toc{margin:1.25rem 0 1.5rem;border:var(--border-retro);border-radius:var(--radius-sm);background:var(--bg-white);box-shadow:var(--shadow-retro-sm);overflow:hidden;font-family:var(--font-body)}.toc-toggle{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:6px 14px;background:var(--color-code-header);border:none;border-bottom:1px solid transparent;cursor:pointer;text-align:left;transition:background-color var(--duration-fast) ease,border-color var(--duration-normal) ease}.toc-toggle--expanded{border-bottom-color:var(--color-border)}@media(hover:hover){.toc-toggle:hover{background:var(--color-code-hover)}}.toc-toggle:active{background:var(--color-surface-active)}.toc-toggle:focus-visible{outline:2px dashed var(--clay);outline-offset:-2px}.toc-toggle-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;color:var(--color-text-muted);transition:color var(--duration-fast) ease}.toc-chevron{transition:transform .25s var(--ease-bounce)}.toc-toggle--expanded .toc-chevron{transform:rotate(180deg)}@media(hover:hover){.toc-toggle:hover .toc-toggle-icon{color:var(--pine)}}.toc-toggle-label{flex:1;font-size:.9rem;font-weight:600;color:var(--ink);letter-spacing:.01em;position:relative;top:1.5px}.toc-toggle-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;font-family:var(--font-mono);font-size:.7rem;font-weight:700;color:var(--color-text-muted);background:var(--color-ghost-bg);border:1.5px solid var(--color-border);border-radius:var(--radius-full)}.toc-content{max-height:0;overflow:hidden;transition:max-height .35s cubic-bezier(.4,0,.2,1)}.toc-list{list-style:none;list-style-type:none;margin:0;padding:8px 14px}.toc-item{list-style:none;list-style-type:none;margin:0;padding:0}.toc-item+.toc-item{margin-top:2px}.toc-item--h3{padding-left:1.25rem}.toc-link{display:flex;align-items:center;gap:var(--space-sm);padding:4px 10px 4px 0;text-decoration:none;border-radius:var(--radius-sm);transition:background-color var(--duration-fast) ease,color var(--duration-fast) ease,transform var(--duration-fast) ease;position:relative}@media(hover:hover){.toc-link:hover{background:var(--color-surface-muted);color:var(--pine);transform:translate(4px)}.toc-link:hover .toc-link-number{background:var(--pine);border-color:var(--pine);color:#fff}}.toc-link:active{background:var(--color-surface-active);transform:translate(2px)}.toc-link:focus-visible{outline:2px dashed var(--clay);outline-offset:1px}.toc-link-number{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;width:20px;height:20px;font-family:var(--font-mono);font-size:.65rem;font-weight:700;color:var(--color-text-muted);background:var(--color-ghost-bg);border:1px solid var(--color-border);border-radius:50%;transition:background-color var(--duration-fast) ease,border-color var(--duration-fast) ease,color var(--duration-fast) ease}.toc-link-text{font-size:.88rem;line-height:1;color:var(--color-text);transition:color var(--duration-fast) ease;position:relative;top:1px}.toc-item--h3 .toc-link-text{font-size:.82rem;color:var(--color-text-muted);top:1px}@media(hover:hover){.toc-link:hover .toc-link-text{color:var(--pine)}}.toc-content--expanded .toc-item{animation:tocItemReveal .25s ease-out both;animation-delay:calc(var(--item-index, 0) * 40ms)}@keyframes tocItemReveal{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.toc-target-highlight{animation:tocTargetPulse 2s ease-out}@keyframes tocTargetPulse{0%{background:var(--color-surface-active);border-radius:var(--radius-sm);box-shadow:0 0 0 4px var(--color-surface-active)}to{background:transparent;box-shadow:0 0 0 4px transparent}}@media(max-width:480px){.toc{margin:1rem 0 1.25rem}.toc-toggle{padding:5px 12px}.toc-list{padding:6px 12px}.toc-link{padding:4px 8px 4px 0}.toc-item--h3{padding-left:1rem}}@media(prefers-reduced-motion:reduce){.toc-content,.toc-chevron,.toc-link{transition:none}.toc-content--expanded .toc-item{animation:none;opacity:1;transform:none}.toc-target-highlight{animation:none}}.post-body .table-wrapper{position:relative;margin:1.5rem 0;overflow-x:auto;-webkit-overflow-scrolling:touch}.post-body .table-wrapper:before,.post-body .table-wrapper:after{content:"";position:absolute;top:0;bottom:0;width:24px;pointer-events:none;opacity:0;transition:opacity var(--duration-normal) ease;z-index:2}.post-body .table-wrapper:before{left:0;background:linear-gradient(to right,var(--panel-bg),transparent)}.post-body .table-wrapper:after{right:0;background:linear-gradient(to left,var(--panel-bg),transparent)}.post-body .table-wrapper.scrollable-left:before,.post-body .table-wrapper.scrollable-right:after{opacity:1}.post-body table{width:100%;margin:1.5rem 0;border-collapse:separate;border-spacing:0;border:var(--border-retro);border-radius:var(--radius-sm);background:var(--bg-white);box-shadow:var(--shadow-retro-sm);font-size:var(--text-sm);line-height:var(--leading-normal);overflow:hidden;transition:background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease),box-shadow var(--theme-transition-duration) var(--theme-transition-ease)}.post-body .table-wrapper table{margin:0}.post-body thead{background:var(--color-code-header);transition:background-color var(--theme-transition-duration) var(--theme-transition-ease)}.post-body th{padding:.6rem .85rem;font-family:var(--font-body);font-size:var(--text-xs);font-weight:700;letter-spacing:var(--tracking-wide);text-transform:uppercase;text-align:left;color:var(--color-text);border-bottom:1px solid var(--color-border);transition:border-color var(--theme-transition-duration) var(--theme-transition-ease)}.post-body th[align=right]{text-align:right}.post-body th[align=center]{text-align:center}.post-body td{padding:.55rem .85rem;font-family:var(--font-body);font-size:var(--text-sm);color:var(--color-text);border-bottom:1px solid var(--color-border);vertical-align:top;background:transparent;transition:background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease)}.post-body tbody tr:last-child td{border-bottom:none}.post-body td[align=right]{text-align:right}.post-body td[align=center]{text-align:center}.post-body td:first-child{font-weight:600;color:var(--color-text);background:var(--color-surface-muted);white-space:nowrap}.post-body td:first-child:empty{background:transparent}@media(hover:hover)and (pointer:fine){.post-body tbody tr:hover td{background-color:var(--color-surface-hover)}.post-body tbody tr:hover td:first-child:not(:empty){background-color:var(--color-surface-active)}}.post-body td a{color:var(--aero);text-decoration:underline;text-decoration-color:var(--line);text-decoration-thickness:1px;text-underline-offset:2px}@media(hover:hover){.post-body td a:hover{color:var(--clay);text-decoration-color:var(--clay)}}.post-body td code,.post-body th code{font-family:var(--font-mono);font-size:.85em;color:var(--pine);background:var(--color-ghost-bg);padding:.1em .35em;border-radius:3px;border:1px solid var(--line)}.post-body td strong,.post-body th strong{font-weight:700}.post-body td em,.post-body th em{font-style:italic}@media(max-width:640px){.post-body table{font-size:.78rem}.post-body th,.post-body td{padding:.45rem .6rem}.post-body th{font-size:.68rem}}@media(prefers-reduced-motion:reduce){.post-body table,.post-body thead,.post-body th,.post-body td{transition:none!important}}.filter-row{display:flex;flex-direction:column;gap:var(--space-md);margin-top:var(--space-base)}.tag-cloud-wrapper{position:relative;width:100%;min-width:0}.scroll-gradient{position:absolute;top:0;bottom:0;width:60px;pointer-events:none;opacity:0;transition:opacity .3s ease;z-index:2}.scroll-gradient.visible{opacity:1}.scroll-gradient.left{left:-1px;background:linear-gradient(to right,var(--color-fade-end),var(--color-fade-start))}.scroll-gradient.right{right:-1px;background:linear-gradient(to left,var(--color-fade-end),var(--color-fade-start))}@media(max-width:640px){.scroll-gradient{width:32px}}.tag-cloud{display:flex;flex-direction:column;gap:var(--space-xs);overflow-x:auto;overflow-y:hidden;padding-bottom:4px;width:100%;scrollbar-width:none;-ms-overflow-style:none}.tag-cloud::-webkit-scrollbar{display:none}.tag-cloud-row{display:flex;flex-wrap:nowrap;gap:var(--space-sm);width:max-content;align-items:center;padding-right:var(--space-md)}.active-tags{display:flex;align-items:center;justify-content:flex-start;gap:var(--space-sm);flex-wrap:wrap}.active-tags.fading-out{pointer-events:none}@keyframes activeTagFadeIn{0%{opacity:0;transform:translateY(4px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.active-tags:not(.fading-out) .pill.tag-stable{opacity:1}.active-tags:not(.fading-out) .pill.tag-entering{opacity:0;animation:activeTagFadeIn .26s cubic-bezier(.33,0,.2,1) both}.posts-panel:not(.pagination-transitioning) .panel-head-main .btn{opacity:0;animation:activeTagFadeIn .26s cubic-bezier(.33,0,.2,1) both;animation-delay:0ms}.posts-panel.pagination-transitioning .panel-head-main .btn{opacity:1;animation:none}.pagination{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:var(--space-md);margin-top:4px}.pagination .btn{min-width:90px}.pagination .muted{min-width:100px;text-align:center;font-weight:600;font-size:.85rem;color:var(--color-text-muted)}.pagination-arrow{display:none}.pagination-text{display:inline}.back-link{display:inline-block;margin-bottom:1.5rem;font-size:.9rem;font-weight:600;color:var(--color-text-muted);transition:color var(--theme-transition-duration) var(--theme-transition-ease),transform var(--duration-normal) ease}@media(hover:hover){.back-link:hover{color:var(--aero);transform:translate(-4px)}}.back-link:active,.back-link.tap-active{color:var(--aero);transform:translate(-2px);transition:transform .06s ease-out,color .06s ease-out}.post-page-head{margin-bottom:2rem}.post-page-head .eyebrow{letter-spacing:.1em}.post-page .post-title{font-size:var(--text-3xl);margin-bottom:.5rem;line-height:var(--leading-tight)}.post-page .post-title.title-style-shimmer:not(.touch-title),.title-style-shimmer .post-page .post-title:not(.touch-title),.title-style-shimmer article.post-page .post-title:not(.touch-title){--shimmer-x: 50%;--shimmer-width: 0%;background:linear-gradient(90deg,var(--shimmer-base) 0%,var(--shimmer-base) calc(var(--shimmer-x) - var(--shimmer-width) * 1.8),color-mix(in srgb,var(--shimmer-accent) 3%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * 1.6),color-mix(in srgb,var(--shimmer-accent) 8%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * 1.4),color-mix(in srgb,var(--shimmer-accent) 18%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * 1.2),color-mix(in srgb,var(--shimmer-accent) 35%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * 1),color-mix(in srgb,var(--shimmer-accent) 65%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * .5),color-mix(in srgb,var(--shimmer-accent) 90%,var(--shimmer-base)) calc(var(--shimmer-x) - var(--shimmer-width) * .15),var(--shimmer-accent) var(--shimmer-x),color-mix(in srgb,var(--shimmer-accent) 90%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * .15),color-mix(in srgb,var(--shimmer-accent) 65%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * .5),color-mix(in srgb,var(--shimmer-accent) 35%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * 1),color-mix(in srgb,var(--shimmer-accent) 18%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * 1.2),color-mix(in srgb,var(--shimmer-accent) 8%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * 1.4),color-mix(in srgb,var(--shimmer-accent) 3%,var(--shimmer-base)) calc(var(--shimmer-x) + var(--shimmer-width) * 1.6),var(--shimmer-base) calc(var(--shimmer-x) + var(--shimmer-width) * 1.8),var(--shimmer-base) 100%)!important;background-size:100% 100%!important;-webkit-background-clip:text!important;background-clip:text!important;-webkit-text-fill-color:transparent!important;filter:drop-shadow(-1px -1px 0 var(--shimmer-highlight)) drop-shadow(1px 1px 0 var(--shimmer-shadow-1)) drop-shadow(2px 2px 0 var(--shimmer-shadow-2)) drop-shadow(2px 2px 0 var(--shimmer-shadow-3))!important;padding-bottom:.15em!important;transition:--shimmer-width .4s cubic-bezier(.16,1,.3,1),--shimmer-base var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-accent var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-highlight var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-1 var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-2 var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-3 var(--theme-transition-duration) var(--theme-transition-ease),filter var(--theme-transition-duration) var(--theme-transition-ease)!important}@media(hover:hover){.post-page .post-title.title-style-shimmer:not(.touch-title):not(.shimmer-hidden),.title-style-shimmer .post-page .post-title:not(.touch-title):not(.shimmer-hidden),.title-style-shimmer article.post-page .post-title:not(.touch-title):not(.shimmer-hidden){transition:--shimmer-width .3s cubic-bezier(.34,1.56,.64,1),--shimmer-base var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-accent var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-highlight var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-1 var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-2 var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-3 var(--theme-transition-duration) var(--theme-transition-ease),filter var(--theme-transition-duration) var(--theme-transition-ease)!important}}.post-page .post-title.title-style-shimmer.shimmer-sweeping:not(.touch-title),.title-style-shimmer .post-page .post-title.shimmer-sweeping:not(.touch-title),.title-style-shimmer article.post-page .post-title.shimmer-sweeping:not(.touch-title){transition:--shimmer-width .5s cubic-bezier(.4,0,.2,1),--shimmer-base var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-accent var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-highlight var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-1 var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-2 var(--theme-transition-duration) var(--theme-transition-ease),--shimmer-shadow-3 var(--theme-transition-duration) var(--theme-transition-ease),filter var(--theme-transition-duration) var(--theme-transition-ease)!important}.post-page .post-title.shimmer-hidden,.title-style-shimmer .post-page .post-title.shimmer-hidden{background:var(--shimmer-base)!important;-webkit-background-clip:text!important;background-clip:text!important;-webkit-text-fill-color:transparent!important}@media(hover:none){.post-page .post-title.touch-title{color:var(--color-text);--reveal-size: 0%;--reveal-opacity: 0;background:radial-gradient(ellipse at 50% 50%,color-mix(in srgb,var(--pine) calc(var(--reveal-opacity) * 35%),var(--color-text)) 0%,color-mix(in srgb,var(--pine) calc(var(--reveal-opacity) * 25%),var(--color-text)) calc(var(--reveal-size) * .3),color-mix(in srgb,var(--pine) calc(var(--reveal-opacity) * 15%),var(--color-text)) calc(var(--reveal-size) * .6),color-mix(in srgb,var(--pine) calc(var(--reveal-opacity) * 5%),var(--color-text)) calc(var(--reveal-size) * .85),var(--color-text) var(--reveal-size),var(--color-text) 100%);background-size:100% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;transition:--reveal-size 0s,--reveal-opacity 0s,color var(--theme-transition-duration) var(--theme-transition-ease)}.post-page .post-title.touch-title.radial-reveal-touch{animation:radial-reveal 2.4s cubic-bezier(.25,.1,.25,1) forwards}}@keyframes radial-reveal{0%{--reveal-size: 0%;--reveal-opacity: 0}15%{--reveal-size: 40%;--reveal-opacity: 1}45%{--reveal-size: 200%;--reveal-opacity: 1}60%{--reveal-size: 200%;--reveal-opacity: .7}to{--reveal-size: 200%;--reveal-opacity: 0}}.post-tags{margin-top:1.5rem;margin-bottom:.75rem}.post-footer{margin-top:1.5rem;padding-top:1.25rem;padding-bottom:1.25rem;margin-bottom:-.4rem;border-top:1px solid var(--color-border)}.post-nav{display:flex;justify-content:space-between;gap:var(--space-lg)}.post-nav-link{display:flex;flex-direction:column;gap:.15rem;max-width:45%;transition:transform var(--duration-normal) ease,color var(--theme-transition-duration) var(--theme-transition-ease)}.post-nav-prev{align-items:flex-start;text-align:left}.post-nav-next{align-items:flex-end;text-align:right}@media(hover:hover){.post-nav-link:hover{transform:translateY(-2px)}.post-nav-prev:hover{transform:translate(-4px)}.post-nav-next:hover{transform:translate(4px)}}.post-nav-link:active,.post-nav-link.tap-active{transform:translateY(1px);transition:transform .06s ease-out}.post-nav-link:active .post-nav-label,.post-nav-link:active .post-nav-title,.post-nav-link.tap-active .post-nav-label,.post-nav-link.tap-active .post-nav-title{color:var(--aero);transition:color .06s ease-out}.post-nav-prev:active,.post-nav-prev.tap-active{transform:translate(-2px)}.post-nav-next:active,.post-nav-next.tap-active{transform:translate(2px)}.post-nav-label{font-size:.9rem;font-weight:600;color:var(--color-text-muted);transition:color var(--theme-transition-duration) var(--theme-transition-ease)}.post-nav-title{font-family:var(--font-body);font-size:.88rem;font-style:italic;font-weight:500;color:var(--color-text-muted);line-height:1.4;transition:color var(--theme-transition-duration) var(--theme-transition-ease)}@media(hover:hover){.post-nav-link:hover .post-nav-label,.post-nav-link:hover .post-nav-title{color:var(--aero)}}.post-nav-spacer{flex:1}@media(min-width:840px){.filter-row{flex-direction:row;align-items:center;justify-content:space-between}}@media(max-width:480px){.post-nav-link{max-width:50%}}@media(max-width:380px){.pagination{flex-wrap:nowrap;gap:var(--space-sm)}.pagination .btn{min-width:auto;width:36px;height:36px;padding:0;position:relative}.pagination .muted{min-width:auto;font-size:.85rem}.pagination-text{display:none}.pagination-arrow{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:1rem;line-height:1;position:absolute;top:0;left:0}}.portfolio-panel{display:flex;flex-direction:column;gap:var(--space-lg)}.portfolio-panel .panel-head{align-items:flex-start}.portfolio-panel .muted{max-width:520px;color:var(--color-text-muted)}.moodboard{display:flex;flex-direction:row;gap:var(--space-lg);align-items:flex-start;width:100%;overflow:visible}.moodboard-column{display:flex;flex-direction:column;gap:var(--space-lg);flex:1 1 0%;min-width:0;overflow:visible}.moodboard.mobile{flex-direction:column}.scroll-sentinel{width:100%;height:24px}.project-card{--card-border-color: var(--ink);position:relative;border:1.5px solid var(--card-border-color);border-radius:var(--radius-sm);background:var(--bg-card);box-shadow:var(--card-shadow-edge),var(--card-shadow-contact),var(--card-shadow-ambient);overflow:hidden;display:block;width:100%;height:auto;transition:transform .32s var(--ease-spring-settle),box-shadow .38s var(--ease-spring-settle),background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease);isolation:isolate;transform-origin:center center}.project-media{position:relative;width:100%;height:auto;display:block;background:var(--bg-card)}.project-media img{width:100%;height:auto;min-height:1px;display:block;z-index:1}.project-pill{position:absolute;left:var(--space-lg);bottom:var(--space-lg);margin:0;z-index:2;border-radius:var(--radius-full);padding:.42rem .95rem .38rem;border:1px solid var(--color-pill-glass-border);background:var(--color-pill-glass-bg);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);display:inline-flex;align-items:center;justify-content:center;box-shadow:0 4px 12px var(--shadow-color);max-width:calc(100% - 28px)}.pill-label{font-family:var(--font-display);font-weight:600;font-size:.9rem;letter-spacing:var(--tracking-tight);color:var(--ink);line-height:var(--leading-tight)}.project-card:hover{transform:translateY(-12px) translateZ(0) scale(1.05);box-shadow:var(--card-shadow-hover-edge),var(--card-shadow-hover-contact),var(--card-shadow-hover-ambient);transition:transform .28s var(--ease-spring-out),box-shadow .32s var(--ease-spring-out),background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease)}.project-card:active{transform:translateY(-2px) translateZ(0) scale(.98);box-shadow:var(--card-shadow-active-edge),var(--card-shadow-active-contact),var(--card-shadow-active-ambient);transition:transform .1s var(--ease-snap),box-shadow .1s var(--ease-snap),background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease)}.project-card.touch-hover{transform:translateY(-12px) translateZ(0) scale(1.05);box-shadow:var(--card-shadow-hover-edge),var(--card-shadow-hover-contact),var(--card-shadow-hover-ambient);transition:transform .28s var(--ease-spring-out),box-shadow .32s var(--ease-spring-out),background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease)}.project-card.touch-hover:active,.project-card:active{transform:translateY(-2px) translateZ(0) scale(.98);box-shadow:var(--card-shadow-active-edge),var(--card-shadow-active-contact),var(--card-shadow-active-ambient);transition:transform .1s var(--ease-snap),box-shadow .1s var(--ease-snap),background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease)}.featured-project-card{--card-border-color: var(--ink);display:block;position:relative;border:1.5px solid var(--card-border-color);border-radius:var(--radius-sm);background:var(--bg-card);box-shadow:var(--card-shadow-edge),var(--card-shadow-contact),var(--card-shadow-ambient);overflow:hidden;width:100%;transition:transform .32s var(--ease-spring-settle),box-shadow .38s var(--ease-spring-settle),background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease);isolation:isolate;transform-origin:center center}.featured-project-media{position:relative;width:100%;height:auto;display:block;background:var(--bg-card)}.featured-project-media img{width:100%;height:auto;max-height:420px;object-fit:cover;object-position:center top;display:block}.featured-project-card:hover{transform:translateY(-12px) translateZ(0) scale(1.04);box-shadow:var(--card-shadow-hover-edge),var(--card-shadow-hover-contact),var(--card-shadow-hover-ambient);transition:transform .28s var(--ease-spring-out),box-shadow .32s var(--ease-spring-out),background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease)}.featured-project-card:active{transform:translateY(-2px) translateZ(0) scale(.98);box-shadow:var(--card-shadow-active-edge),var(--card-shadow-active-contact),var(--card-shadow-active-ambient);transition:transform .1s var(--ease-snap),box-shadow .1s var(--ease-snap),background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease)}@media(max-width:640px){.featured-project-media img{max-height:280px}}.project-detail-panel{display:flex;flex-direction:column;gap:var(--space-2xl)}.project-header{display:flex;flex-direction:column;gap:2px}.project-header h1{font-size:var(--text-4xl);line-height:var(--leading-tight);margin:.12em 0 .24em}.project-title-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-xl);flex-wrap:wrap;margin:.12em 0 .28em}.project-title-row h1{margin:0}.project-links{display:flex;align-items:center;gap:var(--space-md);flex-wrap:wrap}.project-tags{display:flex;flex-wrap:wrap;gap:var(--space-sm);padding-top:var(--space-lg);border-top:1px dashed var(--line);transition:border-color var(--theme-transition-duration) var(--theme-transition-ease)}.project-content{display:flex;flex-direction:column;gap:var(--space-base)}.project-description{font-size:1rem;line-height:1.55;margin:0}.project-description>div:not(.code-block){display:contents}.project-description p{margin-bottom:.9rem}.project-description h2{font-size:1.35rem;margin-top:1.4rem;margin-bottom:.5rem}.project-description h3{font-size:var(--text-lg);margin-top:1rem;margin-bottom:.4rem}.project-description ul,.project-description ol{margin-top:.4rem;margin-bottom:.9rem;padding-left:1.5rem}.project-description li{margin-bottom:.35rem}.project-description code{font-family:var(--font-mono);font-size:.85em;color:var(--pine);background:var(--color-ghost-bg);padding:.15em .45em .18em;border-radius:4px;border:1px solid var(--line);box-shadow:inset 0 1px 2px #0000000a;white-space:nowrap;transition:background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease),color var(--theme-transition-duration) var(--theme-transition-ease),box-shadow var(--theme-transition-duration) var(--theme-transition-ease)}.project-description code::selection{background:#c45b3726;color:var(--clay)}.project-description pre code{font-size:inherit;color:inherit;background:transparent;padding:0;border:none;border-radius:0;box-shadow:none;white-space:pre}.project-description a code{color:inherit;border-color:currentColor;opacity:.9}.project-description .code-block{margin:1rem 0 1.5rem}.project-description .code-block pre{background:transparent;color:var(--ink);border:none;box-shadow:none;padding:var(--space-xl);border-radius:0}.project-description blockquote{position:relative;margin:1.25rem 0;padding:0 0 0 1.25rem;border-left:3px solid var(--pine);color:var(--color-text-muted);transition:transform var(--duration-normal) var(--ease-out),border-color var(--theme-transition-duration) var(--theme-transition-ease),color var(--theme-transition-duration) var(--theme-transition-ease)}.project-description blockquote p{margin:0}.project-description blockquote p+p{margin-top:.6rem}.project-description blockquote cite{display:block;margin-top:.5rem;font-size:.85em;font-weight:600;color:var(--pine);transition:color var(--theme-transition-duration) var(--theme-transition-ease)}.project-description blockquote cite:before{content:"— "}@media(hover:hover)and (pointer:fine){.project-description blockquote:not(.attributed-quote):hover{transform:translate(4px);border-color:var(--clay)}.project-description blockquote:not(.attributed-quote):hover cite{color:var(--clay)}}.project-description blockquote.attributed-quote{position:relative;margin:1.5rem 0;padding:0 0 0 1.5rem;border-left:3px solid var(--pine);background:transparent;transition:transform var(--duration-normal) var(--ease-out),border-color var(--theme-transition-duration) var(--theme-transition-ease)}.project-description blockquote.attributed-quote:before{content:'"';position:absolute;top:-.4em;left:-.08em;font-family:var(--font-display);font-size:4rem;line-height:1;color:var(--pine);opacity:.12;pointer-events:none;-webkit-user-select:none;user-select:none;transition:opacity var(--duration-normal) var(--ease-out),color var(--theme-transition-duration) var(--theme-transition-ease)}.project-description blockquote.attributed-quote .quote-text{position:relative}.project-description blockquote.attributed-quote .quote-text p{font-family:var(--font-body);font-size:1rem;line-height:var(--leading-relaxed);color:var(--color-text-muted);margin:0;transition:color var(--theme-transition-duration) var(--theme-transition-ease)}.project-description blockquote.attributed-quote .quote-text p+p{margin-top:.6rem}.project-description blockquote.attributed-quote .quote-attribution{display:block;margin-top:.75rem;font-family:var(--font-body);font-size:.85rem;font-style:italic;color:var(--pine);transition:color var(--theme-transition-duration) var(--theme-transition-ease)}.project-description blockquote.attributed-quote .quote-author,.project-description blockquote.attributed-quote .quote-source,.project-description blockquote.attributed-quote .quote-context{display:inline;font-size:inherit;font-style:inherit;font-weight:inherit;color:inherit}.project-description blockquote.attributed-quote .quote-author:before{content:"— "}.project-description blockquote.attributed-quote .quote-source:before{content:", "}.project-description blockquote.attributed-quote .quote-context:before{content:", "}@media(hover:hover)and (pointer:fine){.project-description blockquote.attributed-quote:hover{transform:translate(4px);border-color:var(--clay)}.project-description blockquote.attributed-quote:hover:before{opacity:.2;color:var(--clay)}.project-description blockquote.attributed-quote:hover .quote-attribution{color:var(--clay)}}@media(max-width:480px){.project-description blockquote.attributed-quote:before{font-size:3rem;top:-.3em}}.project-description a{color:var(--aero);text-decoration:underline;text-decoration-color:var(--line);text-decoration-thickness:1px;text-underline-offset:2px;transition:color var(--theme-transition-duration) var(--theme-transition-ease),text-decoration-color var(--theme-transition-duration) var(--theme-transition-ease),text-decoration-thickness var(--duration-normal) ease}@media(hover:hover){.project-description a:hover{color:var(--clay);text-decoration-color:var(--clay);text-decoration-thickness:2px}}.project-description a:active{color:var(--clay);text-decoration-color:var(--clay)}.project-description a:focus-visible{outline:2px dashed var(--clay);outline-offset:3px;border-radius:2px;text-decoration-color:var(--clay);text-decoration-thickness:2px}.project-description hr{position:relative;border:none;margin:1.5rem 0;height:1rem;background:transparent;display:flex;align-items:center;justify-content:center}.project-description hr:before{content:"◆";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-size:.55rem;color:var(--pine);background:var(--panel-bg);padding:0 .6rem;z-index:2;line-height:1;transition:color var(--theme-transition-duration) var(--theme-transition-ease),background-color var(--theme-transition-duration) var(--theme-transition-ease)}.project-description hr:after{content:"";position:absolute;left:25%;right:25%;top:50%;transform:translateY(-50%);height:0;border-top:1px solid var(--line);z-index:1;transition:border-color var(--theme-transition-duration) var(--theme-transition-ease)}.github-card{display:inline-flex;align-items:center;gap:var(--space-lg);padding:var(--space-xl);border:var(--border-retro);border-radius:var(--radius-sm);background:var(--bg-white);box-shadow:var(--shadow-retro-sm);transition:transform .15s ease,box-shadow var(--theme-transition-duration) var(--theme-transition-ease),background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease),color var(--theme-transition-duration) var(--theme-transition-ease);width:max-content;text-decoration:none;color:var(--ink)}@media(hover:hover){.github-card:hover{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--retro-shadow-color);color:var(--ink)}.github-card:hover .github-arrow{color:var(--pine);transform:translate(2px) translateY(-2px)}}.github-icon{width:32px;height:32px;display:grid;place-items:center;color:var(--ink)}.github-icon svg{width:100%;height:100%}.github-info{display:flex;flex-direction:column;gap:2px}.github-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--color-text-muted)}.github-url{font-family:var(--font-display);font-size:var(--text-lg);line-height:1}.github-arrow{margin-left:var(--space-base);color:var(--color-text-muted);transition:transform var(--duration-normal) ease,color var(--theme-transition-duration) var(--theme-transition-ease)}.about-panel p{font-size:var(--text-base);line-height:var(--leading-loose);margin:0 0 1rem}.about-panel p:last-of-type{margin-bottom:0}.about-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.6rem}.about-panel .panel-head{display:flex;align-items:center;justify-content:space-between;gap:var(--space-base);flex-wrap:wrap;margin-bottom:.5rem}.about-body{display:block}.about-body p{margin:0 0 1rem}.about-body p:last-child{margin-bottom:0}.about-body a{color:var(--aero);text-decoration:underline;text-decoration-color:var(--line);text-decoration-thickness:1px;text-underline-offset:2px;transition:color var(--theme-transition-duration) var(--theme-transition-ease),text-decoration-color var(--theme-transition-duration) var(--theme-transition-ease),text-decoration-thickness var(--duration-normal) ease}@media(hover:hover){.about-body a:hover{color:var(--clay);text-decoration-color:var(--clay);text-decoration-thickness:2px}}.about-body a:active{color:var(--clay);text-decoration-color:var(--clay)}.about-body a:focus-visible{outline:2px dashed var(--clay);outline-offset:3px;border-radius:2px;text-decoration-color:var(--clay);text-decoration-thickness:2px}.about-body code{font-family:var(--font-mono);font-size:.85em;color:var(--pine);background:var(--color-ghost-bg);padding:.15em .45em .18em;border-radius:4px;border:1px solid var(--line);box-shadow:inset 0 1px 2px #0000000a;white-space:nowrap;transition:background-color var(--theme-transition-duration) var(--theme-transition-ease),border-color var(--theme-transition-duration) var(--theme-transition-ease),color var(--theme-transition-duration) var(--theme-transition-ease),box-shadow var(--theme-transition-duration) var(--theme-transition-ease)}.about-body code::selection{background:#c45b3726;color:var(--clay)}.about-body a code{color:inherit;border-color:currentColor;opacity:.9}.about-panel h2{margin-top:.3rem}.about-page-panel{max-width:var(--max-width-content);width:100%}.about-eyebrow{margin-bottom:1rem}.photo-gallery-section{margin-top:1.5rem;padding-top:1.25rem;border-top:1px dashed var(--color-border)}.contact-section{margin-top:1.5rem;padding-top:1.25rem;border-top:1px dashed var(--color-border);display:flex;align-items:center;justify-content:space-between;gap:var(--space-base);flex-wrap:wrap}.contact-section h3{margin:0;font-size:var(--text-xl);white-space:nowrap}.contact-links{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-sm);flex-wrap:wrap}.contact-icon-btn{position:relative;width:auto;height:auto;border:none;background:none;box-shadow:none;color:var(--bg-white);display:inline-flex;align-items:center;justify-content:center;will-change:transform;padding:4px;filter:drop-shadow(2.5px 2.5px 0px var(--ink));transition:transform var(--duration-normal) ease,filter var(--theme-transition-duration) var(--theme-transition-ease),color var(--theme-transition-duration) var(--theme-transition-ease)}@media(hover:hover){.contact-icon-btn:hover{transform:translate(1px,1px);filter:drop-shadow(1.5px 1.5px 0px var(--ink));color:var(--bg-white)}.contact-icon-btn:hover .contact-icon{fill:var(--color-surface-active);stroke:var(--pine)}}.contact-icon-btn:active{transform:translate(2.5px,2.5px);filter:drop-shadow(0px 0px 0px var(--ink))}.contact-icon-btn:active .contact-icon{fill:var(--color-surface-active);stroke:var(--pine)}.contact-icon-btn:after{display:none}.contact-icon-btn:focus-visible{outline:2px dashed var(--clay);outline-offset:4px}.contact-icon{width:26px;height:26px;fill:var(--bg-white);stroke:var(--ink);stroke-width:1.5px;stroke-linejoin:round;stroke-linecap:round;paint-order:stroke fill;overflow:visible;transition:fill var(--duration-normal) ease,stroke var(--duration-normal) ease}.about-panel-compact .about-body{margin-top:.25rem}.about-panel-compact .panel-head:only-child{margin-bottom:0}.about-panel-compact .panel-head:only-child .eyebrow{margin-bottom:0;line-height:1;transform:translateY(2px)}.contact-links-compact{justify-content:flex-start}.contact-links-compact .contact-icon-btn{filter:drop-shadow(2px 2px 0px var(--shadow-color-muted))}@media(hover:hover){.contact-links-compact .contact-icon-btn:hover{filter:drop-shadow(1px 1px 0px var(--shadow-color-muted))}.contact-links-compact .contact-icon-btn:hover .contact-icon{fill:var(--color-surface-active);stroke:var(--pine)}}.contact-links-compact .contact-icon-btn:active{filter:drop-shadow(0px 0px 0px var(--shadow-color-muted))}.contact-links-compact .contact-icon-btn:active .contact-icon{fill:var(--color-surface-active);stroke:var(--pine)}.contact-links-compact .contact-icon{width:24px;height:24px;stroke:var(--color-text-muted);stroke-width:1.3px;transition:fill var(--duration-normal) ease,stroke var(--duration-normal) ease}@media(max-width:340px){.contact-section{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.contact-links{justify-content:flex-start;width:100%}}[data-theme=dark] .contact-icon{fill:var(--ink);stroke:none;stroke-width:0}[data-theme=dark] .contact-icon-btn{filter:drop-shadow(2.5px 2.5px 0px rgba(0,0,0,.85))}@media(hover:hover){[data-theme=dark] .contact-icon-btn:hover{filter:drop-shadow(1.5px 1.5px 0px rgba(0,0,0,.85))}[data-theme=dark] .contact-icon-btn:hover .contact-icon{fill:var(--pine)}}[data-theme=dark] .contact-icon-btn:active{filter:drop-shadow(0px 0px 0px rgba(0,0,0,.85))}[data-theme=dark] .contact-icon-btn:active .contact-icon{fill:var(--pine)}[data-theme=dark] .contact-links-compact .contact-icon{fill:var(--color-text-muted);stroke:none;stroke-width:0}[data-theme=dark] .contact-links-compact .contact-icon-btn{filter:drop-shadow(2px 2px 0px rgba(0,0,0,.7))}@media(hover:hover){[data-theme=dark] .contact-links-compact .contact-icon-btn:hover{filter:drop-shadow(1px 1px 0px rgba(0,0,0,.7))}[data-theme=dark] .contact-links-compact .contact-icon-btn:hover .contact-icon{fill:var(--pine)}}[data-theme=dark] .contact-links-compact .contact-icon-btn:active{filter:drop-shadow(0px 0px 0px rgba(0,0,0,.7))}[data-theme=dark] .contact-links-compact .contact-icon-btn:active .contact-icon{fill:var(--pine)}@media(max-width:1099px){.about-panel-compact{position:relative}.fab-dock-target{position:absolute;inset:0;pointer-events:none}.fab-dock-target .mobile-fab{pointer-events:auto}}
