@import"https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Josefin+Sans:ital,wght@0,100..700;1,100..700&family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&family=Roboto:ital,wght@0,100..900;1,100..900&display=swap";@import"https://fonts.googleapis.com/css2?family=Barrio&family=Funnel+Display:wght@300..800&family=Rock+Salt&family=Zen+Loop:ital@0;1&display=swap";@import"https://fonts.googleapis.com/css2?family=Homemade+Apple&display=swap";body,html,:root{--font-inter: "Inter", sans-serif;--font-josefin-sans: "Josefin Sans", sans-serif;--font-zen-loop: "Zen Loop", cursive;--font-poppins: "Poppins", sans-serif;--font-roboto: "Roboto", sans-serif;--font-dm-sans: "DM Sans", sans-serif;--font-krona: "Krona One", sans-serif;--font-do-hyeon: "Do Hyeon", sans-serif;--font-homemade-apple: "Homemade Apple", cursive;--tiny: .625rem;--small: .75rem;--s-regular: .875rem;--s-medium: 1rem;--big: 1.25rem;--large: 1.5rem;--xlarge: 2rem;--xxlarge: 2rem;--large-40: 2.5rem;--large-60: 3.75rem;--large-80: 5rem;--large-96: 6rem;--extra-light: 200;--light: 300;--regular: 400;--medium: 500;--semi-bold: 600;--bold: 700;--extra-bold: 800;--black: 900;--border-radius-small: 4px;--border-radius-medium: 6px;--border-radius-large: 12px;--border-radius-circle: 50%;--border-radius-xlarge: 16px;--border-radius-extra-large: 20px;--border-radius-xxx: 30px;--yellow-dark: #c2a80c;--text-color: #f1f2f2;--hidden-text: #171717;--text-gray-color: #565656;--accent: #fcff00;--background-main: #000;--background-card: #121212;--background-card-2: #1f1f1f;--cursor-pointer: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNDQiIGhlaWdodD0iNDQiIHZpZXdCb3g9IjAgMCA0NCA0NCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48Y2lyY2xlIGN4PSIyMiIgY3k9IjIyIiByPSIxOCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjZmNmZjAwIiBzdHJva2Utd2lkdGg9IjQiLz48L3N2Zz4=) 22 22, auto;--cursor-default: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzIiIGhlaWdodD0iMzIiIHZpZXdCb3g9IjAgMCAzMiAzMiIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48Y2lyY2xlIGN4PSIxNiIgY3k9IjE2IiByPSI2IiBmaWxsPSIjZmNmZjAwIi8+PC9zdmc+) 16 16, auto}*{margin:0;padding:0;box-sizing:border-box;font-family:var(--font-dm-sans);cursor:var(--cursor-default)}body{color:#ffffffde;background-color:var(--background-main);font-family:var(--font-dm-sans)}a{font-weight:var(--medium);color:var(--accent);text-decoration:inherit}a:hover{color:#ffd900}button{border:none;outline:none;font-weight:var(--medium);font-family:inherit;transition:border-color .25s}::selection{background-color:var(--accent);color:#020202}::-moz-selection{background-color:var(--accent);color:#fff}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:#0a0a0a}::-webkit-scrollbar-thumb{background:var(--accent);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#d4d600}.latest-work-section{padding:clamp(3rem,8vw,6rem) 1.5rem;color:var(--text-color)}.latest-work-frame{max-width:1200px;margin:0 auto;background:var(--background-card);color:var(--text-color);border-radius:36px;padding:clamp(2rem,5vw,4.5rem);overflow:hidden}.projects-heading{text-align:center;max-width:640px;margin:0 auto}.projects-eyebrow{font-size:var(--small);letter-spacing:.24em;color:var(--accent);margin-bottom:.75rem;font-weight:600;font-family:var(--font-homemade-apple)}.projects-heading h2{font-size:clamp(2.5rem,4vw,3.75rem);font-family:var(--font-josefin-sans);letter-spacing:.08em;margin-bottom:.75rem;color:var(--text-color)}.projects-subtitle{color:var(--text-gray-color);font-size:1rem;line-height:1.6}.projects-zigzag{margin-top:clamp(2rem,5vw,3.5rem);display:flex;flex-direction:column;gap:clamp(2rem,4vw,4rem)}.zigzag-row{display:flex;flex-direction:row;gap:2rem;align-items:center;justify-content:space-between}.project-visual-link{flex:1.3;text-decoration:none;color:inherit;width:50%}.project-visual-card{background:var(--background-card-2);border-radius:32px;padding:6px;border:1px solid var(--hidden-text);transform:rotate(-2deg);transition:transform .4s ease,box-shadow .4s ease}.project-card-media{border-radius:24px;overflow:hidden;background:var(--background-main);min-height:240px}.project-card-media img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}.project-details{flex:1;padding:clamp(1.5rem,3vw,2.5rem);display:flex;flex-direction:column}.project-details h3{font-size:clamp(1.75rem,3vw,2.25rem);margin-bottom:.75rem;color:var(--text-color)}.project-details p{color:var(--text-gray-color);line-height:1.7;margin-bottom:1.5rem;font-size:1rem;max-width:420px}.project-card-meta{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;margin-bottom:1rem}.project-pill{font-size:.8rem;text-transform:capitalize;padding:.35rem .85rem;border-radius:999px;background:var(--background-card);color:var(--text-color);border:1px solid var(--hidden-text)}.pill-muted{background:var(--background-main);color:var(--text-gray-color);border-color:transparent}.pill-outline{background:transparent;border-color:var(--text-gray-color);color:var(--text-color)}.project-details-link{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;color:var(--accent);text-decoration:none;border-bottom:2px solid currentColor;width:fit-content}.project-visual-link:hover .project-visual-card{transform:rotate(0) translateY(0);box-shadow:0 30px 80px #0006}.project-visual-link:hover .project-card-media img{transform:scale(1.05)}.zigzag-row.is-reverse,.zigzag-row.is-reverse .project-visual-link{flex-direction:row-reverse}.zigzag-row.is-reverse .project-details{text-align:right;align-items:flex-end}.projects-cta{margin-top:clamp(2rem,4vw,3rem);display:flex;flex-direction:column;align-items:center;gap:.5rem}.projects-cta-link{padding:.85rem 2.5rem;border-radius:999px;background:var(--accent);color:var(--hidden-text);border:1px solid transparent;font-weight:600;font-size:.95rem}.projects-cta-link:hover{color:var(--hidden-text)}.projects-cta-hint{color:var(--text-gray-color);font-size:.9rem}@media(max-width:1024px){.zigzag-row{flex-direction:column;align-items:stretch}.project-visual-link,.project-details{width:100%}.zigzag-row.is-reverse .project-details{text-align:left;align-items:flex-start}}@media(max-width:768px){.latest-work-section{padding:2rem 1rem}.latest-work-frame{padding:clamp(1.5rem,4vw,2.5rem)}.projects-heading h2{font-size:clamp(2rem,5vw,2.5rem)}.zigzag-row{gap:1.5rem}.project-details{padding:clamp(1rem,2vw,1.5rem)}.project-details h3{font-size:clamp(1.5rem,4vw,1.75rem)}.project-details p{font-size:.95rem}}@media(max-width:768px){.latest-work-frame{border-radius:28px}.zigzag-row,.zigzag-row.is-reverse{flex-direction:column}.zigzag-row.is-reverse .project-details{text-align:left;align-items:flex-end}.project-visual-card{transform:rotate(-1deg)}.project-details{margin-top:1rem}.project-card-meta{gap:.4rem}.project-pill{font-size:.75rem;padding:.3rem .7rem}}#gallery{padding:4rem 2rem;max-width:1200px;margin:0 auto 120px}.gallery-container{position:relative}.gallery-container .dummy-shape-div{position:absolute;bottom:-40px;right:10%}.gallery-container .header{display:flex;align-items:center;justify-content:space-between}.gallery-container .header .title{font-size:var(--xxlarge)}.gallery-container .grid-gallery{display:flex;gap:8px;max-width:1200px;overflow-x:auto;overflow-y:hidden;cursor:grab;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none}.gallery-container .grid-gallery::-webkit-scrollbar:horizontal{display:none;height:0}.gallery-container .grid-gallery::-webkit-scrollbar{width:8px;height:0}.gallery-container .grid-gallery::-webkit-scrollbar-track{background:var(--background-card);border-radius:4px}.gallery-container .grid-gallery::-webkit-scrollbar-thumb{background:var(--accent);border-radius:4px}.gallery-container .grid-gallery::-webkit-scrollbar-thumb:hover{background:#ffd900}.gallery-container .grid-gallery:active{cursor:grabbing}.gallery-container .card-image-container-small{width:264px;min-width:264px;height:386px;overflow:hidden;border-radius:0}.gallery-container .card-image{-webkit-user-select:none;user-select:none;-webkit-user-drag:none;-khtml-user-drag:none;-moz-user-drag:none;-o-user-drag:none}.modal-backdrop{position:fixed;inset:0;background-color:#0009;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000;padding:2rem;height:100vh;width:100vw}.modal-content{max-width:90%;max-height:90%;display:flex;flex-direction:column;align-items:center;gap:1.5rem;position:relative;animation:modal-content-animation .3s ease-in-out forwards;position:absolute}.home-modal-image-container{position:relative;width:100%;display:flex;justify-content:center;align-items:center}.home-modal-image-skeleton{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;display:flex;align-items:center;justify-content:center}.home-modal-skeleton-inner{width:100%;max-width:90vw;height:100%;max-height:80vh;border-radius:var(--border-radius-medium)}.home-modal-image{position:relative;z-index:2;max-width:90vw;max-height:80vh;object-fit:contain;box-shadow:0 8px 32px #00000080;transition:opacity .3s ease;animation:modal-image-animation .5s ease-in-out forwards}.home-modal-image.loading{opacity:0}.home-modal-image.loaded{opacity:1}.btn-close{background-color:transparent;border-radius:50%;cursor:var(--cursor-pointer);transition:all .3s ease;height:60px;width:60px;display:flex;align-items:center;justify-content:center}.btn-close:hover{background-color:var(--accent)}@media(max-width:1024px){#gallery{padding:3rem 1.5rem}.card-image-container-small{width:220px;min-width:220px;height:320px}}@media(max-width:768px){#gallery{padding:2rem 1rem;margin-bottom:80px}.gallery-container .header .title{font-size:var(--large)}.card-image-container-small{width:180px;min-width:180px;height:260px}.modal-backdrop{padding:1rem}.modal-content{max-width:95%;max-height:95%}.home-modal-image{max-height:60vh}.btn-close{height:50px;width:50px}}@media(max-width:480px){.card-image-container-small{width:150px;min-width:150px;height:220px}}.skeleton{display:inline-block;background:var(--background-card-2);border-radius:var(--border-radius-small);position:relative;overflow:hidden}.skeleton-rectangular{border-radius:var(--border-radius-small)}.skeleton-circular{border-radius:var(--border-radius-circle)}.skeleton-text{border-radius:var(--border-radius-small);height:1em}.skeleton-image{border-radius:var(--border-radius-medium);aspect-ratio:16 / 9}.skeleton-pulse{animation:skeleton-pulse 1.5s ease-in-out infinite}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.5}}.skeleton-wave{position:relative;overflow:hidden}.skeleton-wave:after{content:"";position:absolute;inset:0;transform:translate(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);animation:skeleton-wave 1.5s infinite}@keyframes skeleton-wave{0%{transform:translate(-100%)}to{transform:translate(100%)}}.about-container{position:relative;max-width:1200px;margin:0 auto;height:100vh;max-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:2rem;padding:0 2rem}.about-container h2{font-size:clamp(2.5rem,4vw,3.75rem);font-family:var(--font-josefin-sans);letter-spacing:.08em;margin-bottom:.75rem;color:var(--text-color);text-align:center;margin-bottom:2rem}.about-container .content-container{display:flex;align-items:center;justify-content:center;gap:2rem}.about-container .content-container .content{flex:1}.about-container .content-container .image-container{flex:1;height:430px;display:flex;align-items:center;justify-content:center}.about-container .content-container .image-container .about-image{height:100%;object-fit:cover}@media(max-width:768px){.about-container{height:auto;min-height:100vh;padding:2rem 1rem;gap:1.5rem}.about-container h2{font-size:clamp(2rem,5vw,2.5rem);margin-bottom:1.5rem}.content-container{flex-direction:column;gap:1.5rem}.image-container{display:none!important}.content-container .content{width:100%;text-align:center}.content-container .content p{font-size:.95rem;line-height:1.6}}body{background:#000;margin:0;font-family:sans-serif}.contact-container{position:relative;width:100%;height:100vh;text-align:center;transform:scale(1);display:flex;justify-content:center;align-items:center;gap:4rem}@media(max-width:1024px){.contact-container{gap:3rem}.line-1,.line-2{font-size:clamp(2rem,4vw,var(--large-40))}.block{margin-top:8rem}.block .email{font-size:clamp(1.25rem,3vw,var(--large))}}@media(max-width:768px){.contact-container{transform:scale(.6);flex-direction:column;gap:2rem}.block{margin-top:6rem;gap:.75rem}.block .resume{padding:.75rem 2rem;font-size:1rem}}@media(max-width:480px){.contact-container{gap:1.5rem}.block{margin-top:4rem}}.line-1,.line-2{font-size:var(--large-40);font-family:var(--font-krona);color:#fff;margin:5px 0}.block{margin-top:12rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.block .email{font-size:var(--large);font-family:var(--font-krona);text-decoration:none;transition:color .3s ease;width:fit-content}.block .email:hover{text-decoration:underline;color:var(--accent)}.block .resume{padding:.85rem 2.5rem;border-radius:999px;background:var(--accent);color:var(--hidden-text);border:1px solid transparent;font-weight:600;font-size:.95rem;text-transform:capitalize}.timeline-page{min-height:100vh;background-color:#000;color:#fff;padding:4rem 2rem;position:relative;overflow-x:hidden;max-width:1200px;margin:0 auto;border-top:1px solid var(--text-gray-color);display:flex;flex-direction:column;justify-content:center;align-items:center}.timeline-top-section{position:relative;width:100%;min-height:260px;padding:2rem 0}.person-graphic{position:absolute;left:3%;top:5%;z-index:1}.person-svg{filter:drop-shadow(0 0 15px rgba(252,255,0,.4))}.hand-graphic{position:absolute;left:22%;top:15%;z-index:2}.hand-svg{filter:drop-shadow(0 0 10px rgba(255,255,255,.6))}.skill-label{position:absolute;color:#fff;font-size:1.1rem;font-weight:500;white-space:nowrap;z-index:3;font-family:var(--font-inter)}.pill-1{top:40%;left:40%;background-color:#2a2a2a;width:fit-content;padding:.6rem 1.2rem;border-radius:25px}.pill-2{top:25%;left:58%;background-color:transparent;color:#fff}.pill-3{top:70%;left:58%;background-color:transparent;color:#fff}.pill-4{top:45%;left:68%;background-color:#2a2a2a;width:fit-content;padding:.6rem 1.2rem;border-radius:25px}.pill-5{top:12%;left:78%;background-color:transparent;border:2.5px solid #fcff00;border-radius:50%;padding:.6rem 1rem;width:fit-content;height:fit-content;display:flex;align-items:center;justify-content:center}.yellow-circle{color:#fff}.pill-6{top:8%;left:52%;background-color:transparent;color:#fff}.timeline-bottom-section{width:100%}.timeline-container{display:flex;justify-content:space-evenly;align-items:flex-start;gap:2rem;flex-wrap:wrap;margin:0 auto}.timeline-item{flex:1;min-width:280px;max-width:400px;display:flex;flex-direction:column;gap:1.5rem}.timeline-text{display:flex;align-items:center;gap:.5rem;font-size:1rem;color:#fff;white-space:nowrap}.timeline-date{font-weight:600}.timeline-flag{font-size:.8rem}.timeline-location{text-transform:lowercase;color:var(--text-gray-color)}.timeline-image{width:116px;height:134px;overflow:hidden;position:relative;background-color:#1a1a1a}.grayscale-image{width:100%;height:100%;object-fit:cover;filter:grayscale(100%);transition:filter .3s ease;display:block}.grayscale-image:hover{filter:grayscale(80%)}.placeholder-image{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:#1a1a1a;color:#565656;font-size:1.2rem;text-align:center;border:2px dashed #2a2a2a;border-radius:8px;padding:1rem;line-height:1.6}@media(max-width:1024px){.timeline-top-section{min-height:350px}.person-graphic{left:2%}.hand-graphic{left:20%}.skill-label{font-size:.9rem}.pill-1{left:40%}.pill-2{left:55%}.pill-3{left:45%}.pill-4{left:65%}.pill-5{left:70%}.pill-6{left:50%}}@media(max-width:768px){.timeline-page{padding:2rem 1rem}.timeline-top-section{display:none}.timeline-bottom-section{width:100%}.timeline-container{flex-direction:column;align-items:stretch;gap:1.5rem}.timeline-item{width:100%;max-width:100%;min-width:auto;gap:1rem}.timeline-text{font-size:.9rem;flex-wrap:wrap}.timeline-image{width:100%;height:140px}}@media(max-width:480px){.timeline-page{padding:1.5rem .75rem}.timeline-item{gap:1rem}.timeline-text{font-size:.85rem;gap:.4rem}.timeline-image{height:140px}}.works-container{max-width:1200px;margin:0 auto;padding:120px 40px 40px}.category-section{margin-bottom:3rem}.category-heading{font-size:1.5rem;font-weight:600;color:inherit}.empty-category{color:#999;font-style:italic;margin-bottom:1rem}.card-image-project{aspect-ratio:4 / 1;object-fit:cover;width:100%}.card-image-gallery{aspect-ratio:4 / 3;object-fit:cover;width:100%}.card-image-comic{aspect-ratio:4 / 6;object-fit:cover;width:100%;max-width:160px;margin:0 auto;display:block}@keyframes modal-image-animation{0%{scale:.4;opacity:0}to{scale:1;opacity:1}}@keyframes modal-content-animation{0%{opacity:0}to{opacity:1}}.modal-image-container{position:relative;width:100%;display:flex;justify-content:center;align-items:center;overflow:hidden;transition:transform .3s ease-in-out}.modal-image-skeleton{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;display:flex;align-items:center;justify-content:center}.modal-skeleton-inner{width:100%;height:100%;max-height:80vh;border-radius:var(--border-radius-medium)}.modal-image{position:relative;z-index:2;max-width:100%;max-height:70vh;object-fit:contain;box-shadow:0 8px 32px #00000080;transition:opacity .3s ease}.modal-image.loading{opacity:0}.modal-image.loaded{opacity:1}.modal-image.modal-image-initial{animation:modal-image-animation .5s ease-in-out forwards}.modal-image.slide-out-left{animation:slide-out-left .3s ease-in-out forwards!important}.modal-image.slide-out-right{animation:slide-out-right .3s ease-in-out forwards!important}.modal-image.slide-in-right{animation:slide-in-from-right .3s ease-in-out forwards!important}.modal-image.slide-in-left{animation:slide-in-from-left .3s ease-in-out forwards!important}@keyframes slide-out-left{0%{transform:translate(0);opacity:1}to{transform:translate(-100%);opacity:0}}@keyframes slide-out-right{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}@keyframes slide-in-from-left{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slide-in-from-right{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.btn-close{background-color:transparent;border:none;border-radius:50%;cursor:var(--cursor-pointer);transition:all .3s ease;height:60px;width:60px;display:flex;align-items:center;justify-content:center;color:#fff}.btn-close:hover{background-color:var(--accent, #ffd700)}.btn-close:hover svg{filter:invert(1)}.btn-nav{position:fixed;top:50%;background-color:transparent;border:2px solid var(--accent);border-radius:50%;cursor:var(--cursor-pointer);transition:all .3s ease;height:60px;width:60px;display:flex;align-items:center;justify-content:center;color:#fff;z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-nav:hover{background-color:var(--accent)}.btn-nav:hover path{fill:var(--background-main)}.btn-nav-prev{left:40px;transform:translateY(-50%) scale(-1)}.btn-nav-next{transform:translateY(-50%);right:40px}.arrow-icon{display:flex;align-items:center;justify-content:center}.arrow-left{pointer-events:none}.btn-nav svg{width:24px;height:24px;transition:transform .3s ease}.btn-nav:hover svg{transform:scale(1.2)}@media(max-width:768px){.btn-nav{height:50px;width:50px}.btn-nav-prev{left:10px}.btn-nav-next{right:10px}.btn-nav svg{width:20px;height:20px}}.project-page-container{max-width:1200px;margin:0 auto;padding:100px 40px 40px;min-height:100vh}.project-error{max-width:800px;margin:0 auto;padding:120px 40px 40px;text-align:center;min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center}.project-error h1{font-size:clamp(2rem,5vw,3rem);margin-bottom:1rem;color:var(--text-color);font-family:var(--font-josefin-sans)}.project-error p{color:var(--text-gray-color);font-size:1.1rem;margin-bottom:2rem;line-height:1.6}.project-error-link{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--background-card);color:var(--accent);text-decoration:none;border-radius:8px;border:1px solid rgba(255,255,255,.1);transition:all .3s ease;font-weight:600}.project-error-link:hover{background:var(--background-card-2);transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.project-header{margin-bottom:3rem}.project-header-content{display:flex;gap:3rem;align-items:flex-start;margin-bottom:2rem}.project-thumbnail{flex-shrink:0;width:200px;height:300px;border-radius:16px;overflow:hidden;background:var(--background-card-2);border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 24px #0000004d}.project-thumbnail img{width:100%;height:100%;object-fit:cover;display:block}.project-info{flex:1}.project-title{font-size:clamp(2rem,4vw,3rem);font-family:var(--font-josefin-sans);font-weight:700;margin-bottom:1rem;color:var(--text-color);letter-spacing:-.02em}.project-description{font-size:1.1rem;line-height:1.8;color:var(--text-gray-color);margin-bottom:1.5rem;max-width:600px}.project-meta{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;margin-bottom:1.5rem}.project-meta-item{display:flex;align-items:center;gap:.5rem;font-size:.95rem;color:var(--text-gray-color)}.project-meta-item strong{color:var(--text-color);font-weight:600}.project-badge{display:inline-flex;align-items:center;padding:.4rem 1rem;border-radius:999px;font-size:.85rem;font-weight:600;text-transform:capitalize}.badge-category{background:var(--background-card);color:var(--accent);border:1px solid rgba(252,255,0,.2)}.badge-status{background:var(--background-card-2);color:var(--text-color);border:1px solid rgba(255,255,255,.1)}.badge-beta{background:#fcff001a;color:var(--accent);border:1px solid rgba(252,255,0,.3)}.project-chapters{margin-top:4rem}.chapters-heading{font-size:clamp(1.75rem,3vw,2.25rem);font-family:var(--font-josefin-sans);font-weight:700;margin-bottom:2rem;color:var(--text-color);display:flex;align-items:center;gap:1rem}.chapters-heading:after{content:"";flex:1;height:1px;background:linear-gradient(to right,rgba(255,255,255,.2),transparent)}.chapters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.chapter-card{background:var(--background-card);border-radius:12px;padding:1.5rem;border:1px solid rgba(255,255,255,.1);transition:all .3s ease;text-decoration:none;color:inherit;display:block;cursor:var(--cursor-pointer);position:relative;overflow:hidden}.chapter-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.chapter-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0006;border-color:#fcff004d}.chapter-card:hover:before{transform:scaleX(1)}.chapter-title{font-size:1.25rem;font-weight:600;margin-bottom:.5rem;color:var(--text-color);font-family:var(--font-josefin-sans);pointer-events:none}.chapter-pages-count{font-size:.9rem;color:var(--text-gray-color);display:flex;align-items:center;gap:.5rem;pointer-events:none}.chapter-pages-count:before{content:"📄";font-size:1rem}.project-back-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--accent);text-decoration:none;font-weight:600;margin-bottom:2rem;transition:all .3s ease;padding:.5rem 0}.project-back-link:hover{gap:.75rem;opacity:.9}.project-back-link:before{content:"←";font-size:1.2rem;transition:transform .3s ease}.project-back-link:hover:before{transform:translate(-4px)}@media(max-width:768px){.project-page-container{padding:100px 20px 20px}.project-header-content{flex-direction:column;gap:2rem}.project-thumbnail{width:100%;max-width:300px;height:400px;margin:0 auto}.project-title{font-size:clamp(1.75rem,5vw,2.25rem)}.project-description{font-size:1rem}.project-meta{flex-direction:column;align-items:flex-start;gap:.75rem}.chapters-grid{grid-template-columns:1fr;gap:1rem}.chapter-card{padding:1.25rem}.project-error{padding:80px 20px 20px}}@media(max-width:480px){.project-thumbnail{height:300px}.chapters-heading{font-size:1.5rem}.chapter-title{font-size:1.1rem}}.lazy-image-skeleton{width:100%;position:absolute;top:0;left:0;z-index:1}.lazy-image-skeleton-inner{width:100%;height:100%;min-height:400px}.lazy-image-error{width:100%;aspect-ratio:2 / 3;display:flex;align-items:center;justify-content:center;background-color:var(--background-card-2);border-radius:var(--border-radius-medium);color:var(--text-gray-color);position:absolute;top:0;left:0;z-index:1}.lazy-image-error p{margin:0;font-size:.875rem}.lazy-image{width:100%;height:auto;display:block;opacity:0;transition:opacity .3s ease;position:relative;z-index:2}.lazy-image.error{display:none}@media(max-width:768px){.lazy-image-container,.lazy-image-skeleton-inner{min-height:300px}}.section-container{padding:4rem 2rem;max-width:1200px;margin:0 auto}.section-title{font-size:2.5rem;margin-bottom:3rem;text-align:center}.grid-projects{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem;margin-bottom:3rem}.grid-works{display:flex;flex-wrap:wrap;gap:2rem;padding:2rem 0}.card{text-decoration:none;color:inherit;display:block;background-color:#1a1a1a;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease;cursor:var(--cursor-pointer)}.card:hover{transform:translateY(-8px);box-shadow:0 12px 24px #0000004d}.card-works{text-decoration:none;color:inherit;display:block;border:1px solid #333;overflow:hidden;border:none;transition:transform .2s,box-shadow .2s;width:fit-content;max-width:calc(33.333% - 1.34rem)}.gallery-container .card-works{max-width:calc(19.6% - 1.34rem)}@media(max-width:768px){.gallery-container .card-works,.comics-container .card-works{max-width:calc(50% - .8rem)}}.card-image-container{width:100%;height:240px;overflow:hidden;background-color:#0a0a0a}.card-image-container-works{width:100%;height:200px;overflow:hidden}.card-image{width:100%;height:100%;object-fit:cover;margin:0;transition:transform .3s ease}.card-image:hover{transform:scale(1.05)}.card-content{padding:1.5rem}.card-content-small{padding:1rem}.card-title{margin:0 0 .75rem;font-size:1.5rem;font-weight:600}.card-title-medium{margin:0 0 .5rem;font-size:1.3rem;font-weight:600}.card-title-small{margin:0 0 .5rem;font-size:1.2rem}.card-description{margin:0 0 1rem;font-size:.95rem;color:#aaa;line-height:1.6}.card-description-small{margin:0 0 .75rem;font-size:.9rem;color:#aaa;line-height:1.5}.card-description-works{margin:0 0 .5rem;font-size:.9rem;color:#888}.badge-container{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.badge{font-size:.8rem;padding:.35rem .75rem;background-color:#2a2a2a;border-radius:6px;text-transform:capitalize;border:1px solid #3a3a3a;display:inline-block}.badge-category{font-size:.8rem;padding:.25rem .5rem;background-color:#333;border-radius:4px;text-transform:capitalize}.badge-beta{font-size:.8rem;padding:.35rem .75rem;background-color:#3a2a1a;color:#fa0;border-radius:6px;border:1px solid #4a3a2a}.badge-beta-small{font-size:.8rem;color:#888}.badge-live{font-size:.8rem;padding:.35rem .75rem;background-color:#1a3a2a;color:#4ade80;border-radius:6px;border:1px solid #2a4a3a}.badge-live-small{font-size:.8rem;padding:.25rem .5rem;background-color:#1a3a2a;color:#4ade80;border-radius:4px}.badge-featured{font-size:.8rem;color:gold}.btn-primary{display:inline-block;padding:.75rem 2rem;background-color:transparent;border:2px solid #333;border-radius:8px;text-decoration:none;color:inherit;font-size:1rem;transition:all .3s ease;font-weight:500;text-align:center}.btn-primary:hover{border-color:#555;background-color:#2a2a2a}.center-container{text-align:center}.form-container{max-width:500px}.form-group{margin-bottom:1rem}.form-label{display:block;margin-bottom:.5rem}.form-input{width:100%;padding:.5rem}.form-button{padding:.5rem 1rem;cursor:var(--cursor-pointer)}.nav-container{margin-top:2rem;padding:1rem;border:1px solid #333;border-radius:4px}.nav-links{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.nav-section{margin-top:1rem}.tech-stack-section{padding:2rem 0}.tech-marquee-container{overflow:hidden;width:100%}.tech-marquee{display:flex;gap:3rem;width:fit-content}.tech-marquee-content{display:flex;gap:3rem;align-items:center}.tech-item{display:flex;flex-direction:column;align-items:center;gap:.5rem;min-width:80px;flex-shrink:0}.tech-icon-container{display:flex;align-items:center;justify-content:center;width:150px;height:150px;border-radius:50%;border:1px solid var(--text-color)}.tech-name{font-size:.875rem;color:#888}@media(max-width:1024px){.section-container{padding:3rem 1.5rem}.section-title{font-size:2rem;margin-bottom:2rem}.grid-projects{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.tech-icon-container{width:120px;height:120px}.tech-marquee,.tech-marquee-content{gap:2rem}}@media(max-width:768px){.section-container{padding:2rem 1rem}.section-title{font-size:1.75rem;margin-bottom:1.5rem}.grid-projects{grid-template-columns:1fr;gap:1.5rem}.card-content{padding:1.25rem}.card-title{font-size:1.25rem}.card-description{font-size:.9rem}.tech-stack-section{padding:1.5rem 0}.tech-icon-container{width:100px;height:100px}.tech-item{min-width:70px}.tech-marquee,.tech-marquee-content,.grid-works{gap:1.5rem}.card-works{max-width:100%}}@media(max-width:480px){.section-title{font-size:1.5rem}.card-content{padding:1rem}.card-title{font-size:1.1rem}.tech-icon-container{width:80px;height:80px}.tech-item{min-width:60px}}.chapter-container{max-width:1200px;margin:0 auto;padding:120px 40px 40px;min-height:100vh}.chapter-header{text-align:center;margin-bottom:1rem}.chapter-header h1{font-size:2.5rem;margin-bottom:1rem;color:inherit}.chapter-subtitle{font-size:1.1rem;color:#999;margin:0}.nav-container{display:flex;justify-content:center;margin:0;padding:1.5rem;border-radius:8px;border:none;outline:none}.nav-container.nav-bottom{margin-top:4rem}.nav-links{display:flex;gap:2rem;flex-wrap:wrap;justify-content:center;align-items:center}.nav-link{color:var(--accent, #ffd700);text-decoration:none;font-weight:500;transition:all .5s ease;padding:.5rem 1rem;border-radius:24px}.nav-link:hover{color:var(--background-main);background-color:var(--accent)}.comic-pages-container{display:flex;flex-direction:column;align-items:center;margin-bottom:3rem}.comic-page-wrapper{width:100%;max-width:800px;display:flex;flex-direction:column;align-items:center;position:relative}.comic-page-image{width:100%;height:auto;display:block;border-radius:8px}.comic-page-number{margin-top:1rem;font-size:.9rem;color:#999;font-weight:500}.comic-page-placeholder{width:100%;aspect-ratio:2 / 3;display:flex;align-items:center;justify-content:center;background-color:var(--background-card, #1a1a1a);border-radius:8px;color:#666;font-size:1.2rem}.lazy-image-container{width:100%;position:relative;min-height:400px}.lazy-image-placeholder{width:100%;aspect-ratio:2 / 3;display:flex;align-items:center;justify-content:center;background-color:var(--background-card, #1a1a1a);border-radius:8px;position:absolute;top:0;left:0}.lazy-image-spinner{width:40px;height:40px;border:3px solid rgba(255,215,0,.2);border-top-color:var(--accent, #ffd700);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.lazy-image{width:100%;height:auto;display:block;opacity:0;transition:opacity .3s ease}.lazy-image.loaded{opacity:1}@media(max-width:768px){.chapter-container{padding:100px 20px 20px}.chapter-header h1{font-size:2rem}.nav-links{flex-direction:column;gap:1rem}.lazy-image-container{min-height:300px}}.not-found-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background-color:var(--background-main)}.not-found-content{max-width:600px;text-align:center;padding:3rem 2rem}.not-found-title{font-size:clamp(4rem,10vw,8rem);font-weight:var(--black);margin-bottom:1rem;color:var(--accent);font-family:var(--font-josefin-sans);line-height:1;letter-spacing:-.02em}.not-found-subtitle{font-size:clamp(1.5rem,4vw,2.5rem);margin-bottom:1rem;color:var(--text-color);font-family:var(--font-josefin-sans);font-weight:var(--bold)}.not-found-description{color:var(--text-gray-color);font-size:1.1rem;margin-bottom:2.5rem;line-height:1.6}.not-found-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.not-found-button{display:inline-flex;align-items:center;padding:.75rem 1.5rem;background:var(--accent);color:var(--hidden-text);text-decoration:none;border-radius:var(--border-radius-medium);font-weight:var(--medium);transition:all .3s ease;border:none;cursor:pointer}.not-found-button:hover{background:#ffd900;transform:translateY(-2px);box-shadow:0 4px 12px #fcff004d}.not-found-link{display:inline-flex;align-items:center;padding:.75rem 1.5rem;background:var(--background-card);color:var(--accent);text-decoration:none;border-radius:var(--border-radius-medium);border:1px solid rgba(255,255,255,.1);font-weight:var(--medium);transition:all .3s ease}.not-found-link:hover{background:var(--background-card-2);transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}nav{margin:auto;margin-bottom:2rem;padding:1rem;display:flex;justify-content:center;align-items:center;gap:1rem;position:fixed;top:26px;left:50%;transform:translate(-50%);z-index:10;padding:12px 12px 12px 28px;border-radius:50px;background:#00000080;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 4px 30px #0000001a;-webkit-box-shadow:0 4px 30px rgba(0,0,0,.1);-moz-box-shadow:0 4px 30px rgba(0,0,0,.1);-ms-box-shadow:0 4px 30px rgba(0,0,0,.1);-o-box-shadow:0 4px 30px rgba(0,0,0,.1)}nav a{color:inherit;text-decoration:none;transition:color .3s ease}nav a:hover{color:var(--accent)}.contact-me-btn{color:var(--accent);padding:6px 16px;border-radius:20px;font-size:inherit;font-family:inherit;cursor:pointer;transition:all .3s ease;font-weight:var(--medium);background:#fcff001a;position:relative;overflow:hidden}.contact-me-btn span{display:inline-block}.contact-me-btn:hover{border-color:var(--accent);color:var(--accent)}.contact-me-btn:active{transform:scale(.98)}.home-container,.works-container{position:relative;z-index:2;width:100%;margin:0 auto}.hero-main-wrapper{position:relative;z-index:2;height:100vh;width:100%;background-image:url(/assets/bg-gray-CHrAqrPO.png);background-size:cover;background-position:center;background-repeat:no-repeat}.hero-main-wrapper:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:120px;background:linear-gradient(to top,var(--background-main) 20%,transparent 100%)}.hero-main-wrapper .hero-bg-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-image:url(/assets/bg-color-M0cYfzHc.png);background-size:cover;background-position:center;background-repeat:no-repeat;pointer-events:none;z-index:1;--mouse-x: -999px;--mouse-y: -999px;mask-image:radial-gradient(circle 280px at var(--mouse-x) var(--mouse-y),black 30%,transparent 100%);-webkit-mask-image:radial-gradient(circle 280px at var(--mouse-x) var(--mouse-y),black 30%,transparent 100%)}.hero-main-wrapper .hero-bg-overlay:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:120px;background:linear-gradient(to top,var(--background-main) 20%,transparent 100%)}@media(max-width:768px){.hero-main-wrapper .hero-bg-overlay{display:none}}.hero-main-wrapper .hero-text-wrapper{position:relative;z-index:2;-webkit-user-select:none;user-select:none;display:flex;justify-content:center;align-items:center;flex-direction:column;height:100%;width:100%}.hero-main-wrapper .hero-text-wrapper .hero-title-wrapper{overflow:hidden}.hero-main-wrapper .hero-text-wrapper .hero-title-wrapper .hero-title{background-color:var(--background-main);padding:2px 10px;font-size:var(--big);font-weight:var(--light);font-family:var(--font-baren-outline)}.hero-main-wrapper .hero-text-wrapper .hero-title-wrapper .hero-title span{color:var(--accent);font-weight:var(--bold);font-family:var(--font-baren-vintage)}@media(max-width:768px){.hero-main-wrapper .hero-text-wrapper .hero-title-wrapper .hero-title{font-size:var(--small)!important;margin-bottom:20px}}.hero-main-wrapper .hero-text-wrapper .hero-subtitle{overflow:hidden}.hero-main-wrapper .hero-text-wrapper .hero-subtitle .content{font-size:var(--large-80);font-weight:var(--semi-bold)}.hero-main-wrapper .hero-text-wrapper .hero-subtitle .content .span{margin:0 18px;color:var(--accent);font-size:var(--large-40);text-shadow:none;background:transparent}@media(max-width:768px){.hero-main-wrapper .hero-text-wrapper .hero-subtitle .content{display:flex;text-align:center}.hero-main-wrapper .hero-text-wrapper .hero-subtitle .content span,.hero-main-wrapper .hero-text-wrapper .hero-subtitle .content .span{font-size:var(--big)}}.fixed-content-wrapper .logo{position:fixed;top:20px;left:20px;z-index:10;font-size:var(--large-40);font-weight:var(--bold);color:var(--accent);pointer-events:all}.fixed-content-wrapper .social-media-links{position:fixed;bottom:20px;left:20px;z-index:10;display:flex;gap:10px}.fixed-content-wrapper .social-media-links a{pointer-events:all;filter:saturate(0);transition:filter .3s ease-in-out}.fixed-content-wrapper .social-media-links a:hover{filter:saturate(1)}@media(max-width:1024px){nav{padding:10px 24px;font-size:.95rem}.hero-main-wrapper .hero-text-wrapper .hero-title-wrapper .hero-title{font-size:clamp(2rem,5vw,var(--big))}.hero-main-wrapper .hero-text-wrapper .hero-subtitle .content{font-size:clamp(1.5rem,4vw,var(--large-80))}}@media(max-width:768px){nav{padding:8px 20px;font-size:.85rem;top:20px}.fixed-content-wrapper .logo{font-size:var(--large);top:15px;left:15px}.fixed-content-wrapper .social-media-links{bottom:15px;left:15px;gap:8px}.fixed-content-wrapper .social-media-links a{width:32px;height:32px}.hero-main-wrapper .hero-text-wrapper{padding:0 1rem}}@media(max-width:480px){nav{padding:6px 16px;font-size:.75rem}.fixed-content-wrapper .logo{font-size:var(--medium);top:10px;left:10px}.fixed-content-wrapper .social-media-links{bottom:10px;left:10px;gap:6px}.fixed-content-wrapper .social-media-links a{width:28px;height:28px}}.cb-cursor{position:fixed;top:0;left:0;pointer-events:none;z-index:9999;will-change:transform;isolation:isolate;mix-blend-mode:exclusion;width:0;height:0}.cb-cursor-rotation{position:absolute;top:0;left:0;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;will-change:transform}.cb-cursor-inner{width:20px;height:20px;transform-origin:center;background:#fff;border:1px solid #e9e9e93a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:50%;transition:all .3s}body.cursor-hidden .cb-cursor{scale:0;opacity:0;pointer-events:none}body.button-hovered .cb-cursor-inner{height:60px;width:60px}.cb-cursor-label{position:absolute;left:calc(100% + 10px);transform:translateY(-0%);padding:6px 12px 4px;border-radius:12px;color:var(--text-color);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0707074a;font-size:12px;font-weight:500;font-family:var(--font-josefin-sans);white-space:nowrap;pointer-events:none;opacity:0;scale:.5;transition:all .2s ease}.cb-cursor-label-visible{opacity:1;scale:1}@media(max-width:768px){.cb-cursor{display:none}}.footer-container{display:flex;align-items:center;justify-content:flex-end;font-family:var(--font-zen-loop);padding:4px 16px;margin:auto}.footer-container .content{color:var(--accent)}.footer-container .year{font-size:14px}@media(max-width:768px){.footer-container .year{font-size:12px}}.page-transition{position:relative;min-height:100vh;width:100%;overflow:hidden;isolation:isolate}.page-transition-content{position:relative;z-index:1;min-height:100vh;will-change:transform,opacity,filter}.page-transition-overlay{position:fixed;bottom:-20vh;left:50%;width:150vw;height:150vh;transform:translate(-50%);background:radial-gradient(ellipse 85% 110% at 50% 100%,#fcff0026,#fcff0014 30%,#0000 70%),radial-gradient(ellipse 100% 60% at 50% 0%,#0f0f0ff2,#0a0a0afa,#000),linear-gradient(180deg,#141414e0,#050505f0 40%,#000000f5);box-shadow:0 -20px 80px #fcff001a,0 40px 160px #000000b3,inset 0 0 100px #0000004d;z-index:9;pointer-events:none;border-radius:60% 60% 0 0/25% 25% 0 0;filter:drop-shadow(0 -10px 30px rgba(252,255,0,.08)) drop-shadow(0 40px 60px rgba(0,0,0,.6)) blur(.5px);will-change:transform;backface-visibility:hidden;transform-origin:center bottom}@media(max-width:768px){.page-transition-overlay{width:180vw;height:180vh;border-radius:65% 65% 0 0/30% 30% 0 0}}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background-color:var(--background-main);color:var(--text-color)}.error-boundary-content{max-width:600px;text-align:center;padding:2rem;background:var(--background-card);border-radius:var(--border-radius-large);border:1px solid rgba(255,255,255,.1)}.error-boundary h1{font-size:clamp(1.5rem,4vw,2.5rem);margin-bottom:1rem;color:var(--text-color);font-family:var(--font-josefin-sans)}.error-boundary p{color:var(--text-gray-color);font-size:1.1rem;margin-bottom:2rem;line-height:1.6}.error-details{margin:1.5rem 0;text-align:left;background:var(--background-card-2);padding:1rem;border-radius:var(--border-radius-medium);border:1px solid rgba(255,255,255,.1)}.error-details summary{cursor:pointer;color:var(--accent);font-weight:var(--medium);margin-bottom:.5rem;-webkit-user-select:none;user-select:none}.error-details pre{margin-top:.5rem;padding:.75rem;background:var(--background-main);border-radius:var(--border-radius-small);overflow-x:auto;font-size:.875rem;color:var(--text-gray-color);white-space:pre-wrap;word-break:break-word}.error-boundary-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:2rem}.error-boundary-button{padding:.75rem 1.5rem;background:var(--accent);color:var(--hidden-text);border:none;border-radius:var(--border-radius-medium);font-weight:var(--medium);cursor:pointer;transition:all .3s ease;font-family:inherit}.error-boundary-button:hover{background:#ffd900;transform:translateY(-2px);box-shadow:0 4px 12px #fcff004d}.error-boundary-link{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--background-card-2);color:var(--accent);text-decoration:none;border-radius:var(--border-radius-medium);border:1px solid rgba(255,255,255,.1);transition:all .3s ease;font-weight:var(--medium)}.error-boundary-link:hover{background:var(--background-card);transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}
