:root {
    --color: #303133;
    --color-primary: #409eff;
    --color-success: #67c23a;
    --color-info: #a8abb2;
    --color-warning: #e6a23c;
    --color-danger: #f56c6c;
    --border-color: #dcdfe6;
    --placeholder-color: #a8abb2;
    --disable-background-color: #f5f7fa;
    --disable-text-color: #a8abb2;
    --button-background-color: #f4f4f5;
    --pagination-button-background-color: #f0f2f5;
}

/* 滚动条样式 */
::-webkit-scrollbar {
    width: 6px
}

::-webkit-scrollbar:horizontal {
    height: 6px
}

::-webkit-scrollbar-track {
    border-radius: 10px
}

::-webkit-scrollbar-thumb {
    background-color: #00000030;
    border-radius: 10px;
    transition: all .2s ease-in-out
}

::-webkit-scrollbar-thumb:hover {
    cursor: pointer;
    background-color: #0000004d
}

/* 设置页面中可交互元素的触摸操作行为
 * 此规则应用给一系列可交互的HTML元素，确保它们在触摸屏设备上具有预期的行为
 * touch-action: manipulation; 使得这些元素仅允许平移和缩放操作，提升用户交互体验
 */
a, area, button, [role=button], input, label, select, summary, textarea {
    touch-action: manipulation;
}

* {
    vertical-align: middle;
    font-family: inherit;
    transition: all .2s ease;
}

*:focus {
    outline: none;
}

img{
    max-width: 100%;
    object-fit: cover;
}

body {
    font-family: Helvetica Neue, Helvetica, PingFang SC, Hiragino Sans GB, Microsoft YaHei, SimSun, sans-serif;
    margin: 0;
    font-size: 14px;
    color: var(--color);
}

a {
    color: inherit;
    text-decoration: none;
}

a:hover {
    opacity: 0.9;
}

.text-default {
    color: var(--color);
}

.text-primary {
    color: var(--color-primary);
}

.text-success {
    color: var(--color-success);
}

.text-info {
    color: var(--color-info);
}

.text-warning {
    color: var(--color-warning);
}

.text-danger {
    color: var(--color-danger);
}

.text-disabled {
    opacity: 0.7;
    pointer-events: none;
}

.button {
    display: inline-block;
    height: 32px;
    box-sizing: border-box;
    padding: 0 16px;
    cursor: pointer;
    background: var(--button-background-color);
    border: none;
    border-radius: 4px;
    color: var(--color);
    line-height: 32px;
    font-size: inherit;
}

.button:hover {
    opacity: 0.9;
}

.button:disabled, .button-disabled {
    opacity: 0.7;
    pointer-events: none;
}

.button-default {
    background: var(--button-background-color);
    color: var(--color);
}

.button-primary {
    background-color: var(--color-primary);
    color: #FFFFFF;
}

.button-info {
    background-color: var(--color-info);
    color: #FFFFFF;
}

.button-success {
    background-color: var(--color-success);
    color: #FFFFFF;
}

.button-warning {
    background-color: var(--color-warning);
    color: #FFFFFF;
}

.button-danger {
    background-color: var(--color-danger);
    color: #FFFFFF;
}

select {
    appearance: none;
    height: 32px;
    box-sizing: border-box;
    padding: 4px 36px 4px 12px;
    line-height: 24px;
    border-radius: 4px;
    border: 1px solid var(--border-color);
    background-color: #FFFFFF;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23a8abb2' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
    background-size: 16px 12px;
    background-position: right 12px center;
    background-repeat: no-repeat;
}

select:disabled {
    background-color: var(--disable-background-color);
    color: var(--disable-text-color);
}

input:is([type=text],[type=number],[type=password],[type=email],[type=url],[type=date],[type=datetime-local],[type=month],[type=time],[type=week]) {
    height: 32px;
    box-sizing: border-box;
    padding: 4px 12px;
    border-radius: 4px;
    border: 1px solid var(--border-color);
    background-color: #FFFFFF;
}

input:is([type=text],[type=number],[type=password],[type=email],[type=url],[type=date],[type=datetime-local],[type=month],[type=time],[type=week]):disabled {
    background-color: var(--disable-background-color);
    color: var(--disable-text-color);
}

input:is([type=text],[type=number],[type=password],[type=email],[type=url],[type=date],[type=datetime-local],[type=month],[type=time],[type=week]):disabled::placeholder {
    color: var(--disable-text-color);
}

input[type=color] {
    height: 32px;
    border: 1px solid var(--border-color);
    border-radius: 2px;
    width: 32px;
    background-color: #FFFFFF;
}

input[type=color]:disabled {
    background-color: var(--disable-background-color);
    color: var(--disable-text-color);
}

input[type=checkbox] {
    width: 16px;
    height: 16px;
    background-color: #FFFFFF;
    appearance: none;
    border: 1px solid var(--border-color);
    border-radius: 2px;
}

input[type=checkbox]:checked {
    background-color: var(--color-primary);
    border: none;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='m6 10 3 3 6-6'/%3e%3c/svg%3e");
    background-size: contain;
    background-position: center center;
    background-repeat: no-repeat;
}

input[type=checkbox]:disabled {
    background-color: var(--disable-background-color);
    border: 1px solid var(--border-color);
}

input[type=checkbox]:disabled:checked {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23a8abb2' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='m6 10 3 3 6-6'/%3e%3c/svg%3e");
}

input[type=radio] {
    width: 16px;
    height: 16px;
    background-color: #FFFFFF;
    appearance: none;
    border: 1px solid var(--border-color);
    border-radius: 50%;
}

input[type=radio]:checked {
    background-color: #409eff;
    border: none;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='2' fill='%23fff'/%3e%3c/svg%3e");
    background-size: contain;
    background-position: center center;
    background-repeat: no-repeat;
}

input[type=radio]:disabled {
    background-color: var(--disable-background-color);
    border: 1px solid var(--border-color);
}

input[type=radio]:disabled:checked {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='2' fill='%23a8abb2'/%3e%3c/svg%3e");
}

input::placeholder {
    color: var(--placeholder-color);
}

textarea {
    box-sizing: border-box;
    padding: 8px 12px;
    border-radius: 4px;
    background-color: #FFFFFF;
    border: 1px solid var(--border-color);
}

textarea::placeholder {
    color: var(--placeholder-color);
}

textarea:disabled {
    background-color: var(--disable-background-color);
    color: var(--disable-text-color);
}

textarea:disabled::placeholder {
    color: var(--disable-text-color);
}

.tox-tinymce {
    border: 1px solid var(--border-color) !important;
    border-radius: 4px !important;
}

table {
    width: 100%;
    border-collapse: collapse;
    border-spacing: 0;
    border: 1px solid #EBEEF5;
    table-layout: fixed;
    overflow: hidden;
    font-size: 14px;
}

tr {
    border-bottom: 1px solid #EBEEF5;
    transition: all 0.2s;
}

tr:hover {
    background-color: #f5f7fa;
}

th {
    background: #f6f6f6;
    font-weight: bolder;
    text-align: left;
    padding: 10px;
    color: #666;
}

td {
    padding: 10px;
    color: #333;
}

/* 分页 */
.pagination {
    display: inline-block;
    padding-left: 0;
    margin: 0;
}

.pagination > li {
    display: inline-block;
    margin: 0 2px;
}

.pagination > li > a,
.pagination > li > span {
    position: relative;
    float: left;
    padding: 4px 12px;
    margin-left: -1px;
    line-height: 24px;
    color: var(--color);
    text-decoration: none;
    background-color: var(--pagination-button-background-color);
    border-radius: 2px;
}

.pagination > li > a:hover,
.pagination > li > span:hover,
.pagination > li > a:focus,
.pagination > li > span:focus {
    z-index: 2;
    color: var(--color-primary);
}

.pagination > .active > a,
.pagination > .active > span,
.pagination > .active > a:hover,
.pagination > .active > span:hover,
.pagination > .active > a:focus,
.pagination > .active > span:focus {
    z-index: 3;
    color: #ffffff;
    cursor: default;
    background-color: var(--color-primary);
}

.pagination > .disabled > span,
.pagination > .disabled > span:hover,
.pagination > .disabled > span:focus,
.pagination > .disabled > a,
.pagination > .disabled > a:hover,
.pagination > .disabled > a:focus {
    color: var(--color-info);
    pointer-events: none;
    background-color: var(--disable-background-color);
}