@font-face{font-family:Syne;font-display:swap;src:local("Syne")}:root{--bg-color: #050505;--card-bg: #0f0f0f;--card-border: rgba(255,255,255,.06);--text-main: #ffffff;--text-muted: #737373;--accent: #e8e8e8;--nav-height: 80px;--font-display: "Syne", "Helvetica Neue", sans-serif;--font-body: "DM Sans", "Helvetica Neue", sans-serif;--font-mono: "Space Mono", "Courier New", monospace;--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--ease-out-quart: cubic-bezier(.25, 1, .5, 1);--ease-out-quint: cubic-bezier(.23, 1, .32, 1);--ease-out-back: cubic-bezier(.34, 1.56, .64, 1);--ease-in-out-circ: cubic-bezier(.85, 0, .15, 1);--ease-spring: cubic-bezier(.175, .885, .32, 1.275);--glow-primary: rgba(102, 126, 234, .4);--glow-secondary: rgba(240, 147, 251, .4);--glow-accent: rgba(79, 172, 254, .4);--card-padding: 24px;--card-gap: 24px;--card-radius: 16px;--card-min-height: 180px;--card-hover-lift: -4px;--card-transition: all .4s var(--ease-out-expo);--type-kicker: .72rem;--type-title: 1.25rem;--type-subtitle: .98rem;--type-body: .95rem;--type-body-tight: .9rem;--space-xs: clamp(.5rem, 2vw, .75rem);--space-sm: clamp(.75rem, 3vw, 1rem);--space-md: clamp(1rem, 4vw, 1.5rem);--space-lg: clamp(1.5rem, 6vw, 2.5rem);--space-xl: clamp(2rem, 8vw, 4rem);--space-2xs: .25rem;--space-3xs: .125rem;--pill-radius: 999px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--control-font: .85rem;--pad-compact: 20px;--gap-compact: 16px;--mt-compact: 24px;--icon-compact: 48px;--icon-mb-compact: 12px;--work-image-compact: 160px;--btn-hover-lift: -2px;--btn-hover-shadow: 0 8px 24px rgba(0, 0, 0, .3);--btn-focus-ring: 0 0 0 2px rgba(255, 255, 255, .14), 0 0 0 5px rgba(255, 255, 255, .06)}body:after{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E");background-size:200px 200px;pointer-events:none;opacity:.032;z-index:99998;mix-blend-mode:overlay}#section-nav-dots{position:fixed;right:28px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:10px;z-index:500;pointer-events:none}body[data-page=project] #section-nav-dots,body[data-page=project] #mobile-progress,body[data-page=project] .edge-arrow{display:none!important}.s-dot{width:4px;height:4px;border:none;padding:0;border-radius:50%;background:#fff3;transition:all .4s cubic-bezier(.4,0,.2,1);pointer-events:auto;cursor:pointer;position:relative}.s-dot:before{content:"";position:absolute;inset:-5px;border-radius:50%}.s-dot.active{background:#ffffffe6;height:20px;border-radius:2px;box-shadow:0 0 8px #ffffff4d}.mobile-progress-indicator{position:fixed;right:max(6px,env(safe-area-inset-right));top:50%;transform:translateY(-50%);display:none;flex-direction:column;align-items:center;gap:8px;z-index:500;pointer-events:none}.mobile-progress-indicator .m-dots-container{display:flex;flex-direction:column;align-items:center;gap:12px;pointer-events:auto}.mobile-progress-indicator .m-dot{width:4px;height:4px;border:none;padding:0;border-radius:50%;background:#fff3;transition:all .4s cubic-bezier(.4,0,.2,1);pointer-events:auto;cursor:pointer;position:relative}.mobile-progress-indicator .m-dot.active{background:#ffffffe6;height:20px;border-radius:2px;box-shadow:0 0 8px #ffffff4d}.mobile-progress-indicator .m-dot:before{content:"";position:absolute;inset:-8px;border-radius:50%}@media(max-width:768px){.mobile-progress-indicator{display:flex}}@media(max-width:768px){#section-nav-dots{display:none}}@media(max-width:768px){.sub-page .article-list .article-item,.sub-page .article-list .article-body,.sub-page .article-list .article-content{min-width:0;width:100%}}@media(max-width:480px){.sub-page .article-list .article-item{min-width:0}}.section-scroll-wrapper{position:absolute;inset:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;scrollbar-width:none;-ms-overflow-style:none}.section-scroll-wrapper::-webkit-scrollbar{display:none}.section-scroll-content{min-height:100%;padding:calc(var(--nav-height) + 40px) clamp(20px,4vw,56px) calc(50px + env(safe-area-inset-bottom));box-sizing:border-box;display:flex;flex-direction:column;justify-content:flex-start}.sc-blur-overlay{position:absolute;inset:0;backdrop-filter:blur(0px);background:#05050500;pointer-events:none;z-index:9999}.edge-arrow{position:absolute;right:10px;color:#ffffff4d;font-size:16px;opacity:0;transition:opacity .2s ease,transform .2s ease;pointer-events:none;z-index:100;will-change:opacity,transform}.edge-arrow.top-arrow{top:120px}.edge-arrow.bottom-arrow{bottom:80px}*{margin:0;padding:0;box-sizing:border-box}body{background-color:var(--bg-color);color:var(--text-main);font-family:var(--font-body);line-height:1.65;height:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;text-size-adjust:100%;overscroll-behavior-y:none}html{-webkit-text-size-adjust:100%;text-size-adjust:100%}button,a{-webkit-tap-highlight-color:transparent;touch-action:manipulation}h1,h2,h3,h4,h5,h6,.section-title,.hero-text h1,.hero-label,.page-title{font-family:var(--font-display)}p,li,span:not(.en):not(.cn){line-height:1.7}a{text-decoration:none;color:inherit;transition:.3s}ul{list-style:none}img{max-width:100%;display:block}.text-group{display:flex;flex-direction:column}.en{font-weight:600;letter-spacing:.5px}.cn{font-size:.85em;color:var(--text-muted);font-weight:400;margin-top:2px}#navbar{position:fixed;top:0;left:0;width:100%;height:var(--nav-height);display:flex;justify-content:space-between;align-items:center;padding:0 5%;z-index:1000;transition:all .5s var(--ease-out-expo);background:transparent}#navbar.scrolled{background:#050505bf;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid rgba(255,255,255,.06);box-shadow:0 4px 30px #0000004d}@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))){#navbar.scrolled{background:#050505f0}.mobile-nav{background:#050505fa}.mobile-nav-overlay.active{background:#0000008c}}.logo{display:flex;align-items:center;gap:12px;font-weight:700;font-size:1.2rem;letter-spacing:1px;z-index:1001;cursor:pointer;transition:transform .3s var(--ease-out-back)}.logo:hover{transform:scale(1.02)}.nav-links{display:flex;gap:40px}.nav-link-item{display:flex;flex-direction:column;align-items:center;text-transform:uppercase;color:var(--text-muted);cursor:pointer;position:relative;padding:8px 0;transition:color .4s var(--ease-out-expo)}.nav-link-item .en{font-size:.85rem;letter-spacing:1.5px;font-weight:500;transition:all .4s var(--ease-out-expo)}.nav-link-item .cn{font-size:.65rem;position:absolute;top:100%;left:50%;transform:translate(-50%) translateY(4px);opacity:0;transition:all .3s var(--ease-out-expo);white-space:nowrap;margin-top:2px;letter-spacing:1px}.nav-links a:hover .nav-link-item,.nav-links a.active .nav-link-item{color:var(--text-main)}.nav-links a:hover .cn,.nav-links a.active .cn{opacity:1;transform:translate(-50%) translateY(0)}.nav-links a:hover .en,.nav-links a.active .en{transform:translateY(-2px)}#copy-toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#ffffffe6;color:#000;padding:10px 20px;border-radius:20px;font-weight:700;opacity:0;transition:.3s;z-index:2000;pointer-events:none}main{width:100%}section{background-color:var(--bg-color);box-shadow:0 -15px 30px #000c;border-top:1px solid #111;border-radius:0;overflow:hidden;height:100vh;height:100dvh}#home{z-index:1;box-shadow:none;border-top:none;border-radius:0;width:100vw;max-width:100vw;left:0}#about{z-index:2}#blog{z-index:3}#portfolio{z-index:4}#share{z-index:5}#about .section-scroll-content,#blog .section-scroll-content,#portfolio .section-scroll-content,#share .section-scroll-content{max-width:1200px;width:100%;margin:0 auto;box-sizing:border-box;padding:calc(var(--nav-height) + 60px) clamp(24px,5vw,80px) 80px}.page-header{margin-bottom:50px}.page-title{font-size:2.5rem;font-weight:300;margin-bottom:12px;display:flex;flex-direction:column;line-height:1.2}.page-title .cn{font-size:1rem;color:var(--text-muted);margin-top:8px;display:block}@media(max-width:1024px){#about .section-scroll-content,#blog .section-scroll-content,#portfolio .section-scroll-content,#share .section-scroll-content{padding:calc(var(--nav-height) + 40px) clamp(20px,4vw,48px) 60px}}@media(max-width:768px){#about .section-scroll-content,#blog .section-scroll-content,#portfolio .section-scroll-content,#share .section-scroll-content{padding:calc(var(--nav-height) + 24px) clamp(16px,4vw,24px) 48px}.page-title{font-size:1.8rem}}.card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--card-radius);padding:var(--card-padding);transition:var(--card-transition);box-shadow:0 4px 20px #0003}.card:hover{background:#ffffff08;border-color:#ffffff1f;transform:translateY(var(--card-hover-lift));box-shadow:0 16px 48px #00000059}.card-header{font-size:.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.15em;font-family:var(--font-mono);margin-bottom:18px;display:flex;align-items:center;gap:10px}.card-header i{font-size:1.2rem}.card-list{display:flex;flex-direction:column;gap:10px}.card-list li{color:var(--text-main);font-size:.9rem;padding-left:16px;position:relative;opacity:.85}.card-list li:before{content:"·";position:absolute;left:0;color:var(--text-muted);font-size:1.2em;line-height:1;top:2px}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px}.posts-list{display:flex;flex-direction:column;gap:32px}.post-item{padding:24px 0;border-bottom:1px solid var(--card-border);transition:all .2s ease}.post-item:hover{padding-left:12px}.post-date{color:var(--text-muted);font-size:.75rem;font-family:var(--font-mono);letter-spacing:.1em;margin-bottom:12px;display:block}.post-title{font-size:1.4rem;font-weight:400;margin-bottom:8px}.post-title .cn{font-size:.9rem;color:var(--text-muted);margin-top:4px;display:block}.post-excerpt{color:var(--text-muted);line-height:1.7;font-size:.95rem}h2.section-title{font-size:clamp(2rem,3.5vw,3rem);margin-bottom:50px;font-weight:300;line-height:1.1;flex-shrink:0;padding-top:10px;font-family:var(--font-display);letter-spacing:-.02em}h2.section-title span.sub{color:var(--text-muted);font-size:.7rem;display:block;margin-bottom:12px;letter-spacing:.25em;text-transform:uppercase;font-family:var(--font-mono);font-weight:400}.section-title .text-group{display:inline-flex;flex-direction:column}.section-title-cn{font-size:1.1rem}.section-link{display:inline-flex;flex-direction:column;gap:6px;cursor:pointer}.section-link:hover .en,.section-link:hover .cn{color:var(--text-main)}#home .section-scroll-content{flex-direction:row;align-items:center;justify-content:space-between}.hero-text{flex:1;padding-right:60px;z-index:2;animation:fadeIn .9s cubic-bezier(.4,0,.2,1) forwards .3s;opacity:0}.hero-text h1{font-size:clamp(2.8rem,5vw,4.5rem);line-height:1;margin-bottom:24px;font-weight:800;letter-spacing:-.03em;font-family:var(--font-display)}.hero-text .hero-label{display:flex;align-items:center;gap:12px;margin-bottom:28px}.hero-text .hero-label:before{content:"";display:block;width:24px;height:1px;background:var(--text-muted)}.hero-text .hero-label .en{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.2em;color:var(--text-muted);font-weight:400}.hero-cn-inline{font-size:.35em;font-weight:400;color:var(--text-muted);letter-spacing:.1em;vertical-align:middle;margin-left:.4em;font-family:var(--font-body)}.hero-intro{margin-top:20px}.hero-intro-en{color:var(--text-muted);font-size:1rem;line-height:1.7;max-width:420px}.hero-intro-cn{margin-top:6px}.btn-connect{display:inline-flex;flex-direction:row;align-items:center;gap:8px;padding:12px 28px;border:1px solid rgba(255,255,255,.25);border-radius:3px;margin-top:36px;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;background:transparent;position:relative;overflow:hidden}.btn-connect:before{display:none}.btn-connect .en{font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;font-family:var(--font-mono);position:relative;z-index:1;transition:color .3s}.btn-connect .cn{font-size:.7rem;color:var(--text-muted);position:relative;z-index:1;transition:color .3s}.btn-connect:hover .en{color:#000}.btn-connect:hover .cn{color:#444}.btn-connect:hover{background:#ffffffeb;border-color:#ffffffeb}.hero-img{flex:1.3;height:85vh;position:relative;animation:fadeIn 1s ease forwards;opacity:0}.hero-img img{width:100%;height:100%;object-fit:cover;border-radius:10px;filter:grayscale(100%) blur(4px) brightness(.8);transition:all .6s ease;transform:scale(1.01)}@media(hover:hover)and (pointer:fine){.hero-img:hover img{filter:grayscale(0%) blur(0px) brightness(1)}}@media(hover:none)and (pointer:coarse){.hero-img img{filter:grayscale(50%) blur(4px) brightness(.85)}}.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1px;margin-top:40px;border:1px solid var(--card-border);border-radius:4px;overflow:hidden}.blog-card{background:var(--card-bg);padding:32px 28px;border:none;transition:all .4s var(--ease-out-expo);position:relative;overflow:hidden}.blog-card:before{display:none}.blog-date{color:var(--text-muted);font-size:.65rem;margin-bottom:18px;font-family:var(--font-mono);letter-spacing:.1em;transition:color .3s ease}.blog-card:hover .blog-date{color:#fffc}.works-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;max-height:70vh;overflow-y:auto;margin-top:30px}.works-gallery::-webkit-scrollbar{display:none}.work-item{position:relative;height:300px;background:#222;border-radius:8px;overflow:hidden;transition:transform .4s var(--ease-out-back),box-shadow .4s ease}.work-item:before{display:none}.work-item:hover:before{display:none}.work-item img{width:100%;height:100%;object-fit:cover;opacity:.6;transition:all .6s var(--ease-out-expo)}.work-item:hover img{transform:scale(1.08);opacity:1}.work-info{position:absolute;bottom:25px;left:25px;z-index:2;transition:transform .4s var(--ease-out-expo)}.work-item:hover .work-info{transform:translateY(-4px)}.work-info h4{margin:0 0 5px;font-size:1.1rem;transition:color .3s ease}.work-info p{margin:0;font-size:.9rem;opacity:.8;transition:opacity .3s ease}.work-item:hover .work-info p{opacity:1}.skills-showcase{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:30px}.skill-block{background:transparent;border:1px solid var(--card-border);border-radius:0;padding:32px;transition:all .4s var(--ease-out-expo);position:relative;overflow:hidden}.skill-block:before{display:none}.skill-block:hover{background:#ffffff08;border-color:#ffffff26;transform:translateY(-4px)}.skill-block:hover:before{display:none}.skill-header{display:flex;align-items:center;gap:12px;margin-bottom:22px}.skill-header i{font-size:1.4rem;color:var(--text-muted);transition:all .4s var(--ease-out-expo)}.skill-block:hover .skill-header i{color:var(--text-main);transform:scale(1.1)}.skill-cat{font-size:.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.18em;font-family:var(--font-mono);transition:color .3s ease}.skill-block:hover .skill-cat{color:var(--text-main)}.skill-items{display:flex;flex-direction:column;gap:10px}.skill-items li{color:var(--text-main);font-size:.88rem;padding-left:16px;position:relative;opacity:.75;transition:all .3s var(--ease-out-expo);transform:translate(0)}.skill-block:hover .skill-items li{opacity:1}.skill-block:hover .skill-items li:nth-child(1){transition-delay:.05s}.skill-block:hover .skill-items li:nth-child(2){transition-delay:.1s}.skill-block:hover .skill-items li:nth-child(3){transition-delay:.15s}.skill-block:hover .skill-items li:nth-child(4){transition-delay:.2s}.skill-items li:before{content:"·";position:absolute;left:0;color:var(--text-muted);font-size:1.2em;line-height:1;top:2px;transition:color .3s ease}.skill-block:hover .skill-items li:before{color:var(--text-main)}.skills-cta{margin-top:50px;text-align:center}#share{background-color:#080808}#share .tool-card{display:flex;flex-direction:column;height:100%;text-decoration:none}#share .tool-card .card-list{margin-top:auto}.mobile-scroll-hint{display:none!important}@media(max-width:768px){.edge-arrow{display:none!important}}footer{margin-top:auto;text-align:center;padding:20px;font-size:.8rem;color:#444;width:100%}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.mobile-menu-btn{display:none;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);color:var(--text-main);font-size:1.1rem;cursor:pointer;z-index:3100;padding:0;border-radius:6px;transition:all .3s var(--ease-out-expo);width:36px;height:36px;align-items:center;justify-content:center;position:relative;display:inline-flex}.mobile-menu-btn:hover{background:#ffffff1f;border-color:#fff3;transform:translateY(var(--btn-hover-lift));box-shadow:var(--btn-hover-shadow)}.mobile-menu-btn:active{transform:translateY(0)}.mobile-menu-btn i{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;line-height:1;font-size:1.1rem;transition:all .3s var(--ease-out-expo)}.mobile-nav{position:fixed;top:0;right:0;width:65%;max-width:260px;height:100%;min-height:100vh;background:#050505fa;backdrop-filter:blur(20px);z-index:3000;display:flex;flex-direction:column;padding:70px 16px 24px;transform:translate(100%);transition:transform .5s cubic-bezier(.16,1,.3,1);border-left:1px solid rgba(255,255,255,.1);overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;will-change:transform}html.ua-firefox .mobile-nav,html.ua-firefox #navbar.scrolled,html.ua-quark .mobile-nav,html.ua-inapp .mobile-nav,html.ua-quark #navbar.scrolled,html.ua-inapp #navbar.scrolled{backdrop-filter:none;-webkit-backdrop-filter:none;background:#050505f0}html.ua-quark .mobile-nav-overlay.active,html.ua-inapp .mobile-nav-overlay.active{backdrop-filter:none;-webkit-backdrop-filter:none;background:#0000008c}html.ua-inapp #section-nav-dots,html.ua-inapp #mobile-progress{display:none!important}.mobile-nav-close{position:absolute;top:16px;right:16px;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);color:var(--text-muted);font-size:1.1rem;cursor:pointer;padding:0;border-radius:6px;transition:all .3s ease;width:36px;height:36px;display:flex;align-items:center;justify-content:center;z-index:3001}.mobile-nav-close i{display:block;line-height:1}.mobile-nav-close:hover{background:#ffffff1f;border-color:#fff3;color:var(--text-main)}.mobile-nav.active{transform:translate(0)}.mobile-nav-link{display:flex;flex-direction:column;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.05);color:var(--text-muted);transition:all .4s var(--ease-out-expo);opacity:0;transform:translate(40px)}.mobile-nav.active .mobile-nav-link{opacity:1;transform:translate(0)}.mobile-nav.active .mobile-nav-link:nth-of-type(1){transition-delay:.06s}.mobile-nav.active .mobile-nav-link:nth-of-type(2){transition-delay:.12s}.mobile-nav.active .mobile-nav-link:nth-of-type(3){transition-delay:.18s}.mobile-nav.active .mobile-nav-link:nth-of-type(4){transition-delay:.24s}.mobile-nav.active .mobile-nav-link:nth-of-type(5){transition-delay:.3s}.mobile-nav-link .en{font-size:1rem;font-weight:600;letter-spacing:1px;text-transform:uppercase}.mobile-nav-link .cn{font-size:.75rem;margin-top:2px}.mobile-nav-link:hover,.mobile-nav-link.active{color:var(--text-main)}.mobile-nav-overlay{position:fixed;top:0;left:0;width:100%;height:100vh;background:#000000b3;z-index:2900;opacity:0;visibility:hidden;transition:opacity .4s var(--ease-out-expo),visibility .4s;backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px);will-change:opacity,backdrop-filter}.mobile-nav-overlay.active{opacity:1;visibility:visible;z-index:2999;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.mobile-menu-btn{z-index:3100}@media(min-width:769px)and (max-width:1024px){.section-scroll-content{padding-left:5%;padding-right:5%}.hero-text h1{font-size:2.8rem}.skills-showcase{grid-template-columns:repeat(2,1fr);gap:30px}.works-gallery{grid-template-columns:repeat(2,1fr)}}@media(min-width:481px)and (max-width:768px){.mobile-menu-btn{display:inline-flex}.nav-links{display:none}.section-scroll-content{padding:90px 5% 80px}h2.section-title{font-size:2rem;margin-bottom:40px;padding-top:20px;flex-shrink:0}#home .section-scroll-content{flex-direction:column;align-items:flex-start;justify-content:flex-start}.hero-text{padding-right:0;margin-top:20px;text-align:center;order:2}.hero-text h1{font-size:2.8rem}.hero-img{height:35vh;width:100%;order:1;margin-top:0;display:flex;align-items:flex-start;justify-content:center}.hero-img img{object-fit:contain;object-position:center top}.works-gallery{grid-template-columns:1fr;height:auto;max-height:none;overflow-y:visible;margin-top:20px}.skills-showcase{grid-template-columns:1fr;gap:20px;margin-top:20px}.skill-block{padding:25px}.work-info{bottom:20px;left:20px}header{padding:0 20px}.logo{font-size:1rem}}@media(max-width:480px){.mobile-menu-btn{display:inline-flex}.nav-links{display:none}:root{--nav-height: 70px}.section-scroll-content{padding:70px 5% 80px}h2.section-title{font-size:1.5rem;margin-bottom:30px;padding-top:20px;flex-shrink:0}h2.section-title span.sub{font-size:.75rem}#home .section-scroll-content{flex-direction:column;align-items:flex-start;justify-content:flex-start}.hero-text{padding-right:0;margin-top:15px;text-align:center;order:2;z-index:2;flex-shrink:0}.hero-text h1{font-size:2.2rem;line-height:1.2;text-shadow:0 2px 10px rgba(0,0,0,.8);margin-bottom:10px}.hero-text p{font-size:.9rem;margin-bottom:5px}.hero-img{width:100%;height:55vh;order:1;margin-top:0;display:flex;align-items:center;justify-content:center;flex-shrink:0}.hero-img img{object-fit:cover;object-position:center 20%;height:100%;width:auto;max-width:100%}.btn-connect{padding:8px 25px;margin-top:20px}.btn-connect .en{font-size:.8rem}.btn-connect .cn{font-size:.65rem}.works-gallery{grid-template-columns:1fr;height:auto;max-height:none;overflow-y:visible;margin-top:20px}.work-item{height:200px}.work-info{bottom:20px;left:20px}.work-info h4{font-size:1rem}.work-info p{font-size:.85rem}.skills-showcase{grid-template-columns:1fr;gap:15px;margin-top:20px}.skill-block{padding:20px}.skill-header{margin-bottom:15px}.skill-header i{font-size:1.5rem}.skill-cat{font-size:1rem}.skill-items li{font-size:.85rem}.blog-grid{grid-template-columns:1fr;gap:20px;margin-top:20px}.blog-card{padding:20px}.blog-card h3{font-size:1.1rem}.share-grid{grid-template-columns:1fr;gap:15px;margin-top:20px}.tool-card{padding:20px}header{padding:0 15px;height:var(--nav-height)}.logo{font-size:1rem}.logo img{width:36px;height:36px}.mobile-menu-btn{font-size:1.5rem;padding:6px}.mobile-nav{width:60%;max-width:220px;padding:70px 20px 20px}.mobile-nav-link .en{font-size:.95rem}.mobile-nav-link .cn{font-size:.7rem}}@media(max-height:600px)and (orientation:landscape){.mobile-menu-btn{display:inline-flex}.nav-links{display:none}.mobile-nav{width:45%;max-width:260px;height:100vh;padding:70px 20px 20px;overflow-y:auto;-webkit-overflow-scrolling:touch}.mobile-nav-overlay{z-index:2999}.mobile-nav.active{z-index:3000}.mobile-nav-link{padding:12px 0}.mobile-nav-link .en{font-size:1rem}.mobile-nav-link .cn{font-size:.75rem}.section-scroll-content{padding:55px 5% 15px}h2.section-title{font-size:1.4rem;margin-bottom:20px;padding-top:10px}h2.section-title span.sub{font-size:.7rem}#home .section-scroll-content{flex-direction:row!important;justify-content:center;align-items:center;gap:4%}.hero-text{padding-right:0;margin-top:0;text-align:left;order:1;z-index:2;flex:0 0 48%;max-width:48%;flex-shrink:0}.hero-text h1{font-size:1.8rem;line-height:1.15;margin-bottom:8px}.hero-text p{font-size:.8rem;line-height:1.4}.hero-img{flex:0 0 48%;height:70vh;width:auto;max-width:48%;order:2;margin-top:0;display:flex;align-items:center;justify-content:center}.hero-img img{object-fit:cover;object-position:center center;height:100%;width:100%;max-width:100%;border-radius:8px}.btn-connect{padding:6px 20px;margin-top:15px}.btn-connect .en{font-size:.75rem}.btn-connect .cn{font-size:.6rem}.skills-showcase{grid-template-columns:repeat(2,1fr);gap:12px;margin-top:15px}.skill-block{padding:15px}.skill-header{margin-bottom:12px;gap:10px}.skill-header i{font-size:1.4rem}.skill-cat{font-size:.9rem}.skill-items li{font-size:.8rem;padding-left:12px}.works-gallery{grid-template-columns:repeat(2,1fr);gap:12px;height:auto;max-height:none;overflow-y:visible;margin-top:15px}.work-item{height:130px}.work-info{bottom:12px;left:12px}.work-info h4{font-size:.85rem;margin-bottom:2px}.work-info p{font-size:.7rem}.blog-grid{grid-template-columns:repeat(2,1fr);gap:15px;margin-top:15px}.blog-card{padding:18px}.blog-card h3{font-size:.9rem}.blog-card p{font-size:.75rem;margin-top:6px}.share-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin-top:15px}.tool-card{padding:15px}.tool-icon{font-size:1.5rem}footer{padding:15px;font-size:.7rem}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes fadeInBlur{0%{opacity:0;filter:blur(10px)}to{opacity:1;filter:blur(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-60px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(60px)}to{opacity:1;transform:translate(0)}}@keyframes glowPulse{0%,to{box-shadow:0 0 20px var(--glow-primary)}50%{box-shadow:0 0 40px var(--glow-primary),0 0 60px var(--glow-secondary)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes rotateGradient{0%{--gradient-angle: 0deg}to{--gradient-angle: 360deg}}.animate-fade-up{opacity:0;transform:translateY(40px);transition:opacity .6s var(--ease-out-expo),transform .6s var(--ease-out-expo)}.animate-fade-up.visible{opacity:1;transform:translateY(0)}.animate-fade-scale{opacity:0;transform:scale(.95);transition:opacity .5s var(--ease-out-quint),transform .5s var(--ease-out-quint)}.animate-fade-scale.visible{opacity:1;transform:scale(1)}.animate-slide-left{opacity:0;transform:translate(-60px);transition:opacity .6s var(--ease-out-expo),transform .6s var(--ease-out-expo)}.animate-slide-left.visible{opacity:1;transform:translate(0)}.animate-slide-right{opacity:0;transform:translate(60px);transition:opacity .6s var(--ease-out-expo),transform .6s var(--ease-out-expo)}.animate-slide-right.visible{opacity:1;transform:translate(0)}.stagger-children>*:nth-child(1){transition-delay:0s}.stagger-children>*:nth-child(2){transition-delay:.08s}.stagger-children>*:nth-child(3){transition-delay:.16s}.stagger-children>*:nth-child(4){transition-delay:.24s}.stagger-children>*:nth-child(5){transition-delay:.32s}.stagger-children>*:nth-child(6){transition-delay:.4s}.stagger-children>*:nth-child(7){transition-delay:.48s}.stagger-children>*:nth-child(8){transition-delay:.56s}.hover-lift{transition:transform .4s var(--ease-out-back),box-shadow .4s var(--ease-out-quint)}.hover-lift:hover{transform:translateY(-8px);box-shadow:0 20px 40px #0000004d,0 0 0 1px #ffffff0d}.hover-glow{transition:box-shadow .3s var(--ease-out-quint)}.hover-glow:hover{box-shadow:0 0 30px var(--glow-primary)}.magnetic-btn{position:relative;transition:transform .3s var(--ease-out-back)}.text-reveal{overflow:hidden}.text-reveal span{display:inline-block;transform:translateY(100%);opacity:0;transition:transform .6s var(--ease-out-expo),opacity .6s ease}.text-reveal.visible span{transform:translateY(0);opacity:1}.img-zoom{overflow:hidden}.img-zoom img{transition:transform .6s var(--ease-out-quint)}.img-zoom:hover img{transform:scale(1.08)}.perspective-container{perspective:1000px}.tilt-card{transform-style:preserve-3d;transition:transform .1s ease-out}html{scroll-behavior:smooth}@media(forced-colors:active){.unified-card,.card,.project-card,.blog-card-home,.btn-connect,.btn-primary-unified,.mobile-menu-btn,.category-tab,.email-item{border:1px solid CanvasText!important;background:Canvas!important;color:CanvasText!important;box-shadow:none!important}#section-nav-dots,#mobile-progress{display:none!important}}*:focus-visible{outline:2px solid var(--text-main);outline-offset:2px}button:focus-visible,a:focus-visible{box-shadow:0 0 0 3px #fff3}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.animate-fade-up,.animate-fade-scale,.animate-slide-left,.animate-slide-right{opacity:1;transform:none;transition:none}}@media(pointer:coarse){.btn-connect,.btn-primary-unified,.mobile-menu-btn,.mobile-nav-link,.category-tab,.email-item,.social-link{min-height:44px;min-width:44px}}[data-animate]{opacity:0;will-change:opacity,transform}[data-animate=fade-up]{transform:translateY(30px)}[data-animate=fade-down]{transform:translateY(-20px)}[data-animate=fade-scale]{transform:scale(.96)}[data-animate=slide-left]{transform:translate(30px)}[data-animate=slide-right]{transform:translate(-30px)}[data-animate=blur-in]{filter:blur(8px);transform:scale(.98)}[data-animate].animate-in{opacity:1;transform:translateY(0) translate(0) scale(1);filter:blur(0);transition:opacity .8s var(--ease-out-expo),transform .8s var(--ease-out-expo),filter .6s var(--ease-out-quart)}[data-animate][data-delay="1"]{transition-delay:.1s}[data-animate][data-delay="2"]{transition-delay:.2s}[data-animate][data-delay="3"]{transition-delay:.3s}[data-animate][data-delay="4"]{transition-delay:.4s}[data-animate][data-delay="5"]{transition-delay:.5s}.page-header[data-animate]{opacity:0;transform:translateY(20px)}.page-header.animate-in{opacity:1;transform:translateY(0);transition:opacity .9s var(--ease-out-expo),transform .9s var(--ease-out-expo)}.page-header .en{display:block;opacity:0;transform:translateY(15px);transition:opacity .7s var(--ease-out-expo) .1s,transform .7s var(--ease-out-expo) .1s}.page-header .cn{display:block;opacity:0;transform:translateY(10px);transition:opacity .6s var(--ease-out-expo) .2s,transform .6s var(--ease-out-expo) .2s}.page-header.animate-in .en,.page-header.animate-in .cn{opacity:1;transform:translateY(0)}.post-card[data-animate],.project-card[data-animate]{opacity:0;transform:translateY(40px) scale(.98)}.post-card.animate-in,.project-card.animate-in{opacity:1;transform:translateY(0) scale(1);transition:opacity .8s var(--ease-out-expo),transform .8s var(--ease-out-expo),box-shadow .4s var(--ease-out-quart),border-color .3s ease}.post-card:hover,.project-card:hover{transform:translateY(-8px) scale(1.01);transition:transform .4s var(--ease-out-back),box-shadow .4s var(--ease-out-quart),border-color .3s ease}.post-card.animate-in:hover,.project-card.animate-in:hover{transform:translateY(-8px) scale(1.01)}.post-card-visual,.project-image-wrapper{overflow:hidden;position:relative}.post-card-visual:after,.project-image-wrapper:after{content:"";position:absolute;inset:0;background:var(--card-bg);transform:translateY(0);transition:transform .8s var(--ease-out-expo);z-index:2}.post-card.animate-in .post-card-visual:after,.project-card.animate-in .project-image-wrapper:after{transform:translateY(100%)}.post-card-visual img,.project-image-wrapper img{transform:scale(1.1);transition:transform .8s var(--ease-out-expo)}.post-card.animate-in .post-card-visual img,.project-card.animate-in .project-image-wrapper img{transform:scale(1)}a:not(.btn):not(.post-card-link):not(.project-card){position:relative;transition:color .3s ease}:where(.btn,.btn-connect,.btn-primary-unified,.mobile-menu-btn,.category-tab,.social-modal-close,.email-item){position:relative;overflow:hidden;transition:transform .3s var(--ease-out-back),box-shadow .3s ease,border-color .3s ease,background-color .3s ease,color .3s ease}.btn:before,.btn-connect:before{display:none}:where(.btn,.btn-connect,.btn-primary-unified,.mobile-menu-btn,.category-tab,.social-modal-close,.email-item):hover{transform:translateY(var(--btn-hover-lift));box-shadow:var(--btn-hover-shadow)}.btn:hover:before,.btn-connect:hover:before{display:none}:where(.btn,.btn-connect,.btn-primary-unified,.mobile-menu-btn,.category-tab,.social-modal-close,.email-item):active{transform:translateY(0);transition:transform .1s ease}:where(.btn,.btn-connect,.btn-primary-unified,.mobile-menu-btn,.category-tab,.social-modal-close,.email-item):focus-visible{outline:none;box-shadow:var(--btn-hover-shadow),var(--btn-focus-ring)}.nav-link{position:relative;transition:color .3s ease}.project-category,.post-date{transition:color .3s ease,letter-spacing .3s ease}.project-card:hover .project-category{letter-spacing:2px}.post-gradient,.project-gradient-overlay{transition:opacity .5s var(--ease-out-quart),transform .7s var(--ease-out-expo)}@media(max-width:768px){[data-animate]{transform:translateY(20px)}[data-animate=fade-scale]{transform:scale(.98)}[data-animate].animate-in{transition:opacity .6s var(--ease-out-quart),transform .6s var(--ease-out-quart)}.post-card[data-animate],.project-card[data-animate]{transform:translateY(25px)}.post-card.animate-in,.project-card.animate-in{transition:opacity .6s var(--ease-out-quart),transform .6s var(--ease-out-quart)}.post-card-visual:after,.project-image-wrapper:after{display:none}.post-card-visual img,.project-image-wrapper img{transform:none}.post-card:hover,.project-card:hover{transform:translateY(-4px)}.btn:hover,.btn-connect:hover{transform:translateY(-1px)}}@media(min-width:769px)and (max-width:1024px){[data-animate].animate-in{transition:opacity .7s var(--ease-out-expo),transform .7s var(--ease-out-expo)}}@media(prefers-reduced-motion:reduce){[data-animate]{opacity:1;transform:none;filter:none;transition:none!important}[data-animate].animate-in{transition:none!important}.post-card-visual:after,.project-image-wrapper:after{display:none}}.sub-page,.page-content-unified{max-width:1200px;margin:0 auto;padding:calc(var(--nav-height) + 60px) clamp(24px,5vw,80px) 80px;min-height:100vh;width:100%;box-sizing:border-box}.stacked-page-shell{max-width:1200px;margin:0 auto;width:100%;box-sizing:border-box;padding:0 clamp(24px,5vw,80px)}.stacked-page-section .section-scroll-content{padding:calc(var(--nav-height) + 60px) 0 calc(80px + env(safe-area-inset-bottom))}.sub-page .page-header,.page-content-unified .page-header,.stacked-page-shell .page-header{margin-bottom:clamp(32px,5vw,56px)}.sub-page .page-title,.page-content-unified .page-title,.stacked-page-shell .page-title{font-size:clamp(2.2rem,5vw,3.8rem);font-weight:300;letter-spacing:-.03em;line-height:1.1;display:flex;flex-direction:column;gap:6px}.sub-page .page-title .en,.page-content-unified .page-title .en,.stacked-page-shell .page-title .en{display:block;font-weight:300;color:var(--text-main);letter-spacing:-.02em}.sub-page .page-title .cn,.page-content-unified .page-title .cn,.stacked-page-shell .page-title .cn{display:block;font-size:.4em;color:var(--text-muted);font-weight:400;letter-spacing:.02em;margin-top:4px}.sub-page .content-grid,.page-content-unified .content-grid,.stacked-page-shell .content-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-top:32px}.sub-page .unified-card,.page-content-unified .unified-card,.stacked-page-shell .unified-card,.sub-page .card,.page-content-unified .card,.stacked-page-shell .card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;padding:28px;transition:all .35s var(--ease-out-expo);text-decoration:none;color:inherit;display:flex;flex-direction:column;position:relative;overflow:hidden;box-shadow:0 4px 20px #0003}.sub-page .unified-card:hover,.page-content-unified .unified-card:hover,.stacked-page-shell .unified-card:hover,.sub-page .card:hover,.page-content-unified .card:hover,.stacked-page-shell .card:hover{transform:translateY(-4px);border-color:#ffffff1a;background:#ffffff08;box-shadow:0 16px 48px #00000059}.sub-page .card-icon-header,.page-content-unified .card-icon-header,.stacked-page-shell .card-icon-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;font-family:var(--font-mono);font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);transition:color .3s ease}.sub-page .card-icon-header i,.page-content-unified .card-icon-header i,.stacked-page-shell .card-icon-header i{font-size:1.4rem;color:var(--text-muted);transition:all .4s var(--ease-out-expo)}.sub-page .unified-card:hover .card-icon-header,.page-content-unified .unified-card:hover .card-icon-header,.stacked-page-shell .unified-card:hover .card-icon-header{color:var(--text-main)}.sub-page .unified-card:hover .card-icon-header i,.page-content-unified .unified-card:hover .card-icon-header i,.stacked-page-shell .unified-card:hover .card-icon-header i{color:var(--text-main);transform:scale(1.1)}.sub-page .card-items,.sub-page .card-list,.page-content-unified .card-items,.page-content-unified .card-list,.stacked-page-shell .card-items,.stacked-page-shell .card-list{list-style:none;display:flex;flex-direction:column;gap:10px;margin-top:auto}.sub-page .card-items li,.sub-page .card-list li,.page-content-unified .card-items li,.page-content-unified .card-list li,.stacked-page-shell .card-items li,.stacked-page-shell .card-list li{color:var(--text-muted);font-size:.88rem;padding-left:16px;position:relative;transition:color .3s ease;line-height:1.5}.sub-page .card-items li:before,.sub-page .card-list li:before,.page-content-unified .card-items li:before,.page-content-unified .card-list li:before,.stacked-page-shell .card-items li:before,.stacked-page-shell .card-list li:before{content:"·";position:absolute;left:0;color:var(--text-muted);font-size:1.2em;line-height:1;top:2px}.sub-page .unified-card:hover .card-items li,.sub-page .unified-card:hover .card-list li,.page-content-unified .unified-card:hover .card-items li,.page-content-unified .unified-card:hover .card-list li,.stacked-page-shell .unified-card:hover .card-items li,.stacked-page-shell .unified-card:hover .card-list li{color:#fffc}.sub-page .section-title,.page-content-unified .section-title,.stacked-page-shell .section-title{font-size:clamp(1.6rem,3vw,2.4rem);font-weight:300;margin-bottom:32px;line-height:1.2;letter-spacing:-.02em;display:flex;flex-direction:column;gap:4px}.sub-page .section-title span.sub,.page-content-unified .section-title span.sub,.stacked-page-shell .section-title span.sub{color:var(--text-muted);font-size:.75rem;display:block;margin-bottom:8px;letter-spacing:.2em;text-transform:uppercase;font-family:var(--font-mono);font-weight:400}.sub-page .section-title .en,.page-content-unified .section-title .en,.stacked-page-shell .section-title .en{display:block;font-weight:300}.sub-page .section-title .cn,.page-content-unified .section-title .cn,.stacked-page-shell .section-title .cn{display:block;font-size:.5em;color:var(--text-muted);font-weight:400}.hero-text[data-animate]{opacity:0;transform:translateY(30px)}.hero-text.animate-in{opacity:1;transform:translateY(0);transition:opacity .9s var(--ease-out-expo),transform .9s var(--ease-out-expo)}.hero-text h1{overflow:hidden}.hero-text h1 .en{display:inline-block;opacity:0;transform:translateY(100%);transition:opacity .8s var(--ease-out-expo) .1s,transform .8s var(--ease-out-expo) .1s}.hero-text.animate-in h1 .en{opacity:1;transform:translateY(0)}.skill-card[data-animate]{opacity:0;transform:translateY(30px) scale(.98)}.skill-card.animate-in{opacity:1;transform:translateY(0) scale(1);transition:opacity .7s var(--ease-out-expo),transform .7s var(--ease-out-expo),box-shadow .4s ease,border-color .3s ease}.timeline-item[data-animate]{opacity:0;transform:translate(-20px)}.timeline-item.animate-in{opacity:1;transform:translate(0);transition:opacity .6s var(--ease-out-expo),transform .6s var(--ease-out-expo)}.reveal-on-scroll{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}.reveal-on-scroll.revealed{opacity:1;transform:translateY(0)}.card-unified{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--card-radius);padding:var(--card-padding);min-height:var(--card-min-height);display:flex;flex-direction:column;transition:var(--card-transition);box-shadow:0 4px 20px #0003}.card-unified:hover{transform:translateY(var(--card-hover-lift));border-color:#ffffff1f;box-shadow:0 12px 40px #00000059}.card-unified .card-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.card-unified .card-header i{font-size:1.5rem;color:var(--text-muted);transition:all .3s var(--ease-out-expo)}.card-unified:hover .card-header i{color:var(--text-main);transform:scale(1.1)}.card-unified .card-header span{font-family:var(--font-mono);font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);transition:color .3s ease}.card-unified:hover .card-header span{color:var(--text-main)}.card-unified .card-list{margin-top:auto;list-style:none}.card-unified .card-list li{color:var(--text-muted);font-size:.9rem;line-height:1.6;transition:color .3s ease}.card-unified:hover .card-list li{color:#ffffffd9}.grid-unified{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--card-gap);margin-top:32px}@media(max-width:768px){.mobile-nav{transform:translate(100%);transition:transform .5s var(--ease-out-expo)}.mobile-nav.active{transform:translate(0)}[data-animate]{opacity:0;transform:translateY(20px)}[data-animate].animate-in{opacity:1;transform:translateY(0);transition:opacity .6s var(--ease-out-quart),transform .6s var(--ease-out-quart)}.card-unified:hover,.post-card:hover,.project-card:hover{transform:translateY(-2px)}.btn:hover,.btn-connect:hover{transform:translateY(-1px)}.grid-unified{grid-template-columns:1fr;gap:var(--gap-compact);margin-top:var(--mt-compact)}.card-unified{padding:var(--pad-compact);min-height:auto}.page-content-unified{animation:mobilePageEntry .5s var(--ease-out-expo) forwards}@keyframes mobilePageEntry{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}}@media(min-width:769px)and (max-width:1024px){.grid-unified{grid-template-columns:repeat(2,1fr);gap:20px}}@media(max-width:1024px){.sub-page,.page-content-unified{padding:calc(var(--nav-height) + 40px) clamp(20px,4vw,48px) 60px}.stacked-page-section .section-scroll-content{padding:calc(var(--nav-height) + 40px) 0 calc(60px + env(safe-area-inset-bottom))}.stacked-page-shell{padding:0 clamp(20px,4vw,48px)}}@media(max-width:768px){.sub-page,.page-content-unified{padding:calc(var(--nav-height) + 24px) clamp(16px,4vw,24px) 48px}.stacked-page-section .section-scroll-content{padding:calc(var(--nav-height) + 24px) 0 calc(48px + env(safe-area-inset-bottom))}.stacked-page-shell{padding:0 clamp(16px,4vw,24px)}.sub-page .page-title,.page-content-unified .page-title,.stacked-page-shell .page-title{font-size:clamp(1.8rem,6vw,2.4rem)}.sub-page .section-title,.page-content-unified .section-title,.stacked-page-shell .section-title{font-size:clamp(1.4rem,4vw,1.8rem);margin-bottom:24px}.sub-page .content-grid,.page-content-unified .content-grid,.stacked-page-shell .content-grid{grid-template-columns:1fr;gap:var(--gap-compact);margin-top:var(--mt-compact)}.sub-page .unified-card,.sub-page .card,.page-content-unified .unified-card,.page-content-unified .card,.stacked-page-shell .unified-card,.stacked-page-shell .card{padding:var(--pad-compact)}}#about .unified-card,#blog .unified-card,#portfolio .unified-card,#share .unified-card{padding:var(--card-padding);min-height:220px}#about .card-icon-header,#blog .card-icon-header,#portfolio .card-icon-header,#share .card-icon-header{font-size:.8rem;margin-bottom:18px}#about .card-icon-header i,#blog .card-icon-header i,#portfolio .card-icon-header i,#share .card-icon-header i{font-size:1.5rem}#about .card-items li,#blog .card-items li,#portfolio .card-items li,#share .card-items li{font-size:.95rem;line-height:1.6}.content-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-top:32px}.unified-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--card-radius);padding:var(--card-padding);transition:var(--card-transition);box-shadow:0 4px 20px #0003;text-decoration:none;color:inherit;display:flex;flex-direction:column;position:relative;overflow:hidden}.unified-card:hover{transform:translateY(var(--card-hover-lift));border-color:#ffffff1f;box-shadow:0 16px 48px #00000059}.card-icon-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;font-family:var(--font-mono);font-size:var(--type-kicker);font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);transition:color .3s ease}.card-icon-header i{font-size:1.4rem;transition:all .4s var(--ease-out-expo)}.unified-card:hover .card-icon-header{color:var(--text-main)}.unified-card:hover .card-icon-header i{color:var(--text-main);transform:scale(1.1)}.card-items{list-style:none;display:flex;flex-direction:column;gap:8px}.card-items li{color:var(--text-muted);font-size:var(--type-body);padding-left:16px;position:relative;transition:color .3s ease}.card-items li:before{content:"·";position:absolute;left:0;color:var(--text-muted);font-size:1.2em;line-height:1}.unified-card:hover .card-items li{color:#ffffffd9}.skill-card{min-height:var(--card-min-height)}.blog-card-home{min-height:240px}.blog-card-home .card-meta{display:flex;align-items:center;gap:16px;margin-bottom:18px}.blog-card-home .card-num{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted);opacity:.5}.blog-card-home .card-date{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted)}.blog-card-home .card-titles{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.blog-card-home .title-en{font-size:var(--type-title);font-weight:500;color:var(--text-main);transition:color .3s ease}.blog-card-home .title-cn{font-size:var(--type-subtitle);color:var(--text-muted);transition:color .3s ease}.blog-card-home:hover .title-en{color:#fff}.blog-card-home:hover .title-cn{color:#fffc}.blog-card-home .card-excerpt{font-size:var(--type-body);color:var(--text-muted);line-height:1.65;margin-top:auto;transition:color .3s ease}.blog-card-home:hover .card-excerpt{color:#ffffffb3}.works-grid-home{grid-template-columns:repeat(2,1fr)}.work-card{overflow:hidden}.work-card .work-image-wrapper{position:relative;height:240px;border-radius:calc(var(--card-radius) - 4px);overflow:hidden;margin-bottom:16px}.work-card .work-image-wrapper img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease-out-expo)}.work-card:hover .work-image-wrapper img{transform:scale(1.08)}.work-card .work-info{padding:0;display:flex;flex-direction:column;gap:8px}.work-card .work-category{font-family:var(--font-mono);font-size:.65rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted);transition:color .3s ease}.work-card:hover .work-category{color:#ffffffb3}.work-card .work-titles{display:flex;flex-direction:column;gap:4px}.work-card .work-titles .title-en{font-size:var(--type-title);font-weight:600;color:var(--text-main);transition:color .3s ease}.work-card .work-titles .title-cn{font-size:var(--type-subtitle);color:var(--text-muted);transition:color .3s ease}.work-card:hover .work-titles .title-en{color:#fff}.work-card:hover .work-titles .title-cn{color:#ffffffbf}.tools-grid-home{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.tool-card{align-items:center;text-align:center;min-height:220px;justify-content:center}.tool-card .tool-icon-wrapper{width:70px;height:70px;display:flex;align-items:center;justify-content:center;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:var(--card-radius);margin-bottom:var(--space-sm);transition:all .4s var(--ease-out-expo)}.tool-card:hover .tool-icon-wrapper{background:#ffffff0f;border-color:#ffffff1a;transform:scale(1.05)}.tool-card .tool-icon-wrapper i{font-size:2.15rem;color:var(--text-muted);transition:all .4s var(--ease-out-expo)}.tool-card:hover .tool-icon-wrapper i{color:var(--text-main)}.tool-card .tool-content{display:flex;flex-direction:column;gap:var(--space-2xs)}.tool-card .tool-name{font-family:var(--font-mono);font-size:var(--type-body);font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-main)}.tool-card .tool-desc{font-size:var(--type-body);color:var(--text-muted);transition:color .3s ease}.tool-card:hover .tool-desc{color:#fffc}.skills-cta{margin-top:40px;display:flex;justify-content:center}section footer{margin-top:60px;text-align:center;padding:40px 0}section footer .text-group{display:flex;flex-direction:column;gap:4px}section footer .en{font-size:.75rem;color:var(--text-muted);font-family:var(--font-mono)}section footer .cn{font-size:.7rem;color:var(--text-muted);opacity:.7}@media(max-width:768px){#about .unified-card,#blog .unified-card,#portfolio .unified-card,#share .unified-card{padding:var(--pad-compact);min-height:auto}.content-grid{grid-template-columns:1fr;gap:var(--gap-compact);margin-top:var(--mt-compact)}.works-grid-home{grid-template-columns:1fr}.tools-grid-home{grid-template-columns:repeat(2,1fr)}.unified-card{padding:var(--pad-compact);min-height:auto}.blog-card-home{min-height:auto}.work-card .work-image-wrapper{height:var(--work-image-compact)}.work-card .work-info{padding:var(--gap-compact)}.tool-card{min-height:auto;padding:var(--pad-compact)}.tool-card .tool-icon-wrapper{width:var(--icon-compact);height:var(--icon-compact);margin-bottom:var(--icon-mb-compact)}.tool-card .tool-icon-wrapper i{font-size:1.5rem}.skills-cta{margin-top:var(--mt-compact)}section footer{margin-top:40px;padding:24px 0}}@media(max-width:480px){.tools-grid-home{grid-template-columns:1fr}.tool-card{flex-direction:row;align-items:center;text-align:left;gap:var(--gap-compact)}.tool-card .tool-icon-wrapper{margin-bottom:0}.tool-card .tool-content{align-items:flex-start}}@media(min-width:769px)and (max-width:1024px){.content-grid{grid-template-columns:repeat(2,1fr);gap:20px}.skills-grid-home,.tools-grid-home{grid-template-columns:repeat(2,1fr)}}.project-page-unified{width:100%;min-height:100vh}.project-page-unified section{position:fixed;inset:0;width:100%;height:calc(var(--vvh, 1vh) * 100);height:100vh;height:100dvh;background-color:var(--bg-color);box-shadow:0 -20px 60px #000c;border-top:1px solid #111;overflow:hidden;transform:translateY(100%);z-index:1}.project-page-unified section:first-child{transform:translateY(0);z-index:1;box-shadow:none;border-top:none}.project-page-unified .section-scroll-content{position:absolute;inset:0;overflow-y:auto;overflow-x:hidden;padding:calc(var(--nav-height) + 40px) clamp(20px,4vw,56px) 60px;display:flex;flex-direction:column;justify-content:center;min-height:100vh;box-sizing:border-box}.project-header-unified{margin-bottom:24px}.project-header-unified .project-category{display:block;color:var(--text-muted);font-size:.8rem;text-transform:uppercase;letter-spacing:2px;margin-bottom:12px;font-family:var(--font-mono)}.project-header-unified .project-title{font-size:2.4rem;font-weight:300;line-height:1.2;display:flex;flex-direction:column}.project-header-unified .project-title .cn{font-size:1.1rem;color:var(--text-muted);margin-top:8px}.project-image-unified{margin:24px 0;border-radius:var(--card-radius);overflow:hidden;border:1px solid var(--card-border)}.project-image-unified img{width:100%;height:auto;max-height:280px;object-fit:cover;display:block}.project-intro-unified{margin-top:8px}.project-intro-unified p{color:var(--text-muted);line-height:1.8;font-size:1rem;margin-bottom:20px;max-width:70ch}.tech-tags-unified{display:flex;flex-wrap:wrap;gap:10px}.tech-tags-unified span{padding:6px 14px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:20px;font-size:.8rem;color:var(--text-muted);font-family:var(--font-mono);transition:all .3s ease}.tech-tags-unified span:hover{background:#ffffff1a;border-color:#fff3;color:var(--text-main)}.section-title-unified{font-size:1.6rem;font-weight:300;margin-bottom:24px;margin-top:0}.content-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.content-cards-grid.two-cols{grid-template-columns:repeat(2,1fr)}.content-cards-grid.three-cols{grid-template-columns:repeat(3,1fr)}.info-card{background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:24px;transition:all .3s var(--ease-out-expo)}.info-card:hover{background:#ffffff0d;border-color:#ffffff1f;transform:translateY(-3px)}.info-card h3{font-size:1rem;font-weight:500;margin-bottom:10px;color:var(--text-main)}.info-card h4{font-size:.95rem;font-weight:500;margin-bottom:8px;color:var(--text-main)}.info-card p{font-size:.9rem;color:var(--text-muted);line-height:1.6;margin:0}.highlight-box{background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:24px;margin-top:24px}.highlight-box h3{font-size:1.1rem;font-weight:500;margin-bottom:16px;margin-top:0}.arch-diagram-unified{display:flex;flex-direction:column;align-items:center;gap:8px}.arch-layer{width:100%;display:flex;justify-content:center}.arch-box{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:15px 25px;text-align:center;font-size:.9rem;min-width:280px;max-width:400px}.arch-box small{color:var(--text-muted);font-size:.8rem}.arch-arrow{color:var(--text-muted);font-size:1.2rem}.step-list{display:flex;flex-direction:column;gap:16px}.step-item{display:flex;gap:16px;align-items:flex-start}.step-num{width:36px;height:36px;background:#ffffff14;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem;flex-shrink:0;color:var(--text-main)}.step-content{flex:1;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:20px}.step-content h4{font-size:1rem;font-weight:500;margin-bottom:8px;color:var(--text-main);margin-top:0}.step-content p{font-size:.9rem;color:var(--text-muted);line-height:1.7;margin:0}.two-col-layout{display:grid;grid-template-columns:1fr 1fr;gap:40px}.two-col-layout .col-wide{grid-template-columns:2fr 1fr}.code-block-unified{background:#0006;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:16px;overflow-x:auto;margin-bottom:16px}.code-block-unified pre{margin:0;font-family:Consolas,Monaco,monospace;font-size:.8rem;line-height:1.5;color:#ccc}.feature-list-unified{list-style:none}.feature-list-unified li{color:var(--text-muted);font-size:.9rem;position:relative;padding:8px 0 8px 24px}.feature-list-unified li:before{content:"✓";position:absolute;left:0;color:#4ade80}.numbered-list{list-style:none;counter-reset:item-counter}.numbered-list li{position:relative;padding-left:32px;margin-bottom:12px;color:var(--text-muted);line-height:1.7;font-size:.9rem}.numbered-list li:before{counter-increment:item-counter;content:counter(item-counter);position:absolute;left:0;top:2px;width:22px;height:22px;background:#ffffff14;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;color:var(--text-main)}.arrow-list{list-style:none}.arrow-list li{position:relative;padding-left:24px;margin-bottom:12px;color:var(--text-muted);line-height:1.7}.arrow-list li:before{content:"→";position:absolute;left:0;color:var(--text-muted)}.github-section-unified{display:grid;grid-template-columns:2fr 1fr;gap:40px;align-items:center}.github-desc{color:var(--text-muted);font-size:1rem;line-height:1.7;margin-bottom:24px}.github-stats{display:flex;gap:30px}.github-stat-item{display:flex;align-items:center;gap:10px;color:var(--text-muted);font-size:.9rem}.github-stat-item i{font-size:1.5rem}.btn-primary-unified{display:inline-flex;align-items:center;gap:10px;padding:12px 28px;background:var(--text-main);color:var(--bg-color);border:1px solid rgba(255,255,255,.25);border-radius:3px;font-weight:700;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;font-family:var(--font-mono);text-decoration:none;transition:all .3s var(--ease-out-expo);cursor:pointer}.btn-primary-unified:hover{transform:translateY(var(--btn-hover-lift));box-shadow:var(--btn-hover-shadow);background:#ffffffeb;color:#111}.btn-primary-unified i{font-size:1.3rem}@media(max-width:768px){.project-page-unified .section-scroll-content{padding:calc(var(--nav-height) + 20px) 5% 40px;justify-content:flex-start}.project-header-unified{margin-bottom:20px}.project-header-unified .project-category{font-size:.7rem;letter-spacing:1.5px}.project-header-unified .project-title{font-size:1.6rem}.project-header-unified .project-title .cn{font-size:1rem;margin-top:6px}.project-image-unified{margin:16px 0}.project-image-unified img{max-height:180px}.project-intro-unified p{font-size:.9rem;line-height:1.7}.tech-tags-unified{gap:8px}.tech-tags-unified span{padding:5px 12px;font-size:.75rem}.section-title-unified{font-size:1.3rem;margin-bottom:20px}.content-cards-grid,.content-cards-grid.two-cols,.content-cards-grid.three-cols{grid-template-columns:1fr;gap:12px}.info-card{padding:18px}.info-card h3{font-size:.95rem}.info-card p{font-size:.85rem}.highlight-box{padding:18px;margin-top:20px}.arch-box{min-width:auto;width:100%;padding:12px 16px;font-size:.85rem}.step-item{gap:12px}.step-num{width:32px;height:32px;font-size:.9rem}.step-content{padding:16px}.step-content h4{font-size:.95rem}.step-content p{font-size:.85rem;line-height:1.6}.two-col-layout,.github-section-unified{grid-template-columns:1fr;gap:24px}.code-block-unified{padding:12px}.code-block-unified pre{font-size:.7rem}.btn-primary-unified{padding:14px 24px;font-size:.9rem}}@media(min-width:769px)and (max-width:1024px){.project-page-unified .section-scroll-content{padding:calc(var(--nav-height) + 28px) clamp(16px,3.5vw,36px) 50px}.content-cards-grid.three-cols{grid-template-columns:repeat(2,1fr)}.github-section-unified{grid-template-columns:1.5fr 1fr}}.back-button-fixed[data-astro-cid-37fxchfa]{position:fixed;top:100px;left:20px;z-index:999;display:flex;flex-direction:column;align-items:center;gap:4px;background:none;border:none;color:var(--text-muted, #888);cursor:pointer;padding:10px;font-family:inherit;transition:all .3s ease}.back-button-fixed[data-astro-cid-37fxchfa]:hover{color:var(--text-main, #fff);transform:translate(-3px)}.back-button-fixed[data-astro-cid-37fxchfa] i[data-astro-cid-37fxchfa]{font-size:1.5rem}.back-text[data-astro-cid-37fxchfa]{display:flex;flex-direction:column;align-items:center;font-size:.75rem}.back-text[data-astro-cid-37fxchfa] .cn[data-astro-cid-37fxchfa]{font-size:.65rem;opacity:.8}@media(max-width:1024px){.back-button-fixed[data-astro-cid-37fxchfa]{left:20px;top:90px}}@media(max-width:1024px){.back-button-nav[data-astro-cid-37fxchfa]{display:flex;align-items:center;justify-content:center}.back-button-fixed[data-astro-cid-37fxchfa]{display:none!important}}.nav-left[data-astro-cid-37fxchfa]{display:flex;align-items:center;gap:15px}.back-button-nav[data-astro-cid-37fxchfa]{display:none;background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;padding:5px;transition:color .3s ease}.back-button-nav[data-astro-cid-37fxchfa]:hover{color:var(--text-main)}@media(max-width:768px){.back-button-nav[data-astro-cid-37fxchfa]{display:flex;align-items:center;justify-content:center}.back-button-fixed[data-astro-cid-37fxchfa]{display:none!important}.nav-left[data-astro-cid-37fxchfa]{gap:10px}}.mobile-nav[data-astro-cid-37fxchfa].active~.back-button-fixed[data-astro-cid-37fxchfa],.mobile-nav-overlay[data-astro-cid-37fxchfa].active~.back-button-fixed[data-astro-cid-37fxchfa]{display:none}
