:root{--panel-bg: rgba(255, 248, 220, .78);--panel-border: #c41e3a;--panel-shadow: 4px 4px 0 #1a1a2e;--accent-hot: #ff00aa;--accent-cool: #00d4aa;--link: #0000ee;--link-visited: #551a8b;--text-dark: #1a0a2e;--tile-inner: rgba(255, 255, 255, .55)}html{scroll-behavior:smooth;overflow-x:hidden;overscroll-behavior-x:none}body{min-height:100vh;font-family:VT323,Courier New,Courier,monospace;font-size:1.35rem;color:var(--text-dark);background-color:#0d0221;overflow-x:hidden;overscroll-behavior-x:none}b,strong{font-weight:700}a{color:initial}.retro-bg{position:fixed;width:100%;height:100%;z-index:-2;background-color:#2b1055;background-image:url(/media/background.jpg);background-size:cover;background-position:center}.retro-bg:after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(135deg,#ff009626,#00c8ff1f,#ffc8001a);pointer-events:none}.site-wrap{z-index:1}.retro-header .subtitle{font-size:1rem;letter-spacing:.08em;color:#fff;text-shadow:2px 2px 0 #000,0 0 12px rgba(255,0,200,.8)}.site-title{font-family:"Press Start 2P",cursive;font-size:clamp(.85rem,3vw,1.35rem);line-height:1.6;color:#fffde7;text-shadow:3px 3px 0 #ff006e,6px 6px 0 #3a0ca3,0 0 20px rgba(0,255,200,.5);white-space:nowrap;display:flex;align-items:center;justify-content:center;gap:.5ch}.title-graphic{color:#ffea00;animation:twinkle 1.8s ease-in-out infinite;white-space:nowrap;flex-shrink:0}.title-graphic:last-child{animation-delay:.9s}@keyframes twinkle{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.tagline{font-size:1.25rem;color:#e0f7fa;text-shadow:1px 1px 2px #000}.marquee-wrap{overflow:hidden;border:3px ridge #ffd700;background:#00000073;box-shadow:3px 3px #000}.marquee-inner{display:flex;width:max-content;animation:marquee-scroll 28s linear infinite}.marquee-text{flex-shrink:0;padding:.35rem 2rem;font-size:1.1rem;color:#fff9c4;white-space:nowrap}@keyframes marquee-scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.retro-panel{background:var(--panel-bg);border:4px double var(--panel-border);box-shadow:var(--panel-shadow);padding:1.25rem 1.5rem;backdrop-filter:blur(4px)}.panel-title{font-family:"Press Start 2P",cursive;font-size:.65rem;line-height:1.8;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:3px groove #f4a261;color:#7209b7}.blink{animation:blink-90s 1.1s step-end infinite;color:var(--accent-hot);margin-right:.5rem}@keyframes blink-90s{0%,50%{opacity:1}50.01%,to{opacity:0}}.retro-lead{font-size:1.4rem}.retro-list{list-style:none;padding-left:0;margin-bottom:0}.retro-list li{position:relative;padding-left:1.25rem;margin-bottom:.35rem}.bullet{position:absolute;left:0;color:var(--accent-cool)}.project-tile{background:var(--tile-inner);border:2px outset #83c5be;padding:.85rem;height:100%}.project-name{font-family:"Press Start 2P",cursive;font-size:.55rem;line-height:1.6;color:#0077b6;margin-bottom:.65rem}.badge-retro{display:inline-block;font-size:.9rem;padding:.1rem .45rem;margin-right:.35rem;margin-top:.25rem;background:linear-gradient(180deg,#fefae0,#dda15e);border:2px solid #bc6c25;color:#283618}.retro-input{font-family:inherit;font-size:1.15rem;background:#ffffffeb;border:3px inset #999;border-radius:0}.retro-input:focus,.btn-retro:focus,.btn-ring:focus{outline:2px dashed var(--accent-hot);outline-offset:2px}.btn-retro{font-family:"Press Start 2P",cursive;font-size:.55rem;line-height:1.6;padding:.75rem 1rem;background:linear-gradient(180deg,#b5179e,#7209b7);color:#fff;border:3px outset #c77dff;box-shadow:2px 2px #000}.btn-retro:hover{background:linear-gradient(180deg,#f72585,#b5179e);color:#fff}.btn-retro:active{border-style:inset;transform:translate(1px,1px)}.site-hint{color:#d30d14;font-style:italic;text-shadow:2px 2px 0 #000,0 0 10px rgba(0,255,200,.5)}.hp-field{position:absolute;left:-10000px;width:1px;height:1px;overflow:hidden}.turnstile-wrap{min-height:4.5rem;display:flex;justify-content:center;align-items:center}.turnstile-wrap code{font-size:.95rem}.guestbook-entries{max-height:14rem;overflow-y:auto;padding-right:.25rem;border:2px inset rgba(0,0,0,.12);background:#ffffff59}.guestbook-entry{padding:.5rem .4rem;border-bottom:1px dashed rgba(114,9,183,.35)}.guestbook-entry:last-child{border-bottom:none}.guestbook-entry-meta{font-size:1rem;margin-bottom:.15rem}.guestbook-name{color:#0077b6}.guestbook-when{color:#555;font-size:.95rem}.guestbook-message{font-size:1.05rem;white-space:pre-wrap;word-break:break-word}.guestbook-empty{padding:.75rem .25rem;color:#555}.guestbook-loading{color:#560bad;font-style:italic}.guestbook-toast{min-height:2.5rem;text-align:center;font-size:1.1rem;color:#0077b6}.guestbook-toast.visible{animation:pop-in .35s ease}@keyframes pop-in{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.btn-ring{font-family:inherit;font-size:1rem;background:linear-gradient(180deg,#ffd6a5,#ffadad);border:2px outset #ff006e;color:#1a1a2e;padding:.25rem .6rem}.btn-ring:hover{background:linear-gradient(180deg,#ffee93,#ffd6a5);color:#000}.btn-ring:active{border-style:inset}.ring-status{font-style:italic;color:#560bad}.last-updated{background:#e0f7fabf}.btn-link-retro{font-family:inherit;font-size:1.1rem;background:none;border:none;color:var(--link);text-decoration:underline;cursor:pointer;padding:0}.btn-link-retro:hover{color:#d00000}.btn-link-retro:focus,.icon-link:focus,.footer-links a:focus,.footer-links button:focus{outline:2px dashed var(--accent-cool);outline-offset:2px}.retro-footer{color:#fff;text-shadow:1px 1px 3px #000;white-space:nowrap;display:flex;flex-direction:column;align-items:center}.retro-footer a,.retro-footer button{color:#ffea00;white-space:nowrap}.retro-footer a:visited,.retro-footer button:visited{color:#caffbf}.footer-links .divider{opacity:.7;margin:0 .35rem;white-space:nowrap}.project-tile img,.retro-panel img{max-width:100%;height:auto;display:block;margin-left:auto;margin-right:auto}@media(max-width:600px){.site-title{font-size:1rem;white-space:nowrap;gap:.2ch}.retro-footer{font-size:.95rem;white-space:nowrap}.project-tile img,.retro-panel img{max-width:80vw;height:auto}}@media(max-width:420px){.site-title{font-size:.8rem;gap:.1ch}}.confetti-layer{position:fixed;inset:0;pointer-events:none;z-index:100;overflow:hidden}.confetti-piece{position:absolute;width:10px;height:10px;top:-12px;animation:confetti-fall linear forwards;opacity:.95}.easter-egg-message{color:var(--accent-hot);font-size:.9rem}@keyframes confetti-fall{to{transform:translate(var(--dx),110vh) rotate(720deg);opacity:.3}}@media(prefers-reduced-motion:reduce){.marquee-inner{animation:none}.marquee-text{white-space:normal;text-align:center;display:block}.title-graphic,.blink{animation:none}.confetti-piece{animation:none;display:none}}a.linkComponent,.linkComponent{background:none;border:none;color:var(--link);text-decoration:underline;cursor:pointer;padding:0;font:inherit}.icon-link svg{filter:drop-shadow(2px 2px 0 #fff) drop-shadow(0 0 5px rgba(255,0,200,.8));transition:filter .2s,color .2s,fill .2s}.icon-link:hover svg{color:#fff;filter:drop-shadow(2px 2px 0 #000) drop-shadow(0 0 5px rgba(255,0,200,.8))}.site-title-wrapper{display:inline-block;position:relative}.splash-overlay{position:absolute;left:100%;top:1em;transform:translate(-10%) scale(1);pointer-events:none;z-index:2;min-width:7.5rem}@media(max-width:800px){.splash-overlay{left:95%;top:2em;transform:translate(-50%);width:100%;text-align:center;min-width:unset}}@media(max-width:600px){.site-title-wrapper{display:block}.splash-overlay{left:80%;top:3em;transform:translate(-50%);width:100%;text-align:center;min-width:unset}}.splash-text{display:inline-block;color:#ffec3d;font-weight:700;font-size:1.5rem;text-shadow:2px 2px 0 #3e3e3e,0 0 10px #fff200;transform:rotate(-15deg);animation:splash-pulse 1.6s infinite cubic-bezier(.4,0,.2,1);user-select:none;white-space:nowrap}@media(max-width:800px){.splash-text{font-size:1.3rem}}@media(max-width:600px){.splash-text{font-size:1.2rem}}@media(max-width:420px){.splash-text{font-size:.8rem}}@keyframes splash-pulse{0%{transform:rotate(-15deg) scale(.96)}25%{transform:rotate(-15deg) scale(1.04)}50%{transform:rotate(-15deg) scale(.96)}75%{transform:rotate(-15deg) scale(1.04)}to{transform:rotate(-15deg) scale(.96)}}
