/* ================================================
   PECB API Common Styles
   Shared styles across all modules (Events, Trainers, Partners)
   ================================================ */

/* ================================================
   1. GENERAL RESETS & FONTS
   ================================================ */
.events-api-container,
.trainers-api-container,
.partners-api-container {
    opacity: 1 !important;
    visibility: visible !important;
    font-family: 'parabolica', sans-serif;
}

.events-api-container hr,
.trainers-api-container hr,
.partners-api-container hr {
    border: 0 !important;
    border-top: 1px solid #CBD5E1 !important;
}

/* Font family - Parabolica */
.events-api-container *,
.trainers-api-container *,
.partners-api-container * {
    font-family: 'parabolica', sans-serif !important;
}

/* ================================================
   2. SELECT2 DROPDOWN STYLES
   ================================================ */
.events-api-container.events-api-container .select2-container .select2-selection--single,
.trainers-api-container .select2-container .select2-selection--single,
.partners-api-container .select2-container .select2-selection--single {
    padding: 22px 6px !important;
    background-color: #F1F5F9 !important;
    color: #000 !important;
    font-size: 14px !important;
    font-style: normal !important;
    font-weight: 600 !important;
    box-shadow: none !important;
}

.events-api-container.events-api-container .select2-container--default .select2-selection--single .select2-selection__placeholder,
.trainers-api-container .select2-container--default .select2-selection--single .select2-selection__placeholder,
.partners-api-container .select2-container--default .select2-selection--single .select2-selection__placeholder {
    color: #1E293B !important;
}

.events-api-container.events-api-container .select2-container--default .select2-selection--single .select2-selection__arrow b,
.trainers-api-container .select2-container--default .select2-selection--single .select2-selection__arrow b,
.partners-api-container .select2-container--default .select2-selection--single .select2-selection__arrow b {
    left: 0px !important;
}


/* Select2 Results */
.select2-container--default .select2-results__option--highlighted.select2-results__option--selectable {
    background-color: #F1F5F9;
    color: #000;
    border-radius: 8px;
}

.select2-container--default .select2-results__option--selected {
    background-color: #dbe6f0;
    border-radius: 8px;
}

.select2-results__option {
    padding: 6px;
    user-select: none;
    -webkit-user-select: none;
    margin: 0 4px;
    font-size: 14px !important;
    font-family: 'parabolica' !important;
}

.select2-container--default .select2-selection--single .select2-selection__clear {
    cursor: pointer;
    color: red !important;
    padding: 0px !important;
    margin: 0px !important;
    font-size: 18px;
    margin-right: -6px !important;
    padding: 0px 6px !important;
    padding-bottom: 3px !important;
}

.select2-search--dropdown {
    display: block;
    padding: 4px;
    background-color: #fff;
    margin-bottom: 6px;
    padding-bottom: 6px;
    border: 1px solid #E2E8F0;
    border-radius: 8px;
}

.select2-dropdown {
    background-color: white;
    border: 1px solid #E2E8F0;
    border-radius: 4px;
    box-sizing: border-box;
    display: block;
    position: absolute;
    left: -100000px;
    width: 100%;
    z-index: 1051;
    border-radius: 8px;
    padding: 8px;
}

.select2-container--default .select2-search--dropdown .select2-search__field {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    border: 1px solid #E2E8F0;
}

.select2-container--open .select2-dropdown--below {
    border-top: none;
    border-top-left-radius: 0;
    border-top-right-radius: 0;
    border: 1px solid #E2E8F0;
    padding-bottom: 8px;
    border-radius: 8px;
}

.select2-container--open .select2-dropdown--above {
    border: 1px solid #E2E8F0;
    border-radius: 8px;
}

/* ================================================
   3. FLATPICKR DATE PICKER STYLES
   ================================================ */
.flatpickr-day.endRange,
.flatpickr-day.endRange.inRange,
.flatpickr-day.endRange.nextMonthDay,
.flatpickr-day.endRange.prevMonthDay,
.flatpickr-day.endRange:focus,
.flatpickr-day.endRange:hover,
.flatpickr-day.selected,
.flatpickr-day.selected.inRange,
.flatpickr-day.selected.nextMonthDay,
.flatpickr-day.selected.prevMonthDay,
.flatpickr-day.selected:focus,
.flatpickr-day.selected:hover,
.flatpickr-day.startRange,
.flatpickr-day.startRange.inRange,
.flatpickr-day.startRange.nextMonthDay,
.flatpickr-day.startRange.prevMonthDay,
.flatpickr-day.startRange:focus,
.flatpickr-day.startRange:hover {
    background: #a11239;
    -webkit-box-shadow: none;
    box-shadow: none;
    color: #fff;
    border-color: #E2E8F0;
}

.flatpickr-day.inRange,
.flatpickr-day.nextMonthDay.inRange,
.flatpickr-day.nextMonthDay.today.inRange,
.flatpickr-day.nextMonthDay:focus,
.flatpickr-day.nextMonthDay:hover,
.flatpickr-day.prevMonthDay.inRange,
.flatpickr-day.prevMonthDay.today.inRange,
.flatpickr-day.prevMonthDay:focus,
.flatpickr-day.prevMonthDay:hover,
.flatpickr-day.today.inRange,
.flatpickr-day:focus,
.flatpickr-day:hover {
    cursor: pointer;
    outline: 0;
    background: #F1F5F9;
    border-color: #F1F5F9;
}

.flatpickr-day.inRange {
    box-shadow: -5px 0 0 #F1F5F9, 5px 0 0 #F1F5F9;
}

.flatpickr-day.endRange.startRange+.endRange:not(:nth-child(7n+1)),
.flatpickr-day.selected.startRange+.endRange:not(:nth-child(7n+1)),
.flatpickr-day.startRange.startRange+.endRange:not(:nth-child(7n+1)) {
    -webkit-box-shadow: -10px 0 0 #F1F5F9;
    box-shadow: -10px 0 0 #F1F5F9;
}

/* ================================================
   4. SKELETON LOADING ANIMATIONS
   ================================================ */
.events-api-container .skeleton-card,
.trainers-api-container .skeleton-card,
.partners-api-container .skeleton-card {
    background: #f8f9fa;
    border-radius: 12px;
    padding: 20px;
    margin: 24px 0;
    animation: pulse 1.5s infinite;
    display: flex;
    gap: 16px;
}

.events-api-container .skeleton-card .box1,
.trainers-api-container .skeleton-card .box1,
.partners-api-container .skeleton-card .box1 {
    width: 30%;
    background: #F1F5F9;
    border-radius: 16px;
    border: 1px solid #E2E8F0;
}

.events-api-container .skeleton-card .box2,
.trainers-api-container .skeleton-card .box2,
.partners-api-container .skeleton-card .box2 {
    width: 70%;
}

.events-api-container .skeleton-line,
.trainers-api-container .skeleton-line,
.partners-api-container .skeleton-line {
    background: #e2e8f0;
    border-radius: 8px;
    height: 16px;
    margin: 10px 0;
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200%;
    animation: shimmer 1.5s infinite;
}

.events-api-container .skeleton-line.short,
.trainers-api-container .skeleton-line.short,
.partners-api-container .skeleton-line.short {
    width: 50%;
}

.events-api-container .skeleton-line.medium,
.trainers-api-container .skeleton-line.medium,
.partners-api-container .skeleton-line.medium {
    width: 75%;
}

.events-api-container .skeleton-line.long,
.trainers-api-container .skeleton-line.long,
.partners-api-container .skeleton-line.long {
    width: 95%;
}

.events-api-container .skeleton-button,
.trainers-api-container .skeleton-button,
.partners-api-container .skeleton-button {
    height: 40px;
    width: 100px;
    background: #e2e8f0;
    border-radius: 8px;
    display: inline-block;
}

.trainers-api-container .skeleton-button,
.partners-api-container .skeleton-button {
    width: 120px;
    margin-top: 15px;
}

@keyframes shimmer {
    0% {
        background-position: -200% 0;
    }

    100% {
        background-position: 200% 0;
    }
}

@keyframes pulse {

    0%,
    100% {
        opacity: 1;
    }

    50% {
        opacity: 0.7;
    }
}

/* ================================================
   5. LAYOUT - FILTER & DATA CONTAINERS
   ================================================ */
.events-api-container,
.trainers-api-container,
.partners-api-container {
    display: flex;
    flex-wrap: nowrap;
    gap: 20px;
    padding: 20px;
    background-color: #F1F5F9;
    min-width: 0;
}

.events-api-container .filter,
.trainers-api-container .filter,
.partners-api-container .filter {
    flex: 0 0 20%;
    max-width: 20%;
    background-color: #fff;
    padding: 16px;
    border-radius: 16px;
    /* box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); */
    height: fit-content;
    min-width: 0;
    overflow-wrap: anywhere;
    position: sticky;
    top: 20px;
    z-index: 10;
    align-self: flex-start;
    margin-bottom: 75px;
    transition: top 0.3s ease;
    max-height: 80vh;
    overflow-x: auto;
}

.events-api-container .data,
.trainers-api-container .data,
.partners-api-container .data {
    flex: 0 0 calc(80% - 20px);
    min-width: 0;
}

/* ================================================
   6. FILTER FORM STYLES
   ================================================ */
.events-api-container .filter form,
.trainers-api-container .filter form,
.partners-api-container .filter form {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.trainers-api-container .filter form,
.partners-api-container .filter form {
    gap: 12px;
}

.events-api-container .filter form select,
.events-api-container .filter form input,
.trainers-api-container .filter input[type="text"],
.trainers-api-container .filter select,
.partners-api-container .filter input[type="text"],
.partners-api-container .filter select {
    width: 100%;
    padding: 10px 12px;
    background-color: #F1F5F9 !important;
    border-radius: 8px;
    font-size: 14px;
    appearance: none;
    background-repeat: no-repeat;
    background-position: right 12px center;
    border: 1px solid #E5E7EB !important;
    box-sizing: border-box;
    font-weight: 600;
    color: #1E293B;
}

.trainers-api-container .filter input[type="text"],
.trainers-api-container .filter select,
.partners-api-container .filter input[type="text"],
.partners-api-container .filter select {
    padding: 12px;
}

.events-api-container .filter form input::placeholder,
.events-api-container .filter form select::placeholder,
.trainers-api-container .filter input[type="text"]::placeholder,
.partners-api-container .filter input[type="text"]::placeholder {
    color: #1E293B !important;
    opacity: 1;
    font-weight: 600 !important;
}

.events-api-container .filter form input[type="date"],
.events-api-container .filter form input[type="text"] {
    background-image: none;
    padding-right: 12px;
}


.events-api-container .format-btn.active,
.partners-api-container .level-scheme-selector label,
.trainers-api-container .level-scheme-selector label {
    font-weight: 400;
    color: #475569;
    margin: 0;
    font-size: 16px;
}



.events-api-container .delivery-format-selector,
.partners-api-container .level-scheme-selector,
.trainers-api-container .level-scheme-selector {
    display: flex;
    align-items: center;
    gap: 15px;
    flex-wrap: wrap;
}


.events-api-container .format-btn,
.partners-api-container .level-scheme-selector .level-scheme-btn,
.trainers-api-container .level-scheme-selector .level-scheme-btn {
    padding: 8px 16px;
    color: #475569;
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.3s;
    font-size: 16px;
    border: none;
    width: fit-content;
    max-width: fit-content;
}

.events-api-container .format-btn:hover,
.partners-api-container .level-scheme-selector .level-scheme-btn:hover,
.trainers-api-container .level-scheme-selector .level-scheme-btn:hover {
    background-color: #f8f9fa;
    border-color: #475569;
}

.events-api-container .format-btn.active,
.partners-api-container .level-scheme-selector .level-scheme-btn.active,
.trainers-api-container .level-scheme-selector .level-scheme-btn.active {
    background-color: #0F172A;
    color: #fff;
    font-size: 16px;
}

/* Event status  */

.events-api-container .pecb-event-card .other .status,
#pecb-partner-modal .event-meta .meta-item .meta-valu .status-badge {
    color: #007124 !important;
    border: 1px solid #8BD7A0 !important;
    background: #E8F8EB !important;
    padding: 4px 12px !important;
    border-radius: 8px !important;
}

.events-api-container .pecb-event-card .other .status.Planned,
#pecb-partner-modal .event-meta .meta-item .meta-valu .status-badge.planned {
    border: 1px solid #FFB876 !important;
    background: #FFF0E2 !important;
    color: #BF6300 !important;
    padding: 4px 12px !important;
    border-radius: 8px !important;
}


.pecb-event-card .other>div:first-of-type {
    margin-top: 12px;
}

/* Level Scheme  */

.events-api-container .pecb-event-card .other .level,
.partners-api-container .pecb-partner-card .other .level,
.partners-api-container .pecb-partner-card .other p span,
#pecb-partner-modal .partner-level-large {
    color: #1E293B;
    width: fit-content;
    text-align: center;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    padding: 4px 12px;
    line-height: 18px;
    position: relative;
    overflow: hidden;
    border-radius: 8px;
}

/* ---------- CERTIFIED ---------- */
.events-api-container .pecb-event-card .other .level.Certified,
.partners-api-container .pecb-partner-card .other .level.Certified,
.partners-api-container .pecb-partner-card .other p .level.Certified,
#pecb-partner-modal .partner-level-large.Certified {
    color: #1E293B;
    background: linear-gradient(90deg, #D46869 0.17%, #FEDEE3 79.89%, #E07F7E 154.98%);
}

.events-api-container .pecb-event-card .other .level.Certified::before,
.partners-api-container .pecb-partner-card .other .level.Certified::before,
.partners-api-container .pecb-partner-card .other p .level.Certified::before,
#pecb-partner-modal .partner-level-large.Certified::before {
    content: "";
    position: absolute;
    inset: 0;
    padding: 1px;
    border-radius: inherit;
    background: linear-gradient(90deg, #E07F7E 0%, #FEDEE3 50%, #D46869 100%);
    -webkit-mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
}

/* ---------- AUTHORIZED ---------- */
.events-api-container .pecb-event-card .other .level.Authorized,
.partners-api-container .pecb-partner-card .other .level.Authorized,
.partners-api-container .pecb-partner-card .other p .level.Authorized,
#pecb-partner-modal .partner-level-large.Authorized,
.modal-event-details .partner-level-badge.Authorized {
    color: #1E293B;
    background: linear-gradient(90deg, #D7696A 0%, #F69E96 100%);
}

.events-api-container .pecb-event-card .other .level.Authorized::before,
.partners-api-container .pecb-partner-card .other .level.Authorized::before,
.partners-api-container .pecb-partner-card .other p .level.Authorized::before,
#pecb-partner-modal .partner-level-large.Authorized::before,
.modal-event-details .partner-level-badge.Authorized::before {
    content: "";
    position: absolute;
    inset: 0;
    padding: 1px;
    border-radius: inherit;
    background: linear-gradient(90deg, #F69E96 0%, #D7696A 100%);
    -webkit-mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
}

/* ---------- SILVER ---------- */
.events-api-container .pecb-event-card .other .level.Silver,
.partners-api-container .pecb-partner-card .other .level.Silver,
.partners-api-container .pecb-partner-card .other p .level.Silver,
#pecb-partner-modal .partner-level-large.Silver,
.modal-event-details .partner-level-badge.Silver {
    color: #1E293B;
    background: linear-gradient(90deg, #D1D5D7 0%, #FEFFFF 100%);
}

.events-api-container .pecb-event-card .other .level.Silver::before,
.partners-api-container .pecb-partner-card .other .level.Silver::before,
.partners-api-container .pecb-partner-card .other p .level.Silver::before,
#pecb-partner-modal .partner-level-large.Silver::before,
.modal-event-details .partner-level-badge.Silver::before {
    content: "";
    position: absolute;
    inset: 0;
    padding: 1px;
    border-radius: inherit;
    background: linear-gradient(90deg, #FEFFFF 0%, #D1D5D7 100%);
    -webkit-mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
}

/* ---------- GOLD ---------- */
.events-api-container .pecb-event-card .other .level.Gold,
.partners-api-container .pecb-partner-card .other .level.Gold,
.partners-api-container .pecb-partner-card .other p .level.Gold,
#pecb-partner-modal .partner-level-large.Gold,
.modal-event-details .partner-level-badge.Gold {
    color: #1E293B;
    background: linear-gradient(90deg, #A87A3A 0%, #D6AD54 100%);
}

.events-api-container .pecb-event-card .other .level.Gold::before,
.partners-api-container .pecb-partner-card .other .level.Gold::before,
.partners-api-container .pecb-partner-card .other p .level.Gold::before,
#pecb-partner-modal .partner-level-large.Gold::before,
.modal-event-details .partner-level-badge.Gold::before {
    content: "";
    position: absolute;
    inset: 0;
    padding: 1px;
    border-radius: inherit;
    background: linear-gradient(90deg, #D6AD54 0%, #A87A3A 100%);
    -webkit-mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
}

/* ---------- PLATINUM ---------- */
.events-api-container .pecb-event-card .other .level.Platinum,
.partners-api-container .pecb-partner-card .other .level.Platinum,
.partners-api-container .pecb-partner-card .other p .level.Platinum,
#pecb-partner-modal .partner-level-large.Platinum,
.modal-event-details .partner-level-badge.Platinum {
    color: #1E293B;
    background: linear-gradient(90deg, #8A8C8C 0%, #E0E2E2 100%);
}

.events-api-container .pecb-partner-card .other .level.Platinum::before,
.events-api-container .pecb-event-card .other .level.Platinum::before,
.partners-api-container .pecb-partner-card .other p .level.Platinum::before,
#pecb-partner-modal .partner-level-large.Platinum::before,
.modal-event-details .partner-level-badge.Platinum::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    padding: 1px !important;
    border-radius: inherit !important;
    background: linear-gradient(90deg, #E0E2E2 0%, #8A8C8C 100%) !important;
    -webkit-mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0) !important;
    -webkit-mask-composite: xor !important;
    mask-composite: exclude !important;
}

/* ---------- TITANIUM ---------- */
.events-api-container .pecb-event-card .other .level.Titanium,
.partners-api-container .pecb-partner-card .other .level.Titanium,
.partners-api-container .pecb-partner-card .other p .level.Titanium,
#pecb-partner-modal .partner-level-large.Titanium,
.modal-event-details .partner-level-badge.Titanium {
    color: #FFF;
    background: linear-gradient(90deg, #040707 0%, #4B494B 100%);
}

.events-api-container .pecb-event-card .other .level.Titanium::before,
.partners-api-container .pecb-partner-card .other .level.Titanium::before,
.partners-api-container .pecb-partner-card .other p .level.Titanium::before,
#pecb-partner-modal .partner-level-large.Titanium::before,
.modal-event-details .partner-level-badge.Titanium::before {
    content: "";
    position: absolute;
    inset: 0;
    padding: 1px;
    border-radius: inherit;
    background: linear-gradient(90deg, #4B494B 0%, #040707 100%);
    -webkit-mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
}


/* ================================================
   7. BUTTONS - FILTER, CLEAR, APPLY
   ================================================ */
.events-api-container .filter form button,
.trainers-api-container .filter button,
.partners-api-container .filter button {
    padding: 12px 20px;
    border: none;
    background-color: #000;
    color: #fff;
    border-radius: 46px;
    font-size: 14px;
    font-weight: 400;
    cursor: pointer;
    transition: all 0.3s;
    margin-top: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

.trainers-api-container .filter button,
.partners-api-container .filter button {
    border-radius: 45px;
    font-weight: 600;
    transition: background-color 0.3s, transform 0.1s;
}

.events-api-container .filter form button:hover,
.trainers-api-container .filter button:hover,
.partners-api-container .filter button:hover {
    background-color: #a11e29;
    transform: translateY(-1px);
}

.trainers-api-container .filter button:active,
.partners-api-container .filter button:active {
    transform: translateY(0);
}

.events-api-container .filter form button.clear-filters-btn,
.trainers-api-container .filter .clear-filters-btn,
.partners-api-container .filter .clear-filters-btn {
    background-color: #dc2626;
    margin-top: -10px;
}

.trainers-api-container .filter .clear-filters-btn,
.partners-api-container .filter .clear-filters-btn {
    margin-top: -4px;
}

.events-api-container .filter form button.clear-filters-btn:hover,
.trainers-api-container .filter .clear-filters-btn:hover,
.partners-api-container .filter .clear-filters-btn:hover {
    background-color: #b91c1c;
}

/* ================================================
   8. SEARCH BAR STYLES
   ================================================ */
.events-api-container .search-container .pecb-search-wrapper,
.trainers-api-container .pecb-search-wrapper,
.partners-api-container .pecb-search-wrapper {
    position: relative;
    width: 100%;
}

.events-api-container .search-container .pecb-search-wrapper .search-icon,
.trainers-api-container .pecb-search-wrapper .search-icon,
.partners-api-container .pecb-search-wrapper .search-icon {
    position: absolute;
    left: 10px;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
}

.events-api-container #pecb-events-search,
.trainers-api-container #pecb-trainers-search,
.partners-api-container #pecb-partners-search {
    padding-left: 32px;
    border: 1px solid #ddd;
    border-radius: 12px;
    font-size: 14px;
    background-color: #fff;
    width: 250px;
}

.events-api-container #pecb-events-search:focus,
.trainers-api-container #pecb-trainers-search:focus,
.partners-api-container #pecb-partners-search:focus {
    outline: none;
    border-color: #1e40af;
    box-shadow: 0 0 0 2px rgba(30, 64, 175, 0.1);
}

/* ================================================
   9. LOAD MORE BUTTON
   ================================================ */
.events-api-container #pecb-events-load-more,
.trainers-api-container #pecb-trainers-load-more,
.partners-api-container #pecb-partners-load-more {
    border: 1px solid #000;
    border-radius: 46px;
    background-color: #F1F5F9;
    color: #000;
    cursor: pointer;
    align-self: center;
    transition: background-color 0.3s;
    padding: 12px 36px;
}

.events-api-container #pecb-events-load-more:hover,
.trainers-api-container #pecb-trainers-load-more:hover,
.partners-api-container #pecb-partners-load-more:hover {
    background-color: #000;
    color: #fff;
}

/* ================================================
   10. ERROR & NO RESULTS MESSAGES
   ================================================ */
.events-api-container .no-events,
.events-api-container .error-message,
.trainers-api-container .no-trainers,
.trainers-api-container .error-message,
.partners-api-container .no-partners,
.partners-api-container .error-message {
    padding: 20px;
    text-align: center;
    color: #666;
    background: #f8f9fa;
    border-radius: 8px;
    margin: 20px 0;
}

.events-api-container .error-message,
.trainers-api-container .error-message,
.partners-api-container .error-message {
    color: #dc3545;
    background: #f8d7da;
    border: 1px solid #f5c6cb;
}



/* ================================================
   11. CARD COMPONENTS - COMMON STRUCTURE
   ================================================ */

/* Card Container - Remove default shadow, add on hover */
.events-api-container .pecb-event-card,
.trainers-api-container .pecb-trainer-card,
.partners-api-container .pecb-partner-card {
    background-color: #fff;
    padding: 16px;
    border-radius: 16px;
    box-shadow: none;
    display: flex;
    flex-direction: row;
    gap: 16px;
    width: 100%;
    margin-bottom: 20px;
    transition: all 0.3s;
    border: none;
}

.events-api-container .pecb-event-card:hover,
.trainers-api-container .pecb-trainer-card:hover,
.partners-api-container .pecb-partner-card:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
    transform: translateY(-2px);
}

/* Card Title Section */
.events-api-container .pecb-event-card .title,
.trainers-api-container .pecb-trainer-card .title,
.partners-api-container .pecb-partner-card .title {
    width: 30%;
    background-color: #F1F5F9;
    border: 1px solid #E2E8F0;
    padding: 24px 18px;
    border-radius: 16px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

/* Title Typography */
.events-api-container .pecb-event-card .title p,
.trainers-api-container .pecb-trainer-card .title p,
.partners-api-container .pecb-partner-card .title p {
    color: #020617;
    font-size: 14px;
    font-style: normal;
    font-weight: 500;
    line-height: 18px;
    margin: 0;
}

.events-api-container .pecb-event-card .title p span,
.trainers-api-container .pecb-trainer-card .title p span,
.partners-api-container .pecb-partner-card .title p span {
    font-weight: 400;
    color: #64748B;
    font-size: 14px;
}


.events-api-container .pecb-event-card .title a,
.trainers-api-container .pecb-trainer-card .title a,
.partners-api-container .pecb-partner-card .title a {
    color: #020617;
    font-size: 14px;
    font-style: normal;
    font-weight: 500;
    line-height: 18px;
    margin: 0;
    transition: all 0.3s;
}

.events-api-container .pecb-event-card .title a:hover,
.trainers-api-container .pecb-trainer-card .title a:hover,
.partners-api-container .pecb-partner-card .title a:hover {
    color: #a11e29;
    text-decoration: underline;
}


/* Card Other/Content Section */
.events-api-container .pecb-event-card .other,
.trainers-api-container .pecb-trainer-card .other,
.partners-api-container .pecb-partner-card .other {
    width: 70%;
    margin: auto 0;
}

.events-api-container .pecb-event-card .other div

/* .trainers-api-container .pecb-trainer-card .other div,
.partners-api-container .pecb-partner-card .other div  */
    {
    display: flex;
    flex-direction: row;
    gap: 16px;
    padding: 12px 0;
    justify-content: space-between;
    flex-wrap: wrap;
}

/* Other Section Typography */
.events-api-container .pecb-event-card .other p,
.trainers-api-container .pecb-trainer-card .other p,
.partners-api-container .pecb-partner-card .other p {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin: 0;
    padding: 0;
    color: #020617;
    font-size: 14px;
    font-style: normal;
    font-weight: 500;
    line-height: 18px;
}

.events-api-container .pecb-event-card .other p span,
.trainers-api-container .pecb-trainer-card .other p span,
.partners-api-container .pecb-partner-card .other p span {
    margin: 0;
    padding: 0;
    width: fit-content;
    font-weight: 400;
    color: #64748B;
    font-size: 14px;
    padding: 0 4px;
    border-radius: 8px;
}


/* ================================================
   MODAL STYLES
   ================================================ */

.pecb-modal {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 10000;
    overflow-y: auto;
}

.pecb-modal.active {
    display: flex;
    align-items: start;
    justify-content: center;
    top: 40px;
}

.pecb-modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(2px);
}

.pecb-modal-content {
    position: relative;
    background: #fff;
    border-radius: 12px;
    max-width: 850px;
    width: 90%;
    max-height: 85vh;
    /* min-height: 90vh; */
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.2);
    z-index: 10001;
    display: flex;
    flex-direction: column;
    overflow-y: auto;
}

.pecb-modal-close {
    position: absolute;
    padding: 0;
    padding-bottom: 5px;
    top: 6px;
    right: 12px;
    background-color: #fff !important;
    border: 1px solid #ddd;
    font-size: 20px;
    line-height: 1;
    color: #666 !important;
    cursor: pointer;
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: all 0.3s;
    z-index: 10002;
}

.pecb-modal-close:hover {
    background: #f0f0f0 !important;
    color: #000 !important;
}

.pecb-modal-body {
    padding: 24px;
    overflow-y: auto;
    flex: 1;
}

.modal-loading {
    text-align: center;
    padding: 40px;
    color: #666;
}

.modal-loading p {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

/* ================================================
   12. BUTTON COMPONENTS - REUSABLE CLASSES
   ================================================ */

/* Primary Black Button */
.pecb-btn-black,
.events-api-container .btn-enroll,
.trainers-api-container .view-trainer-details,
.partners-api-container .view-partner-details,
.modal-actions .btn-enroll,
.modal-actions-2 .btn-enroll,
.modal-event-details .contact-btn {
    height: 40px !important;
    padding: 12px 24px 10px 24px !important;
    background-color: #000 !important;
    border-radius: 46px !important;
    border: 1px solid #000 !important;
    font-size: 14px !important;
    color: #fff !important;
    text-decoration: none !important;
    min-width: fit-content;
    display: flex;
    align-items: center;
    cursor: pointer;
    transition: all 0.3s ease;
}

.pecb-btn-black:hover,
.events-api-container .btn-enroll:hover,
.trainers-api-container .view-trainer-details:hover,
.partners-api-container .view-partner-details:hover,
.modal-actions .btn-enroll:hover,
.modal-actions-2 .btn-enroll:hover,
.modal-event-details .contact-btn :hover {
    background-color: #a11e29 !important;
    color: #fff !important;
    transform: translateY(-1px);
    border: 1px solid #a11e29 !important;
}

/* Secondary White Button */
.pecb-btn-white,
.events-api-container .view-more,
.trainers-api-container .contact-trainer-btn,
.partners-api-container .contact-partner-btn,
.modal-actions .view-more-details,
.modal-actions-2 .view-more-details {
    /* height: 40px !important; */
    padding: 12px 24px 10px 24px !important;
    background-color: #fff !important;
    border-radius: 46px !important;
    border: 1px solid #000 !important;
    color: #000 !important;
    font-size: 14px !important;
    line-height: 16px;
    text-decoration: none !important;
    min-width: fit-content;
    display: flex;
    justify-content: center;
    cursor: pointer;
    transition: all 0.3s ease;
}

.pecb-btn-white:hover,
.events-api-container .view-more:hover,
.trainers-api-container .contact-trainer-btn:hover,
.partners-api-container .contact-partner-btn:hover,
.modal-actions .view-more-details:hover,
.modal-actions-2 .view-more-details:hover {
    background-color: #a11e29 !important;
    color: #fff !important;
    transform: translateY(-1px);
    border: 1px solid #a11e29 !important;
}

/* Button positioning in cards */
.events-api-container .btn-enroll,
.trainers-api-container .view-trainer-btn,
.partners-api-container .view-partner-btn {
    margin-left: auto !important;
    margin-top: auto !important;
    margin-bottom: auto !important;
}

.events-api-container .view-more,
.trainers-api-container .contact-trainer-btn,
.partners-api-container .contact-partner-btn {
    margin: auto 0 !important;
}

/* ================================================
   13. MODAL BUTTON CONSISTENCY
   ================================================ */

/* Modal action buttons inherit from common button classes */
.modal-actions button,
.modal-actions-2 button,
.modal-actions a,
.modal-actions-2 a {
    transition: all 0.3s ease;
}

.modal-actions button:hover,
.modal-actions-2 button:hover,
.modal-actions a:hover,
.modal-actions-2 a:hover {
    transform: translateY(-1px);
    background-color: #a11229 !important;
    border: #a11e29 !important;
}

/* 14. Contact Form Styles */
.contact-form {
    margin: 24px 0;
    padding: 20px;
    background: #f8fafc;
    border-radius: 12px;
    border: 1px solid #e2e8f0;
}

.contact-form-notice {
    background: #fff3cd;
    border: 1px solid #ffeaa7;
    border-radius: 8px;
    padding: 12px 16px;
    margin-bottom: 20px;
}

.contact-form-notice p {
    color: #B45309;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    letter-spacing: 0.075px;
}

.form-row {
    display: flex;
    gap: 16px;
    margin-bottom: 16px;
}

.form-group {
    flex: 1;
}

.form-group label {
    display: block;
    font-size: 12px;
    color: #64748b;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 6px;
}

.form-group input,
.form-group textarea {
    width: 100%;
    padding: 12px;
    border: 1px solid #d1d5db;
    border-radius: 8px;
    font-size: 14px;
    color: #1e293b;
    background: #fff;
    transition: border-color 0.3s;
    box-sizing: border-box;
}

.form-group input:focus,
.form-group textarea:focus {
    outline: none;
    border-color: #1e40af;
    box-shadow: 0 0 0 3px rgba(30, 64, 175, 0.1);
}

.form-group input::placeholder,
.form-group textarea::placeholder {
    color: #9ca3af;
}

.form-checkbox {
    margin: 16px 0;
}

.form-checkbox label {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: 14px;
    color: #475569;
    cursor: pointer;
}

.form-checkbox input[type="checkbox"] {
    margin: 0;
    margin-top: 2px;
    accent-color: #a11e29;
}

.form-recaptcha {
    margin: 16px 0;
}

.form-recaptcha .g-recaptcha {
    transform-origin: left top;
}

/* Legacy placeholder styles - can be removed after reCAPTCHA is implemented */
.recaptcha-placeholder {
    display: none;
}

.form-actions {
    margin-top: 20px;
}

.contact-form-fields .send-message-btn {
    display: flex !important;
    padding: 8px 32px !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 10px !important;
    border-radius: 46px !important;
    border: 1px solid #000 !important;
    background-color: #000;
}

.contact-form-fields .send-message-btn:hover {
    background-color: #a11e29 !important;
    border: 1px solid #a11e29 !important;
    color: #fff !important;
    transform: translateY(-1px) !important;
}

/* ================================================
   15. FILTER TOGGLE - MOBILE
   ================================================ */
.filter-toggle {
    display: none;
}

/* ================================================
   16. RESPONSIVE DESIGN - MOBILE
   ================================================ */
@media (max-width: 981px) {

    .events-api-container,
    .trainers-api-container,
    .partners-api-container {
        flex-direction: column;
        gap: 16px;
    }

    /* Filter Toggle Button */
    .filter-toggle {
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 100%;
        padding: 14px;
        color: #000 !important;
        background-color: #fff!important;
        border: 1px solid #E2E8F0;
        border-radius: 12px;
        cursor: pointer;
        font-size: 16px;
        font-weight: 500;
        color: #1E293B;
        transition: all 0.3s ease;
        margin-bottom: 0;
        border-radius: 16px !important;
    }

    .filter-toggle:hover {
        background-color: #fff;
        border: 1px solid #E2E8F0;
    }

    .filter-toggle:focus {
        background-color: #fff;
        border: 1px solid #E2E8F0;
    }

    .filter-toggle .filter-arrow {
        transition: transform 0.3s ease;
    }

    .filter-toggle.open .filter-arrow {
        transform: rotate(180deg);
    }

    /* Filter Container - Hidden by default on mobile */
    .events-api-container .filter,
    .trainers-api-container .filter,
    .partners-api-container .filter {
        display: none;
        overflow: hidden;
        transition: all 0.3s ease;
    }

    .events-api-container .filter.open,
    .trainers-api-container .filter.open,
    .partners-api-container .filter.open {
        display: block;
        margin-top: 10px;
    }

    .events-api-container .filter,
    .events-api-container .data,
    .trainers-api-container .filter,
    .trainers-api-container .data,
    .partners-api-container .filter,
    .partners-api-container .data {
        flex: 0 0 100%;
        max-width: 100%;
        width: 100%;
        position: relative;
        margin: 0px !important;
        top: 0px !important;
        max-height: 100% !important;
        overflow: unset !important;
    }

    .pecb-modal-content {
        width: 95%;
        margin: 10px auto;
        max-height: 90vh;
    }

    .pecb-modal-body {
        padding: 30px 20px;
    }
}


@media (max-width: 768px) {

    .pecb-modal-body {
        padding: 10px;
    }

    .pecb-modal-content {
        width: 95%;
        margin: 10px auto;
        max-height: 78vh;
        top: 0;
    }

    .pecb-modal-close {
        top: 16px;
        right: 16px;
    }
}