*{margin:0;padding:0;box-sizing:border-box;}
@font-face {
  font-family: 'HarmonyOS Sans SC';
  src: local('HarmonyOS Sans SC'), local('HarmonyOS Sans');
  font-weight: 100 900;
}
:root{
  --font:'HarmonyOS Sans SC','Noto Sans SC',-apple-system,'PingFang SC','Microsoft YaHei',sans-serif;
  --text:#111827;--text2:#6b7280;--text3:#9ca3af;
  --border:#e5e7eb;--bg:#f0f1f8;--white:#f4f5fc;
  --blue:#3b82f6;--blue-l:#eff6ff;
  --sidebar:220px;
  --topbar:130px;    /* ← 修改这里调整顶栏高度 */
  --filterbar:58px; /* ← 修改这里调整筛选栏高度 */
  --max-w:1720px;   /* ← 修改这里调整整体最大宽度 */
}
html,body{height:100%;overflow:hidden;font-family:var(--font);background:#1a1a2e;}body{padding:36px;box-sizing:border-box;background:#1a1a2e url('/bg/beijngtu1.jfif?v=5') no-repeat center center;background-size:cover;}
/* ===== 专注模式：低饱和深灰蓝背景，阅读优先 ===== */
html:not(.theme-soft):not(.theme-dark){
  --text:#1f2937;
  --text2:#4b5563;
  --text3:#6b7280;
  --border:#d8dee6;
  --bg:rgba(255,255,255,0.94);
  --white:rgba(255,255,255,0.96);
  --blue:#334155;
  --blue-l:rgba(226,232,240,0.72);
}
html.auth-has-session:not(.theme-soft):not(.theme-dark) body{
  background:#eef2f7 url('/bg/beijngtu1.jfif?v=5') no-repeat center center;
  background-size:cover;
}
html:not(.theme-soft):not(.theme-dark) .app-wrap{
  background:rgba(255,255,255,0.95);
  border:1px solid var(--border);
  box-shadow:0 22px 56px rgba(11,21,35,0.22);
  z-index:1;
}
html:not(.theme-soft):not(.theme-dark) .sidebar,
html:not(.theme-soft):not(.theme-dark) .topbar,
html:not(.theme-soft):not(.theme-dark) .filterbar,
html:not(.theme-soft):not(.theme-dark) .table-area,
html:not(.theme-soft):not(.theme-dark) .table-area > .inner,
html:not(.theme-soft):not(.theme-dark) .sb-bottom{
  background:rgba(255,255,255,0.93) !important;
  border-color:var(--border) !important;
  box-shadow:none;
}
html:not(.theme-soft):not(.theme-dark) .nav-item:hover,
html:not(.theme-soft):not(.theme-dark) .nav-item.active,
html:not(.theme-soft):not(.theme-dark) .sb-user:hover,
html:not(.theme-soft):not(.theme-dark) .t-icon:hover,
html:not(.theme-soft):not(.theme-dark) .f-reset:hover{
  background:rgba(0,0,0,0.13) !important;
}
html:not(.theme-soft):not(.theme-dark) .t-icon,
html:not(.theme-soft):not(.theme-dark) .f-sel,
html:not(.theme-soft):not(.theme-dark) .f-reset,
html:not(.theme-soft):not(.theme-dark) #search-pool{
  background:rgba(255,255,255,0.96);
  border-color:var(--border);
}
html:not(.theme-soft):not(.theme-dark) .app-wrap input:not(.login-box input):not(.register-box input),
html:not(.theme-soft):not(.theme-dark) .app-wrap select:not(.fo-stage-pill-select),
html:not(.theme-soft):not(.theme-dark) .app-wrap textarea{
  background:rgba(255,255,255,0.96);
  border-color:var(--border);
}
html:not(.theme-soft):not(.theme-dark) .app-wrap table,
html:not(.theme-soft):not(.theme-dark) .app-wrap th,
html:not(.theme-soft):not(.theme-dark) .app-wrap td{
  border-color:#e5e7eb !important;
  color:#111827 !important;
}
html:not(.theme-soft):not(.theme-dark) #order-table thead th,
html:not(.theme-soft):not(.theme-dark) #followup-list-tbl thead th,
html:not(.theme-soft):not(.theme-dark) #sample-table thead th,
html:not(.theme-soft):not(.theme-dark) #fo-table thead th,
html:not(.theme-soft):not(.theme-dark) thead th{
  background:#fafafa !important;
  color:#111827 !important;
  border-bottom-color:#e5e7eb !important;
}
html:not(.theme-soft):not(.theme-dark) #order-table tbody tr,
html:not(.theme-soft):not(.theme-dark) #sample-table tbody tr,
html:not(.theme-soft):not(.theme-dark) #followup-list-tbl tbody tr,
html:not(.theme-soft):not(.theme-dark) #fo-table tbody tr,
html:not(.theme-soft):not(.theme-dark) tbody tr{
  border-bottom-color:#e5e7eb !important;
}
html:not(.theme-soft):not(.theme-dark) #order-table tbody tr:hover,
html:not(.theme-soft):not(.theme-dark) #sample-table tbody tr:hover,
html:not(.theme-soft):not(.theme-dark) #followup-list-tbl tbody tr:hover,
html:not(.theme-soft):not(.theme-dark) #fo-table tbody tr:hover,
html:not(.theme-soft):not(.theme-dark) #tbl-shares tbody tr:hover,
html:not(.theme-soft):not(.theme-dark) tbody tr:hover{
  background:#e5e7eb !important;
}

/* 电话重复闪烁动画 */
@keyframes phone-dup-blink {
  0%,100% { background:transparent; }
  50% { background:#fef2f2; }
}
.phone-dup {
  animation: phone-dup-blink 1.5s ease-in-out infinite;
  color: #dc2626 !important;
  font-weight: 600 !important;
  cursor: help;
  position: relative;
}
.phone-dup-badge {
  display:inline-flex;align-items:center;gap:3px;
  font-size:10px;color:#dc2626;font-weight:600;
  background:#fef2f2;border:1px solid #fecaca;border-radius:4px;
  padding:1px 5px;margin-left:4px;white-space:nowrap;
  vertical-align:middle;
}

/* 整体居中包裹 */
.app-wrap{
  max-width:var(--max-w);
  margin:0 auto;
  height:calc(100vh - 72px);
  position:relative;
  background:var(--white);
  box-shadow:0 4px 32px rgba(0,0,0,0.10);
  border-radius:20px;
  overflow:hidden;
  border-left:none;
  border-right:none;
}

/* 侧边栏 — 相对于 app-wrap 定位 */
.sidebar{
  position:absolute;left:0;top:0;bottom:0;width:var(--sidebar);
  background:var(--white);border-right:1px solid var(--border);
  display:flex;flex-direction:column;z-index:10;
  user-select:none;-webkit-user-select:none;
}
.sb-logo{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:0 16px;height:var(--topbar);border-bottom:1px solid var(--border);flex-shrink:0;}
.sb-logo-icon{width:32px;height:32px;border-radius:8px;background:#111827;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.sb-logo-icon img{width:100%;height:100%;object-fit:contain;display:block;transform:scale(1.22);filter:drop-shadow(0 20px 38px rgba(124,58,237,0.18));}
.sb-logo-icon svg{width:18px;height:18px;}
.sb-logo-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;}
.sb-logo-fallback svg{width:18px;height:18px;}
.sb-logo-name{font-size:14px;font-weight:700;color:var(--text);}
.app-version-badge{
  display:inline-flex;
  align-items:center;
  height:16px;
  padding:0 6px;
  border-radius:999px;
  background:#f3f4f6;
  color:#6b7280;
  font-size:10px;
  font-weight:700;
  letter-spacing:0;
  white-space:nowrap;
}
.sb-div{height:1px;background:var(--border);}
.sb-nav{padding:8px 10px;flex:1;overflow-y:auto;}
.nav-section{font-size:11px;font-weight:700;color:#9ca3af;letter-spacing:0.08em;text-transform:uppercase;padding:14px 12px 6px;}
.nav-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:9999px;font-size:15px;font-weight:400;color:var(--text);cursor:pointer;transition:all .15s;margin-bottom:2px;user-select:none;-webkit-user-select:none;}
.nav-item:hover{background:rgba(0,0,0,0.13);}
.nav-item.active{background:rgba(0,0,0,0.13);font-weight:700;}
.nav-item.is-disabled{
  opacity:.45;
  cursor:not-allowed;
  pointer-events:none;
}
.nav-item.is-disabled:hover{
  background:transparent;
}
.nav-icon{width:18px;height:18px;flex-shrink:0;display:flex;align-items:center;justify-content:center;}
.nav-icon svg{width:16px;height:16px;}
.nav-badge{margin-left:auto;background:var(--text3);color:white;font-size:11px;font-weight:600;padding:1px 7px;border-radius:10px;}
.sb-div2{height:1px;background:var(--border);margin:6px 0;}
.mode-toggle{
  display:flex;
  padding:0;
  margin:6px 0 0;
}
.mode-toggle__btn{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:10px;
  font-size:15px;
  font-weight:400;
  padding:8px 12px;
  border-radius:9999px;
  border:1px solid var(--border);
  background:transparent;
  color:var(--text);
  cursor:pointer;
  transition:all 0.15s ease;
  user-select:none;
  outline:none;
  font-family:inherit;
  white-space:nowrap;
}
.mode-toggle__btn:hover{
  background:rgba(0,0,0,0.06);
}
.mode-toggle__btn.active{
  background:transparent;
  border-color:var(--border);
  color:var(--text);
}
.mode-toggle__btn:active{
  background:rgba(0,0,0,0.13);
}
.mode-toggle__btn svg{
  width:16px;
  height:16px;
  flex-shrink:0;
}
.mode-toggle__hint{
  margin-left:auto;
  font-size:10px;
  color:#9ca3af;
  font-weight:500;
  letter-spacing:0;
}
.mode-toggle__btn:hover .mode-toggle__hint{
  color:#6b7280;
}
.ocean-nav-badge{display:none;margin-left:auto;min-width:18px;height:18px;padding:0 6px;border-radius:999px;background:#16a34a;color:#fff;font-size:11px;font-weight:800;line-height:1;align-items:center;justify-content:center;box-shadow:0 4px 10px rgba(22,163,74,.22);}
.ocean-refresh-notice{display:none;align-items:center;height:26px;padding:0 10px;border:1px solid #bbf7d0;border-radius:999px;background:#f0fdf4;color:#15803d;font-size:12px;font-weight:800;line-height:1;white-space:nowrap;cursor:pointer;font-family:var(--font);transition:all .15s;}
.ocean-refresh-notice:hover{background:#dcfce7;border-color:#86efac;color:#166534;}
.academy-nav-badge{display:none;margin-left:auto;color:#16a34a;font-size:12px;font-weight:800;line-height:1;white-space:nowrap;}
.product-demand-nav-badge{display:none;margin-left:auto;color:#16a34a;font-size:12px;font-weight:800;line-height:1;white-space:nowrap;}
.shares-nav-item{gap:8px;}
.shares-nav-label{flex-shrink:0;white-space:nowrap;}
.shares-nav-badges{min-width:0;max-width:96px;margin-left:auto;align-items:center;justify-content:flex-end;gap:4px;flex-wrap:wrap;line-height:1;}
.shares-nav-status-badge{display:none;flex-shrink:0;align-items:center;justify-content:center;gap:1px;min-height:18px;padding:0 6px;border-radius:999px;color:#fff;font-size:11px;font-weight:800;line-height:1;white-space:nowrap;}
.shares-nav-status-badge-approved,.shares-nav-status-badge-good-feedback{background:#16a34a;box-shadow:0 4px 10px rgba(22,163,74,.22);}
.shares-nav-status-badge-offline{background:#d97706;box-shadow:0 4px 10px rgba(217,119,6,.20);}
.shares-nav-status-badge-rejected,.shares-nav-status-badge-bad-feedback{background:#dc2626;box-shadow:0 4px 10px rgba(220,38,38,.20);}
.shares-nav-badge-num{display:inline-block;min-width:7px;text-align:center;animation:sharesNoticeBlink 1.15s ease-in-out infinite;transform-origin:center;}
@keyframes sharesNoticeBlink{
  0%,100%{opacity:1;transform:scale(1);}
  50%{opacity:.35;transform:scale(1.14);}
}
.product-demand-notice-modal{display:none;position:fixed;inset:0;z-index:9999;background:rgba(17,24,39,.38);align-items:center;justify-content:center;padding:20px;}
.product-demand-notice-modal.show{display:flex;}
.product-demand-panel{width:min(900px,96vw);max-height:86vh;background:#fff;border-radius:14px;box-shadow:0 24px 70px rgba(15,23,42,.22);display:flex;flex-direction:column;overflow:hidden;}
.product-demand-head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 22px;border-bottom:1px solid #e5e7eb;background:#fff;}
.product-demand-kicker{font-size:12px;font-weight:800;color:#16a34a;margin-bottom:2px;}
.product-demand-title{font-size:20px;font-weight:900;color:#111827;line-height:1.25;}
.product-demand-close{width:34px;height:34px;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#6b7280;font-size:22px;line-height:1;cursor:pointer;}
.product-demand-close:hover{background:#f8fafc;color:#111827;}
.product-demand-body{padding:18px 22px 22px;overflow:auto;}
.product-demand-empty{padding:42px 20px;text-align:center;color:#9ca3af;font-size:14px;}
.product-demand-table-wrap{overflow:auto;border:1px solid #e5e7eb;border-radius:10px;}
.product-demand-table{width:100%;min-width:900px;border-collapse:collapse;table-layout:fixed;}
.product-demand-table th{position:static;height:40px;padding:0 10px;background:#f8fafc;border-bottom:1px solid #e5e7eb;color:#374151;font-size:13px;font-weight:800;text-align:left;white-space:nowrap;}
.product-demand-table td{height:auto;padding:12px 10px;border-bottom:1px solid #eef2f7;color:#111827;font-size:13px;line-height:1.6;text-align:left;white-space:normal;word-break:break-word;overflow:visible;}
.product-demand-table tr:last-child td{border-bottom:none;}
.theme-dark .product-demand-panel,
.theme-dark .product-demand-head{background:#0f172a;border-color:#243041;}
.theme-dark .product-demand-title,
.theme-dark .product-demand-table td{color:#e5eefc;}
.theme-dark .product-demand-table-wrap,
.theme-dark .product-demand-close{border-color:#334155;}
.theme-dark .product-demand-close,
.theme-dark .product-demand-table th{background:#111827;color:#cbd5e1;}
.sb-bottom{padding:10px;border-top:1px solid var(--border);}
.sb-user{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;cursor:pointer;}
.sb-user:hover{background:var(--bg);}
.sb-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#7c3aed,#6d28d9);box-shadow:0 4px 14px rgba(124,58,237,0.35);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:white;flex-shrink:0;}
.sb-uname{font-size:11.5px;font-weight:300;color:var(--text);line-height:1.4;}
.sb-uemail{font-size:11px;color:var(--text3);}
.sb-chev{margin-left:auto;color:var(--text3);}

/* 侧边栏底部用户卡片 */
.sb-card-row{display:flex;align-items:center;gap:10px;padding:8px 12px 4px;}
.sb-av-ring{
  width:40px;height:40px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,#7c3aed,#6d28d9);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 3px 12px rgba(124,58,237,0.30);
}
.sb-av-inner{font-size:17px;font-weight:700;color:#fff;line-height:1;}
.sb-info{flex:1;min-width:0;}
.sb-info-name{font-size:12px;font-weight:500;color:#374151;line-height:1.4;white-space:normal;word-break:break-all;}
.sb-info-anon{font-size:11px;color:#374151;font-weight:500;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sb-rank-bar-wrap{padding:6px 12px 10px;}
.sb-rank-labels{font-size:11px;font-weight:600;color:#374151;margin-bottom:4px;text-align:center;}
.sb-rank-track{height:6px;background:#eeecf5;border-radius:3px;overflow:hidden;}
.sb-rank-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,#7c3aed,#a78bfa);transition:width .6s ease;}

/* 顶栏 - 第一行 */
/* 内容居中容器 */
.inner{
  max-width: var(--max-w);
  margin: 0 auto;
  width: 100%;
  display: flex;
  align-items: center;
  height: 100%;
  gap: inherit;
  padding: inherit;
}
.topbar{
  position:absolute;left:var(--sidebar);right:0;top:0;height:var(--topbar);
  background:var(--white);border-bottom:1px solid var(--border);
  display:flex;align-items:center;
  padding:0;
  z-index:9;
}
.topbar .inner{ padding:0 48px; gap:16px; }
.topbar-demand-visual{
  display:none;position:absolute;left:50%;top:calc(50% + 20px);transform:translate(-50%,-50%);
  width:min(720px,53vw);height:auto;object-fit:contain;pointer-events:none;z-index:1;
}
html[data-current-page="demand"] .topbar-demand-visual,
html.auth-has-session[data-boot-page="demand"] .topbar-demand-visual{display:block;}
html[data-current-page="demand"] .topbar,
html.auth-has-session[data-boot-page="demand"] .topbar{height:260px;border-bottom:0 !important;background:#f4f5fc;overflow:hidden;}
.topbar-title{font-size:26px;font-weight:700;color:var(--text);}
.topbar-actions{margin-left:auto;display:flex;align-items:center;gap:8px;position:relative;z-index:2;}
.t-icon{width:44px;height:44px;border-radius:8px;border:1px solid var(--border);background:var(--white);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text2);}
.t-icon:hover{background:var(--bg);}
.t-icon svg{width:18px;height:18px;}
.t-pri{display:flex;align-items:center;gap:6px;padding:12px 28px;border-radius:8px;color:white;border:none;font-size:14px;font-weight:600;cursor:pointer;font-family:var(--font);white-space:nowrap;}
.t-pri:hover{background:#6d28d9;}

/* 筛选栏 */
.filterbar{
  position:absolute;left:var(--sidebar);right:0;top:var(--topbar);height:var(--filterbar);
  background:var(--white);border-bottom:1px solid var(--border);
  display:flex;align-items:center;
  padding:0;
  z-index:9;
}
.filterbar .inner{ padding:0 28px; gap:14px; min-width:0; }
.filterbar-title{display:flex;align-items:center;gap:6px;flex:0 0 auto;min-width:120px;white-space:nowrap;}
.filterbar-controls{margin-left:auto;display:flex;align-items:center;justify-content:flex-end;gap:8px;min-width:0;flex:1 1 auto;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;}
.filterbar-controls::-webkit-scrollbar{display:none;}
.filterbar-title #page-title-sub{font-size:23px;font-weight:700;color:var(--text);white-space:nowrap;}
.filterbar-title #title-count-sub{font-size:16px;font-weight:700;color:#111827;margin-left:6px;white-space:nowrap;flex-shrink:0;}
.filterbar-title #private-tip{display:none;font-size:14px;color:#9ca3af;margin-left:10px;font-weight:400;white-space:nowrap;}
.filterbar-search{flex:0 0 250px;width:250px;min-width:250px;max-width:250px;padding:6px 12px;border:1px solid var(--border);border-radius:7px;font-size:13px;font-family:var(--font);outline:none;color:var(--text);}
.f-sel{flex:0 0 auto;min-width:0;padding:6px 28px 6px 12px;border:1px solid var(--border);border-radius:6px;background:white;font-size:14px;color:var(--text);font-family:var(--font);cursor:pointer;outline:none;height:36px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
#sel-ind{width:160px;max-width:160px;}
#sel-province{width:128px;max-width:128px;}
#sel-source{width:128px;max-width:128px;}
#sel-q{width:136px;max-width:136px;}
#sel-s{width:132px;max-width:132px;}
.f-sel:focus{border-color:var(--blue);}
.f-reset{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;height:36px;border-radius:6px;border:1px solid var(--border);background:white;font-size:14px;font-weight:500;color:var(--text2);cursor:pointer;font-family:var(--font);}
.f-reset:hover{background:var(--bg);}
.f-reset svg{width:14px;height:14px;}
.f-count{margin-left:auto;font-size:12.5px;color:var(--text3);}

/* 表格区域 */
.table-area{
  position:absolute;
  left:var(--sidebar);right:0;
  top:calc(var(--topbar) + var(--filterbar));
  bottom:46px;
  overflow:auto;
  background:var(--white);
}
.table-area > .inner{
  max-width:var(--max-w);
  margin:0 auto;
  min-height:100%;
  padding:0;
  box-sizing:border-box;
}
table{width:100%;border-collapse:collapse;table-layout:fixed;}
col.c-seq{width:55px;}
col.c-co{width:240px;}
col.c-ind{width:128px;}
col.c-contact{width:78px;}
col.c-phone{width:112px;}
col.c-pos{width:74px;}
col.c-q{width:96px;}
col.c-trend{width:96px;}
col.c-op{width:82px;}
col.c-date{width:150px;}
col.c-src{width:76px;}
col.c-add{width:88px;}
thead th{
  padding:0 8px;height:42px;text-align:center;
  font-size:14px;font-weight:600;color:var(--text);
  border-bottom:1px solid var(--border);background:white;
  white-space:nowrap;position:sticky;top:0;z-index:1;
  overflow:hidden;
}
thead th:first-child{padding:0 8px 0 24px;text-align:center;}
thead th:last-child{padding:0 24px 0 8px;}
tbody tr{border-bottom:1px solid var(--border);cursor:pointer;transition:background .08s;}
tbody tr:last-child{border-bottom:none;}
tbody tr:hover{background:#f8faff;}
#tbl-ocean tbody tr:hover,
#tbl-mine tbody tr:hover,
#tbl-ocean tbody tr.table-row-hover-active,
#tbl-mine tbody tr.table-row-hover-active{background:#e5e7eb !important;}
td{padding:0 8px;height:50px;font-size:14px;color:var(--text);white-space:nowrap;text-align:center;overflow:hidden;}
td:first-child{padding:0 8px 0 24px;}
td:last-child{padding:0 24px 0 8px;}
#tbl-ocean td:nth-child(2),
#tbl-mine td:nth-child(2),
#tbl-shares td:nth-child(2){white-space:normal;text-align:left;overflow:visible;}

/* 订单表格 */
#order-table{width:calc(100% - 30px);border-collapse:collapse;table-layout:fixed;}
#order-table thead th{font-size:13px;font-weight:500;color:#000;padding:8px 10px;border-bottom:1px solid #e5e7eb;white-space:nowrap;background:#fafafa;position:sticky;top:58px;z-index:2;height:auto;text-align:left;}
#order-table thead th:first-child{padding-left:24px;text-align:left;}
#order-table thead th:nth-child(2){padding-left:16px;}
#order-table thead th:last-child{padding:8px 10px;}
#order-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background .1s;cursor:default;}
#order-table tbody tr:last-child{border-bottom:none;}
#order-table tbody tr:hover{background:#e5e7eb;}
#order-table td{font-size:13px;color:#374151;padding:11px 10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;height:auto;text-align:left;font-weight:400;}
#order-table td:first-child{padding-left:24px;text-align:left;}
#order-table td:nth-child(2){padding-left:16px;}
#order-table td:last-child{padding:11px 10px;}
#order-table thead th.left{text-align:left;}
#order-table thead th.right{text-align:left;}
#order-table td.right{text-align:left;}
#order-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background .1s;cursor:default;}
#order-table tbody tr:last-child{border-bottom:none;}
#order-table tbody tr:hover{background:#e5e7eb;}
#order-table td{font-size:13px;color:#374151;padding:11px 10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
#order-table td:first-child{padding-left:24px;}
#order-table td:nth-child(2){padding-left:16px;}
#order-table td.left{text-align:left;}
#order-table td.right{text-align:left;}
#followup-list-tbl{width:100%;border-collapse:collapse;table-layout:fixed;}
#followup-list-tbl thead th{font-size:13px;font-weight:700;color:#111827;padding:8px 10px;border-bottom:1px solid #d1d5db;white-space:nowrap;background:white;text-align:left;}
#followup-list-tbl thead th:first-child{padding-left:20px;}
#followup-list-tbl thead th.cur{cursor:pointer;}
#followup-list-tbl tbody tr{border-bottom:1px solid #e5e7eb;transition:background .1s;cursor:default;}
#followup-list-tbl tbody tr:last-child{border-bottom:none;}
#followup-list-tbl tbody tr:hover{background:#e5e7eb;}
#followup-list-tbl td{font-size:13px;color:#374151;padding:11px 10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left;}
#followup-list-tbl td:first-child{padding-left:20px;}
#followup-list-tbl td:nth-child(2){padding-left:10px;}
#sample-table{width:calc(100% - 30px);border-collapse:collapse;table-layout:fixed;}
#sample-table thead th{font-size:13px;font-weight:500;color:#000;padding:8px 10px;border-bottom:1px solid #e5e7eb;white-space:nowrap;background:#fafafa;text-align:left;position:sticky;top:58px;z-index:2;height:auto;}
#sample-table thead th:first-child{padding-left:24px;text-align:left;}
#sample-table thead th:nth-child(2){padding-left:16px;}
#sample-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background .1s;cursor:default;}
#sample-table tbody tr:last-child{border-bottom:none;}
#sample-table tbody tr:hover{background:#e5e7eb;}
#sample-table td{font-size:13px;color:#374151;padding:11px 10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left;height:auto;font-weight:400;}
#sample-table td:first-child{padding-left:24px;text-align:left;}
#sample-table thead th.left{text-align:left;}
#sample-table thead th.right{text-align:left;}
#sample-table td.left{text-align:left;}
#sample-table td.right{text-align:left;}

/* ===== 客户跟进 · v3重设计 ===== */
.fo-header{background:var(--white);border-bottom:1px solid var(--border);padding:0 28px;height:58px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10;}
.fo-title{font-size:23px;font-weight:700;color:#000;}
.fo-view-toggle{display:inline-flex;border:1px solid var(--border);border-radius:8px;overflow:hidden;}
.fo-view-toggle span{padding:7px 20px;font-size:14px;cursor:pointer;color:var(--text2);transition:all .15s;font-family:var(--font);font-weight:600;}
.fo-view-toggle span.active{background:#374151;color:white;}
.fo-btn{padding:7px 14px;font-size:12px;font-weight:600;border:1px solid var(--border);border-radius:6px;background:var(--white);color:var(--text);cursor:pointer;font-family:var(--font);transition:all .15s;}
.fo-btn:hover{background:var(--bg);}
.fo-btn-primary{padding:7px 16px;font-size:12px;font-weight:600;border:none;border-radius:6px;background:var(--text);color:var(--white);cursor:pointer;font-family:var(--font);transition:all .15s;}
.fo-btn-primary:hover{opacity:.85;}
.fo-btn-import-green{padding:8px 18px;border:none;border-radius:10px;background:linear-gradient(135deg,#16a34a,#15803d);color:#fff;font-size:13px;font-weight:700;cursor:pointer;font-family:var(--font);transition:all .15s;box-shadow:0 6px 18px rgba(21,128,61,0.24);}
.fo-btn-import-green:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(21,128,61,0.3);}
#import-layer-2 .mh{background:#fff !important;color:#111827 !important;border-bottom:1px solid #e5e7eb !important;}
#import-layer-2 .mh h2{color:#111827 !important;}
#import-layer-2 .mh p{color:#6b7280 !important;opacity:1 !important;}
#import-layer-2 .mh button{background:#fff !important;border:1px solid #d1d5db !important;color:#374151 !important;box-shadow:none !important;}
#import-layer-2 .mh button:hover{background:#f9fafb !important;box-shadow:0 2px 8px rgba(15,23,42,0.08) !important;}
#import-customer-list > div button{padding:7px 16px !important;background:linear-gradient(135deg,#16a34a,#15803d) !important;color:#fff !important;border:none !important;border-radius:8px !important;font-size:13px !important;font-weight:700 !important;box-shadow:0 4px 14px rgba(21,128,61,0.24) !important;}
#import-customer-list > div button:hover{transform:translateY(-1px) !important;box-shadow:0 8px 20px rgba(21,128,61,0.28) !important;}
.fo-kanban-wrap{background:#f0f1f5;}
.fo-kanban{display:inline-flex;gap:12px;}
.fo-col{width:228px;flex-shrink:0;}
.fo-col-head{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;margin-bottom:8px;border-radius:8px;cursor:pointer;transition:all .15s;user-select:none;position:sticky;top:0;z-index:3;}
.fo-col-head:hover{filter:brightness(0.96);}
.fo-col-head.active-filter{outline:2px solid var(--accent,#4f46e5);outline-offset:-2px;}
.fo-col-title{font-size:14px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:7px;}
.fo-col-dot{width:8px;height:8px;border-radius:50%;}
.fo-col-count{font-size:15px;font-weight:700;color:var(--text);}
.col-bg-初次联系{background:#c7d2fe;}
.col-bg-需求确认{background:#a5f3fc;}
.col-bg-报价中{background:#a7f3d0;}
.col-bg-已寄样{background:#fbcfe8;}
.col-bg-已成交{background:#fef08a;}
.col-bg-已流失{background:#fed7aa;}
.col-bg-初次联系 .fo-col-title{color:#000;}
.col-bg-需求确认 .fo-col-title{color:#000;}
.col-bg-报价中 .fo-col-title{color:#000;}
.col-bg-已寄样 .fo-col-title{color:#000;}
.col-bg-已成交 .fo-col-title{color:#000;}
.col-bg-已流失 .fo-col-title{color:#000;}
.col-bg-初次联系 .fo-col-count{color:#000;}
.col-bg-需求确认 .fo-col-count{color:#000;}
.col-bg-报价中 .fo-col-count{color:#000;}
.col-bg-已寄样 .fo-col-count{color:#000;}
.col-bg-已成交 .fo-col-count{color:#000;}
.col-bg-已流失 .fo-col-count{color:#000;}
.fo-col-body{min-height:calc(100vh - 180px);border-radius:8px;padding:3px;transition:all .12s;}
.fo-card{background:var(--white);border:1px solid var(--border);border-radius:10px;padding:9px 12px;margin-bottom:6px;cursor:grab;transition:all .15s;box-shadow:0 1px 3px rgba(0,0,0,0.04);}
.fo-card:hover{border-color:#c0c0ca;box-shadow:0 3px 10px rgba(0,0,0,0.07);transform:translateY(-1px);}
.fo-card-top{display:flex;align-items:center;justify-content:space-between;gap:6px;}
.fo-card-info{flex:1;min-width:0;}
.fo-card-company{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:3px;}
.fo-card-meta{font-size:11px;color:#9ca3af;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.fo-card-note{font-size:11px;color:var(--text);font-weight:500;margin-top:5px;padding:4px 8px;background:#f8f8fb;border-radius:5px;line-height:1.5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.fo-card-tag{display:inline-flex;align-items:center;font-size:10px;padding:2px 7px;border-radius:4px;font-weight:600;flex-shrink:0;}
.fo-tag-sample{background:#ecfdf5;color:#059669;border:1px solid #a7f3d0;}
.fo-tag-closed{background:#fef3c7;color:#b45309;border:1px solid #fcd34d;}
.fo-card-actions{display:none;margin-top:5px;padding-top:5px;border-top:1px solid #f0f0f3;gap:5px;align-items:center;}
.fo-card:hover .fo-card-actions{display:flex;}
.fo-card-act{padding:4px 10px;font-size:13px;font-weight:500;border:none;background:none;border-radius:8px;color:#111827;cursor:pointer;font-family:var(--font);transition:all .15s;}
.fo-card-act:hover{background:rgba(0,0,0,0.06);}
.fo-record-count{font-size:10px;color:#b0b0ba;}
.fo-joined-date{font-size:10px;color:#9ca3af;white-space:nowrap;}
.fo-col-drop-active{background:rgba(79,70,229,0.05) !important;outline:1.5px dashed #c7d2fe;border-radius:8px;}
.fo-list-wrap{padding:0;background:white;}
.fo-list-filters{display:flex;gap:12px;padding:16px 16px;background:#f0f1f5;border-bottom:1px solid #e5e7eb;}
.fo-list-filter{display:flex;align-items:center;gap:6px;padding:10px 18px;cursor:pointer;transition:all .15s;user-select:none;border-bottom:2px solid transparent;position:relative;}
.fo-list-filter:hover{background:#f3f3f6;}
.fo-list-filter.active-filter{background:white;border-bottom-color:#4f46e5;}
.fo-list-filter-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;}
.fo-list-filter-name{font-size:13px;font-weight:500;color:#6b7280;}
.fo-list-filter.active-filter .fo-list-filter-name{color:var(--text);font-weight:600;}
.fo-list-filter-count{font-size:13px;font-weight:700;color:var(--text);}
#fo-table{width:100%;border-collapse:collapse;table-layout:fixed;}
#fo-table thead th{font-size:13px;font-weight:500;color:#000;padding:8px 10px;border-bottom:1px solid #e5e7eb;white-space:nowrap;background:#fafafa;text-align:left;position:sticky;top:0;z-index:3;height:auto;}
#fo-table thead th:first-child{padding-left:24px;}
#fo-table thead th:nth-child(2){padding-left:16px;}
#fo-table tbody tr{position:relative;border-bottom:1px solid #e5e7eb;transition:background .1s;}
#fo-table tbody tr:last-child{border-bottom:none;}
#fo-table tbody tr:hover{background:#e5e7eb;}
#fo-table td{font-size:13px;color:#374151;padding:11px 10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left;height:auto;font-weight:400;}
#fo-table td:first-child{padding-left:24px;}
#fo-table td:nth-child(2){padding-left:16px;}
#fo-table thead th:nth-child(8),#fo-table thead th:nth-child(9){text-align:right;}
#fo-table tbody td:nth-child(8),#fo-table tbody td:nth-child(9){text-align:right;}
.fo-latest-cell{cursor:pointer;}
.fo-latest-text{display:block;color:#6b7280;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .12s ease;}
.fo-latest-text.is-empty{color:#d1d5db;}
.fo-row-overlay{position:absolute;left:50%;top:calc(100% - 6px);transform:translateX(-50%);display:block;padding:14px 18px;border:1px solid #e5e7eb;border-radius:10px;background:#fff;color:#111827;font-size:13px;line-height:1.85;white-space:normal;word-break:break-word;text-align:left;min-width:420px;min-height:84px;width:max-content;max-width:min(820px,calc(100vw - 80px));max-height:220px;overflow-y:auto;box-shadow:0 10px 24px rgba(15,23,42,0.12);z-index:20;}
.fo-latest-floating{
  position:fixed;
  display:none;
  min-width:420px;
  max-width:min(820px,calc(100vw - 80px));
  max-height:220px;
  overflow-y:auto;
  padding:14px 18px;
  border:1px solid #000;
  border-radius:10px;
  background:#fff;
  color:#111827;
  font-size:13px;
  line-height:1.85;
  white-space:normal;
  word-break:break-word;
  text-align:left;
  box-shadow:none;
  z-index:5000;
  pointer-events:none;
}
.fo-latest-cell.is-active .fo-latest-text{color:#111827;font-weight:500;}
.order-product-summary{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#7c3aed;font-weight:500;cursor:pointer;}
.fo-stage-pill-select{-webkit-appearance:none;appearance:none;font-size:11px;padding:3px 10px;border-radius:10px;font-weight:600;white-space:nowrap;border:none;cursor:pointer;font-family:var(--font);outline:none;transition:none;}
.fo-stage-pill-select:hover{opacity:1;}
.fo-stage-pill-select option{background:white;color:#111827;font-weight:500;}
.fo-tbl-act{padding:4px 10px;border:none;background:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;font-family:var(--font);transition:all .15s;color:#111827;}
.fo-tbl-act:hover{background:rgba(0,0,0,0.06);}
.fo-stage-pill{display:inline-block;font-size:11px;padding:2px 8px;border-radius:10px;font-weight:600;white-space:nowrap;}
.pill-初次联系{background:#c7d2fe;color:#000;}
.pill-需求确认{background:#a5f3fc;color:#000;}
.pill-报价中{background:#a7f3d0;color:#000;}
.pill-已寄样{background:#fbcfe8;color:#000;}
.pill-已成交{background:#fef08a;color:#000;}
.pill-已流失{background:#fed7aa;color:#000;}
.fo-empty{text-align:center;padding:28px 8px;font-size:12px;color:#bbb;}
/* 详情面板 */
.fo-detail-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.35);z-index:999;opacity:0;pointer-events:none;transition:opacity .2s;backdrop-filter:blur(3px);}
.fo-detail-overlay.open{opacity:1;pointer-events:auto;}
.fo-detail-panel{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(0.95);width:900px;max-height:90vh;background:var(--white);z-index:1000;box-shadow:0 24px 60px rgba(0,0,0,0.18);border-radius:20px;opacity:0;pointer-events:none;transition:all .25s cubic-bezier(.34,1.56,.64,1);display:flex;flex-direction:column;overflow:hidden;}
.fo-detail-panel.open{transform:translate(-50%,-50%) scale(1);opacity:1;pointer-events:auto;}
.fo-dp-header{padding:20px 24px 16px;border-bottom:1px solid var(--border);flex-shrink:0;}
.fo-dp-header-bar{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;}
.fo-dp-head-left{display:flex;align-items:flex-start;gap:12px;flex-wrap:wrap;min-width:0;}
.fo-dp-title-wrap{min-width:0;}
.fo-dp-title-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;min-width:0;}
.fo-dp-remove-btn{display:inline-flex;align-items:center;justify-content:center;padding:7px 16px;border:1px solid #111827;background:#fff;border-radius:8px;font-size:13px;font-weight:500;color:#111827;cursor:pointer;font-family:var(--font);white-space:nowrap;transition:all .15s;}
.fo-dp-remove-btn:hover{background:rgba(0,0,0,0.06);}
.fo-dp-close{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;min-width:72px;height:34px;padding:0 16px;border:1.5px solid #111827;background:#fff;border-radius:8px;font-size:13px;font-weight:500;color:#111827;cursor:pointer;font-family:var(--font);transition:all .15s;line-height:1;white-space:nowrap;}
.fo-dp-close:hover{background:#f3f4f6;border-color:#111827;}
.fo-dp-company{font-size:18px;font-weight:700;color:var(--text);margin-bottom:0;line-height:1.4;word-break:break-word;}
.fo-dp-meta{font-size:13px;color:var(--text2);}
.fo-dp-body{flex:1;overflow-y:auto;padding:0;}
.fo-dp-section{padding:12px 24px;border-bottom:1px solid var(--border);}
.fo-dp-section-title{font-size:11px;font-weight:700;color:#9ca3af;letter-spacing:0.06em;margin-bottom:10px;}
.fo-dp-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;font-size:13px;}
.fo-dp-label{color:var(--text2);}
.fo-dp-value{color:var(--text);font-weight:500;}
.fo-dp-actions{display:flex;gap:8px;padding:16px 24px;border-bottom:1px solid var(--border);}
.fo-dp-act{flex:1;padding:8px;font-size:12px;font-weight:600;text-align:center;border:1px solid var(--border);border-radius:6px;background:var(--white);color:var(--text);cursor:pointer;font-family:var(--font);transition:all .12s;}
.fo-dp-act:hover{background:#eef2ff;color:#4f46e5;border-color:#c7d2fe;}
.fo-dp-act-danger{color:#ef4444;border-color:#fecaca;}
.fo-dp-act-danger:hover{background:#fef2f2;color:#dc2626;border-color:#fca5a5;}
.fo-timeline{padding:16px 24px;}
.fo-tl-item{position:relative;padding-left:20px;padding-bottom:16px;border-left:1.5px solid #e8e8ee;margin-left:4px;}
.fo-tl-item:last-child{border-left-color:transparent;padding-bottom:0;}
.fo-tl-dot{position:absolute;left:-4.5px;top:2px;width:7px;height:7px;border-radius:50%;border:2px solid var(--border);background:var(--white);}
.fo-tl-dot-note{border-color:#3b82f6;background:#dbeafe;}
.fo-tl-dot-sample{border-color:#10b981;background:#dcfce7;}
.fo-tl-dot-stage{border-color:#f59e0b;background:#fef3c7;}
.fo-tl-dot-create{border-color:#9ca3af;background:#f3f4f6;}
.fo-tl-time{font-size:13px;color:#374151;margin-bottom:4px;font-weight:500;}
.fo-tl-content{font-size:13px;color:var(--text);line-height:1.6;}
.fo-tl-type{display:inline-block;font-size:11px;font-weight:600;padding:2px 7px;border-radius:4px;margin-right:5px;}
.fo-tl-type-note{background:#dbeafe;color:#1d4ed8;}
.fo-tl-type-sample{background:#dcfce7;color:#15803d;}
.fo-tl-type-stage{background:#fef3c7;color:#92400e;}
.fo-tl-type-create{background:#f3f4f6;color:#6b7280;}
.fo-tl-input-wrap{padding:16px 24px;border-top:1px solid var(--border);flex-shrink:0;background:var(--bg);}
.fo-tl-input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:var(--font);color:var(--text);resize:none;outline:none;background:var(--white);transition:border-color .15s;}
.fo-tl-input:focus{border-color:#4f46e5;}
.fo-tl-submit{margin-top:8px;padding:7px 16px;font-size:12px;font-weight:600;border:none;border-radius:6px;background:var(--text);color:var(--white);cursor:pointer;font-family:var(--font);transition:all .12s;}
.fo-tl-submit:hover{opacity:.85;}

/* 分页栏 */
.pager{
  position:absolute;left:var(--sidebar);right:0;bottom:0;height:46px;
  background:var(--white);border-top:1px solid var(--border);
  display:flex;align-items:center;
  padding:0;font-size:12.5px;color:#000;z-index:9;
}
.page-btns{display:flex;align-items:center;justify-content:flex-end;gap:4px;min-width:0;}
.pg{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:white;font-size:12px;cursor:pointer;font-family:var(--font);display:flex;align-items:center;justify-content:center;color:var(--text2);}
.pg:hover{background:var(--bg);}
.pg.active{background:var(--blue);color:white;border-color:var(--blue);font-weight:600;}
.pg.pg-wide{width:auto;min-width:42px;padding:0 8px;}
.pg.pg-ellipsis{border-color:transparent;background:transparent;cursor:default;color:#9ca3af;}
.pg.pg-ellipsis:hover{background:transparent;}
.page-jump{display:inline-flex;align-items:center;gap:4px;margin-left:8px;color:#6b7280;white-space:nowrap;}
.page-jump-input{width:48px;height:28px;border:1px solid var(--border);border-radius:6px;padding:0 6px;font-size:12px;color:#374151;font-family:var(--font);box-sizing:border-box;}
.page-jump-btn{height:28px;padding:0 8px;border:1px solid var(--border);border-radius:6px;background:#fff;color:#374151;font-size:12px;font-family:var(--font);cursor:pointer;}
.page-jump-btn:hover{background:var(--bg);}
@media (max-width:760px){
  .page-jump{display:none;}
  .pg.pg-wide{min-width:36px;padding:0 6px;}
}

/* cells */
.co-cell{display:flex;align-items:center;gap:8px;margin-right:8px;min-width:0;}
.co-av{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:white;flex-shrink:0;}
.co-name{display:block;min-width:0;font-size:13px;font-weight:500;color:#374151;white-space:normal;line-height:1.35;word-break:break-all;}
.co-meta-line{display:flex;align-items:center;gap:6px;max-width:100%;min-height:14px;margin-top:2px;line-height:1.2;white-space:nowrap;overflow:hidden;}
.co-type-inline{color:#8b93a3;font-size:12px;font-weight:500;white-space:nowrap;}
.customer-contact-update-badge{
  display:inline-block;
  flex:0 0 auto;
  color:#16a34a;
  font-size:11px;
  font-weight:700;
  line-height:1.2;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.customer-offline-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:max-content;
  min-height:18px;
  margin:1px 0 3px;
  padding:1px 7px;
  border-radius:999px;
  background:#fee2e2;
  color:#b91c1c;
  font-size:11px;
  font-weight:700;
  line-height:1.35;
}
.customer-offline-badge-inline{
  min-height:24px;
  margin:0;
  padding:2px 10px;
  font-size:13px;
  font-weight:500;
}
.mine-offline-row td{background:#fff7f7;}
.mine-offline-row:hover td{background:#fff1f1;}
.detail-offline-notice{
  grid-column:1/-1;
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px 10px;
  padding:10px 12px;
  border:1px solid #fecaca;
  border-radius:10px;
  background:#fef2f2;
  color:#991b1b;
  font-size:13px;
  line-height:1.55;
}
.detail-offline-notice strong{font-weight:800;color:#991b1b;}
.detail-offline-notice span{color:#7f1d1d;}
.detail-offline-feedback{
  padding:12px 14px;
  background:#fef2f2;
  border:1.5px solid #fecaca;
  border-radius:10px;
  margin-bottom:10px;
}
.detail-offline-feedback .detail-feedback-title{color:#b91c1c;}
.detail-offline-feedback-reason{
  margin-top:6px;
  font-size:13px;
  line-height:1.65;
  color:#374151;
}
.detail-offline-feedback-reason strong{color:#991b1b;}
.ind-tag{display:inline-block;max-width:100%;padding:2px 0px;font-size:13px;font-weight:500;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;vertical-align:middle;}
.customer-table-pill{display:inline-block;max-width:100%;padding:3px 9px;border-radius:999px;font-size:13px;font-weight:400;line-height:1.25;color:#000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;vertical-align:middle;}
.customer-table-pill-green{background:#22c55e;color:#000;}
.customer-table-text{display:inline-block;max-width:100%;font-size:13px;font-weight:400;color:#000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;vertical-align:middle;}
.pie-cell{display:flex;align-items:center;gap:8px;justify-content:center;}
.act{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;font-size:13px;font-weight:500;cursor:pointer;border:none;border-radius:8px;background:none;font-family:var(--font);white-space:nowrap;color:#374151;transition:background .15s;}
.act:hover{background:rgba(0,0,0,0.13);box-shadow:0 2px 8px rgba(0,0,0,0.15);}
.act-view{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border:none;border-radius:8px;background:none;color:#374151;font-size:13px;font-weight:500;cursor:pointer;font-family:var(--font);white-space:nowrap;transition:background .15s;}
.act-view:hover{background:rgba(0,0,0,0.13);box-shadow:0 2px 8px rgba(0,0,0,0.15);}
.act-view::before{content:'';width:7px;height:7px;border-radius:2px;background:#16a34a;flex-shrink:0;display:inline-block;}
.ocean-btn{border:1px solid #d1d5db !important;background:#fff !important;color:#374151;}
.ocean-btn:hover{background:rgba(0,0,0,0.13);border-color:#cbd5e1;box-shadow:0 2px 8px rgba(0,0,0,0.15);}
.act-plus.ocean-btn{border:1px solid #d1d5db !important;background:#fff !important;color:#374151;}
.act-plus.ocean-btn:hover{background:rgba(0,0,0,0.13) !important;border-color:#cbd5e1 !important;box-shadow:0 2px 8px rgba(0,0,0,0.15) !important;}
.ocean-btn.act-view::before{content:none;display:none;}
#tbl-ocean .ocean-btn,
#tbl-mine .ocean-btn{box-shadow:none !important;}
#tbl-ocean .ocean-btn:hover,
#tbl-mine .ocean-btn:hover{background:rgba(0,0,0,0.13) !important;border-color:#cbd5e1 !important;box-shadow:none !important;}
.act-ok{color:#16a34a;}
.act-ok:hover{opacity:.7;}
.act-err{color:#dc2626;}
.act-err:hover{opacity:.7;}
.act-edit{color:#2563eb;}
.act-edit:hover{opacity:.7;}
.act-plus{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border:none;border-radius:8px;background:none;color:#374151;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s;white-space:nowrap;font-family:var(--font);}
.act-plus:hover{background:rgba(0,0,0,0.13);box-shadow:0 2px 8px rgba(0,0,0,0.15);}
.act-plus svg{display:none;}
.act-plus.line-btn{border:1px solid #d1d5db;background:#fff;}
.act-plus.line-btn:hover{border-color:#cbd5e1;}

/* 弹窗 */
.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;align-items:center;justify-content:center;}
.overlay.show{display:flex;}
.detail-modal-panel{background:white;border-radius:20px;width:900px;max-width:96vw;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 24px 60px rgba(0,0,0,0.18);}
.detail-header{padding:14px 24px 10px;border-bottom:1px solid #e5e7eb;flex-shrink:0;}
.detail-header-top{display:flex;align-items:flex-start;gap:16px;}
.detail-header-top>.detail-head-btn{margin-left:auto;flex:0 0 auto;}
.detail-title{font-size:18px;font-weight:700;color:#111827;line-height:1.4;word-break:break-word;flex:1 1 auto;min-width:0;}
.detail-title-private{flex:0 1 auto;width:auto;max-width:calc(100% - 120px);}
.detail-title-inline{display:inline-flex;align-items:center;justify-content:flex-start;gap:10px;flex-wrap:nowrap;width:auto;max-width:100%;}
.detail-title-inline-text{font-size:18px;font-weight:700;color:#111827;line-height:1.4;word-break:break-word;display:inline-block;flex:0 1 auto;min-width:0;}
.detail-meta-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:8px;}
.detail-subtitle{font-size:13px;color:#6b7280;line-height:1.6;}
.detail-header-actions{margin-left:auto;display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.detail-head-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:6px 18px;border:1.5px solid #111827;background:#fff;border-radius:8px;font-size:13px;font-weight:500;color:#111827;cursor:pointer;font-family:var(--font);white-space:nowrap;transition:all .15s;}
.detail-head-btn:hover{background:#f3f4f6;border-color:#111827;}
.detail-head-btn-danger{border-color:#ef4444;color:#dc2626;background:#fff;}
.detail-head-btn-danger:hover{background:#fef2f2;border-color:#ef4444;color:#dc2626;}
.detail-head-btn-primary{background:#f0fdf4;border-color:#bbf7d0;}
.detail-head-btn-primary:hover{background:rgba(0,0,0,0.13);}
.detail-head-btn-solid{background:linear-gradient(135deg,#16a34a,#22c55e);border:none;color:#fff;box-shadow:0 6px 18px rgba(34,197,94,0.22);}
.detail-head-btn-solid:hover{background:linear-gradient(135deg,#15803d,#16a34a);border:none;color:#fff;transform:translateY(-1px);box-shadow:0 10px 24px rgba(22,163,74,0.28);}
.detail-inline-btn{display:inline-flex;align-items:center;justify-content:center;padding:4px 12px;border:1px solid #d1d5db;background:#fff;border-radius:8px;font-size:13px;font-weight:500;color:#374151;cursor:pointer;font-family:var(--font);transition:all .15s;}
.detail-inline-btn:hover{background:rgba(0,0,0,0.13);border-color:#cbd5e1;box-shadow:0 2px 8px rgba(0,0,0,0.15);}
.detail-ocean-row{display:grid;grid-template-columns:repeat(5,minmax(0,1fr)) minmax(114px,auto);align-items:center;gap:16px;width:100%;}
.detail-ocean-row-no-action{grid-template-columns:repeat(5,minmax(0,1fr));}
.detail-ocean-meta{display:flex;flex-direction:column;gap:6px;min-width:0;text-align:left;}
.detail-ocean-meta-label{font-size:12px;color:#6b7280;}
.detail-ocean-meta-value{font-size:15px;font-weight:600;color:#111827;line-height:1.35;word-break:break-word;}
.detail-ocean-item{font-size:14px;font-weight:500;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:center;min-width:0;}
.detail-ocean-muted{color:#6b7280;font-weight:400;}
.detail-ocean-divider{width:1px;height:16px;background:#e5e7eb;flex-shrink:0;}
.detail-ocean-row .detail-head-btn-solid{width:100%;}
@media (max-width:760px){
  .detail-ocean-row,
  .detail-ocean-row-no-action{grid-template-columns:repeat(2,minmax(0,1fr));align-items:start;}
  .detail-ocean-row .detail-head-btn-solid{grid-column:1/-1;}
}
.detail-score-chips{display:flex;gap:8px;flex-wrap:wrap;}
.detail-score-chip{padding:8px 14px;border-radius:10px;text-align:center;min-width:86px;}
.detail-score-chip-label{font-size:11px;font-weight:600;color:#111827;opacity:.72;}
.detail-score-chip-value{font-size:22px;font-weight:700;color:#111827;line-height:1.1;margin-top:3px;}
.detail-score-chip-init{background:#c7d2fe;}
.detail-score-chip-current{background:#a5f3fc;}
.detail-score-chip-up{background:#a7f3d0;}
.detail-score-chip-flat{background:#fbcfe8;}
.detail-score-chip-down{background:#fed7aa;}
.detail-feedback-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;}
.detail-feedback-main{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.detail-feedback-title{font-size:14px;font-weight:700;line-height:1.4;}
.detail-feedback-score{display:inline-flex;align-items:center;gap:10px;padding:8px 12px;border-radius:14px;background:rgba(255,255,255,0.88);box-shadow:0 6px 18px rgba(15,23,42,0.06);font-weight:700;line-height:1;}
.detail-feedback-score-val{font-size:14px;font-weight:700;letter-spacing:0;}
.detail-feedback-score-old{opacity:1;}
.detail-feedback-score-arrow{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:999px;box-shadow:inset 0 0 0 1px rgba(255,255,255,0.35);}
.detail-feedback-score-arrow svg{width:16px;height:16px;display:block;}
.detail-feedback-meta{font-size:12px;white-space:nowrap;}
.modal{background:white;border-radius:18px;width:680px;max-height:92vh;overflow-y:auto;}
.mh{background:#7c3aed;padding:30px 32px 24px;border-radius:18px 18px 0 0;color:white;}
.mh h2{font-size:18px;font-weight:700;margin-bottom:4px;}
.mh p{font-size:13px;opacity:.85;}
.mb{padding:32px;}
.sf-g{margin-bottom:20px;}
.sf-l{display:block;font-size:15px;font-weight:600;color:var(--text2);margin-bottom:9px;}
.sf-i{width:100%;padding:13px 16px;border:1.5px solid var(--border);border-radius:8px;font-size:15px;font-family:var(--font);color:var(--text);outline:none;background:var(--bg);}.sf-i:focus{border-color:#7c3aed;background:white;}
.sf-i:focus{border-color:var(--blue);background:white;}
.sf-i.sf-i-error{border-color:#ef4444 !important;background:#fef2f2 !important;box-shadow:0 0 0 3px rgba(239,68,68,0.08);}
.sf-field-result{display:none;margin-top:8px;padding:10px 14px;background:#fef2f2;border:1.5px solid #fecaca;border-radius:8px;font-size:13px;color:#b91c1c;line-height:1.75;}
.sf-row{display:flex;gap:10px;}
.sf-row .sf-g{flex:1;}
.sf-sub{width:100%;padding:15px;background:#7c3aed;color:white;border:none;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer;font-family:var(--font);margin-top:8px;}
.sf-can{width:100%;padding:9px;background:none;border:1.5px solid var(--border);border-radius:6px;font-size:13px;color:var(--text2);cursor:pointer;font-family:var(--font);margin-top:8px;transition:all .15s;}
.sf-can:hover{background:rgba(0,0,0,0.05);box-shadow:0 2px 8px rgba(0,0,0,0.08);transform:translateY(-1px);}
.sf-sub:hover{background:#6d28d9;box-shadow:0 4px 14px rgba(124,58,237,0.4);transform:translateY(-1px);}
.sf-sub{transition:all .15s;}
.sf-dd-wrap{position:relative;}
.sf-dd{position:absolute;top:calc(100% + 4px);left:0;right:0;background:white;border:1.5px solid var(--blue);border-radius:6px;max-height:200px;overflow-y:auto;z-index:300;display:none;}
.sf-dd.open{display:block;}
.sf-dd-title{padding:6px 12px;font-size:11px;font-weight:700;color:var(--text3);background:var(--bg);}
.sf-dd-item{padding:8px 14px;font-size:13px;cursor:pointer;}
.sf-dd-item:hover{background:var(--blue-l);color:var(--blue);}

/* 线索互换弹窗 — 表单工作台 */
#shareModal.overlay{background:rgba(17,24,39,.38);backdrop-filter:none;-webkit-backdrop-filter:none;padding:24px;}
#shareModal .modal{
  width:min(780px,calc(100vw - 32px));
  max-height:calc(100vh - 48px);
  border-radius:24px;
  border:1px solid #d7dde7;
  background:#fff;
  box-shadow:0 28px 70px rgba(15,23,42,.22);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  animation:shareModalIn .22s cubic-bezier(.2,.8,.2,1);
}
@keyframes shareModalIn{from{opacity:0;transform:translateY(8px) scale(.99);}to{opacity:1;transform:translateY(0) scale(1);}}
#shareModal .modal::-webkit-scrollbar{width:0;height:0;}
#shareModal .mh{
  flex-shrink:0;
  position:relative;
  padding:28px 36px 22px;
  border-radius:24px 24px 0 0;
  border-bottom:1px solid #e5e7eb;
  background:#fff;
  color:#111827;
}
#shareModal .mh h2{color:#111827;font-size:25px;font-weight:800;line-height:1.18;letter-spacing:0;margin:0 96px 8px 0;}
#shareModal .mh p{opacity:1;margin:0;max-width:640px;}
#shareModal .share-modal-summary{font-size:14px;line-height:1.7;color:#4b5563;}
#shareModal .share-modal-note{
  margin-top:10px;
  padding-left:12px;
  border-left:3px solid #111827;
  font-size:13px;
  line-height:1.65;
  color:#374151;
}
#shareModal .mh > button{
  top:28px !important;
  right:28px !important;
  transform:none !important;
  min-width:64px !important;
  height:36px !important;
  border-radius:999px !important;
  border:1px solid #cfd6e2 !important;
  background:#fff !important;
  color:#111827 !important;
  box-shadow:none !important;
}
#shareModal .mh > button:hover{background:#f8fafc !important;border-color:#b8c1cf !important;color:#111827 !important;box-shadow:none !important;}
#shareModal .mb{
  padding:26px 36px 30px;
  background:#fff;
  overflow:auto;
  scrollbar-width:thin;
  scrollbar-color:rgba(31,35,41,.18) transparent;
}
#shareModal .mb::-webkit-scrollbar{width:10px;}
#shareModal .mb::-webkit-scrollbar-track{background:transparent;margin:18px 0;}
#shareModal .mb::-webkit-scrollbar-thumb{background:rgba(31,35,41,.18);border:3px solid transparent;border-radius:999px;background-clip:content-box;}
#shareModal .mb::-webkit-scrollbar-thumb:hover{background:rgba(31,35,41,.32);border:3px solid transparent;background-clip:content-box;}
#shareModal .share-check-panel{
  margin:0 0 24px;
  padding:0 0 22px;
  border-bottom:1px solid #e5e7eb;
}
#shareModal .share-check-row{display:grid !important;grid-template-columns:minmax(0,1fr) 86px;gap:10px !important;align-items:center;}
#shareModal .sf-g{margin-bottom:18px;}
#shareModal #sf-extra .sf-g:last-child{margin-bottom:0;}
#shareModal .sf-l{display:block;font-size:13px;font-weight:700;color:#111827;margin-bottom:8px;letter-spacing:0;line-height:1.5;}
#shareModal .sf-l span[style*="color:#ef4444"]{color:#dc2626 !important;}
#shareModal .share-label-note{font-size:12px;font-weight:500;color:#6b7280;}
#shareModal .share-form-hint{font-size:12px;color:#6b7280;margin-top:6px;line-height:1.65;}
#shareModal .sf-row{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(0,.92fr);gap:16px 18px;}
#shareModal .sf-i{
  width:100%;
  min-height:48px;
  padding:12px 15px;
  border:1px solid #d7dde7;
  border-radius:12px;
  background:#fff;
  color:#111827;
  font-size:14px;
  line-height:1.45;
  box-shadow:none;
  transition:border-color .16s ease,box-shadow .16s ease,background .16s ease;
}
#shareModal .sf-i::placeholder{color:#9aa3b2;opacity:1;}
#shareModal textarea.sf-i{min-height:96px;}
#shareModal .sf-i:focus{border-color:#111827;background:#fff;box-shadow:0 0 0 3px rgba(17,24,39,.08);}
#shareModal .sf-i.sf-i-error{border-color:#dc2626 !important;background:#fff !important;box-shadow:0 0 0 3px rgba(220,38,38,.08);}
#shareModal #sf-extra{padding:0;border:0;background:transparent;box-shadow:none;}
#shareModal .sf-field-result{display:none;margin-top:6px;padding:0;border:0;background:transparent;border-radius:0;font-size:12px;color:#b42318;line-height:1.65;}
#shareModal #sf-result{margin-top:10px;}
#shareModal .sf-check-message{
  margin-top:8px;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  color:#374151;
  display:flex;
  align-items:flex-start;
  gap:7px;
  font-size:13px;
  line-height:1.58;
  box-shadow:none;
}
#shareModal .sf-check-message strong{font-weight:900;}
#shareModal .sf-check-detail{
  margin-top:2px;
  font-size:12px;
  color:inherit;
  font-weight:800;
  opacity:1;
}
#shareModal .sf-check-sub{
  margin-top:3px;
  font-size:12px;
  color:inherit;
  font-weight:800;
  opacity:1;
}
#shareModal .sf-check-icon{
  flex:0 0 auto;
  width:auto;
  height:auto;
  margin-top:1px;
  border-radius:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:transparent !important;
  font-size:15px;
  font-weight:900;
  line-height:1.35;
}
#shareModal .sf-check-icon--loading{color:#4b5563;}
#shareModal .sf-check-icon--ok{color:#15803d;}
#shareModal .sf-check-icon--warn{color:#dc2626;}
#shareModal .sf-check-icon--error{color:#b91c1c;}
#shareModal .sf-check-message--loading{color:#4b5563;background:transparent;}
#shareModal .sf-check-message--ok{border:0;background:transparent;color:#15803d;font-weight:800;}
#shareModal .sf-check-message--warn{border:0;background:transparent;color:#dc2626;font-weight:800;}
#shareModal .sf-check-message--error{border:0;background:transparent;color:#991b1b;}
#shareModal .share-check-btn,
#shareModal .sf-sub{
  min-height:48px;
  border-radius:12px !important;
  background:linear-gradient(135deg,#16a34a,#15803d) !important;
  color:#fff !important;
  border:none !important;
  box-shadow:0 8px 22px rgba(21,128,61,.22) !important;
  transform:none !important;
  cursor:pointer;
  font-family:var(--font);
  font-size:14px;
  font-weight:700;
  transition:background .16s ease,transform .16s ease;
}
#shareModal .share-check-btn:hover,
#shareModal .sf-sub:hover{background:linear-gradient(135deg,#15803d,#166534) !important;transform:translateY(-1px) !important;box-shadow:0 12px 28px rgba(21,128,61,.28) !important;}
#shareModal .sf-g button[type="button"]{
  min-height:48px;
  border-radius:12px !important;
  border:1px solid #d7dde7 !important;
  background:#fff !important;
  color:#111827 !important;
  box-shadow:none !important;
}
#shareModal .sf-g button[type="button"]:hover{background:#f8fafc !important;color:#111827 !important;box-shadow:none !important;}
#shareModal .sf-sub{
  width:100%;
  font-size:15px;
  font-weight:800;
  margin-top:8px;
  background:linear-gradient(135deg,#16a34a,#15803d) !important;
  box-shadow:0 8px 22px rgba(21,128,61,.22) !important;
}
#shareModal .sf-sub:hover{
  background:linear-gradient(135deg,#15803d,#166534) !important;
  transform:translateY(-1px) !important;
  box-shadow:0 12px 28px rgba(21,128,61,.28) !important;
}
#shareModal .sf-can{
  width:100%;
  min-height:42px;
  margin-top:12px;
  border:1px solid #cfd6e2;
  border-radius:12px;
  color:#374151;
  background:#fff;
  font-weight:700;
  transition:background .16s ease,color .16s ease,border-color .16s ease;
}
#shareModal .sf-can:hover{background:#f8fafc;color:#111827;border-color:#9aa3b2;box-shadow:none;transform:none;}
#shareModal .sf-can:focus-visible{outline:3px solid rgba(17,24,39,.12);outline-offset:2px;}
#shareModal .share-note-count{text-align:right;font-size:12px;color:#9ca3af;margin-top:5px;}
#shareModal .sf-dd{border:1px solid #d7dde7;border-radius:12px;box-shadow:0 14px 34px rgba(15,23,42,.12);overflow:hidden;}
#shareModal .sf-dd-item{padding:10px 14px;}
#shareModal .sf-dd-item:hover{background:#f8fafc;color:#111827;}
@media (prefers-reduced-motion:reduce){
  #shareModal .modal{animation:none;}
  #shareModal .sf-i,
  #shareModal .sf-sub,
  #shareModal .sf-can,
  #shareModal .mh > button{transition:none !important;}
}
@media (max-width:760px){
  #shareModal.overlay{padding:12px;align-items:flex-start;}
  #shareModal .modal{width:100%;max-height:calc(100vh - 24px);border-radius:18px;}
  #shareModal .mh{padding:22px 20px 18px;border-radius:18px 18px 0 0;}
  #shareModal .mh h2{font-size:22px;margin-right:76px;}
  #shareModal .mh > button{top:20px !important;right:18px !important;}
  #shareModal .mb{padding:22px 20px 24px;}
  #shareModal .sf-row{grid-template-columns:1fr;gap:0;}
  #shareModal .share-check-row{grid-template-columns:1fr;}
  #shareModal .share-check-btn{width:100%;}
}
.theme-dark #shareModal.overlay{background:rgba(0,0,0,.50);}
.theme-dark #shareModal .modal{background:#0f172a;border-color:#243041;box-shadow:0 28px 80px rgba(0,0,0,.42);}
.theme-dark #shareModal .mh{background:#0f172a;border-bottom-color:#243041;}
.theme-dark #shareModal .mh h2,
.theme-dark #shareModal .sf-l{color:#e5eefc;}
.theme-dark #shareModal .share-modal-summary,
.theme-dark #shareModal .share-label-note,
.theme-dark #shareModal .share-form-hint{color:#94a3b8;}
.theme-dark #shareModal .share-modal-note{color:#cbd5e1;border-left-color:#e5eefc;}
.theme-dark #shareModal .mb{background:#0f172a;}
.theme-dark #shareModal .share-check-panel{border-bottom-color:#243041;}
.theme-dark #shareModal .sf-i{background:#111827;border-color:#334155;color:#e5eefc;}
.theme-dark #shareModal .sf-i:focus{background:#111827;border-color:#94a3b8;box-shadow:0 0 0 3px rgba(148,163,184,.16);}
.theme-dark #shareModal .sf-check-message{background:transparent;border-color:transparent;color:#cbd5e1;}
.theme-dark #shareModal .sf-check-icon--loading{color:#cbd5e1;}
.theme-dark #shareModal .sf-check-icon--ok{color:#86efac;}
.theme-dark #shareModal .sf-check-icon--warn{color:#fca5a5;}
.theme-dark #shareModal .sf-check-icon--error{color:#fecaca;}
.theme-dark #shareModal .sf-check-message--loading{background:transparent;color:#94a3b8;}
.theme-dark #shareModal .sf-check-message--ok{background:transparent;border-color:transparent;color:#86efac;}
.theme-dark #shareModal .sf-check-message--warn{background:transparent;border-color:transparent;color:#fca5a5;}
.theme-dark #shareModal .sf-check-message--error{background:transparent;border-color:transparent;color:#fecaca;}
.theme-dark #shareModal .sf-g button[type="button"],
.theme-dark #shareModal .sf-can,
.theme-dark #shareModal .mh > button{background:#111827 !important;color:#e5eefc !important;border-color:#334155 !important;}
.theme-dark #shareModal .sf-g button[type="button"]:hover,
.theme-dark #shareModal .sf-can:hover,
.theme-dark #shareModal .mh > button:hover{background:#1f2937 !important;color:#fff !important;border-color:#475569 !important;}
.theme-dark #shareModal .sf-dd{background:#111827;border-color:#334155;}
.theme-dark #shareModal .sf-dd-title{background:#0f172a;color:#94a3b8;}
.theme-dark #shareModal .sf-dd-item{color:#e5eefc;}
.theme-dark #shareModal .sf-dd-item:hover{background:#1f2937;color:#fff;}

/* 庆祝弹窗 */
.celebrate-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:9999;display:flex;align-items:center;justify-content:center;animation:celebFadeIn .3s ease;}
@keyframes celebFadeIn{from{opacity:0}to{opacity:1}}
.celebrate-card{background:white;border-radius:20px;padding:40px 48px;text-align:center;box-shadow:0 24px 60px rgba(0,0,0,0.2);animation:celebPop .4s cubic-bezier(.175,.885,.32,1.275);}
@keyframes celebPop{from{opacity:0;transform:scale(0.7)}to{opacity:1;transform:scale(1)}}
.celebrate-icon{font-size:56px;margin-bottom:12px;}
.celebrate-title{font-size:20px;font-weight:700;color:#111827;margin-bottom:8px;}
.celebrate-desc{font-size:14px;color:#6b7280;margin-bottom:20px;}
.celebrate-btn{padding:10px 32px;background:#7c3aed;color:white;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;font-family:var(--font);transition:all .15s;}
.celebrate-btn:hover{background:#6d28d9;transform:translateY(-1px);box-shadow:0 4px 14px rgba(124,58,237,0.35);}
.confetti{position:absolute;width:8px;height:8px;border-radius:2px;animation:confettiFall 1.8s ease-out forwards;}
@keyframes confettiFall{
  0%{opacity:1;transform:translate(0,0) rotate(0deg) scale(1);}
  100%{opacity:0;transform:translate(var(--cx),var(--cy)) rotate(720deg) scale(0.3);}
}
.order-reminder-blink{animation:orderReminderBlink 2.2s ease-in-out infinite;}
@keyframes orderReminderBlink{
  0%,100%{opacity:1;}
  50%{opacity:.45;}
}

::-webkit-scrollbar{width:4px;height:4px;}
::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px;}
::-webkit-scrollbar-thumb:hover{background:#94a3b8;}
::-webkit-scrollbar-track{background:transparent;}
/* ===== 业绩看板 ===== */
.dash-card{background:#fff;border:1px solid #eeedf2;border-radius:14px;padding:22px;margin-bottom:0;box-shadow:0 1px 4px rgba(0,0,0,0.04);transition:all .2s;}
.dash-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,0.08);}
.settings-wrap{padding:28px;max-width:860px;}
.settings-card{background:#fff;border:1px solid #eeedf2;border-radius:14px;padding:22px;margin-top:16px;box-shadow:0 1px 4px rgba(0,0,0,0.04);}
.settings-card:first-of-type{margin-top:20px;}
.settings-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px;}
.settings-title{font-size:15px;font-weight:800;color:#374151;margin-bottom:4px;}
.settings-desc{font-size:12px;color:#9ca3af;line-height:1.6;}
.settings-center-desc{text-align:center;margin-top:8px;}
.settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;}
.settings-password-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
.settings-field{display:flex;flex-direction:column;gap:7px;font-size:13px;font-weight:700;color:#374151;}
.settings-field-wide{grid-column:1 / -1;}
.settings-input{width:100%;height:42px;border:1.5px solid #e5e7eb;border-radius:10px;background:#fff;color:#111827;font-size:13px;font-family:var(--font);padding:0 12px;outline:none;transition:border-color .15s,box-shadow .15s,background .15s;}
.settings-input:focus{border-color:#7c3aed;box-shadow:0 0 0 4px rgba(124,58,237,.10);}
.settings-input.is-readonly{background:#f9fafb;color:#6b7280;cursor:not-allowed;}
.settings-count{text-align:right;margin-top:-2px;font-size:12px;font-weight:500;color:#9ca3af;}
.settings-channel-tags{min-height:0;display:flex;flex-wrap:wrap;gap:6px;}
.settings-channel-tag{display:inline-flex;align-items:center;gap:6px;background:#667eea;color:#fff;padding:5px 10px;border-radius:999px;font-size:13px;font-weight:700;line-height:1;}
.settings-channel-tag button{border:none;background:transparent;color:#fff;font-size:16px;line-height:1;padding:0;cursor:pointer;font-family:var(--font);}
.settings-channel-picker{position:relative;}
.settings-channel-dropdown{display:none;position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1.5px solid #667eea;border-radius:10px;max-height:180px;overflow-y:auto;z-index:30;box-shadow:0 8px 24px rgba(17,24,39,0.14);}
.settings-channel-option{width:100%;border:none;border-bottom:1px solid #f0f0f0;background:#fff;padding:10px 14px;text-align:left;font-size:14px;color:#111827;cursor:pointer;font-family:var(--font);}
.settings-channel-option:hover{background:#f0f0ff;}
.settings-channel-option.is-custom{color:#667eea;font-weight:700;}
.settings-actions{display:flex;justify-content:flex-end;margin-top:18px;}
.settings-primary-btn,.settings-secondary-btn,.settings-danger-btn{border-radius:12px;font-family:var(--font);font-weight:700;cursor:pointer;transition:all .15s;}
.settings-primary-btn{border:none;background:#111827;color:#fff;padding:11px 18px;font-size:14px;}
.settings-primary-btn:hover{background:#000;transform:translateY(-1px);}
.settings-secondary-btn{border:1px solid #e5e7eb;background:#fff;color:#6b7280;padding:8px 14px;font-size:13px;}
.settings-secondary-btn:hover{background:#f9fafb;color:#374151;}
.settings-danger-btn{width:100%;padding:14px;background:#fff;border:1.5px solid #e5e7eb;font-size:14px;color:#374151;}
.settings-danger-btn:hover{background:#fef2f2;border-color:#fca5a5;color:#dc2626;}
.settings-msg{display:none;margin:0 0 14px;padding:10px 12px;border-radius:10px;font-size:13px;line-height:1.5;}
.settings-msg.is-show{display:block;}
.settings-msg.is-success{background:#ecfdf5;color:#047857;border:1px solid #bbf7d0;}
.settings-msg.is-error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca;}
@media (max-width:860px){
  .settings-wrap{padding:18px;max-width:none;}
  .settings-grid,.settings-password-grid{grid-template-columns:1fr;}
}
.dash-ct{font-size:14px;font-weight:700;color:#374151;margin-bottom:16px;}
.map-yr-btn{padding:6px 16px;font-size:12px;background:#f3f4f6;color:#6b7280;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s;font-weight:600;}.map-yr-btn.active{background:#4535C1;color:#fff;border-color:#4535C1;}.map-yr-btn:hover:not(.active){background:#e8e5ff;color:#4535C1;}
.dash-kpi-card{background:#fff;border:1px solid #eeedf2;border-radius:14px;padding:20px 22px;box-shadow:0 1px 4px rgba(0,0,0,0.04);display:flex;align-items:center;gap:16px;transition:all .2s;cursor:default;}
.dash-kpi-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,0.08);}
.dash-kpi-val{font-size:26px;font-weight:800;color:#111827;line-height:1.2;}
.dash-kpi-label{font-size:12px;font-weight:500;color:#9ca3af;margin-top:2px;}
.work-summary-range-btn{padding:8px 16px;border:1.5px solid #e5e7eb;border-radius:10px;background:#fff;color:#6b7280;font-size:13px;font-weight:700;cursor:pointer;font-family:var(--font);transition:all .15s;}
.work-summary-range-btn:hover{background:#f9fafb;color:#111827;}
.work-summary-range-btn.active{background:#111827;color:#fff;border-color:#111827;}
.work-summary-style-option{display:flex;align-items:flex-start;gap:10px;padding:14px;border:1.5px solid #e5e7eb;border-radius:12px;cursor:pointer;transition:all .15s;background:#fff;}
.work-summary-style-option:hover{border-color:#9ca3af;background:#f9fafb;}
.work-summary-style-option input{margin-top:2px;accent-color:#111827;}
.work-summary-style-option span{display:flex;flex-direction:column;gap:4px;}
.work-summary-style-option b{font-size:13px;color:#111827;}
.work-summary-style-option em{font-size:12px;color:#6b7280;font-style:normal;line-height:1.5;}
.dash-list-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid #f3f4f6;}
.dash-list-item:last-child{border-bottom:none;}
.dash-list-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:#fff;flex-shrink:0;}
.dash-list-info{flex:1;min-width:0;}
.dash-list-name{font-size:13px;font-weight:600;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.dash-list-sub{font-size:11px;color:#9ca3af;margin-top:1px;}
.dash-list-amt{font-size:14px;font-weight:700;color:#111827;flex-shrink:0;}
.dash-list-tag{font-size:10px;font-weight:600;padding:2px 8px;border-radius:10px;flex-shrink:0;}
.dash-rank-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid #f3f4f6;}
.dash-rank-row:last-child{border-bottom:none;}
.dash-rank-num{width:22px;height:22px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0;}
.dash-rank-info{flex:1;min-width:0;}
.dash-rank-name{font-size:13px;font-weight:600;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.dash-rank-ind{font-size:11px;color:#9ca3af;}
.dash-rank-amt{font-size:14px;font-weight:700;color:#7c3aed;flex-shrink:0;}
/* 行动横幅 */
.dash-action-bar{background:#fff;border:1px solid #eeedf2;border-radius:14px;padding:16px 22px;margin-bottom:14px;display:flex;gap:12px;flex-wrap:wrap;box-shadow:0 1px 4px rgba(0,0,0,0.04);}
.dash-action-item{display:flex;align-items:center;gap:10px;padding:10px 16px;border-radius:10px;font-size:13px;font-weight:600;color:#374151;cursor:pointer;transition:all .15s;flex:1;min-width:200px;}
.dash-action-item:hover{transform:translateY(-1px);}
.dash-action-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.dash-action-num{font-size:18px;font-weight:800;margin-right:2px;}
/* 协同卡片 */
.dash-collab-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.dash-collab-stat{display:flex;align-items:center;gap:14px;padding:16px;border-radius:12px;background:#f9fafb;border:1px solid #f3f4f6;}
.dash-collab-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.dash-collab-val{font-size:22px;font-weight:800;color:#111827;line-height:1.1;}
.dash-collab-label{font-size:11px;color:#9ca3af;font-weight:500;margin-top:2px;}
.bar-col{display:flex;flex-direction:column;align-items:center;flex:1;}
.o-row{display:flex;flex-direction:column;gap:4px;}
.o-label{font-size:12px;font-weight:600;color:#6b7280;}
.o-label i{color:#ef4444;font-style:normal;}
.o-input{padding:8px 12px;border:1.5px solid #e5e7eb;border-radius:7px;font-size:13px;font-family:var(--font);color:#111827;outline:none;width:100%;background:white;}
.o-input:focus{border-color:#7c3aed;}
.private-form-shell{padding:24px;background:linear-gradient(180deg,#f8fafc 0%,#ffffff 100%) !important;}
.private-form-header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding:20px 24px 18px !important;border-bottom:1px solid #e5e7eb;background:white !important;}
.private-form-title{font-size:19px;font-weight:700;color:#111827;line-height:1.4;}
.private-form-desc{font-size:13px;color:#6b7280;line-height:1.7;margin-top:6px;}
.private-form-close{display:inline-flex;align-items:center;justify-content:center;padding:8px 18px !important;border:1px solid #d1d5db !important;background:#fff !important;border-radius:10px !important;font-size:13px !important;font-weight:500 !important;color:#374151 !important;cursor:pointer;font-family:var(--font);transition:all .15s;white-space:nowrap;}
.private-form-close:hover{background:#f3f4f6 !important;box-shadow:0 2px 8px rgba(0,0,0,0.08);}
.private-form-notice{display:flex;align-items:flex-start;gap:12px;padding:16px 18px;background:linear-gradient(135deg,#ecfdf5,#f0fdf4);border:1px solid #bbf7d0;border-radius:14px;margin-bottom:20px;box-shadow:0 6px 18px rgba(34,197,94,0.08);}
.private-form-notice-icon{width:36px;height:36px;border-radius:12px;background:linear-gradient(135deg,#16a34a,#22c55e);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 8px 18px rgba(34,197,94,0.18);}
.private-form-notice-text{font-size:13px;color:#166534;line-height:1.75;font-weight:600;}
.private-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 18px;}
.private-form-row{display:flex;flex-direction:column;gap:7px;padding:14px 14px 12px;background:white;border:1px solid #eef2f7;border-radius:14px;box-shadow:0 3px 10px rgba(15,23,42,0.03);}
.private-form-row-full{grid-column:1 / -1;}
.private-form-label{font-size:12px;font-weight:700;color:#6b7280;line-height:1.5;}
.private-form-label i{color:#ef4444;font-style:normal;}
.private-form-label-hint{font-size:11px;color:#9ca3af;font-weight:500;}
.private-form-input{padding:12px 14px !important;border:1.5px solid #e5e7eb !important;border-radius:10px !important;font-size:14px !important;font-family:var(--font);color:#111827;outline:none;width:100%;background:#fff;transition:all .15s;}
.private-form-input:focus{border-color:#16a34a;box-shadow:0 0 0 4px rgba(34,197,94,0.12);}
.private-form-assist{display:inline-flex;align-items:center;justify-content:center;padding:10px 16px !important;border:1px solid #d1d5db !important;background:#fff !important;border-radius:10px !important;font-size:13px !important;font-weight:500 !important;color:#6b7280 !important;cursor:pointer;font-family:var(--font);white-space:nowrap;transition:all .15s;}
.private-form-assist:hover{background:#f9fafb !important;box-shadow:0 2px 8px rgba(0,0,0,0.08);}
.private-form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:22px;}
.private-form-submit{padding:13px 34px !important;background:linear-gradient(135deg,#16a34a,#15803d) !important;color:white !important;border:none !important;border-radius:12px !important;font-size:15px !important;font-weight:700 !important;cursor:pointer;font-family:var(--font);box-shadow:0 8px 22px rgba(21,128,61,0.22) !important;transition:all .15s;}
.private-form-submit:hover{transform:translateY(-1px);box-shadow:0 12px 28px rgba(21,128,61,0.28) !important;}
.private-form-cancel{padding:13px 22px;background:white;border:1px solid #d1d5db;border-radius:12px;font-size:14px;font-weight:500;color:#6b7280;cursor:pointer;font-family:var(--font);transition:all .15s;}
.private-form-cancel:hover{background:#f9fafb;}
#import-layer-3 .private-form-title,
#import-layer-3 .private-form-desc{display:block;}
#import-layer-3 .mh h2{font-size:19px !important;color:#111827 !important;font-weight:800 !important;}
#import-layer-3 .mh p{display:none !important;}
#import-layer-3 .mb > div:first-child{display:none !important;}
#import-layer-3 .mb > div:nth-child(2){gap:16px 18px !important;}
#import-layer-3 .mb > div:nth-child(2) .o-row{gap:7px;background:#fff;padding:14px 14px 12px;border:1px solid #eef2f7;border-radius:14px;box-shadow:0 3px 10px rgba(15,23,42,0.03);}
#import-layer-3 .mb > div:nth-child(2) .o-row:last-child{grid-column:1 / -1;}
#import-layer-3 .mb > div:nth-child(2) .o-label{font-size:14px !important;font-weight:800 !important;color:#111827 !important;line-height:1.5;}
#import-layer-3 .mb > div:last-child{justify-content:flex-end !important;gap:10px;}
.order-create-modal{width:820px !important;max-width:96vw;border-radius:20px !important;background:linear-gradient(180deg,#f8fafc 0%,#ffffff 100%);box-shadow:0 24px 60px rgba(15,23,42,0.16) !important;overflow:hidden;}
.order-create-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;background:#fff !important;color:#111827 !important;border-bottom:1px solid #e5e7eb;padding:16px 20px !important;border-radius:20px 20px 0 0 !important;position:relative;}
.order-create-header h2{font-size:19px !important;font-weight:800 !important;color:#111827 !important;}
.order-create-header p{font-size:13px !important;color:#6b7280 !important;opacity:1 !important;margin-top:6px !important;}
.order-create-close{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;min-width:72px;height:34px;padding:0 16px !important;border:1.5px solid #111827 !important;background:#fff !important;border-radius:8px !important;font-size:13px !important;font-weight:500 !important;color:#111827 !important;cursor:pointer;font-family:var(--font);transition:all .15s;white-space:nowrap;line-height:1;}
.order-create-close:hover{background:#f3f4f6 !important;border-color:#111827 !important;}
.order-create-header-copy{min-width:0;}
.order-create-body{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:10px 12px !important;padding:18px 20px 20px !important;background:transparent !important;}
.order-create-grid{display:contents;}
.order-create-grid .o-row,
.order-create-note,
.order-create-panel{gap:6px;background:#fff;padding:10px 12px 11px;border:1px solid #eef2f7;border-radius:12px;box-shadow:0 3px 10px rgba(15,23,42,0.03);}
.order-create-grid .o-row{min-width:0;}
.order-edit-form{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:10px 12px;}
.order-edit-banner{grid-column:1 / -1;font-size:13px;font-weight:700;color:#6b7280;}
.order-create-grid .o-row:has(#noChan),
.order-create-grid .o-row:has(#noSpec),
.order-create-grid .o-row:has(#noQty),
.order-create-grid .o-row:has(#noPrice),
.order-create-grid .o-row:has(#noAmt){display:none !important;}
.order-create-span-12{grid-column:span 12;}
.order-create-span-8{grid-column:span 8;}
.order-create-span-6{grid-column:span 6;}
.order-create-span-5{grid-column:span 5;}
.order-create-span-4{grid-column:span 4;}
.order-create-span-3{grid-column:span 3;}
.order-create-span-2{grid-column:span 2;}
.order-create-order-1{order:1;}
.order-create-order-2{order:2;}
.order-create-order-3{order:3;}
.order-create-order-4{order:4;}
.order-create-order-5{order:5;}
.order-create-order-6{order:6;}
.order-create-order-7{order:7;}
.order-create-order-8{order:8;}
.order-create-order-9{order:9;}
.order-create-order-10{order:10;}
.order-create-order-11{order:11;}
.order-create-order-12{order:12;}
.order-create-order-13{order:13;}
.order-create-order-14{order:14;}
.order-create-order-15{order:15;}
.order-create-order-16{order:16;}
.order-create-order-17{order:17;}
.order-create-grid .o-label,
.order-create-note .o-label,
.order-create-panel .o-label{font-size:13px !important;font-weight:800 !important;color:#111827 !important;line-height:1.4;}
.order-create-grid .o-label span,
.order-create-note .o-label span,
.order-create-panel .o-label span{font-size:11px !important;color:#9ca3af !important;font-weight:500 !important;}
.order-create-grid .o-input,
.order-create-note .o-input,
.order-create-panel .o-input{padding:10px 12px;border:1.5px solid #e5e7eb;border-radius:10px;font-size:13px;font-family:var(--font);color:#111827;outline:none;width:100%;background:#fff;transition:all .15s;}
.order-create-readonly{background:#f8fafc !important;color:#6b7280 !important;cursor:not-allowed;}
.order-create-grid .o-input:focus,
.order-create-note .o-input:focus,
.order-create-panel .o-input:focus{border-color:#16a34a;box-shadow:0 0 0 4px rgba(34,197,94,0.12);}
.order-create-panel{grid-column:1 / -1;padding:12px;}
.order-create-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px;}
.order-create-panel-title{display:none;}
.order-create-panel-grid{display:grid;grid-template-columns:1.5fr 0.95fr 0.85fr 0.95fr 1fr 0.95fr;gap:10px;}
.order-create-panel-title i{color:#ef4444;font-style:normal;}
.order-create-panel-meta{display:flex;flex-direction:column;align-items:flex-start;gap:10px;flex-wrap:nowrap;}
.order-create-panel-add{padding:7px 20px;background:linear-gradient(135deg,#16a34a,#15803d);border:none;border-radius:8px;font-size:14px;font-weight:700;color:#fff;cursor:pointer;font-family:var(--font);transition:all .15s;white-space:nowrap;box-shadow:0 8px 22px rgba(21,128,61,0.22);}
.order-create-panel-add:hover{transform:translateY(-1px);box-shadow:0 12px 28px rgba(21,128,61,0.28);}
.order-create-panel-stats{display:flex;align-items:center;gap:18px;flex-wrap:wrap;}
.order-create-panel-stat{display:flex;align-items:baseline;gap:8px;font-size:15px;font-weight:500;color:#111827;}
.order-create-panel-stat strong{font-size:21px;font-weight:600;color:#111827;line-height:1;}
.order-create-panel-stat.is-total strong{color:#16a34a;}
.order-create-item-head{margin-bottom:8px;align-items:center;}
.order-create-item-head span{font-size:11px;font-weight:700;color:#9ca3af;line-height:1.4;text-align:center;justify-self:center;width:100%;}
.order-create-items-wrap{display:flex;flex-direction:column;gap:10px;}
.order-create-item-row{align-items:end;}
.order-create-item-row > div{min-width:0;}
.order-create-panel input[type=number]::-webkit-outer-spin-button,
.order-create-panel input[type=number]::-webkit-inner-spin-button,
#noQty::-webkit-outer-spin-button,
#noQty::-webkit-inner-spin-button,
#noPrice::-webkit-outer-spin-button,
#noPrice::-webkit-inner-spin-button{
  -webkit-appearance:none;
  margin:0;
}
.order-create-panel input[type=number],
#noQty,
#noPrice{
  -moz-appearance:textfield;
  appearance:textfield;
}
.order-create-item-total{background:#f8fafc !important;color:#16a34a !important;font-weight:700;}
.order-create-item-remove{width:100%;padding:10px 12px;background:#fff;border:1px solid #e5e7eb;border-radius:10px;font-size:13px;font-weight:600;color:#6b7280;cursor:pointer;font-family:var(--font);transition:all .15s;}
.order-create-item-remove:hover{background:#f9fafb;border-color:#d1d5db;color:#374151;}
.order-create-panel-summary{display:none;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-top:12px;padding-top:12px;border-top:1px dashed #e5e7eb;font-size:12px;color:#6b7280;}
.order-create-panel-summary strong{font-size:13px;color:#111827;}
.order-create-panel-summary .is-total{color:#16a34a;font-weight:800;}
#orderItemsPanel{order:13;margin-top:0 !important;}
.order-create-note{grid-column:1 / -1;order:14;margin-top:0;}
.order-create-note-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px;}
.order-create-note-tip{font-size:11px;font-weight:600;color:#ef4444;white-space:nowrap;}
.order-create-note .o-input{min-height:92px;resize:vertical;line-height:1.6;}
.order-create-actions{display:flex;grid-column:1 / -1;order:15;gap:10px;margin-top:4px;}
.order-create-submit{flex:1;padding:13px;background:linear-gradient(135deg,#16a34a,#15803d);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;font-family:var(--font);box-shadow:0 8px 22px rgba(21,128,61,0.22);transition:all .15s;}
.order-create-submit:hover{transform:translateY(-1px);box-shadow:0 12px 28px rgba(21,128,61,0.28);}
.order-create-cancel{flex:1;padding:13px;background:#fff;border:1.5px solid #e5e7eb;border-radius:12px;font-size:14px;font-weight:600;color:#374151;cursor:pointer;font-family:var(--font);transition:all .15s;}
.order-create-cancel:hover{background:#f9fafb;}
.order-create-note-count{text-align:right;font-size:11px;color:#9ca3af;margin-top:6px;}
.sample-create-modal{width:760px !important;max-width:96vw;border-radius:20px !important;background:linear-gradient(180deg,#f8fafc 0%,#ffffff 100%);box-shadow:0 24px 60px rgba(15,23,42,0.16) !important;overflow:hidden;}
.sample-create-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;background:#fff !important;color:#111827 !important;border-bottom:1px solid #e5e7eb;padding:16px 20px !important;border-radius:20px 20px 0 0 !important;position:relative;}
.sample-create-header h2{font-size:19px !important;font-weight:800 !important;color:#111827 !important;}
.sample-create-header p{display:none !important;}
.sample-create-close{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;min-width:72px;height:34px;padding:0 16px !important;border:1.5px solid #111827 !important;background:#fff !important;border-radius:8px !important;font-size:13px !important;font-weight:500 !important;color:#111827 !important;cursor:pointer;font-family:var(--font);transition:all .15s;line-height:1;white-space:nowrap;}
.sample-create-close:hover{background:#f3f4f6 !important;border-color:#111827 !important;}
.sample-create-body{padding:18px 20px 20px !important;background:transparent !important;}
.sample-create-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:10px 12px !important;}
.sample-create-grid .o-row,
.sample-create-source{gap:6px;background:#fff;padding:10px 12px 11px;border:1px solid #eef2f7;border-radius:12px;box-shadow:0 3px 10px rgba(15,23,42,0.03);}
.sample-create-span-12{grid-column:span 12;}
.sample-create-span-6{grid-column:span 6;}
.sample-create-grid .o-label,
.sample-create-source .o-label{font-size:13px !important;font-weight:800 !important;color:#111827 !important;line-height:1.4;}
.sample-create-grid .o-input,
.sample-create-source .o-input{padding:10px 12px;border:1.5px solid #e5e7eb;border-radius:10px;font-size:13px;font-family:var(--font);color:#111827;outline:none;width:100%;background:#fff;transition:all .15s;}
.sample-create-grid .o-input:focus,
.sample-create-source .o-input:focus{border-color:#16a34a;box-shadow:0 0 0 4px rgba(34,197,94,0.12);}
.followup-picker-shell{position:relative;width:100%;}
.followup-picker-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;max-height:260px;overflow-y:auto;background:#fff;border:1.5px solid #dbe3ef;border-radius:12px;box-shadow:0 16px 32px rgba(15,23,42,0.14);z-index:30;padding:6px;}
.followup-picker-option{display:block;width:100%;padding:10px 12px;border:none;background:#fff;border-radius:10px;text-align:left;cursor:pointer;transition:background .15s;}
.followup-picker-option:hover{background:#f8fafc;}
.followup-picker-option-title{font-size:13px;font-weight:700;color:#111827;line-height:1.5;}
.followup-picker-option-meta{font-size:12px;color:#6b7280;line-height:1.5;margin-top:2px;}
.followup-picker-empty{padding:12px 14px;font-size:12px;color:#9ca3af;text-align:center;}
.sample-create-source{margin-bottom:12px;}
.sample-create-source-tabs{display:flex;gap:0;margin-bottom:10px;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;background:#fff;}
.sample-create-source-btn{flex:1;padding:7px 20px;border:none;background:#fff;border-radius:0;font-size:14px;font-weight:600;color:#6b7280;cursor:pointer;font-family:var(--font);transition:all .15s;}
.sample-create-source-btn.is-active{background:#374151;color:#fff;box-shadow:none;}
.sample-create-actions{display:flex;gap:10px;margin-top:16px;}
#sampleFormModal .sample-create-body,
#sampleRecordModal .sample-create-body{font-size:13px !important;color:#111827 !important;}
#sampleFormModal .sample-create-body > div[style*="display:grid;grid-template-columns:1fr 1fr;gap:14px;"],
#sampleRecordModal .sample-create-body > div[style*="display:grid;grid-template-columns:1fr 1fr;gap:14px;"]{display:grid !important;grid-template-columns:repeat(12,minmax(0,1fr)) !important;gap:10px 12px !important;}
#sampleFormModal .sample-create-body > div[style*="display:grid;grid-template-columns:1fr 1fr;gap:14px;"] > .o-row,
#sampleRecordModal .sample-create-body > div[style*="display:grid;grid-template-columns:1fr 1fr;gap:14px;"] > .o-row{grid-column:span 6;gap:6px;background:#fff;padding:10px 12px 11px;border:1px solid #eef2f7;border-radius:12px;box-shadow:0 3px 10px rgba(15,23,42,0.03);}
#sampleFormModal .sample-create-body > div[style*="display:grid;grid-template-columns:1fr 1fr;gap:14px;"] > .o-row > .o-label,
#sampleFormModal .sample-create-body > .o-row > .o-label,
#sampleRecordModal .sample-create-body > div[style*="display:grid;grid-template-columns:1fr 1fr;gap:14px;"] > .o-row > .o-label,
#sampleRecordModal .sample-create-body > .o-row > .o-label{font-size:13px !important;font-weight:800 !important;color:#111827 !important;line-height:1.4 !important;}
#sampleFormModal .sample-create-body > div[style*="display:grid;grid-template-columns:1fr 1fr;gap:14px;"] > .o-row .o-input,
#sampleFormModal .sample-create-body > .o-row .o-input,
#sampleRecordModal .sample-create-body > div[style*="display:grid;grid-template-columns:1fr 1fr;gap:14px;"] > .o-row .o-input,
#sampleRecordModal .sample-create-body > .o-row .o-input,
#sampleRecordModal #sr-custom-wrap .o-input{font-size:13px !important;color:#111827 !important;}
#sampleFormModal .sample-create-body > .o-row[style*="margin-top:14px;"],
#sampleRecordModal .sample-create-body > .o-row[style*="margin-top:14px;"]{gap:6px;background:#fff;padding:10px 12px 11px;border:1px solid #eef2f7;border-radius:12px;box-shadow:0 3px 10px rgba(15,23,42,0.03);margin-top:12px !important;}
#sampleFormModal .sample-create-body > .o-row[style*="margin-top:14px;"]:first-of-type,
#sampleRecordModal .sample-create-body > .o-row[style*="margin-top:14px;"]:first-of-type{margin-top:0 !important;}
#sampleFormModal .sample-create-body > div[style*="display:flex;gap:10px;margin-top:22px;"],
#sampleRecordModal .sample-create-body > div[style*="display:flex;gap:10px;margin-top:22px;"]{display:flex !important;flex-direction:row-reverse !important;gap:10px !important;margin-top:16px !important;}
#sampleFormModal .sample-create-body > div[style*="display:flex;gap:10px;margin-top:22px;"] > button:first-child,
#sampleRecordModal .sample-create-body > div[style*="display:flex;gap:10px;margin-top:22px;"] > button:first-child{flex:1;padding:13px;background:linear-gradient(135deg,#16a34a,#15803d) !important;color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;font-family:var(--font);box-shadow:0 8px 22px rgba(21,128,61,0.22);transition:all .15s;}
#sampleFormModal .sample-create-body > div[style*="display:flex;gap:10px;margin-top:22px;"] > button:last-child,
#sampleRecordModal .sample-create-body > div[style*="display:flex;gap:10px;margin-top:22px;"] > button:last-child{flex:1;padding:13px;background:#fff;border:1.5px solid #e5e7eb;border-radius:12px;font-size:14px;font-weight:600;color:#374151;cursor:pointer;font-family:var(--font);transition:all .15s;}
#sampleFormModal .sample-create-body > div[style*="display:flex;gap:10px;margin-top:22px;"] > button:last-child:hover,
#sampleRecordModal .sample-create-body > div[style*="display:flex;gap:10px;margin-top:22px;"] > button:last-child:hover{background:#f9fafb;}
#sampleRecordModal #sr-customer-row{margin-bottom:12px !important;}
#sampleRecordModal #sr-customer-row > label{font-size:13px !important;font-weight:800 !important;color:#111827 !important;display:block !important;margin-bottom:6px !important;}
#sampleRecordModal #sr-customer-row > div:first-of-type{display:flex !important;gap:8px !important;margin-bottom:10px !important;}
#sampleRecordModal #sr-src-followup,
#sampleRecordModal #sr-src-custom{flex:1;padding:7px 20px !important;border:none !important;background:#fff !important;border-radius:0 !important;font-size:14px !important;font-weight:600 !important;color:#6b7280 !important;cursor:pointer;font-family:var(--font);transition:all .15s;}
#sampleRecordModal #sr-src-followup.is-active,
#sampleRecordModal #sr-src-custom.is-active{background:#374151 !important;color:#fff !important;box-shadow:none !important;}
#sampleRecordModal #sr-followup-sel{padding:10px 12px;border:1.5px solid #e5e7eb;border-radius:10px;font-size:13px;font-family:var(--font);color:#111827;outline:none;width:100%;background:#fff;transition:all .15s;}
#sampleRecordModal #sr-followup-sel:focus{border-color:#16a34a;box-shadow:0 0 0 4px rgba(34,197,94,0.12);}
#sampleRecordModal #sr-custom-wrap > div{display:grid !important;grid-template-columns:1fr 1fr !important;gap:10px !important;margin-top:10px !important;}
@media (max-width: 860px){
  .sample-create-grid{grid-template-columns:1fr 1fr !important;}
  .sample-create-grid > *{grid-column:auto !important;}
  #sampleFormModal .sample-create-body > div[style*="display:grid;grid-template-columns:1fr 1fr;gap:14px;"]{grid-template-columns:1fr 1fr !important;}
  #sampleFormModal .sample-create-body > div[style*="display:grid;grid-template-columns:1fr 1fr;gap:14px;"] > .o-row{grid-column:auto;}
  #sampleRecordModal #sr-custom-wrap > div{grid-template-columns:1fr 1fr !important;}
  #sampleRecordModal .sample-create-body > div[style*="display:grid;grid-template-columns:1fr 1fr;gap:14px;"]{grid-template-columns:1fr 1fr !important;}
  #sampleRecordModal .sample-create-body > div[style*="display:grid;grid-template-columns:1fr 1fr;gap:14px;"] > .o-row{grid-column:auto;}
}
@media (max-width: 640px){
  .sample-create-grid{grid-template-columns:1fr !important;}
  .sample-create-source-tabs{flex-direction:column;}
  #sampleFormModal .sample-create-body > div[style*="display:grid;grid-template-columns:1fr 1fr;gap:14px;"]{grid-template-columns:1fr !important;}
  #sampleRecordModal #sr-custom-wrap > div,
  #sampleRecordModal .sample-create-body > div[style*="display:grid;grid-template-columns:1fr 1fr;gap:14px;"]{grid-template-columns:1fr !important;}
}
@media (max-width: 860px){
  .order-create-body{grid-template-columns:1fr 1fr !important;}
  .order-create-grid > *,
  .order-create-body > .order-create-panel,
  .order-create-body > .order-create-note,
  .order-create-body > .order-create-actions{grid-column:auto !important;}
  .order-create-panel-grid{grid-template-columns:1fr 1fr 1fr !important;}
  .order-create-note-head,
  .order-create-panel-head{flex-wrap:wrap;}
}
@media (max-width: 640px){
  .order-create-body,
  .order-create-panel-grid{grid-template-columns:1fr !important;}
  .order-create-item-head{display:none;}
  .order-create-panel-summary{align-items:flex-start;flex-direction:column;}
}
.order-row{display:flex;align-items:center;gap:8px;padding:10px 0;border-bottom:1px solid var(--border);flex-wrap:wrap;font-size:13px;}
.order-row:last-child{border-bottom:none;}
.o-date{color:#9ca3af;font-size:12px;min-width:85px;}
.o-name{font-weight:600;color:#111827;min-width:120px;}
.o-amt{font-weight:700;color:#7c3aed;min-width:90px;}
.o-tag{font-size:11px;padding:2px 8px;border-radius:6px;font-weight:500;}
.o-paid{background:#dcfce7;color:#15803d;}
.o-unpaid{background:#fee2e2;color:#b91c1c;}
.o-tag-ship{background:#dbeafe;color:#1d4ed8;}
.o-tag-arr{background:#dcfce7;color:#15803d;}
.o-tag-ns{background:#f3f4f6;color:#9ca3af;}
.ord-tab{padding:5px 14px;border-radius:6px;border:1.5px solid #e5e7eb;background:white;font-size:13px;font-weight:500;cursor:pointer;font-family:var(--font);}
.ord-tab.active{background:#7c3aed;color:white;border-color:#7c3aed;}
.fp-tab{padding:4px 10px;border-radius:20px;border:1.5px solid #e5e7eb;background:white;font-size:12px;font-weight:500;cursor:pointer;font-family:var(--font);transition:all .15s;}
.fp-tab:hover{background:#f5f3ff;border-color:#ddd6fe;color:#7c3aed;}
.fp-tab.active{background:#7c3aed;color:white;border-color:#7c3aed;}
.ord-tab.active{background:#7c3aed;color:white;border-color:#7c3aed;}
.o-del{font-size:11px;color:#ef4444;cursor:pointer;padding:2px 8px;border-radius:5px;border:1px solid #fecaca;background:white;font-family:var(--font);}
.o-del:hover{background:#fee2e2;}
@keyframes rowIn{from{opacity:0;transform:translateX(-4px);}to{opacity:1;transform:none;}}
tbody tr{animation:rowIn .18s ease both;}

/* ==================== 登录页面 ==================== */
/* 隐藏浏览器自带的密码显示按钮 */
input::-ms-reveal, input::-ms-clear { display:none; }
input::-webkit-credentials-auto-fill-button { display:none !important; }
.pw-wrap { position:relative; width:100%; }
.pw-wrap input { padding-right:44px; }
.pw-eye { position:absolute; right:12px; top:50%; transform:translateY(-50%); background:none; border:none; cursor:pointer; padding:4px; line-height:1; opacity:0.5; transition:opacity .15s; }
.pw-eye:hover { opacity:0.85; }
html.auth-pending #loginPage,
html.auth-pending #registerPage,
html.auth-has-session #loginPage,
html.auth-has-session #registerPage { display:none !important; }
html.auth-no-session[data-auth-screen="register"] #loginPage{display:none !important;}
html.auth-no-session[data-auth-screen="register"] #registerPage{display:flex !important;}
html.auth-no-session[data-auth-screen="login"] #registerPage{display:none !important;}
html.auth-has-session #appWrap{display:block !important;}
html.auth-no-session #appWrap,
html.auth-pending #appWrap{display:none !important;}
html.auth-has-session[data-boot-page="mine"] #tbl-ocean{display:none !important;}
html.auth-has-session[data-boot-page="mine"] #tbl-mine{display:table !important;}
html.auth-has-session[data-boot-page="mine"] #btn-add-private{display:inline-flex !important;}
html.auth-has-session[data-boot-page="mine"] #btn-share,
html.auth-has-session[data-boot-page="mine"] #topbar-credits,
html.auth-has-session[data-boot-page="guide"] #btn-share,
html.auth-has-session[data-boot-page="guide"] #topbar-credits,
html.auth-has-session[data-boot-page="demand"] #btn-share,
html.auth-has-session[data-boot-page="demand"] #topbar-credits,
html.auth-has-session[data-boot-page="followup"] #btn-share,
html.auth-has-session[data-boot-page="followup"] #topbar-credits,
html.auth-has-session[data-boot-page="sales"] #btn-share,
html.auth-has-session[data-boot-page="sales"] #topbar-credits,
html.auth-has-session[data-boot-page="shares"] #btn-share,
html.auth-has-session[data-boot-page="shares"] #topbar-credits,
html.auth-has-session[data-boot-page="settings"] #btn-share,
html.auth-has-session[data-boot-page="settings"] #topbar-credits,
html.auth-has-session[data-boot-page="points"] #btn-share,
html.auth-has-session[data-boot-page="points"] #topbar-credits,
html.auth-has-session[data-boot-page="orders"] #btn-share,
html.auth-has-session[data-boot-page="orders"] #topbar-credits,
html.auth-has-session[data-boot-page="samples"] #btn-share,
html.auth-has-session[data-boot-page="samples"] #topbar-credits{display:none !important;}
html.auth-has-session[data-boot-page="followup"] .filterbar,
html.auth-has-session[data-boot-page="followup"] .table-area,
html.auth-has-session[data-boot-page="followup"] .pager,
html.auth-has-session[data-boot-page="guide"] .filterbar,
html.auth-has-session[data-boot-page="guide"] .table-area,
html.auth-has-session[data-boot-page="guide"] .pager,
html.auth-has-session[data-boot-page="demand"] .filterbar,
html.auth-has-session[data-boot-page="demand"] .table-area,
html.auth-has-session[data-boot-page="demand"] .pager,
html.auth-has-session[data-boot-page="sales"] .filterbar,
html.auth-has-session[data-boot-page="sales"] .table-area,
html.auth-has-session[data-boot-page="sales"] .pager,
html.auth-has-session[data-boot-page="shares"] .filterbar,
html.auth-has-session[data-boot-page="shares"] .table-area,
html.auth-has-session[data-boot-page="shares"] .pager,
html.auth-has-session[data-boot-page="settings"] .filterbar,
html.auth-has-session[data-boot-page="settings"] .table-area,
html.auth-has-session[data-boot-page="settings"] .pager,
html.auth-has-session[data-boot-page="points"] .filterbar,
html.auth-has-session[data-boot-page="points"] .table-area,
html.auth-has-session[data-boot-page="points"] .pager,
html.auth-has-session[data-boot-page="orders"] .filterbar,
html.auth-has-session[data-boot-page="orders"] .table-area,
html.auth-has-session[data-boot-page="orders"] .pager,
html.auth-has-session[data-boot-page="samples"] .filterbar,
html.auth-has-session[data-boot-page="samples"] .table-area,
html.auth-has-session[data-boot-page="samples"] .pager{display:none !important;}
html.auth-has-session[data-boot-page="academy"] .filterbar,
html.auth-has-session[data-boot-page="academy"] .table-area,
html.auth-has-session[data-boot-page="academy"] .pager{display:none !important;}
html.auth-has-session[data-boot-page="followup"] #page-followup,
html.auth-has-session[data-boot-page="academy"] #page-academy,
html.auth-has-session[data-boot-page="demand"] #page-demand,
html.auth-has-session[data-boot-page="guide"] #page-guide,
html.auth-has-session[data-boot-page="sales"] #page-sales,
html.auth-has-session[data-boot-page="shares"] #page-shares,
html.auth-has-session[data-boot-page="settings"] #page-settings,
html.auth-has-session[data-boot-page="points"] #page-points,
html.auth-has-session[data-boot-page="orders"] #page-orders,
html.auth-has-session[data-boot-page="samples"] #page-samples{display:block !important;}
.purchase-demand-page{
  display:none;position:absolute;left:var(--sidebar);right:0;top:var(--topbar);bottom:0;
  overflow:auto;background:#f4f5fc;
}
html[data-current-page="demand"] .purchase-demand-page,
html.auth-has-session[data-boot-page="demand"] .purchase-demand-page{top:260px;}
.purchase-demand-headbar{
  min-height:76px;display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:18px 28px;background:#fff;border-top:1px solid var(--border);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:6;box-sizing:border-box;
}
.purchase-demand-heading{display:flex;align-items:center;gap:14px;min-width:0;}
.purchase-demand-title{font-size:23px;font-weight:800;color:#111827;line-height:1.2;white-space:nowrap;}
.purchase-demand-head-actions{display:flex;align-items:center;justify-content:flex-end;gap:12px;margin-left:auto;min-width:0;}
.purchase-demand-refresh{
  height:36px;padding:0 16px;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#374151;
  font-size:13px;font-weight:700;cursor:pointer;font-family:var(--font);
}
.purchase-demand-refresh:hover{background:#f8fafc;border-color:#9ca3af;}
.purchase-demand-content{padding:14px 28px 34px;}
.purchase-demand-stats{display:flex;align-items:center;gap:10px;flex-wrap:wrap;min-height:30px;}
.purchase-demand-stat{
  display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 12px;border:1px solid #e5e7eb;border-radius:8px;
  background:#f8fafc;color:#475569;font-size:13px;font-weight:700;
}
.purchase-demand-stat strong{color:#111827;font-size:15px;}
.purchase-demand-stat.is-new-demand{color:#16a34a;border-color:#bbf7d0;background:#f0fdf4;}
.purchase-demand-stat.is-new-demand strong{color:#16a34a;}
.purchase-demand-table-card{overflow:auto;background:#fff;border:1px solid #e5e7eb;border-radius:8px;}
.purchase-demand-table{width:100%;min-width:980px;border-collapse:collapse;table-layout:fixed;}
.purchase-demand-table th{
  position:static;height:42px;padding:0 12px;background:#f8fafc;border-bottom:1px solid #e5e7eb;
  color:#374151;font-size:13px;font-weight:800;text-align:left;white-space:nowrap;
}
.purchase-demand-table td{
  height:auto;padding:13px 12px;border-bottom:1px solid #eef2f7;color:#111827;font-size:13px;line-height:1.65;
  text-align:left;white-space:normal;word-break:break-word;overflow:visible;vertical-align:top;
}
.purchase-demand-table tr:last-child td{border-bottom:none;}
.purchase-demand-requirement{
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:3;
  max-height:4.8em;
  overflow:hidden;
  line-height:1.6;
  word-break:break-word;
}
.purchase-demand-time{font-variant-numeric:tabular-nums;color:#475569;font-weight:700;}
.purchase-demand-mode{display:block;width:max-content;margin-bottom:5px;padding:2px 6px;border-radius:5px;background:#eef2ff;color:#4f46e5;font-size:11px;font-weight:700;line-height:1.4;}
.purchase-demand-mode.is-plaza{background:#fff7ed;color:#c2410c;}
.purchase-demand-ended td{background:#f8fafc;color:#94a3b8;}
.purchase-demand-ended-tag{display:inline-flex;align-items:center;margin:0 0 5px 6px;padding:2px 6px;border-radius:999px;background:#e5e7eb;color:#64748b;font-size:11px;font-weight:800;line-height:1.4;}
.purchase-demand-contact-hidden{color:#9ca3af;font-weight:600;}
.purchase-demand-view-btn{height:30px;min-width:126px;padding:0 12px;border:1px solid #16a34a;border-radius:8px;background:#22c55e;color:#fff;font-size:12px;font-weight:800;cursor:pointer;font-family:var(--font);line-height:1;white-space:nowrap;box-shadow:0 6px 14px rgba(34,197,94,.22);}
.purchase-demand-view-btn:hover{background:#16a34a;border-color:#15803d;}
.purchase-demand-status-new{display:inline-flex;align-items:center;height:22px;padding:0 8px;border-radius:999px;background:#dcfce7;color:#15803d;font-size:12px;font-weight:800;}
.purchase-demand-status-read{display:inline-flex;align-items:center;height:22px;padding:0 8px;border-radius:999px;background:#f1f5f9;color:#64748b;font-size:12px;font-weight:700;}
.purchase-demand-status-ended{display:inline-flex;align-items:center;min-height:22px;padding:4px 8px;border-radius:999px;background:#e5e7eb;color:#64748b;font-size:12px;font-weight:800;line-height:1.2;}
.purchase-demand-empty{padding:52px 20px !important;text-align:center !important;color:#9ca3af !important;font-size:14px !important;}
.academy-page{
  display:none;position:absolute;left:var(--sidebar);right:0;top:var(--topbar);bottom:0;
  overflow:auto;background:#fff;
}
.academy-shell{max-width:1240px;margin:0 auto;padding:26px 28px 48px;}
.academy-hero{
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  padding-bottom:16px;margin-bottom:20px;border-bottom:1px solid #e5e7eb;
}
.academy-hero-copy{min-width:0;}
.academy-kicker{font-size:13px;font-weight:800;color:#6b7280;margin-bottom:8px;}
.academy-hero-title{font-size:26px;line-height:1.2;color:#111827;margin:0 10px 0 0;font-weight:700;white-space:nowrap;}
.academy-hero-desc{font-size:14px;line-height:1.7;color:#4b5563;margin:0;min-width:360px;flex:1 1 390px;}
.academy-hero-actions{display:flex;align-items:center;gap:10px;flex-shrink:0;margin-left:auto;}
.academy-submit-btn,.academy-my-submissions-btn{
  height:38px;border-radius:8px;padding:0 16px;font-size:13px;font-weight:800;cursor:pointer;
  transition:background .15s ease,border-color .15s ease,color .15s ease;
}
.academy-submit-btn{border:1px solid #111827;background:#111827;color:#fff;}
.academy-submit-btn:hover{background:#000;border-color:#000;}
.academy-my-submissions-btn{border:1px solid #d1d5db;background:#fff;color:#111827;}
.academy-my-submissions-btn:hover{border-color:#111827;}
.academy-toolbar{display:flex;align-items:center;gap:18px;margin-bottom:24px;flex-wrap:wrap;}
.academy-hero-tools{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.academy-search-input{
  width:240px;padding:9px 12px;border-radius:8px;border:1px solid #d1d5db;background:#fff;
  font-size:13px;color:#111827;outline:none;box-shadow:none;
}
.academy-search-input:focus{border-color:#111827;box-shadow:0 0 0 3px rgba(17,24,39,0.08);}
.academy-category-tabs{display:flex;flex-wrap:wrap;gap:8px;}
.academy-category-chip{
  border:1px solid #e5e7eb;border-radius:8px;padding:7px 10px;background:#fff;color:#4b5563;
  font-size:13px;font-weight:700;cursor:pointer;transition:border-color .15s ease,background .15s ease,color .15s ease;
}
.academy-category-chip:hover{border-color:#9ca3af;color:#111827;}
.academy-category-chip.active{background:#111827;border-color:#111827;color:#fff;}
.academy-panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px;}
.academy-panel-head--compact{margin-bottom:8px;}
.academy-panel-title{font-size:15px;font-weight:800;color:#111827;}
.academy-count-tag{font-size:12px;font-weight:700;color:#6b7280;margin-left:4px;}
.academy-card-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:12px;color:#6b7280;margin-bottom:12px;}
.academy-card-badge,.academy-card-cat{display:inline-flex;align-items:center;padding:3px 8px;border-radius:6px;font-weight:700;}
.academy-card-badge{background:#111827;color:#fff;}
.academy-card-cat{background:#f3f4f6;color:#374151;}
.academy-main{display:block;}
.academy-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:34px 20px;}
.academy-article-card{display:flex;flex-direction:column;min-width:0;background:#fff;}
.academy-card-cover{
  width:100%;aspect-ratio:1.92/1;border:1px solid #e5e7eb;background:#f3f4f6;overflow:hidden;border-radius:0;
}
.academy-card-cover img{width:100%;height:100%;display:block;object-fit:cover;}
.academy-card-cover-empty{height:100%;display:flex;align-items:center;justify-content:center;color:#9ca3af;font-size:13px;font-weight:700;}
.academy-card-new-badge{display:inline-flex;width:max-content;align-items:center;margin-top:14px;padding:3px 8px;border-radius:6px;background:#dcfce7;color:#15803d;font-size:12px;font-weight:900;line-height:1.3;}
.academy-card-title{margin:18px 0 8px;font-size:22px;line-height:1.28;font-weight:900;color:#111827;}
.academy-card-summary{font-size:15px;line-height:1.75;color:#111827;min-height:52px;}
.academy-read-link{
  width:max-content;margin-top:18px;border:none;background:transparent;border-bottom:1px solid #111827;
  color:#111827;font-size:14px;line-height:1.6;font-weight:900;font-style:italic;cursor:pointer;padding:0 0 2px;
}
.academy-card-footer{margin-top:26px;padding-top:12px;border-top:1px solid #e5e7eb;font-size:13px;font-weight:800;color:#111827;}
.academy-card-footer span{color:#6b7280;margin:0 6px;}
.academy-modal-overlay{position:fixed;inset:0;background:rgba(17,24,39,0.45);z-index:9999;align-items:center;justify-content:center;padding:24px;}
.academy-article-modal,.academy-submit-modal{
  position:relative;width:min(900px,94vw);max-height:90vh;overflow:auto;background:#fff;border-radius:8px;
  box-shadow:0 24px 70px rgba(0,0,0,0.22);padding:30px 34px 36px;
}
.academy-submit-modal{width:min(760px,94vw);}
.academy-status-modal{width:min(820px,94vw);}
.academy-modal-close{
  position:absolute;right:16px;top:14px;width:34px;height:34px;border-radius:8px;border:1px solid #e5e7eb;
  background:#fff;color:#111827;font-size:22px;line-height:1;cursor:pointer;
}
.academy-modal-title{font-size:24px;font-weight:900;color:#111827;margin-bottom:8px;}
.academy-modal-subtitle{font-size:13px;line-height:1.7;color:#6b7280;margin-bottom:18px;}
.academy-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.academy-form-field{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:800;color:#374151;}
.academy-form-field-wide{grid-column:1/-1;}
.academy-form-field input,.academy-form-field select,.academy-form-field textarea{
  width:100%;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#111827;
  padding:10px 12px;font-size:14px;line-height:1.7;font-family:var(--font);outline:none;
}
.academy-form-field textarea{resize:vertical;}
.academy-form-field input:focus,.academy-form-field select:focus,.academy-form-field textarea:focus{
  border-color:#111827;box-shadow:0 0 0 3px rgba(17,24,39,0.08);
}
.academy-submit-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px;}
.academy-cancel-btn,.academy-submit-confirm-btn{
  height:38px;border-radius:8px;padding:0 16px;font-size:13px;font-weight:800;cursor:pointer;
}
.academy-cancel-btn{border:1px solid #d1d5db;background:#fff;color:#111827;}
.academy-submit-confirm-btn{border:1px solid #111827;background:#111827;color:#fff;}
.academy-submit-notice{border-radius:8px;padding:10px 12px;margin-bottom:14px;font-size:13px;font-weight:700;line-height:1.7;}
.academy-submit-notice.is-error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;}
.academy-submit-notice.is-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534;}
.academy-submission-list{display:grid;gap:10px;}
.academy-submission-item{border:1px solid #e5e7eb;border-radius:8px;padding:14px;background:#fff;}
.academy-submission-top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:6px;}
.academy-submission-title{font-size:15px;font-weight:900;color:#111827;line-height:1.5;}
.academy-submission-meta{font-size:12px;color:#6b7280;line-height:1.7;}
.academy-status-tag{display:inline-flex;align-items:center;border-radius:999px;padding:4px 9px;font-size:12px;font-weight:900;white-space:nowrap;}
.academy-status-pending{background:#fef3c7;color:#b45309;}
.academy-status-published{background:#dcfce7;color:#15803d;}
.academy-status-rejected{background:#fee2e2;color:#b91c1c;}
.academy-status-draft,.academy-status-offline{background:#f3f4f6;color:#4b5563;}
.academy-detail-empty{
  min-height:320px;display:flex;align-items:center;justify-content:center;
  border:1px dashed #d1d5db;border-radius:8px;background:#fafafa;color:#9ca3af;font-size:14px;
}
.academy-doc{max-width:760px;margin:0 auto;}
.academy-detail-head{padding-bottom:20px;margin-bottom:24px;}
.academy-detail-title{font-size:32px;line-height:1.26;color:#111827;font-weight:800;margin:14px 0 18px;}
.academy-detail-summary{font-size:14px;line-height:1.9;color:#111827;background:#fff7d6;border-radius:8px;padding:14px 16px;margin-bottom:0;}
.academy-detail-content{font-size:15px;line-height:1.95;color:#111827;}
.academy-detail-content h3{font-size:21px;line-height:1.45;color:#111827;margin:30px 0 10px;font-weight:800;}
.academy-detail-content p{margin:0 0 14px;}
.academy-detail-content ul,
.academy-detail-content ol{margin:0 0 20px;padding-left:22px;}
.academy-detail-content li{margin:6px 0;}
#academyArticleModal.academy-modal-overlay{padding:0;background:#020202;align-items:flex-start;justify-content:center;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;}
#academyArticleModal .academy-article-modal{
  width:100vw;max-width:none;min-height:100vh;max-height:none;overflow:visible;background:#020202;color:#f8fafc;
  border-radius:0;box-shadow:none;padding:0;
}
#academyArticleModal .academy-modal-close{
  position:fixed;right:32px;top:48px;z-index:5;min-width:78px;height:42px;padding:0 18px;border-radius:999px;
  border:1px solid #0f172a;background:#0f172a;color:#ffffff;font-size:15px;font-weight:900;
  box-shadow:0 12px 30px rgba(15,23,42,.22);
}
#academyArticleModal .academy-modal-close:hover{background:#020617;border-color:#020617;}
#academyArticleModal .academy-doc{max-width:760px;margin:0 auto;padding:86px 30px 120px;}
#academyArticleModal .academy-detail-head{padding-bottom:42px;margin-bottom:18px;}
#academyArticleModal .academy-card-meta{gap:14px;margin-bottom:34px;color:#cbd5e1;font-size:16px;line-height:1.7;}
#academyArticleModal .academy-card-cat{background:#111827;color:#f8fafc;border:1px solid #334155;}
#academyArticleModal .academy-card-badge{background:#f8fafc;color:#020617;}
#academyArticleModal .academy-reader-theme-btn{
  margin-left:auto;
  border:1px solid #334155;background:#0f172a;color:#f8fafc;border-radius:999px;
  padding:6px 12px;font-size:13px;font-weight:800;cursor:pointer;font-family:var(--font);
}
#academyArticleModal .academy-reader-theme-btn:hover{border-color:#64748b;background:#1e293b;}
#academyArticleModal .academy-detail-title{font-size:42px;line-height:1.14;color:#ffffff;font-weight:900;margin:0 0 24px;}
#academyArticleModal .academy-detail-summary{
  background:transparent;border-left:3px solid #facc15;border-radius:0;padding:0 0 0 18px;
  color:#e5e7eb;font-size:18px;line-height:1.85;margin:0;
}
#academyArticleModal .academy-detail-content{font-size:18px;line-height:1.9;color:#f1f5f9;}
#academyArticleModal .academy-detail-content p{margin:0 0 22px;}
#academyArticleModal .academy-detail-content h2,
#academyArticleModal .academy-detail-content h3,
#academyArticleModal .academy-detail-content h4{color:#ffffff;font-weight:900;line-height:1.28;}
#academyArticleModal .academy-detail-content h2{font-size:30px;margin:48px 0 18px;}
#academyArticleModal .academy-detail-content h3{font-size:24px;margin:38px 0 14px;}
#academyArticleModal .academy-detail-content h4{font-size:20px;margin:30px 0 12px;}
#academyArticleModal .academy-detail-content strong{
  color:#ffffff;font-weight:900;background:none;
}
#academyArticleModal .academy-detail-content ul,
#academyArticleModal .academy-detail-content ol{margin:0 0 24px;padding-left:24px;}
#academyArticleModal .academy-detail-content li{margin:10px 0;padding-left:4px;}
#academyArticleModal .academy-detail-content hr{border:0;border-top:1px solid #334155;margin:42px 0;}
#academyArticleModal[data-reader-theme="light"].academy-modal-overlay{background:#f8fafc;}
#academyArticleModal[data-reader-theme="light"] .academy-article-modal{background:#f8fafc;color:#111827;}
#academyArticleModal[data-reader-theme="light"] .academy-modal-close{background:#0f172a;color:#ffffff;border-color:#0f172a;}
#academyArticleModal[data-reader-theme="light"] .academy-modal-close:hover{background:#020617;border-color:#020617;}
#academyArticleModal[data-reader-theme="light"] .academy-card-meta{color:#64748b;}
#academyArticleModal[data-reader-theme="light"] .academy-card-cat{background:#e2e8f0;color:#0f172a;border-color:#cbd5e1;}
#academyArticleModal[data-reader-theme="light"] .academy-card-badge{background:#111827;color:#ffffff;}
#academyArticleModal[data-reader-theme="light"] .academy-reader-theme-btn{background:#fff;color:#111827;border-color:#cbd5e1;}
#academyArticleModal[data-reader-theme="light"] .academy-reader-theme-btn:hover{background:#f1f5f9;border-color:#94a3b8;}
#academyArticleModal[data-reader-theme="light"] .academy-detail-title,
#academyArticleModal[data-reader-theme="light"] .academy-detail-content h2,
#academyArticleModal[data-reader-theme="light"] .academy-detail-content h3,
#academyArticleModal[data-reader-theme="light"] .academy-detail-content h4{color:#0f172a;}
#academyArticleModal[data-reader-theme="light"] .academy-detail-summary{color:#334155;}
#academyArticleModal[data-reader-theme="light"] .academy-detail-content{color:#111827;}
#academyArticleModal[data-reader-theme="light"] .academy-detail-content strong{color:#0f172a;background:none;}
#academyArticleModal[data-reader-theme="light"] .academy-detail-content hr{border-top-color:#cbd5e1;}
.academy-empty-card{
  border:1px dashed #d1d5db;border-radius:8px;padding:22px 16px;margin:0 16px;
  text-align:center;color:#9ca3af;background:#fafafa;font-size:14px;
}
@media (max-width: 980px){
  .academy-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}
.guide-page{
  display:none;position:absolute;left:var(--sidebar);right:0;top:var(--topbar);bottom:0;
  overflow:auto;background:#fff;
}
.guide-wrap{max-width:900px;margin:0 auto;padding:28px 28px 44px;}
.guide-block{
  background:#fff;border:1px solid #111827;border-radius:18px;
  padding:26px 28px;margin-bottom:16px;box-shadow:0 1px 4px rgba(0,0,0,0.04);
}
.guide-top-label{
  font-size:12px;font-weight:700;letter-spacing:.08em;color:#9ca3af;text-transform:uppercase;
  margin-bottom:10px;
}
.guide-title{
  margin:0 0 12px;font-size:30px;line-height:1.2;font-weight:800;color:#111827;
}
.guide-text{
  font-size:15px;line-height:1.9;color:#4b5563;
}
.guide-rule-box{
  margin-top:18px;padding:18px 20px;border-radius:14px;background:#f8fafc;border:1px solid #e5e7eb;
}
.guide-subtitle{
  margin:0 0 12px;font-size:18px;font-weight:800;color:#111827;
}
.guide-rule-list,.guide-summary-list{
  display:grid;gap:10px;
}
.guide-rule-item,.guide-summary-item{
  font-size:14px;line-height:1.9;color:#374151;
}
.guide-rule-strong,.guide-summary-strong{
  color:#111827;font-weight:800;
}
.guide-steps{
  display:grid;gap:14px;margin-top:14px;
}
.guide-step{
  display:flex;gap:14px;align-items:flex-start;padding:18px 0;border-top:1px solid #f1f5f9;
}
.guide-step:first-child{border-top:none;padding-top:0;}
.guide-step-no{
  width:30px;height:30px;border-radius:50%;background:#111827;color:#fff;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;
}
.guide-step-main{flex:1;min-width:0;}
.guide-step-title{
  margin:0 0 8px;font-size:18px;font-weight:800;color:#111827;
}
.guide-step-text{
  font-size:14px;line-height:1.9;color:#4b5563;
}
.guide-key{
  display:inline-flex;align-items:center;justify-content:center;min-height:26px;
  padding:0 10px;border-radius:8px;background:#f3f4f6;border:1px solid #e5e7eb;
  color:#111827;font-size:12px;font-weight:700;vertical-align:middle;margin:0 2px;
}
.guide-summary-text{
  font-size:14px;line-height:1.9;color:#4b5563;margin-bottom:12px;
}
@media (max-width: 640px){
  .academy-shell{padding:16px 14px 28px;}
  .academy-hero{display:block;padding-bottom:18px;}
  .academy-hero-title{margin-bottom:12px;}
  .academy-hero-actions{margin-top:14px;justify-content:flex-start;flex-wrap:wrap;}
  .academy-toolbar{display:block;margin-bottom:20px;}
  .academy-hero-desc{min-width:0;margin-bottom:12px;}
  .academy-hero-tools{width:100%;margin-top:14px;}
  .academy-search-input{width:100%;}
  .academy-hero-title{font-size:26px;}
  .academy-grid{grid-template-columns:1fr;gap:28px;}
  .academy-card-title{font-size:20px;}
  .academy-article-modal,.academy-submit-modal{padding:24px 18px;width:96vw;}
  #academyArticleModal .academy-article-modal{width:100vw;padding:0;}
  #academyArticleModal .academy-doc{padding:72px 22px 88px;}
  #academyArticleModal .academy-detail-title{font-size:32px;}
  #academyArticleModal .academy-detail-summary{font-size:16px;}
  #academyArticleModal .academy-detail-content{font-size:16px;line-height:1.85;}
  #academyArticleModal .academy-modal-close{right:16px;top:24px;min-width:70px;height:40px;padding:0 14px;}
  .academy-form-grid{grid-template-columns:1fr;}
  .academy-detail-title{font-size:25px;}
  .guide-wrap{padding:18px 14px 30px;}
  .guide-block{padding:20px 18px;border-radius:16px;}
  .guide-title{font-size:26px;}
  .guide-step-title{font-size:17px;}
}
.theme-toggle-btn{
    display:inline-flex;align-items:center;justify-content:center;gap:8px;
    padding:10px 16px;border:1px solid var(--border);border-radius:10px;
    background:var(--white);color:var(--text);font-size:13px;font-weight:700;
    cursor:pointer;font-family:var(--font);transition:all .15s;white-space:nowrap;
}
.theme-toggle-btn:hover{background:var(--bg);box-shadow:0 4px 14px rgba(15,23,42,0.08);}
.theme-dark{color-scheme:dark;}
html.auth-has-session.theme-dark body{background:#020617;}
.theme-dark{
    --text:#e5eefc;
    --text2:#94a3b8;
    --text3:#64748b;
    --border:#243041;
    --bg:#0b1220;
    --white:#0f172a;
    --blue:#60a5fa;
    --blue-l:#172554;
}
.theme-dark .app-wrap{background:#0b1220;box-shadow:0 20px 60px rgba(0,0,0,0.45);}
.theme-dark .sidebar,
.theme-dark .topbar,
.theme-dark .filterbar,
.theme-dark .table-area,
.theme-dark .table-area > .inner,
.theme-dark .sb-bottom{background:#0f172a !important;border-color:#243041 !important;}
.theme-dark .nav-item:hover,
.theme-dark .nav-item.active,
.theme-dark .sb-user:hover,
.theme-dark .t-icon:hover,
.theme-dark .f-reset:hover,
.theme-dark .theme-toggle-btn:hover{background:rgba(148,163,184,0.12) !important;}
.theme-dark .t-icon,
.theme-dark .f-sel,
.theme-dark .f-reset,
.theme-dark .theme-toggle-btn,
.theme-dark #search-pool{
    background:#111827 !important;
    color:#e5eefc !important;
    border-color:#243041 !important;
}
.theme-dark #topbar-credits{
    background:#111827 !important;
    color:#94a3b8 !important;
    box-shadow:inset 0 0 0 1px #243041;
}
.theme-dark #topbar-credits span{color:inherit !important;}
.theme-dark #topbar-credit-num{color:#a78bfa !important;}
.theme-dark .purchase-demand-page{background:#0b1220;}
.theme-dark .purchase-demand-headbar,
.theme-dark .purchase-demand-table-card,
.theme-dark .purchase-demand-stat{background:#0f172a;border-color:#243041;}
.theme-dark .purchase-demand-title,
.theme-dark .purchase-demand-stat strong,
.theme-dark .purchase-demand-table td{color:#e5eefc;}
.theme-dark .purchase-demand-stat{background:#111827;}
.theme-dark .purchase-demand-stat.is-new-demand{background:#052e1a;border-color:#166534;color:#86efac;}
.theme-dark .purchase-demand-stat.is-new-demand strong{color:#86efac;}
.theme-dark .purchase-demand-time{color:#94a3b8;}
.theme-dark .purchase-demand-refresh,
.theme-dark .purchase-demand-view-btn,
.theme-dark .purchase-demand-table th{background:#111827;color:#cbd5e1;border-color:#334155;}
.theme-dark .purchase-demand-table td{border-color:#243041;}
.theme-dark .purchase-demand-refresh:hover,
.theme-dark .purchase-demand-view-btn:hover{background:#1e293b;}
.theme-dark .purchase-demand-view-btn{background:#22c55e;color:#fff;border-color:#16a34a;box-shadow:0 6px 14px rgba(34,197,94,.18);}
.theme-dark .purchase-demand-view-btn:hover{background:#16a34a;border-color:#15803d;}
.theme-dark .purchase-demand-ended td{background:#111827;color:#64748b;}
.theme-dark .purchase-demand-ended-tag,
.theme-dark .purchase-demand-status-ended{background:#1e293b;color:#94a3b8;}
.theme-dark .sb-logo-icon{background:#111827;}
.theme-dark .app-wrap input:not(.login-box input):not(.register-box input),
.theme-dark .app-wrap select:not(.fo-stage-pill-select),
.theme-dark .app-wrap textarea{
    background:#111827 !important;
    color:#e5eefc !important;
    border-color:#243041 !important;
}
.theme-dark .app-wrap input::placeholder,
.theme-dark .app-wrap textarea::placeholder{color:#64748b !important;}
.theme-dark .app-wrap table,
.theme-dark .app-wrap th,
.theme-dark .app-wrap td{border-color:#243041 !important;color:#e5eefc;}
.theme-dark #order-table thead th,
.theme-dark #followup-list-tbl thead th,
.theme-dark #sample-table thead th,
.theme-dark #fo-table thead th,
.theme-dark thead th{background:#111827 !important;color:#cbd5e1 !important;border-bottom-color:#243041 !important;}
.theme-dark #order-table tbody tr:hover,
.theme-dark #sample-table tbody tr:hover,
.theme-dark #followup-list-tbl tbody tr:hover,
.theme-dark #fo-table tbody tr:hover,
.theme-dark #tbl-shares tbody tr:hover,
.theme-dark tbody tr:hover{background:#111827 !important;}
.theme-dark #tbl-ocean tbody tr:hover,
.theme-dark #tbl-mine tbody tr:hover,
.theme-dark #tbl-ocean tbody tr.table-row-hover-active,
.theme-dark #tbl-mine tbody tr.table-row-hover-active{background:#111827 !important;}
.theme-dark .modal,
.theme-dark .detail-modal-panel,
.theme-dark .fo-detail-panel,
.theme-dark .order-create-modal,
.theme-dark .private-form-header,
.theme-dark .private-form-row,
.theme-dark .order-create-grid .o-row,
.theme-dark .order-create-note,
.theme-dark .order-create-panel,
.theme-dark .dash-card,
.theme-dark .settings-card,
.theme-dark .dash-kpi-card,
.theme-dark .dash-action-bar,
.theme-dark .detail-feedback-score,
.theme-dark .fo-card,
.theme-dark .fo-row-overlay{
    background:#0f172a !important;
    color:#e5eefc !important;
    border-color:#243041 !important;
}
.theme-dark .fo-latest-floating{
    background:#0f172a !important;
    color:#e5eefc !important;
    border-color:#000 !important;
}
.theme-dark [style*="background:white"],
.theme-dark [style*="background: white"],
.theme-dark [style*="background:#fff"],
.theme-dark [style*="background: #fff"]{
    background:#0f172a !important;
    border-color:#243041 !important;
}
.theme-dark [style*="color:#111827"],
.theme-dark [style*="color: #111827"],
.theme-dark [style*="color:#374151"],
.theme-dark [style*="color: #374151"]{color:#e5eefc !important;}
.theme-dark [style*="color:#6b7280"],
.theme-dark [style*="color: #6b7280"],
.theme-dark [style*="color:#9ca3af"],
.theme-dark [style*="color: #9ca3af"]{color:#94a3b8 !important;}
.theme-dark .detail-head-btn,
.theme-dark .detail-inline-btn,
.theme-dark .fo-dp-remove-btn,
.theme-dark .fo-dp-close{
    background:#111827 !important;
    color:#e5eefc !important;
    border-color:#243041 !important;
}
.theme-dark #detail-info-bar,
.theme-dark #detail-chart-area,
.theme-dark #detail-body{
    background:#111827 !important;
    border-color:#243041 !important;
}
.theme-dark #detailModal [style*="background:white"],
.theme-dark #detailModal [style*="background: white"],
.theme-dark #detailModal [style*="background:#fff"],
.theme-dark #detailModal [style*="background: #fff"],
.theme-dark #detailModal [style*="background:#f9fafb"],
.theme-dark #detailModal [style*="background: #f9fafb"],
.theme-dark #detailModal [style*="background:#f0fdf4"],
.theme-dark #detailModal [style*="background: #f0fdf4"]{
    background:#111827 !important;
    border-color:#243041 !important;
    box-shadow:none !important;
}
.theme-dark #detailModal [style*="color:#111827"],
.theme-dark #detailModal [style*="color: #111827"],
.theme-dark #detailModal [style*="color:#374151"],
.theme-dark #detailModal [style*="color: #374151"]{
    color:#e5eefc !important;
}
.theme-dark #detailModal [style*="color:#6b7280"],
.theme-dark #detailModal [style*="color: #6b7280"],
.theme-dark #detailModal [style*="color:#9ca3af"],
.theme-dark #detailModal [style*="color: #9ca3af"]{
    color:#94a3b8 !important;
}
.theme-dark #import-layer-3 .private-form-shell{
    background:linear-gradient(180deg,#0f172a 0%,#111827 100%) !important;
}
.theme-dark #import-layer-3 .private-form-row,
.theme-dark #import-layer-3 .private-form-notice{
    background:#111827 !important;
    border-color:#243041 !important;
    box-shadow:none !important;
}
.theme-dark #import-layer-3 .private-form-label,
.theme-dark #import-layer-3 .private-form-title,
.theme-dark #import-layer-3 .private-form-desc{
    color:#e5eefc !important;
}
.theme-dark #import-layer-3 .private-form-label-hint,
.theme-dark #import-layer-3 .private-form-notice-text{
    color:#94a3b8 !important;
}
.theme-dark #import-layer-3 .private-form-input,
.theme-dark #import-layer-3 .private-form-assist,
.theme-dark #import-layer-3 .private-form-cancel,
.theme-dark #import-layer-3 .sf-dd{
    background:#0f172a !important;
    color:#e5eefc !important;
    border-color:#243041 !important;
}
.theme-dark #import-layer-3 .private-form-input::placeholder{
    color:#64748b !important;
}
.theme-dark #import-layer-3 [style*="background:white"],
.theme-dark #import-layer-3 [style*="background: white"],
.theme-dark #import-layer-3 [style*="background:#fff"],
.theme-dark #import-layer-3 [style*="background: #fff"],
.theme-dark #import-layer-3 [style*="background:#f3f4f6"],
.theme-dark #import-layer-3 [style*="background: #f3f4f6"]{
    background:#0f172a !important;
    color:#e5eefc !important;
    border-color:#243041 !important;
    box-shadow:none !important;
}
.theme-dark #import-layer-3 [style*="color:#111827"],
.theme-dark #import-layer-3 [style*="color: #111827"],
.theme-dark #import-layer-3 [style*="color:#374151"],
.theme-dark #import-layer-3 [style*="color: #374151"]{
    color:#e5eefc !important;
}
.theme-dark #import-layer-3 [style*="color:#6b7280"],
.theme-dark #import-layer-3 [style*="color: #6b7280"],
.theme-dark #import-layer-3 [style*="color:#9ca3af"],
.theme-dark #import-layer-3 [style*="color: #9ca3af"]{
    color:#94a3b8 !important;
}
.theme-dark #contact-correct-btn:hover,
.theme-dark #contact-wrong-btn:hover,
.theme-dark #contact-modify-btn:hover{
    color:#111827 !important;
}
.theme-dark #contact-correct-btn:hover div,
.theme-dark #contact-wrong-btn:hover div,
.theme-dark #contact-modify-btn:hover div,
.theme-dark #contact-correct-btn:hover span,
.theme-dark #contact-wrong-btn:hover span,
.theme-dark #contact-modify-btn:hover span{
    color:#111827 !important;
}
.theme-dark #tbl-ocean .co-name,
.theme-dark #tbl-ocean .ind-tag,
.theme-dark #tbl-mine .co-name,
.theme-dark #tbl-mine .ind-tag,
.theme-dark #tbl-shares .co-name,
.theme-dark #tbl-shares .ind-tag,
.theme-dark #tbl-ocean .act,
.theme-dark #tbl-ocean .act-view,
.theme-dark #tbl-ocean .act-plus{
    color:#ffffff !important;
}
.theme-dark #tbl-ocean .co-name,
.theme-dark #tbl-ocean .ind-tag,
.theme-dark #tbl-mine .co-name,
.theme-dark #tbl-mine .ind-tag,
.theme-dark #tbl-shares .co-name,
.theme-dark #tbl-shares .ind-tag{
    font-size:14px !important;
}
.theme-dark .customer-offline-badge{background:rgba(248,113,113,.18);color:#fecaca;}
.theme-dark .mine-offline-row td{background:rgba(127,29,29,.10);}
.theme-dark .mine-offline-row:hover td{background:rgba(127,29,29,.16);}
.theme-dark .detail-offline-notice{background:rgba(127,29,29,.18);border-color:rgba(248,113,113,.28);color:#fecaca;}
.theme-dark .detail-offline-notice strong,
.theme-dark .detail-offline-notice span{color:#fecaca;}
.theme-dark .detail-offline-feedback{background:rgba(127,29,29,.18);border-color:rgba(248,113,113,.28);}
.theme-dark .detail-offline-feedback .detail-feedback-title,
.theme-dark .detail-offline-feedback-reason strong{color:#fecaca;}
.theme-dark .detail-offline-feedback-reason{color:#e5eefc;}
.theme-dark #tbl-ocean .co-av{
    box-shadow:0 6px 16px rgba(59,130,246,0.18);
}
.theme-dark #tbl-ocean .ocean-btn{
    background:#0f172a !important;
    color:#e5eefc !important;
    border-color:#334155 !important;
    box-shadow:none !important;
}
.theme-dark #tbl-ocean .ocean-btn:hover{
    background:#1f2937 !important;
    border-color:#475569 !important;
    box-shadow:none !important;
}
.theme-dark #tbl-ocean .pie-cell{
    color:#e5eefc !important;
}
.theme-soft{background:#eef2f7;}
html.auth-has-session.theme-soft body{background:#eef2f7 url('/bg/beijngtu.jfif?v=5') no-repeat center center;background-size:cover;}
.theme-soft{
    --text:#111827;
    --text2:#6b7280;
    --text3:#9ca3af;
    --border:#e5e7eb;
    --bg:#f0f1f8;
    --white:#f4f5fc;
    --blue:#3b82f6;
    --blue-l:#eff6ff;
}
.theme-soft .app-wrap{background:var(--white);box-shadow:0 4px 32px rgba(0,0,0,0.10);}
.theme-soft .sidebar,
.theme-soft .topbar,
.theme-soft .filterbar,
.theme-soft .table-area,
.theme-soft .table-area > .inner,
.theme-soft .sb-bottom{background:var(--white) !important;border-color:var(--border) !important;}
.theme-soft .nav-item:hover,
.theme-soft .nav-item.active,
.theme-soft .sb-user:hover,
.theme-soft .t-icon:hover,
.theme-soft .f-reset:hover{background:rgba(0,0,0,0.13) !important;}
.theme-soft .fo-view-toggle span.active{background:#374151 !important;color:#fff !important;}
.theme-soft .t-icon,
.theme-soft .f-sel,
.theme-soft .f-reset,
.theme-soft #search-pool{
    background:#fff !important;
    color:#111827 !important;
    border-color:var(--border) !important;
}
.theme-soft #topbar-credits{
    background:#f5f3ff !important;
    color:#9ca3af !important;
    box-shadow:none;
}
.theme-soft #topbar-credit-num{color:#6d28d9 !important;}
.theme-soft .app-wrap input:not(.login-box input):not(.register-box input),
.theme-soft .app-wrap select:not(.fo-stage-pill-select),
.theme-soft .app-wrap textarea{
    background:#fff !important;
    color:#111827 !important;
    border-color:#e5e7eb !important;
}
.theme-soft .app-wrap input::placeholder,
.theme-soft .app-wrap textarea::placeholder{color:#9ca3af !important;}
.theme-soft .app-wrap table,
.theme-soft .app-wrap th,
.theme-soft .app-wrap td{border-color:#e5e7eb !important;color:#111827;}
.theme-soft #order-table thead th,
.theme-soft #followup-list-tbl thead th,
.theme-soft #sample-table thead th,
.theme-soft #fo-table thead th,
.theme-soft thead th{background:#fafafa !important;color:#111827 !important;border-bottom-color:#e5e7eb !important;}
.theme-soft #order-table tbody tr:hover,
.theme-soft #sample-table tbody tr:hover,
.theme-soft #followup-list-tbl tbody tr:hover,
.theme-soft #fo-table tbody tr:hover,
.theme-soft #tbl-shares tbody tr:hover,
.theme-soft tbody tr:hover{background:#f5f3ff !important;}
.theme-soft #tbl-ocean tbody tr:hover,
.theme-soft #tbl-mine tbody tr:hover,
.theme-soft #order-table tbody tr:hover,
.theme-soft #sample-table tbody tr:hover,
.theme-soft #followup-list-tbl tbody tr:hover,
.theme-soft #fo-table tbody tr:hover,
.theme-soft #tbl-shares tbody tr:hover,
.theme-soft #tbl-ocean tbody tr.table-row-hover-active,
.theme-soft #tbl-mine tbody tr.table-row-hover-active{background:#dfe5ec !important;}
.theme-soft .modal,
.theme-soft .detail-modal-panel,
.theme-soft .fo-detail-panel,
.theme-soft .order-create-modal,
.theme-soft .private-form-header,
.theme-soft .private-form-row,
.theme-soft .order-create-grid .o-row,
.theme-soft .order-create-note,
.theme-soft .order-create-panel,
.theme-soft .dash-card,
.theme-soft .settings-card,
.theme-soft .dash-kpi-card,
.theme-soft .dash-action-bar,
.theme-soft .detail-feedback-score,
.theme-soft .fo-card,
.theme-soft .fo-row-overlay{
    background:#fff !important;
    color:#111827 !important;
    border-color:#e5e7eb !important;
}
.theme-soft .fo-latest-floating{
    background:#fff !important;
    color:#111827 !important;
    border-color:#000 !important;
}
.theme-soft [style*="background:white"],
.theme-soft [style*="background: white"],
.theme-soft [style*="background:#fff"],
.theme-soft [style*="background: #fff"]{
    background:#fff !important;
    border-color:#e5e7eb !important;
}
.theme-soft [style*="color:#111827"],
.theme-soft [style*="color: #111827"],
.theme-soft [style*="color:#374151"],
.theme-soft [style*="color: #374151"]{color:#111827 !important;}
.theme-soft [style*="color:#6b7280"],
.theme-soft [style*="color: #6b7280"],
.theme-soft [style*="color:#9ca3af"],
.theme-soft [style*="color: #9ca3af"]{color:#6b7280 !important;}
.login-page {
  --login-text:#202226;
  --login-muted:#8a9099;
  --login-panel:#ffffff;
  --login-bg:#eeeeef;
  --login-green:#22c55e;
  --login-blue:#5b8cff;
  --login-pink:#ff8baa;
  --login-amber:#ffcf5a;
  position:fixed;
  inset:0;
  z-index:99999;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:34px;
  overflow:auto;
  background:var(--login-bg);
  color:var(--login-text);
}
.login-page.hidden { display: none !important; }
.login-page .login-shell{
  width:min(1180px,100%);
  background:transparent;
}
.login-page .login-main-card{
  min-height:620px;
  background:var(--login-panel);
  box-shadow:0 12px 34px rgba(31,35,41,0.08);
  border:1px solid rgba(229,231,235,0.92);
  border-radius:56px;
  overflow:hidden;
  display:grid;
  grid-template-columns:430px 1fr;
  gap:34px;
  padding:38px;
  position:relative;
}
.login-page .login-side{
  position:relative;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:20px 28px 20px 22px;
}
.login-page .login-brand{
  position:absolute;
  left:22px;
  top:0;
  display:inline-flex;
  align-items:flex-start;
  gap:10px;
  font-size:15px;
  font-weight:760;
  color:#2b3037;
}
.login-page .login-brand-copy{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.login-page .login-brand-sub{
  max-width:330px;
  margin:0;
  font-size:14px;
  line-height:1.7;
  font-weight:500;
  color:var(--login-muted);
}
.login-page .login-brand-mark{
  width:28px;
  height:28px;
  display:block;
  object-fit:contain;
  flex-shrink:0;
}
.login-box{
  width:100%;
  max-width:310px;
  margin:0 auto;
  padding:0;
  background:transparent;
  border:none;
  border-radius:0;
  box-shadow:none;
  text-align:left;
}
.login-box h1{
  font-size:44px;
  line-height:1.08;
  font-weight:850;
  color:#202226;
  margin:0 0 26px;
  text-shadow:none;
}
.login-box .login-sub{
  font-size:14px;
  color:var(--login-muted);
  line-height:1.7;
  margin:0 0 26px;
}
.login-page .login-field{margin-bottom:14px;}
.login-page .login-field label{
  display:block;
  font-size:12px;
  font-weight:700;
  color:#343941;
  margin-bottom:8px;
}
.login-box input{
  width:100%;
  height:43px;
  margin:0;
  border:1px solid #dddddf;
  border-radius:7px;
  padding:0 13px;
  font-size:14px;
  color:#202226;
  outline:none;
  background:#fff;
  transition:border-color .2s ease,box-shadow .2s ease;
  box-sizing:border-box;
  backdrop-filter:none;
}
.login-box input::placeholder{color:#9aa0a8;}
.login-box input:focus{
  border-color:#202226;
  box-shadow:0 0 0 4px rgba(31,35,41,0.06);
  background:#fff;
}
.login-page .pw-wrap input{padding-right:44px;}
.login-page .pw-eye{right:10px;opacity:.62;}
.login-page .pw-eye:hover{opacity:.9;}
.login-box .login-remember{
  display:flex;
  align-items:center;
  gap:8px;
  margin:2px 0 18px;
  color:#5f6670;
  font-size:12px;
  cursor:pointer;
  user-select:none;
}
.login-box .login-remember input{
  width:14px;
  height:14px;
  margin:0;
  padding:0;
  border-radius:3px;
  accent-color:#202226;
  cursor:pointer;
  flex-shrink:0;
}
.login-box .btn-main{
  width:100%;
  height:44px;
  padding:0;
  border:0;
  border-radius:7px;
  background:#202226;
  color:#fff;
  font-size:13px;
  font-weight:760;
  cursor:pointer;
  transition:transform .2s ease,background .2s ease;
}
.login-box .btn-main:hover{
  transform:translateY(-1px);
  background:#16181b;
}
.login-box .login-error-msg{
  margin-top:14px;
  padding:11px 13px;
  background:#fff5f5;
  border:1px solid #fecaca;
  border-radius:8px;
  color:#dc2626;
  font-size:13px;
  line-height:1.6;
  text-align:left;
}
.login-box .link-row{
  margin-top:16px;
  text-align:center;
  color:#606771;
  font-size:12px;
}
.login-box .link-row a{
  color:#202226;
  font-weight:700;
  text-decoration:none;
  cursor:pointer;
}
.login-box .link-row a:hover{text-decoration:underline;}
.login-box .login-version{
  margin-top:10px;
  text-align:center;
  color:#9aa0a8;
  font-size:11px;
}
.login-page .login-visual{
  min-height:544px;
  border-radius:26px;
  overflow:hidden;
  position:relative;
  background:
    radial-gradient(circle at 18% 18%, rgba(255,207,90,.50), transparent 28%),
    radial-gradient(circle at 84% 16%, rgba(91,140,255,.48), transparent 27%),
    radial-gradient(circle at 72% 84%, rgba(255,139,170,.36), transparent 30%),
    linear-gradient(135deg,#f7f4fb 0%,#f2f7fc 100%);
  border:1px solid rgba(229,231,235,.92);
}
.login-page .login-visual-inner{
  position:absolute;
  inset:0;
}
.login-page .login-net-line{
  position:absolute;
  left:50%;
  top:50%;
  height:1px;
  background:linear-gradient(90deg,rgba(31,35,41,0),rgba(31,35,41,.14),rgba(31,35,41,0));
  transform-origin:left center;
  z-index:1;
}
.login-page .login-l1{width:265px;transform:rotate(180deg);}
.login-page .login-l2{width:265px;transform:rotate(0deg);}
.login-page .login-l3{width:225px;transform:rotate(-136deg);}
.login-page .login-l4{width:225px;transform:rotate(-44deg);}
.login-page .login-l5{width:225px;transform:rotate(136deg);}
.login-page .login-l6{width:225px;transform:rotate(44deg);}
.login-page .login-center-hub{
  position:absolute;
  left:50%;
  top:50%;
  width:160px;
  height:160px;
  transform:translate(-50%,-50%);
  z-index:7;
}
.login-page .login-hub-card{
  position:absolute;
  inset:0;
  border-radius:38px;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(255,255,255,.92);
  backdrop-filter:blur(16px);
  box-shadow:0 24px 60px rgba(31,35,41,.12);
  overflow:hidden;
}
.login-page .login-hub-card::before{
  content:"";
  position:absolute;
  inset:-38%;
  background:conic-gradient(from 0deg,rgba(255,207,90,.42),rgba(91,140,255,.38),rgba(255,139,170,.38),rgba(255,207,90,.42));
  animation:loginSpin 8s linear infinite;
}
.login-page .login-hub-card::after{
  content:"";
  position:absolute;
  inset:10px;
  border-radius:30px;
  background:rgba(255,255,255,.94);
}
.login-page .login-hub-content{
  position:absolute;
  inset:0;
  z-index:2;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:10px;
}
.login-page .login-hub-icon{
  width:48px;
  height:48px;
  border-radius:16px;
  background:#202226;
  color:#fff;
  display:grid;
  place-items:center;
  font-size:24px;
  font-weight:850;
  box-shadow:0 14px 30px rgba(31,35,41,.18);
  animation:loginPulseCore 2.6s ease-in-out infinite;
}
.login-page .login-hub-text{
  font-size:13px;
  color:#454c56;
  font-weight:850;
}
.login-page .login-sales-card{
  position:absolute;
  width:98px;
  height:106px;
  border-radius:22px;
  background:rgba(255,255,255,.80);
  border:1px solid rgba(229,231,235,.94);
  backdrop-filter:blur(12px);
  box-shadow:0 16px 42px rgba(31,35,41,.07);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:8px;
  z-index:4;
  animation:loginFloat 5.6s ease-in-out infinite;
}
.login-page .login-sales-a{left:46px;top:220px;animation-delay:0s;}
.login-page .login-sales-b{right:46px;top:220px;animation-delay:-.7s;}
.login-page .login-sales-c{left:142px;top:68px;animation-delay:-1.4s;}
.login-page .login-sales-d{right:142px;top:68px;animation-delay:-2.1s;}
.login-page .login-sales-e{left:142px;bottom:68px;animation-delay:-2.8s;}
.login-page .login-sales-f{right:142px;bottom:68px;animation-delay:-3.5s;}
.login-page .login-online-dot{
  position:absolute;
  right:10px;
  top:10px;
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--login-green);
  box-shadow:0 0 0 5px rgba(34,197,94,.12);
}
.login-page .login-avatar{
  width:58px;
  height:58px;
  position:relative;
  overflow:visible;
  margin-top:2px;
}
.login-page .login-head{
  position:absolute;
  left:50%;
  top:10px;
  transform:translateX(-50%);
  width:28px;
  height:30px;
  background:#fff;
  border:2px solid #1f2329;
  border-radius:48% 48% 45% 45%;
  z-index:3;
}
.login-page .login-neck{
  position:absolute;
  left:50%;
  top:36px;
  transform:translateX(-50%);
  width:8px;
  height:7px;
  background:#fff;
  border-left:2px solid #1f2329;
  border-right:2px solid #1f2329;
  z-index:2;
}
.login-page .login-body{
  position:absolute;
  left:50%;
  bottom:1px;
  transform:translateX(-50%);
  width:42px;
  height:18px;
  border:2px solid #1f2329;
  border-bottom:none;
  border-radius:18px 18px 0 0;
  background:#e9eef6;
  z-index:1;
}
.login-page .login-eye{
  position:absolute;
  top:21px;
  width:3px;
  height:3px;
  background:#1f2329;
  border-radius:50%;
  z-index:5;
}
.login-page .login-eye-left{left:22px;}
.login-page .login-eye-right{right:22px;}
.login-page .login-nose{
  position:absolute;
  left:50%;
  top:23px;
  width:5px;
  height:7px;
  transform:translateX(-50%);
  border-right:2px solid #1f2329;
  border-bottom:2px solid #1f2329;
  border-radius:0 0 6px 0;
  z-index:5;
}
.login-page .login-smile{
  position:absolute;
  left:50%;
  top:28px;
  width:10px;
  height:6px;
  transform:translateX(-50%);
  border-bottom:2px solid #1f2329;
  border-radius:0 0 10px 10px;
  z-index:5;
}
.login-page .login-hair{
  position:absolute;
  z-index:6;
  background:#1f2329;
}
.login-page .login-avatar-a .login-hair-main{
  left:50%;
  top:8px;
  transform:translateX(-50%);
  width:30px;
  height:15px;
  border-radius:16px 16px 6px 6px;
}
.login-page .login-avatar-a .login-hair-bun{
  left:15px;
  top:2px;
  width:14px;
  height:14px;
  border-radius:50%;
}
.login-page .login-avatar-a .login-body{background:#6aa8ff;}
.login-page .login-avatar-b .login-hair-main{
  left:50%;
  top:6px;
  transform:translateX(-50%);
  width:31px;
  height:16px;
  border-radius:16px 16px 9px 9px;
}
.login-page .login-avatar-b .login-hair-curl1,
.login-page .login-avatar-b .login-hair-curl2,
.login-page .login-avatar-b .login-hair-curl3{
  top:14px;
  width:8px;
  height:8px;
  border-radius:50%;
}
.login-page .login-avatar-b .login-hair-curl1{left:13px;}
.login-page .login-avatar-b .login-hair-curl2{left:25px;}
.login-page .login-avatar-b .login-hair-curl3{left:37px;}
.login-page .login-avatar-b .login-body{background:#f2f2f2;}
.login-page .login-cap-top{
  position:absolute;
  left:50%;
  top:8px;
  transform:translateX(-50%);
  width:30px;
  height:12px;
  border:2px solid #1f2329;
  border-bottom:none;
  border-radius:18px 18px 0 0;
  background:#fff;
  z-index:7;
}
.login-page .login-cap-brim{
  position:absolute;
  left:32px;
  top:16px;
  width:16px;
  height:6px;
  border:2px solid #1f2329;
  border-left:none;
  border-radius:0 8px 8px 0;
  background:#fff;
  z-index:7;
}
.login-page .login-avatar-c .login-hair-main{
  left:50%;
  top:16px;
  transform:translateX(-50%);
  width:28px;
  height:9px;
  border-radius:10px 10px 5px 5px;
}
.login-page .login-avatar-c .login-body{background:#ffd84d;}
.login-page .login-hood-l,
.login-page .login-hood-r{
  position:absolute;
  top:42px;
  width:10px;
  height:10px;
  border:2px solid #1f2329;
  border-top:none;
  border-radius:0 0 10px 10px;
  background:transparent;
  z-index:3;
}
.login-page .login-hood-l{left:14px;}
.login-page .login-hood-r{right:14px;}
.login-page .login-avatar-d .login-hair-main{
  left:50%;
  top:7px;
  transform:translateX(-50%);
  width:34px;
  height:22px;
  border-radius:18px 18px 12px 12px;
}
.login-page .login-avatar-d .login-hair-side-l,
.login-page .login-avatar-d .login-hair-side-r,
.login-page .login-avatar-f .login-hair-side-l,
.login-page .login-avatar-f .login-hair-side-r{
  top:18px;
  width:7px;
  height:16px;
  border-radius:8px;
}
.login-page .login-avatar-d .login-hair-side-l{left:12px;height:20px;}
.login-page .login-avatar-d .login-hair-side-r{right:12px;height:20px;}
.login-page .login-glasses-l,
.login-page .login-glasses-r{
  position:absolute;
  top:20px;
  width:11px;
  height:11px;
  border:2px solid #ff5a4f;
  border-radius:50%;
  background:transparent;
  z-index:7;
}
.login-page .login-glasses-l{left:15px;}
.login-page .login-glasses-r{right:15px;}
.login-page .login-glasses-bridge{
  position:absolute;
  left:50%;
  top:24px;
  width:6px;
  height:2px;
  transform:translateX(-50%);
  background:#ff5a4f;
  z-index:7;
}
.login-page .login-avatar-d .login-body{background:#fff;}
.login-page .login-stripe{
  position:absolute;
  left:50%;
  bottom:8px;
  transform:translateX(-50%);
  width:30px;
  height:2px;
  background:#ffb54d;
  z-index:2;
}
.login-page .login-avatar-e .login-hair-main{
  left:50%;
  top:7px;
  transform:translateX(-50%);
  width:28px;
  height:14px;
  border-radius:16px 16px 8px 8px;
}
.login-page .login-headset-band{
  position:absolute;
  left:50%;
  top:7px;
  transform:translateX(-50%);
  width:34px;
  height:18px;
  border:2px solid #5aa2ff;
  border-bottom:none;
  border-radius:18px 18px 0 0;
  z-index:7;
}
.login-page .login-ear-l,
.login-page .login-ear-r{
  position:absolute;
  top:20px;
  width:9px;
  height:14px;
  border-radius:8px;
  background:#5aa2ff;
  border:2px solid #1f2329;
  z-index:7;
}
.login-page .login-ear-l{left:10px;}
.login-page .login-ear-r{right:10px;}
.login-page .login-avatar-e .login-body{background:#f2f2f2;}
.login-page .login-avatar-f .login-hair-main{
  left:50%;
  top:8px;
  transform:translateX(-50%);
  width:31px;
  height:18px;
  border-radius:18px 18px 10px 10px;
}
.login-page .login-avatar-f .login-hair-side-l{left:14px;}
.login-page .login-avatar-f .login-hair-side-r{right:14px;}
.login-page .login-avatar-f .login-body{background:#ff8baa;}
.login-page .login-sales-name{
  font-size:13px;
  font-weight:850;
  color:#323841;
}
.login-page .login-share-card{
  position:absolute;
  min-width:132px;
  height:36px;
  padding:0 13px;
  border-radius:14px;
  background:rgba(255,255,255,.96);
  border:1px solid rgba(229,231,235,.96);
  box-shadow:0 14px 32px rgba(31,35,41,.08);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:11px;
  font-weight:850;
  color:#4d5560;
  white-space:nowrap;
  opacity:0;
  z-index:8;
}
.login-page .login-s1{left:150px;top:230px;animation:loginMoveRight 6.8s linear infinite;}
.login-page .login-s2{right:150px;top:284px;animation:loginMoveLeft 6.8s linear infinite -3.4s;}
.login-page .login-s3{left:220px;top:158px;animation:loginMoveDiag1 6.8s linear infinite -1.7s;}
.login-page .login-s4{right:220px;bottom:142px;animation:loginMoveDiag2 6.8s linear infinite -5.1s;}
.login-page .login-bottom-tag{
  position:absolute;
  left:50%;
  bottom:28px;
  transform:translateX(-50%);
  height:34px;
  padding:0 14px;
  border-radius:999px;
  background:rgba(255,255,255,.88);
  border:1px solid rgba(229,231,235,.95);
  box-shadow:0 10px 26px rgba(31,35,41,.06);
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  font-weight:850;
  color:#4b535d;
  z-index:9;
  white-space:nowrap;
}
.login-page .login-bottom-tag span{
  width:7px;
  height:7px;
  border-radius:50%;
  background:var(--login-green);
  box-shadow:0 0 0 5px rgba(34,197,94,.12);
}
@keyframes loginSpin{to{transform:rotate(360deg);}}
@keyframes loginPulseCore{
  0%,100%{transform:scale(1);}
  50%{transform:scale(1.07);}
}
@keyframes loginFloat{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(-7px);}
}
@keyframes loginMoveRight{
  0%{transform:translateX(0) scale(.94);opacity:0;}
  12%{opacity:1;}
  42%{transform:translateX(190px) scale(1);opacity:1;}
  54%,100%{transform:translateX(230px) scale(.96);opacity:0;}
}
@keyframes loginMoveLeft{
  0%{transform:translateX(0) scale(.94);opacity:0;}
  12%{opacity:1;}
  42%{transform:translateX(-190px) scale(1);opacity:1;}
  54%,100%{transform:translateX(-230px) scale(.96);opacity:0;}
}
@keyframes loginMoveDiag1{
  0%{transform:translate(0,0) scale(.94);opacity:0;}
  12%{opacity:1;}
  44%{transform:translate(115px,64px) scale(1);opacity:1;}
  56%,100%{transform:translate(155px,86px) scale(.96);opacity:0;}
}
@keyframes loginMoveDiag2{
  0%{transform:translate(0,0) scale(.94);opacity:0;}
  12%{opacity:1;}
  44%{transform:translate(-115px,-64px) scale(1);opacity:1;}
  56%,100%{transform:translate(-155px,-86px) scale(.96);opacity:0;}
}
@media (max-width:1080px){
  .login-page{
    align-items:flex-start;
  }
  .login-page .login-main-card{
    grid-template-columns:1fr;
    min-height:auto;
    padding:24px;
  }
  .login-page .login-side{
    min-height:440px;
    padding:52px 10px 20px;
  }
  .login-page .login-brand{left:10px;}
  .login-page .login-visual{min-height:560px;}
}
@media (max-width:760px){
  .login-page{padding:12px;}
  .login-page .login-main-card{
    padding:16px;
    gap:18px;
    border-radius:28px;
  }
  .login-box h1{font-size:38px;}
  .login-page .login-visual{min-height:520px;}
  .login-page .login-sales-card{width:88px;height:96px;}
  .login-page .login-sales-a{left:20px;top:220px;}
  .login-page .login-sales-b{right:20px;top:220px;}
  .login-page .login-sales-c{left:88px;top:68px;}
  .login-page .login-sales-d{right:88px;top:68px;}
  .login-page .login-sales-e{left:88px;bottom:68px;}
  .login-page .login-sales-f{right:88px;bottom:68px;}
  .login-page .login-center-hub{width:142px;height:142px;}
  .login-page .login-share-card{display:none;}
  .login-page .login-bottom-tag{font-size:11px;}
}

/* ==================== 注册页面 ==================== */
.register-page {
    position: fixed; top:0; left:0; width:100vw; height:100vh;
    display: none; justify-content: center; align-items: center;
    background:#eeeeef;
    z-index: 99999;
    overflow-y: auto;
    padding:34px;
}
.register-page.active { display:flex; }

.register-box {
    background: #fff;
    padding: 40px 48px;
    text-align: center;
    width: 620px;
    max-width: 92vw;
    min-width: 320px;
    max-height: 92vh;
    overflow-y: auto;
    border: 1px solid rgba(229,231,235,0.92);
    border-radius: 28px;
    box-shadow: 0 18px 52px rgba(31,35,41,0.10);
    box-sizing: border-box;
    position: relative;
    z-index: 1;
}
.register-box {
    scrollbar-width: thin;
    scrollbar-color: transparent transparent;
}
.register-box:hover {
    scrollbar-color: rgba(31,35,41,0.20) transparent;
}
.register-box::-webkit-scrollbar { width:10px; }
.register-box::-webkit-scrollbar-track {
    background:transparent;
    margin:24px 0;
}
.register-box::-webkit-scrollbar-thumb {
    background:transparent;
    border:3px solid transparent;
    border-radius:999px;
    background-clip:content-box;
}
.register-box:hover::-webkit-scrollbar-thumb {
    background:rgba(31,35,41,0.20);
    border:3px solid transparent;
    background-clip:content-box;
}
.register-box::-webkit-scrollbar-thumb:hover {
    background:rgba(31,35,41,0.34);
    border:3px solid transparent;
    background-clip:content-box;
}
.register-box h1 { color:#111; font-size:48px; margin-bottom:8px; font-weight:700; }
.register-box .subtitle { color:#444; font-size:14px; margin-bottom:20px; }
.reg-section-title { display:block; font-size:15px; font-weight:700; color:#222; text-align:left; margin:20px 0 10px 0; padding-bottom:6px; border-bottom:2px solid #eee; letter-spacing:0.5px; }
.register-box input,
.register-box select {
    display: block;
    width: 100%;
    padding: 13px 16px;
    margin-bottom: 14px;
    border: 1.5px solid #e0e0e0;
    border-radius: 10px;
    font-size: 15px;
    background: #f9f9f9;
    color: #111;
    box-sizing: border-box;
    float: none;
}
.register-box select option { background:#fff; color:#333; }
.register-box input::placeholder { color:#999; }
.register-box input:focus,
.register-box select:focus { outline:none; background:#fff; border-color:#667eea; }
.gender-group { display:flex; gap:10px; margin-bottom:14px; width:100%; }
.gender-btn {
    flex:1; padding:12px; border:1.5px solid #e0e0e0;
    border-radius:10px; background:#f9f9f9;
    color:#222; font-size:15px; cursor:pointer; transition:all 0.2s;
}
.gender-btn.selected { background:#374151; border-color:#374151; color:#fff; font-weight:bold; }
.register-box .btn-main {
    width:100%; padding:14px; background:#333; color:#fff;
    border:none; border-radius:25px; font-size:17px;
    cursor:pointer; transition:all 0.3s; margin-top:6px;
}
.register-box .btn-main:hover { background:#000; transform:scale(1.05); }
.register-box .link-row { margin-top:14px; color:#333; font-size:14px; }
.register-box .link-row a { color:#667eea; font-weight:bold; text-decoration:none; cursor:pointer; }
.register-box .link-row a:hover { text-decoration:underline; }
@media (max-width:760px){
  .register-page{
    align-items:flex-start;
    padding:12px;
  }
  .register-box{
    max-width:calc(100vw - 24px);
    padding:32px 28px;
    border-radius:24px;
  }
  .register-box h1{
    font-size:36px !important;
    line-height:1.12 !important;
  }
  .register-box .gender-group{
    flex-wrap:wrap;
  }
  .register-box .gender-btn{
    flex:1 1 calc(50% - 6px);
    min-width:128px;
    white-space:nowrap;
  }
}

/* ====== 防批量复制：表格区域禁止框选多行，单个单元格可复制 ====== */
#tbl-ocean, #tbl-mine, #order-table, #order-list-new,
#foKanbanView, #foListView, #followup-list-tbl,
#tbl-shares, #import-customer-list {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
/* 允许单个单元格内文字可选（点击后可复制单个字段） */
#tbl-ocean td, #tbl-mine td, #order-table td,
#tbl-shares td,
.fo-kanban-card, .fo-list-row,
#order-list-new .order-card {
  -webkit-user-select: text;
  -moz-user-select: text;
  -ms-user-select: text;
  user-select: text;
}

.shares-inline-summary {
  display:flex;
  align-items:baseline;
  gap:8px;
  margin-left:6px;
  padding:5px 10px;
  border:1px solid #e5e7eb;
  border-radius:8px;
  background:#f8fafc;
  white-space:nowrap;
  font-size:12px;
  color:#9ca3af;
}
.shares-inline-summary strong {
  font-size:18px !important;
  font-weight:800;
  line-height:1;
  color:#111827;
  margin-right:4px;
}
.shares-inline-summary .shares-inline-label {
  color:#9ca3af;
  font-size:12px;
  font-weight:600;
}
.shares-inline-summary .shares-inline-value-positive {
  color:#16a34a !important;
}
.shares-inline-summary .shares-inline-value-negative {
  color:#dc2626 !important;
}
.shares-inline-summary .shares-inline-value-neutral {
  color:#111827 !important;
}
.shares-inline-summary .shares-inline-value-quality {
  color:#2563eb !important;
}
.share-reward-cell {
  display:inline-flex;
  min-width:0;
  min-height:auto;
  border-radius:0;
  padding:0;
  box-sizing:border-box;
  justify-content:center;
  align-items:center;
  line-height:1;
  background:transparent !important;
}
.share-reward-main {
  font-size:14px;
  font-weight:800;
  white-space:nowrap;
}
.share-reward-sub {
  margin-top:3px;
  font-size:11px;
  font-weight:600;
  white-space:nowrap;
}
.share-reward-positive { background:transparent !important; color:#16a34a; }
.share-reward-negative { background:transparent !important; color:#dc2626; }
.share-reward-pending { background:transparent !important; color:#b45309; }
.share-reward-neutral { background:transparent !important; color:#6b7280; }
.theme-dark .shares-inline-summary,
.theme-dark .shares-inline-summary .shares-inline-label {
  color:#94a3b8;
}
.theme-dark .shares-inline-summary {
  background:#111827;
  border-color:#243041;
}
.theme-dark .shares-inline-summary strong {
  color:#e5eefc;
}
.theme-dark .shares-inline-summary .shares-inline-value-positive {
  color:#22c55e !important;
}
.theme-dark .shares-inline-summary .shares-inline-value-negative {
  color:#f87171 !important;
}
.theme-dark .shares-inline-summary .shares-inline-value-quality {
  color:#60a5fa !important;
}

/* ==================== 客户公海动态信息流动画 ==================== */

/* 新行从顶部滑入（仅用 transform + opacity，走 GPU 合成层，不触发重排） */
@keyframes oceanSlideIn {
  from { opacity: 0; transform: translateY(-20px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* 整行绿色闪光背景渐退 */
@keyframes oceanFlashGreen {
  from { background: rgba(22, 163, 74, 0.15); }
  to   { background: transparent; }
}

/* 时间标签信号波纹（只播放 3 次，不是 infinite） */
@keyframes oceanSignalPulse {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.25); }
}

/* 新插入行的组合动画 */
.ocean-row-new {
  animation: oceanSlideIn 0.4s ease-out,
             oceanFlashGreen 2s ease-out 0.3s;
}

/* 2小时内的绿色时间标签 */
.ocean-time-fresh {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: #16a34a;
  font-weight: 600;
  font-size: 13px;
  white-space: nowrap;
}
.ocean-time-fresh .ocean-signal {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  animation: oceanSignalPulse 0.9s ease-in-out 3;
}
.ocean-time-fresh .ocean-signal svg {
  width: 14px;
  height: 14px;
}
