/* style.css — Table refined rows & fixed visuals */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; background:linear-gradient(135deg,#0b0f14,#0a0c10);
  font-family:-apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", Roboto, "Helvetica Neue", Arial, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Noto Sans", sans-serif;
  color:#e9edf1;
}

/* 顶部导航 */
.navbar{position:sticky;top:0;z-index:20;backdrop-filter:blur(10px);
  background:rgba(13,17,23,.6); border-bottom:1px solid rgba(255,215,0,.15)}
.navbar .inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;}
.brand{display:flex;align-items:center;font-weight:800;letter-spacing:.4px;color:#ffd76a;text-shadow:0 0 14px rgba(212,175,55,.22)}
.logo{width:32px;height:32px;margin-right:10px;border-radius:10px;overflow:hidden;display:flex;align-items:center;justify-content:center;background:transparent}
.nav-actions{display:flex;align-items:center}
.nav-actions .btn{margin-left:10px;text-decoration:none}

/* 通用按钮/徽章 */
.btn{cursor:pointer;display:inline-flex;align-items:center;justify-content:center;height:36px;line-height:1;padding:0 12px;border-radius:10px;border:1px solid rgba(212,175,55,.45);
  background:linear-gradient(180deg,rgba(212,175,55,.2),rgba(212,175,55,.08));color:#ffd76a;
  transition:.2s;font-weight:700;text-decoration:none;box-sizing:border-box;font-size:14px;
  -webkit-appearance:none;appearance:none;-moz-appearance:none}
.btn:hover{transform:translateY(-1px);box-shadow:0 8px 18px rgba(212,175,55,.2)}
.btn.ghost{background:transparent}
.badge.gold{display:inline-block;padding:4px 10px;border-radius:999px;background:rgba(212,175,55,.18);
  border:1px solid rgba(212,175,55,.45);color:#ffd76a;font-size:12px}

/* 容器 */
.container{max-width:1200px;margin:24px auto;padding:0 16px}
.section-title{display:flex;align-items:center;justify-content:space-between;margin:10px 0 16px;min-height:44px}
.section-title h2{margin:0;font-size:20px;font-weight:800;color:#ffe08a}
#dateHost{min-height:36px;display:flex;align-items:center}

/* 日期条 */
.datebar{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.datebar .picker{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);padding:6px 10px;border-radius:10px}
.datebar label{font-size:12px;opacity:.85}
.datebar input[type=date], .datebar .date{font-family:-apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", Roboto, "Helvetica Neue", Arial, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Noto Sans", sans-serif;
  background:transparent;border:1px solid rgba(255,255,255,.18);
  color:#e9edf1;padding:6px 10px;border-radius:8px;outline:none}
.datebar .quick{display:flex;align-items:center;gap:8px}
.qbtn{cursor:pointer;padding:6px 10px;border-radius:999px;border:1px solid rgba(212,175,55,.35);
  color:#f9d777;background:rgba(212,175,55,.08);transition:.2s;text-decoration:none}
.qbtn:hover{background:rgba(212,175,55,.15)}
.qbtn.active{background:rgba(212,175,55,.25);border-color:rgba(212,175,55,.55)}
/* 强制移除日期条中任何伪元素分隔符（例如 “/”）*/
.datebar .quick .qbtn::after,
.datebar .quick .qbtn::before,
.datebar .picker > *::after,
.datebar .picker > *::before{ content:'' !important; }
/* 移除最右侧可能残留的分隔符 */
.datebar::after, .datebar::before{ content:'' !important; display:none !important; }

/* KPI 卡片 */
.grid.cards{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:18px}
@media (max-width:1100px){.grid.cards{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.grid.cards{grid-template-columns:1fr}}
.card{
  position:relative; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12);
  border-radius:16px; padding:14px 16px; box-shadow:0 10px 35px rgba(0,0,0,.25);
  backdrop-filter:blur(12px);
}
.kpi .title{font-size:13px;opacity:.9;margin-bottom:6px}
.kpi .value{font-size:28px;font-weight:900;color:#ffe08a;text-shadow:0 0 18px rgba(255,215,0,.25)}
.kpi .hint{margin-top:6px;font-size:12px;color:#aeb7c2;min-height:16px;line-height:16px}

/* 表格（高端实线行，悬浮高亮） */
.table{width:100%;border-collapse:collapse}
.table thead th{font-size:12px;color:#aeb7c2;font-weight:700;text-align:left;padding:12px;border-bottom:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.03)}
.table tbody td{padding:14px 12px;border-bottom:1px solid rgba(255,255,255,.08)}
.table tbody tr:hover{background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.03))}
.expand-btn{cursor:pointer;font-weight:800;color:#ffd76a;text-align:center;width:40px}
.subrow.indent-1 td:first-child{padding-left:12px}
.subrow.indent-2 td:first-child{padding-left:24px}
.small{font-size:12px;color:#aeb7c2}

/* 提示 */
.toast-wrap{position:fixed;right:18px;top:18px;z-index:99;display:flex;flex-direction:column;gap:10px}
.toast{padding:10px 12px;border-radius:10px;background:rgba(30,40,55,.9);border:1px solid rgba(255,255,255,.12);
  box-shadow:0 8px 16px rgba(0,0,0,.25)}
.toast.ok{border-color:rgba(56,193,114,.6);color:#aef1c2}
.toast.err{border-color:rgba(244,67,54,.6);color:#ffc1c1}

/* 登录页 */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.login-card{
  width:100%;max-width:420px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  border-radius:16px;padding:20px;box-shadow:0 10px 35px rgba(0,0,0,.25);backdrop-filter:blur(12px);
}
.login-brand{display:flex;align-items:center;gap:10px;margin-bottom:12px;color:#ffd76a;font-weight:900;font-size:20px;text-shadow:0 0 14px rgba(212,175,55,.22)}
.login-logo{width:36px;height:36px;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center}
.login-card input{width:100%;padding:12px;border-radius:10px;border:1px solid rgba(255,255,255,.18);background:transparent;color:#e9edf1;margin:6px 0;outline:none}
.login-card .btn{width:100%;margin-top:8px}

/* 弹窗 */
#modal .modal-mask{position:fixed;left:0;top:0;right:0;bottom:0;background:rgba(0,0,0,.45)}
#modal .modal-panel{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(12px);
  border-radius:16px;padding:16px;min-width:420px}
#modal .form input{width:100%;padding:10px;border-radius:8px;border:1px solid rgba(255,255,255,.18);background:transparent;color:#e9edf1;margin:6px 0}


/* === 增强：分部总览表头圆角 & 层级缩进 === */
.table thead tr th:first-child{ border-top-left-radius:12px; }
.table thead tr th:last-child{ border-top-right-radius:12px; }
.table.inner{ margin-left:18px; border-color: rgba(255,255,255,.06); }
.table.inner th{ background:rgba(255,255,255,.06) }
.table.inner .exp2{ transform: translateX(8px); }

/* 展开层级视觉区分 */
.subrow > td{ background:rgba(255,255,255,.02); }
.holder td{ background:rgba(255,255,255,.02); }

/* Modal 遮罩点击不关闭，维持原有遮罩外观 */
.modal .modal-mask{ cursor: default; }

/* LOGO 统一为金色 AB，颜色固定不再随机 */
.logo{
  background: radial-gradient(60% 60% at 50% 50%, rgba(231,196,105,.15), rgba(231,196,105,.03));
  border:1px solid rgba(231,196,105,.45);
}
.logo::after{
  content:'AB';
  font-weight:900;
  font-size:14px;
  color:#ffd76a;
  letter-spacing:1px;
}

/* 全局 Loading 叠层 */
#loading-mask{position:fixed;left:0;top:0;right:0;bottom:0;display:none;align-items:center;justify-content:center;z-index:200;
  background:rgba(8,10,14,.45);backdrop-filter:blur(6px)}
.loading-panel{display:flex;flex-direction:column;align-items:center;gap:10px;padding:14px 16px;border-radius:14px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);box-shadow:0 10px 35px rgba(0,0,0,.25)}
.loading-text{color:#ffd76a;font-weight:800;letter-spacing:.3px}
.loading-spinner{width:26px;height:26px;border-radius:50%;border:3px solid rgba(255,215,0,.25);border-top-color:#ffd76a;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* 修复表格内加载图标显示不完整 & 无动画的问题 */
.loading-spinner{ display:inline-block; box-sizing:border-box; will-change:transform; vertical-align:middle; }
.subtable .loading-spinner{ width:18px; height:18px; border-width:2px; }
.subtable-loading td{ line-height:1.2; overflow:visible; }
