@keyframes proj-title-in{0%{opacity:0;transform:translate(-100px)}to{opacity:1;transform:none}}@keyframes proj-meta-in{0%{opacity:0}to{opacity:1}}@keyframes pill-in{0%{opacity:0}to{opacity:1}}.projectDetail .anim-proj-title{animation:proj-title-in .5s ease-out both}.projectDetail .anim-proj-meta{animation:proj-meta-in .5s ease-out .1s both}.projectDetail .anim-pill{animation:pill-in .3s ease-in-out both}.projectDetail h1,.projectDetail h2{color:var(--text-secondary)}.projectDetail h1{margin-bottom:0;font-size:2.1rem;font-weight:700}.projectDetail h2{font-size:1.5rem;margin-bottom:auto;font-weight:600}.projectDetail h2+ul,.projectDetail h2+ol{margin-top:10px}.projectDetail small{color:var(--navbar-primary);margin-bottom:40px;font-size:1rem;display:block;margin-left:-5px;padding-left:0}.projectDetail small span{background:var(--link-hover);color:var(--background);padding:4px 12px;border-radius:18px;margin:4px;display:inline-flex;align-items:center;font-size:1rem;font-weight:600;box-shadow:0 4px 8px #0000001a;transition:background-color var(--transition-speed) ease,transform var(--transition-speed) ease}.projectDetail small span img{margin-right:5px;width:20px;height:20px;background-color:transparent;border:none;display:block;border-radius:50%;overflow:hidden;object-fit:contain}.projectDetail a{color:var(--accent);text-decoration:none;font-weight:500;position:relative}.projectDetail a:hover{color:var(--link-hover);text-decoration:underline}.projectDetail .projectLinks a{margin-top:20px;font-size:1.2rem;transition:color var(--transition-speed) ease,transform var(--transition-speed) ease}.projectDetail .projectLinks a:hover{color:var(--link-hover);transform:scale(1.1)}.projectDetail strong{background:#cecece;padding:0 4px;border-radius:8px;color:#000;font-weight:400;font-size:.8rem}.projectDetail .card{border-radius:12px;padding:25px;background-color:var(--background-card);transition:background var(--transition-speed);border:1px solid var(--border-card);margin:25px 0;display:flex;flex-direction:column;color:var(--navbar-primary)}.projectDetail .projectImage{display:flex;justify-content:center;align-items:center;width:100%;max-width:100%;height:auto;border-radius:12px;overflow:hidden;position:relative;box-shadow:0 8px 16px #0000004d,0 4px 8px #0003}.projectDetail .projectImage img{width:100%;height:auto;max-width:100%;transition:box-shadow .2s ease,transform .2s ease}@media only screen and (min-width:768px){.projectDetail .projectImage{width:80%;margin:0 auto}}.projectDetail .projectLinks{display:flex;flex-direction:row;align-items:center;margin-top:25px}.projectDetail .projectLinks a{margin-right:15px;color:var(--text-primary);font-weight:700}.projectDetail .projectLinks a:hover{color:var(--link-hover)}.projectDetail .projectLinks i{margin-right:5px;color:var(--accent);font-weight:400}.projectDetail .projectLinks .comingSoon{position:relative;display:inline-flex;align-items:center;margin-right:15px;margin-top:20px;font-size:1.2rem;color:var(--text-primary);font-weight:700;opacity:.6;cursor:help}.projectDetail .projectLinks .comingSoon .tooltip{position:absolute;visibility:hidden;opacity:0;bottom:135%;left:50%;transform:translate(-50%);white-space:nowrap;background-color:var(--background-card);border:1px solid var(--border-card);color:var(--text-secondary);font-size:.8rem;font-weight:400;padding:4px 8px;border-radius:6px;z-index:1;transition:opacity var(--transition-speed) ease,visibility var(--transition-speed) ease}.projectDetail .projectLinks .comingSoon:hover .tooltip,.projectDetail .projectLinks .comingSoon:focus .tooltip{visibility:visible;opacity:1}.projectDetail .divider{width:100%;height:1px;background-color:var(--text-primary);margin:20px 0}.projectDetail ul,.projectDetail ol{margin:10px 0;padding-left:20px}.projectDetail .btnContainer{display:flex;justify-content:center;margin-top:20px}.projectDetail .btnFilledProject{background:none;border:2px solid var(--text-secondary);color:var(--text-primary);padding:12px 24px;font-size:1rem;border-radius:30px;transition:background-color var(--transition-speed) ease,color var(--transition-speed) ease,transform var(--transition-speed) ease;text-align:center;cursor:pointer}.projectDetail .btnFilledProject:hover{background-color:var(--background-secondary);color:var(--background);transform:scale(1.05)}@media only screen and (max-width:767px){.projectDetail .btnContainer{width:100%}.projectDetail .btnFilledProject{width:100%;padding:14px 28px;font-size:1.2rem}.projectDetail .card{margin-top:50px}}.projectDetail :not(pre)>code{background-color:var(--inline-code-bg);color:var(--inline-code-color);font-family:var(--font-fira-code),Menlo,monospace;padding:.15em .4em;border-radius:4px;font-size:.875em;border:1px solid var(--inline-code-border)}.projectDetail pre.astro-code{margin:1em 0;padding:1em 1.25em;border-radius:8px;overflow-x:auto;font-size:14px;line-height:1.5;border:1px solid var(--code-block-border)}.projectDetail pre.astro-code code{display:grid;counter-reset:step;font-family:var(--font-fira-code),Menlo,monospace}.projectDetail pre.astro-code .line:before{content:counter(step);counter-increment:step;width:1.5rem;margin-right:1.25rem;display:inline-block;text-align:right;color:var(--code-block-line-number);opacity:.6;user-select:none}.projectDetail pre.astro-code{background-color:var(--code-block-bg)!important}[data-theme=dark] .projectDetail pre.astro-code span{color:var(--shiki-dark)!important}
