@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700&family=Noto+Sans+SC:wght@400;500;700&display=swap";:root{--bg: #f6f8fb;--bg-soft: #eef2f8;--surface: #ffffff;--surface-soft: #f7f9fc;--surface-border: #dce4ef;--text: #1b2434;--muted: #5f6c7f;--accent: #1f6feb;--accent-soft: #e8f1ff;--radius: 16px;--shadow: 0 10px 26px rgba(16, 24, 40, .06)}:root[data-theme=dark]{--bg: #0f1520;--bg-soft: #131b29;--surface: #161f2e;--surface-soft: #1b2536;--surface-border: #2b3a52;--text: #edf2fb;--muted: #9dacbf;--accent: #7ab2ff;--accent-soft: #1f314d;--shadow: 0 10px 30px rgba(0, 0, 0, .28)}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{color:var(--text);background-color:var(--bg);background-image:linear-gradient(180deg,var(--bg-soft),var(--bg));font-family:Manrope,Noto Sans SC,sans-serif;line-height:1.62;transition:background-color .25s ease,color .25s ease}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.site-shell{width:min(1160px,calc(100vw - 40px));margin:0 auto;padding:24px 0 32px}.site-header,.site-footer{display:flex;align-items:center;justify-content:space-between}.site-header{margin-bottom:22px;padding:12px 16px;border-radius:14px;background:var(--surface);border:1px solid var(--surface-border);box-shadow:var(--shadow);gap:12px}.logo{font-size:.94rem;letter-spacing:.08em;font-weight:700;white-space:nowrap}.header-right{display:flex;align-items:center;gap:10px;min-width:0}nav{display:flex;flex-wrap:wrap;gap:6px}.nav-link{color:var(--muted);padding:8px 12px;border-radius:10px;transition:all .2s ease;font-size:.92rem}.nav-link:hover{color:var(--text);background:var(--surface-soft);text-decoration:none}.nav-link-active{color:var(--accent);background:var(--accent-soft);font-weight:600}.theme-tools{display:flex;gap:6px;align-items:center}.theme-btn{border:1px solid var(--surface-border);background:var(--surface-soft);color:var(--text);border-radius:10px;padding:6px 10px;font:inherit;font-size:.83rem;cursor:pointer}.theme-toggle-btn{width:34px;height:34px;padding:0;display:inline-flex;align-items:center;justify-content:center;color:var(--muted)}.theme-icon{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.theme-btn:hover{border-color:var(--accent);color:var(--text)}.theme-btn.is-active{border-color:var(--accent);color:var(--accent)}.page-wrap{display:block}.stack{display:grid;gap:14px}.card{background:var(--surface);border:1px solid var(--surface-border);border-radius:var(--radius);box-shadow:var(--shadow);padding:clamp(16px,2vw,24px)}.hero{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr);gap:20px;align-items:center}.eyebrow{margin:0;color:var(--muted);letter-spacing:.08em;font-size:.74rem;text-transform:uppercase}h1,.page-title{margin:10px 0 8px;font-size:clamp(1.9rem,3.4vw,2.7rem);line-height:1.1}.bi-title{display:flex;flex-direction:column;gap:4px}.title-zh{font-size:clamp(1.7rem,3.2vw,2.5rem);color:var(--text);font-weight:700;line-height:1.14}.title-en{font-size:clamp(.95rem,1.45vw,1.08rem);color:var(--muted);font-weight:500;line-height:1.35}h1 span{display:block;margin-top:4px;font-size:clamp(1.05rem,1.9vw,1.36rem);color:var(--muted);font-weight:500}h2{margin:0;font-size:clamp(1.06rem,2.2vw,1.3rem);overflow-wrap:anywhere}.lead{margin:0;color:var(--text);font-weight:600}.hero-intro{margin-top:12px;color:var(--muted)}.hero-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}.btn{border:1px solid transparent;padding:9px 14px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;font-weight:600}.btn-primary{color:#fff;background:var(--accent)}.btn-secondary{color:var(--text);border-color:var(--surface-border);background:var(--surface-soft)}.btn-home-main{color:#2b5f98;border-color:#4e88d65c;background:#4e88d626}.btn-home-sub{color:#2f629b;border-color:#4e88d652;background:#4e88d61c}:root[data-theme=dark] .btn-home-main{color:#9fc9ff;border-color:#7cb1f861;background:#7ab2ff33}:root[data-theme=dark] .btn-home-sub{color:#a9d0ff;border-color:#7cb1f857;background:#7ab2ff24}.btn:hover{text-decoration:none;opacity:.93}.hero-text-link{display:inline-flex;align-items:center;color:#3b679b;font-size:.92rem;font-weight:600;padding:8px 2px;border-radius:8px;transition:color .2s ease}.hero-text-link:hover{color:#2c5688;text-decoration:none}:root[data-theme=dark] .hero-text-link{color:#9fc9ff}:root[data-theme=dark] .hero-text-link:hover{color:#b7d8ff}.hero-visual{display:flex;justify-content:center}.hero-visual img{width:min(100%,300px);height:auto;object-fit:contain;border-radius:14px;border:1px solid var(--surface-border);background:var(--surface-soft)}.compact-note{padding-top:12px;padding-bottom:12px}.badge-inline{margin:0;color:var(--muted);font-size:.9rem}.highlight-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.compact-highlights{grid-template-columns:repeat(auto-fit,minmax(210px,1fr))}.compact-highlights .mini-card{padding:12px 14px;border-radius:10px}.mini-card{padding:14px;border-radius:12px;border:1px solid var(--surface-border);background:var(--surface-soft)}.mini-card p{margin:0;color:var(--muted);font-size:.82rem}.mini-card strong{display:block;margin-top:8px;font-size:.98rem;overflow-wrap:anywhere}.split{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.edu-timeline{position:relative;display:grid;gap:10px;margin-top:12px}.edu-item{position:relative;padding:12px 12px 12px 18px;border-radius:12px;border:1px solid var(--surface-border);background:var(--surface-soft);border-left:3px solid rgba(78,136,214,.5)}.edu-period{margin:0;color:var(--muted);font-size:.8rem;letter-spacing:.04em}.edu-item h3{margin:6px 0 4px;font-size:1rem}.edu-program{margin:0;font-size:.92rem}.edu-note{margin:6px 0 0;font-size:.85rem}.award-grid{margin-top:12px;display:grid;grid-template-columns:1fr;gap:10px}.award-item{position:relative;display:flex;align-items:center;padding:12px 12px 12px 34px;border-radius:12px;border:1px solid var(--surface-border);background:var(--surface-soft);font-size:.9rem}.award-item:before{content:"";position:absolute;left:14px;top:calc(50% - 4px);width:8px;height:8px;border-radius:50%;background:#4e88d6;box-shadow:0 0 0 4px #4e88d638}:root[data-theme=dark] .award-item:before{background:#8bc0ff;box-shadow:0 0 0 4px #7ab2ff42}.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}.chip{padding:5px 10px;border-radius:999px;background:var(--surface-soft);border:1px solid var(--surface-border);font-size:.8rem}.chip-color{background:var(--chip-bg);border-color:var(--chip-border);color:var(--chip-text);font-weight:600}.muted{color:var(--muted)}.text-link{display:inline-block;margin-top:10px}.timeline{display:grid;gap:12px}.period{display:inline-block;font-size:.78rem;letter-spacing:.05em;color:var(--muted);margin-bottom:8px}ul{margin:8px 0 0;padding-left:18px}li{margin-bottom:8px;overflow-wrap:anywhere}.clean-list{list-style:none;margin:0;padding:0}.clean-list li{padding:12px;background:var(--surface-soft);border:1px solid var(--surface-border);border-radius:10px}.contact-list{margin-top:8px;display:grid;gap:8px}.contact-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-right:8px}.contact-main{min-width:0;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.contact-label{color:var(--text);font-weight:600}.contact-value,.contact-link{color:var(--accent);font-weight:600;overflow-wrap:anywhere}.contact-link{text-decoration:none}.copy-btn{width:32px;height:32px;border-radius:8px;border:1px solid var(--surface-border);background:var(--surface);color:var(--muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .18s ease}.copy-btn:hover{border-color:#4e88d661;background:#4e88d614}.copy-btn:focus-visible{outline:2px solid rgba(78,136,214,.35);outline-offset:2px}.copy-btn.is-copied{color:#13845b;border-color:#13845b59;background:#13845b1f}.copy-svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}.image-lightbox{position:fixed;inset:0;z-index:2200;background:#090e18b8;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);display:flex;align-items:center;justify-content:center;padding:clamp(14px,3vw,28px)}.lightbox-stage{width:min(92vw,1520px);max-height:88vh;border-radius:12px;overflow:auto;background:#ffffff0a;border:1px solid rgba(255,255,255,.2)}.lightbox-stage img{display:block;width:auto;max-width:100%;max-height:88vh;margin:0 auto;object-fit:contain}.lightbox-close{position:absolute;right:clamp(12px,2vw,20px);top:clamp(12px,2vw,20px);width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.38);background:#1c202c94;color:#fff;font-size:24px;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.filter-row{display:flex;flex-wrap:wrap;gap:8px}.filter-btn{background:var(--surface-soft);border:1px solid var(--surface-border);color:var(--text);padding:7px 12px;border-radius:10px;cursor:pointer}.filter-btn-active{color:#fff;background:var(--accent);border-color:var(--accent)}.project-grid{display:grid;grid-template-columns:1fr;gap:14px}.project-card-row{display:grid;grid-template-columns:minmax(360px,40%) minmax(0,1fr);gap:18px;align-items:stretch;min-width:0}.project-media{display:flex;align-items:center;justify-content:center;border:1px solid var(--surface-border);border-radius:12px;overflow:hidden;background:var(--surface-soft)}.media-btn{appearance:none;border:0;padding:0;width:100%;height:auto;aspect-ratio:16 / 9;position:relative;display:flex;align-items:center;justify-content:center;background:transparent;overflow:hidden}.media-btn.is-clickable{cursor:zoom-in}.project-image{position:absolute;inset:0;margin:auto;width:100%;height:100%;object-fit:contain;object-position:center center;background:var(--surface-soft);opacity:0;transition:opacity .35s ease}.project-image.is-loaded{opacity:1}.zoom-hint{position:absolute;top:10px;right:10px;width:30px;height:30px;border-radius:50%;border:1px solid rgba(255,255,255,.65);background:#00000059;pointer-events:none;opacity:0;transform:scale(.88);transition:opacity .2s ease,transform .2s ease}.media-btn.is-clickable:hover .zoom-hint,.media-btn.is-clickable:focus-visible .zoom-hint{opacity:1;transform:scale(1)}.zoom-hint:before{content:"+";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);color:#fff;font-weight:700;font-size:16px;line-height:1}.media-placeholder{position:absolute;inset:0;display:block;background:linear-gradient(120deg,var(--surface-soft),rgba(127,153,194,.14),var(--surface-soft))}.media-placeholder.is-hidden{opacity:0;pointer-events:none;transition:opacity .25s ease}.shape{position:absolute;border:1px solid rgba(127,153,194,.45);background:#7f99c21f;border-radius:50%;animation:pulse 2.2s ease-in-out infinite}.shape-one{width:64px;height:64px;left:14%;top:20%}.shape-two{width:92px;height:92px;right:13%;top:34%;animation-delay:.5s}.shape-three{width:42px;height:42px;left:46%;bottom:20%;animation-delay:.9s}.loader-ring{position:absolute;width:38px;height:38px;left:calc(50% - 19px);top:calc(50% - 19px);border-radius:50%;border:2px solid rgba(127,153,194,.3);border-top-color:var(--accent);animation:spin 1.1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.08);opacity:.45}}.project-body{min-width:0;display:grid;gap:10px}.project-headline{display:grid;gap:8px}.project-meta{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.status{font-size:.76rem;color:var(--muted);border:1px solid var(--surface-border);border-radius:999px;padding:4px 10px;width:fit-content;max-width:100%}.project-year{font-size:.85rem;color:var(--muted)}.project-summary{margin:0}.project-highlights{margin:0;padding-left:18px}.project-links{display:flex;gap:10px;flex-wrap:wrap}.project-link-btn{border:1px solid rgba(78,136,214,.34);border-radius:10px;padding:8px 12px;background:#4e88d61f;color:#295f9f;font-size:.86rem;font-weight:600;display:inline-flex;align-items:center;gap:8px;box-shadow:none}.project-link-btn:hover{text-decoration:none;border-color:#4e88d68c;background:#4e88d62e;color:#224f86}:root[data-theme=dark] .project-link-btn{border-color:#7cb1f857;background:#7ab2ff1f;color:#9ec8ff}:root[data-theme=dark] .project-link-btn:hover{border-color:#7cb1f88f;background:#7ab2ff33;color:#b6d7ff}.link-arrow{font-size:.92rem;line-height:1}.site-footer{margin-top:16px;margin-left:auto;margin-right:auto;width:fit-content;padding:8px 2px;color:var(--muted);font-size:.84rem;justify-content:center;flex-direction:row;align-items:center;gap:10px;flex-wrap:wrap;text-align:center}.icp-link{color:var(--muted);font-size:.84rem}.icp-link:visited{color:var(--muted)}.icp-link:hover{color:var(--muted);text-decoration:underline}.icp-link:active{color:var(--muted)}@media(max-width:980px){.hero,.split,.project-card-row{grid-template-columns:1fr}.site-header,.header-right{flex-direction:column;align-items:stretch}nav,.theme-tools{justify-content:center}.site-footer{text-align:center}}@media(max-width:760px){nav{width:100%;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.nav-link{text-align:center;justify-content:center;white-space:nowrap}}
