
/* ---------------------------------------------------

    1. Common Styles
    2. Testimonial Widget
    3. Course Agenda Widget
    4. Golf Gallery Widget

--------------------------------------------------- */


/** 
    1. Common Styles
*/

    @import url('https://fonts.googleapis.com/css2?family=Oxanium:wght@200..800&display=swap'); /* Oxanium Font */

    :root {
        --mt-e-transition: 375ms cubic-bezier(0.7, 0, 0.3, 1);
        --mt-e-title-font: "Oxanium", sans-serif;
    }

    body { overflow-x: hidden; overflow-y: visible; }


/**    
    2. Testimonial Widget
*/

     
    .gt-mc-testimonial * { margin: 0; padding: 0; box-sizing: border-box; -webkit-tap-highlight-color: transparent; }

    .gt-mc-testimonial { font-family: var(--mt-e-title-font); overflow-x: hidden; 
        -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

    .gt-mc-testimonial .mc-main-container { position: relative; min-height: 100vh; display: flex; 
        align-items: center; justify-content: center; padding: 0px; width: 100%; }

    .gt-mc-testimonial .mc-background { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 0; }

    .gt-mc-testimonial .mc-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; 
        background: var(--background-color); z-index: 1; }

    .gt-mc-testimonial .mc-testimonial-box { position: relative; z-index: 2; width: 100%; max-width: 90%; 
        background: rgba(0, 0, 0, 0.6); backdrop-filter: blur(10px); border-radius: 20px; padding: 100px; 
        box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4); display: flex; gap: 60px; align-items: center; margin: 0 auto; }

    .gt-mc-testimonial .mc-left-section { flex: 0 0 20%; color: white; display: flex; flex-direction: column; align-items: flex-start; }

    .gt-mc-testimonial .mc-quote-icon-large { width: 110px; height: 110px; background: var(--primary-color); 
        border-radius: 50%; display: flex; align-items: center; justify-content: center; margin-bottom: 35px; 
        box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3); }

    .gt-mc-testimonial .mc-quote-icon-large svg { width: 55px; height: 55px; fill: white; }

    .gt-mc-testimonial .mc-left-section h2 { font-size: 32px; font-weight: 700; line-height: 1.25; margin-bottom: 18px; }

    .gt-mc-testimonial .mc-right-section { flex: 0 0 80%; position: relative; overflow: hidden; }

    .gt-mc-testimonial .mc-carousel-e-wrapper {
        overflow: hidden;
        touch-action: pan-y pinch-zoom;
        -webkit-overflow-scrolling: touch;
    }

    .gt-mc-testimonial .mc-cards-container {
        display: flex;
        gap: 20px;
        transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
        will-change: transform;
    }

    .gt-mc-testimonial .mc-error-wrapper {
        padding: 60px 20px;
        text-align: center;
    }

    .gt-mc-testimonial .mc-error-message {
        color: #e91e63;
        font-size: 16px;
        margin-bottom: 20px;
    }

    .gt-mc-testimonial .mc-card {
        flex: 0 0 calc(33.333% - 14px);
        min-width: calc(33.333% - 14px);
        background: white;
        border-radius: 16px;
        overflow: visible;
        box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
        transition: transform 0.3s, box-shadow 0.3s;
        height: 300px;
        display: flex;
        flex-direction: column;
        position: relative;
        margin-top: 40px;
    }

    .gt-mc-testimonial .mc-card:hover {
        transform: translateY(-5px);
        box-shadow: 0 15px 40px rgba(0, 0, 0, 0.3);
    }

    .gt-mc-testimonial .mc-card-content {
        padding: 35px 28px 24px;
        position: relative;
        flex: 1;
        display: flex;
        flex-direction: column;
        min-height: 0;
    }

    .gt-mc-testimonial .mc-card-quote-icon {
        position: absolute;
        top: -30px;
        left: 28px;
        width: 60px;
        height: 60px;
        background: linear-gradient(135deg, var(--primary-color) 0%, #7aa61a 100%);
        border-radius: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
        box-shadow: 0 8px 20px rgba(149, 198, 36, 0.4);
        z-index: 10;
        border: 4px solid white;
    }

    .gt-mc-testimonial .mc-card-quote-icon svg {
        width: 28px;
        height: 28px;
        fill: white;
    }

    .gt-mc-testimonial .mc-card-text-wrapper {
        flex: 1;
        min-height: 0;
        display: flex;
        flex-direction: column;
    }

    .gt-mc-testimonial .mc-card-text {
        color: #333333;
        font-size: 14px;
        line-height: 1.7;
        margin-bottom: 16px;
        margin-top: 0;
        overflow: hidden;
        display: -webkit-box;
        -webkit-line-clamp: 4;
        -webkit-box-orient: vertical;
    }

    .gt-mc-testimonial .mc-card-text.expanded {
        display: block;
        overflow-y: auto;
        max-height: 150px;
        padding-right: 8px;
        -webkit-line-clamp: unset;
    }

    .gt-mc-testimonial .mc-card-text.expanded::-webkit-scrollbar {
        width: 5px;
    }

    .gt-mc-testimonial .mc-card-text.expanded::-webkit-scrollbar-track {
        background: #f1f1f1;
        border-radius: 10px;
    }

    .gt-mc-testimonial .mc-card-text.expanded::-webkit-scrollbar-thumb {
        background: var(--primary-color);
        border-radius: 10px;
    }

    .gt-mc-testimonial .mc-card-text.expanded::-webkit-scrollbar-thumb:hover {
        background: #7aa61a;
    }

    .gt-mc-testimonial .mc-read-more-btn {
        display: none;
        color: var(--primary-color);
        font-size: 13px;
        font-weight: 600;
        cursor: pointer;
        background: none;
        border: none;
        padding: 0;
        margin-bottom: 12px;
        transition: color 0.3s;
        text-align: left;
        flex-shrink: 0;
    }

    .gt-mc-testimonial .mc-read-more-btn:hover {
        color: #7aa61a;
    }

    .gt-mc-testimonial .mc-read-more-btn.show {
        display: inline-block;
    }

    .gt-mc-testimonial .mc-card-author {
        padding-top: 0;
        flex-shrink: 0;
        display: flex;
        align-items: center;
        gap: 14px;
        border-top: 1px solid #f0f0f0;
        padding-top: 16px;
    }

    .gt-mc-testimonial .mc-author-avatar {
        width: 45px;
        height: 45px;
        background: linear-gradient(135deg, var(--primary-color) 0%, #7aa61a 100%);
        border-radius: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
        color: white;
        font-weight: 700;
        font-size: 20px;
        flex-shrink: 0;
        box-shadow: 0 4px 12px rgba(149, 198, 36, 0.3);
    }

    .gt-mc-testimonial .mc-author-info {
        flex: 1;
    }

    .gt-mc-testimonial .mc-card-name {
        font-size: 17px;
        font-weight: 700;
        color: #000000;
        margin-bottom: 4px;
    }

    .gt-mc-testimonial .mc-card-title {
        font-size: 13px;
        color: #666666;
        font-style: italic;
    }

    .gt-mc-testimonial .mc-card-country {
        font-size: 13px;
        color: #666666;
        font-weight: 400;
        margin-top: 2px;
    }

    .gt-mc-testimonial .mc-navigation {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-top: 45px;
    }

    .gt-mc-testimonial .mc-nav-arrows {
        display: flex;
        gap: 10px;
    }

    .gt-mc-testimonial .mc-nav-arrow {
        width: 44px;
        height: 44px;
        background: linear-gradient(135deg, var(--secondary-color) 0%, #e0a101 100%);
        border: none;
        border-radius: 8px;
        display: flex;
        align-items: center;
        justify-content: center;
        cursor: pointer;
        transition: all 0.3s;
        box-shadow: 0 4px 12px rgba(244, 181, 2, 0.3);
    }

    .gt-mc-testimonial .mc-nav-arrow:hover {
        background: linear-gradient(135deg, #e0a101 0%, #c98f01 100%);
        transform: translateY(-2px);
        box-shadow: 0 6px 16px rgba(244, 181, 2, 0.4);
    }

    .gt-mc-testimonial .mc-nav-arrow:disabled {
        background: rgba(244, 181, 2, 0.3);
        cursor: not-allowed;
        box-shadow: none;
        transform: none;
    }

    .gt-mc-testimonial .mc-nav-arrow svg {
        width: 20px;
        height: 20px;
        fill: #ffffff;
    }

    .gt-mc-testimonial .mc-nav-dots {
        display: flex;
        gap: 10px;
        align-items: center;
    }

    .gt-mc-testimonial .mc-dot {
        width: 10px;
        height: 10px;
        background: rgba(255, 255, 255, 0.4);
        border-radius: 50%;
        border: none;
        cursor: pointer;
        transition: all 0.3s;
        padding: 0;
    }

    .gt-mc-testimonial .mc-dot.active {
        width: 36px;
        height: 10px;
        background: linear-gradient(90deg, var(--secondary-color) 0%, var(--primary-color) 100%);
        border-radius: 5px;
    }

    .gt-mc-testimonial .mc-dot:hover {
        background: rgba(255, 255, 255, 0.7);
    }

    @media (max-width: 1200px) {
        .gt-mc-testimonial .mc-main-container {
            padding: 40px 20px;
        }

        .gt-mc-testimonial .mc-testimonial-box {
            flex-direction: column;
            padding: 40px 30px;
            gap: 40px;
        }

        .gt-mc-testimonial .mc-left-section {
            flex: 1;
            width: 100%;
            align-items: center;
            text-align: center;
        }

        .gt-mc-testimonial .mc-left-section h2 {
            font-size: 28px;
        }

        .gt-mc-testimonial .mc-quote-icon-large {
            width: 90px;
            height: 90px;
            margin-bottom: 25px;
        }

        .gt-mc-testimonial .mc-quote-icon-large svg {
            width: 45px;
            height: 45px;
        }

        .gt-mc-testimonial .mc-right-section {
            flex: 1;
            width: 100%;
        }

        .gt-mc-testimonial .mc-card {
            flex: 0 0 calc(50% - 10px);
            min-width: calc(50% - 10px);
        }
    }

    @media (max-width: 768px) {
        .gt-mc-testimonial .mc-main-container { padding: 20px 15px; min-height: auto; }

        .gt-mc-testimonial .mc-testimonial-box { padding: 30px 18px; gap: 30px; }

        .gt-mc-testimonial .mc-left-section h2 { font-size: 24px; margin-bottom: 12px; }

        .gt-mc-testimonial .mc-quote-icon-large { width: 70px; height: 70px; margin-bottom: 20px; }

        .gt-mc-testimonial .mc-quote-icon-large svg { width: 35px; height: 35px; }

        .gt-mc-testimonial .mc-right-section { width: 100%; }

        .gt-mc-testimonial .mc-carousel-e-wrapper { margin: 0 -18px; padding: 0 18px; }

        .gt-mc-testimonial .mc-cards-container { gap: 15px; }

        .gt-mc-testimonial .mc-card { flex: 0 0 100%; min-width: 100%; height: auto; min-height: 260px; }

        .gt-mc-testimonial .mc-card:hover { transform: none; }

        .gt-mc-testimonial .mc-card-content { padding: 30px 20px 20px; }

        .gt-mc-testimonial .mc-card-quote-icon { width: 50px; height: 50px; top: -25px; left: 20px; }

        .gt-mc-testimonial .mc-card-quote-icon svg { width: 24px; height: 24px; }

        .gt-mc-testimonial .mc-card-text { font-size: 13px; line-height: 1.7; }

        .gt-mc-testimonial .mc-card-name { font-size: 16px; }

        .gt-mc-testimonial .mc-card-title { font-size: 12px; }

        .gt-mc-testimonial .mc-card-country { font-size: 12px; }

        .gt-mc-testimonial .mc-navigation { flex-direction: column; gap: 20px; margin-top: 30px; }

        .gt-mc-testimonial .mc-nav-arrows { order: 2; width: 100%; justify-content: center; }

        .gt-mc-testimonial .mc-nav-arrow { width: 48px; height: 48px; }

        .gt-mc-testimonial .mc-nav-arrow svg { width: 22px; height: 22px; }

        .gt-mc-testimonial .mc-nav-dots { order: 1; }

        .gt-mc-testimonial .mc-author-avatar { width: 40px; height: 40px; font-size: 18px; }
    }

    @media (max-width: 480px) {
        .gt-mc-testimonial .mc-main-container { padding: 15px 12px; }

        .gt-mc-testimonial .mc-testimonial-box { padding: 25px 15px; border-radius: 15px; }

        .gt-mc-testimonial .mc-left-section h2 { font-size: 22px; }

        .gt-mc-testimonial .mc-quote-icon-large { width: 60px; height: 60px; margin-bottom: 15px; }

        .gt-mc-testimonial .mc-quote-icon-large svg { width: 30px; height: 30px; }

        .gt-mc-testimonial .mc-carousel-e-wrapper { margin: 0 -15px; padding: 0 15px; }

        .gt-mc-testimonial .mc-card { min-height: 240px; }

        .gt-mc-testimonial .mc-card-content { padding: 28px 18px 18px; }

        .gt-mc-testimonial .mc-card-text { font-size: 12px; }

        .gt-mc-testimonial .mc-card-name { font-size: 15px; }

        .gt-mc-testimonial .mc-card-country { font-size: 11px; }

        .gt-mc-testimonial .mc-author-avatar { width: 36px; height: 36px; font-size: 16px; }
    }


/**
   3. Course Agenda Widget
*/

    .course-agenda-wrapper * { margin: 0; padding: 0; box-sizing: border-box; }

    .course-agenda-wrapper { max-width: 90%; margin: 0 auto; font-family: var(--mt-e-title-font); background: #1D1D1D; padding: 20px 0; }

    .course-agenda-wrapper .agenda-header {
        text-align: center;
        margin-bottom: 60px;
    }

    .course-agenda-wrapper .agenda-title {
        font-size: 32px;
        font-weight: 800;
        color: #FFFFFF;
        letter-spacing: 1.5px;
        text-transform: uppercase;
        line-height: 1.2;
        margin: 10px;
    }

    .course-agenda-wrapper .agenda-subtitle {
        display: block;
        font-size: 14px;
        font-weight: 600;
        color: #95C624;
        margin-top: 8px;
        letter-spacing: 0.8px;
    }

    /* ============================================
    DAY CARDS CONTAINER
    ============================================ */
    .course-agenda-wrapper .days-container {
        display: flex;
        flex-direction: column;
        gap: 40px;
        margin-bottom: 60px;
    }

    /* ============================================
    INITIAL CLICKABLE DAY CARD
    ============================================ */
    .course-agenda-wrapper .day-card-wrapper {
        position: relative;
    }

    .course-agenda-wrapper .day-card-initial {
        width: 100%;
        max-width: 400px;
        margin: 0 auto;
        padding: 60px 40px;
        background: linear-gradient(135deg, rgba(149, 198, 36, 0.08) 0%, rgba(209, 157, 2, 0.08) 100%);
        border: 2px solid rgba(149, 198, 36, 0.3);
        border-radius: 20px;
        cursor: pointer;
        transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
        text-align: center;
        box-shadow: 0 10px 40px rgba(0, 0, 0, 0.4);
    }

    .course-agenda-wrapper .day-card-initial:hover {
        transform: translateY(-8px);
        border-color: #95C624;
        box-shadow: 0 20px 60px rgba(149, 198, 36, 0.3);
        background: linear-gradient(135deg, rgba(149, 198, 36, 0.12) 0%, rgba(209, 157, 2, 0.12) 100%);
    }

    .course-agenda-wrapper .day-card-initial.hidden {
        display: none;
    }

    .course-agenda-wrapper .day-number-display {
        font-size: 72px;
        font-weight: 900;
        color: #95C624;
        text-shadow: 0 0 30px rgba(149, 198, 36, 0.5);
        margin-bottom: 20px;
        line-height: 1;
    }

    .course-agenda-wrapper .day-title-display {
        font-size: 20px;
        font-weight: 700;
        color: #FFFFFF;
        margin-bottom: 30px;
        line-height: 1.4;
    }

    .course-agenda-wrapper .click-hint {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 12px;
        font-size: 14px;
        color: rgba(255, 255, 255, 0.6);
        margin-top: 20px;
    }

    .course-agenda-wrapper .hand-icon {
        width: 32px;
        height: 32px;
        animation: tapAnimation 1.5s ease-in-out infinite;
    }

    @keyframes tapAnimation {
        0%, 100% {
            transform: scale(1) translateY(0);
        }
        50% {
            transform: scale(1.15) translateY(-4px);
        }
    }

    /* ============================================
    EXPANDED CONTENT
    ============================================ */
    .course-agenda-wrapper .day-expanded-wrapper {
        display: none;
        opacity: 0;
    }

    .course-agenda-wrapper .day-expanded-wrapper.active {
        display: block;
        animation: fadeInContent 0.6s ease forwards;
    }

    .course-agenda-wrapper .day-expanded-wrapper.collapsing {
        animation: fadeOutContent 0.5s ease forwards;
    }

    @keyframes fadeInContent {
        from {
            opacity: 0;
            transform: translateY(20px);
        }
        to {
            opacity: 1;
            transform: translateY(0);
        }
    }

    @keyframes fadeOutContent {
        from {
            opacity: 1;
            transform: translateY(0) scale(1);
        }
        to {
            opacity: 0;
            transform: translateY(-20px) scale(0.95);
        }
    }

    .course-agenda-wrapper .day-card-initial.appearing {
        animation: appearCard 0.5s ease forwards;
    }

    @keyframes appearCard {
        from {
            opacity: 0;
            transform: scale(0.9) translateY(20px);
        }
        to {
            opacity: 1;
            transform: scale(1) translateY(0);
        }
    }

    .course-agenda-wrapper .day-section-header {
        text-align: center;
        margin-bottom: 30px;
    }

    .course-agenda-wrapper .day-section-title {
        font-size: 24px;
        font-weight: 700;
        color: #d19d02;
        line-height: 1.4;
        letter-spacing: 0.5px;
    }

    .course-agenda-wrapper .day-content-layout {
        display: flex;
        gap: 20px;
        align-items: stretch;
    }

    /* ============================================
    DAY LABEL - LEFT SIDE
    ============================================ */
    .course-agenda-wrapper .day-label-left {
        width: 120px;
        min-width: 120px;
        display: flex;
        align-items: center;
        justify-content: center;
        background: rgba(149, 198, 36, 0.05);
        position: relative;
        flex-shrink: 0;
        cursor: pointer;
        transition: all 0.3s ease;
    }

    .course-agenda-wrapper .day-label-left:hover {
        background: rgba(149, 198, 36, 0.1);
    }

    .course-agenda-wrapper .day-label-left:hover .back-arrow {
        opacity: 1;
        transform: translateX(0);
    }

    .course-agenda-wrapper .day-label-left::before {
        content: '';
        position: absolute;
        inset: 0;
        background: linear-gradient(180deg,
                rgba(149, 198, 36, 0.1) 0%,
                rgba(149, 198, 36, 0.05) 50%,
                rgba(149, 198, 36, 0) 100%);
        pointer-events: none;
    }

    .course-agenda-wrapper .day-label-content {
        position: relative;
        width: 100%;
        height: 100%;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .course-agenda-wrapper .back-arrow {
        position: absolute;
        top: 20px;
        left: 50%;
        transform: translateX(-50%) translateX(-10px);
        width: 32px;
        height: 32px;
        opacity: 0;
        transition: all 0.3s ease;
        z-index: 15;
        animation: reversePointAnimation 1.5s ease-in-out infinite;
    }

    .course-agenda-wrapper .back-arrow svg {
        width: 100%;
        height: 100%;
        fill: #95C624;
        filter: drop-shadow(0 0 10px rgba(149, 198, 36, 0.6));
        transform: rotate(180deg);
    }

    @keyframes reversePointAnimation {
        0%, 100% {
            transform: translateX(-50%) translateX(-10px) scale(1) translateY(0);
        }
        50% {
            transform: translateX(-50%) translateX(-10px) scale(1.15) translateY(-4px);
        }
    }

    .course-agenda-wrapper .day-label-text {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        font-size: clamp(40px, 4.5vw, 72px);
        font-weight: 900;
        letter-spacing: 0.05em;
        text-transform: uppercase;
        writing-mode: vertical-rl;
        text-orientation: mixed;
        z-index: 10;
        text-shadow: 0 0 30px currentColor, 0 0 60px currentColor, 0 4px 8px rgba(0, 0, 0, 0.8);
        color: rgba(149, 198, 36, 0.6);
        white-space: nowrap;
    }

    /* ============================================
    CARDS GRID - RIGHT SIDE
    ============================================ */
    .course-agenda-wrapper .agenda-grid {
        flex: 1;
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 0;
        position: relative;
    }

    .course-agenda-wrapper .agenda-card {
        background: #1D1D1D;
        padding: 20px 18px;
        transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
        display: flex;
        flex-direction: column;
        position: relative;
        min-height: 200px;
        border-right: 1px solid rgba(162, 156, 156, 0.2);
        border-bottom: 1px solid rgba(162, 156, 156, 0.2);
        cursor: pointer;
    }

    /* Remove right border from every 3rd column */
    .course-agenda-wrapper .agenda-card:nth-child(3n) {
        border-right: none;
    }

    /* Remove top border from first row */
    .course-agenda-wrapper .agenda-card:nth-child(-n+3) {
        border-top: none;
    }

    /* JavaScript will add 'last-row-item' class to remove bottom border */
    .course-agenda-wrapper .agenda-card.last-row-item {
        border-bottom: none !important;
    }

    .course-agenda-wrapper .agenda-card::before {
        content: '';
        position: absolute;
        inset: 0;
        background: rgba(255, 255, 255, 0.02);
        opacity: 0;
        transition: opacity 0.4s ease;
        pointer-events: none;
    }

    @media (min-width: 769px) {
        .course-agenda-wrapper .agenda-card:hover {
            border: 2px solid #95C624 !important;
            box-shadow: 0 0 40px rgba(149, 198, 36, 0.3), inset 0 0 60px rgba(149, 198, 36, 0.1);
            transform: scale(1.03);
            z-index: 10;
            background: #000000;
        }

        .course-agenda-wrapper .agenda-card:hover::before {
            opacity: 1;
        }

        .course-agenda-wrapper .agenda-card:hover .card-title {
            color: #95C624;
        }
    }

    .course-agenda-wrapper .card-badge {
        display: flex;
        align-items: center;
        gap: 7px;
        margin-bottom: 12px;
    }

    .course-agenda-wrapper .badge-dot {
        width: 7px;
        height: 7px;
        border-radius: 50%;
        flex-shrink: 0;
    }

    /* ============================================
    COLOR CLASSES
    ============================================ */
    .course-agenda-wrapper .card-purple .badge-dot,
    .course-agenda-wrapper .card-purple .popup-badge-dot {
        background: #9b59b6;
        box-shadow: 0 0 8px rgba(155, 89, 182, 0.6);
    }

    .course-agenda-wrapper .card-teal .badge-dot,
    .course-agenda-wrapper .card-teal .popup-badge-dot {
        background: #16a085;
        box-shadow: 0 0 8px rgba(22, 160, 133, 0.6);
    }

    .course-agenda-wrapper .card-pink .badge-dot,
    .course-agenda-wrapper .card-pink .popup-badge-dot {
        background: #e91e63;
        box-shadow: 0 0 8px rgba(233, 30, 99, 0.6);
    }

    .course-agenda-wrapper .card-orange .badge-dot,
    .course-agenda-wrapper .card-orange .popup-badge-dot {
        background: #e67e22;
        box-shadow: 0 0 8px rgba(230, 126, 34, 0.6);
    }

    .course-agenda-wrapper .card-blue .badge-dot,
    .course-agenda-wrapper .card-blue .popup-badge-dot {
        background: #5b7cff;
        box-shadow: 0 0 8px rgba(91, 124, 255, 0.6);
    }

    .course-agenda-wrapper .card-yellow .badge-dot,
    .course-agenda-wrapper .card-yellow .popup-badge-dot {
        background: #F4B502;
        box-shadow: 0 0 8px rgba(244, 181, 2, 0.6);
    }

    .course-agenda-wrapper .card-cyan .badge-dot,
    .course-agenda-wrapper .card-cyan .popup-badge-dot {
        background: #00bcd4;
        box-shadow: 0 0 8px rgba(0, 188, 212, 0.6);
    }

    .course-agenda-wrapper .card-lime .badge-dot,
    .course-agenda-wrapper .card-lime .popup-badge-dot {
        background: #cddc39;
        box-shadow: 0 0 8px rgba(205, 220, 57, 0.6);
    }

    .course-agenda-wrapper .card-indigo .badge-dot,
    .course-agenda-wrapper .card-indigo .popup-badge-dot {
        background: #3f51b5;
        box-shadow: 0 0 8px rgba(63, 81, 181, 0.6);
    }

    .course-agenda-wrapper .card-title {
        font-size: 16px;
        font-weight: 700;
        color: #FFFFFF;
        margin: 0 0 10px 0;
        line-height: 1.3;
        transition: color 0.3s ease;
    }

    .course-agenda-wrapper .card-description {
        font-size: 12px;
        font-weight: 400;
        color: rgba(162, 156, 156, 0.9);
        line-height: 1.5;
        margin: 0;
        flex-grow: 1;
    }

    /* ============================================
    DESKTOP POPUP MODAL
    ============================================ */
    .course-agenda-wrapper .agenda-popup-overlay {
        display: none;
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background: rgba(0, 0, 0, 0.85);
        backdrop-filter: blur(8px);
        z-index: 10000;
    }

    .course-agenda-wrapper .agenda-popup-overlay.active {
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 20px;
    }

    .course-agenda-wrapper .agenda-popup-content {
        background: #000000;
        border: 2px solid #95C624;
        border-radius: 16px;
        padding: 50px 60px;
        max-width: 700px;
        width: 100%;
        position: relative;
        box-shadow: 0 0 60px rgba(149, 198, 36, 0.4),
            inset 0 0 80px rgba(149, 198, 36, 0.1),
            0 20px 80px rgba(0, 0, 0, 0.8);
        animation: popupSlideIn 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    }

    @keyframes popupSlideIn {
        from {
            opacity: 0;
            transform: scale(0.9) translateY(20px);
        }
        to {
            opacity: 1;
            transform: scale(1) translateY(0);
        }
    }

    .course-agenda-wrapper .popup-close {
        position: absolute;
        top: 20px;
        right: 20px;
        background: transparent;
        border: 2px solid rgba(149, 198, 36, 0.5);
        color: #95C624;
        font-size: 32px;
        width: 45px;
        height: 45px;
        border-radius: 50%;
        cursor: pointer;
        display: flex;
        align-items: center;
        justify-content: center;
        transition: all 0.3s ease;
        line-height: 1;
        padding: 0;
    }

    .course-agenda-wrapper .popup-close:hover {
        background: #95C624;
        color: #000000;
        transform: rotate(90deg);
        border-color: #95C624;
    }

    .course-agenda-wrapper .popup-badge {
        display: flex;
        align-items: center;
        gap: 10px;
        margin-bottom: 24px;
    }

    .course-agenda-wrapper .popup-badge-dot {
        width: 12px;
        height: 12px;
        border-radius: 50%;
        animation: pulse 1.5s ease-in-out infinite;
    }

    @keyframes pulse {
        0%, 100% {
            transform: scale(1);
            opacity: 1;
        }
        50% {
            transform: scale(1.2);
            opacity: 0.8;
        }
    }

    .course-agenda-wrapper .popup-title {
        font-size: 28px;
        font-weight: 700;
        color: #95C624;
        margin: 0 0 20px 0;
        line-height: 1.3;
        text-shadow: 0 0 20px rgba(149, 198, 36, 0.3);
    }

    .course-agenda-wrapper .popup-description {
        font-size: 16px;
        font-weight: 400;
        color: rgba(255, 255, 255, 0.95);
        line-height: 1.8;
        margin: 0;
    }

    /* ============================================
    RESPONSIVE - TABLET
    ============================================ */
    @media (max-width: 1200px) and (min-width: 769px) {
        .course-agenda-wrapper .agenda-grid {
            grid-template-columns: repeat(2, 1fr);
        }

        /* Reset 3-column borders */
        .course-agenda-wrapper .agenda-card:nth-child(3n) {
            border-right: 1px solid rgba(162, 156, 156, 0.2);
        }

        /* Apply 2-column borders */
        .course-agenda-wrapper .agenda-card:nth-child(2n) {
            border-right: none;
        }

        .course-agenda-wrapper .day-label-left {
            width: 100px;
        }

        .course-agenda-wrapper .day-label-text {
            font-size: clamp(35px, 4vw, 55px);
        }
    }

    /* ============================================
    RESPONSIVE - MOBILE
    ============================================ */
    @media (max-width: 768px) {
        /* Hide popup on mobile */
        .course-agenda-wrapper .agenda-popup-overlay {
            display: none !important;
        }

        .course-agenda-wrapper {
            max-width: 100%;
            padding: 20px 15px;
        }

        .course-agenda-wrapper .agenda-header {
            margin-bottom: 40px;
        }

        .course-agenda-wrapper .agenda-title {
            font-size: 26px;
        }

        .course-agenda-wrapper .day-card-wrapper {
            min-height: auto;
        }

        /* Initial clickable card on mobile */
        .course-agenda-wrapper .day-card-initial {
            max-width: 320px;
            padding: 50px 30px;
        }

        .course-agenda-wrapper .day-number-display {
            font-size: 56px;
        }

        .course-agenda-wrapper .day-title-display {
            font-size: 18px;
        }

        /* MOBILE EXPANDED CONTENT */
        .course-agenda-wrapper .day-section-header {
            margin-bottom: 25px;
            padding: 0 5px;
        }

        .course-agenda-wrapper .day-section-title {
            font-size: 18px;
        }

        .course-agenda-wrapper .day-content-layout {
            flex-direction: column;
            gap: 0;
        }

        /* Mobile collapse button */
        .course-agenda-wrapper .day-label-left {
            width: 100%;
            height: 80px;
            margin: 0 auto 25px;
            max-width: 400px;
            background: rgba(149, 198, 36, 0.05);
            border: 2px solid rgba(149, 198, 36, 0.3);
            border-radius: 12px;
        }

        .course-agenda-wrapper .day-label-left:active {
            background: rgba(149, 198, 36, 0.1);
        }

        .course-agenda-wrapper .back-arrow {
            top: 50%;
            left: 20px;
            transform: translateY(-50%) translateX(-10px);
            opacity: 1;
            animation: reverseMobilePointAnimation 1.5s ease-in-out infinite;
        }

        @keyframes reverseMobilePointAnimation {
            0%, 100% {
                transform: translateY(-50%) translateX(-10px) scale(1);
            }
            50% {
                transform: translateY(-50%) translateX(-14px) scale(1.15);
            }
        }

        .course-agenda-wrapper .day-label-text {
            writing-mode: horizontal-tb;
            font-size: 32px;
            text-shadow: 0 0 20px currentColor, 0 2px 4px rgba(0, 0, 0, 0.8);
        }

        /* Mobile stacked cards */
        .course-agenda-wrapper .agenda-grid {
            display: block;
            background: #1D1D1D;
            position: relative;
            padding-left: 20px;
            max-width: 400px;
            margin: 0 auto;
        }

        /* Individual gradient line for each card */
        .course-agenda-wrapper .agenda-card::after {
            content: '';
            position: absolute;
            left: -40px;
            top: 0;
            width: 20px;
            height: 100%;
            background: linear-gradient(to bottom, #FFFFFF 0%, rgba(255, 255, 255, 0.7) 30%, rgba(255, 255, 255, 0.4) 60%, rgba(255, 255, 255, 0.1) 100%);
            border-radius: 2px;
            z-index: 5;
        }

        .course-agenda-wrapper .agenda-card {
            position: sticky;
            top: 140px;
            padding: 40px 28px;
            min-height: 340px;
            border: 2px solid rgba(162, 156, 156, 0.25) !important;
            border-radius: 20px;
            box-shadow: 0 10px 40px rgba(0, 0, 0, 0.6) !important;
            margin-bottom: 30px;
            transform-origin: center top;
            background: #000000 !important;
            opacity: 1 !important;
            transform: scale(1) !important;
        }

        .course-agenda-wrapper .agenda-card:last-child {
            margin-bottom: 0;
        }

        /* Disable all hover effects on mobile */
        .course-agenda-wrapper .agenda-card:hover {
            transform: scale(1) !important;
            border: 2px solid rgba(162, 156, 156, 0.25) !important;
            box-shadow: 0 10px 40px rgba(0, 0, 0, 0.6) !important;
            z-index: inherit !important;
            background: #000000 !important;
        }

        .course-agenda-wrapper .agenda-card:hover::before {
            opacity: 0 !important;
        }

        .course-agenda-wrapper .agenda-card:hover .card-title {
            color: #FFFFFF !important;
        }

        .course-agenda-wrapper .card-title {
            font-size: 20px;
            margin-bottom: 16px;
        }

        .course-agenda-wrapper .card-description {
            font-size: 14px;
            line-height: 1.65;
        }

        .course-agenda-wrapper .badge-dot {
            width: 9px;
            height: 9px;
        }
    }

    
/** 
    4. Golf Gallery Widget
*/


    .golf-gallery-widget { font-family: var(--mt-e-title-font); color: #ffffff; line-height: 1.6; width: 100%; position: relative; }

    .golf-gallery-widget * { box-sizing: border-box; }

    @keyframes shimmer {
        0%, 100% { background-position: 0% center; }
        50% { background-position: 100% center; }
    }

    /* ========== GALLERY SECTION - RESPONSIVE ========== */
    .golf-gallery-widget .gallery-section {
        width: 100%;
        padding: 60px 20px;
        background: linear-gradient(180deg, transparent 0%, rgba(10, 10, 10, 0.3) 50%, transparent 100%);
        overflow: hidden;
        position: relative;
    }

    .golf-gallery-widget .gallery-header {
        text-align: center;
        margin-bottom: 40px;
    }

    .golf-gallery-widget .gallery-header h2 {
        font-size: clamp(1.8rem, 4.5vw, 3.5rem);
        font-weight: 800;
        background: linear-gradient(135deg, #ffffff 0%, #95C624 30%, #F4B502 50%, #ffffff 100%);
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        background-clip: text;
        text-transform: uppercase;
        letter-spacing: clamp(2px, 0.8vw, 5px);
        margin: 0;
        animation: shimmer 3s ease-in-out infinite;
        background-size: 200% auto;
    }

    /* ========== DESKTOP CAROUSEL (min-width: 1025px) ========== */
    @media (min-width: 1025px) {
        .golf-gallery-widget .carousel-e-wrapper {
            position: relative;
            width: 100%;
            max-width: 1400px;
            margin: 0 auto;
            padding: 0 60px;
        }

        .golf-gallery-widget .carousel-e-container {
            position: relative;
            height: 320px;
            width: 100%;
            perspective: 2000px;
            overflow: visible;
        }

        .golf-gallery-widget .carousel-e-track {
            position: absolute;
            width: 100%;
            height: 100%;
            transform-style: preserve-3d;
        }

        .golf-gallery-widget .carousel-e-item {
            position: absolute;
            width: 350px;
            height: 280px;
            border-radius: 16px;
            overflow: hidden;
            box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
            border: 2px solid rgba(149, 198, 36, 0.3);
            will-change: transform, opacity;
            backface-visibility: hidden;
            transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);
            background: #000000;
        }

        .golf-gallery-widget .carousel-e-item img {
            width: 100% !important;
            height: 100% !important;
            max-width: 100% !important;
            max-height: 100% !important;
            object-fit: cover !important;
            object-position: center center !important;
            display: block !important;
            pointer-events: none;
            user-select: none;
            position: absolute !important;
            top: 0 !important;
            left: 0 !important;
            right: 0 !important;
            bottom: 0 !important;
        }

        /* Desktop navigation buttons*/
        .golf-gallery-widget .carousel-e-nav {
            position: absolute;
            top: 50%;
            transform: translateY(-50%);
            background: rgba(0, 0, 0, 0.7);
            border: 2px solid rgba(149, 198, 36, 0.4);
            color: #95C624;
            width: 50px;
            height: 50px;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            cursor: pointer;
            transition: all 0.3s ease;
            z-index: 100;
            backdrop-filter: blur(10px);
            font-size: 1.5rem;
            font-weight: bold;
        }

        .golf-gallery-widget .carousel-e-nav:hover {
            background: #95C624;
            color: #000000;
            transform: translateY(-50%) scale(1.1);
            box-shadow: 0 5px 20px rgba(149, 198, 36, 0.5);
        }

        .golf-gallery-widget .carousel-e-nav.prev {
            left: 0;
        }

        .golf-gallery-widget .carousel-e-nav.next {
            right: 0;
        }
    }

    /* ========== MOBILE SLIDER (max-width: 1024px) ========== */
    @media (max-width: 1024px) {
        .golf-gallery-widget .gallery-section {
            padding: 40px 0;
        }

        .golf-gallery-widget .carousel-e-wrapper {
            position: relative;
            width: 100%;
            overflow: hidden;
            padding: 0;
        }

        .golf-gallery-widget .carousel-e-container {
            position: relative;
            width: 100%;
            height: auto;
            overflow: hidden;
            padding: 20px 0;
        }

        .golf-gallery-widget .carousel-e-track {
            display: flex;
            gap: 0;
            padding: 0;
            transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
            will-change: transform;
        }

        .golf-gallery-widget .carousel-e-item {
            flex: 0 0 100%;
            width: 100%;
            max-width: 100%;
            height: auto;
            aspect-ratio: 4/3;
            border-radius: 12px;
            overflow: hidden;
            box-shadow: 0 8px 25px rgba(0, 0, 0, 0.3);
            border: 2px solid rgba(149, 198, 36, 0.25);
            transition: transform 0.3s ease, box-shadow 0.3s ease;
            background: #000000;
            position: relative;
        }

        .golf-gallery-widget .carousel-e-item.active {
            border-color: rgba(149, 198, 36, 0.5);
        }

        .golf-gallery-widget .carousel-e-item img {
            width: 100% !important;
            height: 100% !important;
            max-width: 100% !important;
            max-height: 100% !important;
            object-fit: cover !important;
            object-position: center center !important;
            display: block !important;
            position: absolute !important;
            top: 0 !important;
            left: 0 !important;
            right: 0 !important;
            bottom: 0 !important;
        }

        /* Mobile navigation - smaller, positioned better */
        .golf-gallery-widget .carousel-e-nav {
            position: absolute;
            top: 50%;
            transform: translateY(-50%);
            background: rgba(0, 0, 0, 0.8);
            border: 2px solid rgba(149, 198, 36, 0.4);
            color: #95C624;
            width: 40px;
            height: 40px;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            cursor: pointer;
            transition: all 0.3s ease;
            z-index: 100;
            backdrop-filter: blur(10px);
            font-size: 1.2rem;
            font-weight: bold;
        }

        .golf-gallery-widget .carousel-e-nav:active {
            background: #95C624;
            color: #000000;
            transform: translateY(-50%) scale(0.95);
        }

        .golf-gallery-widget .carousel-e-nav.prev {
            left: 10px;
        }

        .golf-gallery-widget .carousel-e-nav.next {
            right: 10px;
        }
    }

    /* ========== VERY SMALL MOBILE (max-width: 480px) ========== */
    @media (max-width: 480px) {
        .golf-gallery-widget .carousel-e-nav {
            width: 36px;
            height: 36px;
            font-size: 1.1rem;
        }

        .golf-gallery-widget .carousel-e-nav.prev {
            left: 5px;
        }

        .golf-gallery-widget .carousel-e-nav.next {
            right: 5px;
        }
    }

    /* ========== INDICATORS - UNIVERSAL ========== */
    .golf-gallery-widget .carousel-e-indicators {
        display: flex;
        justify-content: center;
        gap: 8px;
        margin-top: 30px;
        padding-bottom: 10px;
        flex-wrap: wrap;
    }

    .golf-gallery-widget .indicator-dot {
        width: 10px;
        height: 10px;
        border-radius: 50%;
        background: rgba(149, 198, 36, 0.3);
        border: 2px solid rgba(149, 198, 36, 0.5);
        cursor: pointer;
        transition: all 0.3s ease;
    }

    .golf-gallery-widget .indicator-dot:hover {
        background: rgba(149, 198, 36, 0.6);
        transform: scale(1.1);
    }

    .golf-gallery-widget .indicator-dot.active {
        background: #95C624;
        box-shadow: 0 0 10px rgba(149, 198, 36, 0.6);
        transform: scale(1.2);
    }

    /* ========== ELEMENTOR OVERRIDES ========== */
    .elementor-widget-container .golf-gallery-widget .carousel-e-item img {
        margin: 0 !important;
        padding: 0 !important;
        border: none !important;
        width: 100% !important;
        height: 100% !important;
    }

    /* Fix for Elementor image wrapper */
    .golf-gallery-widget .carousel-e-item figure,
    .golf-gallery-widget .carousel-e-item picture {
        width: 100% !important;
        height: 100% !important;
        margin: 0 !important;
        padding: 0 !important;
        display: block !important;
    }