@import url(https://fonts.googleapis.com/css2?family=Share+Tech+Mono&family=VT323&display=swap);body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f5f5f0;--fg:#0a0a0a;--dim:#999;--mid:#555;--accent:#0a0a0a;--border:#ccc;--hover-bg:#efefea;--card-bg:#fafaf7;--mono:"Share Tech Mono",monospace;--display:"VT323",monospace;--nav-h:52px}html{scroll-behavior:smooth}body{background:#f5f5f0;background:var(--bg);color:#0a0a0a;color:var(--fg);cursor:crosshair;font-family:Share Tech Mono,monospace;font-family:var(--mono);font-size:13px;line-height:1.6;overflow-x:hidden}body:before{background-image:radial-gradient(circle,#0000000a 1px,#0000 0);background-size:24px 24px;content:"";inset:0;pointer-events:none;position:fixed;z-index:0}::selection{background:#0a0a0a;background:var(--fg);color:#f5f5f0;color:var(--bg)}a{color:#0a0a0a;color:var(--fg);text-decoration:none}a:hover{text-decoration:underline}.section-label{color:#999;color:var(--dim);font-size:10px;letter-spacing:6px;margin-bottom:12px;text-transform:uppercase}.section-title{color:#0a0a0a;color:var(--fg);font-family:VT323,monospace;font-family:var(--display);font-size:clamp(28px,5vw,52px);letter-spacing:4px;margin-bottom:32px}.page{margin:0 auto;max-width:860px;min-height:100vh;padding:120px 40px 80px;position:relative;z-index:1}.page-label{color:#999;color:var(--dim);font-size:9px;letter-spacing:6px;margin-bottom:12px}.page-title{font-family:VT323,monospace;font-family:var(--display);font-size:clamp(36px,6vw,72px);line-height:1;margin-bottom:48px}.btn-outline,.page-title{color:#0a0a0a;color:var(--fg);letter-spacing:4px}.btn-outline{background:none;border:1px solid #0a0a0a;border:1px solid var(--fg);cursor:pointer;display:inline-block;font-family:Share Tech Mono,monospace;font-family:var(--mono);font-size:10px;padding:10px 24px;text-decoration:none;transition:all .15s}.btn-outline:hover{background:#0a0a0a;background:var(--fg);color:#f5f5f0;color:var(--bg);text-decoration:none}.skill-tag{border:1px solid #ccc;border:1px solid var(--border);color:#555;color:var(--mid);font-size:10px;letter-spacing:2px;padding:4px 12px}.skill-grid{display:flex;flex-wrap:wrap;gap:8px}.scroll-bar{background:#0a0a0a;background:var(--fg);height:1px;left:0;position:fixed;top:52px;top:var(--nav-h);transition:width .1s linear;z-index:101}.site-footer{border-top:1px solid #ccc;border-top:1px solid var(--border);color:#999;color:var(--dim);font-size:10px;letter-spacing:3px;padding:24px 40px;position:relative;z-index:1}.nav,.site-footer{display:flex;justify-content:space-between}.nav{align-items:center;background:var(--bg);border-bottom:1px solid var(--border);height:var(--nav-h);left:0;padding:0 40px;position:fixed;right:0;top:0;z-index:100}.nav-logo{color:var(--fg);cursor:pointer;font-family:var(--display);font-size:26px;letter-spacing:2px;-webkit-user-select:none;user-select:none}.nav-logo:hover{opacity:.7}.nav-links{display:flex;gap:32px;list-style:none}.nav-links a{color:var(--dim);font-size:11px;letter-spacing:3px;position:relative;text-decoration:none;transition:color .15s}.nav-links a:before{content:"[";margin-right:2px;opacity:0;transition:opacity .15s}.nav-links a:after{content:"]";margin-left:2px;opacity:0;transition:opacity .15s}.nav-links a:hover{color:var(--fg);text-decoration:none}.nav-links a:hover:after,.nav-links a:hover:before{opacity:1}.nav-links a.active{color:var(--fg)}.nav-links a.active:after,.nav-links a.active:before{opacity:1}.nav-hamburger{background:none;border:none;cursor:pointer;display:none;flex-direction:column;gap:5px;padding:4px}.nav-hamburger span{background:var(--fg);display:block;height:1px;transition:all .2s;width:22px}@media (max-width:640px){.nav-hamburger{display:flex}.nav-links{background:var(--bg);border-bottom:1px solid var(--border);display:none;flex-direction:column;gap:0;left:0;padding:8px 0;position:absolute;right:0;top:var(--nav-h)}.nav-links.open{display:flex}.nav-links li a{display:block;padding:12px 40px}}.filter-bar{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;margin-bottom:56px}.filter-btn{background:none;border:1px solid var(--border);color:var(--mid);cursor:pointer;font-family:var(--mono);font-size:10px;letter-spacing:3px;padding:6px 16px;transition:all .15s}.filter-btn:hover{border-color:var(--mid);color:var(--fg)}.filter-btn.active{background:var(--fg);border-color:var(--fg);color:var(--bg)}.carousel-stage{align-items:center;display:flex;height:340px;justify-content:center;margin-bottom:40px;perspective:900px;position:relative;width:100%}.carousel-ring{height:280px;position:relative;transform-style:preserve-3d;transition:transform .6s cubic-bezier(.23,1,.32,1);width:220px}.carousel-card{align-items:center;backface-visibility:hidden;background:var(--card-bg);border:1px solid var(--border);cursor:pointer;display:flex;flex-direction:column;height:260px;left:0;overflow:hidden;padding:20px 16px 16px;position:absolute;text-align:center;top:0;transform-style:preserve-3d;transition:border-color .2s,box-shadow .2s;width:200px}.carousel-card:hover{border-color:var(--fg);box-shadow:0 4px 24px #00000014}.carousel-card.active-card{border-color:var(--fg);box-shadow:0 6px 32px #0000001f}.card-category{color:var(--dim);font-size:9px;letter-spacing:4px;margin-bottom:4px}.card-ascii-art{align-items:center;color:var(--mid);display:flex;flex:1 1;font-family:var(--mono);font-size:10px;line-height:1.4;margin:8px 0;white-space:pre}.card-title{color:var(--fg);font-family:var(--display);font-size:22px;letter-spacing:2px;margin-bottom:4px}.card-year{color:var(--dim);font-size:10px;letter-spacing:2px}.card-click-hint{color:var(--dim);font-size:9px;letter-spacing:3px;margin-top:8px;opacity:0;transition:opacity .2s}.carousel-card:hover .card-click-hint{opacity:1}.carousel-nav{gap:16px;margin-top:8px}.carousel-arrow,.carousel-nav{align-items:center;display:flex}.carousel-arrow{background:none;border:1px solid var(--border);color:var(--mid);cursor:pointer;font-family:var(--mono);font-size:16px;height:36px;justify-content:center;transition:all .15s;width:36px}.carousel-arrow:hover{border-color:var(--fg);color:var(--fg)}.carousel-counter{font-size:11px;min-width:60px;text-align:center}.carousel-counter,.carousel-hint{color:var(--dim);letter-spacing:3px}.carousel-hint{font-size:10px;margin-top:32px}.modal-overlay{align-items:center;animation:fadeIn .2s;background:#f5f5f0eb;cursor:pointer;display:flex;inset:0;justify-content:center;position:fixed;z-index:200}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-box{animation:slideUp .25s cubic-bezier(.23,1,.32,1);background:var(--bg);border:1px solid var(--fg);cursor:default;max-width:520px;padding:40px;position:relative;width:90%;z-index:201}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}.modal-top-row{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:16px}.modal-header{color:var(--dim);font-size:9px;letter-spacing:5px}.modal-close{background:none;border:none;color:var(--dim);cursor:pointer;font-family:var(--mono);font-size:18px;line-height:1;margin-top:-4px;transition:color .15s}.modal-close:hover,.modal-title{color:var(--fg)}.modal-title{font-family:var(--display);font-size:40px;letter-spacing:3px;margin-bottom:8px}.modal-category{color:var(--mid);font-size:10px;letter-spacing:4px;margin-bottom:24px}.modal-divider{border:none;border-top:1px solid var(--border);margin:20px 0}.modal-ascii{color:var(--mid);font-family:var(--mono);font-size:11px;line-height:1.4;margin-bottom:24px;white-space:pre}.modal-desc{color:var(--mid);font-size:12px;line-height:1.8;margin-bottom:32px}
/*# sourceMappingURL=main.7b19a0a5.css.map*/