@import"https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,100..900;1,100..900&display=swap";@import"https://fonts.googleapis.com/css2?family=Noto+Sans:ital,wght@0,100..900;1,100..900&family=Roboto:ital,wght@0,100..900;1,100..900&display=swap";html.theme-switching *,html.theme-switching *:before,html.theme-switching *:after{transition:none!important;animation:none!important}:root[data-theme=dark]{color-scheme:dark;--bg-color: rgb(13, 13, 13);--text-color: #f0f0f0;--text-color-rgb: 240, 240, 240;--work-text-color: #cccccc;--timeline-text-color: #cccccc;--skill-label-color: #ddd;--caption-color: #ccc;--card-bg: #111;--card-shadow: rgba(0, 0, 0, .5);--card-shadow-hover: rgba(0, 0, 0, .7);--card-border: #555;--divider-color: #222;--text-primary: #f0f0f0;--text-secondary: #ccc;--text-muted: #777;--highlight-color: #ea596f}:root[data-theme=light]{color-scheme:dark;--bg-color: #fff;--text-color: #000;--text-color-rgb: 0, 0, 0;--work-text-color: #555;--timeline-text-color: #666;--skill-label-color: #333;--caption-color: #777;--card-bg: #fff;--card-shadow: rgba(0, 0, 0, .1);--card-shadow-hover: rgba(0, 0, 0, .2);--card-border: #eee;--divider-color: #eee;--text-primary: #333;--text-secondary: #555;--text-muted: #999;--highlight-color: #ea596f}@media (prefers-color-scheme: light){:root{color-scheme:light;--bg-color: #fff;--text-color: #000;--text-color-rgb: 0, 0, 0;--work-text-color: #555;--timeline-text-color: #666;--skill-label-color: #333;--caption-color: #777;--card-bg: #fff;--card-shadow: rgba(0, 0, 0, .1);--card-shadow-hover: rgba(0, 0, 0, .2);--card-border: #eee;--divider-color: #eee;--text-primary: #333;--text-secondary: #555;--text-muted: #999;--highlight-color: #ea596f}}@media (prefers-color-scheme: dark){:root{color-scheme:dark;--bg-color: rgb(13, 13, 13);--text-color: #f0f0f0;--text-color-rgb: 240, 240, 240;--work-text-color: #cccccc;--timeline-text-color: #cccccc;--skill-label-color: #ddd;--caption-color: #ccc;--card-bg: #111;--card-shadow: rgba(0, 0, 0, .5);--card-shadow-hover: rgba(0, 0, 0, .7);--card-border: #555;--divider-color: #222;--text-primary: #f0f0f0;--text-secondary: #ccc;--text-muted: #777;--highlight-color: #ea596f}}html{scrollbar-gutter:stable;font-size:90%;height:100vh;overscroll-behavior:none;overflow-y:auto}body{font-family:Noto Sans,sans-serif;font-optical-sizing:auto;font-style:normal;font-size:larger;font-weight:300;background-color:#000;color:var(--text-color);text-wrap:pretty;margin:0}html,body{margin:0;padding:0;height:100%}body,#root{min-height:100vh;display:flex;flex-direction:column}main{flex:1 0 auto}footer{flex-shrink:0}header,footer,main{position:relative;background-color:#000;background-image:url(/assets/mainbg-B6z01YrH.webp);background-size:contain;background-position:center;background-repeat:no-repeat;background-attachment:fixed}.background-wrapper{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none}.snow-gutter{position:absolute;top:0;height:100%;pointer-events:none;z-index:0}.snow-gutter.left{left:0}.snow-gutter.right{right:0}.container{max-width:80rem;margin:0 auto;padding:0 1rem;min-height:0;z-index:2;position:relative;background-color:var(--bg-color);background-image:repeating-linear-gradient(to right,rgba(var(--text-color-rgb),.05) 0px,rgba(var(--text-color-rgb),.05) 1px,transparent 1px,transparent 28px),repeating-linear-gradient(to bottom,rgba(var(--text-color-rgb),.05) 0px,rgba(var(--text-color-rgb),.05) 1px,transparent 1px,transparent 28px);background-size:28.08px 28.08px}img{-webkit-user-select:none;user-select:none;height:100%;width:100%}p{margin-bottom:5px}.highlighted{color:#ea596f}.link-underline{position:relative;display:inline-block;text-decoration:none;color:var(--text-color);transition:color .2s}.link-underline:after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:2px;background:var(--highlight-color);transform:scaleX(0);transition:transform .3s ease}.link-underline:hover,.link-underline.active-link{color:var(--highlight-color)}.link-underline:hover:after,.link-underline.active-link:after{transform:scaleX(1)}.link-underline--ltr:after{transform-origin:left}.link-underline--rtl:after{transform-origin:right}.link-underline--center:after{transform-origin:center}strong{font-weight:700}h1{font-weight:700;font-size:x-large}h2,h3{font-weight:700;font-size:larger}.divider{width:50%;margin:0 auto;border:none;border-top:2px solid var(--text-color);margin-top:1.5vh;margin-bottom:3vh}.long-divider{width:80%;margin:0 auto;border:none;border-top:1px solid var(--text-color);margin-bottom:1rem}.work-filters{display:flex;justify-content:center;height:100%;margin-bottom:1rem}.scroll-to-top{position:fixed;bottom:1rem;right:1rem;background:#ea596f;color:#fff;border:none;padding:.75rem 1rem;font-size:1rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;border-radius:50px;opacity:0;transform:translateY(1rem);pointer-events:none;transition:opacity .3s ease-in-out,transform .3s ease-in-out;z-index:727}.scroll-to-top.show{opacity:1;transform:translateY(0);pointer-events:auto}.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1rem}.col-1{grid-column:span 1}.col-2{grid-column:span 2}.col-3{grid-column:span 3}.col-4{grid-column:span 4}.col-5{grid-column:span 5}.col-6{grid-column:span 6}.col-7{grid-column:span 7}.col-8{grid-column:span 8}.col-9{grid-column:span 9}.col-10{grid-column:span 10}.col-11{grid-column:span 11}.col-12{grid-column:span 12}@media screen and (min-width: 0px){.header-menu{padding-top:40px}.scroll-to-top,.col-0-sm{display:none}.col-1-sm{grid-column:span 1}.col-2-sm{grid-column:span 2}.col-3-sm{grid-column:span 3}.col-4-sm{grid-column:span 4}.col-5-sm{grid-column:span 5}.col-6-sm{grid-column:span 6}.col-7-sm{grid-column:span 7}.col-8-sm{grid-column:span 8}.col-9-sm{grid-column:span 9}.col-10-sm{grid-column:span 10}.col-11-sm{grid-column:span 11}.col-12-sm{grid-column:span 12}}@media screen and (min-width: 768px){.col-0-sm,.logo{display:block}.header-menu{padding-top:0}.scroll-to-top{display:flex}.col-1-md{grid-column:span 1}.col-2-md{grid-column:span 2}.col-3-md{grid-column:span 3}.col-4-md{grid-column:span 4}.col-5-md{grid-column:span 5}.col-6-md{grid-column:span 6}.col-7-md{grid-column:span 7}.col-8-md{grid-column:span 8}.col-9-md{grid-column:span 9}.col-10-md{grid-column:span 10}.col-11-md{grid-column:span 11}.col-12-md{grid-column:span 12}}@media screen and (min-width: 1080px){.col-1-lg{grid-column:span 1}.col-2-lg{grid-column:span 2}.col-3-lg{grid-column:span 3}.col-4-lg{grid-column:span 4}.col-5-lg{grid-column:span 5}.col-6-lg{grid-column:span 6}.col-7-lg{grid-column:span 7}.col-8-lg{grid-column:span 8}.col-9-lg{grid-column:span 9}.col-10-lg{grid-column:span 10}.col-11-lg{grid-column:span 11}.col-12-lg{grid-column:span 12}}.clickable-image{cursor:zoom-in}.image-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-img{max-width:90%;max-height:90%;cursor:zoom-out;border-radius:4px}.logo-container{position:relative;padding-left:2rem;width:85px;height:85px;overflow:hidden}.logo-light,.logo-dark{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:contain;opacity:0}[data-theme=dark] .logo-light,[data-theme=light] .logo-dark{opacity:1}.header-menu{display:flex;align-items:flex-start;justify-content:flex-end;padding-top:4rem;padding-right:2rem}.header-menu .nav-toggle-group{display:flex;align-items:center}.header-menu .nav-toggle-group button{margin-left:2rem}.logo-container,.logo{-webkit-user-select:none;user-select:none}.nav-list{display:flex;gap:20px;list-style:none;margin:0;padding:0}.nav-list li a{position:relative;display:inline-block;text-decoration:none;color:var(--text-color);transition:color .2s}.nav-list li:not(:last-child):after{content:"|";margin-left:20px}@media screen and (max-width: 768px){.nav-list li:not(:last-child):after{content:"|";margin-left:10px}.header-menu .nav-toggle-group button{margin-left:1rem}h1,h2{margin-bottom:.01rem}.nav-list li:not(:last-child):after{content:"";margin-left:5px}.arrow-layer{display:none}.header-menu{padding-top:0rem;margin-top:-10px;margin-bottom:-20px;padding-right:0rem}.header-menu .nav-toggle-group button{margin-left:.5rem}}footer{text-align:center}.container{padding:1rem}.copyright{padding-top:1.65rem;padding-bottom:5px;font-weight:400;color:#ea596f;font-size:smaller}.social-icons{margin-top:15px;margin-bottom:10px;display:flex;justify-content:center;gap:25px;color:var(--text-color)}.icon{font-size:40px;text-decoration:none;color:#000;transition:.3s}.icon:hover{opacity:.7}.container{background-color:var(--bg-color)}.header-image{display:block;margin:0 auto;width:100%;height:auto;margin-bottom:1vh}.header-section{margin-bottom:2rem}.header-section h1{margin-top:2rem;margin-bottom:1.4rem}.header-section p{margin-top:1.4rem}h3{color:#ea596f}.home-works-with-widget h2{grid-column:1 / -1}.home-works-with-widget{display:grid;grid-template-columns:1fr;gap:2rem}.home-music-widget{display:block}@media (min-width: 768px){.home-works-with-widget{grid-template-columns:2fr 1fr}}.works{font-family:Roboto,sans-serif;font-optical-sizing:auto;font-style:normal}.work-year{margin-top:5px}.home-year{margin-bottom:5px;align-self:flex-start}.work-item{margin-left:10px}.work-item strong{display:block;font-weight:700}.work-item p{margin-bottom:10px;color:var(--work-text-color)}.last-played{font-weight:400;font-size:smaller;padding-bottom:1.3rem;text-align:center}.lastfm-recent-list{list-style:none;padding:0;margin:0}.lastfm-recent-list li{margin-bottom:.5rem;font-size:.9rem}.lastfm-recent-list a{color:inherit;text-decoration:none}.timestamp{color:#777;margin-left:.5rem;font-style:italic;font-size:.8rem}.skills-container{display:grid;grid-template-columns:repeat(5,1fr);gap:2rem;align-items:center;justify-items:center;padding:1.5rem 1.5rem 2rem}@media (max-width: 768px){.skills-container{display:flex;flex-wrap:wrap;justify-content:center}.skills-container .skill-item{flex:0 0 22%;max-width:20%;margin:.5rem}}@media (max-width: 480px){.skills-container{display:flex;flex-wrap:wrap;justify-content:center}.skills-container .skill-item{flex:0 0 30%;max-width:25%;margin:.5rem}}.skill-item{display:flex;flex-direction:column;align-items:center;width:80px;text-align:center}.skill-item img{max-width:100%;height:80px;object-fit:contain;aspect-ratio:1/1}.skill-label{margin-top:.25rem;font-size:.65rem;color:var(--skill-label-color);text-align:center;width:100%;display:block}.about-title{padding-top:7px;padding-bottom:1.31rem}.about p{margin-bottom:1.6rem}.about h2{padding-bottom:1rem;display:inline-block;text-decoration-line:underline;text-decoration-color:var(--highlight-color);text-decoration-thickness:2px;text-underline-offset:4px}.underlined{text-decoration:underline;text-decoration-color:var(--highlight-color);text-decoration-thickness:1px;text-underline-offset:4px}.portrait-grid{display:flex;flex-direction:column;align-items:center;gap:1.5rem;margin-top:1.5rem;text-align:left}.portrait-wrapper{display:flex;flex-direction:column;align-items:center;flex-shrink:0;min-width:140px}.caption{font-size:.85rem;color:var(--caption-color);margin-top:.5rem}.avatar{width:220px;aspect-ratio:2/3;object-fit:fill}@media (min-width: 768px){.portrait-grid{flex-direction:row;text-align:left;align-items:flex-start}}.timeline-horizontal{margin-top:3rem}.timeline-horizontal h2{font-size:1.5rem;margin-bottom:1.5rem;text-align:center}.timeline-track{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;position:relative;padding-top:2rem}.timeline-track:before{content:"";position:absolute;top:55px;left:0;right:0;height:2px;background-color:#eee;z-index:0}.timeline-step{flex:1;text-align:center;z-index:1}.timeline-step img{width:50px;height:50px;margin-bottom:1rem;background-color:#fff;border:gray 2px solid;padding:.3rem;border-radius:0}.timeline-step h4{font-size:1rem;font-weight:600;margin-bottom:.5rem}.timeline-step p{font-size:.9rem;color:var(--timeline-text-color);line-height:1.4}.values{margin-top:1rem}.values-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;text-align:center}.value-item{padding:1rem}.value-item img{width:60px;height:60px;margin-bottom:1rem}.value-item h4{font-size:1rem;font-weight:600;margin-bottom:.5rem}.value-item p{font-size:.9rem;color:#666;line-height:1.4}.inline-img{width:350px;float:left;margin-right:1.5rem;margin-bottom:.7rem;object-fit:cover}@media (max-width: 768px){.inline-img{float:none;display:block;margin:1rem auto}}.notfound-page{display:flex;justify-content:center;align-items:center;height:70vh;text-align:center}.notfound-page h1{font-size:6rem;margin-bottom:1rem;color:var(--text-primary)}.notfound-page p{font-size:1.25rem;margin-bottom:2rem;color:var(--text-secondary)}.back-home{text-decoration:none;color:var(--highlight-color);font-weight:700;border:2px solid var(--highlight-color);padding:.5rem 1rem;border-radius:4px;transition:background .2s ease,color .2s ease}.back-home:hover{background:var(--highlight-color);color:var(--card-bg)}.work-filters{background-color:#e6adad40;padding:.5rem 1rem;display:flex;justify-content:center}.nav-list li button{position:relative;background:none;border:none;color:inherit;font:inherit;cursor:pointer;outline:none;transition:color .1s}.nav-list li button:hover{color:#ea596f}.nav-list li button:after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:2px;background:#ea596f;transform:scaleX(0);transform-origin:center;transition:transform .3s ease}.nav-list li button:hover:after,.nav-list li button.active:after{transform:scaleX(1);transform-origin:center}.nav-list li button.active{transition:color .1s ease;color:#ea596f}.project-grid{margin-top:2.4rem;display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}.works-container{min-height:calc(100vh - var(--header-h, 145px) - var(--footer-h, 118px));display:flex}.project-card{display:flex;flex-direction:column;height:100%}.work-divider{width:70%;margin:0 auto;border:none;border-top:1px solid var(--divider-color);margin-bottom:1rem}.view-project{display:flex;align-items:end}.video-container{position:relative;width:100%;padding-bottom:56.25%;height:0;max-width:100%}.video-container iframe{position:absolute;top:0;left:0;width:100%;height:100%}.card-content{padding-top:1rem;display:flex;flex-direction:column}.view-project{display:flex;justify-content:flex-end}.work-title{text-align:center;font-size:2rem;font-weight:700;margin-top:.65rem;margin-bottom:.65rem}.work-title-sub{text-align:center;font-weight:bolder;font-size:1rem;margin-bottom:10px}.project-journey{font-family:Noto Sans,sans-serif;font-optical-sizing:auto;padding-top:2rem}.work-link{font-weight:700;text-decoration:underline}.work-link:hover{transition:color .1s ease;color:#ea596f}.reference{color:#ea596f}.project-card-link{text-decoration:none;color:inherit;display:block;margin-bottom:1rem}.project-card{position:relative;background-color:var(--card-bg);border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:transform .3s ease,box-shadow .3s ease}.project-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.project-content p{margin-bottom:0}.image-container img{width:100%;height:100%;object-fit:cover}.card-content{padding:1rem;display:flex;flex-direction:column}.title{font-size:1.2rem;margin-bottom:.5rem;color:var(--text-primary)}.tag{font-weight:400;font-size:.9rem;color:#ea596f;margin-left:.5rem}.description{font-size:.95rem;margin-bottom:1rem;color:var(--text-secondary)}.caption{text-align:center;font-size:.85rem;color:var(--text-muted);margin-top:.5rem}.card-footer{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--divider-color);padding-top:1em}.year{margin:0;font-size:.9rem;color:#999}.arrow-layer{position:absolute;top:85%;right:.5rem;transform:translateY(-0%)}@media screen and (max-width: 768px){.project-grid{grid-template-columns:1fr}}@media screen and (max-width: 1080px){.arrow-layer{top:85%}}.accordion-item summary{list-style:none;cursor:pointer;padding:0;font-weight:700;font-size:larger;margin-bottom:1rem}.accordion-item summary:before{content:"▶";display:inline-block;margin-right:.5rem;transition:transform .25s ease;color:#ea596f}.accordion-item p,.accordion-item ul,.interactive-embed{margin:1rem 0}.interactive-embed h2{font-size:1.25rem;margin-bottom:.5rem}.embed-container{position:relative;width:100%;padding-bottom:75%;overflow:hidden;border:1px solid rgba(0,0,0,.1);border-radius:8px}.embed-container .embed-frame{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.video-wrapper{background-color:transparent;padding:0;border:none}.centered-video{display:block;margin-bottom:1.5rem;width:100%;max-width:720px;box-shadow:0 4px 12px #0000001a}.accordion-item summary{display:inline-block;position:relative;cursor:pointer;transition:color .2s ease}.accordion-item summary:before{content:"▶";display:inline-block;margin-right:.5rem;transition:transform .25s ease;color:var(--highlight-color)}.accordion-item summary::-webkit-details-marker{display:none}.accordion-item summary:after{content:"";position:absolute;left:1.65rem;bottom:-2px;width:calc(100% - 1.5rem);height:2px;background:var(--highlight-color);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.accordion-item summary:hover{color:var(--highlight-color)}.accordion-item summary:hover:after{transform:scaleX(1)}.accordion-item[open] summary:before{transform:rotate(90deg)}.accordion-item[open] summary:after{transform:scaleX(1)}.breadcrumbs{position:sticky;list-style:none;display:flex;gap:10px;padding-top:10px}.breadcrumbs li:not(:last-child):after{content:" > ";margin:0 5px;color:gray}.breadcrumbs a{text-decoration:none;color:var(--text-color)}.breadcrumbs a:hover{color:#ea596f;transition:ease .2s}.breadcrumbs li:last-child span{color:#ea596f}.back-button{position:relative;background:transparent;border:none;color:var(--text-color);font:inherit;font-weight:600;cursor:pointer;padding:3rem 0rem .5rem;transition:color .2s ease;align-self:flex-start;margin-right:auto}.back-button:before{content:"⇐";display:inline-block;margin-right:.5rem;transition:transform .2s ease}.back-button:after{content:"";position:absolute;left:0;bottom:0;width:100%;height:2px;background:var(--highlight-color);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.back-button:hover,.back-button:focus{color:var(--highlight-color)}.back-button:hover:before{transform:translate(-4px)}.back-button:hover:after,.back-button:focus:after{transform:scaleX(1)}*:where(:not(html,iframe,canvas,img,svg,video,audio):not(svg *,symbol *)){all:unset;display:revert}*,*:before,*:after{box-sizing:border-box}html{-moz-text-size-adjust:none;-webkit-text-size-adjust:none;text-size-adjust:none}a,button{cursor:revert}ol,ul,menu,summary{list-style:none}ol{counter-reset:revert}img{max-inline-size:100%;max-block-size:100%}table{border-collapse:collapse}input,textarea{-webkit-user-select:auto}textarea{white-space:revert}meter{-webkit-appearance:revert;-moz-appearance:revert;appearance:revert}:where(pre){all:revert;box-sizing:border-box}::placeholder{color:unset}:where([hidden]){display:none}:where([contenteditable]:not([contenteditable=false])){-moz-user-modify:read-write;-webkit-user-modify:read-write;overflow-wrap:break-word;-webkit-line-break:after-white-space;-webkit-user-select:auto}:where([draggable=true]){-webkit-user-drag:element}:where(dialog:modal){all:revert;box-sizing:border-box}::-webkit-details-marker{display:none}
