/* ================================================================
   页面特定样式 (Pages)
   登录页、控制台、详情页、表单页、404 页
   ================================================================ */

/* ---- 登录页 ---- */
.login-page {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: calc(100vh - var(--navbar-height));
    margin: calc(-1 * var(--space-8)) calc(-1 * var(--space-6));
    background: var(--color-bg);
    padding: var(--space-4);
}

.login-card {
    width: 100%;
    max-width: 380px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    padding: var(--space-10);
    box-shadow: var(--shadow-lg);
}

.login-header {
    text-align: center;
    margin-bottom: var(--space-8);
}

.login-header h1 {
    font-size: var(--font-2xl);
    margin-bottom: var(--space-2);
    color: var(--color-text);
}

.login-subtitle {
    font-size: var(--font-sm);
    color: var(--color-text-muted);
}

.login-form .form-group {
    margin-bottom: var(--space-5);
}

.login-form .btn {
    margin-top: var(--space-4);
    padding: 10px 16px;
    font-size: var(--font-base);
}

/* ---- 控制台 (Dashboard) ---- */
.dashboard {
    /* 由 main-content 控制外层 */
}

.page-header {
    display: flex;
    align-items: baseline;
    gap: var(--space-3);
    margin-bottom: var(--space-6);
}

.search-panel {
    margin-bottom: var(--space-6);
}

.search-row {
    display: flex;
    gap: var(--space-3);
    margin-bottom: var(--space-3);
}

.search-input {
    flex: 1;
}

.filter-row {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex-wrap: wrap;
}

.filter-form .form-select,
.filter-form .form-input[type="date"] {
    width: auto;
    min-width: 120px;
}

.filter-form .form-input[type="date"] {
    width: 140px;
}

.archive-list {
    /* 由 archive-card 组件控制 */
}

/* ---- 详情页 ---- */
.detail-page {
    /* 由 main-content 控制 */
}

.detail-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    box-shadow: var(--shadow-sm);
    margin-bottom: var(--space-8);
}

.detail-header h2 {
    margin-bottom: var(--space-4);
}

.detail-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-sm);
    color: var(--color-text-secondary);
    margin-bottom: var(--space-2);
}

.detail-tags {
    margin-top: var(--space-3);
    display: flex;
    flex-wrap: wrap;
}

.detail-content {
    padding: var(--space-2) 0;
    line-height: 1.8;
    overflow-wrap: break-word;
    word-break: break-word;
}

.detail-content p {
    margin-bottom: var(--space-3);
}

.detail-content ul,
.detail-content ol {
    padding-left: var(--space-6);
    margin-bottom: var(--space-3);
}

.detail-content h3,
.detail-content h4 {
    margin-top: var(--space-4);
    margin-bottom: var(--space-2);
}

.detail-actions {
    display: flex;
    gap: var(--space-3);
}

/* ---- 操作历史 ---- */
.history-section {
    margin-top: var(--space-8);
}

.history-section h3 {
    font-size: var(--font-md);
    margin-bottom: var(--space-4);
}

.history-list {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.history-item {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    border-bottom: 1px solid var(--color-border-light);
    font-size: var(--font-sm);
}

.history-item:last-child {
    border-bottom: none;
}

.history-time {
    font-family: var(--font-mono);
    font-size: var(--font-xs);
    color: var(--color-text-muted);
    white-space: nowrap;
    min-width: 130px;
}

.history-user {
    font-weight: 500;
    color: var(--color-text);
    min-width: 80px;
}

.history-action {
    color: var(--color-text-secondary);
}

/* ---- 新建/编辑档案页 ---- */
.form-page {
    max-width: 720px;
}

.archive-form {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    box-shadow: var(--shadow-sm);
}

/* ---- 404 页 ---- */
.not-found-page {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 60vh;
    text-align: center;
}

.not-found-content h1 {
    font-size: 5rem;
    font-weight: 700;
    color: var(--color-primary);
    margin-bottom: var(--space-4);
}

.not-found-content p {
    font-size: var(--font-lg);
    color: var(--color-text-secondary);
    margin-bottom: var(--space-6);
}

/* ---- 审计日志页 ---- */
.audit-page {
    /* 由 main-content 控制 */
}

/* ---- 响应式 ---- */
@media (max-width: 768px) {
    .login-card {
        padding: var(--space-6);
    }

    .detail-card {
        padding: var(--space-4);
    }

    .detail-actions {
        flex-direction: column;
    }

    .detail-actions .btn {
        width: 100%;
    }

    .search-row {
        flex-direction: column;
    }

    .filter-row {
        flex-direction: column;
        align-items: stretch;
    }

    .filter-row .form-select,
    .filter-row .form-input[type="date"] {
        width: 100%;
    }

    .history-item {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--space-1);
    }

    .history-time {
        min-width: auto;
    }

    .nav-links {
        gap: var(--space-2);
    }
}

@media (min-width: 1024px) {
    .form-page {
        max-width: 760px;
    }
}

@media (min-width: 1440px) {
    :root {
        --max-content-width: 1100px;
    }
}
