@font-face{font-family:MumboSSK;src:url(/assets/MumboSSK%20Bold-gq8RdcbE.ttf) format("truetype");font-weight:700;font-style:normal}:root{font-family:Helvetica Neue,Helvetica,Arial,sans-serif;line-height:1.6;font-weight:300;color:#e0e0e0;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}body{margin:0;background:#000}:root{--react-pdf-annotation-layer: 1;--annotation-unfocused-field-background: url("data:image/svg+xml;charset=UTF-8,<svg width='1px' height='1px' xmlns='http://www.w3.org/2000/svg'><rect width='100%' height='100%' style='fill:rgba(0, 54, 255, 0.13);'/></svg>");--input-focus-border-color: Highlight;--input-focus-outline: 1px solid Canvas;--input-unfocused-border-color: transparent;--input-disabled-border-color: transparent;--input-hover-border-color: black;--link-outline: none}@media screen and (forced-colors:active){:root{--input-focus-border-color: CanvasText;--input-unfocused-border-color: ActiveText;--input-disabled-border-color: GrayText;--input-hover-border-color: Highlight;--link-outline: 1.5px solid LinkText}.annotationLayer .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required{outline:1.5px solid selectedItem}.annotationLayer .linkAnnotation:hover{-webkit-backdrop-filter:invert(100%);backdrop-filter:invert(100%)}}.annotationLayer{position:absolute;top:0;left:0;pointer-events:none;transform-origin:0 0;z-index:3}.annotationLayer[data-main-rotation="90"] .norotate{transform:rotate(270deg) translate(-100%)}.annotationLayer[data-main-rotation="180"] .norotate{transform:rotate(180deg) translate(-100%,-100%)}.annotationLayer[data-main-rotation="270"] .norotate{transform:rotate(90deg) translateY(-100%)}.annotationLayer canvas{position:absolute;width:100%;height:100%}.annotationLayer section{position:absolute;text-align:initial;pointer-events:auto;box-sizing:border-box;margin:0;transform-origin:0 0}.annotationLayer .linkAnnotation{outline:var(--link-outline)}.textLayer.selecting~.annotationLayer section{pointer-events:none}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a{position:absolute;font-size:1em;top:0;left:0;width:100%;height:100%}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a:hover{opacity:.2;background:#ff0;box-shadow:0 2px 10px #ff0}.annotationLayer .textAnnotation img{position:absolute;cursor:pointer;width:100%;height:100%;top:0;left:0}.annotationLayer .textWidgetAnnotation :is(input,textarea),.annotationLayer .choiceWidgetAnnotation select,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{background-image:var(--annotation-unfocused-field-background);border:2px solid var(--input-unfocused-border-color);box-sizing:border-box;font:calc(9px * var(--total-scale-factor)) sans-serif;height:100%;margin:0;vertical-align:top;width:100%}.annotationLayer .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required{outline:1.5px solid red}.annotationLayer .choiceWidgetAnnotation select option{padding:0}.annotationLayer .buttonWidgetAnnotation.radioButton input{border-radius:50%}.annotationLayer .textWidgetAnnotation textarea{resize:none}.annotationLayer .textWidgetAnnotation :is(input,textarea)[disabled],.annotationLayer .choiceWidgetAnnotation select[disabled],.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input[disabled]{background:none;border:2px solid var(--input-disabled-border-color);cursor:not-allowed}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:hover{border:2px solid var(--input-hover-border-color)}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation.checkBox input:hover{border-radius:2px}.annotationLayer .textWidgetAnnotation :is(input,textarea):focus,.annotationLayer .choiceWidgetAnnotation select:focus{background:none;border:2px solid var(--input-focus-border-color);border-radius:2px;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) :focus{background-image:none;background-color:transparent}.annotationLayer .buttonWidgetAnnotation.checkBox :focus{border:2px solid var(--input-focus-border-color);border-radius:2px;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.radioButton :focus{border:2px solid var(--input-focus-border-color);outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after,.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{background-color:CanvasText;content:"";display:block;position:absolute}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{height:80%;left:45%;width:1px}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before{transform:rotate(45deg)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{transform:rotate(-45deg)}.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{border-radius:50%;height:50%;left:30%;top:20%;width:50%}.annotationLayer .textWidgetAnnotation input.comb{font-family:monospace;padding-left:2px;padding-right:0}.annotationLayer .textWidgetAnnotation input.comb:focus{width:103%}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{appearance:none}.annotationLayer .popupTriggerArea{height:100%;width:100%}.annotationLayer .fileAttachmentAnnotation .popupTriggerArea{position:absolute}.annotationLayer .popupWrapper{position:absolute;font-size:calc(9px * var(--total-scale-factor));width:100%;min-width:calc(180px * var(--total-scale-factor));pointer-events:none}.annotationLayer .popup{position:absolute;max-width:calc(180px * var(--total-scale-factor));background-color:#ff9;box-shadow:0 calc(2px * var(--total-scale-factor)) calc(5px * var(--total-scale-factor)) #888;border-radius:calc(2px * var(--total-scale-factor));padding:calc(6px * var(--total-scale-factor));margin-left:calc(5px * var(--total-scale-factor));cursor:pointer;font:message-box;white-space:normal;word-wrap:break-word;pointer-events:auto}.annotationLayer .popup>*{font-size:calc(9px * var(--total-scale-factor))}.annotationLayer .popup h1{display:inline-block}.annotationLayer .popupDate{display:inline-block;margin-left:calc(5px * var(--total-scale-factor))}.annotationLayer .popupContent{border-top:1px solid rgba(51,51,51,1);margin-top:calc(2px * var(--total-scale-factor));padding-top:calc(2px * var(--total-scale-factor))}.annotationLayer .richText>*{white-space:pre-wrap;font-size:calc(9px * var(--total-scale-factor))}.annotationLayer .highlightAnnotation,.annotationLayer .underlineAnnotation,.annotationLayer .squigglyAnnotation,.annotationLayer .strikeoutAnnotation,.annotationLayer .freeTextAnnotation,.annotationLayer .lineAnnotation svg line,.annotationLayer .squareAnnotation svg rect,.annotationLayer .circleAnnotation svg ellipse,.annotationLayer .polylineAnnotation svg polyline,.annotationLayer .polygonAnnotation svg polygon,.annotationLayer .caretAnnotation,.annotationLayer .inkAnnotation svg polyline,.annotationLayer .stampAnnotation,.annotationLayer .fileAttachmentAnnotation{cursor:pointer}.annotationLayer section svg{position:absolute;width:100%;height:100%;top:0;left:0}.annotationLayer .annotationTextContent{position:absolute;width:100%;height:100%;opacity:0;color:transparent;-webkit-user-select:none;user-select:none;pointer-events:none}.annotationLayer .annotationTextContent span{width:100%;display:inline-block}:root{--react-pdf-text-layer: 1;--highlight-bg-color: rgba(180, 0, 170, 1);--highlight-selected-bg-color: rgba(0, 100, 0, 1)}@media screen and (forced-colors:active){:root{--highlight-bg-color: Highlight;--highlight-selected-bg-color: ButtonText}}[data-main-rotation="90"]{transform:rotate(90deg) translateY(-100%)}[data-main-rotation="180"]{transform:rotate(180deg) translate(-100%,-100%)}[data-main-rotation="270"]{transform:rotate(270deg) translate(-100%)}.textLayer{position:absolute;text-align:initial;inset:0;overflow:hidden;line-height:1;text-size-adjust:none;forced-color-adjust:none;transform-origin:0 0;z-index:2}.textLayer :is(span,br){color:transparent;position:absolute;white-space:pre;cursor:text;margin:0;transform-origin:0 0}.textLayer span.markedContent{top:0;height:0}.textLayer .highlight{margin:-1px;padding:1px;background-color:var(--highlight-bg-color);border-radius:4px}.textLayer .highlight.appended{position:initial}.textLayer .highlight.begin{border-radius:4px 0 0 4px}.textLayer .highlight.end{border-radius:0 4px 4px 0}.textLayer .highlight.middle{border-radius:0}.textLayer .highlight.selected{background-color:var(--highlight-selected-bg-color)}.textLayer br::selection{background:transparent}.textLayer .endOfContent{display:block;position:absolute;inset:100% 0 0;z-index:-1;cursor:default;-webkit-user-select:none;user-select:none}.textLayer.selecting .endOfContent{top:0}.hiddenCanvasElement{position:absolute;top:0;left:0;width:0;height:0;display:none}.app{min-height:100vh;display:flex;flex-direction:column;background:#000}.nav{display:flex;justify-content:center;padding:0;position:relative;z-index:10}.nav-inner{display:inline-flex;gap:0;padding:16px 40px 20px;position:relative}.nav-inner:before{content:"";position:absolute;inset:0;background:url(/assets/woodgrain-CzVLlZy0.jpg) center / cover no-repeat;border-radius:0 0 16px 16px;transform:perspective(120px) rotateX(-6deg);transform-origin:top center;z-index:-1}.nav-inner:after{content:"";position:absolute;inset:0;background:#00000026;border-radius:0 0 16px 16px;transform:perspective(120px) rotateX(-6deg);transform-origin:top center;z-index:-1}.nav-link{font-family:MumboSSK,sans-serif;font-weight:700;font-size:1.05rem;color:#f5f0e0;text-decoration:none;padding:6px 28px;position:relative;z-index:1;letter-spacing:.04em;transition:color .2s,text-shadow .2s;text-shadow:0 1px 3px rgba(0,0,0,.5)}.nav-link:hover{color:#fff;text-shadow:0 0 12px rgba(255,200,100,.6),0 1px 3px rgba(0,0,0,.5)}.main{flex:1;display:flex;align-items:center;justify-content:center;gap:48px;padding:32px 48px 48px;max-width:1440px;margin:0 auto;width:100%}.cartridge-col{flex:0 0 auto;display:flex;justify-content:flex-end;align-items:center;min-width:0}.cartridge-canvas-wrap{width:480px;height:560px;cursor:grab}.cartridge-canvas-wrap:active{cursor:grabbing}.bio-col{flex:1 1 0;min-width:0}.name{font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-weight:200;font-size:3rem;margin:0 0 4px;color:#fff;letter-spacing:.02em}.tagline{font-size:.95rem;color:#888;margin:0 0 32px;font-weight:300;letter-spacing:.06em;text-transform:uppercase}.bio p{margin:0 0 14px;font-size:.95rem;font-weight:300;color:silver;line-height:1.7}.bio a{color:#d4a053;text-decoration:none;border-bottom:1px solid rgba(212,160,83,.3);transition:border-color .2s,color .2s}.bio a:hover{color:#f0c070;border-bottom-color:#f0c07099}.main-contact{flex-direction:column;align-items:center;gap:0}.contact-pdf{display:flex;flex-direction:row;align-items:flex-start;gap:0}.games-page{flex:1;display:flex;align-items:center;justify-content:center;padding:32px 48px 48px}.text-adventure{background:#000;border:4px solid white;max-width:800px;width:100%;position:relative;box-shadow:0 0 15px #ffffff80;overflow:hidden;font-family:monospace}.ta-header{display:flex;justify-content:space-between;align-items:center;background:#fff;color:#000;padding:.5em;text-transform:uppercase;border-bottom:4px solid black;font-size:1.2em}.ta-title,.ta-score{font-weight:700}.ta-body{padding:.5em 1em 1em}.ta-body p{margin:.5em 0;line-height:1.05em;color:#fff;font-size:1.2em}.ta-body p strong{color:#fff}.ta-input-line{display:flex;align-items:center;margin:.5em 0;font-size:1.2em;color:#fff;font-family:monospace}.ta-input-line strong{color:#fff}.ta-input{background:transparent;border:none;outline:none;color:#fff;font-family:monospace;font-size:1em;padding:0;margin:0;caret-color:transparent;max-width:80%}.ta-cursor{display:inline-block;width:.4em;height:.8em;background:#fff;animation:blink .5s steps(2,start) infinite;vertical-align:middle}@keyframes blink{0%,to{opacity:1}25%,75%{opacity:.5}50%{opacity:0}}.projects-page{flex:1;display:flex;flex-direction:column;gap:64px;padding:48px 64px 64px;max-width:1200px;margin:0 auto;width:100%}.project-card{display:flex;flex-direction:column}.project-content{display:flex;align-items:stretch;gap:0;height:220px}.project-logo-side{flex:0 0 200px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding-right:32px}.project-logo{max-width:140px;max-height:120px;object-fit:contain;filter:brightness(.95)}.project-visit-btn{display:inline-block;padding:0 0 2px;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-size:.75rem;font-weight:300;letter-spacing:.14em;text-transform:uppercase;color:#ffffff80;text-decoration:none;border-bottom:1px solid rgba(255,255,255,.15);transition:color .3s,border-color .3s}.project-visit-btn:hover{color:#fff;border-bottom-color:#fff9}.project-divider{flex:0 0 1px;background:#ffffff59;align-self:stretch}.project-screenshots-wrap{flex:1 1 0;min-width:0;position:relative}.project-screenshots-wrap:after{content:"";position:absolute;top:0;right:0;width:48px;height:100%;background:linear-gradient(to right,transparent,#000);pointer-events:none;z-index:2}.project-screenshots{display:flex;gap:24px;padding-left:32px;padding-right:48px;overflow-x:auto;align-items:center;height:100%;cursor:grab;scrollbar-width:none;-ms-overflow-style:none;-webkit-user-select:none;user-select:none}.project-screenshots:active{cursor:grabbing}.project-screenshots::-webkit-scrollbar{display:none}.project-screenshot{height:100%;max-height:220px;width:auto;object-fit:cover;border-radius:4px;flex-shrink:0;pointer-events:none}.project-drag-hint{position:absolute;right:-20px;top:50%;transform:translateY(-50%);opacity:.4;transition:opacity .6s ease;z-index:3}.project-drag-hint-hidden{opacity:0;pointer-events:none}.project-drag-icon{opacity:.5;animation:dragNudge 2.4s ease-in-out infinite}@keyframes dragNudge{0%,to{opacity:.5}50%{opacity:.2}}.page-transition{opacity:0;transition:opacity .5s ease-out}.page-transition.page-visible{opacity:1}.page-loading-text{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff6;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-weight:200;font-size:.85rem;letter-spacing:.3em;text-transform:uppercase;pointer-events:none;transition:opacity .3s ease-out;z-index:5}.page-loading-text-hidden{opacity:0}@media(max-width:820px){.main{flex-direction:column;padding:32px 24px;gap:40px}.cartridge-canvas-wrap{width:320px;height:380px}.bio-col{max-width:100%;text-align:center}.name{font-size:2.2rem}.nav-link{font-size:.9rem;padding:6px 16px}}
