/* dashboard.css —— 原 HTML 行 3637-4342 */
/* PAGE NAV + HEADER + KPI + LAYOUT + MATRIX + SIDE + DAILY SUMMARY + TREND CHART */

  /* ─────────── PAGE NAV ─────────── */
  .page-nav{
    display:inline-flex;
    gap:24px;margin-left:6px;
    border-bottom:none;
  }
  .page-nav button{
    background:transparent;border:none;color:var(--text-2);
    font-size:14px;font-weight:400;padding:6px 0;cursor:pointer;
    font-family:inherit;transition:color .15s;position:relative;
    display:inline-flex;align-items:center;gap:5px;
  }
  .page-nav button .ic{display:none}
  .page-nav button:hover:not(.active){color:var(--text)}
  .page-nav button.active{
    color:var(--primary);font-weight:500;
  }
  .page-nav button.active::after{
    content:"";position:absolute;left:50%;bottom:-7px;width:18px;height:2px;
    background:var(--primary);border-radius:2px;transform:translateX(-50%);
  }

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

  .page-2 .summary-section{margin-top:0}

  /* ─────────── HEADER ─────────── */
  header.top{
    display:flex;align-items:center;justify-content:space-between;gap:24px;
    margin-bottom:18px;padding-bottom:14px;
    border-bottom:1px solid var(--line);
  }
  .brand-row{display:flex;align-items:center;gap:10px;margin-bottom:6px}
  .brand-logo{
    width:26px;height:26px;border-radius:6px;
    background:linear-gradient(135deg,#1664ff,#4080ff);
    display:flex;align-items:center;justify-content:center;
    box-shadow:0 2px 6px rgba(22,100,255,0.2);
  }
  .brand-logo svg{width:14px;height:14px}
  .brand-tag{
    display:inline-flex;align-items:center;
    background:var(--bg-2);color:var(--text-2);
    font-family:"Inter",sans-serif;font-size:11px;font-weight:500;
    letter-spacing:0.04em;padding:2px 7px;border-radius:4px;
  }
  .brand-tag .v{color:var(--primary);font-weight:600;margin-right:3px}
  .brand-meta{font-size:12px;color:var(--text-3);display:inline-flex;align-items:center;gap:6px;font-weight:400}
  .brand-meta::before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--down);box-shadow:0 0 0 3px rgba(0,180,42,0.12)}
  .brand-meta b{color:var(--text-2);font-weight:500}
  .brand-title{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
  .brand-title h1{margin:0;font-size:18px;font-weight:600;letter-spacing:-0.01em;color:var(--text)}
  .brand-title .sub{font-size:13px;color:var(--text-3);font-weight:400}

  .header-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
  .month-pick, .day-pick{
    display:inline-flex;align-items:center;gap:6px;
    background:var(--panel);border:1px solid var(--line-mid);color:var(--text);
    font-family:inherit;font-size:13px;font-weight:400;
    padding:6px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;
  }
  .month-pick:hover, .day-pick:hover{border-color:var(--primary);color:var(--primary)}
  .month-pick .ico, .day-pick .ico{color:var(--text-3);font-size:13px}
  .month-pick:hover .ico, .day-pick:hover .ico{color:var(--primary)}
  .day-pick > span:not(.ico){color:var(--text-3);font-size:12.5px}
  .day-pick b{font-weight:500}
  .month-pick b{font-weight:500}

  #month-picker-menu,
  #day-picker-menu{
    overflow:hidden!important;box-sizing:border-box;background-clip:padding-box;isolation:isolate;
    contain:paint;clip-path:inset(0 round 10px);
    -webkit-mask-image:-webkit-radial-gradient(white, black);
  }
  #month-picker-menu::after,
  #day-picker-menu::after{
    content:"";position:absolute;left:0;right:0;bottom:0;height:5px;
    background:#fff;pointer-events:none;z-index:3;border-radius:0 0 10px 10px;
  }

  .range-seg{display:flex;background:var(--panel);border:1px solid var(--line-mid);border-radius:var(--radius-sm);padding:0;gap:0;overflow:hidden}
  .range-seg button{
    background:transparent;border:none;color:var(--text-2);font-size:13px;font-weight:400;
    padding:6px 14px;cursor:pointer;font-family:inherit;
    transition:all .15s;border-right:1px solid var(--line);
  }
  .range-seg button:last-child{border-right:none}
  .range-seg button.active{
    background:var(--primary-soft);color:var(--primary);font-weight:500;
  }
  .range-seg button:hover:not(.active){color:var(--text);background:var(--bg-2)}

  /* ─────────── KPI ─────────── */
  .kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:14px}
  .kpi{
    background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
    padding:14px 16px;position:relative;overflow:hidden;
    transition:border-color .15s, box-shadow .15s;
  }
  .kpi:hover{border-color:#c9d6f0;box-shadow:0 2px 8px rgba(22,100,255,0.06)}

  .kpi-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
  .kpi-head .title{display:inline-flex;align-items:center;gap:4px;font-size:13px;color:var(--text-2);font-weight:400}
  .kpi-head .title .dot{display:none}
  .kpi-head .title::after{
    content:"?";display:inline-flex;align-items:center;justify-content:center;
    width:13px;height:13px;border-radius:50%;background:var(--bg-3);
    color:var(--text-3);font-size:10px;font-weight:500;cursor:help;margin-left:2px;font-family:"Inter";
  }
  .kpi-head .badge{
    font-family:"Inter",sans-serif;font-size:12px;font-weight:500;
    padding:0;border-radius:0;background:transparent !important;
    display:inline-flex;align-items:center;gap:2px;
  }
  /* 中国式涨跌：上升红、下降绿 */
  .kpi-head .badge.up{color:var(--up)}
  .kpi-head .badge.down{color:var(--down)}
  .kpi-head .badge.flat{color:var(--text-3)}
  .kpi-head .badge.neutral{color:var(--primary)}

  .kpi-body{display:flex;align-items:center;gap:10px}
  .kpi-body .left{flex:1;min-width:0}
  .kpi-body .pie{width:46px;height:46px;flex:none;position:relative}
  .kpi-body .pie svg{width:100%;height:100%;transform:rotate(-90deg)}
  .kpi-body .pie .pie-center{
    position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
    font-family:"Inter";font-size:10px;font-weight:600;color:var(--text);
  }

  .kpi-num{font-family:"Inter","PingFang SC",sans-serif;font-size:26px;font-weight:600;letter-spacing:-0.02em;line-height:1.1;color:var(--text)}
  .kpi-sub{margin-top:6px;font-size:12px;color:var(--text-3);display:flex;justify-content:space-between;align-items:baseline;gap:8px;font-weight:400}
  .kpi-sub b{color:var(--text-2);font-weight:500;font-family:"Inter";font-size:12.5px}
  .kpi-spark{margin-top:6px;height:18px}
  .kpi-spark svg{width:100%;height:100%}

  /* "较上期"、"投放占比" 风格的额外信息行 */
  .kpi-extra{
    margin-top:8px;font-size:12px;color:var(--text-3);font-weight:400;
    display:flex;flex-direction:column;gap:3px;
  }
  .kpi-extra .row{display:flex;justify-content:flex-start;gap:6px;align-items:baseline}
  .kpi-extra .row .lb{color:var(--text-3)}
  .kpi-extra .row .vl{color:var(--text-2);font-family:"Inter"}

  /* ─────────── LAYOUT ─────────── */
  .layout{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:12px}
  .layout > div:first-child{min-width:0}

  /* ─────────── MATRIX ─────────── */
  .matrix-card{
    background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
    overflow:hidden;
  }
  .matrix-head{
    padding:12px 16px;border-bottom:1px solid var(--line);
    display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;
  }
  .matrix-head .h-left{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
  .h-title{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:500;color:var(--text);letter-spacing:0}
  .h-title::before{content:"";display:inline-block;width:3px;height:13px;background:var(--primary);border-radius:1px}
  .filters{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
  .chip{
    font-size:12.5px;padding:4px 12px;border:1px solid transparent;background:var(--bg-2);color:var(--text-2);
    border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;font-weight:400;
    font-family:inherit;
  }
  .chip:hover{background:var(--bg-3);color:var(--text)}
  .chip.active{background:var(--primary-soft);color:var(--primary);font-weight:500}
  .controls-right{display:flex;gap:8px;align-items:center}

  /* toggle all button */
  .toggle-all{
    display:inline-flex;align-items:center;gap:5px;
    background:var(--panel);border:1px solid var(--line-mid);color:var(--text-2);
    font-size:12.5px;font-weight:400;padding:4px 10px;border-radius:var(--radius-sm);cursor:pointer;
    font-family:inherit;transition:all .15s;
  }
  .toggle-all:hover{border-color:var(--primary);color:var(--primary)}
  .toggle-all .ic{font-family:"Inter";font-size:12px;line-height:1}

  .matrix-scroll{overflow-x:auto;overflow-y:hidden}
  table.matrix{border-collapse:separate;border-spacing:0;font-size:12px;width:max-content;min-width:100%}
  table.matrix thead th{
    position:sticky;top:0;z-index:5;background:var(--bg-2);
    font-weight:400;font-size:12px;
    color:var(--text-3);text-align:center;
    padding:9px 3px;border-bottom:1px solid var(--line);
  }
  table.matrix thead th.date{min-width:42px;cursor:pointer;transition:background .15s}
  table.matrix thead th.date:hover{background:var(--bg-3)}
  table.matrix thead th.date.selected{background:var(--primary-soft)}
  table.matrix thead th.date .dow{display:block;font-size:10px;color:var(--text-4);font-weight:400;margin-bottom:2px}
  table.matrix thead th.date b{display:block;font-family:"Inter";font-size:12.5px;font-weight:500;color:var(--text-2)}
  table.matrix thead th.date.weekend b{color:var(--up)}
  table.matrix thead th.date.weekend .dow{color:var(--up)}
  table.matrix thead th.date.selected b{color:var(--primary)}
  table.matrix thead th.date.selected .dow{color:var(--primary)}
  table.matrix thead th.date.today{
    background:var(--primary-softer);position:relative;
  }
  table.matrix thead th.date.today::before{
    content:"";position:absolute;left:50%;top:4px;width:4px;height:4px;border-radius:50%;
    background:var(--primary);transform:translateX(-50%);
  }
  /* sticky first columns */
  table.matrix thead th.first,
  table.matrix tbody td.name{
    position:sticky;left:0;z-index:3;background:var(--panel);
  }
  table.matrix thead th.first{z-index:6;background:var(--bg-2)}
  table.matrix thead th.first{text-align:left;padding-left:16px;min-width:200px;border-right:1px solid var(--line)}
  table.matrix thead th.fans{
    position:sticky;left:200px;z-index:5;background:var(--bg-2);min-width:60px;
  }
  table.matrix thead th.search{
    position:sticky;left:260px;z-index:5;background:var(--bg-2);min-width:50px;border-right:1px solid var(--line);
  }
  table.matrix tbody td.fans{position:sticky;left:200px;z-index:2;background:var(--panel)}
  table.matrix tbody td.searchable{position:sticky;left:260px;z-index:2;background:var(--panel);border-right:1px solid var(--line)}

  /* owner header */
  tr.owner-row td{padding:0;border-top:1px solid var(--line);background:#fafbfc !important}
  .owner-cell{padding:10px 16px;cursor:pointer;user-select:none;display:flex;align-items:center;gap:10px}
  .owner-cell .caret{display:inline-flex;width:14px;height:14px;align-items:center;justify-content:center;color:var(--text-3);transition:transform .2s;font-size:9px}
  tr.owner-row:not(.collapsed) .caret{transform:rotate(90deg);color:var(--primary)}
  .owner-cell .avatar{
    width:26px;height:26px;border-radius:6px;display:flex;align-items:center;justify-content:center;
    font-family:"Inter";font-weight:500;font-size:12px;color:#fff;flex:none;
  }
  .owner-cell .o-text{display:flex;flex-direction:column;line-height:1.3}
  .owner-cell .o-name{font-size:13px;font-weight:500;color:var(--text)}
  .owner-cell .o-stats{font-size:11px;color:var(--text-3);margin-top:2px;font-weight:400}
  .owner-cell .o-stats b{color:var(--text-2);font-weight:500;font-family:"Inter"}

  tr.owner-row td.owner-day{
    background:#fafbfc !important;text-align:center;padding:7px 3px;vertical-align:middle;
    border-top:1px solid var(--line);
  }
  tr.owner-row td.owner-day .od-orders{font-family:"Inter";font-size:13px;font-weight:500;color:var(--text);line-height:1}
  tr.owner-row td.owner-day .od-orders.zero{color:var(--text-4);font-weight:400}
  tr.owner-row td.owner-day .od-videos{
    font-family:"Inter";font-size:10px;font-weight:600;color:var(--video);
    margin-top:3px;line-height:1;
    display:inline-flex;align-items:center;gap:2px;
    padding:2px 5px;background:var(--video-soft);border-radius:3px;
  }
  tr.owner-row td.owner-day .od-videos.zero{background:transparent;color:var(--text-4);font-weight:400;padding:0}
  tr.owner-row td.owner-day .od-videos .vd-ico{
    display:inline-block;width:0;height:0;
    border-style:solid;border-width:3px 0 3px 4px;
    border-color:transparent transparent transparent var(--video);
  }

  tr.acct td{
    padding:8px 3px;text-align:center;border-top:1px solid var(--line-soft);
    transition:background .12s;font-family:"Inter";font-size:12.5px;color:var(--text);font-weight:400;
  }
  tr.acct:hover td{background:#fafbfc}
  tr.acct:hover td.name, tr.acct:hover td.fans, tr.acct:hover td.searchable{background:#fafbfc}
  tr.acct td.name{
    text-align:left;padding-left:46px;font-family:inherit;cursor:pointer;font-size:13px;font-weight:400;max-width:240px;
    border-right:1px solid var(--line-soft);
  }
  tr.acct td.name .nick{display:block;font-weight:400;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:color .15s}
  tr.acct td.name .uid{display:block;font-family:"Inter";font-size:11px;color:var(--text-4);margin-top:2px;font-weight:400}
  tr.acct td.name:hover .nick{color:var(--primary)}
  tr.acct td.searchable .pill{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;line-height:1}
  tr.acct td.searchable .pill svg{width:10px;height:10px;display:block}
  tr.acct td.searchable.yes .pill{background:var(--down-soft);color:var(--down)}
  tr.acct td.searchable.no .pill{background:var(--up-soft);color:var(--up)}
  tr.acct td.fans{font-family:"Inter";font-size:12.5px;font-weight:500;color:var(--text-2)}

  td.cell{position:relative;font-family:"Inter";font-size:12.5px;color:var(--text-2);min-width:42px}
  td.cell .v{position:relative;z-index:2;font-weight:500}
  td.cell.empty .v::before{content:"·";color:var(--text-4)}
  td.cell.empty .v{color:transparent}
  /* 视频单元格：粉色背景 + 右上角小三角标识 */
  td.cell.video::after{
    content:"";position:absolute;inset:3px;border-radius:4px;
    background:var(--video-soft);z-index:0;
  }
  td.cell.video::before{
    content:"";position:absolute;top:3px;right:3px;
    width:0;height:0;
    border-style:solid;border-width:0 8px 8px 0;
    border-color:transparent var(--video) transparent transparent;
    z-index:3;border-top-right-radius:4px;
  }
  td.cell.video .v{color:var(--video);font-weight:600}
  /* 空单元格但有视频：显示更精致的播放小圆点 */
  td.cell.video.empty .v::before{
    content:"";display:inline-block;width:6px;height:6px;
    border-radius:50%;background:var(--video);
    box-shadow:0 0 0 3px var(--video-soft);
    position:relative;top:-1px;
  }
  td.cell.weekend{background:#fafbfc}
  td.cell.today{
    background:var(--primary-softer);
  }

  td.cell .heat{position:absolute;inset:3px;border-radius:4px;opacity:0;transition:opacity .2s;z-index:0}
  body.heat-on td.cell .heat{opacity:.85}
  body.heat-on td.cell.video::after{opacity:0}
  body.heat-on td.cell.video::before{
    /* 热力模式下保留右上角小三角 */
    border-color:transparent var(--video) transparent transparent;
  }

  /* ─────────── SIDE ─────────── */
  .side{display:flex;flex-direction:column;gap:12px}
  .card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
  .card-head{
    padding:12px 16px;border-bottom:1px solid var(--line);
    display:flex;justify-content:space-between;align-items:center;gap:8px;
  }
  .card-head .h-sub{font-family:"Inter";font-size:11px;color:var(--text-3);letter-spacing:0.04em;text-transform:uppercase;font-weight:500}
  .card-body{padding:6px 4px 12px}

  /* TOP10 — unified clean rows */
  .top10-list{padding:4px 0}

  .top10-row{
    display:grid;grid-template-columns:22px 1fr auto;gap:10px;align-items:center;
    padding:8px 16px;transition:background .12s;cursor:pointer;position:relative;
  }
  .top10-row:hover{background:var(--bg-2)}
  .top10-row::after{
    content:"";position:absolute;left:48px;right:16px;bottom:0;height:1px;
    background:var(--line-soft);
  }
  .top10-row:last-child::after{display:none}
  .top10-row .rk{
    font-family:"Inter";font-size:12.5px;font-weight:500;color:var(--text-4);text-align:center;
  }
  .top10-row.t1 .rk, .top10-row.t2 .rk, .top10-row.t3 .rk{
    color:#fff;width:18px;height:18px;line-height:18px;border-radius:3px;font-size:11px;font-weight:600;justify-self:center;
  }
  .top10-row.t1 .rk{background:#ff4d4f}
  .top10-row.t2 .rk{background:#ff7a45}
  .top10-row.t3 .rk{background:#faad14}
  .top10-row .info{min-width:0;display:flex;align-items:center;gap:8px}
  .top10-row .o-dot{
    width:5px;height:5px;border-radius:50%;flex:none;
  }
  .top10-row .nm{
    font-family:inherit;font-size:13px;color:var(--text);font-weight:400;
    overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;
  }
  .top10-row .right{display:flex;align-items:baseline;gap:8px;flex:none}
  .top10-row .vl{
    font-family:"Inter";font-size:14px;font-weight:600;color:var(--text);letter-spacing:-0.01em;
  }
  .top10-row .delta-mini{
    font-family:"Inter";font-size:11px;font-weight:500;color:var(--text-3);
    min-width:32px;text-align:right;
  }
  /* 中国式涨跌色 */
  .top10-row .delta-mini.up{color:var(--up)}
  .top10-row .delta-mini.down{color:var(--down)}

  .top10-empty{text-align:center;padding:40px 16px;color:var(--text-4);font-size:12.5px}

  /* Owner ranking carousel */
  .carousel-head{
    display:flex;justify-content:space-between;align-items:center;
    padding:6px 14px;font-family:"Inter";font-size:10px;color:var(--text-3);
    text-transform:uppercase;letter-spacing:0.06em;font-weight:500;
  }
  .carousel-tabs{display:flex;gap:0;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden}
  .carousel-tabs button{
    background:var(--panel);border:none;color:var(--text-2);
    font-size:11.5px;font-weight:400;padding:3px 10px;cursor:pointer;
    font-family:inherit;
    transition:all .15s;border-right:1px solid var(--line);
  }
  .carousel-tabs button:last-child{border-right:none}
  .carousel-tabs button.active{background:var(--primary-soft);color:var(--primary);font-weight:500}
  .carousel-tabs button:hover:not(.active){background:var(--bg-2)}

  .owner-rank-list{padding:8px 16px 10px}
  .owner-rank-item{
    display:grid;grid-template-columns:22px 28px 1fr auto;gap:10px;align-items:center;
    padding:8px 0;
  }
  .owner-rank-item .rk{
    font-family:"Inter";font-size:12.5px;font-weight:500;color:var(--text-4);text-align:center;
  }
  .owner-rank-item.t1 .rk{color:var(--up)}
  .owner-rank-item .av{
    width:26px;height:26px;border-radius:6px;display:flex;align-items:center;justify-content:center;
    font-family:"Inter";font-weight:500;font-size:12px;color:#fff;
  }
  .owner-rank-item .nm{font-size:13px;font-weight:500;color:var(--text)}
  .owner-rank-item .nm .sub{font-size:11px;color:var(--text-3);font-family:inherit;margin-top:2px;font-weight:400}
  .owner-rank-item .vl{font-family:"Inter";font-size:18px;font-weight:600;color:var(--text);letter-spacing:-0.02em}
  .owner-rank-item.t1 .vl{color:var(--text)}
  .owner-rank-item .bar-track{
    grid-column:3 / -1;height:3px;background:var(--bg-2);border-radius:2px;overflow:hidden;margin-top:5px;
  }
  .owner-rank-item .bar-fill{height:100%;border-radius:2px;transition:width .6s cubic-bezier(.2,.7,.2,1)}

  .carousel-dots{display:flex;justify-content:center;gap:4px;padding:4px 0 10px}
  .carousel-dots .dt{width:5px;height:5px;border-radius:50%;background:var(--line-mid);transition:all .2s;cursor:pointer}
  .carousel-dots .dt.active{background:var(--primary);width:14px;border-radius:3px}

  /* legend */
  .legend-card{padding:14px 16px}

  /* 订单省份占比 */
  .province-sub{
    display:flex;justify-content:space-between;align-items:center;
    padding:6px 16px 4px;font-size:11px;color:var(--text-3);font-weight:400;
    font-family:"Inter";
  }
  .province-sub .cols-left{}
  .province-sub .cols-right{display:flex;gap:14px}
  .province-sub .cols-right span{display:inline-block;text-align:right;min-width:38px}
  .province-list{
    padding:2px 0 6px;
    max-height:340px;overflow-y:auto;
  }
  .province-list::-webkit-scrollbar{width:6px}
  .province-list::-webkit-scrollbar-thumb{background:#dfe2e8;border-radius:3px;border:none;background-clip:initial}
  .province-list::-webkit-scrollbar-thumb:hover{background:#c9cdd4;border:none}
  .prov-empty{
    padding:24px 16px 28px;
    text-align:center;
    color:var(--text-3);
    font-size:12.5px;
  }

  .prov-row{
    display:grid;grid-template-columns:22px 36px 1fr 44px 44px;gap:8px;
    align-items:center;padding:7px 16px;font-size:12.5px;
    transition:background .12s;
  }
  .prov-row:hover{background:var(--bg-2)}
  .prov-row .rk{
    font-family:"Inter";font-size:12.5px;font-weight:500;color:var(--text-4);text-align:center;
  }
  .prov-row.t1 .rk{color:#f5413f;font-weight:600}
  .prov-row.t2 .rk{color:#ff9e2c;font-weight:600}
  .prov-row.t3 .rk{color:#f7ba1e;font-weight:600}
  .prov-row .nm{font-size:13px;color:var(--text);font-weight:400}
  .prov-row .bar-track{
    height:7px;background:#f0f2f5;border-radius:99px;overflow:hidden;position:relative;
  }
  .prov-row .bar-fill{
    height:100%;border-radius:99px;
    background:linear-gradient(90deg,#7eb0ff,#5d9eff);
    transition:width .6s cubic-bezier(.2,.7,.2,1);
  }
  .prov-row.t1 .bar-fill{background:linear-gradient(90deg,#ff7a7a,#f5413f)}
  .prov-row.t2 .bar-fill{background:linear-gradient(90deg,#ffb778,#ff9e2c)}
  .prov-row.t3 .bar-fill{background:linear-gradient(90deg,#ffd874,#f7ba1e)}
  .prov-row .pct{
    font-family:"Inter";font-size:12.5px;font-weight:500;color:var(--text-2);
    text-align:right;
  }
  .prov-row .tgi{
    font-family:"Inter";font-size:12.5px;font-weight:500;color:var(--text-3);
    text-align:right;
  }
  .prov-row .tgi.high{color:var(--up)}
  .prov-row .tgi.low{color:var(--text-4)}

  /* 订单年龄分布 - donut chart + 图例 */
  .age-chart{
    padding:8px 16px 14px;
  }
  .age-donut-wrap{
    display:flex;justify-content:center;align-items:center;
    padding:14px 0 18px;
    position:relative;
  }
  .age-donut-wrap svg{
    width:200px;height:200px;display:block;
    overflow:visible;
  }
  .age-legend{
    display:grid;grid-template-columns:1fr 1fr;gap:6px 14px;
    padding-top:6px;
  }
  .age-legend-item{
    display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text-2);
    padding:3px 0;line-height:1.4;
    transition:opacity .15s;
  }
  .age-legend-item .sw{
    width:10px;height:10px;border-radius:3px;flex:none;
  }
  .age-legend-item .lb{
    flex:1;color:var(--text-2);font-weight:400;
    overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  }
  .age-legend-item .pct{
    font-family:"Inter";color:var(--text);font-weight:500;font-size:12.5px;
  }
  .age-chart .seg{
    cursor:pointer;
    pointer-events:all;
    transform-origin:50% 50%;
    transform-box:fill-box;
    transition:opacity .15s, transform .2s cubic-bezier(.4,0,.2,1), filter .15s;
  }
  .age-chart .seg.dim{opacity:.32}
  .age-chart .seg.active{
    transform:scale(1.04);
    filter:drop-shadow(0 2px 6px rgba(31,35,41,0.18));
  }

  /* 饼图 tooltip */
  .age-tooltip{
    position:absolute;pointer-events:none;
    background:rgba(31,35,41,0.92);color:#fff;
    padding:6px 10px;border-radius:6px;
    font-size:12px;font-family:"PingFang SC","Inter";
    white-space:nowrap;
    opacity:0;transform:translate(-50%, -100%);
    transition:opacity .15s;
    z-index:10;
    box-shadow:0 4px 12px rgba(31,35,41,0.16);
    display:flex;align-items:center;gap:6px;
  }
  .age-tooltip.show{opacity:1}
  .age-tooltip::after{
    content:"";position:absolute;left:50%;top:100%;
    transform:translateX(-50%);
    width:0;height:0;
    border:4px solid transparent;
    border-top-color:rgba(31,35,41,0.92);
  }
  .age-tooltip .tip-dot{
    width:8px;height:8px;border-radius:50%;flex:none;
  }
  .age-tooltip .tip-label{color:#fff;font-weight:400}
  .age-tooltip .tip-pct{
    color:#fff;font-weight:600;font-family:"Inter";
    letter-spacing:-0.01em;
  }

  /* legend card 保持原样 */
  .legend-card{padding:14px 16px}
  .legend-card .row{display:flex;align-items:center;gap:10px;padding:5px 0;font-size:12.5px;color:var(--text-2)}
  .legend-card .row .sw{display:inline-block;width:14px;height:14px;border-radius:3px;flex:none}
  .legend-card .note{margin-top:10px;padding-top:10px;border-top:1px dashed var(--line);font-size:11.5px;color:var(--text-3);line-height:1.7}
  .legend-card .note b{color:var(--text-2);font-weight:500}

  /* drawer */
  .drawer-backdrop{position:fixed;inset:0;background:rgba(31,35,41,0.32);backdrop-filter:blur(2px);opacity:0;pointer-events:none;transition:opacity .2s;z-index:90}
  .drawer-backdrop.open{opacity:1;pointer-events:auto}
  .drawer{
    position:fixed;top:0;right:0;height:100vh;width:520px;max-width:92vw;
    background:var(--panel);border-left:1px solid var(--line);
    transform:translateX(100%);transition:transform .28s cubic-bezier(.4,.0,.2,1);
    z-index:100;display:flex;flex-direction:column;box-shadow:-8px 0 24px rgba(31,35,41,0.08);
  }
  .drawer.open{transform:translateX(0)}
  .drawer .drawer-head{padding:20px 24px 16px;border-bottom:1px solid var(--line);position:relative}
  .drawer .close{
    position:absolute;top:16px;right:16px;background:var(--bg-2);border:none;color:var(--text-2);
    font-size:18px;cursor:pointer;padding:5px 9px;border-radius:5px;transition:all .15s;
  }
  .drawer .close:hover{background:var(--up-soft);color:var(--up)}
  .drawer h2{margin:0;font-size:18px;font-weight:600;letter-spacing:0;color:var(--text)}
  .drawer .uid-line{font-family:"Inter";font-size:12px;color:var(--text-3);margin-top:6px;display:flex;align-items:center;gap:8px}
  .drawer .uid-line .owner-tag{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-weight:500;font-size:11px;font-family:inherit}
  .drawer .quick{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:14px}
  .drawer .quick .q{background:var(--bg-2);border-radius:6px;padding:10px 12px;transition:all .15s}
  .drawer .quick .q:hover{background:var(--bg-3)}
  .drawer .quick .q .lbl{font-size:11px;color:var(--text-3);font-weight:400}
  .drawer .quick .q .val{font-family:"Inter";font-size:20px;font-weight:600;margin-top:4px;letter-spacing:-0.02em;color:var(--text)}
  .drawer .quick .q.acc .val{color:var(--primary)}
  .drawer-body{padding:20px 24px;overflow-y:auto;flex:1}
  .drawer-body h3{font-size:13px;color:var(--text);font-weight:500;margin:0 0 12px;letter-spacing:0}
  .mini-chart{height:170px;margin-bottom:24px}
  .mini-chart svg{width:100%;height:100%;overflow:visible}
  .history{list-style:none;padding:0;margin:0}
  .history li{padding:9px 12px;border-radius:6px;margin-bottom:4px;display:flex;justify-content:space-between;background:var(--bg-2);font-size:12.5px;color:var(--text-2)}
  .history li .when{font-family:"Inter";font-size:11px;color:var(--text-3)}
  .history li.current{background:var(--primary-soft);color:var(--primary-deep);font-weight:500}
  .history li.current .when{color:var(--primary)}
  .history li.current::before{content:"●  ";color:var(--primary)}

  .tip{position:fixed;background:#1f2329;color:#fff;padding:7px 10px;border-radius:5px;font-size:11.5px;font-family:"Inter";pointer-events:none;z-index:200;opacity:0;transition:opacity .12s;box-shadow:0 4px 16px rgba(31,35,41,0.2)}
  .tip b{color:#5d9eff;font-weight:600}
  .tip.show{opacity:1}

  .foot{margin-top:12px;font-size:12px;color:var(--text-3);text-align:right;font-weight:400}
  .foot b{color:var(--primary);font-weight:500}

  ::-webkit-scrollbar{width:10px;height:10px}
  ::-webkit-scrollbar-track{background:transparent}
  ::-webkit-scrollbar-thumb{background:#d6dbe0;border-radius:5px;border:2px solid transparent;background-clip:padding-box}
  ::-webkit-scrollbar-thumb:hover{background:#b3b9c0;background-clip:padding-box;border:2px solid transparent}

  /* ─────────── DAILY SUMMARY TABLE (bottom full-width) ─────────── */
  .summary-section{
    margin-top:14px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
    overflow:hidden;position:relative;isolation:isolate;
    contain:paint;clip-path:inset(0 round var(--radius));
    -webkit-mask-image:-webkit-radial-gradient(white, black);
  }
.summary-section::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:4px;
  background:var(--bg-2);
  pointer-events:none;z-index:6;
}
.summary-section:has(table.summary tfoot tr.active)::after{background:#edf4ff}
  .summary-head{
    padding:12px 18px;border-bottom:1px solid var(--line);
    display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;
  }
  .summary-head .stats{
    display:flex;gap:20px;font-size:11px;color:var(--text-3);
    align-items:center;justify-content:space-between;flex:1;min-width:360px;
  }
  .summary-month-btn{
    display:none;
    border:1px solid var(--line-mid);background:#fff;color:var(--text-2);
    height:30px;padding:0 13px;border-radius:999px;font-size:13px;font-weight:400;
    cursor:pointer;transition:all .15s;margin-left:auto;
  }
  .summary-month-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-softer)}
  .summary-month-btn.active{border-color:var(--primary);background:var(--primary-soft);color:var(--primary);font-weight:500}
  .summary-head .stats .s{display:flex;flex-direction:column;gap:2px;align-items:center;text-align:center;min-width:72px}
  .summary-head .stats .s b{color:var(--text);font-weight:600;font-size:18px;font-family:"Inter";letter-spacing:-0.015em;line-height:1}
  .summary-head .stats .s i{font-style:normal;color:var(--text-3);font-size:12px;font-weight:400}
  .summary-head .stats .divider{display:none}

  .summary-scroll{
    overflow:auto;max-height:600px;background:var(--panel);
    overscroll-behavior:contain;contain:paint;
  }
  .summary-product-section{
    margin-top:14px;background:var(--panel);border:1px solid var(--line);
    border-radius:var(--radius);overflow:hidden;
  }
  table.summary{
    width:100%;border-collapse:separate;border-spacing:0;font-size:12px;min-width:980px;
    background:var(--panel);
  }
  table.summary thead th{
    position:sticky;top:0;z-index:3;background:var(--bg-2);
    font-weight:400;font-size:12.5px;
    color:var(--text-3);text-align:right;padding:10px 14px;
    border-bottom:1px solid var(--line);
    white-space:nowrap;
  }
  table.summary thead th:first-child{text-align:left;padding-left:18px}
  table.summary thead th .unit{color:var(--text-4);font-weight:400;font-size:11px;margin-left:2px}
  table.summary thead th.sortable{cursor:pointer;user-select:none;transition:all .15s}
  table.summary thead th.sortable:hover{background:var(--bg-3);color:var(--text)}
  table.summary thead th.sortable .arrow{
    display:inline-block;margin-left:4px;font-size:9px;color:var(--text-4);
  }
  table.summary thead th.sortable.asc .arrow,
  table.summary thead th.sortable.desc .arrow{color:var(--primary)}

  table.summary tbody tr{transition:background .1s;cursor:pointer}
  table.summary tbody tr:hover{background:var(--bg-2)}
  table.summary tbody tr.today{background:var(--primary-softer)}
  table.summary tbody tr.today:hover{background:var(--primary-soft)}
  table.summary tbody tr.active{background:#edf4ff}
  table.summary tbody tr.active:hover{background:#e4efff}
  table.summary tbody tr.active td:first-child{box-shadow:inset 3px 0 0 var(--primary)}
  table.summary tbody td{
    padding:11px 14px;font-family:"Inter",sans-serif;font-size:13px;
    color:var(--text);text-align:right;border-bottom:1px solid var(--line-soft);
    white-space:nowrap;font-weight:400;
  }
  table.summary tbody tr:last-child td{border-bottom:0}
  table.summary tbody td.date-cell{
    text-align:left;padding-left:18px;font-weight:400;
    display:flex;align-items:center;gap:6px;font-family:inherit;
  }
  table.summary tbody td.date-cell .d-num{font-size:13px;font-weight:500;color:var(--text)}
  table.summary tbody td.date-cell .d-dow{
    font-size:11px;color:var(--text-3);padding:1px 6px;border-radius:3px;background:var(--bg-2);
    font-weight:400;
  }
  table.summary tbody td.date-cell .d-dow.weekend{background:var(--up-soft);color:var(--up)}
  table.summary tbody td.date-cell .badge-today{
    background:var(--primary);color:#fff;font-size:10px;font-weight:500;letter-spacing:.04em;
    padding:1px 6px;border-radius:3px;text-transform:uppercase;font-family:"Inter";
  }
  table.summary tbody td.num{font-weight:500}
  table.summary tbody td.num.zero{color:var(--text-4);font-weight:400}
  table.summary tbody td.rate{font-weight:500}
  table.summary tbody td.rate.zero{color:var(--text-4);font-weight:400}
  table.summary tbody td .rate-bar{
    display:inline-block;width:40px;height:3px;background:var(--bg-3);border-radius:2px;
    margin-left:8px;vertical-align:middle;overflow:hidden;
  }
  table.summary tbody td .rate-bar .fill{height:100%;border-radius:2px}
  table.summary tbody td.col-plays{color:var(--c-purple)}
  table.summary tbody td.col-orders{color:var(--c-orange)}
  table.summary tbody td.col-conv{color:var(--down)}
  table.summary tbody td.col-ship{color:var(--c-blue)}
  table.summary tbody td.col-actv{color:var(--c-orange)}

table.summary tfoot td{
  padding:11px 14px;font-family:"Inter";font-size:13px;font-weight:600;
  text-align:right;background:inherit;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  color:var(--text);position:sticky;bottom:0;z-index:2;
  box-shadow:none;
}
table.summary tfoot tr:last-child td{border-bottom:1px solid var(--line)}
  table.summary tfoot td:first-child{text-align:left;padding-left:18px;color:var(--text-2);font-size:12px;font-weight:500;font-family:inherit;letter-spacing:0;text-transform:none}

  .summary-product-detail{
    padding:16px 18px 18px;
    background:#f7f9fc;
  }
  .summary-detail-head{
    display:flex;align-items:flex-start;justify-content:space-between;gap:16px;
    margin-bottom:12px;
  }
  .summary-detail-title{
    font-size:15px;font-weight:600;color:var(--text);line-height:1.4;
  }
  .summary-detail-desc{
    margin-top:3px;font-size:12px;color:var(--text-3);font-weight:400;
  }
  .summary-detail-meta{
    display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end;
    color:var(--text-3);font-size:12px;
  }
  .summary-detail-meta span{
    display:inline-flex;align-items:center;gap:3px;padding:5px 8px;
    border:1px solid var(--line);border-radius:999px;background:#fff;
  }
  .summary-detail-meta b{
    font-family:"Inter",sans-serif;font-size:13px;color:var(--text);font-weight:600;
  }
  .summary-month-trigger{
    cursor:default;border-radius:0;padding:0;margin:0;transition:none;pointer-events:none;
  }
  .summary-month-trigger:hover{background:transparent}
table.summary tfoot tr{cursor:pointer;background:var(--bg-2)}
table.summary tfoot tr.active{background:#edf4ff}
table.summary tfoot tr.active td{background:inherit;border-bottom-color:#dbe8ff}
table.summary tfoot tr.active td:first-child{box-shadow:inset 3px 0 0 var(--primary)}
  .summary-product-grid{
    display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:14px;align-items:stretch;
  }
  .summary-detail-card{
    min-width:0;border:1px solid var(--line);border-radius:12px;background:#fff;
    box-shadow:0 10px 26px rgba(15,23,42,.045);overflow:hidden;
    display:flex;flex-direction:column;height:100%;
  }
  .summary-card-head{
    height:72px;display:flex;align-items:center;justify-content:space-between;gap:12px;
    padding:12px 14px;border-bottom:1px solid var(--line-soft);background:linear-gradient(180deg,#fff,#fbfcff);
    box-sizing:border-box;flex:0 0 72px;
  }
  .summary-card-title{font-size:14px;font-weight:600;color:var(--text);line-height:1.35}
  .summary-card-desc{margin-top:2px;font-size:12px;font-weight:400;color:var(--text-3);line-height:1.35}
  .summary-card-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;min-width:0;flex-wrap:nowrap}
  .summary-card-actions .summary-detail-meta{gap:6px;flex-wrap:nowrap}
  .summary-card-actions .summary-detail-meta span{padding:4px 7px}
  .summary-product-clear{
    height:28px;padding:0 10px;border:1px solid #cfe0ff;border-radius:999px;background:#f3f7ff;
    color:var(--primary);font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;
  }
  .summary-product-clear:hover{background:#eaf2ff;border-color:#9fc2ff}
  .summary-product-main-panel{min-width:0}
  .summary-product-table-wrap{
    overflow:auto;max-height:380px;background:#fff;flex:1;
  }
  table.summary-products{
    width:100%;min-width:820px;border-collapse:separate;border-spacing:0;
    font-size:12px;color:var(--text);
  }
  table.summary-products th{
    position:sticky;top:0;z-index:2;
    background:var(--bg-2);color:var(--text-3);font-weight:400;text-align:center;
    padding:9px 8px;border-bottom:1px solid var(--line);white-space:nowrap;
  }
  table.summary-products th:first-child{text-align:left;padding-left:14px}
  table.summary-products td{
    padding:10px 8px;text-align:center;border-bottom:1px solid var(--line-soft);
    font-family:"Inter",sans-serif;font-weight:500;color:var(--text);
    white-space:nowrap;
  }
  table.summary-products tr.summary-product-row{cursor:pointer}
  table.summary-products tr.summary-product-row:hover td{background:#f7fbff}
  table.summary-products tr.summary-product-row.active td{background:#edf5ff}
  table.summary-products tr.summary-product-row.active td:first-child{box-shadow:inset 3px 0 0 var(--primary)}
  table.summary-products tr:last-child td{border-bottom:0}
  table.summary-products td.summary-product-main{
    text-align:left;padding-left:14px;font-family:inherit;min-width:190px;
  }
  .summary-product-line{
    display:flex;align-items:center;gap:7px;min-width:0;max-width:260px;line-height:22px;
  }
  .summary-product-name{
    min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
    font-size:13px;font-weight:500;color:var(--text);line-height:22px;
  }
  .summary-product-sub{
    flex:0 0 auto;max-width:104px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
    height:22px;line-height:22px;padding:0 7px;border-radius:999px;background:#f3f6fb;
    font-size:11.5px;font-weight:400;color:var(--text-3);
  }
  .summary-rate-pill{
    display:inline-flex;align-items:center;justify-content:center;min-width:48px;
    height:22px;padding:0 7px;border-radius:999px;background:var(--bg-2);
    font-size:11.5px;font-weight:600;font-family:"Inter",sans-serif;color:var(--text-3);
  }
  .summary-rate-pill.good{background:rgba(0,180,42,.1);color:var(--up)}
  .summary-rate-pill.warn{background:rgba(255,125,0,.12);color:var(--c-orange)}
  .summary-rate-pill.low{background:rgba(245,63,63,.1);color:var(--down)}
  .summary-rate-pill.zero{background:#f2f3f5;color:var(--text-4)}
  .summary-product-empty{
    display:flex;align-items:center;justify-content:center;min-height:96px;
    border:1px dashed var(--line);border-radius:10px;background:#fff;color:var(--text-3);
    font-size:13px;
  }
  .summary-province-card{
    min-height:140px;
  }
  .summary-province-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:12px}
  .summary-province-title{font-size:14px;font-weight:600;color:var(--text);line-height:1.35}
  .summary-province-scope{margin-top:2px;font-size:11.5px;color:var(--text-3);max-width:168px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .summary-province-sub{
    display:inline-flex;align-items:center;justify-content:center;height:26px;padding:0 9px;
    border-radius:999px;background:#f5f7fb;color:var(--text-3);font-family:"Inter",sans-serif;
    font-size:12px;white-space:nowrap;
  }
  .summary-province-table-wrap{max-height:380px;overflow:auto;background:#fff;flex:1}
  table.summary-province-table{
    width:100%;min-width:340px;border-collapse:separate;border-spacing:0;
    font-size:12px;color:var(--text);
  }
  table.summary-province-table th{
    position:sticky;top:0;z-index:2;padding:9px 8px;background:var(--bg-2);
    border-bottom:1px solid var(--line);color:var(--text-3);font-weight:400;text-align:center;
    white-space:nowrap;
  }
  table.summary-province-table th:first-child{text-align:left;padding-left:14px}
  table.summary-province-table td{
    padding:10px 8px;border-bottom:1px solid var(--line-soft);text-align:center;
    font-family:"Inter",sans-serif;font-weight:500;color:var(--text);white-space:nowrap;
  }
  table.summary-province-table tr:last-child td{border-bottom:0}
  table.summary-province-table td.summary-province-name{
    text-align:left;padding-left:14px;font-family:inherit;font-weight:400;color:var(--text-2);
    max-width:90px;overflow:hidden;text-overflow:ellipsis;
  }
  .summary-province-ratio{min-width:76px}
  .summary-province-ratio span{display:block;margin-bottom:4px;font-size:11.5px;color:var(--text-2)}
  .summary-province-ratio i{
    display:block;height:4px;border-radius:999px;background:var(--bg-3);overflow:hidden;
  }
  .summary-province-ratio b{
    display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#2f80ff,#00b42a);
  }
  .summary-province-list{
    display:flex;flex-direction:column;gap:10px;max-height:340px;overflow:auto;padding-right:2px;
  }
  .summary-province-row{
    display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:3px;
    font-size:12.5px;color:var(--text-2);
  }
  .summary-province-name{font-weight:400;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .summary-province-value{font-family:"Inter",sans-serif;font-size:12px;color:var(--text-3);white-space:nowrap}
  .summary-province-active{
    display:flex;align-items:center;justify-content:space-between;gap:8px;
    margin-bottom:5px;font-size:11.5px;color:var(--text-4);
  }
  .summary-province-active b{font-family:"Inter",sans-serif;font-size:12px;font-weight:600;color:var(--up)}
  .summary-province-active span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .summary-province-bar{height:5px;background:var(--bg-3);border-radius:999px;overflow:hidden}
  .summary-province-bar span{
    display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#2f80ff,#00b42a);
  }
  .summary-province-empty{
    min-height:116px;margin:14px;border:1px dashed var(--line);border-radius:10px;display:flex;
    align-items:center;justify-content:center;color:var(--text-3);font-size:12.5px;
  }
  @media (max-width: 1180px){
    .summary-product-grid{grid-template-columns:1fr}
    .summary-province-list{max-height:220px}
  }

  /* ─────────── TREND CHART AREA ─────────── */
  .trend-area{
    padding:18px 0 12px;border-bottom:1px solid var(--line);
    background:var(--panel);
  }
  .trend-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;padding:0 18px}
  .trend-tab{
    display:inline-flex;align-items:center;gap:7px;
    background:var(--panel);border:1px solid var(--line-mid);color:var(--text-2);
    font-size:13px;font-weight:400;padding:7px 12px;border-radius:var(--radius-sm);cursor:pointer;
    transition:all .15s;font-family:inherit;
  }
  .trend-tab:hover{border-color:var(--primary);color:var(--text)}
  .trend-tab .dot{display:inline-block;width:7px;height:7px;border-radius:50%}
  .trend-tab .v{font-family:"Inter";font-weight:600;font-size:13px;color:var(--text)}
  .trend-tab .delta{font-family:"Inter";font-size:11px;font-weight:500;padding:0;background:transparent !important}
  .trend-tab .delta.up{color:var(--up)}
  .trend-tab .delta.down{color:var(--down)}
  .trend-tab .delta.flat{color:var(--text-3)}
  .trend-tab.active{
    background:var(--primary-soft);border-color:var(--primary);color:var(--primary);
  }

  .trend-chart{position:relative;height:360px;width:100%;overflow:hidden}
  .trend-chart svg{display:block;max-width:100%}
  .trend-hover{
    position:absolute;pointer-events:none;background:#1f2329;color:#fff;
    padding:10px 12px;border-radius:6px;font-size:11.5px;font-family:"Inter";
    opacity:0;transition:opacity .12s;box-shadow:0 4px 16px rgba(31,35,41,0.25);
    white-space:nowrap;z-index:5;
  }
  .trend-hover.show{opacity:1}
  .trend-hover b{font-weight:600}
  .trend-hover .h-date{color:#5d9eff;font-weight:500;border-bottom:1px solid rgba(255,255,255,0.12);padding-bottom:5px;margin-bottom:6px}
  .trend-hover .h-row{display:flex;justify-content:space-between;gap:18px;line-height:1.7}
  .trend-hover .h-row .lb{color:#9ba4b4}

  @media (max-width: 1280px){
    .layout{grid-template-columns:1fr}
    .kpis{grid-template-columns:repeat(2,1fr)}
  }
