:root{--bg: #f4efe6;--bg-accent: #efe3d2;--panel: rgba(255, 252, 246, .82);--panel-strong: #fff8ef;--text: #1d261f;--muted: #5f645f;--line: rgba(29, 38, 31, .12);--brand: #1d6b57;--brand-strong: #114739;--danger: #a43b26;--shadow: 0 16px 40px rgba(42, 35, 26, .08);font-family:Noto Sans TC,sans-serif;color:var(--text);background:radial-gradient(circle at top left,rgba(231,195,137,.32),transparent 28%),radial-gradient(circle at top right,rgba(88,145,125,.22),transparent 24%),linear-gradient(180deg,#f8f2e8,#f4efe6)}*{box-sizing:border-box}body{margin:0;min-height:100vh}a{color:inherit;text-decoration:none}button,input,textarea{font:inherit}input[type=file]{padding:0;background:transparent;border:0}#root{min-height:100vh}.shell{width:min(1320px,calc(100vw - 32px));margin:0 auto;padding:24px 0 64px}.shell-wide{width:min(1800px,calc(100vw - 24px))}.topbar{display:flex;justify-content:space-between;align-items:center;gap:20px;padding:16px 0 28px}.brand{display:flex;align-items:center;gap:14px}.brand p{margin:4px 0 0;color:var(--muted);font-size:.95rem}.brand-mark{display:inline-grid;place-items:center;width:48px;height:48px;border-radius:18px;background:linear-gradient(135deg,var(--brand),#d48c56);color:#fff;font-family:Manrope,sans-serif;font-weight:800}.nav{display:flex;align-items:center;gap:18px;flex-wrap:wrap}.nav a.active{color:var(--brand)}.page-shell{position:relative;overflow:clip}.page,.stack{display:grid;gap:20px}.home-intro-active{position:relative}.home-intro{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;display:grid;place-items:center;gap:14px;padding:24px;background:radial-gradient(circle at 20% 20%,rgba(255,215,142,.28),transparent 24%),radial-gradient(circle at 78% 18%,rgba(29,107,87,.24),transparent 22%),linear-gradient(135deg,#111814eb,#1c2b25e0);color:#fff9f1;text-align:center;overflow:hidden}.home-intro:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(110deg,transparent 18%,rgba(255,255,255,.22) 34%,transparent 49%),radial-gradient(circle,rgba(255,243,220,.18),transparent 56%);mix-blend-mode:screen;animation:home-intro-sheen 1.2s cubic-bezier(.16,.84,.26,1) .18s both}.home-intro-closing{animation:home-intro-fade .72s cubic-bezier(.2,.8,.2,1) forwards}.home-intro-mark,.home-intro-kicker,.home-intro h1,.home-intro-scroll-hint{position:relative;z-index:1}.home-intro-mark{display:inline-grid;place-items:center;width:88px;height:88px;border:1px solid rgba(255,249,241,.28);border-radius:28px;background:linear-gradient(135deg,#ffffff2e,#d48c5629);font-family:Manrope,sans-serif;font-size:2rem;font-weight:800;letter-spacing:.08em;box-shadow:0 20px 50px #0000003d;animation:home-intro-rise .82s cubic-bezier(.16,.84,.26,1) both}.home-intro-kicker{margin:0;font-size:.8rem;letter-spacing:.24em;text-transform:uppercase;opacity:.78;animation:home-intro-rise .9s cubic-bezier(.16,.84,.26,1) 80ms both}.home-intro h1{margin:0;font-family:Manrope,sans-serif;font-size:clamp(2rem,7vw,4.8rem);line-height:.94;animation:home-intro-rise .98s cubic-bezier(.16,.84,.26,1) .14s both}.home-intro-scroll-hint{margin-top:8px;font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;opacity:.7;animation:home-intro-rise 1.04s cubic-bezier(.16,.84,.26,1) .22s both,home-intro-pulse 1.8s ease-in-out 1.2s infinite}.route-transition{position:relative;isolation:isolate}.route-transition:before,.route-transition:after{content:"";position:absolute;pointer-events:none;opacity:0}.route-transition:before{inset:-40px auto auto -24px;width:min(420px,52vw);height:220px;border-radius:999px;background:radial-gradient(circle at 30% 50%,rgba(255,236,179,.8),transparent 42%),linear-gradient(110deg,#ffffff1f,#1d6b572e,#d48c5642);filter:blur(14px);transform:translate3d(-12%,12%,0) rotate(-10deg);animation:route-sheen .84s cubic-bezier(.2,.8,.2,1)}.route-transition:after{top:0;right:0;bottom:0;left:0;border-radius:32px;background:linear-gradient(135deg,rgba(255,255,255,.42),transparent 18%,transparent 82%,rgba(17,71,57,.08)),linear-gradient(180deg,rgba(255,255,255,.22),transparent 20%);animation:route-frame .62s ease-out}.route-transition-content{position:relative;z-index:1;animation:route-content-in .62s cubic-bezier(.2,.8,.2,1)}.route-transition-content>*{animation:route-rise .76s cubic-bezier(.18,.8,.22,1)}.editor-split{display:grid;grid-template-columns:minmax(0,1.7fr) minmax(360px,.7fr);gap:20px;align-items:start}.blog-editor-page{width:min(1720px,100%)}.hero,.grid-two,.section-header,.action-row,.post-meta,.inline-form,.modal-header{display:flex;gap:16px}.hero{align-items:stretch}.hero-copy,.hero-card,.hero-photo-card,.panel{border:1px solid var(--line);border-radius:28px;background:var(--panel);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:var(--shadow)}.hero-copy{flex:1.5;padding:32px}.hero-photo-card{width:min(320px,100%);overflow:hidden;background:linear-gradient(180deg,#fff8eff2,#efe3d2cc)}.hero-photo{width:100%;aspect-ratio:4 / 5;object-fit:cover;display:block}.hero-photo-placeholder{display:grid;place-items:center;background:linear-gradient(135deg,var(--brand),#d48c56);color:#fff;font-family:Manrope,sans-serif;font-size:5rem;font-weight:800}.hero-photo-meta{padding:20px 22px 24px}.hero-photo-meta p{margin:8px 0 0;color:var(--muted)}.hero-copy h1,.hero-copy h2,.section-header h1,.article h1,.panel h2,.auth-card h1{font-family:Manrope,sans-serif;margin:0}.hero-copy h1{font-size:clamp(2.6rem,8vw,4.8rem);line-height:.92}.hero-copy h2{margin-top:10px;font-size:clamp(1.2rem,2.6vw,1.8rem);color:var(--muted);font-weight:500}.hero-card{width:min(280px,100%);padding:28px;background:linear-gradient(180deg,var(--panel-strong),rgba(255,248,239,.8))}.label,.eyebrow,.section-heading span{display:inline-flex;align-items:center;width:fit-content;padding:6px 12px;border-radius:999px;background:var(--bg-accent);color:var(--brand-strong);font-size:.82rem;letter-spacing:.03em;text-transform:uppercase}.panel{padding:28px}.preview-pane{position:sticky;top:24px}.grid-two{align-items:flex-start}.grid-two>*{flex:1}.section-header,.action-row,.post-meta,.modal-header{justify-content:space-between;align-items:center}.post-meta,.muted{color:var(--muted);font-size:.92rem}.tag-row,.link-row{display:flex;flex-wrap:wrap;gap:10px}.experience-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.publication-card{display:grid;gap:12px;padding:18px 0;border-top:1px solid var(--line)}.publication-card:first-child{border-top:0;padding-top:0}.publication-card-editing{padding:18px;border:1px solid var(--line);border-radius:20px;background:#fff6}.publication-copy{gap:8px}.latest-posts-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.latest-post-card{display:grid;gap:14px;padding:22px;border:1px solid var(--line);border-radius:24px;background:linear-gradient(180deg,#fffcf6eb,#f5ede0c2),linear-gradient(135deg,rgba(29,107,87,.06),transparent 45%);box-shadow:var(--shadow)}.latest-post-card h3{margin:0;font-family:Manrope,sans-serif;font-size:1.15rem}.overview-masonry{column-count:2;column-gap:20px}.overview-editor-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;align-items:start}.overview-editor-item{display:grid;gap:12px}.overview-editor-item.is-dragging{opacity:.58}.overview-editor-handle{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;border:1px dashed rgba(29,107,87,.28);border-radius:18px;background:#fffcf6bd;color:var(--brand-strong);cursor:grab}.overview-editor-handle span{font-family:Manrope,sans-serif;font-weight:700}.overview-editor-handle small{color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.overview-editor-item:active .overview-editor-handle{cursor:grabbing}.overview-masonry-item{break-inside:avoid;margin-bottom:20px}.overview-masonry-item .panel{margin:0}.publication-title-link,.publication-card h3{margin:0;font-family:Manrope,sans-serif;font-size:1.08rem;color:var(--brand-strong)}.experience-card{display:grid;gap:12px;min-height:320px;overflow:hidden;padding:0 0 24px;border:1px solid var(--line);border-radius:24px;background:linear-gradient(180deg,#fff8eff2,#f5ede0cc),linear-gradient(135deg,rgba(29,107,87,.05),transparent 40%);box-shadow:var(--shadow);transition:transform .18s ease,box-shadow .18s ease}.experience-card:hover{transform:translateY(-4px);box-shadow:0 20px 44px #2a231a24}.experience-card-editing:hover{transform:none}.experience-card h3,.experience-card strong{margin:0}.experience-card h3,.experience-card strong,.experience-card p,.experience-card .primary-link,.experience-card .label,.experience-summary{margin-left:24px;margin-right:24px}.experience-summary{line-height:1.7}.project-summary{color:var(--muted);line-height:1.7}.experience-summary>:first-child{margin-top:0}.project-summary>:first-child,.experience-summary>:first-child{margin-top:0}.project-summary>:last-child,.experience-summary>:last-child{margin-bottom:0}.project-summary ul,.project-summary ol,.experience-summary ul,.experience-summary ol{padding-left:1.25rem}.experience-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.experience-logo{width:52px;height:52px;object-fit:cover;border-radius:16px;background:#fff;border:1px solid rgba(29,38,31,.08);box-shadow:0 10px 20px #1d261f14;margin-right:24px}.experience-project-image{width:100%;height:180px;object-fit:cover;margin-bottom:10px}.post-cover,.article-cover{width:100%;object-fit:cover;border-radius:20px;margin-bottom:18px}.post-cover{height:220px}.article-cover{height:min(420px,52vw)}.tag,.link-row a,.primary-link{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:#11473914}.primary-link,.link-row a{color:var(--brand-strong)}.primary-button,.danger-button,.text-button{border:none;cursor:pointer}.primary-button,.danger-button{padding:12px 16px;border-radius:14px;color:#fff}.primary-button{background:linear-gradient(135deg,var(--brand),#2f8b73)}.danger-button{background:var(--danger)}.text-button{background:transparent;color:var(--brand-strong);padding:0}.markdown-body{line-height:1.8}.markdown-body h1,.markdown-body h2,.markdown-body h3{font-family:Manrope,sans-serif}.intro p:first-child{margin-top:0}.article-summary{font-size:1.1rem;color:var(--muted)}.auth-card{width:min(520px,100%);margin:64px auto 0}input,textarea{width:100%;border-radius:16px;border:1px solid var(--line);padding:14px 16px;background:#ffffffbf}textarea{min-height:140px}textarea{resize:vertical}.checkbox{display:flex;align-items:center;gap:10px}.checkbox input{width:auto}.upload-field{display:grid;gap:8px;padding:14px 16px;border-radius:16px;border:1px dashed var(--line);background:#ffffff8c}.image-manager{display:grid;gap:10px}.image-preview{width:100%;object-fit:cover;border-radius:18px;border:1px solid var(--line);background:#fffc}.image-preview-avatar{width:120px;height:120px}.image-preview-logo{width:96px;height:96px}.image-preview-banner{max-height:220px}.inline-edit-stack{gap:12px}.inline-edit-textarea{min-height:120px}.inline-edit-links{display:grid}.inline-chip-editor{width:100%}.inline-experience-form{padding:0 24px 24px}.award-badge{display:inline-flex;width:fit-content;margin:0;padding:7px 12px;border-radius:999px;background:#d48c5629;color:#8a4d1f;font-size:.88rem;font-weight:700}.preview-card{min-height:auto}.inline-post-editor{padding:24px}.guestbook-entry-editing{border-color:#1d6b5747;background:#ffffffe0}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1d261f57;display:grid;place-items:center;padding:20px}.modal{width:min(840px,100%);max-height:90vh;overflow:auto;border-radius:28px;background:#fffdf8;padding:24px;box-shadow:0 24px 60px #1d261f2e}.nested-panel{padding:18px;border-radius:20px;background:#f8f2e8cc;box-shadow:none}.error-text{color:var(--danger)}@keyframes route-sheen{0%{opacity:0;transform:translate3d(-12%,14%,0) rotate(-10deg) scale(.94)}35%{opacity:.9}to{opacity:0;transform:translate3d(18%,-8%,0) rotate(-6deg) scale(1.06)}}@keyframes home-intro-rise{0%{opacity:0;transform:translateY(26px) scale(.94);filter:blur(8px)}to{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}}@keyframes home-intro-sheen{0%{opacity:0;transform:translate(-14%) scaleX(.9)}30%{opacity:1}to{opacity:0;transform:translate(16%) scaleX(1.05)}}@keyframes home-intro-fade{0%{opacity:1;visibility:visible}to{opacity:0;visibility:hidden}}@keyframes home-intro-pulse{0%,to{opacity:.45;transform:translateY(0)}50%{opacity:.85;transform:translateY(6px)}}@keyframes route-frame{0%{opacity:0;transform:scale(.985)}to{opacity:1;transform:scale(1)}}@keyframes route-content-in{0%{opacity:0;transform:translateY(18px) scale(.985);filter:blur(10px)}to{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}}@keyframes route-rise{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}@media(max-width:860px){.topbar,.hero,.grid-two,.editor-split,.section-header,.action-row,.post-meta,.inline-form{flex-direction:column;align-items:stretch}.hero-card,.grid-two>*{width:100%}.shell{width:min(100vw - 20px,1120px)}.experience-grid,.latest-posts-grid{grid-template-columns:1fr}.overview-masonry{column-count:1}.overview-editor-grid{grid-template-columns:1fr}.preview-pane{position:static}.route-transition:before{width:min(300px,68vw);height:180px}}@media(prefers-reduced-motion:reduce){.home-intro,.home-intro:before,.home-intro-mark,.home-intro-kicker,.home-intro h1,.home-intro-scroll-hint,.route-transition:before,.route-transition:after,.route-transition-content,.route-transition-content>*{animation:none}}
