:root{line-height:1.5;font-weight:400;font-family:sitefont,sans-serif;color-scheme:light dark;color:#ffffffde;background-color:#212223}@media (min-width: 768px){:root{background-image:url(/background.png);background-attachment:fixed;background-size:cover;-webkit-background-size:cover;background-position:center}}@media (max-width: 767px){:root{background:linear-gradient(135deg,#1a1b1c,#2a2b2c)}}a{font-weight:500;color:#6473ff;text-decoration:inherit}a:hover{color:#afc0eb}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height: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 (max-width: 600px){:root{background-attachment:scroll}}@font-face{font-family:sitefont;src:url(/fonts/SourceCodePro.ttf)}.emblem{display:inline-block;justify-content:center}.emblems{display:inline-block;line-height:0}.role-badge{padding:5px 10px;border-radius:8px;color:#f7f7f7;background-color:#1f1f20;font-weight:700;display:inline-block;text-wrap:nowrap;font-size:.875rem}@media (max-width: 600px){.role-badge{font-size:inherit}}.technology-badge{padding:5px 10px;border-radius:8px;color:#fff;font-weight:700;display:inline-block;text-wrap:nowrap;font-size:.875rem}@media (max-width: 600px){.technology-badge{font-size:inherit}}.project-card{padding:0 20px 20px;background-color:#2d3f4566;-webkit-backdrop-filter:saturate(180%) blur(10px);backdrop-filter:saturate(180%) blur(10px);border-radius:8px;text-align:left;opacity:0;animation:rise .5s ease-out forwards;contain:layout style paint;will-change:transform,opacity}.title{display:inline-flex;vertical-align:middle;align-items:center}.title h3{color:#f0f8ff;margin-top:0}.date{position:absolute;font-weight:400;text-align:right;right:24px}.project-thumbnail{width:100%;height:200%;height:auto;border-radius:4px}.project-thumbnail-cutoff{width:100%;height:192px;mask-image:linear-gradient(to bottom,black 60%,transparent 100%);-webkit-mask-image:linear-gradient(to bottom,black 60%,transparent 100%)}.project-card:hover{backface-visibility:hidden;transition:all .1s ease-in-out;background-color:#2d2f2f80;cursor:pointer}.p{color:#f0f8ff;line-height:1.5}.platforms{margin-left:8px;display:flex;align-items:center}.badges-container{display:flex;flex-direction:column}.badges{margin-top:auto;justify-content:space-between;display:inline-flex;gap:8px;width:100%;flex-grow:1}.badges-technologies{display:flex;justify-content:flex-start;gap:4px}.badges-roles{display:flex;justify-content:flex-end;gap:4px}@media (max-width: 600px){.card{font-size:3.2vh;background-color:#424546b3;-webkit-backdrop-filter:none;backdrop-filter:none;will-change:transform,opacity}.card:hover{transition:background-color .1s ease-in-out;background-color:#2d2f2fcc}.project-thumbnail{image-rendering:auto;height:auto;max-height:192px;object-fit:cover}}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;-webkit-backdrop-filter:saturate(180%) blur(4px);backdrop-filter:saturate(180%) blur(4px);display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s forwards}.modal-content{background:linear-gradient(#424242,#2c2c2c);-webkit-backdrop-filter:saturate(180%) blur(10px);backdrop-filter:saturate(180%) blur(10px);padding:20px;border-radius:8px;width:90%;max-width:500px;position:relative;box-shadow:0 4px 15px #0000004d}.modal-content p{padding-left:4px;padding-right:4px;text-align:justify}.modal-close{position:absolute;top:10px;right:10px;border:none;background:transparent;cursor:pointer}.modal-close:hover{transition:all .1s ease-in-out;background-color:#353737}body.modal-open{overflow:hidden}.modal-content .badges-container{margin:10px 0}.modal-content .technology-badge,.modal-content .role-badge{font-size:.75rem;padding:3px 8px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 600px){.modal-content{max-width:100%;font-size:4vh;-webkit-backdrop-filter:saturate(180%);backdrop-filter:saturate(180%)}.modal-overlay{-webkit-backdrop-filter:saturate(180%);backdrop-filter:saturate(180%)}}.link{color:#9bc3f1;font-weight:700}.link:hover{color:#5a71bc}.image-container{display:flex;justify-content:center;align-items:center}.image-container img{object-fit:contain;max-width:100%;max-height:100%;border-radius:4px}.project-list{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;place-items:center;align-self:center}@media (max-width: 768px){.project-list{grid-template-columns:1fr}}header{align-content:center}h1{padding:0}.face{max-width:15%}.socials-list{list-style-type:none;display:flex;align-self:center;justify-content:center;padding:0;margin:0}.socials-item{margin:0 16px}@media (max-width: 600px){.socials-list{font-size:5vh}}.skill-categories{display:flex;justify-content:center;align-items:flex-start;gap:10px}@media (max-width: 600px){.skill-categories{display:grid;grid-template-columns:1fr 1fr;gap:10px}}.skill-category{display:flex;flex-direction:column;justify-content:space-evenly;align-items:center;min-width:150px;padding:20px;background-color:#42454666;border-radius:8px;text-align:left;-webkit-backdrop-filter:saturate(180%) blur(10px);backdrop-filter:saturate(180%) blur(10px)}.skill-category h4{text-align:center;margin-bottom:10px;margin-top:0}.badges-technologies{display:flex;justify-content:space-between}@media (max-width: 600px){.skill-category{background-color:#424546b3;-webkit-backdrop-filter:saturate(180%);backdrop-filter:saturate(180%)}}footer:before{content:"";position:absolute;z-index:-1;-webkit-mask-image:linear-gradient(#fff0,#000);mask-image:linear-gradient(#fff0,#000);background-color:#000c;-webkit-backdrop-filter:saturate(180%) blur(10px);backdrop-filter:saturate(180%) blur(10px);height:64px;top:0;left:0;right:0}footer{position:fixed;color:#e4e4e4;height:64px;line-height:.4;bottom:0;left:0;width:100%}.footer-contents{padding-top:16px;padding-bottom:8px;height:32px;font-size:small}@media (max-width: 600px){footer:before{-webkit-backdrop-filter:none;-webkit-mask-image:none;mask-image:none;backdrop-filter:none;background-color:#0000}footer{height:max-content;background-color:#00000080}.footer-contents{padding-top:0;padding-bottom:0;font-size:3vh;height:72px}}.product-card{position:relative;display:flex;flex-direction:column;width:260px;height:200px;background-color:#42454666;-webkit-backdrop-filter:saturate(180%) blur(10px);backdrop-filter:saturate(180%) blur(10px);border-radius:8px;overflow:hidden;opacity:0;animation:rise .5s ease-out forwards;cursor:pointer;transition:transform .2s ease,background-color .2s ease;contain:layout style paint;will-change:transform,opacity}.product-card:hover{transform:translateY(-4px);background-color:#42454699}.product-title{position:absolute;top:8px;left:8px;color:#f0f8ff;font-size:.95rem;margin:0;line-height:1.3;font-weight:600;background-color:#0009;padding:4px 8px;border-radius:4px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10;max-width:calc(100% - 60px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.product-platforms{position:absolute;top:8px;right:8px;display:flex;justify-content:flex-end;align-items:center;background-color:#0009;padding:4px 6px;border-radius:4px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10}.thumbnail{width:100%;height:100%;object-fit:cover;border-radius:0}.thumbnail-cutoff{width:100%;height:100%;overflow:hidden;position:absolute;top:0;left:0;right:0;bottom:0}@keyframes rise{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 600px){.product-card{width:calc(50% - 5px);height:180px;background-color:#424546b3;-webkit-backdrop-filter:saturate(180%);backdrop-filter:saturate(180%)}.product-card:hover{transform:translateY(-2px)}.product-title{font-size:.85rem;top:6px;left:6px;padding:3px 6px}.product-platforms{top:6px;right:6px;padding:3px 5px}}.shipped-products-container{display:flex;justify-content:center;align-items:stretch;gap:15px;flex-wrap:wrap;max-width:1200px;margin:0 auto}@media (max-width: 600px){.shipped-products-container{gap:10px}}#root{max-width:1200px;margin:0 auto;padding:2rem;text-align:center}main{padding-bottom:48px}.blurb{max-width:60%;margin-left:auto;margin-right:auto;text-align:justify}@font-face{font-family:blurb;src:url(/fonts/MPLUSCode.ttf);font-display:swap}@media (max-width: 600px){#root{padding:1rem;font-size:3vh}.blurb{max-width:80%}}
