.nav{height:var(--nav-height);z-index:100;transition:all var(--t-base);justify-content:space-between;align-items:center;padding:0 40px;display:flex;position:fixed;top:0;left:0;right:0}.nav.scrolled{background:var(--nav-bg);-webkit-backdrop-filter:blur(24px)saturate(180%);border-bottom:1px solid var(--nav-border)}.nav__logo{transition:opacity var(--t-fast);align-items:center;gap:10px;text-decoration:none;display:flex}.nav__logo:hover{opacity:.7}.nav__logo-icon{background:var(--gradient-main);color:#fff;width:32px;height:32px;font-family:var(--font-display);border-radius:var(--radius-sm);justify-content:center;align-items:center;font-size:.9rem;font-weight:700;display:flex}.nav__logo-text{font-family:var(--font-display);color:var(--gray-900);letter-spacing:-.01em;font-size:1.05rem;font-weight:600}.nav__links{background:var(--links-pill-bg);border-radius:var(--radius-full);border:1px solid var(--links-pill-border);align-items:center;gap:2px;padding:4px;display:flex}.nav__link{font-family:var(--font-cn);color:var(--gray-500);border-radius:var(--radius-full);transition:all var(--t-fast);padding:7px 18px;font-size:.8rem;font-weight:400;position:relative}.nav__link:hover{color:var(--gray-900)}.nav__link.active{color:var(--accent-light);background:var(--link-active-bg);font-weight:500}.nav__contact-btn{font-family:var(--font-cn);color:var(--gray-600);border:1px solid var(--contact-btn-border);border-radius:var(--radius-full);transition:all var(--t-fast);padding:8px 20px;font-size:.8rem;font-weight:500}.nav__contact-btn:hover{border-color:var(--accent);color:var(--accent-light);box-shadow:0 0 20px #818cf833}.nav__theme-btn{border-radius:var(--radius-full);width:34px;height:34px;color:var(--gray-500);border:1px solid var(--card-border);background:var(--links-pill-bg);transition:all var(--t-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.nav__theme-btn:hover{color:var(--accent-light);background:var(--accent-glow);border-color:#818cf84d;transform:scale(1.05);box-shadow:0 0 20px #818cf826}.nav__menu-btn{z-index:110;flex-direction:column;justify-content:center;gap:5px;width:28px;height:28px;display:none}.nav__menu-btn span{background:var(--gray-700);width:100%;height:1.5px;transition:all var(--t-base);transform-origin:50%;border-radius:1px;display:block}.nav__menu-btn.open span:first-child{transform:translateY(6.5px)rotate(45deg)}.nav__menu-btn.open span:nth-child(2){opacity:0}.nav__menu-btn.open span:nth-child(3){transform:translateY(-6.5px)rotate(-45deg)}.nav__mobile{background:var(--mobile-menu-bg);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);z-index:99;opacity:0;pointer-events:none;transition:opacity var(--t-base);flex-direction:column;justify-content:center;align-items:center;gap:8px;display:none;position:fixed;inset:0}.nav__mobile.open{opacity:1;pointer-events:auto}.nav__mobile-link{font-family:var(--font-cn);color:var(--gray-500);border-radius:var(--radius-full);transition:all var(--t-base);padding:14px 36px;font-size:1.4rem;font-weight:400}.nav__mobile-link:hover,.nav__mobile-link.active{color:var(--accent-light);background:var(--link-active-bg)}.nav__mobile-cta{font-family:var(--font-cn);color:#fff;background:var(--gradient-main);border-radius:var(--radius-full);box-shadow:var(--shadow-accent);transition:all var(--t-base);margin-top:16px;padding:14px 36px;font-size:.9rem;font-weight:500}.nav__mobile-cta:hover{box-shadow:var(--shadow-accent-lg);transform:translateY(-2px)}@media (width<=768px){.nav{padding:0 20px}.nav__links,.nav__contact-btn{display:none}.nav__menu-btn,.nav__mobile{display:flex}.nav__theme-btn{width:30px;height:30px}}.footer{border-top:1px solid var(--gray-100);background:var(--body-bg);padding:60px 0 40px}.footer__inner{max-width:1100px;margin:0 auto;padding:0 40px}.footer__top{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.footer__brand{align-items:center;gap:10px;display:flex}.footer__logo{border-radius:var(--radius-sm);object-fit:cover;width:42px;height:42px}.footer__logo-text{background:var(--gradient-main);color:#fff;font-family:var(--font-display);border-radius:var(--radius-sm);justify-content:center;align-items:center;width:28px;height:28px;font-size:.8rem;font-weight:700;display:flex}.footer__name{font-family:var(--font-display);color:var(--gray-900);font-size:1rem;font-weight:600}.footer__tagline{font-family:var(--font-display);color:var(--gray-400);letter-spacing:.02em;font-size:.8rem}.footer__divider{background:var(--gray-100);height:1px;margin-bottom:20px}.footer__bottom{justify-content:space-between;align-items:center;display:flex}.footer__copy,.footer__icp{color:var(--gray-400);font-size:.75rem}.footer__links{gap:20px;display:flex}.footer__links a,.footer__links button{color:var(--gray-400);transition:color var(--t-fast);cursor:pointer;font-size:.78rem;font-family:var(--font-body);background:0 0;border:none}.footer__links a:hover,.footer__links button:hover{color:var(--accent)}@media (width<=768px){.footer__inner{padding:0 20px}.footer__top,.footer__bottom{flex-direction:column;align-items:flex-start;gap:12px}}.cursor-wrap{pointer-events:none;z-index:9999;position:fixed;inset:0}.cursor-dot{background:var(--accent);width:8px;height:8px;transition:width .2s var(--ease-spring), height .2s var(--ease-spring);will-change:transform;border-radius:50%;position:absolute;top:0;left:0}.cursor-ring{border:1.5px solid var(--accent);width:40px;height:40px;transition:width .35s var(--ease-spring), height .35s var(--ease-spring), opacity .3s ease;will-change:transform;border-radius:50%;position:absolute;top:0;left:0}@media (width<=768px){.cursor-wrap{display:none}}.ploader{z-index:99999;pointer-events:all;position:fixed;inset:0}.ploader--exit{pointer-events:none}.ploader__panel{background:var(--body-bg);will-change:transform;width:50%;transition:transform 1.2s cubic-bezier(.87,0,.13,1);position:absolute;top:0;bottom:0}.ploader__panel--left{left:0}.ploader__panel--right{right:0}.ploader--exit .ploader__panel--left{transform:translate(-100%)}.ploader--exit .ploader__panel--right{transition-delay:50ms;transform:translate(100%)}.ploader__center{pointer-events:none;flex-direction:column;justify-content:center;align-items:center;gap:28px;transition:opacity .5s .1s,transform .5s .1s;display:flex;position:absolute;inset:0}.ploader--exit .ploader__center{opacity:0;transform:translateY(-16px)}.ploader__name{align-items:baseline;gap:14px;animation:.9s cubic-bezier(.16,1,.3,1) .25s both ploaderIn;display:flex}.ploader__en{letter-spacing:-.03em;background:var(--gradient-text);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-family:Space Grotesk,sans-serif;font-size:clamp(2.2rem,7vw,4.5rem);font-style:italic;font-weight:700}.ploader__dot{color:var(--gray-400);font-family:Space Grotesk,sans-serif;font-size:clamp(1.5rem,4vw,2.8rem)}.ploader__cn{color:var(--gray-600);letter-spacing:.04em;font-family:Noto Sans SC,PingFang SC,sans-serif;font-size:clamp(1.4rem,4vw,2.4rem);font-weight:700}.ploader__track{background:var(--gray-200);border-radius:1px;width:140px;height:1px;animation:.6s .45s both ploaderIn;overflow:hidden}.ploader__fill{background:var(--gradient-main);transform-origin:0;height:100%;animation:1.3s cubic-bezier(.4,0,.2,1) .55s both ploaderBar}@keyframes ploaderIn{0%{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}@keyframes ploaderBar{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.particle-background{pointer-events:none;z-index:0;width:100%;height:100%;position:fixed;top:0;left:0;-webkit-mask-image:linear-gradient(#000 60%,#0000 100%);mask-image:linear-gradient(#000 60%,#0000 100%)}.theme-transition-overlay{z-index:99999;pointer-events:none;background:var(--accent);opacity:.15;clip-path:circle(0% at var(--clip-x) var(--clip-y));transition:clip-path;position:fixed;inset:0}.theme-transition-overlay.expanding{clip-path:circle(150% at var(--clip-x) var(--clip-y));transition:clip-path .7s cubic-bezier(.16,1,.3,1)}.error-boundary{justify-content:center;align-items:center;min-height:60vh;padding:40px;display:flex}.error-boundary__inner{text-align:center;max-width:420px}.error-boundary__icon{opacity:.6;margin-bottom:20px;font-size:3rem}.error-boundary__title{font-family:var(--font-cn);color:var(--gray-900);margin-bottom:12px;font-size:1.5rem;font-weight:700}.error-boundary__msg{color:var(--gray-500);font-size:.875rem;font-family:var(--font-body);word-break:break-word;margin-bottom:28px;line-height:1.6}.error-boundary__btn{background:var(--accent);color:#fff;border-radius:var(--radius-full);font-size:.875rem;font-weight:600;font-family:var(--font-display);cursor:pointer;transition:all var(--t-base);align-items:center;padding:10px 28px;display:inline-flex}.error-boundary__btn:hover{background:var(--accent-dark);box-shadow:var(--shadow-accent);transform:translateY(-2px)}.hero{min-height:100vh;padding:var(--nav-height) 40px 0;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.hero__bg{z-index:0;position:absolute;inset:0;overflow:hidden}.hero__orb{filter:blur(120px);will-change:transform;border-radius:50%;animation:20s ease-in-out infinite orbFloat;position:absolute}.hero__orb--1{opacity:.6;background:radial-gradient(circle,#6366f1b3,#4f46e54d);width:900px;height:900px;animation-delay:0s;top:-25%;right:-15%}.hero__orb--2{opacity:.5;background:radial-gradient(circle,#8b5cf6b3,#7c3aed4d);width:650px;height:650px;animation-delay:-7s;bottom:-20%;left:-10%}.hero__orb--3{opacity:.4;background:radial-gradient(circle,#c084fc99,#a78bfa33);width:450px;height:450px;animation-delay:-14s;top:40%;left:30%}.hero__orb--4{opacity:.35;background:radial-gradient(circle,#818cf880,#6366f126);width:350px;height:350px;animation-duration:25s;animation-delay:-10s;bottom:30%;right:25%}@keyframes orbFloat{0%,to{transform:translate(0)scale(1)}25%{transform:translate(40px,-50px)scale(1.08)}50%{transform:translate(-30px,30px)scale(.95)}75%{transform:translate(20px,40px)scale(1.03)}}.hero__spotlight{z-index:3;pointer-events:none;transition:background .15s;position:absolute;inset:0}.hero__grid{background-image:linear-gradient(var(--grid-line) 1px, transparent 1px), linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);z-index:1;background-size:60px 60px;animation:8s ease-in-out infinite gridPulse;position:absolute;inset:0;-webkit-mask-image:radial-gradient(70% 70%,#000 20%,#0000 75%);mask-image:radial-gradient(70% 70%,#000 20%,#0000 75%)}@keyframes gridPulse{0%,to{opacity:1}50%{opacity:.7}}.hero__floating-elements{z-index:2;pointer-events:none;position:absolute;inset:0}.floating-element{color:var(--accent);opacity:.15;animation:15s ease-in-out infinite float;position:absolute}.floating-element svg{width:100%;height:100%}.floating-element--1{width:48px;height:48px;animation-delay:0s;top:15%;left:10%}.floating-element--2{width:36px;height:36px;animation-delay:-3s;top:25%;right:12%}.floating-element--3{width:42px;height:42px;animation-delay:-6s;bottom:30%;left:8%}.floating-element--4{width:32px;height:32px;animation-delay:-9s;bottom:20%;right:15%}.floating-element--5,.floating-element--6{font-family:var(--font-mono);color:var(--accent-light);font-size:1.2rem;font-weight:600}.floating-element--5{animation-delay:-5s;top:60%;right:8%}.floating-element--6{animation-delay:-12s;top:35%;left:5%}.code-snippet{opacity:.2}@keyframes float{0%,to{transform:translateY(0)rotate(0)}33%{transform:translateY(-20px)rotate(5deg)}66%{transform:translateY(10px)rotate(-3deg)}}.hero__ghost{font-family:var(--font-display);letter-spacing:-.04em;color:#0000;-webkit-text-stroke:1.5px var(--ghost-stroke);-webkit-user-select:none;user-select:none;pointer-events:none;z-index:2;white-space:nowrap;font-size:clamp(8rem,25vw,22rem);font-weight:900;animation:6s ease-in-out infinite ghostPulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes ghostPulse{0%,to{opacity:.5}50%{opacity:.8}}.hero__content{z-index:10;text-align:center;-webkit-user-select:none;user-select:none;max-width:900px;position:relative}.char-group{display:inline}.char-clip{vertical-align:bottom;margin-bottom:-.05em;padding-bottom:.05em;display:inline-block;overflow:hidden}.char{will-change:transform;transition:transform 1s cubic-bezier(.16,1,.3,1);display:inline-block;transform:translateY(105%)rotate(4deg)}.hero__content.loaded .char{transform:translateY(0)rotate(0)}.hero__badge{background:var(--badge-bg);border:1px solid var(--badge-border);border-radius:var(--radius-full);font-family:var(--font-display);color:var(--accent-light);letter-spacing:.06em;opacity:0;transition:opacity .8s var(--ease-out), transform .8s var(--ease-out);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);align-items:center;gap:10px;margin-bottom:28px;padding:8px 20px 8px 14px;font-size:.75rem;font-weight:500;display:inline-flex;transform:translateY(20px)}.hero__badge.show{opacity:1;transform:none}.hero__badge-dot{background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:50%;flex-shrink:0;width:8px;height:8px;animation:2s ease-in-out infinite pulse;box-shadow:0 0 12px #22c55e99}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.3)}}.hero__eyebrow{font-family:var(--font-display);letter-spacing:.18em;text-transform:uppercase;color:var(--gray-400);opacity:0;transition:opacity .7s var(--ease-out) 50ms, transform .7s var(--ease-out) 50ms;margin-bottom:16px;font-size:clamp(.85rem,1.5vw,1.1rem);font-weight:400;transform:translateY(16px)}.hero__eyebrow.show{opacity:1;transform:none}.hero__title-wrap{will-change:transform;flex-direction:column;align-items:center;margin-bottom:24px;transition:transform .3s ease-out;display:flex;position:relative}.hero__title{font-family:var(--font-display);letter-spacing:-.03em;line-height:1}.hero__title--en{margin-bottom:8px;font-size:clamp(5rem,18vw,16rem);font-style:italic;font-weight:800}.title-gradient{background:var(--gradient-text);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;display:inline-block;position:relative}.title-gradient:after{content:"";background:var(--gradient-main);filter:blur(60px);opacity:.3;z-index:-1;border-radius:50%;animation:4s ease-in-out infinite titleGlow;position:absolute;inset:-10px}@keyframes titleGlow{0%,to{opacity:.25;transform:scale(1)}50%{opacity:.4;transform:scale(1.1)}}.hero__title--cn{font-family:var(--font-cn);color:var(--cn-name-color);letter-spacing:.1em;font-size:clamp(1.8rem,6vw,5rem);font-style:normal;font-weight:800}.hero__title--cn .char-clip{letter-spacing:inherit}.hero__dynamic-sub{opacity:0;transition:opacity .8s var(--ease-out) .4s, transform .8s var(--ease-out) .4s;min-height:28px;margin-bottom:20px;transform:translateY(20px)}.hero__dynamic-sub.show{opacity:1;transform:none}.hero__typewriter{font-family:var(--font-body);color:var(--gray-500);letter-spacing:.05em;font-size:clamp(.9rem,1.6vw,1.1rem);font-weight:400}.typewriter-cursor{color:var(--accent);margin-left:2px;animation:1s step-end infinite cursorBlink;display:inline-block}@keyframes cursorBlink{0%,to{opacity:1}50%{opacity:0}}.hero__skill-tags{flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:28px;display:flex}.skill-tag{background:var(--gradient-subtle);border:1px solid var(--card-border);border-radius:var(--radius-full);font-family:var(--font-display);color:var(--gray-600);letter-spacing:.05em;opacity:0;animation:tagPop .5s var(--ease-spring) forwards;padding:6px 16px;font-size:.75rem;font-weight:500;transform:translateY(10px)scale(.9)}@keyframes tagPop{to{opacity:1;transform:translateY(0)scale(1)}}.skill-tag:hover{border-color:var(--accent);color:var(--accent-light);box-shadow:0 0 20px var(--accent-glow);transition:all .3s var(--ease-out);transform:translateY(-2px)}.hero__rule{background:var(--gradient-main);width:0;height:1px;transition:width 1.2s var(--ease-out) .6s;opacity:.6;margin:0 auto 24px;position:relative}.hero__rule.show{width:clamp(80px,15vw,160px)}.hero__rule:before,.hero__rule:after{content:"";background:var(--accent);width:6px;height:6px;box-shadow:0 0 10px var(--accent);border-radius:50%;position:absolute;top:50%;transform:translateY(-50%)}.hero__rule:before{left:0}.hero__rule:after{right:0}.hero__stats{justify-content:center;gap:clamp(32px,6vw,64px);margin-bottom:36px;display:flex}.hero__stat{opacity:0;animation:statFadeIn .8s var(--ease-out) forwards;flex-direction:column;align-items:center;gap:6px;display:flex;transform:translateY(20px)}@keyframes statFadeIn{to{opacity:1;transform:translateY(0)}}.hero__stat-value{font-family:var(--font-display);background:var(--gradient-text);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:clamp(1.5rem,3vw,2.2rem);font-weight:700}.hero__stat-label{font-family:var(--font-cn);color:var(--gray-500);letter-spacing:.1em;font-size:.75rem}.hero__cta{opacity:0;transition:opacity .8s var(--ease-out) .6s, transform .8s var(--ease-out) .6s;justify-content:center;gap:16px;display:flex;transform:translateY(20px)}.hero__cta.show{opacity:1;transform:none}.hero__scroll{opacity:0;transition:opacity 1s var(--ease-out) 1.2s;flex-direction:column;align-items:center;gap:12px;display:flex;position:absolute;bottom:44px;left:50%;transform:translate(-50%)}.hero__scroll.show{opacity:1}.hero__scroll-line{background:linear-gradient(to bottom, transparent, var(--scroll-line), transparent);width:1px;height:56px;animation:2s ease-in-out infinite scrollPulse;position:relative}.hero__scroll-line:after{content:"";background:var(--accent);border-radius:50%;width:4px;height:4px;animation:2s ease-in-out infinite scrollDot;position:absolute;top:0;left:50%;transform:translate(-50%)}@keyframes scrollPulse{0%,to{opacity:.3}50%{opacity:.8}}@keyframes scrollDot{0%{opacity:1;top:0}to{opacity:0;top:100%}}.hero__scroll span{font-family:var(--font-display);letter-spacing:.3em;text-transform:uppercase;color:var(--gray-400);font-size:.65rem}.hero__corner{border:1px solid var(--card-border);opacity:.5;z-index:5;width:40px;height:40px;position:absolute}.hero__corner--tl{border-bottom:none;border-right:none;top:100px;left:40px}.hero__corner--tr{border-bottom:none;border-left:none;top:100px;right:40px}.hero__corner--bl{border-top:none;border-right:none;bottom:100px;left:40px}.hero__corner--br{border-top:none;border-left:none;bottom:100px;right:40px}@media (width<=768px){.hero{padding:var(--nav-height) 20px 0}.hero__ghost{display:none}.hero__cta{flex-direction:column;align-items:center}.hero__title--en{font-size:clamp(4rem,20vw,7rem)}.hero__title--cn{font-size:clamp(1.4rem,8vw,2.5rem)}.hero__orb{filter:blur(80px)}.hero__stats{gap:24px}.hero__skill-tags{gap:8px}.skill-tag{padding:5px 12px;font-size:.7rem}.hero__corner,.floating-element{display:none}}@media (width<=480px){.hero__title--en{font-size:clamp(3.5rem,18vw,5rem)}.hero__typewriter{font-size:.8rem}}.magnetic-button{will-change:transform;justify-content:center;align-items:center;transition:transform .3s cubic-bezier(.16,1,.3,1);display:inline-flex;position:relative}.magnetic-button__text{will-change:transform;align-items:center;gap:8px;transition:transform .3s cubic-bezier(.16,1,.3,1);display:inline-flex}.magnetic-button{border-radius:var(--radius-full);font-family:var(--font-cn);color:inherit;cursor:none;background:0 0;border:none;padding:14px 32px;font-size:.88rem;font-weight:500;text-decoration:none}.magnetic-button--primary{background:var(--gradient-main);color:#fff;box-shadow:0 0 40px #818cf859}.magnetic-button--primary:hover{box-shadow:0 0 70px #818cf88c}.magnetic-button--ghost{border:1px solid var(--btn-ghost-border);color:var(--gray-500);background:var(--btn-ghost-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.magnetic-button--ghost:hover{color:var(--accent-light);border-color:#818cf866;box-shadow:0 0 30px #818cf826}.magnetic-button--circle{background:var(--card-bg);border:1px solid var(--card-border);border-radius:50%;width:56px;height:56px;padding:0}.magnetic-button--circle:hover{border-color:var(--accent);box-shadow:0 0 30px var(--accent-glow)}@media (width<=768px){.magnetic-button{cursor:pointer}}.marquee{border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle);background:var(--marquee-bg);padding:40px 0;position:relative;overflow:hidden}.marquee:after{content:"";background:var(--gradient-main);filter:blur(1px);z-index:2;pointer-events:none;width:200px;height:1px;position:absolute;top:0;left:50%;transform:translate(-50%);box-shadow:0 0 20px #818cf866}.marquee__fade-left,.marquee__fade-right{z-index:1;pointer-events:none;width:120px;position:absolute;top:0;bottom:0}.marquee__fade-left{background:linear-gradient(to right, var(--marquee-fade), transparent);left:0}.marquee__fade-right{background:linear-gradient(to left, var(--marquee-fade), transparent);right:0}.marquee__track{width:100%;overflow:hidden}.marquee__inner{gap:0;width:max-content;animation:28s linear infinite marqueeScroll;display:flex}.marquee__inner:hover{animation-play-state:paused}.marquee__item{font-family:var(--font-display);color:var(--gray-300);white-space:nowrap;letter-spacing:.04em;padding:0 28px;font-size:clamp(1rem,2.2vw,1.35rem);font-weight:600;transition:color .4s}.marquee__item:hover{color:var(--accent-light)}.marquee__item.dot{color:#818cf840;vertical-align:middle;padding:0 16px;font-size:.5rem}@keyframes marqueeScroll{0%{transform:translate(0)}to{transform:translate(-25%)}}.skills{padding:var(--section-padding) 0;position:relative}.skills:before{content:"";background:linear-gradient(#0000,#818cf84d,#0000);width:1px;height:80px;position:absolute;top:0;left:50%;transform:translate(-50%)}.skills__inner{max-width:1140px;margin:0 auto;padding:0 40px}.skills__heading{margin-bottom:64px}.skills__grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.skill-card-wrap{opacity:0;transition:opacity .9s var(--ease-out), transform .9s var(--ease-out)}.skill-card-wrap:first-child{transform:translate(-60px)translateY(40px)scale(.9)}.skill-card-wrap:nth-child(2){transform:translateY(70px)scale(.88)}.skill-card-wrap:nth-child(3){transform:translate(60px)translateY(40px)scale(.9)}.skill-card-wrap.visible{opacity:1;transform:none}.skill-card{border-radius:var(--radius-lg);transition:transform var(--t-base), box-shadow var(--t-base);will-change:transform;height:100%;position:relative;overflow:hidden}.skill-card:hover{box-shadow:0 20px 60px #0009, var(--shadow-accent)}.skill-card__border{border-radius:var(--radius-lg);background:var(--gray-200);-webkit-mask-composite:xor;transition:background .5s var(--ease-out);pointer-events:none;padding:1px;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;mask-position:0 0,0 0;-webkit-mask-size:auto,auto;mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.skill-card:hover .skill-card__border{background:var(--gradient-main)}.skill-card__content{background:var(--card-bg);border-radius:var(--radius-lg);z-index:1;height:100%;padding:36px 32px;position:relative;overflow:hidden}.skill-card__content:before{content:"";background:var(--accent);filter:blur(60px);opacity:0;width:180px;height:180px;transition:opacity .6s var(--ease-out);pointer-events:none;border-radius:50%;position:absolute;top:-60px;left:50%;transform:translate(-50%)}.skill-card:hover .skill-card__content:before{opacity:.06}.skill-card__content:after{content:"";background:var(--shine-color);transition:transform .7s var(--ease-out);pointer-events:none;position:absolute;inset:0;transform:translate(-100%)}.skill-card:hover .skill-card__content:after{transform:translate(100%)}.skill-card__header{justify-content:space-between;align-items:flex-start;margin-bottom:22px;display:flex}.skill-card__icon{font-size:1.8rem;line-height:1}.skill-card__arrow{width:36px;height:36px;color:var(--gray-400);border:1px solid var(--gray-200);transition:all var(--t-base);border-radius:50%;justify-content:center;align-items:center;font-size:1rem;display:flex}.skill-card:hover .skill-card__arrow{color:var(--accent-light);background:var(--accent-glow);border-color:#818cf84d;transform:translate(2px,-2px)}.skill-card__title{font-family:var(--font-cn);color:var(--gray-900);margin-bottom:12px;font-size:1.15rem;font-weight:700}.skill-card__desc{color:var(--gray-500);font-size:.85rem;line-height:1.75;font-family:var(--font-cn);margin-bottom:28px}.skill-card__stats{border-top:1px solid var(--border-subtle);gap:20px;padding-top:20px;display:flex}.skill-stat{flex-direction:column;gap:3px;display:flex}.skill-stat__value{font-family:var(--font-display);font-variant-numeric:tabular-nums;background:var(--gradient-text);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:700;line-height:1}.skill-stat__label{color:var(--gray-400);font-size:.7rem;font-family:var(--font-cn)}@media (width<=900px){.skills__grid{grid-template-columns:1fr;max-width:480px;margin:0 auto}.skill-card-wrap:first-child,.skill-card-wrap:nth-child(2),.skill-card-wrap:nth-child(3){transform:translateY(50px)scale(.92)}}@media (width<=768px){.skills__inner{padding:0 20px}.skills:before{display:none}}.projects{padding:var(--section-padding) 0;background:var(--gray-50);position:relative}.projects:before{content:"";background:linear-gradient(90deg,#0000,#818cf826,#0000);height:1px;position:absolute;top:0;left:0;right:0}.projects__inner{max-width:1140px;margin:0 auto;padding:0 40px}.projects__heading{margin-bottom:64px}.projects__grid{grid-template-columns:repeat(2,1fr);gap:24px;display:grid}.project-card-wrap{opacity:0;transition:opacity .9s var(--ease-out), transform .9s var(--ease-out)}.projects__more{justify-content:center;margin-top:48px;display:flex}.projects__more-btn{font-family:var(--font-cn);color:var(--gray-600);border:1px solid var(--contact-btn-border);border-radius:var(--radius-full);transition:all var(--t-fast);align-items:center;gap:8px;padding:12px 28px;font-size:.85rem;font-weight:500;display:inline-flex}.projects__more-btn:hover{border-color:var(--accent);color:var(--accent-light);gap:14px;box-shadow:0 0 20px #818cf833}@media (width<=900px){.projects__grid{grid-template-columns:1fr}.project-card-wrap:nth-child(odd),.project-card-wrap:nth-child(2n){transform:translateY(50px)scale(.94)}}@media (width<=768px){.projects__inner{padding:0 20px}}.about{padding:var(--section-padding) 0;position:relative}.toast{background:var(--gray-900);color:var(--white);font-family:var(--font-cn);border-radius:var(--radius-full);z-index:10001;box-shadow:var(--shadow-lg);animation:toastIn .3s var(--ease-spring), toastOut .3s ease 1.7s forwards;pointer-events:none;padding:10px 24px;font-size:.82rem;font-weight:500;position:fixed;top:80px;left:50%;transform:translate(-50%)}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(-10px)scale(.95)}to{opacity:1;transform:translate(-50%)translateY(0)scale(1)}}@keyframes toastOut{0%{opacity:1;transform:translate(-50%)translateY(0)scale(1)}to{opacity:0;transform:translate(-50%)translateY(-10px)scale(.95)}}.about__inner{grid-template-rows:auto 1fr;grid-template-columns:1fr 1fr;align-items:start;gap:40px;max-width:1100px;margin:0 auto;padding:0 40px;display:grid}.about__logo-container{grid-column:1/-1;justify-content:center;align-items:center;display:flex}.about__logo{flex-direction:column;justify-content:center;align-items:center;gap:8px;width:120px;height:120px;display:flex}.about__logo-title{font-family:var(--font-cn);color:var(--gray-900);font-size:1.6rem;font-weight:500}.about__logo img{object-fit:contain;width:100%;height:100%}.about__left{opacity:0;width:90%;transition:opacity .9s var(--ease-out), transform .9s var(--ease-out);transform:translate(-50px)translateY(20px)}.about__left.visible{opacity:1;transform:none}.about__bio{font-family:var(--font-cn);color:var(--gray-600);margin-bottom:32px;font-size:.95rem;line-height:1.9}.about__meta{flex-direction:column;gap:12px;margin-bottom:28px;display:flex}.about__meta-item{align-items:center;gap:12px;display:flex}.about__meta-label{color:var(--gray-400);min-width:60px;font-size:.82rem}.about__meta-value{color:var(--gray-700);font-size:.85rem;font-family:var(--font-cn);font-weight:500}.about__tags{flex-wrap:wrap;gap:8px;display:flex}.about__tag{font-family:var(--font-display);color:var(--gray-500);border:1px solid var(--gray-200);border-radius:var(--radius-full);transition:all var(--t-fast);padding:6px 14px;font-size:.72rem;font-weight:500}.about__tag:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}.about__right{opacity:0;transition:opacity .9s var(--ease-out) .15s, transform .9s var(--ease-out) .15s;transform:translate(50px)translateY(20px)}.about__right.visible{opacity:1;transform:none}.contact-card{background:var(--white);border:1px solid var(--gray-100);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);transition:border-color var(--t-base), box-shadow var(--t-base);padding:32px}.contact-card:focus-within{border-color:var(--accent);box-shadow:var(--shadow-accent)}.contact-card__header{margin-bottom:24px}.contact-card__title{font-family:var(--font-cn);color:var(--gray-900);margin-bottom:4px;font-size:1.1rem;font-weight:700}.contact-card__subtitle{color:var(--gray-400);font-size:.82rem;font-family:var(--font-cn)}.contact-form{flex-direction:column;gap:18px;display:flex}.contact-field{flex-direction:column;gap:6px;display:flex}.contact-field label{color:var(--gray-400);font-size:.72rem;font-weight:500;font-family:var(--font-cn);letter-spacing:.04em;transition:color var(--t-fast)}.contact-field.focused label{color:var(--accent)}.contact-field input,.contact-field textarea{background:var(--input-bg);border-radius:var(--radius-md);font-size:.85rem;font-family:var(--font-cn);color:var(--gray-900);transition:all var(--t-fast);resize:none;border:1px solid #0000;outline:none;padding:10px 14px}.contact-field input:focus,.contact-field textarea:focus{border-color:var(--accent);background:var(--input-focus-bg);box-shadow:0 0 0 3px var(--accent-glow)}.contact-field input::placeholder,.contact-field textarea::placeholder{color:var(--gray-300)}.contact-submit{background:var(--gradient-main);color:#fff;border-radius:var(--radius-full);font-size:.85rem;font-family:var(--font-cn);cursor:pointer;transition:all var(--t-base);box-shadow:var(--shadow-accent);border:none;justify-content:center;align-self:flex-start;align-items:center;gap:8px;margin-top:4px;padding:12px 28px;font-weight:500;display:inline-flex}.contact-submit:hover{box-shadow:var(--shadow-accent-lg);transform:translateY(-2px)}.contact-submit.sent{background:#16a34a;box-shadow:0 4px 20px #16a34a40}.about__socials{gap:10px;margin-top:20px;display:flex}.social-link{border:1px solid var(--gray-100);border-radius:var(--radius-full);color:var(--gray-500);transition:all var(--t-fast);align-items:center;gap:8px;padding:10px 18px;font-size:.8rem;font-weight:500;display:flex}.social-link:hover{color:var(--accent-light);border-color:#818cf859;transform:translateY(-3px);box-shadow:0 0 24px #818cf826}.social-link__icon{font-size:.9rem}@media (width<=900px){.about__inner{grid-template-columns:1fr;gap:48px}}@media (width<=768px){.about__inner{padding:0 20px}.about__socials{flex-wrap:wrap}}.blog-page{padding:calc(var(--nav-height) + var(--section-padding)) 0 var(--section-padding);background:var(--body-bg);min-height:100vh}.blog-page__inner{max-width:1140px;margin:0 auto;padding:0 40px}.blog-page__heading{margin-bottom:64px}.blog-page__sections{flex-direction:column;gap:48px;display:flex}.blog-page__section{opacity:0;animation:.6s forwards fadeInUp;transform:translateY(20px)}.blog-page__section:first-child{animation-delay:.1s}.blog-page__section:nth-child(2){animation-delay:.2s}.blog-page__section:nth-child(3){animation-delay:.3s}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}.blog-page__section-title{font-family:var(--font-display);color:var(--gray-800);border-radius:var(--radius-lg);transition:all var(--t-base);background:linear-gradient(135deg,#6366f114,#8b5cf614);border:1px solid #6366f126;align-items:center;gap:10px;margin-bottom:24px;padding:8px 20px;font-size:1.15rem;font-weight:700;display:inline-flex}.blog-page__section-title:hover{background:linear-gradient(135deg,#6366f11f,#8b5cf61f);border-color:#6366f140;transform:translate(4px)}.blog-page__section-count{color:var(--accent);border-radius:var(--radius-full);text-align:center;background:#6366f11f;min-width:28px;padding:4px 12px;font-size:.75rem;font-weight:600}.blog-page__grid{grid-template-columns:repeat(2,1fr);gap:28px;display:grid}.blog-card{background:var(--card-bg);border-radius:var(--radius-lg);border:1px solid var(--card-border);transition:transform var(--t-base), box-shadow var(--t-base), border-color var(--t-base);opacity:0;cursor:pointer;flex-direction:column;display:flex;overflow:hidden;transform:translateY(40px)scale(.96)}.blog-card.visible{opacity:1;transform:none}.blog-card:hover{box-shadow:var(--shadow-xl), 0 0 60px #818cf81f;border-color:#818cf833;transform:translateY(-4px)}.blog-card__cover{flex-shrink:0;height:180px;position:relative;overflow:hidden}.blog-card__cover-overlay{background:var(--preview-overlay);position:absolute;inset:0}.blog-card__read-time{font-family:var(--font-display);color:#ffffffd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-full);z-index:1;background:#ffffff1f;border:1px solid #ffffff1f;padding:4px 12px;font-size:.68rem;font-weight:500;position:absolute;top:14px;right:14px}.blog-card__body{flex-direction:column;flex:1;padding:24px;display:flex}.blog-card__meta{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.blog-card__date{font-family:var(--font-display);color:var(--gray-500);font-size:.72rem}.blog-card__tags{gap:6px;display:flex}.blog-card__tag{font-family:var(--font-display);color:var(--gray-500);background:var(--gray-100);border:1px solid var(--gray-200);border-radius:var(--radius-full);letter-spacing:.03em;transition:all var(--t-fast);padding:3px 10px;font-size:.6rem;font-weight:500}.blog-card:hover .blog-card__tag{background:var(--accent-glow);color:var(--accent-light);border-color:#818cf840}.blog-card__title{font-family:var(--font-cn);color:var(--gray-900);margin-bottom:10px;font-size:1.1rem;font-weight:700;line-height:1.45}.blog-card__excerpt{color:var(--gray-500);font-size:.82rem;line-height:1.75;font-family:var(--font-cn);-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:1;display:-webkit-box;overflow:hidden}.blog-card__link{font-family:var(--font-cn);color:var(--gray-400);border-top:1px solid var(--border-subtle);transition:all var(--t-fast);align-items:center;gap:7px;margin-top:16px;padding-top:16px;font-size:.8rem;font-weight:500;display:inline-flex}.blog-card:hover .blog-card__link{color:var(--accent-light);gap:12px}.blog-page__loading,.blog-page__error,.blog-page__empty{text-align:center;padding:80px 0}.blog-page__loading p,.blog-page__error p,.blog-page__empty p{color:var(--gray-500);font-size:.9rem;font-family:var(--font-cn)}.blog-page__spinner{border:2px solid var(--gray-200);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;margin:0 auto 16px;animation:.8s linear infinite blog-spin}@keyframes blog-spin{to{transform:rotate(360deg)}}.blog-page__error p{color:#ef4444}.blog-page__toc-toggle{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);cursor:pointer;z-index:100;width:48px;height:48px;transition:all var(--t-base);color:var(--gray-600);box-shadow:var(--shadow-lg);justify-content:center;align-items:center;display:flex;position:fixed;top:50%;left:20px;transform:translateY(-50%)}.blog-page__toc-toggle:hover{background:var(--accent);color:#fff;border-color:var(--accent);transform:translateY(-50%)scale(1.05)}.blog-page__toc-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#0006;animation:.2s tocFadeIn;position:fixed;inset:0}@keyframes tocFadeIn{0%{opacity:0}to{opacity:1}}.blog-page__toc-wrapper{z-index:201;gap:8px;display:flex;position:fixed;top:50%;left:80px;transform:translateY(-50%)}.blog-page__toc{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-xl);min-width:240px;box-shadow:var(--shadow-xl);padding:20px;transition:width .3s cubic-bezier(.16,1,.3,1);animation:.3s cubic-bezier(.16,1,.3,1) tocSlideIn}.blog-page__toc--shrink{min-width:200px}@keyframes tocSlideIn{0%{opacity:0;transform:translateY(-50%)translate(20px)}to{opacity:1;transform:translateY(-50%)translate(0)}}.blog-page__toc-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;display:flex}.blog-page__toc-header span{font-family:var(--font-display);color:var(--gray-800);font-size:1rem;font-weight:700}.blog-page__toc-close{background:var(--gray-100);border-radius:var(--radius-md);cursor:pointer;width:28px;height:28px;color:var(--gray-500);transition:all var(--t-fast);border:none;justify-content:center;align-items:center;display:flex}.blog-page__toc-close:hover{background:var(--gray-200);color:var(--gray-700)}.blog-page__toc-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.blog-page__toc-list li{background:var(--gray-50);border-radius:var(--radius-lg);cursor:pointer;font-family:var(--font-cn);color:var(--gray-700);transition:all var(--t-fast);justify-content:space-between;align-items:center;padding:12px 16px;font-size:.9rem;font-weight:500;display:flex}.blog-page__toc-list li:hover{color:var(--accent);background:linear-gradient(135deg,#6366f11a,#8b5cf61a);transform:translate(4px)}.blog-page__toc-list li.active{color:var(--accent);border-left:3px solid var(--accent);background:linear-gradient(135deg,#6366f126,#8b5cf626)}.blog-page__toc-arrow{color:var(--gray-400);transition:all var(--t-fast)}.blog-page__toc-list li:hover .blog-page__toc-arrow,.blog-page__toc-list li.active .blog-page__toc-arrow{color:var(--accent);transform:translate(4px)}.blog-page__toc-count{color:var(--accent);border-radius:var(--radius-full);background:#6366f11f;margin-right:8px;padding:2px 10px;font-size:.75rem;font-weight:600}.blog-page__toc-sub{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-xl);min-width:280px;max-height:400px;box-shadow:var(--shadow-xl);padding:20px;animation:.3s cubic-bezier(.16,1,.3,1) tocSubSlideIn;overflow-y:auto}@keyframes tocSubSlideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.blog-page__toc-sub-header{border-bottom:1px solid var(--border-subtle);align-items:center;gap:10px;margin-bottom:16px;padding-bottom:12px;display:flex}.blog-page__toc-sub-back{background:var(--gray-100);border-radius:var(--radius-md);cursor:pointer;width:28px;height:28px;color:var(--gray-500);transition:all var(--t-fast);border:none;justify-content:center;align-items:center;display:flex}.blog-page__toc-sub-back:hover{background:var(--gray-200);color:var(--gray-700);transform:translate(-2px)}.blog-page__toc-sub-header span{font-family:var(--font-display);color:var(--gray-800);font-size:.95rem;font-weight:700}.blog-page__toc-sub-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.blog-page__toc-sub-list li{border-radius:var(--radius-lg);cursor:pointer;font-family:var(--font-cn);color:var(--gray-600);transition:all var(--t-fast);align-items:center;gap:12px;padding:10px 14px;font-size:.85rem;display:flex}.blog-page__toc-sub-list li:hover{color:var(--accent);background:linear-gradient(135deg,#6366f114,#8b5cf614);transform:translate(6px)}.blog-page__toc-sub-index{font-family:var(--font-display);color:var(--gray-400);background:var(--gray-100);border-radius:var(--radius-full);text-align:center;flex-shrink:0;min-width:24px;padding:2px 8px;font-size:.7rem;font-weight:600}.blog-page__toc-sub-list li:hover .blog-page__toc-sub-index{color:var(--accent);background:#6366f126}.blog-page__toc-sub-title{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.blog-page__back-to-top{background:var(--accent);color:#fff;border-radius:var(--radius-full);cursor:pointer;z-index:100;width:48px;height:48px;transition:all var(--t-base);border:none;justify-content:center;align-items:center;animation:.3s backToTopFadeIn;display:flex;position:fixed;bottom:32px;right:32px;box-shadow:0 4px 20px #6366f166}@keyframes backToTopFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.blog-page__back-to-top:hover{background:var(--accent-hover);transform:translateY(-4px);box-shadow:0 8px 30px #6366f180}.blog-page__back-to-top:active{transform:translateY(-2px)}.blog-page__search-wrap{margin-bottom:40px}.blog-page__search{align-items:center;max-width:480px;display:flex;position:relative}.blog-page__search-icon{color:var(--gray-500);pointer-events:none;flex-shrink:0;position:absolute;left:16px}.blog-page__search-input{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-full);width:100%;height:48px;font-family:var(--font-cn);color:var(--gray-800);transition:border-color var(--t-fast), box-shadow var(--t-fast);outline:none;padding:0 44px 0 48px;font-size:.9rem}.blog-page__search-input::placeholder{color:var(--gray-400)}.blog-page__search-input:focus{border-color:#818cf880;box-shadow:0 0 0 3px #818cf81a}.blog-page__search-clear{background:var(--gray-100);border-radius:var(--radius-full);cursor:pointer;width:28px;height:28px;color:var(--gray-500);transition:all var(--t-fast);justify-content:center;align-items:center;display:flex;position:absolute;right:14px}.blog-page__search-clear:hover{background:var(--gray-200);color:var(--gray-700)}.blog-page__search-result{font-family:var(--font-cn);color:var(--gray-500);margin-top:10px;font-size:.82rem}.blog-page__search-result strong{color:var(--accent-light)}@keyframes blog-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.blog-page__skeleton-grid{grid-template-columns:repeat(2,1fr);gap:28px;margin-bottom:40px;display:grid}.blog-card-skeleton{background:var(--card-bg);border-radius:var(--radius-lg);border:1px solid var(--card-border);opacity:0;animation:.4s forwards skFadeIn;overflow:hidden}@keyframes skFadeIn{to{opacity:1}}.sk-cover{background:linear-gradient(90deg, var(--gray-100) 25%, var(--gray-200) 50%, var(--gray-100) 75%);background-size:200% 100%;height:180px;animation:1.5s infinite blog-shimmer}.sk-body{flex-direction:column;gap:10px;padding:24px;display:flex}.sk-line{background:linear-gradient(90deg, var(--gray-100) 25%, var(--gray-200) 50%, var(--gray-100) 75%);background-size:200% 100%;border-radius:4px;height:14px;animation:1.5s infinite blog-shimmer}.sk-line--meta{width:45%;height:12px}.sk-line--title{width:90%;height:18px}.sk-line--title-short{width:65%;height:18px}.sk-line--excerpt{width:100%}.sk-line--excerpt-short{width:75%}@media (width<=900px){.blog-page__grid,.blog-page__skeleton-grid{grid-template-columns:1fr}}@media (width<=768px){.blog-page__inner{padding:0 20px}.blog-page__toc-toggle{width:40px;height:40px;left:12px}.blog-page__toc{min-width:200px;left:60px}.blog-page__back-to-top{width:44px;height:44px;bottom:24px;right:24px}}pre code.hljs{padding:1em;display:block;overflow-x:auto}code.hljs{padding:3px 5px}.hljs{color:#abb2bf;background:#282c34}.hljs-comment,.hljs-quote{color:#5c6370;font-style:italic}.hljs-doctag,.hljs-keyword,.hljs-formula{color:#c678dd}.hljs-section,.hljs-name,.hljs-selector-tag,.hljs-deletion,.hljs-subst{color:#e06c75}.hljs-literal{color:#56b6c2}.hljs-string,.hljs-regexp,.hljs-addition,.hljs-attribute,.hljs-meta .hljs-string{color:#98c379}.hljs-attr,.hljs-variable,.hljs-template-variable,.hljs-type,.hljs-selector-class,.hljs-selector-attr,.hljs-selector-pseudo,.hljs-number{color:#d19a66}.hljs-symbol,.hljs-bullet,.hljs-link,.hljs-meta,.hljs-selector-id,.hljs-title{color:#61aeee}.hljs-built_in,.hljs-title.class_,.hljs-class .hljs-title{color:#e6c07b}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}.hljs-link{text-decoration:underline}.blog-post-page{padding:calc(var(--nav-height) + 60px) 0 var(--section-padding);background:var(--body-bg);min-height:100vh}.blog-post-page__inner{opacity:0;max-width:780px;transition:opacity .7s var(--ease-out), transform .7s var(--ease-out);margin:0 auto;padding:0 40px;transform:translateY(30px)}.blog-post-page__inner.visible{opacity:1;transform:none}.blog-post-read-progress{top:var(--nav-height);background:linear-gradient(90deg, var(--accent) 0%, #a78bfa 50%, #c084fc 100%);transform-origin:0;z-index:9999;opacity:.7;height:2px;position:fixed;left:0;right:0;transform:scaleX(0)}.blog-post-back{font-family:var(--font-cn);color:var(--gray-500);transition:color var(--t-fast);align-items:center;gap:6px;margin-bottom:40px;font-size:.82rem;display:inline-flex}.blog-post-back:hover{color:var(--accent-light)}.blog-post-not-found{text-align:center;padding:120px 0}.blog-post-not-found h2{font-family:var(--font-cn);color:var(--gray-900);margin-bottom:12px;font-size:1.5rem;font-weight:700}.blog-post-not-found p{color:var(--gray-500);margin-bottom:24px;font-size:.9rem}.blog-post-header{margin-bottom:48px}.blog-post-header__tags{gap:8px;margin-bottom:20px;display:flex}.blog-post-header__tag{font-family:var(--font-display);color:var(--accent-light);background:var(--accent-glow);border-radius:var(--radius-full);letter-spacing:.03em;border:1px solid #818cf840;padding:4px 14px;font-size:.68rem;font-weight:500}.blog-post-header__title{font-family:var(--font-cn);color:var(--gray-900);margin-bottom:20px;font-size:clamp(2rem,5vw,3rem);font-weight:800;line-height:1.25}.blog-post-header__meta{color:var(--gray-500);font-size:.82rem;font-family:var(--font-display);flex-wrap:wrap;align-items:center;gap:10px;display:flex}.blog-post-content{font-family:var(--font-cn);color:var(--gray-700);font-size:.95rem;line-height:1.9}.blog-post-content h2{font-family:var(--font-cn);color:var(--gray-900);border-bottom:1px solid var(--border-subtle);margin:48px 0 20px;padding-bottom:12px;scroll-margin-top:90px;font-size:1.5rem;font-weight:700}.blog-post-content h3{font-family:var(--font-cn);color:var(--gray-900);margin:36px 0 16px;scroll-margin-top:90px;font-size:1.2rem;font-weight:600}.blog-post-content p{margin-bottom:18px}.blog-post-content ul,.blog-post-content ol{margin-bottom:18px;padding-left:24px}.blog-post-content li{margin-bottom:8px}.blog-post-content code{background:var(--gray-100);color:var(--accent-light);border-radius:4px;padding:2px 8px;font-family:JetBrains Mono,Fira Code,monospace;font-size:.85em}.code-block{border-radius:var(--radius-md);border:1px solid var(--card-border);margin-bottom:24px;overflow:hidden}.code-block__header{background:var(--gray-50);border-bottom:1px solid var(--card-border);justify-content:space-between;align-items:center;padding:8px 16px;display:flex}.code-block__lang{color:var(--accent-light);letter-spacing:.05em;text-transform:uppercase;font-family:JetBrains Mono,Fira Code,monospace;font-size:.72rem;font-weight:600}.code-block__copy{font-family:var(--font-display);color:var(--gray-500);background:var(--gray-100);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--t-fast);white-space:nowrap;align-items:center;gap:5px;padding:4px 10px;font-size:.72rem;font-weight:500;display:inline-flex}.code-block__copy:hover{color:var(--accent-light);background:var(--accent-glow)}.code-block__pre{background:var(--black-2);margin:0;padding:20px 24px;overflow-x:auto}.code-block__pre code{color:var(--gray-800);background:0 0;padding:0;font-size:.82rem;line-height:1.7}.code-block__pre code.hljs{background:0 0;padding:0;font-size:.82rem;line-height:1.7}[data-theme=dark] .hljs{color:#24292e}[data-theme=dark] .hljs-doctag,[data-theme=dark] .hljs-keyword,[data-theme=dark] .hljs-meta .hljs-keyword,[data-theme=dark] .hljs-template-tag,[data-theme=dark] .hljs-template-variable,[data-theme=dark] .hljs-type,[data-theme=dark] .hljs-variable.language_{color:#d73a49}[data-theme=dark] .hljs-title,[data-theme=dark] .hljs-title.class_,[data-theme=dark] .hljs-title.class_.inherited__,[data-theme=dark] .hljs-title.function_{color:#6f42c1}[data-theme=dark] .hljs-attr,[data-theme=dark] .hljs-attribute,[data-theme=dark] .hljs-literal,[data-theme=dark] .hljs-meta,[data-theme=dark] .hljs-number,[data-theme=dark] .hljs-operator,[data-theme=dark] .hljs-variable,[data-theme=dark] .hljs-selector-attr,[data-theme=dark] .hljs-selector-class,[data-theme=dark] .hljs-selector-id{color:#005cc5}[data-theme=dark] .hljs-regexp,[data-theme=dark] .hljs-string,[data-theme=dark] .hljs-meta .hljs-string{color:#032f62}[data-theme=dark] .hljs-built_in,[data-theme=dark] .hljs-symbol{color:#e36209}[data-theme=dark] .hljs-comment,[data-theme=dark] .hljs-code,[data-theme=dark] .hljs-formula{color:#6a737d}[data-theme=dark] .hljs-name,[data-theme=dark] .hljs-quote,[data-theme=dark] .hljs-selector-tag,[data-theme=dark] .hljs-selector-pseudo{color:#22863a}[data-theme=dark] .hljs-subst{color:#24292e}[data-theme=dark] .hljs-section{color:#005cc5;font-weight:700}[data-theme=dark] .hljs-bullet{color:#735c0f}[data-theme=dark] .hljs-emphasis{color:#24292e;font-style:italic}[data-theme=dark] .hljs-strong{color:#24292e;font-weight:700}[data-theme=dark] .hljs-addition{color:#22863a;background-color:#f0fff4}[data-theme=dark] .hljs-deletion{color:#b31d28;background-color:#ffeef0}.blog-post-content blockquote{border-left:3px solid var(--accent);background:var(--accent-glow);border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--gray-600);margin-bottom:24px;padding:12px 20px;font-style:italic}.blog-post-content table{border-collapse:collapse;width:100%;margin-bottom:24px}.blog-post-content th,.blog-post-content td{text-align:left;border-bottom:1px solid var(--border-subtle);padding:12px 16px;font-size:.88rem}.blog-post-content th{color:var(--gray-900);background:var(--gray-100);font-weight:600}.blog-post-content a{color:var(--accent-light);text-underline-offset:3px;transition:color var(--t-fast);text-decoration:underline}.blog-post-content a:hover{color:var(--accent)}.blog-post-content hr{background:var(--border-subtle);border:none;height:1px;margin:36px 0}.blog-post-img{border-radius:var(--radius-md);cursor:zoom-in;max-width:100%;transition:transform var(--t-base), box-shadow var(--t-base);margin:24px 0;display:block}.blog-post-img:hover{box-shadow:var(--shadow-lg);transform:scale(1.01)}.blog-post-img-skeleton{background:linear-gradient(90deg, var(--gray-100) 25%, var(--gray-200) 50%, var(--gray-100) 75%);border-radius:var(--radius-md);background-size:200% 100%;width:100%;height:240px;margin:24px 0;animation:1.5s infinite bp-shimmer;display:block}.blog-post-img-error{color:var(--gray-400);font-size:.8rem;font-family:var(--font-display);align-items:center;gap:8px;margin:16px 0;font-style:italic;display:inline-flex}.blog-post-img-error__text{font-style:italic}.blog-post-img-error__retry{font-size:.75rem;font-style:normal;font-family:var(--font-display);color:var(--accent-light);border:1px solid var(--accent-light);cursor:pointer;transition:background var(--t-fast), color var(--t-fast);white-space:nowrap;background:0 0;border-radius:4px;align-items:center;gap:4px;padding:2px 8px;display:inline-flex}.blog-post-img-error__retry:hover{background:var(--accent-light);color:#fff}.lightbox{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:10000;cursor:zoom-out;background:#000000e6;justify-content:center;align-items:center;animation:.2s lightboxFadeIn;display:flex;position:fixed;inset:0}@keyframes lightboxFadeIn{0%{opacity:0}to{opacity:1}}.lightbox__close{border-radius:var(--radius-full);color:#fffc;cursor:pointer;width:44px;height:44px;transition:all var(--t-fast);z-index:1;background:#ffffff1a;justify-content:center;align-items:center;display:flex;position:absolute;top:20px;right:20px}.lightbox__close:hover{color:#fff;background:#fff3}.lightbox__img-wrap{cursor:default;max-width:90vw;max-height:90vh}.lightbox__img{border-radius:var(--radius-md);object-fit:contain;max-width:100%;max-height:90vh;box-shadow:0 32px 80px #000c}.article-toc-toggle{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);cursor:pointer;z-index:100;width:46px;height:46px;color:var(--gray-600);box-shadow:var(--shadow-lg);transition:all var(--t-base);justify-content:center;align-items:center;display:flex;position:fixed;top:50%;right:20px;transform:translateY(-50%)}.article-toc-toggle:hover{background:var(--accent);color:#fff;border-color:var(--accent);transform:translateY(-50%)scale(1.05)}.article-toc-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#0006;animation:.2s tocFade;position:fixed;inset:0}@keyframes tocFade{0%{opacity:0}to{opacity:1}}.article-toc{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-xl);z-index:201;width:260px;max-height:70vh;box-shadow:var(--shadow-xl);flex-direction:column;padding:20px;animation:.3s cubic-bezier(.16,1,.3,1) tocSlideIn;display:flex;position:fixed;top:50%;right:80px;transform:translateY(-50%)}.article-toc__header{border-bottom:1px solid var(--border-subtle);flex-shrink:0;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;display:flex}.article-toc__header span{font-family:var(--font-display);color:var(--gray-800);font-size:.95rem;font-weight:700}.article-toc__close{background:var(--gray-100);border-radius:var(--radius-md);cursor:pointer;width:28px;height:28px;color:var(--gray-500);transition:all var(--t-fast);justify-content:center;align-items:center;display:flex}.article-toc__close:hover{background:var(--gray-200);color:var(--gray-700)}.article-toc__list{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex;overflow-y:auto}.article-toc__item{border-radius:var(--radius-md);cursor:pointer;font-family:var(--font-cn);color:var(--gray-600);transition:all var(--t-fast);text-overflow:ellipsis;white-space:nowrap;padding:8px 12px;font-size:.85rem;line-height:1.4;overflow:hidden}.article-toc__item--h3{color:var(--gray-500);padding-left:24px;font-size:.8rem}.article-toc__item:hover{background:var(--accent-glow);color:var(--accent-light);transform:translate(-4px)}.article-toc__item.active{color:var(--accent-light);border-left:2px solid var(--accent);background:linear-gradient(135deg,#6366f126,#8b5cf61f);padding-left:10px}.article-toc__item--h3.active{padding-left:22px}.blog-post-nav{border-top:1px solid var(--border-subtle);margin-top:64px;padding-top:40px}.blog-post-nav__inner{grid-template-columns:1fr 1fr;gap:16px;display:grid}.blog-post-nav__item{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);transition:all var(--t-base);flex-direction:column;gap:8px;min-width:0;padding:20px;display:flex}.blog-post-nav__item:hover{box-shadow:var(--shadow-md), var(--shadow-accent);border-color:#818cf84d;transform:translateY(-2px)}.blog-post-nav__item--next{text-align:right;align-items:flex-end}.blog-post-nav__label{font-family:var(--font-display);color:var(--accent-light);letter-spacing:.05em;text-transform:uppercase;align-items:center;gap:5px;font-size:.72rem;font-weight:600;display:inline-flex}.blog-post-nav__title{font-family:var(--font-cn);color:var(--gray-700);-webkit-line-clamp:2;transition:color var(--t-fast);-webkit-box-orient:vertical;font-size:.9rem;line-height:1.45;display:-webkit-box;overflow:hidden}.blog-post-nav__item:hover .blog-post-nav__title{color:var(--gray-900)}@keyframes bp-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.bp-sk{background:linear-gradient(90deg, var(--gray-100) 25%, var(--gray-200) 50%, var(--gray-100) 75%);background-size:200% 100%;border-radius:6px;animation:1.5s infinite bp-shimmer}.blog-post-skeleton{padding:0}.bp-sk--tag{border-radius:var(--radius-full);width:80px;height:24px;margin-bottom:20px}.bp-sk--title{border-radius:var(--radius-md);width:70%;height:48px;margin-bottom:16px}.bp-sk--meta{width:220px;height:16px;margin-bottom:40px}.bp-sk-divider{background:var(--border-subtle);height:1px;margin-bottom:32px}.bp-sk--line{height:16px;margin-bottom:12px}.blog-post-back-to-top{background:var(--accent);color:#fff;border-radius:var(--radius-full);cursor:pointer;z-index:100;width:46px;height:46px;transition:all var(--t-base);justify-content:center;align-items:center;animation:.3s backToTopIn;display:flex;position:fixed;bottom:32px;right:80px;box-shadow:0 4px 20px #6366f166}@keyframes backToTopIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.blog-post-back-to-top:hover{background:var(--accent-dark);transform:translateY(-4px);box-shadow:0 8px 32px #6366f180}@media (width<=1100px){.article-toc-toggle{right:12px}.article-toc,.blog-post-back-to-top{right:70px}}@media (width<=768px){.blog-post-page__inner{padding:0 20px}.article-toc-toggle{display:none}.blog-post-back-to-top{width:42px;height:42px;bottom:24px;right:20px}.blog-post-nav__inner{grid-template-columns:1fr}.blog-post-nav__item--next{text-align:left;align-items:flex-start}}.blog-post-content a.wikilink{color:var(--accent);border-bottom:1px dashed var(--accent);text-decoration:none;transition:border-color .2s,color .2s}.blog-post-content a.wikilink:hover{color:#7c3aed;border-bottom-style:solid}.blog-post-content .wikilink--broken{color:#999;cursor:help;border-bottom:1px dashed #ccc}.blog-post-content center{text-align:center;margin:16px 0}.blog-post-content font{color:inherit}.blog-post-content mark{background:#fef9c3;border-radius:2px;padding:1px 4px}.blog-post-content kbd{font-size:.8em;font-family:var(--font-mono);background:var(--gray-100);border:1px solid var(--gray-300);box-shadow:0 1px 0 var(--gray-300);border-radius:3px;padding:2px 6px;line-height:1.4;display:inline-block}.projects-page{padding:calc(var(--nav-height) + var(--section-padding)) 0 var(--section-padding);background:var(--body-bg);min-height:100vh}.projects-page__inner{max-width:1140px;margin:0 auto;padding:0 40px}.projects-page__heading{margin-bottom:64px}.projects-page__grid{grid-template-columns:repeat(2,1fr);gap:24px;display:grid}.project-card-wrap{opacity:0;transition:opacity .9s var(--ease-out), transform .9s var(--ease-out);color:inherit;text-decoration:none}.project-card-wrap:nth-child(odd){transform:translate(-50px)translateY(30px)scale(.94)}.project-card-wrap:nth-child(2n){transform:translate(50px)translateY(30px)scale(.94)}.project-card-wrap.visible{opacity:1;transform:none}.project-card{background:var(--card-bg);border-radius:var(--radius-lg);border:1px solid var(--card-border);transition:transform var(--t-base), box-shadow var(--t-base), border-color var(--t-base);will-change:transform;cursor:pointer;flex-direction:column;height:100%;display:flex;overflow:hidden}.project-card:hover{box-shadow:var(--shadow-xl), 0 0 60px #818cf81f;border-color:#818cf833}.project-card__preview{height:190px;transition:height var(--t-base);flex-shrink:0;justify-content:space-between;align-items:flex-end;padding:18px;display:flex;position:relative;overflow:hidden}.project-card:hover .project-card__preview{height:210px}.project-card__preview:after{content:"";background:var(--shine-color);transition:transform .7s var(--ease-out);position:absolute;inset:0;transform:translate(-100%)}.project-card:hover .project-card__preview:after{transform:translate(100%)}.project-card__preview-overlay{background:var(--preview-overlay);position:absolute;inset:0}.project-card__type{z-index:1;font-family:var(--font-display);color:#ffffffe6;letter-spacing:.12em;text-transform:uppercase;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-full);background:#ffffff26;border:1px solid #ffffff26;padding:5px 13px;font-size:.64rem;font-weight:600;position:relative}.project-card__year{z-index:1;font-family:var(--font-display);color:#ffffffbf;letter-spacing:.06em;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-full);background:#ffffff1a;padding:5px 13px;font-size:.72rem;font-weight:500;position:relative}.project-card__body{flex-direction:column;flex:1;padding:26px;display:flex}.project-card__title{font-family:var(--font-cn);color:var(--gray-900);margin-bottom:14px;font-size:1.08rem;font-weight:700;line-height:1.45}.project-card__tags{flex-wrap:wrap;gap:6px;margin-bottom:0;display:flex}.project-card__tag{font-family:var(--font-display);color:var(--gray-500);background:var(--gray-100);border:1px solid var(--gray-200);border-radius:var(--radius-full);letter-spacing:.03em;transition:all var(--t-fast);padding:4px 11px;font-size:.63rem;font-weight:500}.project-card:hover .project-card__tag{background:var(--accent-glow);color:var(--accent-light);border-color:#818cf840}.project-card__desc{color:var(--gray-500);font-size:.82rem;line-height:1.75;font-family:var(--font-cn);opacity:0;max-height:0;transition:max-height .5s var(--ease-out), opacity .4s ease, margin-top .5s var(--ease-out);flex:1;margin-top:0;overflow:hidden}.project-card__desc.show{opacity:1;max-height:220px;margin-top:14px}.project-card__footer{border-top:1px solid var(--border-subtle);margin-top:18px;padding-top:18px}.project-card__link{font-family:var(--font-cn);color:var(--gray-400);transition:all var(--t-fast);align-items:center;gap:7px;font-size:.8rem;font-weight:500;display:inline-flex}.project-card:hover .project-card__link{color:var(--accent-light);gap:12px}@media (width<=900px){.projects-page__grid{grid-template-columns:1fr}.project-card-wrap:nth-child(odd),.project-card-wrap:nth-child(2n){transform:translateY(50px)scale(.94)}}@media (width<=768px){.projects-page__inner{padding:0 20px}}.project-detail-page{padding:calc(var(--nav-height) + 60px) 0 var(--section-padding);background:var(--body-bg);min-height:100vh}.project-detail-page__inner{opacity:0;max-width:860px;transition:opacity .7s var(--ease-out), transform .7s var(--ease-out);margin:0 auto;padding:0 40px;transform:translateY(30px)}.project-detail-page__inner.visible{opacity:1;transform:none}.project-detail-back{font-family:var(--font-cn);color:var(--gray-500);transition:color var(--t-fast);align-items:center;gap:6px;margin-bottom:32px;font-size:.82rem;display:inline-flex}.project-detail-back:hover{color:var(--accent-light)}.project-detail-not-found{text-align:center;padding:120px 0}.project-detail-not-found h2{font-family:var(--font-cn);color:var(--gray-900);margin-bottom:12px;font-size:1.5rem}.project-detail-not-found p{color:var(--gray-500);margin-bottom:24px;font-size:.9rem}.project-detail-header{margin-bottom:40px}.project-detail-header__cover{border-radius:var(--radius-lg);height:240px;margin-bottom:32px;position:relative;overflow:hidden}.project-detail-header__cover-overlay{background:var(--preview-overlay);position:absolute;inset:0}.project-detail-header__cover-content{z-index:1;justify-content:space-between;align-items:flex-end;display:flex;position:absolute;bottom:20px;left:20px;right:20px}.project-detail-header__type{font-family:var(--font-display);color:#ffffffe6;letter-spacing:.12em;text-transform:uppercase;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-full);background:#ffffff26;border:1px solid #ffffff26;padding:6px 16px;font-size:.72rem;font-weight:600}.project-detail-header__year{font-family:var(--font-display);color:#ffffffbf;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-full);background:#ffffff1a;padding:6px 16px;font-size:.8rem;font-weight:500}.project-detail-header__title{font-family:var(--font-cn);color:var(--gray-900);margin-bottom:12px;font-size:clamp(1.8rem,4vw,2.6rem);font-weight:800;line-height:1.25}.project-detail-header__role{color:var(--gray-500);margin-bottom:20px;font-size:.9rem}.project-detail-header__tags{flex-wrap:wrap;gap:8px;display:flex}.project-detail-header__tag{font-family:var(--font-display);color:var(--accent-light);background:var(--accent-glow);border-radius:var(--radius-full);letter-spacing:.03em;border:1px solid #818cf840;padding:5px 14px;font-size:.72rem;font-weight:500}.project-detail-body{flex-direction:column;gap:48px;display:flex}.project-detail-section__title{font-family:var(--font-cn);color:var(--gray-900);border-bottom:1px solid var(--border-subtle);margin-bottom:16px;padding-bottom:12px;font-size:1.3rem;font-weight:700}.project-detail-section__text{color:var(--gray-600);font-size:.92rem;line-height:1.85;font-family:var(--font-cn)}.project-detail-achievements{flex-direction:column;gap:14px;padding:0;list-style:none;display:flex}.project-detail-achievements__item{color:var(--gray-700);font-size:.9rem;font-family:var(--font-cn);background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-md);transition:border-color var(--t-fast);align-items:center;gap:12px;padding:14px 18px;display:flex}.project-detail-achievements__item:hover{border-color:#818cf840}.project-detail-achievements__icon{color:var(--accent-light);flex-shrink:0;font-size:.7rem}.project-detail-tech-stack{flex-wrap:wrap;gap:12px;display:flex}.project-detail-tech-item{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-md);transition:all var(--t-fast);padding:12px 24px}.project-detail-tech-item:hover{border-color:#818cf84d;box-shadow:0 0 20px #818cf81a}.project-detail-tech-item__name{font-family:var(--font-display);color:var(--gray-900);font-size:.85rem;font-weight:600}@media (width<=768px){.project-detail-page__inner{padding:0 20px}.project-detail-header__cover{height:180px}}.favorites-page{padding:calc(var(--nav-height) + var(--section-padding)) 0 var(--section-padding);background:var(--body-bg);min-height:100vh}.favorites-page__inner{max-width:900px;margin:0 auto;padding:0 40px}.favorites-page__heading{margin-bottom:64px}.favorites-page__list{flex-direction:column;gap:48px;display:flex}.fav-category{opacity:0;transition:opacity .7s var(--ease-out), transform .7s var(--ease-out);transform:translateY(30px)}.fav-category.visible{opacity:1;transform:none}.fav-category__title{font-family:var(--font-cn);color:var(--gray-900);border-bottom:1px solid var(--border-subtle);align-items:center;gap:10px;margin-bottom:20px;padding-bottom:14px;font-size:1.2rem;font-weight:700;display:flex}.fav-category__icon{font-size:1.1rem}.fav-category__grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.fav-item{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-md);transition:all var(--t-fast);justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.fav-item:hover{border-color:#818cf833;box-shadow:0 0 20px #818cf814}.fav-item__info{flex:1;min-width:0}.fav-item__name{font-family:var(--font-display);color:var(--gray-900);margin-bottom:4px;font-size:.88rem;font-weight:600}.fav-item__desc{color:var(--gray-500);font-size:.75rem;line-height:1.5;font-family:var(--font-cn);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.fav-item__link{border-radius:var(--radius-full);width:30px;height:30px;color:var(--gray-400);background:var(--gray-100);transition:all var(--t-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.fav-item__link:hover{color:var(--accent-light);background:var(--accent-glow);transform:scale(1.1)}@media (width<=768px){.favorites-page__inner{padding:0 20px}.fav-category__grid{grid-template-columns:1fr}}.guestbook-page{padding:calc(var(--nav-height) + var(--section-padding)) 0 var(--section-padding);background:var(--body-bg);min-height:100vh}.guestbook-page__inner{max-width:780px;margin:0 auto;padding:0 40px}.guestbook-page__heading{margin-bottom:48px}.guestbook-page__heading-row{justify-content:space-between;align-items:flex-end;gap:24px;display:flex}.guestbook-page__heading-text{flex:1;min-width:0}.guestbook-chibi{width:96px;height:104px;image-rendering:pixelated;opacity:0;background-position:0 0;background-repeat:no-repeat;background-size:768px 936px;flex-shrink:0;transition:opacity .6s .3s,transform .6s .3s;animation:.9s steps(6,end) infinite chibi-idle;transform:translateY(12px)}.guestbook-chibi.visible{opacity:1;transform:translateY(0)}@keyframes chibi-idle{0%{background-position-x:0}to{background-position-x:-576px}}.guestbook-form{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);margin-bottom:48px;padding:28px}.guestbook-form__row{gap:12px;margin-bottom:12px;display:flex}.guestbook-form__input{background:var(--input-bg);border:1px solid var(--card-border);border-radius:var(--radius-md);color:var(--gray-900);font-family:var(--font-cn);transition:border-color var(--t-fast), background var(--t-fast);outline:none;flex:1;padding:12px 18px;font-size:.85rem}.guestbook-form__input::placeholder{color:var(--gray-400)}.guestbook-form__input:focus{background:var(--input-focus-bg);border-color:#818cf866}.guestbook-form__btn{background:var(--gradient-main);color:#fff;font-family:var(--font-cn);border-radius:var(--radius-md);transition:all var(--t-fast);white-space:nowrap;flex-shrink:0;padding:12px 28px;font-size:.85rem;font-weight:600}.guestbook-form__btn:hover:not(:disabled){box-shadow:var(--shadow-accent);transform:translateY(-1px)}.guestbook-form__btn:disabled{opacity:.6;cursor:not-allowed}.guestbook-form__textarea{background:var(--input-bg);border:1px solid var(--card-border);border-radius:var(--radius-md);width:100%;color:var(--gray-900);font-family:var(--font-cn);resize:vertical;min-height:80px;transition:border-color var(--t-fast), background var(--t-fast);outline:none;padding:12px 18px;font-size:.85rem}.guestbook-form__textarea::placeholder{color:var(--gray-400)}.guestbook-form__textarea:focus{background:var(--input-focus-bg);border-color:#818cf866}.guestbook-list{flex-direction:column;gap:16px;display:flex}.guestbook-item{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);transition:border-color var(--t-fast);gap:16px;padding:20px 24px;display:flex}.guestbook-item:hover{border-color:#818cf826}.guestbook-item__avatar{border-radius:var(--radius-full);color:#fff;width:40px;height:40px;font-family:var(--font-display);flex-shrink:0;justify-content:center;align-items:center;font-size:.9rem;font-weight:700;display:flex}.guestbook-item__body{flex:1;min-width:0}.guestbook-item__header{align-items:center;gap:12px;margin-bottom:8px;display:flex}.guestbook-item__name{font-family:var(--font-cn);color:var(--gray-900);font-size:.88rem;font-weight:600}.guestbook-item__time{font-family:var(--font-display);color:var(--gray-500);font-size:.72rem}.guestbook-item__content{color:var(--gray-600);font-size:.85rem;line-height:1.7;font-family:var(--font-cn);word-break:break-word}.guestbook-loading,.guestbook-error,.guestbook-empty{text-align:center;padding:60px 0}.guestbook-loading p,.guestbook-error p,.guestbook-empty p{color:var(--gray-500);font-size:.9rem;font-family:var(--font-cn)}.guestbook-loading__spinner{border:2px solid var(--gray-200);border-top-color:var(--accent);border-radius:50%;width:28px;height:28px;margin:0 auto 14px;animation:.8s linear infinite guestbook-spin}@keyframes guestbook-spin{to{transform:rotate(360deg)}}.guestbook-error p{color:#ef4444}@media (width<=768px){.guestbook-page__inner{padding:0 20px}.guestbook-form{padding:20px}.guestbook-form__row{flex-direction:column}.guestbook-chibi{background-size:576px 702px;width:72px;height:78px;animation:.9s steps(6,end) infinite chibi-idle-sm}@keyframes chibi-idle-sm{0%{background-position-x:0}to{background-position-x:-432px}}}.app{-webkit-user-select:none;user-select:none;flex-direction:column;min-height:100vh;display:flex}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--black:#050508;--black-2:#0c0c18;--black-3:#112;--white:#0c0c18;--accent:#818cf8;--accent-light:#a5a8ff;--accent-dark:#6366f1;--accent-glow:#818cf81f;--accent-glow-strong:#818cf847;--gradient-main:linear-gradient(135deg, #818cf8 0%, #a78bfa 50%, #c084fc 100%);--gradient-subtle:linear-gradient(135deg, #818cf81a 0%, #a78bfa0d 100%);--gradient-text:linear-gradient(135deg, #818cf8, #c084fc);--gray-50:#08080f;--gray-100:#ffffff0e;--gray-200:#ffffff17;--gray-300:#ffffff24;--gray-400:#ffffff52;--gray-500:#ffffff7a;--gray-600:#ffffff9e;--gray-700:#ffffffc7;--gray-800:#ffffffe6;--gray-900:#f0f0f8;--font-display:"Space Grotesk", "PingFang SC", "Microsoft YaHei", sans-serif;--font-body:"Inter", "PingFang SC", "Microsoft YaHei", sans-serif;--font-cn:"Noto Sans SC", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif;--nav-height:64px;--section-padding:clamp(100px, 14vw, 180px);--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--radius-xl:28px;--radius-full:9999px;--shadow-sm:0 1px 3px #00000080;--shadow-md:0 4px 20px #0009;--shadow-lg:0 12px 50px #000000b3;--shadow-xl:0 24px 80px #000c;--shadow-accent:0 0 30px #818cf840;--shadow-accent-lg:0 0 60px #818cf866;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--ease-dramatic:cubic-bezier(.87, 0, .13, 1);--t-fast:.15s var(--ease-out);--t-base:.35s var(--ease-out);--t-slow:.7s var(--ease-out);--t-slower:1.1s var(--ease-out);--body-bg:#050508;--nav-bg:#050508d1;--nav-border:#ffffff0f;--card-bg:#0c0c18;--card-border:#ffffff0f;--input-bg:#08080f;--input-focus-bg:#ffffff0a;--border-subtle:#ffffff0f;--ghost-stroke:#818cf80b;--grid-line:#818cf80a;--marquee-bg:#07070e;--marquee-fade:#07070e;--noise-opacity:.045;--cn-name-color:#ffffff40;--btn-ghost-bg:#ffffff08;--btn-ghost-border:#ffffff1f;--mobile-menu-bg:#050508f7;--links-pill-bg:#ffffff0d;--links-pill-border:#ffffff0f;--link-active-bg:#ffffff1a;--contact-btn-border:#ffffff1a;--badge-bg:#818cf814;--badge-border:#818cf833;--scroll-line:var(--accent-light);--preview-overlay:linear-gradient(to top, #00000080 0%, transparent 60%);--shine-color:#ffffff12}[data-theme=dark]{--black:#f8f9fc;--black-2:#fff;--black-3:#f0f1f5;--white:#fff;--accent:#6366f1;--accent-light:#4f46e5;--accent-dark:#818cf8;--accent-glow:#6366f114;--accent-glow-strong:#6366f12e;--gradient-main:linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #a855f7 100%);--gradient-subtle:linear-gradient(135deg, #6366f10f 0%, #8b5cf608 100%);--gradient-text:linear-gradient(135deg, #4f46e5, #7c3aed);--gray-50:#f1f2f6;--gray-100:#0000000f;--gray-200:#00000017;--gray-300:#00000029;--gray-400:#00000061;--gray-500:#0000008c;--gray-600:#000000ad;--gray-700:#000c;--gray-800:#000000e0;--gray-900:#111827;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 20px #0000001a;--shadow-lg:0 12px 50px #0000001f;--shadow-xl:0 24px 80px #00000026;--shadow-accent:0 0 30px #6366f126;--shadow-accent-lg:0 0 60px #6366f140;--body-bg:#f8f9fc;--nav-bg:#f8f9fcd9;--nav-border:#0000000f;--card-bg:#fff;--card-border:#00000014;--input-bg:#f1f2f6;--input-focus-bg:#6366f10a;--border-subtle:#0000000f;--ghost-stroke:#6366f10f;--grid-line:#6366f10d;--marquee-bg:#f0f1f5;--marquee-fade:#f0f1f5;--noise-opacity:.02;--cn-name-color:#0000002e;--btn-ghost-bg:#00000008;--btn-ghost-border:#0000001f;--mobile-menu-bg:#f8f9fcf7;--links-pill-bg:#0000000a;--links-pill-border:#0000000f;--link-active-bg:#00000012;--contact-btn-border:#0000001f;--badge-bg:#6366f10f;--badge-border:#6366f12e;--scroll-line:var(--accent);--preview-overlay:linear-gradient(to top, #0000004d 0%, transparent 60%);--shine-color:#ffffff80}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;font-size:16px}html.theme-transition,html.theme-transition *,html.theme-transition :before,html.theme-transition :after{transition:background-color .5s cubic-bezier(.16,1,.3,1),color .5s cubic-bezier(.16,1,.3,1),border-color .5s cubic-bezier(.16,1,.3,1),box-shadow .5s cubic-bezier(.16,1,.3,1),fill .5s cubic-bezier(.16,1,.3,1),stroke .5s cubic-bezier(.16,1,.3,1)!important}body{background-color:var(--body-bg);color:var(--gray-900);font-family:var(--font-body);cursor:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}body:after{content:"";opacity:var(--noise-opacity);pointer-events:none;z-index:9998;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");position:fixed;inset:0}#root{z-index:1;min-height:100vh;position:relative}a{color:inherit;text-decoration:none}button{cursor:none;font:inherit;background:0 0;border:none}.scroll-progress{background:var(--gradient-main);z-index:10000;transform-origin:0;height:2px;position:fixed;top:0;left:0;right:0;transform:scaleX(0);box-shadow:0 0 12px #818cf899}.section-label{font-family:var(--font-display);letter-spacing:.22em;text-transform:uppercase;color:var(--accent-light);opacity:0;transition:opacity .7s var(--ease-out), transform .7s var(--ease-out);align-items:center;gap:12px;margin-bottom:20px;font-size:.72rem;font-weight:600;display:inline-flex;transform:translate(-28px)}.section-label.visible{opacity:1;transform:none}.section-label:before{content:"";background:var(--gradient-main);border-radius:1px;flex-shrink:0;width:28px;height:1px}.section-title{font-family:var(--font-cn);color:var(--gray-900);opacity:0;transition:opacity .9s var(--ease-out) .1s, transform .9s var(--ease-out) .1s;margin-bottom:20px;font-size:clamp(2.5rem,6vw,4.2rem);font-weight:800;line-height:1.15;transform:translateY(48px)}.section-title.visible{opacity:1;transform:none}.section-desc{color:var(--gray-500);opacity:0;max-width:520px;transition:opacity .9s var(--ease-out) .22s, transform .9s var(--ease-out) .22s;font-size:1rem;line-height:1.8;transform:translateY(28px)}.section-desc.visible{opacity:1;transform:none}@media (width<=768px){body{cursor:auto}button,a{cursor:pointer}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}
