/**
 * Components CSS
 * 可复用组件模板：按钮、卡片、工具栏、空状态。
 * 这里不写具体业务模块差异，模块差异继续放在各自 CSS 文件。
 */

.app-card {
    background: var(--bg-card);
    border: 1px solid rgba(255, 194, 226, 0.72);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-cute);
}

.app-soft-panel {
    background: var(--bg-soft);
    border: 1px solid rgba(255, 194, 226, 0.62);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-panel);
}

.app-toolbar {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-3);
    width: 100%;
}

.app-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: var(--space-3);
    flex-wrap: wrap;
}

.app-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4em;
    min-height: 40px;
    padding: 0 var(--space-5);
    border: 0;
    border-radius: var(--radius-pill);
    color: #fff;
    background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
    box-shadow: 0 8px 22px rgba(255, 142, 199, 0.24);
    cursor: pointer;
    font-family: var(--font-body);
    font-weight: 700;
    transition: transform 0.18s ease, box-shadow 0.18s ease, opacity 0.18s ease;
}

.app-button:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow-hover);
}

.app-button:disabled {
    cursor: not-allowed;
    opacity: 0.55;
    transform: none;
}

.app-button-secondary {
    color: var(--text-medium);
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(255, 194, 226, 0.86);
    box-shadow: none;
}

.app-empty {
    padding: var(--space-8) var(--space-5);
    color: var(--text-light);
    text-align: center;
}

.app-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-3);
    margin-top: var(--space-5);
}
