/*!
 * Repoevo Styles v1.4.1
 * (c) 2026 Repoevo — https://repoevo.com/
 * Licensed under GPL-2.0-or-later
 */
.pm-hero { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; background: #fff; border: 1px solid #f0f0f0; border-radius: 12px; padding: 18px 24px; margin-bottom: 16px; } .pm-hero-left { display: flex; align-items: center; gap: 16px; min-width: 0; } .pm-hero-icon { width: 56px; height: 56px; border-radius: 10px; object-fit: cover; flex-shrink: 0; border: 1px solid #f0f0f0; } .pm-hero-icon-placeholder { width: 56px; height: 56px; border-radius: 10px; background: #f9fafb; border: 1px solid #f0f0f0; display: flex; align-items: center; justify-content: center; flex-shrink: 0; color: #9ca3af; } .pm-hero-info { min-width: 0; } .pm-hero-title { margin: 0 0 6px; padding: 0; font-size: 20px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 600px; } .pm-hero-meta { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; font-size: 12px; color: #374151; } .pm-hero-meta-label { color: #9ca3af; margin-right: 2px; } .pm-hero-meta-sep { color: #d1d5db; } .pm-hero-meta-link { color: #2563eb; text-decoration: none; } .pm-hero-meta-link:hover { text-decoration: underline; } .pm-hero-right { display: flex; align-items: center; gap: 6px; flex-shrink: 0; color: #6b7280; font-size: 12px; font-weight: 500; } .pm-hero-right svg { color: #9ca3af; } .pm-hero-date { color: #374151; } .pm-hero-divider { margin: 0 0 20px; border: none; border-top: 1px solid #f3f3f3; } .pm-live-dot { width: 8px; height: 8px; border-radius: 50%; background: #16a34a; position: relative; flex-shrink: 0; } .pm-live-dot.pulse::after { content: ""; position: absolute; inset: 0; border-radius: 50%; background: #16a34a; animation: pmPulse 1.8s infinite; } @keyframes pmPulse { 0% { transform: scale(1); opacity: 0.8; } 70% { transform: scale(2.2); opacity: 0; } 100% { opacity: 0; } } .pm-filter-form { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 10px; } .pm-filter-left { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; } .pm-compare-select-wrap { display: flex; align-items: center; gap: 8px; } .pm-compare-select-wrap form { display: flex; align-items: center; gap: 6px; margin: 0; } .pm-compare-label { font-size: 13px; color: #64748b; white-space: nowrap; } .pm-compare-select { min-width: 140px; max-width: 200px; } .pm-stats-grid { display: grid; gap: 20px; margin: 30px 0; grid-template-columns: repeat(4, 1fr); } @media (max-width: 1200px) { .pm-stats-grid { grid-template-columns: repeat(2, 1fr); } } @media (max-width: 600px) { .pm-stats-grid { grid-template-columns: 1fr; } } .pm-stat-box { background: #fff; padding: 25px; border-radius: 12px; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05); text-align: center; display: flex; flex-direction: column; gap: 10px; } .pm-stat-box h3 { margin: 0; font-size: 14px; font-weight: 500; color: #666; } .pm-stat-box strong { font-size: 28px; display: block; } .pm-conv-sehr.gut, .pm-conv-value.pm-conv-sehr\.gut { color: #16a34a; } .pm-conv-gut, .pm-conv-value.pm-conv-gut { color: #22c55e; } .pm-conv-ok, .pm-conv-value.pm-conv-ok { color: #f59e0b; } .pm-conv-schwach, .pm-conv-value.pm-conv-schwach { color: #dc2626; } .pm-conv-label.pm-conv-sehr\.gut { color: #16a34a; } .pm-conv-label.pm-conv-gut { color: #22c55e; } .pm-conv-label.pm-conv-ok { color: #f59e0b; } .pm-conv-label.pm-conv-schwach { color: #dc2626; } .pm-chart-grid { display: grid; gap: 30px; grid-template-columns: 1fr; } .pm-chart-box { position: relative; width: 100%; max-height: 500px; } .pm-chart-inner { display: flex; gap: 20px; } .pm-chart-canvas-wrap { flex: 1; max-height: 500px; } .pm-chart-grid .pm-chart-box canvas { width: 100% !important; height: 100% !important; } .pm-chart-legend { width: 200px; } .pm-chart-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; } .pm-add-keyword-form { display: flex; gap: 6px; align-items: center; } .pm-add-keyword-form input { width: 180px; } @media (max-width: 1200px) { .pm-chart-grid { grid-template-columns: 1fr; } } .pm-compare-wrap { margin-top: 40px; } .pm-plugin-name { max-width: 320px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .pm-meta { font-size: 12px; color: #6b7280; } .pm-self-row { background: #ecfdf5; } .pm-self-badge { margin-left: 6px; color: #16a34a; font-size: 12px; font-weight: 400; } .pm-status-ok { color: #16a34a; } .pm-status-muted { color: #6b7280; } .pm-actions { display: flex; gap: 6px; align-items: center; justify-content: flex-end; } .pm-btn-icon { display: inline-flex; align-items: center; justify-content: center; width: 30px; height: 30px; border-radius: 6px; border: 1px solid #d1d5db; background: #fff; cursor: pointer; text-decoration: none; color: #374151; transition: background 0.15s, border-color 0.15s; } .pm-btn-icon:hover { background: #f3f4f6; border-color: #9ca3af; color: #111827; } .pm-btn-icon svg { width: 15px; height: 15px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; } .keywordflex { position: relative; display: grid; gap: 20px; margin: 0; padding: 20px; grid-template-columns: repeat(2, 1fr); } .keyword_form { position: relative; padding: 20px; } @media (max-width: 768px) { .pm-hero { flex-direction: column; align-items: flex-start; } .pm-hero-title { font-size: 16px; max-width: 100%; white-space: normal; } .pm-hero-right { align-self: flex-start; } .pm-chart-inner { flex-direction: column; } .pm-chart-legend { width: 100%; margin-top: 12px; } .keywordflex { grid-template-columns: 1fr; } .pm-chart-header { flex-direction: column; align-items: flex-start; gap: 10px; } .pm-add-keyword-form { width: 100%; } .pm-add-keyword-form input { flex: 1; width: auto; } } .pm-section-wrap { margin-top: 30px; } .pm-section-toggle { display: flex; align-items: center; gap: 10px; width: 100%; background: #fff; border: 1px solid #e5e7eb; border-radius: 10px; padding: 14px 20px; cursor: pointer; font-size: 15px; font-weight: 600; color: #111827; text-align: left; transition: background 0.15s; } .pm-section-toggle:hover { background: #f9fafb; } .pm-section-toggle span:first-child { flex: 1; } .pm-section-badge { background: #2563eb; color: #fff; font-size: 11px; font-weight: 600; padding: 2px 8px; border-radius: 999px; } .pm-pro-badge { background: #f59e0b; color: #fff; font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 999px; } .pm-toggle-icon { width: 18px; height: 18px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; transition: transform 0.2s; flex-shrink: 0; } .pm-section-body { margin-top: 12px; } .pm-section-desc { color: #6b7280; font-size: 13px; margin-bottom: 12px; } .pm-table td:last-child { text-align: right; white-space: nowrap; } .pm-table th:last-child { text-align: right; } .pm-rank-badge { display: inline-block; background: #f3f4f6; color: #374151; font-size: 12px; font-weight: 600; padding: 2px 8px; border-radius: 6px; } .pm-rank-locked { display: inline-block; background: #fef3c7; color: #92400e; font-size: 12px; font-weight: 600; padding: 2px 8px; border-radius: 6px; } .pm-b-match-badge { display: inline-block; background: #f59e0b1a; color: #92400e; border: 1px solid #f59e0b66; border-radius: 4px; font-size: 11px; font-weight: 600; padding: 1px 6px; margin-left: 6px; vertical-align: middle; max-width: 120px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .pm-dashboard h1 { margin-bottom: 25px; } .pm-headline { display: flex; align-items: center; gap: 10px; } .pm-plan-badge { display: inline-block; font-size: 12px; padding: 4px 10px; border-radius: 999px; color: #fff; text-transform: uppercase; font-weight: 600; vertical-align: middle; } .pm-plan-badge.pm-plan-free { background: #6b7280; } .pm-plan-badge.pm-plan-pro { background: #2563eb; } .pm-plan-badge.pm-plan-business { background: #16a34a; } .pm-card { background: #fff; padding: 25px; border-radius: 14px; box-shadow: 0 6px 20px rgba(0, 0, 0, 0.04); margin-bottom: 30px; } .pm-add-form { display: flex; gap: 15px; flex-wrap: wrap; } .pm-add-form input { flex: 1; min-width: 250px; padding: 8px 12px; } .pm-candidates-wrapper { position: relative; margin-top: 20px; width: 100%; } .pm-table { width: 100%; border-collapse: collapse; } .pm-table th { text-align: left; padding: 12px; border-bottom: 1px solid #eee; } .pm-table td { padding: 12px; vertical-align: middle; } .pm-table tr { border-bottom: 1px solid #f3f3f3; } .pm-plugin-cell { display: flex; align-items: center; gap: 10px; min-width: 0; } .pm-plugin-icon { width: 36px; height: 36px; border-radius: 6px; object-fit: cover; flex-shrink: 0; } .pm-plugin-icon-placeholder { width: 36px; height: 36px; border-radius: 6px; background: #e5e7eb; flex-shrink: 0; } .pm-plugin-info { min-width: 0; } .pm-plugin-name { font-weight: 600; font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 200px; display: block; } .pm-plugin-slug { font-size: 11px; color: #6b7280; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 200px; display: block; } .pm-status { display: inline-block; font-size: 13px; } .pm-status-ok { color: #16a34a; } .pm-status-update { color: #f59e0b; } .pm-status-pending { color: #6b7280; } .pm-status-blocked { color: #dc2626; } .pm-actions { display: flex; gap: 6px; align-items: center; } .pm-remove-form { margin: 0; } .pm-btn-icon { display: inline-flex; align-items: center; justify-content: center; width: 30px; height: 30px; border-radius: 6px; border: 1px solid #d1d5db; background: #fff; cursor: pointer; text-decoration: none; color: #374151; transition: background 0.15s, border-color 0.15s; } .pm-btn-icon:hover { background: #f3f4f6; border-color: #9ca3af; color: #111827; } .pm-btn-icon.pm-btn-delete { border-color: #fca5a5; color: #dc2626; } .pm-btn-icon.pm-btn-delete:hover { background: #fef2f2; border-color: #dc2626; } .pm-btn-icon svg { width: 15px; height: 15px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; } @media ( max-width: 768px ) { .pm-table thead { display: none; } .pm-table tr { display: block; margin-bottom: 20px; } .pm-table td { display: block; padding: 8px 0; } .pm-actions { margin-top: 10px; } .pm-plugin-candidates td:nth-child(2), .pm-plugin-candidates td:nth-child(3) { white-space: normal; } .pm-plugin-candidate-slug { max-width: 100%; } .pm-plugin-candidates td:nth-child(3) { text-align: left; } .pm-plugin-name, .pm-plugin-slug { max-width: 100%; white-space: normal; } } .repoevo-nav { display: flex; align-items: center; gap: 4px; background: #fff; border: 1px solid #e2e8f0; border-radius: 10px; padding: 6px; margin: 16px 0 24px; width: fit-content; } .repoevo-nav-tab { display: inline-flex; align-items: center; gap: 6px; padding: 7px 16px; border-radius: 7px; font-size: 13px; font-weight: 500; color: #64748b; text-decoration: none; border: none; background: transparent; cursor: pointer; transition: background 0.15s, color 0.15s; white-space: nowrap; } .repoevo-nav-tab:hover { background: #f1f5f9; color: #1e293b; } .repoevo-nav-tab.repoevo-nav-tab-active { background: #2563eb; color: #fff; font-weight: 600; } .repoevo-nav-tab.repoevo-nav-tab-active:hover { background: #1d4ed8; color: #fff; } .repoevo-nav-tab.repoevo-nav-tab-upgrade { color: #92400e; } .repoevo-nav-tab.repoevo-nav-tab-upgrade:hover { background: #fef3c7; color: #92400e; } .repoevo-nav-tab.repoevo-nav-tab-active.repoevo-nav-tab-upgrade { background: #f59e0b; color: #fff; } .repoevo-page-wrap { margin-top: 0; } .repoevo-settings-wrap { max-width: 100%; margin-top: 20px; } .repoevo-onboarding-hero { background: linear-gradient(135deg, #1e3a5f 0%, #2563eb 100%); border-radius: 12px; padding: 40px 48px; margin-bottom: 28px; color: #fff; display: flex; align-items: center; gap: 32px; } .repoevo-onboarding-hero .repoevo-hero-icon { font-size: 56px; line-height: 1; flex-shrink: 0; } .repoevo-onboarding-hero h2 { color: #fff; font-size: 24px; margin: 0 0 8px; font-weight: 700; } .repoevo-onboarding-hero p { color: rgba(255, 255, 255, 0.85); margin: 0; font-size: 15px; line-height: 1.6; } .repoevo-feature-list { list-style: none; margin: 12px 0 0; padding: 0; display: flex; flex-wrap: wrap; gap: 6px 16px; } .repoevo-feature-list li { color: rgba(255, 255, 255, 0.9); font-size: 13px; display: flex; align-items: center; gap: 5px; } .repoevo-feature-list li::before { content: '✓'; color: #86efac; font-weight: 700; } .repoevo-steps { display: flex; gap: 16px; margin-bottom: 28px; } .repoevo-step { flex: 1; background: #fff; border: 1px solid #e2e8f0; border-radius: 10px; padding: 20px; text-align: center; } .repoevo-step.active { border-color: #2563eb; box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12); } .repoevo-step.done { border-color: #16a34a; background: #f0fdf4; } .repoevo-step-number { width: 32px; height: 32px; border-radius: 50%; background: #e2e8f0; color: #64748b; font-weight: 700; font-size: 14px; display: flex; align-items: center; justify-content: center; margin: 0 auto 10px; } .repoevo-step.active .repoevo-step-number { background: #2563eb; color: #fff; } .repoevo-step.done .repoevo-step-number { background: #16a34a; color: #fff; } .repoevo-step h4 { margin: 0 0 4px; font-size: 13px; font-weight: 600; color: #1e293b; } .repoevo-step p { margin: 0; font-size: 12px; color: #64748b; } .repoevo-api-card { background: #fff; border: 1px solid #e2e8f0; border-radius: 10px; padding: 28px 32px; margin-bottom: 24px; } .repoevo-api-card h3 { margin: 0 0 6px; font-size: 16px; color: #1e293b; } .repoevo-api-card .repoevo-card-desc { color: #64748b; font-size: 13px; margin: 0 0 20px; } .repoevo-connected-badge { display: inline-flex; align-items: center; gap: 8px; background: #f0fdf4; border: 1px solid #bbf7d0; border-radius: 8px; padding: 10px 16px; margin-bottom: 20px; color: #16a34a; font-weight: 600; font-size: 14px; } .repoevo-connected-badge span { font-size: 18px; } .repoevo-plan-badge { display: inline-block; background: #dbeafe; color: #1d4ed8; border-radius: 4px; padding: 2px 8px; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; margin-left: 8px; } .repoevo-plan-badge.pro { background: #fef3c7; color: #92400e; } .repoevo-plan-badge.business { background: #ede9fe; color: #5b21b6; } .repoevo-api-key-display { display: flex; align-items: center; gap: 8px; margin-bottom: 16px; } .repoevo-api-key-display code { background: #f1f5f9; border: 1px solid #e2e8f0; border-radius: 6px; padding: 6px 12px; font-size: 12px; color: #475569; flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .repoevo-connect-btn { background: #2563eb !important; color: #fff !important; border: none !important; border-radius: 8px !important; padding: 10px 24px !important; font-size: 14px !important; font-weight: 600 !important; cursor: pointer; transition: background 0.15s; } .repoevo-connect-btn:hover { background: #1d4ed8 !important; } .repoevo-disconnect-btn { color: #dc2626 !important; border-color: #fca5a5 !important; } .repoevo-settings-section { background: #fff; border: 1px solid #e2e8f0; border-radius: 10px; padding: 24px 32px; margin-bottom: 24px; } .repoevo-settings-section h3 { margin: 0 0 4px; font-size: 15px; color: #1e293b; } .repoevo-settings-section .repoevo-section-desc { color: #64748b; font-size: 13px; margin: 0 0 16px; } a.repoevo-step { cursor: pointer; color: inherit; } a.repoevo-step:hover { border-color: #2563eb; box-shadow: 0 0 0 3px rgba(37,99,235,0.12); text-decoration: none; color: inherit; } ------------------------------------------------------------- */ .repoevo-license-url-hint { margin: 12px 0 0; font-size: 13px; color: #64748b; } .repoevo-license-url-hint strong { color: #1e293b; font-weight: 600; } .repoevo-license-url-hint--connected { background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 8px; padding: 10px 14px; font-size: 13px; margin-bottom: 16px; } .pm-upgrade-wrap { max-width: 100%; } .pm-upgrade-header { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; margin-bottom: 24px; } .pm-upgrade-header h1 { margin: 0; font-size: 1.8em; } .pm-upgrade-header-links { display: flex; gap: 10px; flex-wrap: wrap; } .pm-upgrade-current { border-radius: 12px; padding: 20px 24px; margin-bottom: 24px; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 16px; } .pm-upgrade-current-label { font-size: 12px; color: #6b7280; margin-bottom: 4px; } .pm-upgrade-current-plan { display: flex; align-items: center; gap: 10px; } .pm-upgrade-current-name { font-size: 22px; font-weight: 700; } .pm-upgrade-current-links { display: flex; gap: 8px; flex-wrap: wrap; } .pm-upgrade-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 24px; } @media (max-width: 900px) { .pm-upgrade-grid { grid-template-columns: 1fr; } } .pm-upgrade-card { background: #fff; border: 1px solid #e5e7eb; border-radius: 12px; padding: 20px; position: relative; display: flex; flex-direction: column; } .pm-upgrade-card.is-current { border-width: 2px; } .pm-upgrade-card-badge { position: absolute; top: -11px; left: 50%; transform: translateX(-50%); color: #fff; font-size: 11px; font-weight: 600; padding: 2px 12px; border-radius: 999px; white-space: nowrap; } .pm-upgrade-card-title { font-size: 18px; font-weight: 700; margin-bottom: 4px; } .pm-upgrade-card-sub { font-size: 12px; color: #6b7280; margin-bottom: 16px; } .pm-upgrade-card-features { list-style: none; margin: 0 0 20px 0; padding: 0; flex: 1; } .pm-upgrade-card-features li { display: flex; align-items: center; gap: 8px; font-size: 13px; margin-bottom: 8px; } .pm-upgrade-card-features li.is-missing { color: #9ca3af; } .pm-upgrade-card-features li .pm-feat-icon { font-size: 15px; flex-shrink: 0; } .pm-upgrade-card-action { text-align: center; font-size: 13px; font-weight: 500; margin-top: auto; } .pm-upgrade-card-action .button { width: 100%; text-align: center; box-sizing: border-box; } .pm-upgrade-footer { background: #fff; border: 1px solid #e5e7eb; border-radius: 12px; padding: 16px 20px; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; } .pm-upgrade-footer p { margin: 0; font-size: 13px; color: #6b7280; }