/* ============================================================================
 * Probestunde landing — bespoke sections (bookable slot grid + filters, promo,
 * SEO text, final CTA). Content bands come from reusable components, which
 * bring their own CSS. Scoped under .rc-pb. px-only.
 *
 * @package robboclub-platform
 * @since 0.27.0
 * ========================================================================= */

.rc-pb {
    --pb-green: #00BF63;
    --pb-green-dark: #00A356;
    --pb-green-soft: #EAFBF1;
    --pb-ink: #14181D;
    --pb-muted: #555E6B;
    --pb-line: #E6EAEE;
    --pb-bg-alt: #F8FAFB;
    font-family: 'ProximaNova', 'Proxima Nova', 'Noto Sans', sans-serif;
    color: var(--pb-ink);
}
.rc-pb *, .rc-pb *::before, .rc-pb *::after { box-sizing: border-box; }

.rc-pb-wrap { max-width: 1366px; margin: 0 auto; padding: 0 32px; }

.rc-pb-head { text-align: center; max-width: 760px; margin: 0 auto 28px; }
.rc-pb-eyebrow {
    display: inline-block;
    font-family: 'Plakkaat', 'ProximaNova', sans-serif;
    font-size: 12px; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase;
    color: var(--pb-green-dark); margin: 0 0 12px;
}
.rc-pb-h2 {
    font-family: 'ProximaNova', sans-serif; font-weight: 800;
    font-size: 28px; line-height: 1.15; letter-spacing: -0.015em; margin: 0 0 12px;
}
.rc-pb-lead { font-size: 17px; line-height: 1.55; color: var(--pb-muted); margin: 0; }

/* ---- Slots section ----------------------------------------------------- */
.rc-pb-slots { background: var(--pb-bg-alt); padding: 64px 0; }

.rc-pb-filters {
    display: flex; flex-wrap: wrap; gap: 12px; justify-content: center;
    margin: 0 auto 28px; max-width: 900px;
}
.rc-pb-filter {
    min-height: 48px; min-width: 180px;
    border: 1px solid var(--pb-line); border-radius: 12px;
    background: #fff; padding: 0 16px;
    font-family: 'ProximaNova', sans-serif; font-size: 15px; color: var(--pb-ink);
    cursor: pointer;
}
.rc-pb-filter:focus { outline: none; border-color: var(--pb-green); box-shadow: 0 0 0 3px rgba(0,191,99,.15); }

.rc-pb-grid {
    display: grid; grid-template-columns: 1fr; gap: 18px;
    max-width: 1100px; margin: 0 auto;
}
.rc-pb-card {
    display: flex; flex-direction: column;
    background: #fff; border: 1px solid var(--pb-line);
    border-left: 4px solid var(--pb-green);
    border-radius: 16px; padding: 20px 22px;
    transition: transform .18s ease, box-shadow .18s ease;
}
.rc-pb-card:hover { transform: translateY(-3px); box-shadow: 0 14px 32px rgba(16,32,24,.10); }
.rc-pb-card.is-sold { opacity: .62; border-left-color: #c2c8cf; }

.rc-pb-card__top { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 14px; }
.rc-pb-card__age {
    font-size: 12px; font-weight: 700; color: var(--pb-green-dark);
    background: var(--pb-green-soft); border-radius: 999px; padding: 4px 12px;
}
.rc-pb-card__price { font-family: 'ProximaNova', sans-serif; font-weight: 800; font-size: 22px; color: var(--pb-ink); }

.rc-pb-card__meta { list-style: none; margin: 0 0 16px; padding: 0; display: flex; flex-direction: column; gap: 7px; flex-grow: 1; }
.rc-pb-card__meta li { display: flex; align-items: center; gap: 8px; font-size: 14px; color: var(--pb-muted); }
.rc-pb-card__meta svg { color: var(--pb-green); flex: none; }

.rc-pb-card__foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; border-top: 1px solid #f0f2f4; padding-top: 14px; }
.rc-pb-card__free { font-size: 13px; font-weight: 600; color: var(--pb-green-dark); }
.rc-pb-card__free.is-sold { color: #e53e3e; }
.rc-pb-card__btn {
    display: inline-flex; align-items: center; justify-content: center;
    min-height: 44px; padding: 11px 26px; border-radius: 999px;
    background: var(--pb-green); color: #fff;
    font-family: 'ProximaNova', sans-serif; font-weight: 700; font-size: 15px;
    text-decoration: none; border: none; cursor: pointer;
    transition: background-color .18s ease, transform .18s ease;
}
.rc-pb-card__btn:hover { background: var(--pb-green-dark); color: #fff; transform: translateY(-1px); }
.rc-pb-card__btn.is-disabled { background: #e6eaee; color: #99a1ab; cursor: default; pointer-events: none; }

.rc-pb-empty, .rc-pb-empty-all { text-align: center; color: var(--pb-muted); font-size: 16px; margin: 24px auto 0; max-width: 560px; }

/* ---- Reassurance bar --------------------------------------------------- */
.rc-pb-reassure { background: #fff; border-bottom: 1px solid var(--pb-line); padding: 22px 0; }
.rc-pb-reassure__list {
    max-width: 1100px; margin: 0 auto; padding: 0 32px;
    list-style: none; display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px 24px;
}
.rc-pb-reassure__item { display: flex; align-items: center; gap: 12px; }
.rc-pb-reassure__ic {
    flex: none; width: 42px; height: 42px; border-radius: 12px;
    background: var(--pb-green-soft); color: var(--pb-green-dark);
    display: flex; align-items: center; justify-content: center;
}
.rc-pb-reassure__txt { display: flex; flex-direction: column; line-height: 1.25; }
.rc-pb-reassure__txt strong { font-size: 15px; font-weight: 700; color: var(--pb-ink); }
.rc-pb-reassure__txt span { font-size: 13px; color: var(--pb-muted); }

/* ---- Standorte --------------------------------------------------------- */
.rc-pb-locs { background: #fff; padding: 64px 0; }
.rc-pb-locs__grid { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: 1fr; gap: 16px; max-width: 1100px; margin: 0 auto; }
.rc-pb-loc {
    display: flex; flex-direction: column;
    background: var(--pb-bg-alt); border: 1px solid var(--pb-line); border-radius: 16px;
    overflow: hidden; transition: box-shadow .18s ease, transform .18s ease;
}
.rc-pb-loc:hover { transform: translateY(-3px); box-shadow: 0 14px 32px rgba(16,32,24,.10); }
.rc-pb-loc__pick {
    display: flex; align-items: flex-start; gap: 14px; text-align: left;
    background: none; border: none; cursor: pointer; padding: 22px 22px 16px; width: 100%;
    font-family: inherit;
}
.rc-pb-loc__pick[disabled] { cursor: default; }
.rc-pb-loc__pin { flex: none; width: 40px; height: 40px; border-radius: 11px; background: var(--pb-green-soft); color: var(--pb-green-dark); display: flex; align-items: center; justify-content: center; }
.rc-pb-loc__body { display: flex; flex-direction: column; gap: 3px; }
.rc-pb-loc__bezirk { font-size: 16px; font-weight: 800; color: var(--pb-ink); }
.rc-pb-loc__street { font-size: 14px; color: var(--pb-muted); }
.rc-pb-loc__free { margin-top: 4px; font-size: 13px; font-weight: 600; color: var(--pb-green-dark); }
.rc-pb-loc__free.is-none { color: #99a1ab; }
.rc-pb-loc__link {
    display: inline-flex; align-items: center; gap: 6px;
    margin: 0 22px 18px; font-size: 14px; font-weight: 700; color: var(--pb-green-dark); text-decoration: none;
}
.rc-pb-loc__link:hover { color: var(--pb-green); }
.rc-pb-loc.is-active { box-shadow: 0 0 0 2px var(--pb-green); }

/* ---- Final CTA --------------------------------------------------------- */
.rc-pb-cta { background: linear-gradient(135deg, #00BF63 0%, #00A356 100%); padding: 60px 32px; text-align: center; }
.rc-pb-cta__inner { max-width: 720px; margin: 0 auto; }
.rc-pb-cta__h2 { font-family: 'ProximaNova', sans-serif; font-weight: 800; font-size: 30px; line-height: 1.15; color: #fff; margin: 0 0 12px; }
.rc-pb-cta__sub { font-size: 17px; line-height: 1.55; color: #EAFBF1; margin: 0 0 26px; }
.rc-pb-cta__btn {
    display: inline-flex; align-items: center; justify-content: center;
    min-height: 52px; padding: 15px 34px; border-radius: 999px;
    background: #fff; color: var(--pb-green-dark);
    font-family: 'ProximaNova', sans-serif; font-weight: 700; font-size: 16px;
    text-decoration: none; box-shadow: 0 14px 30px rgba(0,0,0,.16);
    transition: transform .18s ease, background-color .18s ease;
}
.rc-pb-cta__btn:hover { background: #F2FFF8; color: var(--pb-green-dark); transform: translateY(-2px); }

/* ---- Responsive -------------------------------------------------------- */
@media (max-width: 767px) {
    .rc-pb-wrap { padding: 0 16px; }
    .rc-pb-h2 { font-size: 23px; }
    .rc-pb-filter { min-width: 0; flex: 1 1 100%; }
    .rc-pb-promo { flex-direction: column; text-align: center; }
    .rc-pb-cta__h2 { font-size: 25px; }
}
@media (min-width: 768px) {
    .rc-pb-h2 { font-size: 34px; }
    .rc-pb-grid { grid-template-columns: repeat(2, 1fr); }
    .rc-pb-reassure__list { grid-template-columns: repeat(4, 1fr); }
    .rc-pb-locs__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
    .rc-pb-grid { grid-template-columns: repeat(3, 1fr); }
    .rc-pb-locs__grid { grid-template-columns: repeat(3, 1fr); }
}
