﻿/* ============================================================
   Course Central – Public Stylesheet  v2.0 (Phase 3)
   ============================================================ */

:root {
    --cc-p:     #4f46e5;
    --cc-ph:    #4338ca;
    --cc-sec:   #06b6d4;
    /* Prefer BCM theme tokens when present to keep pages consistent */
    --cc-text:  var(--bcm-text, #1e293b);
    --cc-muted: var(--bcm-text-muted, #64748b);
    --cc-border:var(--bcm-border, #e2e8f0);
    --cc-bg:    var(--bcm-bg, #f8fafc);
    --cc-card:  var(--bcm-surface, #ffffff);
    --cc-r:     8px;
    --cc-shadow:0 1px 3px rgba(0,0,0,.08);
    --cc-clip:  polygon(18px 0%,calc(100% - 18px) 0%,100% 18px,100% calc(100% - 18px),calc(100% - 18px) 100%,18px 100%,0% calc(100% - 18px),0% 18px);
    --cc-drop:  drop-shadow(5px 5px 0 rgba(15,23,42,.12));
}

/* ── Dark mode — mirrors BCM [data-theme="dark"] on <html> ─────────────────── */
[data-theme="dark"] {
    /* Keep aligned with BCM dark variables */
    --cc-text:  var(--bcm-text, #e2e8f0);
    --cc-bg:    var(--bcm-bg, #0f172a);
    --cc-card:  var(--bcm-surface, #1e293b);
    --cc-muted: var(--bcm-text-muted, #94a3b8);
    --cc-border:var(--bcm-border, #334155);
    --cc-shadow:0 1px 3px rgba(0,0,0,.35);
    --cc-drop:  drop-shadow(5px 5px 0 rgba(0,0,0,.4));
}
[data-theme="dark"] .cc-single-course { background: var(--cc-bg); }
[data-theme="dark"] .cc-panel { background: var(--cc-card); }
[data-theme="dark"] .cc-panel-desc { color: #cbd5e1; }
[data-theme="dark"] .cc-panel-title,
[data-theme="dark"] .cc-panel-subtitle { color: var(--cc-text); }
[data-theme="dark"] .cc-sec-nav-wrap { background: var(--cc-bg); border-bottom-color: var(--cc-border); }
[data-theme="dark"] .cc-accordion-section { border-color: var(--cc-border); }
[data-theme="dark"] .cc-accordion-header { background: #1e293b; color: var(--cc-text); }
[data-theme="dark"] .cc-accordion-header:hover { background: #243557; }
[data-theme="dark"] .cc-accordion-body { border-top-color: var(--cc-border); background: #0f172a; }
[data-theme="dark"] .cc-lesson-row { color: var(--cc-text); border-bottom-color: #1e293b; }
[data-theme="dark"] .cc-lesson-row:hover { background: #1e293b; }
[data-theme="dark"] .cc-price-box { border-color: var(--cc-border); background: var(--cc-card); }
[data-theme="dark"] .cc-price-disc,
[data-theme="dark"] .cc-price-main { color: #e2e8f0; }
[data-theme="dark"] .cc-detail-value { color: var(--cc-text); }
[data-theme="dark"] .cc-learn-item { color: var(--cc-text); }
[data-theme="dark"] .cc-includes-item { color: var(--cc-text); }
[data-theme="dark"] #cc-support-widget { background: var(--cc-card); border-color: var(--cc-border); }
[data-theme="dark"] .cc-sw-messages { background: #0f172a; }
[data-theme="dark"] .cc-sw-msg-admin { background: #1e293b; color: #e2e8f0; border-color: #334155; }
[data-theme="dark"] .cc-sw-form { background: #1e293b; border-top-color: #334155; }
[data-theme="dark"] .cc-sw-form input[type=text] { background: #0f172a; color: #e2e8f0; border-color: #334155; }
[data-theme="dark"] .cc-sw-login-prompt { color: #94a3b8; }
[data-theme="dark"] .cc-suggest-card { background: var(--cc-card); }
[data-theme="dark"] .cc-suggest-title { color: var(--cc-text); }

*, *::before, *::after { box-sizing: border-box; }

/* ── Wrapper ───────────────────────────────────────────────── */
.cc-single-course { background: var(--cc-bg); min-height: 60vh; padding-bottom: 60px; }

/* ══════════════════════════════════════════════════════════════
   HERO CAROUSEL
══════════════════════════════════════════════════════════════ */
.cc-hc-outer {
    position: relative;
    width: 85%;
    margin: 36px auto 0;
}
.cc-hc-panel {
    width: 100%;
    height: 399px;
    overflow: hidden;
    /* Smooth rounded corners (match Metallic cards) */
    clip-path: none;
    border-radius: var(--bcm-radius-card, 30px);
    filter: var(--cc-drop);
    background: #0f172a;
    position: relative;
}
.cc-hc-track {
    display: flex;
    height: 100%;
    transition: transform .45s cubic-bezier(.4,0,.2,1);
    will-change: transform;
}
.cc-hc-slide {
    flex: 0 0 100%;
    height: 100%;
    overflow: hidden;
}
.cc-hc-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    user-select: none;
}
/* Dots */
.cc-hc-dots {
    position: absolute;
    bottom: 14px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 8px;
    z-index: 5;
}
.cc-hc-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: rgba(255,255,255,.45);
    border: 2px solid rgba(255,255,255,.6);
    cursor: pointer;
    padding: 0;
    transition: background .2s, transform .2s;
}
.cc-hc-dot-active,
.cc-hc-dot:hover {
    background: #fff;
    transform: scale(1.25);
}
/* Arrows — sit outside the panel */
.cc-hc-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: rgba(255,255,255,.92);
    color: var(--cc-text);
    border: 2px solid var(--cc-border);
    font-size: 14px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
    box-shadow: 0 2px 8px rgba(0,0,0,.18);
    transition: background .15s, transform .15s;
}
.cc-hc-arrow:hover { background: var(--cc-p); color: #fff; border-color: var(--cc-p); }
.cc-hc-prev { left: -19px; }
.cc-hc-next { right: -19px; }

/* ── Carousel Title Overlay — centred ───── */
.cc-hc-title-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    display: flex;
    align-items: center;          /* vertical center */
    justify-content: center;      /* horizontal center */
    text-align: center;
    background: linear-gradient(to bottom, rgba(0,0,0,.55) 0%, rgba(0,0,0,.18) 60%, transparent 100%);
    padding: 20px 24px;
    z-index: 6;
    pointer-events: none;
}
.cc-hc-course-title {
    color: #fff;
    font-size: 32px;
    font-weight: 800;
    margin: 0;
    line-height: 1.25;
    text-shadow: 0 2px 12px rgba(0,0,0,.7);
    word-break: break-word;
    max-width: 85%;
    letter-spacing: -0.4px;
}
@media (max-width: 640px) {
    .cc-hc-course-title { font-size: 20px; max-width: 92%; }
    .cc-hc-title-overlay { padding: 14px 16px; }
}

/* ══════════════════════════════════════════════════════════════
   PAGE CONTENT WRAPPER
══════════════════════════════════════════════════════════════ */
.cc-page-content {
    width: 85%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 0 40px;
}

/* ══════════════════════════════════════════════════════════════
   SECTION NAV TABS
══════════════════════════════════════════════════════════════ */
.cc-sec-nav-wrap {
    display: flex;
    align-items: center;
    margin: 32px 0 22px;
    gap: 4px;
    position: sticky;
    top: 0;
    z-index: 200;
    background: var(--cc-bg);
    border-bottom: 2px solid var(--cc-border);
    padding: 0 0 0 0;
}
.cc-sec-nav {
    flex: 1;
    display: flex;
    overflow-x: auto;
    gap: 0;
    scroll-behavior: smooth;
    scrollbar-width: none;
}
.cc-sec-nav::-webkit-scrollbar { display: none; }
.cc-sec-tab {
    flex-shrink: 0;
    padding: 12px 18px;
    font-size: 13px;
    font-weight: 600;
    color: var(--cc-muted);
    text-decoration: none;
    border-bottom: 3px solid transparent;
    margin-bottom: -2px;
    transition: color .15s, border-color .15s;
    white-space: nowrap;
}
.cc-sec-tab:hover { color: var(--cc-p); }
.cc-sec-tab-active { color: var(--cc-p); border-bottom-color: var(--cc-p); }
.cc-sec-nav-arrow {
    background: transparent;
    border: none;
    color: var(--cc-muted);
    cursor: pointer;
    font-size: 12px;
    padding: 4px 6px;
    transition: color .15s;
    flex-shrink: 0;
}
.cc-sec-nav-arrow:hover { color: var(--cc-p); }

/* ══════════════════════════════════════════════════════════════
   CHAMFERED PANEL — C-TYPE CORNERS
══════════════════════════════════════════════════════════════ */
.cc-panel {
    background: var(--cc-card);
    clip-path: var(--cc-clip);
    filter: var(--cc-drop);
    padding: 32px 36px;
    margin-bottom: 28px;
    outline: none;
}
.cc-panel-title {
    font-size: 24px;
    font-weight: 800;
    color: var(--cc-text);
    margin: 0 0 18px;
    line-height: 1.25;
    letter-spacing: -0.3px;
}
.cc-panel-subtitle {
    font-size: 16px;
    font-weight: 700;
    color: var(--cc-text);
    margin: 0 0 14px;
}
.cc-panel-desc {
    font-size: 16px;
    line-height: 1.75;
    color: #334155;
    margin: 0 0 4px;
}
.cc-divider {
    border: none;
    border-top: 1px solid var(--cc-border);
    margin: 18px 0;
}

/* ══════════════════════════════════════════════════════════════
   COURSE DETAILS  — detail rows
══════════════════════════════════════════════════════════════ */
.cc-detail-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px 20px;
    padding: 4px 0;
}
.cc-detail-meta-row { gap: 10px 24px; }
.cc-detail-info-row { gap: 8px 22px; }
.cc-detail-rating {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 13px;
    color: var(--cc-text);
}
.cc-rating-num  { font-weight: 700; color: #d97706; }
.cc-rating-count { color: var(--cc-muted); font-size: 12px; }
.cc-detail-students {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 13px;
    color: var(--cc-muted);
}
.cc-detail-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}
.cc-tag-pill {
    display: inline-flex;
    align-items: center;
    padding: 2px 9px;
    border-radius: 20px;
    color: #fff;
    font-size: 11px;
    font-weight: 600;
    background: var(--cc-p);
    box-shadow: 0 2px 6px rgba(0,0,0,0.35);
}
.cc-detail-label {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--cc-muted);
    white-space: nowrap;
}
.cc-detail-value { font-size: 14px; color: var(--cc-text); font-weight: 500; }
.cc-author-name  { color: var(--cc-p); font-weight: 600; }
.cc-detail-info-item {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 12.5px;
    color: var(--cc-muted);
}

/* ══════════════════════════════════════════════════════════════
   PRICING GRID
══════════════════════════════════════════════════════════════ */
.cc-pricing-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    margin-top: 4px;
}
.cc-price-box {
    flex: 1 1 200px;
    border: 1.5px solid var(--cc-border);
    border-radius: 10px;
    padding: 18px 20px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    min-width: 180px;
}
.cc-price-dur-lbl {
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--cc-p);
}
.cc-price-row {
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 6px;
}
.cc-price-orig { font-size: 14px; color: var(--cc-muted); }
.cc-price-disc { font-size: 22px; color: #0f172a; }
.cc-price-main { font-size: 22px; color: #0f172a; }
.cc-price-free { font-size: 22px; color: #16a34a; }
.cc-disc-badge {
    display: inline-flex;
    align-items: center;
    padding: 2px 7px;
    border-radius: 4px;
    background: #fef9c3;
    color: #92400e;
    font-size: 11px;
    font-weight: 700;
    border: 1px solid #fde68a;
}
.cc-offer-timer {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 11.5px;
    color: #b45309;
    background: #fffbeb;
    border: 1px solid #fde68a;
    border-radius: 6px;
    padding: 4px 10px;
}
/* Enroll buttons: auto-width so they fit their text only */
.cc-enroll-btn,
.cc-enroll-btn-free {
    align-self: flex-start;
    width: auto;
}
.cc-enrolled-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 13px;
    font-weight: 600;
    color: #16a34a;
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    border-radius: 6px;
    padding: 6px 14px;
}
.cc-enrolled-wrap {
    display: flex;
    flex-direction: column;
    gap: 8px;
    align-items: flex-start;
    margin-top: 4px;
}
.cc-start-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13.5px;
    font-weight: 600;
    color: #fff;
    background: var(--cc-p);
    border: none;
    border-radius: 6px;
    padding: 8px 18px;
    text-decoration: none;
    transition: background .15s;
}
.cc-start-btn:hover { background: var(--cc-ph); color: #fff; text-decoration: none; }
[data-theme="dark"] .cc-enrolled-badge { background: #052e16; border-color: #166534; color: #4ade80; }
[data-theme="dark"] .cc-start-btn { background: var(--cc-p); color: #fff; }

/* ══════════════════════════════════════════════════════════════
   RATING WIDGET (on details panel)
══════════════════════════════════════════════════════════════ */
.cc-rating-widget { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.cc-rate-stars { display: flex; gap: 3px; }
.cc-rate-star {
    font-size: 22px;
    color: #d1d5db;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0 1px;
    transition: color .15s, transform .1s;
    line-height: 1;
}
.cc-rate-star:hover,
.cc-rate-star.cc-star-lit { color: #f59e0b; transform: scale(1.2); }
.cc-rate-msg { font-size: 13px; color: var(--cc-muted); }

/* ══════════════════════════════════════════════════════════════
   WHAT YOU WILL LEARN  /  SKILLS
══════════════════════════════════════════════════════════════ */
.cc-learn-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.cc-learn-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px 24px;
}
.cc-learn-item {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: 13.5px;
    line-height: 1.55;
    color: var(--cc-text);
}
.cc-learn-check {
    flex-shrink: 0;
    width: 18px;
    height: 18px;
    background: #e0e7ff;
    color: var(--cc-p);
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 10px;
    font-weight: 700;
    margin-top: 1px;
}
.cc-skills-wrap { display: flex; flex-wrap: wrap; gap: 8px; }
.cc-skill-chip {
    display: inline-flex;
    align-items: center;
    padding: 5px 13px;
    border-radius: 20px;
    background: #ede9fe;
    color: var(--cc-p);
    font-size: 12.5px;
    font-weight: 600;
    border: 1px solid #c4b5fd;
}

/* ══════════════════════════════════════════════════════════════
   COURSE INCLUDES
══════════════════════════════════════════════════════════════ */
.cc-includes-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.cc-includes-item {
    display: flex;
    align-items: flex-start;
    gap: 9px;
    font-size: 13.5px;
    color: var(--cc-text);
    line-height: 1.55;
}
.cc-inc-icon { flex-shrink: 0; color: var(--cc-p); font-size: 9px; margin-top: 4.5px; }

/* ══════════════════════════════════════════════════════════════
   COURSE CONTENT SUMMARY LINE
══════════════════════════════════════════════════════════════ */
.cc-content-summary {
    font-size: 12.5px;
    color: var(--cc-muted);
    margin: -10px 0 18px;
}

/* ══════════════════════════════════════════════════════════════
   ACCORDION (Course Content)
══════════════════════════════════════════════════════════════ */
.cc-accordion { display: flex; flex-direction: column; gap: 8px; }
.cc-accordion-section { border: 1px solid var(--cc-border); border-radius: 8px; overflow: hidden; }
.cc-accordion-header {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 13px 18px;
    background: #f8fafc;
    border: none;
    cursor: pointer;
    font-size: 13.5px;
    font-weight: 700;
    color: var(--cc-text);
    text-align: left;
    transition: background .15s;
}
.cc-accordion-header:hover { background: #f1f5f9; }
.cc-acc-title  { flex: 1; }
.cc-acc-count  { font-size: 12px; color: var(--cc-muted); white-space: nowrap; }
.cc-acc-arrow  { font-size: 10px; color: var(--cc-muted); margin-left: 6px; transition: transform .2s; }
.cc-accordion-section.cc-acc-open .cc-acc-arrow { transform: rotate(180deg); }
.cc-accordion-body { display: none; border-top: 1px solid var(--cc-border); }
.cc-accordion-section.cc-acc-open .cc-accordion-body { display: block; }

/* ── Lesson rows ────────────────────────────────────────────── */
.cc-lesson-row {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 11px 18px;
    border-bottom: 1px solid #f1f5f9;
    font-size: 13px;
    color: var(--cc-text);
    transition: background .15s;
}
.cc-lesson-row:last-child { border-bottom: none; }
.cc-lesson-row:hover { background: #fafafa; }
.cc-lesson-icon { font-size: 12px; color: var(--cc-muted); flex-shrink: 0; }
.cc-lesson-title { flex: 1; line-height: 1.4; }
/* Enrolled: lesson title is a clickable link */
.cc-lesson-title-link {
    flex: 1;
    line-height: 1.4;
    color: var(--cc-text);
    text-decoration: none;
    font-weight: 500;
    transition: color .15s;
}
.cc-lesson-title-link:hover { color: var(--cc-p); text-decoration: none; }
/* Locked row (not enrolled) */
.cc-lesson-row--locked {
    opacity: .65;
    cursor: default;
    pointer-events: none;
}
.cc-lesson-row--locked .cc-lesson-icon { color: #94a3b8; }
.cc-lesson-open {
    font-size: 12px;
    font-weight: 600;
    color: var(--cc-p);
    text-decoration: none;
    white-space: nowrap;
    padding: 3px 10px;
    border-radius: 20px;
    border: 1px solid var(--cc-p);
    transition: background .15s, color .15s;
}
.cc-lesson-open:hover { background: var(--cc-p); color: #fff; }
.cc-locked-icon { font-size: 13px; color: #94a3b8; flex-shrink: 0; }

/* ══════════════════════════════════════════════════════════════
   LESSON PLAYER
══════════════════════════════════════════════════════════════ */
.cc-lesson-player { margin-bottom: 28px; }
.cc-player-top-bar {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 18px;
    flex-wrap: wrap;
}
.cc-player-htitle {
    font-size: 16px;
    font-weight: 700;
    color: var(--cc-text);
    margin: 0;
    flex: 1;
}
.cc-player-video {
    width: 100%;
    border-radius: 8px;
    overflow: hidden;
    background: #0f172a;
    aspect-ratio: 16/9;
    margin-bottom: 16px;
}
.cc-player-video iframe,
.cc-player-video video {
    width: 100%;
    height: 100%;
    display: block;
    border: none;
}
.cc-player-desc {
    font-size: 14px;
    line-height: 1.7;
    color: #334155;
    margin-bottom: 16px;
}
.cc-player-resources { display: flex; flex-direction: column; gap: 10px; }
.cc-btn-link {
    background: none;
    border: none;
    color: var(--cc-p);
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
    padding: 0;
    font-size: 13px;
}
.cc-btn-link:hover {
    color: var(--cc-ph);
    text-decoration: none;
}
.cc-btn-outline {
    background: transparent;
    color: var(--cc-p);
    border: 2px solid var(--cc-p);
}
.cc-btn-outline:hover { background: var(--cc-p); color: #fff; }

/* ══════════════════════════════════════════════════════════════
   SUGGESTED COURSES
══════════════════════════════════════════════════════════════ */
.cc-suggestions { margin-bottom: 32px; }
.cc-suggestions-title {
    font-size: 20px;
    font-weight: 800;
    color: var(--cc-text);
    margin: 0 0 18px;
}
.cc-suggest-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}
.cc-suggest-card {
    background: var(--cc-card);
    clip-path: var(--cc-clip);
    filter: var(--cc-drop);
    text-decoration: none;
    color: inherit;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    transition: filter .2s;
}
.cc-suggest-card:hover {
    filter: drop-shadow(6px 6px 0 rgba(79,70,229,.2));
}
.cc-suggest-thumb { height: 140px; overflow: hidden; background: #e0e7ff; flex-shrink: 0; }
.cc-suggest-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .35s; }
.cc-suggest-card:hover .cc-suggest-thumb img { transform: scale(1.04); }
.cc-suggest-body { padding: 14px 16px; display: flex; flex-direction: column; flex: 1; gap: 6px; }
.cc-suggest-title { font-size: 14px; font-weight: 700; color: var(--cc-text); margin: 0; line-height: 1.4; }
.cc-suggest-desc  { font-size: 12px; color: var(--cc-muted); margin: 0; overflow: hidden; display: -webkit-box; line-clamp: 2; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
.cc-suggest-foot  { display: flex; justify-content: space-between; align-items: center; margin-top: auto; padding-top: 8px; }
.cc-suggest-rating { display: flex; align-items: center; gap: 3px; font-size: 11.5px; color: #d97706; }
.cc-suggest-price  { font-size: 13px; font-weight: 700; color: var(--cc-p); }

/* ══════════════════════════════════════════════════════════════
   COMMENTS SECTION
══════════════════════════════════════════════════════════════ */
.cc-comments-section { margin-bottom: 32px; }
.cc-comments-panel .panel-title,
.cc-comments-panel h2 { font-size: 18px; font-weight: 800; margin-bottom: 16px; }
.cc-comments-panel textarea { width: 100%; min-height: 90px; border: 1px solid var(--cc-border); border-radius: 6px; padding: 10px 14px; font-size: 13px; resize: vertical; }
.cc-comments-panel input[type=submit] { appearance: none; background: var(--cc-p); color: #fff; border: none; border-radius: 6px; padding: 9px 20px; font-size: 13px; font-weight: 600; cursor: pointer; }
.cc-comments-panel input[type=submit]:hover { background: var(--cc-ph); }

/* Star rating display (readonly, inside cards/ratings) */
.cc-star-fill  { color: #f59e0b; font-size: 14px; }
.cc-star-empty { color: #d1d5db; font-size: 14px; }

/* ══════════════════════════════════════════════════════════════
   ARCHIVE PAGE
══════════════════════════════════════════════════════════════ */
.cc-archive-wrap { max-width: 1180px; margin: 0 auto; padding: 32px 24px; }
.cc-archive-header { margin-bottom: 28px; }
.cc-archive-title { font-size: 28px; font-weight: 800; }
.cc-courses-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; }
.cc-course-card { background: var(--cc-card); border: 1px solid var(--cc-border); border-radius: var(--cc-r); overflow: hidden; box-shadow: var(--cc-shadow); transition: box-shadow .2s; }
.cc-course-card:hover { box-shadow: 0 8px 24px rgba(0,0,0,.1); }
.cc-card-link { display: block; text-decoration: none; }
.cc-card-thumb { height: 180px; background-size: cover; background-position: center; background-color: #e0e7ff; }
.cc-no-thumb { display: flex; align-items: center; justify-content: center; font-size: 48px; }
.cc-card-body { padding: 16px; }
.cc-card-tags { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 8px; }
.cc-card-title { font-size: 15px; font-weight: 700; margin: 0 0 6px; }
.cc-card-title a { text-decoration: none; color: var(--cc-text); }
.cc-card-title a:hover { color: var(--cc-p); }
.cc-card-desc { font-size: 13px; color: var(--cc-muted); margin: 0 0 10px; overflow: hidden; display: -webkit-box; line-clamp: 2; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
.cc-card-footer { display: flex; justify-content: space-between; align-items: center; }
.cc-card-stars { font-size: 13px; color: #f59e0b; }
.cc-card-price { font-weight: 700; font-size: 15px; color: var(--cc-p); }
.cc-no-courses { text-align: center; padding: 60px 20px; color: var(--cc-muted); }
.cc-archive-pagination { margin-top: 32px; display: flex; justify-content: center; }

/* ══════════════════════════════════════════════════════════════
   MISC BUTTONS
══════════════════════════════════════════════════════════════ */
.cc-btn { display: inline-flex; align-items: center; gap: 5px; padding: 8px 16px; border-radius: 6px; font-weight: 600; font-size: 13px; cursor: pointer; border: 2px solid transparent; text-decoration: none; transition: all .15s; }
.cc-btn-primary { background: var(--cc-p); color: #fff; border-color: var(--cc-p); }
.cc-btn-primary:hover { background: var(--cc-ph); border-color: var(--cc-ph); }
.cc-btn-ghost { background: transparent; color: var(--cc-muted); border-color: transparent; }
.cc-btn-ghost:hover { background: var(--cc-bg); color: var(--cc-text); }
.cc-btn-sm { padding: 5px 12px; font-size: 12px; }

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
    .cc-hc-outer { width: 94%; }
    .cc-page-content { width: 94%; }
    .cc-suggest-grid { grid-template-columns: 1fr 1fr; }
    .cc-learn-grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
    .cc-hc-outer { width: 100%; }
    .cc-hc-panel { height: 240px; }
    .cc-hc-prev { left: 6px; }
    .cc-hc-next { right: 6px; }
    .cc-panel { padding: 22px 20px; }
    .cc-suggest-grid { grid-template-columns: 1fr; }
    .cc-page-content { width: 100%; padding: 0 14px 32px; }
    .cc-sec-nav-wrap { margin-top: 18px; }
}
@media (max-width: 480px) {
    .cc-pricing-grid { flex-direction: column; }
    .cc-price-box { min-width: unset; }
}

/* ── Floating Support Chat Button ─────────────────────────────────────────── */
/* Positioned just above the BCM scroll-to-top button (bottom:20px, height:48px) */
#cc-support-fab-wrap {
    position: fixed;
    bottom: 82px;          /* 20px (scroll-top bottom) + 48px (scroll-top height) + 14px gap */
    right: 20px;           /* aligned with scroll-to-top right:20px */
    z-index: 99999;        /* highest layer — above all theme/admin elements */
    display: flex;
    flex-direction: column; /* chat window ABOVE; icon stays BELOW */
    align-items: flex-end;
    gap: 10px;
}

#cc-support-fab {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background: var(--cc-p, #4f46e5);
    color: #fff;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 18px rgba(79,70,229,.5);
    transition: transform .2s, box-shadow .2s, background .2s;
    flex-shrink: 0;
    position: relative;
}
@supports (box-shadow: 0 0 0 color-mix(in srgb, #000 10%, transparent)) {
    #cc-support-fab { box-shadow: 0 4px 18px color-mix(in srgb, var(--cc-p, #4f46e5) 55%, transparent); }
}
#cc-support-fab:hover {
    background: var(--cc-ph, #4338ca);
    transform: scale(1.1);
    box-shadow: 0 6px 26px rgba(79,70,229,.6);
}
@supports (box-shadow: 0 0 0 color-mix(in srgb, #000 10%, transparent)) {
    #cc-support-fab:hover { box-shadow: 0 6px 26px color-mix(in srgb, var(--cc-p, #4f46e5) 65%, transparent); }
}
/* Unread badge */
#cc-support-fab .cc-fab-badge {
    position: absolute;
    top: -3px;
    right: -3px;
    background: #ef4444;
    color: #fff;
    border-radius: 50%;
    width: 18px;
    height: 18px;
    font-size: 10px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid #fff;
    display: none;
}

#cc-support-widget {
    width: 320px;
    border-radius: 16px;
    background: var(--cc-card, #fff);
    box-shadow: var(--cc-shadow, 0 8px 40px rgba(0,0,0,.18));
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border: 1px solid var(--cc-border, #e2e8f0);
    transform-origin: bottom right;
    animation: cc-widget-open .2s ease;
    max-height: 460px;
    position: relative;
    z-index: 99998;
}
@keyframes cc-widget-open {
    from { opacity: 0; transform: scale(.92) translateY(8px); }
    to   { opacity: 1; transform: scale(1) translateY(0); }
}

.cc-sw-header {
    background: var(--cc-p, #4f46e5);
    color: #fff;
    padding: 14px 16px;
    display: flex;
    align-items: center;
    gap: 8px;
}
.cc-sw-name { font-weight: 700; font-size: 14px; flex: 1; }
.cc-sw-status { font-size: 11px; padding: 2px 8px; border-radius: 20px; font-weight: 600; }
.cc-sw-status-online  { background: rgba(255,255,255,.2); }
.cc-sw-status-offline { background: rgba(255,255,255,.15); color: #e2e8f0; }
.cc-sw-status-busy    { background: rgba(245,158,11,.3); color: #fef3c7; }
.cc-sw-close { background: transparent; border: none; color: #fff; font-size: 18px; cursor: pointer; padding: 0 2px; line-height: 1; opacity: .8; }
.cc-sw-close:hover { opacity: 1; }
.cc-sw-body { display: flex; flex-direction: column; flex: 1; overflow: hidden; }
.cc-sw-messages {
    flex: 1; padding: 12px 14px; overflow-y: auto; display: flex; flex-direction: column;
    gap: 8px; min-height: 180px; max-height: 280px; background: var(--cc-bg, #f8fafc);
}
.cc-sw-msg { padding: 8px 12px; border-radius: 12px; font-size: 13px; line-height: 1.5; max-width: 85%; word-break: break-word; }
.cc-sw-msg-user { background: var(--cc-p, #4f46e5); color: #fff; align-self: flex-end; border-bottom-right-radius: 4px; }
.cc-sw-msg-admin { background: var(--cc-card, #fff); color: var(--cc-text, #1e293b); border: 1px solid var(--cc-border, #e2e8f0); align-self: flex-start; border-bottom-left-radius: 4px; }
.cc-sw-form { display: flex; gap: 8px; padding: 10px 12px; border-top: 1px solid var(--cc-border, #e2e8f0); background: var(--cc-card, #fff); align-items: center; }
.cc-sw-form input[type=text] { flex: 1; border: 1px solid var(--cc-border, #e2e8f0); border-radius: 20px; padding: 8px 14px; font-size: 13px; outline: none; background: var(--cc-bg, #f8fafc); color: var(--cc-text, #1e293b); transition: border-color .15s, background .15s; }
.cc-sw-form input[type=text]:focus { border-color: var(--cc-p, #4f46e5); }
.cc-sw-send { width: 34px; height: 34px; border-radius: 50%; background: var(--cc-p, #4f46e5); color: #fff; border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: background .15s; }
.cc-sw-send:hover { background: var(--cc-ph, #4338ca); }
.cc-sw-media-btn { background: transparent; border: none; color: #94a3b8; cursor: pointer; padding: 0 4px; display: flex; align-items: center; flex-shrink: 0; transition: color .15s; }
.cc-sw-media-btn:hover { color: var(--cc-p, #4f46e5); }
.cc-sw-login-prompt { padding: 20px 16px; text-align: center; font-size: 13px; color: #64748b; line-height: 1.6; }
.cc-sw-login-prompt a { color: var(--cc-p, #4f46e5); font-weight: 600; text-decoration: none; }
.cc-sw-login-prompt a:hover { text-decoration: underline; }
.cc-sw-op-avatar { width: 30px; height: 30px; border-radius: 50%; object-fit: cover; border: 2px solid rgba(255,255,255,.4); flex-shrink: 0; }

@media (max-width: 480px) {
    #cc-support-fab-wrap { bottom: 70px; right: 12px; }
    #cc-support-widget { width: calc(100vw - 48px); }
}

/* ── Auth pages: completely hide the support chat FAB ───── */
body.cc-auth-page #cc-support-fab-wrap {
    display: none !important;
}

/* ============================================================
   BCM THEME COMPATIBILITY — Metallic Design Overrides
   Inherits --bcm-* custom properties from the active theme.
   ============================================================ */

/* — Sync primary colour and shadow with BCM tokens — */
:root {
    --cc-p:      var(--bcm-primary,     #3b82f6);
    --cc-ph:     #2563eb;               /* hover: slightly darker blue */
    --cc-shadow: var(--bcm-shadow,      6px 6px 0px #000000);
    --cc-r:      16px;                  /* fallback for small elements */
}

/* — Course panels: replace chamfered clip-path with metallic card — */
.cc-panel {
    background:    var(--bcm-metal-bg,     linear-gradient(145deg, #e0e0e0 0%, #fff 50%, #d1d1d1 100%));
    border:        var(--bcm-metal-border, 1px solid #c0c0c0);
    box-shadow:    var(--bcm-shadow,       6px 6px 0 #000);
    border-radius: 24px;
    clip-path:     none;
    filter:        none;
}
[data-theme="dark"] .cc-panel {
    background: var(--bcm-metal-dark,  linear-gradient(145deg,#2a2a2a,#444,#1a1a1a));
    border:     var(--bcm-metal-dark-border, 1px solid #444);
}

/* — Hero carousel panel: keep clip-path look, just update shadow — */
.cc-hc-panel {
    filter: var(--cc-drop);
    clip-path: var(--cc-clip);
}

/* — Section nav: pill-shaped metallic bar — */
.cc-sec-nav-wrap {
    background:    var(--bcm-metal-bg,     linear-gradient(145deg, #e0e0e0 0%, #fff 50%, #d1d1d1 100%));
    border:        var(--bcm-metal-border, 1px solid #c0c0c0);
    box-shadow:    3px 3px 0 var(--bcm-shadow-color, #000);
    border-bottom: var(--bcm-metal-border, 1px solid #c0c0c0);
    border-radius: var(--bcm-radius-pill,  60px);
    padding:       6px 12px;
    gap:           4px;
}
[data-theme="dark"] .cc-sec-nav-wrap {
    background: var(--bcm-metal-dark, linear-gradient(145deg,#2a2a2a,#444,#1a1a1a));
    border:     var(--bcm-metal-dark-border, 1px solid #444);
}
.cc-sec-tab {
    border-radius:   40px;
    border-bottom:   none !important;
    margin-bottom:   0;
    padding:         8px 18px;
}
.cc-sec-tab-active {
    background:        var(--bcm-primary, #3b82f6);
    color:             #fff !important;
    border-bottom:     none !important;
    border-bottom-color: transparent !important;
    box-shadow:        3px 3px 0 var(--bcm-shadow-color, #000);
}
.cc-sec-tab:hover { color: var(--bcm-primary, #3b82f6); }

/* — Price / enroll boxes — */
.cc-price-box {
    background:    var(--bcm-metal-bg,     linear-gradient(145deg, #e0e0e0 0%, #fff 50%, #d1d1d1 100%));
    border:        var(--bcm-metal-border, 1px solid #c0c0c0) !important;
    box-shadow:    var(--bcm-shadow,       6px 6px 0 #000);
    border-radius: 20px;
}
[data-theme="dark"] .cc-price-box {
    background: var(--bcm-metal-dark,  linear-gradient(145deg,#2a2a2a,#444,#1a1a1a));
    border:     var(--bcm-metal-dark-border, 1px solid #444) !important;
}

/* — Enroll / start buttons — */
.cc-enroll-btn,
.cc-enroll-btn-free,
.cc-start-btn {
    border-radius: var(--bcm-radius-pill, 60px);
    box-shadow:    3px 3px 0 var(--bcm-shadow-color, #000);
    transition:    background .15s, box-shadow .15s, transform .15s;
}
.cc-enroll-btn:hover,
.cc-enroll-btn-free:hover,
.cc-start-btn:hover {
    transform:  translate(-2px, -2px);
    box-shadow: 5px 5px 0 var(--bcm-shadow-color, #000);
}

/* — Accordion sections — */
.cc-accordion-section {
    border:        var(--bcm-metal-border, 1px solid #c0c0c0);
    border-radius: 16px;
}
.cc-accordion-header {
    background: var(--bcm-metal-bg,     linear-gradient(145deg, #e0e0e0 0%, #fff 50%, #d1d1d1 100%));
}
.cc-accordion-header:hover {
    background: linear-gradient(145deg, #d8d8d8 0%, #f5f5f5 50%, #cccccc 100%);
}
[data-theme="dark"] .cc-accordion-header { background: #1e293b; }
[data-theme="dark"] .cc-accordion-header:hover { background: #243557; }

/* — Suggested course cards — */
.cc-suggest-card {
    background:    var(--bcm-metal-bg,     linear-gradient(145deg, #e0e0e0 0%, #fff 50%, #d1d1d1 100%));
    border:        var(--bcm-metal-border, 1px solid #c0c0c0);
    box-shadow:    var(--bcm-shadow,       6px 6px 0 #000);
    border-radius: var(--bcm-radius-card,  30px);
}
[data-theme="dark"] .cc-suggest-card {
    background: var(--bcm-metal-dark, linear-gradient(145deg,#2a2a2a,#444,#1a1a1a));
    border:     var(--bcm-metal-dark-border, 1px solid #444);
}

/* ═══════════════════════════════════════════════════════════════════════════
   CHECKOUT MODAL
═══════════════════════════════════════════════════════════════════════════ */
.cc-checkout-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.55);
    z-index: 100000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 16px;
    opacity: 0;
    transition: opacity .2s;
}
.cc-checkout-overlay.is-open { opacity: 1; }

.cc-checkout-modal {
    background: var(--bcm-metal-bg, linear-gradient(145deg, #e8e8e8 0%, #fff 50%, #d4d4d4 100%));
    border: var(--bcm-metal-border, 2px solid #b0b0b0);
    box-shadow: var(--bcm-shadow, 8px 8px 0 #000);
    border-radius: var(--bcm-radius-card, 28px);
    width: 100%;
    max-width: 480px;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    transform: translateY(24px);
    transition: transform .22s cubic-bezier(.34,1.56,.64,1);
    position: relative;
}
.cc-checkout-overlay.is-open .cc-checkout-modal { transform: translateY(0); }

[data-theme="dark"] .cc-checkout-modal {
    background: var(--bcm-metal-dark, linear-gradient(145deg,#2a2a2a,#444,#1a1a1a));
    border-color: #555;
}

.cc-checkout-head {
    padding: 20px 24px 14px;
    border-bottom: 1px solid rgba(0,0,0,.08);
    display: flex;
    align-items: flex-start;
    gap: 12px;
}
.cc-checkout-title { font-size: 17px; font-weight: 700; margin: 0 0 3px; line-height: 1.3; }
.cc-checkout-subtitle { font-size: 13px; color: #64748b; margin: 0; }
.cc-checkout-close {
    margin-left: auto;
    background: none;
    border: none;
    font-size: 22px;
    cursor: pointer;
    color: #94a3b8;
    line-height: 1;
    padding: 0 2px;
    flex-shrink: 0;
}
.cc-checkout-close:hover { color: #0f172a; }

.cc-checkout-body { padding: 16px 24px 24px; overflow-y: auto; flex: 1; }

/* Gateway tabs */
.cc-gw-tabs {
    display: flex;
    gap: 8px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}
.cc-gw-tab {
    padding: 7px 16px;
    border-radius: 60px;
    border: 2px solid #cbd5e1;
    background: #fff;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: all .15s;
}
.cc-gw-tab.is-active, .cc-gw-tab:hover {
    background: #3b82f6;
    border-color: #3b82f6;
    color: #fff;
}
[data-theme="dark"] .cc-gw-tab { background: #1e293b; border-color:#334155; color:#e2e8f0; }
[data-theme="dark"] .cc-gw-tab.is-active { background:#3b82f6; border-color:#3b82f6; color:#fff; }

.cc-gw-panel { display: none; }
.cc-gw-panel.is-active { display: block; }

/* PayPal panel */
#cc-paypal-buttons { min-height: 48px; }

/* Card (Stripe) panel */
.cc-card-field-label { font-size: 12px; font-weight: 600; color: #64748b; margin-bottom: 4px; display: block; }
.cc-stripe-card-element {
    border: 2px solid #cbd5e1;
    border-radius: 12px;
    padding: 12px 14px;
    background: #fff;
    transition: border-color .15s;
}
.cc-stripe-card-element.StripeElement--focus { border-color: #3b82f6; }
.cc-stripe-card-element.StripeElement--invalid { border-color: #ef4444; }
[data-theme="dark"] .cc-stripe-card-element { background: #1e293b; border-color: #334155; color: #e2e8f0; }

.cc-checkout-err {
    color: #ef4444;
    font-size: 13px;
    margin: 8px 0 0;
    min-height: 18px;
}

.cc-checkout-submit {
    display: block;
    width: 100%;
    margin-top: 14px;
    padding: 12px;
    border-radius: 60px;
    border: none;
    background: linear-gradient(135deg, #3b82f6, #6366f1);
    color: #fff;
    font-size: 15px;
    font-weight: 700;
    cursor: pointer;
    box-shadow: 3px 3px 0 #000;
    transition: box-shadow .15s, transform .15s;
}
.cc-checkout-submit:hover { transform: translate(-2px,-2px); box-shadow: 5px 5px 0 #000; }
.cc-checkout-submit:disabled { opacity: .6; cursor: not-allowed; transform: none; box-shadow: 3px 3px 0 #000; }

.cc-checkout-success {
    text-align: center;
    padding: 28px 16px;
}
.cc-checkout-success .cc-success-icon { font-size: 52px; margin-bottom: 12px; }
.cc-checkout-success p { font-size: 16px; font-weight: 600; color: #10b981; }

/* Secure badge */
.cc-checkout-secure {
    text-align: center;
    font-size: 11px;
    color: #94a3b8;
    margin-top: 14px;
}
.cc-checkout-secure .dashicons { font-size: 13px; vertical-align: middle; }

/* ── Manual Payment panel ──────────────────────────────────────────────── */
.cc-manual-panel { display: flex; flex-direction: column; gap: 16px; }
.cc-manual-instructions { background: #1e293b; border: 1px solid #334155; border-radius: 10px; padding: 16px; }
.cc-manual-instructions h4 { margin: 0 0 10px; font-size: 14px; font-weight: 700; color: #f1f5f9; }
.cc-manual-steps { font-size: 13px; color: #94a3b8; line-height: 1.7; white-space: pre-line; }
.cc-manual-form { display: flex; flex-direction: column; gap: 6px; }
.cc-field-label { font-size: 13px; color: #94a3b8; }
.cc-manual-note {
    width: 100%; box-sizing: border-box;
    background: #1e293b; border: 1px solid #334155; border-radius: 8px;
    color: #f1f5f9; padding: 10px 12px; font-size: 13px; resize: vertical;
    font-family: inherit;
}
.cc-manual-note:focus { outline: none; border-color: #6366f1; }
.cc-manual-hint {
    font-size: 12px; color: #64748b; text-align: center;
    margin: 0; line-height: 1.5;
}

/* ── Plan countdown ────────────────────────────────────────────────────── */
.cc-plan-countdown {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    font-weight: 600;
    color: #f59e0b;
    background: rgba(245, 158, 11, 0.1);
    border: 1px solid rgba(245, 158, 11, 0.25);
    border-radius: 20px;
    padding: 3px 10px;
    margin: 8px 0;
}
.cc-plan-countdown .cc-clock-icon { font-size: 13px; }

/* ── Enrolled plan box ─────────────────────────────────────────────────── */
.cc-price-box--owned {
    border: 2px solid #10b981 !important;
    background: linear-gradient(145deg, #052e16, #064e3b) !important;
    position: relative;
}
.cc-enrolled-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 12px;
    font-weight: 700;
    color: #10b981;
    background: rgba(16,185,129,.15);
    border: 1px solid rgba(16,185,129,.3);
    border-radius: 20px;
    padding: 3px 10px;
    margin-bottom: 10px;
}
.cc-upgrade-btn {
    background: transparent;
    border: 2px solid #f59e0b;
    color: #f59e0b;
    border-radius: 8px;
    padding: 9px 18px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: background .18s, color .18s;
    margin-top: 8px;
}
.cc-upgrade-btn:hover { background: #f59e0b; color: #000; }

/* ── Upgrade modal ─────────────────────────────────────────────────────── */
.cc-upgrade-modal {
    position: fixed;
    inset: 0;
    z-index: 10000;
    display: none;
    align-items: center;
    justify-content: center;
}
.cc-upgrade-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, .75);
}
.cc-upgrade-box {
    position: relative;
    background: #0f172a;
    border: 1px solid #334155;
    border-radius: 16px;
    padding: 28px 24px;
    width: min(520px, 94vw);
    max-height: 80vh;
    overflow-y: auto;
    z-index: 1;
}
.cc-upgrade-box h3 {
    margin: 0 0 8px;
    font-size: 18px;
    font-weight: 800;
    color: #f1f5f9;
}
.cc-upgrade-notice {
    font-size: 12px;
    color: #f59e0b;
    background: rgba(245,158,11,.1);
    border: 1px solid rgba(245,158,11,.25);
    border-radius: 8px;
    padding: 8px 12px;
    margin: 0 0 18px;
    line-height: 1.5;
}
.cc-upgrade-close {
    position: absolute;
    top: 14px;
    right: 16px;
    background: transparent;
    border: none;
    color: #94a3b8;
    font-size: 22px;
    cursor: pointer;
    line-height: 1;
    padding: 4px 8px;
}
.cc-upgrade-close:hover { color: #f1f5f9; }
.cc-upgrade-plan-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: #1e293b;
    border: 1px solid #334155;
    border-radius: 10px;
    padding: 14px 16px;
    margin-bottom: 10px;
}
.cc-upgrade-plan-info { display: flex; flex-direction: column; gap: 3px; }
.cc-upgrade-plan-name { font-size: 15px; font-weight: 700; color: #f1f5f9; }
.cc-upgrade-plan-price { font-size: 13px; color: #94a3b8; }
.cc-upgrade-select-btn {
    background: linear-gradient(135deg, #3b82f6, #6366f1);
    border: none;
    color: #fff;
    border-radius: 8px;
    padding: 8px 18px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: opacity .18s;
}
.cc-upgrade-select-btn:hover { opacity: .85; }

/* ── Purchase History tab ──────────────────────────────────────────────── */
.cc-ph-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}
.cc-ph-table th {
    padding: 10px 14px;
    background: #1e293b;
    color: #94a3b8;
    text-align: left;
    font-weight: 600;
    white-space: nowrap;
}
.cc-ph-table th:first-child { border-radius: 8px 0 0 8px; }
.cc-ph-table th:last-child  { border-radius: 0 8px 8px 0; }
.cc-ph-table td {
    padding: 11px 14px;
    border-bottom: 1px solid #1e293b;
    color: #e2e8f0;
    vertical-align: middle;
}
.cc-ph-table tr:last-child td { border-bottom: none; }
.cc-ph-table tr:hover td { background: rgba(255,255,255,.02); }
.cc-ph-empty {
    text-align: center;
    padding: 40px 20px;
    color: #64748b;
    font-size: 14px;
}
.cc-ph-empty p { margin: 0 0 16px; }
.cc-plan-pill-sm {
    display: inline-block;
    font-size: 11px;
    font-weight: 600;
    background: rgba(99,102,241,.15);
    color: #818cf8;
    padding: 2px 8px;
    border-radius: 20px;
    white-space: nowrap;
}
.cc-expired-badge {
    font-size: 11px;
    color: #ef4444;
    font-weight: 600;
}

/* ============================================================
   CATEGORY CARDS — Front-end
   ============================================================ */
.cc-cat-section { padding: 40px 0 32px; }
.cc-cat-front-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 28px;
}
.cc-cat-front-card {
    background: var(--cc-card, #fff);
    border: 1px solid var(--cc-border, #e5e7eb);
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 3px 12px rgba(0,0,0,.07);
    display: flex;
    flex-direction: column;
    transition: box-shadow .2s, transform .2s;
}
.cc-cat-front-card:hover { box-shadow: 0 10px 36px rgba(0,0,0,.14); transform: translateY(-4px); }

/* Carousel */
.cc-cat-front-carousel {
    position: relative;
    width: 100%;
    height: 220px;
    background: #f3f4f6;
    overflow: hidden;
    cursor: pointer;
}
.cc-cat-front-slide { display: none; width: 100%; height: 100%; }
.cc-cat-front-slide.active { display: block; }
.cc-cat-front-slide img { width: 100%; height: 100%; object-fit: cover; }
.cc-cat-front-ph {
    display: flex;
    align-items: center;
    justify-content: center;
}
.cc-cat-ph-icon-front { font-size: 40px; color: rgba(255,255,255,.88); }
.cc-cat-fr-btn {
    position: absolute;
    top: 50%; transform: translateY(-50%);
    background: rgba(0,0,0,.42);
    color: #fff;
    border: none;
    border-radius: 50%;
    width: 28px; height: 28px;
    font-size: 20px; line-height: 1;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    padding: 0; z-index: 2;
    transition: background .15s;
}
.cc-cat-fr-btn:hover { background: rgba(0,0,0,.68); }
.cc-cat-fr-prev { left: 6px; }
.cc-cat-fr-next { right: 6px; }
.cc-cat-fr-dots { position: absolute; bottom: 6px; left: 50%; transform: translateX(-50%); display: flex; gap: 5px; z-index: 2; }
.cc-cat-fr-dot { width: 6px; height: 6px; border-radius: 50%; background: rgba(255,255,255,.45); transition: background .2s; }
.cc-cat-fr-dot.active { background: #fff; }

/* Card body */
.cc-cat-front-body {
    display: block;
    padding: 18px 20px 20px;
    text-decoration: none;
    flex: 1;
    color: inherit;
}
.cc-cat-front-title {
    font-size: 16px;
    font-weight: 800;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--cc-text, #1e293b);
    margin: 0 0 7px;
}
.cc-cat-front-desc {
    font-size: 13px;
    color: var(--cc-muted, #64748b);
    margin: 0 0 8px;
    line-height: 1.55;
}
.cc-cat-front-count { font-size: 12px; color: var(--cc-muted, #64748b); font-weight: 600; }

/* Category filter bar on archive page */
.cc-cat-filter-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 20px;
}
.cc-cat-filter-btn {
    padding: 5px 14px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
    border: 2px solid #e5e7eb;
    background: var(--cc-card, #fff);
    color: var(--cc-text, #1e293b);
    text-decoration: none;
    transition: border-color .15s, background .15s, color .15s;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.cc-cat-filter-btn:hover,
.cc-cat-filter-btn.active {
    border-color: var(--cc-p, #4f46e5);
    background: var(--cc-p, #4f46e5);
    color: #fff;
}

/* ── Category cards — responsive breakpoints ───────────────────────── */
@media (max-width: 640px) {
    .cc-cat-front-grid {
        grid-template-columns: 1fr 1fr;
        gap: 14px;
    }
    .cc-cat-front-carousel { height: 150px; }
    .cc-cat-front-body { padding: 11px 13px 13px; }
    .cc-cat-front-title { font-size: 13px; letter-spacing: .04em; }
    .cc-cat-front-desc { font-size: 11px; }
}

@media (max-width: 360px) {
    .cc-cat-front-grid { grid-template-columns: 1fr; }
    .cc-cat-front-carousel { height: 180px; }
}

/* ═══════════════════════════════════════════════════════════════
   Course Details — Split Layout (left: info, right: preview video)
   ═══════════════════════════════════════════════════════════════ */
.cc-details-panel { overflow: visible; }

.cc-details-split {
    display: grid;
    grid-template-columns: 1fr 480px;
    gap: 32px;
    align-items: start;
    margin-bottom: 24px;
}

.cc-details-left { min-width: 0; }

.cc-details-right {
    position: sticky;
    top: 84px;
    min-width: 0;
}

/* ── Preview Video Wrapper ───────────────────────────────────── */
.cc-preview-video-wrap {
    border-radius: 14px;
    overflow: hidden;
    background: #0f0f0f;
    box-shadow: 0 8px 36px rgba(0,0,0,.22);
    aspect-ratio: 16 / 9;
    position: relative;
    cursor: pointer;
    width: 100%;
}

.cc-pvideo-thumb {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.cc-pvideo-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.cc-pvideo-play-btn {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 0;
    transition: transform .18s;
    z-index: 2;
}
.cc-pvideo-play-btn:hover { transform: scale(1.1); }

/* No-thumbnail variant — gradient background */
.cc-pvideo-thumb--noimg {
    background: linear-gradient(135deg, #1e1b4b 0%, #312e81 100%);
}

.cc-pvideo-play-btn--solo {
    flex-direction: column;
    gap: 10px;
}
.cc-pvideo-play-label {
    color: #fff;
    font-size: 15px;
    font-weight: 600;
    letter-spacing: .03em;
    text-shadow: 0 1px 4px rgba(0,0,0,.4);
}

/* Active player area (iframe / html5 video) */
.cc-pvideo-player {
    position: absolute;
    inset: 0;
    background: #000;
}
.cc-pvideo-iframe,
.cc-pvideo-el {
    width: 100%;
    height: 100%;
    display: block;
    border: none;
}

/* Static image fallback (no video configured) */
.cc-preview-image-only { cursor: default; }
.cc-preview-static-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Pricing grid — extra breathing room when it sits below the split */
.cc-details-panel .cc-pricing-grid { margin-top: 28px; }
.cc-details-panel .cc-rating-widget { margin-top: 8px; }

/* ── Responsive ─────────────────────────────────────────────── */

/* Tablet (~960px): collapse to single-column stack — details → video → prices */
@media (max-width: 960px) {
    .cc-details-split {
        grid-template-columns: 1fr;
        gap: 20px;
    }
    .cc-details-right {
        position: static;
        order: 2;          /* video below details */
    }
    .cc-details-left { order: 1; }  /* details on top */
}

/* Mobile: tighter spacing, smaller radius */
@media (max-width: 640px) {
    .cc-details-split { gap: 14px; }
    .cc-preview-video-wrap { border-radius: 10px; }
}

/* ============================================================
   AI Chat Widget — tab bar, AI panel, chips, typing indicator
   ============================================================ */

/* Tab bar (choice mode dual-tab header) */
.cc-sw-tab-bar {
    display: flex;
    border-bottom: 1px solid var(--cc-border, #e2e8f0);
    background: var(--cc-card, #fff);
    flex-shrink: 0;
}
.cc-sw-tab {
    flex: 1;
    padding: 9px 6px;
    font-size: 12px;
    font-weight: 600;
    color: var(--cc-muted, #64748b);
    background: transparent;
    border: none;
    border-bottom: 2px solid transparent;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    transition: color .15s, border-color .15s;
    white-space: nowrap;
}
.cc-sw-tab:hover { color: var(--cc-p, #4f46e5); }
.cc-sw-tab.cc-sw-tab-active {
    color: var(--cc-p, #4f46e5);
    border-bottom-color: var(--cc-p, #4f46e5);
}

/* AI panel container */
.cc-sw-ai-panel {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    overflow: hidden;
    position: relative;
}

/* AI messages list */
.cc-sw-ai-messages {
    flex: 1;
    overflow-y: auto;
    padding: 12px 12px 8px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    scroll-behavior: smooth;
}

/* AI bot message bubble */
.cc-sw-msg-ai {
    align-self: flex-start;
    display: flex;
    align-items: flex-start;
    gap: 6px;
    background: linear-gradient(135deg, #ede9fe 0%, #ddd6fe 100%);
    color: #3730a3;
    border-radius: 0 12px 12px 12px;
    padding: 9px 12px;
    font-size: 13px;
    line-height: 1.5;
    max-width: 88%;
    word-break: break-word;
}
[data-theme="dark"] .cc-sw-msg-ai {
    background: linear-gradient(135deg, #312e81 0%, #3730a3 100%);
    color: #c7d2fe;
}

/* Starter question chips */
.cc-sw-ai-starters {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 4px 0 4px;
}
.cc-sw-ai-chip {
    background: var(--cc-card, #fff);
    border: 1px solid #c4b5fd;
    color: #5b21b6;
    border-radius: 20px;
    padding: 5px 12px;
    font-size: 12px;
    cursor: pointer;
    transition: background .15s, color .15s;
    text-align: left;
    line-height: 1.4;
}
.cc-sw-ai-chip:hover {
    background: #ede9fe;
    border-color: #7c3aed;
}
[data-theme="dark"] .cc-sw-ai-chip {
    background: #1e1b4b;
    border-color: #4f46e5;
    color: #c7d2fe;
}

/* Rate limit indicator */
.cc-sw-ai-rate {
    font-size: 11px;
    color: var(--cc-muted, #64748b);
    text-align: center;
    padding: 4px 8px;
    border-top: 1px solid var(--cc-border, #e2e8f0);
    flex-shrink: 0;
}

/* Typing indicator (three bouncing dots) */
.cc-sw-ai-typing {
    background: #ede9fe !important;
    padding: 10px 14px !important;
    display: flex !important;
    align-items: center;
    gap: 4px;
}
.cc-sw-ai-typing span {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #7c3aed;
    display: inline-block;
    animation: cc-ai-bounce 1.2s infinite ease-in-out;
}
.cc-sw-ai-typing span:nth-child(2) { animation-delay: .2s; }
.cc-sw-ai-typing span:nth-child(3) { animation-delay: .4s; }

@keyframes cc-ai-bounce {
    0%, 80%, 100% { transform: translateY(0); opacity: .5; }
    40%           { transform: translateY(-6px); opacity: 1; }
}

/* Admin: tiny model preset buttons */
.cc-btn-xs {
    padding: 3px 8px !important;
    font-size: 11px !important;
    line-height: 1.6 !important;
    border-radius: 5px !important;
}

/* ── AI Session Bar ─────────────────────────────────────────────────────── */
.cc-sw-ai-sess-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 6px 10px;
    border-bottom: 1px solid var(--cc-border, #e2e8f0);
    background: var(--cc-bg, #f8fafc);
    flex-shrink: 0;
}
[data-theme="dark"] .cc-sw-ai-sess-bar {
    background: #1e293b;
    border-color: #334155;
}
.cc-sw-sess-toggle {
    display: flex;
    align-items: center;
    gap: 6px;
    background: none;
    border: none;
    cursor: pointer;
    font-size: 12px;
    font-weight: 600;
    color: var(--cc-text, #1e293b);
    padding: 4px 6px;
    border-radius: 5px;
    max-width: 164px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    transition: background .12s;
}
.cc-sw-sess-toggle:hover { background: #f1f5f9; }
@supports (background: color-mix(in srgb, #000 10%, #fff)) {
    .cc-sw-sess-toggle:hover { background: color-mix(in srgb, var(--cc-p, #4f46e5) 10%, transparent); }
}
[data-theme="dark"] .cc-sw-sess-toggle { color: #e2e8f0; }
[data-theme="dark"] .cc-sw-sess-toggle:hover { background: #334155; }
.cc-sw-new-sess {
    background: none;
    border: 1px solid var(--cc-border, #e2e8f0);
    border-radius: 50%;
    width: 26px;
    height: 26px;
    cursor: pointer;
    font-size: 16px;
    line-height: 1;
    color: var(--cc-p, #4f46e5);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: background .15s, border-color .15s;
}
.cc-sw-new-sess:hover { background: #ede9fe; border-color: #a5b4fc; }
[data-theme="dark"] .cc-sw-new-sess { border-color: #334155; color: #818cf8; }
[data-theme="dark"] .cc-sw-new-sess:hover { background: #1e1b4b; border-color: #6366f1; }

/* ── Session Drawer ─────────────────────────────────────────────────────── */
.cc-sw-sess-drawer {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--cc-card, #fff);
    z-index: 10;
    border-radius: 0 0 16px 16px;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
}
[data-theme="dark"] .cc-sw-sess-drawer { background: #1e293b; }
.cc-sw-sess-drawer-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 14px 8px;
    font-size: 13px;
    font-weight: 700;
    color: var(--cc-text, #1e293b);
    border-bottom: 1px solid var(--cc-border, #e2e8f0);
    flex-shrink: 0;
}
[data-theme="dark"] .cc-sw-sess-drawer-head { color: #e2e8f0; border-color: #334155; }
.cc-sw-sess-hint {
    font-size: 11px;
    font-weight: 400;
    color: var(--cc-muted, #64748b);
}
.cc-sw-sess-list { padding: 6px 8px; flex: 1; overflow-y: auto; }
.cc-sw-sess-empty {
    text-align: center;
    padding: 28px 16px;
    font-size: 12px;
    color: var(--cc-muted, #64748b);
}
.cc-sw-sess-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 9px 10px;
    border-radius: 8px;
    cursor: pointer;
    font-size: 13px;
    color: var(--cc-text, #1e293b);
    gap: 8px;
    transition: background .12s;
}
.cc-sw-sess-row:hover { background: #f1f5f9; }
@supports (background: color-mix(in srgb, #000 10%, #fff)) {
    .cc-sw-sess-row:hover { background: color-mix(in srgb, var(--cc-p, #4f46e5) 8%, transparent); }
}
[data-theme="dark"] .cc-sw-sess-row { color: #e2e8f0; }
[data-theme="dark"] .cc-sw-sess-row:hover { background: #334155; }
.cc-sw-sess-active { background: #ede9fe !important; color: #3730a3 !important; font-weight: 600; }
@supports (background: color-mix(in srgb, #000 10%, #fff)) {
    .cc-sw-sess-active {
        background: color-mix(in srgb, var(--cc-p, #4f46e5) 16%, var(--cc-card, #fff)) !important;
        color: var(--cc-text, #1e293b) !important;
    }
}
[data-theme="dark"] .cc-sw-sess-active { background: #1e1b4b !important; color: #a5b4fc !important; }
.cc-sw-sess-row-title { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cc-sw-sess-del {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 16px;
    line-height: 1;
    color: var(--cc-muted, #64748b);
    padding: 0 4px;
    border-radius: 4px;
    flex-shrink: 0;
    transition: color .12s, background .12s;
}
.cc-sw-sess-del:hover { color: #ef4444; background: rgba(239,68,68,.1); }
[data-theme="dark"] .cc-sw-sess-del:hover { color: #f87171; background: rgba(239,68,68,.15); }

/* ── Storage Notice ─────────────────────────────────────────────────────── */
.cc-sw-ai-notice {
    display: flex;
    align-items: center;
    gap: 6px;
    background: #eff6ff;
    border: 1px solid #bfdbfe;
    border-radius: 7px;
    padding: 7px 10px;
    font-size: 11.5px;
    color: #1d4ed8;
    margin: 8px 8px 0;
    flex-shrink: 0;
    line-height: 1.4;
}
[data-theme="dark"] .cc-sw-ai-notice { background: #172554; border-color: #1d4ed8; color: #93c5fd; }
.cc-sw-ai-notice-close {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 14px;
    color: #3b82f6;
    padding: 0 2px;
    margin-left: auto;
    line-height: 1;
}
[data-theme="dark"] .cc-sw-ai-notice-close { color: #93c5fd; }

/* ── Suggest Support Banner ─────────────────────────────────────────────── */
.cc-sw-suggest-support {
    display: flex;
    align-items: center;
    gap: 10px;
    background: #fffbeb;
    border: 1px solid #fcd34d;
    border-radius: 8px;
    padding: 9px 12px;
    font-size: 12.5px;
    color: #92400e;
    margin: 4px 0;
    flex-shrink: 0;
    flex-wrap: wrap;
}
[data-theme="dark"] .cc-sw-suggest-support { background: #1c1002; border-color: #78350f; color: #fde68a; }
.cc-btn-contact-support {
    background: var(--cc-p, #4f46e5);
    color: #fff;
    border: none;
    border-radius: 6px;
    padding: 5px 12px;
    font-size: 11.5px;
    cursor: pointer;
    white-space: nowrap;
    font-weight: 600;
    flex-shrink: 0;
    transition: background .15s;
}
.cc-btn-contact-support:hover { background: #4338ca; }
