Iwara 外部播放器

支持外部播放器和视频播放链接代理(需自建服务)

// ==UserScript==
// @name         Iwara 外部播放器
// @namespace    none
// @version      1.4
// @description  支持外部播放器和视频播放链接代理(需自建服务)
// @author       EvilSissi
// @match        *://*.iwara.tv/*
// @include      *://*/*iwara.tv/*
// @icon         https://www.google.com/s2/favicons?sz=64&domain=iwara.tv
// @require      https://lf26-cdn-tos.bytecdntp.com/cdn/expire-1-y/pako/2.0.4/pako.min.js
// @grant        GM_registerMenuCommand
// @grant        GM_getValue
// @grant        GM_setValue
// @grant        GM_addStyle
// @grant        GM_xmlhttpRequest
// @connect      api.iwara.tv
// @connect      files.iwara.tv
// @connect      *
// ==/UserScript==

(function () {
    'use strict';

    console.log('[Iwara Player] 脚本已启动');

    // SVG 图标(用于按钮)
    const SVG_ICONS = {
        COPY: '<rect x="9" y="9" width="13" height="13" rx="2" ry="2"></rect><path d="M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1"></path>',
        NEW_TAB: '<path d="M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6"></path><polyline points="15 3 21 3 21 9"></polyline><line x1="10" y1="14" x2="21" y2="3"></line>',
        PLAY: '<polygon points="5 3 19 12 5 21 5 3"></polygon>'
    };

    // 注入全局样式
    GM_addStyle(`
        /* ========== 浮动按钮样式 ========== */
        .iwara-mpv-fab {
            position: fixed;
            right: 30px;
            z-index: 999998;
            background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
            color: #fff;
            border: none;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            box-shadow: 0 4px 16px rgba(102, 126, 234, 0.4);
            transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
            backdrop-filter: blur(10px);
            user-select: none;
            font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
        }
        .iwara-mpv-fab:hover {
            background: linear-gradient(135deg, #764ba2 0%, #667eea 100%);
            box-shadow: 0 6px 20px rgba(102, 126, 234, 0.6);
            transform: translateY(-2px) scale(1.05);
        }
        .iwara-mpv-fab:active {
            transform: translateY(0) scale(0.98);
        }
        #iwara-mpv-settings-fab {
            bottom: 30px;
            width: 56px;
            height: 56px;
            border-radius: 50%;
            font-size: 24px;
        }
        #iwara-mpv-settings-fab svg {
            width: 28px;
            height: 28px;
            fill: #ffffff;
            transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
            display: block;
        }
        #iwara-mpv-settings-fab:hover {
            box-shadow: 0 8px 24px rgba(102, 126, 234, 0.7);
        }
        #iwara-mpv-settings-fab:hover svg {
            transform: rotate(90deg);
        }

        /* 视频播放页按钮组 - 1x4 垂直布局 */
        #iwara-mpv-button-group-detail {
            position: fixed;
            right: 30px;
            bottom: 100px;
            z-index: 999998;
            display: flex;
            flex-direction: column;
            gap: 12px;
        }
        #iwara-mpv-button-group-detail button {
            width: 56px;
            height: 56px;
            border-radius: 50%;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            box-shadow: 0 4px 16px rgba(102, 126, 234, 0.4);
            transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
            border: 2px solid;
            backdrop-filter: blur(10px);
        }
        #iwara-mpv-button-group-detail button:hover {
            box-shadow: 0 6px 20px rgba(102, 126, 234, 0.6);
            transform: translateY(-2px) scale(1.05);
        }
        #iwara-mpv-button-group-detail button:active {
            transform: translateY(0) scale(0.98);
        }
        #iwara-mpv-button-group-detail button svg {
            width: 24px;
            height: 24px;
        }
        #iwara-mpv-button-group-detail .copy-btn {
            background: rgba(255, 255, 255, 0.95);
            color: #667eea;
            border-color: #667eea;
        }
        #iwara-mpv-button-group-detail .copy-btn:hover {
            background: #667eea;
            color: #fff;
        }
        #iwara-mpv-button-group-detail .new-tab-btn {
            background: rgba(255, 255, 255, 0.95);
            color: #51cf66;
            border-color: #51cf66;
        }
        #iwara-mpv-button-group-detail .new-tab-btn:hover {
            background: #51cf66;
            color: #fff;
        }
        #iwara-mpv-button-group-detail .quality-btn {
            background: rgba(255, 255, 255, 0.95);
            color: #ffa500;
            border-color: #ffa500;
            font-size: 14px;
            font-weight: bold;
        }
        #iwara-mpv-button-group-detail .quality-btn:hover {
            background: #ffa500;
            color: #fff;
        }
        #iwara-mpv-button-group-detail .play-btn {
            background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
            color: #fff;
            border-color: #667eea;
        }
        #iwara-mpv-button-group-detail .play-btn:hover {
            box-shadow: 0 6px 16px rgba(102, 126, 234, 0.7);
        }

        /* 悬停按钮容器 - 2x2 网格布局 */
        .iwara-mpv-button-group {
            position: absolute;
            right: 10px;
            bottom: 10px;
            z-index: 100;
            display: none;
            grid-template-columns: repeat(2, 1fr);
            grid-template-rows: repeat(2, 1fr);
            gap: 8px;
            opacity: 0;
            transition: opacity 0.2s ease;
        }
        /* 当按钮少于4个时,改为单列布局 */
        .iwara-mpv-button-group.single-column {
            grid-template-columns: 1fr;
            grid-template-rows: auto;
        }
        .iwara-mpv-button-group.visible {
            opacity: 1;
        }

        /* 按钮组内所有按钮的统一基础样式 */
        .iwara-mpv-button-group button {
            width: 44px;
            height: 44px;
            border-radius: 50%;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
            transition: all 0.2s ease;
            opacity: 0;
            transform: scale(0.8);
            border: 2px solid;
        }
        .iwara-mpv-button-group button:hover {
            transform: scale(1.05);
            box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
        }
        .iwara-mpv-button-group button svg {
            width: 18px;
            height: 18px;
        }

        /* 复制按钮 */
        .iwara-mpv-action-btn.copy {
            background: rgba(255, 255, 255, 0.95);
            color: #667eea;
            border-color: #667eea;
        }
        .iwara-mpv-action-btn.copy:hover {
            background: #667eea;
            color: #fff;
        }

        /* 新标签页播放按钮 */
        .iwara-mpv-action-btn.new-tab {
            background: rgba(255, 255, 255, 0.95);
            color: #51cf66;
            border-color: #51cf66;
        }
        .iwara-mpv-action-btn.new-tab:hover {
            background: #51cf66;
            color: #fff;
        }

        /* 画质按钮 */
        .iwara-mpv-action-btn.quality {
            background: rgba(255, 255, 255, 0.95);
            color: #ffa500;
            border-color: #ffa500;
            font-size: 14px;
            font-weight: bold;
        }
        .iwara-mpv-action-btn.quality:hover {
            background: #ffa500;
            color: #fff;
        }

        /* 播放按钮 */
        .iwara-mpv-button-group .iwara-mpv-hover-button {
            background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
            color: #fff;
            border-color: #667eea;
        }
        .iwara-mpv-button-group .iwara-mpv-hover-button:hover {
            box-shadow: 0 6px 16px rgba(102, 126, 234, 0.7);
        }
        .iwara-mpv-button-group .iwara-mpv-hover-button svg {
            width: 20px;
            height: 20px;
        }

        /* ========== 统一表单输入框样式 ========== */
        .iwara-form-input,
        .iwara-form-textarea {
            width: 100%;
            padding: 12px 16px;
            background: rgba(255, 255, 255, 0.05);
            border: 2px solid rgba(255, 255, 255, 0.1);
            border-radius: 8px;
            color: #e0e0e0;
            font-size: 14px;
            font-family: 'Consolas', 'Monaco', 'Courier New', monospace;
            transition: all 0.2s;
            box-sizing: border-box;
        }
        .iwara-form-input:focus,
        .iwara-form-textarea:focus {
            outline: none;
            border-color: #667eea;
            background: rgba(255, 255, 255, 0.08);
        }
        .iwara-form-input::placeholder,
        .iwara-form-textarea::placeholder {
            color: #666;
        }
        .iwara-form-textarea {
            resize: vertical;
            min-height: 80px;
            line-height: 1.5;
        }

        /* ========== 按钮设置复选框样式 ========== */
        .iwara-button-settings-grid {
            display: grid;
            grid-template-columns: repeat(2, 1fr);
            gap: 12px;
        }
        .iwara-checkbox-label {
            display: flex;
            align-items: center;
            gap: 10px;
            padding: 12px 16px;
            background: rgba(255, 255, 255, 0.03);
            border: 2px solid rgba(255, 255, 255, 0.08);
            border-radius: 8px;
            cursor: pointer;
            transition: all 0.2s;
            user-select: none;
        }
        .iwara-checkbox-label:hover {
            background: rgba(102, 126, 234, 0.1);
            border-color: rgba(102, 126, 234, 0.3);
        }
        .iwara-checkbox-label input[type="checkbox"] {
            appearance: none;
            -webkit-appearance: none;
            width: 18px;
            height: 18px;
            border: 2px solid rgba(255, 255, 255, 0.3);
            border-radius: 4px;
            background: rgba(0, 0, 0, 0.3);
            cursor: pointer;
            position: relative;
            transition: all 0.2s;
            flex-shrink: 0;
        }
        .iwara-checkbox-label input[type="checkbox"]:hover {
            border-color: #667eea;
        }
        .iwara-checkbox-label input[type="checkbox"]:checked {
            background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
            border-color: #667eea;
        }
        .iwara-checkbox-label input[type="checkbox"]:checked::after {
            content: '✓';
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
            color: white;
            font-size: 12px;
            font-weight: bold;
        }
        .iwara-checkbox-label span {
            color: #94a3b8;
            font-size: 13px;
            font-weight: 500;
            transition: color 0.2s;
        }
        .iwara-checkbox-label:hover span {
            color: #cbd5e1;
        }
        .iwara-checkbox-label input[type="checkbox"]:checked + span {
            color: #e2e8f0;
        }
        .iwara-settings-subsection {
            margin-bottom: 16px;
            padding-bottom: 16px;
            border-bottom: 1px dashed rgba(255, 255, 255, 0.04);
        }
        .iwara-settings-subsection:last-child {
            margin-bottom: 0;
            padding-bottom: 0;
            border-bottom: none;
        }
        .iwara-settings-subsection h5 {
            color: #cbd5e1;
            margin: 0 0 10px 0;
            font-size: 14px;
            font-weight: 600;
            display: flex;
            align-items: center;
            gap: 6px;
        }
        .iwara-settings-section-title {
            color: #e2e8f0;
            margin: 0 0 20px 0;
            font-size: 17px;
            font-weight: 700;
            display: flex;
            align-items: center;
            gap: 10px;
            padding-bottom: 0;
            border-bottom: none;
            position: relative;
            padding-left: 16px;
            letter-spacing: 0.3px;
        }
        .iwara-settings-section-title::before {
            content: '';
            position: absolute;
            left: 0;
            top: 50%;
            transform: translateY(-50%);
            width: 4px;
            height: 20px;
            background: linear-gradient(to bottom, #667eea, #764ba2);
            border-radius: 2px;
        }
        .iwara-settings-section-title.no-indicator {
            padding-left: 0;
        }
        .iwara-settings-section-title.no-indicator::before {
            display: none;
        }
        .iwara-settings-section {
            padding: 24px 0;
            margin-bottom: 0;
            background: transparent;
            border-radius: 0;
            border: none;
            border-bottom: 1px solid rgba(255, 255, 255, 0.06);
            position: relative;
        }
        .iwara-settings-section::before {
            content: '';
            position: absolute;
            left: 0;
            right: 0;
            bottom: -1px;
            height: 1px;
            background: linear-gradient(90deg, transparent, rgba(102, 126, 234, 0.3), transparent);
            opacity: 0;
            transition: opacity 0.3s;
        }
        .iwara-settings-section:hover::before {
            opacity: 1;
        }
        .iwara-settings-section:last-child {
            margin-bottom: 0;
            border-bottom: none;
        }
        .iwara-settings-section:last-child::before {
            display: none;
        }
        .iwara-settings-section:first-child {
            padding-top: 0;
        }
        .iwara-settings-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin: -4px 0 14px 0;
        }
        .iwara-settings-header h4 {
            color: #e2e8f0;
            margin: 0;
            font-size: 16px;
            font-weight: 600;
        }

        /* ========== 新设计的模态框样式 ========== */
        .iwara-modal {
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            z-index: 999999;
            font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
        }
        .iwara-modal-overlay {
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: rgba(0, 0, 0, 0.85);
            backdrop-filter: blur(12px);
            display: flex;
            align-items: center;
            justify-content: center;
            animation: fadeIn 0.3s ease;
        }
        @keyframes fadeIn {
            from { opacity: 0; }
            to { opacity: 1; }
        }
        
        /* 新设计:左右分栏容器 */
        .iwara-modal-content {
            background: #1a1d2e;
            border-radius: 10px;
            width: 900px;
            max-width: 1100px;
            height: 85vh;
            max-height: 750px;
            box-shadow: 0 25px 80px rgba(0, 0, 0, 0.7);
            animation: slideUp 0.4s cubic-bezier(0.16, 1, 0.3, 1);
            overflow: hidden;
            display: flex;
            flex-direction: column;
            position: relative;
        }
        @keyframes slideUp {
            from { transform: translateY(40px) scale(0.95); opacity: 0; }
            to { transform: translateY(0) scale(1); opacity: 1; }
        }
        

        
        /* 主容器 */
        .iwara-modal-main {
            display: flex;
            flex: 1;
            overflow: hidden;
        }
        
        /* 左侧边栏 */
        .iwara-modal-sidebar {
            width: 200px;
            background: #15172b;
            border-right: 1px solid rgba(255, 255, 255, 0.06);
            display: flex;
            flex-direction: column;
            overflow-y: auto;
        }
        
        
        /* 播放器列表 */
        .iwara-sidebar-players {
            flex: 1;
            padding: 16px 12px;
            overflow-y: auto;
        }
        .iwara-sidebar-player-item {
            display: flex;
            align-items: center;
            padding: 12px 14px;
            margin-bottom: 8px;
            border-radius: 12px;
            cursor: pointer;
            transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
            border: 1px solid transparent;
            position: relative;
            overflow: hidden;
        }
        .iwara-sidebar-player-item::before {
            content: '';
            position: absolute;
            left: 0;
            top: 0;
            bottom: 0;
            width: 3px;
            background: linear-gradient(to bottom, #667eea, #764ba2);
            transform: scaleY(0);
            transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
            border-radius: 0 2px 2px 0;
        }
        .iwara-sidebar-player-item::after {
            content: '';
            position: absolute;
            inset: 0;
            background: linear-gradient(135deg, rgba(102, 126, 234, 0.08), rgba(118, 75, 162, 0.05));
            opacity: 0;
            transition: opacity 0.3s;
            border-radius: 12px;
        }
        .iwara-sidebar-player-item:hover {
            border-color: rgba(102, 126, 234, 0.25);
            transform: translateX(4px);
            box-shadow: 0 4px 12px rgba(102, 126, 234, 0.12);
        }
        .iwara-sidebar-player-item:hover::before {
            transform: scaleY(1);
        }
        .iwara-sidebar-player-item:hover::after {
            opacity: 1;
        }
        .iwara-sidebar-player-item.active {
            background: linear-gradient(135deg, rgba(102, 126, 234, 0.18), rgba(118, 75, 162, 0.12));
            border-color: rgba(102, 126, 234, 0.45);
            box-shadow: 0 4px 16px rgba(102, 126, 234, 0.25), inset 0 1px 0 rgba(255, 255, 255, 0.1);
            transform: translateX(4px);
        }
        .iwara-sidebar-player-item.active::before {
            transform: scaleY(1);
        }
        .iwara-sidebar-player-item.active::after {
            opacity: 0;
        }
        .iwara-sidebar-player-icon {
            width: 42px;
            height: 42px;
            display: flex;
            align-items: center;
            justify-content: center;
            margin-right: 12px;
            font-size: 22px;
            background: rgba(255, 255, 255, 0.05);
            border-radius: 11px;
            transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
            position: relative;
            z-index: 1;
            box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.2);
        }
        .iwara-sidebar-player-item:hover .iwara-sidebar-player-icon {
            background: linear-gradient(135deg, rgba(102, 126, 234, 0.15), rgba(118, 75, 162, 0.1));
            transform: scale(1.08) rotate(-5deg);
            box-shadow: 0 4px 12px rgba(102, 126, 234, 0.25), inset 0 1px 2px rgba(255, 255, 255, 0.1);
        }
        .iwara-sidebar-player-item.active .iwara-sidebar-player-icon {
            background: linear-gradient(135deg, rgba(102, 126, 234, 0.25), rgba(118, 75, 162, 0.18));
            transform: scale(1.05);
            box-shadow: 0 4px 12px rgba(102, 126, 234, 0.35), inset 0 1px 2px rgba(255, 255, 255, 0.15);
        }
        .iwara-sidebar-player-icon img {
            width: 30px;
            height: 30px;
            object-fit: contain;
            transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
        }
        .iwara-sidebar-player-item:hover .iwara-sidebar-player-icon img {
            transform: scale(1.1);
        }
        .iwara-sidebar-player-info {
            flex: 1;
            min-width: 0;
            position: relative;
            z-index: 1;
        }
        .iwara-sidebar-player-name {
            font-size: 14px;
            font-weight: 600;
            color: #cbd5e1;
            margin: 0 0 3px 0;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            transition: all 0.3s;
            letter-spacing: 0.2px;
        }
        .iwara-sidebar-player-item:hover .iwara-sidebar-player-name {
            color: #e0e7ff;
            transform: translateX(2px);
        }
        .iwara-sidebar-player-item.active .iwara-sidebar-player-name {
            color: #e0e7ff;
            font-weight: 700;
        }
        .iwara-sidebar-player-desc {
            font-size: 11px;
            color: #64748b;
            margin: 0;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            transition: all 0.3s;
        }
        .iwara-sidebar-player-item:hover .iwara-sidebar-player-desc {
            color: #94a3b8;
            transform: translateX(2px);
        }
        .iwara-sidebar-player-item.active .iwara-sidebar-player-desc {
            color: #a78bfa;
            font-weight: 500;
        }
        
        /* 左侧底部 - 设置 */
        .iwara-sidebar-footer {
            padding: 16px;
            border-top: 1px solid rgba(255, 255, 255, 0.06);
            background: linear-gradient(to top, rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.15));
            height: 86px;
            box-sizing: border-box;
            display: flex;
            align-items: center;
            position: relative;
        }
        .iwara-sidebar-footer::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            height: 1px;
            background: linear-gradient(90deg, transparent, rgba(102, 126, 234, 0.3), transparent);
        }
        .iwara-sidebar-main-settings {
            display: flex;
            align-items: center;
            width: 100%;
            padding: 14px 16px;
            background: transparent;
            border: 1px solid transparent;
            border-radius: 12px;
            cursor: pointer;
            transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
            position: relative;
            overflow: hidden;
        }
        .iwara-sidebar-main-settings::before {
            content: '';
            position: absolute;
            inset: 0;
            background: linear-gradient(135deg, rgba(102, 126, 234, 0.1), rgba(118, 75, 162, 0.1));
            opacity: 0;
            transition: opacity 0.3s;
            border-radius: 12px;
        }
        .iwara-sidebar-main-settings:hover::before {
            opacity: 1;
        }
        .iwara-sidebar-main-settings:hover {
            border-color: rgba(102, 126, 234, 0.25);
            transform: translateY(-1px);
            box-shadow: 0 4px 12px rgba(102, 126, 234, 0.15);
        }
        .iwara-sidebar-main-settings.active {
            background: linear-gradient(135deg, rgba(102, 126, 234, 0.18), rgba(118, 75, 162, 0.15));
            border-color: rgba(102, 126, 234, 0.45);
            box-shadow: 0 4px 16px rgba(102, 126, 234, 0.25), inset 0 1px 0 rgba(255, 255, 255, 0.1);
        }
        .iwara-sidebar-main-settings.active::before {
            opacity: 0;
        }
        .iwara-sidebar-main-icon {
            width: 40px;
            height: 40px;
            display: flex;
            align-items: center;
            justify-content: center;
            margin-right: 12px;
            font-size: 20px;
            background: rgba(255, 255, 255, 0.05);
            border-radius: 10px;
            color: #94a3b8;
            transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
            position: relative;
            z-index: 1;
            box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.2);
        }
        .iwara-sidebar-main-settings:hover .iwara-sidebar-main-icon {
            background: linear-gradient(135deg, rgba(102, 126, 234, 0.2), rgba(118, 75, 162, 0.15));
            color: #a78bfa;
            transform: scale(1.05);
            box-shadow: 0 4px 12px rgba(102, 126, 234, 0.3), inset 0 1px 2px rgba(255, 255, 255, 0.1);
        }
        .iwara-sidebar-main-settings.active .iwara-sidebar-main-icon {
            background: linear-gradient(135deg, rgba(102, 126, 234, 0.3), rgba(118, 75, 162, 0.25));
            color: #c4b5fd;
            box-shadow: 0 4px 12px rgba(102, 126, 234, 0.4), inset 0 1px 2px rgba(255, 255, 255, 0.15);
        }
        .iwara-sidebar-main-text {
            font-size: 14px;
            font-weight: 600;
            color: #94a3b8;
            transition: all 0.3s;
            position: relative;
            z-index: 1;
            letter-spacing: 0.3px;
        }
        .iwara-sidebar-main-settings:hover .iwara-sidebar-main-text {
            color: #e0e7ff;
        }
        .iwara-sidebar-main-settings.active .iwara-sidebar-main-text {
            color: #e0e7ff;
        }
        
        /* 右侧内容区 */
        .iwara-modal-content-area {
            flex: 1;
            display: flex;
            flex-direction: column;
            overflow: hidden;
        }
        
        /* 内容顶部标题栏 */
        .iwara-content-header {
            padding: 20px 32px;
            border-bottom: 1px solid rgba(255, 255, 255, 0.06);
            background: rgba(0, 0, 0, 0.2);
            display: flex;
            justify-content: space-between;
            align-items: center;
            min-height: 70px;
        }
        .iwara-content-title {
            font-size: 18px;
            font-weight: 600;
            color: #e2e8f0;
            margin: 0;
            line-height: 1.4;
        }
        #header-action-buttons {
            display: flex;
            gap: 12px;
            align-items: center;
        }
        .iwara-btn-delete-player {
            padding: 8px 18px;
            background: rgba(255, 59, 48, 0.15);
            border: 1px solid rgba(255, 59, 48, 0.4);
            border-radius: 8px;
            color: #ff3b30;
            font-size: 14px;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.2s;
            height: 38px;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            line-height: 1;
        }
        .iwara-btn-delete-player:hover {
            background: rgba(255, 59, 48, 0.25);
            border-color: rgba(255, 59, 48, 0.6);
            transform: translateY(-2px);
            box-shadow: 0 4px 12px rgba(255, 59, 48, 0.3);
        }
        .iwara-btn-create-player {
            padding: 8px 18px;
            background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
            border: none;
            border-radius: 8px;
            color: #fff;
            font-size: 14px;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.2s;
            height: 38px;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            line-height: 1;
        }
        .iwara-btn-create-player:hover {
            transform: translateY(-2px);
            box-shadow: 0 4px 12px rgba(102, 126, 234, 0.4);
        }
        
        /* 内容主体 */
        .iwara-content-body {
            flex: 1;
            padding: 24px 28px;
            overflow-y: auto;
        }
        
        /* 内容底部 - 按钮区 */
        .iwara-content-footer {
            padding: 16px 32px;
            border-top: 1px solid rgba(255, 255, 255, 0.06);
            background: rgba(0, 0, 0, 0.2);
            height: 86px;
            box-sizing: border-box;
            display: flex;
            justify-content: space-between;
            align-items: center;
        }
        .iwara-footer-hint {
            flex: 1;
            display: flex;
            align-items: center;
        }
        .iwara-footer-buttons {
            display: flex;
            gap: 12px;
            align-items: center;
        }
        .iwara-btn {
            padding: 10px 24px;
            border: none;
            border-radius: 8px;
            font-size: 14px;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.2s;
        }
        .iwara-btn-cancel {
            background: rgba(255, 255, 255, 0.08);
            color: #cbd5e1;
            border: 1px solid rgba(255, 255, 255, 0.1);
            transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
            position: relative;
            overflow: hidden;
        }
        .iwara-btn-cancel::before {
            content: '';
            position: absolute;
            inset: 0;
            background: linear-gradient(135deg, rgba(239, 68, 68, 0.15), rgba(220, 38, 38, 0.1));
            opacity: 0;
            transition: opacity 0.3s;
        }
        .iwara-btn-cancel:hover {
            background: rgba(239, 68, 68, 0.15);
            border-color: rgba(239, 68, 68, 0.4);
            color: #fca5a5;
            transform: translateY(-2px);
            box-shadow: 0 4px 12px rgba(239, 68, 68, 0.25);
        }
        .iwara-btn-cancel:hover::before {
            opacity: 1;
        }
        .iwara-btn-cancel:active {
            transform: translateY(0);
        }
        .iwara-btn-secondary {
            background: rgba(102, 126, 234, 0.2);
            border: 2px solid rgba(102, 126, 234, 0.5);
            color: #667eea;
        }
        .iwara-btn-secondary:hover {
            background: rgba(102, 126, 234, 0.3);
            border-color: #667eea;
            transform: translateY(-2px);
        }
        .iwara-btn-primary {
            background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
            color: #fff;
        }
        .iwara-btn-primary:hover {
            transform: translateY(-2px);
            box-shadow: 0 4px 12px rgba(102, 126, 234, 0.4);
        }
        .iwara-btn-small {
            padding: 6px 14px;
            background: rgba(102, 126, 234, 0.2);
            border: 1px solid rgba(102, 126, 234, 0.4);
            border-radius: 6px;
            color: #667eea;
            font-size: 13px;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.2s;
        }
        .iwara-btn-small:hover {
            background: rgba(102, 126, 234, 0.3);
            border-color: #667eea;
        }

        /* ========== 设置页面专用样式 ========== */
        .iwara-settings-section {
            margin-bottom: 28px;
        }
        .iwara-settings-section:last-child {
            margin-bottom: 0;
        }
        .iwara-settings-section h3 {
            margin: 0 0 20px 0;
            color: #e2e8f0;
            font-size: 17px;
            font-weight: 700;
            position: relative;
            padding-left: 16px;
            letter-spacing: 0.3px;
        }
        .iwara-settings-section h3::before {
            content: '';
            position: absolute;
            left: 0;
            top: 50%;
            transform: translateY(-50%);
            width: 4px;
            height: 20px;
            background: linear-gradient(to bottom, #667eea, #764ba2);
            border-radius: 2px;
        }
        .iwara-hint {
            margin: 8px 0 0 0;
            color: #999;
            font-size: 12px;
        }

        /* 播放器选项 */
        .iwara-player-options {
            display: flex;
            flex-direction: column;
            gap: 10px;
        }
        .iwara-player-option {
            position: relative;
            display: flex;
            align-items: center;
            padding: 16px;
            background: rgba(255, 255, 255, 0.05);
            border: 2px solid rgba(255, 255, 255, 0.1);
            border-radius: 12px;
            cursor: pointer;
            transition: all 0.2s;
        }
        .iwara-player-option:hover {
            background: rgba(255, 255, 255, 0.08);
            border-color: rgba(102, 126, 234, 0.5);
        }
        .iwara-player-option.active {
            background: rgba(102, 126, 234, 0.15);
            border-color: #667eea;
        }
        .iwara-player-option input[type="radio"] {
            margin-right: 12px;
            cursor: pointer;
        }
        .iwara-option-icon {
            font-size: 24px;
            margin-right: 12px;
        }
        .iwara-option-text {
            display: flex;
            flex-direction: column;
            gap: 2px;
        }
        .iwara-option-text strong {
            color: #e0e0e0;
            font-size: 14px;
        }
        .iwara-option-text small {
            color: #999;
            font-size: 12px;
        }
        .iwara-player-actions {
            position: absolute;
            right: 12px;
            top: 50%;
            transform: translateY(-50%);
            display: flex;
            gap: 8px;
            z-index: 10;
        }
        .iwara-edit-btn,
        .iwara-delete-btn {
            background: rgba(255, 255, 255, 0.1);
            border: 1px solid rgba(255, 255, 255, 0.2);
            border-radius: 6px;
            padding: 4px 8px;
            font-size: 14px;
            cursor: pointer;
            transition: all 0.2s;
            opacity: 0.8;
        }
        .iwara-edit-btn:hover {
            background: rgba(102, 126, 234, 0.3);
            border-color: rgba(102, 126, 234, 0.6);
            opacity: 1;
            transform: scale(1.1);
        }
        .iwara-delete-btn {
            background: rgba(255, 59, 48, 0.15);
            border-color: rgba(255, 59, 48, 0.4);
        }
        .iwara-delete-btn:hover {
            background: rgba(255, 59, 48, 0.3);
            border-color: rgba(255, 59, 48, 0.6);
            opacity: 1;
            transform: scale(1.1);
        }

        /* 画质选项 */
        .iwara-quality-options {
            display: flex;
            flex-direction: column;
            gap: 8px;
        }
        .iwara-quality-option {
            display: flex;
            align-items: center;
            padding: 12px 16px;
            background: rgba(255, 255, 255, 0.05);
            border: 2px solid rgba(255, 255, 255, 0.1);
            border-radius: 8px;
            cursor: pointer;
            transition: all 0.2s;
        }
        .iwara-quality-option:hover {
            background: rgba(255, 255, 255, 0.08);
            border-color: rgba(102, 126, 234, 0.5);
        }
        .iwara-quality-option.active {
            background: rgba(102, 126, 234, 0.15);
            border-color: #667eea;
        }
        .iwara-quality-option input[type="radio"] {
            margin-right: 12px;
            cursor: pointer;
        }

        /* 代理列表 */
        .iwara-proxy-list {
            display: flex;
            flex-direction: column;
            gap: 8px;
            max-height: 200px;
            overflow-y: auto;
            padding: 4px;
        }
        .iwara-proxy-list::-webkit-scrollbar {
            width: 6px;
        }
        .iwara-proxy-list::-webkit-scrollbar-track {
            background: rgba(255, 255, 255, 0.05);
            border-radius: 3px;
        }
        .iwara-proxy-list::-webkit-scrollbar-thumb {
            background: rgba(102, 126, 234, 0.5);
            border-radius: 3px;
        }
        .iwara-proxy-list::-webkit-scrollbar-thumb:hover {
            background: rgba(102, 126, 234, 0.7);
        }

        /* ========== 统一滚动条样式 ========== */
        .iwara-modal-sidebar::-webkit-scrollbar,
        .iwara-sidebar-players::-webkit-scrollbar,
        .iwara-content-body::-webkit-scrollbar {
            width: 8px;
        }
        .iwara-modal-sidebar::-webkit-scrollbar-track,
        .iwara-sidebar-players::-webkit-scrollbar-track,
        .iwara-content-body::-webkit-scrollbar-track {
            background: rgba(255, 255, 255, 0.03);
            border-radius: 4px;
            margin: 4px 0;
        }
        .iwara-modal-sidebar::-webkit-scrollbar-thumb,
        .iwara-sidebar-players::-webkit-scrollbar-thumb,
        .iwara-content-body::-webkit-scrollbar-thumb {
            background: rgba(102, 126, 234, 0.4);
            border-radius: 4px;
            border: 2px solid transparent;
            background-clip: padding-box;
            transition: background 0.2s;
        }
        .iwara-modal-sidebar::-webkit-scrollbar-thumb:hover,
        .iwara-sidebar-players::-webkit-scrollbar-thumb:hover,
        .iwara-content-body::-webkit-scrollbar-thumb:hover {
            background: rgba(102, 126, 234, 0.6);
            background-clip: padding-box;
        }
        .iwara-modal-sidebar::-webkit-scrollbar-thumb:active,
        .iwara-sidebar-players::-webkit-scrollbar-thumb:active,
        .iwara-content-body::-webkit-scrollbar-thumb:active {
            background: rgba(102, 126, 234, 0.8);
            background-clip: padding-box;
        }
        
        .iwara-proxy-item {
            display: flex;
            align-items: center;
            padding: 10px 14px;
            background: rgba(255, 255, 255, 0.05);
            border: 2px solid rgba(255, 255, 255, 0.1);
            border-radius: 8px;
            transition: all 0.2s;
            gap: 10px;
        }
        .iwara-proxy-item:hover {
            background: rgba(255, 255, 255, 0.08);
            border-color: rgba(102, 126, 234, 0.3);
        }
        .iwara-proxy-item.disabled {
            opacity: 0.5;
        }
        .iwara-proxy-item .proxy-url {
            flex: 1;
            color: #e0e0e0;
            font-size: 13px;
            font-family: 'Consolas', 'Monaco', monospace;
            word-break: break-all;
        }
        .iwara-proxy-item.disabled .proxy-url {
            color: #999;
            text-decoration: line-through;
        }
        .iwara-proxy-status {
            padding: 4px 10px;
            border: 1px solid;
            border-radius: 6px;
            font-size: 11px;
            font-weight: 600;
            white-space: nowrap;
            min-width: 70px;
            text-align: center;
        }
        .iwara-proxy-status.checking {
            background: rgba(102, 126, 234, 0.2);
            border-color: rgba(102, 126, 234, 0.4);
            color: #667eea;
        }
        .iwara-proxy-status.success {
            background: rgba(81, 207, 102, 0.2);
            border-color: rgba(81, 207, 102, 0.4);
            color: #51cf66;
        }
        .iwara-proxy-status.failed {
            background: rgba(255, 107, 107, 0.2);
            border-color: rgba(255, 107, 107, 0.4);
            color: #ff6b6b;
        }
        .iwara-proxy-status.slow {
            background: rgba(255, 165, 0, 0.2);
            border-color: rgba(255, 165, 0, 0.4);
            color: #ffa500;
        }
        .iwara-proxy-toggle {
            padding: 4px 12px;
            background: rgba(81, 207, 102, 0.2);
            border: 1px solid rgba(81, 207, 102, 0.4);
            border-radius: 6px;
            color: #51cf66;
            font-size: 11px;
            font-weight: 600;
            cursor: pointer;
            transition: all 0.2s;
            white-space: nowrap;
        }
        .iwara-proxy-toggle:hover {
            background: rgba(81, 207, 102, 0.3);
            border-color: #51cf66;
            transform: scale(1.05);
        }
        .iwara-proxy-toggle.disabled {
            background: rgba(255, 107, 107, 0.2);
            border-color: rgba(255, 107, 107, 0.4);
            color: #ff6b6b;
        }
        .iwara-proxy-toggle.disabled:hover {
            background: rgba(255, 107, 107, 0.3);
            border-color: #ff6b6b;
        }
        .iwara-proxy-delete {
            padding: 4px 8px;
            background: rgba(255, 59, 48, 0.15);
            border: 1px solid rgba(255, 59, 48, 0.4);
            border-radius: 6px;
            color: #ff3b30;
            font-size: 14px;
            cursor: pointer;
            transition: all 0.2s;
            line-height: 1;
        }
        .iwara-proxy-delete:hover {
            background: rgba(255, 59, 48, 0.3);
            border-color: #ff3b30;
            transform: scale(1.1);
        }

        /* Select 下拉框样式 */
        select.iwara-form-input {
            cursor: pointer;
            background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23667eea' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
            background-repeat: no-repeat;
            background-position: right 12px center;
            padding-right: 36px;
            appearance: none;
            -webkit-appearance: none;
            -moz-appearance: none;
        }
        select.iwara-form-input:hover {
            border-color: rgba(102, 126, 234, 0.5);
        }
        select.iwara-form-input option {
            background: #1a1a2e;
            color: #e0e0e0;
            padding: 10px;
        }
        select.iwara-form-input option:hover {
            background: #667eea;
        }
    `);

    // 代理列表(数组格式:[{url: '', enabled: true}, ...])
    let proxyList = GM_getValue('proxyList', []);

    // 代理检测超时时间(毫秒)
    let proxyTimeout = GM_getValue('proxyTimeout', 10000);

    // 外部播放器名称
    let externalPlayer = GM_getValue('externalPlayer', 'MPV');

    // 视频画质设置 - 固定为 Source
    const videoQuality = 'Source';

    // 按钮显示设置
    let buttonSettings = GM_getValue('buttonSettings', {
        detailPage: {
            copy: true,
            newTab: true,
            quality: true,
            play: true
        },
        listPage: {
            copy: true,
            newTab: true,
            quality: true,
            play: true
        }
    });

    // 默认播放器列表
    const defaultPlayers = [
        {
            name: "MPV",
            icon: "",
            description: "MPV + ush",
            type: "ush",
            appName: "MPV",
            args: ["${url}", "--force-media-title=${title}", "--ontop"]
        },
        {
            name: "PotPlayer",
            icon: "",
            description: "PotPlayer 标准协议",
            type: "protocol",
            protocol: "potplayer://${url}"
        },
        {
            name: "VLC",
            icon: "",
            description: "VLC 标准协议",
            type: "protocol",
            protocol: "vlc://${url}"
        }
    ];

    // 自定义播放器列表
    let customPlayers = GM_getValue('customPlayers', []);

    // 标记是否已初始化过默认播放器
    const hasInitializedDefaults = GM_getValue('hasInitializedDefaults', false);

    // 仅在首次安装时添加默认播放器
    if (!hasInitializedDefaults && customPlayers.length === 0) {
        customPlayers = [...defaultPlayers];
        GM_setValue('customPlayers', customPlayers);
        GM_setValue('hasInitializedDefaults', true);
    }

    // 恢复默认播放器列表的函数
    function resetToDefaultPlayers() {
        if (confirm('确定要恢复默认播放器列表吗?\n这将清除所有自定义播放器并恢复为 MPV、PotPlayer、VLC。')) {
            customPlayers = [...defaultPlayers];
            GM_setValue('customPlayers', customPlayers);
            externalPlayer = 'MPV';
            GM_setValue('externalPlayer', externalPlayer);
            showNotification('✅ 已恢复默认播放器列表', 'success');
            setTimeout(() => location.reload(), 1500);
        }
    }

    // 代理地址补全和验证
    function normalizeProxyUrl(url) {
        if (!url || url.trim() === '') {
            return '';
        }

        url = url.trim();

        // 检查是否包含协议
        if (!/^https?:\/\//i.test(url)) {
            url = 'https://' + url;
        }

        // 验证URL格式
        try {
            const urlObj = new URL(url);

            // 验证域名:必须包含点号(.)表示是有效域名
            const hostname = urlObj.hostname;

            // 检查是否包含非ASCII字符(中文等)
            if (!/^[a-z0-9.-]+$/i.test(hostname)) {
                console.warn(`[Iwara Player] 无效的代理域名(包含非法字符): ${hostname}`);
                return null;
            }

            // 检查是否至少包含一个点号(排除 localhost 等)
            if (!hostname.includes('.')) {
                console.warn(`[Iwara Player] 无效的代理域名(缺少顶级域名): ${hostname}`);
                return null;
            }

            // 检查域名部分是否为空或只有点号
            const parts = hostname.split('.');
            if (parts.some(part => part === '')) {
                console.warn(`[Iwara Player] 无效的代理域名格式: ${hostname}`);
                return null;
            }

            // 检查顶级域名长度(至少2个字符)
            const tld = parts[parts.length - 1];
            if (tld.length < 2) {
                console.warn(`[Iwara Player] 无效的顶级域名: ${tld}`);
                return null;
            }

            // 重构URL:协议和域名小写,路径保持原样
            const protocol = urlObj.protocol.toLowerCase(); // http: 或 https:
            const lowercaseHostname = hostname.toLowerCase();
            const port = urlObj.port ? `:${urlObj.port}` : '';
            const pathname = urlObj.pathname; // 保持原始大小写
            const search = urlObj.search; // 保持原始大小写
            const hash = urlObj.hash; // 保持原始大小写

            // 重组URL
            let normalizedUrl = `${protocol}//${lowercaseHostname}${port}${pathname}${search}${hash}`;

            // 检查是否以 / 结尾(仅当没有查询参数和hash时)
            if (!search && !hash && !normalizedUrl.endsWith('/')) {
                normalizedUrl += '/';
            }

            return normalizedUrl;
        } catch (e) {
            console.warn(`[Iwara Player] URL格式错误: ${url}`, e);
            return null;
        }
    }

    // 从启用的代理中随机选择一个并应用到视频URL
    function getProxiedUrl(videoUrl) {
        // 检查当前域名是否为 iwara.tv
        const currentHostname = window.location.hostname;
        const isIwaraDomain = currentHostname === 'iwara.tv' || currentHostname === 'www.iwara.tv' || currentHostname.endsWith('.iwara.tv');

        // 如果不是 iwara.tv 域名,使用当前访问的代理前缀
        if (!isIwaraDomain) {
            const currentProxy = getCurrentProxyPrefix();
            if (currentProxy) {
                const proxiedUrl = currentProxy + videoUrl;
                console.log(`%c[Iwara Player] 代理信息`, 'color: #ffa500; font-weight: bold;',
                    `\n当前域名: ${currentHostname}`,
                    '\n使用当前代理前缀:',
                    '\n代理地址:', currentProxy,
                    '\n代理后URL:', proxiedUrl);
                return proxiedUrl;
            } else {
                console.log(`%c[Iwara Player] 代理信息`, 'color: #ffa500; font-weight: bold;',
                    `\n当前域名: ${currentHostname}`,
                    '\n非 iwara.tv 域名且无法检测代理,返回原始URL');
                return videoUrl;
            }
        }

        // 在 iwara.tv 域名下,使用设置中的代理列表
        const enabledProxies = proxyList.filter(p => p.enabled);

        if (enabledProxies.length === 0) {
            return videoUrl;
        }

        const randomIndex = Math.floor(Math.random() * enabledProxies.length);
        const selectedProxy = enabledProxies[randomIndex];
        const proxiedUrl = selectedProxy.url + videoUrl;

        console.log(`%c[Iwara Player] 代理信息`, 'color: #ffa500; font-weight: bold;',
            `\n当前域名: ${currentHostname}`,
            `\n已选择代理: (${randomIndex + 1}/${enabledProxies.length})`,
            '\n代理地址:', selectedProxy.url,
            '\n代理后URL:', proxiedUrl);

        return proxiedUrl;
    }

    // 获取当前代理前缀(用于 API 请求)
    function getCurrentProxyPrefix() {
        const currentHostname = window.location.hostname;
        const isIwaraDomain = currentHostname.endsWith('.iwara.tv');

        // 如果是 iwara.tv 域名,不需要代理前缀
        if (isIwaraDomain) {
            return '';
        }

        // 如果是通过代理网站访问,提取代理前缀
        const currentUrl = window.location.href;
        const match = currentUrl.match(/^(https?:\/\/[^\/]+)\//);

        if (match) {
            const pureProxy = match[1] + '/';

            console.log(`%c[Iwara Player] API 代理`, 'color: #ffa500; font-weight: bold;',
                `\n当前域名: ${currentHostname}`,
                `\n检测到代理访问,API 请求将使用代理: ${pureProxy}`);

            return pureProxy;
        }

        console.warn(`%c[Iwara Player] API 代理`, 'color: #ff6b6b; font-weight: bold;',
            `\n当前域名: ${currentHostname}`,
            '\n无法检测代理前缀,API 请求可能失败');

        return '';
    }

    // 获取所有可用播放器
    function getAllPlayers() {
        return customPlayers;
    }

    // 根据名称查找播放器
    function getPlayerByName(playerName) {
        return customPlayers.find(p => p.name === playerName);
    }

    // 刷新设置弹窗中的播放器列表
    function refreshPlayerList() {
        const settingsModal = document.getElementById('iwara-mpv-settings-modal');
        if (!settingsModal) return;

        const playerOptionsContainer = settingsModal.querySelector('.iwara-player-options');
        if (!playerOptionsContainer) return;

        const allPlayers = getAllPlayers();
        const playerOptionsHtml = [];

        allPlayers.forEach(player => {
            const isActive = externalPlayer === player.name ? 'active' : '';
            const isChecked = externalPlayer === player.name ? 'checked' : '';
            const deleteBtn = `<button class="iwara-delete-btn" data-player-name="${player.name}" title="删除此播放器" onclick="event.preventDefault(); event.stopPropagation();">❌</button>`;
            const editBtn = `<button class="iwara-edit-btn" data-player-name="${player.name}" title="编辑此播放器" onclick="event.preventDefault(); event.stopPropagation();">✏️</button>`;

            const iconHtml = player.icon && player.icon.startsWith('data:image')
                ? `<img src="${player.icon}" alt="${player.name}" style="width: 24px; height: 24px; object-fit: contain;">`
                : (player.icon || '🎮');

            playerOptionsHtml.push(`
                <label class="iwara-player-option ${isActive}">
                    <input type="radio" name="player" value="${player.name}" ${isChecked}>
                    <span class="iwara-option-icon">${iconHtml}</span>
                    <span class="iwara-option-text">
                        <strong>${player.name}</strong>
                        <small>${player.description || '自定义播放器'}</small>
                    </span>
                    <div class="iwara-player-actions">
                        ${editBtn}
                        ${deleteBtn}
                    </div>
                </label>
            `);
        });

        playerOptionsContainer.innerHTML = playerOptionsHtml.join('');

        // 重新绑定删除和编辑按钮事件
        bindPlayerActionEvents(settingsModal);
    }

    // 绑定播放器操作按钮事件(删除、编辑)
    function bindPlayerActionEvents(modal) {
        // 删除按钮
        modal.querySelectorAll('.iwara-delete-btn').forEach(btn => {
            btn.addEventListener('click', (e) => {
                e.preventDefault();
                e.stopPropagation();
                const playerName = btn.dataset.playerName;
                const player = getPlayerByName(playerName);

                let confirmMessage = `确定要删除"${player.name}"吗?`;
                const isDefaultPlayer = defaultPlayers.some(dp => dp.name === playerName);
                if (isDefaultPlayer) {
                    confirmMessage += '\n\n⚠️ 这是预设播放器,删除后可点击 🔄 重置';
                }

                if (confirm(confirmMessage)) {
                    // 过滤掉要删除的播放器
                    customPlayers = customPlayers.filter(p => p.name !== playerName);
                    GM_setValue('customPlayers', customPlayers);

                    // 如果删除的是当前选中的播放器
                    if (externalPlayer === playerName) {
                        // 到第一个可用播放器
                        if (customPlayers.length > 0) {
                            externalPlayer = customPlayers[0].name;
                            GM_setValue('externalPlayer', externalPlayer);
                        } else {
                            // 如果没有播放器了,使用默认MPV
                            externalPlayer = 'MPV';
                            GM_setValue('externalPlayer', externalPlayer);
                        }
                    }

                    showNotification(`✅ 已删除"${player.name}"`, 'success');
                    refreshPlayerList();
                }
            });
        });

        // 编辑按钮
        modal.querySelectorAll('.iwara-edit-btn').forEach(btn => {
            btn.addEventListener('click', (e) => {
                e.preventDefault();
                e.stopPropagation();
                const playerName = btn.dataset.playerName;
                const player = getPlayerByName(playerName);
                if (player) {
                    createEditPlayerModal(player);
                }
            });
        });
    }

    // 创建设置弹窗 - 全新左右分栏设计
    function createSettingsModal() {
        // 移除已存在的弹窗
        const existingModal = document.getElementById('iwara-mpv-settings-modal');
        if (existingModal) {
            existingModal.remove();
        }

        // 创建临时数据副本(关闭不保存时不会影响原始数据)
        let tempPlayers = JSON.parse(JSON.stringify(customPlayers)); // 临时播放器列表
        let currentView = 'main-settings'; // 默认打开设置
        let currentDefaultPlayer = externalPlayer; // 临时存储的默认播放器
        let tempProxyList = JSON.parse(JSON.stringify(proxyList)); // 临时代理列表
        let tempButtonSettings = JSON.parse(JSON.stringify(buttonSettings)); // 临时按钮设置
        let tempProxyTimeout = proxyTimeout; // 临时代理超时时间
        let editingPlayer = null; // 当前编辑的播放器

        // 创建弹窗容器
        const modal = document.createElement('div');
        modal.id = 'iwara-mpv-settings-modal';
        modal.className = 'iwara-modal';

        modal.innerHTML = `
            <div class="iwara-modal-overlay">
                <div class="iwara-modal-content">
                    <!-- 主容器 -->
                    <div class="iwara-modal-main">
                        <!-- 左侧边栏 -->
                        <div class="iwara-modal-sidebar">
                            <!-- 播放器列表 -->
                            <div class="iwara-sidebar-players" id="player-list"></div>
                            
                            <!-- 底部 - 设置 -->
                            <div class="iwara-sidebar-footer">
                                <div class="iwara-sidebar-main-settings" data-view="main-settings">
                                    <div class="iwara-sidebar-main-icon">🎛️</div>
                                    <div class="iwara-sidebar-main-text">设置</div>
                                </div>
                            </div>
                        </div>
                        
                        <!-- 右侧内容区 -->
                        <div class="iwara-modal-content-area">
                            <!-- 内容顶部标题栏 -->
                            <div class="iwara-content-header" id="content-header" style="display: none;">
                                <h3 class="iwara-content-title" id="content-title"></h3>
                                <div id="header-action-buttons">
                                    <button class="iwara-btn-create-player" id="btn-create-player" style="display: none;">✓ 创建</button>
                                    <button class="iwara-btn-delete-player" id="btn-delete-player" style="display: none;">🗑️ 删除</button>
                                </div>
                            </div>
                            
                            <!-- 内容主体 -->
                            <div class="iwara-content-body" id="content-body">
                                <p style="color: #64748b; text-align: center; margin-top: 100px;">👈 请从左侧选择一个播放器或设置</p>
                            </div>
                            
                            <!-- 内容底部 - 按钮区 -->
                            <div class="iwara-content-footer">
                                <div class="iwara-footer-hint">
                                    <span style="color: #94a3b8; font-size: 13px;">💡 提示:若保存设置未生效,请手动刷新页面</span>
                                </div>
                                <div class="iwara-footer-buttons">
                                    <button class="iwara-btn iwara-btn-cancel" id="btn-close">✕ 关闭</button>
                                    <button class="iwara-btn iwara-btn-primary" id="btn-save">💾 保存</button>
                                </div>
                            </div>
                        </div>
                    </div>
                </div>
            </div>
        `;

        document.body.appendChild(modal);

        // 渲染左侧播放器列表
        function renderPlayerList() {
            const playerListContainer = modal.querySelector('#player-list');
            playerListContainer.innerHTML = '';

            tempPlayers.forEach(player => {
                const item = document.createElement('div');
                item.className = 'iwara-sidebar-player-item';
                item.dataset.playerName = player.name;
                if (currentView === player.name) {
                    item.classList.add('active');
                }

                const iconHtml = player.icon && player.icon.startsWith('data:image')
                    ? `<img src="${player.icon}" alt="${player.name}">`
                    : (player.icon || '🎮');

                item.innerHTML = `
                    <div class="iwara-sidebar-player-icon">${iconHtml}</div>
                    <div class="iwara-sidebar-player-info">
                        <p class="iwara-sidebar-player-name">${player.name}</p>
                    </div>
                `;

                item.addEventListener('click', () => {
                    currentView = player.name;
                    editingPlayer = player.name;
                    updateView();
                });

                playerListContainer.appendChild(item);
            });

            // 添加"添加"按钮
            const addPlayerItem = document.createElement('div');
            addPlayerItem.className = 'iwara-sidebar-player-item iwara-sidebar-add-player';
            if (currentView === 'add-player') {
                addPlayerItem.classList.add('active');
            }
            addPlayerItem.innerHTML = `
                <div class="iwara-sidebar-player-icon"><img src="" alt="添加"></div>
                <div class="iwara-sidebar-player-info">
                    <p class="iwara-sidebar-player-name">添加</p>
                </div>
            `;
            addPlayerItem.addEventListener('click', () => {
                currentView = 'add-player';
                editingPlayer = null;
                updateView();
            });
            playerListContainer.appendChild(addPlayerItem);
        }

        // 更新视图
        function updateView() {
            // 更新左侧选中状态
            modal.querySelectorAll('.iwara-sidebar-player-item').forEach(item => {
                if (item.classList.contains('iwara-sidebar-add-player')) {
                    item.classList.toggle('active', currentView === 'add-player');
                } else {
                    item.classList.toggle('active', item.dataset.playerName === currentView);
                }
            });
            modal.querySelector('.iwara-sidebar-main-settings').classList.toggle('active', currentView === 'main-settings');

            // 获取标题栏元素
            const contentHeader = modal.querySelector('#content-header');
            const contentTitle = modal.querySelector('#content-title');
            const deleteButton = modal.querySelector('#btn-delete-player');
            const createButton = modal.querySelector('#btn-create-player');

            // 更新右侧内容
            if (currentView === 'main-settings') {
                contentHeader.style.display = 'none';
                renderMainSettings();
            } else if (currentView === 'add-player') {
                contentHeader.style.display = 'flex';
                contentTitle.textContent = '➕ 添加';
                deleteButton.style.display = 'none';
                createButton.style.display = 'block';
                renderAddPlayerForm();
            } else {
                const player = tempPlayers.find(p => p.name === currentView);
                if (player) {
                    contentHeader.style.display = 'flex';
                    contentTitle.textContent = `✏️ 编辑`;
                    deleteButton.style.display = 'block';
                    createButton.style.display = 'none';
                    renderPlayerEditForm(player);
                }
            }
        }

        // 通用播放器表单渲染函数
        function renderPlayerForm(isEditMode, player = null) {
            const isProtocol = player ? player.type === 'protocol' : true;
            const protocolDisplay = isProtocol ? 'block' : 'none';
            const ushDisplay = isProtocol ? 'none' : 'block';
            const prefix = isEditMode ? 'edit' : 'new';

            return `
                <div style="margin-bottom: 20px;">
                    <label style="display: block; color: #94a3b8; font-size: 13px; margin-bottom: 8px;">播放器名称</label>
                    <input type="text" id="${prefix}-player-name" value="${player ? player.name : ''}" class="iwara-form-input" placeholder="例如: PotPlayer">
                </div>
                
                <div style="margin-bottom: 20px;">
                    <label style="display: block; color: #94a3b8; font-size: 13px; margin-bottom: 8px;">协议类型</label>
                    <select id="${prefix}-protocol-type" class="iwara-form-input">
                        <option value="protocol" ${isProtocol ? 'selected' : ''}>标准协议</option>
                        <option value="ush" ${!isProtocol ? 'selected' : ''}>USH协议</option>
                    </select>
                </div>
                
                <div id="${prefix}-protocol-group" style="margin-bottom: 20px; display: ${protocolDisplay};">
                    <label style="display: block; color: #94a3b8; font-size: 13px; margin-bottom: 8px;">协议链接参数</label>
                    <input type="text" id="${prefix}-protocol" value="${player && player.protocol ? player.protocol : ''}" class="iwara-form-input" placeholder="例如: potplayer://\${url}">
                    <p style="color: #64748b; font-size: 12px; margin: 6px 0 0 0;">可用参数: \${title} 标题 | \${url} 原始链接 | \${url:base64} base64编码 | \${url:encode} url编码</p>
                </div>
                
                <div id="${prefix}-ush-group" style="display: ${ushDisplay};">
                    <div style="margin-bottom: 20px;">
                        <label style="display: block; color: #94a3b8; font-size: 13px; margin-bottom: 8px;">应用名称</label>
                        <input type="text" id="${prefix}-ush-app" value="${player && player.appName ? player.appName : ''}" class="iwara-form-input" placeholder="例如: MPV (和ush工具配置的名称要完全一致)">
                        <p class="iwara-hint"><a href="https://github.com/LuckyPuppy514/url-scheme-handler" target="_blank" style="color: #667eea;">⭐ ush工具 - LuckyPuppy514/url-scheme-handler</a></p>
                    </div>
                    <div style="margin-bottom: 20px;">
                        <label style="display: block; color: #94a3b8; font-size: 13px; margin-bottom: 8px;">启动参数 (可选)</label>
                        <textarea id="${prefix}-ush-args" class="iwara-form-textarea" rows="4" placeholder="每行一个参数,例如:\n--ontop\n--fullscreen">${player && player.args ? player.args.join('\n') : ''}</textarea>
                        <p style="color: #64748b; font-size: 12px; margin: 6px 0 0 0;">可用参数: \${title} 标题 | \${url} 原始链接 | \${url:base64} base64编码 | \${url:encode} url编码</p>
                    </div>
                </div>
                
                <div style="margin-bottom: 20px;">
                    <label style="display: block; color: #94a3b8; font-size: 13px; margin-bottom: 8px;">图标 (Base64 Data URL)</label>
                    <textarea id="${prefix}-player-icon" class="iwara-form-textarea" rows="3" placeholder="...">${player && player.icon ? player.icon : ''}</textarea>
                    <p style="color: #64748b; font-size: 12px; margin: 6px 0 0 0;">支持 data:image/png、data:image/svg+xml 等格式</p>
                </div>
            `;
        }

        // 设置协议类型切换逻辑
        function setupProtocolTypeToggle(prefix) {
            const contentBody = modal.querySelector('#content-body');
            const protocolTypeSelect = contentBody.querySelector(`#${prefix}-protocol-type`);
            const protocolGroup = contentBody.querySelector(`#${prefix}-protocol-group`);
            const ushGroup = contentBody.querySelector(`#${prefix}-ush-group`);

            if (protocolTypeSelect) {
                protocolTypeSelect.addEventListener('change', () => {
                    if (protocolTypeSelect.value === 'protocol') {
                        protocolGroup.style.display = 'block';
                        ushGroup.style.display = 'none';
                    } else {
                        protocolGroup.style.display = 'none';
                        ushGroup.style.display = 'block';
                    }
                });
            }
        }

        // 渲染播放器编辑表单
        function renderPlayerEditForm(player) {
            const contentBody = modal.querySelector('#content-body');

            const originalName = player.name;

            contentBody.innerHTML = renderPlayerForm(true, player);

            // 设置协议类型切换
            setupProtocolTypeToggle('edit');

            // 实时更新播放器数据
            const inputs = [
                contentBody.querySelector('#edit-player-name'),
                contentBody.querySelector('#edit-protocol-type'),
                contentBody.querySelector('#edit-protocol'),
                contentBody.querySelector('#edit-ush-app'),
                contentBody.querySelector('#edit-ush-args'),
                contentBody.querySelector('#edit-player-icon')
            ];

            inputs.forEach(input => {
                if (input) {
                    input.addEventListener('input', () => {
                        const name = contentBody.querySelector('#edit-player-name').value.trim();
                        const type = contentBody.querySelector('#edit-protocol-type').value;
                        const icon = contentBody.querySelector('#edit-player-icon').value.trim();

                        // 更新播放器对象
                        const playerIndex = tempPlayers.findIndex(p => p.name === originalName);
                        if (playerIndex !== -1) {
                            tempPlayers[playerIndex].name = name;
                            tempPlayers[playerIndex].type = type;
                            tempPlayers[playerIndex].icon = icon;

                            if (type === 'protocol') {
                                tempPlayers[playerIndex].protocol = contentBody.querySelector('#edit-protocol').value.trim();
                                delete tempPlayers[playerIndex].appName;
                                delete tempPlayers[playerIndex].args;
                            } else {
                                tempPlayers[playerIndex].appName = contentBody.querySelector('#edit-ush-app').value.trim();
                                const args = contentBody.querySelector('#edit-ush-args').value.trim();
                                tempPlayers[playerIndex].args = args ? args.split('\n').map(a => a.trim()).filter(a => a) : ['{url}'];
                                delete tempPlayers[playerIndex].protocol;
                            }
                        }

                        // 更新标题栏的播放器名称
                        const contentTitle = modal.querySelector('#content-title');
                        if (contentTitle && name) {
                            contentTitle.textContent = `✏️ 编辑播放器: ${name}`;
                        }
                    });
                }
            });

            // 删除按钮事件 - 绑定到标题栏的删除按钮
            const deleteButton = modal.querySelector('#btn-delete-player');
            // 移除之前的事件监听器(如果有)
            const newDeleteButton = deleteButton.cloneNode(true);
            deleteButton.parentNode.replaceChild(newDeleteButton, deleteButton);

            newDeleteButton.addEventListener('click', () => {
                let confirmMessage = `确定要删除"${player.name}"吗?`;

                if (confirm(confirmMessage)) {
                    const index = tempPlayers.findIndex(p => p.name === originalName);
                    if (index !== -1) {
                        tempPlayers.splice(index, 1);
                    }

                    if (currentDefaultPlayer === originalName) {
                        currentDefaultPlayer = tempPlayers.length > 0 ? tempPlayers[0].name : 'MPV';
                    }

                    currentView = 'main-settings';
                    renderPlayerList();
                    updateView();
                    showNotification(`✅ 已删除"${player.name}"`, 'success');
                }
            });
        }

        // 渲染添加表单
        function renderAddPlayerForm() {
            const contentBody = modal.querySelector('#content-body');

            contentBody.innerHTML = renderPlayerForm(false);

            // 设置协议类型切换
            setupProtocolTypeToggle('new');

            // 添加按钮事件 - 绑定到标题栏的创建按钮
            const createButton = modal.querySelector('#btn-create-player');
            // 移除之前的事件监听器(如果有)
            const newCreateButton = createButton.cloneNode(true);
            createButton.parentNode.replaceChild(newCreateButton, createButton);

            newCreateButton.addEventListener('click', () => {
                const name = contentBody.querySelector('#new-player-name').value.trim();
                const type = contentBody.querySelector('#new-protocol-type').value;
                const icon = contentBody.querySelector('#new-player-icon').value.trim();

                if (!name) {
                    showNotification('❌ 请输入播放器名称', 'error');
                    return;
                }

                // 检查名称是否已存在
                if (tempPlayers.some(p => p.name === name)) {
                    showNotification('❌ 播放器名称已存在', 'error');
                    return;
                }

                const playerConfig = {
                    name: name,
                    type: type,
                    icon: icon || ""
                };

                if (type === 'protocol') {
                    const protocol = contentBody.querySelector('#new-protocol').value.trim();
                    if (!protocol) {
                        showNotification('❌ 请输入协议链接参数', 'error');
                        return;
                    }
                    if (!protocol.includes('${url}')) {
                        showNotification('❌ 协议链接必须包含 ${url} 占位符', 'error');
                        return;
                    }
                    playerConfig.protocol = protocol;
                } else {
                    const appName = contentBody.querySelector('#new-ush-app').value.trim();
                    if (!appName) {
                        showNotification('❌ 请输入应用名称', 'error');
                        return;
                    }
                    const args = contentBody.querySelector('#new-ush-args').value.trim();
                    playerConfig.appName = appName;
                    playerConfig.args = args ? args.split('\n').map(a => a.trim()).filter(a => a) : ['{url}'];
                }

                tempPlayers.push(playerConfig);
                currentView = name;
                renderPlayerList();
                updateView();
                showNotification(`✅ 已添加"${name}"`, 'success');
            });
        }

        // 渲染设置
        function renderMainSettings() {
            const contentBody = modal.querySelector('#content-body');

            const currentProxy = tempProxyList.map(p => {
                const prefix = p.enabled ? '' : '#';
                return `${prefix}${p.url}`;
            }).join('\n');

            contentBody.innerHTML = `
                <!-- 默认播放器设置 -->
                <div class="iwara-settings-section">
                    <div class="iwara-settings-header">
                        <h4>🎬 默认播放器</h4>
                        <button class="iwara-btn-small" id="reset-players">🔄 重置</button>
                    </div>
                    <select id="default-player-select" class="iwara-form-input">
                        ${tempPlayers.map(p => `<option value="${p.name}" ${p.name === currentDefaultPlayer ? 'selected' : ''}>${p.name}</option>`).join('')}
                    </select>
                </div>
                
                <!-- 按钮显示设置 -->
                <div class="iwara-settings-section">
                    <h4 class="iwara-settings-section-title no-indicator">⚪ 按钮显示设置</h4>
                    
                    <div class="iwara-settings-subsection">
                        <h5>📄 详情页</h5>
                        <div class="iwara-button-settings-grid">
                            <label class="iwara-checkbox-label">
                                <input type="checkbox" id="detail-copy" ${tempButtonSettings.detailPage.copy ? 'checked' : ''}>
                                <span>复制链接</span>
                            </label>
                            <label class="iwara-checkbox-label">
                                <input type="checkbox" id="detail-newtab" ${tempButtonSettings.detailPage.newTab ? 'checked' : ''}>
                                <span>新标签页播放</span>
                            </label>
                            <label class="iwara-checkbox-label">
                                <input type="checkbox" id="detail-quality" ${tempButtonSettings.detailPage.quality ? 'checked' : ''}>
                                <span>540画质播放</span>
                            </label>
                            <label class="iwara-checkbox-label">
                                <input type="checkbox" id="detail-play" ${tempButtonSettings.detailPage.play ? 'checked' : ''}>
                                <span>Source画质播放</span>
                            </label>
                        </div>
                    </div>
                    
                    <div class="iwara-settings-subsection">
                        <h5>📋 列表页</h5>
                        <div class="iwara-button-settings-grid">
                            <label class="iwara-checkbox-label">
                                <input type="checkbox" id="list-copy" ${tempButtonSettings.listPage.copy ? 'checked' : ''}>
                                <span>复制链接</span>
                            </label>
                            <label class="iwara-checkbox-label">
                                <input type="checkbox" id="list-newtab" ${tempButtonSettings.listPage.newTab ? 'checked' : ''}>
                                <span>新标签页播放</span>
                            </label>
                            <label class="iwara-checkbox-label">
                                <input type="checkbox" id="list-quality" ${tempButtonSettings.listPage.quality ? 'checked' : ''}>
                                <span>540画质播放</span>
                            </label>
                            <label class="iwara-checkbox-label">
                                <input type="checkbox" id="list-play" ${tempButtonSettings.listPage.play ? 'checked' : ''}>
                                <span>Source画质播放</span>
                            </label>
                        </div>
                    </div>
                </div>
                
                <!-- 代理服务设置 -->
                <div class="iwara-settings-section">
                    <div class="iwara-settings-header">
                        <h4>🔗 代理服务 (可选)</h4>
                        <div style="display: flex; gap: 8px;">
                            <button class="iwara-btn-small" id="save-multi-edit" style="display: none;">💾 保存</button>
                            <button class="iwara-btn-small" id="toggle-edit-mode">📝 手动编辑</button>
                        </div>
                    </div>
                    
                    <div id="single-add-mode" style="display: block;">
                        <div style="display: flex; gap: 8px; margin-bottom: 12px;">
                            <input type="text" id="new-proxy-input" placeholder="多个将会随机选取, 代理地址 例: https://proxy.example.com/" class="iwara-form-input" style="flex: 1;">
                            <button class="iwara-btn-small" id="add-proxy">➕ 添加</button>
                        </div>
                        <div style="display: flex; gap: 8px; margin-bottom: 12px; flex-wrap: wrap; align-items: center;">
                            <div style="display: flex; align-items: center; gap: 4px;">
                                <label style="color: #94a3b8; font-size: 13px; white-space: nowrap;">超时</label>
                                <input type="number" id="proxy-timeout" value="${tempProxyTimeout}" min="1" max="100000" step="100" class="iwara-form-input" style="width: 80px; padding: 4px 8px; font-size: 13px;">
                                <span style="color: #94a3b8; font-size: 13px;">ms</span>
                            </div>
                            <button class="iwara-btn-small" id="check-all-proxies">🔍 检测延迟</button>
                            <button class="iwara-btn-small" id="enable-all-proxies" style="background: rgba(34, 197, 94, 0.2); border-color: rgba(34, 197, 94, 0.4); color: #22c55e;">✓ 启用全部</button>
                            <button class="iwara-btn-small" id="disable-failed-proxies" style="background: rgba(255, 165, 0, 0.2); border-color: rgba(255, 165, 0, 0.4); color: #ffa500;">⚠️ 禁用超时</button>
                            <button class="iwara-btn-small" id="delete-failed-proxies" style="background: rgba(255, 59, 48, 0.2); border-color: rgba(255, 59, 48, 0.4); color: #ff3b30;">🗑️ 删除超时</button>
                        </div>
                        <div id="proxy-list-container" class="iwara-proxy-list" style="max-height: 200px;"></div>
                    </div>
                    
                    <div id="multi-edit-mode" style="display: none;">
                        <textarea id="proxy-input" class="iwara-form-textarea" style="min-height: 160px;" placeholder="每行一个代理,以#开头表示禁用:\nproxy1.example.com\n#proxy2.example.com (禁用)\nhttps://proxy3.example.com/">${currentProxy}</textarea>
                        <p style="color: #64748b; font-size: 12px; margin: 8px 0 0 0;">💡 每行一个代理地址,以 # 开头的代理将被禁用</p>
                    </div>
                    
                    <p style="color: #64748b; font-size: 12px; margin: 8px 0 0 0;">
                        <a href="https://github.com/1234567Yang/cf-proxy-ex" target="_blank" style="color: #818cf8; text-decoration: none;">⭐ 代理项目(需自行部署): cf-proxy-ex</a>
                    </p>
                    <p style="color: #64748b; font-size: 12px; margin: 8px 0 0 0;">⏩ 仅代理视频的播放链接</p>
                </div>
            `;

            // 绑定默认播放器选择
            contentBody.querySelector('#default-player-select').addEventListener('change', (e) => {
                currentDefaultPlayer = e.target.value;
            });

            // 绑定按钮显示设置 - 视频详情页
            contentBody.querySelector('#detail-copy').addEventListener('change', (e) => {
                tempButtonSettings.detailPage.copy = e.target.checked;
            });
            contentBody.querySelector('#detail-newtab').addEventListener('change', (e) => {
                tempButtonSettings.detailPage.newTab = e.target.checked;
            });
            contentBody.querySelector('#detail-quality').addEventListener('change', (e) => {
                tempButtonSettings.detailPage.quality = e.target.checked;
            });
            contentBody.querySelector('#detail-play').addEventListener('change', (e) => {
                tempButtonSettings.detailPage.play = e.target.checked;
            });

            // 绑定按钮显示设置 - 视频列表页
            contentBody.querySelector('#list-copy').addEventListener('change', (e) => {
                tempButtonSettings.listPage.copy = e.target.checked;
            });
            contentBody.querySelector('#list-newtab').addEventListener('change', (e) => {
                tempButtonSettings.listPage.newTab = e.target.checked;
            });
            contentBody.querySelector('#list-quality').addEventListener('change', (e) => {
                tempButtonSettings.listPage.quality = e.target.checked;
            });
            contentBody.querySelector('#list-play').addEventListener('change', (e) => {
                tempButtonSettings.listPage.play = e.target.checked;
            });

            // 绑定恢复默认
            contentBody.querySelector('#reset-players').addEventListener('click', () => {
                if (confirm('确定要恢复到默认播放器列表吗?\n\n这将删除所有自定义播放器。')) {
                    modal.remove();
                    resetToDefaultPlayers();
                }
            });

            // 代理设置逻辑
            renderProxyList();
            setupProxyEditMode();
        }

        // 渲染代理列表
        function renderProxyList() {
            const container = modal.querySelector('#proxy-list-container');
            if (!container) return;

            container.innerHTML = '';

            if (tempProxyList.length === 0) {
                container.innerHTML = '<p style="color: #64748b; text-align: center; padding: 20px 0; margin: 0;">暂无代理,请使用上方输入框添加</p>';
                return;
            }

            tempProxyList.forEach((proxy, index) => {
                const item = document.createElement('div');
                item.className = 'iwara-proxy-item' + (proxy.enabled ? '' : ' disabled');
                item.dataset.index = index;

                const urlSpan = document.createElement('span');
                urlSpan.className = 'proxy-url';
                urlSpan.textContent = proxy.url;

                // 状态显示
                const statusSpan = document.createElement('span');
                statusSpan.className = 'iwara-proxy-status';
                statusSpan.style.display = 'none';
                statusSpan.textContent = '-';

                const toggleBtn = document.createElement('button');
                toggleBtn.className = 'iwara-proxy-toggle' + (proxy.enabled ? '' : ' disabled');
                toggleBtn.textContent = proxy.enabled ? '✓ 启用' : '✕ 禁用';
                toggleBtn.addEventListener('click', () => {
                    proxy.enabled = !proxy.enabled;
                    renderProxyList();
                });

                const deleteBtn = document.createElement('button');
                deleteBtn.className = 'iwara-proxy-delete';
                deleteBtn.textContent = '🗑️';
                deleteBtn.addEventListener('click', () => {
                    if (confirm(`确定要删除代理 "${proxy.url}" 吗?`)) {
                        tempProxyList.splice(index, 1);
                        renderProxyList();
                    }
                });

                item.appendChild(urlSpan);
                item.appendChild(statusSpan);
                item.appendChild(toggleBtn);
                item.appendChild(deleteBtn);
                container.appendChild(item);
            });
        }

        // 检测单个代理
        async function checkSingleProxy(proxyUrl, timeoutMs) {
            const startTime = performance.now();

            return new Promise((resolve) => {
                const timeout = setTimeout(() => {
                    resolve({ success: false, latency: -1, error: 'timeout' });
                }, timeoutMs);

                GM_xmlhttpRequest({
                    method: 'GET',
                    url: proxyUrl,
                    timeout: timeoutMs,
                    onload: function (response) {
                        clearTimeout(timeout);
                        const endTime = performance.now();
                        const latency = Math.round(endTime - startTime);
                        // 任何响应都算成功(包括404等),只要能连接
                        resolve({ success: true, latency, status: response.status });
                    },
                    onerror: function (error) {
                        clearTimeout(timeout);
                        resolve({ success: false, latency: -1, error: 'network' });
                    },
                    ontimeout: function () {
                        clearTimeout(timeout);
                        resolve({ success: false, latency: -1, error: 'timeout' });
                    }
                });
            });
        }

        // 检测所有代理
        async function checkAllProxies() {
            const container = modal.querySelector('#proxy-list-container');
            if (!container || tempProxyList.length === 0) {
                showNotification('❌ 没有可检测的代理', 'error');
                return;
            }

            // 获取自定义超时时间
            const timeoutInput = modal.querySelector('#proxy-timeout');
            let timeoutMs = parseInt(timeoutInput.value) || 10000;

            // 验证超时时间范围
            if (timeoutMs < 100) timeoutMs = 100;
            if (timeoutMs > 100000) timeoutMs = 100000;
            timeoutInput.value = timeoutMs;

            const checkBtn = modal.querySelector('#check-all-proxies');
            const originalText = checkBtn.textContent;
            checkBtn.disabled = true;
            checkBtn.textContent = '🔍 检测中...';

            // 显示所有状态标签并设置为检测中
            const items = container.querySelectorAll('.iwara-proxy-item');
            items.forEach(item => {
                const statusSpan = item.querySelector('.iwara-proxy-status');
                if (statusSpan) {
                    statusSpan.style.display = 'inline-block';
                    statusSpan.className = 'iwara-proxy-status checking';
                    statusSpan.textContent = '检测中...';
                }
                // 清除之前的检测结果
                const proxy = tempProxyList[item.dataset.index];
                if (proxy) {
                    delete proxy.checkResult;
                }
            });

            // 并发检测所有代理
            const results = await Promise.all(
                tempProxyList.map(proxy => checkSingleProxy(proxy.url, timeoutMs))
            );

            // 更新显示结果
            results.forEach((result, index) => {
                const item = container.querySelector(`[data-index="${index}"]`);
                if (!item) return;

                const statusSpan = item.querySelector('.iwara-proxy-status');
                if (!statusSpan) return;

                // 保存检测结果到代理对象
                tempProxyList[index].checkResult = result;

                if (result.success) {
                    const latency = result.latency;
                    statusSpan.textContent = `${latency}ms`;

                    // 根据延迟设置不同颜色
                    if (latency < 200) {
                        statusSpan.className = 'iwara-proxy-status success';
                    } else if (latency < 1000) {
                        statusSpan.className = 'iwara-proxy-status slow';
                    } else {
                        statusSpan.className = 'iwara-proxy-status slow';
                    }
                } else {
                    statusSpan.className = 'iwara-proxy-status failed';
                    statusSpan.textContent = result.error === 'timeout' ? '超时' : '失败';
                }
            });

            checkBtn.disabled = false;
            checkBtn.textContent = originalText;

            const successCount = results.filter(r => r.success).length;
            const failCount = results.length - successCount;
            showNotification(`✅ 检测完成: ${successCount} 个可用, ${failCount} 个失败`, 'success');
        }

        // 启用全部代理
        function enableAllProxies() {
            if (tempProxyList.length === 0) {
                showNotification('ℹ️ 没有可启用的代理', 'info');
                return;
            }

            const disabledCount = tempProxyList.filter(p => !p.enabled).length;

            if (disabledCount === 0) {
                showNotification('ℹ️ 所有代理都已启用', 'info');
                return;
            }

            tempProxyList.forEach(proxy => {
                proxy.enabled = true;
            });
            renderProxyList();
            showNotification(`✅ 已启用全部代理 (${disabledCount} 个)`, 'success');
        }

        // 禁用所有失败的代理
        function disableFailedProxies() {
            const failedCount = tempProxyList.filter(p => p.checkResult && !p.checkResult.success).length;

            if (failedCount === 0) {
                showNotification('ℹ️ 没有检测到超时的代理', 'info');
                return;
            }

            if (confirm(`确定要禁用 ${failedCount} 个失败的代理吗?`)) {
                tempProxyList.forEach(proxy => {
                    if (proxy.checkResult && !proxy.checkResult.success) {
                        proxy.enabled = false;
                    }
                });
                renderProxyList();
                showNotification(`✅ 已禁用 ${failedCount} 个失败的代理`, 'success');
            }
        }

        // 删除所有失败的代理
        function deleteFailedProxies() {
            const failedCount = tempProxyList.filter(p => p.checkResult && !p.checkResult.success).length;

            if (failedCount === 0) {
                showNotification('ℹ️ 没有检测到超时的代理', 'info');
                return;
            }

            if (confirm(`确定要删除 ${failedCount} 个失败的代理吗?\n\n此操作不可恢复!`)) {
                tempProxyList = tempProxyList.filter(p => !p.checkResult || p.checkResult.success);
                renderProxyList();
                showNotification(`✅ 已删除 ${failedCount} 个失败的代理`, 'success');
            }
        }

        // 设置代理编辑模式
        function setupProxyEditMode() {
            let isMultiEditMode = false;
            const toggleModeBtn = modal.querySelector('#toggle-edit-mode');
            const singleAddMode = modal.querySelector('#single-add-mode');
            const multiEditMode = modal.querySelector('#multi-edit-mode');
            const addProxyBtn = modal.querySelector('#add-proxy');
            const newProxyInput = modal.querySelector('#new-proxy-input');

            if (!toggleModeBtn) return;

            const saveMultiEditBtn = modal.querySelector('#save-multi-edit');

            toggleModeBtn.addEventListener('click', () => {
                if (isMultiEditMode) {
                    // 切换回列表编辑模式(先保存)
                    const textarea = modal.querySelector('#proxy-input');
                    const lines = textarea.value.split('\n');

                    tempProxyList = [];
                    const urlSet = new Set(); // 用于去重
                    let duplicateCount = 0;
                    let invalidCount = 0;

                    lines.forEach(line => {
                        line = line.trim();
                        if (line === '') return;

                        let enabled = true;
                        let url = line;

                        if (line.startsWith('#')) {
                            enabled = false;
                            url = line.substring(1).trim();
                        }

                        if (url !== '') {
                            // 标准化URL用于去重判断
                            const normalized = normalizeProxyUrl(url);
                            if (normalized && !urlSet.has(normalized)) {
                                urlSet.add(normalized);
                                tempProxyList.push({ url: normalized, enabled });
                            } else if (normalized && urlSet.has(normalized)) {
                                duplicateCount++;
                            } else if (!normalized) {
                                // 无效的URL
                                invalidCount++;
                            }
                        }
                    });

                    isMultiEditMode = false;
                    multiEditMode.style.display = 'none';
                    singleAddMode.style.display = 'block';
                    saveMultiEditBtn.style.display = 'none';
                    toggleModeBtn.textContent = '📝 手动编辑';
                    renderProxyList();

                    // 构建提示信息
                    let messages = [];
                    if (duplicateCount > 0) {
                        messages.push(`已去重 ${duplicateCount} 个重复项`);
                    }
                    if (invalidCount > 0) {
                        messages.push(`已忽略 ${invalidCount} 个无效项`);
                    }

                    if (messages.length > 0) {
                        showNotification(`✅ 已保存并切换到列表编辑(${messages.join(',')})`, 'success');
                    } else {
                        showNotification('✅ 已保存并切换到列表编辑', 'success');
                    }
                } else {
                    // 切换到手动编辑
                    isMultiEditMode = true;
                    const textarea = modal.querySelector('#proxy-input');
                    const lines = tempProxyList.map(p => {
                        const prefix = p.enabled ? '' : '#';
                        return `${prefix}${p.url}`;
                    });
                    textarea.value = lines.join('\n');

                    singleAddMode.style.display = 'none';
                    multiEditMode.style.display = 'block';
                    saveMultiEditBtn.style.display = 'block';
                    toggleModeBtn.textContent = '📋 列表编辑';
                }
            });

            // 保存手动编辑
            if (saveMultiEditBtn) {
                saveMultiEditBtn.addEventListener('click', () => {
                    const textarea = modal.querySelector('#proxy-input');
                    const lines = textarea.value.split('\n');

                    tempProxyList = [];
                    const urlSet = new Set(); // 用于去重
                    let duplicateCount = 0;
                    let invalidCount = 0;

                    lines.forEach(line => {
                        line = line.trim();
                        if (line === '') return;

                        let enabled = true;
                        let url = line;

                        if (line.startsWith('#')) {
                            enabled = false;
                            url = line.substring(1).trim();
                        }

                        if (url !== '') {
                            // 标准化URL用于去重判断
                            const normalized = normalizeProxyUrl(url);
                            if (normalized && !urlSet.has(normalized)) {
                                urlSet.add(normalized);
                                tempProxyList.push({ url: normalized, enabled });
                            } else if (normalized && urlSet.has(normalized)) {
                                duplicateCount++;
                            } else if (!normalized) {
                                // 无效的URL
                                invalidCount++;
                            }
                        }
                    });

                    isMultiEditMode = false;
                    multiEditMode.style.display = 'none';
                    singleAddMode.style.display = 'block';
                    saveMultiEditBtn.style.display = 'none';
                    toggleModeBtn.textContent = '📝 手动编辑';
                    renderProxyList();

                    // 构建提示信息
                    let messages = [];
                    if (duplicateCount > 0) {
                        messages.push(`已去重 ${duplicateCount} 个重复项`);
                    }
                    if (invalidCount > 0) {
                        messages.push(`已忽略 ${invalidCount} 个无效项`);
                    }

                    if (messages.length > 0) {
                        showNotification(`✅ 已保存并切换到列表编辑(${messages.join(',')})`, 'success');
                    } else {
                        showNotification('✅ 已保存并切换到列表编辑', 'success');
                    }
                });
            }

            // 添加代理
            addProxyBtn.addEventListener('click', () => {
                const url = newProxyInput.value.trim();

                if (!url) {
                    showNotification('❌ 请输入代理地址', 'error');
                    return;
                }

                const normalized = normalizeProxyUrl(url);
                if (normalized === null) {
                    showNotification(`❌ 代理地址格式错误: ${url}`, 'error');
                    return;
                }

                if (tempProxyList.some(p => p.url === normalized)) {
                    showNotification('❌ 该代理已存在', 'error');
                    return;
                }

                tempProxyList.push({ url: normalized, enabled: true });
                newProxyInput.value = '';
                renderProxyList();
                showNotification('✅ 代理已添加', 'success');
            });

            newProxyInput.addEventListener('keypress', (e) => {
                if (e.key === 'Enter') {
                    addProxyBtn.click();
                }
            });

            // 超时时间输入框变化监听
            const timeoutInput = modal.querySelector('#proxy-timeout');
            if (timeoutInput) {
                timeoutInput.addEventListener('change', () => {
                    let value = parseInt(timeoutInput.value) || 10000;
                    // 验证范围
                    if (value < 100) value = 100;
                    if (value > 100000) value = 100000;
                    timeoutInput.value = value;
                    tempProxyTimeout = value;
                });
            }

            // 检测所有代理按钮
            const checkAllBtn = modal.querySelector('#check-all-proxies');
            if (checkAllBtn) {
                checkAllBtn.addEventListener('click', checkAllProxies);
            }

            // 启用全部代理按钮
            const enableAllBtn = modal.querySelector('#enable-all-proxies');
            if (enableAllBtn) {
                enableAllBtn.addEventListener('click', enableAllProxies);
            }

            // 禁用失败代理按钮
            const disableFailedBtn = modal.querySelector('#disable-failed-proxies');
            if (disableFailedBtn) {
                disableFailedBtn.addEventListener('click', disableFailedProxies);
            }

            // 删除失败代理按钮
            const deleteFailedBtn = modal.querySelector('#delete-failed-proxies');
            if (deleteFailedBtn) {
                deleteFailedBtn.addEventListener('click', deleteFailedProxies);
            }
        }

        // 初始化
        renderPlayerList();
        updateView(); // 默认显示设置页

        // 设置点击
        modal.querySelector('[data-view="main-settings"]').addEventListener('click', () => {
            currentView = 'main-settings';
            updateView();
        });

        // 关闭按钮
        const closeModal = () => modal.remove();
        modal.querySelector('#btn-close').addEventListener('click', closeModal);

        // 保存设置按钮
        function saveSettings(shouldReload = false) {
            let hasChanges = false;

            // 保存默认播放器
            if (externalPlayer !== currentDefaultPlayer) {
                externalPlayer = currentDefaultPlayer;
                GM_setValue('externalPlayer', externalPlayer);
                hasChanges = true;
            }

            // 保存播放器列表
            const oldPlayersStr = JSON.stringify(customPlayers);
            const newPlayersStr = JSON.stringify(tempPlayers);
            if (oldPlayersStr !== newPlayersStr) {
                customPlayers = tempPlayers;
                GM_setValue('customPlayers', customPlayers);
                hasChanges = true;
            }

            // 保存按钮显示设置
            const oldButtonSettingsStr = JSON.stringify(buttonSettings);
            const newButtonSettingsStr = JSON.stringify(tempButtonSettings);
            if (oldButtonSettingsStr !== newButtonSettingsStr) {
                buttonSettings = tempButtonSettings;
                GM_setValue('buttonSettings', buttonSettings);
                hasChanges = true;
            }

            // 验证并保存代理列表
            const validatedProxyList = [];
            for (const proxy of tempProxyList) {
                const normalized = normalizeProxyUrl(proxy.url);
                if (normalized === null) {
                    showNotification(`❌ 代理地址格式错误: ${proxy.url}`, 'error');
                    return;
                }
                validatedProxyList.push({
                    url: normalized,
                    enabled: proxy.enabled
                });
            }

            const oldListStr = JSON.stringify(GM_getValue('proxyList', []));
            const newListStr = JSON.stringify(validatedProxyList);

            if (oldListStr !== newListStr) {
                proxyList = validatedProxyList;
                GM_setValue('proxyList', proxyList);
                hasChanges = true;
            }

            // 保存代理超时时间
            if (proxyTimeout !== tempProxyTimeout) {
                proxyTimeout = tempProxyTimeout;
                GM_setValue('proxyTimeout', proxyTimeout);
                hasChanges = true;
            }

            closeModal();

            if (hasChanges) {
                if (shouldReload) {
                    showNotification('✅ 设置已保存,正在刷新页面...', 'success');
                    setTimeout(() => location.reload(), 800);
                } else {
                    showNotification('✅ 设置已保存,正在应用更改...', 'success');
                    // 刷新所有按钮以应用新设置
                    setTimeout(() => {
                        refreshAllButtons();
                        showNotification('✅ 设置已生效', 'success');
                    }, 500);
                }
            } else {
                showNotification('ℹ️ 没有修改任何设置', 'info');
            }
        }

        modal.querySelector('#btn-save').addEventListener('click', () => saveSettings(false));
    }

    // 创建编辑播放器弹窗
    function createEditPlayerModal(playerData) {
        const editModal = document.createElement('div');
        editModal.id = 'iwara-edit-player-modal';
        editModal.style.zIndex = '9999999'; // 确保在设置弹窗之上

        // 根据播放器类型显示不同的输入框
        const isProtocolType = playerData.type === 'protocol';
        const protocolDisplay = isProtocolType ? 'block' : 'none';
        const ushDisplay = isProtocolType ? 'none' : 'block';

        editModal.innerHTML = `
            <div class="modal-overlay">
                <div class="modal-content" style="max-width: 450px;">
                    <div class="modal-header">
                        <h2>✏️ 编辑播放器</h2>
                        <button class="close-btn">✕</button>
                    </div>

                    <div class="modal-body">
                        <div class="form-group">
                            <label>播放器名称</label>
                            <input type="text" id="edit-player-name-input" placeholder="例如: PotPlayer" class="form-input" value="${playerData.name}">
                        </div>

                        <div class="form-group">
                            <label>协议类型</label>
                            <select id="edit-protocol-type-select" class="form-input">
                                <option value="protocol" ${isProtocolType ? 'selected' : ''}>标准协议</option>
                                <option value="ush" ${!isProtocolType ? 'selected' : ''}>USH协议</option>
                            </select>
                        </div>

                        <div class="form-group" id="edit-protocol-input-group" style="display: ${protocolDisplay};">
                            <label>协议链接参数</label>
                            <input type="text" id="edit-protocol-input" placeholder="例如: potplayer://\${url}" class="form-input" value="${playerData.protocol || ''}">
                            <p class="hint">可用参数: \${title} 标题 | \${url} 原始链接 | \${url:base64} base64编码 | \${url:encode} url编码</p>
                        </div>

                        <div class="form-group" id="edit-ush-app-input-group" style="display: ${ushDisplay};">
                            <label>应用名称</label>
                            <input type="text" id="edit-ush-app-input" placeholder="例如: MPV (和ush工具配置的名称要完全一致)" class="form-input" value="${playerData.appName || ''}">
                            <p class="iwara-hint"><a href="https://github.com/LuckyPuppy514/url-scheme-handler" target="_blank" style="color: #667eea;">⭐ ush工具 - LuckyPuppy514/url-scheme-handler</a></p>
                        </div>

                        <div class="form-group" id="edit-ush-args-input-group" style="display: ${ushDisplay};">
                            <label>启动参数 (可选)</label>
                            <textarea id="edit-ush-args-input" placeholder="每行一个参数,例如:\n--ontop\n--fullscreen" class="form-textarea" rows="3">${playerData.args ? playerData.args.join('\n') : ''}</textarea>
                            <p class="hint">可用参数: \${title} 标题 | \${url} 原始链接 | \${url:base64} base64编码 | \${url:encode} url编码</p>
                        </div>

                        <div class="form-group">
                            <label>图标 (Base64 Data URL)</label>
                            <textarea id="edit-player-icon-input" placeholder="..." class="form-textarea" rows="3">${playerData.icon || ''}</textarea>
                            <p class="hint">支持 data:image/png、data:image/svg+xml 等格式</p>
                        </div>

                        <div class="form-group">
                            <label>描述 (可选)</label>
                            <input type="text" id="edit-player-desc-input" placeholder="例如: 需要安装 PotPlayer" class="form-input" value="${playerData.description || ''}">
                        </div>
                    </div>

                    <div class="modal-footer">
                        <button class="btn-cancel">取消</button>
                        <button class="btn-save">保存修改</button>
                    </div>
                </div>
            </div>
        `;

        // 添加样式
        const style = document.createElement('style');
        style.textContent = `
            #iwara-edit-player-modal {
                position: fixed;
                top: 0;
                left: 0;
                right: 0;
                bottom: 0;
                z-index: 9999999 !important;
                font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
            }

            #iwara-edit-player-modal .modal-overlay {
                position: absolute;
                top: 0;
                left: 0;
                right: 0;
                bottom: 0;
                background: rgba(20, 20, 30, 0.75);
                backdrop-filter: blur(12px);
                display: flex;
                align-items: center;
                justify-content: center;
                animation: fadeIn 0.2s ease;
            }

            #iwara-edit-player-modal .modal-content {
                background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
                border-radius: 16px;
                width: 90%;
                max-width: 450px;
                box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
                animation: slideUp 0.3s ease;
                overflow: hidden;
            }

            #iwara-edit-player-modal .modal-header {
                padding: 24px 28px;
                background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
                display: flex;
                justify-content: space-between;
                align-items: center;
            }

            #iwara-edit-player-modal .modal-header h2 {
                margin: 0;
                color: white;
                font-size: 20px;
                font-weight: 600;
            }

            #iwara-edit-player-modal .close-btn {
                background: rgba(255, 255, 255, 0.2);
                border: none;
                color: white;
                width: 32px;
                height: 32px;
                border-radius: 50%;
                cursor: pointer;
                font-size: 20px;
                display: flex;
                align-items: center;
                justify-content: center;
                transition: all 0.2s;
            }

            #iwara-edit-player-modal .close-btn:hover {
                background: rgba(255, 255, 255, 0.3);
                transform: rotate(90deg);
            }

            #iwara-edit-player-modal .modal-body {
                padding: 28px;
                max-height: 70vh;
                overflow-y: auto;
            }

            #iwara-edit-player-modal .form-group {
                margin-bottom: 20px;
            }

            #iwara-edit-player-modal .form-group label {
                display: block;
                color: #e0e0e0;
                font-size: 14px;
                font-weight: 600;
                margin-bottom: 8px;
            }

            #iwara-edit-player-modal .form-input,
            #iwara-edit-player-modal .form-textarea {
                width: 100%;
                padding: 10px 14px;
                background: rgba(255, 255, 255, 0.05);
                border: 2px solid rgba(255, 255, 255, 0.1);
                border-radius: 8px;
                color: #e0e0e0;
                font-size: 14px;
                transition: all 0.2s;
                box-sizing: border-box;
                font-family: inherit;
            }

            #iwara-edit-player-modal .form-input:focus,
            #iwara-edit-player-modal .form-textarea:focus {
                outline: none;
                border-color: #667eea;
                background: rgba(255, 255, 255, 0.08);
            }

            #iwara-edit-player-modal .form-input::placeholder,
            #iwara-edit-player-modal .form-textarea::placeholder {
                color: #666;
            }

            #iwara-edit-player-modal .form-textarea {
                resize: vertical;
                min-height: 60px;
            }

            #iwara-edit-player-modal select.form-input {
                cursor: pointer;
                background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23667eea' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
                background-repeat: no-repeat;
                background-position: right 12px center;
                padding-right: 36px;
                appearance: none;
                -webkit-appearance: none;
                -moz-appearance: none;
            }

            #iwara-edit-player-modal select.form-input:hover {
                border-color: rgba(102, 126, 234, 0.5);
            }

            #iwara-edit-player-modal select.form-input option {
                background: #1a1a2e;
                color: #e0e0e0;
                padding: 10px;
            }

            #iwara-edit-player-modal select.form-input option:hover {
                background: #667eea;
            }

            #iwara-edit-player-modal .hint {
                margin: 8px 0 0 0;
                color: #999;
                font-size: 12px;
            }

            #iwara-edit-player-modal .modal-footer {
                padding: 20px 28px;
                background: rgba(0, 0, 0, 0.2);
                display: flex;
                justify-content: flex-end;
                gap: 12px;
            }

            #iwara-edit-player-modal .modal-footer button {
                padding: 10px 24px;
                border: none;
                border-radius: 8px;
                font-size: 14px;
                font-weight: 600;
                cursor: pointer;
                transition: all 0.2s;
            }

            #iwara-edit-player-modal .btn-cancel {
                background: rgba(255, 255, 255, 0.1);
                color: #e0e0e0;
            }

            #iwara-edit-player-modal .btn-cancel:hover {
                background: rgba(255, 255, 255, 0.15);
            }

            #iwara-edit-player-modal .btn-save {
                background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
                color: white;
            }

            #iwara-edit-player-modal .btn-save:hover {
                transform: translateY(-2px);
                box-shadow: 0 4px 12px rgba(102, 126, 234, 0.4);
            }
        `;

        editModal.appendChild(style);
        document.body.appendChild(editModal);

        const originalName = playerData.name; // 保存原始名称用于更新

        // 绑定事件
        const closeEditModal = () => editModal.remove();

        editModal.querySelector('.close-btn').addEventListener('click', closeEditModal);
        editModal.querySelector('.btn-cancel').addEventListener('click', closeEditModal);
        editModal.querySelector('.modal-overlay').addEventListener('click', (e) => {
            if (e.target.classList.contains('modal-overlay')) {
                closeEditModal();
            }
        });

        // 协议类型
        const protocolTypeSelect = editModal.querySelector('#edit-protocol-type-select');
        const protocolInputGroup = editModal.querySelector('#edit-protocol-input-group');
        const ushAppInputGroup = editModal.querySelector('#edit-ush-app-input-group');
        const ushArgsInputGroup = editModal.querySelector('#edit-ush-args-input-group');

        protocolTypeSelect.addEventListener('change', () => {
            if (protocolTypeSelect.value === 'protocol') {
                protocolInputGroup.style.display = 'block';
                ushAppInputGroup.style.display = 'none';
                ushArgsInputGroup.style.display = 'none';
            } else {
                protocolInputGroup.style.display = 'none';
                ushAppInputGroup.style.display = 'block';
                ushArgsInputGroup.style.display = 'block';
            }
        });

        // 保存修改
        editModal.querySelector('.btn-save').addEventListener('click', () => {
            const name = editModal.querySelector('#edit-player-name-input').value.trim();
            const icon = editModal.querySelector('#edit-player-icon-input').value.trim();
            const description = editModal.querySelector('#edit-player-desc-input').value.trim();
            const protocolType = protocolTypeSelect.value;

            if (!name) {
                showNotification('❌ 请输入播放器名称', 'error');
                return;
            }

            // 检查名称是否与其他播放器冲突(除了自己)
            const existingPlayer = customPlayers.find(p => p.name === name && p.name !== originalName);
            if (existingPlayer) {
                showNotification('❌ 播放器名称已存在,请使用其他名称', 'error');
                return;
            }

            // 验证 icon 格式
            let validIcon = icon;
            if (icon && !icon.startsWith('data:image')) {
                showNotification('❌ 图标必须是 data:image 格式的 Base64 数据', 'error');
                return;
            }
            if (!icon) {
                // 默认图标
                validIcon = "";
            }

            const updatedPlayerConfig = {
                name: name,
                icon: validIcon,
                description: description || '自定义播放器'
            };

            if (protocolType === 'protocol') {
                const protocol = editModal.querySelector('#edit-protocol-input').value.trim();
                if (!protocol) {
                    showNotification('❌ 请输入协议链接参数', 'error');
                    return;
                }
                if (!protocol.includes('${url}')) {
                    showNotification('❌ 协议链接参数必须包含 ${url} 占位符', 'error');
                    return;
                }
                updatedPlayerConfig.type = 'protocol';
                updatedPlayerConfig.protocol = protocol;
            } else {
                const appName = editModal.querySelector('#edit-ush-app-input').value.trim();
                if (!appName) {
                    showNotification('❌ 请输入应用名称', 'error');
                    return;
                }
                const args = editModal.querySelector('#edit-ush-args-input').value.trim();
                updatedPlayerConfig.type = 'ush';
                updatedPlayerConfig.appName = appName;
                updatedPlayerConfig.args = args ? args.split('\n').map(a => a.trim()).filter(a => a) : ['{url}'];
            }

            // 找到播放器在数组中的索引并更新
            const playerIndex = customPlayers.findIndex(p => p.name === originalName);
            if (playerIndex !== -1) {
                customPlayers[playerIndex] = updatedPlayerConfig;
                GM_setValue('customPlayers', customPlayers);

                // 如果修改的是当前选中的播放器,更新选中状态
                if (externalPlayer === originalName && name !== originalName) {
                    externalPlayer = name;
                    GM_setValue('externalPlayer', externalPlayer);
                }

                closeEditModal();
                showNotification('✅ 播放器已更新', 'success');

                // 刷新设置弹窗中的播放器列表
                refreshPlayerList();
            } else {
                showNotification('❌ 播放器更新失败', 'error');
            }
        });
    }

    // 创建添加弹窗
    function createAddPlayerModal() {
        const addModal = document.createElement('div');
        addModal.id = 'iwara-add-player-modal';
        addModal.style.zIndex = '9999999'; // 确保在设置弹窗之上
        addModal.innerHTML = `
            <div class="modal-overlay">
                <div class="modal-content" style="max-width: 450px;">
                    <div class="modal-header">
                        <h2>➕ 添加</h2>
                        <button class="close-btn">✕</button>
                    </div>

                    <div class="modal-body">
                        <div class="form-group">
                            <label>播放器名称</label>
                            <input type="text" id="player-name-input" placeholder="例如: PotPlayer" class="form-input">
                        </div>

                        <div class="form-group">
                            <label>协议类型</label>
                            <select id="protocol-type-select" class="form-input">
                                <option value="protocol">标准协议</option>
                                <option value="ush">USH协议</option>
                            </select>
                        </div>

                        <div class="form-group" id="protocol-input-group">
                            <label>协议链接参数</label>
                            <input type="text" id="protocol-input" placeholder="例如: potplayer://\${url}" class="form-input">
                            <p class="hint">可用参数: \${title} 标题 | \${url} 原始链接 | \${url:base64} base64编码 | \${url:encode} url编码</p>
                        </div>

                        <div class="form-group" id="ush-app-input-group" style="display: none;">
                            <label>应用名称</label>
                            <input type="text" id="ush-app-input" placeholder="例如: PotPlayer" class="form-input">
                        </div>

                        <div class="form-group" id="ush-args-input-group" style="display: none;">
                            <label>启动参数 (可选)</label>
                            <textarea id="ush-args-input" placeholder="每行一个参数,例如:\n--ontop\n--fullscreen" class="form-textarea" rows="3"></textarea>
                            <p class="hint">可用参数: \${title} 标题 | \${url} 原始链接 | \${url:base64} base64编码 | \${url:encode} url编码</p>
                        </div>

                        <div class="form-group">
                            <label>图标 (Base64 Data URL)</label>
                            <textarea id="player-icon-input" placeholder="..." class="form-textarea" rows="3"></textarea>
                            <p class="hint">支持 data:image/png、data:image/svg+xml 等格式</p>
                        </div>

                        <div class="form-group">
                            <label>描述 (可选)</label>
                            <input type="text" id="player-desc-input" placeholder="例如: 需要安装 PotPlayer" class="form-input">
                        </div>
                    </div>

                    <div class="modal-footer">
                        <button class="btn-cancel">取消</button>
                        <button class="btn-save">添加</button>
                    </div>
                </div>
            </div>
        `;

        // 添加样式
        const style = document.createElement('style');
        style.textContent = `
            #iwara-add-player-modal {
                position: fixed;
                top: 0;
                left: 0;
                right: 0;
                bottom: 0;
                z-index: 9999999 !important;
                font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
            }

            #iwara-add-player-modal .modal-overlay {
                position: absolute;
                top: 0;
                left: 0;
                right: 0;
                bottom: 0;
                background: rgba(20, 20, 30, 0.75);
                backdrop-filter: blur(12px);
                display: flex;
                align-items: center;
                justify-content: center;
                animation: fadeIn 0.2s ease;
            }

            #iwara-add-player-modal .modal-content {
                background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
                border-radius: 16px;
                width: 90%;
                max-width: 450px;
                box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
                animation: slideUp 0.3s ease;
                overflow: hidden;
            }

            #iwara-add-player-modal .modal-header {
                padding: 24px 28px;
                background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
                display: flex;
                justify-content: space-between;
                align-items: center;
            }

            #iwara-add-player-modal .modal-header h2 {
                margin: 0;
                color: white;
                font-size: 20px;
                font-weight: 600;
            }

            #iwara-add-player-modal .close-btn {
                background: rgba(255, 255, 255, 0.2);
                border: none;
                color: white;
                width: 32px;
                height: 32px;
                border-radius: 50%;
                cursor: pointer;
                font-size: 20px;
                display: flex;
                align-items: center;
                justify-content: center;
                transition: all 0.2s;
            }

            #iwara-add-player-modal .close-btn:hover {
                background: rgba(255, 255, 255, 0.3);
                transform: rotate(90deg);
            }

            #iwara-add-player-modal .modal-body {
                padding: 28px;
                max-height: 70vh;
                overflow-y: auto;
            }

            #iwara-add-player-modal .form-group {
                margin-bottom: 20px;
            }

            #iwara-add-player-modal .form-group label {
                display: block;
                color: #e0e0e0;
                font-size: 14px;
                font-weight: 600;
                margin-bottom: 8px;
            }

            #iwara-add-player-modal .form-input,
            #iwara-add-player-modal .form-textarea {
                width: 100%;
                padding: 10px 14px;
                background: rgba(255, 255, 255, 0.05);
                border: 2px solid rgba(255, 255, 255, 0.1);
                border-radius: 8px;
                color: #e0e0e0;
                font-size: 14px;
                transition: all 0.2s;
                box-sizing: border-box;
                font-family: inherit;
            }

            #iwara-add-player-modal .form-input:focus,
            #iwara-add-player-modal .form-textarea:focus {
                outline: none;
                border-color: #667eea;
                background: rgba(255, 255, 255, 0.08);
            }

            #iwara-add-player-modal .form-input::placeholder,
            #iwara-add-player-modal .form-textarea::placeholder {
                color: #666;
            }

            #iwara-add-player-modal .form-textarea {
                resize: vertical;
                min-height: 60px;
            }

            #iwara-add-player-modal select.form-input {
                cursor: pointer;
                background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23667eea' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
                background-repeat: no-repeat;
                background-position: right 12px center;
                padding-right: 36px;
                appearance: none;
                -webkit-appearance: none;
                -moz-appearance: none;
            }

            #iwara-add-player-modal select.form-input:hover {
                border-color: rgba(102, 126, 234, 0.5);
            }

            #iwara-add-player-modal select.form-input option {
                background: #1a1a2e;
                color: #e0e0e0;
                padding: 10px;
            }

            #iwara-add-player-modal select.form-input option:hover {
                background: #667eea;
            }

            #iwara-add-player-modal .hint {
                margin: 8px 0 0 0;
                color: #999;
                font-size: 12px;
            }

            #iwara-add-player-modal .modal-footer {
                padding: 20px 28px;
                background: rgba(0, 0, 0, 0.2);
                display: flex;
                justify-content: flex-end;
                gap: 12px;
            }

            #iwara-add-player-modal .modal-footer button {
                padding: 10px 24px;
                border: none;
                border-radius: 8px;
                font-size: 14px;
                font-weight: 600;
                cursor: pointer;
                transition: all 0.2s;
            }

            #iwara-add-player-modal .btn-cancel {
                background: rgba(255, 255, 255, 0.1);
                color: #e0e0e0;
            }

            #iwara-add-player-modal .btn-cancel:hover {
                background: rgba(255, 255, 255, 0.15);
            }

            #iwara-add-player-modal .btn-save {
                background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
                color: white;
            }

            #iwara-add-player-modal .btn-save:hover {
                transform: translateY(-2px);
                box-shadow: 0 4px 12px rgba(102, 126, 234, 0.4);
            }
        `;

        addModal.appendChild(style);
        document.body.appendChild(addModal);

        // 绑定事件
        const closeAddModal = () => addModal.remove();

        addModal.querySelector('.close-btn').addEventListener('click', closeAddModal);
        addModal.querySelector('.btn-cancel').addEventListener('click', closeAddModal);
        addModal.querySelector('.modal-overlay').addEventListener('click', (e) => {
            if (e.target.classList.contains('modal-overlay')) {
                closeAddModal();
            }
        });

        // 协议类型
        const protocolTypeSelect = addModal.querySelector('#protocol-type-select');
        const protocolInputGroup = addModal.querySelector('#protocol-input-group');
        const ushAppInputGroup = addModal.querySelector('#ush-app-input-group');
        const ushArgsInputGroup = addModal.querySelector('#ush-args-input-group');

        protocolTypeSelect.addEventListener('change', () => {
            if (protocolTypeSelect.value === 'protocol') {
                protocolInputGroup.style.display = 'block';
                ushAppInputGroup.style.display = 'none';
                ushArgsInputGroup.style.display = 'none';
            } else {
                protocolInputGroup.style.display = 'none';
                ushAppInputGroup.style.display = 'block';
                ushArgsInputGroup.style.display = 'block';
            }
        });

        // 保存播放器
        addModal.querySelector('.btn-save').addEventListener('click', () => {
            const name = addModal.querySelector('#player-name-input').value.trim();
            const icon = addModal.querySelector('#player-icon-input').value.trim();
            const description = addModal.querySelector('#player-desc-input').value.trim();
            const protocolType = protocolTypeSelect.value;

            if (!name) {
                showNotification('❌ 请输入播放器名称', 'error');
                return;
            }

            // 检查名称是否已存在
            const existingPlayer = customPlayers.find(p => p.name === name);
            if (existingPlayer) {
                showNotification('❌ 播放器名称已存在,请使用其他名称', 'error');
                return;
            }

            // 验证 icon 格式
            let validIcon = icon;
            if (icon && !icon.startsWith('data:image')) {
                showNotification('❌ 图标必须是 data:image 格式的 Base64 数据', 'error');
                return;
            }
            if (!icon) {
                // 默认图标
                validIcon = "";
            }

            const playerConfig = {
                name: name,
                icon: validIcon,
                description: description || '自定义播放器'
            };

            if (protocolType === 'protocol') {
                const protocol = addModal.querySelector('#protocol-input').value.trim();
                if (!protocol) {
                    showNotification('❌ 请输入协议链接参数', 'error');
                    return;
                }
                if (!protocol.includes('${url}')) {
                    showNotification('❌ 协议链接参数必须包含 ${url} 占位符', 'error');
                    return;
                }
                playerConfig.type = 'protocol';
                playerConfig.protocol = protocol;
            } else {
                const appName = addModal.querySelector('#ush-app-input').value.trim();
                if (!appName) {
                    showNotification('❌ 请输入应用名称', 'error');
                    return;
                }
                const args = addModal.querySelector('#ush-args-input').value.trim();
                playerConfig.type = 'ush';
                playerConfig.appName = appName;
                playerConfig.args = args ? args.split('\n').map(a => a.trim()).filter(a => a) : ['{url}'];
            }

            customPlayers.push(playerConfig);
            GM_setValue('customPlayers', customPlayers);

            closeAddModal();
            showNotification('✅ 播放器已添加', 'success');

            // 重新打开设置弹窗
            const settingsModal = document.getElementById('iwara-mpv-settings-modal');
            if (settingsModal) {
                settingsModal.remove();
            }
            setTimeout(() => createSettingsModal(), 500);
        });
    }

    // 显示通知(带高亮效果)
    function showNotification(message, type = 'info') {
        const styles = {
            error: {
                bg: 'linear-gradient(135deg, #ff6b6b 0%, #ee5a6f 100%)',
                glow: 'rgba(255, 107, 107, 0.5)',
                glowStrong: 'rgba(255, 107, 107, 0.8)'
            },
            success: {
                bg: 'linear-gradient(135deg, #51cf66 0%, #37b24d 100%)',
                glow: 'rgba(81, 207, 102, 0.5)',
                glowStrong: 'rgba(81, 207, 102, 0.8)'
            },
            info: {
                bg: 'linear-gradient(135deg, #667eea 0%, #764ba2 100%)',
                glow: 'rgba(102, 126, 234, 0.5)',
                glowStrong: 'rgba(102, 126, 234, 0.8)'
            }
        };

        const style = styles[type] || styles.info;
        const notification = document.createElement('div');
        notification.style.cssText = `
            position: fixed;
            top: 20px;
            right: 20px;
            z-index: 9999999;
            padding: 16px 24px;
            background: ${style.bg};
            color: white;
            border-radius: 12px;
            box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3), 0 0 20px ${style.glow};
            font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
            font-size: 14px;
            font-weight: 600;
            border: 2px solid rgba(255, 255, 255, 0.3);
            animation: slideInRight 0.3s ease, pulse 1.5s ease-in-out infinite;
            white-space: pre-line;
        `;

        const styleSheet = document.createElement('style');
        styleSheet.textContent = `
            @keyframes slideInRight {
                from { transform: translateX(100%); opacity: 0; }
                to { transform: translateX(0); opacity: 1; }
            }
            @keyframes pulse {
                0%, 100% { box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3), 0 0 20px ${style.glow}; }
                50% { box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3), 0 0 30px ${style.glowStrong}, 0 0 10px rgba(255, 255, 255, 0.5); }
            }
        `;
        notification.appendChild(styleSheet);

        notification.textContent = message;
        document.body.appendChild(notification);

        setTimeout(() => {
            notification.style.animation = 'slideInRight 0.3s ease reverse';
            setTimeout(() => notification.remove(), 300);
        }, 3000);
    }

    // 通知容器和队列管理(新版本 - 支持堆叠)
    let notificationContainer = null;
    const activeNotifications = new Set();

    // 显示通知(优化版 - 带代理信息和堆叠管理)
    function showNotificationV2(message, type = 'info') {
        // 添加代理主机名信息
        const enabledProxies = proxyList.filter(p => p.enabled);
        if (enabledProxies.length > 0) {
            const currentProxy = enabledProxies[Math.floor(Math.random() * enabledProxies.length)];
            try {
                const url = new URL(currentProxy.url);
                const hostname = url.hostname;
                message = `${message}\n🔗 当前代理: ${hostname}`;
            } catch (e) {
                // URL 解析失败,不添加主机名
            }
        }

        const styles = {
            error: {
                bg: 'linear-gradient(135deg, #ff6b6b 0%, #ee5a6f 100%)',
                glow: 'rgba(255, 107, 107, 0.5)',
                glowStrong: 'rgba(255, 107, 107, 0.8)'
            },
            success: {
                bg: 'linear-gradient(135deg, #51cf66 0%, #37b24d 100%)',
                glow: 'rgba(81, 207, 102, 0.5)',
                glowStrong: 'rgba(81, 207, 102, 0.8)'
            },
            info: {
                bg: 'linear-gradient(135deg, #667eea 0%, #764ba2 100%)',
                glow: 'rgba(102, 126, 234, 0.5)',
                glowStrong: 'rgba(102, 126, 234, 0.8)'
            }
        };

        // 确保容器存在
        if (!notificationContainer) {
            notificationContainer = document.createElement('div');
            notificationContainer.id = 'iwara-notification-container';
            notificationContainer.style.cssText = `
                position: fixed;
                top: 20px;
                right: 20px;
                z-index: 9999999;
                display: flex;
                flex-direction: column;
                gap: 12px;
                pointer-events: none;
            `;
            document.body.appendChild(notificationContainer);

            // 添加全局样式
            if (!document.getElementById('iwara-notification-styles')) {
                const globalStyles = document.createElement('style');
                globalStyles.id = 'iwara-notification-styles';
                globalStyles.textContent = `
                    @keyframes slideInRight {
                        from { transform: translateX(100%); opacity: 0; }
                        to { transform: translateX(0); opacity: 1; }
                    }
                    @keyframes slideOutRight {
                        from { transform: translateX(0); opacity: 1; }
                        to { transform: translateX(100%); opacity: 0; }
                    }
                `;
                document.head.appendChild(globalStyles);
            }
        }

        const style = styles[type] || styles.info;
        const notification = document.createElement('div');
        notification.className = 'iwara-notification-item';
        notification.style.cssText = `
            padding: 16px 24px;
            background: ${style.bg};
            color: white;
            border-radius: 12px;
            box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3), 0 0 20px ${style.glow};
            font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
            font-size: 14px;
            font-weight: 600;
            border: 2px solid rgba(255, 255, 255, 0.3);
            animation: slideInRight 0.3s ease;
            white-space: pre-line;
            pointer-events: auto;
            transition: transform 0.3s ease, opacity 0.3s ease;
        `;

        // 添加脉冲动画样式
        const pulseId = `pulse-${Date.now()}`;
        const styleSheet = document.createElement('style');
        styleSheet.textContent = `
            @keyframes ${pulseId} {
                0%, 100% { box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3), 0 0 20px ${style.glow}; }
                50% { box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3), 0 0 30px ${style.glowStrong}, 0 0 10px rgba(255, 255, 255, 0.5); }
            }
        `;
        notification.appendChild(styleSheet);
        notification.style.animation += `, ${pulseId} 1.5s ease-in-out infinite`;

        notification.textContent = message;
        notificationContainer.appendChild(notification);
        activeNotifications.add(notification);

        // 自动移除
        setTimeout(() => {
            notification.style.animation = 'slideOutRight 0.3s ease';
            setTimeout(() => {
                activeNotifications.delete(notification);
                notification.remove();

                // 如果没有通知了,移除容器
                if (activeNotifications.size === 0 && notificationContainer) {
                    notificationContainer.remove();
                    notificationContainer = null;
                }
            }, 300);
        }, 3000);
    }

    // 使用新版本通知函数
    showNotification = showNotificationV2;

    // 统一设置菜单
    GM_registerMenuCommand('⚙️ 播放器设置', createSettingsModal);

    // 创建右下角设置按钮
    function createSettingsButton() {
        // 防止重复创建
        if (document.getElementById('iwara-mpv-settings-fab')) {
            return;
        }

        const settingsButton = document.createElement('button');
        settingsButton.id = 'iwara-mpv-settings-fab';
        settingsButton.className = 'iwara-mpv-fab';
        settingsButton.innerHTML = `
            <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24">
                <path d="M12 15.5A3.5 3.5 0 0 1 8.5 12 3.5 3.5 0 0 1 12 8.5a3.5 3.5 0 0 1 3.5 3.5 3.5 3.5 0 0 1-3.5 3.5m7.43-2.53c.04-.32.07-.64.07-.97 0-.33-.03-.66-.07-1l2.11-1.63c.19-.15.24-.42.12-.64l-2-3.46c-.12-.22-.39-.31-.61-.22l-2.49 1c-.52-.39-1.06-.73-1.69-.98l-.37-2.65A.506.506 0 0 0 14 2h-4c-.25 0-.46.18-.5.42l-.37 2.65c-.63.25-1.17.59-1.69.98l-2.49-1c-.22-.09-.49 0-.61.22l-2 3.46c-.13.22-.07.49.12.64L4.57 11c-.04.34-.07.67-.07 1 0 .33.03.65.07.97l-2.11 1.66c-.19.15-.25.42-.12.64l2 3.46c.12.22.39.3.61.22l2.49-1.01c.52.4 1.06.74 1.69.99l.37 2.65c.04.24.25.42.5.42h4c.25 0 .46-.18.5-.42l.37-2.65c.63-.26 1.17-.59 1.69-.99l2.49 1.01c.22.08.49 0 .61-.22l2-3.46c.12-.22.07-.49-.12-.64l-2.11-1.66z"/>
            </svg>
        `;
        settingsButton.title = '播放器设置';

        // 点击打开设置
        settingsButton.addEventListener('click', createSettingsModal);

        document.body.appendChild(settingsButton);
    }

    // 压缩参数
    function compress(str) {
        return btoa(String.fromCharCode(...pako.gzip(str)));
    }

    // ========== 视频链接获取逻辑 (来自 getvideo.js) ==========

    // SHA-1 哈希 (使用Web Crypto API)
    async function hashStringSHA1(input) {
        const encoder = new TextEncoder();
        const data = encoder.encode(input);
        const hashBuffer = await crypto.subtle.digest('SHA-1', data);
        const hashArray = Array.from(new Uint8Array(hashBuffer));
        return hashArray.map(b => b.toString(16).padStart(2, '0')).join('');
    }

    // 通过视频ID获取视频链接
    async function getVideoLinkById(videoId, quality = null) {
        try {
            // 获取代理前缀(在非 iwara.tv 域名下使用)
            const proxyPrefix = getCurrentProxyPrefix();

            // 获取本地存储的访问令牌
            const token = localStorage.getItem('token');
            const headers = {};
            if (token) {
                headers['Authorization'] = `Bearer ${token}`;
            }

            // 步骤1: 获取视频信息(添加代理前缀)
            const apiUrl = `${proxyPrefix}https://api.iwara.tv/video/${videoId}`;
            const infoResponse = await fetch(apiUrl, {
                headers: headers
            });
            if (!infoResponse.ok) throw new Error('获取视频信息失败');
            const info = await infoResponse.json();

            if (!info.file) throw new Error('视频文件不存在');

            const fileUrl = new URL(info.fileUrl);
            const fileId = info.file.id;
            const expires = fileUrl.searchParams.get('expires');
            const hash = fileUrl.searchParams.get('hash');

            // 步骤2: 生成验证令牌
            const xVersion = await hashStringSHA1(`${fileId}_${expires}_5nFp9kmbNnHdAFhaqMvt`);

            // 步骤3: 获取视频资源(添加代理前缀)
            const resourceUrl = `${proxyPrefix}https://files.iwara.tv${fileUrl.pathname}?expires=${expires}&hash=${hash}`;
            const resourceHeaders = { 'X-Version': xVersion };
            if (token) {
                resourceHeaders['Authorization'] = `Bearer ${token}`;
            }

            const resourceResponse = await fetch(resourceUrl, {
                headers: resourceHeaders
            });

            if (!resourceResponse.ok) throw new Error('获取视频资源失败');
            const resources = await resourceResponse.json();

            // 步骤4: 提取链接 - 优先使用指定画质,否则使用设置的画质
            const targetQuality = quality || videoQuality;

            // 调试:输出所有可用画质
            console.log('[Iwara Player] 可用画质:', resources.map(v => v.name));
            console.log('[Iwara Player] 目标画质:', targetQuality);

            // 查找匹配的画质
            let video = resources.find(v => v.name === targetQuality);

            // 如果没找到精确匹配,尝试模糊匹配(例如 '540' 匹配 '540p')
            if (!video && targetQuality) {
                video = resources.find(v => v.name.includes(targetQuality) || targetQuality.includes(v.name));
            }

            // 如果还是没找到,使用 Source 或第一个
            if (!video) {
                video = resources.find(v => v.name === 'Source') || resources[0];
            }

            const finalUrl = 'https:' + video.src.view;

            console.log('[Iwara Player] 最终使用画质:', video.name);

            return { url: finalUrl, title: info.title, quality: video.name };
        } catch (error) {
            console.error('[Iwara Player] 获取视频链接失败:', error);
            throw error;
        }
    }

    // 动态获取视频URL(支持页面变动后重新获取)
    function getVideoUrl() {
        const videoElement = document.querySelector('#vjs_video_3_html5_api, [id^="vjs_video_"][id$="_html5_api"], video.vjs-tech, video[src]');
        if (videoElement && videoElement.src) {
            return videoElement.src;
        }

        console.warn('%c[Iwara Player] 未找到视频源', 'color: #ff6b6b; font-weight: bold;');
        return null;
    }

    // 生成播放器协议链接
    function getPlayerProtocolUrl(playerName, videoUrl, videoTitle) {
        // 查找播放器
        const player = customPlayers.find(p => p.name === playerName);
        if (!player) {
            // 默认使用 MPV
            const defaultArgs = [`"${videoUrl}"`, `--force-media-title="${videoTitle}"`, '--ontop'];
            return `ush://MPV?${compress(defaultArgs.join(' '))}`;
        }

        // 替换参数的通用函数
        const replaceParams = (text) => {
            return text
                .replace(/\$\{title\}/g, videoTitle)
                .replace(/\$\{url\}/g, videoUrl)
                .replace(/\$\{url:base64\}/g, btoa(videoUrl))
                .replace(/\$\{url:encode\}/g, encodeURIComponent(videoUrl));
        };

        if (player.type === 'protocol') {
            // 标准协议: 支持参数模板,使用 ${xxx} 占位符
            const protocolTemplate = player.protocol || '';
            // 替换所有支持的占位符
            return replaceParams(protocolTemplate);
        } else if (player.type === 'ush') {
            // USH协议: ush://AppName?args
            let args = player.args || [`"${videoUrl}"`];
            // 替换占位符
            args = args.map(arg => replaceParams(arg));
            return `ush://${player.appName}?${compress(args.join(' '))}`;
        }

        // 兜底
        const defaultArgs = [`"${videoUrl}"`, `--force-media-title="${videoTitle}"`, '--ontop'];
        return `ush://MPV?${compress(defaultArgs.join(' '))}`;
    }

    // 获取视频标题的公共函数
    function getVideoTitle() {
        const titleElement = document.querySelector('h1.text-xl, h1[class*="title"], .page-video__details h1, h1');
        return titleElement ? titleElement.innerText.trim() : document.title;
    }

    // 创建SVG图标
    const createSVGIcon = (iconName) => {
        const pathData = SVG_ICONS[iconName];
        return `<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2">${pathData}</svg>`;
    };

    // 创建按钮的通用辅助函数
    const createButton = (className, title, content, onClick) => {
        const button = document.createElement('button');
        button.className = className;
        button.title = title;
        button.innerHTML = typeof content === 'string' && SVG_ICONS[content]
            ? createSVGIcon(content)
            : content;
        if (onClick) button.addEventListener('click', onClick);
        return button;
    };

    // 从当前页面 URL 提取视频 ID
    function getVideoIdFromUrl() {
        const match = window.location.pathname.match(/\/video\/([^\/]+)/);
        return match ? match[1] : null;
    }

    // 使用外部播放器播放 (视频详情页)
    function playWithExternalPlayer() {
        const videoUrl = getVideoUrl();

        if (!videoUrl) {
            showNotification('❌ 未找到视频源\n请确保视频已加载', 'error');
            return;
        }

        // 应用代理到视频URL
        const finalUrl = getProxiedUrl(videoUrl);

        // 获取视频标题
        const videoTitle = getVideoTitle();

        // 使用外部播放器播放
        const protocolUrl = getPlayerProtocolUrl(externalPlayer, finalUrl, videoTitle);

        try {
            // 合并输出信息
            console.log(`%c[Iwara Player] 播放信息`, 'color: #667eea; font-weight: bold;',
                '\n标题:', videoTitle,
                '\n播放器:', externalPlayer,
                '\n画质: 当前网页画质',
                '\nURL:', finalUrl);

            showNotification(`🎬 调用 ${externalPlayer} 播放器\n📸 画质: 当前网页画质`, 'info');
            window.open(protocolUrl, '_self');
        } catch (error) {
            console.error('[Iwara Player] 调用失败:', error);
            showNotification(`❌ 启动 ${externalPlayer} 失败\n请确保已安装并正确配置协议`, 'error');
        }
    }

    // 播放视频 (通过视频ID)
    async function playVideoById(videoId, videoTitle, quality = null) {
        try {
            showNotification('🔄 正在获取视频链接...', 'info');

            const { url, title, quality: actualQuality } = await getVideoLinkById(videoId, quality);
            const finalUrl = getProxiedUrl(url);
            const finalTitle = videoTitle || title;

            // 合并输出信息
            console.log(`%c[Iwara Player] 播放信息`, 'color: #667eea; font-weight: bold;',
                '\n视频ID:', videoId,
                '\n标题:', finalTitle,
                '\n播放器:', externalPlayer,
                '\n画质:', actualQuality,
                '\nURL:', finalUrl);

            // 使用外部播放器播放
            showNotification(`🎬 调用 ${externalPlayer} 播放器\n📸 画质: ${actualQuality}`, 'info');
            const protocolUrl = getPlayerProtocolUrl(externalPlayer, finalUrl, finalTitle);
            window.open(protocolUrl, '_self');
        } catch (error) {
            console.error('[Iwara Player] 播放失败:', error);
            showNotification(`❌ 获取视频链接失败\n${error.message}`, 'error');
        }
    }

    // 创建固定按钮组 (视频详情页)
    function createButtonGroup() {
        // 防止重复创建
        if (document.getElementById('iwara-mpv-button-group-detail')) {
            return;
        }

        // 获取当前视频URL
        const videoUrl = getVideoUrl();
        if (!videoUrl) {
            console.warn('[Iwara Player] 视频URL未找到,无法创建按钮');
            return;
        }

        // 获取视频标题
        const videoTitle = getVideoTitle();

        // 创建按钮组容器
        const buttonGroup = document.createElement('div');
        buttonGroup.id = 'iwara-mpv-button-group-detail';

        // 复制按钮
        if (buttonSettings.detailPage.copy) {
            const copyButton = createButton('copy-btn', '复制视频链接', 'COPY', async () => {
                try {
                    // 从 URL 中提取视频 ID
                    const videoId = getVideoIdFromUrl();
                    if (!videoId) {
                        showNotification('❌ 无法获取视频 ID', 'error');
                        return;
                    }

                    showNotification('🔄 正在获取视频链接...', 'info');
                    const { url } = await getVideoLinkById(videoId);
                    const finalUrl = getProxiedUrl(url);
                    await navigator.clipboard.writeText(finalUrl);
                    showNotification('✅ 链接已复制到剪贴板', 'success');
                } catch (error) {
                    console.error('[Iwara Player] 复制失败:', error);
                    showNotification('❌ 复制失败: ' + error.message, 'error');
                }
            });
            buttonGroup.appendChild(copyButton);
        }

        // 新标签页播放按钮
        if (buttonSettings.detailPage.newTab) {
            const downloadButton = createButton('new-tab-btn', '在新标签页播放', 'NEW_TAB', async () => {
                try {
                    // 从 URL 中提取视频 ID
                    const videoId = getVideoIdFromUrl();
                    if (!videoId) {
                        showNotification('❌ 无法获取视频 ID', 'error');
                        return;
                    }

                    showNotification('🔄 正在获取视频链接...', 'info');
                    const { url } = await getVideoLinkById(videoId);
                    const finalUrl = getProxiedUrl(url);
                    window.open(finalUrl, '_blank');
                    showNotification('✅ 已在新标签页打开', 'success');
                } catch (error) {
                    console.error('[Iwara Player] 打开失败:', error);
                    showNotification('❌ 打开失败: ' + error.message, 'error');
                }
            });
            buttonGroup.appendChild(downloadButton);
        }

        // 画质按钮 - 固定为 540
        if (buttonSettings.detailPage.quality) {
            const qualityButton = createButton('quality-btn', '540 画质', '540', async () => {
                // 从 URL 中提取视频 ID
                const videoId = getVideoIdFromUrl();
                if (!videoId) {
                    showNotification('❌ 无法获取视频 ID', 'error');
                    return;
                }
                // 使用 540 画质播放
                playVideoById(videoId, videoTitle, '540');
            });
            buttonGroup.appendChild(qualityButton);
        }

        // 播放按钮 - 固定为 Source 画质
        if (buttonSettings.detailPage.play) {
            const playButton = createButton('play-btn', 'Source 画质', 'PLAY', playWithExternalPlayer);
            buttonGroup.appendChild(playButton);
        }

        // 只有当至少有一个按钮启用时才添加到页面
        if (buttonGroup.children.length > 0) {
            document.body.appendChild(buttonGroup);
        }
    }

    // 创建悬停按钮 (视频列表页)
    function createHoverButton(videoTeaser, videoId, videoName) {
        // 防止重复创建
        if (videoTeaser.querySelector('.iwara-mpv-button-group')) {
            return;
        }

        // 创建按钮组容器
        const buttonGroup = document.createElement('div');
        buttonGroup.className = 'iwara-mpv-button-group';

        // 复制按钮
        if (buttonSettings.listPage.copy) {
            const copyButton = createButton('iwara-mpv-action-btn copy', '复制视频链接', 'COPY', async (e) => {
                e.preventDefault();
                e.stopPropagation();
                try {
                    showNotification('🔄 正在获取视频链接...', 'info');
                    const { url } = await getVideoLinkById(videoId);
                    const finalUrl = getProxiedUrl(url);
                    await navigator.clipboard.writeText(finalUrl);
                    showNotification('✅ 链接已复制到剪贴板', 'success');
                } catch (error) {
                    console.error('[Iwara Player] 复制失败:', error);
                    showNotification('❌ 复制失败: ' + error.message, 'error');
                }
            });
            buttonGroup.appendChild(copyButton);
        }

        // 新标签页播放按钮
        if (buttonSettings.listPage.newTab) {
            const newTabButton = createButton('iwara-mpv-action-btn new-tab', '在新标签页播放', 'NEW_TAB', async (e) => {
                e.preventDefault();
                e.stopPropagation();
                try {
                    showNotification('🔄 正在获取视频链接...', 'info');
                    const { url } = await getVideoLinkById(videoId);
                    const finalUrl = getProxiedUrl(url);
                    window.open(finalUrl, '_blank');
                    showNotification('✅ 已在新标签页打开', 'success');
                } catch (error) {
                    console.error('[Iwara Player] 打开失败:', error);
                    showNotification('❌ 打开失败: ' + error.message, 'error');
                }
            });
            buttonGroup.appendChild(newTabButton);
        }

        // 画质播放按钮 - 固定为 540
        if (buttonSettings.listPage.quality) {
            const qualityButton = createButton('iwara-mpv-action-btn quality', '540 画质', '540', (e) => {
                e.preventDefault();
                e.stopPropagation();
                playVideoById(videoId, videoName, '540');
            });
            buttonGroup.appendChild(qualityButton);
        }

        // 播放按钮 - 固定为 Source 画质
        if (buttonSettings.listPage.play) {
            const playButton = createButton('iwara-mpv-hover-button', 'Source 画质', 'PLAY', (e) => {
                e.preventDefault();
                e.stopPropagation();
                playVideoById(videoId, videoName);
            });
            buttonGroup.appendChild(playButton);
        }

        // 只有当至少有一个按钮启用时才添加到页面
        if (buttonGroup.children.length > 0) {
            // 如果按钮少于4个,使用单列布局
            if (buttonGroup.children.length < 4) {
                buttonGroup.classList.add('single-column');
            }
            videoTeaser.appendChild(buttonGroup);
            return buttonGroup;
        }
        return null;
    }

    // 处理视频列表项悬停
    function handleVideoTeaserHover() {
        const videoTeasers = document.querySelectorAll('.videoTeaser');

        videoTeasers.forEach((teaser, index) => {
            // 如果已经处理过,跳过
            if (teaser.dataset.mpvProcessed) {
                return;
            }
            teaser.dataset.mpvProcessed = 'true';

            // 从 a.videoTeaser__thumbnail 的 href 获取视频ID
            const thumbnailLink = teaser.querySelector('a.videoTeaser__thumbnail');
            if (!thumbnailLink) {
                return;
            }

            const href = thumbnailLink.getAttribute('href');
            if (!href) {
                return;
            }

            // 从 href 中提取视频ID: /video/{videoId}/{title}
            const videoIdMatch = href.match(/\/video\/([^\/]+)/);
            if (!videoIdMatch) {
                return;
            }

            const videoId = videoIdMatch[1];

            // 尝试从标题元素获取视频名称
            const titleElement = teaser.querySelector('.videoTeaser__title, a[title]');
            const videoName = titleElement ? (titleElement.getAttribute('title') || titleElement.textContent.trim()) : 'Video';

            if (!videoId) {
                return;
            }

            // 创建按钮组
            const buttonGroup = createHoverButton(teaser, videoId, videoName);

            // 鼠标进入显示按钮组
            teaser.addEventListener('mouseenter', () => {
                if (!buttonGroup) return;
                buttonGroup.style.display = 'grid';
                setTimeout(() => {
                    buttonGroup.classList.add('visible');
                    // 为每个按钮添加动画效果
                    buttonGroup.querySelectorAll('button').forEach((btn, index) => {
                        setTimeout(() => {
                            btn.style.transform = 'scale(1)';
                            btn.style.opacity = '1';
                        }, index * 50);
                    });
                }, 10);
            });

            // 鼠标离开隐藏按钮组
            teaser.addEventListener('mouseleave', () => {
                if (!buttonGroup) return;
                buttonGroup.classList.remove('visible');
                buttonGroup.querySelectorAll('button').forEach(btn => {
                    btn.style.opacity = '0';
                    btn.style.transform = btn.classList.contains('iwara-mpv-hover-button') ? 'scale(0.9)' : 'scale(0.8)';
                });
                setTimeout(() => buttonGroup.style.display = 'none', 200);
            });
        });
    }

    // 移除按钮组(页面变化时)
    function removeButtonGroup() {
        const buttonGroup = document.getElementById('iwara-mpv-button-group-detail');
        if (buttonGroup) {
            buttonGroup.remove();
        }
    }

    // 刷新所有按钮(不重新加载页面)
    function refreshAllButtons() {
        // 1. 刷新视频详情页按钮
        removeButtonGroup();
        if (isVideoPage()) {
            createButtonGroup();
        }

        // 2. 刷新视频列表页按钮
        if (isVideoListPage()) {
            // 移除所有已存在的按钮组
            document.querySelectorAll('.iwara-mpv-button-group').forEach(group => {
                group.remove();
            });

            // 清除处理标记
            document.querySelectorAll('.videoTeaser').forEach(teaser => {
                teaser.dataset.mpvProcessed = '';
            });

            // 重新创建按钮组
            handleVideoTeaserHover();
        }
    }

    // 页面类型检查
    const isVideoPage = () => /\/video\/[a-zA-Z0-9]+/.test(window.location.pathname);
    const isVideoListPage = () => /\/(videos|subscriptions|playlist|search|profile)/.test(window.location.pathname) || window.location.pathname === '/';

    // 初始化
    function init() {
        console.log(`%c[Iwara Player] 脚本初始化完成`, 'color: #51cf66; font-weight: bold; font-size: 14px;',
            '\n当前播放器:', externalPlayer,
            '\n默认画质: Source',
            '\n标清画质: 540');

        // 创建右下角设置按钮
        createSettingsButton();

        // 监听URL变化(SPA路由)
        let lastUrl = location.href;
        new MutationObserver(() => {
            const currentUrl = location.href;
            if (currentUrl !== lastUrl) {
                lastUrl = currentUrl;
                removeButtonGroup();

                // 视频详情页
                if (isVideoPage()) {
                    setTimeout(() => {
                        if (getVideoUrl()) {
                            createButtonGroup();
                        }
                    }, 1000);
                }

                // 视频列表页
                if (isVideoListPage()) {
                    setTimeout(handleVideoTeaserHover, 500);
                }
            }
        }).observe(document, { subtree: true, childList: true });

        // 监听视频元素出现(详情页)
        const videoObserver = new MutationObserver(() => {
            if (isVideoPage() && getVideoUrl() && !document.getElementById('iwara-mpv-button-group-detail')) {
                createButtonGroup();
            }
        });

        videoObserver.observe(document.body, {
            childList: true,
            subtree: true
        });

        // 监听列表页视频项出现
        const listObserver = new MutationObserver(() => {
            if (isVideoListPage()) {
                handleVideoTeaserHover();
            }
        });

        listObserver.observe(document.body, {
            childList: true,
            subtree: true
        });

        // 初次检查
        if (isVideoPage() && getVideoUrl()) {
            createButtonGroup();
        }

        if (isVideoListPage()) {
            setTimeout(() => {
                handleVideoTeaserHover();
            }, 1000);
        }
    }

    // 启动
    if (document.readyState === 'loading') {
        document.addEventListener('DOMContentLoaded', init);
    } else {
        init();
    }

})();