:root{font-family:Space Grotesk,system-ui,Helvetica,Arial,sans-serif;font-size:16px;line-height:1.6;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--color-bg: #FAFAFA;--color-surface: #FFFFFF;--color-text: #09090B;--color-muted: #71717A;--color-accent: #8B5CF6;--color-accent-bg: #F5F3FF;--color-blob: #DDD6FE;--color-yellow: #FEF08A;--color-nav-bg: rgba(250, 250, 250, .88);--color-border: rgba(0, 0, 0, .08)}[data-theme=dark]{--color-bg: #09090B;--color-surface: #18181B;--color-text: #FAFAFA;--color-muted: #A1A1AA;--color-accent: #A78BFA;--color-accent-bg: #1E1033;--color-blob: #3B1F8C;--color-yellow: #FACC15;--color-nav-bg: rgba(9, 9, 11, .9);--color-border: rgba(255, 255, 255, .08)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{overflow-x:hidden}body{background-color:var(--color-bg);color:var(--color-text);min-height:100vh;scroll-behavior:smooth;transition:background-color .3s ease,color .3s ease}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}ul,ol{list-style:none}.portfolio{display:flex;flex-direction:column;overflow-x:clip}.about,.projects,.contact{position:relative;overflow:clip}.section-ghost{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:clamp(8rem,22vw,20rem);font-weight:800;letter-spacing:-.05em;line-height:1;color:transparent;-webkit-text-stroke:2px rgba(0,0,0,.055);white-space:nowrap;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:0}[data-theme=dark] .section-ghost{-webkit-text-stroke:2px rgba(167,139,250,.13)}.about__inner,.about__skills,.projects__header,.projects__stack,.contact>*:not(.section-ghost){position:relative;z-index:1}.reveal{opacity:0;transform:translateY(36px);transition:opacity .65s cubic-bezier(.16,1,.3,1),transform .65s cubic-bezier(.16,1,.3,1);transition-delay:var(--reveal-delay, 0s);animation:revealFallback 0s 2s forwards}.reveal--visible{opacity:1;transform:translateY(0)}.reveal--scale{transform:translateY(28px) scale(.97)}.reveal--scale.reveal--visible{transform:translateY(0) scale(1)}@keyframes revealFallback{to{opacity:1;transform:translateY(0) scale(1)}}.nav{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:1.1rem 2.5rem;background-color:var(--color-nav-bg);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border-bottom:1px solid rgba(255,255,255,.18);box-shadow:0 1px 32px #0000000f;transition:background-color .3s ease}[data-theme=dark] .nav{border-bottom:1px solid rgba(255,255,255,.08);box-shadow:0 1px 32px #00000040}.nav__logo{font-size:1.25rem;font-weight:700;letter-spacing:-.02em;color:var(--color-text)}.nav__dot{color:var(--color-accent);font-size:1.5rem}.nav__links{display:flex;gap:2.5rem}.nav__links a{font-size:.9rem;font-weight:500;color:var(--color-muted);transition:color .2s}.nav__links a:hover{color:var(--color-text)}.nav__right{display:flex;align-items:center;gap:.75rem}.nav__cta{font-size:.85rem;font-weight:600;color:var(--color-text);border:1.5px solid var(--color-text);border-radius:50px;padding:.45rem 1.1rem;transition:background-color .2s,color .2s}.nav__cta:hover{background-color:var(--color-text);color:var(--color-bg)}.dark-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:1.5px solid var(--color-border);background-color:transparent;color:var(--color-text);cursor:pointer;transition:background-color .2s,border-color .2s,transform .15s;font-family:inherit}.dark-toggle:hover{background-color:var(--color-surface);border-color:var(--color-accent);transform:rotate(20deg)}.dark-toggle svg{width:16px;height:16px;stroke:currentColor}.hero{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:4rem;padding:6rem 2.5rem 5rem;max-width:1200px;margin:0 auto;width:100%;min-height:90vh;position:relative;overflow:hidden}.hero__ghost{position:absolute;top:50%;left:50%;font-size:clamp(12rem,38vw,28rem);font-weight:800;letter-spacing:-.05em;line-height:1;color:transparent;-webkit-text-stroke:3px rgba(0,0,0,.08);white-space:nowrap;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:0;opacity:1}[data-theme=dark] .hero__ghost{-webkit-text-stroke:3px rgba(167,139,250,.2)}.hero__left{display:flex;flex-direction:column;gap:1.5rem;position:relative;z-index:1}.hero__badge{display:inline-flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:500;color:var(--color-muted);background:#ffffffb8;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.5);border-radius:50px;padding:.4rem .9rem;width:fit-content;box-shadow:0 2px 12px #0000000f}[data-theme=dark] .hero__badge{background:#1c1c1ca6;border:1px solid rgba(255,255,255,.1)}.hero__dot{width:8px;height:8px;border-radius:50%;background-color:#22c55e;display:inline-block;animation:pulse 2s infinite}.hero__title{font-size:clamp(2.8rem,6vw,5rem);font-weight:800;line-height:1;letter-spacing:-.04em;margin:0}.hero__name{font-style:italic;color:var(--color-accent)}.hero__bio{font-size:1.05rem;color:var(--color-muted);max-width:480px;line-height:1.75}mark{background-color:var(--color-yellow);color:var(--color-text);padding:.05em .25em;border-radius:3px}.hero__actions{display:flex;gap:1rem;flex-wrap:wrap}.hero__socials{display:flex;align-items:center;gap:.75rem;font-size:.85rem;color:var(--color-muted)}.social-link{color:var(--color-muted);transition:color .2s}.social-link:hover{color:var(--color-accent)}.hero__right{display:flex;justify-content:center;align-items:center;position:relative;z-index:1}.portrait-wrap{position:relative;width:360px;height:400px}.portrait-blob{display:none}.portrait-placeholder{position:absolute;inset:0;border-radius:20px;background:var(--color-accent-bg);border:1.5px solid rgba(139,92,246,.18);box-shadow:0 24px 64px #8b5cf624;overflow:hidden;display:flex;align-items:flex-end;justify-content:center;transition:background-color .3s ease,border-color .3s ease}[data-theme=dark] .portrait-placeholder{background:var(--color-accent-bg);border-color:#a78bfa40;box-shadow:0 24px 64px #8b5cf638}.portrait-svg{width:90%;height:auto;display:block}.portrait-img{position:absolute;inset:0;border-radius:0;object-fit:cover;width:100%;height:100%}.portrait-badge{position:absolute;background:#ffffffbf;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.55);border-radius:50px;padding:.5rem 1rem;font-size:.8rem;font-weight:600;white-space:nowrap;box-shadow:0 8px 32px #0000001a}[data-theme=dark] .portrait-badge{background:#141414b3;border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 32px #00000059}.portrait-badge--tl{top:-5%;left:8%;transform:rotate(-4deg);color:var(--color-accent)}.portrait-badge--br{bottom:-5%;right:8%;transform:rotate(3deg)}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.75rem 1.6rem;border-radius:50px;font-size:.95rem;font-weight:600;cursor:pointer;border:none;font-family:inherit;transition:transform .2s,box-shadow .2s,background-color .2s}.btn--fill{background-color:var(--color-text);color:var(--color-bg);box-shadow:0 4px 20px #0000001f}.btn--fill:hover{transform:translateY(-2px);box-shadow:0 8px 28px #0000002e}.btn--ghost{background-color:transparent;color:var(--color-text);border:1.5px solid var(--color-border)}.btn--ghost:hover{border-color:var(--color-text);background-color:#0000000a}[data-theme=dark] .btn--ghost:hover{background-color:#ffffff0f}.marquee-wrap{overflow:hidden;border-top:1.5px solid var(--color-accent);border-bottom:1.5px solid var(--color-accent);background-color:var(--color-surface);padding:1.25rem 0;-webkit-user-select:none;user-select:none;transition:background-color .3s ease}.marquee-track{display:flex;width:max-content;animation:marquee 20s linear infinite}.marquee-item{display:inline-flex;align-items:center;gap:1rem;padding:0 1.6rem;font-size:1rem;font-weight:700;color:var(--color-muted);white-space:nowrap;text-transform:uppercase;letter-spacing:.06em}.marquee-star{color:var(--color-accent);font-size:.7rem}.about{padding:5rem 2.5rem;background-color:var(--color-bg);transition:background-color .3s ease}.about__inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1.6fr;gap:5rem;align-items:start;padding-bottom:4rem}.about__lead{position:sticky;top:8rem}.about__body{display:flex;flex-direction:column;gap:1.25rem}.about__skills{max-width:1200px;margin:0 auto;padding-top:3rem;border-top:1px solid var(--color-border)}.about__text{font-size:1.05rem;color:var(--color-muted);line-height:1.85}.skills-cloud{display:flex;flex-wrap:wrap;gap:.6rem}.stats-row{display:flex;gap:2.5rem;padding-top:1.25rem;border-top:1px solid var(--color-border);margin-top:.5rem}.stat{display:flex;flex-direction:column;gap:.2rem}.stat__num{font-size:3.2rem;font-weight:800;color:var(--color-accent);line-height:1;letter-spacing:-.04em}.stat__label{font-size:.8rem;color:var(--color-muted);font-weight:500}.skill-pill{display:inline-block;padding:.4rem 1rem;border-radius:50px;font-size:.82rem;font-weight:600;cursor:default;transition:transform .15s}.skill-pill:hover{transform:scale(1.05)}.skill-pill--0{background-color:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.skill-pill--1{background-color:var(--color-accent-bg);color:var(--color-accent)}.skill-pill--2{background-color:#fef3c7;color:#92400e}[data-theme=dark] .skill-pill--2{background-color:#27150a;color:#facc15}.projects{padding:5rem 0 7rem;background-color:var(--color-surface);transition:background-color .3s ease}.projects__header{max-width:1200px;margin:0 auto 4rem;padding:0 2.5rem;display:flex;flex-direction:column;gap:1rem}.projects__stack{max-width:1200px;margin:0 auto;border-radius:20px;border:1px solid var(--color-border);overflow:hidden;box-shadow:0 2px 8px #0000000a,0 12px 40px #0000000f,0 0 0 1px #fff9 inset}[data-theme=dark] .projects__stack{box-shadow:0 2px 8px #0003,0 16px 48px #00000059,0 0 0 1px #ffffff0a inset}.projects__stack .project-item:first-child{border-top:none}.project-item{display:grid;grid-template-columns:1fr 1fr;min-height:420px;border-top:1px solid var(--color-border);cursor:pointer;outline:none;overflow:hidden;transition:background-color .2s ease}.projects__stack .project-item:last-child{border-bottom:1px solid var(--color-border)}.project-item:focus-visible{outline:2px solid var(--color-accent);outline-offset:-2px}.project-item:hover{background-color:#8b5cf606}[data-theme=dark] .project-item:hover{background-color:#a78bfa0a}.project-item:nth-child(2n) .project-item__preview{order:2}.project-item:nth-child(2n) .project-item__info{order:1}.project-item__preview{display:flex;align-items:center;justify-content:center;transition:background-color .35s ease}.project-item__emoji{font-size:5.5rem;transition:transform .4s cubic-bezier(.34,1.56,.64,1);display:block}.project-item:hover .project-item__emoji{transform:scale(1.15) rotate(-5deg)}.project-item__preview-img{width:100%;height:100%;object-fit:cover;display:block}.project-item__info{padding:3.5rem;display:flex;flex-direction:column;justify-content:center;gap:.9rem;border-left:1px solid var(--color-border)}.project-item:nth-child(odd) .project-item__info{border-left:none;border-right:1px solid var(--color-border)}.project-item__num{font-size:.75rem;font-weight:700;color:var(--color-muted);letter-spacing:.1em;font-variant-numeric:tabular-nums}.project-item__cat{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--color-accent)}.project-item__title{font-size:clamp(1.6rem,2.8vw,2.4rem);font-weight:800;letter-spacing:-.035em;line-height:1.1;color:var(--color-text);margin:0;transition:color .2s}.project-item:hover .project-item__title{color:var(--color-accent)}.project-item__desc{font-size:.95rem;color:var(--color-muted);line-height:1.75;max-width:440px}.project-item__tools{display:flex;gap:.4rem;flex-wrap:wrap}.project-item__link{display:inline-flex;align-items:center;gap:.4rem;font-size:.88rem;font-weight:700;color:var(--color-accent);margin-top:.25rem;transition:gap .2s}.project-item:hover .project-item__link{gap:.75rem}.project-item__arrow{display:inline-block;transition:transform .2s}.project-item:hover .project-item__arrow{transform:translate(4px)}.contact{padding:8rem 2.5rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.5rem;background-color:var(--color-bg);transition:background-color .3s ease}.contact__title{font-size:clamp(2.5rem,6vw,5rem);font-weight:800;line-height:1.05;letter-spacing:-.035em;max-width:800px}.contact__title em,.section-title em{font-style:italic;color:var(--color-accent)}.contact__sub{font-size:1.05rem;color:var(--color-muted);max-width:480px;line-height:1.7}.contact__email{font-size:clamp(1.3rem,3vw,2.2rem);font-weight:800;color:var(--color-text);border-bottom:4px solid var(--color-accent);padding-bottom:.15em;letter-spacing:-.02em;transition:color .2s}.contact__email:hover{color:var(--color-accent)}.contact__socials{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center;margin-top:.5rem}.social-pill{display:inline-block;padding:.5rem 1.1rem;border-radius:50px;font-size:.85rem;font-weight:600;border:1.5px solid var(--color-border);color:var(--color-text);transition:background-color .2s,border-color .2s,transform .15s}.social-pill:hover{background-color:var(--color-text);color:var(--color-bg);border-color:var(--color-text);transform:translateY(-2px)}.footer{display:flex;justify-content:space-between;align-items:center;padding:1.75rem 2.5rem;border-top:1px solid var(--color-border);background-color:var(--color-surface);transition:background-color .3s ease}.footer__name{font-weight:700;font-size:.95rem}.footer__copy{font-size:.8rem;color:var(--color-muted)}.section-tag{display:inline-block;font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--color-accent)}.section-title{font-size:clamp(2.5rem,5.5vw,4.5rem);font-weight:800;line-height:1;letter-spacing:-.035em;margin:0}.accent-star{color:var(--color-accent)}.detail{min-height:100vh;background-color:var(--color-bg);transition:background-color .3s ease}.detail-nav{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:1.1rem 2.5rem;background-color:var(--color-nav-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border)}.detail-back{font-size:.9rem;font-weight:600;color:var(--color-muted);background:none;border:none;cursor:pointer;padding:0;font-family:inherit;transition:color .2s,transform .15s;display:flex;align-items:center;gap:.3rem}.detail-back:hover{color:var(--color-text);transform:translate(-3px)}.detail-nav__brand{font-size:1.1rem;font-weight:700;letter-spacing:-.02em}.detail-nav__cat{font-size:.78rem;font-weight:600;color:var(--color-muted);text-transform:uppercase;letter-spacing:.08em}.detail-hero{max-width:1200px;margin:0 auto;padding:4rem 2.5rem 2rem}.detail-hero__preview{border-radius:20px;height:420px;display:flex;align-items:center;justify-content:center;overflow:hidden;transition:background-color .3s ease;margin-bottom:2rem}.detail-hero__emoji{font-size:7rem;filter:drop-shadow(0 8px 24px rgba(0,0,0,.15))}.detail-hero__img{width:100%;height:100%;object-fit:cover;display:block}.detail-hero__meta{display:flex;flex-direction:column;gap:.75rem}.detail-hero__title{font-size:clamp(2.2rem,5vw,4rem);font-weight:700;line-height:1.05;letter-spacing:-.04em;margin:0}.detail-info{max-width:1200px;margin:0 auto;padding:2.5rem;display:flex;gap:4rem;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}.detail-info__item{display:flex;flex-direction:column;gap:.4rem}.detail-info__label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-muted)}.detail-info__value{font-size:.95rem;font-weight:500;color:var(--color-text)}.detail-info__tools{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.1rem}.tool-tag{display:inline-block;padding:.2rem .7rem;border-radius:50px;font-size:.75rem;font-weight:600;background-color:var(--color-accent-bg);color:var(--color-accent)}.detail-content{max-width:1200px;margin:0 auto;padding:4rem 2.5rem;display:flex;flex-direction:column;gap:4rem}.detail-section{max-width:680px}.detail-section--wide{max-width:100%}.detail-section__title{font-size:1.4rem;font-weight:700;letter-spacing:-.02em;margin-bottom:1rem;color:var(--color-text)}.detail-section__text{font-size:1.05rem;color:var(--color-muted);line-height:1.85}.detail-screens{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:1rem}.detail-screen--main{grid-column:1 / -1}.detail-screen{border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center;transition:background-color .3s ease;aspect-ratio:16 / 9;border:1px solid var(--color-border)}.detail-screen__label{font-size:.75rem;font-weight:600;color:var(--color-muted);opacity:.6;text-transform:uppercase;letter-spacing:.1em}.detail-screen__img{width:100%;height:100%;object-fit:cover;display:block}.detail-cols{display:grid;grid-template-columns:1fr 1fr;gap:3rem}.detail-project-nav{max-width:1200px;margin:0 auto;padding:3rem 2.5rem;display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--color-border);gap:2rem}.detail-project-nav__btn{display:flex;flex-direction:column;gap:.3rem;background:none;border:none;cursor:pointer;padding:0;font-family:inherit;text-align:left;transition:opacity .2s,transform .15s}.detail-project-nav__btn:hover{opacity:.7}.detail-project-nav__btn--right{text-align:right}.detail-project-nav__btn:not(.detail-project-nav__btn--right):hover{transform:translate(-4px)}.detail-project-nav__btn--right:hover{transform:translate(4px)}.detail-project-nav__dir{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-muted)}.detail-project-nav__name{font-size:1.1rem;font-weight:700;color:var(--color-text);letter-spacing:-.02em}.detail-project-nav__divider{color:var(--color-accent);font-size:1.2rem;flex-shrink:0}body:before{content:"";position:fixed;inset:0;z-index:-2;background:radial-gradient(ellipse 60% 50% at 15% 20%,rgba(139,92,246,.18) 0%,transparent 65%),radial-gradient(ellipse 50% 60% at 85% 80%,rgba(167,139,250,.14) 0%,transparent 65%),radial-gradient(ellipse 40% 45% at 62% 12%,rgba(221,214,254,.12) 0%,transparent 58%);animation:bgOrbs 14s ease-in-out infinite alternate;pointer-events:none}[data-theme=dark] body:before{background:radial-gradient(ellipse 60% 50% at 15% 20%,rgba(139,92,246,.28) 0%,transparent 65%),radial-gradient(ellipse 50% 60% at 85% 80%,rgba(167,139,250,.2) 0%,transparent 65%),radial-gradient(ellipse 40% 45% at 62% 12%,rgba(88,28,200,.18) 0%,transparent 58%)}@keyframes bgOrbs{0%{background-position:0% 0%}33%{background-position:3% 5%}66%{background-position:-3% 2%}to{background-position:2% -3%}}body:after{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:200px 200px;animation:grainShift 7s steps(2) infinite}[data-theme=dark] body:after{opacity:.055}@keyframes grainShift{0%{background-position:0px 0px}20%{background-position:-50px -80px}40%{background-position:-120px 60px}60%{background-position:70px -120px}80%{background-position:-40px 100px}to{background-position:100px -50px}}@keyframes marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.15)}}@media(max-width:900px){.hero{grid-template-columns:1fr;text-align:center;padding:4rem 1.5rem;min-height:unset}.hero__left{align-items:center}.hero__actions,.hero__socials{justify-content:center}.portrait-wrap{width:280px;height:320px}.portrait-badge--tl{left:4%}.portrait-badge--br{right:4%}.about__inner{grid-template-columns:1fr;gap:2rem}.about__lead{position:static}.project-item{grid-template-columns:1fr;min-height:auto}.project-item:nth-child(2n) .project-item__preview{order:0}.project-item:nth-child(2n) .project-item__info{order:0}.project-item__info{border-left:none!important;border-right:none!important;border-top:1px solid var(--color-border);padding:2.5rem}.project-item__preview{min-height:260px}}@media(max-width:768px){.nav__cta{display:none}.nav__links{gap:1.2rem}.about{padding:3rem 1.25rem 4rem}.about__inner{gap:1.5rem;padding-bottom:2.5rem}.about__lead{position:static}.projects{padding:4rem 0 5rem}.project-item__info{padding:2rem 1.5rem}.project-item__preview{min-height:220px}.project-item__title{font-size:1.5rem}.contact{padding:5rem 1.5rem}.footer{flex-direction:column;gap:.5rem;text-align:center}.detail-nav__cat{display:none}.detail-info{flex-direction:column;gap:1.5rem;padding:2rem 1.5rem}.detail-content{padding:3rem 1.5rem;gap:3rem}.detail-hero{padding:3rem 1.5rem 1.5rem}.detail-hero__preview{height:240px}.detail-hero__emoji{font-size:4rem}.detail-cols{grid-template-columns:1fr;gap:2rem}.detail-screens{grid-template-columns:1fr}.detail-screen--main{grid-column:1}.detail-project-nav{flex-direction:column;align-items:flex-start;gap:1.5rem;padding:2rem 1.5rem}.detail-project-nav__btn--right{align-self:flex-end}}
