@font-face{font-family:'MiSans';src:url('/uploads/fonts/MiSans-Regular.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'MiSans';src:url('/uploads/fonts/MiSans-Medium.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'MiSans';src:url('/uploads/fonts/MiSans-Bold.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'MiSans',-apple-system,'PingFang SC','Microsoft YaHei',sans-serif;background:#F3EDF7;color:#1C1B1F;font-size:15px}
.hidden{display:none!important}

#loginPage{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#1C1B1F,#1C1B1F);display:flex;align-items:center;justify-content:center;z-index:1000}
.login-box{background:#fff;border-radius:24px;padding:40px;width:380px;max-width:90%;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.login-box h1{text-align:center;font-size:24px;margin-bottom:4px}
.login-box h1 span{color:#6750A4}
.login-box .sub{text-align:center;color:#79747E;font-size:15px;margin-bottom:28px}
.login-box .field{margin-bottom:16px}
.login-box .field label{display:block;font-size:15px;color:#49454F;margin-bottom:6px}
.login-box .field input{width:100%;padding:12px 16px;background:#E7E0EC;border:none;border-bottom:2px solid #79747E;border-radius:24px 12px 0 0;font-size:18px}
.login-box .field input:focus{border-bottom-color:#6750A4;outline:none}
.login-err{color:#BA1A1A;font-size:15px;margin-bottom:12px;display:none}
.login-box .btn{font-size:14px;width:100%;padding:12px;background:linear-gradient(135deg,#6750A4,#7B6AAF);color:#fff;border:none;border-radius:9999px;font-size:16px;cursor:pointer;transition:all 0.3s cubic-bezier(0.2,0,0,1)}
.login-box .btn:active{transform:scale(0.95)}
.login-box .btn:disabled{opacity:.5}

#mainContent{display:flex;height:100vh}

.sidebar{width:200px;background:#1C1B1F;color:#CAC4D0;display:flex;flex-direction:column;flex-shrink:0}
.sidebar .logo{padding:16px 12px;text-align:center;border-bottom:1px solid #49454F;display:flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap}
.sidebar .logo h1{font-size:18px;color:#fff;display:flex;align-items:center;gap:8px;margin:0;white-space:nowrap;flex-wrap:nowrap}
.sidebar .logo h1 .logo-icon{display:inline-flex;align-items:center;flex-shrink:0}
.sidebar .logo h1 .logo-icon img{height:26px;width:auto;display:block}
.sidebar .logo h1 span{color:#fff;white-space:nowrap}
.sidebar .logo h1 span[style*="6750A4"]{color:#6750A4}
.sidebar nav{flex:1;padding:12px 0;overflow-y:auto}
.sidebar nav a{font-size:15px;display:flex;align-items:center;gap:10px;padding:12px 24px;color:#aaa;text-decoration:none;font-size:14px;transition:all .2s;cursor:pointer}
.sidebar nav a:hover{color:#fff;background:rgba(255,255,255,.05)}
.sidebar nav a.active{color:#6750A4;background:rgba(103,80,164,.1);border-right:3px solid #6750A4}
.sidebar nav a .icon{width:20px;text-align:center;font-size:16px}
.sidebar .sidebar-footer{font-size:13px;padding:16px 24px;border-top:1px solid #49454F;font-size:12px;color:#79747E}

.main{flex:1;display:flex;flex-direction:column;overflow:hidden}
.topbar{background:#fff;padding:12px 24px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #E7E0EC;box-shadow:0 1px 8px rgba(103,80,164,.06)}
.topbar .breadcrumb{font-size:15px;color:#49454F}
.topbar .breadcrumb b{color:#1C1B1F}
.topbar .user-info{font-size:14px;display:flex;align-items:center;gap:12px;font-size:13px}
.topbar .user-info .role-badge{font-size:12px;background:#6750A4;color:#fff;padding:2px 10px;border-radius:16px;font-size:11px}
.topbar .btn-logout{font-size:13px;background:none;border:1px solid #CAC4D0;color:#49454F;padding:6px 14px;border-radius:9999px;cursor:pointer;font-size:12px}
.topbar .btn-logout:hover{border-color:#BA1A1A;color:#BA1A1A}
.content{flex:1;overflow-y:auto;padding:20px}

.page{display:none}
.page.active{display:block}

.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:20px}
.stat-card{background:#fff;border-radius:24px;padding:16px;box-shadow:0 1px 8px rgba(103,80,164,.06);transition:all 0.3s cubic-bezier(0.2,0,0,1)}
.stat-card:hover{transform:scale(1.02);box-shadow:0 4px 12px rgba(103,80,164,.15)}
.stat-card .label{font-size:14px;color:#79747E;margin-bottom:6px}
.stat-card .num{font-size:28px;font-weight:700}
.stat-card .compare{font-size:13px;margin-top:4px}
.stat-card .compare .up{color:#BA1A1A}
.stat-card .compare .down{color:#386A20}
.stat-card .compare .total{color:#79747E;margin-left:8px}

.shortcuts{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:20px}
.shortcut-btn{font-size:14px;display:flex;align-items:center;gap:8px;padding:12px 20px;background:#fff;border:1px solid #E7E0EC;border-radius:24px;cursor:pointer;font-size:13px;transition:all 0.3s cubic-bezier(0.2,0,0,1)}
.shortcut-btn:hover{border-color:#6750A4;color:#6750A4;box-shadow:0 4px 12px rgba(103,80,164,.15);transform:scale(1.02)}

.chart-box{background:#fff;border-radius:24px;padding:20px;box-shadow:0 1px 8px rgba(103,80,164,.06);margin-bottom:20px}
.chart-box .chart-title{font-size:15px;font-weight:600;margin-bottom:12px;color:#1C1B1F}

.filters{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:16px}
.filters select,.filters input{font-size:14px;padding:8px 12px;background:#E7E0EC;border:none;border-bottom:2px solid #79747E;border-radius:24px 12px 0 0;font-size:13px}
.filters input{min-width:120px}
.filters select:focus,.filters input:focus{border-bottom-color:#6750A4;outline:none}
.btn{padding:8px 16px;border:none;border-radius:9999px;cursor:pointer;font-size:13px;transition:all 0.3s cubic-bezier(0.2,0,0,1)}
.btn:active{transform:scale(0.95)}
.btn-primary{background:#6750A4;color:#fff}
.btn-primary:hover{background:rgba(103,80,164,.9)}
.btn-secondary{background:#E8DEF8;color:#1D192B;border:1px solid #CAC4D0}
.btn-secondary:hover{background:#D0C4E8;color:#1D192B}
.btn-danger{background:#BA1A1A;color:#fff}
.btn-danger:hover{background:#9A1010}
.btn-success{background:#386A20;color:#fff}
.btn-success:hover{background:#2D5518}
.btn-sm{font-size:13px;padding:5px 10px;font-size:12px}
.btn-primary-sm{background:#6750A4;color:#fff;border:1px solid #6750A4;border-radius:9999px;cursor:pointer}
.btn-primary-sm:hover{background:rgba(103,80,164,.9)}
.btn-danger-sm{background:#BA1A1A;color:#fff;border:1px solid #BA1A1A;border-radius:9999px;cursor:pointer}
.btn-danger-sm:hover{background:#9A1010}
.btn-xs{font-size:12px;padding:3px 8px;font-size:11px}

.status-tabs{display:flex;gap:4px;margin-bottom:16px;flex-wrap:wrap}
.status-tab{font-size:14px;padding:8px 16px;border-radius:9999px;cursor:pointer;font-size:13px;background:#E8DEF8;color:#1D192B;border:1px solid #CAC4D0;transition:all 0.3s cubic-bezier(0.2,0,0,1)}
.status-tab:hover{background:#E7E0EC;color:#1C1B1F;border-color:#CAC4D0}
.status-tab.active{background:linear-gradient(135deg,#6750A4,#7B6AAF);color:#fff;border-color:#6750A4;box-shadow:0 2px 6px rgba(103,80,164,.3)}
.status-tab .count{font-size:12px;opacity:.8;margin-left:4px}

/* 会员管理 Tab 按钮（与 status-tab 风格一致，单独命名以避免冲突） */
.member-tab{font-size:14px;padding:8px 18px;border-radius:9999px;cursor:pointer;font-size:13px;background:#E8DEF8;color:#1D192B;border:1px solid #CAC4D0;transition:all 0.3s cubic-bezier(0.2,0,0,1)}
.member-tab:hover{background:#E7E0EC;color:#1C1B1F;border-color:#CAC4D0}
.member-tab.active{background:linear-gradient(135deg,#6750A4,#7B6AAF);color:#fff;border-color:#6750A4;box-shadow:0 2px 6px rgba(103,80,164,.3)}

.table-wrap{background:#fff;border-radius:24px;overflow-x:auto;box-shadow:0 1px 8px rgba(103,80,164,.06)}
table{width:100%;border-collapse:collapse;font-size:14px;table-layout:auto}
th{background:#FFFBFE;color:#49454F;font-weight:500;padding:12px;text-align:left;white-space:nowrap;border-bottom:1px solid #E7E0EC}
td{padding:12px;border-bottom:1px solid #F3EDF7;vertical-align:middle}
tr:hover td{background:#F3EDF7}
/* 商品管理表格图片：100px × 100px，列宽 120px
   使用 !important 防止被其他规则覆盖
   关联文件：style.css（.pm-img-item）、products.js（内联 style） */
.table-wrap table.products-table img,
.table-wrap table img{max-width:100px;max-height:100px;width:100px !important;height:100px !important;object-fit:cover;display:inline-block;flex-shrink:0}
.table-wrap table.products-table td:first-child,
.table-wrap table td:first-child{width:120px !important;min-width:120px;max-width:120px;padding:8px}
.status-badge{font-size:12px;display:inline-block;padding:3px 8px;border-radius:12px;font-size:11px;font-weight:500}
.status-pending{background:#FFFBFE;color:#7D5260}
.status-paid{background:#E8DEF8;color:#0061A4}
.status-shipped{background:#E0F7FA;color:#0061A4}
.status-completed{background:#E8F5E9;color:#386A20}
.status-cancelled{background:#FDE8E8;color:#BA1A1A}
.status-on{background:#E8F5E9;color:#386A20}
.status-off{background:#FDE8E8;color:#BA1A1A}

.modal-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.4);z-index:100;align-items:center;justify-content:center}
.modal-overlay.show{display:flex}
.modal{background:#fff;border-radius:24px;padding:24px;width:90%;max-width:600px;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.modal h3{font-size:18px;margin-bottom:16px;font-size:17px;color:#1C1B1F}
.modal .form-row{margin-bottom:12px}
.modal .form-row label{display:block;font-size:12px;color:#49454F;margin-bottom:4px}
.modal .form-row input,.modal .form-row select,.modal .form-row textarea{width:100%;padding:10px 12px;background:#E7E0EC;border:none;border-bottom:2px solid #79747E;border-radius:24px 12px 0 0;font-size:13px}
.modal .form-row input:focus,.modal .form-row select:focus,.modal .form-row textarea:focus{border-bottom-color:#6750A4;outline:none}
.modal .form-row textarea{min-height:80px;resize:vertical}
.modal .form-row-inline{display:flex;gap:12px}
.modal .form-row-inline .form-row{flex:1}
.modal-actions{display:flex;gap:8px;margin-top:16px;justify-content:flex-end}

.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:12px;margin-bottom:16px}
.image-item{position:relative;border-radius:12px;overflow:hidden;border:2px solid transparent;cursor:pointer;transition:all .2s;aspect-ratio:1;background:#F3EDF7}
.image-item:hover{border-color:#6750A4;transform:translateY(-2px)}
.image-item.selected{border-color:#6750A4;box-shadow:0 0 0 3px rgba(103,80,164,.3)}
.image-item img{width:100%;height:100%;object-fit:cover}
.image-item .del-btn{width:26px;height:26px;font-size:14px;position:absolute;top:4px;right:4px;background:rgba(186,26,26,.8);color:#fff;border:none;border-radius:50%;width:22px;height:22px;font-size:12px;cursor:pointer;display:none}
.image-item:hover .del-btn{display:block}
.image-item .img-name{font-size:12px;position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.6);color:#fff;font-size:10px;padding:4px 6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.pagination{display:flex;align-items:center;justify-content:center;gap:6px;padding:16px;flex-wrap:wrap}
.pg-btn{padding:6px 12px;border:1px solid #CAC4D0;background:#fff;color:#49454F;border-radius:8px;cursor:pointer;font-size:12px;transition:all .2s}
.pg-btn:hover:not(:disabled){background:#E8DEF8;border-color:#6750A4;color:#6750A4}
.pg-btn:disabled{opacity:.4;cursor:not-allowed}
.pg-num{padding:6px 10px;border:1px solid #CAC4D0;background:#fff;color:#49454F;border-radius:8px;cursor:pointer;font-size:12px;min-width:32px;transition:all .2s}
.pg-num:hover{background:#E8DEF8;border-color:#6750A4;color:#6750A4}
.pg-num.pg-active{background:#6750A4;color:#fff;border-color:#6750A4}
.pg-info{font-size:12px;color:#79747E;margin:0 4px}
.pg-jump{font-size:12px;color:#79747E;display:flex;align-items:center;gap:4px;margin-left:8px}
.pg-input{width:48px;padding:4px 6px;border:1px solid #CAC4D0;border-radius:8px;font-size:12px;text-align:center;outline:none}
.pg-input:focus{border-color:#6750A4}

/* 商品编辑器图片：100px × 100px
   关联文件：products.js（renderProductImages） */
.pm-img-item{position:relative;width:100px !important;height:100px !important;min-width:100px;min-height:100px;max-width:100px;max-height:100px;border-radius:10px;overflow:hidden;border:2px solid #E7E0EC;cursor:pointer;transition:all .2s;flex-shrink:0;background:#F3EDF7}
.pm-img-item:hover{border-color:#6750A4}
.pm-img-item.main{border-color:#6750A4;box-shadow:0 0 0 2px rgba(103,80,164,.3)}
.pm-img-item .main-badge{position:absolute;top:1px;left:1px;background:#6750A4;color:#fff;font-size:11px;padding:2px 5px;border-radius:3px;line-height:16px}
.pm-img-item .del-img{position:absolute;top:1px;right:1px;background:rgba(186,26,26,.8);color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:12px;cursor:pointer;display:none;line-height:20px;text-align:center;padding:0}
.pm-img-item:hover .del-img{display:block}
.pm-img-item img{width:100px !important;height:100px !important;min-width:100px;min-height:100px;max-width:100px;max-height:100px;object-fit:cover;display:block}
.img-rename-input{font-size:12px;width:100%;border:1px solid #6750A4;border-radius:4px;padding:2px 4px;font-size:10px;outline:none;box-sizing:border-box}
.img-rename-input:focus{border-color:#5B4A94}
.img-rename-ok{position:absolute;bottom:2px;right:2px;background:#6750A4;color:#fff;border:none;border-radius:3px;font-size:9px;padding:1px 5px;cursor:pointer}
.img-edit-btn{width:26px;height:26px;font-size:13px;position:absolute;top:4px;left:4px;background:rgba(0,97,164,.85);color:#fff;border:none;border-radius:50%;width:22px;height:22px;font-size:11px;cursor:pointer;display:none;align-items:center;justify-content:center}
.image-item:hover .img-edit-btn{width:26px;height:26px;font-size:13px;display:flex}

.img-preview-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.85);z-index:9999;display:flex;align-items:center;justify-content:center;cursor:zoom-out}
.img-preview-overlay img{max-width:90%;max-height:90%;object-fit:contain;border-radius:12px;box-shadow:0 4px 30px rgba(0,0,0,.5)}
.img-preview-overlay .preview-close{position:absolute;top:20px;right:20px;color:#fff;font-size:28px;cursor:pointer;background:rgba(255,255,255,.15);border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center}
.img-preview-overlay .preview-info{position:absolute;bottom:30px;color:rgba(255,255,255,.7);font-size:13px}
.pm-img-item.dragging{opacity:.4;border-color:#6750A4}
.drag-over{border:2px dashed #6750A4 !important;background:rgba(103,80,164,.05)}
.toast{position:fixed;top:16px;right:16px;background:#1C1B1F;color:#fff;padding:12px 20px;border-radius:24px;font-size:13px;display:none;z-index:999;box-shadow:0 4px 12px rgba(0,0,0,.2)}
.toast.show{display:block;animation:slideIn .3s}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}

.empty{text-align:center;padding:60px 20px;color:#79747E}
.empty .empty-icon{font-size:48px;margin-bottom:12px}
.empty .empty-text{font-size:14px}

.loading{text-align:center;padding:40px;color:#79747E}
.loading::after{content:'';display:inline-block;width:20px;height:20px;border:2px solid #CAC4D0;border-top-color:#6750A4;border-radius:50%;animation:spin .6s linear infinite;margin-left:8px;vertical-align:middle}
@keyframes spin{to{transform:rotate(360deg)}}

th.sortable{cursor:pointer;user-select:none;position:relative;padding-right:24px}
th.sortable:hover{background:#F3EDF7}
th.sortable::after{content:'⇅';position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:11px;color:#CAC4D0}
th.sortable.asc::after{content:'↑';color:#6750A4}
th.sortable.desc::after{content:'↓';color:#6750A4}

.chart-detail-tooltip{position:absolute;background:#1C1B1F;color:#fff;padding:10px 14px;border-radius:24px;font-size:13px;pointer-events:none;z-index:50;box-shadow:0 4px 16px rgba(0,0,0,.25);white-space:nowrap;transform:translate(-50%,-110%);opacity:0;transition:opacity .15s}
.chart-detail-tooltip::after{content:'';position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid #1C1B1F}
.chart-detail-tooltip.show{opacity:1}
.chart-box{position:relative}

.sidebar-toggle{display:none;position:fixed;top:10px;left:10px;z-index:200;width:36px;height:36px;background:#1C1B1F;color:#fff;border:none;border-radius:24px;font-size:18px;cursor:pointer;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(0,0,0,.2)}
.sidebar-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.4);z-index:149}

@media(max-width:768px){
  .sidebar{width:60px}
  .sidebar .logo h1,.sidebar nav a span,.sidebar .sidebar-footer{display:none}
  .sidebar nav a{justify-content:center;padding:14px}
  .sidebar nav a .icon{margin:0}
  .stats{grid-template-columns:1fr 1fr}
  /* 平板：商品图片 100px → 80px */
  .table-wrap table img{width:80px !important;height:80px !important;max-width:80px;max-height:80px;min-width:80px;min-height:80px}
  .table-wrap table td:first-child{width:100px !important;min-width:100px;max-width:100px}
  .pm-img-item{width:80px !important;height:80px !important;max-width:80px;max-height:80px;min-width:80px;min-height:80px}
  .pm-img-item img{width:80px !important;height:80px !important;max-width:80px;max-height:80px;min-width:80px;min-height:80px}
}

@media(max-width:480px){
  .sidebar-toggle{display:flex}
  .sidebar-overlay.show{display:block}
  .sidebar{position:fixed;top:0;left:-240px;height:100%;width:220px;z-index:150;transition:left .3s}
  .sidebar .logo h1,.sidebar nav a span,.sidebar .sidebar-footer{display:block}
  .sidebar nav a{justify-content:flex-start;padding:12px 24px}
  .sidebar.open{left:0}
  .main{margin-top:0}
  .topbar{padding:10px 12px}
  .topbar .breadcrumb{font-size:13px}
  .topbar .user-info{gap:6px}
  .topbar .btn-logout{padding:4px 8px;font-size:11px}
  .content{padding:12px}
  .stats{grid-template-columns:1fr}
  .stat-card{padding:12px}
  .stat-card .num{font-size:22px}
  .shortcuts{gap:8px}
  .shortcut-btn{padding:10px 14px;font-size:12px}
  .filters{gap:6px}
  .filters select,.filters input{font-size:12px;padding:6px 8px}
  .filters .btn{font-size:12px;padding:6px 10px}
  .status-tabs{gap:3px}
  .status-tab{padding:6px 10px;font-size:12px}
  .table-wrap{margin:0 -12px;border-radius:0}
  table{font-size:12px}
  th,td{padding:8px 6px}
  .chart-box{padding:12px;margin-bottom:12px}
  .chart-box .chart-title{font-size:13px}
  .modal{padding:16px;max-width:95%}
  .modal h3{font-size:15px}
  /* 手机：商品图片 80px → 60px */
  .table-wrap table img{width:60px !important;height:60px !important;max-width:60px;max-height:60px;min-width:60px;min-height:60px}
  .table-wrap table td:first-child{width:76px !important;min-width:76px;max-width:76px}
  .pm-img-item{width:60px !important;height:60px !important;max-width:60px;max-height:60px;min-width:60px;min-height:60px}
  .pm-img-item img{width:60px !important;height:60px !important;max-width:60px;max-height:60px;min-width:60px;min-height:60px}
  .modal .form-row input,.modal .form-row select,.modal .form-row textarea{padding:8px 10px;font-size:13px}
  .pagination{padding:10px;gap:6px}
  .image-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}
  .page .chart-box ~ .chart-box{margin-top:0}
}
