:root{--bg: #f2f2f2;--fg: #111111;--muted: #8a8a8a;--line: #ececec;--max: 1440px;--header-h: 72px;--gap: 28px;--panel-w: 60vw;--ease: cubic-bezier(.16, 1, .3, 1);--font: "Helvetica Neue", Helvetica, Arial, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", system-ui, sans-serif}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--fg);font-family:var(--font);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}a{color:inherit;text-decoration:none}img{display:block;max-width:100%;height:auto}html[lang=en] :is(.lang-zh),html[lang=zh] :is(.lang-en){display:none!important}.site-header{position:fixed;inset:0 0 auto;height:var(--header-h);background:var(--bg);z-index:50}.header-inner{max-width:var(--max);margin:0 auto;height:100%;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(20px,4vw,48px)}.site-name{font-size:19px;font-weight:600;letter-spacing:.02em}.header-right{display:flex;align-items:center;gap:18px}.lang-toggle{background:none;border:none;cursor:pointer;font:inherit;font-size:14px;color:var(--muted);padding:6px 8px;letter-spacing:.04em;transition:color .2s var(--ease)}.lang-toggle:hover{color:var(--fg)}.menu-toggle{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;width:30px;height:30px;background:none;border:none;cursor:pointer;padding:0}.menu-toggle span{display:block;height:1.5px;width:24px;background:var(--fg);transition:transform .3s var(--ease),opacity .2s var(--ease)}.menu-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}.menu-toggle.open span:nth-child(2){opacity:0}.menu-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}.nav-overlay{position:fixed;inset:0;background:var(--bg);z-index:40;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .35s var(--ease),visibility .35s var(--ease)}.nav-overlay.open{opacity:1;visibility:visible}.nav-links{list-style:none;margin:0;padding:0;text-align:center}.nav-links li{margin:18px 0;opacity:0;transform:translateY(12px);transition:opacity .4s var(--ease),transform .4s var(--ease)}.nav-overlay.open .nav-links li{opacity:1;transform:none}.nav-overlay.open .nav-links li:nth-child(1){transition-delay:.08s}.nav-overlay.open .nav-links li:nth-child(2){transition-delay:.14s}.nav-overlay.open .nav-links li:nth-child(3){transition-delay:.2s}.nav-links a{font-size:clamp(28px,5vw,44px);font-weight:300;letter-spacing:.01em;transition:opacity .2s var(--ease)}.nav-links a:hover{opacity:.45}.page{max-width:var(--max);margin:0 auto;--page-gap: clamp(4px, 1vw, 12px);padding:calc(var(--header-h) + var(--page-gap)) clamp(20px,4vw,48px) 96px}.intro{margin:0 0 clamp(12px,2vw,24px)}.tag-filter{display:flex;flex-wrap:wrap;gap:16px;font-size:clamp(15px,2.4vw,18px);font-weight:300;letter-spacing:.02em}.tag{background:none;border:none;margin:0;padding:2px 0;cursor:pointer;font:inherit;font-size:inherit;font-weight:inherit;letter-spacing:inherit;color:var(--muted);transition:color .2s var(--ease)}.tag:hover{color:var(--fg)}.tag.active{color:var(--fg);text-decoration:underline;text-underline-offset:5px;text-decoration-thickness:1px}.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--gap)}.work-card.is-hidden{display:none}.work-card{display:block;width:100%;text-align:left;background:none;border:none;padding:0;cursor:pointer;font:inherit;color:inherit}.work-card__media{position:relative;aspect-ratio:4 / 3;overflow:hidden;background:#f4f4f4}.work-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease),opacity .4s var(--ease)}.work-card:hover .work-card__media img{transform:scale(1.03);opacity:.92}.backdrop{position:fixed;inset:0;background:#fff9;backdrop-filter:blur(2px);opacity:0;visibility:hidden;transition:opacity .4s var(--ease),visibility .4s var(--ease);z-index:60}.backdrop.open{opacity:1;visibility:visible}.panel{position:fixed;top:0;right:0;height:100%;width:min(var(--panel-w),100%);background:var(--bg);border-left:1px solid var(--line);transform:translate(100%);transition:transform .5s var(--ease);z-index:70;overflow-y:auto;overscroll-behavior:contain}.panel.open{transform:translate(0)}.panel-close{position:sticky;top:0;margin-left:auto;display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:var(--bg);border:none;cursor:pointer;font-size:26px;line-height:1;color:var(--fg);z-index:2}.panel-inner{padding:0 clamp(28px,5vw,56px) 72px}.panel-media{margin:0 0 28px}.panel-media img{width:100%;height:auto;background:#f4f4f4}.panel-media+.panel-media{margin-top:14px}.video-embed{position:relative;width:100%;aspect-ratio:16 / 9;background:#000}.video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}.panel-title{font-size:clamp(22px,3.4vw,30px);font-weight:500;margin:0 0 18px;line-height:1.25}.panel-meta{margin:0 0 28px;padding:0 0 24px;border-bottom:1px solid var(--line)}.panel-meta .row{display:flex;gap:16px;padding:4px 0;font-size:14px}.panel-meta dt{flex:0 0 96px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-size:12px;padding-top:2px}.panel-meta dd{margin:0}.panel-desc{font-size:16px;line-height:1.8;color:#222}.panel-desc p{margin:0 0 1em;white-space:pre-line}.prose{max-width:680px}.prose h1{font-size:clamp(26px,4vw,38px);font-weight:500;margin:0 0 24px}.prose p{font-size:16px;line-height:1.8;margin:0 0 1.2em}.prose .muted{color:var(--muted)}.about{display:flex;gap:clamp(28px,5vw,64px);align-items:flex-start}.about__photo{flex:0 0 38%;max-width:360px}.about__photo img,.about__photo-empty{display:block;width:100%;aspect-ratio:4 / 5;object-fit:cover;background:#e7e7e7}.about__text{flex:1 1 0;max-width:620px}.about__text h1{font-size:clamp(26px,4vw,38px);font-weight:500;margin:0 0 28px}.about__section{margin:0 0 36px}.about__section h2{font-size:13px;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:0 0 12px}.about__section p{font-size:16px;line-height:1.8;margin:0 0 1em}@media(max-width:768px){.about{flex-direction:column}.about__photo{flex-basis:auto;width:100%;max-width:320px}}body.no-scroll{overflow:hidden}@media(max-width:768px){.panel{width:100%}}@media(max-width:600px){:root{--gap: 18px}.gallery{grid-template-columns:1fr}}@media(prefers-reduced-motion:reduce){*{transition-duration:.01ms!important}}
