:root,:root[data-theme=dark]{--bg: #05070d;--panel: rgba(14, 20, 35, .8);--text: #edf1ff;--muted: #94a3b8;--line: rgba(148, 163, 184, .28);--accent: #60a5fa}:root[data-theme=light]{--bg: #f3f6fb;--panel: rgba(255, 255, 255, .92);--text: #0f172a;--muted: #475569;--line: rgba(100, 116, 139, .28);--accent: #2563eb}*{box-sizing:border-box}html,body,#app{margin:0;min-height:100%;scroll-behavior:smooth}body{font-family:Inter,Noto Sans TC,system-ui,sans-serif;color:var(--text);background:radial-gradient(circle at top right,rgba(96,165,250,.2),transparent 38%),radial-gradient(circle at 12% 20%,rgba(56,189,248,.15),transparent 30%),var(--bg);line-height:1.65}a{color:var(--accent)}h1,h2,h3{margin-top:0;line-height:1.25}ul{padding-left:1.1rem}.app-shell{width:min(1180px,94vw);margin:1rem auto 3rem}.topbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;border:1px solid var(--line);border-radius:1rem;background:var(--panel);padding:.85rem 1rem;position:sticky;top:.8rem;z-index:20}.brand{font-size:1.1rem;font-weight:700}.brand-subtitle{color:var(--muted)}.brand-link{text-decoration:none;color:inherit;display:flex;align-items:center;gap:.7rem}.topbar-avatar{width:38px;height:38px;border-radius:12px;border:1px solid var(--line);object-fit:cover}.home-head{display:flex;gap:.8rem;align-items:center}.home-avatar{width:72px;height:72px;border-radius:16px;border:2px solid rgba(96,165,250,.65)}.layout-body{display:grid;grid-template-columns:220px 1fr;gap:1rem;margin-top:1rem}.side-nav,.content-panel,.breadcrumb{border:1px solid var(--line);border-radius:1rem;background:var(--panel)}.side-nav{height:fit-content;padding:1rem;position:sticky;top:5.8rem}.side-nav-title,.side-nav-jump p{margin:0 0 .45rem;color:var(--muted);font-size:.88rem}.side-nav-links,.side-nav-jump{display:grid;gap:.45rem}.side-nav a{text-decoration:none;color:var(--text);padding:.35rem .5rem;border-radius:.5rem}.side-nav a.router-link-active,.side-nav a:hover{background:#60a5fa2e}.main-content{display:grid;gap:.7rem}.breadcrumb{padding:.6rem .9rem}.content-panel{padding:1rem}.topbar-actions{display:flex;gap:.45rem}button{border:1px solid var(--line);color:var(--text);background:transparent;border-radius:999px;padding:.3rem .7rem;cursor:pointer}.scroll-top{position:fixed;right:1rem;bottom:1rem;background:#60a5fa40}.profile-wrap{display:flex;gap:1rem;align-items:center}.avatar{width:88px;height:88px;border-radius:999px;border:2px solid rgba(96,165,250,.65)}.profile-page{display:grid;gap:1rem}.panel{border:1px solid var(--line);border-radius:1rem;background:var(--panel);padding:1rem}@media (max-width: 900px){.layout-body{grid-template-columns:1fr}.side-nav{position:static;display:flex;gap:1rem;align-items:flex-start;overflow-x:auto}.side-nav-links,.side-nav-jump{min-width:180px}}@media (max-width: 640px){.app-shell{width:96vw;margin-top:.6rem}.topbar{flex-direction:column;align-items:flex-start}.topbar-actions{flex-wrap:wrap}}.eyebrow,.subtitle,.meta{margin:0;color:var(--muted)}.summary{margin:1rem 0 .8rem}.chips{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:.8rem}.chip{background:#60a5fa26;border:1px solid rgba(96,165,250,.3);border-radius:999px;padding:.2rem .7rem;font-size:.83rem}.quick-nav{display:flex;gap:.4rem;flex-wrap:wrap}.home-skill-zone{margin:1rem 0}.home-skill-zone h2{margin-bottom:.2rem}.skill-group-list{display:grid;gap:.85rem;margin-top:.75rem}.skill-group{border-top:1px dashed var(--line);padding-top:.75rem}.skill-group-title{margin:0 0 .55rem;font-size:.92rem;color:var(--muted);opacity:0;animation:skillGroupTitleIn .42s ease forwards;animation-delay:var(--group-delay, 0ms)}.skill-logo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.65rem}.skill-logo-card{text-decoration:none;color:var(--text);border:1px solid var(--line);border-radius:.8rem;padding:.65rem .45rem;display:grid;place-items:center;gap:.35rem;min-height:88px;background:#60a5fa14;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease;opacity:0;animation-name:skillCardIn,logoFloat;animation-duration:.45s,3.1s;animation-timing-function:ease,ease-in-out;animation-fill-mode:both,both;animation-delay:calc(var(--group-delay, 0ms) + .12s + var(--card-stagger, 0ms)),calc(var(--group-delay, 0ms) + .12s + var(--card-stagger, 0ms))}.skill-logo-card:hover{transform:translateY(-4px) scale(1.02);border-color:#60a5fab8;box-shadow:0 8px 18px #2563eb2e}.skill-logo{width:34px;height:34px;object-fit:contain;transition:transform .2s ease}.skill-logo-card:hover .skill-logo{transform:rotate(2deg) scale(1.03)}.skill-logo-fallback{width:34px;height:34px;border-radius:999px;display:grid;place-items:center;background:#60a5fa33;border:1px solid rgba(96,165,250,.45);font-size:.72rem;font-weight:700}@keyframes logoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes skillGroupTitleIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes skillCardIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion: reduce){.skill-logo-card{animation:none;transition:none}}.quick-nav a{border:1px solid var(--line);border-radius:999px;padding:.2rem .65rem;text-decoration:none;color:var(--muted);transition:.2s ease}.quick-nav a:hover{color:var(--text);border-color:#60a5faa6}.timeline-item+.timeline-item,.project-item+.project-item{margin-top:1rem;padding-top:1rem;border-top:1px dashed var(--line)}.note-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.7rem}.note-card{display:block;color:var(--text);border:1px solid var(--line);border-radius:.8rem;padding:.8rem;text-decoration:none;transition:transform .2s ease,border-color .2s ease}.note-card:hover{transform:translateY(-3px);border-color:#60a5faa6}.contact-list{list-style:none;padding:0;margin:0}.contact-list li+li{margin-top:.4rem}.reveal{animation:rise .6s ease both}@keyframes rise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.muted{color:var(--muted)}.notes-panel{display:grid;gap:1rem}.note-hub h3{margin:0}.note-hub p{margin:.4rem 0 0}.carousel-wrap{border:1px solid var(--line);border-radius:.9rem;padding:.8rem}.carousel-head{display:flex;justify-content:space-between;gap:.8rem;align-items:center}.carousel-controls{display:flex;gap:.4rem}.topic-tabs{display:flex;gap:.4rem;flex-wrap:wrap}.topic-tab{border:1px solid var(--line);border-radius:999px;background:transparent;color:var(--muted);padding:.2rem .6rem}.topic-tab.active{color:var(--text);border-color:#60a5faa6;background:#60a5fa33}.project-kv{margin-top:.6rem;display:grid;grid-template-columns:80px 1fr;gap:.3rem .6rem}.project-kv dt{color:var(--muted);font-weight:600}.project-kv dd{margin:0}.timeline-panel{overflow:hidden}.timeline-track{list-style:none;margin:0;padding:0;position:relative}.timeline-track:before{content:"";position:absolute;left:12px;top:4px;bottom:4px;width:2px;background:linear-gradient(180deg,#60a5facc,#60a5fa1a)}.timeline-node{position:relative;margin-left:0;padding-left:2.1rem;opacity:0;animation:timelineRise .55s ease forwards;animation-delay:var(--item-delay, 0ms)}.timeline-dot{position:absolute;left:6px;top:.4rem;width:14px;height:14px;border-radius:999px;background:var(--accent);box-shadow:0 0 0 4px #60a5fa33;animation:timelineDotPulse .68s ease-out 1 both;animation-delay:calc(var(--item-delay, 0ms) + .12s)}.timeline-card{border:1px solid var(--line);border-radius:.85rem;padding:.9rem;background:#60a5fa14;transition:transform .22s ease,border-color .22s ease,box-shadow .22s ease}.timeline-card:hover{transform:translateY(-3px);border-color:#60a5fa9e;box-shadow:0 8px 18px #2563eb29}.timeline-head{display:flex;align-items:center;gap:.55rem}.timeline-head h3{margin-bottom:0}.timeline-org-logo{width:38px;height:38px;object-fit:contain;border-radius:6px;background:#ffffffe6;border:1px solid var(--line);padding:3px;animation:logoShine 1.5s ease-in-out infinite}.timeline-tags{margin-top:.7rem}.timeline-tags .chips{margin:.35rem 0 0}@keyframes timelineRise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes timelineDotPulse{0%{transform:scale(.86);box-shadow:0 0 #60a5fa80}70%{transform:scale(1.12);box-shadow:0 0 0 10px #60a5fa00}to{transform:scale(1);box-shadow:0 0 0 4px #60a5fa33}}@keyframes logoShine{0%,72%,to{filter:brightness(1)}80%{filter:brightness(1.12)}}.carousel-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));grid-auto-rows:1fr;gap:.7rem;padding-left:0;list-style:none;margin:.8rem 0}.note-carousel-card{border:1px solid var(--line);border-radius:.9rem;padding:.8rem;background:var(--panel);height:152px;display:flex;flex-direction:column;justify-content:space-between;transition:transform .2s ease,border-color .2s ease}.note-card-title{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4;min-height:2.8em}.note-carousel-card:hover{transform:translateY(-3px);border-color:#60a5faa6}.note-date{display:inline-block;transition:transform .16s ease}.note-date:hover{transform:scale(1.03)}.note-tag-chip{transition:transform .16s ease}.note-tag-chip:hover{transform:scale(1.05)}.topic-fade-enter-active,.topic-fade-leave-active{transition:opacity .24s ease}.topic-fade-enter-from,.topic-fade-leave-to{opacity:0}.project-grid{display:grid;grid-template-columns:1fr;gap:.8rem}.project-card{height:100%}.project-card-animated{position:relative;overflow:hidden;opacity:0;animation:projectRise .5s ease forwards;animation-delay:var(--project-delay, 0ms)}.project-card-animated:before{content:"";position:absolute;left:0;right:0;top:0;height:2px;background:linear-gradient(90deg,#60a5fa26,#60a5fae6,#60a5fa26);transform:scaleX(0);transform-origin:left;transition:transform .26s ease}.project-card-animated:hover:before{transform:scaleX(1)}.project-tech-tags{margin-top:.6rem}@keyframes projectRise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.strength-list{margin:.8rem 0 0}.strength-list li+li{margin-top:.45rem}@media (prefers-reduced-motion: reduce){.timeline-node{animation:none;opacity:1}.timeline-card{transition:none}.timeline-dot,.timeline-org-logo{animation:none}.project-card-animated{animation:none;opacity:1}.project-card-animated:before{transition:none}.skill-group-title,.skill-logo-card{animation:none;opacity:1}.skill-logo,.note-date,.note-tag-chip,.topic-fade-enter-active,.topic-fade-leave-active{transition:none}}
