/* competitor.css —— 原 HTML 行 1323-1720 */

  /* ─────────── 竞品监控（数据）─────────── */
  .cm-page{padding:6px 2px 24px}
  .cm-header{
    display:flex;justify-content:space-between;align-items:flex-end;
    gap:16px;flex-wrap:wrap;padding:14px 0 18px;
  }
  .cm-title{
    margin:0 0 4px;font-size:22px;font-weight:600;color:var(--text);
    letter-spacing:-0.01em;display:flex;align-items:center;gap:10px;
  }
  .cm-title .cm-bili-logo{
    height:30px;width:auto;display:inline-block;
    vertical-align:middle;flex:none;
  }
  .cm-sub{margin:0;color:var(--text-3);font-size:13px}
  .cm-sub b{color:var(--text);font-weight:600;font-family:"Inter"}
  .cm-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
  .cm-add-btn{
    display:inline-flex;align-items:center;gap:6px;
    background:var(--primary);color:#fff;border:none;
    padding:0 14px;height:32px;border-radius:6px;cursor:pointer;
    font-size:12.5px;font-weight:500;font-family:inherit;
    transition:background .15s;
  }
  .cm-add-btn:hover{background:#0e54e6}
  .cm-refresh-btn{
    display:inline-flex;align-items:center;gap:6px;
    background:var(--panel);color:var(--text-2);border:1px solid var(--line-mid);
    padding:0 12px;height:32px;border-radius:6px;cursor:pointer;
    font-size:12.5px;font-family:inherit;transition:all .15s;
  }
  .cm-refresh-btn:hover{border-color:var(--primary);color:var(--primary)}
  .cm-refresh-btn .spinning{animation:spin 1s linear infinite}
  @keyframes spin{from{transform:rotate(0)} to{transform:rotate(360deg)}}

  /* 实时监控开关 */
  .cm-live-monitor{
    display:inline-flex;align-items:center;gap:10px;
    height:32px;padding:0 12px;
    background:var(--panel);border:1px solid var(--line-mid);border-radius:6px;
    transition:all .15s;
  }
  .cm-live-monitor.active{
    border-color:rgba(245,63,63,0.4);background:rgba(245,63,63,0.04);
  }
  .cm-live-switch{
    display:inline-flex;align-items:center;gap:8px;cursor:pointer;
    font-size:12.5px;color:var(--text-2);font-weight:500;user-select:none;
  }
  .cm-live-switch input{display:none}
  .cm-switch-track{
    width:30px;height:16px;border-radius:99px;
    background:var(--bg-3);position:relative;transition:background .2s;
    flex:none;
  }
  .cm-switch-thumb{
    position:absolute;top:1px;left:1px;
    width:14px;height:14px;border-radius:50%;
    background:#fff;transition:transform .2s;
    box-shadow:0 1px 3px rgba(0,0,0,0.15);
  }
  .cm-live-switch input:checked + .cm-switch-track{background:#f53f3f}
  .cm-live-switch input:checked + .cm-switch-track .cm-switch-thumb{transform:translateX(14px)}
  .cm-switch-label{display:inline-flex;align-items:center;gap:5px}
  .cm-live-ind{
    width:6px;height:6px;border-radius:50%;background:var(--text-4);
    flex:none;transition:background .2s;
  }
  .cm-live-monitor.active .cm-live-ind{
    background:#f53f3f;
    box-shadow:0 0 0 0 rgba(245,63,63,0.5);
    animation:livePulse 1.4s ease-out infinite;
  }
  .cm-live-interval{
    height:24px !important;min-width:auto !important;
    padding:0 24px 0 10px !important;font-size:12px !important;
    border:1px solid var(--line) !important;
  }
  .cm-live-monitor:not(.active) .cm-live-interval{opacity:0.6}
  .cm-countdown{
    font-family:"Inter";font-size:11.5px;color:var(--text-3);
    min-width:40px;text-align:right;font-weight:500;
  }
  .cm-live-monitor.active .cm-countdown{color:#f53f3f}

  /* 顶部 KPI */
  .cm-kpi-row{
    display:grid;grid-template-columns:repeat(5, 1fr);gap:10px;
    margin-bottom:14px;
  }
  @media (max-width:1080px){.cm-kpi-row{grid-template-columns:repeat(3, 1fr)}}
  @media (max-width:680px){.cm-kpi-row{grid-template-columns:repeat(2, 1fr)}}
  .cm-kpi{
    background:var(--panel);border:1px solid var(--line);border-radius:8px;
    padding:12px 14px;
  }
  .cm-kpi .lbl{font-size:11.5px;color:var(--text-3);margin-bottom:6px}
  .cm-kpi .val{
    font-family:"Inter";font-size:20px;font-weight:600;
    color:var(--text);letter-spacing:-0.02em;
  }
  .cm-kpi .val .unit{font-size:11px;color:var(--text-4);font-weight:400;margin-left:3px}
  .cm-kpi .trend{
    font-family:"Inter";font-size:11px;margin-top:3px;
    display:inline-flex;align-items:center;gap:3px;
  }
  .cm-kpi .trend.up{color:#f53f3f}
  .cm-kpi .trend.down{color:#00b42a}
  .cm-kpi .live-pulse{
    display:inline-flex;align-items:center;gap:6px;
    color:#f53f3f;
  }
  .cm-kpi .live-pulse #cm-kpi-live{
    font-family:"Inter";font-size:20px;font-weight:600;
    color:#f53f3f;letter-spacing:-0.02em;line-height:1;
  }
  .cm-table .cm-live-ico-th{
    width:14px;height:14px;display:inline-block;
    margin-left:4px;vertical-align:middle;
  }
  .cm-kpi .live-dot{
    width:8px;height:8px;border-radius:50%;background:#f53f3f;
    box-shadow:0 0 0 0 rgba(245,63,63,0.5);
    animation:livePulse 1.4s ease-out infinite;
  }
  @keyframes livePulse{
    0%{box-shadow:0 0 0 0 rgba(245,63,63,0.5)}
    70%{box-shadow:0 0 0 8px rgba(245,63,63,0)}
    100%{box-shadow:0 0 0 0 rgba(245,63,63,0)}
  }

  /* 工具栏 */
  .cm-toolbar{
    display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:12px;
  }
  .cm-search{
    display:inline-flex;align-items:center;gap:6px;
    background:var(--panel);border:1px solid var(--line-mid);border-radius:6px;
    padding:0 12px;height:32px;width:240px;
    transition:border-color .15s;
  }
  .cm-search:focus-within{border-color:var(--primary)}
  .cm-search svg{color:var(--text-4);flex:none}
  .cm-search input{
    border:none;outline:none;background:transparent;flex:1;min-width:0;
    font-size:12.5px;color:var(--text);font-family:inherit;
  }
  .cm-search input::placeholder{color:var(--text-4)}
  .cm-select{
    background:var(--panel);border:1px solid var(--line-mid);border-radius:6px;
    padding:0 30px 0 12px;height:32px;min-width:130px;
    font-size:12.5px;color:var(--text);font-family:inherit;
    appearance:none;-webkit-appearance:none;cursor:pointer;outline:none;
    background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2386909c' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 10px center;
    transition:border-color .15s;
  }
  .cm-select:hover, .cm-select:focus{border-color:var(--primary)}
  .cm-toolbar-spacer{flex:1}
  .cm-pinned-filter{
    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-family:inherit;
    padding:0 12px;height:32px;border-radius:6px;cursor:pointer;
    transition:all .15s;
  }
  .cm-pinned-filter:hover{border-color:#fb7299;color:#fb7299}
  .cm-pinned-filter.active{
    background:rgba(251,114,153,0.08);
    border-color:#fb7299;color:#fb7299;font-weight:500;
  }

  /* 表格 */
  .cm-list-card{
    background:var(--panel);border:1px solid var(--line);border-radius:10px;
    overflow:hidden;
  }
  .cm-list-wrap{overflow-x:auto}
  .cm-table{
    width:100%;border-collapse:separate;border-spacing:0;
    font-size:13px;min-width:1600px;
  }
  .cm-table thead th{
    background:var(--bg-2);font-weight:400;font-size:12.5px;
    color:var(--text-3);text-align:center;
    padding:11px 10px;border-bottom:1px solid var(--line);
    white-space:nowrap;position:sticky;top:0;z-index:1;
  }
  .cm-table thead th.cm-th-sortable{cursor:pointer;user-select:none;transition:color .15s}
  .cm-table thead th.cm-th-sortable:hover{color:var(--text)}
  .cm-table thead th .sort-ico{
    display:inline-block;margin-left:3px;color:var(--text-4);
    transition:transform .15s, color .15s;vertical-align:middle;
  }
  .cm-table thead th.cm-th-sortable.asc .sort-ico{color:var(--primary);transform:rotate(180deg)}
  .cm-table thead th.cm-th-sortable.desc .sort-ico{color:var(--primary)}
  .cm-table tbody td{
    padding:10px 10px;font-size:13px;color:var(--text);
    border-bottom:1px solid var(--line-soft);text-align:center;
    transition:background .12s;vertical-align:middle;
  }
  .cm-table tbody tr:hover td{background:var(--bg-2)}
  .cm-table tbody tr:last-child td{border-bottom:none}

  /* 账号/创意单元 */
  .cm-acct{
    display:flex;align-items:center;gap:8px;
    text-align:left;min-width:160px;max-width:200px;
  }
  .cm-avatar{
    width:32px;height:32px;border-radius:50%;flex:none;
    display:flex;align-items:center;justify-content:center;
    color:#fff;font-family:"Inter";font-size:12px;font-weight:600;
    text-shadow:0 1px 2px rgba(0,0,0,0.2);overflow:hidden;
  }
  .cm-acct-info{min-width:0}
  .cm-acct-name{
    color:var(--text);font-weight:500;font-size:13px;
    overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  }
  .cm-acct-plat{
    font-size:11px;color:var(--text-4);margin-top:1px;
    display:inline-flex;align-items:center;gap:3px;
  }
  .cm-plat-tag{
    font-size:10.5px;padding:1px 5px;border-radius:3px;
    background:var(--bg-2);color:var(--text-3);font-weight:500;
  }
  .cm-plat-tag.douyin{background:#1f1f1f;color:#fff}
  .cm-plat-tag.kuaishou{background:#ff4838;color:#fff}
  .cm-plat-tag.xhs{background:#ff2741;color:#fff}
  .cm-plat-tag.bilibili{background:#00aeec;color:#fff}
  .cm-plat-tag.weibo{background:#ff8200;color:#fff}
  .cm-plat-tag.youtube{background:#ff0000;color:#fff}

  /* 视频缩略 */
  .cm-video{
    display:flex;align-items:center;gap:8px;
    text-align:left;min-width:200px;max-width:240px;
  }
  .cm-video-thumb{
    width:50px;height:36px;border-radius:5px;flex:none;
    background:var(--bg-2);overflow:hidden;
    display:flex;align-items:center;justify-content:center;
    color:var(--text-4);position:relative;
  }
  .cm-video-thumb.has-img{padding:0}
  .cm-video-thumb img{width:100%;height:100%;object-fit:cover;display:block}
  .cm-video-thumb .play-ico{position:absolute;color:rgba(255,255,255,0.95)}
  .cm-video-title{
    min-width:0;font-size:12.5px;color:var(--text);line-height:1.4;
    display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
    overflow:hidden;text-overflow:ellipsis;
  }

  /* 数字单元 */
  .cm-num{font-family:"Inter";font-weight:500}
  .cm-num.hot{color:#f53f3f;font-weight:600}
  .cm-time{font-family:"Inter";font-size:12px;color:var(--text-2)}
  .cm-time .date{display:block}
  .cm-time .clock{display:block;color:var(--text-4);font-size:11px}

  /* 实时正在看 */
  .cm-live{
    display:inline-flex;align-items:center;gap:4px;
    color:#f53f3f;font-family:"Inter";font-weight:600;
  }
  .cm-live .pulse{
    width:6px;height:6px;border-radius:50%;background:#f53f3f;
    animation:livePulse 1.4s ease-out infinite;
  }
  .cm-live.cold{color:var(--text-4);font-weight:400}
  .cm-live.cold .pulse{display:none}

  /* 链接按钮 */
  .cm-link-btns{display:inline-flex;gap:4px;justify-content:center}
  .cm-link-btn{
    width:26px;height:26px;border-radius:5px;
    background:var(--bg-2);border:none;color:var(--text-2);
    cursor:pointer;display:inline-flex;align-items:center;justify-content:center;
    transition:all .15s;text-decoration:none;
  }
  .cm-link-btn:hover{background:var(--primary-soft);color:var(--primary)}
  .cm-link-btn.disabled{
    opacity:0.35;cursor:not-allowed;pointer-events:none;
  }
  .cm-link-btn .cm-link-tip{
    position:absolute;background:var(--text);color:#fff;
    font-size:11px;padding:3px 7px;border-radius:4px;
    pointer-events:none;opacity:0;transition:opacity .15s;
    white-space:nowrap;margin-top:-30px;
  }
  /* 操作 */
  .cm-act{
    width:26px;height:26px;border-radius:5px;
    background:transparent;border:none;color:var(--text-3);
    cursor:pointer;display:inline-flex;align-items:center;justify-content:center;
    transition:all .15s;
  }
  .cm-act:hover{background:var(--bg-2);color:var(--primary)}
  .cm-act.danger:hover{background:rgba(245,63,63,0.08);color:#f53f3f}
  .cm-act.pin{color:var(--text-4)}
  .cm-act.pin:hover{background:rgba(251,114,153,0.10);color:#fb7299}
  .cm-act.pin.active{
    color:#fb7299;background:rgba(251,114,153,0.10);
  }

  /* 重点监控行整体高亮（B 站粉色） */
  .cm-table tbody tr.pinned td{
    background:rgba(251,114,153,0.06);
  }
  .cm-table tbody tr.pinned:hover td{
    background:rgba(251,114,153,0.10);
  }
  .cm-table tbody tr.pinned td:first-child{
    box-shadow:inset 3px 0 0 #fb7299;
  }
  .cm-pin-badge{
    display:inline-flex;align-items:center;gap:2px;
    font-size:10.5px;color:#fb7299;font-weight:500;
    margin-left:6px;letter-spacing:0;vertical-align:middle;
  }
  .cm-pin-badge svg{flex:none}

  .cm-empty{
    padding:80px 20px;text-align:center;color:var(--text-4);font-size:13px;
    background:var(--panel);border:1px solid var(--line);border-radius:10px;
  }
  .cm-empty svg{margin-bottom:14px;opacity:0.5}

  /* 编辑 Modal */
  .cm-modal-backdrop{
    position:fixed;inset:0;background:rgba(31,35,41,0.45);
    backdrop-filter:blur(3px);opacity:0;pointer-events:none;
    transition:opacity .2s;z-index:200;
  }
  .cm-modal-backdrop.open{opacity:1;pointer-events:auto}
  .cm-modal{
    position:fixed;top:50%;left:50%;
    width:min(680px, calc(100vw - 40px));max-height:calc(100vh - 60px);
    transform:translate(-50%, -48%);opacity:0;pointer-events:none;
    background:var(--panel);border:1px solid var(--line);border-radius:12px;
    box-shadow:0 18px 48px rgba(31,35,41,0.18);
    z-index:210;display:flex;flex-direction:column;overflow:hidden;
    transition:opacity .22s, transform .22s cubic-bezier(.4,.0,.2,1);
  }
  .cm-modal.open{opacity:1;pointer-events:auto;transform:translate(-50%, -50%)}
  .cm-modal-head{
    padding:16px 22px;border-bottom:1px solid var(--line);
    display:flex;justify-content:space-between;align-items:center;
  }
  .cm-modal-head h2{margin:0;font-size:16px;font-weight:600;color:var(--text)}
  .cm-modal-close{
    background:var(--bg-2);border:none;color:var(--text-2);
    width:28px;height:28px;border-radius:6px;cursor:pointer;
    font-size:18px;line-height:1;
    display:inline-flex;align-items:center;justify-content:center;
    transition:all .15s;
  }
  .cm-modal-close:hover{background:rgba(245,63,63,0.1);color:#f53f3f}
  .cm-modal-body{padding:18px 22px 20px;overflow-y:auto;flex:1}
  .cm-modal-foot{
    padding:12px 22px;border-top:1px solid var(--line);
    display:flex;justify-content:flex-end;gap:8px;background:var(--bg-1);
  }
  .cm-form-row{margin-bottom:14px}
  .cm-form-row:last-child{margin-bottom:0}
  .cm-form-label{
    display:block;font-size:12.5px;color:var(--text-3);
    margin-bottom:6px;
  }
  .cm-form-label .req{color:#f53f3f;margin-left:2px}
  .cm-form-input, .cm-form-select{
    width:100%;border:1px solid var(--line-mid);border-radius:6px;
    padding:9px 12px;font-size:13px;font-family:inherit;
    color:var(--text);background:var(--panel);
    transition:border-color .15s;outline:none;box-sizing:border-box;
  }
  .cm-form-input:focus, .cm-form-select:focus{border-color:var(--primary)}
  .cm-form-input.is-error{border-color:#f53f3f}
  .cm-form-help{font-size:11.5px;color:var(--text-4);margin-top:4px}
  .cm-form-select{
    appearance:none;-webkit-appearance:none;cursor:pointer;
    background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2386909c' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 12px center;
    padding-right:32px;
  }
  .cm-form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
  .cm-form-grid-3{display:grid;grid-template-columns:repeat(3, 1fr);gap:10px}
  .cm-modal-btn-primary, .cm-modal-btn-secondary{
    border:none;cursor:pointer;font-family:inherit;font-size:13px;font-weight:500;
    padding:8px 18px;border-radius:6px;transition:all .15s;
  }
  .cm-modal-btn-primary{background:var(--primary);color:#fff}
  .cm-modal-btn-primary:hover{background:#0e54e6}
  .cm-modal-btn-secondary{background:var(--bg-2);color:var(--text-2);border:1px solid var(--line-mid)}
  .cm-modal-btn-secondary:hover{background:var(--bg-3);color:var(--text)}

