@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=Inter:ital,wght@0,300;0,400;0,500;0,600;1,400&display=swap";.loader{z-index:9999;background:#0a0a0f;flex-direction:column;justify-content:center;align-items:center;transition:opacity .6s cubic-bezier(.16,1,.3,1),transform .6s cubic-bezier(.16,1,.3,1);display:flex;position:fixed;inset:0}.loader--exit{opacity:0;pointer-events:none;transform:scale(1.04)}.loader__inner{flex-direction:column;align-items:center;gap:1.25rem;display:flex}.loader__mark{opacity:0;transition:opacity .6s cubic-bezier(.16,1,.3,1),transform .6s cubic-bezier(.16,1,.3,1);transform:scale(.8)}.loader__mark--visible{opacity:1;transform:scale(1)}.loader__svg{filter:drop-shadow(0 0 24px #6366f180);width:80px;height:80px}.loader__path{stroke-dasharray:300;stroke-dashoffset:300px;animation:1.1s cubic-bezier(.16,1,.3,1) .1s forwards draw-path}.loader__path--b{animation-delay:.3s}.loader__path--b2{animation-delay:.55s}@keyframes draw-path{to{stroke-dashoffset:0}}.loader__name{opacity:0;color:#f1f0ff;letter-spacing:.04em;font-family:Space Grotesk,sans-serif;font-size:1.375rem;font-weight:600;transition:opacity .5s,transform .5s;transform:translateY(10px)}.loader__name--visible{opacity:1;transform:translateY(0)}.loader__tagline{opacity:0;letter-spacing:.14em;text-transform:uppercase;color:#6366f1;font-family:Inter,sans-serif;font-size:.8125rem;font-weight:400;transition:opacity .4s}.loader__tagline--visible{opacity:1}.loader__progress{background:#1e1e2e;height:2px;position:absolute;bottom:0;left:0;right:0}.loader__progress-bar{background:linear-gradient(90deg,#6366f1,#a78bfa,#38bdf8);width:0%;height:100%;transition:width 1.6s cubic-bezier(.16,1,.3,1) .1s}.loader__progress-bar--full{width:100%}.navbar{z-index:100;border-bottom:1px solid #0000;padding:1.25rem 0;transition:background .4s,-webkit-backdrop-filter .4s,backdrop-filter .4s,border-color .4s,padding .4s;position:fixed;top:0;left:0;right:0}.navbar--scrolled{-webkit-backdrop-filter:blur(20px);border-bottom-color:var(--border-subtle);background:#0a0a0fcc;padding:.875rem 0}.navbar__inner{justify-content:space-between;align-items:center;gap:2rem;width:100%;max-width:100%;margin:0;padding:0 4rem;transition:padding .4s;display:flex;position:relative}@media (width<=1200px){.navbar__inner{padding:0 2rem}}@media (width<=768px){.navbar__inner{padding:0 1.25rem}}.navbar__logo{flex-shrink:0;align-items:center;gap:.625rem;text-decoration:none;display:flex}.navbar__logo-mark{background:var(--accent);width:36px;height:36px;font-family:var(--font-display);color:#fff;letter-spacing:-.03em;box-shadow:0 0 20px var(--accent-glow);border-radius:8px;flex-shrink:0;place-items:center;font-size:.875rem;font-weight:700;display:grid}.navbar__logo-name{font-family:var(--font-display);color:var(--text-secondary);letter-spacing:-.01em;font-size:.9rem;font-weight:500;transition:color .2s}.navbar__logo:hover .navbar__logo-name{color:var(--text-primary)}.navbar__links{align-items:center;gap:.25rem;list-style:none;display:flex;position:absolute;left:50%;transform:translate(-50%)}.navbar__link{color:var(--text-secondary);border-radius:var(--radius-sm);padding:.5rem .875rem;font-size:.9rem;font-weight:450;text-decoration:none;transition:color .2s,background .2s}.navbar__link:hover{color:var(--text-primary);background:#ffffff0a}.navbar__link--active{color:var(--accent)}.navbar__actions{flex-shrink:0;align-items:center;gap:1rem;display:flex}.navbar__cta{background:var(--accent);color:#fff;border-radius:var(--radius-sm);padding:.5625rem 1.25rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:background .2s,transform .2s,box-shadow .2s}.navbar__cta:hover{background:var(--accent-hover);box-shadow:0 4px 16px var(--accent-glow);transform:translateY(-1px)}.navbar__hamburger{border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;flex-direction:column;gap:5px;padding:8px;transition:background .2s;display:none}.navbar__hamburger:hover{background:#ffffff0f}.navbar__hamburger span{background:var(--text-primary);transform-origin:50%;border-radius:2px;width:22px;height:2px;transition:transform .3s cubic-bezier(.16,1,.3,1),opacity .3s;display:block}.navbar__hamburger--open span:first-child{transform:translateY(7px)rotate(45deg)}.navbar__hamburger--open span:nth-child(2){opacity:0;transform:scaleX(0)}.navbar__hamburger--open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.mobile-menu{z-index:99;-webkit-backdrop-filter:blur(24px);pointer-events:none;opacity:0;background:#0a0a0ff7;flex-direction:column;justify-content:center;padding:6rem 2rem 3rem;transition:opacity .4s cubic-bezier(.16,1,.3,1),transform .4s cubic-bezier(.16,1,.3,1);display:flex;position:fixed;inset:0;transform:translate(-100%)}.mobile-menu--open{pointer-events:all;opacity:1;transform:translate(0)}.mobile-menu__inner{flex-direction:column;gap:3rem;max-width:400px;display:flex}.mobile-menu__links{flex-direction:column;gap:.25rem;list-style:none;display:flex}.mobile-menu__item{opacity:0;transition:opacity .4s cubic-bezier(.16,1,.3,1),transform .4s cubic-bezier(.16,1,.3,1);transform:translate(-20px)}.mobile-menu--open .mobile-menu__item{opacity:1;transform:translate(0)}.mobile-menu__link{font-family:var(--font-display);color:var(--text-primary);border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:1rem 0;font-size:1.75rem;font-weight:600;text-decoration:none;transition:color .2s;display:flex}.mobile-menu__link svg{opacity:0;transition:opacity .2s,transform .2s;transform:translate(-8px)}.mobile-menu__link:hover{color:var(--accent)}.mobile-menu__link:hover svg{opacity:1;transform:translate(0)}.mobile-menu__footer{opacity:0;flex-direction:column;gap:1rem;transition:opacity .4s,transform .4s;display:flex;transform:translateY(16px)}.mobile-menu--open .mobile-menu__footer{opacity:1;transform:translateY(0)}.mobile-menu__domain{font-family:var(--font-display);color:var(--text-muted);letter-spacing:.08em;font-size:.8125rem}.mobile-overlay{z-index:98;position:fixed;inset:0}@media (width<=768px){.navbar__links,.navbar__cta{display:none}.navbar__hamburger{display:flex}}.hero{align-items:center;min-height:100dvh;padding-top:80px;display:flex;position:relative;overflow:hidden}.hero__canvas{pointer-events:none;position:absolute;inset:0}.hero__orb{filter:blur(80px);pointer-events:none;will-change:transform;border-radius:50%;transition:transform .15s ease-out;position:absolute}.hero__orb--1{background:radial-gradient(circle,#6366f12e 0%,#0000 70%);width:600px;height:600px;top:-100px;left:-200px}.hero__orb--2{background:radial-gradient(circle,#a78bfa24 0%,#0000 70%);width:500px;height:500px;top:50%;right:-150px;transform:translateY(-50%)}.hero__orb--3{background:radial-gradient(circle,#38bdf81a 0%,#0000 70%);width:400px;height:400px;bottom:0;left:40%}.hero__content{z-index:1;flex-direction:column;align-items:flex-start;gap:1.5rem;width:100%;max-width:100%;padding:2rem 4rem 6rem;transition:padding .4s;display:flex;position:relative}@media (width<=1200px){.hero__content{padding:2rem 2rem 6rem}}.hero__badge{color:var(--accent-violet);background:#6366f11a;border:1px solid #6366f140;border-radius:100px;align-items:center;gap:.5rem;padding:.375rem .875rem .375rem .625rem;font-size:.8125rem;font-weight:500;animation:.8s cubic-bezier(.16,1,.3,1) .2s both badge-in;display:inline-flex}.hero__badge-dot{background:#22c55e;border-radius:50%;width:7px;height:7px;animation:2s ease-in-out infinite pulse-dot;box-shadow:0 0 8px #22c55eb3}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.3)}}.hero__name{font-family:var(--font-display);letter-spacing:-.035em;color:var(--text-primary);flex-direction:column;gap:.05em;font-size:6.25rem;font-weight:700;line-height:.95;display:flex}.hero__name-line{animation:1s cubic-bezier(.16,1,.3,1) both name-in;display:block}.hero__name-line:first-child{animation-delay:.35s}.hero__name-line:nth-child(2){animation-delay:.5s}.hero__name-line--accent{background:linear-gradient(135deg,#6366f1 0%,#a78bfa 50%,#38bdf8 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}@keyframes name-in{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes badge-in{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.hero__subtitle{font-family:var(--font-display);color:var(--text-secondary);align-items:center;gap:2px;min-height:2em;font-size:1.625rem;font-weight:500;animation:.8s cubic-bezier(.16,1,.3,1) .7s both fade-up;display:flex}.hero__type{color:var(--text-primary)}.hero__cursor{background:var(--accent);border-radius:1px;width:2px;height:1.1em;margin-left:2px;animation:1s step-end infinite blink;display:inline-block}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero__desc{color:var(--text-secondary);max-width:520px;font-size:1.0625rem;line-height:1.7;animation:.8s cubic-bezier(.16,1,.3,1) .85s both fade-up}.hero__ctas{flex-wrap:wrap;align-items:center;gap:1rem;animation:.8s cubic-bezier(.16,1,.3,1) 1s both fade-up;display:flex}.hero__cta-primary,.hero__cta-ghost{padding:1rem 2.25rem;font-size:1rem}.hero__socials{gap:.75rem;animation:.8s cubic-bezier(.16,1,.3,1) 1.15s both fade-up;display:flex}.hero__social{border:1px solid var(--border);width:40px;height:40px;color:var(--text-secondary);border-radius:8px;place-items:center;transition:color .2s,border-color .2s,background .2s,transform .2s;display:grid}.hero__social:hover{color:var(--text-primary);border-color:var(--accent);background:var(--accent-glow-soft);transform:translateY(-2px)}.hero__scroll{flex-direction:column;align-items:center;gap:.625rem;animation:1s 1.5s both fade-in;display:flex;position:absolute;bottom:2.5rem;right:2rem}.hero__scroll-label{letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);writing-mode:vertical-rl;font-size:.6875rem;font-weight:500}.hero__scroll-line{background:var(--border);border-radius:1px;width:1px;height:60px;position:relative;overflow:hidden}.hero__scroll-dot{background:linear-gradient(to bottom, transparent, var(--accent), transparent);width:100%;height:30px;animation:2s ease-in-out infinite scroll-dot}@keyframes scroll-dot{0%{transform:translateY(-30px)}to{transform:translateY(60px)}}@keyframes fade-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@media (width<=1200px){.hero__name{font-size:5.25rem}}@media (width<=992px){.hero__name{font-size:4.5rem}.hero__subtitle{font-size:1.45rem}}@media (width<=768px){.hero__name{font-size:3.5rem}.hero__subtitle{font-size:1.25rem}.hero__content{gap:1.25rem;padding:2rem 1.25rem 5rem}.hero__ctas{flex-direction:column;align-items:stretch}.hero__cta-primary,.hero__cta-ghost{text-align:center;justify-content:center}.hero__scroll{display:none}.hero__orb--1{width:300px;height:300px}.hero__orb--2{width:250px;height:250px}}@media (width<=480px){.hero__name{font-size:2.75rem}}.about{background:var(--bg-secondary);position:relative;overflow:hidden}.about__grid-lines{pointer-events:none;background-image:linear-gradient(#6366f10a 1px,#0000 1px),linear-gradient(90deg,#6366f10a 1px,#0000 1px);background-size:60px 60px;position:absolute;inset:0}.about__layout{grid-template-columns:1fr 420px;align-items:start;gap:5rem;display:grid}.about__text{flex-direction:column;gap:0;display:flex}.about__bio{color:var(--text-secondary);margin-bottom:1.125rem;font-size:1.0625rem;line-height:1.8}.about__bio:last-of-type{margin-bottom:1.75rem}.about__chips{flex-wrap:wrap;gap:.5rem;margin-top:.5rem;display:flex}.about__chip{border:1px solid var(--border);color:var(--text-secondary);background:var(--bg-card);border-radius:100px;padding:.375rem .875rem;font-size:.8125rem;font-weight:500;transition:border-color .2s,color .2s,background .2s}.about__chip:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-glow-soft)}.about__card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);flex-direction:column;align-items:center;gap:.75rem;padding:2.5rem 2rem;display:flex;position:sticky;top:100px}.about__avatar-wrap{width:100px;height:100px;margin-bottom:.25rem;position:relative}.about__avatar{width:100px;height:100px;font-family:var(--font-display);color:#fff;z-index:1;background:linear-gradient(135deg,#6366f1 0%,#a78bfa 50%,#38bdf8 100%);border-radius:50%;place-items:center;font-size:1.75rem;font-weight:700;display:grid;position:relative}.about__avatar-ring{border:1px solid #6366f14d;border-radius:50%;animation:8s linear infinite ring-spin;position:absolute;inset:-6px}.about__avatar-glow{pointer-events:none;background:radial-gradient(circle,#6366f126 0%,#0000 70%);border-radius:50%;position:absolute;inset:-20px}@keyframes ring-spin{0%{opacity:.6;transform:rotate(0)scale(1)}50%{opacity:1;transform:rotate(180deg)scale(1.05)}to{opacity:.6;transform:rotate(360deg)scale(1)}}.about__card-name{font-family:var(--font-display);color:var(--text-primary);font-size:1.125rem;font-weight:600}.about__card-role{color:var(--text-secondary);margin-top:-.25rem;font-size:.8125rem}.about__card-divider{background:var(--border);width:100%;height:1px;margin:.75rem 0}.about__stats{background:var(--border);border-radius:var(--radius-md);grid-template-columns:1fr 1fr;gap:1px;width:100%;display:grid;overflow:hidden}.about__stat{background:var(--bg-card);flex-direction:column;align-items:center;gap:.25rem;padding:1.25rem 1rem;transition:background .2s;display:flex}.about__stat:hover{background:var(--bg-card-hover)}.about__stat-value{font-family:var(--font-display);background:linear-gradient(135deg,#6366f1,#a78bfa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.875rem;font-weight:700;line-height:1}.about__stat-label{color:var(--text-muted);text-align:center;font-size:.75rem;line-height:1.3}@media (width<=960px){.about__layout{grid-template-columns:1fr;gap:3rem}.about__card{max-width:440px;margin:0 auto;position:static}}.projects{background:var(--bg-primary)}.projects__header{margin-bottom:5rem}.projects__list{flex-direction:column;gap:6rem;display:flex}.project-card{grid-template-columns:1fr 1fr;align-items:center;gap:4.5rem;display:grid}.project-card--reversed{direction:rtl}.project-card--reversed>*{direction:ltr}.project-card--portrait{grid-template-columns:420px 1fr}.project-card--portrait.project-card--reversed{grid-template-columns:1fr 420px}.landscape-gallery{position:relative}.landscape-gallery__wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;transition:box-shadow .4s,transform .4s;overflow:hidden;box-shadow:0 0 0 1px #ffffff0a,0 32px 80px #0006,0 8px 24px #0000004d}.landscape-gallery__wrap:hover{transform:translateY(-4px);box-shadow:0 0 0 1px #6366f133,0 40px 100px #00000080,0 0 60px #6366f114}.browser-chrome{border-bottom:1px solid var(--border);background:#1a1a26;align-items:center;gap:.75rem;padding:.625rem .875rem;display:flex}.browser-chrome__dots{flex-shrink:0;gap:5px;display:flex}.browser-chrome__dots span{border-radius:50%;width:10px;height:10px;display:block}.browser-chrome__bar{background:var(--bg-secondary);border:1px solid var(--border);border-radius:5px;flex:1;align-items:center;padding:.25rem .625rem;display:flex}.browser-chrome__url{font-family:var(--font-body);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.6875rem;overflow:hidden}.landscape-gallery__img-wrap{aspect-ratio:16/9;position:relative;overflow:hidden}.landscape-gallery__img{object-fit:cover;object-position:top;width:100%;height:100%;transition:transform .6s cubic-bezier(.16,1,.3,1)}.landscape-gallery__img-wrap:hover .landscape-gallery__img{transform:scale(1.03)}.landscape-gallery__overlay{opacity:0;background:linear-gradient(135deg,#0a0a0fbf 0%,#6366f159 100%);justify-content:center;align-items:center;text-decoration:none;transition:opacity .3s;display:flex;position:absolute;inset:0}.landscape-gallery__img-wrap:hover .landscape-gallery__overlay{opacity:1}.landscape-gallery__visit-btn{color:#0a0a0f;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#fffffff2;border-radius:8px;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.875rem;font-weight:600;transition:transform .3s cubic-bezier(.16,1,.3,1),background .2s;display:inline-flex;transform:translateY(10px)}.landscape-gallery__img-wrap:hover .landscape-gallery__visit-btn{transform:translateY(0)}.landscape-gallery__visit-btn:hover{background:#fff}.landscape-gallery__dots{background:var(--bg-card);justify-content:center;gap:6px;padding:.75rem 0;display:flex}.landscape-gallery__dot{background:var(--text-muted);cursor:pointer;border:none;border-radius:50%;width:6px;height:6px;padding:0;transition:background .2s,transform .2s}.landscape-gallery__dot--active{background:var(--accent);transform:scale(1.4)}.portrait-gallery{justify-content:center;align-items:center;gap:1.25rem;padding:1rem 0;display:flex}.portrait-gallery__frame{cursor:pointer;opacity:.5;transition:transform .4s cubic-bezier(.16,1,.3,1),opacity .3s;transform:scale(.88)}.portrait-gallery__frame--active{opacity:1;cursor:default;transform:scale(1)}.portrait-gallery__frame:not(.portrait-gallery__frame--active):hover{opacity:.75;transform:scale(.92)}.phone-frame{background:#1a1a28;border:2px solid #ffffff1f;border-radius:28px;flex-direction:column;align-items:center;gap:8px;width:180px;padding:12px 8px;display:flex;position:relative;box-shadow:0 0 0 1px #00000080,0 30px 70px #00000080,inset 0 0 0 1px #ffffff0d}.portrait-gallery__frame--active .phone-frame{border-color:#6366f166;box-shadow:0 0 0 1px #00000080,0 30px 70px #00000080,0 0 40px #6366f126,inset 0 0 0 1px #ffffff0d}.phone-frame__notch{background:#ffffff26;border-radius:3px;flex-shrink:0;width:60px;height:5px}.phone-frame__screen{aspect-ratio:9/19;background:#0f1117;border-radius:12px;width:100%;overflow:hidden}.phone-frame__screen img{object-fit:cover;object-position:top;width:100%;height:100%;display:block}.phone-frame__home{background:#fff3;border-radius:2px;flex-shrink:0;width:50px;height:4px}.portrait-gallery__hint{gap:5px;display:flex;position:absolute;bottom:-1.5rem;left:50%;transform:translate(-50%)}.portrait-gallery__dot{background:var(--text-muted);cursor:pointer;border-radius:50%;width:5px;height:5px;transition:background .2s,transform .2s}.portrait-gallery__dot--active{background:var(--accent);transform:scale(1.3)}.project-card__content{flex-direction:column;gap:1.25rem;display:flex}.project-card__meta{align-items:center;gap:1rem;display:flex}.project-card__subtitle{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-size:.75rem;font-weight:600}.project-card__year{background:var(--bg-card);border:1px solid var(--border);color:var(--text-muted);border-radius:100px;padding:.2rem .625rem;font-size:.6875rem;font-weight:500}.project-card__title{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.025em;font-size:clamp(1.75rem,3vw,2.25rem);font-weight:700;line-height:1.15}.project-card__desc{color:var(--text-secondary);font-size:.9875rem;line-height:1.8}.project-card__highlights{flex-direction:column;gap:.5rem;list-style:none;display:flex}.project-card__highlight{color:var(--text-secondary);align-items:center;gap:.625rem;font-size:.875rem;display:flex}.project-card__tags{flex-wrap:wrap;gap:.4rem;display:flex}.project-card__tag{color:#a5b4fc;letter-spacing:.03em;background:#6366f114;border:1px solid #6366f133;border-radius:6px;padding:.3rem .7rem;font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:.72rem;font-weight:600;transition:background .2s,border-color .2s}.project-card__tag:hover{background:#6366f126;border-color:#6366f166}.project-card__actions{align-items:center;gap:.75rem;margin-top:.25rem;display:flex}.project-card__cta{align-self:flex-start}@media (width<=1024px){.project-card,.project-card--portrait,.project-card--portrait.project-card--reversed{direction:ltr;grid-template-columns:1fr;gap:2.5rem}.portrait-gallery{justify-content:center}.phone-frame{width:160px}}@media (width<=768px){.projects__list{gap:4rem}.project-card__cta{justify-content:center;align-self:stretch}.phone-frame{width:140px}}.skills{background:var(--bg-secondary)}.skills__header{margin-bottom:3.5rem}.skills__grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.skills__group{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;gap:1.5rem;padding:2rem;transition:border-color .3s,box-shadow .3s;display:flex}.skills__group:hover{border-color:#6366f14d;box-shadow:0 0 40px #6366f10f}.skills__group-header{align-items:center;gap:.75rem;display:flex}.skills__group-icon{color:var(--accent);font-size:1.25rem}.skills__group-title{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.01em;font-size:1rem;font-weight:600}.skills__items{flex-direction:column;gap:.5rem;display:flex}.skill-item{border-radius:var(--radius-sm);border:1px solid var(--border-subtle);background:var(--bg-secondary);justify-content:space-between;align-items:center;padding:.625rem .875rem;transition:border-color .2s,background .2s,transform .2s;display:flex}.skill-item:hover{border-color:var(--border);background:var(--bg-card-hover);transform:translate(3px)}.skill-item__name{color:var(--text-primary);font-size:.9rem;font-weight:500}.skill-item__level{letter-spacing:.08em;text-transform:uppercase;border-radius:100px;padding:.2rem .5rem;font-size:.6875rem;font-weight:600}.skill-item__level--core{color:#818cf8;background:#6366f126}.skill-item__level--proficient{color:#c4b5fd;background:#a78bfa1f}.skill-item__level--familiar{color:#7dd3fc;background:#38bdf81a}.skills__note{text-align:center;color:var(--text-muted);margin-top:2.5rem;font-size:.8125rem;line-height:1.6}.skills__note span{color:var(--text-secondary);font-weight:500}@media (width<=960px){.skills__grid{grid-template-columns:1fr 1fr}}@media (width<=640px){.skills__grid{grid-template-columns:1fr}}.services{background:var(--bg-primary);position:relative;overflow:hidden}.services:before{content:"";pointer-events:none;background:radial-gradient(circle,#6366f10f 0%,#0000 65%);width:800px;height:800px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.services__header{margin-bottom:3.5rem}.services__grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.service-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;gap:1rem;padding:2rem;transition:border-color .35s,transform .35s,box-shadow .35s;display:flex;position:relative;overflow:hidden}.service-card:before{content:"";background:linear-gradient(90deg, transparent, var(--accent), transparent);opacity:0;height:1px;transition:opacity .35s;position:absolute;top:0;left:0;right:0}.service-card:hover{border-color:#6366f14d;transform:translateY(-4px);box-shadow:0 20px 60px #0000004d,0 0 40px #6366f10f}.service-card:hover:before{opacity:1}.service-card__icon-wrap{background:var(--accent-glow-soft);border:1px solid #6366f133;border-radius:12px;flex-shrink:0;place-items:center;width:48px;height:48px;transition:background .2s,border-color .2s;display:grid}.service-card:hover .service-card__icon-wrap{background:#6366f133;border-color:#6366f166}.service-card__icon{color:var(--accent);font-size:1.25rem}.service-card__title{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.01em;font-size:1.0625rem;font-weight:600}.service-card__desc{color:var(--text-secondary);flex:1;font-size:.9rem;line-height:1.7}.service-card__features{flex-direction:column;gap:.4rem;list-style:none;display:flex}.service-card__feature{color:var(--text-secondary);align-items:center;gap:.5rem;font-size:.8125rem;display:flex}.service-card__dot{background:var(--accent);border-radius:50%;flex-shrink:0;width:4px;height:4px}.service-card__cta{color:var(--accent);align-items:center;gap:.375rem;margin-top:.25rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:gap .2s;display:inline-flex}.service-card__cta:hover{gap:.625rem}@media (width<=1024px){.services__grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.services__grid{grid-template-columns:1fr}}.testimonials{background:var(--bg-secondary)}.testimonials__header{margin-bottom:3rem}.testimonials__carousel{position:relative}.testimonials__track{min-height:320px;position:relative}.testimonial-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);opacity:0;pointer-events:none;flex-direction:column;gap:1.25rem;padding:2.5rem;transition:opacity .5s cubic-bezier(.16,1,.3,1),transform .5s cubic-bezier(.16,1,.3,1);display:flex;position:absolute;inset:0;transform:translate(40px)scale(.97)}.testimonial-card--prev{transform:translate(-40px)scale(.97)}.testimonial-card--active{opacity:1;pointer-events:all;position:relative;transform:translate(0)scale(1)}.testimonial-card__quote-mark{color:var(--accent);opacity:.3;-webkit-user-select:none;user-select:none;font-family:Georgia,serif;font-size:5rem;font-weight:700;line-height:.6}.testimonial-card__stars{gap:3px;display:flex}.testimonial-card__text{color:var(--text-primary);border:none;flex:1;margin:0;padding:0;font-size:1.0625rem;font-style:italic;line-height:1.8}.testimonial-card__author{border-top:1px solid var(--border);align-items:center;gap:.875rem;margin-top:auto;padding-top:1rem;display:flex}.testimonial-card__avatar{width:44px;height:44px;font-family:var(--font-display);color:#fff;border-radius:50%;flex-shrink:0;place-items:center;font-size:.875rem;font-weight:700;display:grid}.testimonial-card__name{font-family:var(--font-display);color:var(--text-primary);font-size:.9375rem;font-weight:600}.testimonial-card__role{color:var(--text-secondary);margin-top:.125rem;font-size:.8125rem}.testimonials__controls{justify-content:center;align-items:center;gap:1.5rem;margin-top:2rem;display:flex}.testimonials__btn{border:1px solid var(--border);background:var(--bg-card);width:42px;height:42px;color:var(--text-secondary);cursor:pointer;border-radius:50%;place-items:center;transition:color .2s,border-color .2s,background .2s,transform .2s;display:grid}.testimonials__btn:hover{color:var(--text-primary);border-color:var(--accent);background:var(--accent-glow-soft);transform:scale(1.08)}.testimonials__dots{gap:6px;display:flex}.testimonials__dot{background:var(--border);cursor:pointer;border:none;border-radius:50%;width:8px;height:8px;padding:0;transition:background .2s,transform .2s}.testimonials__dot--active{background:var(--accent);transform:scale(1.25)}@media (width<=768px){.testimonial-card{padding:1.75rem}.testimonial-card__text{font-size:.9375rem}}.contact{background:var(--bg-primary);position:relative;overflow:hidden}.contact__orb{pointer-events:none;background:radial-gradient(circle,#a78bfa1a 0%,#0000 65%);border-radius:50%;width:600px;height:600px;position:absolute;bottom:-200px;right:-200px}.contact__layout{grid-template-columns:1fr 1fr;align-items:start;gap:5rem;display:grid}.contact__intro{color:var(--text-secondary);margin-bottom:2rem;font-size:1.0625rem;line-height:1.8}.contact__methods{flex-direction:column;gap:1rem;display:flex}.contact__method{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);align-items:center;gap:1rem;padding:1rem 1.25rem;text-decoration:none;transition:border-color .2s,background .2s,transform .2s;display:flex}.contact__method:hover{border-color:var(--accent);background:var(--bg-card-hover);transform:translate(4px)}.contact__method--discord{cursor:default}.contact__method--discord:hover{transform:none;border-color:var(--border)!important;background:var(--bg-card)!important}.contact__method-icon{background:var(--accent-glow-soft);width:40px;height:40px;color:var(--accent);border:1px solid #6366f133;border-radius:10px;flex-shrink:0;place-items:center;display:grid}.contact__method-label{letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);font-size:.75rem;font-weight:500}.contact__method-value{color:var(--text-primary);margin-top:.125rem;font-size:.9375rem;font-weight:500}.contact__form-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:2.5rem}.contact__form{flex-direction:column;gap:1.25rem;display:flex}.contact__row{grid-template-columns:1fr 1fr;gap:1.25rem;display:grid}.contact__field{flex-direction:column;gap:.5rem;display:flex}.contact__label{color:var(--text-secondary);letter-spacing:.03em;font-size:.8125rem;font-weight:500}.contact__input,.contact__textarea{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;font-family:var(--font-body);color:var(--text-primary);resize:none;outline:none;padding:.875rem 1rem;font-size:.9375rem;transition:border-color .2s,box-shadow .2s}.contact__input::placeholder,.contact__textarea::placeholder{color:var(--text-muted)}.contact__input:focus,.contact__textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow-soft)}.contact__submit{justify-content:center;width:100%;padding:1rem}.contact__submit--loading{opacity:.7;cursor:not-allowed}.contact__spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.contact__success{text-align:center;flex-direction:column;align-items:center;gap:1rem;padding:2rem 0;display:flex}.contact__success-icon{color:#22c55e;background:#22c55e26;border:2px solid #22c55e66;border-radius:50%;place-items:center;width:64px;height:64px;font-size:1.75rem;animation:.5s cubic-bezier(.16,1,.3,1) pop-in;display:grid}@keyframes pop-in{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.contact__success-title{font-family:var(--font-display);color:var(--text-primary);font-size:1.5rem;font-weight:700}.contact__success-text{color:var(--text-secondary);max-width:320px;line-height:1.7}@media (width<=960px){.contact__layout{grid-template-columns:1fr;gap:3rem}}@media (width<=560px){.contact__row{grid-template-columns:1fr}.contact__form-wrap{padding:1.75rem}}.footer{background:var(--bg-secondary);border-top:1px solid var(--border)}.footer__top{padding:4rem 0}.footer__inner{grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;display:grid}.footer__brand{flex-direction:column;gap:1rem;display:flex}.footer__logo{align-items:center;gap:.625rem;display:flex}.footer__logo-mark{background:var(--accent);width:36px;height:36px;font-family:var(--font-display);color:#fff;letter-spacing:-.03em;box-shadow:0 0 20px var(--accent-glow);border-radius:8px;place-items:center;font-size:.875rem;font-weight:700;display:grid}.footer__logo-text{font-family:var(--font-display);color:var(--text-primary);font-size:.9375rem;font-weight:500}.footer__tagline{color:var(--text-secondary);font-size:.9rem;line-height:1.7}.footer__socials{gap:.5rem;margin-top:.25rem;display:flex}.footer__social{border:1px solid var(--border);width:36px;height:36px;color:var(--text-secondary);border-radius:8px;place-items:center;text-decoration:none;transition:color .2s,border-color .2s,background .2s,transform .2s;display:grid}.footer__social:hover{color:var(--text-primary);border-color:var(--accent);background:var(--accent-glow-soft);transform:translateY(-2px)}.footer__nav{flex-direction:column;gap:.75rem;display:flex}.footer__nav-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-primary);margin-bottom:.25rem;font-size:.75rem;font-weight:600}.footer__nav ul{flex-direction:column;gap:.625rem;list-style:none;display:flex}.footer__nav-link{color:var(--text-secondary);font-size:.9rem;text-decoration:none;transition:color .2s;display:inline-block}.footer__nav-link:hover{color:var(--text-primary)}.footer__nav-link--plain{cursor:default}.footer__nav-link--plain:hover{color:var(--text-secondary)}.footer__cta{color:var(--accent);font-size:.9rem;font-weight:500;text-decoration:none;transition:color .2s,letter-spacing .2s}.footer__cta:hover{color:var(--accent-hover);letter-spacing:.02em}.footer__bottom{border-top:1px solid var(--border-subtle);padding:1.25rem 0}.footer__bottom-inner{justify-content:space-between;align-items:center;display:flex}.footer__copy,.footer__built{color:var(--text-muted);font-size:.8125rem}@media (width<=960px){.footer__inner{grid-template-columns:1fr 1fr;gap:2rem}.footer__brand{grid-column:span 2}}@media (width<=560px){.footer__inner{grid-template-columns:1fr}.footer__brand{grid-column:span 1}.footer__bottom-inner{text-align:center;flex-direction:column;gap:.5rem}}:root{--bg-primary:#08080f;--bg-secondary:#0c0c16;--bg-card:#111120;--bg-card-hover:#14142a;--border:#1e1e30;--border-subtle:#131325;--accent:#6366f1;--accent-hover:#818cf8;--accent-violet:#a78bfa;--accent-blue:#38bdf8;--accent-glow:#6366f166;--accent-glow-soft:#6366f11a;--text-primary:#eef;--text-secondary:#88a;--text-muted:#44446a;--text-on-accent:#fff;--gradient-brand:linear-gradient(135deg, #6366f1 0%, #a78bfa 50%, #38bdf8 100%);--gradient-card:linear-gradient(135deg, #111120 0%, #14142a 100%);--section-pad:9rem 0;--container-max:1180px;--container-pad:0 2rem;--font-display:"Space Grotesk", sans-serif;--font-body:"Inter", sans-serif;--font-mono:"SF Mono", "Fira Code", "Cascadia Code", "Courier New", monospace;--radius-xs:4px;--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-in-out:cubic-bezier(.45, 0, .55, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--dur-fast:.12s;--dur-normal:.28s;--dur-slow:.5s;--dur-enter:.75s}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:16px}body{background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-body);line-height:1.65;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);letter-spacing:-.025em;color:var(--text-primary);font-weight:600;line-height:1.12}p{color:var(--text-secondary);line-height:1.75}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto;display:block}button{font-family:var(--font-body);cursor:pointer;background:0 0;border:none}ul,ol{list-style:none}.container{max-width:var(--container-max);padding:var(--container-pad);margin:0 auto}.section{padding:var(--section-pad);position:relative}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}::selection{color:var(--accent-violet);background:#6366f133}.skip-link{background:var(--accent);color:#fff;z-index:9999;border-radius:0 0 8px 8px;padding:.5rem 1rem;font-size:.875rem;font-weight:600;transition:top .2s;position:absolute;top:-40px;left:1rem}.skip-link:focus{top:0}.reveal{opacity:0;transition:opacity var(--dur-enter) var(--ease-out), transform var(--dur-enter) var(--ease-out);transform:translateY(24px)}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-left{opacity:0;transition:opacity var(--dur-enter) var(--ease-out), transform var(--dur-enter) var(--ease-out);transform:translate(-32px)}.reveal-left.visible{opacity:1;transform:translate(0)}.reveal-right{opacity:0;transition:opacity var(--dur-enter) var(--ease-out), transform var(--dur-enter) var(--ease-out);transform:translate(32px)}.reveal-right.visible{opacity:1;transform:translate(0)}.stagger-1{transition-delay:80ms}.stagger-2{transition-delay:.16s}.stagger-3{transition-delay:.24s}.stagger-4{transition-delay:.32s}.stagger-5{transition-delay:.4s}.stagger-6{transition-delay:.48s}.section-label{font-family:var(--font-body);letter-spacing:.15em;text-transform:uppercase;color:var(--accent);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.6875rem;font-weight:700;display:inline-flex}.section-label:before{content:"";background:currentColor;border-radius:1px;width:18px;height:1px;display:block}.section-heading{color:var(--text-primary);letter-spacing:-.03em;margin-bottom:1rem;font-size:clamp(2rem,4vw,2.875rem);font-weight:700}.section-subheading{color:var(--text-secondary);max-width:520px;font-size:1.0625rem;line-height:1.75}.gradient-text{background:var(--gradient-brand);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.btn-primary{background:var(--accent);color:#fff;border-radius:var(--radius-sm);font-family:var(--font-body);letter-spacing:.01em;transition:background var(--dur-normal) var(--ease-out), transform var(--dur-normal) var(--ease-out), box-shadow var(--dur-normal) var(--ease-out);isolation:isolate;align-items:center;gap:.5rem;padding:.875rem 1.875rem;font-size:.9375rem;font-weight:500;display:inline-flex;position:relative;overflow:hidden}.btn-primary:after{content:"";opacity:0;transition:opacity var(--dur-normal);background:linear-gradient(135deg,#ffffff1f 0%,#0000 70%);position:absolute;inset:0}.btn-primary:hover{background:var(--accent-hover);box-shadow:0 8px 28px var(--accent-glow);transform:translateY(-2px)}.btn-primary:hover:after{opacity:1}.btn-primary:active{transform:translateY(0)}.btn-ghost{color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);transition:border-color var(--dur-normal), color var(--dur-normal), background var(--dur-normal), transform var(--dur-normal) var(--ease-out);background:0 0;align-items:center;gap:.5rem;padding:.875rem 1.875rem;font-size:.9375rem;font-weight:500;display:inline-flex}.btn-ghost:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-glow-soft);transform:translateY(-2px)}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}html{scroll-behavior:auto}.reveal,.reveal-left,.reveal-right{opacity:1;transform:none}}@media (width<=768px){:root{--section-pad:5.5rem 0;--container-pad:0 1.25rem}}
