/**
 * FluentCommunity Partner Program Widget Styles
 * Supports FluentCommunity's html.dark class for dark mode
 */

/* Ensure sidebar uses flexbox for priority ordering */
.fcom_main_side_wrap {
    display: flex !important;
    flex-direction: column !important;
}

/* Main Widget Container */
.partner-widget-sidebar {
    background: var(--fcom-primary-bg, #ffffff);
    border-radius: 8px;
    padding: 20px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    margin-bottom: 16px;
    border: 1px solid var(--fcom-primary-border, #e4e7eb);
}

/* Widget Header */
.partner-widget-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 12px;
}

.partner-heading {
    font-size: 18px !important;
    font-weight: 600 !important;
    color: var(--fcom-primary-text, #2c3e50) !important;
    margin: 0 !important;
    padding: 0 !important;
}

.partner-heading a {
    color: inherit !important;
    text-decoration: none !important;
}

.partner-heading a:hover {
    text-decoration: underline !important;
}

/* Widget Message */
.partner-widget-message {
    margin-bottom: 16px;
}

.partner-widget-message p {
    font-size: 14px !important;
    line-height: 1.5 !important;
    color: var(--fcom-menu-text, #64748b) !important;
    margin: 0 !important;
}

/* Badge Preview Section */
.partner-badge-preview {
    margin-bottom: 16px;
    padding: 12px;
    background: var(--fcom-secondary-bg, #f8fafc);
    border-radius: 6px;
    border: 1px solid var(--fcom-primary-border, #e4e7eb);
}

/* Badge Section Header */
.partner-badge-header {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--fcom-menu-text, #64748b);
    text-align: center;
    margin-bottom: 10px;
}

.partner-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: space-evenly;
}

/* For 6+ tiers, tighten up the gap slightly */
.partner-badge-preview[data-tier-count="6"] .partner-badges,
.partner-badge-preview[data-tier-count="7"] .partner-badges,
.partner-badge-preview[data-tier-count="8"] .partner-badges {
    gap: 6px;
}

/* For 9-10 tiers, even tighter */
.partner-badge-preview[data-tier-count="9"] .partner-badges,
.partner-badge-preview[data-tier-count="10"] .partner-badges {
    gap: 4px;
}

.partner-badge-item {
    font-size: 18px;
    cursor: help;
}

.partner-badge-item:hover {
    transform: scale(1.2);
}

.partner-option-range {
    font-size: 11px;
    color: var(--fcom-menu-text, #64748b);
}

.partner-divider {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--fcom-menu-text, #64748b);
    font-size: 12px;
    font-weight: 500;
    padding: 0 8px;
}

/* Call to Action Button
 * Uses FluentCommunity's native primary button styling
 * Source: fluent-community/assets/global.css (.fcom_primary_button)
 */
.partner-widget-cta {
    margin-top: 16px;
    text-align: center;
}

.partner-widget-cta .fcom_primary_button {
    display: inline-block !important;
    text-align: center !important;
    text-decoration: none !important;
    /* FluentCommunity primary button styling (matches top menu) */
    padding: 9px 20px !important;
    border-radius: 8px !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    line-height: 1 !important;
    cursor: pointer !important;
    transition: opacity 0.3s ease !important;
    /* Native FC primary button colors - no hardcoded fallbacks */
    color: var(--fcom-primary-button-text, var(--fcom-primary-bg)) !important;
    background: var(--fcom-primary-button) !important;
    border: 1px solid var(--fcom-primary-button) !important;
}

.partner-widget-cta .fcom_primary_button:hover {
    opacity: 0.8 !important;
}

/* Dark Mode Styles */
html.dark .partner-widget-sidebar {
    background: var(--fcom-primary-bg, #1e293b);
    border-color: var(--fcom-primary-border, #334155);
}

html.dark .partner-heading {
    color: var(--fcom-primary-text, #e2e8f0) !important;
}

html.dark .partner-widget-message p {
    color: var(--fcom-menu-text, #94a3b8) !important;
}

html.dark .partner-badge-preview {
    background: var(--fcom-secondary-bg, #0f172a);
    border-color: var(--fcom-primary-border, #334155);
}

html.dark .partner-badge-header {
    color: var(--fcom-menu-text, #94a3b8);
}

html.dark .partner-option-label {
    color: var(--fcom-primary-text, #e2e8f0);
}

html.dark .partner-option-range {
    color: var(--fcom-menu-text, #94a3b8);
}

html.dark .partner-divider {
    color: var(--fcom-menu-text, #94a3b8);
}

/* ========================================
   TOP PARTNERS SECTION
   (v2.10.0 - Mini leaderboard teaser)
   ======================================== */

.partner-widget-top-partners {
    margin-bottom: 16px;
}

.partner-widget-section {
    margin-bottom: 12px;
}

.partner-widget-section:last-child {
    margin-bottom: 0;
}

.partner-widget-section-header {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--fcom-menu-text, #64748b);
    margin-bottom: 8px;
    padding-bottom: 4px;
    border-bottom: 1px solid var(--fcom-primary-border, #e4e7eb);
}

.partner-widget-top-list {
    list-style: none;
    margin: 0;
    padding: 0;
    counter-reset: partner-rank;
}

.partner-widget-top-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 4px 0;
    font-size: 13px;
    counter-increment: partner-rank;
}

.partner-widget-top-item::before {
    content: counter(partner-rank) ".";
    min-width: 18px;
    font-weight: 500;
    color: var(--fcom-menu-text, #64748b);
    font-size: 12px;
}

/* Dark Mode - Top Partners Section */
html.dark .partner-widget-section-header {
    color: var(--fcom-menu-text, #94a3b8);
    border-bottom-color: var(--fcom-primary-border, #334155);
}

html.dark .partner-widget-top-item::before {
    color: var(--fcom-menu-text, #94a3b8);
}

html.dark .partner-widget-view-all {
    color: var(--fcom-menu-text, #94a3b8);
}

/* ========================================
   ACTIVITY SECTION
   (v0.9.85 - Most Active members widget)
   ======================================== */

.partner-widget-activity {
    margin-bottom: 16px;
}

.partner-widget-section-header-linked {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
}

.partner-widget-view-all {
    font-size: 11px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--fcom-menu-text, #64748b);
    text-decoration: none;
}

.partner-widget-view-all:hover {
    text-decoration: underline;
}

/* ========================================
   VUE COMPONENT WRAPPERS
   (v2.11.0 - Native FC components)
   ======================================== */

/* Loading state */
.partner-widget-loading {
    text-align: center;
    padding: 12px;
    color: var(--fcom-menu-text, #64748b);
    font-size: 12px;
}

/* Avatar wrapper - make native FC avatar smaller for widget */
.partner-widget-avatar-wrapper {
    flex-shrink: 0;
}

.partner-widget-avatar-wrapper .fcom_avatar_is_rounded,
.partner-widget-avatar-wrapper .fcom_user_avatar {
    width: 24px !important;
    height: 24px !important;
    min-width: 24px !important;
    min-height: 24px !important;
}

.partner-widget-avatar-wrapper .fcom_user_avatar span img {
    width: 24px !important;
    height: 24px !important;
}

/* Hide level badge indicator on mini avatars (too small) */
.partner-widget-avatar-wrapper .fcom_level_badge_indicator {
    display: none !important;
}

/* Name wrapper - constrain width and handle overflow */
.partner-widget-name-wrapper {
    flex: 1;
    min-width: 0;
    overflow: hidden;
}

/* Make the user route link truncate properly */
.partner-widget-name-wrapper .user_route {
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-decoration: none !important;
}

/* Underline only the name on hover, not the badge */
.partner-widget-name-wrapper .user_route:hover .user_route_name {
    text-decoration: underline !important;
}

/* Truncate the display name text */
.partner-widget-name-wrapper .user_route > span:first-child,
.partner-widget-name-wrapper .user_route_name {
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    flex: 0 1 auto !important;
    min-width: 0 !important;
}

/* Keep badge visible and sized appropriately */
.partner-widget-name-wrapper .user_badge {
    flex-shrink: 0 !important;
    font-size: 12px !important;
    text-decoration: none !important;
}

.partner-widget-name-wrapper .user_badge_inner {
    padding: 1px 4px !important;
    font-size: 11px !important;
    gap: 2px !important;
    text-decoration: none !important;
}

.partner-widget-name-wrapper .user_badge_inner span {
    text-decoration: none !important;
}

.partner-widget-name-wrapper .fcom_emoji {
    font-size: 12px !important;
}

/* Adjust popover trigger styling in widget context */
.partner-widget-name-wrapper .el-tooltip__trigger {
    max-width: 100% !important;
}

/* ========================================
   ACCESSIBILITY
   ======================================== */

.partner-badge-item:focus {
    outline: 2px solid var(--fcom-accent, #667eea);
    outline-offset: 2px;
    border-radius: 4px;
}

/* Print Styles */
@media print {
    .partner-widget-sidebar {
        display: none;
    }
}
