:root{--bg:oklch(9% 0.015 240);--bg-surface:oklch(13% 0.018 240);--bg-elevated:oklch(17% 0.02 240);--border:oklch(24% 0.022 240);--border-subtle:oklch(18% 0.018 240);--accent:#a38cf3;--accent-dim:#a38cf326;--accent-2:oklch(72% 0.14 185);--text:oklch(94% 0.008 240);--text-muted:oklch(72% 0.01 240);--text-dim:oklch(54% 0.01 240);--code-bg:oklch(8% 0.012 240);--output-bg:oklch(11% 0.014 240);--font-scale:1;--radius:8px;--shadow:0 4px 32px oklch(0% 0 0 / 0.5);--shadow-sm:0 2px 12px oklch(0% 0 0 / 0.3);--content-width:680px}[data-theme=light]{--bg:oklch(98% 0.005 240);--bg-surface:oklch(95% 0.008 240);--bg-elevated:oklch(92% 0.01 240);--border:oklch(82% 0.01 240);--border-subtle:oklch(88% 0.008 240);--accent:#1a6ef5;--accent-dim:#1a6ef514;--accent-2:oklch(52% 0.14 185);--text:oklch(10% 0.01 240);--text-muted:oklch(45% 0.01 240);--text-dim:oklch(62% 0.01 240);--code-bg:oklch(96% 0.005 240);--output-bg:oklch(94% 0.008 240);--shadow:0 4px 32px oklch(0% 0 0 / 0.1);--shadow-sm:0 2px 12px oklch(0% 0 0 / 0.06)}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{font-size:calc(16px * var(--font-scale,1));scroll-behavior:smooth;background:var(--bg)}body{background:var(--bg);color:var(--text);font-family:space grotesk,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.65;overflow-x:hidden;transition:background .3s,color .3s}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}button{background:0 0;border:none;font-family:inherit;font-size:inherit;color:inherit;cursor:pointer}.mono{font-family:jetbrains mono,ui-monospace,SFMono-Regular,monospace}@media(hover:hover) and (pointer:fine){body{cursor:none}body *{cursor:none}.cursor-dot{position:fixed;top:0;left:0;z-index:9999;width:8px;height:8px;border-radius:50%;background:var(--accent);pointer-events:none;transition:width .2s,height .2s,background .2s;will-change:transform}.cursor-ring{position:fixed;top:0;left:0;z-index:9998;width:36px;height:36px;border-radius:50%;border:1.5px solid var(--accent);opacity:.55;pointer-events:none;transition:width .25s,height .25s,opacity .25s,border-color .25s;will-change:transform}.cursor-dot--hover{width:6px;height:6px}.cursor-ring--hover{width:52px;height:52px;opacity:.7;background:var(--accent-dim)}}@media not all and (hover:hover){.cursor-dot,.cursor-ring{display:none}}.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:var(--radius);font-family:space grotesk,sans-serif;font-size:.9rem;font-weight:600;letter-spacing:.02em;transition:all .22s ease;position:relative;overflow:hidden}.btn::after{content:'';position:absolute;inset:0;background:#fff;opacity:0;transition:opacity .2s;pointer-events:none}.btn:hover::after{opacity:.07}.btn--primary{background:var(--accent);color:#fff;box-shadow:0 0 24px var(--accent-dim)}.btn--primary:hover{box-shadow:0 0 40px var(--accent-dim),0 0 0 1px var(--accent);transform:translateY(-1px)}.btn--outline{border:1.5px solid var(--border);color:var(--text)}.btn--outline:hover{border-color:var(--accent);color:var(--accent)}.btn--ghost{color:var(--accent);border:1.5px solid var(--accent-dim)}.btn--ghost:hover{background:var(--accent-dim)}.btn--sm{padding:7px 16px;font-size:.8rem}.navbar{position:fixed;top:0;left:0;right:0;z-index:900;transition:background .3s,backdrop-filter .3s,box-shadow .3s;padding:0 clamp(20px,5vw,80px)}.navbar--scrolled{background:oklch(from var(--bg) l c h/.85);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 1px 0 var(--border-subtle)}.navbar__inner{display:flex;align-items:center;gap:24px;height:70px;max-width:1200px;margin:0 auto}.navbar__brand{font-size:1.5rem;font-weight:800;letter-spacing:-.02em;display:flex;align-items:baseline;gap:1px;margin-right:auto}.navbar__brand-letter{color:var(--text)}.navbar__brand-dot{color:var(--accent)}.navbar__links{display:flex;align-items:center;gap:4px}.navbar__link{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--radius);font-size:.88rem;font-weight:500;color:var(--text-muted);transition:color .2s,background .2s}.navbar__link:hover{color:var(--text);background:var(--bg-surface)}.navbar__link-num{color:var(--accent);font-size:.72rem;font-family:jetbrains mono,monospace}.navbar__actions{display:flex;align-items:center;gap:10px}.theme-toggle{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);border:1.5px solid var(--border);transition:all .2s;background:0 0}.theme-toggle:hover{color:var(--accent);border-color:var(--accent)}.theme-toggle svg{width:18px;height:18px}.theme-toggle .icon-sun{display:none}.theme-toggle .icon-moon{display:block}[data-theme=dark] .theme-toggle .icon-sun{display:block}[data-theme=dark] .theme-toggle .icon-moon{display:none}.hamburger{display:none;flex-direction:column;gap:5px;padding:8px}.hamburger span{display:block;width:22px;height:2px;background:var(--text);transition:all .2s}.navbar__mobile-menu{display:none;background:var(--bg-surface);border-top:1px solid var(--border);padding:16px clamp(20px,5vw,80px);flex-direction:column;gap:4px}.navbar__mobile-link{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius);font-size:1rem;color:var(--text-muted);transition:all .2s}.navbar__mobile-link:hover{color:var(--text);background:var(--bg-elevated)}.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}.reveal--visible{opacity:1;transform:translateY(0)}.section{padding:clamp(60px,10vw,120px)clamp(20px,5vw,80px);max-width:1200px;margin:0 auto;opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}.section--visible{opacity:1;transform:translateY(0)}.section__inner{max-width:1100px;margin:0 auto}.section__header{display:flex;align-items:center;gap:20px;margin-bottom:clamp(40px,6vw,72px)}.section__num{font-family:jetbrains mono,monospace;font-size:.85rem;color:var(--accent);flex-shrink:0}.section__title{font-size:clamp(1.5rem,3vw,2.1rem);font-weight:700;letter-spacing:-.025em;white-space:nowrap}.section__line{height:1px;background:var(--border);flex:1;min-width:40px}.section--contact{background:var(--bg-surface);max-width:100%}.section--contact .section__inner{max-width:1100px}.stack-badge{display:inline-block;padding:3px 10px;border-radius:4px;background:var(--accent-dim);color:var(--accent);font-family:jetbrains mono,monospace;font-size:.72rem;border:1px solid oklch(from var(--accent) l c h/.2);transition:background .2s}.link{color:var(--accent);text-decoration:underline;text-decoration-color:var(--accent-dim);text-underline-offset:3px;transition:text-decoration-color .2s}.link:hover{text-decoration-color:var(--accent)}.hero{min-height:100vh;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:70px clamp(20px,5vw,80px)60px}.hero__bg{position:absolute;inset:0;pointer-events:none;z-index:0}.hero__grid{position:absolute;inset:0;background-image:linear-gradient(var(--border-subtle) 1px,transparent 1px),linear-gradient(90deg,var(--border-subtle) 1px,transparent 1px);background-size:60px 60px;opacity:.5;-webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 40%,transparent 100%);mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 40%,transparent 100%)}.hero__orb{position:absolute;border-radius:50%;filter:blur(80px);animation:orb-float 8s ease-in-out infinite}.hero__orb--1{width:500px;height:500px;background:oklch(from var(--accent) l c h/.12);top:-100px;right:-100px;animation-delay:0s}.hero__orb--2{width:300px;height:300px;background:oklch(72% .14 185/.08);bottom:50px;left:-80px;animation-delay:-3s}.hero__orb--3{width:200px;height:200px;background:oklch(from var(--accent) l c h/.08);top:40%;left:40%;animation-delay:-5s}@keyframes orb-float{0%,100%{transform:translateY(0)scale(1)}50%{transform:translateY(-30px)scale(1.05)}}.hero__content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:clamp(32px,5vw,52px);text-align:center;max-width:780px;width:100%}.hero__photo-wrap{display:flex;flex-direction:column;align-items:center;gap:12px}.hero__photo-frame{position:relative;width:clamp(140px,20vw,200px);height:clamp(140px,20vw,200px)}.hero__photo{width:100%;height:100%;border-radius:12px;object-fit:cover;object-position:top;display:block;filter:grayscale(15%)contrast(1.05)}.hero__corner{position:absolute;width:20px;height:20px;border-color:var(--accent);border-style:solid;transition:all .3s}.hero__corner--tl{top:-4px;left:-4px;border-width:2px 0 0 2px;border-radius:3px 0 0 0}.hero__corner--tr{top:-4px;right:-4px;border-width:2px 2px 0 0;border-radius:0 3px 0 0}.hero__corner--bl{bottom:-4px;left:-4px;border-width:0 0 2px 2px;border-radius:0 0 0 3px}.hero__corner--br{bottom:-4px;right:-4px;border-width:0 2px 2px 0;border-radius:0 0 3px 0}.hero__scan-line{position:absolute;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:.7;animation:scan 3s ease-in-out infinite;pointer-events:none}@keyframes scan{0%{top:0;opacity:0}10%{opacity:.7}90%{opacity:.7}100%{top:100%;opacity:0}}.hero__photo-label{font-size:.68rem;color:var(--accent);letter-spacing:.15em}.hero__text{display:flex;flex-direction:column;align-items:center;gap:16px}.hero__greeting{display:flex;align-items:center;gap:12px;font-size:.8rem;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase}.hero__greeting-line{display:inline-block;width:32px;height:1px;background:var(--accent)}.hero__name{font-size:clamp(3rem,8vw,6.5rem);font-weight:800;letter-spacing:-.04em;line-height:.9;background:linear-gradient(135deg,var(--text) 60%,var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero__role{font-size:.82rem;color:var(--text-muted);letter-spacing:.04em}.hero__role-accent{color:var(--accent)}.hero__role-sep{color:var(--text-dim);margin:0 4px}.hero__tagline{font-size:clamp(1.3rem,3.5vw,2.2rem);font-weight:600;line-height:1.2;color:var(--text);letter-spacing:-.02em;min-height:2.8em}.hero__tagline-line{display:block}.hero__cursor{display:inline-block;color:var(--accent);font-weight:300;opacity:0;transition:opacity .1s}.hero__cursor--on{opacity:1}.hero__actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:8px}.hero__socials{display:flex;align-items:center;gap:16px;margin-top:4px}.hero__social{font-size:.7rem;letter-spacing:.12em;color:var(--text-dim);transition:color .2s}.hero__social:hover{color:var(--accent)}.hero__scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:10px;animation:scroll-bounce 2s ease-in-out infinite;z-index:1}.hero__scroll-line{width:1px;height:48px;background:linear-gradient(180deg,transparent,var(--accent))}.hero__scroll-label{font-size:.65rem;color:var(--text-dim);letter-spacing:.15em}@keyframes scroll-bounce{0%,100%{transform:translateX(-50%)translateY(0)}50%{transform:translateX(-50%)translateY(6px)}}.about__grid{display:grid;grid-template-columns:260px 1fr;gap:clamp(32px,5vw,72px);align-items:start}.about__photo-wrap{position:relative}.about__photo{width:100%;border-radius:12px;object-fit:cover;filter:grayscale(20%);transition:filter .4s}.about__photo:hover{filter:grayscale(0%)}.about__photo-outline{position:absolute;inset:-8px;border:1.5px solid var(--accent);border-radius:16px;opacity:0;transition:opacity .4s;z-index:-1}.about__photo-wrap:hover .about__photo-outline{opacity:.4}.about__content{display:flex;flex-direction:column;gap:20px}.about__bio{font-size:1.02rem;color:var(--text-muted);line-height:1.75}.about__bio--muted{color:var(--text-dim);font-size:.92rem}.about__bio p+p{margin-top:1em}.skills{margin-top:12px}.skills__title{font-size:.72rem;color:var(--accent);letter-spacing:.06em;margin-bottom:20px}.skills__groups{display:flex;flex-direction:column;gap:16px}.skills__group{display:flex;align-items:baseline;gap:16px;flex-wrap:wrap}.skills__group-name{font-size:.7rem;color:var(--text-dim);letter-spacing:.1em;min-width:80px;flex-shrink:0;text-transform:uppercase}.skills__items{display:flex;flex-wrap:wrap;gap:8px}.skill-chip{display:inline-block;padding:5px 14px;border-radius:4px;background:var(--accent-dim);color:var(--accent);font-family:jetbrains mono,monospace;font-size:.82rem;border:1px solid oklch(from var(--accent) l c h/.2)}.timeline{display:flex;flex-direction:column;gap:18px}.timeline__item-wrap{width:100%}.timeline__item{display:grid;grid-template-columns:24px 1fr;gap:0 24px;cursor:pointer}.timeline__marker{display:flex;flex-direction:column;align-items:center}.timeline__dot{width:12px;height:12px;border-radius:50%;border:2px solid var(--accent);background:var(--bg);flex-shrink:0;margin-top:5px;transition:background .2s}.timeline__item--open .timeline__dot{background:var(--accent)}.timeline__line{width:1.5px;flex:1;min-height:24px;background:var(--border);margin:6px 0}.timeline__content{padding-bottom:32px;border-bottom:1px solid var(--border-subtle);margin-bottom:0}.timeline__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding-top:2px}.timeline__meta{flex:1}.timeline__title{font-size:1.05rem;font-weight:600;margin-bottom:4px}.timeline__company{display:flex;align-items:center;gap:12px;font-size:.88rem;color:var(--text-muted)}.timeline__location{font-size:.7rem;color:var(--text-dim);letter-spacing:.04em}.timeline__right{display:flex;align-items:center;gap:12px;flex-shrink:0}.timeline__period{font-size:.72rem;color:var(--text-dim);letter-spacing:.04em}.timeline__chevron{font-size:1.3rem;color:var(--accent);line-height:1;width:1ch;text-align:center}.timeline__body{max-height:0;opacity:0;overflow:hidden;padding-top:0;padding-bottom:0;transform:translateY(-4px);transition:max-height .45s cubic-bezier(.4,0,.2,1),opacity .3s ease,padding .3s ease,transform .35s cubic-bezier(.4,0,.2,1)}.timeline__item--open .timeline__body{max-height:2000px;opacity:1;padding-top:16px;padding-bottom:4px;transform:translateY(0);transition:max-height .55s cubic-bezier(.16,1,.3,1),opacity .35s ease .08s,padding .35s ease,transform .4s cubic-bezier(.16,1,.3,1).05s}.timeline__chevron{display:inline-block;transition:transform .25s ease,color .2s}.timeline__item--open .timeline__chevron{transform:rotate(180deg)}.timeline__intro{display:flex;flex-direction:column;gap:10px;font-size:.9rem;color:var(--text-muted);line-height:1.6;margin-bottom:16px}.timeline__intro p{margin:0}.timeline__points{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.timeline__point{display:flex;gap:12px;font-size:.9rem;color:var(--text-muted);line-height:1.6}.timeline__bullet{color:var(--accent);flex-shrink:0;margin-top:2px}.timeline__stack{display:flex;flex-wrap:wrap;gap:8px}.timeline__points p{display:inline}.projects__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}.project-card-wrap{height:100%}.project-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;height:100%;transition:transform .3s ease,box-shadow .3s ease,border-color .3s}.project-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px oklch(0% 0 0/.4);border-color:var(--accent)}.project-card__img-wrap{position:relative;height:180px;overflow:hidden}.project-card__img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.project-card:hover .project-card__img{transform:scale(1.04)}.project-card__img-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,var(--bg-surface));pointer-events:none}.project-card__num{position:absolute;top:12px;right:12px;font-size:.68rem;color:var(--accent);background:var(--bg-surface);padding:2px 8px;border-radius:4px;border:1px solid var(--border)}.project-card__body{padding:20px;display:flex;flex-direction:column;gap:10px;flex:1}.project-card__title{font-size:1.05rem;font-weight:700}.project-card__desc{font-size:.875rem;color:var(--text-muted);line-height:1.6;flex:1}.project-card__footer{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:4px}.project-card__tags{display:flex;flex-wrap:wrap;gap:6px}.project-card__link{color:var(--text-dim);flex-shrink:0;transition:color .2s;display:inline-flex}.project-card__link:hover{color:var(--accent)}.project-card__link svg{width:20px;height:20px}.edu-list{display:flex;flex-direction:column;gap:0}.edu-item{display:grid;grid-template-columns:110px 1fr;gap:24px;padding:28px 0;border-bottom:1px solid var(--border-subtle)}.edu-item__left{padding-top:4px}.edu-item__period{font-size:.72rem;color:var(--text-dim);letter-spacing:.04em;line-height:1.4}.edu-item__degree{font-size:1rem;font-weight:600;margin-bottom:6px}.edu-item__school{font-size:.88rem;color:var(--accent);display:block;margin-bottom:8px}.edu-item__note{font-size:.85rem;color:var(--text-dim);line-height:1.6}.edu-item__note p+p{margin-top:.5em}.achieve-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px}.achieve-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;display:flex;gap:0}.achieve-card__img-wrap{width:90px;flex-shrink:0}.achieve-card__img{width:100%;height:100%;object-fit:cover}.achieve-card__body{padding:18px;display:flex;flex-direction:column;gap:6px}.achieve-card__title{font-size:.95rem;font-weight:600}.achieve-card__desc{font-size:.82rem;color:var(--text-muted);line-height:1.5}.contact__layout{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,72px);align-items:start}.contact__tagline{font-size:1.2rem;font-weight:500;line-height:1.6;color:var(--text-muted);margin-bottom:28px}.contact__email{display:block;font-size:1rem;font-weight:600;margin-bottom:20px}.contact__socials{display:flex;gap:10px;flex-wrap:wrap}.contact__form{display:flex;flex-direction:column;gap:18px}.form-field{display:flex;flex-direction:column;gap:8px}.form-field__label{font-size:.72rem;color:var(--text-dim);letter-spacing:.08em;text-transform:uppercase}.form-field__input{background:var(--bg-elevated);border:1.5px solid var(--border);border-radius:var(--radius);padding:12px 16px;font-family:space grotesk,sans-serif;font-size:.92rem;color:var(--text);outline:none;transition:border-color .2s,box-shadow .2s;resize:vertical}.form-field__input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.form-field__input::placeholder{color:var(--text-dim)}.form-field__textarea{min-height:130px}.form-error{font-size:.82rem;color:oklch(65% .2 25)}.contact__success{display:flex;flex-direction:column;align-items:center;gap:16px;padding:48px 24px;text-align:center;border:1.5px solid var(--accent);border-radius:12px}.contact__success-icon{width:48px;height:48px;border-radius:50%;background:var(--accent-dim);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:1.4rem;line-height:1}.contact__success--hidden{display:none}.blog__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}.blog-card-wrap{height:100%}.blog-card{display:flex;flex-direction:column;background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;height:100%;transition:transform .3s ease,box-shadow .3s ease,border-color .3s;text-decoration:none}.blog-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px oklch(0% 0 0/.4);border-color:var(--accent)}.blog-card__img-wrap{position:relative;height:160px;overflow:hidden;flex-shrink:0}.blog-card__img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.blog-card:hover .blog-card__img{transform:scale(1.04)}.blog-card__img-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,var(--bg-surface));pointer-events:none}.blog-card__body{padding:20px;display:flex;flex-direction:column;gap:10px;flex:1}.blog-card__meta{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.blog-card__date{font-size:.7rem;color:var(--text-dim);letter-spacing:.04em}.blog-card__tags{display:flex;gap:6px;flex-wrap:wrap}.blog-card__title{font-size:.98rem;font-weight:700;line-height:1.35;color:var(--text)}.blog-card__excerpt{font-size:.84rem;color:var(--text-muted);line-height:1.6;flex:1}.blog-card__cta{font-size:.75rem;color:var(--accent);letter-spacing:.04em;margin-top:4px;transition:letter-spacing .2s}.blog-card:hover .blog-card__cta{letter-spacing:.08em}.footer{border-top:1px solid var(--border-subtle);padding:28px clamp(20px,5vw,80px)}.footer__inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.footer__copy{font-size:.78rem;color:var(--text-dim)}.footer__built{font-size:.78rem;color:var(--text-dim)}.progress-bar{position:fixed;top:0;left:0;height:2px;z-index:1000;background:var(--accent);transform-origin:left;transform:scaleX(0);transition:transform .1s linear;width:100%}.post-nav{position:sticky;top:0;z-index:900;background:oklch(from var(--bg) l c h/.88);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-subtle);padding:0 clamp(16px,4vw,60px)}.post-nav__inner{display:flex;align-items:center;gap:20px;height:60px;max-width:1200px;margin:0 auto}.post-nav__back{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--text-muted);transition:color .2s}.post-nav__back:hover{color:var(--accent)}.post-nav__sep{color:var(--border);font-size:.9rem}.post-nav__title{font-size:.85rem;color:var(--text-dim);overflow:hidden;white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0}.post-nav__actions{display:flex;align-items:center;gap:10px;margin-left:auto;flex-shrink:0}.article-hero{padding:clamp(40px,6vw,80px)clamp(16px,4vw,60px)0;max-width:1100px;margin:0 auto}.article-hero__meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:24px}.tag{display:inline-block;padding:3px 10px;border-radius:4px;background:var(--accent-dim);color:var(--accent);font-family:jetbrains mono,monospace;font-size:.7rem;border:1px solid oklch(from var(--accent) l c h/.2)}.meta-dot{color:var(--text-dim);font-size:.8rem}.meta-text{font-size:.8rem;color:var(--text-dim);font-family:jetbrains mono,monospace}.article-hero__title{font-size:clamp(2rem,5vw,3.5rem);font-weight:800;letter-spacing:-.035em;line-height:1.1;margin-bottom:20px;text-wrap:balance}.article-hero__subtitle{font-size:1.1rem;color:var(--text-muted);line-height:1.65;max-width:620px;margin-bottom:28px}.article-hero__byline{display:flex;align-items:center;gap:12px;padding-bottom:28px;border-bottom:1px solid var(--border-subtle)}.byline__avatar{width:38px;height:38px;border-radius:50%;object-fit:cover;object-position:top;flex-shrink:0;border:2px solid var(--border)}.byline__author{font-size:.88rem;font-weight:600}.byline__info{font-size:.78rem;color:var(--text-dim)}.article-hero__cover{margin-top:40px;width:100%;max-height:420px;object-fit:cover;border-radius:12px;border:1px solid var(--border)}.article-layout{display:grid;grid-template-columns:220px minmax(0,var(--content-width))1fr;gap:0 48px;max-width:1100px;margin:0 auto;padding:0 clamp(16px,4vw,60px);align-items:start}.toc{position:sticky;top:80px;padding:32px 0;font-size:.78rem;max-height:calc(100vh - 90px);overflow-y:auto}.toc__label{font-family:jetbrains mono,monospace;font-size:.65rem;color:var(--accent);letter-spacing:.12em;text-transform:uppercase;margin-bottom:16px}.toc nav ul,.toc__list{list-style:none;display:flex;flex-direction:column;gap:2px;padding:0}.toc nav ul ul{padding-left:12px}.toc nav a,.toc__item a{display:block;padding:5px 10px;color:var(--text-dim);text-decoration:none;border-left:2px solid var(--border);border-radius:0 4px 4px 0;line-height:1.4;transition:all .2s;font-size:.78rem}.toc nav a:hover,.toc__item a:hover,.toc nav a.active,.toc__item--active a{color:var(--accent);border-left-color:var(--accent);background:var(--accent-dim)}.article-content{padding:48px 0 80px;min-width:0;font-size:1.05rem;line-height:1.78}.article-content>:first-child{margin-top:0}.article-content h2{font-size:1.55rem;font-weight:700;letter-spacing:-.025em;line-height:1.25;margin:56px 0 20px;color:var(--text);scroll-margin-top:80px}.article-content h3{font-size:1.12rem;font-weight:600;letter-spacing:-.015em;line-height:1.3;margin:36px 0 14px;color:var(--text);scroll-margin-top:80px}.article-content p{margin-bottom:20px;color:var(--text-muted)}.article-content p:last-child{margin-bottom:0}.article-content strong{color:var(--text);font-weight:600}.article-content em{font-style:italic}.article-content a{color:var(--accent);text-decoration:underline;text-decoration-color:var(--accent-dim);text-underline-offset:3px}.article-content a:hover{text-decoration-color:var(--accent)}.article-content ul,.article-content ol{padding-left:24px;margin-bottom:20px;color:var(--text-muted)}.article-content li{margin-bottom:6px}.article-content code{font-family:jetbrains mono,monospace;font-size:.82em;background:var(--bg-surface);padding:2px 6px;border-radius:4px;color:var(--accent);border:1px solid var(--border)}.article-content img{max-width:100%;border-radius:10px;border:1px solid var(--border);margin:24px auto}.article-content blockquote{margin:28px 0;padding:16px 20px;background:var(--accent-dim);border-left:3px solid var(--accent);border-radius:0 var(--radius)var(--radius)0;font-size:.96rem;color:var(--text-muted);line-height:1.65}.article-content blockquote p:last-child{margin-bottom:0}.article-content blockquote strong{color:var(--accent)}.article-content pre{margin:28px 0;padding:18px 20px;background:var(--code-bg);border:1px solid var(--border);border-radius:10px;overflow-x:auto;font-size:.82rem;position:relative}.article-content pre code{background:0 0;border:none;padding:0;color:inherit;font-size:.82rem}.article-content pre::-webkit-scrollbar{height:4px}.article-content pre::-webkit-scrollbar-track{background:0 0}.article-content pre::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.code-copy{position:absolute;top:8px;right:8px;font-family:jetbrains mono,monospace;font-size:.65rem;color:var(--text-dim);padding:3px 8px;border:1px solid var(--border);border-radius:4px;background:var(--bg-surface);cursor:pointer;transition:all .2s;opacity:0}.article-content pre:hover .code-copy{opacity:1}.code-copy:hover{color:var(--accent);border-color:var(--accent)}.article-content table{width:100%;border-collapse:collapse;margin:24px 0;font-size:.92rem}.article-content th,.article-content td{padding:10px 14px;border-bottom:1px solid var(--border);text-align:left}.article-content th{color:var(--text);font-weight:600}.article-content td{color:var(--text-muted)}.article-figure{margin:36px 0;display:flex;flex-direction:column;align-items:center;gap:12px}.article-figure img{width:100%;border:1px solid var(--border);border-radius:10px}.article-figure figcaption{font-size:.78rem;color:var(--text-dim);font-style:italic;text-align:center;max-width:500px}.article-footer{padding:48px clamp(16px,4vw,60px);max-width:1100px;margin:0 auto;border-top:1px solid var(--border-subtle)}.article-footer__nav{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:16px}.post-nav-link{display:flex;flex-direction:column;gap:6px;padding:20px 24px;border-radius:10px;background:var(--bg-surface);border:1px solid var(--border);max-width:280px;flex:1;text-decoration:none;color:inherit;transition:border-color .2s,transform .2s}.post-nav-link:hover{border-color:var(--accent);transform:translateY(-2px)}.post-nav-link--next{text-align:right;align-items:flex-end}.post-nav-label{font-size:.68rem;color:var(--text-dim);font-family:jetbrains mono,monospace;letter-spacing:.08em}.post-nav-title{font-size:.9rem;font-weight:600;color:var(--text);line-height:1.35}.list-page{max-width:1100px;margin:0 auto;padding:clamp(80px,10vw,140px)clamp(20px,5vw,80px)80px}.list-page__title{font-size:clamp(2rem,5vw,3rem);font-weight:800;letter-spacing:-.035em;margin-bottom:12px}.list-page__subtitle{font-size:1rem;color:var(--text-muted);margin-bottom:48px}.pagination{display:flex;justify-content:center;align-items:center;gap:6px;margin-top:48px;list-style:none;padding:0}.pagination li a,.pagination li span{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 10px;border-radius:var(--radius);border:1.5px solid var(--border);color:var(--text-muted);font-size:.85rem;text-decoration:none;transition:all .2s}.pagination li.active a,.pagination li.active span{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.pagination li a:hover{border-color:var(--accent);color:var(--accent)}.not-found{min-height:70vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;text-align:center;padding:80px 24px}.not-found__code{font-family:jetbrains mono,monospace;color:var(--accent);font-size:.9rem}.not-found__title{font-size:2.4rem;font-weight:800;letter-spacing:-.03em}.not-found__desc{color:var(--text-muted);margin-bottom:16px}@media(max-width:900px){.article-layout{grid-template-columns:1fr}.toc{display:none}}@media(max-width:800px){.navbar__links{display:none}.hamburger{display:flex}.navbar--open .navbar__mobile-menu{display:flex}.about__grid{grid-template-columns:1fr}.about__photo-wrap{max-width:240px}.contact__layout{grid-template-columns:1fr}.edu-item{grid-template-columns:1fr;gap:8px}.timeline__item{grid-template-columns:16px 1fr}.timeline__header{flex-direction:column;gap:8px}.timeline__right{width:100%;justify-content:space-between}.footer__inner{flex-direction:column;gap:8px;text-align:center}}@media(max-width:600px){.article-hero__title{font-size:1.9rem}.article-footer__nav{flex-direction:column}.post-nav-link{max-width:100%}}@media(max-width:540px){.hero__content{gap:24px}.hero__actions{flex-direction:column;width:100%}.hero__actions .btn{width:100%;justify-content:center}.projects__grid{grid-template-columns:1fr}}@media(prefers-reduced-motion:reduce){.reveal,.section{transition:none;opacity:1;transform:none}.hero__orb{animation:none}.hero__scan-line{animation:none}.hero__scroll{animation:none}.timeline__body,.timeline__item--open .timeline__body{transition:none}.timeline__chevron{transition:none}}