/* =========================================================================
   Zonkey Courses — frontend styling
   Scoped to our own classes to avoid fighting Flatsome / parent theme rules.
   ========================================================================= */

:root {
    --zcf-accent:      #b85c3a;
    --zcf-accent-dark: #9a4a2e;
    --zcf-accent-soft: #f6e6df;
    --zcf-text:        #2a241e;
    --zcf-muted:       #7a7166;
    --zcf-border:      #e8e1d4;
    --zcf-surface:     #ffffff;
    --zcf-surface-alt: #faf6f0;
    --zcf-success:     #4a8a3f;
    --zcf-success-soft:#e3f1e0;
    --zcf-warning:     #c8862e;
    --zcf-warning-soft:#fbeed6;
    --zcf-danger:      #b03f3f;
    --zcf-danger-soft: #f6dede;
}

/* ---------- Product-card next-date strip --------------------------------- */

.product-small .zonkey-card-date {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    margin: 4px 0 6px;
    padding: 8px 10px;
    background: var(--zcf-surface-alt);
    border-radius: 6px;
    font-size: 12px;
    line-height: 1.3;
    color: var(--zcf-text);
}

.zonkey-card-date--none {
    color: var(--zcf-muted);
    font-style: italic;
    background: transparent !important;
    padding: 0 !important;
}

.zonkey-card-date__label {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 700;
    color: var(--zcf-muted);
}

.zonkey-card-date__date {
    font-weight: 600;
}

.zonkey-card-date__time {
    color: var(--zcf-muted);
}

.zonkey-card-date__seats {
    margin-left: auto;
    padding: 2px 8px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 600;
}
.zonkey-card-date__seats--ok   { background: var(--zcf-success-soft); color: var(--zcf-success); }
.zonkey-card-date__seats--low  { background: var(--zcf-warning-soft); color: var(--zcf-warning); }
.zonkey-card-date__seats--full { background: var(--zcf-danger-soft);  color: var(--zcf-danger); }

.zonkey-card-date__more {
    font-size: 11px;
    color: var(--zcf-muted);
    flex-basis: 100%;
}

/* ---------- Shortcode: workshop cards ------------------------------------ */

.zonkey-workshops {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 22px;
    margin: 28px 0;
}

.zonkey-workshops--compact {
    grid-template-columns: 1fr;
    gap: 12px;
}

.zonkey-workshop-card {
    background: var(--zcf-surface);
    border: 1px solid var(--zcf-border);
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(42,36,30,0.05);
    display: flex;
    flex-direction: column;
    transition: transform 150ms ease, box-shadow 150ms ease;
}

.zonkey-workshop-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 24px rgba(42,36,30,0.10), 0 1px 3px rgba(42,36,30,0.06);
}

.zonkey-workshops--compact .zonkey-workshop-card {
    flex-direction: row;
    align-items: stretch;
}

.zonkey-workshop-card__image {
    display: block;
    aspect-ratio: 4 / 3;
    background: var(--zcf-surface-alt);
    overflow: hidden;
}
.zonkey-workshop-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 350ms ease;
}
.zonkey-workshop-card:hover .zonkey-workshop-card__image img {
    transform: scale(1.04);
}

.zonkey-workshops--compact .zonkey-workshop-card__image {
    width: 140px;
    flex-shrink: 0;
    aspect-ratio: 1 / 1;
}

.zonkey-workshop-card__body {
    padding: 18px 20px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    flex: 1;
}

.zonkey-workshop-card__title {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
    line-height: 1.25;
    color: var(--zcf-text);
}
.zonkey-workshop-card__title a {
    color: inherit;
    text-decoration: none;
}
.zonkey-workshop-card__title a:hover {
    color: var(--zcf-accent);
}

.zonkey-workshop-card__next {
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 6px;
    font-size: 14px;
    color: var(--zcf-text);
}
.zonkey-workshop-card__next-label {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 700;
    color: var(--zcf-muted);
    display: block;
    flex-basis: 100%;
    margin-bottom: -2px;
}
.zonkey-workshop-card__next strong {
    font-weight: 700;
    color: var(--zcf-accent-dark);
}
.zonkey-workshop-card__next-time {
    color: var(--zcf-muted);
    font-size: 13px;
}

.zonkey-workshop-card__meta {
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    font-size: 13px;
    color: var(--zcf-muted);
}

.zonkey-pill {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    line-height: 1.4;
}
.zonkey-pill--ok   { background: var(--zcf-success-soft); color: var(--zcf-success); }
.zonkey-pill--low  { background: var(--zcf-warning-soft); color: var(--zcf-warning); }
.zonkey-pill--full { background: var(--zcf-danger-soft);  color: var(--zcf-danger); }

.zonkey-workshop-card__price {
    margin-left: auto;
    color: var(--zcf-text);
    font-weight: 600;
}
.zonkey-workshop-card__price del { color: var(--zcf-muted); }

.zonkey-workshop-card__more {
    margin: 4px 0 0;
    border-top: 1px dashed var(--zcf-border);
    padding-top: 10px;
}
.zonkey-workshop-card__more summary {
    cursor: pointer;
    font-size: 13px;
    color: var(--zcf-muted);
    list-style: none;
}
.zonkey-workshop-card__more summary::before {
    content: "▾ ";
    color: var(--zcf-accent);
    margin-right: 2px;
}
.zonkey-workshop-card__more[open] summary::before {
    content: "▴ ";
}
.zonkey-workshop-card__more ul {
    margin: 6px 0 0;
    padding: 0;
    list-style: none;
}
.zonkey-workshop-card__more li {
    padding: 6px 0;
    border-bottom: 1px dashed var(--zcf-border);
    font-size: 13px;
    display: flex;
    justify-content: space-between;
    gap: 10px;
}
.zonkey-workshop-card__more li:last-child {
    border-bottom: none;
}

.zonkey-workshop-card__cta {
    margin: auto 0 0;
}
.zonkey-workshop-card__book {
    display: inline-block;
    background: var(--zcf-accent);
    color: #fff !important;
    border: 1px solid var(--zcf-accent);
    padding: 8px 18px;
    border-radius: 6px;
    font-weight: 600;
    text-decoration: none;
    transition: background 120ms ease;
}
.zonkey-workshop-card__book:hover {
    background: var(--zcf-accent-dark);
    border-color: var(--zcf-accent-dark);
    color: #fff !important;
}

.zonkey-workshops__more-link {
    text-align: center;
    margin: 18px 0 0;
}
.zonkey-workshops__more-link a {
    display: inline-block;
    padding: 10px 22px;
    border: 1px solid var(--zcf-accent);
    border-radius: 6px;
    color: var(--zcf-accent-dark) !important;
    text-decoration: none;
    font-weight: 600;
    transition: background 120ms ease, color 120ms ease;
}
.zonkey-workshops__more-link a:hover {
    background: var(--zcf-accent);
    color: #fff !important;
}
