/* ===== ml-biomat.com - Professional Academic Blog ===== */
:root {
    --c-bg: #fafbfc;
    --c-surface: #ffffff;
    --c-fg: #1e293b;
    --c-fg-soft: #475569;
    --c-muted: #94a3b8;
    --c-primary: #1e40af;
    --c-primary-soft: #dbeafe;
    --c-accent: #0d9488;
    --c-accent-soft: #ccfbf1;
    --c-border: #e2e8f0;
    --c-code-bg: #f1f5f9;
    --c-code-fg: #334155;
    --c-lang-en: #2563eb;
    --c-lang-zh: #dc2626;
    --r: 8px;
    --r-sm: 5px;
    --shadow-sm: 0 1px 2px rgba(0,0,0,.04);
    --shadow: 0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
    --shadow-md: 0 4px 6px rgba(0,0,0,.05),0 2px 4px rgba(0,0,0,.04);
    --max-w: 760px;
    --max-w-wide: 1020px;
    --font-sans: -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Noto Sans SC","Microsoft YaHei",sans-serif;
    --font-mono: "SF Mono","Fira Code","Consolas","Microsoft YaHei",monospace
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;line-height:1.75;color:var(--c-fg);background:var(--c-bg);font-family:var(--font-sans);-webkit-font-smoothing:antialiased}
body{min-height:100vh;display:flex;flex-direction:column}
a{color:var(--c-primary);text-decoration:none;transition:color .15s}
a:hover{color:var(--c-accent)}
img{max-width:100%;height:auto}
.container{max-width:var(--max-w);margin:0 auto;padding:0 1.5rem}
.container-wide{max-width:var(--max-w-wide)}

.site-header{background:var(--c-surface);border-bottom:1px solid var(--c-border);position:sticky;top:0;z-index:100}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:56px;max-width:var(--max-w-wide);margin:0 auto;padding:0 1.5rem;gap:1rem}
.site-brand{display:flex;align-items:baseline;gap:.5rem}
.site-logo{font-size:1.15rem;font-weight:700;color:var(--c-fg);letter-spacing:-.01em}
.site-logo:hover{color:var(--c-primary)}
.site-logo .dot{color:var(--c-accent)}
.nav-links{display:flex;align-items:center;gap:.25rem;font-size:.85rem}
.nav-links a{padding:.4rem .75rem;border-radius:var(--r-sm);color:var(--c-fg-soft);font-weight:500}
.nav-links a:hover,.nav-links a.active{background:var(--c-primary-soft);color:var(--c-primary)}
.lang-switch{display:flex;border:1px solid var(--c-border);border-radius:var(--r-sm);overflow:hidden;margin-left:.5rem}
.lang-switch a{padding:.25rem .55rem;font-size:.78rem;font-weight:600;border-radius:0;color:var(--c-muted)}
.lang-switch a.active{background:var(--c-primary);color:#fff}
.lang-switch a:hover:not(.active){background:var(--c-primary-soft)}

.hero{padding:3rem 0 1.5rem}
.hero h1{font-size:2rem;font-weight:800;letter-spacing:-.03em;line-height:1.2;margin-bottom:.5rem}
.hero .subtitle{font-size:1.05rem;color:var(--c-fg-soft);max-width:580px;line-height:1.65}
.badge-row{display:flex;gap:.5rem;margin-top:1rem;flex-wrap:wrap}
.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.25rem .65rem;font-size:.78rem;font-weight:600;border-radius:999px;background:var(--c-primary-soft);color:var(--c-primary)}

.section-head{display:flex;align-items:baseline;justify-content:space-between;margin:2.5rem 0 1rem;padding-bottom:.6rem;border-bottom:2px solid var(--c-border)}
.section-head h2{font-size:1.2rem;font-weight:700}
.section-head .lang-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:.4rem}
.section-head .lang-dot.en{background:var(--c-lang-en)}
.section-head .lang-dot.zh{background:var(--c-lang-zh)}
.section-head .view-all{font-size:.85rem;font-weight:500;color:var(--c-muted)}
.section-head .view-all:hover{color:var(--c-primary)}

.post-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem}
.post-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r);padding:1.25rem 1.35rem;transition:box-shadow .2s,border-color .2s}
.post-card:hover{box-shadow:var(--shadow-md);border-color:var(--c-primary-soft)}
.card-lang{display:inline-block;font-size:.68rem;font-weight:700;text-transform:uppercase;padding:1px 7px;border-radius:999px;margin-bottom:.5rem}
.card-lang.en{background:#eff6ff;color:var(--c-lang-en)}
.card-lang.zh{background:#fef2f2;color:var(--c-lang-zh)}
.post-card h3{font-size:1.05rem;font-weight:700;line-height:1.35;margin-bottom:.3rem}
.post-card h3 a{color:var(--c-fg)}
.post-card h3 a:hover{color:var(--c-primary)}
.card-meta{font-size:.78rem;color:var(--c-muted);margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}
.card-desc{font-size:.85rem;color:var(--c-fg-soft);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.card-tags{display:flex;gap:.35rem;flex-wrap:wrap;margin-top:.6rem}
.tag-pill{font-size:.7rem;color:var(--c-muted);background:var(--c-code-bg);padding:1px 8px;border-radius:999px}

.article-header{margin-bottom:2rem}
.lang-badge{display:inline-block;font-size:.7rem;font-weight:700;text-transform:uppercase;padding:2px 9px;border-radius:999px;margin-bottom:.75rem}
.lang-badge.en{background:#eff6ff;color:var(--c-lang-en)}
.lang-badge.zh{background:#fef2f2;color:var(--c-lang-zh)}
.article-header h1{font-size:2rem;font-weight:800;line-height:1.2;letter-spacing:-.03em}
.article-meta{display:flex;align-items:center;gap:.75rem;margin-top:.6rem;font-size:.85rem;color:var(--c-muted);flex-wrap:wrap}
.content{margin-top:2rem;font-size:1.02rem}
.content h2{font-size:1.4rem;font-weight:700;margin:2.5rem 0 .6rem;padding-bottom:.35rem;border-bottom:2px solid var(--c-border)}
.content h3{font-size:1.12rem;font-weight:700;margin:2rem 0 .4rem}
.content p{margin:.85rem 0}
.content ul,.content ol{margin:.5rem 0;padding-left:1.5rem}
.content li{margin:.25rem 0}
.content blockquote{margin:1.25rem 0;padding:.6rem 1.1rem;border-left:3px solid var(--c-accent);background:var(--c-accent-soft);border-radius:0 var(--r-sm) var(--r-sm) 0;font-style:italic;color:var(--c-fg-soft);font-size:.95rem}
.content strong{color:var(--c-fg);font-weight:700}
.content a{text-decoration:underline;text-underline-offset:2px;text-decoration-color:var(--c-primary-soft)}
.content hr{margin:2rem 0;border:none;border-top:1px solid var(--c-border)}
.content img{border-radius:var(--r-sm);margin:1rem 0}
.content table{width:100%;border-collapse:collapse;margin:1.25rem 0;font-size:.9rem}
.content th,.content td{border:1px solid var(--c-border);padding:.55rem .75rem;text-align:left}
.content th{background:var(--c-code-bg);font-weight:600;font-size:.82rem;color:var(--c-fg-soft)}
:not(pre)>code{font-family:var(--font-mono);font-size:.88em;background:var(--c-code-bg);color:var(--c-fg-soft);padding:.12em .4em;border-radius:3px;font-weight:500}
pre{background:var(--c-code-bg);border:1px solid var(--c-border);border-radius:var(--r);padding:1rem 1.2rem;overflow-x:auto;margin:1.25rem 0;font-size:.85rem;line-height:1.6}
pre code{font-family:var(--font-mono);font-size:inherit;background:none;padding:0;color:var(--c-code-fg)}

.section-title{font-size:1.5rem;font-weight:800;margin-bottom:1.5rem}
.section-title .highlight{color:var(--c-primary)}
.post-list-simple{list-style:none;display:flex;flex-direction:column;gap:.25rem}
.post-row{display:flex;align-items:baseline;gap:.75rem;padding:.55rem 0;border-bottom:1px solid var(--c-border);font-size:.95rem}
.row-date{font-size:.78rem;color:var(--c-muted);white-space:nowrap;min-width:5.5rem}
.post-row a{font-weight:600;color:var(--c-fg)}
.post-row a:hover{color:var(--c-primary)}
.pagination{display:flex;justify-content:space-between;align-items:center;margin:2.5rem 0;padding:1rem 0;border-top:1px solid var(--c-border);font-size:.88rem}
.pagination a{padding:.4rem 1rem;border:1px solid var(--c-border);border-radius:var(--r-sm);font-weight:500}
.pagination a:hover{border-color:var(--c-primary);color:var(--c-primary)}

.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:1rem}
.about-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r);padding:1.5rem}
.about-card h2{font-size:1.1rem;font-weight:700;margin-bottom:.75rem}
.about-card p,.about-card li{font-size:.9rem;color:var(--c-fg-soft);line-height:1.7}
.about-card ul{list-style:none;padding:0}
.about-card li::before{content:"\2192";margin-right:.5rem;color:var(--c-accent)}
.cta-banner{background:linear-gradient(135deg,var(--c-primary),#3b82f6);border-radius:var(--r);padding:2rem;margin:2rem 0;color:#fff;text-align:center}
.cta-banner h3{font-size:1.1rem;font-weight:700;margin-bottom:.5rem}
.cta-banner p{font-size:.9rem;opacity:.9;margin-bottom:1rem}
.cta-banner a{display:inline-block;padding:.5rem 1.5rem;background:#fff;color:var(--c-primary);border-radius:999px;font-weight:700;font-size:.88rem}

.site-footer{margin-top:auto;border-top:1px solid var(--c-border);background:var(--c-surface);padding:2rem 0;font-size:.82rem;color:var(--c-muted)}
.footer-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;max-width:var(--max-w-wide);margin:0 auto;padding:0 1.5rem}
.footer-links{display:flex;gap:1.25rem}
.footer-links a{color:var(--c-muted)}
.footer-links a:hover{color:var(--c-primary)}

@media(max-width:768px){
    html{font-size:15px}
    .header-inner{height:52px;padding:0 1rem}
    .site-logo{font-size:1rem}
    .hero h1{font-size:1.6rem}
    .hero .subtitle{font-size:.95rem}
    .post-grid{grid-template-columns:1fr}
    .article-header h1{font-size:1.5rem}
    .about-grid{grid-template-columns:1fr}
    .footer-inner{flex-direction:column;text-align:center}
    .container{padding:0 1rem}
}
@media(prefers-color-scheme:dark){
    :root{
        --c-bg:#0f172a;--c-surface:#1e293b;--c-fg:#e2e8f0;
        --c-fg-soft:#94a3b8;--c-muted:#64748b;
        --c-primary:#60a5fa;--c-primary-soft:#1e3a5f;
        --c-accent:#2dd4bf;--c-accent-soft:#134e4a;
        --c-border:#334155;--c-code-bg:#1e293b;--c-code-fg:#cbd5e1
    }
    .card-lang.en,.lang-badge.en{background:#1e3a5f;color:#93c5fd}
    .card-lang.zh,.lang-badge.zh{background:#450a0a;color:#fca5a5}
}
/* ===== CV Page ===== */
.pub-list{font-size:.9rem;line-height:1.85;text-align:justify}
.pub-list li{margin:.65rem 0}
.cv-page .content p,.cv-page .content li,.cv-page .content td{text-align:justify}
.cv-page table td{padding:.5rem .75rem;vertical-align:top}
.cv-page table td:first-child{min-width:120px}
