:root{--font-display: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-body: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace;--color-text: #1d1d1f;--color-text-secondary: #6e6e73;--color-text-tertiary: #999;--color-bg: #fbfbfd;--color-bg-elevated: #ffffff;--color-bg-alt: #f5f5f7;--color-border: #e8e8ed;--color-border-light: #f0f0f3;--color-accent: #0071e3;--color-accent-hover: #0077ed;--max-width: 1120px;--header-height: 64px;--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--ease-out-quart: cubic-bezier(.25, 1, .5, 1);color-scheme:light dark}[data-theme=dark]{--color-text: #f5f5f7;--color-text-secondary: #a1a1a6;--color-text-tertiary: #6e6e73;--color-bg: #0a0a0a;--color-bg-elevated: #1c1c1e;--color-bg-alt: #141414;--color-border: #2c2c2e;--color-border-light: #1c1c1e;--color-accent: #2997ff;--color-accent-hover: #40a9ff}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:100%;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);font-size:1rem;line-height:1.6;color:var(--color-text);background-color:var(--color-bg);min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden}img{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none}ul,ol{list-style:none}h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;letter-spacing:-.025em;line-height:1.15}h1{font-size:clamp(2.5rem,5vw,3.5rem)}h2{font-size:clamp(1.75rem,3vw,2.5rem)}h3{font-size:1.25rem}p{margin-bottom:1rem;line-height:1.7}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 2rem}main{flex:1}.section-tag{display:inline-block;font-family:var(--font-mono);font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--color-accent);margin-bottom:1rem}.section-tag:before{content:"// ";color:var(--color-text-tertiary)}.dot-grid{position:relative;background-image:radial-gradient(circle,var(--color-border) 1px,transparent 1px);background-size:24px 24px}.dot-grid:after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 600px 400px at 0% 0%,transparent 0%,var(--color-bg) 70%);background-size:200% 200%;animation:dotWave 8s ease-in-out infinite;pointer-events:none;z-index:0}.dot-grid>*{position:relative;z-index:1}@keyframes dotWave{0%{background-position:0% 0%}25%{background-position:100% 30%}50%{background-position:100% 100%}75%{background-position:0% 70%}to{background-position:0% 0%}}.site-header{position:sticky;top:0;z-index:100;height:var(--header-height);background:#fbfbfdb8;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--color-border-light)}[data-theme=dark] .site-header{background:#0a0a0ab8}.site-header .container{display:flex;align-items:center;justify-content:space-between;height:100%}.site-title{font-family:var(--font-display);font-size:1.25rem;font-weight:800;letter-spacing:-.03em;transition:opacity .2s ease}.site-title:hover{opacity:.7}.site-nav{display:flex;gap:2rem;align-items:center}.site-nav a{font-size:.875rem;font-weight:500;color:var(--color-text-secondary);transition:color .2s ease;position:relative}.site-nav a:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:1.5px;background:var(--color-text);transition:width .3s var(--ease-out-expo)}.site-nav a:hover{color:var(--color-text)}.site-nav a:hover:after{width:100%}.theme-toggle{background:none;border:none;cursor:pointer;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);transition:all .25s ease}.theme-toggle:hover{color:var(--color-text);background:var(--color-bg-alt)}.theme-toggle .icon-sun,.theme-toggle .icon-moon{transition:opacity .2s ease,transform .3s var(--ease-out-expo)}.theme-toggle .icon-sun{display:none}.theme-toggle .icon-moon,[data-theme=dark] .theme-toggle .icon-sun{display:block}[data-theme=dark] .theme-toggle .icon-moon{display:none}.gradient-text{position:relative;background:linear-gradient(90deg,#a78bfa,#7dd3fc,#c4b5fd,#f0abfc,#93c5fd,#a78bfa);background-size:300% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:gradientShift 4s ease infinite}.gradient-text:after{content:"";position:absolute;left:0;bottom:.05em;width:100%;height:.08em;background:linear-gradient(90deg,#a78bfa,#7dd3fc,#c4b5fd);border-radius:1px;transform:scaleX(0);transform-origin:left;transition:transform .35s cubic-bezier(.4,0,.2,1)}.gradient-text:hover:after,.gradient-text:active:after{transform:scaleX(1)}[data-theme=dark] .gradient-text{background:linear-gradient(90deg,#c4b5fd,#7dd3fc,#d8b4fe,#f0abfc,#93c5fd,#c4b5fd);background-size:300% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:gradientShift 4s ease infinite}[data-theme=dark] .gradient-text:after{background:linear-gradient(90deg,#c4b5fd,#7dd3fc,#d8b4fe)}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.hero{padding:3.5rem 0 0;display:flex;flex-direction:column;align-items:center}.hero .container{display:flex;flex-direction:column;align-items:center;text-align:center}.anim-fade{opacity:0;transform:translateY(20px);animation:heroFadeIn .8s var(--ease-out-expo) forwards;animation-delay:var(--delay, 0s)}.anim-line{display:block;opacity:0;transform:translateY(24px);animation:heroFadeIn .7s var(--ease-out-expo) forwards;animation-delay:var(--delay, 0s)}@keyframes heroFadeIn{to{opacity:1;transform:translateY(0)}}.hero-labels{font-family:var(--font-mono);font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-secondary);margin-bottom:1.25rem}.hero-badge{display:inline-flex;align-items:center;gap:.375rem;font-family:var(--font-mono);font-size:.8125rem;font-weight:500;color:var(--color-accent);background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:100px;padding:.375rem 1rem;margin-bottom:1.5rem;transition:box-shadow .3s ease,border-color .3s ease}.hero-badge:hover,.hero-badge:active{box-shadow:0 0 20px #7c3aed66,0 0 40px #7c3aed26;border-color:var(--color-accent)}.hero-badge__bracket{color:var(--color-text-tertiary)}.hero-badge__slash{color:var(--color-accent);opacity:.6}.hero-heading{font-size:clamp(2.25rem,4.5vw,3.25rem);font-weight:700;line-height:1.12;letter-spacing:-.035em;margin-bottom:1.25rem;color:var(--color-text)}.hero-heading strong{font-weight:700}.hero-bio{font-size:1.0625rem;line-height:1.75;color:var(--color-text-secondary);margin-bottom:1.5rem;max-width:520px;margin-left:auto;margin-right:auto}.hero-bio a{color:var(--color-text);text-decoration:underline;text-decoration-color:var(--color-border);text-underline-offset:.2em;transition:text-decoration-color .3s ease}.hero-bio a:hover{text-decoration-color:var(--color-accent)}.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;justify-content:center;margin-bottom:0}.btn{display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:.9375rem;font-weight:600;padding:.75rem 1.75rem;border-radius:980px;cursor:pointer;transition:all .25s var(--ease-out-quart);border:none}.btn-primary{background:var(--color-text);color:var(--color-bg)}.btn-primary:hover{background:#333;transform:scale(1.02)}.btn-ghost{background:transparent;color:var(--color-accent);padding:.75rem .5rem}.btn-ghost:hover{color:var(--color-accent-hover)}.btn-ghost .arrow{display:inline-block;margin-left:.35rem;transition:transform .25s var(--ease-out-expo)}.btn-ghost:hover .arrow{transform:translate(4px)}.hero-showcase{width:100%;margin-top:2.5rem}.hero-showcase__frame{position:relative;overflow:hidden;transition:border-radius .1s linear;margin:0 auto}.hero-showcase__image{width:100%;height:70vh;min-height:400px;max-height:640px;object-fit:cover;object-position:center 20%;display:block}.hero-showcase__name{position:absolute;bottom:2rem;left:0;right:0;text-align:center;font-family:var(--font-display);font-size:clamp(1.25rem,3vw,2.25rem);font-weight:700;letter-spacing:-.02em;color:#fff;text-shadow:0 2px 20px rgba(0,0,0,.4);padding:0 1rem}.back-to-top{position:fixed;bottom:2rem;right:2rem;width:44px;height:44px;border-radius:50%;border:1px solid var(--color-border);background:var(--color-bg-elevated);color:var(--color-text);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(12px);pointer-events:none;transition:opacity .3s ease,transform .3s ease,background .2s ease;z-index:90;box-shadow:0 2px 12px #00000014}.back-to-top.is-visible{opacity:1;transform:translateY(0);pointer-events:auto}.back-to-top:hover{background:var(--color-text);color:var(--color-bg);border-color:var(--color-text)}.stats{padding:4rem 0;border-top:1px solid var(--color-border)}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;text-align:center}.stat-item{padding:1.5rem 0}.stat-value{font-family:var(--font-display);font-size:2rem;font-weight:800;letter-spacing:-.03em;margin-bottom:.5rem;min-height:2.5rem;display:flex;align-items:center;justify-content:center}.stat-label{font-family:var(--font-mono);font-size:.65rem;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-secondary)}.about{padding:6rem 0;background:var(--color-bg-alt)}.about-grid{display:grid;grid-template-columns:200px 1fr;gap:4rem}.about-content h2{margin-bottom:1.5rem}.about-content p{color:var(--color-text-secondary);font-size:1.0625rem;line-height:1.8}.about-details{display:flex;gap:3rem;margin-top:2rem;padding-top:2rem;border-top:1px solid var(--color-border)}.about-detail{display:flex;flex-direction:column;gap:.25rem}.about-detail-label{font-family:var(--font-mono);font-size:.65rem;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-tertiary)}.about-detail-value{font-size:.9375rem;font-weight:600;color:var(--color-text)}.keahlian{padding:6rem 0}.skills-track-wrapper{position:relative;overflow:hidden}.skills-track-wrapper:before,.skills-track-wrapper:after{content:"";position:absolute;top:0;bottom:0;width:4rem;z-index:2;pointer-events:none}.skills-track-wrapper:before{left:0;background:linear-gradient(to right,var(--color-bg),transparent)}.skills-track-wrapper:after{right:0;background:linear-gradient(to left,var(--color-bg),transparent)}.skills-track{display:flex;gap:1.25rem;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:1rem 2rem 1.5rem;padding-left:max(2rem,calc((100vw - var(--max-width)) / 2 + 2rem))}.skills-track::-webkit-scrollbar{display:none}.skill-card{flex:0 0 260px;display:flex;flex-direction:column;scroll-snap-align:center;padding:2rem 1.75rem;border-radius:16px;border:1px solid var(--color-border-light);background:var(--color-bg-elevated);transition:border-color .3s ease,box-shadow .3s ease}.skill-card:hover{border-color:#a78bfa66;box-shadow:0 4px 16px #0000000a,0 0 0 1px #a78bfa26}.skill-icon{color:var(--color-accent);margin-bottom:1.25rem}.skill-card h3{font-family:var(--font-mono);font-size:.95rem;font-weight:600;letter-spacing:-.01em;margin-bottom:.5rem}.skill-card p{font-size:.85rem;color:var(--color-text-secondary);line-height:1.6;margin-bottom:0;margin-top:auto}.skills-nav{display:flex;gap:.5rem;margin-top:1.25rem}.skills-nav__btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;border:1px solid var(--color-border);background:var(--color-bg-elevated);color:var(--color-text);cursor:pointer;transition:border-color .2s,color .2s,opacity .2s}.skills-nav__btn:hover:not(.is-disabled){border-color:var(--color-accent);color:var(--color-accent)}.skills-nav__btn.is-disabled{opacity:.25;cursor:default;pointer-events:none}.portfolio{padding:6rem 0}.section-header{margin-bottom:3rem}.section-header h2{margin-bottom:.5rem}.section-header p{color:var(--color-text-secondary);font-size:1.0625rem}.portfolio-track-wrapper{max-width:1100px;margin:0 auto;padding:0 1.5rem}.portfolio-track{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.portfolio-card{display:block;text-decoration:none;color:inherit;border-radius:16px;overflow:hidden;background:var(--color-bg-elevated);border:1px solid var(--color-border-light);transform:translateY(0);box-shadow:0 2px 8px #0000;transition:transform .5s cubic-bezier(.25,1,.5,1),box-shadow .5s cubic-bezier(.25,1,.5,1),border-color .3s ease}.portfolio-card:hover{transform:translateY(-6px);border-color:#a78bfa66;box-shadow:0 8px 24px #0000000f,0 24px 48px #0000000a,0 0 0 1px #a78bfa26}.portfolio-card__image{overflow:hidden;aspect-ratio:3 / 2}.portfolio-card__image img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.25,1,.5,1)}.portfolio-card:hover .portfolio-card__image img{transform:scale(1.04)}.portfolio-card__body{padding:1.25rem 1.5rem 1.5rem}.portfolio-card__tag{display:inline-block;font-family:var(--font-mono);font-size:.625rem;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--color-accent);margin-bottom:.5rem}.portfolio-card__body h3{margin-bottom:.5rem;letter-spacing:-.015em}.portfolio-card__body p{font-size:.9rem;color:var(--color-text-secondary);line-height:1.55;margin-bottom:0}.portfolio-actions{display:flex;align-items:center;justify-content:space-between;margin-top:1.5rem}.swipe-hint{display:none;align-items:center;gap:.4rem;color:var(--color-text-secondary);font-size:.8125rem;font-family:var(--font-mono);letter-spacing:.02em}.swipe-hint__arrow{animation:swipeArrow 1.5s ease-in-out infinite}@keyframes swipeArrow{0%,to{transform:translate(0);opacity:.5}50%{transform:translate(6px);opacity:1}}.portfolio-page{padding:6rem 0}.portfolio-page__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.blog-preview{padding:6rem 0;background:var(--color-bg-alt)}.blog-preview__list{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.blog-preview__item{display:block;text-decoration:none;color:inherit;border-radius:16px;overflow:hidden;background:var(--color-bg-elevated);border:1px solid var(--color-border-light);transition:transform .5s cubic-bezier(.25,1,.5,1),box-shadow .5s cubic-bezier(.25,1,.5,1),border-color .3s ease}.blog-preview__item:hover{transform:translateY(-4px);border-color:#a78bfa4d;box-shadow:0 8px 24px #0000000f}.blog-preview__image{overflow:hidden;aspect-ratio:16 / 9}.blog-preview__image img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.25,1,.5,1)}.blog-preview__item:hover .blog-preview__image img{transform:scale(1.04)}.blog-preview__body{padding:1.25rem 1.5rem 1.5rem}.blog-preview__date{display:block;font-family:var(--font-mono);font-size:.6875rem;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-secondary);margin-bottom:.5rem}.blog-preview__body h3{margin-bottom:.5rem;letter-spacing:-.015em;font-size:1.1rem}.blog-preview__body p{font-size:.875rem;color:var(--color-text-secondary);line-height:1.55;margin-bottom:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.blog-preview__cta{margin-top:2rem;text-align:center}.galeri-preview{padding:6rem 0 0}.galeri-preview__grid-wrapper{position:relative;max-width:1100px;margin:0 auto;padding:0 1.5rem;overflow:hidden}.galeri-preview__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;max-height:420px;overflow:hidden}.galeri-preview__item{border-radius:8px;overflow:hidden}.galeri-preview__item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}.galeri-preview__item:hover img{transform:scale(1.05)}.galeri-preview__item:nth-child(1),.galeri-preview__item:nth-child(4){grid-row:span 2}.galeri-preview__fade{position:absolute;bottom:0;left:0;right:0;height:180px;background:linear-gradient(to bottom,transparent,var(--color-bg));pointer-events:none;z-index:1}.galeri-preview__cta{position:absolute;bottom:1.5rem;left:0;right:0;text-align:center;z-index:2}@media(max-width:768px){.galeri-preview__grid{grid-template-columns:repeat(2,1fr);max-height:320px}}@media(max-width:480px){.galeri-preview__grid{max-height:260px}}.contact{padding:6rem 0;background:var(--color-bg-alt)}.contact-inner{text-align:center}.contact-heading{font-size:clamp(1.75rem,3vw,2.25rem);margin-bottom:.75rem}.contact-description{color:var(--color-text-secondary);font-size:1.0625rem;max-width:480px;margin:0 auto 3rem;line-height:1.7}.contact-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:1.25rem;max-width:720px;margin:0 auto}.contact-card{width:calc((100% - 2 * 1.25rem) / 3);box-sizing:border-box;display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:2rem 1rem;background:var(--color-bg-elevated);border:1px solid var(--color-border-light);border-radius:16px;transition:all .3s var(--ease-out-expo)}.contact-card:hover{border-color:#a78bfa66;transform:translateY(-4px);box-shadow:0 4px 12px #0000000a,0 12px 32px #0000000f,0 0 0 1px #a78bfa26}.contact-icon{color:var(--color-text-secondary);margin-bottom:.125rem}.contact-label{font-family:var(--font-mono);font-size:.65rem;font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:var(--color-text-tertiary)}.contact-value{font-size:.85rem;font-weight:500;color:var(--color-text);word-break:break-all}.page-header{padding:4rem 0 2rem}.page-header h1{margin-bottom:.5rem}.page-header p{color:var(--color-text-secondary);font-size:1.0625rem}.blog-list{padding:0}.blog-list li{margin-bottom:0}.post-card{display:grid;grid-template-columns:260px 1fr;gap:1.5rem;align-items:center;padding:1.5rem 0;border-bottom:1px solid var(--color-border-light);transition:all .3s var(--ease-out-expo)}.post-card:hover .post-card__title{color:var(--color-accent)}.post-card:hover .post-card__image img{transform:scale(1.03)}.post-card__image{border-radius:12px;overflow:hidden;aspect-ratio:16 / 10}.post-card__image img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease-out-expo)}.post-card__body{min-width:0}.post-card__date{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-tertiary);margin-bottom:.5rem}.post-card__title{font-family:var(--font-display);font-size:1.375rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.5rem;transition:color .2s ease}.post-card__description{font-size:.9375rem;color:var(--color-text-secondary);line-height:1.6;margin-bottom:0}.post-header{text-align:center;padding:4rem 0 2.5rem;max-width:680px;margin:0 auto}.post-header h1{font-size:clamp(2rem,4vw,2.75rem);margin-bottom:.75rem}.post-meta{font-size:.8rem;font-weight:500;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:1.25rem}.post-subtitle{font-size:1.125rem;color:var(--color-text-secondary);line-height:1.6;max-width:540px;margin:0 auto}.post-header .hero-image{margin-top:2.5rem;border-radius:16px;display:block;margin-left:auto;margin-right:auto;max-width:100%}.post-content{max-width:680px;margin:0 auto;font-size:1.0625rem;line-height:1.8;color:var(--color-text-secondary)}.post-content h2{margin-top:3rem;margin-bottom:1rem}.post-content h3{margin-top:2rem;margin-bottom:.75rem}.post-content p{margin-bottom:1.25rem}.post-content ul,.post-content ol{padding-left:1.5rem;margin-bottom:1.25rem}.post-content ul{list-style:disc}.post-content ol{list-style:decimal}.post-content li{margin-bottom:.4rem}.post-content strong{font-weight:600;color:var(--color-text)}.post-content blockquote{border-left:3px solid var(--color-border);padding:.75rem 1.25rem;margin:2rem 0;color:var(--color-text-secondary);font-style:italic;background:#00000003;border-radius:0 8px 8px 0}.post-content code{font-family:var(--font-mono);font-size:.85em;background:#0000000a;padding:.2em .45em;border-radius:6px}.post-content pre{background:#1d1d1f;color:#f5f5f7;padding:1.25rem 1.5rem;border-radius:12px;overflow-x:auto;margin:2rem 0;font-size:.875rem;line-height:1.6}.post-content pre code{background:none;padding:0;color:inherit}.post-content img{border-radius:12px;margin:2rem 0}.post-content hr{border:none;border-top:1px solid var(--color-border);margin:3rem 0}.post-content a{color:var(--color-accent);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}.post-content a:hover{color:var(--color-accent-hover)}.post-nav{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--color-border-light)}.site-footer{padding:3.5rem 0 0;border-top:1px solid var(--color-border-light);font-size:.8125rem;color:var(--color-text-tertiary)}.footer-inner{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:3rem;padding-bottom:2.5rem}.footer-logo{font-family:var(--font-display);font-size:1.25rem;font-weight:800;color:var(--color-text);text-decoration:none;letter-spacing:-.03em}.footer-tagline{margin-top:.75rem;font-size:.875rem;color:var(--color-text-secondary);line-height:1.6;max-width:280px}.footer-nav__title{font-family:var(--font-mono);font-size:.65rem;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-secondary);margin-bottom:1rem}.footer-nav__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.625rem}.footer-nav__list a{font-size:.875rem;color:var(--color-text-tertiary);text-decoration:none;transition:color .2s ease}.footer-nav__list a:hover{color:var(--color-text)}.footer-social__links{display:flex;gap:.75rem}.footer-social__links a{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:1px solid var(--color-border-light);color:var(--color-text-tertiary);transition:all .25s ease}.footer-social__links a:hover{color:var(--color-text);border-color:var(--color-border);transform:translateY(-2px)}.footer-bottom{padding:1.5rem 0;border-top:1px solid var(--color-border-light);text-align:center}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.error-page{padding:8rem 0;text-align:center}.error-content{max-width:480px;margin:0 auto}.error-code{display:block;font-family:var(--font-mono);font-size:clamp(4rem,10vw,8rem);font-weight:700;letter-spacing:-.05em;background:linear-gradient(135deg,var(--color-text-tertiary),var(--color-accent));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:1rem;line-height:1}.error-page h1{margin-bottom:1rem}.error-description{color:var(--color-text-secondary);font-size:1.0625rem;line-height:1.7;margin-bottom:2rem}@keyframes bounceDown{0%,to{transform:translateY(0)}50%{transform:translateY(6px)}}.reveal{opacity:0;transform:translateY(32px);transition:opacity .7s var(--ease-out-expo),transform .7s var(--ease-out-expo)}.reveal.is-visible{opacity:1;transform:translateY(0)}.reveal-stagger>.reveal:nth-child(1){transition-delay:0s}.reveal-stagger>.reveal:nth-child(2){transition-delay:.1s}.reveal-stagger>.reveal:nth-child(3){transition-delay:.2s}.reveal-stagger>.reveal:nth-child(4){transition-delay:.3s}.reveal-stagger>.reveal:nth-child(5){transition-delay:.4s}.reveal-stagger>.reveal:nth-child(6){transition-delay:.5s}button.contact-card{text-align:center;cursor:pointer;font-family:var(--font-body);font-size:inherit;line-height:inherit;color:inherit}.wa-modal{position:fixed;inset:0;z-index:1000;background:#0009;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s ease;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:1.5rem}.wa-modal.is-open{opacity:1;pointer-events:all}.wa-modal__content{background:var(--color-bg-elevated);border-radius:16px;padding:2rem;max-width:420px;width:100%;position:relative;box-shadow:0 20px 60px #0003}.wa-modal__close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;color:var(--color-text-tertiary);cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.wa-modal__close:hover{background:var(--color-bg-alt);color:var(--color-text)}.wa-modal__title{font-size:1.25rem;margin-bottom:.5rem}.wa-modal__desc{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:1.5rem;line-height:1.5}.wa-form__field{margin-bottom:1rem}.wa-form__field label{display:block;font-size:.8125rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:.375rem}.wa-form__field input,.wa-form__field textarea{width:100%;padding:.75rem 1rem;border:1px solid var(--color-border);border-radius:10px;background:var(--color-bg);color:var(--color-text);font-family:var(--font-body);font-size:.9375rem;transition:border-color .2s ease;resize:vertical}.wa-form__field input:focus,.wa-form__field textarea:focus{outline:none;border-color:var(--color-accent)}.wa-form__submit{width:100%;display:flex;align-items:center;justify-content:center;margin-top:.5rem;background:#25d366;border-color:#25d366}.wa-form__submit:hover{background:#1da851;border-color:#1da851}.gallery-filters{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2.5rem}.gallery-filter{padding:.5rem 1.25rem;border:1px solid var(--color-border);border-radius:100px;background:transparent;color:var(--color-text-secondary);font-family:var(--font-body);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .25s var(--ease-out-expo)}.gallery-filter:hover{border-color:var(--color-text);color:var(--color-text)}.gallery-filter.is-active{background:var(--color-text);border-color:var(--color-text);color:var(--color-bg)}.gallery-masonry{columns:3;column-gap:1rem}.gallery-item{break-inside:avoid;margin-bottom:1rem;border-radius:12px;overflow:hidden;position:relative;cursor:pointer}.gallery-item img{width:100%;height:auto;display:block;transition:transform .5s var(--ease-out-expo)}.gallery-item:hover img{transform:scale(1.04)}.gallery-item__overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.65) 0%,transparent 50%);display:flex;flex-direction:column;justify-content:flex-end;padding:1.25rem;opacity:0;transition:opacity .3s ease}.gallery-item:hover .gallery-item__overlay{opacity:1}.gallery-item__category{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#ffffffb3;margin-bottom:.25rem}.gallery-item__title{font-size:.9375rem;font-weight:600;color:#fff;line-height:1.3}.lightbox{position:fixed;inset:0;z-index:1000;background:#000000eb;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1rem;opacity:0;pointer-events:none;transition:opacity .3s ease;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.lightbox.is-open{opacity:1;pointer-events:all}.lightbox__close{position:absolute;top:1.5rem;right:1.5rem;background:none;border:none;color:#ffffffb3;font-size:2rem;cursor:pointer;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.lightbox__close:hover{color:#fff;background:#ffffff1a}.lightbox__image{max-width:90vw;max-height:80vh;object-fit:contain;border-radius:8px;box-shadow:0 20px 60px #00000080}.lightbox__caption{color:#fffc;font-size:.9375rem;font-weight:500}@media(prefers-reduced-motion:reduce){.reveal,.anim-fade,.anim-line{opacity:1;transform:none;transition:none;animation:none}.dot-grid:after{animation:none}}@media(max-width:768px){.hero{padding:3rem 0 0}.hero-heading{font-size:2rem}.hero-bio{max-width:100%}.hero-showcase{margin-top:2.5rem}.hero-showcase__image{height:50vh;min-height:300px}.hero-showcase__name{font-size:1.25rem;bottom:1.5rem}.back-to-top{bottom:1.25rem;right:1.25rem;width:40px;height:40px}.stats-grid{grid-template-columns:1fr;gap:0}.stat-item{padding:1.25rem 0;border-bottom:1px solid var(--color-border-light)}.stat-item:last-child{border-bottom:none}.about-grid{grid-template-columns:1fr;gap:1rem}.about-details{flex-direction:column;gap:1.25rem}.portfolio-track-wrapper{position:relative;overflow:hidden;padding:0;-webkit-mask-image:linear-gradient(to right,transparent,black 1.5rem,black calc(100% - 1.5rem),transparent);mask-image:linear-gradient(to right,transparent,black 1.5rem,black calc(100% - 1.5rem),transparent)}.portfolio-track{display:flex;gap:1rem;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-webkit-overflow-scrolling:touch;padding:.5rem 1.5rem 1rem}.portfolio-track::-webkit-scrollbar{display:none}.portfolio-card{flex:0 0 80vw;max-width:320px;scroll-snap-align:center}.swipe-hint{display:flex}.portfolio-page__grid,.blog-preview__list{grid-template-columns:1fr}.gallery-masonry{columns:2}.post-card{grid-template-columns:1fr;gap:1rem}.contact-card{width:calc((100% - 1rem)/2);min-width:0}.footer-inner{grid-template-columns:1fr;gap:2rem;text-align:center}.footer-tagline{max-width:100%}.footer-nav__list{flex-direction:row;flex-wrap:wrap;justify-content:center;gap:.5rem 1.25rem}.footer-social__links{justify-content:center}.site-nav{gap:1rem;justify-content:center}.site-nav a{font-size:.8125rem}.container{padding:0 1.25rem}}@media(max-width:480px){.site-header .container{flex-direction:column;align-items:center;gap:.25rem;padding-top:.5rem;padding-bottom:0}.site-header{height:auto}.site-header nav{width:100%;position:relative;overflow:hidden;-webkit-mask-image:linear-gradient(to right,transparent,black 2rem,black calc(100% - 2rem),transparent);mask-image:linear-gradient(to right,transparent,black 2rem,black calc(100% - 2rem),transparent)}.site-nav{flex-wrap:nowrap;white-space:nowrap;gap:1.5rem;padding:.5rem 1rem;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;justify-content:flex-start}.site-nav::-webkit-scrollbar{display:none}.site-nav a{font-size:.8125rem}.contact-card{width:100%;min-width:0}.gallery-masonry{columns:1}}
