@import"https://fonts.googleapis.com/css2?family=EB+Garamond:ital,wght@0,400;0,500;0,600;1,400&display=swap";*{box-sizing:border-box}html,body{overflow-x:hidden;width:100%;margin:0;padding:0}:root{font-family:EB Garamond,Garamond,Times New Roman,serif;line-height:1.6;font-weight:400;color:#0a0a0a;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{min-width:320px;min-height:100vh}h1,h2,h3,h4,h5,h6{margin:0;font-weight:500}p{margin:0}a{color:inherit;text-decoration:none}#root{width:100%;overflow-x:hidden}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.portfolio{max-width:820px;width:100%;margin:0 auto;padding:5rem 2.5rem;overflow-x:hidden}.desktop-only{display:grid}.mobile-only{display:none}@media(max-width:1024px)and (min-width:769px){.portfolio{max-width:100%;padding:4rem 3rem}}@media(max-width:768px){.portfolio{padding:2rem 1.5rem}.desktop-only{display:none!important}.mobile-only{display:block!important}}@media(max-width:480px){.portfolio{padding:1.5rem 1rem}}.header{margin-bottom:6rem}.intro{font-size:1.75rem;line-height:1.65;color:#0a0a0a;font-weight:400;max-width:100%;overflow-wrap:break-word;word-wrap:break-word}.intro p{margin-bottom:1.25rem;max-width:100%}.intro a{color:#0a0a0a;text-decoration:underline;text-decoration-color:#00000040;text-underline-offset:3px;text-decoration-thickness:1px;transition:all .25s ease}.intro a:hover{text-decoration-color:#000000b3}.intro .name-highlight{color:#381ff9;font-weight:500;text-decoration:underline;text-decoration-color:#381ff9;text-underline-offset:3px;text-decoration-thickness:2px;transition:all .25s ease}.intro .name-highlight:hover{color:#0a0a0a;text-decoration-color:#0a0a0a}.intro .service-highlight{color:#ff4f00;font-weight:500;text-decoration:underline;text-decoration-color:#ff4f00;text-underline-offset:3px;text-decoration-thickness:2px;transition:all .25s ease}.intro .service-highlight:hover{color:#0a0a0a;text-decoration-color:#0a0a0a}.intro .ai-highlight{color:#ff4f00;font-weight:500;text-decoration:underline;text-decoration-color:#ff4f00;text-underline-offset:3px;text-decoration-thickness:2px;transition:all .25s ease}.intro .ai-highlight:hover{color:#0a0a0a;text-decoration-color:#0a0a0a}@media(max-width:1024px)and (min-width:769px){.header{margin-bottom:5rem}.intro{font-size:1.625rem;line-height:1.65}.intro p{margin-bottom:1.375rem}}@media(max-width:768px){.header{margin-bottom:4rem;margin-top:2rem}.intro{font-size:1.375rem;line-height:1.6}.intro p{margin-bottom:1rem}}@media(max-width:480px){.header{margin-bottom:3rem}.intro{font-size:1.25rem;line-height:1.55}.intro p{margin-bottom:.875rem}}.projects{margin-bottom:4rem}.see-more{text-align:center;margin-top:3rem;padding-top:2rem}.see-more-link{font-size:1.125rem;color:#0a0a0a;text-decoration:underline;text-decoration-color:#00000040;text-underline-offset:3px;text-decoration-thickness:1px;transition:all .25s ease;font-weight:400}.see-more-link:hover{text-decoration-color:#000000b3}.project{margin-bottom:5rem;padding-bottom:3rem;border-bottom:1px solid #e5e5e5}.project:last-child{border-bottom:none}.project-header{display:flex;justify-content:space-between;align-items:baseline;gap:2rem;margin-bottom:2rem}.project-header h2{font-size:2rem;font-weight:500;margin:0;color:#0a0a0a}.subtitle{font-weight:400;color:#555;margin-left:.5rem;font-size:.85em}.project-links{display:flex;align-items:center;gap:.25rem;white-space:nowrap;flex-shrink:0}.project-links a{font-size:1rem;color:#0a0a0a;text-decoration:underline;text-decoration-color:#00000040;text-underline-offset:3px;text-decoration-thickness:1px;transition:all .25s ease;font-weight:400}.project-links a:hover{text-decoration-color:#000000b3}.project-links .separator{color:#999;font-weight:300}.project-images{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2rem;width:100%;max-width:100%}.project-images.one-image{grid-template-columns:1fr}.project-images.one-image .image-item{min-height:500px}.project-images.one-image .image-item:first-child{grid-column:span 1;grid-row:span 1}.project-images.two-images{grid-template-columns:repeat(2,1fr)}.project-images.two-images .image-item{min-height:400px}.project-images.two-images .image-item:first-child{grid-column:span 1;grid-row:span 1}.image-item{background:#f5f5f5;border-radius:8px;overflow:hidden;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;position:relative;min-height:200px;width:100%;max-width:100%}.image-item:first-child{grid-column:span 2;grid-row:span 2}.image-item:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0000001a}.image-item img{width:100%;height:100%;object-fit:cover;display:block;position:absolute;top:0;left:0}.project-tags{display:flex;flex-wrap:wrap;gap:.625rem;margin-bottom:1.75rem}.tag{font-size:.875rem;color:#555;padding:.5rem 1rem;font-weight:400;font-style:normal;background:#f0f0f0;border-radius:20px;display:inline-flex;align-items:center;gap:.5rem;transition:all .2s ease}.tag:hover{background:#e5e5e5}.tag svg{width:16px;height:16px;color:#666;flex-shrink:0}.project-description{font-size:1.125rem;line-height:1.75;color:#1a1a1a}@media(max-width:1024px)and (min-width:769px){.project{margin-bottom:4.5rem;padding-bottom:3rem}.project-header{margin-bottom:1.75rem}.project-header h2{font-size:1.625rem}.project-links a{font-size:.9375rem}.project-images{grid-template-columns:repeat(2,1fr);gap:1rem;grid-auto-rows:350px}.image-item{min-height:350px}.image-item:first-child{grid-column:span 2;grid-row:span 2;min-height:700px}.project-images.one-image .image-item{min-height:550px}.project-images.one-image .image-item:first-child{grid-row:span 1}.project-images.two-images .image-item{min-height:450px}.project-images.two-images .image-item:first-child{grid-column:span 1;grid-row:span 1;min-height:450px}.tag{font-size:.8125rem;padding:.45rem .9rem}.project-description{font-size:1.0625rem;line-height:1.7}}@media(max-width:768px){.project-header{gap:1rem;margin-bottom:1.5rem}.project-header h2{font-size:1.375rem}.project-links a{font-size:.875rem}.project-images{grid-template-columns:1fr}.image-item{min-height:250px}.image-item:first-child{grid-column:span 1;grid-row:span 1}.project-tags{gap:.5rem}.tag{font-size:.75rem;padding:.4rem .8rem}.tag svg{width:14px;height:14px}.project-description{font-size:.9375rem;line-height:1.65}}@media(max-width:480px){.project{margin-bottom:3.5rem;padding-bottom:2.5rem}.project-header{flex-direction:column;align-items:flex-start;gap:.5rem;margin-bottom:1.25rem}.project-header h2{font-size:1.25rem}.project-links{flex-wrap:wrap}.project-links a{font-size:.8125rem}.image-item{min-height:200px}.project-tags{gap:.4rem;margin-bottom:1.25rem}.tag{font-size:.6875rem;padding:.35rem .7rem}.tag svg{width:12px;height:12px}.project-description{font-size:.875rem;line-height:1.6}}.carousel{position:relative;width:100%;max-width:100%;margin-bottom:2rem;overflow:hidden}.carousel *{max-width:100%}.carousel-container{overflow:hidden;border-radius:8px;width:100%}.carousel-track{display:flex;transition:transform .4s ease-in-out;width:100%}.carousel-slide{min-width:100%;width:100%;flex-shrink:0;display:flex;align-items:center;justify-content:center;position:relative}.carousel-slide img{width:100%;height:auto;max-height:400px;object-fit:cover;cursor:pointer;display:block;border-radius:8px}.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);background:#ffffffe6;border:none;width:40px;height:40px;border-radius:50%;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;color:#333;box-shadow:0 2px 8px #0000001a;z-index:10}.carousel-btn:hover{background:#fff;box-shadow:0 4px 12px #00000026}.carousel-btn.prev{left:1rem}.carousel-btn.next{right:1rem}.carousel-dots{display:flex;justify-content:center;gap:.5rem;margin-top:1rem}.dot{width:8px;height:8px;border-radius:50%;border:none;background:#d0d0d0;cursor:pointer;padding:0;transition:all .2s ease}.dot.active{background:#ff6b35;width:24px;border-radius:4px}.dot:hover{background:#b0b0b0}.dot.active:hover{background:#e85a28}@media(max-width:1024px)and (min-width:769px){.carousel-slide img{max-height:500px}}@media(max-width:768px){.carousel-btn{width:36px;height:36px;font-size:1.25rem}.carousel-btn.prev{left:.5rem}.carousel-btn.next{right:.5rem}.carousel-slide img{max-height:400px}}@media(max-width:480px){.carousel-slide img{max-height:280px}}.lightbox-overlay{position:fixed;inset:0;background:#000000f2;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.lightbox-content{max-width:90vw;max-height:90vh;display:flex;align-items:center;justify-content:center}.lightbox-content img{max-width:100%;max-height:90vh;object-fit:contain;border-radius:8px}.lightbox-close{position:absolute;top:2rem;right:2rem;background:#ffffffe6;border:none;width:48px;height:48px;border-radius:50%;font-size:2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;color:#333;line-height:1;z-index:1001}.lightbox-close:hover{background:#fff;transform:scale(1.1)}.lightbox-btn{position:absolute;top:50%;transform:translateY(-50%);background:#ffffffe6;border:none;width:48px;height:48px;border-radius:50%;font-size:2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;color:#333;z-index:1001}.lightbox-btn:hover{background:#fff;transform:translateY(-50%) scale(1.1)}.lightbox-btn.prev{left:2rem}.lightbox-btn.next{right:2rem}@media(max-width:768px){.lightbox-overlay{padding:1rem}.lightbox-close{top:1rem;right:1rem;width:40px;height:40px;font-size:1.5rem}.lightbox-btn{width:40px;height:40px;font-size:1.5rem}.lightbox-btn.prev{left:1rem}.lightbox-btn.next{right:1rem}}.about-me{margin-bottom:3rem}.about-me h2{font-size:1.25rem;font-weight:500;margin-bottom:1.25rem;color:#0a0a0a}.about-content{display:flex;gap:2rem;align-items:flex-start}.about-image{flex-shrink:0;width:150px;height:150px;border-radius:8px;overflow:hidden}.about-image img{width:100%;height:100%;object-fit:cover}.about-text{flex:1}.about-text p{font-size:1rem;line-height:1.7;color:#1a1a1a;margin-bottom:1rem}.about-text h3{font-size:1.0625rem;font-weight:500;margin-top:1.5rem;margin-bottom:.5rem;color:#0a0a0a}.about-vision,.about-mission{margin-bottom:1rem}.about-philosophy{margin-top:1.5rem;font-style:italic}@media(max-width:1024px)and (min-width:769px){.about-image{width:200px;height:200px}}@media(max-width:768px){.about-content{flex-direction:column;gap:1.5rem}.about-image{width:100%;height:320px}.about-image img{object-position:center 20%}.about-text p{font-size:.9375rem}.about-text h3{font-size:1rem}}.tech-stack{margin-bottom:4rem}.tech-stack section{margin-bottom:3rem}.tech-stack h2{font-size:1.25rem;font-weight:500;margin-bottom:1.25rem;color:#0a0a0a}.tech-stack ul{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem 1.5rem}.tech-stack li{margin-bottom:0;font-size:1.0625rem;color:#1a1a1a}@media(max-width:1024px)and (min-width:769px){.tech-stack{margin-bottom:4rem}.tech-stack h2{font-size:1.1875rem}.tech-stack a{font-size:1.03125rem}}@media(max-width:768px){.tech-stack h2{font-size:1.125rem}.tech-stack a{font-size:1rem}}@media(max-width:480px){.tech-stack{margin-bottom:3rem}.tech-stack section{margin-bottom:2rem}.tech-stack h2{font-size:1rem;margin-bottom:1rem}.tech-stack li{margin-bottom:.625rem}.tech-stack a{font-size:.9375rem}}.testimonials{margin-bottom:4rem}.testimonials h2{font-size:1.5rem;font-weight:500;margin-bottom:2rem;color:#0a0a0a}.testimonials-grid{display:flex;gap:2rem;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#ccc transparent;padding-bottom:1rem}.testimonials-grid::-webkit-scrollbar{height:8px}.testimonials-grid::-webkit-scrollbar-track{background:transparent}.testimonials-grid::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}.testimonials-grid::-webkit-scrollbar-thumb:hover{background:#999}.testimonial-card{background:#f9f9f9;padding:1.5rem;border-radius:8px;display:flex;flex-direction:column;gap:1rem;min-width:calc(50% - 1rem);max-width:calc(50% - 1rem);flex-shrink:0;scroll-snap-align:start}.testimonial-quote{font-size:1.0625rem;line-height:1.6;color:#1a1a1a;margin:0;font-style:italic}.testimonial-author{display:flex;align-items:center;gap:1rem;margin-top:auto}.author-avatar{border-radius:50%;object-fit:cover}.author-avatar-placeholder{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:1rem;flex-shrink:0}.author-info{display:flex;flex-direction:column;gap:.25rem}.author-name{font-weight:500;color:#0a0a0a;margin:0;font-size:1rem}.author-role{font-size:.9375rem;color:#666;margin:0}@media(max-width:768px){.testimonials h2{font-size:1.25rem}.testimonials-grid{gap:1.5rem}.testimonial-card{padding:1.5rem;min-width:calc(100% - 1rem)}.testimonial-quote{font-size:1rem}}@media(max-width:480px){.testimonials{margin-bottom:3rem}.testimonials h2{font-size:1.125rem;margin-bottom:1.5rem}.testimonial-card{padding:1.25rem;min-width:calc(100% - .5rem)}.testimonial-quote{font-size:.9375rem}}.contact{margin-bottom:4rem}.contact h2{font-size:1.125rem;font-weight:400;margin-bottom:.75rem;color:#666}.contact-description{font-size:1rem;line-height:1.6;color:#666;margin-bottom:1rem}.contact-email{font-size:2rem;font-weight:600;color:#0a0a0a;text-decoration:none;transition:color .3s ease;display:block}.contact-email:hover{color:#381ff9}@media(max-width:768px){.contact h2{font-size:1rem}.contact-email{font-size:1.5rem}}@media(max-width:480px){.contact{margin-bottom:3rem}.contact h2{font-size:.9375rem}.contact-email{font-size:1.25rem}}.footer{padding-top:2.5rem;border-top:1px solid #d0d0d0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;color:#666;font-size:.9375rem;letter-spacing:.01em}.footer p{margin:0;font-weight:400}.social-links{display:flex;gap:1.75rem}.social-links a{color:#0a0a0a;text-decoration:underline;text-decoration-color:#00000040;text-underline-offset:3px;text-decoration-thickness:1px;transition:all .25s ease;font-weight:400}.social-links a:hover{color:#0a0a0a;text-decoration-color:#000000b3}@media(max-width:1024px)and (min-width:769px){.footer{padding-top:2.25rem}}@media(max-width:768px){.footer{flex-direction:column;align-items:flex-start;gap:1.5rem}.footer p{font-size:.875rem}.social-links{gap:1.5rem}.social-links a{font-size:.875rem}}@media(max-width:480px){.footer{padding-top:2rem;gap:1.25rem}.footer p{font-size:.8125rem}.social-links{gap:1.25rem}.social-links a{font-size:.8125rem}}.all-projects-page{max-width:1400px;width:100%;margin:0 auto;padding:5rem 3rem;overflow-x:hidden}.back-button{display:inline-block;font-size:1rem;color:#0a0a0a;text-decoration:none;margin-bottom:2rem;transition:all .25s ease;font-weight:400}.back-button:hover{opacity:.6;transform:translate(-4px)}.all-projects-header{margin-bottom:4rem}.all-projects-header h1{font-size:3rem;font-weight:500;color:#0a0a0a;margin:0}.all-projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0rem 3rem;margin-bottom:4rem}.all-projects-grid .carousel{margin-bottom:0}.all-projects-grid .carousel-slide img{max-height:500px;min-height:500px;object-fit:cover}.all-projects-grid .carousel-dots{margin-top:1rem;margin-bottom:2rem}.all-projects-grid .carousel-spacer{height:3rem}@media(max-width:1200px){.all-projects-page{padding:4rem 2.5rem}.all-projects-grid{gap:0rem 2.5rem}}@media(max-width:1024px){.all-projects-page{padding:3rem 2rem}.all-projects-grid{grid-template-columns:1fr;gap:0rem}.all-projects-grid .project{margin-bottom:5rem;padding-bottom:3rem;border-bottom:1px solid #e5e5e5}.all-projects-grid .project:last-child{border-bottom:none}.all-projects-grid .carousel-slide img{max-height:450px;min-height:450px}}@media(max-width:768px){.all-projects-page{padding:2rem 1.5rem}.all-projects-grid .project{margin-bottom:4rem;padding-bottom:2.5rem}.all-projects-grid .carousel-slide img{max-height:400px;min-height:400px}}@media(max-width:480px){.all-projects-page{padding:1.5rem 1rem}.all-projects-grid .project{margin-bottom:3.5rem;padding-bottom:2.5rem}}.not-found-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;text-align:center}.not-found-content h1{font-size:8rem;font-weight:500;color:#0a0a0a;margin-bottom:1rem;line-height:1}.not-found-content h2{font-size:2rem;font-weight:500;color:#0a0a0a;margin-bottom:1rem}.not-found-content p{font-size:1.125rem;color:#4a4a4a;margin-bottom:2rem}.back-home-button{display:inline-block;font-size:1rem;color:#0a0a0a;text-decoration:underline;text-decoration-color:#00000040;text-underline-offset:3px;transition:all .25s ease}.back-home-button:hover{text-decoration-color:#000000b3;transform:translate(-4px)}@media(max-width:768px){.not-found-content h1{font-size:5rem}.not-found-content h2{font-size:1.5rem}.not-found-content p{font-size:1rem}}.coming-soon{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#fafafa,#f5f5f5);position:relative}.coming-soon-content{text-align:center;max-width:600px}.coming-soon-badge{display:inline-block;padding:.5rem 1.25rem;background:#0a0a0a;color:#fff;font-size:.75rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;border-radius:100px;margin-bottom:2rem}.coming-soon-title{font-size:clamp(2.5rem,8vw,4rem);font-weight:500;color:#0a0a0a;margin-bottom:.5rem;line-height:1.1}.coming-soon-subtitle{font-size:1.25rem;color:#666;font-style:italic;margin-bottom:1.5rem}.coming-soon-description{font-size:1.125rem;color:#444;line-height:1.7;margin-bottom:2.5rem}.coming-soon-form{display:flex;gap:.75rem;max-width:450px;margin:0 auto 2.5rem}.coming-soon-input{flex:1;padding:1rem 1.25rem;font-size:1rem;font-family:inherit;border:1px solid #ddd;border-radius:8px;background:#fff;transition:border-color .2s,box-shadow .2s}.coming-soon-input:focus{outline:none;border-color:#0a0a0a;box-shadow:0 0 0 3px #0a0a0a1a}.coming-soon-input::placeholder{color:#999}.coming-soon-button{padding:1rem 1.75rem;font-size:1rem;font-family:inherit;font-weight:500;background:#0a0a0a;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background .2s,transform .2s;white-space:nowrap}.coming-soon-button:hover{background:#333;transform:translateY(-1px)}.coming-soon-button:active{transform:translateY(0)}.coming-soon-success{padding:1rem 2rem;background:#f0fdf4;color:#166534;border-radius:8px;font-size:1rem;margin-bottom:2.5rem}.coming-soon-links{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap}.coming-soon-link{color:#666;font-size:.95rem;transition:color .2s}.coming-soon-link:hover{color:#0a0a0a}.coming-soon-divider{color:#ccc}.coming-soon-footer{position:absolute;bottom:2rem;font-size:.875rem;color:#999}@media(max-width:600px){.coming-soon{padding:1.5rem}.coming-soon-form{flex-direction:column}.coming-soon-button{width:100%}.coming-soon-links{gap:.75rem}.coming-soon-divider{display:none}.coming-soon-link{display:block;width:100%}}
