*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:Inter,system-ui,sans-serif;background-color:var(--color-bg);color:var(--color-text);line-height:1.6;-webkit-font-smoothing:antialiased}body:before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;background-color:var(--color-batik);-webkit-mask-image:url(/assets/batik_kawung-D6EEbgax.svg);mask-image:url(/assets/batik_kawung-D6EEbgax.svg);-webkit-mask-size:150px 150px;mask-size:150px 150px;-webkit-mask-repeat:repeat;mask-repeat:repeat;opacity:.07}nav,main,footer{position:relative;z-index:1}a{color:var(--color-accent);text-decoration:none;transition:color .2s ease}a:hover{color:var(--color-accent-hover)}.container{max-width:1160px;margin:0 auto;padding:0 14px}.section{padding:90px 0}.section-label{display:inline-flex;align-items:center;gap:8px;font-family:Fira Code,monospace;font-size:.72rem;color:var(--color-accent);letter-spacing:.14em;text-transform:uppercase;margin-bottom:32px}.section-label:before{content:"";display:inline-block;width:20px;height:1px;background:var(--color-accent);opacity:.6}.section-title{font-size:2.4rem;font-weight:800;color:var(--color-text);margin-bottom:52px;letter-spacing:-1px;line-height:1.15}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 28px;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;border:none;letter-spacing:.01em;transition:background .2s ease,color .2s ease,box-shadow .2s ease,transform .2s ease,border-color .2s ease}.btn--primary{background:var(--color-accent);color:var(--color-bg);box-shadow:0 0 24px color-mix(in srgb,var(--color-accent) 20%,transparent)}.btn--primary:hover{background:var(--color-accent-hover);color:var(--color-bg);box-shadow:0 0 32px color-mix(in srgb,var(--color-accent) 32%,transparent);transform:translateY(-1px)}.btn--outline{border:1px solid color-mix(in srgb,var(--color-accent) 45%,transparent);color:var(--color-text);background:var(--color-surface)}.btn--outline:hover{border-color:color-mix(in srgb,var(--color-accent) 60%,transparent);color:var(--color-accent);transform:translateY(-1px)}@keyframes reveal-up{0%{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}@keyframes reveal-up-scale{0%{opacity:0;transform:translateY(18px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes reveal-left{0%{opacity:0;transform:translate(-28px)}to{opacity:1;transform:translate(0)}}@keyframes reveal-clip{0%{opacity:0;clip-path:inset(0 105% 0 0)}to{opacity:1;clip-path:inset(0 0% 0 0)}}@keyframes hero-blur-in{0%{opacity:0;filter:blur(10px);transform:translateY(10px)}to{opacity:1;filter:blur(0);transform:translateY(0)}}@keyframes reveal-fade{0%{opacity:0}to{opacity:1}}@keyframes hero-enter{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes hero-word-enter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.reveal{opacity:0;transform:translateY(22px)}.reveal.is-visible{animation:reveal-up .65s cubic-bezier(.22,1,.36,1) both;animation-delay:var(--reveal-delay, 0ms)}.reveal--left{opacity:0;transform:translate(-28px)}.reveal--left.is-visible{animation:reveal-left .7s cubic-bezier(.22,1,.36,1) both;animation-delay:var(--reveal-delay, 0ms)}.reveal--clip{opacity:0}.reveal--clip.is-visible{animation:reveal-clip .75s cubic-bezier(.77,0,.175,1) both;animation-delay:var(--reveal-delay, 0ms)}.reveal--fade{opacity:0}.reveal--fade.is-visible{animation:reveal-fade .65s cubic-bezier(.22,1,.36,1) both;animation-delay:var(--reveal-delay, 0ms)}.reveal-stagger>*{opacity:0;transform:translateY(18px)}.reveal-stagger.is-visible>*{animation:reveal-up .6s cubic-bezier(.22,1,.36,1) both}.reveal-stagger.is-visible>*:nth-child(1){animation-delay:0ms}.reveal-stagger.is-visible>*:nth-child(2){animation-delay:80ms}.reveal-stagger.is-visible>*:nth-child(3){animation-delay:.16s}.reveal-stagger.is-visible>*:nth-child(4){animation-delay:.24s}.reveal-stagger.is-visible>*:nth-child(5){animation-delay:.32s}.reveal-stagger--scale>*{opacity:0;transform:translateY(18px) scale(.97)}.reveal-stagger--scale.is-visible>*{animation:reveal-up-scale .7s cubic-bezier(.22,1,.36,1) both}.reveal-stagger--scale.is-visible>*:nth-child(1){animation-delay:0ms}.reveal-stagger--scale.is-visible>*:nth-child(2){animation-delay:90ms}.reveal-stagger--scale.is-visible>*:nth-child(3){animation-delay:.18s}.reveal-stagger--scale.is-visible>*:nth-child(4){animation-delay:.27s}.projects__grid.is-visible+.projects__footer{animation:reveal-fade .9s cubic-bezier(.22,1,.36,1) both;animation-delay:.68s}.hero-animate{animation:hero-enter .7s cubic-bezier(.22,1,.36,1) both}.hero-blur-in{animation:hero-blur-in 1s cubic-bezier(.22,1,.36,1) both}.hero-word{display:inline-block;opacity:0;animation:hero-word-enter .5s cubic-bezier(.22,1,.36,1) both;margin-right:.28em}.hero-word:last-child{margin-right:0}@media(prefers-reduced-motion:reduce){.reveal,.reveal--left,.reveal--clip,.reveal--fade,.reveal-stagger>*,.reveal-stagger--scale>*,.hero-animate,.hero-blur-in,.hero-word,.projects__footer{opacity:1!important;transform:none!important;filter:none!important;clip-path:none!important;animation:none!important}}.nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:16px 48px;background:color-mix(in srgb,var(--color-bg) 75%,transparent);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid color-mix(in srgb,var(--color-border) 50%,transparent)}.nav__logo{font-family:Fira Code,monospace;font-size:1rem;font-weight:700;color:var(--color-text);letter-spacing:-.5px}.nav__logo span{color:var(--color-accent)}.nav__links{list-style:none;display:flex;gap:36px;align-items:center}.nav__links a{font-size:.85rem;color:var(--color-text-muted);letter-spacing:.3px;transition:color .2s ease}.nav__links a:hover{color:var(--color-text)}.nav__right{display:flex;align-items:center;gap:36px}.nav__actions{display:flex;align-items:center;gap:8px}.nav__hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:4px;z-index:101}.nav__hamburger span{display:block;width:22px;height:2px;background:var(--color-text);border-radius:2px;transition:transform .2s ease,opacity .2s ease}.nav__hamburger--open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.nav__hamburger--open span:nth-child(2){opacity:0}.nav__hamburger--open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.nav__dropdown{display:none}.nav__theme-btn{background:none;border:1px solid color-mix(in srgb,var(--color-border) 80%,transparent);border-radius:6px;padding:5px 10px;cursor:pointer;color:var(--color-text);font-size:.82rem;font-family:Fira Code,monospace;transition:color .2s ease,border-color .2s ease;line-height:1}.nav__theme-btn:hover{color:var(--color-accent);border-color:color-mix(in srgb,var(--color-accent) 50%,transparent)}@media(max-width:640px){.nav{padding:14px 24px;flex-wrap:wrap}.nav__hamburger{display:flex}.nav__links{display:none}.nav__dropdown{display:none;width:100%;flex-direction:column;gap:0;list-style:none;border-top:1px solid color-mix(in srgb,var(--color-border) 40%,transparent);padding:8px 0}.nav__dropdown--open{display:flex}.nav__dropdown li a{display:block;padding:12px 4px;font-size:.95rem;color:var(--color-text-muted);letter-spacing:.3px;transition:color .2s ease}.nav__dropdown li a:hover{color:var(--color-text)}}.sun-rays{transform-box:fill-box;transform-origin:center}.nav__theme-btn:hover .sun-rays{animation:sun-spin 16s linear infinite}@keyframes sun-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.moon-body{transform-box:fill-box;transform-origin:center}.nav__theme-btn:hover .moon-body{animation:moon-twist .5s ease-out forwards}@keyframes moon-twist{0%{transform:rotate(0)}to{transform:rotate(12deg)}}.moon-star-1,.moon-star-2,.moon-star-3{transform-box:fill-box;transform-origin:center}.nav__theme-btn:hover .moon-star-1{animation:star-twinkle 2.2s ease-in-out infinite}.nav__theme-btn:hover .moon-star-2{animation:star-twinkle 2.2s ease-in-out infinite .8s}.nav__theme-btn:hover .moon-star-3{animation:star-twinkle 2.2s ease-in-out infinite 1.6s}@keyframes star-twinkle{0%,to{opacity:1;transform:scale(1)}50%{opacity:.2;transform:scale(.6)}}.hero{min-height:100vh;display:flex;align-items:center;padding-top:80px}.hero__greeting{font-family:Fira Code,monospace;font-size:.82rem;color:var(--color-accent);letter-spacing:.16em;margin-bottom:24px;opacity:.8}.hero__name{font-size:clamp(3.5rem,10vw,6.5rem);font-weight:800;line-height:1;letter-spacing:-3px;background:linear-gradient(135deg,var(--color-text) 55%,var(--color-accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:24px}.hero__tagline{font-size:1.1rem;color:var(--color-text);max-width:480px;line-height:1.75;margin-bottom:48px;text-shadow:0 1px 16px var(--color-bg)}.hero__actions{display:flex;gap:14px;flex-wrap:wrap}.about{background:var(--color-surface);border-top:1px solid var(--color-border)}.about__content{display:grid;grid-template-columns:1fr 1.4fr;gap:64px;align-items:stretch}@media(max-width:900px){.about__content{grid-template-columns:1fr;gap:40px}}.about__bio{position:sticky;top:100px}@media(max-width:900px){.about__bio{position:static}}.about__bio-card{display:flex;flex-direction:column;gap:14px;padding:18px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;transition:border-color .2s ease;color:var(--color-text);font-size:.92rem;line-height:1.85}.about__bio-card:hover{border-color:color-mix(in srgb,var(--color-accent) 25%,transparent)}.about__bio-card-header{display:flex;align-items:center;gap:10px}.about__bio-card-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;color:var(--color-accent);flex-shrink:0}.about__bio-card-title{font-size:.82rem;font-weight:600;color:var(--color-text);letter-spacing:.01em}.about__skill-groups{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:10px}@media(max-width:900px){.about__skill-groups{grid-template-columns:1fr}}.about__skill-group{display:flex;flex-direction:column;gap:14px;padding:18px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;transition:border-color .2s ease;min-width:0}.about__skill-group:hover{border-color:color-mix(in srgb,var(--color-accent) 25%,transparent)}.about__skill-group-header{display:flex;align-items:center;gap:10px}.about__skill-group-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;color:var(--color-accent);flex-shrink:0}.about__skill-group-label{font-size:.82rem;font-weight:600;color:var(--color-text);letter-spacing:.01em}.about__skills-list{list-style:none;display:flex;flex-wrap:wrap;gap:6px}.about__skills-list li{font-family:Fira Code,monospace;font-size:.72rem;white-space:nowrap;-webkit-user-select:none;user-select:none;color:var(--color-text);background:color-mix(in srgb,var(--color-accent) 10%,transparent);border:1px solid color-mix(in srgb,var(--color-accent) 22%,transparent);padding:3px 9px;border-radius:4px;transition:background .2s ease,border-color .2s ease,color .2s ease}.about__skills-list li:hover{background:color-mix(in srgb,var(--color-accent) 20%,transparent);border-color:color-mix(in srgb,var(--color-accent) 45%,transparent);color:var(--color-accent)}.projects__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}@media(max-width:1080px){.projects__grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:720px){.projects__grid{grid-template-columns:1fr}}.projects__footer{margin-top:40px;text-align:center;opacity:0}.projects__error{text-align:center;color:var(--color-text-muted);padding:40px 0}.projects__error a{color:var(--color-accent);text-decoration:underline}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.project-card{display:flex;flex-direction:column;padding:24px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;transition:border-color .2s ease,transform .2s ease,box-shadow .2s ease;color:inherit}.project-card:hover{border-color:color-mix(in srgb,var(--color-accent) 30%,transparent);transform:translateY(-3px);box-shadow:0 8px 32px color-mix(in srgb,var(--color-accent) 6%,transparent);color:inherit}.project-card__body{flex:1;display:flex;flex-direction:column;margin-bottom:20px}.project-card__title{font-size:1rem;font-weight:700;color:var(--color-text);margin-bottom:10px}.project-card__desc{font-size:.875rem;color:var(--color-text-muted);line-height:1.65;flex:1;margin-bottom:20px}.project-card__tags{list-style:none;display:flex;flex-wrap:wrap;gap:6px}.project-card__tags li{font-family:Fira Code,monospace;font-size:.72rem;white-space:nowrap;-webkit-user-select:none;user-select:none;color:var(--color-text);background:color-mix(in srgb,var(--color-accent) 10%,transparent);border:1px solid color-mix(in srgb,var(--color-accent) 22%,transparent);padding:3px 9px;border-radius:4px;transition:background .2s ease,border-color .2s ease,color .2s ease}.project-card__tags li:hover{background:color-mix(in srgb,var(--color-accent) 20%,transparent);border-color:color-mix(in srgb,var(--color-accent) 45%,transparent);color:var(--color-accent)}.project-card__footer{display:flex;align-items:center;justify-content:space-between}.project-card__actions{display:flex;align-items:center;gap:6px}.project-card__github{display:flex;align-items:center;justify-content:center;padding:6px;border:1px solid var(--color-border);border-radius:6px;color:var(--color-text-muted);transition:border-color .2s ease,color .2s ease,transform .2s ease}.project-card__github:hover{border-color:color-mix(in srgb,var(--color-accent) 45%,transparent);color:var(--color-accent);transform:translateY(-2px)}.project-card__github svg{width:18px;height:18px;flex-shrink:0}.project-card__github--open{gap:6px;padding-inline:9px}.project-card__github--open span{font-size:.9rem;font-weight:500;letter-spacing:.02em;line-height:1}.project-card__updated{font-size:.75rem;color:var(--color-text-muted);font-family:Fira Code,monospace;text-align:right}.project-card--not-found{opacity:.4;pointer-events:none}.project-card__body--not-found{display:flex;align-items:center;justify-content:center;flex:1;color:var(--color-text-muted);font-size:.875rem}.project-card--skeleton{height:220px;background:linear-gradient(90deg,var(--color-surface) 25%,var(--color-surface-2) 50%,var(--color-surface) 75%);background-size:800px 100%;animation:shimmer 1.4s infinite linear;pointer-events:none}.contact{background:var(--color-surface);border-top:1px solid var(--color-border)}.contact__form-wrap{position:relative;max-width:560px;margin:0 auto}.contact__form{display:flex;flex-direction:column;gap:24px}.contact__form-group{display:flex;flex-direction:column;gap:8px}.contact__label{font-family:Fira Code,monospace;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted)}.contact__input,.contact__textarea{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text);font-family:Inter,system-ui,sans-serif;font-size:.9rem;padding:12px 16px;transition:border-color .2s ease,box-shadow .2s ease;outline:none;width:100%}.contact__input::placeholder,.contact__textarea::placeholder{color:var(--color-text-dim)}.contact__input:focus,.contact__textarea:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-accent) 15%,transparent)}.contact__textarea{resize:none;min-height:120px}.contact__toast{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:color-mix(in srgb,var(--color-accent) 12%,var(--color-surface-2));border:1px solid color-mix(in srgb,var(--color-accent) 40%,transparent);border-radius:8px;padding:12px 24px;font-size:.9rem;color:var(--color-text);z-index:10;white-space:nowrap;animation:toast-in .2s ease}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,calc(-50% + 8px))}to{opacity:1;transform:translate(-50%,-50%)}}:root{--color-bg: #080c10;--color-batik: #14b8a6;--color-surface: #0d1520;--color-surface-2: #131e2c;--color-border: #1d2d3e;--color-accent: #14b8a6;--color-accent-hover: #0d9488;--color-text: #e2eaf4;--color-text-muted: #5d7a96;--color-text-dim: #243040}[data-theme=light]{--color-bg: #f0f4f8;--color-batik: #14b8a6;--color-surface: #ffffff;--color-surface-2: #e4eaf1;--color-border: #c4d2e0;--color-accent: #14b8a6;--color-accent-hover: #0d9488;--color-text: #0f1923;--color-text-muted: #4a6580;--color-text-dim: #94a3b8}.footer{padding:48px 0 32px;background:var(--color-bg);border-top:1px solid var(--color-border)}.footer__inner{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;align-items:start;max-width:1160px;margin:0 auto;padding:0 48px}.footer__logo{font-family:Fira Code,monospace;font-size:.9rem;font-weight:700;color:var(--color-text-muted)}.footer__logo span{color:var(--color-accent)}.footer__nav-label{display:block;font-family:Fira Code,monospace;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:12px}.footer__nav ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.footer__nav a{display:inline-flex;align-items:center;gap:8px;font-size:.85rem;color:var(--color-text-dim);text-decoration:none;font-family:Fira Code,monospace;transition:color .2s ease}.footer__nav a:hover{color:var(--color-accent)}.footer__social ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:row;gap:16px}.footer__social a{display:inline-flex;align-items:center;color:var(--color-text-muted);text-decoration:none;transition:color .2s ease}.footer__social a svg{flex-shrink:0}.footer__social a:hover{color:var(--color-accent)}.footer__copy{margin-top:20px;font-size:.75rem;font-family:Fira Code,monospace;color:var(--color-text-dim)}@media(max-width:640px){.footer__inner{grid-template-columns:1fr 1fr;padding:0 24px}.footer__brand{grid-column:1 / -1}}
