.collapse-btn[collapsed=true]+.collapse-body{opacity:0;font-size:0;transition:opacity .4s,font-size .3s .4s}.collapse-btn[collapsed=true]+.collapse-body p{padding:0!important;transition:padding .3s .3s}.collapse-btn[collapsed=false]+.collapse-body{font-size:inherit;opacity:1;transition:opacity .3s .3s,font-size .3s}.collapse-btn[collapsed=false]+.collapse-body p{transition:padding .3s}nav{position:fixed;top:0;left:0;background-color:#e8d0f0;width:0px;z-index:5}.menu-btn{position:fixed;padding:20px;top:0;left:0;right:0;display:flex;gap:0px;transition:all .7s;z-index:1;justify-content:space-between;pointer-events:none}nav .btn{opacity:0;pointer-events:none;padding:8px 16px;fill:#e8d0f0}.menu-btn>.btn:first-child{padding:8px 24px;margin-right:16px}nav svg{transition:all .2s}html[data-scroll=true] nav .btn{opacity:1;pointer-events:all}.active .btn{box-shadow:6px 6px #e8d0f0b3;background-color:#e8d0f0;color:#4a2d5e;fill:#4a2d5e;border-color:#4a2d5e;opacity:1!important;pointer-events:all!important}.active .btn:hover{box-shadow:8px 8px 6px #e8d0f080}.active .btn:active{box-shadow:4px 4px #e8d0f0b3}.menu-body{background-color:#4a2d5e;color:#e8d0f0;font-size:2em;font-family:public-pixel,monospace;text-decoration:none!important;position:fixed;top:0;bottom:0;left:-100px;right:100vw;z-index:0;transition:all .7s;display:inline-flex;gap:16px;flex-direction:column;padding-top:70px;padding-left:20px;overflow:hidden;box-sizing:border-box;opacity:0}.menu-body a{text-decoration:none!important}.menu-body a:hover{transform:none}.active .menu-body{left:0;right:0;opacity:1}#tip-scroll{position:fixed;bottom:16px;left:50%;transform:translate(-50%);font-family:chill,sans-serif;font-size:14px;box-shadow:6px 6px #000000bf;background-color:#4a2d5e;color:#e8d0f0;transition:all .3s;padding:4px 24px;border:#e8d0f0 solid 1px;pointer-events:none;display:none;opacity:1}html[data-scroll=true] #tip-scroll{opacity:0}.active #tip-scroll{opacity:0!important}@media (min-width: 540px){.menu-btn{justify-content:left}.active .menu-btn{translate:28px}.menu-body{padding-left:50px}}@media (orientation: portrait){#tip-scroll{display:block}}:root{--color: #4a2d5e}@font-face{font-family:public-pixel;src:url(/fonts/public-pixel.woff)}@font-face{font-family:chill;src:url(/fonts/chill.woff)}*{margin:0;padding:0}html,body{overflow-x:hidden;background-color:#e8d0f0;font-family:chill,sans-serif;font-size:18px;-webkit-text-size-adjust:100%}.webgl{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;outline:none;z-index:1}#hero-backup{display:flex;flex-direction:column;justify-content:center;gap:16px;position:absolute;top:0;left:0;right:0;bottom:0;width:clamp(0px,95vw,580px);margin:auto;color:var(--color);outline:none;z-index:0}#hero-backup h1,#hero-backup h3{margin:0;text-align:left}#hero-backup ul{margin-left:32px}.webgl:active{cursor:grabbing}#textarea{position:fixed;top:0;right:0;outline:none;z-index:-1;opacity:0}#loading{color:#e8d0f0;background-color:var(--color);position:fixed;top:0;bottom:0;left:0;right:0;padding:10vw;z-index:6;transition:opacity .3s;display:flex;flex-direction:column;justify-content:center;gap:16px}#loading h2{text-align:left;margin:0;padding:0}#loading-items{height:64px;overflow:hidden;text-overflow:ellipsis}#loading-bar{position:relative;width:100%;height:64px;border:dashed 2px #e8d0f0;box-shadow:2px 2px 0 var(--color),6px 6px #e8d0f0b3}#loading-bar-progress{position:absolute;top:2px;bottom:2px;left:2px;right:2px;background-color:#e8d0f0;transform:scaleX(0);transform-origin:left;transition:transform .2s}h1{display:inline-block;color:#e8d0f0;background-color:var(--color);font-family:public-pixel,monospace;font-size:2em;padding:4px 16px 8px;margin:0 auto .3em}h2{display:inline-block;font-size:1.2em;text-align:center;color:#e8d0f0;background-color:var(--color);font-family:public-pixel,monospace;padding:4px 16px 8px;margin:.3em auto}h3{font-size:1.2em;text-align:center;color:var(--color);font-family:public-pixel,monospace;padding-top:4px;padding-bottom:8px;margin:.3em auto}hr{width:100px;height:2px;background-color:none;margin:40px auto;border:none;border-bottom:dashed 2px var(--color)}.skills,p{padding:16px;text-align:left;line-height:1.5;width:clamp(0px,95vw,960px);margin:auto;box-sizing:border-box}.skills{display:flex;flex-wrap:wrap;align-content:center;justify-content:center;align-items:center;gap:16px;text-align:center;list-style-type:none;transition:all .3s}.skills li{display:inline-block;padding:4px 8px;border:dashed 1px var(--color);box-shadow:1px 1px #e8d0f0,4px 4px #4a2d5e40}.image{display:flex;align-items:flex-start;justify-content:center;flex-wrap:wrap;gap:16px;margin:auto}.image *{box-sizing:border-box;width:clamp(0px,95vw,1200px);box-shadow:1px 1px #e8d0f0,6px 6px #4a2d5e40}main{color:var(--color);margin-top:200vh;text-align:center;position:relative;z-index:2}section{padding-bottom:64px;margin-bottom:80px;position:relative}section:after{content:"";border-bottom:dashed 2px var(--color);position:absolute;bottom:0;transform:translate(-50%);width:clamp(0px,95vw,960px)}section:last-of-type{border-bottom:none;margin-bottom:0}footer{display:flex;gap:32px;flex-direction:column;font-size:12px;width:clamp(0px,95vw,680px);margin:auto;padding:32px 0;text-align:center;color:var(--color);z-index:2;position:relative}a{display:inline-block;color:inherit;text-decoration-style:solid;text-decoration-thickness:2px;transition:all .3s}a:hover{transform:scale(1.1);box-shadow:1px 1px #e8d0f0,4px 4px #4a2d5e40}a:active{transform:scale(1);box-shadow:1px 1px #e8d0f0,3px 3px #4a2d5e66}.btn{position:relative;font-family:chill,sans-serif;font-size:18px;display:inline-flex;gap:.25rem;box-shadow:6px 6px #4a2d5e40;background-color:var(--color);color:#e8d0f0;cursor:pointer;transition:all .3s;padding:4px 24px;border:#e8d0f0 solid 1px;text-decoration:none}.btn:hover{transform:scale(1.1);box-shadow:8px 8px 6px #4a2d5e40;z-index:2}.btn:active{transform:scale(.95);box-shadow:4px 4px #4a2d5e66}.portrait{position:relative;width:clamp(0px,95vw,780px);padding:0;height:400px;margin:auto;overflow:hidden;display:flex;align-items:center;justify-content:center;box-shadow:1px 1px #e8d0f0,6px 6px #4a2d5e40}.portrait-tag{position:absolute;color:#fff;left:calc(50% + 120px);top:30px;transform:translate(-50%) rotate(20deg)}.portrait:after{z-index:-1;position:absolute;top:-30px;bottom:-30px;left:-30px;right:-30px;display:block;content:" ";box-shadow:6px 6px #4a2d5e40;background-color:#2d1040;background-image:url(/assets/bg-ADK_DFsu.png);background-size:contain;filter:blur(30px);color:#e8d0f0;border:#e8d0f0 solid 1px}.tw-scene{width:clamp(0px,95vw,580px);margin:32px auto;perspective:800px}.tw-machine{position:relative;transform-style:preserve-3d;transform:rotateX(12deg) rotateY(-4deg);transition:transform .6s ease}.tw-machine:hover{transform:rotateX(8deg) rotateY(0)}.tw-paper{position:relative;width:75%;margin:0 auto;background:#faf6f0;padding:32px 28px 24px;min-height:120px;border:1px solid #c8b8d0;box-shadow:0 -2px 8px #4a2d5e0f,2px 2px #4a2d5e0d;transform:translateZ(20px) translateY(-10px);z-index:3;font-family:Courier New,Courier,monospace;font-size:.95em;color:#2a1a30;line-height:2;text-align:left}.tw-paper:before{content:"";position:absolute;top:16px;bottom:16px;left:22px;width:1.5px;background-color:#d4a0c0;opacity:.35}.tw-platen{position:relative;display:flex;align-items:center;justify-content:center;width:85%;margin:0 auto;height:28px;transform:translateZ(10px);z-index:2}.tw-platen-roller{flex:1;height:28px;background:linear-gradient(180deg,#3d2050,#5a3570 30%,#3d2050 50%,#2a1538);border-radius:14px;box-shadow:0 4px 8px #0000004d,inset 0 2px 4px #ffffff1a}.tw-platen-knob{width:18px;height:18px;background:radial-gradient(circle at 40% 35%,#7a5a8a,#3d2050);border-radius:50%;border:2px solid #2a1538;box-shadow:1px 1px 3px #0006;flex-shrink:0}.tw-knob-left{margin-right:-4px}.tw-knob-right{margin-left:-4px}.tw-body{position:relative;transform-style:preserve-3d;z-index:1}.tw-body-top{width:92%;margin:0 auto;height:20px;background:linear-gradient(180deg,#4a2d5e,#3a2048);border-radius:4px 4px 0 0;transform:translateZ(5px);box-shadow:0 -2px 6px #4a2d5e26}.tw-body-front{width:100%;height:40px;background:linear-gradient(180deg,#4a2d5e,#3a2048 60%,#2d1838);border-radius:0 0 8px 8px;box-shadow:0 6px 16px #2a1a3859,inset 0 1px #ffffff0d}.tw-keys{position:relative;display:flex;flex-direction:column;align-items:center;gap:5px;padding:10px 0 14px;transform:translateZ(-5px) rotateX(-25deg);transform-origin:top center}.tw-key-row{display:flex;gap:4px;justify-content:center}.tw-key:hover{transform:translateY(2px);box-shadow:0 1px 2px #0000004d,inset 0 1px 1px #ffffff14}.tw-key.tw-pressed{transform:translateY(3px);box-shadow:0 0 2px #0000004d}.tw-spacebar{width:140px;border-radius:14px}.tw-typed{display:inline;border-right:2px solid #2a1a30;animation:tw-blink .6s step-end infinite}.tw-typed.done{border-right-color:transparent;animation:none}.tw-output a{color:var(--color);text-decoration:underline;text-decoration-thickness:2px;transition:color .3s}.tw-output a:hover{color:#d946a8;box-shadow:none;transform:none}.tw-line-static{opacity:0;animation:tw-fade-in .4s ease forwards}.tw-signature{font-style:italic;opacity:.7}@keyframes tw-blink{0%,to{border-right-color:#2a1a30}50%{border-right-color:transparent}}@keyframes tw-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.tw-scene:focus{outline:none}.tw-interactive{animation:tw-fade-in .4s ease forwards}.tw-user-text{min-height:1.5em;word-break:break-all}.tw-user-cursor{animation:tw-blink .6s step-end infinite;font-weight:700}.tw-hint{margin-top:12px;font-size:.7em;color:#a088b0;font-style:italic;animation:tw-fade-in .5s ease .6s both}.tw-send-row{margin-top:12px;display:flex;justify-content:flex-end}.tw-send-btn{font-family:Courier New,Courier,monospace;font-size:.85em;padding:6px 18px;background-color:var(--color);color:#e8d0f0;border:1.5px solid #e8d0f0;cursor:pointer;box-shadow:3px 3px #4a2d5e40;transition:all .2s}.tw-send-btn:hover{transform:scale(1.05);box-shadow:4px 4px 4px #4a2d5e4d}.tw-send-btn:active{transform:scale(.97);box-shadow:1px 1px #4a2d5e4d}.tw-send-status{margin-top:8px;font-size:.7em;color:#a088b0;font-style:italic;opacity:0;transition:opacity .3s}.tw-alt-contact{margin-top:16px;font-size:.7em;color:#a088b0;font-style:italic}.tw-alt-contact a{color:var(--color);transition:color .3s}.tw-alt-contact a:hover{color:#d946a8;box-shadow:none;transform:none}.tw-key{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:radial-gradient(circle at 45% 40%,#5a3570,#3a2048);color:#e8d0f0;font-family:public-pixel,monospace;font-size:.45em;border-radius:50%;border:1.5px solid #2a1538;box-shadow:0 3px 4px #00000059,inset 0 1px 1px #ffffff14;transition:transform .1s,box-shadow .1s;cursor:pointer;-webkit-user-select:none;user-select:none}.project-image{width:clamp(0px,95vw,960px);margin:16px auto;box-sizing:border-box}.project-image img{width:100%;max-width:1448px;height:auto;aspect-ratio:1448 / 1086;object-fit:cover;display:block;border:dashed 2px var(--color);box-shadow:1px 1px #e8d0f0,6px 6px #4a2d5e40;background-color:#4a2d5e0d}.project-image img[src=""]{position:relative}.project-image--phone{display:flex;gap:16px;justify-content:center;align-items:flex-start;flex-wrap:nowrap}.project-image--phone img{width:360px;height:780px;aspect-ratio:auto;object-fit:cover;cursor:pointer}.project-image img{cursor:pointer;transition:transform .2s,box-shadow .2s}.project-image img:hover{transform:scale(1.02);box-shadow:1px 1px #e8d0f0,8px 8px #4a2d5e4d}.store-links,.project-links{display:flex;gap:16px;justify-content:center;margin:16px auto;flex-wrap:wrap}.disclaimer{font-size:.75em;opacity:.7;text-align:center;margin-top:-8px;margin-bottom:-8px}.lightbox-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#2a1a38e6;z-index:100;justify-content:center;align-items:center;cursor:pointer}.lightbox-overlay.active{display:flex}.lightbox-overlay img{max-width:90vw;max-height:90vh;object-fit:contain;box-shadow:0 0 40px #e8d0f04d;border:dashed 2px #e8d0f0}.commit-timeline{width:clamp(0px,95vw,680px);margin:12px auto 8px;padding:12px 16px;box-sizing:border-box}.commit-timeline-label{display:flex;justify-content:space-between;font-family:public-pixel,monospace;font-size:.55em;color:var(--color);opacity:.6;margin-bottom:6px}.commit-timeline-grid{display:flex;gap:3px;flex-wrap:wrap}.commit-week{display:flex;flex-direction:column;gap:3px}.commit-day{width:10px;height:10px;border-radius:2px;background-color:#4a2d5e14}.commit-day.level-1{background-color:#d946a840}.commit-day.level-2{background-color:#d946a880}.commit-day.level-3{background-color:#d946a8bf}.commit-day.level-4{background-color:#d946a8}.commit-timeline-months{display:flex;font-family:public-pixel,monospace;font-size:.45em;color:var(--color);opacity:.5;margin-top:4px;gap:0px}.commit-timeline-months span{flex-shrink:0}
