@import url(https://fonts.googleapis.com/css2?family=Space+Mono:wght@400;700&display=swap);@import url(https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300..700&family=Space+Mono:ital,wght@0,400;0,700;1,400;1,700&display=swap);@import url(https://fonts.googleapis.com/css2?family=WDXL+Lubrifont+SC&display=swap);*{box-sizing:border-box;margin:0;padding:0}body{font-family:Space Mono,monospace;line-height:1.6}.page-container{background-color:#fff;color:#000;min-height:100vh;padding:1rem}@media (min-width:768px){.page-container{padding:2rem}}.content-wrapper{margin:0 auto;max-width:1152px}.content-wrapper-narrow{margin:0 auto;max-width:768px}.title-main{font-family:Space Grotesk,sans-serif;font-optical-sizing:auto;font-size:2rem;font-style:normal;font-weight:700;margin-bottom:.2rem;text-align:center}.title-sub{font-size:.85rem;padding-bottom:3rem;text-align:center}@media (min-width:769px){.hidden{visibility:hidden}}.footer{font-size:.85rem;opacity:60%;padding-top:3rem;text-align:center}@media (min-width:768px){.title-main{font-size:3.75rem}}.title-page{font-size:2.5rem;font-weight:700;margin-bottom:2rem}.title-section{border-bottom:2px solid #000;margin-bottom:1.5rem;padding-bottom:.5rem}.title-card,.title-section{font-size:1.5rem;font-weight:700}.title-card{margin-bottom:.5rem}.title-article{font-size:1.5rem;font-weight:700;margin-bottom:1rem}.grid-2col{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr}@media (min-width:768px){.grid-2col{gap:3rem;grid-template-columns:repeat(2,1fr)}}.grid-1col{grid-gap:2rem;display:grid;gap:2rem}.space-y-large>*+*{margin-top:3rem}.space-y-medium>*+*{margin-top:2rem}.space-y-small>*+*{margin-top:1rem}.mb-small{margin-bottom:.5rem}.mb-medium{margin-bottom:1rem}.mb-large{margin-bottom:2rem}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-between{justify-content:space-between}.space-x-small>*+*{margin-left:.5rem}.gap-small{gap:.75rem}@media (min-width:768px){.md-flex-row{flex-direction:row}.md-justify-between{justify-content:space-between}.md-items-start{align-items:flex-start}}.text-gray{color:#666}.text-small{font-size:.875rem}.text-medium{font-size:1rem}.text-large{font-size:1.25rem}.text-xl{font-size:1.5rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.italic{font-style:italic}.opacity-70{opacity:.7}.leading-relaxed{line-height:1.225}.btn-back{align-items:center;background:#fff;border:1px solid #000;color:#000;cursor:pointer;display:flex;gap:.5rem;margin-bottom:2rem;padding:.5rem;transition:all .3s ease}.btn-back:hover{background-color:#000;color:#fff}.card{border:2px solid #000;cursor:pointer;padding:1.5rem;transition:all .3s ease}.card:hover{background-color:#000;color:#fff}.card-image{aspect-ratio:16/9;margin-bottom:1rem;overflow:hidden}.card-image img{height:100%;object-fit:cover;transition:all .3s ease;width:100%}.card:hover .card-image img{filter:invert(1)}.card-description{font-size:.875rem;opacity:.7}.project-card{border:2px solid #000;padding:1.5rem;transition:all .3s ease}.project-card:hover{background-color:#f8f8f8}.tag{background-color:#000;color:#fff;display:inline-block;font-size:.875rem;padding:.25rem .75rem}.tag-white{border:2px solid #000;cursor:pointer;padding:.5rem 1rem;transition:all .3s ease}.date-badge,.tag-white:hover{background-color:#000;color:#fff}.date-badge{font-size:.875rem;margin-top:.5rem;padding:.25rem .75rem}@media (min-width:768px){.date-badge{margin-top:0}}.article{border-bottom:1px solid #ddd;padding-bottom:2rem}.article-header{display:flex;flex-direction:column;margin-bottom:1rem}@media (min-width:768px){.article-header{align-items:flex-start;flex-direction:row;justify-content:space-between}}.quote-block{border-left:4px solid #000;padding-left:2rem}.quote-text{font-family:Roboto,sans-serif;font-optical-sizing:auto;font-size:1.5rem;font-style:normal;font-style:italic;font-weight:500;line-height:1.625;margin-bottom:1rem}@media (min-width:768px){.quote-text{font-size:1.875rem}}.quote-author{font-size:1.125rem;font-weight:200}.experience-item{margin-bottom:2rem}.experience-header{display:flex;flex-direction:column;margin-bottom:.5rem}@media (min-width:768px){.experience-header{align-items:flex-start;flex-direction:row;justify-content:space-between}}.experience-role{font-size:1.25rem;font-weight:600}.experience-period{background-color:#000;color:#fff;font-size:.875rem;margin-top:.5rem;padding:.25rem .75rem}@media (min-width:768px){.experience-period{margin-top:0}}.skills-grid{display:flex;flex-wrap:wrap;gap:.75rem}.project-image-container{aspect-ratio:16/9;border:1px solid #ddd;margin-bottom:1.5rem;overflow:hidden;position:relative}.project-image{height:100%;object-fit:cover;width:100%}.image-nav{align-items:center;background:#000c;bottom:0;color:#fff;display:flex;justify-content:space-between;left:0;padding:.5rem 1rem;position:absolute;right:0}.image-nav-btn{background:none;border:none;color:#fff;cursor:pointer;padding:.25rem;transition:opacity .3s ease}.image-nav-btn:hover{opacity:.7}.image-counter{font-size:.875rem}.project-links{display:flex;gap:1rem;margin-top:1rem}.project-link{align-items:center;border:1px solid #000;color:#000;display:flex;font-size:.875rem;gap:.5rem;padding:.5rem 1rem;text-decoration:none;transition:all .3s ease}.project-link:hover{background-color:#000;color:#fff}.thought-card{border:2px solid #000;cursor:pointer;overflow:hidden;padding:0;transition:all .3s ease}.thought-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.thought-image-container{height:300px;overflow:hidden;width:100%}.thought-image{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.thought-card:hover .thought-image{transform:scale(1.05)}.thought-content{padding:1.5rem}.article-meta{align-items:center;display:flex;gap:1rem;margin-top:.5rem}@media (min-width:768px){.article-meta{margin-top:0}}.read-time{align-items:center;color:#666;display:flex;font-size:.875rem;gap:.25rem}.article-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0}.article-tag{align-items:center;background-color:#f5f5f5;border-radius:4px;color:#666;display:flex;font-size:.75rem;gap:.25rem;padding:.25rem .5rem}.read-more-btn{background:none;border:none;color:#000;cursor:pointer;font-weight:500;margin-top:1rem;transition:color .3s ease}.read-more-btn:hover{color:#666}.article-modal-overlay{background-color:#000c;bottom:0;left:0;overflow-y:auto;padding:2rem;position:fixed;right:0;top:0;z-index:1000}.article-modal{background:#fff;border-radius:8px;display:flex;flex-direction:column;margin:0 auto;max-height:90vh;max-width:800px;overflow:hidden;position:relative}.article-modal-header{background:#fff;border-bottom:1px solid #eee;display:flex;justify-content:flex-end;padding:1rem;position:sticky;top:0;z-index:1001}.close-button{background:none;border:none;border-radius:4px;cursor:pointer;padding:.5rem;transition:background-color .3s ease}.close-button:hover{background-color:#e2e2e2}.article-modal-content{overflow-y:auto;padding:0 2rem 2rem}.article-featured-image{border-radius:8px;height:300px;margin-bottom:2rem;overflow:hidden;width:100%}.article-featured-image img{height:100%;object-fit:cover;width:100%}.article-modal-meta{align-items:center;color:#666;display:flex;gap:1rem;margin-bottom:1rem}.article-date{font-size:.875rem}.article-read-time{align-items:center;display:flex;font-size:.875rem;gap:.25rem}.article-modal-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem}.article-modal-tag{background-color:#000;border-radius:4px;color:#fff;font-size:.875rem;padding:.25rem .75rem}.article-body{color:#333;line-height:1.5}.article-h1{font-size:2rem;font-weight:700;line-height:1.1;margin:1rem 0 .5rem}.article-h2{font-size:1.25rem;font-weight:700;line-height:1.2;margin:.75rem 0 .5rem}.article-h3{font-size:1rem;font-weight:600;line-height:1.3;margin:.5rem 0 .25rem}.article-paragraph{line-height:1.5;margin-bottom:.25rem}.article-list-item{line-height:1.5;margin:.25rem 0;padding-left:1rem;position:relative}.article-list-item:before{color:#000;content:"•";font-weight:700;left:0;position:absolute}@media (max-width:768px){.article-modal-overlay{padding:1rem}.article-modal-content{padding:0 1.8rem 2rem}.article-h1{font-size:2rem}.article-h2{font-size:1.5rem}}.loading-spinner{color:#666;font-size:1.125rem;padding:2rem}.btn-now,.loading-spinner{align-items:center;display:flex;justify-content:center}.btn-now{--mouse-x:50vw;--mouse-y:50vh;--offset-x:50vw;--offset-y:50vh;background:#fff;border:1px solid #000;border-radius:0;color:#000;cursor:pointer;font-family:inherit;font-size:.875rem;min-height:40px;min-width:60px;overflow:visible;padding:.5rem 1rem;right:1rem;top:1rem;transform-origin:center;z-index:100}.btn-now,.btn-now:before{position:fixed;transition:all 1.5s cubic-bezier(.23,1,.32,1)}.btn-now:before{background:radial-gradient(circle at var(--mouse-x) var(--mouse-y),#000000e6 0,#000000b3 70%,#0006 100%);border-radius:50%;content:"";height:0;left:0;pointer-events:none;top:0;transform:translate(var(--offset-x),var(--offset-y));width:0;z-index:-1}.btn-now.animating:before,.btn-now:hover:before{height:300vmax;transform:translate(calc(var(--offset-x) - 150vmax),calc(var(--offset-y) - 150vmax));width:300vmax}.btn-now.animating:before{transition:all 2s cubic-bezier(.23,1,.32,1)}.btn-now:hover:after{animation:fadeInText 1.5s ease-in-out .5s forwards}.btn-now.animating:after,.btn-now:hover:after{color:#fff;content:"近况";font-family:WDXL Lubrifont SC,sans-serif;font-size:3rem;font-style:normal;font-weight:400;font-weight:700;left:50vw;letter-spacing:.5em;opacity:0;pointer-events:none;position:fixed;text-shadow:2px 2px 4px #000c;top:50vh;transform:translate(-50%,-50%);z-index:1000}.btn-now.animating:after{animation:fadeInText 2s ease-in-out .5s forwards}.btn-now.animating,.btn-now:hover{border-color:#0000;color:#0000;z-index:999}@keyframes fadeInText{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@media (min-width:768px){.btn-now{right:2rem;top:2rem}}.bookshelf-page{background:linear-gradient(180deg,#f8f8f8,#e8e8e8);min-height:100vh}.bookshelf-page,.bookshelf-page *{font-family:Georgia,Times New Roman,serif}.bookshelf-wrapper{margin:0 auto;max-width:1200px;padding:0 1rem}@media (min-width:768px){.bookshelf-wrapper{padding:0 2rem}}.bookshelf-header{margin-bottom:2rem;padding-top:1rem}.btn-back-bookshelf{align-items:center;background:#f8f8f8;border:1px solid #333;border-radius:4px;color:#333;cursor:pointer;display:flex;font-family:Georgia,Times New Roman,serif;font-size:.875rem;gap:.5rem;margin-bottom:1.5rem;padding:.4rem .8rem;transition:all .3s ease}.btn-back-bookshelf:hover{background-color:#333;color:#f8f8f8}.bookshelf-title-section{text-align:center}.bookshelf-title{color:#222;font-size:2.5rem;font-weight:300;letter-spacing:.02em;margin-bottom:.5rem}@media (min-width:768px){.bookshelf-title{font-size:3rem}}.bookshelf-last-updated{color:#666;font-size:.875rem;font-style:italic}.bookshelf-main{display:flex;flex-direction:column;gap:3rem;margin:3rem 0;position:relative}@media (min-width:768px){.bookshelf-main{align-items:flex-start;flex-direction:row;gap:4rem}}.bookshelf-container{align-items:center;display:flex;flex-direction:column}@media (min-width:768px){.bookshelf-container{flex-shrink:0;margin-left:-11rem;min-width:400px}}.bookshelf{align-items:center;background:linear-gradient(135deg,#f0f0f0,#e0e0e0 50%,#d8d8d8);border:1px solid #bbb;border-radius:12px;box-shadow:0 8px 24px #0000001f,inset 0 1px 0 #ffffff80,inset 0 -1px 0 #0000000d;display:flex;flex-direction:column;gap:3rem;padding:2rem 1.5rem;position:relative}.shelf-wood{background:linear-gradient(180deg,#555,#444 30%,#333 70%,#2a2a2a);border:1px solid #222;border-radius:0 0 6px 6px;border-top:none;box-shadow:0 3px 12px #00000040,inset 0 1px 0 #ffffff1a,inset 0 -1px 0 #0000004d;height:12px;max-width:600px;position:relative;width:100%}.shelf-wood:before{background:linear-gradient(180deg,#666,#444);border:1px solid #333;border-bottom:none;border-radius:3px 3px 0 0;content:"";height:3px;left:0;position:absolute;right:0;top:-3px}.shelf-wood:after{background:linear-gradient(90deg,#0000,#0000004d 50%,#0000);border-radius:1px;bottom:-2px;content:"";height:2px;left:5px;position:absolute;right:5px}.books-row{align-items:center;display:flex;flex-direction:column;gap:8px;margin-top:-4px;max-width:600px;padding:0 1rem;width:100%}@media (min-width:768px){.books-row{padding:0}}.book{cursor:pointer;height:45px;position:relative;transform-origin:center;transition:all .4s cubic-bezier(.4,0,.2,1);width:280px}@media (min-width:768px){.book{height:50px;width:320px}}@media (max-width:767px){.book{height:40px;width:240px}}.book:hover{transform:translateX(8px) scale(1.02);z-index:10}.book.pulled{box-shadow:0 4px 20px #0003;transform:translateX(12px) scale(1.05);z-index:20}.book-spine{align-items:center;background:var(--book-color);border:1px solid var(--book-spine-color);border-radius:0 6px 6px 0;box-shadow:inset 0 4px 8px #ffffff1a,2px 2px 8px #00000026;display:flex;height:100%;justify-content:flex-start;padding:0 1.5rem;position:relative;width:100%}.book-spine:before{background:#ffffff4d;left:8px}.book-spine:after,.book-spine:before{border-radius:1px;bottom:6px;content:"";position:absolute;top:6px;width:1px}.book-spine:after{background:#0003;right:6px}.book-title-spine{color:#fffffff2;font-size:.875rem;font-weight:400;letter-spacing:.3px;overflow:hidden;text-align:left;text-overflow:ellipsis;text-shadow:1px 1px 2px #0006;white-space:nowrap}@media (min-width:768px){.book-title-spine{font-size:1rem}}@media (max-width:767px){.book-title-spine{font-size:.75rem}}.book-content-display{align-items:flex-start;display:flex;justify-content:center;position:relative;width:100%}@media (min-width:768px){.book-content-display{flex-shrink:0;width:550px}}.open-book{animation:bookOpen .4s ease-out;background:#fefefe;border:1px solid #ccc;border-radius:8px;box-shadow:0 8px 32px #0000001a,inset 0 1px 0 #fffc;max-width:750px;padding:2rem;position:relative;width:100%}@media (min-width:768px){.open-book{animation:bookOpenSide .4s ease-out;max-width:550px}}.open-book:before{display:none}@keyframes bookOpen{0%{opacity:0;transform:rotateX(-90deg) scale(.8)}to{opacity:1;transform:rotateX(0) scale(1)}}@keyframes bookOpenSide{0%{opacity:0;transform:translateX(-100px) scale(.8)}to{opacity:1;transform:translateX(0) scale(1)}}.book-content-title{border-bottom:1px solid #ccc;color:#222;font-size:1.5rem;font-weight:400;margin-bottom:1.5rem;padding-bottom:1rem;text-align:center}.book-content-text{color:#333;line-height:1.7}.book-content-item{font-size:.95rem;margin-bottom:1rem;padding-left:1.5rem;position:relative}.book-content-item:before{color:#666;content:"•";font-weight:700;left:.5rem;position:absolute}.bookshelf-footer{margin-top:3rem;padding-bottom:2rem;text-align:center}.shelf-wood-bottom{background:linear-gradient(180deg,#555,#444 30%,#333 70%,#2a2a2a);border:1px solid #222;border-radius:6px;box-shadow:0 3px 8px #0003,inset 0 1px 0 #ffffff1a,inset 0 -1px 0 #0000004d;height:12px;margin:0 auto 1.5rem;max-width:600px;width:100%}.bookshelf-footer-text{color:#666;font-size:.875rem;font-style:italic}.bookshelf-link{color:#333;text-decoration:underline;transition:color .3s ease}.bookshelf-link:hover{color:#000}.footer{color:#999;font-size:.8rem;margin-top:1rem}.book:first-child{--book-color:#2a2a2a;--book-spine-color:#1a1a1a}.book:nth-child(2){--book-color:#404040;--book-spine-color:#2a2a2a}.book:nth-child(3){--book-color:#1a1a1a;--book-spine-color:#000}.book:nth-child(4){--book-color:#555;--book-spine-color:#333}.book:nth-child(5){--book-color:#333;--book-spine-color:#1a1a1a}.book:nth-child(6){--book-color:#4a4a4a;--book-spine-color:#2a2a2a}
/*# sourceMappingURL=main.4fc8df16.css.map*/