/* ════════════════════════════════════════
   ERP v2 — 工具类 & 模块特定样式
   ════════════════════════════════════════ */

/* ── 工具类 ── */
.hide{display:none}
.clickable{cursor:pointer}
.flex{display:flex}
.flex-wrap{flex-wrap:wrap}
.flex-between{display:flex;justify-content:space-between}
.flex-align{display:flex;align-items:center}
.flex-gap{gap:10px}
.mb-0{margin-bottom:0}
.mt-15{margin-top:15px}
.w-40{width:40px}.w-60{width:60px}.w-80{width:80px}.w-100{width:100px}.w-120{width:120px}.w-140{width:140px}
.p-20{padding:20px}
.tc{text-align:center}
.c-muted{color:var(--muted)}
.c-primary{color:var(--primary)}
.c-green{color:var(--green)}
.c-red{color:var(--red)}
.c-blue{color:var(--blue)}
.c-orange{color:var(--orange)}
.c-dark{color:var(--text)}
.text-red{color:var(--red);font-weight:600}
.text-green{color:var(--green);font-weight:600}

/* ── 表格单元格工具 ── */
.cell-num{text-align:right;font-variant-numeric:tabular-nums;font-weight:500}
.cell-action{text-align:center;white-space:nowrap}
.cell-center{text-align:center}
.cell-money{color:var(--red);font-weight:600}

/* ── 空状态 ── */
.empty-state{text-align:center;padding:50px 20px;color:var(--muted);font-size:var(--font-lg)}
.empty-state-box{text-align:center;padding:50px 20px;color:var(--muted)}
.empty-state-box .empty-icon{font-size:48px;display:block;margin-bottom:12px;opacity:.5}
.empty-state-box .empty-text{color:var(--text-secondary);margin-top:8px;font-size:var(--font-base)}
.empty-td{text-align:center;padding:30px 20px;color:var(--muted);font-size:var(--font-base)}

/* ── 信息行 ── */
.info-row{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--border-light);font-size:var(--font-base)}
.info-row:last-child{border-bottom:none}
.info-label{color:var(--muted);min-width:70px;flex-shrink:0;font-size:var(--font-sm)}
.info-value{font-weight:500;color:var(--text)}

/* ── 统计摘要 ── */
.stat-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:18px}
.stat-summary .sum-item{background:var(--card);padding:14px 16px;border-radius:var(--radius);border:1px solid var(--border);text-align:center;box-shadow:var(--shadow)}
.stat-summary .sum-item .sum-val{font-size:22px;font-weight:700;color:var(--text);letter-spacing:-.5px}
.stat-summary .sum-item .sum-label{font-size:var(--font-sm);color:var(--text-secondary);margin-top:4px}

/* ── 输入组 ── */
.input-group{display:flex;gap:8px;align-items:center}
.input-group .form-input{flex:1}
.input-sm{width:80px}

/* ── 帮助文本 ── */
.help-text{font-size:11px;color:var(--muted);margin-top:6px}

/* ── 弹窗Animation ── */
@keyframes fadeIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
@keyframes modalIn{from{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}

/* ── 全站水印 ── */
.watermark-overlay{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:9998;overflow:hidden;user-select:none}
.watermark-overlay .wm-item{position:absolute;color:rgba(0,0,0,.025);font-size:14px;font-weight:600;white-space:nowrap;user-select:none;pointer-events:none;font-family:'Microsoft YaHei','PingFang SC',sans-serif;letter-spacing:2px}

/* ── 全局搜索 ── */
.global-search-wrap{position:relative;min-width:200px}
.global-search-input{width:200px;padding:5px 10px 5px 28px;border:none;border-radius:20px;background:rgba(255,255,255,.15);color:rgba(255,255,255,.9);font-size:12px;transition:var(--transition);outline:none}
.global-search-input::placeholder{color:rgba(255,255,255,.5)}
.global-search-input:focus{width:260px;background:rgba(255,255,255,.25);color:#fff}
.global-search-icon{position:absolute;left:8px;top:50%;transform:translateY(-50%);font-size:12px;color:rgba(255,255,255,.5);pointer-events:none}
.global-search-results{position:absolute;top:100%;right:0;width:320px;max-height:360px;overflow-y:auto;background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:999;display:none;margin-top:6px;border:1px solid var(--border)}
.global-search-results.active{display:block}
.gsr-item{display:flex;align-items:center;gap:8px;padding:10px 14px;cursor:pointer;transition:var(--transition);border-bottom:1px solid var(--border-light);font-size:var(--font-base)}
.gsr-item:last-child{border-bottom:none}
.gsr-item:hover{background:var(--primary-light)}
.gsr-item .gsr-icon{font-size:16px;width:24px;text-align:center}
.gsr-item .gsr-title{font-weight:500;color:var(--text)}
.gsr-item .gsr-desc{font-size:11px;color:var(--muted)}
.gsr-empty{padding:20px;text-align:center;color:var(--muted);font-size:var(--font-sm)}

/* ── 仪表盘预警区 ── */
.alert-section{border:2px solid #fde8e8;background:#fef2f2;border-radius:var(--radius);padding:16px 20px;margin-bottom:20px}
.alert-section h3{font-size:15px;font-weight:700;color:var(--red);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.alert-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}
.alert-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--card);border-radius:var(--radius);border:1px solid var(--border);cursor:pointer;transition:var(--transition)}
.alert-item:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.alert-item .alert-icon{font-size:20px;flex-shrink:0}
.alert-item .alert-body{flex:1}
.alert-item .alert-title{font-size:var(--font-base);font-weight:600;color:var(--text)}
.alert-item .alert-desc{font-size:11px;color:var(--muted);margin-top:2px}
.alert-item .alert-badge{background:var(--red);color:#fff;font-size:11px;padding:1px 8px;border-radius:10px;font-weight:600}
.alert-none{padding:20px;text-align:center;color:var(--green);font-size:var(--font-base);font-weight:500}

/* ── 项目详情页 ── */
.detail-container{display:flex;gap:0;align-items:stretch;min-height:500px;background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.detail-sidebar{width:170px;min-width:170px;background:#f7f8fa;padding:8px 0;border-right:1px solid var(--border);display:flex;flex-direction:column}
.detail-sidebar-item{display:flex;align-items:center;gap:8px;padding:10px 18px;font-size:var(--font-base);color:var(--text-secondary);cursor:pointer;border-left:3px solid transparent;transition:all .2s;white-space:nowrap;margin:1px 0}
.detail-sidebar-item:hover{background:var(--primary-light);color:var(--primary)}
.detail-sidebar-item.active{background:var(--primary-light);color:var(--primary);border-left-color:var(--sidebar-active);font-weight:600}
.detail-main{flex:1;padding:22px 26px;overflow:auto;min-height:500px}
.detail-main h4{font-size:16px;font-weight:700;color:var(--text);margin-bottom:18px;padding-bottom:10px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}
.detail-main h5{font-size:var(--font-lg);font-weight:600;color:var(--text-secondary);margin-bottom:12px}
.detail-main .detail-section{background:var(--card);border-radius:var(--radius);padding:20px 22px;margin-bottom:18px;border:1px solid var(--border);transition:var(--transition);box-shadow:var(--shadow)}
.detail-main .detail-section:hover{box-shadow:var(--shadow-md)}
.detail-main .header-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:10px}
.detail-main .header-bar .project-title{font-size:15px;font-weight:700;color:var(--text)}
.detail-main .stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:18px}
.detail-main .stat-card{background:var(--card);padding:16px 18px;border-radius:var(--radius);border:1px solid var(--border);text-align:center;transition:var(--transition)}
.detail-main .info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.detail-main .info-grid .info-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border-light)}
.detail-main .info-grid .info-label{font-size:var(--font-sm);color:var(--muted);min-width:80px;flex-shrink:0}
.detail-main .info-grid .info-value{font-size:var(--font-base);font-weight:600;color:var(--text)}
.detail-main .back-link{display:inline-flex;align-items:center;gap:4px;color:var(--primary);text-decoration:none;font-size:12.5px;margin-bottom:16px}
.detail-main .back-link:hover{text-decoration:underline}

/* ── 分类标签 ── */
.cat-tags{display:flex;flex-wrap:wrap;gap:8px}
.cat-item{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;background:var(--card);border:1px solid var(--border);border-radius:20px;cursor:pointer;font-size:var(--font-sm);transition:all .2s}
.cat-item:hover{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}

/* ── 图表 ── */
.chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.chart-box{height:210px}
.chart-tall{height:230px}
.chart-bars{display:flex;align-items:flex-end;height:180px;padding:0 12px;gap:4px}
.chart-bar-col{display:flex;flex-direction:column;align-items:center;flex:1}
.chart-bar-val{font-size:10px;color:var(--text-secondary);margin-bottom:3px}
.chart-bar-fill{width:100%;border-radius:3px 3px 0 0;min-height:4px;transition:height .5s cubic-bezier(.4,0,.2,1)}
.chart-bar-label{font-size:10px;color:var(--muted);margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:70px;text-align:center}
.pie-grid{display:flex;flex-wrap:wrap;gap:8px;padding:12px}
.pie-item{display:flex;align-items:center;gap:8px;font-size:var(--font-sm);width:45%}
.pie-dot{display:inline-block;width:12px;height:12px;border-radius:3px}
.pie-label{color:var(--text-secondary);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pie-pct{font-weight:600;color:var(--text)}

/* ── 定价模块 ── */
.search-input{flex:1;padding:9px 14px;border:1px solid var(--border);border-radius:var(--radius);font-size:var(--font-base);transition:border-color .2s,box-shadow .2s}
.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}
.bar-chart-sm{display:flex;align-items:flex-end;gap:12px;height:130px;padding:0 8px}
.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;cursor:pointer}
.bar-val{font-size:10px;color:var(--text-secondary);margin-bottom:4px;font-weight:600}
.bar-fill-sm{width:100%;border-radius:4px 4px 0 0;transition:height .5s cubic-bezier(.4,0,.2,1)}
.bar-label{font-size:10px;color:var(--muted);margin-top:4px}

/* ── 系统设置 ── */
.company-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.menu-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border-light)}
.menu-cb{width:18px;height:18px;cursor:pointer;accent-color:var(--primary)}
.appr-card{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;padding:8px 0}

/* ── 成本卡片 ── */
.cost-summary{display:flex;gap:16px;flex-wrap:wrap;margin-top:12px}
.cost-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:16px 20px;min-width:140px;flex:1}
.cost-card .cost-label{font-size:12px;color:#666;margin-bottom:4px}
.cost-card .cost-value{font-size:20px;font-weight:700;color:#333}

/* ── 打印样式 ── */
@media print {
  .sidebar, .topbar, .topbar-right, .watermark-overlay, .tab-header{display:none!important}
  .right-wrap{margin-left:0!important;width:100%!important}
  .main{padding:0!important}
  body{background:#fff!important}
}

/* ── 移动端适配 ── */
@media (max-width: 768px) {
  .sidebar{width:160px!important}
  .right-wrap{margin-left:160px!important;width:calc(100% - 160px)!important}
  .sidebar-brand{padding:14px 12px!important}
  .sidebar-brand .logo{font-size:14px!important}
  .nav-item{padding:10px 12px!important;font-size:var(--font-base)!important;min-height:40px!important}
  .nav-icon{font-size:14px!important;width:18px!important}
  .nav-text{font-size:var(--font-sm)!important}
  .sidebar-footer{padding:8px 12px!important;font-size:11px!important}
  .sidebar-version{font-size:9px!important}
  .topbar{height:36px!important;padding:0 4px!important}
  .topbar-icon{font-size:16px!important}
  .tab-item{padding:0 8px!important;font-size:11px!important}
  .main{padding:12px!important}
  .stats{grid-template-columns:repeat(2,1fr)!important;gap:10px!important}
  .status-blocks{grid-template-columns:repeat(2,1fr)!important;gap:8px!important}
  .finance-grid{grid-template-columns:1fr!important}
  .quick-grid{grid-template-columns:repeat(3,1fr)!important;gap:8px!important}
  .card-grid,.company-grid,.cat-grid{grid-template-columns:1fr!important}
  .chart-grid{grid-template-columns:1fr!important}
  .detail-container{flex-direction:column!important}
  .detail-sidebar{width:100%!important;min-width:auto!important;display:flex!important;overflow-x:auto!important}
  .detail-main{padding:12px!important;min-height:auto!important}
  .data-table{font-size:11px!important}
  .data-table thead th,.data-table tbody td{padding:6px 8px!important}
  .form-row>div{min-width:100%!important}
  .modal-box{width:92%!important;max-width:92%!important;padding:16px!important}
  .login-box{width:90%!important;padding:28px 24px!important}
  .stat-card .value{font-size:20px!important}
  .tmpl-grid{grid-template-columns:1fr!important}
  .filter-bar{flex-direction:column!important;align-items:stretch!important}
  .filter-bar>*{width:100%!important}
  .finance-row{flex-direction:column!important}
  .info-grid{grid-template-columns:1fr!important}
}
