/* --- TEMA BEIGE --- */
:root {
    --primary-navy: #073C57;
    --warm-orange: #C75128;
    --mustard-yellow: #DBA939;
    --teal: #137C74;
    --soft-pink: #FF4667;
    --light-beige: #F5F1E9;
    --off-white: #FFFBF8;
    --text-dark: #222;
    --text-light: #fff;
    --soft-info: #5625E8;
    --soft-danger: #E70D0D;
    --soft-purple: #F0DEF3;
    --soft-success: #03C95A;
    --soft-primary-navy: #E6F2F7;
    --soft-warm-orange:#F7C9BD;

    

}
html, body {
  overflow-x: hidden;
}

.main-content {
  overflow-x: hidden;
}

.popular-courses-section {
  overflow-x: hidden;
}

.hero-image {
  width: 100%;
  max-width: 700px;
  height: auto;
}

body { font-family: 'Poppins', sans-serif; background-color: var(--light-beige); }
.main-content { margin: 0 !important; padding: 0 !important; }

/* Header & Footer (Tetap gelap untuk kontras) */
.navbar-top { background: var(--primary-navy) !important; box-shadow: unset !important; color: var(--primary-navy); padding-top: 15px; padding-bottom: 15px; }
.navbar-brand { color: var(--off-white) !important; }
.navbar-nav .nav-link { color: var(--off-white) !important; font-weight: 600; font-size: 18px !important;  }
.navbar-nav .nav-link.active, .navbar-nav .nav-link.show { color: var(--warm-orange) !important; }
.site-footer { background-color: var(--primary-navy); }
.site-footer-copyright { background-color: var(--warm-orange); }

/* Hero Section (Light) */
.hero-section-corporate {background-image: url('/images/bg2.png'); background-size: cover; background-position: center; }
.hero-section-corporate h1{ font-weight: 700 !important; color: var(--primary-navy); }
.hero-section-corporate h1 span.highlight { color: var(--warm-orange); }
.hero-section p { opacity: 0.9; }
.hero-section .btn-hero-primary { background-color: var(--primary-navy); color: var(--text-light); border-color: var(--primary-navy); }
.hero-section .btn-hero-secondary { background-color: transparent; color: var(--primary-navy); border-color: var(--primary-navy); }
.hero-image{width: 700px;}

/* Why Choose Us (White Background) */
.why-choose-section { background-color: var(--off-white); padding: 6rem 0;}
.section-title { font-weight: 700; color: var(--primary-navy); margin-bottom: 3rem; text-align: center; position: relative;}
.section-title::after{content: "";
    position: absolute;
    display: block;
    width: 70px;
    height: 4px;
    background: var(--warm-orange);
    transform: translate(-50%, -50%);
    left: 50%;
    right: 50%;
    bottom: -17px;
}
.why-choose-section .section-title::after{left: unset; right: unset; transform: unset;}
.feature-item { margin-bottom: 31px;}
.feature-icon { padding: 5px; border-radius: 50px; background: #EBE9F1; display: flex; align-items: center; justify-content: center;margin-right: 16px; }
.feature-item h5 { font-weight: 600; color: var(--warm-orange); }
.feature-item h5 span { color: var(--primary-navy); }


/* Popular Courses (Beige Background) */
.popular-courses-section { background-color: var(--light-beige); padding: 6rem 0; }
.popular-courses-section .slick-slide {margin: 0 12px;}
.popular-courses-section .slick-prev {
    z-index: 99;
    background: var(--white);
    border: 1px solid var(--gray-100);
    width: 44px;
    height: 44px;
    border-radius: 1.5rem;
    left: -22px;
    top: 50%;
}
.popular-courses-section .slick-next {
    z-index: 99;
    background: var(--white);
    border: 1px solid var(--gray-100);
    width: 44px;
    height: 44px;
    border-radius: 1.5rem;
    right: -22px;
    top: 50%;
}
.popular-courses-section .slick-prev::before,
.popular-courses-section .slick-next::before {
   color: var(--text-dark);
    font-size: 35px;
    font-weight: 900;
}
.course-card { background: var(--off-white); border-radius: 10px; box-shadow: 0 8px 20px rgba(0,0,0,0.05); height: 100%;  overflow: hidden; padding: 20px;}
.course-card-img { height: 220px; object-fit: cover; border-radius: 10px; width: 100%; margin-bottom: 24px;}
.course-card-body { padding: 0; }
.course-card-body h6 { font-weight: 700; line-height: 1.5s; min-height: 2em;}
.course-price { font-weight: 800; color: var(--teal); margin-bottom: 0; }
.course-rating { color: #FFC107;}
.avatar {width: 24px; height: 24px;;}
.btn-outline-warm-orange, .btn-warm-orange:hover{ border-color: var(--warm-orange) !important; color: var(--warm-orange);}
.btn-warm-orange, .btn-outline-warm-orange:hover{background-color: var(--warm-orange); color: var(--off-white);}
.btn-outline-primary-navy { border-color: var(--primary-navy); color: var(--primary-navy);}
.btn-primary-navy, .btn-outline-primary-navy:hover { background-color: var(--primary-navy); color: var(--off-white);}
.btn-course-main { background-color: var(--warm-orange); color: var(--text-light); font-size: 14px; border-radius: 10px; font-weight: 600; text-decoration: none; display: block; text-align: center; padding: 8px; }
.btn-course-cta {width: 200px; margin: auto; background-color: var(--primary-navy); color: var(--text-light); border-radius: 10px; font-weight: 600; text-decoration: none; display: block; text-align: center; padding: 8px 12px; }
.btn {border-radius: 8px !important;}

.btn-xl {font-size: 20px !important; font-weight: 600 !important;}
/* Testimonials (White Background) */
.testimonials-section { background-color: var(--off-white); padding: 6rem 0; }
.testimonial-card-content { position: relative; border: 1px solid #e7e7e7; border-radius:10px; padding: 20px;background: white; margin-bottom: 24px; }
.testimonial-card-content .feature-icon { color: var(--teal); }
.testimonial-name {color: var(--warm-orange);}
.testimonial-title {color: var(--primary-navy);}
.testimonials-section .section-title::after {left: unset; right: unset; transform: unset;}
.testimonial-card-content .avatar {width: 45px; height: 45px;}

/* ICON */
.icon {display: inline-block; width: 100px; height: 100px; background-size: contain; background-repeat: no-repeat; background-position: center; }
.icon-modern-platform { background-image: url('/images/modern-platform-icon.png'); }
.icon-expert-intruction {background-image: url('/images/expert-intruction-icon.png');}
.icon-active-community {background-image: url('/images/active-community-icon.png');}


/* bade */
.badge.badge-soft-info { background: rgba(86, 37, 232, 0.1);color: var(--soft-info); }
.badge.badge-soft-danger {background: rgba(231, 13, 13, 0.1);color: var(--soft-danger);}
.badge.badge-soft-purple {background: #F0DEF3 !important;color: var(--soft-purple) !important;}
.badge.badge-soft-success {background: rgba(3, 201, 90, 0.1);color: #03C95A;}


/* slick */
.slick-dots li button{font-size: 0;line-height: 0;display: block;width: 20px;height: 20px;padding: 5px;cursor: pointer;color: transparent;border: 0;outline: none;background: transparent;}
.slick-dots li button::before{display: none;}
.slick-dots li {width: 7px !important;height: 7px !important;border-radius: 10px;background: #D6D4E4;margin-right: 4px;}
.slick-dots li.slick-active {width: 15px !important;height: 7px;border-radius: 10px;background: var(--soft-pink);}



/* pager */
.pagination .page-link,
.page-item.disabled
 {
    width: 32px;
    height: 32px;
    background-color: #F8F8F8;
    border-radius: 50px !important;
    font-size: 14px;
    font-weight: 400;
    border: none;
    color: var(--gray-700);
    box-shadow: none;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: normal;
}

.page-item.disabled {background-color: var(--gray-100);}

.pagination .page-item.active .page-link {
    background-color: var(--soft-pink);
    color: var(--text-light);
}

.course-row {
  gap:50px;
}

.course-content-section .card {
    background: var(--off-white);
}
.course-content-section h6,
.course-content-section h5 { 
    font-weight: 600;
}

.accordion {
    background-color: var(--off-white);
}

.icon-box {
    width: 56px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
}

 
.form-check-input[type=radio] {
   
    border-radius: 0.25em !important; 
}
.form-check-input[type=radio]:checked{
    background-color: var(--soft-pink);
    border-color: var(--soft-pink);
}
.course-content-section .form-check-input[type=radio]:checked:after{display: none;}

.course-content-section .form-check {
    padding-left: 1.5em;
    margin-bottom: 0.5rem !important; 
}

.form-check-label {
    margin-bottom: 0;
}


.category-filter,
.sort-filter {
    background: var(--off-white);
    border-radius: 10px;
    padding: 20px;;
}

.filter-area {
    padding-top: 60px;
}

.search-bar .form-control {
    background-color: var(--off-white);
    border-radius: 10px !important;
    padding: 20px;
    margin-right: 20px;
}

.text-pink {color: var(--soft-pink) !important;}
.text-teal {color: var(--teal);}
.text-primary-navy {color: var(--primary-navy);}
.text-warm-orange {color: var(--warm-orange);}
.text-mustard-yellow {color: var(--mustard-yellow);}
.text-soft-info {color: var(--soft-info);}
.text-soft-danger {color: var(--soft-danger);}
.text-soft-purple {color: var(--soft-purple);}
.text-purple {color: #392C7D !important;}
.text-soft-success {color: var(--soft-success);}
.bg-pink-transparant {background-color: #FFEDF0 !important;}
.bg-purple-transparant {background-color: var(--soft-purple);}
.bg-primary-navy-transparant {background-color: var(--soft-primary-navy) !important;}
.bg-warm-orange-transparant {background-color: var(--soft-warm-orange) !important;}
.bg-primary-navy{background-color: var(--primary-navy) !important;}





 .wishlist-btns a {
    padding: 10px;
 }

 .course-list-header {
        padding: 40px 0 40px;
    position: relative;
    z-index: 1;
    background: linear-gradient(90deg, #FEE0DE 0%, #E4F5FD 51.39%, #DDEDFF 100%);
 }

 .course-content-section {
    padding-top: 60px;
 }


 /* LOGIN */

 .form-column {
    background-color: var(--off-white);
 }

 .login-split .right-panel {
    /* background image - replace with your own or keep gradient */
    background-image: linear-gradient(135deg, rgba(10,25,47,0.9), rgba(40,80,120,0.85)), url('/images/login-bg.jpg');
    background-size: cover;
    background-position: center;
    color: #fff;
}

/* Course item hover */
.course-item-hover:hover {
    background-color: rgba(255,255,255,0.03) !important;
    box-shadow: 0 0.5rem 1rem rgba(0,0,0,0.25) !important;
    transform: translateY(-3px);
    transition: all 0.18s ease-in-out;
}

.field-loginform-rememberme {padding: 0;}

/* Floating input size tweak */
.form-floating > .form-control {
    height: calc(3.5rem + 2px);
    padding: 1rem 0.75rem;
}

.img-login {
    width: 800px;
    height: 400px;
}

/* Course card: slight transparency + blur on large screens */
.course-card {
    backdrop-filter: blur(4px);
}
.card {
    background-color: var(--off-white);
}



.dashboard-tabs .tab-content {
    padding: 0 !important;
    background-color: transparent !important;
    border: 0 !important;
}
.dashboard-tabs .nav-link.active {background-color: transparent !important; border: 0 !important; color: var(--soft-pink) !important; border-bottom: 1px solid var(--soft-pink) !important;}


/* Ensure the right panel content scrolls nicely on small screens */
@media (max-width: 991.98px) {
    .login-split .right-panel {
        min-height: 40vh;
        background-position: top center;
    }
    .course-list {
        max-height: 34vh !important;
    }
}

/* Mobile: stack form then course panel */
@media (max-width: 767.98px) {
    .min-vh-100 { min-height: auto; }
    .login-split .right-panel {
        padding-top: 1rem;
        padding-bottom: 2rem;
    }
}


 /* Small devices (landscape phones, less than 768px) */
@media (max-width: 767.98px) {
    /* HERO SECTION */
    .hero-section-corporate{padding-top: 50px !important; background-image: none !important;}

    /* Testimonial */

    .testimonials-section .section-title::after{transform: translate(-50%, -50%) !important; left: 50% !important; right: 50% !important}


    /* BTN */
    .btn-xl {font-size: 14px !important;  font-weight: 600 !important;}

    /* Slick */
    .slick-arrow {display: none !important;}


}


/*  Medium devices (tablets, less than 992px) */
@media (max-width: 991.98px) { 
    /* HERO SECTION */
    .hero-section-corporate{padding-top: 50px !important; padding-bottom: 50px !important; background-image: none !important;}

}



.progress-circle {
    width: 100px;
    height: 100px;
    display: grid;
    place-items: center;
    border-radius: 50%;
    background: conic-gradient(
        var(--soft-pink) calc(var(--progress) * 1%), 
        #e9ecef calc(var(--progress) * 1%)
    );
}

.progress-circle .progress-value {
    width: 85px;
    height: 85px;
    display: grid;
    place-items: center;
    border-radius: 50%;
    background: #ffffff;
    font-weight: bold;
    font-size: 1.2rem;
    color: #333;
}


/* ========================================= */
/* HALAMAN KONTAK V2 (MODERN SPLIT) */
/* ========================================= */

.contact-page-v2 .container {
    max-width: 1200px; /* Membatasi lebar kontainer utama */
}

/* * 1. STYLING KOLOM INFO (KIRI / BIRU) 
 */
.contact-page-v2 .info-item-v2 {
    display: flex;
    align-items: flex-start;
    margin-bottom: 1.5rem;
}

.contact-page-v2 .info-item-v2 .info-icon {
    flex-shrink: 0;
    width: 30px; 
    font-size: 1.1rem; /* Sedikit lebih kecil agar rapi */
    opacity: 0.8;
    margin-top: 5px;
}

.contact-page-v2 .info-item-v2 .info-content {
    margin-left: 1rem;
}

.contact-page-v2 .info-item-v2 .info-content h6 {
    font-weight: 700;
    margin-bottom: 0.2rem;
    color: #ffffff; /* Teks putih */
}

.contact-page-v2 .info-item-v2 .info-content p {
    margin-bottom: 0;
    color: #ffffff; /* Teks putih */
    opacity: 0.8; /* Sedikit transparan */
    line-height: 1.5;
}

/* Tombol Sosial Media */
.contact-page-v2 .social-icons .btn-circle {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
}
.contact-page-v2 .social-icons .btn-outline-light:hover {
    background-color: #ffffff;
    color: var(--bs-primary);
}


/* * 2. STYLING FORMULIR (KANAN / PUTIH) 
 */

/* Label formulir */
.contact-page-v2 .form-label {
    font-weight: 600;
    font-size: 0.9rem;
    color: #495057;
    margin-bottom: 0.3rem;
}


.contact-page-v2 .form-control-modern {
    background-color: #f8f9fa; /* Latar abu-abu sangat muda */
    border: 0; /* Tanpa border */
    border-radius: 0.5rem; /* Sudut lebih bulat */
    padding: 0.9rem 1rem;
    transition: all 0.2s ease-in-out;
}

/* Efek saat input di-klik (focus) */
.contact-page-v2 .form-control-modern:focus {
    background-color: #ffffff; /* Kembali ke putih */
    border: 1px solid var(--bs-primary); /* Tampilkan border primary */
    box-shadow: 0 0 0 0.25rem rgba(var(--bs-primary-rgb), 0.15); /* Shadow tipis */
}

/* Tombol Kirim */
.contact-page-v2 .btn-primary {
    padding: 0.9rem;
    font-weight: 600;
}


    .lesson-card {
        background: var(--off-white);
        border-radius: 16px;
        box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05);
        padding: 0; 
        margin: 40px auto;
        max-width: 980px;
        overflow: hidden; 
    }

    .card-header-custom {
        padding: 30px 30px 20px 30px;
        border-bottom: 1px solid #f0f0f0;
    }

    .lesson-title {
        font-family: 'Segoe UI', sans-serif;
        font-weight: 700;
        color: #2c3e50;
        font-size: 2rem;
        margin: 0 0 10px 0;
    }

    .lesson-meta {
        display: flex;
        gap: 15px;
        color: #888;
        font-size: 0.9rem;
        align-items: center;
    }
    .meta-item {
        display: flex;
        align-items: center;
    }
    .meta-item i { 
        margin-right: 5px;
    }
    .badge-category {
        background-color: #e3f2fd;
        color: #1976d2;
        padding: 4px 10px;
        border-radius: 20px;
        font-weight: 600;
        font-size: 0.8rem;
    }

    .card-body-custom {
        padding: 30px;
    }

    .embed-container {
        position: relative;
        padding-bottom: 56.25%;
        height: 0;
        overflow: hidden;
        border-radius: 12px;
        box-shadow: 0 4px 12px rgba(0,0,0,0.1);
        background: #000;
    }
    .embed-container iframe {
        position: absolute;
        top: 0; left: 0; width: 100%; height: 100%; border: 0;
    }

    .lesson-description {
        margin-top: 25px;
        color: #555;
        line-height: 1.6;
        font-size: 1rem;
    }
    .description-label {
        font-weight: bold;
        color: #333;
        display: block;
        margin-bottom: 8px;
        text-transform: uppercase;
        font-size: 0.85rem;
        letter-spacing: 1px;
    }
    .card-footer-custom {
        background-color: #fafafa;
        padding: 20px 30px;
        border-top: 1px solid #eee;
        display: flex;
        justify-content: space-between; 
        align-items: flex-end;
    }