:root {
    --bg: #f4f7fb;
    --panel: #ffffff;
    --panel-soft: #f8fafc;
    --line: #e5e9f0;
    --line-strong: #d7dde7;
    --text: #172033;
    --muted: #718096;
    --blue: #2563eb;
    --blue-dark: #1d4ed8;
    --blue-soft: #eaf1ff;
    --green: #16a34a;
    --green-soft: #eaf8ef;
    --amber: #d97706;
    --amber-soft: #fff7e6;
    --red: #dc2626;
    --red-soft: #fff1f1;
    --cyan: #0891b2;
    --cyan-soft: #e6f7fb;
    --violet: #7c3aed;
    --violet-soft: #f3e8ff;
    --shadow: 0 18px 42px rgba(22, 31, 55, 0.08);
    --shadow-soft: 0 14px 34px rgba(22, 31, 55, 0.06);
    --shadow-strong: 0 24px 54px rgba(22, 31, 55, 0.12);
}

* { box-sizing: border-box; }

html { min-height: 100%; background: var(--bg); }

body {
    height: 100vh;
    margin: 0;
    font-family: "Microsoft YaHei", "Segoe UI", Arial, sans-serif;
    color: var(--text);
    background:
        linear-gradient(135deg, rgba(255, 255, 255, .92) 0%, rgba(239, 246, 255, .68) 38%, rgba(236, 253, 245, .46) 100%),
        var(--bg);
    font-size: 14px;
}

a { color: var(--blue); text-decoration: none; }
a:hover { color: var(--blue-dark); }

button {
    height: 36px;
    border: 0;
    border-radius: 8px;
    background: var(--blue);
    color: white;
    padding: 0 16px;
    cursor: pointer;
    font: inherit;
    font-weight: 600;
    box-shadow: 0 8px 18px rgba(37, 99, 235, 0.18);
    transition: transform .16s ease, background .16s ease, border-color .16s ease, box-shadow .16s ease;
}

button:hover { background: var(--blue-dark); transform: translateY(-1px); }
button:active { transform: translateY(0); }
button:disabled,
button[disabled] {
    opacity: .62 !important;
    cursor: not-allowed !important;
    transform: none !important;
    box-shadow: none !important;
    filter: saturate(.68);
}
button:disabled:hover,
button[disabled]:hover {
    transform: none !important;
}
button.ghost, .icon-button {
    background: var(--panel-soft);
    color: var(--text);
    border: 1px solid var(--line);
    box-shadow: none;
}
button.danger { background: var(--red); box-shadow: 0 8px 18px rgba(220, 38, 38, 0.16); }

input, select, textarea {
    width: 100%;
    min-height: 38px;
    border: 1px solid var(--line-strong);
    border-radius: 8px;
    padding: 7px 10px;
    font: inherit;
    color: var(--text);
    background: #fff;
    outline: none;
    transition: border-color .16s ease, box-shadow .16s ease;
}

input:focus, select:focus, textarea:focus {
    border-color: var(--blue);
    box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.12);
}

[data-autosave].autosaving {
    border-color: var(--blue);
}

[data-autosave].autosave-error {
    border-color: var(--red);
    box-shadow: 0 0 0 4px rgba(220, 38, 38, 0.12);
}

textarea { resize: vertical; line-height: 1.65; }
label { color: var(--muted); font-size: 13px; }
label input, label select { margin-top: 6px; }

.app-shell { display: flex; min-height: 100vh; }

.sidebar {
    position: sticky;
    top: 0;
    width: 236px;
    height: 100vh;
    padding: 18px 14px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(247, 250, 252, 0.9));
    backdrop-filter: blur(18px);
    border-right: 1px solid var(--line);
    display: flex;
    flex-direction: column;
}

.brand {
    display: flex;
    align-items: center;
    gap: 12px;
    height: 52px;
    padding: 0 8px 16px;
    border-bottom: 1px solid var(--line);
}

.brand-mark {
    width: 38px;
    height: 38px;
    display: grid;
    place-items: center;
    overflow: hidden;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.brand-mark img {
    width: 100%;
    height: 100%;
    max-width: 100%;
    max-height: 100%;
    display: block;
    object-fit: contain;
}

.brand strong { display: block; font-size: 18px; line-height: 1; }
.brand small { display: block; margin-top: 5px; color: var(--muted); font-size: 12px; }

.sidebar nav {
    display: grid;
    gap: 6px;
    padding: 18px 0;
}

.sidebar a,
.sidebar .logout {
    position: relative;
    display: flex;
    align-items: center;
    gap: 10px;
    min-height: 42px;
    padding: 0 12px;
    border-radius: 10px;
    color: #394255;
    font-weight: 600;
    transition: background .16s ease, color .16s ease, transform .16s ease;
}

.sidebar nav a span {
    width: 24px;
    height: 24px;
    display: grid;
    place-items: center;
    border-radius: 7px;
    background: #eef2f7;
    color: #617086;
    font-size: 12px;
}

.sidebar a.active {
    color: #0f3ea8;
    background: linear-gradient(135deg, #eaf1ff, #eefcf5);
    box-shadow: 0 10px 24px rgba(37, 99, 235, .08);
}

.sidebar a.active span {
    background: var(--blue);
    color: white;
}

.sidebar a:hover,
.sidebar .logout:hover { background: #f2f5fa; transform: translateX(2px); }
.sidebar a.active:hover { background: linear-gradient(135deg, #eaf1ff, #eefcf5); transform: none; }
.logout-form { margin-top: auto; }
.logout {
    width: 100%;
    background: #f8fafc;
    border: 1px solid var(--line);
    justify-content: center;
    cursor: pointer;
    font: inherit;
}

.content-shell { flex: 1; min-width: 0; display: flex; flex-direction: column; }

.topbar {
    height: 78px;
    padding: 16px 24px 10px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.topbar p, .panel-head p {
    margin: 0 0 4px;
    color: var(--muted);
    font-size: 12px;
    letter-spacing: 0;
}

.topbar h1 {
    margin: 0;
    font-size: 24px;
    letter-spacing: 0;
}

.topbar-stats {
    position: fixed;
    top: 28px;
    right: 24px;
    z-index: 60;
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: flex-end;
    margin-left: 0;
    padding: 0;
    pointer-events: none;
}

.topbar-stats > * {
    pointer-events: auto;
}

.topbar-stats > span {
    min-height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 0 12px;
    background: rgba(255, 255, 255, .74);
    color: #475569;
    font-weight: 600;
    min-width: 88px;
    box-shadow: 0 8px 20px rgba(22, 31, 55, .05);
}

.stat-pill {
    gap: 7px;
}

.stat-pill b {
    font: inherit;
    color: inherit;
}

.stat-pill i {
    width: 22px;
    height: 22px;
    display: inline-grid;
    place-items: center;
    border-radius: 50%;
    font-style: normal;
    font-size: 12px;
    font-weight: 900;
}

.stat-pill.users {
    border-color: var(--line);
    background: rgba(255, 255, 255, .74);
    color: #475569;
}

.stat-pill.users i {
    background: #eef2f7;
    color: #617086;
}

.stat-pill.online {
    border-color: var(--line);
    background: rgba(255, 255, 255, .74);
    color: #475569;
}

.stat-pill.online i {
    background: #eef2f7;
    color: #617086;
    font-size: 10px;
}

.stat-pill.cards {
    border-color: var(--line);
    background: rgba(255, 255, 255, .74);
    color: #475569;
}

.stat-pill.cards i {
    background: #eef2f7;
    color: #617086;
}

.admin-menu {
    position: relative;
    padding-bottom: 10px;
    margin-bottom: -10px;
}

.admin-trigger {
    height: 38px;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    border: 1px solid #c7d7fe;
    border-radius: 999px;
    background: #eef4ff;
    color: #1d4ed8;
    padding: 0 5px 0 14px;
    box-shadow: none;
}

.admin-trigger:hover {
    border-color: #c7d7fe;
    background: #eef4ff;
    color: #1d4ed8;
}

.admin-avatar {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    object-fit: cover;
    display: block;
    background: transparent;
    border: 0;
    box-shadow: 0 8px 18px rgba(37, 99, 235, 0.2);
}

.admin-avatar.large {
    width: 42px;
    height: 42px;
    font-size: 17px;
}

.admin-dropdown {
    position: absolute;
    right: 0;
    top: calc(100% - 2px);
    z-index: 80;
    width: 320px;
    display: none;
    gap: 12px;
    padding: 14px;
    border: 1px solid #d7e2f4;
    border-radius: 14px;
    background:
        radial-gradient(circle at 8% 0%, rgba(37, 99, 235, 0.1), transparent 36%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(246, 250, 255, 0.95));
    box-shadow: 0 22px 42px rgba(22, 31, 55, 0.18), 0 2px 8px rgba(37, 99, 235, 0.12);
}

.admin-menu:hover .admin-dropdown,
.admin-menu:focus-within .admin-dropdown,
.admin-menu.open .admin-dropdown {
    display: grid;
}

.admin-card-head {
    display: flex;
    align-items: center;
    gap: 12px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--line);
}

.admin-card-head strong { display: block; }
.admin-card-head small { display: block; color: var(--muted); margin-top: 3px; }

.admin-dropdown form {
    display: grid;
    gap: 10px;
}

.admin-divider {
    height: 1px;
    margin: 2px 0;
    background: linear-gradient(90deg, transparent, #dbe4f4 12%, #dbe4f4 88%, transparent);
}

.admin-email-form {
    position: relative;
    margin-top: 2px;
    padding: 12px 12px 10px;
    border: 1px solid rgba(246, 178, 0, 0.24);
    border-radius: 12px;
    background:
        linear-gradient(180deg, rgba(255, 214, 102, 0.26), rgba(255, 226, 153, 0.16));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55);
    overflow: hidden;
}

.admin-email-form::after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 100%;
    background: linear-gradient(90deg, rgba(246, 178, 0, 0.18), rgba(246, 178, 0, 0));
    pointer-events: none;
}

.admin-dropdown button {
    width: 100%;
    height: 34px;
}
.main {
    flex: 1;
    min-width: 0;
    min-height: 0;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: 18px;
    padding: 0 24px 24px;
    align-items: start;
    overflow: hidden;
}

.workspace {
    min-width: 0;
    min-height: 0;
    max-height: calc(100vh - 102px);
    overflow: auto;
    padding-right: 2px;
}

.panel {
    background: rgba(255, 255, 255, .94);
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 18px;
    margin-bottom: 18px;
    box-shadow: var(--shadow-soft);
}

.panel h2 {
    margin: 0 0 16px;
    color: var(--text);
    font-size: 18px;
    font-weight: 800;
}

.hero-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; }
.form-grid { display: grid; grid-template-columns: repeat(4, minmax(150px, 1fr)); gap: 14px; align-items: end; }
.panel .form-grid:has(label:nth-child(3):last-child) { grid-template-columns: repeat(3, minmax(180px, 1fr)); }
.subadmin-field-account { grid-column: 1; }
.subadmin-field-password { grid-column: 2; }
.subadmin-field-notes { grid-column: 3; }
.subadmin-field-app-range { grid-column: 1 / 3; }
.subadmin-field-user-range { grid-column: 3 / 5; }
.subadmin-field-files { grid-column: 1 / -1; }
.check-grid { display: flex; flex-wrap: wrap; gap: 12px 18px; margin-top: 14px; }
.settings-key-grid { gap: 10px 16px; }
.subadmin-option-section { margin-top: 16px; }
.subadmin-option-head { display: grid; gap: 4px; margin-bottom: 10px; }
.subadmin-option-head strong { font-size: 14px; color: var(--text); }
.subadmin-option-head span { font-size: 12px; color: var(--muted); line-height: 1.5; }
.inline-options { display: flex; gap: 16px; align-items: center; flex-wrap: wrap; margin-bottom: 14px; }
.inline-options label, .check { display: inline-flex; gap: 8px; align-items: center; color: var(--text); }
.inline-options input[type="checkbox"],
.check input[type="checkbox"],
td input[type="checkbox"],
th input[type="checkbox"] {
    width: 16px;
    height: 16px;
    min-height: 16px;
    margin: 0;
    padding: 0;
    accent-color: var(--blue);
}

.login-config-options {
    flex-wrap: nowrap;
    align-items: center;
    gap: 14px;
    margin-bottom: 0;
}

.login-config-options .login-verify-type-field,
.login-config-options .login-unbind-deduct-field {
    display: grid;
    gap: 6px;
    color: var(--muted);
    font-size: 13px;
}

.login-config-options .login-verify-type-field {
    min-width: 160px;
}

.login-config-options .login-unbind-deduct-field {
    min-width: 140px;
}

.login-config-options .login-unbind-deduct-field input {
    margin-top: 6px;
}

/* 登录配置：勾选项补上与输入控件一致的顶部间距 */
.login-config-options .check {
    padding-top: 0;
    padding-bottom: 0;
    transform: translateY(16px);
}
.button-row { display: grid; grid-template-columns: repeat(4, minmax(120px, 1fr)); gap: 12px; margin-top: 16px; }
.button-row.single-action { grid-template-columns: minmax(140px, 180px); }
.search { display: grid; grid-template-columns: auto 1fr auto auto; gap: 10px; align-items: end; }

.form-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 16px;
}

.form-actions button {
    min-width: 150px;
}

.post-form-grid {
    display: grid;
    grid-template-columns: minmax(180px, 360px) minmax(240px, 1fr);
    gap: 14px;
    align-items: end;
}

.version-form-grid {
    display: grid;
    grid-template-columns: minmax(220px, 520px) max-content;
    gap: 18px;
    align-items: end;
}

.settings-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    align-items: end;
}

.settings-form-grid.compact {
    grid-template-columns: minmax(220px, 360px);
}

.settings-form-grid .wide {
    grid-column: 1 / -1;
}

.domain-settings-grid {
    align-items: start;
}

.domain-primary-row {
    display: grid;
    grid-template-columns: max-content minmax(0, 1fr);
    gap: 14px;
    align-items: end;
}

.domain-mode-field {
    display: grid;
    gap: 8px;
    min-width: 240px;
}

.domain-mode-field select {
    margin-top: 0;
}

.domain-host-field {
    display: grid;
    gap: 8px;
}

.domain-host-field input {
    margin-top: 0;
}

.domain-toggle-row {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px 18px;
    align-items: end;
}

.domain-toggle-row .setting-check {
    min-width: 0;
}

.domain-pem-field {
    display: grid;
    gap: 10px;
    align-content: start;
}

.domain-pem-field textarea {
    margin-top: 0;
}

.zpay-settings-grid > label {
    display: grid;
    align-content: end;
    gap: 6px;
}

.zpay-settings-grid > label input,
.zpay-settings-grid > label select,
.zpay-settings-grid > label .custom-select {
    margin-top: 0;
}

.setting-check {
    min-height: 38px;
    align-self: end;
}

.home-service-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.settings-save {
    margin-top: 16px;
    min-width: 160px;
}

.card-registration-panel {
    padding-bottom: 16px;
}

.login-config-panel {
    padding-bottom: 16px;
}

.card-registration-row {
    display: grid;
    grid-template-columns: max-content max-content minmax(240px, 1fr) max-content;
    gap: 14px;
    align-items: end;
}

.card-registration-row .check {
    min-height: 38px;
}

.card-network-input {
    display: grid;
    gap: 6px;
}

.duration-select,
.custom-select {
    position: relative;
    display: block;
    margin-top: 6px;
}

.duration-trigger,
.custom-select-trigger {
    position: relative;
    width: 100%;
    height: 38px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    border: 1px solid var(--line-strong);
    border-radius: 8px;
    background: white;
    color: var(--text);
    padding: 0 34px 0 10px;
    box-shadow: none;
    font-weight: 400;
}

.duration-trigger::after,
.custom-select-trigger::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 15px;
    width: 6px;
    height: 6px;
    border-right: 1.5px solid #475569;
    border-bottom: 1.5px solid #475569;
    transform: translateY(-65%) rotate(45deg);
}

.duration-trigger:hover,
.custom-select-trigger:hover {
    background: white;
    color: var(--text);
}

.duration-select.open .duration-trigger,
.custom-select.open .custom-select-trigger {
    border-color: var(--blue);
    box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.12);
}

.duration-menu,
.custom-select-menu {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% + 4px);
    z-index: 40;
    display: none;
    overflow: hidden;
    border: 1px solid var(--line-strong);
    border-radius: 8px;
    background: white;
    box-shadow: var(--shadow);
}

.duration-select.open .duration-menu,
.custom-select.open .custom-select-menu {
    display: grid;
}

.duration-menu button,
.custom-select-menu button {
    width: 100%;
    height: 34px;
    border-radius: 0;
    background: white;
    color: var(--text);
    box-shadow: none;
    text-align: left;
    justify-content: flex-start;
    padding: 0 12px;
    font-weight: 400;
}

.duration-menu button:hover,
.custom-select-menu button:hover {
    background: var(--blue);
    color: white;
}

.db-maintenance {
    display: grid;
    grid-template-columns: repeat(2, minmax(180px, 1fr));
    gap: 14px;
    margin-bottom: 12px;
}

.db-maintenance div {
    border: 1px solid var(--line);
    border-radius: 12px;
    background: #fbfcff;
    padding: 14px;
}

.db-maintenance span {
    display: block;
    color: var(--muted);
    font-size: 12px;
    margin-bottom: 6px;
}

.db-maintenance strong {
    display: block;
    font-size: 20px;
}

.muted-tip {
    color: var(--muted);
    line-height: 1.6;
}

.mono-input {
    font-family: Consolas, "SFMono-Regular", "Microsoft YaHei", monospace;
}

.security-note {
    margin-top: 16px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: rgba(248, 251, 255, .82);
    padding: 14px;
    color: #475569;
    line-height: 1.7;
}

.security-note h3 {
    margin: 0 0 6px;
    color: var(--text);
    font-size: 14px;
}

.security-note p {
    margin: 0 0 12px;
}

.security-note p:last-child {
    margin-bottom: 0;
}

.api-secret-field {
    display: grid;
    gap: 7px;
    color: var(--muted);
    font-size: 13px;
}

.api-secret-control {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto auto;
    gap: 8px;
    align-items: center;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(247,250,254,.88));
    padding: 8px;
}

.api-secret-control input {
    margin: 0;
    border-color: transparent;
    background: rgba(255,255,255,.72);
}

.api-secret-control button {
    height: 34px;
    padding: 0 12px;
    white-space: nowrap;
}

@media (max-width: 640px) {
    .api-secret-control {
        grid-template-columns: 1fr;
    }

    .api-secret-control button {
        width: 100%;
    }
}

.monitor-overview {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.monitor-overview div {
    border: 1px solid var(--line);
    border-radius: 14px;
    background: linear-gradient(180deg, #ffffff, #f8fbff);
    padding: 14px;
    box-shadow: 0 10px 28px rgba(22, 31, 55, 0.06);
}

.monitor-overview span {
    display: block;
    color: var(--muted);
    font-size: 12px;
    margin-bottom: 8px;
}

.monitor-overview strong {
    display: block;
    font-size: 18px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.resource-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.resource-card {
    display: flex;
    align-items: center;
    gap: 16px;
    border: 1px solid var(--line);
    border-radius: 16px;
    background:
        linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,251,255,.96));
    padding: 18px;
    box-shadow: 0 12px 30px rgba(22, 31, 55, 0.06);
}

.resource-card h3 {
    margin: 0 0 6px;
    font-size: 17px;
}

.resource-card p {
    margin: 0;
    color: var(--muted);
    line-height: 1.45;
}

.ring {
    --value: 0;
    --ring-color: var(--blue);
    width: 86px;
    height: 86px;
    flex: 0 0 auto;
    display: grid;
    place-items: center;
    border-radius: 50%;
    position: relative;
}

.ring svg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    transform: rotate(-90deg);
}

.ring circle {
    fill: none;
    stroke-width: 12;
}

.ring-track {
    stroke: #e8edf5;
}

.ring-value {
    stroke: var(--ring-color);
    stroke-linecap: round;
    stroke-dasharray: 301.59;
    stroke-dashoffset: calc(301.59 - (301.59 * var(--value) / 100));
    transition: stroke-dashoffset .35s ease;
}

.ring span {
    position: relative;
    z-index: 1;
    font-weight: 900;
    color: var(--text);
}

.resource-card[data-ring="memory"] .ring { --ring-color: #16a34a; }
.resource-card[data-ring="disk"] .ring { --ring-color: #f59e0b; }

.monitor-table-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.monitor-table-grid table {
    box-shadow: 0 10px 28px rgba(22, 31, 55, 0.05);
}

.metric-card-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
    margin-bottom: 14px;
}

.metric-card {
    border: 1px solid var(--line);
    border-radius: 16px;
    background: linear-gradient(180deg, #ffffff, #f8fbff);
    padding: 16px;
    box-shadow: 0 12px 30px rgba(22, 31, 55, 0.06);
}

.metric-card span,
.metric-card small {
    display: block;
    color: var(--muted);
}

.metric-card strong {
    display: block;
    margin: 8px 0 6px;
    font-size: 22px;
}

.network-up strong { color: #2563eb; }
.network-down strong { color: #16a34a; }
.process-memory strong { color: #7c3aed; }
.process-cpu strong { color: #f59e0b; }

.monitor-table-grid.enhanced {
    grid-template-columns: minmax(0, 1.45fr) minmax(320px, .75fr);
    align-items: stretch;
}

.chart-card,
.detail-list {
    border: 1px solid var(--line);
    border-radius: 16px;
    background: #ffffff;
    box-shadow: 0 12px 30px rgba(22, 31, 55, 0.06);
}

.chart-card {
    align-self: stretch;
    display: flex;
    flex-direction: column;
    padding: 16px 16px 14px;
    overflow: hidden;
    background:
        radial-gradient(circle at 12% 0%, rgba(37, 99, 235, .08), transparent 28%),
        linear-gradient(180deg, #ffffff, #f8fbff);
}

.chart-head {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: flex-start;
    margin-bottom: 16px;
}

.chart-head h3 {
    margin: 0 0 4px;
    font-size: 17px;
}

.chart-head p,
.chart-head span {
    margin: 0;
    color: var(--muted);
    font-size: 12px;
}

.bar-chart {
    position: relative;
    flex: 1 1 auto;
    min-height: 170px;
    height: auto;
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 1fr;
    align-items: stretch;
    gap: 8px;
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 0;
    background: linear-gradient(180deg, rgba(255,255,255,.82), rgba(241,245,249,.72));
    background-size: 100% 100%;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.9);
}

.bar-chart::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: linear-gradient(90deg, rgba(37, 99, 235, .08), transparent 42%, rgba(22, 163, 74, .07));
    pointer-events: none;
}

.bar-group {
    position: relative;
    height: 100%;
    display: flex;
    align-items: end;
    justify-content: center;
    gap: 4px;
    padding: 0 0 24px;
    z-index: 1;
}

.bar-time {
    position: absolute;
    left: 50%;
    bottom: 4px;
    transform: translateX(-50%);
    color: #64748b;
    font-size: 11px;
    line-height: 1;
    white-space: nowrap;
    pointer-events: none;
}

.bar {
    width: min(12px, 28%);
    min-height: 4px;
    border-radius: 999px 999px 4px 4px;
    transform-origin: bottom;
    cursor: crosshair;
    transition: height .26s ease, filter .22s ease, opacity .22s ease;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.42);
}

.request-chart .bar {
    max-height: calc(100% - 28px);
}

.bar.requests { background: linear-gradient(180deg, #60a5fa, #2563eb); }
.bar.api { background: linear-gradient(180deg, #5eead4, #16a34a); }
.bar.errors { background: linear-gradient(180deg, #fda4af, #dc2626); }

.bar:hover {
    filter: saturate(1.14) drop-shadow(0 8px 10px rgba(15, 23, 42, .12));
}

.chart-legend {
    display: flex;
    justify-content: center;
    gap: 18px;
    margin-top: 8px;
    color: var(--muted);
    line-height: 1.2;
}

.chart-legend span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.chart-legend i {
    width: 12px;
    height: 12px;
    display: inline-block;
    border-radius: 3px;
}

.chart-legend .requests { background: #2563eb; }
.chart-legend .api { background: #16a34a; }
.chart-legend .errors { background: #dc2626; }

.chart-tooltip {
    position: fixed;
    z-index: 1200;
    max-width: 260px;
    transform: translate(14px, -50%);
    opacity: 0;
    pointer-events: none;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 999px;
    background: rgba(15, 23, 42, .9);
    color: white;
    padding: 7px 12px;
    font-size: 12px;
    line-height: 1.2;
    white-space: nowrap;
    box-shadow: 0 12px 24px rgba(15, 23, 42, .16);
    transition: opacity .14s ease, transform .14s ease;
}

.chart-tooltip.visible {
    opacity: 1;
    transform: translate(14px, -50%);
}

.detail-list {
    overflow: hidden;
}

.detail-list > div {
    display: grid;
    gap: 6px;
    padding: 14px 16px;
    border-bottom: 1px solid var(--line);
}

.detail-list > div:last-child {
    border-bottom: 0;
}

.detail-list span {
    color: var(--muted);
    font-size: 12px;
}

.detail-list strong {
    font-size: 15px;
    line-height: 1.45;
}

.detail-list .api-request-summary {
    display: grid;
    gap: 8px;
}

.api-request-card {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
    padding: 8px 10px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: linear-gradient(180deg, #ffffff, #f8fbff);
}

.api-request-row {
    display: block;
    min-height: 0;
    padding: 6px 0;
}

.api-request-row + .api-request-row {
    border-top: 1px solid rgba(203, 214, 228, .5);
}

.api-pill {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    min-height: 30px;
    padding: 0 10px;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
    border: 1px solid transparent;
}

.api-pill small {
    font-size: 12px;
    font-weight: 700;
}

.api-pill-total {
    color: #1d4ed8;
    background: #eaf2ff;
    border-color: #c7dbff;
}

.api-pill-success {
    color: #15803d;
    background: #eaf8ef;
    border-color: #bfeac9;
}

.api-pill-error {
    color: #b91c1c;
    background: #fff1f1;
    border-color: #fecaca;
}

.api-pill strong {
    font-size: 18px;
    line-height: 1;
    letter-spacing: 0.2px;
}

.code-block {
    overflow: auto;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: #0f172a;
    color: #e2e8f0;
    padding: 16px;
    line-height: 1.6;
}

.doc-list {
    line-height: 1.8;
}

table {
    width: 100%;
    border-collapse: collapse;
    border-spacing: 0;
    background: white;
    font-size: 14px;
}

.table-scroll {
    min-height: 320px;
    max-height: clamp(320px, calc(100vh - 430px), 560px);
    overflow: auto;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: white;
}

.table-scroll + .form-grid,
.table-scroll + .form-actions,
.table-scroll + .form-grid + .button-row {
    flex: 0 0 auto;
}

.users-list-toolbar {
    margin: 0 0 5px;
}

.file-pathbar {
    display: flex;
    align-items: center;
    gap: 8px;
    min-height: 40px;
    margin: 0 0 12px;
    padding: 0 12px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: #fff;
    overflow-x: auto;
    white-space: nowrap;
}

.file-crumb {
    color: #334155;
    font-weight: 500;
    padding: 5px 9px;
    border-radius: 6px;
    transition: background-color .16s ease, color .16s ease;
}

.file-crumb.current {
    color: inherit;
    font-weight: inherit;
}

a.file-crumb:hover {
    background: rgba(100, 116, 139, 0.12);
    color: inherit;
}

.file-crumb-sep {
    width: 12px;
    height: 12px;
    display: inline-block;
    position: relative;
    flex: 0 0 auto;
}

.file-crumb-sep::before {
    content: "";
    position: absolute;
    left: 3px;
    top: 2px;
    width: 6px;
    height: 6px;
    border-top: 1.5px solid #475569;
    border-right: 1.5px solid #475569;
    transform: rotate(45deg);
}

.file-name-cell {
    display: flex;
    align-items: center;
    gap: 8px;
}

.file-icon {
    display: inline-block;
    width: 16px;
    height: 14px;
    position: relative;
    flex: 0 0 auto;
}

.file-icon.folder {
    background: #facc15;
    border: 1px solid #eab308;
    border-radius: 2px;
}

.file-icon.folder::before {
    content: "";
    position: absolute;
    top: -4px;
    left: 1px;
    width: 8px;
    height: 4px;
    background: #fde047;
    border: 1px solid #eab308;
    border-bottom: 0;
    border-radius: 2px 2px 0 0;
}

.file-icon.file {
    width: 14px;
    height: 16px;
    border: 1px solid #60a5fa;
    border-radius: 2px;
    background: linear-gradient(180deg, #eff6ff 0%, #dbeafe 100%);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65);
}

.file-icon.file::before {
    content: "";
    position: absolute;
    top: 1px;
    right: 1px;
    width: 6px;
    height: 6px;
    background: #93c5fd;
    clip-path: polygon(0 0, 100% 0, 100% 100%);
}

.file-icon.file::after {
    content: "";
    position: absolute;
    left: 2px;
    right: 2px;
    bottom: 3px;
    height: 1px;
    background: rgba(37, 99, 235, 0.35);
    box-shadow: 0 -3px 0 rgba(37, 99, 235, 0.28), 0 -6px 0 rgba(37, 99, 235, 0.22);
}

.file-browser-panel .table-scroll {
    margin-bottom: 12px;
}

.file-browser-panel th,
.file-browser-panel td {
    padding-top: 10px;
    padding-bottom: 10px;
}

.file-inline-input {
    width: 100%;
    height: 32px;
    min-height: 32px;
    padding: 5px 10px;
    line-height: inherit;
    font-size: 13px;
    border: 1px solid #d7e0eb;
    border-radius: 6px;
    background: #fff;
    color: #334155;
}

.file-link-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 32px;
    min-height: 32px;
    padding: 0 12px;
    line-height: inherit;
    font-size: 13px;
    border-radius: 6px;
    border: 0;
    background: #2563eb;
    color: #fff !important;
    font-weight: 600;
    text-decoration: none;
}

.file-link-btn:hover {
    background: #1d4ed8;
}

/* 文件管理表格：固定欄寬，縮小密碼欄。 */
#files-list-form table[data-table-kind="files"] {
    table-layout: auto;
}

#files-list-form table[data-table-kind="files"] th:nth-child(5),
#files-list-form table[data-table-kind="files"] td:nth-child(5) {
    width: 130px;
    max-width: 130px;
    text-align: left;
}

#files-list-form table[data-table-kind="files"] td:nth-child(5) .file-inline-input {
    max-width: 112px;
    margin-left: 0;
    margin-right: 0;
    text-align: left;
}

#files-list-form table[data-table-kind="files"] th:nth-child(2),
#files-list-form table[data-table-kind="files"] td:nth-child(2),
#files-list-form table[data-table-kind="files"] th:nth-child(3),
#files-list-form table[data-table-kind="files"] td:nth-child(3) {
    width: auto;
    max-width: none;
}

#files-list-form table[data-table-kind="files"] td:nth-child(4) {
    text-align: left;
}

#files-list-form table[data-table-kind="files"] th:nth-child(6),
#files-list-form table[data-table-kind="files"] td:nth-child(6) {
    text-align: left;
    width: 120px;
    max-width: 120px;
    overflow: visible;
    text-overflow: clip;
}

#files-list-form table[data-table-kind="files"] td:nth-child(6) .file-link-btn {
    display: inline-flex;
    margin-left: 0;
    margin-right: 0;
}

/* 文件管理：目录行/文件行统一高度，避免出现高低不一 */
#files-list-form table[data-table-kind="files"] tbody tr:not(.empty-row) {
    height: 54px;
}

#files-list-form table[data-table-kind="files"] tbody tr:not(.empty-row) td {
    height: 54px;
    vertical-align: middle;
}

/* 用户管理表格：用户名列最大宽度（仅作用于用户列表） */
#users-batch-form table[data-table-kind="users"] th:nth-child(3),
#users-batch-form table[data-table-kind="users"] td:nth-child(3) {
    max-width: 100px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

#users-batch-form table[data-table-kind="users"] th:nth-child(11),
#users-batch-form table[data-table-kind="users"] td:nth-child(11),
#users-batch-form table[data-table-kind="users"] th:nth-child(12),
#users-batch-form table[data-table-kind="users"] td:nth-child(12) {
    max-width: 150px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* 卡密管理表格：卡密列最大宽度（仅作用于卡密列表） */
#cards-batch-form table[data-table-kind="cards"] th:nth-child(3),
#cards-batch-form table[data-table-kind="cards"] td:nth-child(3) {
    max-width: 150px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

#files-list-form table[data-table-kind="files"] td:nth-child(4) .file-inline-input {
    text-align: left;
}

#files-list-form table[data-table-kind="files"] td:nth-child(5) .file-inline-input {
    text-align: left;
}

/* 文件管理页：顶部表单文本与控件居中 */
.file-browser-panel .file-config-grid > * {
    text-align: left;
}

.file-browser-panel .file-config-cookie-field span,
.file-browser-panel .file-sync-interval-field {
    text-align: left;
}

.file-browser-panel .file-config-cookie-field input,
.file-browser-panel .file-sync-interval-field .custom-select-trigger {
    text-align: left;
}

.table-scroll.doc-table {
    max-height: 420px;
}

.table-scroll table {
    min-width: 920px;
    border: 0;
    border-radius: 0;
}

th, td {
    border-bottom: 0;
    padding: 12px 14px;
    text-align: left;
    vertical-align: middle;
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
    max-width: 240px;
}

th {
    position: sticky;
    top: 0;
    z-index: 2;
    background: #f8fafc;
    color: #475569;
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    text-align: left;
}

/* 用整行画分割线，避免单元格断层 */
.table-scroll thead tr {
    box-shadow: inset 0 -1px 0 var(--line);
}

.table-scroll tbody tr {
    box-shadow: inset 0 -1px 0 var(--line);
}

.table-scroll tbody tr:last-child {
    box-shadow: none;
}

tr:last-child td { border-bottom: 0; }
tbody tr:hover { background: #f8fbff; }
td:first-child, th:first-child { width: 44px; text-align: center; }

.empty-row td {
    height: 220px;
    color: var(--muted);
    text-align: center;
    background: white;
}

.ok, td:has(.ok) { color: var(--green); }
.warn, td:has(.warn) { color: var(--amber); }

.ok, .warn, .danger-pill {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    border-radius: 999px;
    padding: 0 9px;
    font-weight: 700;
    font-size: 12px;
}
.ok { background: var(--green-soft); }
.warn { background: var(--amber-soft); }
.danger-pill { color: var(--red); background: var(--red-soft); }

.user-tag {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 26px;
    padding: 0 12px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
    border: 1px solid transparent;
}
.user-type-lv0 {
    color: #334155;
    background: #eef2f7;
    border-color: transparent;
}
.user-type-vip {
    color: #0369a1;
    background: #e0f2fe;
    border-color: transparent;
}
.user-type-svip {
    color: #6d28d9;
    background: #f3e8ff;
    border-color: transparent;
}
.user-status-normal {
    color: #15803d;
    background: #dcfce7;
    border-color: #bbf7d0;
}
.user-status-expired {
    color: #b45309;
    background: #fef3c7;
    border-color: #fde68a;
}
.user-status-banned {
    color: #b91c1c;
    background: #fee2e2;
    border-color: #fecaca;
}

.card-duration-tag {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 42px;
    min-height: 26px;
    padding: 0 11px;
    border-radius: 8px;
    color: var(--blue-dark);
    background: #eef6ff;
    border: 1px solid #d7e9ff;
    font-weight: 800;
    line-height: 1;
}

.card-duration-xs {
    color: #3b82f6;
    background: #f2f8ff;
    border-color: #dcecff;
}

.card-duration-sm {
    color: #2f7df2;
    background: #eaf4ff;
    border-color: #cfe5ff;
}

.card-duration-md {
    color: #1f6feb;
    background: #e2efff;
    border-color: #bddcff;
}

.card-duration-lg {
    color: #1b62d0;
    background: #d9eaff;
    border-color: #abcfff;
}

.card-duration-xl,
.card-duration-permanent {
    color: #1557c0;
    background: #d0e4ff;
    border-color: #9bc3ff;
}

.table-context-menu {
    position: fixed;
    z-index: 1400;
    min-width: 170px;
    display: none;
    padding: 6px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: rgba(255, 255, 255, .98);
    box-shadow: 0 14px 30px rgba(15, 23, 42, .14);
}

.table-context-menu.open {
    display: grid;
    gap: 4px;
}

.table-context-menu button {
    width: 100%;
    height: 32px;
    border: 0;
    border-radius: 7px;
    padding: 0 10px;
    text-align: left;
    justify-content: flex-start;
    background: transparent;
    color: var(--text);
    box-shadow: none;
    font-weight: 500;
}
.table-submenu-group {
    position: relative;
}
.table-submenu-group::after {
    content: "";
    position: absolute;
    right: -8px;
    top: 0;
    bottom: 0;
    width: 8px;
    background: transparent;
}
.table-submenu-group .submenu-trigger {
    display: flex;
    align-items: center;
    gap: 8px;
}
.table-submenu-group .submenu-chevron {
    margin-left: auto;
    width: 6px;
    height: 6px;
    border-right: 1.5px solid #475569;
    border-bottom: 1.5px solid #475569;
    transform: rotate(-45deg);
}
.table-submenu {
    position: absolute;
    left: 100%;
    top: -6px;
    min-width: 158px;
    display: none !important;
    padding: 6px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: rgba(255, 255, 255, .98);
    box-shadow: 0 14px 30px rgba(15, 23, 42, .14);
    z-index: 1500;
    transform: translateX(7px);
}
.table-submenu::before {
    content: "";
    position: absolute;
    left: -8px;
    top: 0;
    bottom: 0;
    width: 8px;
    background: transparent;
}
.table-submenu-group:hover .table-submenu {
    display: grid !important;
    gap: 4px;
}

.table-context-menu button:hover:not(:disabled) {
    background: var(--blue-soft);
    color: var(--blue);
}

.table-context-menu button:disabled {
    color: #94a3b8;
    cursor: not-allowed;
}
.app-dialog-mask {
    position: fixed !important;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: 9999;
    display: none;
    align-items: center;
    justify-content: center;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .28), rgba(236, 241, 248, .38)),
        radial-gradient(circle at 18% 14%, rgba(255, 255, 255, .24), transparent 38%),
        radial-gradient(circle at 78% 82%, rgba(255, 255, 255, .16), transparent 42%),
        rgba(190, 202, 214, .34);
    backdrop-filter: saturate(130%);
}
.app-dialog-mask.open { display: flex !important; }
.app-dialog {
    width: min(420px, calc(100vw - 30px));
    max-height: calc(100vh - 40px);
    overflow: auto;
    border: 1px solid rgba(255, 255, 255, .58);
    border-radius: 14px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .88), rgba(245, 248, 252, .86));
    padding: 16px;
    box-shadow: 0 18px 42px rgba(22, 31, 55, 0.20), inset 0 1px 0 rgba(255, 255, 255, .68);
}

.app-dialog.app-dialog-wide {
    width: min(760px, calc(100vw - 30px));
}
.app-dialog h3 { margin: 0 0 8px; font-size: 18px; }
.app-dialog p { margin: 0 0 12px; color: var(--muted); line-height: 1.5; max-height: 180px; overflow: auto; }
.app-dialog input { margin-bottom: 12px; }
.app-dialog-actions { display: flex; justify-content: flex-end; gap: 8px; }
.app-dialog-viewer {
    margin-bottom: 12px;
}
.app-dialog-viewer[hidden] {
    display: none !important;
}
.app-dialog-viewer-content {
    max-height: 280px;
    overflow: auto;
    border: 1px solid #c5d0df;
    border-radius: 10px;
    background: rgba(255, 255, 255, .72);
    padding: 10px 12px;
    font-family: "Microsoft YaHei", "Segoe UI", Arial, sans-serif;
    font-size: 15px;
    line-height: 1.55;
    white-space: pre-wrap;
    word-break: break-all;
}

.app-dialog-viewer-content .viewer-pair {
    display: grid;
    grid-template-columns: minmax(100px, .8fr) minmax(150px, 1.2fr);
    gap: 18px;
    align-items: center;
    white-space: normal;
    word-break: normal;
}

.app-dialog-viewer-content .viewer-pair span {
    overflow: hidden;
    color: #334155;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.app-dialog-viewer-content .viewer-pair strong {
    color: #334155;
    font-family: inherit;
    font-size: inherit;
    font-weight: 400;
    overflow-wrap: anywhere;
}

.app-dialog-viewer-content .viewer-head {
    position: sticky;
    top: -10px;
    z-index: 1;
    margin: -10px -12px 6px;
    padding: 10px 12px 8px;
    border-bottom: 1px solid var(--line);
    background: rgba(248, 251, 255, .96);
}

.app-dialog-viewer-content .viewer-head span,
.app-dialog-viewer-content .viewer-head strong {
    color: #334155;
    font-size: 13px;
    font-weight: 800;
}

.app-dialog-viewer-content div + div {
    margin-top: 6px;
    padding-top: 6px;
    border-top: 1px dashed #d3dcea;
}
.app-dialog-expiry-editor {
    display: grid;
    gap: 10px;
    margin-bottom: 12px;
}
.app-dialog-expiry-editor[hidden] {
    display: none !important;
}
.app-dialog-users-wrap {
    display: grid;
    gap: 6px;
}
.app-dialog-users-wrap label {
    color: var(--muted);
    font-size: 13px;
}
.app-dialog-users-list {
    max-height: 120px;
    overflow: auto;
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 8px 10px;
    background: rgba(255, 255, 255, .75);
}
.app-dialog-users-list div {
    position: relative;
    padding-left: 12px;
    line-height: 1.5;
}
.app-dialog-users-list div::before {
    content: "•";
    position: absolute;
    left: 0;
    color: var(--blue);
}
.app-dialog-permanent {
    margin: 0;
}
.app-dialog-datetime-wrap {
    display: grid;
    gap: 6px;
    color: var(--muted);
    font-size: 13px;
}
.app-dialog-datetime-wrap input {
    margin-bottom: 0;
}
body.dialog-open { overflow: hidden; }

.table-context-divider {
    height: 1px;
    margin: 4px 2px;
    background: var(--line);
}

.log-panel {
    position: sticky;
    top: 78px;
    height: calc(100vh - 102px);
    min-width: 0;
    background: rgba(255, 255, 255, .92);
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 14px;
    box-shadow: var(--shadow);
}

.panel-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 12px;
}

.panel-head h3 { margin: 0; font-size: 17px; }
.icon-button { height: 32px; padding: 0 12px; }
.panel-head form { margin: 0; }
.log-clear-button {
    height: 32px;
    padding: 0 14px;
    background: var(--blue);
    color: white;
}

.logs {
    height: calc(100% - 50px);
    overflow: auto;
    display: grid;
    align-content: start;
    gap: 10px;
    padding-right: 4px;
}

.log-item {
    border: 1px solid var(--line);
    border-radius: 10px;
    background: #fbfcff;
    padding: 10px;
}

.log-item span {
    color: var(--blue);
    font-weight: 800;
    font-size: 12px;
}

.log-item p {
    margin: 5px 0 0;
    color: #334155;
    line-height: 1.5;
}

.log-item em {
    display: block;
    margin-top: 4px;
    color: var(--muted);
    font-style: normal;
    font-size: 12px;
}

/* API 日志分级：成功绿 / 失败与错误红 / 常规蓝 */
.log-item.log-level-success {
    border-left: 3px solid #22c55e;
    background: linear-gradient(180deg, #f0fdf4, #ecfdf5);
}
.log-item.log-level-success span,
.log-item.log-level-success p {
    color: #15803d;
}
.log-item.log-level-success em {
    color: #166534;
    opacity: 0.9;
}

.log-item.log-level-error {
    border-left: 3px solid #ef4444;
    background: linear-gradient(180deg, #fef2f2, #fff1f2);
}
.log-item.log-level-error span,
.log-item.log-level-error p {
    color: #b91c1c;
}
.log-item.log-level-error em {
    color: #991b1b;
    opacity: 0.9;
}

.log-item.log-level-info span,
.log-item.log-level-info p {
    color: #1d4ed8;
}
.log-item.log-level-info em {
    color: #1e40af;
    opacity: 0.85;
}
.log-item.log-level-info {
    border-left: 3px solid #3b82f6;
}

.empty {
    border: 1px dashed var(--line-strong);
    border-radius: 10px;
    padding: 20px;
    color: var(--muted);
    text-align: center;
}

.app-toast-stack {
    position: fixed;
    top: 22px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 20050;
    display: flex;
    flex-direction: column;
    gap: 0;
    width: min(360px, calc(100vw - 32px));
    pointer-events: none;
}

.app-toast {
    --toast-duration: 4200ms;
    margin-bottom: 10px;
    position: relative;
    overflow: hidden;
    display: grid;
    gap: 4px;
    min-height: 64px;
    max-height: 120px;
    border: 1px solid rgba(148, 163, 184, .24);
    border-left-width: 1px;
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(255, 255, 255, .97), rgba(248, 250, 252, .95));
    padding: 9px 40px 9px 14px;
    box-shadow: 0 10px 26px rgba(15, 23, 42, .12);
    cursor: pointer;
    opacity: 1;
    transform: translateY(0);
    transition: max-height .22s ease, padding .22s ease, opacity .2s ease, transform .2s ease, margin .22s ease, border-width .22s ease;
    animation: toast-drop-in .28s cubic-bezier(.16, 1, .3, 1);
    pointer-events: auto;
}

.app-toast::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 3px;
    transform-origin: left;
    transform: scaleX(0);
    background: linear-gradient(90deg, rgba(59, 130, 246, .86), rgba(14, 165, 233, .96));
    animation: toast-countdown var(--toast-duration) linear forwards;
}

.app-toast.closing {
    opacity: 0;
    transform: translateY(-10px);
    max-height: 0;
    padding-top: 0;
    padding-bottom: 0;
    margin-bottom: 0;
    border-top-width: 0;
    border-bottom-width: 0;
}

.app-toast.closing::after {
    opacity: 0;
    transition: opacity .16s ease;
}

.app-toast-stack .app-toast:last-child {
    margin-bottom: 0;
}

.app-toast-close {
    position: absolute;
    top: 50%;
    right: 8px;
    transform: translateY(-50%);
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 0;
    border-radius: 50%;
    padding: 0;
    background: transparent;
    color: #94a3b8;
    box-shadow: none;
    font-size: 0;
    line-height: 0;
}

.app-toast-close::before,
.app-toast-close::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    width: 13px;
    height: 2px;
    border-radius: 999px;
    background: currentColor;
    transform-origin: center;
}

.app-toast-close::before {
    transform: translate(-50%, -50%) rotate(45deg);
}

.app-toast-close::after {
    transform: translate(-50%, -50%) rotate(-45deg);
}

.app-toast-close:hover {
    transform: translateY(-50%);
    background: #eef2f7;
    color: var(--text);
}

.app-toast-close:active,
.app-toast-close:focus-visible {
    transform: translateY(-50%);
}

.app-toast strong {
    font-size: 13px;
    color: var(--text);
}

.app-toast span {
    color: #475569;
    line-height: 1.35;
}

.app-toast.success::after { background: linear-gradient(90deg, rgba(34, 197, 94, .9), rgba(16, 185, 129, .95)); }
.app-toast.error::after { background: linear-gradient(90deg, rgba(248, 113, 113, .92), rgba(239, 68, 68, .95)); }
.app-toast.info::after { background: linear-gradient(90deg, rgba(59, 130, 246, .9), rgba(14, 165, 233, .95)); }

.app-toast.success strong { color: var(--green); }
.app-toast.error strong { color: var(--red); }
.app-toast.info strong { color: var(--blue); }

@keyframes toast-drop-in {
    from { opacity: 0; transform: translateY(-22px) scale(.98); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes toast-countdown {
    from { transform: scaleX(0); }
    to { transform: scaleX(1); }
}

.login-page {
    min-height: 100vh;
    display: grid;
    place-items: center;
    padding: 28px;
    background:
        linear-gradient(135deg, rgba(255,255,255,.92), rgba(239,246,255,.78) 48%, rgba(236,253,245,.58)),
        #f4f7fb;
}

.login-shell {
    width: min(940px, 100%);
    min-height: 520px;
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(340px, .85fr);
    overflow: hidden;
    border: 1px solid rgba(218, 226, 239, .9);
    border-radius: 22px;
    background: rgba(255, 255, 255, .74);
    box-shadow: var(--shadow-strong);
}

.login-intro,
.login-box {
    position: relative;
    padding: 34px;
}

.login-intro {
    display: grid;
    align-content: space-between;
    gap: 28px;
    color: #0f172a;
    background:
        linear-gradient(135deg, rgba(37, 99, 235, .1), rgba(22, 163, 74, .1)),
        linear-gradient(180deg, rgba(255,255,255,.64), rgba(248,250,252,.82));
}

.login-intro::after {
    content: "";
    position: absolute;
    right: 34px;
    top: 34px;
    width: 108px;
    height: 108px;
    border-radius: 30px;
    background: linear-gradient(135deg, rgba(37,99,235,.11), rgba(22,163,74,.1));
    transform: rotate(9deg);
    pointer-events: none;
}

.login-brand {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    gap: 13px;
}

.login-brand strong { display: block; font-size: 22px; line-height: 1; }
.login-brand small { display: block; margin-top: 6px; color: var(--muted); }

.login-intro h1 {
    position: relative;
    z-index: 1;
    max-width: 520px;
    margin: 0;
    font-size: clamp(30px, 4vw, 44px);
    line-height: 1.12;
    letter-spacing: 0;
}

.login-feature-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.login-feature-grid div {
    min-height: 82px;
    display: grid;
    align-content: center;
    gap: 6px;
    border: 1px solid rgba(226, 232, 240, .86);
    border-radius: 14px;
    background: rgba(255,255,255,.68);
    padding: 14px;
}

.login-feature-grid span {
    color: var(--muted);
    font-size: 12px;
}

.login-feature-grid strong {
    font-size: 16px;
}

.login-box {
    display: grid;
    align-content: center;
    gap: 16px;
    background: rgba(255,255,255,.92);
    border-left: 1px solid rgba(218, 226, 239, .9);
}

.login-box h2 {
    margin: 0;
    color: var(--text);
    font-size: 26px;
}

.login-kicker {
    display: block;
    margin-bottom: 6px;
    color: var(--blue);
    font-size: 12px;
    font-weight: 800;
}

.login-title {
    display: grid;
    gap: 4px;
}

.login-title .brand-mark {
    width: 40px;
    height: 40px;
    border-radius: 0;
    flex: 0 0 auto;
}
.login-box p { margin: 0 0 6px; color: var(--muted); }
.login-box label { display: grid; gap: 7px; color: #475569; font-weight: 600; }
.login-box label input { margin-top: 0; }
.login-box button { width: 100%; height: 42px; margin-top: 2px; }
.error { color: var(--red); background: var(--red-soft); border-radius: 8px; padding: 8px 10px; }

.about-page {
    display: grid;
    gap: 18px;
}

.about-page .panel {
    border-radius: 18px;
    border-color: rgba(218, 226, 239, .9);
    background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,251,255,.94));
    box-shadow: var(--shadow-soft);
}

.about-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(240px, 320px);
    gap: 18px;
    align-items: stretch;
}

.about-hero h2 {
    font-size: 24px;
    margin-bottom: 10px;
}

.about-hero p {
    max-width: 760px;
    margin: 0;
    color: #475569;
    line-height: 1.75;
}

.about-version-card {
    display: grid;
    align-content: center;
    gap: 7px;
    border: 1px solid rgba(199, 215, 254, .82);
    border-radius: 16px;
    background: linear-gradient(135deg, rgba(255,255,255,.88), rgba(238,244,255,.82));
    padding: 18px;
}

.about-version-card span,
.about-version-card small {
    color: var(--muted);
}

.about-version-card strong {
    font-size: 22px;
}

.about-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.about-card h2 {
    margin-bottom: 12px;
}

.about-feature-list {
    display: grid;
    gap: 12px;
}

.about-feature-list div {
    border: 1px solid rgba(226, 232, 240, .9);
    border-radius: 14px;
    background: rgba(255,255,255,.72);
    padding: 14px;
}

.about-feature-list span {
    display: block;
    margin-bottom: 6px;
    color: #0f3ea8;
    font-weight: 800;
}

.about-feature-list p {
    margin: 0;
    color: #475569;
    line-height: 1.65;
}

/* About page: clearer per-line layout + nicer rhythm */
.about-lines {
    margin-top: 10px;
    border: 1px solid rgba(226, 232, 240, .9);
    border-radius: 14px;
    overflow: hidden;
    background: rgba(255, 255, 255, .72);
}

.about-line {
    display: grid;
    grid-template-columns: 150px 1fr;
    gap: 16px;
    align-items: center;
    padding: 12px 14px;
    border-bottom: 1px solid rgba(226, 232, 240, .86);
    background: linear-gradient(90deg, rgba(248, 250, 252, .72), rgba(255, 255, 255, .92));
}

.about-line:last-child {
    border-bottom: 0;
}

.about-line b {
    color: #0f3ea8;
    font-weight: 900;
    letter-spacing: .2px;
}

.about-line span {
    color: #334155;
    line-height: 1.65;
}

.about-note {
    margin-top: 14px;
}

/* Make About tables easier to scan */
.about-page .doc-table tbody tr:nth-child(odd) td {
    background: rgba(248, 251, 255, .9);
}

.about-page .doc-table tbody tr:hover td {
    background: rgba(234, 242, 255, .95);
}

@media (max-width: 820px) {
    .about-line {
        grid-template-columns: 1fr;
        gap: 8px;
    }
}

.home-page {
    display: grid;
    gap: 20px;
    padding-bottom: 6px;
}

.home-page .hero-grid {
    align-items: stretch;
}

.home-page .panel {
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(218, 226, 239, .9);
    border-radius: 18px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 251, 255, 0.94));
    box-shadow: var(--shadow-soft);
}

.home-page .panel h2 {
    margin: 0;
    font-size: 19px;
    letter-spacing: 0;
}

.home-panel-head {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 16px;
}

.home-kicker {
    display: block;
    margin-bottom: 5px;
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0;
}

.home-service-panel::before,
.home-overview-panel::before,
.home-resource-panel::before,
.home-network-panel::before,
.home-db-panel::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 4px;
    background: linear-gradient(90deg, var(--blue), var(--green), var(--amber));
}

.home-service-panel::after,
.home-resource-panel::after,
.home-db-panel::after {
    content: "";
    position: absolute;
    right: 18px;
    top: 18px;
    width: 84px;
    height: 84px;
    border-radius: 28px;
    background: linear-gradient(135deg, rgba(37, 99, 235, .08), rgba(22, 163, 74, .08));
    transform: rotate(10deg);
    pointer-events: none;
}

.home-service-panel {
    display: flex;
    flex-direction: column;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(239, 246, 255, 0.94) 62%, rgba(236, 253, 245, 0.88)) !important;
}

.service-layout {
    position: relative;
    z-index: 1;
    flex: 1;
    display: grid;
    grid-template-columns: minmax(0, .82fr) minmax(0, 1fr);
    grid-template-rows: 1fr auto;
    gap: 12px;
    align-items: stretch;
    min-height: 0;
    min-width: 0;
}

.service-status-card {
    position: relative;
    grid-row: 1 / 3;
    min-width: 0;
    display: grid;
    align-content: center;
    gap: 8px;
    min-height: 0;
    padding: 18px;
    border: 1px solid rgba(199, 215, 254, .82);
    border-radius: 16px;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, .88), rgba(238, 244, 255, .82));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .9);
}

.service-status-card span,
.home-stat-strip span,
.home-stat-strip small {
    color: var(--muted);
    font-size: 12px;
}

.service-status-card strong {
    font-size: clamp(26px, 2.35vw, 34px);
    line-height: 1.1;
    white-space: normal;
    overflow-wrap: anywhere;
}

.home-stat-strip {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    min-width: 0;
}

.home-stat-strip div,
.home-service-panel form {
    display: grid;
    align-content: center;
    min-width: 0;
    min-height: 108px;
    border: 1px solid rgba(226, 232, 240, .9);
    border-radius: 16px;
    background: rgba(255, 255, 255, .72);
    padding: 14px 16px;
}

.home-stat-strip div {
    gap: 4px;
}

.home-stat-strip strong {
    color: #0f172a;
    font-size: 26px;
    line-height: 1;
}

.home-service-panel form {
    grid-column: 2;
    justify-items: start;
    gap: 10px;
    min-height: 76px;
    overflow: hidden;
}

.home-service-panel form button {
    width: auto;
    min-width: 112px;
    height: 36px;
    min-height: 36px;
    border-radius: 8px;
    padding: 0 16px;
}

.home-service-panel form span {
    color: var(--muted);
    font-size: 12px;
}

.home-overview-panel {
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(246, 250, 255, 0.94)) !important;
}

.home-overview-panel .monitor-overview {
    position: relative;
    z-index: 1;
}

.home-overview-panel .monitor-overview div {
    border-color: rgba(218, 226, 239, .92);
    border-radius: 15px;
    background: linear-gradient(180deg, #ffffff, #f7faff);
    box-shadow: 0 8px 22px rgba(37, 99, 235, 0.05);
}

.home-overview-panel .monitor-overview strong {
    font-size: 17px;
}

.home-resource-panel .resource-grid,
.home-network-panel .metric-card-grid,
.home-network-panel .monitor-table-grid,
.home-db-panel .db-maintenance,
.home-db-panel .muted-tip,
.home-db-panel button,
.home-db-panel .db-maintenance-buttons {
    position: relative;
    z-index: 1;
}

.home-resource-panel .resource-card {
    min-height: 144px;
    border-color: rgba(218, 226, 239, .92);
    border-radius: 16px;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, .98), rgba(248, 251, 255, .94));
    box-shadow: 0 12px 28px rgba(22, 31, 55, 0.06);
}

.home-resource-panel .resource-card[data-ring="cpu"] {
    background: linear-gradient(135deg, #ffffff, #eef4ff);
}

.home-resource-panel .resource-card[data-ring="memory"] {
    background: linear-gradient(135deg, #ffffff, #ecfdf5);
}

.home-resource-panel .resource-card[data-ring="disk"] {
    background: linear-gradient(135deg, #ffffff, #fff7ed);
}

.home-resource-panel .ring {
    width: 92px;
    height: 92px;
    background: rgba(255, 255, 255, .72);
    box-shadow: inset 0 0 0 8px rgba(255, 255, 255, .72), 0 10px 22px rgba(15, 23, 42, .06);
}

.home-network-panel .metric-card {
    position: relative;
    overflow: hidden;
    min-height: 118px;
    border-color: rgba(218, 226, 239, .92);
    border-radius: 16px;
    background: linear-gradient(180deg, #ffffff, #f8fbff);
    box-shadow: 0 12px 28px rgba(22, 31, 55, 0.06);
}

.home-network-panel .metric-card::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 4px;
    background: var(--blue);
}

.home-network-panel .network-down::after { background: var(--green); }
.home-network-panel .process-memory::after { background: var(--violet); }
.home-network-panel .process-cpu::after { background: var(--amber); }

.home-network-panel .metric-card strong {
    font-size: 24px;
    line-height: 1.1;
}

.home-network-panel .detail-list {
    border-color: rgba(218, 226, 239, .92);
    border-radius: 16px;
}

.home-network-panel .detail-list > div {
    background: linear-gradient(90deg, rgba(248, 250, 252, .78), rgba(255, 255, 255, .96));
}

.home-network-panel .api-request-card {
    border-color: rgba(218, 226, 239, .9);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .85);
}

.home-db-panel {
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(247, 250, 252, 0.95) 60%, rgba(255, 247, 230, 0.74)) !important;
}

.home-db-panel .db-maintenance div {
    min-height: 92px;
    border-color: rgba(218, 226, 239, .92);
    border-radius: 15px;
    background: rgba(255, 255, 255, .76);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .86);
}

.home-db-panel button {
    min-width: 150px;
}

.home-db-panel .db-maintenance-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}

.home-db-panel a.backup-database-btn {
    min-width: 150px;
    height: 36px;
    border-radius: 8px;
    padding: 0 16px;
    font: inherit;
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--green);
    color: #fff !important;
    border: 0;
    box-shadow: 0 8px 18px rgba(22, 163, 74, 0.22);
    transition: transform 0.16s ease, background 0.16s ease, box-shadow 0.16s ease;
}

.home-db-panel a.backup-database-btn:hover {
    background: #15803d;
    transform: translateY(-1px);
}

.home-db-panel a.backup-database-btn:active {
    transform: translateY(0);
}

.home-service-panel p {
    margin: 0 0 10px;
    color: #334155;
}

.home-resource-panel .resource-card,
.home-network-panel .metric-card {
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.home-resource-panel .resource-card:hover,
.home-network-panel .metric-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 16px 26px rgba(15, 23, 42, 0.1);
}

.home-network-panel .detail-list {
    border-color: #e1e8f3;
}

@media (max-width: 1180px) {
    .main { grid-template-columns: 1fr; overflow: visible; }
    .workspace { max-height: none; overflow: visible; }
    .log-panel { position: static; height: 360px; }
    .table-scroll { max-height: 420px; }
    .service-layout { grid-template-columns: minmax(0, .82fr) minmax(0, 1fr); }
    .login-shell { grid-template-columns: 1fr; }
    .login-box { border-left: 0; border-top: 1px solid rgba(218, 226, 239, .9); }
}

@media (max-width: 980px) {
    .service-layout { grid-template-columns: minmax(0, 1fr); grid-template-rows: auto; }
    .service-status-card,
    .home-stat-strip,
    .home-service-panel form { grid-column: auto; grid-row: auto; }
    .home-stat-strip div,
    .home-service-panel form { min-height: 76px; }
    .login-config-options { flex-wrap: wrap; }
}

@media (max-width: 820px) {
    .app-shell { display: block; }
    .sidebar { position: static; width: auto; height: auto; }
    .sidebar nav { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .topbar { height: auto; align-items: flex-start; gap: 12px; flex-direction: column; }
    .topbar-stats {
        position: static;
        justify-content: flex-start;
        pointer-events: auto;
    }
    .main { padding: 0 14px 14px; }
    .form-grid, .hero-grid, .button-row, .search, .post-form-grid, .version-form-grid, .settings-form-grid, .settings-form-grid.compact, .resource-grid, .monitor-table-grid, .monitor-table-grid.enhanced, .monitor-overview, .metric-card-grid, .card-registration-row { grid-template-columns: 1fr; }
    .subadmin-field-account,
    .subadmin-field-password,
    .subadmin-field-notes,
    .subadmin-field-app-range,
    .subadmin-field-user-range,
    .subadmin-field-files { grid-column: auto; }
    .about-hero, .about-grid { grid-template-columns: 1fr; }
    .login-page { padding: 14px; align-items: start; }
    .login-shell { min-height: 0; }
    .login-intro, .login-box { padding: 24px; }
    .login-feature-grid { grid-template-columns: 1fr; }
    .service-layout { grid-template-columns: minmax(0, 1fr); grid-template-rows: auto; }
    .service-status-card,
    .home-stat-strip,
    .home-service-panel form { grid-column: auto; grid-row: auto; }
    .home-stat-strip { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .home-stat-strip div,
    .home-service-panel form { min-height: 76px; }
    .home-service-panel form button { width: 100%; min-height: 40px; }
    .form-actions button { width: 100%; }
}

/* Global visual polish: presentation-only overrides. */
:root {
    --bg: #eef3f8;
    --panel: #ffffff;
    --panel-soft: #f7f9fc;
    --line: #dde5ee;
    --line-strong: #cbd6e4;
    --text: #111827;
    --muted: #64748b;
    --blue: #1f6feb;
    --blue-dark: #1557c0;
    --blue-soft: #eaf2ff;
    --green: #0f9f6e;
    --green-soft: #e8f8f1;
    --amber: #c77700;
    --amber-soft: #fff5df;
    --red: #d92d20;
    --red-soft: #fff0ee;
    --cyan: #0584a3;
    --cyan-soft: #e7f8fb;
    --violet: #7454d6;
    --violet-soft: #f1edff;
    --shadow: 0 22px 60px rgba(23, 37, 58, 0.11);
    --shadow-soft: 0 14px 36px rgba(23, 37, 58, 0.075);
    --shadow-strong: 0 30px 78px rgba(23, 37, 58, 0.18);
}

body {
    background:
        radial-gradient(circle at 13% 10%, rgba(31, 111, 235, .14), transparent 32%),
        radial-gradient(circle at 88% 18%, rgba(15, 159, 110, .12), transparent 30%),
        linear-gradient(135deg, #f8fbff 0%, #eef3f8 46%, #f6faf8 100%);
    -webkit-font-smoothing: antialiased;
    text-rendering: geometricPrecision;
}

body::selection {
    background: rgba(31, 111, 235, .18);
}

button {
    border-radius: 7px;
    background: linear-gradient(180deg, #2f7df2, #1f6feb);
    box-shadow: 0 10px 20px rgba(31, 111, 235, 0.18);
}

button:hover {
    background: linear-gradient(180deg, #246de0, #1557c0);
    box-shadow: 0 14px 24px rgba(31, 111, 235, 0.22);
}

button.ghost,
.icon-button {
    background: linear-gradient(180deg, #ffffff, #f3f6fb);
    color: #263449;
}

button.danger {
    background: linear-gradient(180deg, #ef4d43, #d92d20);
    box-shadow: 0 10px 20px rgba(217, 45, 32, 0.16);
}

input,
select,
textarea,
.duration-trigger,
.custom-select-trigger {
    border-radius: 7px;
    background: linear-gradient(180deg, #ffffff, #fbfcff);
}

input:hover,
select:hover,
textarea:hover {
    border-color: #b8c5d6;
}

.app-shell {
    background:
        linear-gradient(90deg, rgba(255, 255, 255, .36), transparent 28%),
        transparent;
}

.sidebar {
    width: 248px;
    padding: 18px 16px;
    background: transparent;
    border-right: 1px solid rgba(198, 211, 226, .62);
    box-shadow: none;
    backdrop-filter: none;
}

.brand {
    height: 58px;
    padding: 0 8px 17px;
    border-bottom-color: rgba(211, 221, 233, .9);
}

.brand strong {
    color: #111827;
    letter-spacing: .2px;
}

.brand small {
    color: var(--muted);
}

.brand-mark {
    width: 46px;
    height: 46px;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.sidebar nav {
    gap: 7px;
    padding: 20px 0;
}

.sidebar a {
    min-height: 43px;
    border-radius: 8px;
    color: #394255;
    border: 0;
}

.sidebar nav a span {
    background: rgba(255, 255, 255, .52);
    color: #617086;
    border: 0;
}

.sidebar a:hover {
    background: rgba(255, 255, 255, .56);
    color: #1f3b63;
}

.sidebar a.active,
.sidebar a.active:hover {
    color: #0f4fbb;
    background: rgba(219, 234, 254, .82);
    box-shadow: none;
}

.sidebar a.active::before {
    content: "";
    position: absolute;
    left: 0;
    top: 9px;
    bottom: 9px;
    width: 4px;
    border-radius: 999px;
    background: var(--blue);
}

.sidebar a.active span {
    background: rgba(255, 255, 255, .62);
    color: #0f4fbb;
    box-shadow: none;
}

.logout {
    border-color: rgba(198, 211, 226, .74);
    background: rgba(255, 255, 255, .48);
    color: #475569;
}

.topbar {
    height: 86px;
    padding: 20px 28px 12px;
}

.topbar p,
.panel-head p,
.home-kicker,
.login-kicker {
    text-transform: uppercase;
}

.topbar h1 {
    font-size: 25px;
}

.topbar-stats {
    top: 24px;
    right: 28px;
    gap: 10px;
}

.topbar-stats > span,
.admin-trigger {
    min-height: 36px;
    border-color: rgba(203, 214, 228, .86);
    background: rgba(255, 255, 255, .82);
    backdrop-filter: blur(14px);
}

.stat-pill.users i { background: #edf4ff; color: var(--blue); }
.stat-pill.online i { background: #e8f8f1; color: var(--green); }
.stat-pill.cards i { background: #fff5df; color: var(--amber); }

.admin-trigger {
    color: #1f3b63;
    box-shadow: 0 12px 26px rgba(23, 37, 58, .08);
}

.admin-trigger:hover {
    background: #ffffff;
    color: var(--blue-dark);
}

.main {
    grid-template-columns: minmax(0, 1fr) 370px;
    gap: 20px;
    padding: 0 28px 28px;
}

.workspace {
    max-height: calc(100vh - 114px);
}

.panel,
.log-panel,
.chart-card,
.detail-list,
.metric-card,
.resource-card,
.monitor-overview div,
.db-maintenance div {
    border-color: rgba(211, 221, 233, .92);
    box-shadow: var(--shadow-soft);
}

.panel {
    border-radius: 12px;
    background:
        linear-gradient(180deg, rgba(255,255,255,.97), rgba(249,251,254,.94));
}

.panel h2 {
    color: #152036;
}

.panel h2::after,
.home-panel-head h2::after,
.about-card h2::after {
    content: "";
    display: block;
    width: 34px;
    height: 3px;
    margin-top: 8px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--blue), var(--green));
}

.home-panel-head h2::after {
    margin-top: 7px;
}

.search {
    grid-template-columns: auto minmax(180px, 1fr) auto auto;
}

.search a {
    min-height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--line);
    border-radius: 7px;
    padding: 0 14px;
    background: #ffffff;
    color: #475569;
    font-weight: 700;
}

.search a:hover {
    border-color: #b8c5d6;
    color: var(--blue);
}

.table-scroll {
    border-radius: 10px;
    background: #ffffff;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.9);
}

th {
    background: linear-gradient(180deg, #f7f9fd, #eef3f8);
    color: #526176;
    letter-spacing: .02em;
}

td {
    color: #263449;
}

tbody tr {
    transition: background .14s ease, box-shadow .14s ease;
}

tbody tr:hover {
    background: #f3f8ff;
}

.ok,
.warn,
.danger-pill {
    min-height: 26px;
    padding: 0 12px;
    border-radius: 999px;
    border: 1px solid transparent;
}

.user-type-lv0,
.user-type-vip,
.user-type-svip {
    min-height: 24px;
    padding: 0 9px;
    border-radius: 8px;
    border-color: transparent;
}

.ok {
    border-color: #bbf7d0;
}

.warn {
    border-color: #fde68a;
}

.danger-pill {
    border-color: #fecaca;
}

.log-panel {
    top: 86px;
    height: calc(100vh - 114px);
    border-radius: 12px;
    background:
        linear-gradient(180deg, rgba(255,255,255,.95), rgba(247,250,254,.92));
}

.log-item {
    border-radius: 8px;
    background: linear-gradient(180deg, #ffffff, #f7faff);
    box-shadow: 0 8px 18px rgba(23, 37, 58, .045);
}

.app-dialog {
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(246,249,253,.94));
}

.table-context-menu,
.table-submenu,
.duration-menu,
.custom-select-menu,
.admin-dropdown {
    border-radius: 10px;
    backdrop-filter: blur(16px);
}

.login-page {
    background:
        radial-gradient(circle at 18% 18%, rgba(31, 111, 235, .17), transparent 32%),
        radial-gradient(circle at 85% 78%, rgba(15, 159, 110, .13), transparent 30%),
        linear-gradient(135deg, #f8fbff, #eef3f8 52%, #f6faf8);
}

.login-shell {
    width: min(980px, 100%);
    border-radius: 18px;
    background: rgba(255, 255, 255, .82);
    backdrop-filter: blur(20px);
}

.login-intro {
    background:
        linear-gradient(135deg, rgba(17, 24, 39, .94), rgba(31, 111, 235, .72)),
        linear-gradient(180deg, #ffffff, #f8fafc);
    color: #ffffff;
}

.login-intro h1 {
    font-size: clamp(31px, 4vw, 43px);
}

.login-brand strong,
.login-intro .login-brand small {
    color: #ffffff;
}

.login-feature-grid div {
    border-color: rgba(255, 255, 255, .16);
    background: rgba(255, 255, 255, .1);
    backdrop-filter: blur(10px);
}

.login-feature-grid span {
    color: #bfdbfe;
}

.login-feature-grid strong {
    color: #ffffff;
}

.login-box {
    background: rgba(255, 255, 255, .96);
}

.home-page .panel,
.about-page .panel {
    border-radius: 12px;
}

.home-service-panel::before,
.home-overview-panel::before,
.home-resource-panel::before,
.home-network-panel::before,
.home-db-panel::before {
    height: 3px;
}

.service-status-card,
.home-stat-strip div,
.home-service-panel form,
.home-resource-panel .resource-card,
.home-network-panel .metric-card,
.home-db-panel .db-maintenance div,
.about-feature-list div,
.about-version-card {
    border-radius: 10px;
}

.chart-card,
.detail-list,
.bar-chart {
    border-radius: 10px;
}

.bar-chart {
    background:
        linear-gradient(180deg, rgba(255,255,255,.84), rgba(239,244,250,.72)),
        repeating-linear-gradient(0deg, transparent 0 33px, rgba(100, 116, 139, .08) 34px);
}

.home-network-panel .metric-card::after,
.home-service-panel::before,
.home-overview-panel::before,
.home-resource-panel::before,
.home-network-panel::before,
.home-db-panel::before {
    border-radius: 999px;
}

@media (max-width: 1180px) {
    .workspace {
        max-height: none;
    }

    .log-panel {
        top: auto;
        height: 360px;
    }
}

@media (max-width: 820px) {
    .sidebar {
        width: auto;
        border-right: 0;
        border-bottom: 1px solid rgba(255, 255, 255, .1);
    }

    .topbar {
        padding: 18px 16px 12px;
    }

    .main {
        padding: 0 14px 14px;
    }

    .topbar-stats > span,
    .admin-trigger {
        min-height: 34px;
    }
}

.nav-loading .sidebar nav a {
    cursor: progress;
}

.nav-page-loading {
    min-height: min(520px, calc(100vh - 150px));
    display: grid;
    align-content: start;
    gap: 18px;
    border: 1px solid rgba(211, 221, 233, .86);
    border-radius: 12px;
    background: rgba(255, 255, 255, .68);
    padding: 22px;
}

.nav-loading-head {
    display: flex;
    align-items: center;
    gap: 12px;
}

.nav-loading-head span {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: var(--blue);
    animation: nav-loading-pulse 1s ease-in-out infinite;
}

.nav-loading-head strong {
    font-size: 20px;
    color: var(--text);
}

.nav-loading-line,
.nav-loading-grid i {
    display: block;
    overflow: hidden;
    border-radius: 8px;
    background: #e8eef6;
    position: relative;
}

.nav-loading-line {
    height: 18px;
    width: min(520px, 72%);
}

.nav-loading-line.wide {
    width: min(720px, 92%);
}

.nav-loading-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(180px, 1fr));
    gap: 14px;
    margin-top: 8px;
}

.nav-loading-grid i {
    height: 130px;
}

.nav-loading-line::after,
.nav-loading-grid i::after {
    content: "";
    position: absolute;
    inset: 0;
    transform: translateX(-100%);
    background: linear-gradient(90deg, transparent, rgba(255,255,255,.72), transparent);
    animation: nav-loading-shimmer 1.25s ease-in-out infinite;
}

@keyframes nav-loading-pulse {
    0%, 100% { opacity: .38; transform: scale(.92); }
    50% { opacity: 1; transform: scale(1); }
}

@keyframes nav-loading-shimmer {
    to { transform: translateX(100%); }
}

@media (max-width: 820px) {
    .nav-loading-grid {
        grid-template-columns: 1fr;
    }
}

/* Mobile fit: keep the desktop visual language, but prevent narrow-screen overflow. */
@media (max-width: 640px) {
    html,
    body {
        min-height: 100%;
        height: auto;
        overflow-x: hidden;
    }

    body {
        font-size: 13px;
        background-attachment: fixed;
    }

    .app-shell {
        display: block;
        min-height: 100vh;
        width: 100%;
        overflow-x: hidden;
    }

    .sidebar {
        position: sticky;
        top: 0;
        z-index: 90;
        width: 100%;
        height: auto;
        padding: 12px 12px 10px;
        border-right: 0;
        border-bottom: 1px solid rgba(198, 211, 226, .62);
        background:
            radial-gradient(circle at 12% 0%, rgba(31, 111, 235, .12), transparent 32%),
            rgba(244, 248, 252, .82);
        backdrop-filter: blur(16px);
    }

    .brand {
        height: auto;
        min-height: 48px;
        gap: 10px;
        padding: 0 2px 10px;
    }

    .brand-mark {
        width: 40px;
        height: 40px;
    }

    .brand strong {
        font-size: 17px;
    }

    .brand small {
        margin-top: 4px;
        font-size: 11px;
    }

    .sidebar nav {
        display: flex;
        grid-template-columns: none;
        gap: 8px;
        padding: 10px 0 2px;
        overflow-x: auto;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
        scroll-snap-type: x proximity;
    }

    .sidebar a {
        flex: 0 0 auto;
        min-height: 38px;
        gap: 8px;
        padding: 0 12px;
        border-radius: 8px;
        white-space: nowrap;
        scroll-snap-align: start;
        transform: none;
    }

    .sidebar a:hover {
        transform: none;
    }

    .sidebar nav a span {
        width: 24px;
        height: 24px;
        border-radius: 7px;
    }

    .sidebar a.active::before {
        left: 8px;
        top: auto;
        right: 8px;
        bottom: 0;
        width: auto;
        height: 3px;
    }

    .logout {
        min-height: 38px;
        margin-top: 10px;
    }

    .content-shell {
        width: 100%;
        min-width: 0;
    }

    .topbar {
        padding: 16px 14px 10px;
        gap: 10px;
        overflow: visible;
    }

    .topbar h1 {
        font-size: 24px;
        line-height: 1.15;
    }

    .topbar-stats {
        width: 100%;
        display: flex;
        flex-wrap: nowrap;
        gap: 8px;
        overflow-x: auto;
        overflow-y: hidden;
        padding: 6px 0 10px;
        margin: 0 0 4px;
        min-height: 54px;
        align-items: center;
        justify-content: flex-start;
        -webkit-overflow-scrolling: touch;
    }

    .topbar-stats > span,
    .admin-trigger {
        flex: 0 0 auto;
        min-width: auto;
        min-height: 38px;
        padding: 0 10px;
        white-space: nowrap;
    }

    .topbar-stats > span {
        min-width: max-content;
    }

    .admin-trigger {
        min-width: max-content;
        max-width: 160px;
    }

    .admin-trigger strong {
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .admin-dropdown {
        position: fixed;
        left: 12px;
        right: 12px;
        top: 112px;
        width: auto;
        max-height: calc(100vh - 130px);
        overflow: auto;
    }

    .main {
        display: block;
        padding: 0 12px 14px;
        overflow: visible;
    }

    .workspace {
        width: 100%;
        max-height: none;
        overflow: visible;
        padding-right: 0;
    }

    .panel {
        width: 100%;
        padding: 14px;
        margin-bottom: 14px;
        border-radius: 10px;
    }

    .panel h2,
    .home-page .panel h2 {
        font-size: 18px;
    }

    .hero-grid,
    .form-grid,
    .button-row,
    .search,
    .post-form-grid,
    .version-form-grid,
    .settings-form-grid,
    .settings-form-grid.compact,
    .resource-grid,
    .monitor-table-grid,
    .monitor-table-grid.enhanced,
    .monitor-overview,
    .metric-card-grid,
    .card-registration-row,
    .about-hero,
    .about-grid,
    .db-maintenance {
        grid-template-columns: 1fr !important;
    }

    .home-stat-strip {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .inline-options,
    .form-actions,
    .button-row {
        gap: 10px;
    }

    .button-row {
        display: grid;
    }

    .form-actions button,
    .button-row button,
    .search button,
    .search a {
        width: 100%;
        min-width: 0;
    }

    .card-registration-row .check,
    .setting-check,
    .check {
        min-height: 34px;
    }

    .domain-primary-row,
    .domain-toggle-row {
        grid-template-columns: 1fr !important;
    }

    input,
    select,
    textarea,
    .duration-trigger,
    .custom-select-trigger {
        min-height: 38px;
        font-size: 16px;
    }

    .table-scroll {
        min-height: 260px;
        max-height: 58vh;
        border-radius: 10px;
        overflow: auto;
        -webkit-overflow-scrolling: touch;
    }

    .table-scroll table {
        min-width: 760px;
    }

    th,
    td {
        padding: 10px 12px;
        max-width: 190px;
    }

    .resource-card,
    .metric-card,
    .monitor-overview div,
    .detail-list div,
    .db-maintenance div {
        padding: 13px;
    }

    .resource-card {
        gap: 12px;
    }

    .home-resource-panel .ring,
    .ring {
        width: 76px;
        height: 76px;
    }

    .bar-chart {
        min-height: 150px;
    }

    .chart-head {
        display: grid;
    }

    .chart-legend {
        flex-wrap: wrap;
        gap: 10px;
    }

    .log-panel {
        position: static;
        width: 100%;
        height: 300px;
        margin-top: 14px;
        padding: 12px;
        border-radius: 10px;
    }

    .logs {
        height: calc(100% - 48px);
    }

    .app-toast-stack {
        top: 12px;
        width: calc(100vw - 24px);
    }

    .app-dialog {
        width: calc(100vw - 24px);
        padding: 14px;
    }

    .app-dialog-actions {
        display: grid;
        grid-template-columns: 1fr 1fr;
    }

    .table-context-menu {
        max-width: calc(100vw - 16px);
        max-height: calc(100vh - 16px);
        overflow: auto;
    }

    .login-page {
        min-height: 100vh;
        padding: 12px;
        place-items: start stretch;
    }

    .login-shell {
        width: 100%;
        min-height: 0;
        grid-template-columns: 1fr;
        border-radius: 14px;
    }

    .login-intro,
    .login-box {
        padding: 22px;
    }

    .login-intro h1 {
        font-size: 28px;
    }

    .login-feature-grid {
        grid-template-columns: 1fr;
    }

    .nav-page-loading {
        min-height: 320px;
        padding: 16px;
    }
}

@media (max-width: 380px) {
    .topbar h1 {
        font-size: 22px;
    }

    .home-stat-strip {
        grid-template-columns: 1fr;
    }

    .sidebar a {
        padding: 0 10px;
    }
}

.app-dialog.app-dialog-wide {
    width: min(760px, calc(100vw - 30px));
}

/* ----- 文件管理 · 蓝奏 Cookie + 一键导入 ----- */
.form-actions-files .lanzou-cookie-field {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1;
    min-width: min(100%, 320px);
    margin-left: auto;
}

.form-actions-files .lanzou-cookie-field span {
    white-space: nowrap;
    font-size: 13px;
    opacity: 0.85;
}

.form-actions-files .lanzou-cookie-field input {
    flex: 1;
    min-width: 0;
}

.file-browser-panel .file-config-grid {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: end;
    column-gap: 12px;
}

.file-browser-panel .file-config-cookie-field {
    min-width: 0;
    grid-column: 1 / 2;
}

.file-browser-panel .file-config-cookie-field input {
    width: 100%;
}

.file-browser-panel .file-sync-interval-field {
    width: 120px;
    justify-self: end;
    grid-column: 2 / 3;
}

.file-browser-panel .file-sync-interval-field input,
.file-browser-panel .file-sync-interval-field select {
    width: 100%;
}

.file-browser-panel .file-sync-interval-field .custom-select {
    width: 100%;
}

.file-browser-panel .file-sync-status-field {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    gap: 8px;
}

.file-browser-panel .file-sync-status-label {
    font-weight: 700;
    color: var(--text);
}

.file-browser-panel .file-sync-status-text {
    display: inline-flex;
    align-items: center;
    min-height: 26px;
    padding: 0 10px;
    border-radius: 999px;
    border: 1px solid var(--line-strong);
    background: #f8fafc;
    color: #475569;
    font-weight: 700;
    line-height: 1;
}

.file-browser-panel .file-sync-status-text.loading {
    border-color: rgba(37, 99, 235, 0.25);
    background: rgba(37, 99, 235, 0.1);
    color: #1d4ed8;
}

.file-browser-panel .file-sync-status-text.ok {
    border-color: rgba(22, 163, 74, 0.28);
    background: rgba(22, 163, 74, 0.1);
    color: #166534;
}

.file-browser-panel .file-sync-status-text.error {
    border-color: rgba(220, 38, 38, 0.28);
    background: rgba(220, 38, 38, 0.1);
    color: #b91c1c;
}

.files-import-mask {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.45);
    backdrop-filter: blur(2px);
    z-index: 12040;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
    box-sizing: border-box;
}

.files-import-mask.open {
    display: flex;
}

.files-import-dialog {
    width: min(560px, 100%);
    max-height: min(78vh, 640px);
    background: var(--surface, #fff);
    border-radius: 12px;
    box-shadow: 0 24px 56px rgba(15, 23, 42, 0.2);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border: 1px solid var(--hairline, rgba(0, 0, 0, 0.08));
}

.files-import-dialog h3 {
    margin: 0;
    padding: 16px 18px 6px;
    font-size: 17px;
    font-weight: 600;
}

.files-import-meta,
.files-import-hint {
    margin: 0 18px;
    padding: 4px 0;
    font-size: 13px;
    opacity: 0.86;
}

.files-import-tree {
    margin: 8px 12px;
    flex: 1;
    min-height: 200px;
    max-height: 46vh;
    overflow: auto;
    padding: 6px;
    border: 1px solid var(--hairline, rgba(0, 0, 0, 0.08));
    border-radius: 8px;
    background: #fff;
}

.files-import-row {
    display: flex;
    align-items: center;
    gap: 6px;
    min-height: 30px;
    padding: 2px 6px 2px calc(6px + var(--depth, 0) * 14px);
    font-size: 14px;
    line-height: 1.25;
    border-radius: 6px;
}

.files-import-row:hover {
    background: rgba(37, 99, 235, 0.08);
}

.files-import-row label {
    display: flex;
    align-items: center;
    gap: 9px;
    flex: 1;
    cursor: pointer;
    min-width: 0;
    margin: 0;
    font-weight: 500;
    color: #334155;
}

.files-import-indent {
    --depth: 0;
}

.files-import-tree input[type="checkbox"][data-import-key] {
    appearance: auto !important;
    -webkit-appearance: checkbox !important;
    box-shadow: none !important;
    transform: none !important;
    width: 16px !important;
    height: 16px !important;
    min-height: 0 !important;
    min-width: 0 !important;
    flex: 0 0 16px !important;
    display: inline-block !important;
    vertical-align: middle !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 1px solid #94a3b8 !important;
    background: #fff !important;
    accent-color: #2563eb;
    border-radius: 3px;
}

.files-import-tree label input[type="checkbox"][data-import-key] {
    margin-top: 0 !important;
}

.files-import-carett {
    width: 20px;
    height: 20px;
    padding: 0;
    margin: 0;
    flex-shrink: 0;
    border: 0;
    background: transparent;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    opacity: 0.55;
    font-size: 10px;
    line-height: 1;
    border-radius: 4px;
}

.files-import-carett:hover {
    background: rgba(0, 0, 0, 0.06);
    opacity: 0.9;
}

.files-import-folder-children.collapsed {
    display: none;
}

.files-import-icon {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.files-import-icon.file::before {
    content: "";
    display: block;
    width: 14px;
    height: 16px;
    border-radius: 2px;
    background: linear-gradient(180deg, #f8fafc 0%, #e2e8f0 100%);
    border: 1px solid rgba(0, 0, 0, 0.12);
}

.files-import-icon.folder::before {
    content: "";
    display: block;
    width: 16px;
    height: 13px;
    border-radius: 2px 3px 2px 2px;
    background: linear-gradient(180deg, #fde68a 0%, #f59e0b 100%);
    border: 1px solid rgba(180, 83, 9, 0.35);
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.35) inset;
}

.files-import-footer {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    padding: 12px 16px 16px;
    border-top: 0;
}

.files-import-footer .files-import-footer-right {
    display: flex;
    gap: 10px;
}

.files-import-status {
    margin: 0 18px 8px;
    font-size: 12px;
    color: var(--muted, #64748b);
    min-height: 1.2em;
}

.files-import-status.error {
    color: var(--red, #dc2626);
}

.files-import-footer button {
    min-width: 90px;
}

.files-import-browser-head {
    margin: 4px 12px 6px;
    display: grid;
    gap: 8px;
}

.files-import-pathbar {
    margin: 0;
}

.files-import-table-wrap {
    margin: 0 12px;
    min-height: 200px;
    max-height: 46vh;
    overflow-x: hidden !important;
}

.files-import-table-wrap table {
    table-layout: fixed;
    width: 100% !important;
    min-width: 0 !important;
    border-collapse: collapse !important;
    border-spacing: 0 !important;
}

.files-import-table-wrap td,
.files-import-table-wrap th {
    padding: 8px 10px;
    max-width: none;
    overflow: hidden;
    text-overflow: ellipsis;
}

.files-import-table-wrap .file-name-cell {
    min-width: 0;
}

.files-import-table-wrap .file-name-cell span:last-child {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.files-import-table-wrap th:first-child,
.files-import-table-wrap td:first-child {
    width: 38px;
    text-align: center;
}

.files-import-table-wrap th:nth-child(2),
.files-import-table-wrap td:nth-child(2) {
    width: auto;
}

.files-import-table-wrap th:nth-child(3),
.files-import-table-wrap td:nth-child(3) {
    width: 92px;
    white-space: nowrap;
    text-align: right;
}

.files-import-table-wrap th:nth-child(4),
.files-import-table-wrap td:nth-child(4) {
    width: 128px;
    white-space: nowrap;
    text-align: right;
}

.files-import-table-wrap th:nth-child(3),
.files-import-table-wrap td:nth-child(3),
.files-import-table-wrap th:nth-child(4),
.files-import-table-wrap td:nth-child(4) {
    padding-left: 6px;
    padding-right: 10px;
}

.files-import-table-wrap input[type="checkbox"] {
    width: 16px !important;
    height: 16px !important;
    min-height: 0 !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    box-shadow: none !important;
    transform: none !important;
}

.files-import-loading-row td {
    height: 44px;
    text-overflow: clip !important;
    overflow: hidden !important;
    white-space: nowrap !important;
}

.files-import-skeleton {
    display: inline-block;
    height: 12px;
    border-radius: 999px;
    background: linear-gradient(90deg, #edf2f7 25%, #f8fafc 37%, #edf2f7 63%);
    background-size: 300% 100%;
    animation: files-import-shimmer 1.05s linear infinite;
}

.files-import-skeleton-check { width: 16px; height: 16px; border-radius: 4px; }
.files-import-skeleton-name { width: 180px; }
.files-import-skeleton-size { width: 70px; }
.files-import-skeleton-time { width: 120px; }

@keyframes files-import-shimmer {
    0% { background-position: 100% 0; }
    100% { background-position: 0 0; }
}

.files-direct-link-mask {
    position: fixed;
    inset: 0;
    z-index: 12060;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
    background: rgba(15, 23, 42, 0.45);
    backdrop-filter: blur(2px);
}

.files-direct-link-mask.open {
    display: flex;
}

.files-direct-link-dialog {
    width: min(640px, 100%);
    max-height: min(80vh, 680px);
    display: grid;
    gap: 10px;
    padding: 16px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 24px 56px rgba(15, 23, 42, 0.2);
}

.files-direct-link-dialog h3 {
    margin: 0;
    font-size: 17px;
}

.files-direct-link-meta,
.files-direct-link-status {
    margin: 0;
    font-size: 13px;
}

.files-direct-link-status {
    width: 100%;
    min-height: 38px;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    padding: 10px 12px;
    border: 1px solid #bfdbfe;
    border-radius: 10px;
    background: #eff6ff;
    color: #1d4ed8;
    font-weight: 700;
    line-height: 1.35;
}

.files-direct-link-status.loading {
    border-color: #bfdbfe;
    background: #eff6ff;
    color: #1d4ed8;
}

.files-direct-link-status.ok {
    border-color: #bbf7d0;
    background: #ecfdf5;
    color: #15803d;
}

.files-direct-link-status.error {
    border-color: #fecaca;
    background: #fef2f2;
    color: #dc2626;
}

.files-direct-link-output {
    min-height: 120px;
    max-height: 260px;
    resize: vertical;
    margin: 0;
    font-family: Consolas, "SFMono-Regular", "Microsoft YaHei", monospace;
    line-height: 1.5;
    letter-spacing: 0;
    white-space: pre-wrap;
    word-break: break-all;
    overflow-wrap: anywhere;
    line-break: auto;
    overflow-x: hidden;
}

.files-direct-link-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
}

/* Disabled buttons: keep a clearly lighter background. */
button:disabled,
button[disabled] {
    opacity: 1 !important;
    color: #94a3b8 !important;
    background: linear-gradient(180deg, #f4f7fc, #ecf1f8) !important;
    border-color: #d7e1ee !important;
    filter: none !important;
}

button.ghost:disabled,
button.ghost[disabled],
.icon-button:disabled,
.icon-button[disabled] {
    background: linear-gradient(180deg, #fafcff, #f1f5fb) !important;
    color: #9aa7ba !important;
    border-color: #dbe4f0 !important;
}

button.danger:disabled,
button.danger[disabled] {
    background: linear-gradient(180deg, #fdeceb, #f9e0de) !important;
    color: #c59590 !important;
    border-color: #f1c8c4 !important;
}

.admin-trigger:disabled,
.admin-trigger[disabled] {
    background: rgba(255, 255, 255, .92) !important;
    color: #94a3b8 !important;
    border-color: rgba(203, 214, 228, .66) !important;
    box-shadow: none !important;
}

.app-toast-close:disabled,
.app-toast-close[disabled] {
    color: #c0cad8 !important;
    background: transparent !important;
}

@media (max-width: 640px) {
    .file-browser-panel .file-config-grid {
        grid-template-columns: 1fr !important;
    }

    .file-browser-panel .file-sync-interval-field {
        width: 100%;
        justify-self: stretch;
    }
}

.community-admin-page {
    display: grid;
    gap: 18px;
}

.community-hero-head,
.community-group-head,
.community-message-head,
.community-user-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
}

.community-hero-head h2 {
    margin: 0;
    font-size: 22px;
    line-height: 1.4;
}

.community-hero-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.community-master-switch {
    min-height: 36px;
    padding: 0 14px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: var(--panel-soft);
}

.community-realtime-pill {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-height: 38px;
    padding: 0 14px;
    border-radius: 999px;
    border: 1px solid var(--line);
    background: #f8fbff;
    color: var(--text);
    font-weight: 700;
}

.community-pill-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #94a3b8;
    box-shadow: 0 0 0 6px rgba(148, 163, 184, 0.14);
}

.community-realtime-pill.connected .community-pill-dot {
    background: var(--green);
    box-shadow: 0 0 0 6px rgba(22, 163, 74, 0.14);
}

.community-realtime-pill.connecting .community-pill-dot {
    background: var(--amber);
    box-shadow: 0 0 0 6px rgba(217, 119, 6, 0.14);
}

.community-realtime-pill.disconnected .community-pill-dot {
    background: var(--red);
    box-shadow: 0 0 0 6px rgba(220, 38, 38, 0.14);
}

.community-stat-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 12px;
    margin-top: 16px;
}

.community-stat-card {
    min-height: 124px;
    padding: 16px;
    border-radius: 18px;
    border: 1px solid rgba(37, 99, 235, 0.09);
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(241, 247, 255, 0.94));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.community-stat-card small {
    display: block;
    color: var(--muted);
    font-size: 12px;
}

.community-stat-card strong {
    display: block;
    margin-top: 10px;
    font-size: 32px;
    line-height: 1;
    color: #0f3ea8;
}

.community-stat-card span {
    display: block;
    margin-top: 12px;
    color: var(--muted);
    line-height: 1.5;
}

.community-settings-grid {
    display: flex;
    flex-wrap: wrap;
    align-items: end;
    gap: 12px 14px;
}

.community-settings-grid > label {
    display: flex;
    flex-direction: column;
    gap: 6px;
    flex: 1 1 156px;
    min-width: 156px;
    max-width: 188px;
}

.community-settings-grid > label.community-setting-wide {
    flex-basis: 280px;
    min-width: 220px;
    max-width: 320px;
}

.community-settings-grid > label input {
    width: 100%;
    margin-top: 0;
}

.community-admin-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 18px;
}

.community-admin-grid-secondary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 18px;
}

.community-card-list {
    display: grid;
    gap: 12px;
    max-height: 620px;
    overflow: auto;
    padding-right: 4px;
}

.community-load-more-row {
    display: flex;
    justify-content: center;
    margin-top: 12px;
}

.community-empty-block {
    display: grid;
    place-items: center;
    min-height: 180px;
    padding: 24px;
    border: 1px dashed var(--line-strong);
    border-radius: 18px;
    color: var(--muted);
    background: linear-gradient(180deg, rgba(248, 250, 252, 0.95), rgba(243, 247, 252, 0.82));
    text-align: center;
}

.community-toolbar {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    margin-bottom: 14px;
}

.community-avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    overflow: hidden;
    display: inline-grid;
    place-items: center;
    background: linear-gradient(135deg, #dbeafe, #ecfeff);
    color: #0f3ea8;
    font-weight: 800;
    flex: 0 0 auto;
}

.community-avatar-small {
    width: 34px;
    height: 34px;
    font-size: 12px;
}

.community-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.community-user-main,
.community-message-user,
.community-group-owner,
.community-relation-user {
    display: flex;
    align-items: center;
    gap: 12px;
}

.community-user-main strong,
.community-message-user strong,
.community-group-head strong,
.community-relation-user span {
    display: block;
    color: var(--text);
}

.community-inline-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 6px;
    color: var(--muted);
    font-size: 12px;
}

.community-tag {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    padding: 0 10px;
    border-radius: 999px;
    background: var(--panel-soft);
    border: 1px solid var(--line);
}

.community-tag.online {
    color: var(--green);
    background: var(--green-soft);
    border-color: rgba(22, 163, 74, 0.12);
}

.community-tag.offline {
    color: var(--muted);
}

.community-tag.muted {
    color: var(--red);
    background: var(--red-soft);
    border-color: rgba(220, 38, 38, 0.12);
}

.community-tag.normal {
    color: var(--blue);
    background: var(--blue-soft);
    border-color: rgba(37, 99, 235, 0.12);
}

.community-message-card,
.community-user-card,
.community-group-card,
.community-relation-card {
    padding: 14px 16px;
    border-radius: 18px;
    border: 1px solid var(--line);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 250, 252, 0.94));
}

.community-user-card.compact {
    padding: 12px 14px;
}

.community-message-user span,
.community-group-head span {
    display: block;
    margin-top: 5px;
    color: var(--muted);
    font-size: 12px;
    line-height: 1.5;
}

.community-message-body,
.community-group-card p {
    margin: 12px 0 0;
    color: var(--text);
    line-height: 1.6;
    white-space: pre-wrap;
    word-break: break-word;
}

.community-row-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.community-action-button {
    height: 32px;
    padding: 0 12px;
    border-radius: 10px;
    font-size: 12px;
}

.community-relation-users {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.community-relation-link {
    color: var(--muted);
    font-weight: 700;
}

@media (max-width: 1680px) {
    .community-stat-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 1120px) {
    .community-admin-grid,
    .community-admin-grid-secondary,
    .community-stat-grid {
        grid-template-columns: 1fr;
    }

    .community-settings-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    }

    .community-settings-grid > label,
    .community-settings-grid > label.community-setting-wide,
    .community-settings-grid > label input {
        min-width: 0;
        max-width: none;
        width: 100%;
    }

    .community-hero-head,
    .community-hero-actions,
    .community-group-head,
    .community-message-head,
    .community-user-head {
        flex-direction: column;
        align-items: stretch;
    }

    .community-toolbar {
        grid-template-columns: 1fr;
    }
}

.plugins-admin-page {
    display: grid;
    gap: 16px;
}

.plugin-hero-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
}

.plugin-hero-head h2 {
    margin: 0;
    max-width: 720px;
    font-size: 20px;
    line-height: 1.35;
}

.plugin-stat-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(92px, 1fr));
    gap: 10px;
    min-width: 330px;
}

.plugin-stat-grid article,
.plugin-review-permissions,
.plugin-review-summary {
    padding: 10px 12px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: var(--panel-soft);
}

.plugin-stat-grid span,
.plugin-listing-card small,
.plugin-review-title span,
.plugin-review-meta,
.plugin-review-permissions {
    color: var(--muted);
    font-size: 12px;
}

.plugin-stat-grid strong {
    display: block;
    margin-top: 4px;
    font-size: 24px;
}

.plugin-review-list {
    display: grid;
    gap: 12px;
}

.plugin-market-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 148px;
    gap: 16px;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--panel);
    box-shadow: var(--shadow-soft);
    align-items: start;
}

.plugin-review-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 148px;
    gap: 16px;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--panel);
    box-shadow: var(--shadow-soft);
    align-items: start;
}

.plugin-market-card-main {
    display: flex;
    gap: 12px;
    min-width: 0;
}

.plugin-market-logo {
    width: 44px;
    height: 44px;
    flex: 0 0 44px;
    border-radius: 8px;
    object-fit: cover;
    background: #fff;
    border: 1px solid rgba(148, 163, 184, .28);
}

.plugin-market-logo-fallback {
    display: grid;
    place-items: center;
    font-size: 18px;
    font-weight: 800;
    color: var(--blue-dark);
    background: linear-gradient(135deg, var(--blue-soft), var(--green-soft));
}

.plugin-market-body {
    min-width: 0;
    flex: 1 1 auto;
}

.plugin-market-head {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.plugin-market-head h3,
.plugin-market-head strong {
    margin: 0;
    font-size: 17px;
    line-height: 1.25;
}

.plugin-market-version,
.plugin-market-slug {
    color: var(--muted);
    font-size: 12px;
}

.plugin-market-slug {
    display: block;
    margin-top: 2px;
}

.plugin-market-summary {
    margin: 8px 0;
    color: #475569;
    line-height: 1.55;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.plugin-market-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 6px 12px;
    color: var(--muted);
    font-size: 12px;
    line-height: 1.5;
}

.plugin-star-stat {
    color: #b45309;
    font-weight: 700;
}

.plugin-market-card-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
    width: 148px;
    min-width: 148px;
}

.plugin-market-card-actions form {
    margin: 0;
    width: 100%;
}

.plugin-market-card-actions button,
.plugin-market-card-actions .plugin-action-combo {
    width: 100%;
}

.plugin-action-combo {
    display: flex;
    width: 100%;
    border: 1px solid var(--line);
    border-radius: 8px;
    overflow: hidden;
    background: var(--panel-soft);
}

.plugin-action-combo-form {
    margin: 0;
    flex: 1 1 auto;
    min-width: 0;
}

.plugin-action-combo-part {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 0 10px;
    border: 0;
    background: transparent;
    color: var(--text);
    font: inherit;
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    white-space: nowrap;
}

.plugin-action-combo-download {
    flex: 0 0 auto;
    border-right: 1px solid var(--line);
    color: var(--muted);
}

.plugin-action-combo-download:hover {
    background: rgba(148, 163, 184, .12);
    color: var(--text);
}

.plugin-action-combo-publish {
    width: 100%;
    background: var(--blue);
    color: #fff;
}

.plugin-action-combo-publish:hover {
    filter: brightness(1.05);
}

.plugin-review-card.status-approved {
    border-color: rgba(22, 163, 74, .36);
}

.plugin-review-card.status-rejected,
.plugin-review-card.status-failed {
    border-color: rgba(220, 38, 38, .32);
}

.plugin-review-main {
    display: flex;
    gap: 12px;
    min-width: 0;
}

.plugin-review-logo {
    width: 48px;
    height: 48px;
    flex: 0 0 auto;
    display: grid;
    place-items: center;
    border-radius: 12px;
    background: linear-gradient(135deg, var(--blue-soft), var(--green-soft));
    color: var(--blue-dark);
    font-size: 20px;
    font-weight: 800;
}

.plugin-review-body {
    min-width: 0;
}

.plugin-review-title {
    display: flex;
    align-items: baseline;
    gap: 10px;
    flex-wrap: wrap;
}

.plugin-review-title h3 {
    margin: 0;
    font-size: 17px;
}

.plugin-official-tag {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    border-radius: 999px;
    background: var(--blue-soft);
    color: var(--blue-dark);
    font-size: 11px;
    font-weight: 700;
}

.plugin-listing-card-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
    width: 148px;
    min-width: 148px;
    align-self: start;
}

.plugin-listing-card-actions form {
    margin: 0;
    width: 100%;
}

.plugin-listing-card-actions button {
    width: 100%;
}

.plugin-review-body p,
.plugin-listing-card p {
    margin: 7px 0 8px;
    color: #334155;
    line-height: 1.55;
}

.plugin-review-meta {
    display: flex;
    gap: 8px 14px;
    flex-wrap: wrap;
}

.plugin-review-permissions,
.plugin-review-summary {
    margin-top: 8px;
}

.plugin-review-summary {
    color: var(--text);
    line-height: 1.55;
}

.plugin-review-reasons {
    margin: 8px 0 0;
    padding-left: 18px;
    color: var(--muted);
    line-height: 1.65;
}

.plugin-review-actions,
.plugin-inline-reject {
    display: flex;
    flex-direction: column;
    gap: 8px;
    width: 148px;
    min-width: 148px;
}

.plugin-review-actions form {
    margin: 0;
    width: 100%;
}

.plugin-review-actions button,
.plugin-inline-reject input {
    width: 100%;
}

.plugin-status-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 30px;
    border-radius: 999px;
    background: var(--blue-soft);
    color: var(--blue-dark);
    font-size: 12px;
    font-weight: 700;
}

.plugin-listing-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 12px;
}

.plugin-listing-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 148px;
    gap: 16px;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--panel);
    box-shadow: var(--shadow-soft);
    align-items: start;
}

.plugin-listing-card strong {
    display: block;
}

.plugin-listing-card .plugin-market-slug {
    display: block;
    margin-top: 2px;
    color: var(--muted);
    font-size: 12px;
}

@media (max-width: 980px) {
    .plugin-hero-head {
        flex-direction: column;
        align-items: stretch;
    }

    .plugin-review-card,
    .plugin-market-card,
    .plugin-listing-card {
        grid-template-columns: 1fr;
    }

    .plugin-market-card-actions,
    .plugin-listing-card-actions,
    .plugin-review-actions {
        width: 100%;
        min-width: 0;
    }

    .plugin-stat-grid {
        min-width: 0;
        grid-template-columns: repeat(3, 1fr);
    }
}
