:root{--bg-dark:#0d1117;--bg-card:#161b22;--text-white:#fff;--text-dim:#8b949e;--neon-orange:#ff4500;--transition-slow:all .6s cubic-bezier(.22, 1, .36, 1)}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;background-color:var(--bg-dark)}body{color:var(--text-white);font-family:Inter,sans-serif;line-height:1.5}.bento-card{background:var(--bg-card);transition:var(--transition-slow);border:1px solid #ffffff0d;border-radius:24px;position:relative}.bento-card:hover{border-color:#ea580c4d;transform:translateY(-4px);box-shadow:0 20px 40px #0006}.bento-title{letter-spacing:-.02em;font-size:1.25rem;font-weight:700}.tag{color:var(--text-dim);background:#ffffff0d;border-radius:4px;padding:2px 8px}.pill{transition:var(--transition-slow);background:#ffffff08;border:1px solid #ffffff0d;border-radius:100px;padding:8px 16px;font-size:.875rem}.pill:hover{background:#ffffff14;border-color:#ea580c}.reveal{opacity:0;transition:var(--transition-slow);transform:translateY(30px)}.reveal.animate-in{opacity:1;transform:translateY(0)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-dark)}::-webkit-scrollbar-thumb{background:#30363d;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#ea580c}.popup{background:#161b22;border:1px solid #ea580c66;border-radius:16px;width:90%;max-width:380px;padding:1.75rem;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 60px #000c,0 0 20px #ea580c1a}.popup.hidden{display:none}.popup-close{cursor:pointer;font-size:1.25rem;line-height:1;position:absolute;top:12px;right:16px}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.animate-bounce{animation:2s infinite bounce}.project-card{cursor:pointer;-webkit-user-select:none;user-select:none}.project-card:focus-visible{outline-offset:3px;outline:2px solid #ea580cb3}.proj-modal-overlay{z-index:1000;opacity:0;pointer-events:none;background:0 0;justify-content:center;align-items:center;padding:1rem;transition:opacity .28s,background .28s,-webkit-backdrop-filter .28s,backdrop-filter .28s;display:flex;position:fixed;inset:0}.proj-modal-overlay.open{opacity:1;pointer-events:all;-webkit-backdrop-filter:blur(12px);background:#000000b8}.proj-modal-box{opacity:0;background:#161b22;border:1px solid #ffffff14;border-radius:20px;flex-direction:column;width:100%;max-width:780px;max-height:90vh;transition:transform .28s cubic-bezier(.22,1,.36,1),opacity .28s;display:flex;position:relative;overflow:hidden;transform:scale(.94)translateY(12px);box-shadow:0 32px 80px #0009,0 0 0 1px #ea580c14}.proj-modal-overlay.open .proj-modal-box{opacity:1;transform:scale(1)translateY(0)}.proj-modal-accent{background:linear-gradient(90deg,#ea580c 0%,#ff7a00 60%,#0000 100%);flex-shrink:0;height:3px}.proj-modal-scroll{overscroll-behavior:contain;flex-direction:column;gap:2rem;padding:2rem;display:flex;overflow-y:auto}.proj-modal-scroll::-webkit-scrollbar{width:4px}.proj-modal-scroll::-webkit-scrollbar-track{background:0 0}.proj-modal-scroll::-webkit-scrollbar-thumb{background:#30363d;border-radius:4px}.proj-modal-header{justify-content:space-between;align-items:flex-start;gap:1.5rem;display:flex}.proj-modal-title{letter-spacing:-.03em;color:#fff;font-size:1.5rem;font-weight:800;line-height:1.2}.proj-modal-desc{color:#8b949e;max-width:520px;margin-top:.4rem;font-size:.875rem;line-height:1.55}.proj-modal-close{color:#8b949e;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff14;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;transition:background .2s,color .2s,border-color .2s;display:flex}.proj-modal-close:hover{color:#ea580c;background:#ea580c1f;border-color:#ea580c4d}.proj-modal-section{flex-direction:column;gap:1.25rem;display:flex}.proj-section-label{letter-spacing:.14em;color:#ffffff40;text-transform:uppercase;font-family:Fira Code,monospace;font-size:.6rem;font-weight:500}.proj-pipeline-wrap{scrollbar-width:thin;scrollbar-color:#30363d transparent;flex-direction:row;align-items:flex-start;gap:0;padding-bottom:.75rem;display:flex;overflow-x:auto}.proj-pipeline-wrap::-webkit-scrollbar{height:4px}.proj-pipeline-wrap::-webkit-scrollbar-track{background:0 0}.proj-pipeline-wrap::-webkit-scrollbar-thumb{background:#30363d;border-radius:4px}@keyframes stepIn{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.proj-step{opacity:0;cursor:default;background:#ffffff05;border:1px solid #ffffff0d;border-radius:12px;flex-direction:column;flex-shrink:0;align-items:center;gap:.5rem;width:110px;padding:.75rem .5rem;transition:border-color .2s,background .2s;animation:.38s cubic-bezier(.22,1,.36,1) both stepIn;display:flex}.proj-step:hover{background:#ea580c0a;border-color:#ea580c40}.proj-step-badge{letter-spacing:.04em;color:#ea580c80;align-self:flex-start;margin-left:.1rem;font-family:Fira Code,monospace;font-size:.55rem;font-weight:600}@keyframes pulseRing{0%{box-shadow:0 0 #ea580c80}60%{box-shadow:0 0 0 8px #ea580c00}to{box-shadow:0 0 #ea580c00}}.proj-step-icon{color:#ea580c;background:#ea580c14;border:1px solid #ea580c26;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.proj-step-icon.pulsing{animation:.55s ease-out both pulseRing}.proj-step-title{color:#e6edf3;text-align:center;letter-spacing:-.01em;font-size:.65rem;font-weight:700;line-height:1.3}.proj-step-desc{color:#8b949e;text-align:center;font-size:.58rem;line-height:1.45}.proj-connector{flex-direction:column;flex-shrink:0;justify-content:center;align-self:center;align-items:center;gap:2px;width:28px;margin-top:-6px;display:flex}@keyframes connectorIn{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.proj-conn-line{transform-origin:0;background:linear-gradient(90deg,#ea580c66,#ea580c33);width:100%;height:1px;animation:.22s ease-out both connectorIn;transform:scaleX(0)}@keyframes arrowIn{0%{opacity:0}to{opacity:1}}.proj-conn-arrow{opacity:0;justify-content:center;align-items:center;margin-top:-5px;animation:.15s ease-out both arrowIn;display:flex}.proj-modal-footer{border-top:1px solid #ffffff0d;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1.5rem;padding-top:1.5rem;display:flex}.proj-tech-wrap{flex-wrap:wrap;gap:.4rem;margin-top:.6rem;display:flex}.proj-tech-chip{color:#ea580c;letter-spacing:.02em;background:#ea580c14;border:1px solid #ea580c33;border-radius:100px;padding:2px 10px;font-family:Fira Code,monospace;font-size:.65rem}.proj-gh-btn{color:#e6edf3;white-space:nowrap;background:#ffffff0a;border:1px solid #ffffff1f;border-radius:8px;flex-shrink:0;align-items:center;gap:.5rem;padding:8px 16px;font-family:Fira Code,monospace;font-size:.75rem;font-weight:500;text-decoration:none;transition:border-color .2s,background .2s,color .2s;display:inline-flex}.proj-gh-btn:hover{color:#ea580c;background:#ea580c14;border-color:#ea580c66}@media (width<=640px){.proj-modal-scroll{gap:1.5rem;padding:1.25rem}.proj-modal-title{font-size:1.2rem}.proj-step{width:92px;padding:.6rem .35rem}.proj-step-icon{width:30px;height:30px}.proj-modal-footer{flex-direction:column;align-items:flex-start;gap:1rem}}
