.app-wrap[data-v-bbe73a91]{min-height:100vh;display:flex;flex-direction:column}main[data-v-bbe73a91]{flex:1}.router-link-active[data-v-bbe73a91]{color:var(--accent)!important;background:var(--accent-soft)}:root{--bg: #f6f3ee;--bg-elevated: #fffdf9;--text: #1c1917;--text-muted: #57534e;--accent: #0d5c63;--accent-light: #14808a;--accent-soft: rgba(13, 92, 99, .1);--border: #e7e5e4;--shadow: 0 4px 24px rgba(28, 25, 23, .06);--radius: 12px;--font-sans: "DM Sans", "PingFang SC", "Microsoft YaHei", sans-serif;--font-serif: "Noto Serif SC", "Songti SC", serif;--max-width: 1100px;--nav-height: 64px}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:var(--font-sans);font-size:16px;line-height:1.65;color:var(--text);background:var(--bg);min-height:100vh}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 50% at 100% 0%,rgba(13,92,99,.06),transparent),radial-gradient(ellipse 60% 40% at 0% 100%,rgba(180,140,90,.08),transparent);pointer-events:none;z-index:-1}img{max-width:100%;height:auto;display:block}a{color:var(--accent);text-decoration:none;transition:color .2s}a:hover{color:var(--accent-light)}.container{width:min(100% - 2rem,var(--max-width));margin-inline:auto}.site-header{position:sticky;top:0;z-index:100;height:var(--nav-height);background:#f6f3eed9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.nav-inner{display:flex;align-items:center;justify-content:space-between;height:var(--nav-height)}.logo{font-family:var(--font-serif);font-size:1.25rem;font-weight:600;color:var(--text);letter-spacing:-.02em}.logo span{color:var(--accent)}.nav-links{display:flex;gap:.25rem;list-style:none;margin:0;padding:0}.nav-links a{display:block;padding:.5rem 1rem;color:var(--text-muted);font-size:.9375rem;font-weight:500;border-radius:8px;transition:background .2s,color .2s}.nav-links a:hover,.nav-links a.active{color:var(--accent);background:var(--accent-soft)}.nav-toggle{display:none;background:none;border:none;padding:.5rem;cursor:pointer;color:var(--text)}.hero{padding:4rem 0 3rem}.hero-grid{display:grid;grid-template-columns:1fr auto;gap:3rem;align-items:center}.hero h1{font-family:var(--font-serif);font-size:clamp(2rem,5vw,3rem);font-weight:600;line-height:1.2;margin:0 0 1rem;letter-spacing:-.03em}.hero .lead{font-size:1.125rem;color:var(--text-muted);max-width:32em;margin:0 0 1.5rem}.hero-actions{display:flex;flex-wrap:wrap;gap:.75rem}.avatar{width:140px;height:140px;border-radius:50%;object-fit:cover;border:3px solid var(--bg-elevated);box-shadow:var(--shadow);background:linear-gradient(135deg,var(--accent-soft),#d6cfc4)}.avatar-placeholder{display:flex;align-items:center;justify-content:center;font-family:var(--font-serif);font-size:2.5rem;color:var(--accent);font-weight:600}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.9375rem;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:transform .15s,box-shadow .2s,background .2s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-light);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #0d5c6340}.btn-outline{background:var(--bg-elevated);color:var(--accent);border:1.5px solid var(--border)}.btn-outline:hover{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.section{padding:3rem 0}.section-title{font-family:var(--font-serif);font-size:1.5rem;font-weight:600;margin:0 0 1.5rem;display:flex;align-items:center;gap:.75rem}.section-title:after{content:"";flex:1;height:1px;background:var(--border);max-width:120px}.post-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.post-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:transform .2s,box-shadow .2s}.post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}.post-card a{color:inherit;display:block;height:100%}.post-card-cover{height:160px;background:linear-gradient(135deg,var(--accent) 0%,#3d8b96 100%);display:flex;align-items:flex-end;padding:1rem}.post-card-cover.alt-1{background:linear-gradient(135deg,#6b4c3a,#a67c52)}.post-card-cover.alt-2{background:linear-gradient(135deg,#2d4a3e,#5a8f7b)}.post-card-cover .tag{background:#fff3;color:#fff;font-size:.75rem;padding:.25rem .625rem;border-radius:4px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.post-card-body{padding:1.25rem}.post-card h3{font-size:1.125rem;margin:0 0 .5rem;line-height:1.4}.post-card .meta{font-size:.8125rem;color:var(--text-muted);margin-bottom:.5rem}.post-card p{font-size:.9375rem;color:var(--text-muted);margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.page-header{padding:3rem 0 2rem;text-align:center}.page-header h1{font-family:var(--font-serif);font-size:clamp(1.75rem,4vw,2.5rem);margin:0 0 .5rem}.page-header p{color:var(--text-muted);margin:0;max-width:36em;margin-inline:auto}.article-layout{padding:2rem 0 4rem}.article-header{max-width:720px;margin:0 auto 2rem;text-align:center}.article-header h1{font-family:var(--font-serif);font-size:clamp(1.5rem,4vw,2.25rem);margin:0 0 1rem;line-height:1.3}.article-meta{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem;font-size:.875rem;color:var(--text-muted)}.article-content{max-width:720px;margin:0 auto;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:2rem 2.5rem;box-shadow:var(--shadow)}.article-content h2{font-family:var(--font-serif);font-size:1.375rem;margin:2rem 0 .75rem}.article-content h2:first-child{margin-top:0}.article-content p,.article-content li{color:var(--text)}.article-content pre{background:#292524;color:#e7e5e4;padding:1rem 1.25rem;border-radius:8px;overflow-x:auto;font-size:.875rem;line-height:1.5}.article-content code{font-family:JetBrains Mono,Fira Code,monospace;font-size:.9em}.article-content p code{background:var(--accent-soft);padding:.15em .4em;border-radius:4px;color:var(--accent)}.back-link{display:inline-flex;align-items:center;gap:.375rem;margin-bottom:1.5rem;font-size:.9375rem;color:var(--text-muted)}.back-link:hover{color:var(--accent)}.resume-layout{padding:2rem 0 4rem}.resume-paper{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:2.5rem 3rem;max-width:800px;margin:0 auto}.resume-header{text-align:center;padding-bottom:2rem;border-bottom:1px solid var(--border);margin-bottom:2rem}.resume-header h1{font-family:var(--font-serif);font-size:2rem;margin:0 0 .25rem}.resume-header .title{color:var(--accent);font-weight:600;margin:0 0 1rem}.resume-contact{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem 1.5rem;font-size:.875rem;color:var(--text-muted)}.resume-contact a{color:var(--text-muted)}.resume-contact a:hover{color:var(--accent)}.resume-section{margin-bottom:2rem}.resume-section:last-child{margin-bottom:0}.resume-section h2{font-family:var(--font-serif);font-size:1.125rem;color:var(--accent);margin:0 0 1rem;padding-bottom:.375rem;border-bottom:2px solid var(--accent-soft);text-transform:uppercase;letter-spacing:.05em}.resume-item{margin-bottom:1.25rem}.resume-item:last-child{margin-bottom:0}.resume-item-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:.5rem;margin-bottom:.25rem}.resume-item h3{font-size:1rem;margin:0;font-weight:600}.resume-item .period{font-size:.8125rem;color:var(--text-muted);white-space:nowrap}.resume-item .org{font-size:.9375rem;color:var(--text-muted);margin:0 0 .5rem}.resume-item ul{margin:0;padding-left:1.25rem;color:var(--text-muted);font-size:.9375rem}.resume-item li{margin-bottom:.25rem}.skill-tags{display:flex;flex-wrap:wrap;gap:.5rem}.skill-tag{background:var(--accent-soft);color:var(--accent);font-size:.8125rem;font-weight:500;padding:.375rem .75rem;border-radius:6px}.about-block{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.about-item{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.about-item h3{font-size:.875rem;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);margin:0 0 .5rem}.about-item p{margin:0;font-size:.9375rem;color:var(--text-muted)}.site-footer{margin-top:auto;padding:2rem 0;border-top:1px solid var(--border);text-align:center;font-size:.875rem;color:var(--text-muted)}.site-footer a{color:var(--text-muted)}.site-footer a:hover{color:var(--accent)}.blog-filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem;justify-content:center}.filter-btn{padding:.375rem .875rem;font-size:.875rem;font-weight:500;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-muted);border-radius:999px;cursor:pointer;transition:all .2s}.filter-btn:hover,.filter-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.empty-state{text-align:center;padding:3rem;color:var(--text-muted)}@media print{.site-header,.site-footer,.hero-actions,.back-link{display:none!important}body{background:#fff}.resume-paper{box-shadow:none;border:none;padding:0}}@media(max-width:768px){.nav-toggle{display:block}.nav-links{position:fixed;top:var(--nav-height);left:0;right:0;background:var(--bg-elevated);border-bottom:1px solid var(--border);flex-direction:column;padding:1rem;gap:0;transform:translateY(-100%);opacity:0;pointer-events:none;transition:transform .25s,opacity .25s}.nav-links.open{transform:translateY(0);opacity:1;pointer-events:auto}.nav-links a{padding:.75rem 1rem}.hero-grid{grid-template-columns:1fr;text-align:center}.hero .lead{margin-inline:auto}.hero-actions{justify-content:center}.avatar{margin:0 auto}.resume-paper{padding:1.5rem}.article-content{padding:1.25rem}}.admin-page{max-width:960px;margin:0 auto;padding:2rem 1rem 4rem}.admin-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow);margin-bottom:1.5rem}.admin-card h2{font-family:var(--font-serif);font-size:1.25rem;margin:0 0 1rem}.admin-form label{display:block;font-size:.875rem;font-weight:600;color:var(--text-muted);margin-bottom:.35rem}.admin-form .field{margin-bottom:1rem}.admin-form input,.admin-form textarea,.admin-form select{width:100%;padding:.5rem .75rem;border:1px solid var(--border);border-radius:8px;font-family:inherit;font-size:.9375rem;background:#fff}.admin-form textarea{min-height:120px;resize:vertical}.admin-toolbar{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem;align-items:center}.admin-table{width:100%;border-collapse:collapse;font-size:.875rem}.admin-table th,.admin-table td{border-bottom:1px solid var(--border);padding:.75rem .5rem;text-align:left}.admin-table th{color:var(--text-muted);font-weight:600}.status-draft{color:#b45309}.status-published{color:var(--accent)}.admin-nav{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.5rem}.admin-nav a{padding:.5rem 1rem;border-radius:8px;color:var(--text-muted);font-weight:500}.admin-nav a.router-link-active{background:var(--accent-soft);color:var(--accent)}.login-box{max-width:400px;margin:4rem auto}.msg-error{color:#b91c1c;font-size:.875rem;margin-top:.5rem}.msg-success{color:var(--accent);font-size:.875rem;margin-top:.5rem}.btn-danger{background:#b91c1c;color:#fff}.btn-danger:hover{background:#991b1b;color:#fff}.btn-sm{padding:.35rem .75rem;font-size:.8125rem}.inline-actions{display:flex;gap:.5rem;flex-wrap:wrap}
