/* ===================================================
   家族族谱 · 管理后台样式
   桌面优先,与用户端共用同一套"墨绿+朱红印章"配色体系
   =================================================== */

:root {
    --ink: #1a1a18;
    --ink-secondary: #5c5a52;
    --ink-faint: #8a8779;
    --paper: #ffffff;
    --paper-soft: #faf8f4;
    --brand: #1c3d3a;
    --brand-light: #e8efee;
    --seal: #b23a2e;
    --seal-dark: #8e2e24;
    --seal-light: #f7e9e6;
    --border: #e4e0d6;
    --success: #3b7a3f;
    --success-light: #e7f1e8;
    --danger: #a3342b;
    --danger-light: #f7e9e6;
    --radius: 10px;
}

* { box-sizing: border-box; }
html, body {
    margin: 0; padding: 0;
    background: var(--paper-soft);
    color: var(--ink);
    font-family: -apple-system, BlinkMacSystemFont, "PingFang SC", "Microsoft YaHei", sans-serif;
    font-size: 15px;
    line-height: 1.6;
}
a { color: var(--brand); text-decoration: none; }

.admin-header {
    background: var(--brand);
    color: #fff;
    padding: 14px 24px;
    display: flex;
    align-items: center;
    gap: 18px;
    border-bottom: 3px solid var(--seal);
    flex-wrap: wrap;
}
.admin-header .logo { font-size: 17px; font-weight: 500; }
.admin-header .scope { font-size: 13px; opacity: .8; }
.admin-header .spacer { flex: 1; }
.admin-header a.logout { color: #fff; opacity: .85; font-size: 13px; }

.admin-tabs {
    background: var(--paper);
    border-bottom: 1px solid var(--border);
    display: flex;
    gap: 4px;
    padding: 0 24px;
    overflow-x: auto;
}
.admin-tabs a {
    padding: 14px 16px;
    font-size: 14px;
    color: var(--ink-secondary);
    border-bottom: 3px solid transparent;
    white-space: nowrap;
}
.admin-tabs a.active { color: var(--seal); border-bottom-color: var(--seal); font-weight: 500; }

.admin-content {
    max-width: 960px;
    margin: 0 auto;
    padding: 24px;
}

.admin-card {
    background: var(--paper);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 20px;
    margin-bottom: 20px;
}
.admin-card h2 {
    font-size: 16px;
    font-weight: 500;
    margin: 0 0 14px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.admin-card h2 .hint { font-size: 13px; font-weight: 400; color: var(--ink-faint); }

.stat-grid { display: flex; gap: 14px; flex-wrap: wrap; }
.stat-box {
    flex: 1;
    min-width: 120px;
    background: var(--brand-light);
    border-radius: var(--radius);
    padding: 16px;
    text-align: center;
}
.stat-box .num { font-size: 26px; font-weight: 600; color: var(--brand); }
.stat-box .label { font-size: 13px; color: var(--ink-secondary); margin-top: 4px; }

table { width: 100%; border-collapse: collapse; font-size: 14px; }
table th, table td { text-align: left; padding: 10px 8px; border-bottom: 1px solid var(--border); }
table th { color: var(--ink-secondary); font-weight: 500; font-size: 13px; }
table tr:hover td { background: var(--paper-soft); }

.btn {
    display: inline-flex; align-items: center; justify-content: center;
    min-height: 38px; padding: 0 16px;
    border-radius: var(--radius);
    font-size: 14px; font-weight: 500;
    border: 1px solid transparent;
    cursor: pointer;
    background: var(--paper);
}
.btn-primary { background: var(--seal); color: #fff; }
.btn-outline { background: var(--paper); color: var(--brand); border-color: var(--brand); }
.btn-danger { color: var(--danger); border-color: var(--danger); }
.btn-sm { min-height: 30px; padding: 0 10px; font-size: 13px; }

.form-row { margin-bottom: 14px; }
.form-row label { display: block; font-size: 13px; color: var(--ink-secondary); margin-bottom: 6px; }
.form-control {
    width: 100%; min-height: 38px; padding: 8px 12px;
    font-size: 14px; border: 1px solid var(--border); border-radius: var(--radius);
    background: var(--paper); color: var(--ink); font-family: inherit;
}
.inline-form { display: flex; gap: 10px; align-items: flex-end; flex-wrap: wrap; }
.inline-form .form-row { margin-bottom: 0; flex: 1; min-width: 160px; }

.flash { padding: 10px 14px; border-radius: var(--radius); margin-bottom: 16px; font-size: 14px; }
.flash.success { background: var(--success-light); color: var(--success); }
.flash.error { background: var(--danger-light); color: var(--danger); }

.tag {
    display: inline-block; font-size: 12px; padding: 2px 8px;
    border-radius: 100px; background: var(--brand-light); color: var(--brand);
}
.tag.seal { background: var(--seal-light); color: var(--seal-dark); }
.muted { color: var(--ink-secondary); }
.empty-state { text-align: center; color: var(--ink-faint); padding: 30px; }
