*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}img{display:block;max-width:100%}a{text-decoration:none;color:inherit}ul{list-style:none}button{cursor:pointer;border:none;background:none;font:inherit}:root{--bg: #ffffff;--bg2: #f5f5f7;--surface: #f0f0f4;--accent: #8b7ec8;--accent2: #a899d4;--accent-glow: rgba(139, 126, 200, .3);--accent-dim: rgba(139, 126, 200, .07);--text: #0d0d14;--muted: #6b6b80;--subtle: #e4e4ec;--rule: rgba(0, 0, 0, .08);--sans: "Plus Jakarta Sans", sans-serif;--mono: "DM Mono", monospace;--nav-h: 65px}body{font-family:var(--sans);background:var(--bg);color:var(--text);line-height:1.65;-webkit-font-smoothing:antialiased;cursor:none;overflow-x:hidden}body:after{content:"";position:fixed;top:-200%;right:-200%;bottom:-200%;left:-200%;width:400%;height:400%;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");opacity:.025;pointer-events:none;z-index:1}.reveal{opacity:0;transform:translateY(36px);transition:opacity .7s ease,transform .7s ease}.reveal.vis{opacity:1;transform:translateY(0)}.reveal-d1{transition-delay:.1s}.reveal-d2{transition-delay:.2s}.reveal-d3{transition-delay:.3s}.cursor{position:fixed;width:8px;height:8px;background:var(--accent);border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:9999;box-shadow:0 0 8px var(--accent-glow)}.cursor-ring{position:fixed;width:32px;height:32px;border:1.5px solid var(--accent);border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:9998;opacity:.45;transition:width .2s,height .2s,opacity .2s}body:has(a:hover) .cursor-ring,body:has(button:hover) .cursor-ring{width:48px;height:48px;opacity:.75}nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;padding:0 48px;background:#ffffffe0;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--rule);z-index:500}.logo{font-family:var(--sans);font-weight:800;font-size:1.1rem;letter-spacing:-.03em;color:var(--text)}.logo span{color:var(--accent)}.nav-links{display:flex;gap:32px}.nav-links a{font-size:.875rem;font-weight:500;color:var(--muted);transition:color .2s}.nav-links a:hover,.nav-links a.active{color:var(--text)}.nav-right{display:flex;align-items:center;gap:16px}.nav-btn{font-family:var(--sans);font-size:.8rem;font-weight:600;padding:8px 20px;border-radius:8px;background:var(--accent);color:#fff;letter-spacing:.01em;transition:opacity .2s,box-shadow .2s;box-shadow:0 2px 12px var(--accent-glow)}.nav-btn:hover{opacity:.88}.hamburger{display:none;flex-direction:column;gap:5px;width:24px}.ham-line{display:block;height:2px;width:100%;background:var(--text);border-radius:2px;transition:transform .3s,opacity .3s}.ham-line.open:nth-child(1){transform:translateY(7px) rotate(45deg)}.ham-line.open:nth-child(2){opacity:0}.ham-line.open:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.mobile-menu{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);z-index:499;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding-top:var(--nav-h)}.mobile-nav-links{display:flex;flex-direction:column;align-items:center}.mobile-nav-links a{font-size:clamp(2rem,8vw,3.2rem);font-weight:800;letter-spacing:-.04em;color:var(--text);transition:color .2s;line-height:1.3;padding:4px 0}.mobile-nav-links a:hover{color:var(--accent)}.mobile-email{font-family:var(--mono);font-size:.8rem;color:var(--muted);margin-top:32px;letter-spacing:.05em}.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-size:.875rem;font-weight:600;padding:12px 28px;border-radius:10px;transition:all .2s;white-space:nowrap}.btn-glow{background:var(--accent);color:#fff;box-shadow:0 4px 20px var(--accent-glow)}.btn-glow:hover{opacity:.88;box-shadow:0 6px 28px var(--accent-glow)}.btn-outline{border:1.5px solid var(--subtle);color:var(--text);background:transparent}.btn-outline:hover{border-color:var(--accent);color:var(--accent)}.hero{position:relative;height:100vh;min-height:640px;display:flex;align-items:center;overflow:hidden;padding-top:var(--nav-h)}.hero-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(var(--rule) 1px,transparent 1px),linear-gradient(90deg,var(--rule) 1px,transparent 1px);background-size:48px 48px;opacity:.7;z-index:0}.hero-orb{position:absolute;top:5%;right:-5%;width:640px;height:640px;background:radial-gradient(circle,var(--accent-dim) 0%,transparent 70%);pointer-events:none;z-index:0}.hero-content{position:relative;z-index:2;max-width:55%;padding:0 80px}.hero-badge{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:.75rem;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin-bottom:24px;opacity:0;animation:fadeUp .7s ease .1s forwards}.badge-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent-glow);animation:pulse 2.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.hero-name-label{font-family:var(--mono);font-size:.78rem;color:var(--muted);letter-spacing:.06em;margin-bottom:12px;opacity:0;animation:fadeUp .7s ease .2s forwards}.hero-headline{font-size:clamp(3rem,6vw,5.5rem);font-weight:800;line-height:1.02;letter-spacing:-.04em;color:var(--text);margin-bottom:20px;opacity:0;animation:fadeUp .7s ease .3s forwards}.hero-headline em{font-style:italic;font-weight:800;color:var(--accent)}.hero-headline .accent{color:var(--accent)}.hero-typed-wrap{font-family:var(--mono);font-size:1rem;color:var(--muted);margin-bottom:36px;opacity:0;animation:fadeUp .7s ease .4s forwards;min-height:1.5em}.caret{display:inline-block;width:2px;height:1em;background:var(--accent);margin-left:2px;vertical-align:middle;animation:blink 1s step-end infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:48px;opacity:0;animation:fadeUp .7s ease .5s forwards}.hero-stats{display:grid;grid-template-columns:repeat(3,auto);gap:0;opacity:0;animation:fadeUp .7s ease .6s forwards}.hero-stat{padding:0 24px;border-right:1px solid var(--rule)}.hero-stat:first-child{padding-left:0}.hero-stat:last-child{border-right:none}.stat-num{font-size:1.75rem;font-weight:800;color:var(--text);letter-spacing:-.04em;line-height:1.1}.stat-num span{color:var(--accent)}.stat-lbl{font-size:.75rem;color:var(--muted);font-family:var(--mono);letter-spacing:.03em;margin-top:2px}.hero-image-wrap{position:absolute;right:0;top:var(--nav-h);bottom:0;width:48%;z-index:3;display:flex;align-items:flex-end;justify-content:center}.hero-image-glow{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:320px;height:200px;background:radial-gradient(ellipse,var(--accent-glow) 0%,transparent 70%);filter:blur(50px);z-index:0}.hero-image{position:relative;z-index:1;max-height:calc(100vh - var(--nav-h));width:100%;object-fit:contain;object-position:bottom center;filter:drop-shadow(0 0 32px var(--accent-glow))}.hero-image-placeholder{width:72%;max-width:380px;aspect-ratio:3/4;border-radius:20px;background:var(--surface);border:1.5px dashed var(--subtle);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--muted);font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;margin-bottom:48px}.hero-image-placeholder svg{opacity:.25;color:var(--accent)}@keyframes fadeUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.marquee-wrap{overflow:hidden;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:14px 0;background:var(--bg2)}.marquee-track{display:flex;width:max-content;animation:marquee 32s linear infinite}.marquee-item{display:flex;align-items:center;gap:14px;padding:0 24px;font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);white-space:nowrap}.m-dot{width:4px;height:4px;border-radius:50%;background:var(--accent);flex-shrink:0}@keyframes marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}.section{padding:100px 80px;max-width:1200px;margin:0 auto}.preview-alt{background:var(--bg2);max-width:100%;padding:100px 80px}.preview-alt>*{max-width:1200px;margin-left:auto;margin-right:auto}.s-eyebrow{font-family:var(--mono);font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:16px}.s-title{font-size:clamp(2.2rem,4vw,3.5rem);font-weight:800;line-height:1.05;letter-spacing:-.03em;margin-bottom:40px}.s-title em{font-style:italic;color:var(--accent);font-weight:800}.preview-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:48px;gap:24px}.about-preview-layout{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}.about-text{font-size:1rem;color:var(--muted);line-height:1.75;max-width:560px}.about-text strong{color:var(--text);font-weight:600}.about-preview-stats{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:24px}.prev-stat{background:var(--surface);border:1px solid var(--subtle);border-radius:12px;padding:20px}.prev-stat .stat-num{font-size:1.5rem}.about-mobile-image{display:none}.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.svc-card{background:var(--surface);border:1px solid var(--subtle);border-radius:16px;padding:28px;transition:border-color .2s,box-shadow .2s;position:relative;overflow:hidden}.svc-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at top left,var(--accent-dim),transparent 60%);opacity:0;transition:opacity .3s;pointer-events:none}.svc-card:hover{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 8px 32px var(--accent-dim)}.svc-card:hover:after{opacity:1}.svc-num{font-family:var(--mono);font-size:.7rem;color:var(--muted);letter-spacing:.08em;display:block;margin-bottom:16px}.svc-icon{display:block;color:var(--accent);margin-bottom:16px}.svc-title{font-size:1rem;font-weight:700;margin-bottom:10px;color:var(--text)}.svc-desc{font-size:.875rem;color:var(--muted);line-height:1.65;margin-bottom:16px}.svc-tags{display:flex;flex-wrap:wrap;gap:6px}.svc-tag{font-family:var(--mono);font-size:.68rem;color:var(--muted);background:var(--bg);border:1px solid var(--subtle);border-radius:4px;padding:3px 8px;letter-spacing:.04em}.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.work-card{background:var(--surface);border:1px solid var(--subtle);border-radius:16px;overflow:hidden;transition:border-color .2s}.work-card:hover{border-color:var(--accent)}.work-thumb{height:220px;display:flex;align-items:center;justify-content:center}.wt1{background:linear-gradient(135deg,#ede8fb,#ddd4f5)}.wt2{background:linear-gradient(135deg,#e8eefb,#d4defc)}.wt3{background:linear-gradient(135deg,#e8f3fb,#d4e8f5)}.wt4{background:linear-gradient(135deg,#f3ebe8,#f0ddd4)}.wt5{background:linear-gradient(135deg,#ebf3e8,#ddf0d4)}.wt6{background:linear-gradient(135deg,#f3e8ef,#f0d4e4)}.work-thumb-icon{color:var(--accent);opacity:.4}.work-body{padding:24px}.work-type{font-family:var(--mono);font-size:.68rem;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:8px}.work-title{font-size:1.1rem;font-weight:700;margin-bottom:10px;color:var(--text);transition:color .2s}.work-card:hover .work-title{color:var(--accent)}.work-desc{font-size:.875rem;color:var(--muted);line-height:1.65;margin-bottom:16px}.work-chips{display:flex;flex-wrap:wrap;gap:6px}.chip{font-family:var(--mono);font-size:.68rem;color:var(--muted);background:var(--bg);border:1px solid var(--subtle);border-radius:4px;padding:3px 8px}.testi-section{background:var(--bg2);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:80px}.testi-inner{max-width:720px;margin:0 auto;text-align:center}.testi-stars{color:var(--accent);font-size:1.1rem;letter-spacing:4px;margin-bottom:24px}.testi-quote{font-size:clamp(1.05rem,2.5vw,1.35rem);font-weight:500;line-height:1.65;color:var(--text);margin-bottom:32px}.testi-quote em{color:var(--accent);font-style:italic}.testi-author{display:flex;align-items:center;justify-content:center;gap:16px}.testi-av{width:44px;height:44px;border-radius:50%;background:var(--accent-dim);border:1.5px solid var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;color:var(--accent)}.testi-name{font-weight:600;font-size:.9rem;color:var(--text)}.testi-role{font-family:var(--mono);font-size:.72rem;color:var(--muted);margin-top:2px}.cta-strip{margin:0 80px;padding:32px 40px;border:1px solid var(--subtle);border-radius:16px;display:flex;justify-content:space-between;align-items:center;gap:24px;position:relative;overflow:hidden;background:var(--surface)}.cta-strip:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent2),transparent)}.cta-strip-label{font-family:var(--mono);font-size:.72rem;color:var(--accent);letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px}.cta-strip-title{font-size:1.35rem;font-weight:700;letter-spacing:-.02em;color:var(--text)}.cta-section{padding:120px 80px;text-align:center;position:relative;overflow:hidden}.cta-orb{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:400px;background:radial-gradient(ellipse,var(--accent-dim) 0%,transparent 70%);pointer-events:none}.cta-headline{font-size:clamp(2.5rem,5vw,4.5rem);font-weight:800;line-height:1.05;letter-spacing:-.04em;margin-bottom:20px;position:relative;z-index:1}.cta-headline em{font-style:italic;color:var(--accent)}.cta-sub{font-size:1rem;color:var(--muted);max-width:460px;margin:0 auto 40px;line-height:1.7;position:relative;z-index:1}.cta-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:24px;position:relative;z-index:1}.cta-contact-links{display:flex;align-items:center;gap:12px;justify-content:center;position:relative;z-index:1}.cta-email{font-family:var(--mono);font-size:.82rem;color:var(--muted);transition:color .2s}.cta-email:hover{color:var(--accent)}.cta-divider{color:var(--subtle)}.about-layout{display:grid;grid-template-columns:1fr 380px;gap:64px;align-items:start}.skills-block{margin-top:40px}.skill-row{margin-bottom:18px}.skill-top{display:flex;justify-content:space-between;margin-bottom:6px}.skill-name-lbl{font-size:.875rem;font-weight:600;color:var(--text)}.skill-pct{font-family:var(--mono);font-size:.78rem;color:var(--muted)}.skill-track{height:3px;background:var(--subtle);border-radius:2px;overflow:hidden}.skill-fill{height:100%;background:var(--accent);border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform .9s cubic-bezier(.16,1,.3,1)}.about-card{background:var(--surface);border:1px solid var(--subtle);border-radius:20px;padding:32px;position:sticky;top:calc(var(--nav-h) + 24px)}.about-card:before{content:"";display:block;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:2px;margin-bottom:28px}.avatar{width:80px;height:80px;border-radius:50%;background:var(--accent-dim);border:2px solid var(--accent);margin:0 auto 16px;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;color:var(--accent)}.about-name{text-align:center;font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:4px}.about-role{text-align:center;font-family:var(--mono);font-size:.72rem;color:var(--muted);letter-spacing:.04em;margin-bottom:24px}.about-divider{height:1px;background:var(--subtle);margin-bottom:20px}.about-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--rule)}.about-row:last-child{border-bottom:none}.about-row-key{font-family:var(--mono);font-size:.7rem;color:var(--muted);letter-spacing:.05em;text-transform:uppercase}.about-row-val{font-size:.875rem;font-weight:500;color:var(--text)}.process-section{background:var(--bg2);border-top:1px solid var(--rule);padding:80px}.process-section .s-eyebrow,.process-section .s-title{max-width:1200px;margin-left:auto;margin-right:auto}.process-section .s-title{margin-bottom:48px}.process-row{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;max-width:1200px;margin:0 auto}.proc-item{padding:28px;background:var(--bg);border:1px solid var(--subtle);border-radius:16px}.proc-num{font-family:var(--mono);font-size:.7rem;color:var(--accent);letter-spacing:.08em;text-transform:uppercase;display:block;margin-bottom:16px}.proc-title{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:10px}.proc-desc{font-size:.875rem;color:var(--muted);line-height:1.65}.certs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.cert-card{background:var(--surface);border:1px solid var(--subtle);border-radius:12px;padding:20px 24px;transition:border-color .2s}.cert-card:hover{border-color:var(--accent)}.cert-year{font-family:var(--mono);font-size:.68rem;color:var(--accent);letter-spacing:.08em;margin-bottom:8px}.cert-title{font-size:.875rem;font-weight:600;color:var(--text);margin-bottom:4px;line-height:1.45}.cert-org{font-size:.8rem;color:var(--muted)}.footer{background:var(--bg2);border-top:1px solid var(--rule);padding:64px 80px 32px;position:relative}.footer:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent2),transparent)}.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:48px;margin-bottom:48px}.footer-logo{font-size:1.1rem;font-weight:800;letter-spacing:-.03em;color:var(--text);display:block;margin-bottom:12px}.footer-logo span{color:var(--accent)}.footer-tagline{font-size:.875rem;color:var(--muted);margin-bottom:6px}.footer-sub{font-size:.78rem;color:var(--muted);font-family:var(--mono);margin-bottom:20px}.footer-socials{display:flex;gap:10px;flex-wrap:wrap}.footer-social-link{font-size:.8rem;color:var(--muted);border:1px solid var(--subtle);border-radius:6px;padding:5px 12px;transition:border-color .2s,color .2s}.footer-social-link:hover{border-color:var(--accent);color:var(--accent)}.footer-col-title{font-family:var(--mono);font-size:.7rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-bottom:16px}.footer-nav-list li+li{margin-top:10px}.footer-nav-list a{font-size:.875rem;color:var(--muted);transition:color .2s}.footer-nav-list a:hover{color:var(--accent)}.footer-avail{background:var(--surface);border:1px solid var(--subtle);border-radius:12px;padding:20px}.footer-avail-status{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:.72rem;color:var(--accent);letter-spacing:.06em;margin-bottom:10px}.footer-avail-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);animation:pulse 2.5s infinite}.footer-avail-text{font-size:.82rem;color:var(--muted);line-height:1.6}.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid var(--rule)}.footer-copy{font-size:.8rem;color:var(--muted)}.footer-credit{font-family:var(--mono);font-size:.72rem;color:var(--muted)}@media (max-width: 960px){nav{padding:0 24px}.nav-links,.nav-btn{display:none}.hamburger{display:flex}.hero{height:auto;min-height:100svh;padding:0 24px;padding-top:var(--nav-h);align-items:flex-start}.hero-content{max-width:100%;padding:48px 0}.hero-image-wrap{display:none}.hero-stats{grid-template-columns:1fr 1fr;gap:12px}.hero-stat{padding:14px 16px;border:1px solid var(--subtle);border-radius:10px;border-right:1px solid var(--subtle)}.section,.preview-alt{padding:64px 24px}.about-preview-layout{grid-template-columns:1fr;gap:32px}.about-mobile-image{display:block;margin-top:24px;border-radius:16px;overflow:hidden;border:1px solid var(--subtle)}.about-mobile-image img{width:100%;height:280px;object-fit:cover;object-position:top}.services-grid,.work-grid{grid-template-columns:1fr}.preview-header{flex-direction:column;align-items:flex-start;gap:16px}.testi-section{padding:60px 24px}.cta-strip{margin:0 24px;flex-direction:column;text-align:center}.cta-section{padding:80px 24px}.about-layout{grid-template-columns:1fr}.about-card{position:static}.process-section{padding:64px 24px}.process-row,.certs-grid{grid-template-columns:1fr}.footer{padding:48px 24px 24px}.footer-top{grid-template-columns:1fr;gap:32px}.footer-bottom{flex-direction:column;gap:8px;text-align:center}}
