/* 
Theme Name: Hello Elementor Child
Theme URI: https://github.com/elementor/hello-theme-child/
Description: Hello Elementor Child is a child theme of Hello Elementor, created by Elementor team
Author: Elementor Team
Author URI: https://elementor.com/
Template: hello-elementor
Version: 2.0.0
Text Domain: hello-elementor-child
License: GNU General Public License v3 or later.
License URI: https://www.gnu.org/licenses/gpl-3.0.html
Tags: flexible-header, custom-colors, custom-menu, custom-logo, editor-style, featured-images, rtl-language-support, threaded-comments, translation-ready
*/

			html, body {
				max-width: 100% !important;
				overflow-x: hidden !important;
			}

            /* --- Layout Wrappers --- */
            .obl-course-wrapper {
                width: 100%;
                overflow-x: hidden;
            }
            .obl-container {
                display: flex;
                flex-direction: column;
                row-gap: 4vw;
            }
            
            /* --- Headings & Typography --- */
            .obl-section-heading {
                font-family: var(--e-global-typography-5b14ebb-font-family), Sans-serif;
                font-size: var(--e-global-typography-5b14ebb-font-size);
                text-transform: var(--e-global-typography-5b14ebb-text-transform);
                line-height: var(--e-global-typography-5b14ebb-line-height);
                letter-spacing: var(--e-global-typography-5b14ebb-letter-spacing);
            }
            .obl-section-heading.text-center { text-align: center; }
            .obl-text-content p:last-child { margin-bottom: 0; }

            /* --- Grid System --- */
            .obl-grid-2col {
                display: grid;
                grid-template-columns: 1fr;
                gap: 20px;
                padding: 20px 0 0 0;
            }
            @media (min-width: 768px) {
                .obl-grid-2col {
                    grid-template-columns: 1fr 1fr;
                    column-gap: 20px;
                }
            }

            /* --- Icon List Items --- */
            .obl-icon-item {
                display: flex;
                align-items: flex-start;
                gap: 10px;
                margin-bottom: 10px;
            }
            .obl-module-item {
                border: 1px solid var(--e-global-color-731562d);
                padding: 16px;
                border-radius: 14px;
                min-height: 100px;
            }
            .obl-icon {
                width: 24px;
                height: 24px;
                flex-shrink: 0;
                margin-top: 3px;
            }
            .obl-item-text {
                font-size: 1rem;
                line-height: 1.5;
                color: var(--e-global-color-49967e4);
            }

            /* --- Slider Section --- */
            .obl-slider-section {
                background-color: #dfe2da;
                padding: 3vw 1.5em;
                border-radius: 20px;
            }
            
            /* --- Profile Card Styling --- */
            .obl-profile-card {
                background-color: var(--e-global-color-3be427c);
                border: 1px solid var(--e-global-color-49967e4);
                border-radius: 12px;
                padding: 15px 30px;
                text-align: center;
                height: 100%;
                box-sizing: border-box;
                flex: 1 1 0;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-content: flex-start;
            }
            .obl-card-icon img {
                width: 40px;
                height: 40px;
                object-fit: contain;
            }
            .obl-card-icon {
                margin-top: -35px;
            }
            .obl-card-title {
                font-size: 20px !important;
                font-family: var(--e-global-typography-accent-font-family) !important;
                text-transform: capitalize !important;
                line-height: 1.4em !important;
                font-weight: 600;
                margin-bottom: 10px;
                letter-spacing: -0.02em !important;
            }
            .obl-card-desc {
                font-size: 16px;
                line-height: 1.6;
                opacity: 0.8;
            }

            /* --- Swiper Tweaks --- */
            .obl-swiper-container {
                padding: 40px 0 50px 0 !important;
            }
            .obl-swiper-container .swiper-slide {
                overflow: visible !important;
                max-width: 310px !important;
            }
            .swiper-pagination-bullet {
                width: 8px;
                height: 8px;
                background: #bbb;
                opacity: 1;
            }
            .swiper-pagination-bullet-active {
                background: #333;
            }
            /* --- Card Container --- */

            /* --- Image --- */
            .obl-cta-image img {
                width: 100%;
                height: auto;
                display: block;
                border-bottom: 1px solid rgba(0,0,0,0.05);
            }

            /* --- Price --- */
            .obl-cta-price-wrap {
                margin-bottom: 25px;
                display: flex;
                align-items: baseline;
                gap: 8px;
            }
            .obl-cta-price {
                font-size: 2rem;
                font-weight: 400; /* Serif style often looks lighter */
                font-family: var(--e-global-typography-accent-font-family), serif; /* Try to grab accent font */
            }
            /* Remove WooCommerce default symbol styling if it conflicts */
            .obl-cta-price .woocommerce-Price-amount {
                font-weight: 600; 
            }
            .obl-cta-suffix {
                font-size: 1rem;
                opacity: 0.8;
                font-weight: 400;
            }

            /* --- Button --- */
            .obl-cta-button {
                display: block;
                width: 100%;
                background-color: var(--e-global-color-accent);
                color: var(--e-global-color-3be427c) !important;
                text-align: center;
                padding: 10px;
                border-radius: 8px;
                font-size: 16px;
                font-weight: 600;
                transition: background 0.3s;
                margin-bottom: 15px;
            }
            .obl-cta-button:hover {
                background-color: #a81545;
                color: #fff;
            }

            /* --- List --- */
            .obl-cta-list-title {
                font-size: 1.2rem !important;
                margin-bottom: 10px;
                font-family: var(--e-global-typography-accent-font-family) "Aileron", sans-serif !important;
                text-transform: capitalize !important;
                font-weight: 600;
            }
            .obl-cta-ul {
                list-style: none;
                padding: 0;
                margin: 0;
            }
            .obl-cta-li {
                display: flex;
                align-items: flex-start;
                gap: 10px;
                margin-bottom: 8px;
                font-size: 1rem;
                line-height: 1.5;
            }
            .obl-cta-icon {
                width: 20px;
                height: 20px;
                flex-shrink: 0;
                margin-top: 4px; /* Align with text top */
            }
            .obl-cta-image-wrap {
                display: flex;
            }
            .obl-cta-image-wrap img {
                width: 100%;
                max-width: 300px;
                margin: 0.5em auto;
            }
            /* Video Wrapper */
            .obl-video-wrapper {
                padding: 0;
                margin-bottom: -1em;
            }
            .obl-video-wrapper iframe {
                border-radius: 15px;
            }

			/** Learndash Focus Mode Stylings */
			.ld-in-focus-mode .learndash-wrapper,
			.ld-in-focus-mode .learndash-wrapper .ld-focus .ld-focus-header,
			.ld-in-focus-mode .learndash-wrapper .ld-focus .ld-focus-header .ld-brand-logo,
			.ld-in-focus-mode .learndash-wrapper .ld-focus .ld-focus-sidebar,
			.ld-in-focus-mode .ld-course-navigation .ld-lesson-item,
			.ld-in-focus-mode .ld-course-navigation .ld-lesson-item-expanded,
			.ld-in-focus-mode .ld-course-navigation .ld-topic-list.ld-table-list::before {
				background: var(--e-global-color-3be427c) !important;
			}
            .ld-focus .ld-focus-header .ld-progress .ld-progress-bar {
                background: white !important;
            }            
			.ld-in-focus-mode .ld-course-navigation .ld-topic-list.ld-table-list {
				background-color: #d4dbd6 !important;
			}
			.ld-in-focus-mode .ld-status-icon.ld-status-incomplete {
				border: 4px solid #d4dbd6 !important;
			}
			.ld-in-focus-mode .ld-course-navigation .ld-topic-list.ld-table-list .ld-status-icon.ld-status-incomplete {
				border: 4px solid var(--e-global-color-3be427c) !important;
			}
			.ld-in-focus-mode h1 {
				font-size: 40px !important;
			}
			.ld-in-focus-mode .ld-breadcrumbs {
				background: #d4dbd6 !important;
				padding: 1rem !important;
			}
			.ld-in-focus-mode .ld-breadcrumbs .ld-status {
				margin-bottom: 0 !important;
			}
			.ld-in-focus-mode .ld-breadcrumbs .ld-breadcrumbs-segments {
				text-overflow: initial;
				white-space: normal;
				line-height: 1.4rem;
			}
			.ld-in-focus-mode .ld-lesson-item-preview-heading {
				color: var(--e-global-color-49967e4) !important;
				font-size: var(--e-global-typography-f28ab0e-font-size) !important;
			}

            /** Mobile Design */
            @media only screen and (max-width: 768px) {
                .ld-in-focus-mode h1 {
                    font-size: 28px !important;
                    line-height: 1.2em;
                    letter-spacing: -1px;
                }
                .ld-focus-main .ld-focus-content,
                .ld-focus-header .ld-content-action .sfwd-mark-complete {
                    margin: 0 !important;
                }
            }