.blog-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:1.5rem}@media (min-width: 768px){.blog-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 1024px){.blog-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.card-blog-post{display:flex;flex-direction:column;overflow:hidden;border-radius:.5rem;border-width:1px;border-color:var(--color-border);background-color:var(--color-surface);--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.blog-content{display:flex;height:100%;flex-direction:column;padding:1.5rem}.blog-post-title{margin-bottom:.75rem;font-size:1.25rem;line-height:1.75rem;font-weight:700;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;color:var(--color-text)}.blog-post-summary{margin-bottom:1rem;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;flex:1 1 0%;color:var(--color-text-muted)}.blog-tags-container{margin-bottom:1rem;display:flex;flex-wrap:wrap;gap:.5rem}.blog-post-meta{margin-bottom:1rem;display:flex;justify-content:space-between;font-size:.875rem;line-height:1.25rem;color:var(--color-text-muted)}.blog-read-more{margin-top:auto;display:flex;width:100%;align-items:center;justify-content:center}.blog-image-placeholder{display:flex;height:12rem;align-items:center;justify-content:center;background-color:var(--color-surface-alt, rgb(var(--color-surface-rgb, 240, 240, 240)/.5));color:var(--color-text-muted)}.blog-image{height:100%;width:100%;-o-object-fit:cover;object-fit:cover}.blog-unified-tags{margin-bottom:.75rem;display:flex;flex-wrap:wrap;gap:.5rem}.badge-category-inline{border-radius:9999px;padding:.25rem .75rem;font-size:.875rem;line-height:1.25rem;font-weight:600;background-color:var(--color-primary);color:var(--color-background, #ffffff)}.badge-tag-inline{cursor:pointer;border-radius:9999px;padding:.25rem .5rem;font-size:.75rem;line-height:1rem;font-weight:500;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;background-color:var(--color-surface-alt, rgb(var(--color-surface-rgb, 240, 240, 240)/.1));color:var(--color-primary);border:1px solid var(--color-border)}.badge-tag-inline:hover{background-color:var(--color-surface-hover, rgb(var(--color-surface-rgb, 240, 240, 240)/.2))}.heading-section{margin-bottom:1.5rem;font-size:1.5rem;line-height:2rem;font-weight:700;color:var(--color-text)}.heading-article{margin-bottom:.75rem;font-size:1.875rem;line-height:2.25rem;font-weight:700}@media (min-width: 768px){.heading-article{font-size:2.25rem;line-height:2.5rem}}.heading-article{color:var(--color-text)}.text-description{margin-left:auto;margin-right:auto;max-width:42rem;text-align:center;line-height:1.625;color:var(--color-text-muted)}.text-meta{font-size:.875rem;line-height:1.25rem;color:var(--color-text-muted)}.article-header{border-bottom-width:1px;padding:2rem;border-color:var(--color-border)}.article-content{padding:2rem}.btn-report-issue{display:inline-flex;align-items:center;gap:.5rem;border-radius:.375rem;padding:.375rem .75rem;font-size:.875rem;line-height:1.25rem;font-weight:500;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;background-color:var(--color-surface-alt, rgb(var(--color-surface-rgb, 240, 240, 240)/.8));color:var(--color-text-muted);border:1px solid var(--color-border)}.btn-report-issue:hover{background-color:var(--color-surface-hover);color:var(--color-text)}.related-posts-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:1.5rem}@media (min-width: 768px){.related-posts-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 1024px){.related-posts-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.prose,.prose h1,.prose h2,.prose h3,.prose h4,.prose h5,.prose h6{color:var(--color-text)}.prose p{color:var(--color-text-muted)}.prose code{background-color:var(--color-surface-alt);color:var(--color-primary);padding:.125rem .25rem;border-radius:.25rem}.prose pre{background-color:var(--color-surface-alt);border:1px solid var(--color-border)}.prose pre code{background-color:transparent;color:var(--color-text)}.prose blockquote{border-left-color:var(--color-primary);color:var(--color-text-muted);background-color:var(--color-surface-alt, rgb(var(--color-surface-rgb, 240, 240, 240)/.5));padding:1rem;border-radius:.5rem}.prose ul,.prose ol{color:var(--color-text-muted)}.prose a{color:var(--color-primary)}.prose a:hover,.blog-post-title:hover{color:var(--color-accent, var(--color-primary))}.loading-container{display:flex;align-items:center;justify-content:center;padding-top:4rem;padding-bottom:4rem}.loading-spinner{display:flex;flex-direction:column;align-items:center;gap:1rem}.loading-circle{height:2rem;width:2rem}@keyframes spin{to{transform:rotate(360deg)}}.loading-circle{animation:spin 1s linear infinite;border-radius:9999px;border-width:2px;border-top-color:transparent;border-color:var(--color-primary)}.loading-text{color:var(--color-text-muted)}.empty-state{padding-top:4rem;padding-bottom:4rem;text-align:center;color:var(--color-text-muted)}.error-text{border-radius:.5rem;padding:2rem 1rem;text-align:center;background-color:var(--color-surface-alt, rgb(var(--color-surface-rgb, 240, 240, 240)/.5));color:var(--color-text);border:1px solid var(--color-border)}.btn-primary{border-radius:.375rem;background-color:var(--color-primary);padding:.75rem 1.5rem;font-weight:500;--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1));transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.btn-primary:hover{background-color:var(--color-accent)}.btn-secondary{border-radius:.375rem;border-width:1px;border-color:var(--color-primary);padding:.75rem 1.5rem;color:var(--color-primary);transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.btn-secondary:hover{background-color:rgb(var(--color-primary-rgb)/.1)}.btn-back{display:inline-flex;align-items:center;font-weight:500;color:var(--color-primary);transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.btn-back:hover{color:var(--color-accent)}.btn-tag{cursor:pointer;border-radius:9999px;padding:.25rem .75rem;font-size:.875rem;line-height:1.25rem;font-weight:500;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.btn-tag-active{background-color:var(--color-primary);--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.btn-tag-inactive{border-width:1px;border-color:var(--color-border);background-color:var(--color-surface);color:var(--color-text-muted)}.btn-tag-inactive:hover{background-color:rgb(var(--color-primary-rgb)/.1)}.btn-github-large{display:flex;align-items:center;gap:.5rem;border-radius:.375rem;background-color:var(--color-text);padding:.75rem 1.5rem;font-weight:500;color:var(--color-background);transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.btn-github-large:hover{opacity:.8}.btn-demo-large{display:flex;align-items:center;gap:.5rem;border-radius:.375rem;background-color:var(--color-primary);padding:.75rem 1.5rem;font-weight:500;--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1));transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.scroll-to-top-button{position:fixed;bottom:2rem;right:2rem;z-index:30;border-radius:9999px;background-color:var(--color-primary);padding:.75rem;--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1));--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.scroll-to-top-button:hover{background-color:var(--color-accent)}.home-button-container{position:fixed;bottom:2rem;right:2rem;z-index:50}.home-button-link{display:flex;align-items:center;justify-content:center;border-radius:9999px;background-color:var(--color-primary);padding:.75rem;--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1));--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.home-button-link:hover{background-color:var(--color-accent)}.dark-mode-toggle{position:relative;display:flex;height:1.5rem;width:3rem;cursor:pointer;align-items:center;border-radius:9999px;--tw-bg-opacity: 1;background-color:rgb(242 241 236 / var(--tw-bg-opacity, 1));padding:.25rem;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.dark-mode-toggle:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))}.dark-mode-toggle-slider{position:absolute;display:flex;height:1.25rem;width:1.25rem;align-items:center;justify-content:center;border-radius:9999px}.page-container{min-height:100vh;padding-top:6rem;padding-bottom:4rem;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;background-color:var(--color-background);color:var(--color-text)}.content-container{width:100%}@media (min-width: 640px){.content-container{max-width:640px}}@media (min-width: 768px){.content-container{max-width:768px}}@media (min-width: 1024px){.content-container{max-width:1024px}}@media (min-width: 1280px){.content-container{max-width:1280px}}@media (min-width: 1536px){.content-container{max-width:1536px}}.content-container{margin-left:auto;margin-right:auto;padding:2rem 1rem}.content-container-narrow{margin-left:auto;margin-right:auto;max-width:56rem;padding:2rem 1rem}.content-container-wide{margin-left:auto;margin-right:auto;max-width:80rem;padding:2rem 1rem}.card-base{border-radius:.5rem;--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;background-color:var(--color-surface);border:1px solid var(--color-border)}.card-elevated{border-radius:.5rem;--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;background-color:var(--color-surface);border:1px solid var(--color-border)}.card-elevated:hover{background-color:var(--color-surface-hover)}.card-contact{display:flex;align-items:center;gap:1rem;border-radius:.5rem;padding:1.5rem;--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.card-contact:hover{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.card-contact{background-color:var(--color-surface);border:1px solid var(--color-border)}.card-about{border-radius:.5rem;padding:1.5rem;--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;background-color:var(--color-surface);border:1px solid var(--color-border)}.card-project{overflow:hidden;border-radius:.5rem;border-width:1px;border-color:var(--color-border);background-color:var(--color-surface);--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.card-project:hover{--tw-translate-y: -.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.badge-category{display:inline-block;border-radius:9999px;padding:.25rem .75rem;font-size:.875rem;line-height:1.25rem;font-weight:500;background-color:var(--color-accent);color:var(--color-text-inverse)}.badge-tag{display:inline-block;border-radius:.25rem;padding:.25rem .5rem;font-size:.875rem;line-height:1.25rem;background-color:rgb(var(--color-surface-rgb)/.8);color:var(--color-text-muted);border:1px solid var(--color-border)}.badge-tag-link{display:inline-block;cursor:pointer;border-radius:.25rem;padding:.25rem .5rem;font-size:.875rem;line-height:1.25rem;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;background-color:rgb(var(--color-surface-rgb)/.8);color:var(--color-text-muted)}.badge-tag-link:hover{background-color:var(--color-primary);color:var(--color-text-inverse)}.badge-tech{border-radius:9999px;padding:.25rem .75rem;font-size:.875rem;line-height:1.25rem;font-weight:500;background-color:rgb(var(--color-primary-rgb)/.1);color:var(--color-primary);border:1px solid var(--color-border)}.badge-tech-large{border-radius:9999px;padding:.5rem 1rem;font-weight:500;background-color:rgb(var(--color-primary-rgb)/.1);color:var(--color-primary);border:1px solid var(--color-border)}.icon-container{display:flex;height:3rem;width:3rem;align-items:center;justify-content:center;border-radius:.5rem;background-color:var(--color-primary);color:var(--color-text-inverse)}.filter-container{margin-bottom:2rem;display:flex;flex-wrap:wrap;gap:1rem}.modal-header{display:flex;justify-content:flex-end;padding:1rem;border-bottom:1px solid var(--color-border)}.modal-title{margin-bottom:1rem;font-size:1.5rem;line-height:2rem;font-weight:700;color:var(--color-text)}.modal-image-container{margin-bottom:1.5rem;overflow:hidden;border-radius:.5rem}.modal-image{height:16rem;width:100%;-o-object-fit:cover;object-fit:cover}.feature-list>:not([hidden])~:not([hidden]),.challenge-list>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.feature-item,.challenge-item{display:flex;align-items:flex-start;gap:.5rem;color:var(--color-text-muted)}.feature-item:before,.challenge-item:before{margin-top:.25rem;font-weight:700;content:"•";color:var(--color-primary)}.screenshot-image{height:12rem;width:100%;border-radius:.5rem;-o-object-fit:cover;object-fit:cover;border:1px solid var(--color-border)}.modal-actions{display:flex;gap:1rem;padding-top:1rem;border-top:1px solid var(--color-border)}.metadata-item{display:flex;flex-direction:column}.metadata-label{margin-bottom:.25rem;font-size:.875rem;line-height:1.25rem;font-weight:500;color:var(--color-text-muted)}.metadata-value{font-weight:600;color:var(--color-text)}.contact-info>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.contact-item-title{margin-bottom:.25rem;font-size:1.125rem;line-height:1.75rem;font-weight:600;color:var(--color-text)}.contact-item-text{color:var(--color-text-muted)}.error-page-content{display:flex;min-height:60vh;flex-direction:column;align-items:center;justify-content:center;padding-left:1rem;padding-right:1rem;text-align:center}.error-icon-container{margin-bottom:1.5rem;color:var(--color-primary)}.error-icon{height:4rem;width:4rem}.error-description{margin-bottom:2rem;max-width:32rem;text-align:center;color:var(--color-text-muted)}.error-debug-container{margin-bottom:2rem;width:100%;max-width:42rem;overflow:auto;border-radius:.375rem;border-width:1px;--tw-border-opacity: 1;border-color:rgb(254 202 202 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(254 242 242 / var(--tw-bg-opacity, 1));padding:1rem}.error-debug-container:is(.dark *){--tw-border-opacity: 1;border-color:rgb(153 27 27 / var(--tw-border-opacity, 1));background-color:#7f1d1d33}.error-debug-text{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.875rem;line-height:1.25rem;--tw-text-opacity: 1;color:rgb(153 27 27 / var(--tw-text-opacity, 1))}.error-debug-text:is(.dark *){--tw-text-opacity: 1;color:rgb(248 113 113 / var(--tw-text-opacity, 1))}.error-actions{display:flex;flex-direction:column;gap:1rem}@media (min-width: 640px){.error-actions{flex-direction:row}}.not-found-code{font-size:8rem;line-height:1;font-weight:700;color:rgb(var(--color-text-rgb)/.1)}.heading-page{margin-bottom:2rem;text-align:center;font-size:1.875rem;line-height:2.25rem;font-weight:700;color:var(--color-text);transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.hero-section{position:relative;display:flex;height:100vh;flex-direction:column;justify-content:space-between;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;background-color:var(--color-background)}.hero-content{width:100%}@media (min-width: 640px){.hero-content{max-width:640px}}@media (min-width: 768px){.hero-content{max-width:768px}}@media (min-width: 1024px){.hero-content{max-width:1024px}}@media (min-width: 1280px){.hero-content{max-width:1280px}}@media (min-width: 1536px){.hero-content{max-width:1536px}}.hero-content{margin-left:auto;margin-right:auto;display:flex;flex-grow:1;align-items:flex-start;padding:2rem 1rem 4rem}@media (min-width: 768px){.hero-content{align-items:center;padding-top:3rem;padding-bottom:3rem}}.hero-layout{display:flex;width:100%;flex-direction:column;align-items:center}@media (min-width: 768px){.hero-layout{flex-direction:row}}.hero-image-container{order:1;margin-bottom:2rem;display:flex;width:100%;justify-content:center}@media (min-width: 768px){.hero-image-container{order:2;margin-bottom:0;width:50%}}.hero-text-container{order:2;width:100%;text-align:center}@media (min-width: 768px){.hero-text-container{order:1;width:50%;padding-right:2rem;text-align:left}}.hero-title{margin-bottom:1.5rem;font-size:2.25rem;line-height:2.5rem;font-weight:700;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}@media (min-width: 768px){.hero-title{font-size:3rem;line-height:1}}@media (min-width: 1024px){.hero-title{font-size:3.75rem;line-height:1}}.hero-title{color:var(--color-text)}.hero-profile-image{display:flex;align-items:center;justify-content:center;--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.hero-profile-image:hover{--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hero-profile-image{width:12rem;height:12rem;border-radius:9999px;overflow:hidden;aspect-ratio:1 / 1;background:linear-gradient(135deg,var(--color-primary),var(--color-accent))}@media (min-width: 768px){.hero-profile-image{width:20rem;height:20rem}}.hero-profile-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;-o-object-position:center;object-position:center;display:block}.hero-description{font-size:1.125rem;line-height:1.75rem;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;color:var(--color-text-muted)}.hero-scroll-container{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:center;padding-bottom:6rem}@media (min-width: 640px){.hero-scroll-container{padding-bottom:5rem}}@media (min-width: 768px){.hero-scroll-container{padding-bottom:4rem}}.hero-scroll-button-wrapper{display:flex;flex-direction:column;align-items:center}.hero-scroll-text{margin-bottom:.5rem;font-size:.875rem;line-height:1.25rem;font-weight:500;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;color:var(--color-text-muted)}.hero-scroll-button{border-radius:9999px;padding:.5rem;--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.hero-scroll-button:hover{--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hero-scroll-button{color:var(--color-primary);background-color:var(--color-surface);border:1px solid var(--color-border)}.hero-scroll-button:hover{color:var(--color-primary-hover);background-color:var(--color-surface-hover);border-color:var(--color-primary)}.about-section{padding-top:6rem;padding-bottom:6rem;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;background:linear-gradient(180deg,var(--color-background),var(--color-background-alt))}.about-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));align-items:stretch;gap:2rem}@media (min-width: 768px){.about-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.about-content-section>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(2rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2rem * var(--tw-space-y-reverse))}.about-section-title{margin-bottom:1rem;font-size:1.25rem;line-height:1.75rem;font-weight:700;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;color:var(--color-text)}.about-section-text{line-height:1.625;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;color:var(--color-text-muted)}.skills-section{display:flex;flex-direction:column;align-items:center}.skills-title{margin-bottom:2rem;text-align:center;font-size:1.25rem;line-height:1.75rem;font-weight:700;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;color:var(--color-text)}.timeline-section{padding-top:6rem;padding-bottom:6rem;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;background-color:var(--color-background)}.home-section-header{margin-bottom:4rem;text-align:center}.home-section-title{font-size:2.25rem;line-height:2.5rem;font-weight:700;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;color:var(--color-text)}.home-section-accent{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;color:var(--color-primary)}.home-section-divider{margin-left:auto;margin-right:auto;margin-top:1rem;height:.25rem;width:5rem;background:linear-gradient(90deg,var(--color-primary),var(--color-accent))}.home-story-title{margin-bottom:1.5rem;display:flex;align-items:center;font-size:1.5rem;line-height:2rem;font-weight:600;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;color:var(--color-text)}.home-story-accent-bar{margin-right:.75rem;display:inline-block;height:2rem;width:.75rem;border-radius:.125rem;background-color:var(--color-primary)}.home-story-divider{height:.25rem;width:2rem;border-radius:9999px;background:linear-gradient(90deg,var(--color-primary),var(--color-accent))}.home-story-content>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.home-story-content{text-align:center;line-height:1.625;color:var(--color-text-muted)}.home-story-content p{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.home-story-content>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.home-story-content{text-align:justify;line-height:1.625;color:var(--color-text-muted)}.home-skills-title{margin-bottom:1.5rem;display:flex;align-items:center;font-size:1.5rem;line-height:2rem;font-weight:600;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;color:var(--color-text)}.home-timeline-title{margin-bottom:3rem;text-align:center;font-size:1.875rem;line-height:2.25rem;font-weight:700;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;color:var(--color-text)}.home-timeline-container{margin-left:auto;margin-right:auto;max-width:64rem;padding-top:2rem;padding-bottom:2rem}.language-switcher-container{position:relative}.language-switcher-mobile{margin-top:1rem;width:100%}.language-switcher-mobile-wrapper{width:100%}.language-switcher-compact-button{border-radius:9999px;--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1));padding:.5rem;--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.language-switcher-compact-button:hover{--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}.language-switcher-compact-button:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(209 213 219 / var(--tw-text-opacity, 1))}.language-switcher-compact-button:hover:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(75 85 99 / var(--tw-bg-opacity, 1))}.language-switcher-compact-content{display:flex;align-items:center}.language-switcher-mobile-button{display:flex;width:100%;align-items:center;justify-content:space-between;border-radius:.5rem;border-width:1px;--tw-border-opacity: 1;border-color:rgb(209 213 219 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));padding:.5rem 1rem;--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.language-switcher-mobile-button:is(.dark *){--tw-border-opacity: 1;border-color:rgb(75 85 99 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(209 213 219 / var(--tw-text-opacity, 1))}.language-switcher-mobile-content,.language-switcher-desktop-button{display:flex;align-items:center}.language-switcher-desktop-button>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.25rem * var(--tw-space-x-reverse));margin-left:calc(.25rem * calc(1 - var(--tw-space-x-reverse)))}.language-switcher-desktop-button{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1));transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.language-switcher-desktop-button:hover{--tw-text-opacity: 1;color:rgb(65 193 186 / var(--tw-text-opacity, 1))}.language-switcher-desktop-button:is(.dark *){--tw-text-opacity: 1;color:rgb(209 213 219 / var(--tw-text-opacity, 1))}.language-switcher-desktop-button:hover:is(.dark *){--tw-text-opacity: 1;color:rgb(65 193 186 / var(--tw-text-opacity, 1))}.language-switcher-icon{height:1.25rem;width:1.25rem}.language-switcher-icon-mobile{margin-right:.5rem;height:1.25rem;width:1.25rem}.language-switcher-label{font-size:.875rem;line-height:1.25rem;font-weight:500}.language-switcher-chevron{height:1rem;width:1rem;transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.language-switcher-chevron-open{--tw-rotate: 180deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.language-switcher-dropdown-compact{position:absolute;right:0;bottom:3rem;z-index:10;width:10rem;border-radius:.375rem;--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000);--tw-ring-color: rgb(0 0 0 / var(--tw-ring-opacity, 1));--tw-ring-opacity: .05}.language-switcher-dropdown-compact:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity, 1))}.language-switcher-dropdown-mobile{z-index:10;margin-top:.5rem;width:100%;border-radius:.375rem;--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000);--tw-ring-color: rgb(0 0 0 / var(--tw-ring-opacity, 1));--tw-ring-opacity: .05}.language-switcher-dropdown-mobile:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity, 1))}.language-switcher-dropdown-desktop{position:absolute;right:0;top:2rem;z-index:10;width:10rem;border-radius:.375rem;--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000);--tw-ring-color: rgb(0 0 0 / var(--tw-ring-opacity, 1));--tw-ring-opacity: .05}.language-switcher-dropdown-desktop:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity, 1))}.language-switcher-menu{padding-top:.25rem;padding-bottom:.25rem}.language-switcher-option{display:flex;width:100%;align-items:center;padding:.5rem 1rem;font-size:.875rem;line-height:1.25rem;--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.language-switcher-option:hover{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.language-switcher-option:is(.dark *){--tw-text-opacity: 1;color:rgb(209 213 219 / var(--tw-text-opacity, 1))}.language-switcher-option:hover:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))}.language-switcher-option-active{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(65 193 186 / var(--tw-text-opacity, 1))}.language-switcher-option-active:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(65 193 186 / var(--tw-text-opacity, 1))}.layout-container{display:flex;min-height:100vh;flex-direction:column;background-color:var(--color-background);color:var(--color-text)}.layout-main{flex:1 1 0%;padding-top:4rem}.header-container{position:fixed;top:0;left:0;right:0;z-index:50;padding-top:1rem;padding-bottom:1rem;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;background-color:var(--color-surface);border-bottom:1px solid var(--color-border)}.header-scrolled{box-shadow:0 2px 10px #0000001a}.header-transparent{border-color:transparent;background-color:transparent;--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.header-content{width:100%}@media (min-width: 640px){.header-content{max-width:640px}}@media (min-width: 768px){.header-content{max-width:768px}}@media (min-width: 1024px){.header-content{max-width:1024px}}@media (min-width: 1280px){.header-content{max-width:1280px}}@media (min-width: 1536px){.header-content{max-width:1536px}}.header-content{margin-left:auto;margin-right:auto;padding-left:1rem;padding-right:1rem}.header-layout{display:flex;align-items:center;justify-content:space-between}.header-brand{display:flex;flex-direction:column}.header-brand-name{font-size:1.875rem;line-height:2.25rem;font-weight:700;line-height:1.25;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;color:var(--color-text)}.header-brand-role{font-size:1.25rem;line-height:1.75rem;line-height:1.25;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;color:var(--color-text-muted)}.header-desktop-controls{display:none;align-items:center}.header-desktop-controls>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(1.5rem * var(--tw-space-x-reverse));margin-left:calc(1.5rem * calc(1 - var(--tw-space-x-reverse)))}@media (min-width: 768px){.header-desktop-controls{display:flex}}.header-mobile-button{border-radius:.5rem;padding:.5rem;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}@media (min-width: 768px){.header-mobile-button{display:none}}.header-mobile-button{color:var(--color-text);background-color:transparent}.header-mobile-button:hover{background-color:var(--color-surface-hover)}.nav-container{display:none;align-items:center}.nav-container>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(1.5rem * var(--tw-space-x-reverse));margin-left:calc(1.5rem * calc(1 - var(--tw-space-x-reverse)))}@media (min-width: 768px){.nav-container{display:flex}}.nav-link{position:relative;font-weight:500;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;color:var(--color-text-muted)}.nav-link:hover,.nav-link-active{color:var(--color-primary)}.nav-underline{position:absolute;bottom:-.25rem;left:0;right:0;height:.125rem;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;background-color:var(--color-primary)}.mobile-menu-container{position:absolute;top:100%;left:0;right:0;z-index:50;display:flex;flex-direction:column;overflow:hidden;--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}@media (min-width: 768px){.mobile-menu-container{display:none}}.mobile-menu-container{background-color:var(--color-surface)}.mobile-menu-nav{display:flex;flex-direction:column;padding:.5rem 1rem}.mobile-menu-link{display:block;border-bottom-width:1px;padding:.5rem;font-size:1rem;line-height:1.5rem;font-weight:500;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.mobile-menu-link:last-child{border-style:none}.mobile-menu-link{border-color:var(--color-border)}.mobile-menu-link-active{color:var(--color-primary)}.mobile-menu-link-inactive{color:var(--color-text-muted)}.mobile-menu-link-inactive:hover{color:var(--color-primary)}.mobile-menu-controls{margin-top:.25rem;border-top-width:1px;padding:.75rem;border-color:var(--color-border)}.mobile-menu-controls-layout{display:flex;align-items:center;justify-content:center;gap:1.5rem}.footer-container{border-top-width:1px;padding-top:2rem;padding-bottom:2rem;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;background-color:var(--color-surface);border-color:var(--color-border)}.footer-content{width:100%}@media (min-width: 640px){.footer-content{max-width:640px}}@media (min-width: 768px){.footer-content{max-width:768px}}@media (min-width: 1024px){.footer-content{max-width:1024px}}@media (min-width: 1280px){.footer-content{max-width:1280px}}@media (min-width: 1536px){.footer-content{max-width:1536px}}.footer-content{margin-left:auto;margin-right:auto;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding-left:1rem;padding-right:1rem}@media (min-width: 768px){.footer-content{flex-direction:row}}.footer-copyright{margin-bottom:1rem;font-size:.875rem;line-height:1.25rem;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}@media (min-width: 768px){.footer-copyright{margin-bottom:0}}.footer-copyright{color:var(--color-text-muted)}.footer-social-links{display:flex;justify-content:center}.footer-social-links>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(1rem * var(--tw-space-x-reverse));margin-left:calc(1rem * calc(1 - var(--tw-space-x-reverse)))}.footer-social-link{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;color:var(--color-text-muted)}.footer-social-link:hover{color:var(--color-primary)}.project-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:1.5rem}@media (min-width: 768px){.project-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 1024px){.project-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.project-content{padding:1.5rem}.project-title{margin-bottom:.5rem;font-size:1.25rem;line-height:1.75rem;font-weight:700;color:var(--color-text);transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.project-description{margin-bottom:1rem;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;color:var(--color-text-muted);transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.project-tech-grid{margin-bottom:1rem;display:flex;flex-wrap:wrap;gap:.5rem}.project-links{display:flex;justify-content:space-between}.project-metadata{margin-bottom:1.5rem;display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:1rem;border-radius:.5rem;border-width:1px;border-color:var(--color-border);background-color:rgb(var(--color-surface-rgb)/.5);padding:1rem}@media (min-width: 768px){.project-metadata{grid-template-columns:repeat(3,minmax(0,1fr))}}.project-image-container{height:12rem;overflow:hidden;background-color:rgb(var(--color-surface-rgb)/.5);transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.project-image{height:100%;width:100%;-o-object-fit:cover;object-fit:cover}.project-image-placeholder{display:flex;height:100%;width:100%;align-items:center;justify-content:center;font-weight:600;color:var(--color-text-muted);transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.link-demo{display:flex;align-items:center;gap:.5rem;border-radius:.375rem;background-color:var(--color-primary);padding:.5rem 1rem;font-weight:500;--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1));transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.link-demo:hover{background-color:var(--color-accent)}.link-github{display:flex;align-items:center;gap:.375rem;border-radius:.375rem;border-width:1px;border-color:var(--color-border);padding:.5rem 1rem;font-weight:500;color:var(--color-text);transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.link-github:hover{border-color:var(--color-primary);color:var(--color-primary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;overflow-y:auto;background-color:#00000080;padding:1rem;--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.modal-content{max-height:90vh;width:100%;max-width:56rem;overflow-y:auto;border-radius:.75rem;border-width:1px;border-color:var(--color-border);background-color:var(--color-surface);--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.modal-header{position:sticky;top:0;z-index:10;display:flex;justify-content:flex-end;border-bottom-width:1px;border-color:var(--color-border);background-color:var(--color-surface);padding:1rem}.modal-body{padding:1.5rem}.modal-title{margin-bottom:.5rem;font-size:1.5rem;line-height:2rem;font-weight:700;color:var(--color-text)}.modal-image-container{margin-bottom:1.5rem}.modal-image{width:100%;border-radius:.5rem;--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.modal-section{margin-bottom:1.5rem}.section-title{margin-bottom:.75rem;font-size:1.125rem;line-height:1.75rem;font-weight:600;color:var(--color-text)}.section-content{line-height:1.625;color:var(--color-text-muted)}.modal-actions{margin-top:1.5rem;display:flex;gap:1rem}.btn-close{border-radius:9999px;padding:.5rem;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.btn-close:hover{background-color:rgb(var(--color-surface-rgb)/.8)}.btn-github-large{display:flex;align-items:center;gap:.5rem;border-radius:.5rem;--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity, 1));padding:.75rem 1.5rem;font-weight:500;--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1));transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.btn-github-large:hover{--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))}.btn-github-large:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))}.btn-github-large:hover:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(75 85 99 / var(--tw-bg-opacity, 1))}.btn-demo-large{display:flex;align-items:center;gap:.5rem;border-radius:.5rem;background-color:var(--color-primary);padding:.75rem 1.5rem;font-weight:500;--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1));transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.btn-demo-large:hover{background-color:var(--color-accent)}.feature-list{list-style-type:disc}.feature-list>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.feature-list{padding-left:1.5rem}.feature-item{color:var(--color-text-muted)}.challenge-list{list-style-type:disc}.challenge-list>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.challenge-list{padding-left:1.5rem}.challenge-item{color:var(--color-text-muted)}.screenshot-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:1rem}@media (min-width: 768px){.screenshot-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.screenshot-image{width:100%;border-radius:.5rem;--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.screenshot-image:hover{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.metadata-item{font-size:.875rem;line-height:1.25rem;color:var(--color-text-muted)}.metadata-label{font-weight:500}.metadata-value{margin-left:.25rem;color:var(--color-text)}.skill-bubbles-container{position:relative;height:20rem;width:100%;overflow:hidden;border-radius:.5rem;background:linear-gradient(135deg,rgb(var(--color-background-rgb) / .8),rgb(var(--color-surface-rgb) / .9))}.category-center{position:absolute;z-index:10;display:flex;align-items:center;justify-content:center;border-radius:9999px;border-width:2px;font-weight:600;--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1));--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transform:translate(-50%,-50%);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--color-text-inverse);border-color:#ffffff4d;box-shadow:0 4px 15px rgba(var(--color-primary-rgb),.3);font-size:1rem;letter-spacing:.5px;text-shadow:0 1px 3px rgba(0,0,0,.5)}.category-group{position:absolute;width:0;height:0}.category-technical{background:var(--color-primary);box-shadow:0 4px 15px rgba(var(--color-primary-rgb),.3)}.category-creative{background:var(--color-accent);box-shadow:0 4px 15px rgba(var(--color-accent-rgb),.3)}.category-research{background:var(--color-secondary);box-shadow:0 4px 15px rgba(var(--color-secondary-rgb),.3)}.skill-bubble{position:absolute;display:flex;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;align-items:center;justify-content:center;border-radius:9999px;font-weight:500;--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transform:translate(-50%,-50%);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.3);transition:all .3s ease;color:var(--color-text-inverse);box-shadow:0 3px 10px #0003,0 0 5px #0000001a;text-shadow:0 1px 3px rgba(0,0,0,.5);overflow:hidden;padding:4px}:root:not([data-theme=dark]) .skill-bubble{text-shadow:0 1px 2px rgba(0,0,0,.7);color:#fff}[data-theme=dark] .skill-bubble{text-shadow:0 1px 3px rgba(0,0,0,.8);color:#fff}.skill-bubble:hover{transform:translate(-50%,-50%) scale(1.15);box-shadow:0 6px 20px #0000004d,0 0 10px #0003;z-index:100!important;border:1px solid rgba(255,255,255,.5)}.skill-bubble-text{padding-left:.5rem;padding-right:.5rem;text-align:center;font-weight:500;text-shadow:inherit;font-size:inherit;letter-spacing:.2px;display:flex;align-items:center;justify-content:center;width:100%;height:100%;line-height:1.05;word-break:normal;overflow-wrap:break-word;white-space:normal;-webkit-hyphens:none;hyphens:none}@media (max-width: 768px){.skill-bubbles-container{height:16rem}.category-center{font-size:.75rem;line-height:1rem;letter-spacing:.3px}.skill-bubble-text{font-size:.75rem;line-height:1rem;letter-spacing:.2px}}.timeline-container{width:100%;max-width:100%;overflow:visible;padding:0 8px}.timeline-card-hover-container{margin:4px}.timeline-wrapper{position:relative;margin-left:auto;margin-right:auto;width:100%;overflow:visible;padding:0 8px}.timeline-content{position:relative;width:100%;overflow:visible;padding:0 8px}.timeline-empty-state{padding-top:2.5rem;padding-bottom:2.5rem;text-align:center;font-style:italic;--tw-text-opacity: 1;color:rgb(54 91 109 / var(--tw-text-opacity, 1))}.timeline-empty-state:is(.dark *){--tw-text-opacity: 1;color:rgb(65 193 186 / var(--tw-text-opacity, 1))}.timeline-center-line-bg{position:absolute;left:50%;z-index:0;height:100%;--tw-translate-x: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.timeline-line-background{position:absolute;left:0;height:100%;width:.125rem;--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1));--tw-shadow: 0 0 8px rgba(0,0,0,.05);--tw-shadow-colored: 0 0 8px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.timeline-line-background:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1));--tw-shadow: 0 0 8px rgba(255,255,255,.03);--tw-shadow-colored: 0 0 8px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.timeline-line-gradient{position:absolute;left:0;height:100%;width:.125rem;background-image:linear-gradient(to bottom,var(--tw-gradient-stops));--tw-gradient-from: #41c1ba var(--tw-gradient-from-position);--tw-gradient-to: rgb(65 193 186 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);--tw-gradient-to: rgb(96 165 250 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), #60a5fa var(--tw-gradient-via-position), var(--tw-gradient-to);--tw-gradient-to: #365b6d var(--tw-gradient-to-position);--tw-shadow: 0 0 15px rgba(45,212,191,.5);--tw-shadow-colored: 0 0 15px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.timeline-line-gradient:is(.dark *){--tw-shadow: 0 0 15px rgba(20,184,166,.5);--tw-shadow-colored: 0 0 15px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.timeline-mobile-line{position:absolute;left:1.5rem;top:0;bottom:0;z-index:10;width:.125rem;--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}.timeline-mobile-line:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))}.timeline-mobile-line{display:none}@media (max-width: 768px){.timeline-mobile-line{display:block}.timeline-center-line-bg{display:none}}.timeline-year-desktop{position:absolute;left:50%;z-index:30;--tw-translate-x: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.timeline-year-circle{position:relative;z-index:30;display:flex;height:3.5rem;width:3.5rem;align-items:center;justify-content:center;border-radius:9999px;border-width:4px;--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;background-color:var(--color-year-circle-bg);border-color:var(--color-year-circle-border);box-shadow:0 4px 12px #00000026,inset 0 1px #ffffff1a}.timeline-year-circle-active{background-color:var(--color-year-circle-bg-active);border-color:var(--color-year-circle-border-active);box-shadow:0 0 20px rgba(var(--color-primary-rgb),.4),0 4px 12px #00000026;transform:scale(1.1)}.timeline-year-text{font-size:.875rem;line-height:1.25rem;font-weight:700;color:var(--color-year-circle-text);text-shadow:0 1px 2px rgba(0,0,0,.3)}.timeline-year-circle-active .timeline-year-text{color:var(--color-year-circle-text-active);text-shadow:0 1px 2px rgba(0,0,0,.5)}.timeline-year-mobile{position:relative;z-index:20;display:none}.timeline-mobile-year-marker{display:flex;height:2.5rem;width:2.5rem;align-items:center;justify-content:center;border-radius:9999px;border-width:4px;--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);background-color:var(--color-year-circle-bg-active);border-color:var(--color-surface);margin-left:-20px;margin-top:5px}.timeline-mobile-year-text{font-size:.75rem;line-height:1rem;font-weight:700;color:var(--color-year-circle-text-active);text-shadow:0 1px 2px rgba(0,0,0,.3)}@media (max-width: 768px){.timeline-year-mobile{display:block}.timeline-year-desktop{display:none}}.timeline-category-icon{height:1rem;width:1rem;flex-shrink:0;display:inline-block;vertical-align:middle}.timeline-mobile-category .timeline-category-icon,.timeline-desktop-category .timeline-category-icon{margin-right:.375rem;height:1rem;width:1rem;display:inline-flex;align-items:center;vertical-align:middle}.timeline-mobile-category,.timeline-desktop-category{display:flex;align-items:center}.timeline-mobile-category-text,.timeline-desktop-category-text{margin-left:.375rem;display:flex;align-items:center;text-transform:capitalize}.timeline-item-wrapper{position:relative;margin-bottom:1.5rem;width:100%}.timeline-item-left{left:0}.timeline-item-right{right:0}@media (min-width: 768px){.timeline-item-wrapper{position:absolute;min-height:auto}}@media (max-width: 768px){.timeline-item-wrapper{position:static;min-height:auto}}.timeline-item-mobile{position:relative;z-index:20;margin-bottom:1rem;display:block;width:100%}@media (min-width: 768px){.timeline-item-mobile{display:none}}.timeline-item-mobile-content{position:relative;margin-left:1.5rem;padding-left:2rem}.timeline-mobile-connector{position:absolute;left:0;top:0;bottom:0;width:.125rem;--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}.timeline-mobile-connector:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))}.timeline-mobile-card{cursor:pointer;border-radius:.5rem;border-width:1px;--tw-border-opacity: 1;border-color:rgb(243 244 246 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));padding:1rem;--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.timeline-mobile-card:is(.dark *){--tw-border-opacity: 1;border-color:rgb(55 65 81 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity, 1))}.timeline-mobile-card{flex-direction:column;min-height:150px;max-height:200px;position:relative;z-index:15;overflow:hidden;width:100%;display:flex}.timeline-mobile-card-content{display:flex;height:100%;flex:1 1 0%;flex-direction:column;justify-content:space-between;overflow-y:auto}@media (max-width: 768px){.timeline-item-wrapper{margin-bottom:20px!important;position:relative!important;height:auto!important;top:auto!important;display:block!important}.timeline-mobile-year-marker{margin-top:0}}.timeline-mobile-card:hover{transform:translateY(-1px);box-shadow:0 6px 20px #00000026;--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000);--tw-ring-color: rgb(65 193 186 / .5)}.timeline-mobile-card:hover:is(.dark *){--tw-ring-color: rgb(54 91 109 / .5)}.timeline-mobile-card:hover{z-index:40}.timeline-mobile-card-active{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000);--tw-ring-opacity: 1;--tw-ring-color: rgb(65 193 186 / var(--tw-ring-opacity, 1))}.timeline-mobile-card-active:is(.dark *){--tw-ring-opacity: 1;--tw-ring-color: rgb(54 91 109 / var(--tw-ring-opacity, 1))}.timeline-mobile-card-active{box-shadow:0 8px 25px #2dd4bf4d;transform:translateY(-1px);z-index:40}.timeline-mobile-header{margin-bottom:.5rem;display:flex;align-items:center;justify-content:space-between;font-size:.875rem;line-height:1.25rem;--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.timeline-mobile-header:is(.dark *){--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.timeline-mobile-header{flex-shrink:0}.timeline-mobile-year{border-radius:9999px;--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1));padding:.125rem .5rem;font-size:.75rem;line-height:1rem;font-weight:500}.timeline-mobile-year:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))}.timeline-mobile-title{margin-bottom:.25rem;font-size:1rem;line-height:1.5rem;font-weight:700;--tw-text-opacity: 1;color:rgb(0 0 0 / var(--tw-text-opacity, 1))}.timeline-mobile-title:is(.dark *){--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.timeline-mobile-title{flex-shrink:0}.timeline-mobile-organization{margin-bottom:.5rem;font-size:.875rem;line-height:1.25rem;font-weight:500;--tw-text-opacity: 1;color:rgb(54 91 109 / var(--tw-text-opacity, 1))}.timeline-mobile-organization:is(.dark *){--tw-text-opacity: 1;color:rgb(65 193 186 / var(--tw-text-opacity, 1))}.timeline-mobile-organization{flex-shrink:0}.timeline-mobile-tags{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:auto;flex-shrink:0}.timeline-mobile-tag{display:inline-block;border-radius:9999px;--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1));padding:.125rem .5rem;font-size:.75rem;line-height:1rem;--tw-text-opacity: 1;color:rgb(54 91 109 / var(--tw-text-opacity, 1))}.timeline-mobile-tag:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(65 193 186 / var(--tw-text-opacity, 1))}.timeline-mobile-more-tags{padding:.125rem .25rem;font-size:.75rem;line-height:1rem;--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.timeline-mobile-more-tags:is(.dark *){--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.timeline-item-desktop{margin-bottom:3rem;display:none;align-items:center}@media (min-width: 768px){.timeline-item-desktop{display:flex}}.timeline-item-desktop{width:100%}.timeline-item-desktop-left{flex-direction:row;justify-content:flex-end}.timeline-item-desktop-right{flex-direction:row-reverse;justify-content:flex-end}.timeline-desktop-content{width:41.666667%;min-width:250px;padding:8px;overflow:visible}.timeline-desktop-content-left{padding-right:2rem;text-align:right;width:calc(100% - 8px);padding-right:16px;overflow:visible}.timeline-desktop-content-right{padding-left:2rem;width:calc(100% - 8px);padding-left:16px;overflow:visible}.home-timeline-container{margin-left:auto;margin-right:auto;max-width:64rem;padding-top:2rem;padding-bottom:2rem;overflow:visible;padding:0 8px}.timeline-wrapper{position:relative;margin-left:auto;margin-right:auto;display:flex;width:100%;justify-content:center;overflow:visible;padding:0 8px}.timeline-content{position:relative;display:flex;width:100%;flex-direction:column;overflow:visible;padding:0 8px}.timeline-desktop-card{cursor:pointer;border-radius:.5rem;border-width:1px;--tw-border-opacity: 1;border-color:rgb(243 244 246 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));padding:1.25rem;--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.timeline-desktop-card:is(.dark *){--tw-border-opacity: 1;border-color:rgb(55 65 81 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity, 1))}.timeline-desktop-card{display:flex;flex-direction:column;min-height:350px;min-width:300px;position:relative;margin-left:auto;margin-right:auto;z-index:15}.timeline-desktop-card-content{display:flex;height:100%;flex:1 1 0%;flex-direction:column;justify-content:space-between;gap:.5rem;word-break:break-word;overflow-wrap:break-word}.timeline-mobile-card{position:relative;z-index:15}.timeline-desktop-card:hover{transform:translateY(-2px) scale(1.01);box-shadow:0 8px 25px #00000026;--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000);--tw-ring-color: rgb(65 193 186 / .5)}.timeline-desktop-card:hover:is(.dark *){--tw-ring-color: rgb(54 91 109 / .5)}.timeline-desktop-card:hover{z-index:40}.timeline-desktop-card-active{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000);--tw-ring-opacity: 1;--tw-ring-color: rgb(65 193 186 / var(--tw-ring-opacity, 1))}.timeline-desktop-card-active:is(.dark *){--tw-ring-opacity: 1;--tw-ring-color: rgb(54 91 109 / var(--tw-ring-opacity, 1))}.timeline-desktop-card-active{box-shadow:0 8px 25px #2dd4bf4d;transform:translateY(-2px) scale(1.01);z-index:40}.timeline-desktop-header{margin-bottom:.75rem;display:flex;flex-direction:column;align-items:flex-start;font-size:.875rem;line-height:1.25rem;--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.timeline-desktop-header:is(.dark *){--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}@media (min-width: 640px){.timeline-desktop-header{flex-direction:row;align-items:center;justify-content:space-between}}.timeline-desktop-header{flex-shrink:0}.timeline-desktop-year{border-radius:9999px;--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1));padding:.125rem .5rem;font-size:.75rem;line-height:1rem;font-weight:500}.timeline-desktop-year:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))}.timeline-desktop-title{margin-bottom:.25rem;font-size:1.125rem;line-height:1.75rem;font-weight:700;--tw-text-opacity: 1;color:rgb(0 0 0 / var(--tw-text-opacity, 1))}.timeline-desktop-title:is(.dark *){--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.timeline-desktop-title{flex-shrink:0;word-break:break-word}.timeline-desktop-organization{margin-bottom:.75rem;font-weight:500;--tw-text-opacity: 1;color:rgb(54 91 109 / var(--tw-text-opacity, 1))}.timeline-desktop-organization:is(.dark *){--tw-text-opacity: 1;color:rgb(65 193 186 / var(--tw-text-opacity, 1))}.timeline-desktop-organization{flex-shrink:0;word-break:break-word}.timeline-desktop-description{margin-bottom:1rem;text-align:justify;--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.timeline-desktop-description:is(.dark *){--tw-text-opacity: 1;color:rgb(209 213 219 / var(--tw-text-opacity, 1))}.timeline-desktop-description{flex:1 1 0%;word-break:break-word}.timeline-desktop-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:auto;flex-shrink:0}.timeline-desktop-tag{display:inline-block;min-width:4rem;border-radius:9999px;--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1));padding:.25rem .75rem;text-align:center;font-size:.75rem;line-height:1rem;--tw-text-opacity: 1;color:rgb(54 91 109 / var(--tw-text-opacity, 1))}.timeline-desktop-tag:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(65 193 186 / var(--tw-text-opacity, 1))}.timeline-desktop-marker-container{display:flex;width:16.666667%;justify-content:center}.timeline-desktop-spacer{width:41.666667%}.timeline-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;overflow-y:auto;background-color:#00000080;padding:1rem;--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.timeline-modal-content{max-height:90vh;width:100%;max-width:48rem;overflow-y:auto;border-radius:.75rem;--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.timeline-modal-content:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity, 1))}.timeline-modal-header{position:sticky;top:0;z-index:10;display:flex;justify-content:flex-end;border-bottom-width:1px;--tw-border-opacity: 1;border-color:rgb(243 244 246 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));padding:1rem}.timeline-modal-header:is(.dark *){--tw-border-opacity: 1;border-color:rgb(55 65 81 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity, 1))}.timeline-modal-close{border-radius:9999px;padding:.5rem;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.timeline-modal-close:hover{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.timeline-modal-close:hover:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))}.timeline-modal-close-icon{height:1.25rem;width:1.25rem;--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.timeline-modal-close-icon:is(.dark *){--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.timeline-modal-body{padding:1.5rem}.timeline-modal-info-header{margin-bottom:1.5rem}.timeline-modal-info-badges{margin-bottom:.5rem;display:flex;align-items:center}.timeline-modal-year-badge{border-radius:9999px;background-color:#41c1ba1a;padding:.25rem .5rem;font-size:.875rem;line-height:1.25rem;font-weight:500;--tw-text-opacity: 1;color:rgb(54 91 109 / var(--tw-text-opacity, 1))}.timeline-modal-year-badge:is(.dark *){background-color:#41c1ba33;--tw-text-opacity: 1;color:rgb(65 193 186 / var(--tw-text-opacity, 1))}.timeline-modal-category-badge{margin-left:.75rem;font-size:.875rem;line-height:1.25rem;font-weight:500;text-transform:capitalize;--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.timeline-modal-category-badge:is(.dark *){--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.timeline-modal-main-title{margin-bottom:.25rem;font-size:1.5rem;line-height:2rem;font-weight:700;--tw-text-opacity: 1;color:rgb(0 0 0 / var(--tw-text-opacity, 1))}.timeline-modal-main-title:is(.dark *){--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.timeline-modal-organization{font-size:1.25rem;line-height:1.75rem;font-weight:500;--tw-text-opacity: 1;color:rgb(54 91 109 / var(--tw-text-opacity, 1))}.timeline-modal-organization:is(.dark *){--tw-text-opacity: 1;color:rgb(65 193 186 / var(--tw-text-opacity, 1))}.timeline-modal-section{margin-bottom:1.5rem}.timeline-modal-section-title{margin-bottom:.75rem;font-size:1.125rem;line-height:1.75rem;font-weight:600;--tw-text-opacity: 1;color:rgb(0 0 0 / var(--tw-text-opacity, 1))}.timeline-modal-section-title:is(.dark *){--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.timeline-modal-section-text{line-height:1.625;--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.timeline-modal-section-text:is(.dark *){--tw-text-opacity: 1;color:rgb(209 213 219 / var(--tw-text-opacity, 1))}.timeline-modal-links{margin-top:.5rem;display:flex;flex-wrap:wrap;gap:.75rem}.timeline-modal-link{display:flex;align-items:center;gap:.5rem;border-radius:.375rem;--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1));padding:.5rem 1rem;--tw-text-opacity: 1;color:rgb(54 91 109 / var(--tw-text-opacity, 1));transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.timeline-modal-link:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(65 193 186 / var(--tw-text-opacity, 1))}.timeline-modal-link:hover{--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}.timeline-modal-link:hover:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(75 85 99 / var(--tw-bg-opacity, 1))}.timeline-modal-link-icon{height:1rem;width:1rem}.timeline-modal-achievements{margin-top:.5rem;list-style-type:disc}.timeline-modal-achievements>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.timeline-modal-achievements{padding-left:1.25rem}.timeline-modal-achievement-item{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.timeline-modal-achievement-item:is(.dark *){--tw-text-opacity: 1;color:rgb(209 213 219 / var(--tw-text-opacity, 1))}.timeline-modal-tech-grid{display:flex;flex-wrap:wrap;gap:.5rem}.timeline-modal-tech-tag{border-radius:9999px;--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1));padding:.25rem .75rem;font-size:.875rem;line-height:1.25rem;--tw-text-opacity: 1;color:rgb(54 91 109 / var(--tw-text-opacity, 1))}.timeline-modal-tech-tag:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(65 193 186 / var(--tw-text-opacity, 1))}.timeline-content-mobile{display:flex;flex-direction:column;overflow:visible!important;height:auto!important}.timeline-year-group{position:relative;margin-bottom:2rem}.timeline-year-items{margin-left:2.5rem;margin-top:.5rem}.timeline-content-mobile .timeline-item-wrapper{position:relative!important;top:auto!important;left:auto!important;right:auto!important;height:auto!important;width:100%!important;margin-bottom:1.5rem;display:block!important}.timeline-content-mobile .timeline-year-mobile{position:relative;left:0;top:auto;margin:0;z-index:20}.timeline-content-mobile .timeline-mobile-line{position:absolute;left:1.5rem;top:0;height:100%;z-index:10}.timeline-content-mobile .timeline-mobile-year-marker{--tw-bg-opacity: 1;background-color:rgb(65 193 186 / var(--tw-bg-opacity, 1))}.timeline-content-mobile .timeline-mobile-year-marker:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(54 91 109 / var(--tw-bg-opacity, 1))}.timeline-content-mobile .timeline-mobile-year-marker{width:3rem;height:3rem;margin-left:0;border-width:3px;border-color:#fff;box-shadow:0 0 10px #0003}.timeline-content-mobile .timeline-mobile-year-text{font-weight:700;--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.timeline-content-mobile .timeline-mobile-year-text:is(.dark *){--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.timeline-content-mobile .timeline-mobile-year-text{font-size:1rem}.timeline-content-mobile .timeline-mobile-connector{position:absolute;left:.375rem;top:0;bottom:0;width:.125rem;--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}.timeline-content-mobile .timeline-mobile-connector:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))}.mobile-skills-container{display:flex;width:100%;flex-direction:column;overflow:hidden;border-radius:.5rem;background:linear-gradient(135deg,rgb(var(--color-background-rgb) / .8),rgb(var(--color-surface-rgb) / .9))}.mobile-category-tabs{display:flex;width:100%;border-bottom-width:1px;--tw-border-opacity: 1;border-color:rgb(229 231 235 / var(--tw-border-opacity, 1))}.mobile-category-tabs:is(.dark *){--tw-border-opacity: 1;border-color:rgb(55 65 81 / var(--tw-border-opacity, 1))}.mobile-category-tab{position:relative;flex:1 1 0%;padding:.75rem 1rem;text-align:center;font-weight:500;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s;color:var(--color-text-muted)}.mobile-category-tab:after{content:"";position:absolute;bottom:0;left:0;height:.25rem;width:100%;--tw-scale-x: 0;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.mobile-category-tab.active{color:var(--color-text);font-weight:600}.mobile-category-tab.active:after{--tw-scale-x: 1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.mobile-category-tab.category-technical:after{background-color:var(--color-primary)}.mobile-category-tab.category-creative:after{background-color:var(--color-accent)}.mobile-category-tab.category-research:after{background-color:var(--color-secondary)}.mobile-skills-content{height:18rem;overflow:hidden;padding:1rem;position:relative}.mobile-skills-grid{position:absolute;top:0;left:0;width:100%;height:100%;padding:1rem;opacity:0;visibility:hidden;transition:opacity .5s ease;will-change:opacity,visibility;z-index:1}.mobile-skills-grid.active{opacity:1;visibility:visible;z-index:2}.mobile-skill-bubble{display:flex;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;align-items:center;justify-content:center;border-radius:9999px;font-weight:500;--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.3);transition:transform .3s ease,box-shadow .3s ease,border .3s ease;box-shadow:0 3px 10px #0003;padding:4px;position:absolute;will-change:transform}.mobile-skill-bubble.category-technical{background-color:var(--color-primary);color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.8);font-weight:600}.mobile-skill-bubble.category-creative{background-color:var(--color-accent);color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.8);font-weight:600}.mobile-skill-bubble.category-research{background-color:var(--color-secondary);color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.8);font-weight:600}.mobile-skill-text{padding-left:.25rem;padding-right:.25rem;text-align:center;display:flex;align-items:center;justify-content:center;width:100%;height:100%;line-height:1.1;word-break:normal;overflow-wrap:break-word;white-space:normal;font-size:clamp(10px,.8rem,14px)}[data-theme=dark] .mobile-skill-bubble.category-technical{color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.9);font-weight:700;border:1px solid rgba(255,255,255,.5)}[data-theme=dark] .mobile-skill-bubble.category-creative,[data-theme=dark] .mobile-skill-bubble.category-research{color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.8);font-weight:600}.mobile-skill-bubble:hover{box-shadow:0 6px 20px #0000004d;border:1px solid rgba(255,255,255,.6);z-index:10}[data-theme=dark] .mobile-category-tab.category-technical{color:#fff}[data-theme=dark] .mobile-category-tab.category-technical.active{color:#fff;font-weight:700}[data-theme=dark] .mobile-category-tab.category-technical:not(.active){color:#d1d5db;text-shadow:0 1px 2px rgba(0,0,0,.5)}[data-theme=dark] .mobile-category-tab{color:#d1d5db}[data-theme=dark] .mobile-category-tab.active{color:#fff}@media (max-width: 360px){.mobile-skills-grid{grid-template-columns:repeat(auto-fill,minmax(60px,1fr));grid-gap:8px}}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.\!container{width:100%!important}.container{width:100%}@media (min-width: 640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media (min-width: 768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media (min-width: 1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media (min-width: 1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media (min-width: 1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.visible{visibility:visible}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.mx-auto{margin-left:auto;margin-right:auto}.my-4{margin-top:1rem;margin-bottom:1rem}.mb-12{margin-bottom:3rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.ml-auto{margin-left:auto}.mr-6{margin-right:1.5rem}.mt-12{margin-top:3rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.block{display:block}.inline{display:inline}.flex{display:flex}.hidden{display:none}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-8{height:2rem}.h-full{height:100%}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-8{width:2rem}.max-w-2xl{max-width:42rem}.max-w-full{max-width:100%}.max-w-none{max-width:none}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.list-decimal{list-style-type:decimal}.list-disc{list-style-type:disc}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:.5rem}.gap-4{gap:1rem}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.rounded{border-radius:.25rem}.rounded-lg{border-radius:.5rem}.border{border-width:1px}.border-l-4{border-left-width:4px}.border-turquoise{--tw-border-opacity: 1;border-color:rgb(65 193 186 / var(--tw-border-opacity, 1))}.bg-gray-100{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.p-4{padding:1rem}.p-8{padding:2rem}.px-1{padding-left:.25rem;padding-right:.25rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-16{padding-top:4rem;padding-bottom:4rem}.pl-4{padding-left:1rem}.pl-6{padding-left:1.5rem}.text-center{text-align:center}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.font-bold{font-weight:700}.italic{font-style:italic}.text-black{--tw-text-opacity: 1;color:rgb(0 0 0 / var(--tw-text-opacity, 1))}.text-dark-teal{--tw-text-opacity: 1;color:rgb(54 91 109 / var(--tw-text-opacity, 1))}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.text-turquoise{--tw-text-opacity: 1;color:rgb(65 193 186 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.ring{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-150{transition-duration:.15s}.duration-300{transition-duration:.3s}.duration-500{transition-duration:.5s}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}.hover\:underline:hover{text-decoration-line:underline}.dark\:border-dark-teal:is(.dark *){--tw-border-opacity: 1;border-color:rgb(54 91 109 / var(--tw-border-opacity, 1))}.dark\:bg-gray-800:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity, 1))}.dark\:text-dark-teal:is(.dark *){--tw-text-opacity: 1;color:rgb(54 91 109 / var(--tw-text-opacity, 1))}.dark\:text-gray-300:is(.dark *){--tw-text-opacity: 1;color:rgb(209 213 219 / var(--tw-text-opacity, 1))}.dark\:text-gray-400:is(.dark *){--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.dark\:text-gray-500:is(.dark *){--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.dark\:text-turquoise:is(.dark *){--tw-text-opacity: 1;color:rgb(65 193 186 / var(--tw-text-opacity, 1))}.dark\:text-white:is(.dark *){--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}@media (min-width: 640px){.sm\:h-10{height:2.5rem}.sm\:w-10{width:2.5rem}}
