:root{--bg-color:#fdf9f9;--text-color:#b00020;--secondary-color:#e57373;--hairline:#ffcdd2;--accent:#8e0010;--font-main:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-mono:"SF Mono", "Menlo", "Monaco", "Courier New", monospace;--pad:24px}*{box-sizing:border-box;margin:0;padding:0}html{cursor:none}body{background-color:var(--bg-color);color:var(--text-color);font-family:var(--font-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;cursor:none;flex-direction:column;width:100vw;height:100vh;display:flex;overflow:hidden}#root{width:100vw;height:100vh;overflow:hidden}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:var(--bg-color)}::-webkit-scrollbar-thumb{background:var(--hairline);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:var(--secondary-color)}main{flex-direction:column;width:100vw;height:100vh;display:flex}#cursor-dot{background-color:var(--text-color);z-index:100000;pointer-events:none;border-radius:50%;width:6px;height:6px;transition:opacity .2s,background-color .2s;position:fixed;top:0;left:0;transform:translate(-50%,-50%)}#cursor-outline{border:1px solid var(--text-color);z-index:100000;pointer-events:none;border-radius:50%;width:40px;height:40px;transition:width .2s,height .2s,opacity .2s,border-color .2s,background-color .2s;position:fixed;top:0;left:0;transform:translate(-50%,-50%)}#cursor-dot,#cursor-outline,body.nav-open #cursor-dot,body.nav-open #cursor-outline{opacity:1!important}body.nav-open #cursor-dot{opacity:1!important;background-color:#fff!important}body.nav-open #cursor-outline{opacity:1!important;background-color:#0000!important;border-color:#fff!important}body.nav-open #cursor-outline.hovering{background-color:#fff!important;border-color:#fff!important}body.nav-open #cursor-dot.hovering,body.secondary-page #cursor-dot{background-color:var(--text-color)!important}body.secondary-page #cursor-outline{border-color:var(--text-color)!important}#cursor-outline.hovering,body.secondary-page #cursor-outline.hovering{background-color:#b0002033!important;width:60px!important;height:60px!important}.corner-index{font-family:var(--font-main);color:var(--text-color);pointer-events:none;font-size:2.5rem;font-weight:600;line-height:1;position:fixed;z-index:9999!important}.corner-index.tl{top:var(--pad);left:var(--pad)}.corner-index.tr{top:var(--pad);right:var(--pad)}.corner-index.bl{bottom:var(--pad);left:var(--pad)}.corner-index.br{bottom:var(--pad);right:var(--pad)}#nav-overlay{opacity:0;pointer-events:none;background:#b00020;justify-content:center;align-items:center;width:100vw;height:100vh;transition:opacity .4s;display:flex;position:fixed;top:0;left:0;z-index:99998!important}#nav-overlay.active{opacity:1;pointer-events:auto;pointer-events:auto!important}.nav-content{text-align:center;z-index:99999;flex-direction:column;gap:2rem;display:flex;position:relative;pointer-events:auto!important}.nav-item{color:#ffcdd2;cursor:pointer;z-index:9999;font-size:3.5rem;font-weight:600;transition:color .3s;position:relative;pointer-events:auto!important}.nav-item:hover{color:#fff}#canvas-zone{border-bottom:1px solid var(--hairline);width:100%;height:70vh;position:relative;overflow:hidden}#ascii-canvas{width:100%;height:100%;display:block}.hero-text{bottom:24px;left:var(--pad);pointer-events:auto;position:absolute}.hero-headline{letter-spacing:-.04em;color:var(--text-color);margin-bottom:8px;font-size:3.5rem;font-weight:600;line-height:1.1}.hero-subline{font-family:var(--font-mono);color:var(--secondary-color);font-size:.8rem}#panel-zone{width:100%;height:30vh;padding:var(--pad);grid-template-columns:2fr 1.5fr 1fr;align-content:start;gap:40px;font-size:.85rem;line-height:1.5;display:grid}.panel-col{flex-direction:column;gap:24px;display:flex}.meta-line{color:var(--secondary-color);text-transform:uppercase;letter-spacing:.05em;gap:12px;margin-bottom:4px;font-size:.75rem;display:flex}.bio-text{max-width:400px;color:var(--text-color)}.job-button{border:1px solid var(--hairline);cursor:pointer;background:0 0;border-radius:4px;align-items:center;gap:8px;padding:2px 10px;transition:all .3s;display:inline-flex}.job-button:hover{border-color:var(--accent);background:#b0002008}.job-indicator{background:#b00020;border-radius:50%;flex-shrink:0;width:4px;height:4px;animation:2s infinite pulse}@keyframes pulse{0%,to{opacity:1;box-shadow:0 0 #b0002066}50%{opacity:.8;box-shadow:0 0 0 8px #b0002000}}.job-text{color:var(--text-color);letter-spacing:.02em;font-size:.75rem;font-weight:500}.job-section{align-items:center;gap:4px;margin-top:8px;display:inline-flex}.job-resume-link{text-transform:uppercase;letter-spacing:0;color:var(--secondary-color);cursor:pointer;font-size:.65rem;display:inline-block}.job-resume-link.typing:after{content:"|";opacity:1;margin-left:2px;animation:1s infinite blink}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.current-status{color:var(--secondary-color);margin-top:auto;font-size:.8rem}.link-list{flex-direction:column;gap:8px;list-style:none;display:flex}.link-list a{color:var(--text-color);width:fit-content;font-weight:500;text-decoration:none;display:inline-block;position:relative}.link-list a:after{content:"";background:var(--text-color);transform-origin:100%;width:100%;height:1px;transition:transform .4s cubic-bezier(.19,1,.22,1);position:absolute;bottom:0;left:0;transform:scaleX(0)}.link-list a:hover:after{transform-origin:0;transform:scaleX(1)}.link-list .wechat-link{color:var(--text-color);cursor:pointer;width:fit-content;font-weight:500;text-decoration:none;display:inline-block;position:relative}.link-list .wechat-link:after{content:"";background:var(--text-color);transform-origin:100%;width:100%;height:1px;transition:transform .4s cubic-bezier(.19,1,.22,1);position:absolute;bottom:0;left:0;transform:scaleX(0)}.link-list .wechat-link:hover:after{transform-origin:0;transform:scaleX(1)}.colophon{color:var(--secondary-color);margin-top:24px;font-size:.75rem}.telemetry-col{text-align:right;justify-content:flex-start}.copyright{font-size:.75rem}.telemetry{font-family:var(--font-mono);color:var(--secondary-color);text-align:right;margin-top:auto;font-size:.7rem}@media (width<=768px){#panel-zone{grid-template-columns:1fr;height:auto;min-height:30vh}.corner-index{font-size:1.5rem}.hero-headline{font-size:2.2rem}.nav-item{font-size:2.5rem}}body.modal-open{overflow:hidden}.wechat-modal-overlay{z-index:9999;opacity:0;pointer-events:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);cursor:default;background:#00000080;justify-content:center;align-items:center;width:100vw;height:100vh;transition:opacity .3s;display:flex;position:fixed;top:0;left:0}.wechat-modal-overlay.active{opacity:1;pointer-events:auto}.wechat-modal{background:var(--bg-color);border:1px solid var(--hairline);border-radius:8px;width:90%;max-width:360px;transition:transform .3s;transform:translateY(20px);box-shadow:0 10px 40px #b0002026}.wechat-modal-overlay.active .wechat-modal{transform:translateY(0)}.wechat-modal-header{border-bottom:1px solid var(--hairline);color:var(--text-color);justify-content:space-between;align-items:center;padding:16px 20px;font-weight:600;display:flex}.wechat-modal-close{color:var(--text-color);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:40px;height:40px;padding:8px;font-size:1.8rem;line-height:1;transition:all .2s;display:flex}.wechat-modal-close:hover{color:var(--accent);background:#b000200d}.wechat-modal-content{text-align:center;padding:24px}.wechat-modal-content img{border:1px solid var(--hairline);border-radius:8px;width:100%;max-width:240px;height:auto;margin-bottom:16px}.wechat-modal-content p{color:var(--secondary-color);margin:0;font-size:.85rem}.wechat-modal-content .wechat-account{color:var(--text-color);font-family:var(--font-mono);margin-top:8px}.page-container{min-height:100vh;padding:calc(var(--pad) * 2);background-color:var(--bg-color);color:var(--text-color);padding-top:80px;padding-bottom:120px;overflow-y:auto}.page-header{border-bottom:1px solid var(--hairline);justify-content:space-between;align-items:center;margin-bottom:48px;padding-bottom:16px;display:flex}.page-title{color:var(--text-color);letter-spacing:-.04em;margin:0;font-size:3rem;font-weight:700}.back-link{color:var(--text-color);font-weight:500;font-family:var(--font-mono);cursor:pointer;background:0 0;border:none;padding:0;font-size:.9rem;text-decoration:none;transition:color .2s}.back-link:hover{color:var(--accent)}#global-footer{background:var(--bg-color);border-top:1px solid var(--hairline);width:100%;padding:var(--pad);z-index:100;position:fixed;bottom:0;left:0}.footer-content{grid-template-columns:2fr 1fr;align-items:start;gap:40px;font-size:.85rem;display:grid}.footer-left .meta-line{margin-bottom:8px}.footer-bio{color:var(--text-color);max-width:400px;margin:0}.footer-right{text-align:right}.about-content{grid-template-columns:2fr 1fr;gap:60px;max-width:1200px;display:grid}.about-section{margin-bottom:48px}.section-title{color:var(--text-color);letter-spacing:-.02em;margin-bottom:20px;font-size:1.5rem;font-weight:600}.about-bio{color:var(--text-color);margin-bottom:16px;font-size:1rem;line-height:1.7}.experience-list{flex-direction:column;gap:32px;display:flex}.experience-item{border-bottom:1px solid var(--hairline);padding-bottom:24px}.experience-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.experience-title{color:var(--text-color);margin:0;font-size:1.2rem;font-weight:600}.experience-period{font-family:var(--font-mono);color:var(--secondary-color);font-size:.8rem}.experience-company{color:var(--secondary-color);margin-bottom:12px;font-size:.95rem}.experience-description{color:var(--text-color);margin:0;line-height:1.6}.skills-grid{flex-wrap:wrap;gap:10px;display:flex}.skill-tag{border:1px solid var(--hairline);color:var(--text-color);background:#b000200d;border-radius:4px;padding:6px 14px;font-size:.85rem;transition:all .2s}.skill-tag:hover{background:var(--text-color);color:#fff;border-color:var(--text-color)}.avatar-card{border:1px solid var(--hairline);text-align:center;background:#fff;border-radius:8px;margin-bottom:24px;padding:24px;box-shadow:0 4px 20px #b000200d}.avatar-placeholder{border:2px solid var(--hairline);border-radius:50%;width:120px;height:120px;margin:0 auto 20px;overflow:hidden}.avatar-pattern{grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr;width:100%;height:100%;display:grid}.pattern-block{width:100%;height:100%}.pattern-yellow{background:gold}.pattern-blue{background:#0047ab}.pattern-red{background:#b00020}.pattern-white{background:#fff}.avatar-info h3{color:var(--text-color);margin-bottom:8px;font-size:1.3rem;font-weight:600}.avatar-info p{color:var(--secondary-color);margin-bottom:4px;font-size:.9rem}.avatar-location{font-family:var(--font-mono);font-size:.8rem!important}.info-card{border:1px solid var(--hairline);background:#fff;border-radius:8px;padding:24px;box-shadow:0 4px 20px #b000200d}.info-card h3{color:var(--text-color);margin-bottom:16px;font-size:1.1rem;font-weight:600}.info-list{flex-direction:column;gap:10px;list-style:none;display:flex}.info-list a{color:var(--text-color);text-decoration:none;transition:color .2s}.info-list a:hover{color:var(--accent)}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:32px;max-width:1200px;display:grid}.project-card{border:1px solid var(--hairline);cursor:pointer;background:#fff;border-radius:8px;transition:all .3s;overflow:hidden;box-shadow:0 4px 20px #b000200d}.project-card:hover{border-color:var(--text-color);transform:translateY(-4px);box-shadow:0 10px 30px #b000201a}.project-image{background:var(--bg-color);width:100%;height:200px;overflow:hidden}.project-image img{object-fit:cover;width:100%;height:100%}.project-content{padding:24px}.project-title{color:var(--text-color);margin-bottom:12px;font-size:1.3rem;font-weight:600}.project-description{color:var(--text-color);margin-bottom:16px;font-size:.95rem;line-height:1.6}.project-tags{flex-wrap:wrap;gap:8px;display:flex}.project-tag{border:1px solid var(--hairline);color:var(--text-color);font-size:.75rem;font-family:var(--font-mono);background:#b000200d;border-radius:4px;padding:4px 10px}.project-modal-overlay{z-index:9999;opacity:0;pointer-events:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;justify-content:center;align-items:center;width:100vw;height:100vh;transition:opacity .3s;display:flex;position:fixed;top:0;left:0}.project-modal-overlay.active{opacity:1;pointer-events:auto}.project-modal{background:var(--bg-color);border:1px solid var(--hairline);border-radius:8px;width:90%;max-width:700px;max-height:80vh;transition:transform .3s;overflow-y:auto;transform:translateY(20px);box-shadow:0 10px 40px #b0002026}.project-modal-overlay.active .project-modal{transform:translateY(0)}.project-modal-header{border-bottom:1px solid var(--hairline);color:var(--text-color);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.project-modal-header h2{margin:0;font-size:1.5rem;font-weight:600}.modal-close{color:var(--text-color);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:40px;height:40px;padding:8px;font-size:1.8rem;line-height:1;transition:all .2s;display:flex}.modal-close:hover{color:var(--accent);background:#b000200d}.project-modal-content{padding:24px}.project-modal-image{background:#fff;border-radius:8px;width:100%;height:300px;margin-bottom:24px;overflow:hidden}.project-modal-image img{object-fit:cover;width:100%;height:100%}.project-modal-description{color:var(--text-color);margin-bottom:20px;font-size:1rem;line-height:1.7}.project-modal-tags{flex-wrap:wrap;gap:8px;margin-bottom:24px;display:flex}.project-link{color:var(--text-color);font-weight:500;font-family:var(--font-mono);text-decoration:none;transition:color .2s;display:inline-block}.project-link:hover{color:var(--accent)}.articles-list{flex-direction:column;gap:32px;max-width:900px;display:flex}.article-item{border:1px solid var(--hairline);background:#fff;border-radius:8px;grid-template-columns:180px 1fr 40px;gap:24px;padding:24px;text-decoration:none;transition:all .3s;display:grid;box-shadow:0 4px 20px #b000200d}.article-item:hover{border-color:var(--text-color);transform:translate(8px);box-shadow:0 10px 30px #b000201a}.article-meta{flex-direction:column;gap:8px;display:flex}.article-date{font-family:var(--font-mono);color:var(--secondary-color);font-size:.85rem}.article-tags{flex-wrap:wrap;gap:6px;display:flex}.article-tag{border:1px solid var(--hairline);color:var(--text-color);font-size:.7rem;font-family:var(--font-mono);background:#b000200d;border-radius:4px;padding:3px 8px}.article-content h3{color:var(--text-color);margin-bottom:12px;font-size:1.3rem;font-weight:600;transition:color .2s}.article-item:hover .article-content h3{color:var(--accent)}.article-excerpt{color:var(--secondary-color);margin:0;font-size:.95rem;line-height:1.6}.article-arrow{color:var(--hairline);justify-content:center;align-items:center;font-size:1.5rem;transition:all .3s;display:flex}.article-item:hover .article-arrow{color:var(--text-color);transform:translate(4px)}.writing-footer{border-top:1px solid var(--hairline);max-width:900px;margin-top:48px;padding-top:24px}.writing-footer p{color:var(--secondary-color);font-size:.95rem}.writing-footer a{color:var(--text-color);font-weight:500;text-decoration:none;transition:color .2s}.writing-footer a:hover{color:var(--accent)}@media (width<=768px){.page-container{padding:var(--pad);padding-top:80px;padding-bottom:140px}.page-title{font-size:2rem}.about-content{grid-template-columns:1fr;gap:40px}.projects-grid{grid-template-columns:1fr}.article-item{grid-template-columns:1fr;gap:16px}.article-meta{flex-direction:row;justify-content:space-between;align-items:center}.article-arrow{display:none}.footer-content{grid-template-columns:1fr;gap:20px}.footer-right{text-align:left}}.resume-page{padding-top:80px;padding-bottom:120px}.resume-content{max-width:900px;margin:0 auto}.resume-header{border:1px solid var(--hairline);background:#fff;border-radius:12px;justify-content:space-between;margin-bottom:32px;padding:40px;display:flex;box-shadow:0 4px 20px #b000200d}.resume-left-col{flex-direction:column;flex:1;justify-content:space-between;align-items:flex-start;display:flex}.resume-name{color:var(--text-color);letter-spacing:-.04em;margin:0;font-size:3rem;font-weight:700;line-height:1.1}.resume-right-col{flex-direction:column;justify-content:space-between;display:flex}.resume-title{color:var(--secondary-color);font-size:1.2rem;font-weight:500;font-family:var(--font-mono);margin:0}.resume-years{color:var(--text-color);opacity:.8;margin:0;font-size:.95rem}.resume-contact{text-align:right;flex-direction:column;gap:8px;display:flex}.contact-block{flex-direction:column;gap:2px;display:flex}.contact-label{font-family:var(--font-mono);color:var(--secondary-color);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem}.contact-value{color:var(--text-color);font-size:.95rem;font-weight:500}.resume-section{margin-bottom:40px}.resume-section-title{color:var(--text-color);letter-spacing:-.02em;border-bottom:1px solid var(--hairline);margin-bottom:20px;padding-bottom:12px;font-size:1.3rem;font-weight:700}.advantages-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.advantage-card{border:1px solid var(--hairline);background:#fff;border-radius:10px;padding:24px;transition:all .3s}.advantage-card:hover{border-color:var(--text-color);transform:translateY(-4px);box-shadow:0 8px 24px #b000201a}.advantage-title{color:var(--text-color);margin:0 0 10px;font-size:1.1rem;font-weight:600}.advantage-description{color:var(--secondary-color);margin:0;font-size:.9rem;line-height:1.6}.projects-list{flex-direction:column;gap:20px;display:flex}.project-card{border:1px solid var(--hairline);background:#fff;border-radius:10px;padding:28px;transition:all .3s}.project-card:hover{border-color:var(--text-color);box-shadow:0 8px 24px #b0002014}.project-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.project-name{color:var(--text-color);margin:0;font-size:1.2rem;font-weight:600}.project-meta{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.project-meta span,.experience-relation{color:var(--accent);font-family:var(--font-mono);background:#b000200f;border-radius:4px;align-items:center;padding:3px 8px;font-size:.72rem;font-weight:500;display:inline-flex}.project-period{font-family:var(--font-mono);color:var(--secondary-color);font-size:.85rem}.project-subsection{margin-bottom:20px}.project-subsection:last-child{margin-bottom:0}.project-subtitle{color:var(--text-color);font-size:1rem;font-weight:600;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;margin:0 0 10px;font-size:.8rem}.project-text{color:var(--text-color);margin:0;font-size:.95rem;line-height:1.8}.project-list{margin:0;padding:0;list-style:none}.project-list-item{color:var(--text-color);margin-bottom:12px;padding-left:20px;font-size:.95rem;line-height:1.8;position:relative}.project-list-item:last-child{margin-bottom:0}.project-list-item:before{content:"•";color:var(--accent);font-weight:700;position:absolute;left:4px}.project-results{border-left:3px solid var(--accent);background:#b000200d;border-radius:8px;padding:16px 20px;font-weight:500}.experience-list-resume{flex-direction:column;gap:20px;display:flex}.experience-item-resume{border:1px solid var(--hairline);background:#fff;border-radius:10px;padding:28px;transition:all .3s}.experience-item-resume:hover{border-color:var(--text-color);box-shadow:0 8px 24px #b0002014}.experience-header-resume{justify-content:space-between;align-items:flex-start;margin-bottom:12px;display:flex}.experience-company-resume{color:var(--text-color);margin:0 0 4px;font-size:1.2rem;font-weight:600}.experience-relation{vertical-align:middle;margin-left:8px}.experience-title-resume{color:var(--secondary-color);margin:0;font-size:1rem;font-weight:500}.experience-period-resume{font-family:var(--font-mono);color:var(--secondary-color);font-size:.85rem}.experience-description-resume{color:var(--text-color);margin:10px 0 0;font-size:.95rem;line-height:1.7}.education-list{flex-direction:column;gap:20px;display:flex}.education-item{border:1px solid var(--hairline);background:#fff;border-radius:10px;padding:28px;transition:all .3s}.education-item:hover{border-color:var(--text-color);box-shadow:0 8px 24px #b0002014}.education-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.education-school{color:var(--text-color);margin:0;font-size:1.2rem;font-weight:600}.education-period{font-family:var(--font-mono);color:var(--secondary-color);font-size:.85rem}.education-info{color:var(--secondary-color);margin:0;font-size:.95rem;font-weight:500}@media (width<=768px){.resume-page{padding-left:var(--pad);padding-right:var(--pad)}.resume-header{flex-direction:column;gap:24px;padding:28px}.resume-contact{text-align:left;flex-flow:wrap;gap:16px}.resume-name{font-size:2.2rem}.advantages-grid{grid-template-columns:1fr}.project-header,.experience-header-resume,.education-header{flex-direction:column;align-items:flex-start;gap:6px}}
