/* +----------------------------------------------------------------------
/* | Custom Blue Theme — Enterprise-grade UI Overrides
/* | Applied after console.css — safe from composer updates
/* +---------------------------------------------------------------------- */

/* ===== 1. Global Font & Base ===== */
body {
    font-family: -apple-system, BlinkMacSystemFont, "PingFang SC", "Helvetica Neue",
                 "Microsoft YaHei", "Source Han Sans SC", "Noto Sans CJK SC",
                 "WenQuanYi Micro Hei", sans-serif;
    font-size: 13px;
    color: #333;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* ===== 2. White Theme — Sidebar ===== */
.layui-layout-theme-white > .layui-layout-admin > .layui-side {
    border-right: 1px solid #eee;
    box-shadow: none !important;
    background-color: #fbfcfe !important;
}
.layui-layout-theme-white > .layui-layout-admin > .layui-side .layui-logo {
    border-bottom: 1px solid #eee;
    font-size: 15px;
    font-weight: 600;
    letter-spacing: 1px;
    color: #1a1a1a;
    background: #fbfcfe !important;
}
.layui-layout-theme-white > .layui-layout-admin > .layui-side .layui-logo .headtxt sup {
    color: #bbb;
    font-size: 10px;
    font-weight: 400;
}

/* Sidebar menu items */
.layui-layout > .layui-side .layui-side-scroll .layui-nav-item a {
    font-size: 13px;
    height: 44px;
    line-height: 44px;
    transition: all .15s ease;
    padding-left: 20px !important;
}
/* Category group header — the top level non-leaf items */
.layui-layout-theme-white > .layui-layout-admin > .layui-side .layui-side-scroll .layui-side-tree .layui-nav-item > a {
    color: #666 !important;
    font-size: 13px;
    font-weight: 500;
}
/* Expand arrow */
.layui-layout-theme-white > .layui-layout-admin > .layui-side .layui-side-scroll .layui-nav-item .layui-nav-more {
    color: #ccc;
}
/* Sub-menu items */
.layui-layout-theme-white > .layui-layout-admin > .layui-side .layui-side-scroll .layui-side-tree .layui-nav-item dd > a {
    color: #555 !important;
    font-size: 13px;
    padding-left: 32px !important;
}
/* Hover — subtle */
.layui-layout-theme-white > .layui-layout-admin > .layui-side .layui-side-scroll .layui-side-tree .layui-nav-item a:hover {
    color: #1890ff !important;
    background-color: transparent !important;
}
/* Active item — left blue bar + light blue bg + blue text */
.layui-layout-theme-white > .layui-layout-admin > .layui-side .layui-side-scroll .layui-side-tree .layui-nav-item .layui-this > a,
.layui-layout-theme-white > .layui-layout-admin > .layui-side .layui-side-scroll .layui-side-tree .layui-nav-item.layui-this > a {
    color: #1890ff !important;
    background: #e6f4ff !important;
    font-weight: 600 !important;
    border-radius: 0;
    margin-right: 0;
    position: relative;
    border-left: 3px solid #1890ff;
    padding-left: 29px !important;
}
/* Override the default dark theme active */
.layui-layout-theme-white > .layui-layout-admin > .layui-side .layui-side-scroll .layui-side-tree .layui-nav-item.layui-this > a {
    border-left: 3px solid #1890ff;
    padding-left: 17px !important;
}
/* Expanded group header */
.layui-layout-theme-white > .layui-layout-admin > .layui-side .layui-side-scroll .layui-side-tree .layui-nav-itemed > a {
    color: #333 !important;
    font-weight: 600 !important;
}

/* Header active tab */
.layui-layout-theme-white > .layui-layout-admin > .layui-header .layui-nav-item.layui-this > a {
    color: #1890ff !important;
    font-weight: 600;
    background: none !important;
}
.layui-layout-theme-white > .layui-layout-admin > .layui-header .layui-nav-item > a:hover {
    color: #1890ff !important;
    background: rgba(24,144,255,.04) !important;
}
.layui-layout-theme-white .help-label b,
.layui-layout-theme-white .layui-tab-title .layui-this {
    color: #1890ff !important;
}

/* ===== 3. Buttons — All blue, danger stays red ===== */
.layui-btn {
    border: none !important;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: .5px;
    background-color: #1890ff;
    transition: all .2s ease;
    box-shadow: 0 2px 4px rgba(24,144,255,.15);
}
.layui-btn:hover:not(.layui-btn-disabled) {
    background-color: #40a9ff;
    box-shadow: 0 4px 8px rgba(24,144,255,.2);
    transform: translateY(-1px);
}
.layui-btn-sm {
    border-radius: 4px;
    font-size: 12px;
}
.layui-btn-primary {
    background: #fff !important;
    color: #666 !important;
    border: 1px solid #d9d9d9 !important;
    box-shadow: none;
}
.layui-btn-primary:hover:not(.layui-btn-disabled) {
    color: #1890ff !important;
    border-color: #1890ff !important;
    background: #fff !important;
    box-shadow: none;
    transform: none;
}
.layui-btn-normal {
    background-color: #1890ff;
}
.layui-btn-normal:hover:not(.layui-btn-disabled) {
    background-color: #40a9ff;
}
.layui-btn-danger {
    background-color: #ff4d4f !important;
    box-shadow: 0 2px 4px rgba(255,77,79,.15);
}
.layui-btn-danger:hover:not(.layui-btn-disabled) {
    background-color: #ff7875 !important;
    box-shadow: 0 4px 8px rgba(255,77,79,.2);
}
.layui-btn-warm {
    background-color: #faad14 !important;
    box-shadow: 0 2px 4px rgba(250,173,20,.15);
}
.layui-btn-warm:hover:not(.layui-btn-disabled) {
    background-color: #ffc53d !important;
}
.layui-btn-group {
    border: none !important;
    background-color: #1890ff !important;
    border-radius: 6px;
    overflow: hidden;
}

/* ===== 4. Modal / Layer — Enterprise feel ===== */
.layui-layer {
    border-radius: 12px !important;
    overflow: hidden;
    box-shadow: 0 12px 48px rgba(0,0,0,.12), 0 4px 16px rgba(0,0,0,.08) !important;
}
.layui-layer .layui-layer-title {
    font-size: 15px !important;
    font-weight: 600 !important;
    color: #1a1a1a !important;
    height: 52px !important;
    line-height: 52px !important;
    padding: 0 24px !important;
    border-bottom: 1px solid #f0f0f0 !important;
    background: #fff !important;
    letter-spacing: .5px;
}
.layui-layer .layui-layer-setwin {
    top: 14px !important;
    right: 16px !important;
}
.layui-layer .layui-layer-setwin a {
    width: 28px !important;
    height: 28px !important;
    line-height: 28px !important;
    font-size: 18px !important;
    border-radius: 6px;
    transition: all .15s ease;
}
.layui-layer .layui-layer-setwin a:hover {
    background: #f5f5f5;
}
.layui-layer .layui-layer-content {
    font-size: 13px;
}
/* Form inside modal */
.layui-layer-content .layui-form.layui-card > .layui-card-body {
    padding: 28px 32px 10px !important;
}
/* Modal buttons */
.layui-layer-content .layui-form-item.text-center {
    padding: 16px 0 20px;
}
.layui-layer-content .layui-form-item.text-center .layui-btn {
    min-width: 100px;
    height: 38px;
    line-height: 38px;
    font-size: 14px;
    margin: 0 8px;
}

/* Dialog confirm/alert */
.layui-layer-dialog {
    border-radius: 12px !important;
}
.layui-layer-dialog .layui-layer-content {
    font-size: 14px !important;
    padding: 24px 28px 16px !important;
}
.layui-layer-btn {
    padding: 12px 24px 16px !important;
    text-align: right !important;
}
.layui-layer-btn a {
    border-radius: 6px !important;
    font-size: 13px !important;
    height: 34px !important;
    line-height: 34px !important;
    padding: 0 20px !important;
    min-width: 72px;
    font-weight: 500;
}
.layui-layer-btn .layui-layer-btn0 {
    background: #1890ff !important;
    border-color: #1890ff !important;
}
.layui-layer-btn .layui-layer-btn0:hover {
    background: #40a9ff !important;
}

/* ===== 5. Form Inputs — Refined ===== */
.layui-input, .layui-select, .layui-textarea {
    border-color: #e5e7eb;
    border-radius: 6px;
    font-size: 13px;
    transition: border-color .2s ease, box-shadow .2s ease;
}
.layui-input:focus, .layui-select:focus, .layui-textarea:focus {
    border-color: #1890ff !important;
    box-shadow: 0 0 0 2px rgba(24,144,255,.1);
}
.layui-input:hover, .layui-select:hover, .layui-textarea:hover {
    border-color: #c0c4cc;
}
.help-label {
    font-size: 12px;
    color: #999;
}
.help-label b {
    color: #1890ff !important;
    font-size: 13px;
    font-weight: 600;
}

/* ===== 6. Search Bar — Cleaner ===== */
.form-search .layui-form-item {
    border: 1px solid #e5e7eb;
    border-radius: 6px;
    transition: border-color .2s ease;
}
.form-search .layui-form-item:hover {
    border-color: #c0c4cc;
}
.form-search .layui-form-item .layui-form-label {
    border-right: 1px solid #e5e7eb;
    color: #666;
    font-size: 12px;
    font-weight: 500;
    background: #fafafa;
    border-radius: 6px 0 0 6px;
}
.form-search .layui-form-item .layui-input-inline input,
.form-search .layui-form-item .layui-input-inline select {
    font-size: 12px;
}
.form-search .layui-btn {
    border-radius: 6px;
    font-weight: 500;
}

/* ===== 7. Table — Professional ===== */
.layui-table {
    font-size: 13px;
}
.layui-table th {
    background: #fafafa;
    color: #333;
    font-weight: 600;
    font-size: 13px;
}
.layui-table-view .layui-table td,
.layui-table-view .layui-table th {
    font-size: 13px;
}
/* Table row hover */
.layui-table-hover,
.layui-table[lay-even] tr:hover {
    background: #f0f7ff !important;
}
/* Table cell padding */
.layui-table td .layui-table-cell {
    line-height: 28px;
}
/* Table action buttons */
.layui-table .layui-btn.layui-btn-sm {
    height: 28px;
    line-height: 28px;
    padding: 0 12px;
    font-size: 12px;
    border-radius: 4px;
}

/* ===== 8. Breadcrumb Header ===== */
.layui-layout > .layui-body > .think-page-body > .layui-card > .layui-card-header {
    font-size: 14px;
    color: #333;
    font-weight: 500;
    letter-spacing: .5px;
}
.layui-layout > .layui-body > .think-page-body > .layui-card > .layui-card-header .layui-icon {
    color: #999;
}

/* ===== 9. Tab ===== */
.layui-tab-title .layui-this {
    color: #1890ff !important;
    font-weight: 600;
}
.layui-tab-brief > .layui-tab-title .layui-this:after {
    background: #1890ff;
    height: 3px;
    border-radius: 2px;
}
.layui-tab-title li {
    font-size: 14px;
    transition: color .15s ease;
}
.layui-tab > .layui-tab-content {
    padding: 16px;
}

/* ===== 10. Card & Shadow ===== */
.layui-card {
    border-radius: 8px;
}
.layui-layout > .layui-body > .think-page-body > .layui-card > .layui-card-body > div > .layui-tab.layui-tab-card {
    box-shadow: 0 1px 4px rgba(0,0,0,.06);
    border-radius: 8px;
}

/* ===== 11. Pagination — Blue ===== */
.pagination-container ul li a:hover {
    border-color: #1890ff;
    color: #1890ff;
}
.pagination-container ul li.active span {
    border-color: #1890ff;
    background: #1890ff !important;
    border-radius: 4px;
}
.layui-laypage .layui-laypage-curr .layui-laypage-em {
    background-color: #1890ff !important;
    border-radius: 4px !important;
}
.layui-laypage a:hover {
    color: #1890ff;
}
.layui-laypage a, .layui-laypage span {
    border-radius: 4px !important;
}

/* ===== 12. Checkbox/Radio — Blue ===== */
.think-checkbox input[type=checkbox]:checked,
.think-checkbox input[type=radio]:checked,
.think-radio input[type=checkbox]:checked,
.think-radio input[type=radio]:checked {
    border-color: #1890ff;
}
.think-radio input[type=radio]:checked:after {
    background: #1890ff;
}
.think-checkbox input[type=checkbox]:checked:after {
    color: #1890ff;
}

/* ===== 13. Switch — Blue ===== */
.layui-form-onswitch {
    background-color: #1890ff !important;
    border-color: #1890ff !important;
}

/* ===== 14. Nav tree active — Blue (for non-white themes) ===== */
.layui-layout:not(.layui-layout-theme-white) > .layui-side .layui-side-scroll .layui-nav-tree > li.layui-this {
    background: #1890ff;
}
.layui-layout:not(.layui-layout-theme-white) > .layui-side .layui-side-scroll .layui-nav-item dd.layui-this > a {
    background-color: #1890ff;
}

/* ===== 15. Badge — Refined ===== */
.layui-badge {
    border-radius: 4px;
    font-size: 12px;
    padding: 2px 8px;
    font-weight: 500;
}

/* ===== 16. Fieldset — Cleaner ===== */
fieldset {
    border: 1px solid #f0f0f0;
    border-radius: 8px;
    padding: 16px 20px;
}
fieldset legend {
    font-size: 13px;
}

/* ===== 17. Sort button ===== */
.layui-table .list-table-sort-td button {
    background: #1890ff;
    border-radius: 4px;
}

/* ===== 18. Form select dropdown ===== */
.layui-form-select dl {
    border-radius: 6px;
    box-shadow: 0 6px 20px rgba(0,0,0,.1) !important;
    border: 1px solid #e5e7eb;
}
.layui-form-select dl dd.layui-this {
    background: #f0f7ff;
    color: #1890ff;
}

/* ===== 19. Scrollbar ===== */
::-webkit-scrollbar {
    width: 6px !important;
    height: 6px !important;
}
::-webkit-scrollbar-track {
    background: transparent !important;
}
::-webkit-scrollbar-thumb {
    background-color: rgba(0,0,0,.15) !important;
    border-radius: 3px !important;
}
::-webkit-scrollbar-thumb:hover {
    background-color: rgba(0,0,0,.25) !important;
}

/* ===== 20. Tooltip / Tips ===== */
.layui-table-tips .layui-table-tips-main {
    border-radius: 8px;
}

/* ===== 21. Notify ===== */
.think-box-notify {
    border-radius: 8px;
    box-shadow: 0 2px 12px rgba(0,0,0,.06);
}

/* ===== 22. Upload image ===== */
.uploadimage {
    border-radius: 6px;
}

/* ===== 23. HR line ===== */
.hr-line-dashed {
    border-top: 1px dashed #e5e7eb;
    margin: 20px 0;
}

/* ===== 24. Breadcrumb header — modern ===== */
.layui-layout > .layui-body > .think-page-body > .layui-card > .layui-card-header .layui-icon {
    display: none;
}

/* ===== 25. Sidebar nav-child (sub-menu) background ===== */
.layui-layout-theme-white > .layui-layout-admin > .layui-side .layui-nav-child {
    background: transparent !important;
}

/* ===== 26. Header bottom border ===== */
.layui-layout > .layui-header {
    border-bottom: 1px solid #f0f0f0;
    box-shadow: none !important;
}

/* ===== 27. Header top nav — blue underline for active ===== */
.layui-layout-theme-white > .layui-layout-admin > .layui-header .layui-nav-item.layui-this > a::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 24px;
    height: 3px;
    background: #1890ff;
    border-radius: 2px;
}
.layui-layout-theme-white > .layui-layout-admin > .layui-header .layui-nav-item > a {
    position: relative;
}

/* ===== 28. Content area — top shadow bar soften ===== */
.layui-layout > .layui-body > .think-page-body > .layui-card > .layui-card-line {
    box-shadow: 0 1px 3px rgba(0,0,0,.04) !important;
}

