:root{--bg-main: #fdfdfc;--bg-surface: #FFFFFF;--text-main: #0A0A0A;--text-muted: #525252;--border-main: #000000;--text-highlight: #000000;--magenta-warm: #D81B60;--trans-blue: #3873B8;--accent-soft: #fdfdfc}.dark-mode{--bg-main: #0A0A0A;--bg-surface: #171717;--text-main: #f5f5f5;--text-muted: #a3a3a3;--border-main: #262626;--text-highlight: #ffffff}html{font-size:105%;transition:filter .3s ease,font-size .3s ease;scroll-behavior:smooth}body{background-color:var(--bg-main);color:var(--text-main);font-family:"Source Sans 3",sans-serif;transition:background-color .3s ease,color .3s ease;line-height:1.7;overflow-x:hidden;width:100%}*,*:before,*:after{border-color:var(--border-main);transition-property:color,background-color,border-color,opacity;transition-duration:.3s;transition-timing-function:ease-out}h1,h2,h3,h4,h5,h6,.serif{font-family:Fraunces,serif}.mono{font-family:IBM Plex Mono,monospace}.typewriter{font-family:Special Elite,Courier Prime,Courier New,monospace}.duotone-blue{filter:grayscale(1) contrast(1.2) brightness(.9) sepia(.5) hue-rotate(180deg) saturate(2);mix-blend-mode:multiply}.archival-photo{position:relative;overflow:hidden}.archival-photo:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(#0a0a0a1a 50%,#0003 50%);background-size:100% 4px;pointer-events:none;opacity:.1}.technical-mark{position:absolute;font-family:IBM Plex Mono,monospace;font-size:8px;text-transform:uppercase;color:#d81b60;pointer-events:none;z-index:20}:focus-visible{outline:2px solid var(--magenta-warm);outline-offset:4px;border-radius:2px}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-main)}::-webkit-scrollbar-thumb{background:var(--border-main);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}html.grayscale-mode{filter:grayscale(100%) contrast(110%)}html.grayscale-mode body{--text-main: #000000;--text-muted: #404040;--bg-main: #ffffff;--bg-surface: #f5f5f5;--border-main: #000000;--text-highlight: #000000}html.grayscale-mode.dark-mode body{--text-main: #ffffff;--text-muted: #e5e5e5;--bg-main: #000000;--bg-surface: #121212;--border-main: #ffffff;--text-highlight: #ffffff}html.high-contrast,html.high-contrast body{background-color:#000!important}html.high-contrast body{--bg-main: #000000;--bg-surface: #000000;--text-main: #ffff00;--text-muted: #ffff00;--border-main: #ffff00;--text-highlight: #ffffff}html.high-contrast .typewriter,html.high-contrast .mono{color:#ff0!important}html.large-text{font-size:130%}html.large-text .typewriter{font-size:1.25rem!important}html.large-text h1{font-size:10rem!important}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .6s ease-out forwards}@keyframes float{0%,to{transform:translate(0) rotate(0)}33%{transform:translate(15px,-20px) rotate(2deg)}66%{transform:translate(-10px,-35px) rotate(-2deg)}}.animate-float-slow{animation:float 18s ease-in-out infinite}.animate-float-medium{animation:float 12s ease-in-out infinite}.animate-float-fast{animation:float 8s ease-in-out infinite}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}
