/* ============================================================
   asp.css — 全球服务商网络分布
   设计语言：fine / airy glass-tech · 纤细几何字体 · 单一 cyan 强调 · 呼吸式微动效
   复用 app.css 的 :root 令牌，本页重定义字体与质感
   ============================================================ */

/* —— 字体：纤细几何感（Outfit 正文 / Space Grotesk 标题 / JetBrains Mono 数字）—— */
body{
  --sans:"Outfit","Inter",-apple-system,"PingFang SC","Microsoft YaHei",sans-serif;
  --display:"Space Grotesk","Outfit",var(--sans);
  --mono:"JetBrains Mono",ui-monospace,Menlo,monospace;
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-soft:cubic-bezier(.4,.14,.3,1);
  --glass:rgba(10,14,22,.34);
  --glass-bd:rgba(160,196,240,.10);
  --glass-hi:rgba(180,214,255,.16);
  --txt2:#cdd5e2;          /* 次级可读文本（标签） */
  --txt3:#a6b1c2;          /* 三级可读文本（数值/计数） */
  font-family:var(--sans);font-weight:300;letter-spacing:.01em;
}

/* 环境氛围：极淡的青色光晕 + 暗角，给暗底图增加纵深与未来感（不挡交互） */
body::before{
  content:"";position:fixed;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(120% 80% at 50% -10%, rgba(86,207,225,.06), transparent 60%),
    radial-gradient(90% 70% at 50% 120%, rgba(86,207,225,.04), transparent 55%),
    radial-gradient(140% 120% at 50% 50%, transparent 55%, rgba(4,7,12,.55));
}

/* 玻璃面板：更透、更薄边、顶部高光描边，整体克制 */
.glass{
  background:linear-gradient(180deg, rgba(16,22,33,.40), rgba(9,13,20,.30));
  backdrop-filter:blur(26px) saturate(1.15);-webkit-backdrop-filter:blur(26px) saturate(1.15);
  border:1px solid var(--glass-bd);
  border-radius:18px;
  box-shadow:0 24px 70px -20px rgba(0,0,0,.6), inset 0 1px 0 var(--glass-hi);
  position:relative;
}
/* 顶部一道极细流光，呼吸感的来源之一 */
.glass::after{
  content:"";position:absolute;left:18px;right:18px;top:0;height:1px;
  background:linear-gradient(90deg, transparent, rgba(86,207,225,.45), transparent);
  opacity:.5;
}

/* ============ 顶栏 ============ */
#topbar{z-index:20;backdrop-filter:blur(20px);background:linear-gradient(180deg,rgba(7,10,16,.78),rgba(7,10,16,.30)) !important;border-bottom:1px solid var(--glass-bd) !important;height:64px !important}
.brand-tt h1{font-family:var(--display);font-weight:400 !important;letter-spacing:.02em;font-size:15px !important}
.brand-tt h1 .demo-tag{color:var(--cyan);font-weight:300;letter-spacing:.24em;font-size:10px}
.brand-tt > span{letter-spacing:.28em !important;font-weight:300;opacity:.7}
.top-right{margin-left:auto;display:flex;align-items:center;gap:12px}
.back-link{font-size:11px;color:var(--dim);text-decoration:none;padding:6px 13px;border:1px solid var(--glass-bd);border-radius:999px;transition:all .3s var(--ease);white-space:nowrap;letter-spacing:.04em}
.back-link:hover{color:var(--cyan);border-color:rgba(86,207,225,.45);background:rgba(86,207,225,.06);transform:translateY(-1px)}
.ti{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:999px;color:var(--dim);cursor:pointer;transition:all .3s var(--ease);border:1px solid transparent}
.ti:hover{color:var(--cyan);border-color:rgba(86,207,225,.25);background:rgba(86,207,225,.05)}
.ti svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round}

/* KPI：纤细大字，呼吸式留白 */
.kpis{display:flex;align-items:stretch;height:100%;overflow:hidden}
.kpi{display:flex;flex-direction:column;justify-content:center;padding:0 clamp(14px,1.7vw,26px);border-left:1px solid var(--glass-bd);cursor:default}
.kpi .k{font-size:10px;color:var(--txt3);margin-bottom:5px;letter-spacing:.03em;white-space:nowrap;font-weight:400}
.kpi .k em{font-style:normal;color:var(--faint);font-size:8px;letter-spacing:.2em;display:block;text-transform:uppercase;opacity:.75;margin-top:2px}
.kpi .v{font-family:var(--mono);font-size:clamp(19px,1.7vw,26px);font-weight:200;line-height:.95;letter-spacing:.01em;white-space:nowrap;color:var(--tx)}

/* ============ 左：多维切片 ============ */
#slicer{position:absolute;left:18px;top:82px;bottom:18px;width:296px;z-index:14;display:flex;flex-direction:column;overflow:hidden;animation:rise .7s var(--ease) both}
#analytics{position:absolute;right:18px;top:82px;bottom:18px;width:320px;z-index:14;display:flex;flex-direction:column;overflow:hidden;animation:rise .7s var(--ease) .08s both}

.sl-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 14px;border-bottom:1px solid var(--glass-bd);flex-shrink:0}
.sl-head .tt b{font-family:var(--display);font-size:13px;font-weight:400;letter-spacing:.03em}
.sl-head .tt span{display:block;font-size:8.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--txt3);margin-top:4px;font-weight:400}
.sl-reset{font-size:10px;color:var(--dim);cursor:pointer;padding:5px 11px;border:1px solid var(--glass-bd);border-radius:999px;transition:all .3s var(--ease);white-space:nowrap;letter-spacing:.03em}
.sl-reset:hover{color:var(--amber);border-color:rgba(239,178,39,.4);transform:translateY(-1px)}

.sl-body,.an-body{overflow-y:auto;overflow-x:hidden;padding:6px 18px 20px;flex:1}
.sl-body::-webkit-scrollbar,.an-body::-webkit-scrollbar,.sl-list::-webkit-scrollbar{width:5px}
.sl-body::-webkit-scrollbar-thumb,.an-body::-webkit-scrollbar-thumb,.sl-list::-webkit-scrollbar-thumb{background:rgba(160,196,240,.12);border-radius:4px}
.sl-body::-webkit-scrollbar-track,.an-body::-webkit-scrollbar-track{background:transparent}

.sl-group{margin-top:20px}
.sl-group:first-child{margin-top:10px}
.sl-glabel{display:flex;align-items:center;justify-content:space-between;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--txt3);font-weight:500;margin-bottom:12px}
.sl-glabel .cnt{color:var(--cyan);letter-spacing:.04em;font-weight:400;opacity:.95}

/* 胶囊筹码：纤细、克制，hover 轻浮起 */
.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;line-height:1;padding:7px 12px;border:1px solid var(--glass-bd);border-radius:999px;color:var(--txt2);cursor:pointer;transition:all .28s var(--ease);user-select:none;font-weight:400;letter-spacing:.01em}
.chip .dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;box-shadow:0 0 6px currentColor}
.chip .n{font-family:var(--mono);font-size:10.5px;color:var(--txt3);font-weight:400}
.chip:hover{border-color:rgba(86,207,225,.4);color:var(--tx);transform:translateY(-1px)}
.chip.on{background:rgba(86,207,225,.10);border-color:rgba(86,207,225,.5);color:var(--tx);box-shadow:0 0 0 1px rgba(86,207,225,.12), 0 4px 14px -6px rgba(86,207,225,.4)}
.chip.on .n{color:var(--cyan)}

/* 长列表：品牌商 / 国家 */
.sl-list{max-height:188px;overflow-y:auto;margin:0 -6px;padding:0 6px}
.sl-row{display:flex;align-items:center;gap:9px;padding:6px 8px;border-radius:8px;cursor:pointer;transition:background .25s var(--ease);position:relative;overflow:hidden}
.sl-row:hover{background:rgba(160,196,240,.05)}
.sl-row.on{background:rgba(86,207,225,.08)}
.sl-row .dot{width:7px;height:7px;border-radius:2px;flex-shrink:0;box-shadow:0 0 6px currentColor}
.sl-row .nm{flex:1;font-size:11.5px;color:var(--txt2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:400}
.sl-row.on .nm{color:var(--tx)}
.sl-row .ct{font-family:var(--mono);font-size:10.5px;color:var(--txt3);font-weight:400}
.sl-row .bar{position:absolute;left:0;bottom:0;height:1.5px;background:linear-gradient(90deg,transparent,var(--cyan));opacity:.45;transition:width .55s var(--ease)}

.sl-search{width:100%;background:rgba(8,12,19,.5);border:1px solid var(--glass-bd);border-radius:10px;color:var(--tx);font-family:var(--sans);font-size:11px;font-weight:300;padding:9px 12px;outline:none;transition:all .3s var(--ease);letter-spacing:.02em}
.sl-search:focus{border-color:rgba(86,207,225,.5);background:rgba(8,12,19,.7);box-shadow:0 0 0 3px rgba(86,207,225,.07)}
.sl-search::placeholder{color:var(--faint);font-weight:300}

/* 着色方式切换 */
.seg{display:flex;border:1px solid var(--glass-bd);border-radius:10px;overflow:hidden;padding:2px;gap:2px}
.seg button{flex:1;background:transparent;border:none;color:var(--txt2);font-family:var(--sans);font-size:11.5px;font-weight:400;padding:8px 4px;cursor:pointer;transition:all .28s var(--ease);border-radius:8px;letter-spacing:.02em}
.seg button.on{background:rgba(86,207,225,.13);color:var(--cyan)}
.seg button:hover:not(.on){color:var(--tx)}

/* ============ 右：联动分析 ============ */
.an-sect{margin-top:24px}
.an-sect:first-child{margin-top:10px}
.an-stitle{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--txt3);font-weight:500;margin-bottom:14px}

.bars{display:flex;flex-direction:column;gap:13px}
.barrow{position:relative;cursor:default}
.barrow .brt{display:flex;justify-content:space-between;align-items:center;gap:10px;font-size:12.5px;line-height:1.5;margin-bottom:6px}
.barrow .brt .lab{flex:1;min-width:0;color:var(--txt2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:400;letter-spacing:.01em;line-height:1.5}
.barrow:hover .brt .lab{color:var(--tx)}
.barrow .brt .val{font-family:var(--mono);font-size:11.5px;color:var(--txt3);flex-shrink:0;font-weight:400;line-height:1.5}
.barrow .track{height:5px;background:rgba(160,196,240,.07);border-radius:4px;overflow:hidden}
.barrow .fill{height:100%;border-radius:4px;transition:width .65s var(--ease);box-shadow:0 0 8px -1px currentColor;filter:saturate(1.1)}

/* 状态环 */
.donut-wrap{display:flex;align-items:center;gap:18px}
.donut-wrap svg{flex-shrink:0}
.donut-leg{display:flex;flex-direction:column;gap:11px;font-size:12.5px}
.donut-leg .dl{display:flex;align-items:center;gap:9px;color:var(--txt2);font-weight:400}
.donut-leg .dl .dot{width:9px;height:9px;border-radius:2px;box-shadow:0 0 6px currentColor}
.donut-leg .dl b{font-family:var(--mono);font-weight:400;color:var(--tx);margin-left:auto;padding-left:12px}

/* ============ 地图叠加 ============ */
.map-title{position:absolute;left:50%;top:80px;transform:translateX(-50%);z-index:12;text-align:center;pointer-events:none}
.map-title b{font-family:var(--display);font-size:12px;font-weight:400;letter-spacing:.08em;color:var(--tx);text-shadow:0 2px 16px rgba(0,0,0,.9)}
.map-title b::before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--cyan);box-shadow:0 0 9px var(--cyan);margin-right:9px;vertical-align:middle;animation:breathe 2.6s var(--ease-soft) infinite}
.map-title span{display:block;font-size:8px;letter-spacing:.3em;text-transform:uppercase;color:var(--faint);margin-top:5px;font-weight:300}

.zoomctl{position:absolute;right:354px;bottom:22px;z-index:13;display:flex;flex-direction:column;gap:6px}
.zoomctl button{width:34px;height:34px;background:var(--glass);backdrop-filter:blur(16px);border:1px solid var(--glass-bd);border-radius:11px;color:var(--dim);font-size:15px;font-weight:300;cursor:pointer;transition:all .3s var(--ease)}
.zoomctl button:hover{background:rgba(86,207,225,.1);color:var(--cyan);border-color:rgba(86,207,225,.3);transform:translateY(-1px)}

.legend{position:absolute;left:330px;bottom:22px;z-index:13;padding:13px 16px;max-width:360px}
.legend .lh{font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--txt3);font-weight:500;margin-bottom:10px}
.legend .items{display:flex;flex-wrap:wrap;gap:10px 16px}
.legend .li{display:flex;align-items:center;gap:7px;font-size:11.5px;color:var(--txt2);font-weight:400;letter-spacing:.01em}
.legend .li .dot{width:8px;height:8px;border-radius:50%;box-shadow:0 0 7px currentColor}

/* 悬浮提示 */
.asp-tip{position:fixed;z-index:60;pointer-events:none;background:linear-gradient(180deg,rgba(13,18,28,.94),rgba(9,13,20,.92));border:1px solid var(--glass-bd);border-radius:12px;padding:11px 14px;font-size:11px;color:var(--tx);max-width:288px;box-shadow:0 16px 40px -10px rgba(0,0,0,.7), inset 0 1px 0 var(--glass-hi);line-height:1.6;font-weight:300;backdrop-filter:blur(12px);animation:rise .25s var(--ease) both}
.asp-tip b{font-family:var(--display);color:var(--cyan);font-weight:400;letter-spacing:.02em}
.asp-tip .r{color:var(--dim);font-size:10px;margin-top:3px}
.asp-tip .r em{color:var(--tx);font-style:normal;font-family:var(--mono);font-weight:300}

.hidden{display:none !important}

/* 切片组右侧操作区 + 品牌编辑入口 */
.gl-right{display:flex;gap:9px;align-items:center}
.sl-edit{font-size:9.5px;letter-spacing:.04em;color:var(--cyan);cursor:pointer;padding:3px 9px;border:1px solid rgba(86,207,225,.3);border-radius:999px;transition:all .28s var(--ease);text-transform:none;font-weight:400}
.sl-edit:hover{background:rgba(86,207,225,.1);border-color:rgba(86,207,225,.55);transform:translateY(-1px)}
.sl-all{font-size:9.5px;letter-spacing:.04em;color:var(--txt3);cursor:pointer;padding:3px 9px;border:1px solid var(--glass-bd);border-radius:999px;transition:all .28s var(--ease);text-transform:none;font-weight:400}
.sl-all:hover{color:var(--cyan);border-color:rgba(86,207,225,.45);transform:translateY(-1px)}

/* ============ 品牌商管理弹窗 ============ */
.bm-backdrop{position:fixed;inset:0;z-index:80;display:flex;align-items:center;justify-content:center;background:rgba(4,7,12,.62);backdrop-filter:blur(6px);animation:rise .25s var(--ease) both}
.bm{width:480px;max-width:calc(100vw - 40px);max-height:84vh;display:flex;flex-direction:column;overflow:hidden;border-radius:20px}
.bm-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px 15px;border-bottom:1px solid var(--glass-bd);flex-shrink:0}
.bm-head .tt b{font-family:var(--display);font-size:15px;font-weight:400;letter-spacing:.02em}
.bm-head .tt span{display:block;font-size:10px;color:var(--txt3);margin-top:5px;font-weight:400;letter-spacing:.02em}
.bm-x{font-size:15px;color:var(--dim);cursor:pointer;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:999px;transition:all .25s var(--ease)}
.bm-x:hover{color:var(--red);background:rgba(226,75,74,.1)}
.bm-tools{display:flex;gap:9px;padding:15px 22px;border-bottom:1px solid var(--glass-bd);flex-shrink:0}
.bm-tools .sl-search{flex:1}
.bm-btn{background:rgba(160,196,240,.06);border:1px solid var(--glass-bd);color:var(--txt2);font-family:var(--sans);font-size:12px;font-weight:400;padding:0 16px;border-radius:10px;cursor:pointer;transition:all .25s var(--ease);white-space:nowrap;letter-spacing:.02em}
.bm-btn:hover{color:var(--tx);border-color:rgba(86,207,225,.4);transform:translateY(-1px)}
.bm-btn.primary{background:rgba(86,207,225,.14);border-color:rgba(86,207,225,.45);color:var(--cyan)}
.bm-btn.primary:hover{background:rgba(86,207,225,.2)}
.bm-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}
.bm-list{overflow-y:auto;padding:10px 14px;flex:1}
.bm-list::-webkit-scrollbar{width:6px}.bm-list::-webkit-scrollbar-thumb{background:rgba(160,196,240,.14);border-radius:4px}
.bm-row{display:flex;align-items:center;gap:11px;padding:8px 10px;border-radius:10px;transition:background .2s var(--ease)}
.bm-row:hover{background:rgba(160,196,240,.05)}
.bm-ck{display:flex;align-items:center;cursor:pointer}
.bm-ck input{appearance:none;-webkit-appearance:none;width:15px;height:15px;border:1px solid var(--glass-bd);border-radius:5px;cursor:pointer;transition:all .2s var(--ease);position:relative;background:rgba(8,12,19,.5)}
.bm-ck input:checked{background:var(--cyan);border-color:var(--cyan)}
.bm-ck input:checked::after{content:"✓";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:10px;color:#06222a;font-weight:700}
.bm-row .dot{width:10px;height:10px;border-radius:3px;flex-shrink:0;box-shadow:0 0 7px currentColor}
.bm-name{flex:1;background:transparent;border:1px solid transparent;border-radius:8px;color:var(--txt2);font-family:var(--sans);font-size:13px;font-weight:400;padding:6px 9px;outline:none;transition:all .2s var(--ease);min-width:0}
.bm-name:hover{border-color:var(--glass-bd)}
.bm-name:focus{border-color:rgba(86,207,225,.5);background:rgba(8,12,19,.5);color:var(--tx)}
.bm-ct{font-family:var(--mono);font-size:11px;color:var(--txt3);flex-shrink:0;font-weight:400}
.bm-foot{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;border-top:1px solid var(--glass-bd);flex-shrink:0}
.bm-stat{font-size:11px;color:var(--txt3);font-weight:400;letter-spacing:.02em}

/* ============ 加载 ============ */
.loader{position:absolute;inset:0;z-index:90;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px;background:var(--bg0)}
.loader.hidden{display:none}
.loader .ring{width:40px;height:40px;border:2px solid rgba(86,207,225,.15);border-top-color:var(--cyan);border-radius:50%;animation:spin 1s linear infinite}
.loader .lt{font-size:11px;color:var(--dim);letter-spacing:.16em;font-weight:300;animation:breathe 2.6s var(--ease-soft) infinite}

/* ============ 动效 ============ */
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes breathe{0%,100%{opacity:.5}50%{opacity:1}}
/* KPI 数字切换时的轻微脉冲 */
@keyframes kpipulse{0%{color:var(--cyan)}100%{color:var(--tx)}}
.kpi .v.flash{animation:kpipulse .6s var(--ease)}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}
}

@media (max-width:1240px){
  #analytics{display:none}
  .zoomctl{right:22px}
  .legend{max-width:300px}
}
