/* ==========================================================================
   WC Service Booking — Courses / Classes shortcode styles
   Scoped under .wcsb-courses-wrap to avoid any global conflicts.
   ========================================================================== */

/* ── Reset inside scope ── */
.wcsb-courses-wrap *,
.wcsb-courses-wrap *::before,
.wcsb-courses-wrap *::after {
    box-sizing: border-box;
}

.wcsb-courses-wrap {
    font-family: var(--wcsb-font-sans, 'DM Sans', sans-serif);
    color: var(--wcsb-text, #1a1a1a);
    width: 100%;
    margin: 0 auto;
    -webkit-font-smoothing: antialiased;
}

.wcsb-no-services {
    text-align: center;
    color: #888;
    padding: 48px 24px;
    font-size: 15px;
}

/* ==========================================================================
   TABS
   ========================================================================== */

.wcsb-courses-tabs {
    display: flex;
    gap: 0;
    margin-bottom: 36px !important;
	display: flex;
    justify-content: center; /* center horizontally */
    align-items: center;     /* center vertically */
    gap: 10px;               /* optional spacing between tabs */
    margin: 0 auto;
    text-align: center;
}

.wcsb-courses-tab {
    appearance: none;
    background: none;
    border: 1px solid #000000 !important;
    margin-bottom: -2px;
    padding: 12px 28px;
    font-family: inherit;
    font-size: 15px;
    font-weight: 600;
    color: #000000 !important;
    cursor: pointer;
    letter-spacing: 0.02em;
    transition: color 150ms ease, border-color 150ms ease;
    white-space: nowrap;
	border-radius:100px !important;
}

.wcsb-courses-tab:hover {
    color: #fff !important;
	background-color:#4A90E2 !important;
}

.wcsb-courses-tab.is-active {
    color: #fff !important;
	background-color: #4A90E2 !important;
}

/* ==========================================================================
   PANELS
   ========================================================================== */

.wcsb-courses-panel {
    display: none;
}

.wcsb-courses-panel.is-active {
    display: block;
    animation: wcsb-courses-in 200ms ease both;
}

@keyframes wcsb-courses-in {
    from { opacity: 0; transform: translateY(10px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ==========================================================================
   CARD GRID
   ========================================================================== */

.wcsb-courses-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
}

@media (max-width: 900px) {
    .wcsb-courses-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
}

@media (max-width: 560px) {
    .wcsb-courses-grid { grid-template-columns: 1fr; gap: 20px; }
}

/* ==========================================================================
   SINGLE CARD
   ========================================================================== */

.wcsb-course-card {
    background: #fff;
    border: 1px solid #ebebeb;
    display: flex;
    flex-direction: column;
    transition: box-shadow 200ms ease, transform 200ms ease;
    overflow: hidden;
	border-radius:12px !important;
}

.wcsb-course-card:hover {
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.10);
    transform: translateY(-2px);
}

/* Thumbnail */
.wcsb-card-thumb {
    width: 100%;
    aspect-ratio: 16 / 10;
    overflow: hidden;
    background: #f0f0f0;
    flex-shrink: 0;
}

.wcsb-card-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 300ms ease;
}

.wcsb-course-card:hover .wcsb-card-img {
    transform: scale(1.03);
}

.wcsb-card-img-placeholder {
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, #e8e8e8 0%, #d5d5d5 100%);
}

/* Card body */
.wcsb-card-body {
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: 20px 22px 24px;
}

.wcsb-card-title {
    font-size: 17px;
    font-weight: 700;
    line-height: 1.3;
    margin: 0 0 10px;
    color: #1a1a1a;
    letter-spacing: -0.01em;
}

/* Meta row: duration | price */
.wcsb-card-meta {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 14px;
    flex-wrap: wrap;
}

.wcsb-card-duration {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 13px;
    font-weight: 600;
    color: #555;
}

.wcsb-card-duration svg {
    flex-shrink: 0;
    color: #888;
}

.wcsb-card-meta-sep {
    color: #ccc;
    font-size: 13px;
}

.wcsb-card-price {
    font-size: 16px;
    font-weight: 700;
    color: #1a1a1a;
}

.wcsb-card-price .woocommerce-Price-amount { color: inherit; }
.wcsb-card-price del { color: #aaa; font-weight: 400; font-size: 13px; margin-right: 4px; }
.wcsb-card-price ins { text-decoration: none; }

/* Description */
.wcsb-card-desc {
    font-size: 13.5px;
    line-height: 1.6;
    color: #555;
    flex: 1;
    margin-bottom: 20px;
}

.wcsb-card-desc p { margin: 0 0 8px; }
.wcsb-card-desc p:last-child { margin-bottom: 0; }
.wcsb-card-desc ul { margin: 0 0 8px 16px; padding: 0; }
.wcsb-card-desc li { margin-bottom: 4px; }

/* CTA Button */
.wcsb-courses-cta {
    display: block;
    width: 100%;
    padding: 12px 20px;
    background: #4A90E2 !important;
    color: #fff !important;
    border: 2px solid #4A90E2;
	border-radius:100px !important;
    font-family: inherit;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    text-align: center;
    text-decoration: none !important;
    cursor: pointer;
    transition: background 150ms ease, color 150ms ease;
    margin-top: auto;
}

.wcsb-courses-cta:hover {
    background: #4A90E2;
    color: #fff !important;
}

/* ==========================================================================
   PRODUCT DURATION on single product page
   ========================================================================== */

.wcsb-product-duration {
    font-size: 15px;
    color: #555;
    margin: 0 0 12px;
}
