@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;700&display=swap";:root{--color-primary: #FFB000;--color-dim: #805800;--color-bg: #0A0A0A;--color-glow: #FFB000;--color-scanline: rgba(0, 0, 0, .3);--font-mono: "IBM Plex Mono", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%;overflow:hidden}body{background:var(--color-bg);color:var(--color-primary);font-family:var(--font-mono)}.game-container{position:relative;width:100%;height:100%;display:flex}.mute-toggle{position:absolute;bottom:16px;right:16px;z-index:15;background:transparent;border:1px solid var(--color-dim);color:var(--color-dim);font-family:var(--font-mono);font-size:12px;padding:4px 8px;cursor:pointer;transition:color .2s,border-color .2s}.mute-toggle:hover{color:var(--color-primary);border-color:var(--color-primary)}.crt-screen{position:relative;width:100%;height:100%;overflow:hidden;background:var(--color-bg);border-radius:12px}.crt-screen:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:12px;background:radial-gradient(ellipse at center,transparent 60%,rgba(0,0,0,.4) 100%);pointer-events:none;z-index:12}.crt-content{position:relative;width:100%;height:100%;z-index:1;text-shadow:0 0 5px rgba(255,176,0,.5),0 0 10px rgba(255,176,0,.2)}.crt-scanlines{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:10;background:repeating-linear-gradient(to bottom,transparent 0px,transparent 2px,var(--color-scanline) 2px,var(--color-scanline) 4px)}@keyframes flicker{0%{opacity:.02}5%{opacity:.04}10%{opacity:.02}15%{opacity:.03}20%{opacity:.02}50%{opacity:.03}to{opacity:.02}}.crt-flicker{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:11;background:var(--color-primary);animation:flicker .15s infinite}.landing{min-height:100%;display:flex;align-items:center;justify-content:center;padding:24px;font-family:var(--font-mono);color:var(--color-primary)}.landing__inner{display:flex;flex-direction:column;align-items:center;gap:40px;animation:landing-fade-in .8s ease-out}@keyframes landing-fade-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.landing__header{text-align:center;display:flex;flex-direction:column;align-items:center}.landing__name{font-size:clamp(2rem,5vw,3rem);font-weight:700;letter-spacing:.12em;color:var(--color-primary);text-shadow:0 0 12px rgba(255,176,0,.4);margin:0}.landing__rule{color:#c89b00;font-size:14px;margin-top:8px;white-space:pre;text-align:center}.landing__tagline{font-size:14px;color:#c89b00;margin-top:8px;letter-spacing:.08em}.landing__bio{font-size:13px;color:#c89b00;margin-top:16px;line-height:1.6;max-width:480px;text-align:center}.landing__cards{display:flex;gap:24px;justify-content:center}.landing__card{cursor:pointer;background:none;border:1px solid var(--color-dim);padding:0;outline:none;font-family:var(--font-mono);color:var(--color-dim);text-align:left;transition:color .2s ease,text-shadow .2s ease,transform .15s ease,border-color .2s ease;flex:1 1 0;min-width:200px;max-width:300px;overflow:hidden}.landing__card:hover,.landing__card:focus{color:var(--color-primary);border-color:var(--color-primary);text-shadow:0 0 8px rgba(255,176,0,.3);box-shadow:0 0 8px #ffb00026;transform:translateY(-2px)}.landing__card:focus{outline:1px solid rgba(255,176,0,.3);outline-offset:4px}.landing__card-body{padding:16px 20px}.landing__card-title{font-size:18px;font-weight:700;margin:0 0 8px}.landing__card-desc{font-size:13px;line-height:1.5;margin:0;opacity:.8;overflow-wrap:break-word}.landing__hint{font-size:12px;color:var(--color-dim);opacity:.5;margin:0;letter-spacing:.04em}.landing__cursor{animation:cursor-blink 1s step-end infinite}@keyframes cursor-blink{0%,to{opacity:1}50%{opacity:0}}@media(max-width:580px){.landing{padding:40px 16px 16px;align-items:flex-start}.landing__inner{gap:20px}.landing__cards{flex-direction:column;gap:12px}.landing__card{flex:none;width:100%;max-width:100%}.landing__card-body{padding:12px 16px}.landing__bio{max-width:100%;margin-top:8px}}.portfolio{height:100%;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--color-dim) transparent;padding:40px 24px 80px;font-family:var(--font-mono);color:var(--color-primary)}.portfolio::-webkit-scrollbar{width:6px}.portfolio::-webkit-scrollbar-thumb{background:var(--color-dim);border-radius:3px}.portfolio__container{max-width:680px;margin:0 auto;display:flex;flex-direction:column;gap:28px;animation:portfolio-fade-in .6s ease-out}@keyframes portfolio-fade-in{0%{opacity:0}to{opacity:1}}.portfolio__back{cursor:pointer;background:none;border:none;font-family:var(--font-mono);font-size:14px;color:var(--color-dim);padding:0;width:fit-content;transition:color .15s ease,text-shadow .15s ease}.portfolio__back:hover,.portfolio__back:focus{color:var(--color-primary);text-shadow:0 0 5px rgba(255,176,0,.3);outline:none}.portfolio__header{text-align:center}.portfolio__name{font-size:clamp(1.8rem,4vw,2.5rem);font-weight:700;letter-spacing:.1em;color:var(--color-primary);text-shadow:0 0 10px rgba(255,176,0,.4);margin:0}.portfolio__rule{color:var(--color-dim);font-size:14px;margin:8px 0;white-space:pre;overflow:hidden}.portfolio__bio{font-size:14px;line-height:1.7;color:var(--color-primary);margin:0;text-align:left}.portfolio__contact{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:13px;color:var(--color-dim)}.portfolio__contact-label{color:var(--color-primary)}.portfolio__contact a{color:var(--color-primary);text-decoration:none;transition:text-shadow .15s ease}.portfolio__contact a:hover{text-shadow:0 0 8px rgba(255,176,0,.5);text-decoration:underline}.portfolio__sep{color:var(--color-dim);opacity:.5}.portfolio__projects{display:flex;flex-direction:column;gap:4px}.portfolio__section-divider{font-size:14px;color:var(--color-dim);white-space:pre;overflow:hidden}.project-card{cursor:pointer;outline:none;padding:12px 16px;border-left:2px solid transparent;transition:border-color .2s ease,background .2s ease}.project-card:hover{border-left-color:var(--color-dim);background:#ffb00005}.project-card--expanded{border-left-color:var(--color-primary);background:#ffb00008}.project-card--expanded:hover{border-left-color:var(--color-primary)}.project-card__header{display:flex;align-items:center;gap:8px}.project-card__prefix{color:var(--color-dim);font-size:14px;flex-shrink:0}.project-card__name{font-size:16px;font-weight:700;color:var(--color-primary);margin:0;flex:1}.project-card__toggle{color:var(--color-dim);font-size:12px;flex-shrink:0}.project-card__tagline{font-size:13px;color:var(--color-dim);margin:4px 0 0 32px;line-height:1.5}.project-card__details{margin:16px 0 0 32px;padding-top:12px;border-top:1px solid rgba(128,88,0,.3);animation:details-expand .25s ease-out}@keyframes details-expand{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.project-card__description{font-size:14px;line-height:1.7;color:var(--color-primary);margin:0}.project-card__meta{display:flex;flex-wrap:wrap;gap:16px;margin-top:12px;font-size:13px;color:var(--color-dim)}.project-card__meta-label{color:var(--color-primary);opacity:.7}.project-card__links{display:flex;flex-wrap:wrap;gap:12px;margin-top:12px}.project-card__link{color:var(--color-primary);text-decoration:none;font-size:13px;font-family:var(--font-mono);transition:text-shadow .15s ease}.project-card__link:hover{text-shadow:0 0 8px rgba(255,176,0,.5);text-decoration:underline}.portfolio__footer{margin-top:8px;display:flex;flex-direction:column;gap:8px}.portfolio__resume-link{color:var(--color-primary);text-decoration:none;font-size:14px;font-family:var(--font-mono);width:fit-content;transition:text-shadow .15s ease}.portfolio__resume-link:hover{text-shadow:0 0 8px rgba(255,176,0,.5);text-decoration:underline}.portfolio__email{font-size:13px;color:var(--color-dim);margin:0}.simple-md{margin-top:16px}.simple-md__h4{font-size:14px;font-weight:700;color:var(--color-primary);margin:20px 0 8px;letter-spacing:.04em}.simple-md__h4:before{content:"> ";color:var(--color-dim)}.simple-md>.simple-md__h4:first-child{margin-top:0}.simple-md__p{font-size:13px;line-height:1.75;color:var(--color-primary);margin:0 0 12px;opacity:.9}.simple-md__ul{list-style:none;padding:0;margin:0 0 12px}.simple-md__li{font-size:13px;line-height:1.65;color:var(--color-primary);padding-left:16px;position:relative;margin-bottom:4px;opacity:.9}.simple-md__li:before{content:"–";position:absolute;left:0;color:var(--color-dim)}.simple-md__li strong,.simple-md__p strong{color:var(--color-primary);font-weight:700}@media(max-width:480px){.portfolio{padding:24px 16px 60px}.project-card__tagline,.project-card__details{margin-left:0}.portfolio__contact{flex-direction:column;align-items:flex-start;gap:4px}.portfolio__sep{display:none}}.boot-sequence{padding:40px;font-family:var(--font-mono);font-size:14px;color:var(--color-primary);line-height:1.6;height:100%;display:flex;justify-content:center;align-items:center}.boot-scroll-box{width:580px;max-height:80vh;overflow-y:hidden;text-align:left;display:flex;flex-direction:column;justify-content:flex-start}.boot-line{white-space:pre}@keyframes boot-blink{0%,49%{opacity:1}50%,to{opacity:0}}.boot-cursor{animation:boot-blink 1s step-end infinite}.terminal{display:flex;flex-direction:column;align-items:center;flex:1;height:100%;padding:56px 24px 24px;font-family:var(--font-mono);font-size:14px;line-height:1.6;color:var(--color-primary);cursor:text}.terminal-room-header{flex-shrink:0;width:100%;max-width:640px;padding-bottom:12px;margin-bottom:8px;border-bottom:1px solid rgba(128,88,0,.3);text-align:center}.terminal-room-header__art{margin-top:4px;display:inline-block;text-align:left}.terminal-line--room-name{font-weight:700;letter-spacing:2px;color:var(--color-primary);text-align:center}.terminal-output{flex:1;overflow-y:auto;scrollbar-width:none;width:100%;max-width:640px}.terminal-output::-webkit-scrollbar{display:none}.terminal-line{white-space:pre-wrap;word-break:break-word;min-height:1.6em}.terminal-line--input,.terminal-line--output{color:var(--color-primary)}.terminal-line--ascii{white-space:pre;line-height:1.2}.terminal-line--system{color:var(--color-dim);font-style:italic}.terminal-line--dim{color:var(--color-dim)}.terminal-prompt{-webkit-user-select:none;user-select:none}.terminal-input-line{display:flex;align-items:center;padding-top:8px;flex-shrink:0;width:100%;max-width:640px}.terminal-input-line input{flex:1;background:transparent;border:none;outline:none;color:var(--color-primary);font-family:var(--font-mono);font-size:14px;line-height:1.6;caret-color:var(--color-primary)}.terminal-input-line input:disabled{opacity:.5;cursor:default}@keyframes blink{0%,49%{opacity:1}50%,to{opacity:0}}.terminal-cursor{animation:blink 1s step-end infinite}.terminal-transition{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;width:100%;max-width:640px}.terminal-static-line{white-space:pre;line-height:1.2;color:var(--color-primary);font-family:var(--font-mono);font-size:14px;opacity:.7;transition:opacity .15s ease-out,transform .15s ease-out}.terminal-static-line--dissolving{opacity:0;transform:translateY(-3px)}.inventory-panel{position:absolute;top:0;left:0;width:280px;height:100%;background:#0a0a0af2;border-right:1px solid var(--color-dim);transform:translate(-100%);transition:transform .3s ease;z-index:5;display:flex;flex-direction:column;font-family:var(--font-mono);font-size:13px;color:var(--color-primary);overflow-y:auto}.inventory-panel--open{transform:translate(0)}.inventory-panel__header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid var(--color-dim);font-size:14px;letter-spacing:2px}.inventory-panel__close{background:none;border:none;color:var(--color-dim);font-family:var(--font-mono);font-size:11px;cursor:pointer;padding:2px 4px}.inventory-panel__close:hover{color:var(--color-primary)}.inventory-panel__items{flex:1;padding:8px 0;overflow-y:auto;scrollbar-width:none}.inventory-panel__empty{padding:16px;color:var(--color-dim);font-style:italic}.inventory-panel__item-group{border-bottom:1px solid rgba(128,88,0,.2)}.inventory-panel__item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 16px;background:none;border:none;color:var(--color-primary);font-family:var(--font-mono);font-size:13px;cursor:pointer;text-align:left}.inventory-panel__item:hover{background:#ffb0000d}.inventory-panel__item--selected{background:#ffb0001a}.inventory-panel__icon{font-size:16px;width:24px;text-align:center;flex-shrink:0}.inventory-panel__name{flex:1}.inventory-panel__description{padding:8px 16px 12px 50px;color:var(--color-dim);font-size:12px;line-height:1.5}.inventory-panel__link{display:block;margin-top:8px;color:var(--color-primary);text-decoration:none}.inventory-panel__link:hover{text-decoration:underline}.map-panel{position:absolute;top:0;right:0;width:300px;height:100%;background:#0a0a0af2;border-left:1px solid var(--color-dim);transform:translate(100%);transition:transform .3s ease;z-index:5;display:flex;flex-direction:column;font-family:var(--font-mono);font-size:13px;color:var(--color-primary)}.map-panel--open{transform:translate(0)}.map-panel__header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid var(--color-dim);font-size:14px;letter-spacing:2px}.map-panel__close{background:none;border:none;color:var(--color-dim);font-family:var(--font-mono);font-size:11px;cursor:pointer;padding:2px 4px}.map-panel__close:hover{color:var(--color-primary)}.map-panel__content{flex:1;display:flex;flex-direction:column;justify-content:center;padding:16px}.map-panel__ascii{font-family:var(--font-mono);font-size:12px;line-height:1.4;color:var(--color-primary);white-space:pre;margin:0}.map-room--current{animation:map-blink 1s step-end infinite}@keyframes map-blink{0%,49%{opacity:1}50%,to{opacity:.3}}.map-panel__legend{margin-top:24px;padding-top:12px;border-top:1px solid var(--color-dim);display:flex;flex-direction:column;gap:4px;font-size:11px;color:var(--color-dim)}.mini-map{position:absolute;top:12px;right:12px;z-index:4;cursor:pointer;background:#0a0a0ad9;border:1px solid var(--color-dim);padding:6px 8px;font-family:var(--font-mono);color:var(--color-dim);transition:border-color .2s,color .2s;-webkit-user-select:none;user-select:none}.mini-map:hover{border-color:var(--color-primary);color:var(--color-primary)}.mini-map__label{text-align:center;margin-bottom:4px;letter-spacing:1px;font-size:8px}.mini-map__grid{display:grid;grid-template-columns:repeat(3,8px);grid-template-rows:repeat(3,8px);gap:2px}.mini-map__grid--outdoor{grid-template-columns:repeat(3,8px);grid-template-rows:8px}.mini-map__room{width:8px;height:8px;border:1px solid rgba(128,88,0,.4);background:transparent}.mini-map__room--visited{background:var(--color-dim);border-color:var(--color-dim)}.mini-map__room--current{background:var(--color-primary);border-color:var(--color-primary);animation:mini-map-blink 1s step-end infinite}.mini-map__room--branched{border-color:var(--color-primary);box-shadow:0 0 2px var(--color-primary)}@keyframes mini-map-blink{0%,49%{opacity:1}50%,to{opacity:.3}}.mini-inventory{position:absolute;top:12px;left:12px;z-index:4;cursor:pointer;background:#0a0a0ad9;border:1px solid var(--color-dim);padding:6px 8px;font-family:var(--font-mono);color:var(--color-dim);transition:border-color .2s,color .2s;-webkit-user-select:none;user-select:none}.mini-inventory:hover{border-color:var(--color-primary);color:var(--color-primary)}.mini-inventory__label{text-align:center;letter-spacing:1px;font-size:8px}.mini-inventory__count{text-align:center;font-size:14px;color:var(--color-primary);margin:2px 0}.mini-inventory__icons{display:flex;gap:2px;justify-content:center;font-size:10px}.mini-inventory__more{color:var(--color-dim);font-size:9px}.logbook-overlay{position:absolute;top:0;left:0;right:0;bottom:0;z-index:8;display:flex;align-items:center;justify-content:center;background:var(--color-bg)}.logbook{max-width:100%;max-height:100%;padding:24px;overflow:auto;scrollbar-width:none}.logbook__content{font-family:var(--font-mono);font-size:13px;line-height:1.5;color:var(--color-primary);white-space:pre;margin:0}
