*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--white: #ffffff;--off-white: #f5f5f3;--grey-100: #e8e8e6;--grey-200: #d4d4d2;--grey-300: #a3a3a1;--grey-400: #6b6b69;--grey-500: #666664;--grey-600: #444442;--grey-700: #2a2a28;--grey-800: #1a1a18;--dark: #0a0a0a;--accent: #c8b8a0;--accent-light: #e8ddd0;--accent-dark: #8a7d6e}html{scroll-behavior:smooth}body{font-family:Inter,sans-serif;background:var(--white);color:var(--grey-800);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.grain{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1;opacity:.018}.cursor-dot,.cursor-ring{display:none}@media(pointer:fine){.cursor-dot{display:block;position:fixed;width:6px;height:6px;background:var(--accent);border-radius:50%;pointer-events:none;z-index:10000;transform:translate(-50%,-50%);transition:transform .1s}.cursor-ring{display:block;position:fixed;width:32px;height:32px;border:1px solid var(--accent);border-radius:50%;pointer-events:none;z-index:10000;transform:translate(-50%,-50%);transition:width .3s,height .3s,border-color .3s;opacity:.5}body,a,button{cursor:none}.cursor-hover .cursor-ring{width:48px;height:48px;border-color:var(--accent-dark)}}.intro-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--white);z-index:9998;display:flex;align-items:center;justify-content:center;flex-direction:column;transition:opacity .6s ease,visibility .6s ease}.intro-overlay.hidden{opacity:0;visibility:hidden;pointer-events:none}.intro-line{width:0;height:1px;background:var(--accent);margin-bottom:24px;animation:introLine .8s ease forwards}@keyframes introLine{to{width:40px}}.intro-logo{opacity:0;animation:introFade .6s ease .6s forwards}.intro-logo span:first-child{font-family:Sora,sans-serif;font-weight:800;font-size:20px;color:var(--grey-800)}.intro-logo span:last-child{font-family:Sora,sans-serif;font-weight:400;font-size:20px;color:#767674;letter-spacing:.14em;text-transform:uppercase;margin-left:2px}@keyframes introFade{to{opacity:1}}.nav{position:fixed;top:0;left:0;width:100%;z-index:1000;padding:0 48px;height:64px;display:flex;align-items:center;justify-content:space-between;background:#ffffffd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:border-color .3s,opacity .3s;opacity:0;pointer-events:none}.nav.visible{opacity:1;pointer-events:all}.nav.scrolled{border-bottom-color:var(--grey-100)}.nav-logo{text-decoration:none;display:flex;align-items:baseline;gap:2px}.nav-logo-jv{font-family:Sora,sans-serif;font-weight:800;font-size:16px;color:var(--grey-800)}.nav-logo-studio{font-family:Sora,sans-serif;font-weight:400;font-size:16px;color:#767674;letter-spacing:.14em;text-transform:uppercase}.nav-links{display:flex;align-items:center;gap:36px;list-style:none}.nav-links a{font-family:Inter,sans-serif;font-weight:400;font-size:12px;color:var(--grey-400);text-decoration:none;transition:color .3s}.nav-links a:hover{color:var(--grey-800)}.nav-cta{font-family:Sora,sans-serif;font-weight:500;font-size:11px;color:var(--white);background:linear-gradient(135deg,var(--grey-800) 0%,#3a3a38 100%);border:none;border-radius:50px;padding:10px 24px;text-decoration:none;white-space:nowrap;position:relative;overflow:hidden;transition:box-shadow .4s,transform .4s cubic-bezier(.16,1,.3,1);box-shadow:0 2px 12px #c8b8a026,0 0 0 1px #c8b8a014;animation:ctaPulseGlow 3s ease-in-out infinite}.nav-cta:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(200,184,160,.2),transparent);transition:none}.nav-cta:after{content:"";position:absolute;inset:-1px;border-radius:50px;background:linear-gradient(135deg,rgba(200,184,160,.3),transparent,rgba(200,184,160,.15));z-index:-1;opacity:0;transition:opacity .4s ease}.nav-cta:hover:before{animation:ctaShimmer .6s ease forwards}.nav-cta:hover:after{opacity:1}.nav-cta:hover{box-shadow:0 6px 28px #c8b8a04d,0 0 0 1px #c8b8a033;transform:scale(1.06);animation:none}.nav-cta:active{transform:scale(.97)}@keyframes ctaShimmer{to{left:100%}}@keyframes ctaPulseGlow{0%,to{box-shadow:0 2px 12px #c8b8a026,0 0 0 1px #c8b8a014}50%{box-shadow:0 4px 20px #c8b8a04d,0 0 0 1px #c8b8a026}}.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:4px}.hamburger span{display:block;width:20px;height:1px;background:var(--grey-800);transition:transform .3s,opacity .3s}.hamburger.active span{background:var(--white)}.hamburger.active span:nth-child(1){transform:rotate(45deg) translateY(4.2px)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:rotate(-45deg) translateY(-4.2px)}.mobile-menu{display:none;position:fixed;top:0;left:0;width:100%;height:100vh;height:100dvh;background:var(--dark);z-index:999;flex-direction:column;align-items:flex-start;justify-content:center;gap:0;opacity:0;visibility:hidden;transition:opacity .5s cubic-bezier(.4,0,.2,1),visibility .5s ease;padding:100px 40px 80px;overflow:hidden}.mobile-menu:before{content:"";position:absolute;bottom:-20%;right:-10%;width:400px;height:400px;background:radial-gradient(circle,rgba(200,184,160,.08) 0%,transparent 70%);border-radius:50%;pointer-events:none;opacity:0;transform:scale(.6);transition:opacity .8s ease .2s,transform .8s cubic-bezier(.16,1,.3,1) .2s}.mobile-menu.open:before{opacity:1;transform:scale(1)}.mobile-menu:after{content:"JV";position:absolute;bottom:40px;right:40px;font-family:Sora,sans-serif;font-weight:800;font-size:120px;color:#ffffff05;letter-spacing:4px;pointer-events:none;line-height:1}.mobile-menu.open{display:flex;opacity:1;visibility:visible}.mobile-menu a{font-family:Sora,sans-serif;font-weight:300;font-size:32px;color:#ffffffd9;text-decoration:none;padding:14px 0;opacity:0;transform:translate(-30px);transition:opacity .5s ease,transform .5s cubic-bezier(.16,1,.3,1),color .3s;position:relative;letter-spacing:-.5px}.mobile-menu a:before{content:"";position:absolute;left:0;bottom:8px;width:0;height:1px;background:var(--accent);transition:width .4s cubic-bezier(.16,1,.3,1)}.mobile-menu a:hover:before,.mobile-menu a:active:before{width:100%}.mobile-menu a:hover,.mobile-menu a:active{color:var(--white)}.mobile-menu.open a{opacity:1;transform:translate(0)}.mobile-menu a:nth-child(1){transition-delay:.08s}.mobile-menu a:nth-child(2){transition-delay:.14s}.mobile-menu a:nth-child(3){transition-delay:.2s}.mobile-menu a:nth-child(4){transition-delay:.26s}.mobile-menu a:nth-child(5){transition-delay:.32s}.mobile-menu a:nth-child(6){transition-delay:.38s}.mobile-menu .nav-cta{font-family:Sora,sans-serif;font-weight:500;font-size:15px;padding:18px 40px;margin-top:32px;color:var(--dark);background:linear-gradient(135deg,var(--accent) 0%,var(--accent-light) 100%);border-radius:50px;box-shadow:0 4px 24px #c8b8a040;animation:ctaPulseGlow 3s ease-in-out infinite;letter-spacing:.5px}.hero{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:0 24px;position:relative}.hero-accent-line{width:0;height:1px;background:var(--accent);margin-bottom:28px;opacity:0;transition:width .8s cubic-bezier(.16,1,.3,1),opacity .6s ease}.hero-accent-line.visible{width:40px;opacity:1}.hero h1{font-family:Sora,sans-serif;font-weight:200;font-size:clamp(42px,6.5vw,82px);color:var(--grey-800);letter-spacing:-.03em;line-height:1.15}.hero h1 .word{display:inline-block;opacity:0;transform:translateY(16px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}.hero h1 .word.visible{opacity:1;transform:translateY(0)}.hero-sub{margin-top:32px;font-family:Inter,sans-serif;font-weight:300;font-size:15px;color:var(--grey-400);max-width:420px;line-height:1.7;opacity:0;transform:translateY(12px);transition:opacity .8s ease .6s,transform .8s ease .6s}.hero-sub.visible{opacity:1;transform:translateY(0)}.scroll-indicator{position:absolute;bottom:40px;display:flex;flex-direction:column;align-items:center;gap:8px;opacity:0;animation:scrollFadeIn .6s ease 1.8s forwards}.scroll-line{width:1px;height:32px;background:var(--grey-200);position:relative;overflow:hidden}.scroll-dot{width:3px;height:3px;border-radius:50%;background:var(--grey-400);animation:scrollDrop 2s ease-in-out infinite}@keyframes scrollDrop{0%,to{transform:translateY(0);opacity:0}20%{opacity:1}80%{opacity:1}to{transform:translateY(24px);opacity:0}}.scroll-text{font-family:Inter,sans-serif;font-size:8px;color:var(--grey-400);text-transform:uppercase;letter-spacing:2px}@keyframes scrollFadeIn{to{opacity:1}}.reveal{opacity:0;transform:translateY(20px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-child{opacity:0;transform:translateY(20px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}.reveal-child.visible{opacity:1;transform:translateY(0)}.section-label{font-family:Sora,sans-serif;font-weight:500;font-size:10px;letter-spacing:5px;text-transform:uppercase;color:var(--accent-dark);text-align:center;margin-bottom:48px}.section-label:before{content:"//";margin-right:10px;font-weight:300;letter-spacing:2px}.services{padding:120px 24px;background:var(--off-white)}.services-list{max-width:720px;margin:0 auto}.service-item{display:grid;grid-template-columns:48px 1fr;gap:0;padding:40px 0;border-bottom:1px solid var(--grey-100);align-items:start;transition:padding-left .4s cubic-bezier(.16,1,.3,1),border-left-color .4s ease;border-left:2px solid transparent}.service-item:hover{padding-left:16px;border-left-color:var(--accent)}.service-number{font-family:Sora,sans-serif;font-size:13px;font-weight:300;color:var(--accent);letter-spacing:.04em;transition:transform .4s cubic-bezier(.16,1,.3,1);display:inline-block;padding-top:3px}.service-item:hover .service-number{transform:translate(4px)}.service-content h3{font-family:Sora,sans-serif;font-size:18px;font-weight:500;color:var(--grey-800);margin-bottom:6px}.service-content p{font-size:14px;font-weight:400;color:var(--grey-400);line-height:1.6}.about{padding:140px 24px;background:var(--white)}.about-title{font-family:Sora,sans-serif;font-weight:400;font-size:32px;color:var(--grey-800);text-align:center;margin-bottom:24px;line-height:1.3}.about-text{font-family:Inter,sans-serif;font-weight:300;font-size:18px;color:var(--grey-500);max-width:580px;margin:0 auto 64px;text-align:center;line-height:1.8}.about-stats{display:flex;justify-content:center;gap:80px;margin-bottom:72px}.about-stat{text-align:center}.about-stat-number{font-family:Sora,sans-serif;font-weight:600;font-size:32px;color:var(--grey-800)}.about-stat-label{font-family:Inter,sans-serif;font-weight:400;font-size:11px;color:var(--grey-300);text-transform:uppercase;letter-spacing:3px;margin-top:8px}.about-skills{display:flex;flex-wrap:wrap;justify-content:center;gap:16px 40px;max-width:700px;margin:0 auto}.about-skill-item{display:flex;align-items:center;gap:10px;font-family:Inter,sans-serif;font-weight:400;font-size:13px;color:var(--grey-500);white-space:nowrap}.about-skill-item:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0}.portfolio{padding:120px 24px;background:var(--off-white)}.portfolio-inner{max-width:1000px;margin:0 auto}.project-card{background:var(--white);border-radius:24px;overflow:hidden;box-shadow:0 4px 24px #00000008;display:grid;grid-template-columns:1.2fr 1fr;transition:all .4s cubic-bezier(.4,0,.2,1)}.project-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px #00000012}.project-card+.project-card{margin-top:24px}.project-card.reversed{grid-template-columns:1fr 1.2fr}.project-card.reversed .project-image{order:2}.project-card.reversed .project-info{order:1}.project-image{aspect-ratio:16/10;background:linear-gradient(135deg,var(--accent-light),var(--grey-100));position:relative;min-height:280px;display:flex;align-items:center;justify-content:center;overflow:hidden}.project-image img{width:100%;height:100%;object-fit:cover;object-position:top;position:absolute;inset:0;transition:transform .6s cubic-bezier(.4,0,.2,1)}.project-card:hover .project-image img{transform:scale(1.03)}.project-image:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(200,184,160,.08),transparent);z-index:1}.project-image-placeholder{font-family:Sora,sans-serif;font-weight:300;font-size:14px;color:var(--grey-300);letter-spacing:2px;position:relative;z-index:1}.project-info{padding:48px 40px;display:flex;flex-direction:column;justify-content:center}.project-meta{font-family:Inter,sans-serif;font-weight:400;font-size:13px;color:var(--grey-300);text-transform:uppercase;letter-spacing:2px;margin-bottom:12px}.project-info h3{font-family:Sora,sans-serif;font-weight:500;font-size:24px;color:var(--grey-800);margin-bottom:16px}.project-desc{font-family:Inter,sans-serif;font-weight:400;font-size:14px;color:var(--grey-400);line-height:1.7;margin-bottom:20px}.project-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}.project-tag{font-family:Inter,sans-serif;font-weight:400;font-size:11px;color:var(--grey-400);background:var(--off-white);border:1px solid var(--grey-100);border-radius:50px;padding:5px 14px}.project-link{font-family:Sora,sans-serif;font-weight:500;font-size:13px;color:var(--accent-dark);text-decoration:none;display:inline-flex;align-items:center;gap:6px;position:relative}.project-link:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--accent-dark);transition:width .4s}.project-link:hover:after{width:100%}.testimonials{padding:120px 24px;text-align:center;background:var(--white)}.testimonials-carousel{position:relative;max-width:580px;margin:0 auto;min-height:200px}.testimonial-slide{position:absolute;top:0;left:0;width:100%;opacity:0;transition:opacity .8s ease;pointer-events:none}.testimonial-slide.active{opacity:1;position:relative;pointer-events:all}.testimonial-quote{font-family:Inter,sans-serif;font-weight:300;font-style:italic;font-size:20px;color:var(--grey-600);line-height:1.7;margin-bottom:32px}.testimonial-quote:before{content:"“"}.testimonial-quote:after{content:"”"}.testimonial-name{font-family:Sora,sans-serif;font-weight:500;font-size:14px;color:var(--grey-800);margin-bottom:4px}.testimonial-role{font-family:Inter,sans-serif;font-weight:400;font-size:12px;color:var(--grey-400)}.carousel-dots{display:flex;justify-content:center;gap:8px;margin-top:32px}.carousel-dot{width:6px;height:6px;border-radius:50%;background:var(--grey-200);border:none;padding:0;cursor:pointer;transition:background .3s,width .3s,border-radius .3s}.carousel-dot.active{background:var(--accent);width:20px;border-radius:3px}.blog{padding:120px 24px;background:var(--off-white)}.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1080px;margin:0 auto}.blog-card{border:1px solid var(--grey-100);border-radius:16px;overflow:hidden;transition:border-color .4s,transform .4s cubic-bezier(.16,1,.3,1),box-shadow .4s;text-decoration:none;color:inherit;display:block;background:var(--white)}.blog-card:hover{border-color:var(--accent-light);transform:translateY(-4px);box-shadow:0 12px 40px #0000000a}.blog-thumb{aspect-ratio:16/9;background:var(--dark);position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:16px 16px 0 0}.blog-thumb img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:transform .6s cubic-bezier(.4,0,.2,1)}.blog-card:hover .blog-thumb img{transform:scale(1.03)}.blog-thumb-icon{font-family:Sora,sans-serif;font-size:24px;font-weight:200;color:var(--grey-200)}.blog-body{padding:24px}.blog-date{font-family:Inter,sans-serif;font-size:11px;font-weight:400;color:var(--grey-300);text-transform:uppercase;letter-spacing:1px;margin-bottom:10px}.blog-body h3{font-family:Sora,sans-serif;font-weight:500;font-size:16px;color:var(--grey-800);margin-bottom:8px;line-height:1.35}.blog-body p{font-family:Inter,sans-serif;font-size:13px;font-weight:400;color:var(--grey-400);line-height:1.6}.blog-meta{display:flex;align-items:center;gap:8px;margin-bottom:10px}.blog-category{font-family:Sora,sans-serif;font-size:9px;font-weight:500;color:var(--accent-dark);background:var(--accent-light);padding:3px 10px;border-radius:50px;text-transform:uppercase;letter-spacing:1px}.blog-read-time{font-family:Inter,sans-serif;font-size:11px;font-weight:400;color:var(--grey-300)}.blog-post-hero{padding:160px 24px 60px;text-align:center;background:var(--white)}.blog-post-meta{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:24px}.blog-post-hero h1{font-family:Sora,sans-serif;font-weight:300;font-size:clamp(28px,4vw,42px);color:var(--grey-800);line-height:1.25;max-width:720px;margin:0 auto}.blog-post-content{padding:60px 24px 120px;max-width:720px;margin:0 auto;background:var(--white)}.blog-post-content h2{font-family:Sora,sans-serif;font-weight:500;font-size:22px;color:var(--grey-800);margin-top:48px;margin-bottom:16px}.blog-post-content h3{font-family:Sora,sans-serif;font-weight:500;font-size:18px;color:var(--grey-800);margin-top:32px;margin-bottom:12px}.blog-post-content p{font-family:Inter,sans-serif;font-weight:400;font-size:15px;color:var(--grey-500);line-height:1.85;margin-bottom:16px}.blog-post-content ul,.blog-post-content ol{padding-left:24px;margin-bottom:16px}.blog-post-content li{font-family:Inter,sans-serif;font-weight:400;font-size:15px;color:var(--grey-500);line-height:1.85;margin-bottom:8px}.blog-post-content strong{font-weight:600;color:var(--grey-700)}.blog-post-content blockquote{border-left:2px solid var(--accent);padding-left:24px;margin:32px 0}.blog-post-content blockquote p{font-style:italic;color:var(--grey-600)}.blog-related{padding:80px 24px;background:var(--off-white)}.blog-related-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;max-width:720px;margin:0 auto}.project-detail-hero{padding:160px 24px 80px;background:var(--white)}.project-detail-header{max-width:720px;margin:0 auto;text-align:center}.project-detail-header .project-meta{margin-bottom:16px}.project-detail-header h1{font-family:Sora,sans-serif;font-weight:300;font-size:clamp(32px,5vw,52px);color:var(--grey-800);margin-bottom:20px}.project-detail-header .project-desc{font-size:16px;max-width:560px;margin:0 auto 32px}.project-detail-header .project-tags{justify-content:center}.project-detail-image{max-width:1000px;margin:0 auto;border-radius:24px;overflow:hidden;aspect-ratio:16/9;background:linear-gradient(135deg,var(--accent-light),var(--grey-100));display:flex;align-items:center;justify-content:center;position:relative}.project-detail-image img{width:100%;height:100%;object-fit:cover;object-position:top;position:absolute;inset:0}.project-detail-image:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(200,184,160,.05),transparent);z-index:1}.project-detail-body{padding:100px 24px 80px;background:var(--off-white)}.project-detail-grid{max-width:900px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:64px}.project-detail-section h2{font-family:Sora,sans-serif;font-weight:500;font-size:20px;color:var(--grey-800);margin-bottom:16px}.project-detail-section p{font-family:Inter,sans-serif;font-weight:400;font-size:15px;color:var(--grey-500);line-height:1.8}.project-results{padding:80px 24px;background:var(--white)}.project-results-inner{max-width:900px;margin:0 auto}.project-results-list{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:32px}.project-result-item{display:flex;align-items:flex-start;gap:12px;font-family:Inter,sans-serif;font-weight:400;font-size:14px;color:var(--grey-500);line-height:1.6}.project-result-item:before{content:"";width:8px;height:8px;min-width:8px;border-radius:50%;background:var(--accent);margin-top:6px}.project-tech{display:flex;flex-wrap:wrap;gap:8px;margin-top:32px}.project-tech-tag{font-family:Sora,sans-serif;font-weight:500;font-size:11px;color:var(--accent-dark);background:var(--accent-light);border-radius:50px;padding:6px 16px;letter-spacing:.5px}.project-visit-btn{font-family:Sora,sans-serif;font-weight:500;font-size:14px;background:var(--grey-800);color:var(--white);border-radius:50px;padding:16px 36px;margin-top:32px;display:inline-flex;align-items:center;gap:8px;text-decoration:none;position:relative;overflow:hidden;transition:all .4s cubic-bezier(.16,1,.3,1);box-shadow:0 4px 16px #0000001a}.project-visit-btn:hover{background:var(--dark);box-shadow:0 8px 32px #0003;transform:translateY(-2px) scale(1.03)}.project-visit-btn:active{transform:translateY(0) scale(.98)}@media(max-width:768px){.project-detail-grid{grid-template-columns:1fr;gap:40px}.project-results-list,.blog-related-grid{grid-template-columns:1fr}}.process{padding:120px 24px;background:var(--white)}.process-steps{display:flex;align-items:flex-start;justify-content:center;max-width:900px;margin:0 auto;position:relative}.process-line{position:absolute;top:16px;left:50%;transform:translate(-50%);width:calc(100% - 160px);height:1px;background:var(--accent);opacity:.5}.process-step{flex:1;text-align:center;position:relative;z-index:1;padding:0 16px}.process-circle{width:32px;height:32px;border-radius:50%;border:1px solid var(--accent);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;background:var(--white)}.process-circle span{font-family:Sora,sans-serif;font-weight:500;font-size:13px;color:var(--accent-dark)}.process-step h3{font-family:Sora,sans-serif;font-weight:500;font-size:15px;color:var(--grey-800);margin-bottom:8px}.process-step p{font-family:Inter,sans-serif;font-weight:400;font-size:12px;color:var(--grey-400);line-height:1.5}.faq{padding:120px 24px;background:var(--off-white)}.faq-list{max-width:680px;margin:0 auto}.faq-item{border-bottom:1px solid var(--grey-100)}.faq-question{width:100%;background:none;border:none;padding:24px 0;display:flex;align-items:center;justify-content:space-between;gap:16px;text-align:left;font-family:Sora,sans-serif;font-weight:500;font-size:16px;color:var(--grey-800);transition:color .3s}.faq-question:hover{color:var(--accent-dark)}.faq-icon{font-family:Inter,sans-serif;font-weight:300;font-size:20px;color:var(--accent);transition:transform .3s;flex-shrink:0}.faq-item.open .faq-icon{transform:rotate(45deg)}.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.16,1,.3,1),padding .4s;padding:0}.faq-item.open .faq-answer{max-height:200px;padding:0 0 24px}.faq-answer p{font-family:Inter,sans-serif;font-weight:400;font-size:14px;color:var(--grey-400);line-height:1.7}.cta-section{padding:100px 24px;background:var(--white)}.cta-container{max-width:900px;margin:0 auto;border-radius:32px;background:linear-gradient(135deg,#f5f5f3,#e8ddd0);padding:80px 48px;text-align:center;position:relative;overflow:hidden}.cta-blob{position:absolute;width:350px;height:350px;background:var(--accent);opacity:.06;border-radius:45% 55% 60% 40%/55% 45% 40% 60%;top:-100px;right:-100px;animation:ctaBlobMorph 20s ease-in-out infinite alternate}@keyframes ctaBlobMorph{0%{border-radius:45% 55% 60% 40%/55% 45% 40% 60%}50%{border-radius:60% 40% 45% 55%/40% 60% 55% 45%}to{border-radius:50% 50% 55% 45%/45% 55% 50% 50%}}.cta-container h2{font-family:Sora,sans-serif;font-weight:600;font-size:36px;color:var(--grey-800);position:relative;z-index:1}.cta-container p{font-size:15px;color:var(--grey-500);margin-top:16px;max-width:420px;margin-left:auto;margin-right:auto;line-height:1.7;position:relative;z-index:1}.cta-btn{font-family:Sora,sans-serif;font-weight:500;font-size:14px;background:linear-gradient(135deg,var(--grey-800) 0%,#3a3a38 100%);color:var(--white);border-radius:50px;padding:18px 44px;margin-top:32px;animation:ctaBtnPulse 3s ease-in-out infinite;display:inline-block;text-decoration:none;position:relative;z-index:1;overflow:hidden;transition:all .4s cubic-bezier(.16,1,.3,1);box-shadow:0 4px 16px #0000001a}.cta-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent)}.cta-btn:hover:before{animation:ctaShimmer .6s ease forwards}.cta-btn:after{content:"";position:absolute;inset:-2px;border-radius:52px;background:linear-gradient(135deg,var(--accent),var(--accent-dark));z-index:-1;opacity:0;transition:opacity .4s}.cta-btn:hover{background:linear-gradient(135deg,var(--dark) 0%,#2a2a28 100%);box-shadow:0 8px 32px #c8b8a040,0 0 0 1px #c8b8a033;transform:translateY(-2px) scale(1.05);animation:none}.cta-btn:hover:after{opacity:1}.cta-btn:active{transform:translateY(0) scale(.98);animation:none}@keyframes ctaBtnPulse{0%,to{box-shadow:0 4px 16px #0000001a}50%{box-shadow:0 6px 28px #c8b8a04d,0 0 0 1px #c8b8a01f}}.cta-email{font-size:13px;color:var(--grey-500);margin-top:16px;position:relative;z-index:1}.footer{background:var(--off-white);padding:60px 24px 32px}.footer-container{background:var(--white);border-radius:24px;padding:48px;box-shadow:0 4px 24px #00000008;max-width:1000px;margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:48px}.footer-logo{font-family:Sora,sans-serif;font-size:14px;margin-bottom:12px}.footer-logo .jv{font-weight:800;color:var(--grey-800)}.footer-logo .studio{font-weight:400;color:#767674;letter-spacing:.14em;text-transform:uppercase}.footer-desc{font-size:13px;color:var(--grey-400);line-height:1.7;margin-bottom:20px}.footer-socials{display:flex;gap:8px}.social-circle{width:36px;height:36px;border-radius:50%;border:1px solid var(--grey-200);display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--grey-500);font-weight:600;text-decoration:none;transition:all .3s}.social-circle:hover{background:var(--accent-light);border-color:var(--accent);color:var(--accent-dark)}.footer-col .footer-heading{font-family:Sora,sans-serif;font-weight:500;font-size:11px;color:#6f6355;text-transform:uppercase;letter-spacing:3px;margin-bottom:20px}.footer-col a,.footer-col p{display:block;font-size:13px;color:var(--grey-400);margin-bottom:10px;transition:color .3s;line-height:1.6;text-decoration:none}.footer-col a:hover{color:var(--grey-800)}.footer-bottom{display:flex;justify-content:space-between;align-items:center;max-width:1000px;margin:28px auto 0;padding:0 8px}.footer-copy{font-size:11px;color:var(--grey-400)}.footer-legal{display:flex;gap:20px}.footer-legal a{font-size:11px;color:var(--grey-400);text-decoration:none;transition:color .3s}.footer-legal a:hover{color:var(--grey-500)}.scroll-btn{position:fixed;bottom:32px;right:32px;width:44px;height:44px;border-radius:50%;background:var(--white);border:1px solid var(--grey-100);box-shadow:0 4px 16px #0000000f;display:flex;align-items:center;justify-content:center;z-index:900;opacity:0;pointer-events:none;transition:opacity .4s,transform .4s cubic-bezier(.16,1,.3,1),box-shadow .3s,border-color .3s;transform:translateY(12px)}.scroll-btn.visible{opacity:1;pointer-events:all;transform:translateY(0)}.scroll-btn:hover{border-color:var(--accent);box-shadow:0 6px 20px #0000001a;transform:translateY(-2px)}.scroll-btn:active{transform:translateY(0) scale(.95)}.scroll-btn svg{width:16px;height:16px;stroke:var(--grey-500);transition:stroke .3s}.scroll-btn:hover svg{stroke:var(--accent-dark)}.scroll-btn .arrow-up,.scroll-btn.at-bottom .arrow-down{display:none}.scroll-btn.at-bottom .arrow-up{display:block}.inner-hero{padding:160px 24px 80px;text-align:center;background:var(--white)}.inner-hero h1{font-family:Sora,sans-serif;font-weight:200;font-size:clamp(32px,5vw,56px);color:var(--grey-800);letter-spacing:-.03em;line-height:1.15;margin-bottom:20px}.inner-hero p{font-family:Inter,sans-serif;font-weight:300;font-size:16px;color:var(--grey-400);max-width:520px;margin:0 auto;line-height:1.7}.inner-content{padding:80px 24px;max-width:720px;margin:0 auto}.inner-content h2{font-family:Sora,sans-serif;font-weight:500;font-size:24px;color:var(--grey-800);margin-bottom:16px;margin-top:48px}.inner-content h2:first-child{margin-top:0}.inner-content p{font-family:Inter,sans-serif;font-weight:400;font-size:15px;color:var(--grey-500);line-height:1.8;margin-bottom:16px}.inner-content ul,.inner-content ol{padding-left:24px;margin-bottom:16px}.inner-content li{font-family:Inter,sans-serif;font-weight:400;font-size:15px;color:var(--grey-500);line-height:1.8;margin-bottom:8px}.page-404{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:0 24px}.page-404 h1{font-family:Sora,sans-serif;font-weight:200;font-size:120px;color:var(--grey-100);line-height:1}.page-404 p{font-family:Inter,sans-serif;font-weight:300;font-size:16px;color:var(--grey-400);margin:16px 0 32px}.page-404 a{font-family:Sora,sans-serif;font-weight:500;font-size:13px;color:var(--accent-dark);text-decoration:none;border-bottom:1px solid var(--accent);padding-bottom:2px;transition:color .3s,border-color .3s}.page-404 a:hover{color:var(--grey-800);border-color:var(--grey-800)}.legal-content{padding:80px 24px 120px;max-width:720px;margin:0 auto}.legal-content .section-prefix{font-family:Sora,sans-serif;font-weight:500;font-size:10px;letter-spacing:5px;text-transform:uppercase;color:var(--accent-dark);margin-bottom:12px}.legal-content .section-prefix:before{content:"//";margin-right:10px;font-weight:300;letter-spacing:2px}.legal-content h2{font-family:Sora,sans-serif;font-weight:500;font-size:20px;color:var(--grey-800);margin-bottom:16px;margin-top:48px}.legal-content h2:first-child{margin-top:0}.legal-content p{font-family:Inter,sans-serif;font-weight:400;font-size:14px;color:var(--grey-500);line-height:1.8;margin-bottom:12px}.legal-content ul{padding-left:20px;margin-bottom:12px}.legal-content li{font-family:Inter,sans-serif;font-weight:400;font-size:14px;color:var(--grey-500);line-height:1.8;margin-bottom:6px}@media(max-width:1024px){.blog-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.nav{padding:0 24px}.nav-links,.nav-cta-desktop{display:none}.hamburger{display:flex;z-index:1000}.about-stats{flex-direction:column;gap:32px}.about-skills{gap:12px 24px}.project-card,.project-card.reversed{grid-template-columns:1fr}.project-card.reversed .project-image,.project-card.reversed .project-info{order:0}.project-image{min-height:200px}.project-info{padding:32px 28px}.process-steps{flex-direction:column;gap:32px;align-items:center}.process-line{display:none}.cta-container{padding:52px 28px}.cta-container h2{font-size:28px}.footer-container{grid-template-columns:1fr;gap:32px}.footer-bottom{flex-direction:column;gap:12px;text-align:center}.hero h1{font-size:clamp(32px,8vw,52px)}.about-title{font-size:26px}.about-text{font-size:16px}.testimonial-quote{font-size:17px}.service-item{grid-template-columns:40px 1fr;padding:32px 0}.blog-grid{grid-template-columns:1fr;max-width:400px}.mobile-menu a{font-size:26px;padding:12px 0}.mobile-menu{padding:90px 32px 60px}.mobile-menu .nav-cta{font-size:14px;padding:16px 36px;margin-top:24px}.mobile-menu:after{font-size:80px;bottom:30px;right:30px}.blog-post-content{padding:40px 24px 80px}.blog-post-hero{padding:120px 24px 40px}}
