:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}#root{background-color:#000000d9}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{border:none}.read-the-docs{color:#888}.project-card .card-body{display:flex;flex-direction:column;height:100%;text-align:left;cursor:pointer}.project-card:hover{transform:scale(1.04);box-shadow:0 8px 32px #a259ff40,0 2px 8px #0000001a;transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1)}.project-card{transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1)}.ribbon{position:absolute;top:12px;right:12px;background:#d69e2e;color:#111;padding:.25rem .6rem;font-weight:700;font-size:.85rem;border-radius:6px;box-shadow:0 4px 10px #00000026;z-index:10;text-transform:uppercase;letter-spacing:.04em}.modal-wip{background:#d69e2e;color:#111;padding:.25rem .6rem;font-weight:700;font-size:.85rem;border-radius:6px;box-shadow:0 4px 10px #00000026;text-transform:uppercase;letter-spacing:.04em;text-align:center;max-width:fit-content;margin-inline:auto;margin-top:.5em}.description{white-space:pre-line}.skill-tags{margin-bottom:2px;display:flex;gap:6px;flex-wrap:wrap}.skill{background:radial-gradient(ellipse at top right,#e0b3ff,#a259ff 40%,#6d28d9);box-shadow:0 2px 12px #a259ff80,0 0 8px 2px #fff3 inset;color:#fff;padding:.25rem .6rem;font-weight:700;border-radius:20px;font-size:.8rem}.project-card-carousel img{width:100%;height:220px;object-fit:cover}.modal-carousel{padding:1px;background:linear-gradient(135deg,#a259ff,#e0b3ff);border-radius:8px;box-shadow:0 0 16px 4px #a259ff80,0 0 8px 2px #fff3 inset;display:flex;align-items:center;justify-content:center}.modal-carousel img{width:100%;object-fit:cover;border-radius:8px}.modal-dialog .modal-content{border:none}.badge-in-dev{background:#ffc107;color:#111}@media (prefers-color-scheme: light){.project-card-placeholder{background:linear-gradient(135deg,#f4f6fb,#eef3ff);color:#334}}.row{display:flex;flex-wrap:wrap;justify-content:left}h2{text-align:center;border-bottom-width:1px;border-bottom-color:#fff;border-bottom-style:inset}.bottom-divider{border-bottom:1px inset plum}#navbar-section{padding-top:1em;position:fixed;width:100%;top:0;z-index:100;margin-bottom:5em;text-align:center}#navbar{background-color:#fff;box-shadow:0 4px 16px purple;border-radius:30px;text-align:center;width:50%;padding-inline:2em;margin:0 auto;color:#000}#title-section{background-image:radial-gradient(#0003,#00000080),url(/hero-background.jpeg);background-size:cover;background-repeat:no-repeat;background-position-y:center;min-height:20em;margin-inline:0;color:#fff;display:flex;flex-direction:column;justify-content:space-between}#title-text{display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;margin-bottom:10%;margin-top:12%}.subtitle{font-weight:700;font-size:large}section{color:#fff}.text-section{padding:15%}.narrow-body{margin-inline:10%}.contact-icon{width:64px}.footer{justify-items:center;justify-content:center}
