/*
Theme Name: Petaluma Social
Theme URI: https://petaluma.ngrok.app
Author: Petaluma Social
Description: Editorial event listings for Petaluma, CA
Version: 1.1.0
*/

/* ── Reset & Base ──────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
    margin: 0 !important;
    padding: 0;
}

:root {
    --pj-red:       #C62828;
    --pj-red-light: #FFEBEE;
    --pj-blue:      #1565C0;
    --pj-blue-light:#E3F2FD;
    --pj-green:     #2E7D32;
    --pj-green-light:#E8F5E9;
    --pj-orange:    #E65100;
    --pj-orange-light:#FFF3E0;
    --pj-purple:    #7B1FA2;
    --pj-purple-light:#F3E5F5;
    --pj-black:     #1a1a1a;
    --pj-gray-900:  #333;
    --pj-gray-700:  #555;
    --pj-gray-500:  #888;
    --pj-gray-300:  #ddd;
    --pj-gray-100:  #f5f5f5;
    --pj-white:     #fff;
    --font-serif:   'Playfair Display', Georgia, serif;
    --font-sans:    'Inter', -apple-system, sans-serif;
}

body {
    font-family: var(--font-sans);
    background: var(--pj-gray-100);
    color: var(--pj-black);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    margin: 0 !important;
    padding-top: 0;
    /* Keep scrollable content clear of the fixed bottom nav without making the nav feel pulled upward. */
    padding-bottom: calc(120px + env(safe-area-inset-bottom, 0px));
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

/* ── Sticky Header Wrapper (header + category tabs) ────────── */
.pj-sticky-header {
    position: sticky;
    top: 0;
    z-index: 100;
}

/* ── Header ────────────────────────────────────────────────── */
.pj-site-header {
    background: var(--pj-white);
    border-bottom: 1px solid var(--pj-gray-300);
    padding: 16px 20px;
    text-align: center;
}
.pj-site-title {
    font-family: var(--font-serif);
    font-size: 24px;
    font-weight: 700;
    line-height: 1.05;
    color: var(--pj-black);
    letter-spacing: -0.5px;
}
.pj-site-subtitle {
    font-size: 11px;
    line-height: 1.1;
    font-weight: 500;
    color: var(--pj-gray-500);
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-top: 2px;
}
.pj-top-nav {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 10px;
}
.pj-top-nav a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    padding: 7px 14px;
    border: 1px solid var(--pj-gray-300);
    border-radius: 999px;
    color: var(--pj-gray-700);
    background: var(--pj-white);
    font-size: 13px;
    font-weight: 700;
    line-height: 1;
    white-space: nowrap;
}
.pj-top-nav a.active {
    background: var(--pj-black);
    border-color: var(--pj-black);
    color: var(--pj-white);
}

/* ── Archive / Section Headers ─────────────────────────────── */
.pj-archive-header {
    padding: 18px 20px 10px;
    text-align: center;
}
.pj-archive-title {
    font-family: var(--font-serif);
    font-size: 28px;
    font-weight: 700;
}
.pj-archive-theme-scope {
    --pj-theme-accent: var(--pj-red);
    --pj-theme-ink: #5f2430;
    --pj-theme-soft: #fff8f4;
    --pj-theme-soft-2: #fffdfb;
    --pj-theme-border: rgba(196, 30, 58, 0.13);
    --pj-theme-shadow: rgba(95, 36, 48, 0.06);
    background: linear-gradient(180deg, var(--pj-theme-soft) 0, #fff 185px);
    padding-top: 1px;
    min-height: 70vh;
}
.pj-archive-theme--family,
.pj-archive-theme--kids { --pj-theme-accent:#b9762c; --pj-theme-ink:#735128; --pj-theme-soft:#fff7e8; --pj-theme-soft-2:#fffdf7; --pj-theme-border:rgba(185,118,44,.14); --pj-theme-shadow:rgba(115,81,40,.06); }
.pj-archive-theme--outdoors,
.pj-archive-theme--dogs,
.pj-archive-theme--parks,
.pj-archive-theme--farms,
.pj-archive-theme--scenic { --pj-theme-accent:#587b4b; --pj-theme-ink:#3e5a37; --pj-theme-soft:#f5f9f1; --pj-theme-soft-2:#fcfff9; --pj-theme-border:rgba(88,123,75,.14); --pj-theme-shadow:rgba(62,90,55,.06); }
.pj-archive-theme--date-night,
.pj-archive-theme--nightlife { --pj-theme-accent:#8f4057; --pj-theme-ink:#643446; --pj-theme-soft:#fff4f6; --pj-theme-soft-2:#fffafb; --pj-theme-border:rgba(143,64,87,.14); --pj-theme-shadow:rgba(100,52,70,.06); }
.pj-archive-theme--happy-hour,
.pj-archive-theme--food-drink,
.pj-archive-theme--wine,
.pj-archive-theme--coffee { --pj-theme-accent:#9d6330; --pj-theme-ink:#6b4a2f; --pj-theme-soft:#fff5e9; --pj-theme-soft-2:#fffbf5; --pj-theme-border:rgba(157,99,48,.14); --pj-theme-shadow:rgba(107,74,47,.06); }
.pj-archive-theme--classes-workshops,
.pj-archive-theme--classes,
.pj-archive-theme--arts,
.pj-archive-theme--theater,
.pj-archive-theme--music,
.pj-archive-theme--books,
.pj-archive-theme--museums { --pj-theme-accent:#6f638f; --pj-theme-ink:#514865; --pj-theme-soft:#f7f4ff; --pj-theme-soft-2:#fcfbff; --pj-theme-border:rgba(111,99,143,.14); --pj-theme-shadow:rgba(81,72,101,.06); }
.pj-archive-theme--downtown,
.pj-archive-theme--first-time,
.pj-archive-theme--shopping,
.pj-archive-theme--history { --pj-theme-accent:#977137; --pj-theme-ink:#66522f; --pj-theme-soft:#fff7e7; --pj-theme-soft-2:#fffdf7; --pj-theme-border:rgba(151,113,55,.14); --pj-theme-shadow:rgba(102,82,47,.06); }
.pj-archive-theme--rainy-day,
.pj-archive-theme--riverfront,
.pj-archive-theme--film,
.pj-archive-theme--comedy { --pj-theme-accent:#55798d; --pj-theme-ink:#405d6c; --pj-theme-soft:#f0f8fb; --pj-theme-soft-2:#fafdff; --pj-theme-border:rgba(85,121,141,.14); --pj-theme-shadow:rgba(64,93,108,.06); }
.pj-archive-theme--free,
.pj-archive-theme--community,
.pj-archive-theme--markets,
.pj-archive-theme--seasonal { --pj-theme-accent:#a45a46; --pj-theme-ink:#704339; --pj-theme-soft:#fff3ee; --pj-theme-soft-2:#fffbf8; --pj-theme-border:rgba(164,90,70,.14); --pj-theme-shadow:rgba(112,67,57,.06); }
.pj-archive-theme--sports,
.pj-archive-theme--wellness { --pj-theme-accent:#4d857d; --pj-theme-ink:#3a635e; --pj-theme-soft:#f0faf8; --pj-theme-soft-2:#fafffd; --pj-theme-border:rgba(77,133,125,.14); --pj-theme-shadow:rgba(58,99,94,.06); }
.pj-archive-theme--happening-now,
.pj-archive-theme--events-date { --pj-theme-accent:#b82d42; --pj-theme-ink:#6f2531; --pj-theme-soft:#fff4f1; --pj-theme-soft-2:#fffdf9; --pj-theme-border:rgba(184,45,66,.14); --pj-theme-shadow:rgba(111,37,49,.06); }
.pj-archive-theme-scope .pj-archive-header {
    margin: 9px 14px 8px;
    padding: 20px 18px 15px;
    border: 1px solid var(--pj-theme-border);
    border-radius: 24px;
    background: linear-gradient(145deg, var(--pj-theme-soft) 0%, var(--pj-theme-soft-2) 76%);
    box-shadow: 0 8px 22px var(--pj-theme-shadow);
}
.pj-archive-theme-scope .pj-archive-title {
    color: var(--pj-theme-ink);
}
.pj-archive-theme-scope .pj-archive-subhead {
    color: var(--pj-theme-ink);
    opacity: .78;
}
.pj-archive-subtitle {
    color: var(--pj-gray-600);
    font-size: 14px;
    line-height: 1.4;
    margin: 6px auto 0;
    max-width: 520px;
}
.pj-search-header {
    padding-bottom: 8px;
}
.pj-search-form {
    display: flex;
    gap: 8px;
    margin: 14px auto 0;
    max-width: 620px;
    padding: 0 4px;
    position: sticky;
    top: 0;
    z-index: 20;
}
.pj-search-form input[type="search"] {
    flex: 1;
    border: 1px solid var(--pj-gray-200);
    border-radius: 999px;
    box-shadow: 0 2px 10px rgba(15, 23, 42, 0.06);
    font-size: 16px;
    min-width: 0;
    padding: 12px 15px;
    background: #fff;
}
.pj-search-autocomplete {
    position: absolute;
    left: 4px;
    right: 92px;
    top: calc(100% + 8px);
    z-index: 50;
    max-height: min(48vh, 340px);
    overflow-y: auto;
    border: 1px solid rgba(34,34,34,0.10);
    border-radius: 18px;
    background: rgba(255,255,255,0.96);
    box-shadow: 0 16px 34px rgba(17, 24, 39, 0.16);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    padding: 6px;
    text-align: left;
}
.pj-search-autocomplete[hidden] {
    display: none;
}
.pj-search-autocomplete-item {
    display: block;
    width: 100%;
    min-height: 42px;
    border: 0;
    border-radius: 13px;
    padding: 10px 12px;
    background: transparent;
    color: var(--pj-ink);
    box-shadow: none;
    font-size: 14px;
    font-weight: 750;
    line-height: 1.2;
    text-align: left;
}
.pj-search-autocomplete-item:hover,
.pj-search-autocomplete-item:focus {
    outline: none;
    background: #f7eadc;
    color: #9b3f26;
}
.pj-search-form > button {
    border: 0;
    border-radius: 999px;
    background: var(--pj-red);
    color: #fff;
    font-weight: 800;
    padding: 0 18px;
    box-shadow: 0 3px 0 rgba(124, 20, 31, 0.25);
}
.pj-popular-searches,
.pj-search-filter-row {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding: 10px 16px 4px;
    scrollbar-width: none;
}
.pj-search-header .pj-popular-searches {
    justify-content: flex-start;
    margin: 6px auto 0;
    max-width: 620px;
    padding-left: 4px;
    padding-right: 4px;
}
.pj-popular-searches::-webkit-scrollbar,
.pj-search-filter-row::-webkit-scrollbar {
    display: none;
}
.pj-search-chip,
.pj-search-filter {
    align-items: center;
    background: #fff;
    border: 1px solid var(--pj-gray-200);
    border-radius: 999px;
    color: var(--pj-gray-700);
    display: inline-flex;
    flex: 0 0 auto;
    font-size: 13px;
    font-weight: 700;
    line-height: 1;
    padding: 9px 12px;
    text-decoration: none;
    white-space: nowrap;
}
.pj-search-filter-row {
    border-bottom: 1px solid var(--pj-gray-100);
    padding-top: 4px;
}
.pj-search-filter.is-active {
    background: #111827;
    border-color: #111827;
    color: #fff;
}
.pj-search-group-label {
    color: var(--pj-gray-700);
    font-size: 15px;
    font-weight: 800;
    letter-spacing: 0.01em;
    margin: 6px 20px 10px;
}
.pj-search-empty {
    margin: 12px 16px 20px;
    text-align: left;
}
.pj-popular-searches--empty {
    padding: 12px 0 0;
}
.screen-reader-text {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* ── Date Section Labels ───────────────────────────────────── */
.pj-section-label {
    font-family: var(--font-sans);
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--pj-gray-500);
    padding: 14px 20px 8px;
    margin: 0;
}

/* ── Event Cards (Compact Horizontal Row) ──────────────────── */
.pj-event-card {
    background: var(--pj-white);
    border-radius: 14px;
    margin: 0 16px 16px;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0,0,0,0.06);
    transition: transform 0.15s ease, box-shadow 0.15s ease;
    display: flex;
    align-items: stretch;
    padding: 12px;
    gap: 12px;
}
.pj-event-card:active {
    transform: scale(0.995);
    box-shadow: 0 1px 2px rgba(0,0,0,0.04);
}

.pj-card-link {
    display: flex;
    text-decoration: none;
    color: inherit;
    flex: 1;
    gap: 12px;
    align-items: stretch;
}

.pj-event-image-wrap {
    flex-shrink: 0;
    width: 80px;
    height: 80px;
    border-radius: 10px;
    overflow: hidden;
    position: relative;
}
.pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap {
    align-self: center;
}
.pj-event-image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
}
/* Hide broken/empty images and their wrappers */
.pj-event-image[src=""],
.pj-event-image:not([src]) {
    display: none;
}
.pj-event-image-wrap:has(.pj-event-image[src=""]),
.pj-event-image-wrap:has(.pj-event-image:not([src])) {
    display: none;
}

.pj-event-body {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-width: 0;
}

/* ── Card Header (Category + Time) ─────────────────────────── */
.pj-event-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 4px;
}
.pj-event-category {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    padding: 3px 8px;
    border-radius: 6px;
}
.pj-event-time {
    font-size: 11px;
    font-weight: 500;
    color: var(--pj-gray-500);
}

/* ── Title ─────────────────────────────────────────────────── */
.pj-event-title {
    font-family: var(--font-serif);
    font-size: 16px;
    font-weight: 700;
    line-height: 1.3;
    margin-bottom: 4px;
    color: var(--pj-black);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.pj-event-title a {
    color: inherit;
}
.pj-event-title a:hover,
.pj-event-title a:active {
    color: var(--pj-red);
}

/* ── Description ───────────────────────────────────────────── */
.pj-event-desc {
    font-size: 13px;
    color: var(--pj-gray-700);
    line-height: 1.4;
    margin-bottom: 5px;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    min-height: calc(1.4em * 3);
    overflow: hidden;
}

/* ── Footer Row (Venue + Price) ────────────────────────────── */
.pj-event-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.pj-event-venue {
    font-size: 12px;
    color: var(--pj-gray-500);
    display: flex;
    align-items: center;
    gap: 4px;
}
.pj-venue-icon {
    font-size: 12px;
}
.pj-event-price {
    font-size: 12px;
    font-weight: 600;
    color: var(--pj-gray-900);
}
.pj-event-price.pj-free {
    color: var(--pj-red);
    font-weight: 700;
}

/* ── Source Link (inline, small) ───────────────────────────── */
.pj-event-source {
    display: none; /* hide on card rows, show on detail page */
}

/* ── Archive Layout: time + price aligned right ────────────── */
.pj-event-meta-right {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: center;
    gap: 8px;
    flex-shrink: 0;
    text-align: right;
    padding-left: 10px;
}
.pj-event-meta-right .pj-event-time {
    font-size: 11px;
    font-weight: 800;
    color: var(--pj-gray-900);
}
.pj-event-meta-right .pj-event-price {
    font-size: 12px;
    font-weight: 600;
    color: var(--pj-gray-900);
}
.pj-event-meta-right .pj-event-price.pj-free {
    color: var(--pj-red);
}
.pj-add-calendar-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 30px;
    max-width: 68px;
    padding: 6px 8px;
    border-radius: 999px;
    background: #f7eadc;
    color: #9b3f26;
    border: 1px solid rgba(155,63,38,.16);
    font-size: 10px;
    line-height: 1.05;
    font-weight: 850;
    text-align: center;
    text-decoration: none;
    box-shadow: 0 3px 8px rgba(39,31,24,.06);
}
.pj-add-calendar-link:active {
    transform: translateY(1px);
}

/* ── No Events / Pagination ───────────────────────────────── */
.pj-no-events {
    text-align: center;
    padding: 60px 20px;
    color: var(--pj-gray-500);
    font-size: 16px;
}

.pj-pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    padding: 20px 16px 34px;
}

.pj-pagination .page-numbers {
    border: 1px solid var(--pj-gray-300);
    border-radius: 999px;
    color: var(--pj-gray-900);
    font-size: 14px;
    font-weight: 700;
    line-height: 1;
    padding: 10px 13px;
    text-decoration: none;
}

.pj-pagination .current {
    background: var(--pj-gray-900);
    color: #fff;
}

.pj-pagination--explore,
.pj-pagination--events-infinite,
.pj-pagination--infinite-hidden {
    border: 0;
    height: 1px;
    margin: 0;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
}

.pj-infinite-status {
    color: var(--pj-gray-500);
    font-size: 14px;
    font-weight: 700;
    min-height: 22px;
    opacity: 0;
    padding: 4px 16px 28px;
    text-align: center;
    transition: opacity 0.16s ease;
}

.pj-infinite-status.is-visible {
    opacity: 1;
}

/* ── Bottom Tab Nav ────────────────────────────────────────── */
.pj-bottom-nav {
    position: fixed;
    /* Stay above iOS Safari's dynamic bottom controls so one tap activates links. */
    bottom: var(--pj-visual-viewport-bottom, 0px) !important;
    top: auto !important;
    left: 0;
    right: 0;
    width: 100%;
    background: rgba(255, 252, 246, 0.96);
    backdrop-filter: blur(18px) saturate(1.08);
    -webkit-backdrop-filter: blur(18px) saturate(1.08);
    border-top: 1px solid rgba(41, 34, 28, 0.10);
    box-shadow: 0 -10px 28px rgba(39, 31, 24, 0.08);
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 2px;
    /* iPhone mini/Safari needs extra internal bottom breathing room so labels stay above the browser/home area. */
    padding: 7px 10px calc(18px + env(safe-area-inset-bottom, 0px));
    min-height: calc(76px + env(safe-area-inset-bottom, 0px));
    z-index: 9999;
    transform: translateZ(0);
    transition: none;
}

/* Dropped state is intentionally neutralized: keep the nav anchored low even if an older cached page toggles the class. */
.pj-bottom-nav-is-dropped .pj-bottom-nav {
    bottom: 0 !important;
    padding-bottom: calc(18px + env(safe-area-inset-bottom, 0px));
    min-height: calc(76px + env(safe-area-inset-bottom, 0px));
}
.pj-bottom-nav::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: calc(-1 * env(safe-area-inset-bottom, 0px));
    height: env(safe-area-inset-bottom, 0px);
    background: rgba(255, 252, 246, 0.96);
    pointer-events: none;
}
.pj-bottom-nav a {
    min-height: 48px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    font-size: 11px;
    line-height: 1.05;
    font-weight: 650;
    letter-spacing: -0.01em;
    color: #52606f;
    padding: 5px 4px;
    border-radius: 18px;
    text-align: center;
    white-space: nowrap;
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
    transition: background 0.16s ease, color 0.16s ease, transform 0.16s ease;
}
.pj-bottom-nav a.active {
    color: #9b3f26;
    font-weight: 800;
}
.pj-bottom-nav a.active .pj-nav-icon {
    background: #f7eadc;
    color: #9b3f26;
    box-shadow: inset 0 0 0 1px rgba(155, 63, 38, 0.10);
}
.pj-bottom-nav a:active {
    transform: translateY(1px);
}
.pj-nav-icon {
    position: relative;
    width: 34px;
    height: 28px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #384553;
    line-height: 1;
}
.pj-nav-icon svg {
    width: 21px;
    height: 21px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
    display: block;
}
.pj-bottom-nav a:not(.active) .pj-nav-icon {
    color: #111827;
}
.pj-nav-mask {
    width: 24px;
    height: 24px;
    display: block;
    background: currentColor;
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
}
.pj-nav-mask-home {
    -webkit-mask-image: url('assets/bottom-nav-reference/home.png');
    mask-image: url('assets/bottom-nav-reference/home.png');
}
.pj-nav-mask-events {
    -webkit-mask-image: url('assets/bottom-nav-reference/events.png');
    mask-image: url('assets/bottom-nav-reference/events.png');
}
.pj-nav-mask-activities {
    -webkit-mask-image: url('assets/bottom-nav-reference/activities.png');
    mask-image: url('assets/bottom-nav-reference/activities.png');
}
.pj-nav-mask-experiences {
    -webkit-mask-image: url('assets/bottom-nav-reference/experiences.png');
    mask-image: url('assets/bottom-nav-reference/experiences.png');
}
.pj-nav-mask-saved {
    -webkit-mask-image: url('assets/bottom-nav-reference/saved.png');
    mask-image: url('assets/bottom-nav-reference/saved.png');
}
.pj-nav-label {
    display: block;
}


.pj-archive-subhead {
    margin: 4px auto 0;
    max-width: 640px;
    color: var(--pj-gray-500);
    font-size: 15px;
    line-height: 1.4;
}
.pj-event-header {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}
.pj-event-status-badge {
    display: inline-flex;
    align-items: center;
    min-height: 20px;
    padding: 4px 8px;
    border-radius: 999px;
    background: #fff3cd;
    color: #7a4a00;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: .02em;
    text-transform: uppercase;
}
.pj-event-ongoing-line {
    margin: 1px 0 6px;
    color: var(--pj-gray-800);
    font-size: 13px;
    font-weight: 750;
    line-height: 1.35;
}

.pj-explore-tabs {
    display: flex;
    align-items: center;
    gap: 0;
    padding: 3px;
    max-width: 520px;
    margin: 0 auto 10px;
    border: 1px solid var(--pj-gray-300);
    border-radius: 999px;
    background: var(--pj-gray-100);
}
.pj-explore-tab {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 1 1 0;
    min-height: 32px;
    padding: 7px 9px;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: var(--pj-gray-900);
    text-decoration: none;
    font-weight: 750;
    font-size: 12px;
    line-height: 1.1;
    text-align: center;
}
.pj-explore-tab.active {
    background: var(--pj-black);
    color: var(--pj-white);
    box-shadow: 0 1px 3px rgba(0,0,0,0.12);
}

/* ── Clean chip filters ───────────────────────────────────── */
.pj-filter-stack {
    position: sticky;
    top: 0;
    z-index: 10000;
    background: var(--pj-white);
    box-shadow: 0 1px 0 rgba(0,0,0,0.06);
}
.pj-archive-theme-scope .pj-filter-stack {
    background: rgba(255,255,255,.88);
    box-shadow: 0 1px 0 var(--pj-theme-border);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
}
.pj-primary-filter-bar {
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
    gap: 6px;
    padding: 8px 12px;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    background: var(--pj-white);
    border-bottom: 1px solid var(--pj-gray-200);
}
.pj-primary-filter-bar::-webkit-scrollbar { display: none; }

.pj-category-tab,
.pj-filter-chip,
.pj-filter-reset,
.pj-filter-clear-date,
.pj-filter-go {
    flex-shrink: 0;
    font-size: 12px;
    font-weight: 650;
    line-height: 1;
    min-height: 32px;
    padding: 9px 13px;
    border-radius: 999px;
    border: 1px solid var(--pj-gray-300);
    background: var(--pj-white);
    color: var(--pj-gray-700);
    cursor: pointer;
    transition: border-color 0.15s ease;
    white-space: nowrap;
    -webkit-tap-highlight-color: transparent;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.pj-category-tab.active,
.pj-category-tab:has(input:checked) {
    background: var(--pj-black);
    color: var(--pj-white);
    border-color: var(--pj-black);
}
.pj-archive-theme-scope .pj-category-tab.active,
.pj-archive-theme-scope .pj-category-tab:has(input:checked),
.pj-archive-theme-scope .pj-filter-chip.active,
.pj-archive-theme-scope .pj-filter-chip:has(input:checked) {
    background: var(--pj-theme-accent);
    color: var(--pj-white);
    border-color: var(--pj-theme-accent);
    box-shadow: 0 2px 8px var(--pj-theme-shadow);
}
@media (hover: hover) and (pointer: fine) {
    .pj-category-tab:hover {
        border-color: var(--pj-black);
    }
}
.pj-category-tab {
    min-height: 34px;
    padding: 10px 14px;
    border-color: var(--pj-gray-400);
    color: var(--pj-gray-900);
    font-weight: 800;
}

.pj-quick-filter-bar {
    position: static;
    top: auto;
    z-index: auto;
    padding-top: 6px;
    padding-bottom: 6px;
    white-space: nowrap;
    background: #fafafa;
    border-bottom-color: var(--pj-gray-200);
}
.pj-filter-stack--explore {
    box-shadow: none;
    overflow: visible;
}
.pj-explore-filter-form {
    position: relative;
    margin: 0;
}
.pj-filter-stack--explore .pj-primary-filter-bar {
    border-bottom: 0;
    padding-top: 11px;
    padding-bottom: 4px;
}
.pj-archive-theme-scope .pj-filter-stack--explore .pj-primary-filter-bar,
.pj-archive-theme-scope .pj-filter-stack--explore .pj-explore-filter-actions,
.pj-archive-theme-scope .pj-filter-stack--events .pj-primary-filter-bar,
.pj-archive-theme-scope .pj-events-filter-actions,
.pj-archive-theme-scope .pj-class-type-row {
    background: var(--pj-theme-soft);
}
.pj-archive-theme-scope .pj-explore-sort-toggle,
.pj-archive-theme-scope .pj-class-type-chip {
    border-color: var(--pj-theme-border);
    background: var(--pj-theme-soft-2);
}
.pj-archive-theme-scope .pj-sort-chip.active,
.pj-archive-theme-scope .pj-class-type-chip.active {
    color: var(--pj-theme-ink);
    box-shadow: 0 1px 6px var(--pj-theme-shadow);
}
.pj-filter-stack--explore .pj-more-filters {
    padding-top: 0;
    padding-bottom: 6px;
    margin-top: -1px;
    text-align: center;
}
.pj-filter-stack--explore .pj-more-filters summary {
    margin-left: auto;
    margin-right: auto;
    transform: translateY(2px);
}
.pj-filter-stack--explore .pj-more-filters-panel {
    text-align: left;
}
.pj-class-type-row {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 7px;
    overflow-x: auto;
    padding: 2px 14px 8px;
    background: var(--pj-white);
    scrollbar-width: none;
}
.pj-class-type-row::-webkit-scrollbar { display: none; }
.pj-class-type-row > span {
    flex: 0 0 auto;
    color: #8a7461;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.pj-class-type-chip {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 28px;
    padding: 7px 11px;
    border: 1px solid #eadfd2;
    border-radius: 999px;
    background: #fffaf4;
    color: #6e5541;
    font-size: 12px;
    font-weight: 800;
    text-decoration: none;
    white-space: nowrap;
}
.pj-class-type-chip.active {
    background: #6f432b;
    border-color: #6f432b;
    color: #fffdf8;
    box-shadow: 0 2px 7px rgba(111,67,43,.18);
}
.pj-explore-filter-actions {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    flex-wrap: wrap;
    padding: 0 12px 8px;
    background: var(--pj-white);
}
.pj-explore-filter-actions .pj-more-filters {
    margin: 0;
    padding: 0;
}
.pj-explore-sort-toggle {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px;
    border: 1px solid var(--pj-gray-200);
    border-radius: 999px;
    background: #f7f3ee;
}
.pj-sort-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 28px;
    padding: 7px 10px;
    border-radius: 999px;
    color: #5f574d;
    font-size: 11px;
    font-weight: 800;
    line-height: 1;
    text-decoration: none;
    white-space: nowrap;
}
.pj-sort-chip.active {
    background: var(--pj-white);
    color: var(--pj-black);
    box-shadow: 0 1px 4px rgba(0,0,0,.08);
}
.pj-explore-curation-head {
    max-width: 680px;
    margin: 18px auto 12px;
    padding: 0 20px;
    text-align: center;
}
.pj-explore-curation-kicker {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 5px;
    color: var(--pj-red);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .12em;
    line-height: 1;
    text-transform: uppercase;
}
.pj-archive-theme-scope .pj-explore-curation-kicker {
    color: var(--pj-theme-accent);
}
.pj-archive-theme-scope .pj-explore-curation-head p {
    color: var(--pj-theme-ink);
    opacity: .72;
}
.pj-archive-theme-scope .pj-event-card {
    border: 1px solid var(--pj-theme-border);
    box-shadow: 0 4px 14px var(--pj-theme-shadow);
}
.pj-archive-theme-scope .pj-event-card--explore {
    background: linear-gradient(180deg, #fff 0%, var(--pj-theme-soft-2) 100%);
    border-top: 3px solid var(--pj-theme-border);
}
.pj-archive-theme-scope .pj-event-card--explore::before {
    background: var(--pj-theme-accent);
    opacity: .18;
}
.pj-explore-curation-head p {
    margin: 0;
    color: var(--pj-gray-600);
    font-size: 13px;
    line-height: 1.35;
}
.pj-filter-stack--events .pj-primary-filter-bar {
    padding-top: 12px;
    padding-bottom: 7px;
    overflow-y: visible;
}
.pj-events-filter-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 0 12px 8px;
    background: var(--pj-white);
    overflow: visible;
}
.pj-events-filter-actions .pj-more-filters {
    flex: 0 0 auto;
    margin: 0;
    padding: 0;
    border-bottom: 0;
    background: transparent;
}
.pj-events-filter-actions .pj-date-form {
    margin-left: auto;
}
.pj-events-filter-actions .pj-filter-chip--date {
    min-height: 34px;
    padding: 9px 13px;
}
.pj-filter-chip,
.pj-filter-reset,
.pj-filter-clear-date,
.pj-filter-go {
    min-height: 28px;
    padding: 7px 11px;
    background: #fafafa;
    border-color: var(--pj-gray-200);
    color: var(--pj-gray-600);
    font-weight: 650;
}
.pj-filter-chip.active,
.pj-filter-chip:has(input:checked) {
    background: var(--pj-red);
    color: var(--pj-white);
    border-color: var(--pj-red);
}
@media (hover: hover) and (pointer: fine) {
    .pj-filter-chip:hover {
        border-color: var(--pj-red);
    }
}
.pj-event-filter-form {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    margin: 0;
    width: 100%;
}
.pj-filter-choice {
    position: relative;
    user-select: none;
}
.pj-filter-choice input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}
.pj-filter-go {
    min-height: 28px;
    padding: 7px 11px;
    border: 1px solid #9f3f20;
    background: linear-gradient(180deg, #e37a3f 0%, #c65a2e 48%, #a94624 100%);
    color: var(--pj-white);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0.01em;
    gap: 6px;
    box-shadow: 0 2px 0 #84331c, 0 5px 9px rgba(166, 70, 35, 0.24);
    transform: translateY(-1px);
}
.pj-filter-go:hover,
.pj-filter-go:focus-visible {
    background: linear-gradient(180deg, #d86a34 0%, #a94624 100%);
    border-color: #84331c;
    color: var(--pj-white);
    box-shadow: 0 1px 0 #84331c, 0 4px 7px rgba(166, 70, 35, 0.24);
    transform: translateY(0);
}
.pj-filter-go:active {
    box-shadow: 0 0 0 #84331c, 0 2px 5px rgba(166, 70, 35, 0.18);
    transform: translateY(1px);
}
.pj-filter-go-label,
.pj-filter-go-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}
.pj-filter-go-icon {
    width: 16px;
    height: 16px;
    border-radius: 999px;
    background: rgba(255,255,255,0.22);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.28);
    font-size: 12px;
}
.pj-filter-go--floating {
    position: absolute;
    left: 50%;
    top: calc(100% + 8px);
    z-index: 140;
    min-height: 42px;
    padding: 12px 18px;
    border-radius: 999px;
    box-shadow: 0 3px 0 #0b5f2b, 0 12px 26px rgba(21, 128, 61, 0.34);
    opacity: 0;
    pointer-events: none;
    transform: translate(-50%, -8px) scale(0.96);
    transition: opacity 0.16s ease, transform 0.16s ease;
}
.pj-explore-filter-form.is-dirty .pj-filter-go--floating {
    opacity: 1;
    pointer-events: auto;
    transform: translate(-50%, 0) scale(1);
}
.pj-explore-filter-form:has(.pj-more-filters[open]) .pj-filter-go--floating {
    opacity: 0;
    pointer-events: none;
    transform: translate(-50%, -8px) scale(0.96);
}
.pj-filter-chip--anytime {
    background: #e8f7ef;
    border-color: #9fd9b7;
    color: #17633a;
    font-weight: 800;
    box-shadow: 0 1px 4px rgba(23, 99, 58, 0.12);
}
.pj-filter-chip--anytime:hover,
.pj-filter-chip--anytime:focus-visible {
    background: #d5f0e2;
    border-color: #58b57d;
    color: #0f4f2d;
    box-shadow: 0 2px 8px rgba(23, 99, 58, 0.18);
}
.pj-filter-reset {
    border-color: transparent;
    background: var(--pj-gray-100);
    color: var(--pj-gray-500);
}
.pj-filter-clear-date {
    width: 32px;
    padding: 0;
    font-size: 18px;
    border-color: transparent;
    background: var(--pj-gray-100);
    color: var(--pj-gray-500);
}

.pj-date-form {
    display: inline-flex;
    align-items: center;
    flex-shrink: 0;
    flex-grow: 0;
    width: auto;
    margin: 0;
    position: relative;
    gap: 6px;
}
.pj-date-select-panel {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    z-index: 2147483000;
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 0;
    background: transparent;
    white-space: nowrap;
}
.pj-date-select-panel[hidden] {
    display: none;
}
.pj-date-select {
    min-height: 34px;
    padding: 0 8px;
    border: 1px solid rgba(17, 24, 39, 0.14);
    border-radius: 999px;
    background: #fff;
    color: var(--pj-ink);
    font: 800 12px/1 var(--font-sans);
}
.pj-date-select--day {
    min-width: 58px;
}
.pj-date-select--year {
    min-width: 76px;
}
.pj-filter-chip--date {
    position: relative;
    overflow: hidden;
    gap: 4px;
    width: auto;
}
.pj-filter-chip--date::before {
    content: '📅';
    font-size: 12px;
}
.pj-date-popover {
    position: fixed;
    top: 126px;
    left: 12px;
    right: 12px;
    z-index: 2147483000;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px;
    align-items: end;
    max-width: 360px;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}
.pj-date-today-marker {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    min-height: 34px;
    padding: 0 12px;
    border: 1px solid rgba(17, 24, 39, 0.10);
    border-radius: 999px;
    background: #f3f4f6;
    color: var(--pj-gray-700);
    font-size: 12px;
    font-weight: 800;
}
.pj-date-today-marker__label {
    color: var(--pj-gray-500);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-size: 10px;
}
.pj-date-today-marker__date {
    color: var(--pj-ink);
}
.pj-date-popover[hidden] {
    display: none;
}
.pj-date-popover-open .pj-filter-stack,
.pj-date-popover-open .pj-filter-stack--events,
.pj-date-popover-open .pj-filter-stack--events .pj-primary-filter-bar {
    overflow: visible !important;
    z-index: 2147482000 !important;
}
.pj-date-form.is-date-open {
    z-index: 2147482500;
}
.pj-date-popover-open .pj-events-list,
.pj-date-popover-open .pj-event-card {
    position: relative;
    z-index: 1;
}
.pj-date-popover-label {
    display: grid;
    gap: 5px;
    color: var(--pj-gray-600);
    font-size: 12px;
    font-weight: 700;
}
.pj-date-popover-label--picker {
    position: relative;
}
.pj-date-display {
    display: flex;
    align-items: center;
    min-height: 40px;
    padding: 0 12px;
    border: 1px solid rgba(196, 30, 58, 0.20);
    border-radius: 999px;
    background: rgba(196, 30, 58, 0.06);
    color: var(--pj-red);
    font-size: 13px;
    font-weight: 800;
    white-space: nowrap;
}
.pj-date-display::after {
    content: '›';
    margin-left: auto;
    transform: rotate(90deg);
    font-size: 16px;
    line-height: 1;
}
.pj-date-picker-shell {
    position: relative;
    display: inline-flex;
    flex: 0 0 auto;
}
.pj-date-picker-shell .pj-filter-chip--date {
    pointer-events: auto;
}
.pj-native-date-input {
    position: fixed;
    left: -100vw;
    top: 0;
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}
.pj-calendar-panel {
    position: fixed;
    left: 50%;
    top: 50%;
    right: auto;
    z-index: 2147483000;
    width: min(92vw, 360px);
    max-width: 360px;
    padding: 14px;
    border: 1px solid rgba(255,255,255,0.58);
    border-radius: 22px;
    background: rgba(255,255,255,0.68);
    box-shadow: 0 18px 48px rgba(17, 24, 39, 0.20);
    backdrop-filter: blur(22px);
    -webkit-backdrop-filter: blur(22px);
    transform: translate(-50%, -50%);
}
.pj-calendar-panel[hidden] {
    display: none;
}
.pj-calendar-head {
    display: grid;
    grid-template-columns: 36px minmax(0, 1fr) 36px;
    gap: 10px;
    align-items: center;
    margin-bottom: 10px;
    text-align: center;
}
.pj-calendar-head strong {
    font: 800 16px/1 var(--font-sans);
    color: var(--pj-ink);
}
.pj-calendar-head span {
    font: 700 11px/1 var(--font-sans);
    color: var(--pj-gray-500);
}
.pj-calendar-weekdays,
.pj-calendar-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 5px;
    text-align: center;
}
.pj-calendar-weekdays {
    margin-bottom: 6px;
    color: var(--pj-gray-500);
    font: 800 10px/1 var(--font-sans);
    text-transform: uppercase;
}
.pj-calendar-day {
    position: relative;
    aspect-ratio: 1;
    border: 1px solid transparent;
    border-radius: 999px;
    background: transparent;
    color: var(--pj-ink);
    font: 800 13px/1 var(--font-sans);
    cursor: pointer;
}
.pj-calendar-day.is-today {
    border-color: #c65a2e;
    background: #fff3e0;
    color: #9f3f20;
    box-shadow: 0 0 0 3px rgba(198, 90, 46, 0.18), 0 5px 14px rgba(159, 63, 32, 0.16);
}
.pj-calendar-day.is-today::after {
    content: '';
    position: absolute;
    left: 50%;
    bottom: 6px;
    width: 4px;
    height: 4px;
    border-radius: 999px;
    background: #c65a2e;
    transform: translateX(-50%);
}
.pj-calendar-day.is-selected {
    border-color: #2563eb;
    background: #2563eb;
    color: #fff;
}
.pj-calendar-day.is-selected::after {
    background: #fff;
}
.pj-calendar-day.is-in-range {
    background: rgba(37, 99, 235, 0.14);
    color: #1d4ed8;
}
.pj-calendar-day.is-disabled,
.pj-calendar-day:disabled {
    color: var(--pj-gray-400);
    cursor: not-allowed;
    opacity: 0.45;
}
.pj-calendar-nav {
    width: 36px;
    height: 36px;
    border: 0;
    border-radius: 999px;
    background: rgba(17, 24, 39, 0.07);
    color: var(--pj-ink);
    font: 900 22px/1 var(--font-sans);
}
.pj-calendar-nav:disabled {
    opacity: 0.35;
}
.pj-calendar-help {
    margin: 0 0 10px;
    color: var(--pj-gray-600);
    font: 700 11px/1.3 var(--font-sans);
    text-align: center;
}
.pj-calendar-actions {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 8px;
    align-items: center;
    margin-top: 12px;
}
.pj-date-reset--calendar {
    min-height: 40px;
    padding: 0 12px;
    border: 0;
    border-radius: 999px;
    background: rgba(17, 24, 39, 0.07);
    color: var(--pj-gray-700);
    font: 800 12px/1 var(--font-sans);
    cursor: pointer;
}
.pj-date-apply--calendar {
    width: 100%;
    margin-top: 12px;
    min-height: 40px;
}
.pj-date-input {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    opacity: 0.01;
    cursor: pointer;
    border: 0;
    background: transparent;
    color: transparent;
}
.pj-date-input--popover {
    position: absolute;
    inset: 19px 0 0 0;
    width: 100%;
    height: 40px;
    opacity: 0.01;
    padding: 0;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: transparent;
    font: inherit;
    z-index: 2;
    -webkit-appearance: none;
    appearance: none;
}
.pj-date-apply {
    min-height: 36px;
    padding: 0 12px;
    border: 0;
    border-radius: 999px;
    background: var(--pj-red);
    color: #fff;
    font-size: 12px;
    font-weight: 800;
    cursor: pointer;
}
.pj-date-apply--inline {
    min-height: 34px;
    padding: 0 12px;
    flex: 0 0 auto;
}
.pj-date-reset {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    padding: 0 10px;
    border-radius: 999px;
    border: 1px solid rgba(196, 30, 58, 0.22);
    background: rgba(196, 30, 58, 0.08);
    color: var(--pj-red);
    font-size: 12px;
    font-weight: 700;
    text-decoration: none;
    white-space: nowrap;
}

.pj-filter-toggle {
    display: none;
    position: fixed;
    right: 14px;
    bottom: 74px;
    z-index: 160;
    padding: 10px 14px;
    border: 0;
    border-radius: 999px;
    background: var(--pj-black);
    color: var(--pj-white);
    font: 700 12px/1 var(--font-sans);
    box-shadow: 0 6px 18px rgba(0,0,0,0.22);
}
body.pj-filters-collapsed .pj-quick-filter-bar:not(.is-open) {
    transform: translateY(-100%);
    opacity: 0;
    max-height: 0;
    padding-top: 0;
    padding-bottom: 0;
    border-bottom-width: 0;
    overflow: hidden;
}
body.pj-filters-collapsed .pj-filter-toggle {
    display: inline-flex;
}
.pj-quick-filter-bar.is-open {
    transform: none;
    opacity: 1;
    max-height: 48px;
}

/* ── Single Event Page ─────────────────────────────────────── */
/* Full-bleed blurred backplate fills width behind image */
.pj-single-hero {
    position: relative;
    width: 100%;
    min-height: 280px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background: var(--pj-gray-100);
}
.pj-single-hero-bg {
    position: absolute;
    inset: -20px;
    background-size: cover;
    background-position: center;
    filter: blur(40px) brightness(0.75);
    z-index: 0;
}
.pj-single-hero-link {
    position: relative;
    z-index: 1;
    display: inline-flex;
    max-width: 100%;
    cursor: pointer;
}
.pj-single-hero-link:focus-visible {
    outline: 3px solid var(--pj-red);
    outline-offset: 4px;
}
.pj-single-hero-link:hover img {
    transform: scale(1.01);
}
.pj-single-hero img {
    position: relative;
    z-index: 1;
    max-height: 70vh;
    width: auto;
    max-width: 100%;
    object-fit: contain;
    box-shadow: 0 8px 40px rgba(0,0,0,0.25);
    transition: transform 0.18s ease;
}
.pj-single-content {
    padding: 24px 20px;
    max-width: 640px;
    margin: 0 auto;
}
.pj-single-title {
    font-family: var(--font-serif);
    font-size: 28px;
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 12px;
}
.pj-single-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 20px;
}
.pj-single-meta-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 14px;
    color: var(--pj-gray-700);
    padding: 6px 12px;
    background: var(--pj-gray-100);
    border-radius: 8px;
}
.pj-single-description {
    font-size: 16px;
    line-height: 1.7;
    color: var(--pj-gray-900);
    margin-bottom: 24px;
}
.pj-single-source {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    background: var(--pj-red);
    color: var(--pj-white);
    font-size: 15px;
    font-weight: 600;
    padding: 14px 28px;
    border-radius: 12px;
    margin: 0 auto 24px;
    width: fit-content;
    transition: background 0.15s ease;
}
.pj-single-source:hover {
    background: #a02020;
}
.pj-single-calendar {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    background: #f7eadc;
    color: #9b3f26;
    border: 1px solid rgba(155,63,38,.16);
    font-size: 15px;
    font-weight: 850;
    padding: 14px 28px;
    border-radius: 12px;
    margin: 0 auto 12px;
    width: fit-content;
    text-decoration: none;
    box-shadow: 0 6px 16px rgba(39,31,24,.07);
}
.pj-single-calendar:active {
    transform: translateY(1px);
}

/* ── Front Page / Weekend Guide ────────────────────────────── */
.pj-weekend-hero {
    padding: 24px 20px;
    text-align: center;
}
.pj-weekend-hero h2 {
    font-family: var(--font-serif);
    font-size: 26px;
    font-weight: 700;
    margin-bottom: 4px;
}
.pj-weekend-hero p {
    font-size: 15px;
    color: var(--pj-gray-500);
}
.pj-featured-grid {
    padding: 0 16px;
    display: grid;
    gap: 12px;
}

/* ── Mobile Text Wrapping ─────────────────────────────────────── */
@media (max-width: 760px) {
    .pj-site-header {
        padding: 6px 16px 6px;
    }
    .pj-site-title {
        font-size: 22px;
    }
    .pj-archive-header {
        padding: 12px 16px 7px;
    }
    .pj-archive-title {
        font-size: 24px;
        line-height: 1.12;
    }
    .pj-archive-subhead {
        margin-top: 2px;
        font-size: 13px;
        line-height: 1.25;
    }
    .pj-explore-tabs {
        margin: 0 10px 8px;
        max-width: none;
        overflow: visible;
        padding: 3px;
    }
    .pj-explore-tab {
        min-width: 0;
        min-height: 30px;
        padding: 7px 5px;
        font-size: 11.5px;
    }
    .pj-filter-stack {
        top: 0;
    }
    .pj-filter-stack--explore .pj-primary-filter-bar {
        padding-top: 12px;
        padding-bottom: 3px;
    }
    .pj-category-tabs {
        padding: 6px 10px;
        gap: 5px;
        flex-wrap: nowrap;
    }
    .pj-category-tab,
    .pj-filter-chip,
    .pj-filter-reset,
    .pj-filter-clear-date {
        min-height: 30px;
        padding: 8px 11px;
        font-size: 11.5px;
    }
    .pj-category-tab {
        min-height: 32px;
        padding: 8px 12px;
        font-size: 11.5px;
    }
    .pj-filter-chip,
    .pj-filter-reset,
    .pj-filter-clear-date {
        min-height: 27px;
        padding: 7px 10px;
        font-size: 11px;
    }
    .pj-quick-filter-bar {
        top: 88px;
        padding: 5px 10px;
        gap: 5px;
        max-height: 40px;
        flex-wrap: nowrap;
        overflow-x: auto;
        overflow-y: hidden;
        transition: transform 0.18s ease, opacity 0.18s ease, max-height 0.18s ease;
    }
    .pj-date-form {
        flex: 0 0 auto;
        width: auto;
    }
    .pj-filter-chip--date {
        width: auto;
        min-width: 0;
    }
    .pj-filter-toggle {
        display: inline-flex;
        opacity: 0;
        pointer-events: none;
        transform: translateY(8px);
        transition: opacity 0.18s ease, transform 0.18s ease;
    }
    body.pj-filters-collapsed .pj-quick-filter-bar:not(.is-open) {
        transform: translateY(-100%);
        opacity: 0;
        max-height: 0;
        padding-top: 0;
        padding-bottom: 0;
        border-bottom-width: 0;
        overflow: hidden;
    }
    body.pj-filters-collapsed .pj-filter-toggle {
        opacity: 1;
        pointer-events: auto;
        transform: translateY(0);
    }
    .pj-quick-filter-bar.is-open {
        transform: none;
        opacity: 1;
        max-height: 40px;
    }
    .pj-section-label {
        padding: 10px 16px 7px;
        font-size: 11.5px;
        letter-spacing: 1.2px;
    }
    .pj-event-card--recurring .pj-event-title {
        margin-bottom: 2px;
    }
    .pj-event-card--recurring .pj-event-ongoing-line {
        font-size: 12.5px;
        margin-bottom: 5px;
    }
    .pj-event-title {
        white-space: normal;
        overflow: visible;
        text-overflow: clip;
    }
    .pj-event-desc {
        white-space: normal;
        overflow: visible;
        text-overflow: clip;
    }
}


/* ── Anytime / Explore cards ───────────────────────────────── */
.pj-event-card--explore {
    align-items: stretch;
    padding: 0;
    border: 1px solid rgba(34,34,34,0.06);
    box-shadow: 0 8px 24px rgba(0,0,0,0.075);
    background: linear-gradient(180deg, #fff 0%, #fff 74%, #fbfaf7 100%);
}
.pj-event-card--explore:active {
    transform: none;
}
.pj-event-card--explore .pj-card-link {
    align-items: stretch;
    flex-direction: column;
    gap: 0;
}
.pj-event-card--explore .pj-card-link { cursor: pointer; }
.pj-event-card--explore .pj-event-image-wrap {
    width: 100%;
    aspect-ratio: 4 / 3;
    height: auto;
    border-radius: 14px 14px 0 0;
    background: var(--pj-gray-100);
}
.pj-event-card--explore .pj-event-image-wrap::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0) 45%, rgba(0,0,0,0.34) 100%);
    pointer-events: none;
}
.pj-event-card--explore .pj-event-image-wrap--placeholder::after {
    background: linear-gradient(180deg, rgba(255,255,255,0) 44%, rgba(0,0,0,0.18) 100%);
}
.pj-event-card--explore .pj-event-image {
    transform: scale(1.01);
}
.pj-event-image-wrap--carousel .pj-event-image {
    position: static;
    display: block;
    width: 100%;
    height: 100%;
    transform: none;
}
.pj-explore-carousel {
    position: absolute;
    inset: 0;
    z-index: 0;
    display: flex;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    touch-action: pan-x pan-y;
}
.pj-explore-carousel::-webkit-scrollbar {
    display: none;
}
.pj-explore-carousel-slide {
    position: relative;
    flex: 0 0 100%;
    width: 100%;
    height: 100%;
    scroll-snap-align: center;
}
.pj-explore-carousel-btn {
    position: absolute;
    top: 50%;
    z-index: 3;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border: 1px solid rgba(255,255,255,0.78);
    border-radius: 50%;
    background: rgba(15,15,15,0.52);
    color: #fff;
    box-shadow: 0 4px 12px rgba(0,0,0,0.22);
    backdrop-filter: blur(8px);
    font-size: 25px;
    line-height: 1;
    cursor: pointer;
    transform: translateY(-50%);
}
.pj-explore-carousel-btn--prev { left: 10px; }
.pj-explore-carousel-btn--next { right: 10px; }
.pj-explore-carousel-count {
    position: absolute;
    right: 12px;
    bottom: 12px;
    z-index: 3;
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 5px 8px;
    background: rgba(20,20,20,0.72);
    color: #fff;
    box-shadow: 0 4px 12px rgba(0,0,0,0.16);
    backdrop-filter: blur(8px);
    font-size: 11px;
    font-weight: 800;
    line-height: 1;
}
.pj-event-image-wrap--carousel .pj-explore-image-badge {
    max-width: calc(100% - 90px);
}
.pj-explore-card-number {
    position: absolute;
    left: 12px;
    top: 12px;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 30px;
    height: 26px;
    border: 1px solid rgba(255,255,255,0.74);
    border-radius: 999px;
    padding: 0 8px;
    background: rgba(252, 242, 224, 0.92);
    color: #5e3d25;
    box-shadow: 0 8px 18px rgba(35, 22, 12, 0.18), inset 0 1px 0 rgba(255,255,255,0.68);
    backdrop-filter: blur(10px);
    font-family: 'Inter', sans-serif;
    font-size: 12px;
    font-weight: 850;
    line-height: 1;
    letter-spacing: 0.04em;
    text-shadow: none;
}
.pj-explore-image-badge {
    position: absolute;
    left: 12px;
    bottom: 12px;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    max-width: calc(100% - 24px);
    border-radius: 999px;
    padding: 6px 10px;
    background: rgba(20,20,20,0.78);
    color: #fff;
    box-shadow: 0 4px 12px rgba(0,0,0,0.16);
    backdrop-filter: blur(8px);
    font-size: 10.5px;
    font-weight: 800;
    letter-spacing: .08em;
    line-height: 1;
    text-transform: uppercase;
}
.pj-event-card--explore .pj-event-body {
    justify-content: flex-start;
    padding: 11px 13px 12px;
}
.pj-event-card--explore .pj-event-title {
    font-family: 'Playfair Display', serif;
    font-size: 18.5px;
    line-height: 1.1;
    letter-spacing: -0.01em;
    margin: 0 0 5px;
}
.pj-event-card--explore .pj-event-desc {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    font-size: 13px;
    line-height: 1.34;
    color: var(--pj-gray-700);
    margin-bottom: 7px;
}
.pj-anytime-badges,
.pj-anytime-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    margin: 4px 0 6px;
}
.pj-anytime-badges span,
.pj-anytime-tags span {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 4px 7px;
    font-size: 10.5px;
    font-weight: 750;
    line-height: 1;
    background: #f2efe9;
    color: #5b5449;
}
.pj-anytime-badges span {
    background: #fff7e4;
    color: #7a4f08;
    border: 1px solid rgba(122,79,8,0.12);
}
.pj-explore-why-go {
    margin: 0 0 7px;
    font-size: 12.25px;
    line-height: 1.34;
    color: #5f574d;
}
.pj-explore-why-go span,
.pj-happy-hour-line span,
.pj-class-price-line span,
.pj-explore-time-needed span {
    font-weight: 800;
    color: #3f372f;
}
.pj-happy-hour-line {
    display: block;
    width: max-content;
    max-width: min(86%, 280px);
    margin: 0 auto 7px;
    padding: 7px 10px;
    border-radius: 11px;
    background: #fff3df;
    border: 1px solid rgba(184,93,34,.15);
    color: #66401f;
    font-size: 12px;
    line-height: 1.28;
    text-align: center;
}
.pj-explore-best-for {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    margin: 0 0 7px;
}
.pj-explore-best-for span {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 4px 7px;
    background: #eaf3ff;
    border: 1px solid rgba(35,83,129,.12);
    color: #244766;
    font-size: 10.5px;
    font-weight: 800;
    line-height: 1;
}
.pj-explore-detail-planner {
    display: grid;
    gap: 5px;
    margin: 10px 0 0;
    color: rgba(255,255,255,.9);
    font-size: 13px;
    line-height: 1.35;
}
.pj-explore-detail-planner p { margin: 0; }
.pj-explore-detail-planner span { font-weight: 800; color: #fff; }
.pj-explore-time-needed {
    margin: 0 0 7px;
    font-size: 11.75px;
    line-height: 1.25;
    color: #645a4d;
}
.pj-class-price-line {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    width: max-content;
    max-width: 100%;
    margin: 0 0 8px;
    padding: 6px 9px;
    border-radius: 999px;
    background: #fff2d9;
    border: 1px solid rgba(179, 99, 29, .18);
    color: #65411f;
    font-size: 12px;
    line-height: 1.12;
    font-weight: 800;
    box-shadow: 0 2px 7px rgba(91, 53, 20, .06);
}
.pj-class-price-line span {
    color: #9b5319;
    text-transform: uppercase;
    letter-spacing: .05em;
    font-size: 10px;
}
.pj-anytime-meta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin: 8px 0 0;
}
.pj-anytime-meta-row span {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 5px 8px;
    background: #f7f2e9;
    border: 1px solid rgba(88,70,48,.08);
    color: #4a4035;
    font-size: 11px;
    font-weight: 750;
    line-height: 1;
}
.pj-anytime-hours-note,
.pj-anytime-disclaimer {
    font-size: 12px;
    line-height: 1.35;
    color: var(--pj-gray-500);
}
.pj-anytime-hours-note { margin: 5px 0 0; }
.pj-event-card--explore .pj-anytime-hours-note { display: none; }
.pj-anytime-disclaimer {
    margin: 10px 16px 6px;
    padding: 10px 12px;
    border: 1px solid var(--pj-gray-300);
    border-radius: 12px;
    background: var(--pj-white);
    text-align: center;
}
.pj-anytime-disclaimer--single {
    margin: -6px 0 18px;
    text-align: left;
    background: var(--pj-gray-100);
}
.pj-anytime-tags--single { margin: -8px 0 16px; }

@media (max-width: 760px) {
    .pj-event-card--explore .pj-event-image-wrap {
        width: 100%;
        aspect-ratio: 4 / 3;
        height: auto;
    }
    .pj-event-card--explore .pj-event-title {
        font-size: 18px;
    }
    .pj-explore-image-badge {
        left: 10px;
        bottom: 10px;
    }
    .pj-explore-card-number {
        left: 10px;
        top: 10px;
        min-width: 28px;
        height: 24px;
        padding: 0 7px;
        font-size: 11px;
    }
}

.pj-event-card--explore-clean {
    position: relative;
    overflow: hidden;
    min-height: 244px;
    border: 1px solid rgba(82,55,35,.14);
    border-radius: 26px;
    background: #1f1814;
    box-shadow: 0 16px 34px rgba(64,43,27,.13);
    isolation: isolate;
}
.pj-archive-theme-scope .pj-event-card--explore-clean {
    background: #1f1814;
    border-top: 0;
}
.pj-event-card--explore-clean::before {
    display: none;
}
.pj-event-card--explore-clean .pj-card-link {
    display: block;
    min-height: 244px;
    position: relative;
    color: #fff;
}
.pj-event-card--explore-clean .pj-event-image-wrap {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    aspect-ratio: auto;
    border-radius: 0;
    background: #281f19;
}
.pj-event-card--explore-clean .pj-event-image-wrap::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(to top, rgba(20,13,9,.80) 0%, rgba(20,13,9,.44) 45%, rgba(20,13,9,.08) 78%);
    pointer-events: none;
}
.pj-event-card--explore-clean .pj-event-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: scale(1.01);
}
.pj-event-card--explore-clean .pj-explore-image-badge {
    left: 14px;
    top: 14px;
    bottom: auto;
    z-index: 3;
    max-width: calc(100% - 74px);
    border: 1px solid rgba(255,255,255,.24);
    background: rgba(255,255,255,.18);
    color: #fff;
    backdrop-filter: blur(10px);
    box-shadow: none;
    font-size: 10.5px;
    letter-spacing: .06em;
}
.pj-event-card--explore-clean .pj-event-body {
    position: absolute;
    left: 15px;
    right: 15px;
    bottom: 15px;
    z-index: 2;
    padding: 0;
    color: #fff;
}
.pj-event-card--explore-clean .pj-event-title {
    margin: 0 44px 7px 0;
    color: #fff;
    font-family: 'Playfair Display', serif;
    font-size: 28px;
    line-height: .98;
    letter-spacing: -0.03em;
    text-shadow: 0 2px 12px rgba(0,0,0,.18);
}
.pj-event-card--explore-clean .pj-event-desc {
    display: block;
    margin: 0;
    max-width: 295px;
    color: rgba(255,255,255,.90);
    font-size: 13.25px;
    font-weight: 750;
    line-height: 1.28;
    overflow: visible;
    text-shadow: 0 1px 9px rgba(0,0,0,.20);
}
.pj-event-card--explore-clean .pj-anytime-meta-row--clean {
    margin: 11px 0 0;
    gap: 7px;
}
.pj-event-card--explore-clean .pj-anytime-meta-row--clean span {
    border: 1px solid rgba(255,255,255,.55);
    background: rgba(255,251,243,.94);
    color: #403127;
    box-shadow: 0 4px 12px rgba(0,0,0,.10);
    font-size: 11px;
    font-weight: 900;
    padding: 7px 10px;
}
.pj-event-card--explore-clean .pj-explore-card-action--save {
    position: absolute !important;
    right: 13px;
    top: 13px;
    z-index: 4;
    width: 40px;
    height: 40px;
    min-height: 0;
    padding: 0 !important;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.74);
    background: rgba(255,250,241,.94);
    color: #2f2520;
    box-shadow: 0 8px 20px rgba(0,0,0,.18);
    font-size: 20px !important;
    line-height: 1;
    align-items: center;
    justify-content: center;
}
.pj-event-card--explore-clean .pj-explore-card-action--save em {
    display: none;
}
.pj-event-card--explore-clean .pj-explore-card-action--save[aria-pressed="true"] {
    color: #9b3f26;
    background: #fff3df;
}
@media (max-width: 760px) {
    .pj-event-card--explore-clean,
    .pj-event-card--explore-clean .pj-card-link {
        min-height: 238px;
    }
    .pj-event-card--explore-clean .pj-event-image-wrap {
        width: 100%;
        height: 100%;
        aspect-ratio: auto;
    }
    .pj-event-card--explore-clean .pj-event-title {
        font-size: 26px;
    }
}

/* ── Mobile cleanup: Events / Explore Anytime ───────────────── */
.pj-top-nav {
    gap: 0;
    margin: 8px auto 0;
    max-width: 360px;
    padding: 3px;
    border: 1px solid var(--pj-gray-300);
    border-radius: 999px;
    background: var(--pj-gray-100);
}
.pj-top-nav a {
    flex: 1 1 0;
    min-height: 34px;
    border-color: transparent;
    text-align: center;
}
.pj-top-nav a.active {
    box-shadow: 0 1px 3px rgba(0,0,0,0.12);
}
.pj-more-filters {
    display: block;
    border-bottom: 1px solid var(--pj-gray-200);
    background: #fafafa;
    padding: 0 12px 8px;
}
.pj-more-filters summary {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 8px 12px;
    border: 1px solid var(--pj-gray-200);
    border-radius: 999px;
    color: var(--pj-gray-700);
    background: var(--pj-white);
    font-size: 12px;
    font-weight: 750;
    list-style: none;
    cursor: pointer;
}
.pj-more-filters summary::-webkit-details-marker { display: none; }
.pj-more-filters summary::after {
    content: '▾';
    margin-left: 6px;
    font-size: 10px;
}
.pj-more-filters[open] summary::after { content: '▴'; }
.pj-more-filters-panel {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding-top: 8px;
}

@media (max-width: 760px) {
    .pj-site-header {
        padding: 7px 14px 8px;
    }
    .pj-site-title {
        font-size: 21px;
        line-height: 1;
    }
    .pj-site-subtitle {
        font-size: 10px;
        letter-spacing: 1.7px;
        margin-top: 1px;
    }
    .pj-top-nav {
        margin-top: 7px;
        max-width: 330px;
        padding: 3px;
    }
    .pj-top-nav a {
        min-height: 32px;
        padding: 8px 8px;
        font-size: 12.5px;
    }
    .pj-archive-header {
        padding: 10px 16px 6px;
    }
    .pj-archive-title {
        font-size: 22px;
        line-height: 1.08;
    }
    .pj-archive-subhead {
        max-width: 340px;
        font-size: 12.5px;
        line-height: 1.25;
    }
    .pj-filter-stack {
        top: 0;
        box-shadow: 0 1px 0 rgba(0,0,0,0.04);
    }
    .pj-primary-filter-bar {
        padding: 5px 10px;
        gap: 5px;
        border-bottom-color: var(--pj-gray-200);
    }
    .pj-more-filters {
        background: var(--pj-white);
        padding: 0 10px 6px;
    }
    .pj-mobile-extra-filter {
        display: none !important;
    }
    .pj-more-filters {
        display: block;
        border-bottom: 1px solid var(--pj-gray-200);
        background: #fafafa;
        padding: 0 10px 6px;
    }
    .pj-more-filters summary {
        display: inline-flex;
        align-items: center;
        min-height: 28px;
        padding: 7px 11px;
        border: 1px solid var(--pj-gray-200);
        border-radius: 999px;
        color: var(--pj-gray-700);
        background: var(--pj-white);
        font-size: 11px;
        font-weight: 750;
        list-style: none;
    }
    .pj-more-filters summary::-webkit-details-marker { display: none; }
    .pj-more-filters summary::after {
        content: '▾';
        margin-left: 6px;
        font-size: 10px;
    }
    .pj-more-filters[open] summary::after { content: '▴'; }
    .pj-more-filters-panel {
        display: flex;
        flex-wrap: wrap;
        gap: 6px;
        padding-top: 7px;
    }
    .pj-event-card {
        margin: 0 12px 10px;
        padding: 9px;
        gap: 9px;
        border-radius: 13px;
    }
    .pj-event-card:not(.pj-event-card--explore) {
        min-height: 124px;
    }
    .pj-card-link { gap: 9px; }
    .pj-event-image-wrap {
        width: 84px;
        height: 84px;
        border-radius: 10px;
    }
    .pj-event-body { justify-content: center; }
    .pj-event-header {
        gap: 5px;
        margin-bottom: 3px;
    }
    .pj-event-category {
        padding: 3px 7px;
        font-size: 9px;
        letter-spacing: .07em;
    }
    .pj-event-status-badge {
        min-height: 18px;
        padding: 3px 7px;
        font-size: 9px;
    }
    .pj-event-title {
        font-size: 15.5px;
        line-height: 1.22;
        margin-bottom: 3px;
    }
    .pj-event-card:not(.pj-event-card--explore) .pj-event-desc {
        font-size: 12.25px;
        line-height: 1.3;
        margin-bottom: 3px;
        display: -webkit-box;
        -webkit-line-clamp: 3;
        -webkit-box-orient: vertical;
        min-height: calc(1.3em * 3);
        overflow: hidden;
    }
    .pj-event-card--explore .pj-event-desc {
        min-height: 0;
    }
    .pj-event-footer { margin-top: 1px; }
    .pj-event-venue {
        font-size: 11.5px;
        line-height: 1.2;
    }
    .pj-event-meta-right {
        padding-left: 6px;
        min-width: 54px;
        gap: 7px;
    }
    .pj-event-meta-right .pj-event-time,
    .pj-event-meta-right .pj-event-price {
        font-size: 11px;
        line-height: 1.15;
    }
    .pj-event-meta-right .pj-event-time {
        font-weight: 800;
    }
    .pj-bottom-nav a {
        font-size: 10.5px;
        padding-left: 3px;
        padding-right: 3px;
    }
    .pj-nav-icon {
        width: 32px;
        height: 27px;
    }
    .pj-nav-icon svg {
        width: 20px;
        height: 20px;
    }
}

/* ── Explore Anytime detail pages ───────────────────────────── */
.pj-explore-view-details { margin-left:auto; color:var(--pj-red); font-weight:800; font-size:12px; }

.pj-explore-detail { max-width: 1040px; margin: 0 auto; padding: 0 14px 96px; background:linear-gradient(180deg,#fffaf1 0,#fbfaf7 360px); }
.pj-explore-detail-hero { margin: 0 -14px 16px; padding:16px 14px 0; background:radial-gradient(circle at 16% 0%, rgba(248,216,166,.28), transparent 34%), linear-gradient(180deg,#261b14,#17130f); color:#fff; border-radius:0 0 28px 28px; overflow:hidden; box-shadow:0 18px 42px rgba(39,31,24,.18); }
.pj-explore-detail-hero-media { position:relative; padding:10px; border-radius:26px; background:linear-gradient(145deg,#fff8ec,#e7d4ba); border:1px solid rgba(255,255,255,.42); box-shadow:0 18px 38px rgba(0,0,0,.24), inset 0 0 0 1px rgba(86,55,30,.12); }
.pj-explore-detail-hero-media::after { content:''; position:absolute; inset:10px; pointer-events:none; border-radius:18px; box-shadow:inset 0 0 0 1px rgba(255,255,255,.35), inset 0 -40px 80px rgba(39,31,24,.05); }
.pj-explore-detail-hero-img { width:100%; height:clamp(230px, 48vw, 440px); object-fit:contain; display:block; border-radius:18px; background:linear-gradient(135deg,#241a13,#3b2c21); }
.pj-explore-detail-hero-copy { position:relative; margin:-2px 8px 0; padding: 16px 8px 18px; background:transparent; }
.pj-explore-back { color:#f8e7cf; font-size:13px; font-weight:800; text-decoration:none; }
.pj-explore-detail h1 { font-family:'Playfair Display',serif; font-size:38px; line-height:1.02; margin:10px 0 8px; letter-spacing:-.025em; }
.pj-explore-detail-hero-copy p { color:#f7efe5; font-size:15px; line-height:1.38; margin:0 0 12px; }
.pj-explore-detail-chips { display:flex; flex-wrap:wrap; gap:6px; margin:10px 0 13px; }
.pj-explore-detail-chips span { border:1px solid rgba(255,255,255,.24); border-radius:999px; padding:6px 9px; background:rgba(255,255,255,.1); color:#fff; font-size:11px; font-weight:800; }
.pj-explore-detail-ctas { display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:8px; margin-top:2px; }
.pj-detail-btn { min-height:44px; display:inline-flex; align-items:center; justify-content:center; border-radius:999px; padding:10px 15px; text-decoration:none; font-weight:900; box-shadow:0 7px 16px rgba(0,0,0,.11); }
.pj-detail-btn--maps { background:#2f7d46; color:#fff; }
.pj-detail-btn--official { min-height:40px; padding:9px 14px; background:#fff; color:#261d16; border:1px solid rgba(255,255,255,.42); box-shadow:0 5px 12px rgba(0,0,0,.10); font-size:13px; font-weight:850; }
.pj-explore-detail-section { margin:10px 0; padding:14px 15px; border:1px solid rgba(40,30,20,.08); border-radius:18px; background:#fff; box-shadow:0 6px 18px rgba(0,0,0,.045); }
.pj-explore-detail-section h2 { font-family:'Playfair Display',serif; font-size:21px; line-height:1.08; margin:0 0 7px; }
.pj-explore-detail-section p { font-size:15px; line-height:1.45; color:#3f372f; margin:0; }
.pj-plan-grid { display:grid; grid-template-columns:1fr; gap:9px; }
.pj-plan-card { border-radius:15px; padding:11px 12px; background:linear-gradient(135deg,#fff7ea,#f7efe4); border:1px solid rgba(177,88,46,.13); }
.pj-plan-card span { display:block; margin-bottom:4px; color:#8b3f23; font-size:11px; font-weight:950; text-transform:uppercase; letter-spacing:.055em; }
.pj-plan-card strong { display:block; color:#2d251f; font-size:14px; line-height:1.32; font-weight:800; }
.pj-explore-detail-story { position:relative; overflow:hidden; border-color:rgba(177,88,46,.16); background:linear-gradient(145deg,#fffdf8,#fff3df); }
.pj-explore-detail-story::before { content:'“'; position:absolute; right:16px; top:-18px; color:rgba(177,88,46,.13); font-family:'Playfair Display',serif; font-size:96px; line-height:1; }
.pj-explore-detail-story h2 { color:#8b3f23; }
.pj-explore-detail-story p { position:relative; font-size:16px; line-height:1.55; color:#30261f; }
.pj-explore-detail-story p + p { margin-top:12px; }
.pj-explore-detail-history { border-color:rgba(30,82,97,.14); background:linear-gradient(145deg,#f8fcfb,#eef7f3); }
.pj-explore-detail-history h2 { color:#245764; }
.pj-explore-detail-history p { font-size:15.5px; line-height:1.55; color:#2f3a37; }
.pj-explore-detail-place { border-color:rgba(49,58,76,.12); background:#fffdf8; }
.pj-explore-detail-place h2 { color:#29384c; }
.pj-place-facts { display:grid; gap:8px; margin-top:12px; }
.pj-place-fact { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; padding:10px 12px; border-radius:14px; background:#f6f1e8; }
.pj-place-fact span { flex:0 0 104px; color:#786a5b; font-size:11px; font-weight:900; text-transform:uppercase; letter-spacing:.05em; }
.pj-place-fact strong, .pj-place-fact a { color:#252a34; font-size:14px; line-height:1.3; text-align:right; font-weight:850; }
.pj-place-fact a { color:#8b3f23; text-decoration:none; }
.pj-detail-info-grid { display:grid; grid-template-columns:1fr; gap:8px; }
.pj-detail-info-card { border-radius:14px; background:#f7f2e9; padding:10px 12px; }
.pj-detail-info-card span { display:block; color:#7a6b5b; font-size:12px; font-weight:900; text-transform:uppercase; letter-spacing:.05em; margin-bottom:4px; }
.pj-detail-info-card strong { color:#2b241e; font-size:14px; line-height:1.25; }
.pj-detail-gallery { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.pj-detail-gallery img { width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:16px; background:#eee; }
.pj-detail-map-card { border-radius:18px; padding:18px; background:linear-gradient(135deg,#e8f4e8,#fff8ea); border:1px solid rgba(47,125,70,.16); }
.pj-related-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.pj-related-card { color:inherit; text-decoration:none; border-radius:16px; overflow:hidden; background:#fbfaf7; border:1px solid rgba(0,0,0,.07); box-shadow:0 5px 14px rgba(0,0,0,.06); }
.pj-related-card img { width:100%; aspect-ratio:4/3; object-fit:cover; display:block; }
.pj-related-card span { display:block; padding:10px; font-weight:850; font-size:13px; line-height:1.2; }
@media (min-width: 720px) { .pj-explore-detail { padding-left:24px; padding-right:24px; } .pj-explore-detail-hero { margin-left:0; margin-right:0; border-radius:28px; } .pj-plan-grid { grid-template-columns:repeat(2, minmax(0,1fr)); } .pj-detail-info-grid { grid-template-columns:repeat(2, minmax(0,1fr)); } .pj-detail-gallery { grid-template-columns:repeat(3, 1fr); } .pj-related-grid { grid-template-columns:repeat(4, 1fr); } }

/* ── Mobile events premium polish (compact local guide) ─────── */
.pj-more-filters {
    flex: 0 0 auto;
    position: static;
}
.pj-more-filters summary {
    list-style: none;
    min-height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 9px 13px;
    border-radius: 999px;
    border: 1px solid var(--pj-gray-300);
    background: #fffdf9;
    color: var(--pj-gray-900);
    font-size: 12px;
    line-height: 1;
    font-weight: 800;
    cursor: pointer;
    white-space: nowrap;
}
.pj-more-filters summary::-webkit-details-marker { display: none; }
.pj-more-filters summary::before {
    content: '';
    width: 13px;
    height: 13px;
    display: inline-block;
    background: currentColor;
    -webkit-mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='black' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M4 7h16'/%3E%3Cpath d='M4 17h16'/%3E%3Ccircle cx='9' cy='7' r='2' fill='black'/%3E%3Ccircle cx='15' cy='17' r='2' fill='black'/%3E%3C/g%3E%3C/svg%3E") center/contain no-repeat;
    mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='black' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M4 7h16'/%3E%3Cpath d='M4 17h16'/%3E%3Ccircle cx='9' cy='7' r='2' fill='black'/%3E%3Ccircle cx='15' cy='17' r='2' fill='black'/%3E%3C/g%3E%3C/svg%3E") center/contain no-repeat;
}
.pj-more-filters[open] summary {
    background: var(--pj-black);
    border-color: var(--pj-black);
    color: #fff;
}
.pj-more-filters-panel {
    position: absolute;
    left: 12px;
    right: 12px;
    top: calc(100% + 8px);
    z-index: 110;
    padding: 12px;
    border: 1px solid rgba(39,31,24,.10);
    border-radius: 18px;
    background: #fffdf9;
    box-shadow: 0 16px 36px rgba(39,31,24,.16);
}
.pj-filter-date-field {
    flex: 1 1 160px;
    min-height: 38px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 7px 10px;
    border: 1px solid var(--pj-gray-200);
    border-radius: 999px;
    background: #fff;
    color: var(--pj-gray-700);
    font-size: 12px;
    font-weight: 800;
}
.pj-filter-date-field input[type="date"] {
    min-width: 0;
    flex: 1;
    border: 0;
    background: transparent;
    color: var(--pj-gray-900);
    font: inherit;
}

@media (max-width: 760px) {
    body {
        background: #fffaf2;
        padding-bottom: calc(120px + env(safe-area-inset-bottom, 0px));
    }
    .pj-site-header {
        background: #fffaf2;
        padding: 7px 16px 8px;
        border-bottom-color: rgba(39,31,24,.08);
    }
    .pj-site-title {
        font-size: 21px;
        letter-spacing: -0.035em;
    }
    .pj-site-subtitle {
        margin-top: 1px;
        color: #a25d35;
        font-size: 9.5px;
        font-weight: 800;
        letter-spacing: 1.7px;
    }
    .pj-top-nav {
        margin-top: 7px;
        gap: 6px;
    }
    .pj-top-nav a {
        min-width: 92px;
        min-height: 30px;
        padding: 7px 12px;
        border-color: rgba(39,31,24,.16);
        background: #fffdf9;
        color: #252a34;
        font-size: 12.5px;
    }
    .pj-top-nav a.active {
        background: #182232;
        border-color: #182232;
        color: #fff;
        box-shadow: 0 4px 12px rgba(24,34,50,.12);
    }
    .pj-archive-header {
        padding: 10px 16px 5px;
        background: #fffaf2;
    }
    .pj-archive-title {
        font-size: 23px;
    }
    .pj-filter-stack {
        top: 0;
        background: #fffaf2;
        box-shadow: 0 1px 0 rgba(39,31,24,.06);
    }
    .pj-primary-filter-bar {
        position: relative;
        gap: 7px;
        padding: 8px 14px 9px;
        background: #fffaf2;
        border-bottom-color: rgba(39,31,24,.08);
        scroll-padding-left: 14px;
        scroll-padding-right: 18px;
    }
    .pj-primary-filter-bar::after {
        content: '';
        flex: 0 0 6px;
        height: 1px;
    }
    .pj-category-tab,
    .pj-filter-chip,
    .pj-more-filters summary {
        min-height: 34px;
        padding: 9px 13px;
        border-radius: 999px;
        border-color: rgba(39,31,24,.16);
        background: #fffdf9;
        color: #252a34;
        font-size: 12px;
        font-weight: 800;
    }
    .pj-category-tab.active,
    .pj-category-tab:has(input:checked),
    .pj-filter-chip.active,
    .pj-filter-chip:has(input:checked) {
        background: #182232;
        border-color: #182232;
        color: #fff;
    }
    @media (hover: hover) and (pointer: fine) {
        .pj-category-tab:hover,
        .pj-filter-chip:hover {
            border-color: #182232;
        }
    }
    .pj-section-label {
        display: flex;
        align-items: center;
        gap: 8px;
        padding: 12px 16px 8px;
        color: #3a342f;
        font-size: 13px;
        font-weight: 850;
        line-height: 1.2;
        letter-spacing: 0;
        text-transform: none;
    }
    .pj-section-label-icon {
        width: 28px;
        height: 28px;
        border-radius: 999px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        flex: 0 0 auto;
        background: #f7eadc;
        color: #9b3f26;
    }
    .pj-section-label-icon svg {
        width: 15px;
        height: 15px;
        fill: none;
        stroke: currentColor;
        stroke-width: 2;
        stroke-linecap: round;
        stroke-linejoin: round;
    }
    .pj-event-card:not(.pj-event-card--explore) {
        margin: 0 12px 12px;
        padding: 10px;
        gap: 9px;
        border-radius: 18px;
        border: 1px solid rgba(39,31,24,.07);
        background: #fffdf9;
        box-shadow: 0 6px 18px rgba(39,31,24,.055);
    }
    .pj-event-card:not(.pj-event-card--explore) .pj-card-link {
        gap: 10px;
        min-width: 0;
    }
    .pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap {
        width: 92px;
        height: 92px;
        border-radius: 14px;
    }
    .pj-event-card:not(.pj-event-card--explore) .pj-event-body {
        justify-content: flex-start;
        padding-top: 1px;
    }
    .pj-event-card:not(.pj-event-card--explore) .pj-event-header {
        margin-bottom: 4px;
        gap: 5px;
    }
    .pj-event-card:not(.pj-event-card--explore) .pj-event-category,
    .pj-event-card:not(.pj-event-card--explore) .pj-event-status-badge {
        border-radius: 999px;
        padding: 4px 8px;
        font-size: 9px;
        letter-spacing: .065em;
    }
    .pj-event-card:not(.pj-event-card--explore) .pj-event-title {
        font-family: var(--font-sans);
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
        color: #171b24;
        font-size: 15.5px;
        font-weight: 850;
        line-height: 1.18;
        margin-bottom: 4px;
    }
    .pj-event-card:not(.pj-event-card--explore) .pj-event-desc {
        -webkit-line-clamp: 2;
        min-height: 0;
        color: #667080;
        font-size: 12.3px;
        line-height: 1.32;
        margin-bottom: 5px;
    }
    .pj-event-card:not(.pj-event-card--explore) .pj-event-footer {
        min-width: 0;
    }
    .pj-event-card:not(.pj-event-card--explore) .pj-event-venue {
        min-width: 0;
        max-width: 100%;
        overflow: hidden;
        color: #697487;
        font-size: 11.5px;
        line-height: 1.15;
        white-space: nowrap;
        text-overflow: ellipsis;
    }
    .pj-venue-icon {
        color: #9b3f26;
        font-size: 11px;
    }
    .pj-event-meta-right {
        min-width: 54px;
        padding-left: 2px;
        gap: 6px;
        justify-content: flex-start;
        padding-top: 16px;
    }
    .pj-event-meta-right .pj-event-time {
        color: #171b24;
        font-size: 11.5px;
        font-weight: 900;
    }
    .pj-event-meta-right .pj-event-price {
        color: #5d6675;
        font-size: 11px;
        font-weight: 750;
    }
    .pj-add-calendar-link {
        min-height: 26px;
        max-width: none;
        padding: 6px 8px;
        border-color: rgba(155,63,38,.22);
        background: #fff5ed;
        color: #9b3f26;
        font-size: 9.5px;
        font-weight: 900;
        letter-spacing: -.01em;
        box-shadow: none;
    }
    .pj-bottom-nav {
        background: rgba(255, 250, 242, 0.97);
        border-top-color: rgba(39,31,24,.11);
        box-shadow: 0 -8px 24px rgba(39,31,24,.08);
    }
    .pj-bottom-nav a.active {
        color: #9b3f26;
    }
    .pj-bottom-nav a.active .pj-nav-icon {
        background: #f7eadc;
        color: #9b3f26;
    }
}

/* Restore the visible Event Filters disclosure below the date row. */
.pj-filter-stack > .pj-more-filters {
    display: block;
    padding: 6px 12px 8px;
    background: #fffaf2;
    border-bottom: 1px solid rgba(39,31,24,.08);
}
.pj-filter-stack > .pj-more-filters summary {
    min-height: 32px;
    padding: 8px 13px;
}
.pj-filter-stack > .pj-more-filters .pj-more-filters-panel {
    position: static;
    margin-top: 8px;
    max-height: min(58vh, 430px);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    box-shadow: 0 10px 26px rgba(39,31,24,.12);
}
.pj-filter-stack > .pj-more-filters:not([open]) .pj-more-filters-panel {
    display: none;
}
.pj-filter-stack > .pj-more-filters .pj-event-filter-form {
    align-items: flex-start;
    padding-bottom: 4px;
}
.pj-filter-stack > .pj-more-filters .pj-filter-choice {
    cursor: pointer;
}
.pj-filter-stack > .pj-more-filters .pj-filter-go {
    position: sticky;
    bottom: 0;
    margin-left: auto;
    min-height: 38px;
    padding: 10px 14px;
    z-index: 2;
}

/* Center Explore Apply Filters button inside the More Filters panel. */
.pj-filter-stack--explore > .pj-explore-filter-form > .pj-more-filters .pj-filter-go {
    margin-left: auto;
    margin-right: auto;
}

/* Explore filter action row: More Filters left, Apply Filters right. */
.pj-filter-stack--explore .pj-explore-filter-actions {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 0 12px 8px;
    background: #fffaf2;
    border-bottom: 1px solid rgba(39,31,24,.08);
}
.pj-filter-stack--explore .pj-explore-filter-actions .pj-more-filters {
    flex: 0 0 auto;
    margin: 0;
    padding: 0;
    border-bottom: 0;
    background: transparent;
    text-align: left;
}
.pj-filter-stack--explore .pj-explore-filter-actions .pj-more-filters summary {
    margin: 0;
    transform: translateY(2px);
}
.pj-filter-stack--explore .pj-explore-filter-actions .pj-filter-go--floating {
    position: static;
    margin-left: auto;
    min-height: 34px;
    padding: 9px 13px;
    transform: translateY(2px) scale(0.96);
}
.pj-filter-stack--explore .pj-explore-filter-form.is-dirty .pj-explore-filter-actions .pj-filter-go--floating {
    transform: translateY(2px) scale(1);
}
.pj-filter-stack--explore .pj-explore-filter-form:has(.pj-more-filters[open]) .pj-explore-filter-actions .pj-filter-go--floating {
    opacity: 0;
    pointer-events: none;
    transform: translateY(2px) scale(0.96);
}
.pj-filter-stack--explore .pj-explore-filter-actions .pj-more-filters-panel {
    position: absolute;
    left: 12px;
    right: 12px;
    top: calc(100% + 8px);
    text-align: left;
}

/* Center the Apply Filters button used inside the Explore More Filters dropdown. */
.pj-filter-stack--explore .pj-explore-filter-actions .pj-more-filters-panel > .pj-filter-go {
    flex: 0 0 auto;
    margin-left: auto;
    margin-right: auto;
}

/* Compact Explore More Filters dropdown so all choices are visible together. */
.pj-filter-stack--explore .pj-explore-filter-actions .pj-more-filters-panel {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: stretch;
    gap: 6px;
    padding: 10px;
    max-height: none;
    overflow: visible;
}
.pj-filter-stack--explore .pj-explore-filter-actions .pj-more-filters-panel .pj-filter-choice {
    width: 100%;
    min-height: 30px;
    padding: 8px 7px;
    font-size: 11px;
    line-height: 1.05;
    text-align: center;
}
.pj-filter-stack--explore .pj-explore-filter-actions .pj-more-filters-panel > .pj-filter-go,
.pj-filter-stack--explore .pj-explore-filter-actions .pj-more-filters-panel > .pj-filter-reset {
    grid-column: 1 / -1;
    justify-self: center;
}
.pj-filter-stack--explore .pj-explore-filter-actions .pj-more-filters-panel > .pj-filter-go {
    margin-top: 4px;
}

/* Explore dropdown all filters grouped in one flexible set. */
.pj-filter-stack--explore .pj-explore-filter-actions .pj-more-filters-panel {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    padding: 10px;
    max-height: min(62vh, 520px);
    overflow-y: auto;
}
.pj-filter-stack--explore .pj-explore-filter-actions .pj-more-filters-panel .pj-filter-choice {
    width: auto;
    flex: 0 0 auto;
    min-height: 30px;
    padding: 8px 10px;
    font-size: 11px;
    line-height: 1.05;
    text-align: center;
}
.pj-filter-stack--explore .pj-explore-filter-actions .pj-more-filters-panel > .pj-filter-go,
.pj-filter-stack--explore .pj-explore-filter-actions .pj-more-filters-panel > .pj-filter-reset {
    flex: 0 0 100%;
    width: fit-content;
    margin-left: auto;
    margin-right: auto;
}

/* Explore open-state: hide top row to avoid duplicate filters and center compact Apply bubble. */
.pj-filter-stack--explore .pj-explore-filter-form:has(.pj-more-filters[open]) .pj-primary-filter-bar {
    display: none;
}
.pj-filter-stack--explore .pj-explore-filter-actions .pj-filter-go--floating {
    position: absolute;
    left: 50%;
    right: auto;
    margin-left: 0;
    min-height: 30px;
    padding: 7px 11px;
    font-size: 11px;
    gap: 4px;
    transform: translate(-50%, 2px) scale(0.94);
}
.pj-filter-stack--explore .pj-explore-filter-form.is-dirty .pj-explore-filter-actions .pj-filter-go--floating {
    transform: translate(-50%, 2px) scale(1);
}
.pj-filter-stack--explore .pj-explore-filter-actions .pj-filter-go--floating .pj-filter-go-icon {
    width: 14px;
    height: 14px;
    font-size: 10px;
}
.pj-filter-stack--explore .pj-explore-filter-form:has(.pj-more-filters[open]) .pj-explore-filter-actions .pj-filter-go--floating {
    opacity: 0;
    pointer-events: none;
    transform: translate(-50%, 2px) scale(0.94);
}

/* Final Explore action placement: More Filters left, top Apply right, dropdown Apply below. */
.pj-filter-stack--explore .pj-explore-filter-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.pj-filter-stack--explore .pj-explore-filter-actions .pj-filter-go--floating {
    position: static;
    left: auto;
    right: auto;
    margin-left: auto;
    margin-right: 0;
    min-height: 30px;
    padding: 7px 11px;
    font-size: 11px;
    transform: translateY(2px) scale(0.94);
}
.pj-filter-stack--explore .pj-explore-filter-form.is-dirty .pj-explore-filter-actions .pj-filter-go--floating {
    transform: translateY(2px) scale(1);
}
.pj-filter-stack--explore .pj-explore-filter-form:has(.pj-more-filters[open]) .pj-explore-filter-actions .pj-filter-go--floating {
    opacity: 0;
    pointer-events: none;
    transform: translateY(2px) scale(0.94);
}
.pj-filter-stack--explore .pj-explore-filter-actions .pj-more-filters-panel > .pj-filter-go {
    flex: 0 0 100%;
    justify-self: center;
    width: fit-content;
    margin: 5px auto 0;
}

/* Explore action row: clear button and smaller right-aligned Apply. */
.pj-filter-stack--explore .pj-explore-filter-actions {
    justify-content: flex-start;
}
.pj-filter-stack--explore .pj-explore-filter-actions .pj-filter-reset--action {
    margin-left: auto;
    min-height: 28px;
    padding: 7px 10px;
    font-size: 10.5px;
    background: rgba(39,31,24,.06);
    border-color: rgba(39,31,24,.10);
    color: #6b6258;
}
.pj-filter-stack--explore .pj-explore-filter-actions .pj-filter-go--floating {
    position: static;
    margin-left: 6px;
    margin-right: 0;
    min-height: 28px;
    padding: 7px 10px;
    font-size: 10.5px;
    gap: 4px;
    transform: translateY(2px) scale(0.94);
}
.pj-filter-stack--explore .pj-explore-filter-actions .pj-filter-go--floating .pj-filter-go-icon {
    width: 13px;
    height: 13px;
    font-size: 9px;
}
.pj-filter-stack--explore .pj-explore-filter-form.is-dirty .pj-explore-filter-actions .pj-filter-go--floating {
    transform: translateY(2px) scale(1);
}

/* Explore More Filters open cleanup: hide top clear, compact dropdown buttons. */
.pj-filter-stack--explore .pj-explore-filter-form:has(.pj-more-filters[open]) .pj-explore-filter-actions > .pj-filter-reset--action {
    display: none;
}
.pj-filter-stack--explore .pj-explore-filter-actions .pj-more-filters-panel > .pj-filter-go {
    flex: 0 0 auto;
    width: auto;
    min-height: 30px;
    padding: 7px 11px;
    font-size: 11px;
    margin: 5px auto 0;
}
.pj-filter-stack--explore .pj-explore-filter-actions .pj-more-filters-panel > .pj-filter-reset {
    flex: 0 0 auto;
    width: auto;
    min-height: 28px;
    padding: 7px 10px;
    font-size: 10.5px;
    margin: 5px 0 0 auto;
}

/* Center compact dropdown Apply Filters button. */
.pj-filter-stack--explore .pj-explore-filter-actions .pj-more-filters-panel > .pj-filter-go {
    margin-left: auto;
    margin-right: auto;
    align-self: center;
}

/* Polished top-row Explore Apply Now button: warm, compact, and no green shadow. */
.pj-filter-stack--explore .pj-explore-filter-actions .pj-filter-go--floating {
    background: linear-gradient(180deg, #fff8ef 0%, #f7e7d5 100%);
    color: #8f3f22;
    border: 1px solid rgba(190, 113, 63, 0.34);
    box-shadow: 0 2px 0 rgba(195, 137, 94, 0.45), 0 9px 20px rgba(116, 62, 28, 0.15);
    letter-spacing: 0.01em;
}
.pj-filter-stack--explore .pj-explore-filter-actions .pj-filter-go--floating .pj-filter-go-icon {
    background: linear-gradient(180deg, #d87540 0%, #ad4c28 100%);
    color: #fff8ef;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.28);
}

/* Event card calendar bubble pinned to bottom. */
.pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right {
    align-self: stretch;
    justify-content: flex-start;
}
.pj-event-card:not(.pj-event-card--explore) .pj-add-calendar-link {
    margin-top: auto;
}


/* ── Saved hearts ─────────────────────────────────────────── */
.pj-event-card {
    position: relative;
}
.pj-save-heart {
    position: absolute;
    top: 14px;
    right: 14px;
    z-index: 6;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border: 1px solid rgba(255,255,255,0.86);
    border-radius: 999px;
    background: rgba(255,255,255,0.92);
    color: #b13d45;
    box-shadow: 0 8px 20px rgba(0,0,0,0.18);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    font-size: 24px;
    line-height: 1;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
    transition: transform 0.16s ease, background 0.16s ease, color 0.16s ease, box-shadow 0.16s ease;
}
.pj-save-heart span {
    transform: translateY(-1px);
}
.pj-save-heart:active {
    transform: scale(0.94);
}
.pj-save-heart.is-saved {
    background: #b13d45;
    color: #fff;
    box-shadow: 0 10px 22px rgba(177,61,69,0.28);
}
.pj-event-card:not(.pj-event-card--explore) .pj-save-heart {
    top: 16px;
    left: 70px;
    right: auto;
    width: 34px;
    height: 34px;
    font-size: 21px;
}
.pj-saved-count {
    position: absolute;
    top: -6px;
    right: -7px;
    min-width: 16px;
    height: 16px;
    padding: 0 4px;
    border: 2px solid rgba(255,252,246,0.96);
    border-radius: 999px;
    background: #b13d45;
    color: #fff;
    font-size: 9px;
    font-weight: 850;
    line-height: 12px;
    text-align: center;
}
.pj-saved-count.is-empty {
    display: none !important;
}
.pj-saved-page {
    max-width: 760px;
    margin: 0 auto;
    padding: 18px 16px 110px;
}
.pj-saved-shell {
    margin-top: 16px;
}
.pj-saved-empty {
    border: 1px solid rgba(34,34,34,0.08);
    border-radius: 24px;
    padding: 34px 22px;
    background: #fff;
    box-shadow: 0 10px 28px rgba(0,0,0,0.06);
    text-align: center;
}
.pj-saved-empty[hidden] {
    display: none;
}
.pj-saved-empty-icon {
    width: 62px;
    height: 62px;
    margin: 0 auto 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: #fff0f1;
    color: #b13d45;
    font-size: 38px;
}
.pj-saved-empty h2 {
    margin: 0 0 6px;
    font-family: var(--font-serif);
    font-size: 25px;
}
.pj-saved-empty p {
    margin: 0 auto 18px;
    max-width: 420px;
    color: var(--pj-gray-600);
    line-height: 1.45;
}
.pj-saved-empty-actions {
    display: flex;
    justify-content: center;
    gap: 10px;
    flex-wrap: wrap;
}
.pj-saved-empty-actions a {
    display: inline-flex;
    border-radius: 999px;
    padding: 10px 14px;
    background: #2f6f3e;
    color: #fff;
    font-weight: 800;
}
.pj-saved-list {
    display: grid;
    gap: 14px;
}
.pj-saved-card {
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(34,34,34,0.08);
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 8px 22px rgba(0,0,0,0.07);
}
.pj-saved-card a {
    display: grid;
    grid-template-columns: 96px 1fr;
    gap: 12px;
    align-items: center;
    min-height: 96px;
    padding: 10px 56px 10px 10px;
    color: inherit;
    text-decoration: none;
}
.pj-saved-card img {
    width: 96px;
    height: 76px;
    border-radius: 12px;
    object-fit: cover;
    background: var(--pj-gray-100);
}
.pj-saved-kind {
    display: block;
    width: fit-content;
    margin-bottom: 4px;
    border-radius: 999px;
    padding: 3px 8px;
    background: #f7eadc;
    color: #9b3f26;
    font-size: 10px;
    font-weight: 850;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.pj-saved-card strong {
    display: block;
    font-family: var(--font-serif);
    font-size: 18px;
    line-height: 1.22;
}
.pj-saved-card .pj-save-heart {
    top: 50%;
    right: 12px;
    left: auto;
    transform: translateY(-50%);
}
.pj-saved-card .pj-save-heart:active {
    transform: translateY(-50%) scale(0.94);
}

@media (max-width: 760px) {
    .pj-bottom-nav {
        gap: 0;
        padding-left: 6px;
        padding-right: 6px;
    }
    .pj-bottom-nav a {
        font-size: 10px;
        padding-left: 2px;
        padding-right: 2px;
    }
    .pj-save-heart {
        width: 36px;
        height: 36px;
        font-size: 22px;
    }
    .pj-event-card:not(.pj-event-card--explore) .pj-save-heart {
        left: 68px;
        width: 32px;
        height: 32px;
        font-size: 20px;
    }
    .pj-saved-page {
        padding-top: 10px;
    }
}


/* Saved-heart placement refinement: Events below price, Explore bottom-right by tags. */
.pj-event-card:not(.pj-event-card--explore) .pj-save-heart--event {
    position: static;
    inset: auto;
    width: 30px;
    height: 30px;
    margin-top: -2px;
    align-self: flex-end;
    border-color: rgba(177,61,69,0.18);
    background: #fff7f7;
    box-shadow: 0 3px 10px rgba(177,61,69,0.12);
    font-size: 19px;
}
.pj-event-card:not(.pj-event-card--explore) .pj-save-heart--event.is-saved {
    background: #b13d45;
    color: #fff;
}
.pj-event-card--explore .pj-event-body {
    padding-right: 58px;
}
.pj-event-card--explore .pj-save-heart--explore {
    top: auto;
    right: 14px;
    bottom: 13px;
    left: auto;
    width: 36px;
    height: 36px;
    font-size: 22px;
    border-color: rgba(177,61,69,0.18);
    background: rgba(255,255,255,0.96);
    box-shadow: 0 5px 14px rgba(0,0,0,0.12);
}
.pj-event-card--explore .pj-save-heart--explore.is-saved {
    background: #b13d45;
    color: #fff;
}
.pj-event-card--explore .pj-anytime-meta-row {
    padding-right: 0;
}
@media (max-width: 760px) {
    .pj-event-card:not(.pj-event-card--explore) .pj-save-heart--event {
        position: static;
        width: 28px;
        height: 28px;
        font-size: 18px;
    }
    .pj-event-card--explore .pj-save-heart--explore {
        right: 12px;
        bottom: 12px;
        width: 34px;
        height: 34px;
        font-size: 21px;
    }
    .pj-event-card--explore .pj-event-body {
        padding-right: 54px;
    }
}


/* ── Saved page premium cards ─────────────────────────────── */
.pj-saved-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin: 0 0 14px;
    padding: 12px 14px;
    border: 1px solid rgba(34,34,34,0.08);
    border-radius: 18px;
    background: rgba(255,255,255,0.86);
    box-shadow: 0 8px 22px rgba(0,0,0,0.045);
}
.pj-saved-toolbar[hidden] { display: none !important; }
.pj-saved-actions[hidden] { display: none !important; }
.pj-saved-actions {
    display: flex;
    gap: 8px;
    margin: 0 0 14px;
    overflow-x: auto;
    padding-bottom: 0;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
}
.pj-saved-actions::-webkit-scrollbar { display: none; }
.pj-saved-actions button {
    flex: 0 0 auto;
    border: 1px solid rgba(47,111,62,0.18);
    border-radius: 999px;
    padding: 9px 12px;
    background: #fff;
    color: #2f6f3e;
    box-shadow: 0 4px 12px rgba(0,0,0,0.045);
    font-size: 12px;
    font-weight: 850;
    cursor: pointer;
}
.pj-saved-actions .pj-saved-clear {
    border-color: rgba(177,61,69,0.20);
    color: #9f313a;
}
.pj-saved-toolbar strong {
    display: block;
    font-family: var(--font-serif);
    font-size: 18px;
    line-height: 1.15;
    color: var(--pj-black);
}
.pj-saved-toolbar span {
    display: block;
    margin-top: 2px;
    color: var(--pj-gray-500);
    font-size: 12px;
    line-height: 1.25;
}
.pj-saved-clear {
    flex: 0 0 auto;
    border: 1px solid rgba(177,61,69,0.22);
    border-radius: 999px;
    padding: 8px 11px;
    background: #fff7f7;
    color: #9f313a;
    font-size: 12px;
    font-weight: 850;
    cursor: pointer;
}
.pj-saved-list {
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 16px;
}
.pj-saved-group {
    display: grid;
    gap: 10px;
}
.pj-saved-group + .pj-saved-group {
    margin-top: 18px;
}
.pj-saved-group-title {
    margin: 0;
    font-family: var(--font-serif);
    font-size: 22px;
    line-height: 1.1;
    color: var(--pj-black);
}
.pj-saved-group-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
}
.pj-saved-card {
    display: flex;
    flex-direction: column;
    border-radius: 24px;
    background: linear-gradient(180deg, #fff 0%, #fffaf3 100%);
    box-shadow: 0 12px 30px rgba(39,31,24,0.08);
}
.pj-saved-card-media {
    position: relative;
    display: block;
    aspect-ratio: 16 / 10;
    overflow: hidden;
    background: linear-gradient(135deg, #fff0f1, #f7eadc);
    color: inherit;
    text-decoration: none;
}
.pj-saved-card-media::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0) 52%, rgba(0,0,0,0.24) 100%);
    pointer-events: none;
}
.pj-saved-card-media img {
    width: 100%;
    height: 100%;
    border-radius: 0;
    object-fit: cover;
    display: block;
    transition: transform 0.18s ease;
}
.pj-saved-card:active .pj-saved-card-media img {
    transform: scale(1.015);
}
.pj-saved-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    color: #b13d45;
    font-size: 52px;
}
.pj-saved-card-body {
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: 9px;
    padding: 13px 14px 14px;
}
.pj-saved-card-topline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}
.pj-saved-card .pj-saved-kind {
    margin: 0;
    background: #f7eadc;
    color: #9b3f26;
}
.pj-saved-card.is-event .pj-saved-kind {
    background: #fff0f1;
    color: #9f313a;
}
.pj-saved-note {
    color: #b13d45;
    font-size: 11px;
    font-weight: 800;
}
.pj-saved-card-title {
    display: block;
    color: var(--pj-black);
    font-family: var(--font-serif);
    font-size: 20px;
    font-weight: 800;
    line-height: 1.17;
    text-decoration: none;
}
.pj-saved-card-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-top: auto;
    padding-top: 4px;
}
.pj-saved-open {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    border-radius: 999px;
    padding: 8px 12px;
    background: #2f6f3e;
    color: #fff;
    font-size: 12px;
    font-weight: 850;
    text-decoration: none;
    box-shadow: 0 5px 12px rgba(47,111,62,0.18);
}
.pj-saved-card .pj-saved-remove,
.pj-saved-card .pj-save-heart.pj-saved-remove {
    position: static;
    inset: auto;
    transform: none;
    width: 34px;
    height: 34px;
    margin: 0;
    box-shadow: 0 5px 14px rgba(177,61,69,0.18);
    font-size: 21px;
}
.pj-saved-card .pj-saved-remove:active {
    transform: scale(0.94);
}
@media (max-width: 760px) {
    .pj-saved-toolbar {
        align-items: flex-start;
        padding: 11px 12px;
    }
    .pj-saved-toolbar strong { font-size: 17px; }
    .pj-saved-clear { padding: 7px 10px; }
    .pj-saved-list {
        grid-template-columns: 1fr;
        gap: 14px;
    }
    .pj-saved-card {
        border-radius: 22px;
    }
    .pj-saved-card-media {
        aspect-ratio: 16 / 9;
    }
    .pj-saved-card-title {
        font-size: 19px;
    }
}


/* ── Saved feed: match Events + Explore cards in one place ── */
.pj-saved-list {
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
}
.pj-saved-card--feed {
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(34,34,34,0.07);
    background: #fff;
    box-shadow: 0 8px 24px rgba(0,0,0,0.07);
}
.pj-saved-card--feed .pj-saved-card-link {
    display: flex;
    color: inherit;
    text-decoration: none;
}
.pj-saved-card--feed .pj-saved-card-media {
    position: relative;
    display: block;
    overflow: hidden;
    background: var(--pj-gray-100);
    flex-shrink: 0;
}
.pj-saved-card--feed .pj-saved-card-media img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.pj-saved-card--feed .pj-saved-card-body {
    display: flex;
    flex-direction: column;
    min-width: 0;
}
.pj-saved-card--feed .pj-saved-card-title {
    margin: 0;
    color: var(--pj-black);
    font-family: var(--font-serif);
    font-weight: 800;
    line-height: 1.2;
}
.pj-saved-card--feed .pj-saved-card-hint {
    margin: 4px 0 0;
    color: var(--pj-gray-600);
    font-size: 12.5px;
    line-height: 1.35;
}
.pj-saved-card--feed .pj-saved-card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: auto;
    padding-top: 8px;
}
.pj-saved-card--feed .pj-saved-card-meta span {
    display: inline-flex;
    border-radius: 999px;
    padding: 4px 8px;
    background: #f5f1ea;
    color: #5e554a;
    font-size: 10.5px;
    font-weight: 800;
}
.pj-saved-card--event {
    border-radius: 16px;
}
.pj-saved-card--event .pj-saved-card-link {
    gap: 12px;
    align-items: stretch;
    padding: 12px 58px 12px 12px;
}
.pj-saved-card--event .pj-saved-card-media {
    width: 80px;
    height: 80px;
    align-self: center;
    border-radius: 10px;
}
.pj-saved-card--event .pj-saved-card-body {
    justify-content: center;
}
.pj-saved-card--event .pj-saved-card-title {
    font-size: 16px;
}
.pj-saved-card--event .pj-saved-card-topline {
    justify-content: flex-start;
    gap: 6px;
    margin-bottom: 4px;
}
.pj-saved-card--event .pj-saved-kind {
    background: #fff0f1;
    color: #9f313a;
}
.pj-saved-card--event .pj-saved-remove {
    position: absolute;
    right: 14px;
    top: 50%;
    transform: translateY(-50%);
}
.pj-saved-card--event .pj-saved-remove:active {
    transform: translateY(-50%) scale(0.94);
}
.pj-saved-card--explore {
    border-radius: 18px;
    background: linear-gradient(180deg, #fff 0%, #fff 74%, #fbfaf7 100%);
}
.pj-saved-card--explore .pj-saved-card-link {
    flex-direction: column;
}
.pj-saved-card--explore .pj-saved-card-media {
    width: 100%;
    aspect-ratio: 4 / 3;
    border-radius: 18px 18px 0 0;
}
.pj-saved-card--explore .pj-saved-card-media::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0) 45%, rgba(0,0,0,0.32) 100%);
    pointer-events: none;
}
.pj-saved-image-badge {
    position: absolute;
    left: 12px;
    bottom: 12px;
    z-index: 1;
    border-radius: 999px;
    padding: 6px 10px;
    background: rgba(20,20,20,0.76);
    color: #fff;
    font-size: 10.5px;
    font-weight: 850;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.pj-saved-card--explore .pj-saved-card-body {
    padding: 11px 58px 12px 13px;
}
.pj-saved-card--explore .pj-saved-card-topline {
    display: none;
}
.pj-saved-card--explore .pj-saved-card-title {
    font-size: 18.5px;
}
.pj-saved-card--explore .pj-saved-card-meta span {
    background: #f4efe6;
    color: #5f4f3f;
}
.pj-saved-card--explore .pj-saved-remove {
    position: absolute;
    right: 14px;
    bottom: 13px;
    top: auto;
    transform: none;
}
.pj-saved-card--explore .pj-saved-remove:active {
    transform: scale(0.94);
}
.pj-saved-card--feed .pj-saved-remove {
    width: 34px;
    height: 34px;
    font-size: 21px;
    margin: 0;
}
@media (min-width: 760px) {
    .pj-saved-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        align-items: start;
    }
    .pj-saved-card--event {
        grid-column: span 2;
    }
}
@media (max-width: 760px) {
    .pj-saved-card--event .pj-saved-card-link {
        padding-right: 54px;
    }
    .pj-saved-card--event .pj-saved-card-title {
        font-size: 16px;
    }
    .pj-saved-card--explore .pj-saved-card-body {
        padding-right: 54px;
    }
    .pj-saved-card--feed .pj-saved-remove {
        width: 32px;
        height: 32px;
        font-size: 20px;
    }
}


/* ── Saved shortlist filters + right-side heart actions ───── */
.pj-saved-filters {
    display: flex;
    gap: 8px;
    margin: 0 0 14px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
}
.pj-saved-filters::-webkit-scrollbar { display: none; }
.pj-saved-filters[hidden] { display: none !important; }
.pj-saved-filters button {
    flex: 0 0 auto;
    border: 1px solid rgba(34,34,34,0.09);
    border-radius: 999px;
    padding: 9px 14px;
    background: #fff;
    color: #4c5562;
    box-shadow: 0 4px 12px rgba(0,0,0,0.045);
    font-weight: 850;
    font-size: 13px;
    cursor: pointer;
}
.pj-saved-filters button.is-active {
    border-color: rgba(47,111,62,0.24);
    background: #2f6f3e;
    color: #fff;
    box-shadow: 0 6px 16px rgba(47,111,62,0.18);
}
.pj-saved-filter-empty {
    border: 1px dashed rgba(34,34,34,0.16);
    border-radius: 20px;
    padding: 24px 18px;
    background: rgba(255,255,255,0.72);
    text-align: center;
}
.pj-saved-filter-empty[hidden] { display: none !important; }
.pj-saved-filter-empty h2 {
    margin: 0 0 6px;
    font-family: var(--font-serif);
    font-size: 22px;
}
.pj-saved-filter-empty p {
    margin: 0;
    color: var(--pj-gray-600);
}
.pj-saved-card--feed .pj-saved-open {
    position: absolute;
    z-index: 7;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    border-radius: 999px;
    padding: 8px 12px;
    background: #2f6f3e;
    color: #fff;
    box-shadow: 0 6px 14px rgba(47,111,62,0.18);
    font-size: 12px;
    font-weight: 900;
    text-decoration: none;
}
.pj-saved-card--event .pj-saved-card-link {
    padding-right: 108px;
}
.pj-saved-card--event .pj-saved-open {
    right: 14px;
    bottom: 12px;
}
.pj-saved-card--event .pj-saved-remove {
    position: absolute;
    top: 16px;
    right: 14px;
    bottom: auto;
    left: auto;
    transform: none;
}
.pj-saved-card--event .pj-saved-remove:active {
    transform: scale(0.94);
}
.pj-saved-card--explore .pj-saved-card-body {
    padding-bottom: 54px;
}
.pj-saved-card--explore .pj-saved-open {
    left: 13px;
    bottom: 13px;
}
.pj-saved-card--explore .pj-saved-remove {
    position: absolute;
    right: 14px;
    bottom: 13px;
    top: auto;
    left: auto;
    transform: none;
}
.pj-saved-card--explore .pj-saved-remove:active {
    transform: scale(0.94);
}
.pj-saved-clear {
    background: transparent;
    border-color: transparent;
    color: #9f313a;
    box-shadow: none;
    text-decoration: underline;
    text-underline-offset: 3px;
}
@media (max-width: 760px) {
    .pj-saved-filters {
        padding: 0 1px 2px;
    }
    .pj-saved-filters button {
        padding: 8px 13px;
        font-size: 12.5px;
    }
    .pj-saved-card--event .pj-saved-card-link {
        padding-right: 98px;
    }
    .pj-saved-card--event .pj-saved-open {
        right: 12px;
        bottom: 11px;
    }
    .pj-saved-card--event .pj-saved-remove {
        right: 12px;
        top: 14px;
    }
    .pj-saved-card--explore .pj-saved-remove {
        right: 12px;
    }
}


/* Force Saved-page remove hearts onto the right edge of every saved card. */
.pj-saved-card--feed {
    padding-right: 0;
}
.pj-saved-card--feed .pj-saved-card-link {
    padding-right: 58px !important;
}
.pj-saved-card--feed .pj-saved-remove,
.pj-saved-card--event .pj-saved-remove,
.pj-saved-card--explore .pj-saved-remove {
    position: absolute !important;
    top: 50% !important;
    right: 12px !important;
    bottom: auto !important;
    left: auto !important;
    transform: translateY(-50%) !important;
    z-index: 9 !important;
}
.pj-saved-card--feed .pj-saved-remove:active,
.pj-saved-card--event .pj-saved-remove:active,
.pj-saved-card--explore .pj-saved-remove:active {
    transform: translateY(-50%) scale(0.94) !important;
}
.pj-saved-card--feed .pj-saved-open {
    left: 13px !important;
    right: auto !important;
    bottom: 13px !important;
}
.pj-saved-card--feed .pj-saved-maps {
    position: absolute;
    z-index: 7;
    left: 74px;
    bottom: 13px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    border: 1px solid rgba(47,111,62,0.18);
    border-radius: 999px;
    padding: 8px 11px;
    background: #f3fbf4;
    color: #2f6f3e;
    box-shadow: 0 5px 12px rgba(47,111,62,0.10);
    font-size: 12px;
    font-weight: 900;
    text-decoration: none;
    white-space: nowrap;
}
.pj-saved-card--explore .pj-saved-maps {
    left: 50%;
    transform: translateX(-50%);
}
.pj-saved-card--event .pj-saved-card-body,
.pj-saved-card--explore .pj-saved-card-body {
    padding-right: 48px;
}
.pj-saved-card--event .pj-saved-card-link {
    padding-right: 58px !important;
}
.pj-saved-card--event .pj-saved-card-body {
    padding-bottom: 42px;
}
@media (max-width: 760px) {
    .pj-saved-card--feed .pj-saved-card-link,
    .pj-saved-card--event .pj-saved-card-link {
        padding-right: 54px !important;
    }
    .pj-saved-card--feed .pj-saved-remove,
    .pj-saved-card--event .pj-saved-remove,
    .pj-saved-card--explore .pj-saved-remove {
        right: 10px !important;
    }
}


/* Saved-page final placement: remove heart at bottom-right. */
.pj-saved-card--feed .pj-saved-remove,
.pj-saved-card--event .pj-saved-remove,
.pj-saved-card--explore .pj-saved-remove {
    position: absolute !important;
    top: auto !important;
    right: 12px !important;
    bottom: 12px !important;
    left: auto !important;
    transform: none !important;
    z-index: 9 !important;
}
.pj-saved-card--feed .pj-saved-remove:active,
.pj-saved-card--event .pj-saved-remove:active,
.pj-saved-card--explore .pj-saved-remove:active {
    transform: scale(0.94) !important;
}
.pj-saved-card--feed .pj-saved-card-link,
.pj-saved-card--event .pj-saved-card-link {
    padding-right: 54px !important;
}
.pj-saved-card--event .pj-saved-card-body,
.pj-saved-card--explore .pj-saved-card-body {
    padding-bottom: 54px;
}
.pj-saved-card--feed .pj-saved-open {
    left: 13px !important;
    right: auto !important;
    bottom: 13px !important;
}
@media (max-width: 760px) {
    .pj-saved-card--feed .pj-saved-remove,
    .pj-saved-card--event .pj-saved-remove,
    .pj-saved-card--explore .pj-saved-remove {
        right: 10px !important;
        bottom: 10px !important;
    }
}


/* Saved Event cards: bottom Add to Calendar action. */
.pj-saved-card--feed .pj-saved-calendar {
    position: absolute;
    z-index: 7;
    right: 54px;
    bottom: 13px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    border: 1px solid rgba(47,111,62,0.18);
    border-radius: 999px;
    padding: 8px 11px;
    background: #f3fbf4;
    color: #2f6f3e;
    box-shadow: 0 5px 12px rgba(47,111,62,0.10);
    font-size: 12px;
    font-weight: 900;
    text-decoration: none;
    white-space: nowrap;
}
.pj-saved-card--event .pj-saved-card-link {
    padding-bottom: 60px !important;
}
.pj-saved-card--event .pj-saved-card-body {
    padding-bottom: 0;
}
@media (max-width: 760px) {
    .pj-saved-card--feed .pj-saved-calendar {
        right: 50px;
        bottom: 10px;
        min-height: 32px;
        padding-left: 10px;
        padding-right: 10px;
        font-size: 11.5px;
    }
}


/* Saved Event cards: stack Calendar above bottom-right heart. */
.pj-saved-card--feed .pj-saved-calendar {
    right: 10px !important;
    bottom: 52px !important;
    min-height: 30px;
    padding: 7px 9px;
    font-size: 11px;
}
.pj-saved-card--event .pj-saved-card-link {
    padding-right: 112px !important;
    padding-bottom: 56px !important;
}
.pj-saved-card--event .pj-saved-card-body {
    padding-right: 58px;
    padding-bottom: 0;
}
.pj-saved-card--event .pj-saved-remove {
    right: 12px !important;
    bottom: 12px !important;
}
@media (max-width: 760px) {
    .pj-saved-card--feed .pj-saved-calendar {
        right: 8px !important;
        bottom: 48px !important;
        padding-left: 8px;
        padding-right: 8px;
        font-size: 10.5px;
    }
    .pj-saved-card--event .pj-saved-card-link {
        padding-right: 104px !important;
    }
    .pj-saved-card--event .pj-saved-remove {
        right: 10px !important;
        bottom: 10px !important;
    }
}


/* Saved Event cards: raise Calendar button well above heart. */
.pj-saved-card--event .pj-saved-calendar,
.pj-saved-card--feed .pj-saved-calendar {
    top: 14px !important;
    right: 10px !important;
    bottom: auto !important;
}
.pj-saved-card--event .pj-saved-card-link {
    padding-right: 112px !important;
    padding-bottom: 48px !important;
}
.pj-saved-card--event .pj-saved-card-body {
    padding-right: 62px;
}
@media (max-width: 760px) {
    .pj-saved-card--event .pj-saved-calendar,
    .pj-saved-card--feed .pj-saved-calendar {
        top: 12px !important;
        right: 8px !important;
        bottom: auto !important;
    }
    .pj-saved-card--event .pj-saved-card-link {
        padding-right: 104px !important;
    }
}


/* Saved Event cards: Calendar centered at bottom. */
.pj-saved-card--event .pj-saved-calendar,
.pj-saved-card--feed .pj-saved-calendar {
    top: auto !important;
    left: 50% !important;
    right: auto !important;
    bottom: 12px !important;
    transform: translateX(-50%) !important;
}
.pj-saved-card--event .pj-saved-card-link {
    padding-right: 54px !important;
    padding-bottom: 58px !important;
}
.pj-saved-card--event .pj-saved-card-body {
    padding-right: 0;
    padding-bottom: 0;
}
.pj-saved-card--event .pj-saved-open {
    left: 13px !important;
    right: auto !important;
    bottom: 12px !important;
}
.pj-saved-card--event .pj-saved-remove {
    right: 12px !important;
    bottom: 12px !important;
}
@media (max-width: 760px) {
    .pj-saved-card--event .pj-saved-calendar,
    .pj-saved-card--feed .pj-saved-calendar {
        left: 50% !important;
        right: auto !important;
        bottom: 10px !important;
        transform: translateX(-50%) !important;
    }
    .pj-saved-card--feed .pj-saved-maps {
        left: 70px;
        bottom: 10px;
        min-height: 32px;
        padding-left: 10px;
        padding-right: 10px;
        font-size: 11.5px;
    }
    .pj-saved-card--event .pj-saved-maps {
        left: 68px;
    }
    .pj-saved-card--explore .pj-saved-maps {
        left: 50%;
    }
}


/* Saved cards: richer metadata hierarchy. */
.pj-saved-card--feed .pj-saved-card-hint {
    color: #2f3540;
    font-weight: 800;
}
.pj-saved-card--feed .pj-saved-card-meta {
    padding-top: 7px;
}
.pj-saved-card--feed .pj-saved-card-meta span {
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.pj-saved-card--event .pj-saved-card-hint {
    color: #171b24;
}
.pj-saved-card--event .pj-saved-card-meta span {
    background: #f7eadc;
    color: #72533a;
}
.pj-saved-card--explore .pj-saved-card-hint {
    font-weight: 700;
    color: #5b4a3c;
}

/* Saved cards: center the Open / Maps / Calendar action row. */
.pj-saved-card--feed .pj-saved-card-actions {
    position: absolute;
    left: 50%;
    right: auto;
    bottom: 12px;
    z-index: 8;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    width: max-content;
    max-width: calc(100% - 78px);
    transform: translateX(-50%);
}
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
    position: static !important;
    inset: auto !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    top: auto !important;
    transform: none !important;
    min-height: 32px;
    white-space: nowrap;
}
.pj-saved-card--event .pj-saved-card-link,
.pj-saved-card--explore .pj-saved-card-link {
    padding-bottom: 60px !important;
}
@media (max-width: 760px) {
    .pj-saved-card--feed .pj-saved-card-actions {
        bottom: 10px;
        gap: 6px;
        max-width: calc(100% - 72px);
    }
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
        padding-left: 9px;
        padding-right: 9px;
        font-size: 11px;
    }
}

/* Saved cards: heart top-right, bottom buttons spread evenly. */
.pj-saved-card--feed .pj-saved-remove,
.pj-saved-card--event .pj-saved-remove,
.pj-saved-card--explore .pj-saved-remove {
    top: 12px !important;
    right: 12px !important;
    bottom: auto !important;
    transform: none !important;
}
.pj-saved-card--feed .pj-saved-remove:active,
.pj-saved-card--event .pj-saved-remove:active,
.pj-saved-card--explore .pj-saved-remove:active {
    transform: scale(0.94) !important;
}
.pj-saved-card--feed .pj-saved-card-actions {
    left: 12px;
    right: 12px;
    bottom: 12px;
    width: auto;
    max-width: none;
    transform: none;
    justify-content: space-between;
}
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
    flex: 1 1 0;
}
.pj-saved-card--event .pj-saved-card-link,
.pj-saved-card--explore .pj-saved-card-link {
    padding-bottom: 62px !important;
}
.pj-saved-card--event .pj-saved-card-link {
    padding-right: 58px !important;
}
.pj-saved-card--explore .pj-saved-card-body {
    padding-right: 54px;
}
@media (max-width: 760px) {
    .pj-saved-card--feed .pj-saved-remove,
    .pj-saved-card--event .pj-saved-remove,
    .pj-saved-card--explore .pj-saved-remove {
        top: 10px !important;
        right: 10px !important;
    }
    .pj-saved-card--feed .pj-saved-card-actions {
        left: 10px;
        right: 10px;
        bottom: 10px;
        max-width: none;
    }
}

/* Saved cards: compact bottom action buttons. */
.pj-saved-card--feed .pj-saved-card-actions {
    left: 50%;
    right: auto;
    width: max-content;
    max-width: calc(100% - 76px);
    gap: 7px;
    transform: translateX(-50%);
    justify-content: center;
}
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
    flex: 0 0 auto;
    min-width: 0;
    padding-left: 10px;
    padding-right: 10px;
}
@media (max-width: 760px) {
    .pj-saved-card--feed .pj-saved-card-actions {
        left: 50%;
        right: auto;
        max-width: calc(100% - 70px);
        gap: 6px;
        transform: translateX(-50%);
    }
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
        padding-left: 8px;
        padding-right: 8px;
    }
}

/* Saved cards: evenly spaced same-size bottom action buttons. */
.pj-saved-card--feed .pj-saved-card-actions {
    left: 12px;
    right: 12px;
    width: auto;
    max-width: none;
    gap: 8px;
    transform: none;
    justify-content: space-between;
}
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
    flex: 1 1 0;
    min-width: 0;
    padding-left: 8px;
    padding-right: 8px;
    text-align: center;
}
@media (max-width: 760px) {
    .pj-saved-card--feed .pj-saved-card-actions {
        left: 10px;
        right: 10px;
        max-width: none;
        gap: 7px;
        transform: none;
    }
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
        flex: 1 1 0;
        min-width: 0;
        padding-left: 6px;
        padding-right: 6px;
        font-size: 10.5px;
    }
}

/* Saved cards: narrower bottom action buttons, keeping Calendar in the middle. */
.pj-saved-card--feed .pj-saved-card-actions {
    left: 50%;
    right: auto;
    width: max-content;
    max-width: calc(100% - 72px);
    gap: 7px;
    transform: translateX(-50%);
    justify-content: center;
}
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
    flex: 0 0 auto;
    min-width: 0;
    padding-left: 9px;
    padding-right: 9px;
}
@media (max-width: 760px) {
    .pj-saved-card--feed .pj-saved-card-actions {
        left: 50%;
        right: auto;
        max-width: calc(100% - 66px);
        gap: 6px;
        transform: translateX(-50%);
    }
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
        padding-left: 7px;
        padding-right: 7px;
        font-size: 10.5px;
    }
}

/* Saved cards: spread bottom action buttons apart without stretching button widths. */
.pj-saved-card--feed .pj-saved-card-actions {
    left: 12px;
    right: 54px;
    width: auto;
    max-width: none;
    gap: 10px;
    transform: none;
    justify-content: space-between;
}
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
    flex: 0 0 auto;
}
@media (max-width: 760px) {
    .pj-saved-card--feed .pj-saved-card-actions {
        left: 10px;
        right: 50px;
        max-width: none;
        gap: 8px;
        transform: none;
        justify-content: space-between;
    }
}

/* Saved cards: symmetrical bottom action buttons. */
.pj-saved-card--feed .pj-saved-card-actions {
    left: 12px;
    right: 12px;
    width: auto;
    max-width: none;
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(0, 1fr);
    gap: 8px;
    transform: none;
    justify-content: stretch;
}
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
    width: 100%;
    min-width: 0;
    flex: none;
    padding-left: 6px;
    padding-right: 6px;
    text-align: center;
}
@media (max-width: 760px) {
    .pj-saved-card--feed .pj-saved-card-actions {
        left: 10px;
        right: 10px;
        gap: 7px;
    }
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
        padding-left: 5px;
        padding-right: 5px;
        font-size: 10.5px;
    }
}

/* Saved cards: thinner evenly spaced bottom action buttons. */
.pj-saved-card--feed .pj-saved-card-actions {
    left: 14px;
    right: 14px;
    bottom: 10px;
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(0, 1fr);
    gap: 10px;
    width: auto;
    max-width: none;
    transform: none;
    justify-content: stretch;
}
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
    width: 100%;
    min-width: 0;
    min-height: 26px;
    flex: none;
    padding: 5px 6px;
    font-size: 10.5px;
    line-height: 1;
    text-align: center;
    box-shadow: 0 3px 8px rgba(47,111,62,0.10);
}
.pj-saved-card--event .pj-saved-card-link,
.pj-saved-card--explore .pj-saved-card-link {
    padding-bottom: 52px !important;
}
@media (max-width: 760px) {
    .pj-saved-card--feed .pj-saved-card-actions {
        left: 12px;
        right: 12px;
        bottom: 9px;
        gap: 8px;
    }
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
        min-height: 24px;
        padding: 4px 5px;
        font-size: 10px;
    }
    .pj-saved-card--event .pj-saved-card-link,
    .pj-saved-card--explore .pj-saved-card-link {
        padding-bottom: 48px !important;
    }
}

/* Saved cards: normal-height but less-wide bottom action buttons. */
.pj-saved-card--feed .pj-saved-card-actions {
    left: 50%;
    right: auto;
    bottom: 12px;
    display: flex;
    width: max-content;
    max-width: calc(100% - 78px);
    gap: 12px;
    transform: translateX(-50%);
    justify-content: center;
}
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
    width: auto;
    min-width: 0;
    min-height: 32px;
    flex: 0 0 auto;
    padding: 8px 10px;
    font-size: 11.5px;
    line-height: 1.1;
    text-align: center;
}
.pj-saved-card--event .pj-saved-card-link,
.pj-saved-card--explore .pj-saved-card-link {
    padding-bottom: 58px !important;
}
@media (max-width: 760px) {
    .pj-saved-card--feed .pj-saved-card-actions {
        left: 50%;
        right: auto;
        bottom: 10px;
        max-width: calc(100% - 70px);
        gap: 9px;
        transform: translateX(-50%);
    }
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
        min-height: 32px;
        padding: 8px 8px;
        font-size: 11px;
    }
    .pj-saved-card--event .pj-saved-card-link,
    .pj-saved-card--explore .pj-saved-card-link {
        padding-bottom: 56px !important;
    }
}

/* Saved cards: spread normal-size bottom buttons evenly. */
.pj-saved-card--feed .pj-saved-card-actions {
    left: 14px;
    right: 14px;
    bottom: 12px;
    display: flex;
    width: auto;
    max-width: none;
    gap: 8px;
    transform: none;
    justify-content: space-between;
}
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
    width: auto;
    min-height: 32px;
    flex: 0 0 auto;
    padding: 8px 10px;
    font-size: 11.5px;
}
@media (max-width: 760px) {
    .pj-saved-card--feed .pj-saved-card-actions {
        left: 12px;
        right: 12px;
        bottom: 10px;
        gap: 6px;
        justify-content: space-between;
    }
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
        min-height: 32px;
        padding: 8px 8px;
        font-size: 11px;
    }
}

/* Saved cards: bottom action buttons slightly wider. */
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
    padding-left: 12px;
    padding-right: 12px;
}
@media (max-width: 760px) {
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
        padding-left: 10px;
        padding-right: 10px;
    }
}

/* Saved cards: bottom action buttons a little wider. */
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
    padding-left: 14px;
    padding-right: 14px;
}
@media (max-width: 760px) {
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
        padding-left: 12px;
        padding-right: 12px;
    }
}

/* Saved cards: tiny extra width on bottom action buttons. */
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
    padding-left: 16px;
    padding-right: 16px;
}
@media (max-width: 760px) {
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
        padding-left: 14px;
        padding-right: 14px;
    }
}

/* Saved cards: tad wider bottom action buttons. */
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
    padding-left: 18px;
    padding-right: 18px;
}
@media (max-width: 760px) {
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
        padding-left: 16px;
        padding-right: 16px;
    }
}

/* Saved page final planning polish. */
.pj-saved-helper {
    margin: -2px 0 12px;
    color: #6b6258;
    font-size: 12.5px;
    line-height: 1.35;
    text-align: center;
}
.pj-saved-helper[hidden] {
    display: none !important;
}
.pj-saved-actions .pj-saved-clear {
    margin-left: auto;
    color: #8c5b5f;
    background: transparent;
    border-color: rgba(177,61,69,0.10);
    box-shadow: none;
}
.pj-saved-card--event .pj-saved-card-hint {
    display: inline-flex;
    align-self: flex-start;
    margin-top: 5px;
    border-radius: 999px;
    padding: 5px 8px;
    background: #fff4df;
    color: #6d4618;
    font-size: 12px;
    font-weight: 900;
}
.pj-saved-card--explore .pj-saved-card-meta::before {
    content: "Best for";
    align-self: center;
    color: #8a7665;
    font-size: 10.5px;
    font-weight: 900;
    letter-spacing: .05em;
    text-transform: uppercase;
}
@media (max-width: 760px) {
    .pj-saved-helper {
        padding: 0 4px;
        font-size: 12px;
    }
}

/* Saved page: center circled action/filter chips evenly. */
.pj-saved-actions,
.pj-saved-filters {
    display: grid;
    width: 100%;
    overflow-x: visible;
    -webkit-overflow-scrolling: auto;
}
.pj-saved-actions {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
    align-items: center;
    justify-items: stretch;
}
.pj-saved-filters {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    align-items: center;
    justify-items: stretch;
}
.pj-saved-actions button,
.pj-saved-filters button,
.pj-saved-actions .pj-saved-clear {
    width: 100%;
    margin-left: 0;
    justify-content: center;
    text-align: center;
}
@media (max-width: 760px) {
    .pj-saved-actions,
    .pj-saved-filters {
        gap: 7px;
        padding-left: 0;
        padding-right: 0;
    }
    .pj-saved-actions button,
    .pj-saved-filters button {
        padding-left: 8px;
        padding-right: 8px;
    }
}

/* Saved page: itinerary-style polish. */
.pj-saved-plan {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin: 2px 0 12px;
    padding: 12px 13px;
    border: 1px solid rgba(47,111,62,0.12);
    border-radius: 18px;
    background: linear-gradient(135deg, rgba(255,255,255,0.96), rgba(245,250,246,0.96));
    box-shadow: 0 8px 20px rgba(39,31,24,0.055);
}
.pj-saved-plan[hidden],
.pj-saved-clear-link[hidden] {
    display: none !important;
}
.pj-saved-plan-label {
    display: block;
    margin-bottom: 2px;
    color: #2f6f3e;
    font-size: 10.5px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.pj-saved-plan strong {
    display: block;
    color: #201a16;
    font-size: 13px;
    line-height: 1.25;
}
.pj-saved-plan button {
    flex: 0 0 auto;
    border: 1px solid rgba(47,111,62,0.18);
    border-radius: 999px;
    padding: 9px 11px;
    background: #2f6f3e;
    color: #fff;
    font-size: 11.5px;
    font-weight: 900;
    box-shadow: 0 5px 12px rgba(47,111,62,0.16);
}
.pj-saved-plan button.is-active {
    background: #184d2a;
}
.pj-saved-actions {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}
.pj-saved-actions .pj-saved-clear {
    margin-left: 0;
}
.pj-saved-clear-link {
    display: block;
    width: max-content;
    margin: -4px auto 12px;
    border: 0;
    background: transparent;
    color: #8c5b5f;
    font-size: 12px;
    font-weight: 800;
    text-decoration: underline;
    text-underline-offset: 3px;
    box-shadow: none;
}
.pj-saved-card--feed .pj-saved-open::before,
.pj-saved-card--feed .pj-saved-maps::before,
.pj-saved-card--feed .pj-saved-calendar::before {
    display: none;
}
.pj-saved-card--event .pj-saved-card-hint {
    box-shadow: inset 0 0 0 1px rgba(109,70,24,0.08);
}
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
    padding-left: 14px;
    padding-right: 14px;
}
@media (max-width: 760px) {
    .pj-saved-plan {
        align-items: flex-start;
        padding: 11px 12px;
    }
    .pj-saved-plan strong {
        font-size: 12.5px;
    }
    .pj-saved-plan button {
        padding: 8px 10px;
        font-size: 11px;
    }
    .pj-saved-actions button {
        font-size: 11.5px;
    }
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps,
    .pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar {
        padding-left: 12px;
        padding-right: 12px;
    }
}


/* PJ 1.5.22: Saved planning labels, event detail CTAs, search-image polish */
.pj-saved-plan-label {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 3px 8px;
    font-size: 0.72rem;
    font-weight: 800;
    color: #7A341D;
    background: rgba(255, 239, 210, 0.92);
    border: 1px solid rgba(196, 119, 64, 0.24);
    white-space: nowrap;
}
.pj-saved-card-topline {
    gap: 6px;
    flex-wrap: wrap;
}
.pj-saved-note {
    margin-left: auto;
}
.pj-single-action-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(128px, 1fr));
    gap: 10px;
    margin: 16px 0 18px;
}
.pj-single-action-row a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    border-radius: 999px;
    padding: 10px 14px;
    font-weight: 800;
    text-decoration: none;
    border: 1px solid rgba(31, 41, 55, 0.12);
    box-shadow: 0 8px 18px rgba(31, 41, 55, 0.08);
}
.pj-single-action-row .pj-single-calendar {
    background: #C41E3A;
    color: #fff;
}
.pj-single-action-row .pj-single-map {
    background: #fff7ed;
    color: #9a3412;
}
.pj-single-action-row .pj-single-source {
    background: #f8fafc;
    color: #334155;
}
@media (max-width: 560px) {
    .pj-single-action-row {
        grid-template-columns: 1fr;
        gap: 8px;
    }
    .pj-saved-plan-label {
        font-size: 0.68rem;
        padding: 2px 7px;
    }
}


/* PJ 1.5.22: Saved planning labels, event detail CTAs, search-image polish */
.pj-saved-plan-label {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 3px 8px;
    font-size: 0.72rem;
    font-weight: 800;
    color: #7A341D;
    background: rgba(255, 239, 210, 0.92);
    border: 1px solid rgba(196, 119, 64, 0.24);
    white-space: nowrap;
}
.pj-saved-card-topline {
    gap: 6px;
    flex-wrap: wrap;
}
.pj-saved-note {
    margin-left: auto;
}
.pj-single-action-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(128px, 1fr));
    gap: 10px;
    margin: 16px 0 18px;
}
.pj-single-action-row a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    border-radius: 999px;
    padding: 10px 14px;
    font-weight: 800;
    text-decoration: none;
    border: 1px solid rgba(31, 41, 55, 0.12);
    box-shadow: 0 8px 18px rgba(31, 41, 55, 0.08);
}
.pj-single-action-row .pj-single-calendar {
    background: #C41E3A;
    color: #fff;
}
.pj-single-action-row .pj-single-map {
    background: #fff7ed;
    color: #9a3412;
}
.pj-single-action-row .pj-single-source {
    background: #f8fafc;
    color: #334155;
}
@media (max-width: 560px) {
    .pj-single-action-row {
        grid-template-columns: 1fr;
        gap: 8px;
    }
    .pj-saved-plan-label {
        font-size: 0.68rem;
        padding: 2px 7px;
    }
}


/* PJ 1.5.23: homepage Best Bets + SEO/detail polish */
.pj-home-hero {
    text-align: center;
    padding: 30px 18px 22px;
}
.pj-home-kicker {
    margin: 0 0 6px;
    color: #C41E3A;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
    font-size: .72rem;
}
.pj-home-quick-links {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding: 12px 2px 2px;
    scrollbar-width: none;
    -ms-overflow-style: none;
}
.pj-home-quick-links::-webkit-scrollbar { display: none; }
.pj-home-quick-links a {
    flex: 0 0 auto;
    border-radius: 999px;
    padding: 9px 12px;
    background: rgba(255,255,255,.86);
    border: 1px solid rgba(196,30,58,.16);
    color: #7f1d1d;
    font-weight: 800;
    text-decoration: none;
    box-shadow: 0 8px 18px rgba(31,41,55,.07);
}
.pj-home-section {
    padding: 8px 16px 22px;
}
.pj-home-section-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
    margin: 0 0 12px;
}
.pj-home-section-head h2 {
    margin: 0;
    font-family: 'Playfair Display', serif;
    font-size: clamp(1.45rem, 6vw, 2.1rem);
}
.pj-home-section-head a {
    color: #C41E3A;
    font-weight: 900;
    text-decoration: none;
    white-space: nowrap;
}
.pj-home-all-actions {
    display: grid;
    gap: 10px;
    padding: 12px 20px 110px;
    text-align: center;
}
.pj-home-secondary-action {
    background: #fff7ed !important;
    color: #9a3412 !important;
}
@media (min-width: 760px) {
    .pj-home-all-actions { grid-template-columns: repeat(2, minmax(0, 220px)); justify-content: center; }
}

/* PJ 1.5.25: Saved page square Sort my day button */
.pj-saved-plan {
    align-items: center;
}
.pj-saved-plan .pj-saved-sort-box,
.pj-saved-plan button[data-pj-saved-sort] {
    width: 74px;
    height: 74px;
    min-width: 74px;
    padding: 0 8px;
    border-radius: 18px;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1px;
    text-align: center;
    line-height: 1.05;
    font-size: 12px;
    letter-spacing: .01em;
    text-transform: none;
    white-space: normal;
}
.pj-saved-plan .pj-saved-sort-box span,
.pj-saved-plan button[data-pj-saved-sort] span {
    display: block;
}
.pj-saved-plan .pj-saved-sort-box span:first-child,
.pj-saved-plan button[data-pj-saved-sort] span:first-child {
    font-size: 13px;
    font-weight: 950;
}
.pj-saved-plan .pj-saved-sort-box span:last-child,
.pj-saved-plan button[data-pj-saved-sort] span:last-child {
    font-size: 11.5px;
    font-weight: 850;
    opacity: .94;
}
.pj-saved-plan .pj-saved-sort-box.is-active,
.pj-saved-plan button[data-pj-saved-sort].is-active {
    box-shadow: 0 7px 16px rgba(24,77,42,0.22), inset 0 0 0 1px rgba(255,255,255,0.18);
}
@media (max-width: 560px) {
    .pj-saved-plan .pj-saved-sort-box,
    .pj-saved-plan button[data-pj-saved-sort] {
        width: 68px;
        height: 68px;
        min-width: 68px;
        border-radius: 16px;
        font-size: 11.5px;
    }
}

/* PJ 1.5.26: softer Day order itinerary control */
.pj-saved-plan .pj-saved-sort-box,
.pj-saved-plan button[data-pj-saved-sort] {
    width: 76px;
    height: 76px;
    min-width: 76px;
    border-radius: 18px;
    border: 1px solid rgba(47,111,62,0.24);
    background: linear-gradient(180deg, rgba(255,255,250,0.98), rgba(245,250,246,0.96));
    color: #245a32;
    box-shadow: 0 7px 16px rgba(39,31,24,0.075), inset 0 1px 0 rgba(255,255,255,0.78);
    gap: 0;
}
.pj-saved-plan .pj-saved-sort-box .pj-saved-sort-icon,
.pj-saved-plan button[data-pj-saved-sort] .pj-saved-sort-icon {
    width: 24px;
    height: 24px;
    margin-bottom: 3px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(47,111,62,0.10);
    color: #2f6f3e;
    font-size: 14px;
    line-height: 1;
    font-weight: 950;
}
.pj-saved-plan .pj-saved-sort-box span:not(.pj-saved-sort-icon),
.pj-saved-plan button[data-pj-saved-sort] span:not(.pj-saved-sort-icon) {
    font-size: 11.5px;
    font-weight: 950;
    letter-spacing: .015em;
    line-height: 1.04;
}
.pj-saved-plan .pj-saved-sort-box.is-active,
.pj-saved-plan button[data-pj-saved-sort].is-active {
    border-color: rgba(24,77,42,0.55);
    background: linear-gradient(180deg, #2f6f3e, #1f5630);
    color: #fff;
    box-shadow: 0 9px 18px rgba(24,77,42,0.22), inset 0 1px 0 rgba(255,255,255,0.18);
}
.pj-saved-plan .pj-saved-sort-box.is-active .pj-saved-sort-icon,
.pj-saved-plan button[data-pj-saved-sort].is-active .pj-saved-sort-icon {
    background: rgba(255,255,255,0.20);
    color: #fff;
}
@media (max-width: 560px) {
    .pj-saved-plan .pj-saved-sort-box,
    .pj-saved-plan button[data-pj-saved-sort] {
        width: 70px;
        height: 70px;
        min-width: 70px;
        border-radius: 17px;
    }
    .pj-saved-plan .pj-saved-sort-box .pj-saved-sort-icon,
    .pj-saved-plan button[data-pj-saved-sort] .pj-saved-sort-icon {
        width: 22px;
        height: 22px;
        margin-bottom: 2px;
        font-size: 13px;
    }
    .pj-saved-plan .pj-saved-sort-box span:not(.pj-saved-sort-icon),
    .pj-saved-plan button[data-pj-saved-sort] span:not(.pj-saved-sort-icon) {
        font-size: 11px;
    }
}

/* PJ 1.5.27: premium Saved plan-your-day box */
.pj-saved-plan {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 14px;
    margin: 4px 0 14px;
    padding: 15px 15px 15px 16px;
    overflow: hidden;
    border: 1px solid rgba(196, 30, 58, 0.10);
    border-radius: 24px;
    background:
        radial-gradient(circle at 8% 0%, rgba(196,30,58,0.10), transparent 30%),
        radial-gradient(circle at 100% 100%, rgba(47,111,62,0.12), transparent 32%),
        linear-gradient(135deg, rgba(255,252,246,0.98), rgba(248,246,238,0.97));
    box-shadow: 0 14px 32px rgba(39,31,24,0.10), inset 0 1px 0 rgba(255,255,255,0.82);
}
.pj-saved-plan::before {
    content: '';
    position: absolute;
    inset: 0 auto 0 0;
    width: 5px;
    background: linear-gradient(180deg, #C41E3A, #2f6f3e);
    opacity: .9;
}
.pj-saved-plan-copy {
    position: relative;
    z-index: 1;
    min-width: 0;
    display: grid;
    gap: 5px;
}
.pj-saved-plan .pj-saved-plan-label {
    width: max-content;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    margin: 0;
    padding: 4px 9px;
    border-radius: 999px;
    border: 1px solid rgba(196,30,58,0.15);
    background: rgba(255,255,255,0.78);
    color: #9f1239;
    font-size: 10.5px;
    font-weight: 950;
    letter-spacing: .08em;
    line-height: 1;
    text-transform: uppercase;
    box-shadow: 0 4px 10px rgba(196,30,58,0.06);
}
.pj-saved-plan .pj-saved-plan-label span {
    color: #C41E3A;
    font-size: 10px;
    line-height: 1;
}
.pj-saved-plan strong {
    margin: 0;
    color: #201a16;
    font-family: 'Playfair Display', Georgia, serif;
    font-size: clamp(18px, 4.6vw, 22px);
    font-weight: 800;
    letter-spacing: -0.015em;
    line-height: 1.08;
}
.pj-saved-plan small {
    display: block;
    max-width: 30rem;
    color: #76665a;
    font-size: 12.5px;
    font-weight: 700;
    line-height: 1.35;
}
.pj-saved-plan .pj-saved-sort-box,
.pj-saved-plan button[data-pj-saved-sort] {
    position: relative;
    z-index: 1;
    width: 78px;
    height: 78px;
    min-width: 78px;
    border-radius: 20px;
    border: 1px solid rgba(47,111,62,0.24);
    background: rgba(255,255,255,0.86);
    color: #245a32;
    box-shadow: 0 10px 20px rgba(39,31,24,0.10), inset 0 1px 0 rgba(255,255,255,0.92);
    backdrop-filter: blur(10px);
}
.pj-saved-plan .pj-saved-sort-box .pj-saved-sort-icon,
.pj-saved-plan button[data-pj-saved-sort] .pj-saved-sort-icon {
    background: rgba(47,111,62,0.11);
    color: #2f6f3e;
}
.pj-saved-plan .pj-saved-sort-box.is-active,
.pj-saved-plan button[data-pj-saved-sort].is-active {
    border-color: rgba(24,77,42,0.58);
    background: linear-gradient(180deg, #2f6f3e, #1f5630);
    color: #fff;
    box-shadow: 0 12px 24px rgba(24,77,42,0.24), inset 0 1px 0 rgba(255,255,255,0.18);
}
.pj-saved-plan .pj-saved-sort-box.is-active .pj-saved-sort-icon,
.pj-saved-plan button[data-pj-saved-sort].is-active .pj-saved-sort-icon {
    background: rgba(255,255,255,0.20);
    color: #fff;
}
@media (max-width: 560px) {
    .pj-saved-plan {
        gap: 10px;
        padding: 14px 12px 14px 14px;
        border-radius: 22px;
    }
    .pj-saved-plan strong {
        font-size: 17px;
    }
    .pj-saved-plan small {
        font-size: 11.5px;
        line-height: 1.3;
    }
    .pj-saved-plan .pj-saved-sort-box,
    .pj-saved-plan button[data-pj-saved-sort] {
        width: 70px;
        height: 70px;
        min-width: 70px;
        border-radius: 18px;
    }
}

/* PJ 1.5.28: redesigned Saved plan card */
.pj-saved-plan {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 96px;
    align-items: stretch;
    gap: 12px;
    margin: 8px 0 16px;
    padding: 12px;
    overflow: hidden;
    border: 1px solid rgba(80, 56, 35, 0.10);
    border-radius: 26px;
    background:
        linear-gradient(135deg, rgba(255,255,255,0.82), rgba(255,247,237,0.72)),
        radial-gradient(circle at 0 0, rgba(196,30,58,0.12), transparent 38%),
        radial-gradient(circle at 100% 100%, rgba(47,111,62,0.14), transparent 34%),
        #fbf7ef;
    box-shadow: 0 18px 40px rgba(39,31,24,0.12), inset 0 1px 0 rgba(255,255,255,0.84);
}
.pj-saved-plan::before {
    display: none;
}
.pj-saved-plan-main {
    min-width: 0;
    display: grid;
    align-content: center;
    gap: 10px;
    padding: 3px 2px 3px 3px;
}
.pj-saved-plan-head {
    display: grid;
    grid-template-columns: 38px minmax(0, 1fr);
    align-items: center;
    gap: 11px;
}
.pj-saved-plan-mark {
    width: 38px;
    height: 38px;
    border-radius: 15px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    background: linear-gradient(145deg, #C41E3A, #9f1239);
    box-shadow: 0 10px 18px rgba(196,30,58,0.20), inset 0 1px 0 rgba(255,255,255,0.24);
    font-size: 15px;
    font-weight: 950;
}
.pj-saved-plan .pj-saved-plan-copy {
    display: grid;
    gap: 3px;
    min-width: 0;
}
.pj-saved-plan .pj-saved-plan-label {
    width: auto;
    display: block;
    margin: 0;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    color: #C41E3A;
    font-size: 10.5px;
    font-weight: 950;
    letter-spacing: .105em;
    line-height: 1;
    text-transform: uppercase;
}
.pj-saved-plan strong {
    color: #201a16;
    font-family: 'Playfair Display', Georgia, serif;
    font-size: clamp(19px, 5vw, 24px);
    font-weight: 850;
    letter-spacing: -0.02em;
    line-height: 1.05;
}
.pj-saved-plan-note {
    margin: 0;
    width: fit-content;
    max-width: 100%;
    padding: 7px 10px;
    border-radius: 999px;
    background: rgba(255,255,255,0.70);
    border: 1px solid rgba(80, 56, 35, 0.07);
    color: #6f5f54;
    font-size: 12px;
    font-weight: 800;
    line-height: 1.25;
}
.pj-saved-plan .pj-saved-sort-box,
.pj-saved-plan button[data-pj-saved-sort] {
    width: 96px;
    height: auto;
    min-width: 96px;
    min-height: 96px;
    padding: 10px 8px;
    border-radius: 22px;
    border: 1px solid rgba(47,111,62,0.20);
    background: rgba(255,255,255,0.90);
    color: #245a32;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    box-shadow: 0 12px 24px rgba(39,31,24,0.11), inset 0 1px 0 rgba(255,255,255,0.95);
    backdrop-filter: blur(10px);
}
.pj-saved-plan .pj-saved-sort-box .pj-saved-sort-icon,
.pj-saved-plan button[data-pj-saved-sort] .pj-saved-sort-icon {
    width: 30px;
    height: 30px;
    margin: 0 0 2px;
    border-radius: 13px;
    background: linear-gradient(145deg, rgba(47,111,62,0.13), rgba(47,111,62,0.07));
    color: #2f6f3e;
    font-size: 16px;
    font-weight: 950;
}
.pj-saved-plan .pj-saved-sort-box span:not(.pj-saved-sort-icon),
.pj-saved-plan button[data-pj-saved-sort] span:not(.pj-saved-sort-icon) {
    color: inherit;
    font-size: 12px;
    font-weight: 950;
    letter-spacing: .01em;
    line-height: 1.05;
}
.pj-saved-plan .pj-saved-sort-box small,
.pj-saved-plan button[data-pj-saved-sort] small {
    color: inherit;
    opacity: .64;
    font-size: 9.5px;
    font-weight: 900;
    letter-spacing: .045em;
    line-height: 1;
    text-transform: uppercase;
}
.pj-saved-plan .pj-saved-sort-box.is-active,
.pj-saved-plan button[data-pj-saved-sort].is-active {
    border-color: rgba(24,77,42,0.60);
    background: linear-gradient(160deg, #2f6f3e, #184d2a);
    color: #fff;
    box-shadow: 0 14px 28px rgba(24,77,42,0.25), inset 0 1px 0 rgba(255,255,255,0.20);
}
.pj-saved-plan .pj-saved-sort-box.is-active .pj-saved-sort-icon,
.pj-saved-plan button[data-pj-saved-sort].is-active .pj-saved-sort-icon {
    background: rgba(255,255,255,0.20);
    color: #fff;
}
@media (max-width: 560px) {
    .pj-saved-plan {
        grid-template-columns: minmax(0, 1fr) 86px;
        gap: 9px;
        padding: 10px;
        border-radius: 24px;
    }
    .pj-saved-plan-head {
        grid-template-columns: 34px minmax(0, 1fr);
        gap: 9px;
    }
    .pj-saved-plan-mark {
        width: 34px;
        height: 34px;
        border-radius: 13px;
        font-size: 13px;
    }
    .pj-saved-plan strong {
        font-size: 17.5px;
    }
    .pj-saved-plan-note {
        padding: 6px 8px;
        border-radius: 14px;
        font-size: 11px;
    }
    .pj-saved-plan .pj-saved-sort-box,
    .pj-saved-plan button[data-pj-saved-sort] {
        width: 86px;
        min-width: 86px;
        min-height: 86px;
        padding: 8px 6px;
        border-radius: 20px;
    }
    .pj-saved-plan .pj-saved-sort-box .pj-saved-sort-icon,
    .pj-saved-plan button[data-pj-saved-sort] .pj-saved-sort-icon {
        width: 27px;
        height: 27px;
        border-radius: 12px;
        font-size: 14px;
    }
    .pj-saved-plan .pj-saved-sort-box span:not(.pj-saved-sort-icon),
    .pj-saved-plan button[data-pj-saved-sort] span:not(.pj-saved-sort-icon) {
        font-size: 11.5px;
    }
}

/* PJ 1.5.29: Saved page visual match to Phil mobile mockup. */
body {
    background: #fbf5ec;
}
.pj-site-header {
    background: #fbf5ec;
    border-bottom: 0;
    box-shadow: 0 1px 0 rgba(94,66,44,0.08);
}
.pj-site-bar {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr) 42px;
    align-items: center;
    gap: 8px;
    max-width: 760px;
    margin: 0 auto;
}
.pj-site-brand {
    min-width: 0;
    text-align: center;
}
.pj-header-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: #2a211c;
    text-decoration: none;
    box-shadow: none;
    cursor: pointer;
}
.pj-header-icon--menu {
    flex-direction: column;
    gap: 4px;
}
.pj-header-icon--menu span {
    display: block;
    width: 18px;
    height: 2px;
    border-radius: 999px;
    background: currentColor;
}
.pj-header-icon--refresh {
    font-size: 25px;
    line-height: 1;
}
.pj-site-title {
    font-size: 27px;
    letter-spacing: -0.65px;
}
.pj-site-subtitle {
    color: #b13d45;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: 1.8px;
}
.pj-top-nav {
    width: min(260px, calc(100% - 32px));
    margin: 10px auto 0;
    padding: 4px;
    border: 1px solid rgba(86,66,50,0.08);
    border-radius: 999px;
    background: #efe5d9;
    box-shadow: inset 0 1px 2px rgba(49,38,29,0.04);
}
.pj-top-nav a {
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: #8a8177;
    box-shadow: none;
}
.pj-top-nav a.active {
    background: #fff;
    color: #1f1b18;
    box-shadow: 0 4px 12px rgba(64,45,30,0.10);
}
.pj-saved-page {
    max-width: 430px;
    padding-left: 18px;
    padding-right: 18px;
}
.pj-saved-header {
    padding: 20px 0 8px;
    text-align: left;
}
.pj-saved-header .pj-section-kicker {
    margin: 0 0 5px;
    color: #b13d45;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .13em;
    text-transform: uppercase;
}
.pj-saved-header .pj-archive-title {
    margin: 0;
    color: #17120f;
    font-size: 34px;
    line-height: .98;
    letter-spacing: -0.8px;
}
.pj-saved-header .pj-archive-subtitle {
    max-width: none;
    margin-top: 11px;
    color: #4f4942;
    font-size: 15px;
    line-height: 1.5;
}
.pj-saved-shell {
    margin-top: 12px;
}
.pj-saved-actions {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
    margin-bottom: 14px;
}
.pj-saved-actions button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    min-height: 38px;
    border: 1px solid rgba(177,61,69,0.14);
    border-radius: 999px;
    background: #fffdfa;
    color: #3a3029;
    box-shadow: 0 7px 16px rgba(67,45,28,0.06);
    font-size: 11.5px;
    font-weight: 900;
    white-space: nowrap;
}
.pj-saved-actions button span {
    color: #b13d45;
    font-size: 12px;
    line-height: 1;
}
.pj-saved-plan {
    border: 1px solid rgba(177,61,69,0.13);
    background: linear-gradient(145deg, #fffaf3 0%, #ffffff 52%, #f8eee2 100%);
    box-shadow: 0 16px 34px rgba(69,45,25,0.11);
}
.pj-saved-plan-mark {
    background: #f8e8df;
    color: #b13d45;
    box-shadow: inset 0 0 0 1px rgba(177,61,69,0.10);
}
.pj-saved-plan .pj-saved-plan-label {
    border: 0;
    background: transparent;
    color: #b13d45;
    padding: 0;
    letter-spacing: .12em;
}
.pj-saved-plan strong {
    font-family: var(--font-serif);
    color: #1b1714;
}
.pj-saved-plan-note {
    background: rgba(255,255,255,0.68);
    color: #75685e;
}
.pj-saved-plan .pj-saved-sort-box,
.pj-saved-plan button[data-pj-saved-sort] {
    border-color: rgba(177,61,69,0.22);
    background: #fff;
    color: #94323a;
    box-shadow: 0 13px 24px rgba(177,61,69,0.12);
}
.pj-saved-plan .pj-saved-sort-box .pj-saved-sort-icon,
.pj-saved-plan button[data-pj-saved-sort] .pj-saved-sort-icon {
    background: #f8e8df;
    color: #b13d45;
}
.pj-saved-filters {
    margin-top: 16px;
    margin-bottom: 16px;
}
.pj-saved-filters button {
    min-height: 38px;
    border-color: rgba(86,66,50,0.10);
    background: #fffdfa;
    color: #70665c;
}
.pj-saved-filters button.is-active {
    border-color: rgba(177,61,69,0.22);
    background: #fff;
    color: #17120f;
    box-shadow: 0 8px 18px rgba(67,45,28,0.08);
}
.pj-saved-empty {
    border: 1px solid rgba(177,61,69,0.12);
    background: linear-gradient(145deg, #fffdfa, #f7eadc);
    box-shadow: 0 14px 30px rgba(67,45,28,0.08);
}
.pj-saved-card--feed {
    border-color: rgba(86,66,50,0.09);
    background: #fffdfa;
    box-shadow: 0 12px 28px rgba(67,45,28,0.09);
}
@media (max-width: 560px) {
    .pj-site-header {
        padding: 9px 14px 10px;
    }
    .pj-site-title {
        font-size: 25px;
    }
    .pj-saved-page {
        padding-left: 18px;
        padding-right: 18px;
    }
    .pj-saved-header .pj-archive-title {
        font-size: 32px;
    }
    .pj-saved-actions {
        gap: 6px;
    }
    .pj-saved-actions button {
        min-height: 36px;
        padding-left: 6px;
        padding-right: 6px;
        font-size: 10.5px;
    }
}


/* PJ 1.5.30: tighter Saved mockup mirror. */
.pj-sticky-header { background: #fbf5ec; }
.pj-site-header { padding-top: 10px; padding-bottom: 12px; }
.pj-header-icon--menu { align-items: flex-start; padding-left: 2px; }
.pj-header-icon--menu span { width: 20px; height: 2.2px; }
.pj-header-icon--refresh { justify-self: end; color: #342923; font-size: 27px; font-weight: 400; }
.pj-site-title { font-size: 28px; font-weight: 700; line-height: 1; }
.pj-site-subtitle { margin-top: 5px; color: #b24a37; font-size: 9.5px; font-weight: 900; letter-spacing: .15em; }
.pj-top-nav { width: min(286px, calc(100% - 44px)); min-height: 42px; margin-top: 14px; padding: 5px; background: #eee4d7; border-color: rgba(77,58,40,.07); }
.pj-top-nav a { min-height: 32px; color: #8b837b; font-size: 13px; font-weight: 900; }
.pj-top-nav a.active { color: #211a16; background: #fff; }
.pj-saved-page { max-width: 430px; margin: 0 auto; padding-bottom: 112px; }
.pj-saved-header { padding-top: 22px; padding-bottom: 10px; }
.pj-saved-header .pj-section-kicker { margin-bottom: 7px; color: #b24a37; font-size: 10.5px; letter-spacing: .16em; }
.pj-saved-header .pj-archive-title { font-size: 36px; font-weight: 750; line-height: 1.02; }
.pj-saved-header .pj-archive-subtitle { margin-top: 12px; color: #494039; font-size: 15.5px; line-height: 1.48; }
.pj-saved-actions { margin-top: 4px; margin-bottom: 16px; gap: 8px; }
.pj-saved-actions button { min-height: 40px; padding: 0 9px; border-color: rgba(130,83,56,.13); background: #fffdf8; color: #372c25; box-shadow: 0 6px 15px rgba(68,45,24,.055); font-size: 11px; font-weight: 900; }
.pj-saved-actions button span { color: #b24a37; }
.pj-saved-plan { grid-template-columns: minmax(0,1fr) 92px; align-items: stretch; gap: 12px; margin: 4px 0 15px; padding: 13px; border-radius: 28px; border-color: rgba(159,73,45,.14); background: linear-gradient(145deg,#fffaf2 0%,#fffefd 54%,#f6e8d9 100%); box-shadow: 0 18px 38px rgba(62,41,22,.12); }
.pj-saved-plan-main { min-width: 0; display: flex; flex-direction: column; justify-content: center; gap: 10px; }
.pj-saved-plan-head { grid-template-columns: 48px minmax(0,1fr); gap: 12px; align-items: center; }
.pj-saved-plan-mark { position: relative; width: 48px; height: 48px; border-radius: 50%; background: #f5e5d4; color: #a9442f; font-size: 21px; box-shadow: inset 0 0 0 1px rgba(169,68,47,.10), 0 6px 14px rgba(68,45,24,.06); }
.pj-saved-plan-mark::before, .pj-saved-plan-mark::after { content: "✦"; position: absolute; color: #c9895e; font-size: 9px; line-height: 1; }
.pj-saved-plan-mark::before { right: -4px; top: 4px; }
.pj-saved-plan-mark::after { left: -4px; bottom: 6px; font-size: 7px; }
.pj-saved-plan .pj-saved-plan-label { display: block; margin: 0 0 4px; color: #b24a37; font-size: 10px; font-weight: 950; letter-spacing: .16em; text-transform: uppercase; }
.pj-saved-plan strong { display: block; font-size: 19px; font-weight: 750; line-height: 1.12; letter-spacing: -.25px; }
.pj-saved-plan-note { width: auto; padding: 0; border: 0; background: transparent; color: #7a6c60; font-size: 12.5px; font-weight: 800; }
.pj-saved-plan .pj-saved-sort-box, .pj-saved-plan button[data-pj-saved-sort] { width: 92px; min-width: 92px; min-height: 92px; border-radius: 24px; border-color: rgba(169,68,47,.18); background: #fffaf5; color: #a13f2d; box-shadow: 0 13px 25px rgba(130,73,38,.12), inset 0 1px 0 rgba(255,255,255,.9); }
.pj-saved-plan .pj-saved-sort-box .pj-saved-sort-icon, .pj-saved-plan button[data-pj-saved-sort] .pj-saved-sort-icon { background: #f5e5d4; color: #a9442f; }
.pj-saved-filters { gap: 9px; }
.pj-saved-filters button { border-color: rgba(130,83,56,.12); background: #fffdf8; color: #80756b; }
.pj-saved-filters button.is-active { color: #211a16; background: #fff; border-color: rgba(159,73,45,.16); }
.pj-saved-card--feed { border-radius: 23px; background: #fffdf8; }
@media (max-width: 560px) {
    .pj-site-header { padding: 9px 16px 11px; }
    .pj-site-title { font-size: 27px; }
    .pj-top-nav { width: calc(100% - 54px); }
    .pj-saved-page { padding-left: 22px; padding-right: 22px; }
    .pj-saved-header .pj-archive-title { font-size: 35px; }
    .pj-saved-actions { grid-template-columns: repeat(4,minmax(0,1fr)); gap: 7px; }
    .pj-saved-actions button { min-height: 39px; padding-left: 5px; padding-right: 5px; font-size: 10.2px; }
    .pj-saved-plan { grid-template-columns: minmax(0,1fr) 88px; padding: 12px; gap: 10px; }
    .pj-saved-plan-head { grid-template-columns: 44px minmax(0,1fr); }
    .pj-saved-plan-mark { width: 44px; height: 44px; }
    .pj-saved-plan strong { font-size: 18px; }
    .pj-saved-plan .pj-saved-sort-box, .pj-saved-plan button[data-pj-saved-sort] { width: 88px; min-width: 88px; min-height: 88px; }
}


/* PJ 1.5.31: exact saved mockup pass — neutral app chrome + real icons. */
body, .wp-site-blocks { background: #fbf4ea !important; }
.pj-sticky-header { position: sticky; top: 0; z-index: 100; background: #fbf4ea !important; }
.pj-site-header { background: #fbf4ea !important; border: 0 !important; box-shadow: none !important; padding: 12px 18px 12px !important; }
.pj-site-bar { grid-template-columns: 40px minmax(0,1fr) 40px !important; max-width: 430px !important; }
.pj-header-icon { width: 36px !important; height: 36px !important; color: #1f1a17 !important; }
.pj-header-icon--menu { gap: 4.5px !important; align-items: flex-start !important; justify-self: start !important; }
.pj-header-icon--menu span { width: 19px !important; height: 2px !important; border-radius: 4px !important; }
.pj-header-icon--refresh { justify-self: end !important; font-size: 26px !important; transform: translateY(-1px); }
.pj-site-title { font-size: 27px !important; font-weight: 750 !important; line-height: .98 !important; letter-spacing: -.7px !important; color: #151210 !important; }
.pj-site-subtitle { margin-top: 5px !important; color: #b24a35 !important; font-size: 9.5px !important; line-height: 1 !important; font-weight: 950 !important; letter-spacing: .155em !important; }
.pj-top-nav { width: min(286px, calc(100vw - 86px)) !important; height: 43px !important; min-height: 43px !important; margin: 14px auto 0 !important; padding: 5px !important; border: 0 !important; border-radius: 999px !important; background: #eee3d5 !important; box-shadow: inset 0 1px 2px rgba(63,43,25,.035) !important; }
.pj-top-nav a { min-height: 33px !important; height: 33px !important; padding: 0 18px !important; border: 0 !important; border-radius: 999px !important; background: transparent !important; color: #81796f !important; font-size: 13px !important; font-weight: 900 !important; box-shadow: none !important; }
.pj-top-nav a.active { background: #fff !important; color: #181411 !important; box-shadow: 0 4px 12px rgba(58,39,22,.10) !important; }
.pj-saved-page { max-width: 430px !important; margin: 0 auto !important; padding: 0 24px 112px !important; }
.pj-saved-header { padding: 21px 0 10px !important; text-align: left !important; }
.pj-saved-header .pj-section-kicker { margin: 0 0 7px !important; color: #b24a35 !important; font-size: 10.5px !important; line-height: 1 !important; font-weight: 950 !important; letter-spacing: .16em !important; text-transform: uppercase !important; }
.pj-saved-header .pj-archive-title { margin: 0 !important; color: #151210 !important; font-size: 36px !important; font-weight: 760 !important; line-height: 1.02 !important; letter-spacing: -.85px !important; }
.pj-saved-header .pj-archive-subtitle { margin: 12px 0 0 !important; max-width: none !important; color: #4d443c !important; font-size: 15.5px !important; line-height: 1.5 !important; font-weight: 500 !important; }
.pj-saved-shell { margin-top: 8px !important; }
.pj-saved-actions { display: grid !important; grid-template-columns: repeat(4,minmax(0,1fr)) !important; gap: 8px !important; width: 100% !important; margin: 2px 0 16px !important; overflow: visible !important; }
.pj-saved-actions button { display: inline-flex !important; align-items: center !important; justify-content: center !important; gap: 5px !important; width: 100% !important; min-width: 0 !important; min-height: 40px !important; padding: 0 7px !important; border: 1px solid rgba(139,87,52,.13) !important; border-radius: 999px !important; background: #fffdf8 !important; color: #362b24 !important; box-shadow: 0 6px 15px rgba(68,45,24,.055) !important; font-size: 10.6px !important; font-weight: 900 !important; line-height: 1 !important; white-space: nowrap !important; }
.pj-saved-action-icon { position: relative; display: inline-block !important; flex: 0 0 auto; width: 14px !important; height: 14px !important; color: #b24a35 !important; font-size: 0 !important; }
.pj-saved-action-icon--share::before, .pj-saved-action-icon--share::after { content: ""; position: absolute; background: currentColor; }
.pj-saved-action-icon--share { background: radial-gradient(circle at 2px 7px,currentColor 0 2px,transparent 2.2px),radial-gradient(circle at 11px 3px,currentColor 0 2px,transparent 2.2px),radial-gradient(circle at 11px 11px,currentColor 0 2px,transparent 2.2px); }
.pj-saved-action-icon--share::before { width: 8px; height: 1.5px; left: 3px; top: 5px; transform: rotate(-24deg); transform-origin: left center; }
.pj-saved-action-icon--share::after { width: 8px; height: 1.5px; left: 3px; top: 8.5px; transform: rotate(24deg); transform-origin: left center; }
.pj-saved-action-icon--text { border: 1.8px solid currentColor; border-radius: 5px; }
.pj-saved-action-icon--text::after { content: ""; position: absolute; left: 3px; bottom: -4px; width: 5px; height: 5px; border-left: 1.8px solid currentColor; border-bottom: 1.8px solid currentColor; transform: skew(-18deg); background: #fffdf8; }
.pj-saved-action-icon--email { border: 1.7px solid currentColor; border-radius: 3px; }
.pj-saved-action-icon--email::before, .pj-saved-action-icon--email::after { content: ""; position: absolute; top: 4px; width: 8px; height: 1.5px; background: currentColor; }
.pj-saved-action-icon--email::before { left: -1px; transform: rotate(32deg); }
.pj-saved-action-icon--email::after { right: -1px; transform: rotate(-32deg); }
.pj-saved-action-icon--copy::before, .pj-saved-action-icon--copy::after { content: ""; position: absolute; width: 8px; height: 5px; border: 1.7px solid currentColor; border-radius: 999px; transform: rotate(-35deg); }
.pj-saved-action-icon--copy::before { left: 0; top: 5px; }
.pj-saved-action-icon--copy::after { right: 0; top: 2px; }
.pj-saved-plan { display: grid !important; grid-template-columns: minmax(0,1fr) 90px !important; align-items: stretch !important; gap: 12px !important; margin: 3px 0 15px !important; padding: 14px !important; border: 1px solid rgba(169,76,45,.14) !important; border-radius: 28px !important; background: linear-gradient(145deg,#fffaf2 0%,#fffefd 55%,#f6e7d6 100%) !important; box-shadow: 0 18px 38px rgba(62,41,22,.12) !important; }
.pj-saved-plan-main { display: flex !important; flex-direction: column !important; justify-content: center !important; min-width: 0 !important; gap: 10px !important; }
.pj-saved-plan-head { display: grid !important; grid-template-columns: 48px minmax(0,1fr) !important; align-items: center !important; gap: 12px !important; }
.pj-saved-plan-mark { position: relative !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; width: 48px !important; height: 48px !important; border-radius: 50% !important; background: #f4e3d1 !important; color: #a9442f !important; box-shadow: inset 0 0 0 1px rgba(169,68,47,.10), 0 6px 14px rgba(68,45,24,.06) !important; }
.pj-saved-plan-mark svg { width: 25px !important; height: 25px !important; display: block !important; fill: none !important; stroke: currentColor !important; stroke-width: 1.8 !important; stroke-linecap: round !important; stroke-linejoin: round !important; }
.pj-saved-plan-mark::before, .pj-saved-plan-mark::after { content: "✦" !important; position: absolute !important; color: #c9895e !important; line-height: 1 !important; }
.pj-saved-plan-mark::before { right: -4px !important; top: 4px !important; font-size: 9px !important; }
.pj-saved-plan-mark::after { left: -4px !important; bottom: 6px !important; font-size: 7px !important; }
.pj-saved-plan .pj-saved-plan-label { display: block !important; margin: 0 0 4px !important; padding: 0 !important; border: 0 !important; background: transparent !important; color: #b24a35 !important; font-size: 10px !important; font-weight: 950 !important; letter-spacing: .16em !important; text-transform: uppercase !important; white-space: nowrap !important; }
.pj-saved-plan strong { display: block !important; font-family: var(--font-serif) !important; color: #181411 !important; font-size: 19px !important; font-weight: 760 !important; line-height: 1.12 !important; letter-spacing: -.25px !important; }
.pj-saved-plan-note { margin: 0 !important; width: auto !important; padding: 0 !important; border: 0 !important; background: transparent !important; color: #7a6c60 !important; font-size: 12.5px !important; font-weight: 800 !important; line-height: 1.28 !important; }
.pj-saved-plan .pj-saved-sort-box, .pj-saved-plan button[data-pj-saved-sort] { width: 90px !important; min-width: 90px !important; min-height: 90px !important; align-self: stretch !important; padding: 8px 6px !important; border: 1px solid rgba(169,68,47,.18) !important; border-radius: 24px !important; background: #fffaf5 !important; color: #a13f2d !important; box-shadow: 0 13px 25px rgba(130,73,38,.12), inset 0 1px 0 rgba(255,255,255,.9) !important; }
.pj-saved-plan .pj-saved-sort-box .pj-saved-sort-icon, .pj-saved-plan button[data-pj-saved-sort] .pj-saved-sort-icon { width: 28px !important; height: 28px !important; margin-bottom: 3px !important; border-radius: 12px !important; background: #f4e3d1 !important; color: #a9442f !important; }
.pj-saved-plan .pj-saved-sort-box span:not(.pj-saved-sort-icon), .pj-saved-plan button[data-pj-saved-sort] span:not(.pj-saved-sort-icon) { font-size: 11.5px !important; font-weight: 950 !important; }
.pj-saved-plan .pj-saved-sort-box small, .pj-saved-plan button[data-pj-saved-sort] small { font-size: 9px !important; }
.pj-saved-filters { margin: 15px 0 16px !important; gap: 9px !important; }
.pj-saved-filters button { min-height: 39px !important; border-color: rgba(139,87,52,.13) !important; background: #fffdf8 !important; color: #80756b !important; box-shadow: 0 6px 15px rgba(68,45,24,.05) !important; }
.pj-saved-filters button.is-active { background: #fff !important; color: #181411 !important; border-color: rgba(169,76,45,.16) !important; }
.pj-saved-card--feed { border-radius: 24px !important; background: #fffdf8 !important; border-color: rgba(139,87,52,.10) !important; box-shadow: 0 13px 28px rgba(62,41,22,.10) !important; }
@media (max-width: 560px) {
    .pj-site-header { padding-left: 17px !important; padding-right: 17px !important; }
    .pj-site-title { font-size: 27px !important; }
    .pj-top-nav { width: calc(100vw - 86px) !important; }
    .pj-saved-page { padding-left: 24px !important; padding-right: 24px !important; }
    .pj-saved-header .pj-archive-title { font-size: 35.5px !important; }
    .pj-saved-actions { gap: 7px !important; }
    .pj-saved-actions button { min-height: 39px !important; padding-left: 5px !important; padding-right: 5px !important; font-size: 10.2px !important; }
    .pj-saved-action-icon { width: 13px !important; height: 13px !important; }
    .pj-saved-plan { grid-template-columns: minmax(0,1fr) 88px !important; padding: 13px !important; gap: 10px !important; }
    .pj-saved-plan-head { grid-template-columns: 44px minmax(0,1fr) !important; gap: 11px !important; }
    .pj-saved-plan-mark { width: 44px !important; height: 44px !important; }
    .pj-saved-plan strong { font-size: 18px !important; }
    .pj-saved-plan .pj-saved-sort-box, .pj-saved-plan button[data-pj-saved-sort] { width: 88px !important; min-width: 88px !important; min-height: 88px !important; }
}


/* PJ 1.5.32: saved-page mockup content states and card layout. */
.pj-saved-plan-next,
.pj-saved-plan-time {
    display: block;
    margin-top: 3px;
    color: #1b1714;
    font-family: var(--font-sans);
    font-size: 13px;
    font-weight: 900;
    line-height: 1.25;
}
.pj-saved-plan-time {
    margin-top: 2px;
    color: #7b6b5e;
    font-size: 12px;
    font-weight: 850;
}
.pj-saved-plan-next[hidden],
.pj-saved-plan-time[hidden] { display: none !important; }
.pj-saved-helper {
    display: flex !important;
    align-items: center;
    justify-content: center;
    gap: 7px;
    margin: 2px 0 8px !important;
    color: #6f6257 !important;
    font-size: 12.5px !important;
    font-weight: 750 !important;
    line-height: 1.35 !important;
    text-align: center !important;
}
.pj-saved-helper[hidden] { display: none !important; }
.pj-saved-helper > span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    width: 16px;
    height: 16px;
    border: 1.5px solid #b24a35;
    border-radius: 50%;
    color: #b24a35;
    font-size: 10px;
    font-weight: 950;
    line-height: 1;
}
.pj-saved-clear-link {
    margin: 0 auto 14px !important;
    color: #a6422e !important;
    font-size: 12.5px !important;
    font-weight: 900 !important;
    text-decoration: none !important;
}
.pj-saved-filters {
    display: grid !important;
    grid-template-columns: repeat(3,minmax(0,1fr)) !important;
    gap: 9px !important;
    width: 100% !important;
    margin: 0 0 16px !important;
}
.pj-saved-filters button {
    min-height: 40px !important;
    border: 1px solid rgba(166,92,55,.16) !important;
    border-radius: 999px !important;
    background: #fffdf8 !important;
    color: #776b60 !important;
    box-shadow: 0 6px 15px rgba(68,45,24,.045) !important;
    font-size: 13px !important;
    font-weight: 900 !important;
}
.pj-saved-filters button.is-active {
    border-color: #ad4b31 !important;
    background: #ad4b31 !important;
    color: #fff !important;
    box-shadow: 0 8px 16px rgba(173,75,49,.22) !important;
}
.pj-saved-group-title { display: none !important; }
.pj-saved-group, .pj-saved-group-grid { gap: 12px !important; }
.pj-saved-card--event.pj-saved-card--feed {
    min-height: 150px;
    border-radius: 22px !important;
    overflow: hidden !important;
    background: #fffdf8 !important;
    border: 1px solid rgba(139,87,52,.11) !important;
    box-shadow: 0 12px 28px rgba(62,41,22,.10) !important;
}
.pj-saved-card--event .pj-saved-card-link {
    display: grid !important;
    grid-template-columns: 104px minmax(0,1fr) !important;
    gap: 12px !important;
    align-items: stretch !important;
    padding: 12px 44px 58px 12px !important;
}
.pj-saved-card--event .pj-saved-card-media {
    width: 104px !important;
    height: 104px !important;
    align-self: start !important;
    border-radius: 15px !important;
    background: #efe3d5 !important;
}
.pj-saved-card--event .pj-saved-card-body {
    min-width: 0 !important;
    padding: 0 !important;
    justify-content: flex-start !important;
    gap: 6px !important;
}
.pj-saved-card--event .pj-saved-card-topline {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    margin: 0 !important;
    padding-right: 22px !important;
}
.pj-saved-card--event .pj-saved-kind,
.pj-saved-card--event .pj-saved-plan-label {
    display: inline-flex !important;
    align-items: center !important;
    min-height: 22px !important;
    border-radius: 999px !important;
    padding: 4px 8px !important;
    font-size: 9.5px !important;
    font-weight: 950 !important;
    letter-spacing: .08em !important;
    text-transform: uppercase !important;
    white-space: nowrap !important;
}
.pj-saved-card--event .pj-saved-kind { background: #f7e3dc !important; color: #a6422e !important; }
.pj-saved-card--event .pj-saved-plan-label { background: #e9f1de !important; color: #526b3e !important; border-color: rgba(82,107,62,.16) !important; }
.pj-saved-note { color: #a6422e !important; font-size: 11px !important; font-weight: 900 !important; }
.pj-saved-card--event .pj-saved-note { margin-left: auto !important; }
.pj-saved-card--event .pj-saved-card-title {
    margin: 2px 0 0 !important;
    color: #17120f !important;
    font-family: var(--font-serif) !important;
    font-size: 17px !important;
    font-weight: 800 !important;
    line-height: 1.15 !important;
}
.pj-saved-card--event .pj-saved-card-hint {
    display: block !important;
    margin: 3px 0 0 !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    color: #4a4038 !important;
    font-size: 12px !important;
    font-weight: 800 !important;
    line-height: 1.25 !important;
}
.pj-saved-card--event .pj-saved-card-meta {
    display: flex !important;
    flex-direction: column !important;
    gap: 3px !important;
    margin: 0 !important;
    padding: 0 !important;
}
.pj-saved-card--event .pj-saved-card-meta span {
    display: block !important;
    padding: 0 !important;
    background: transparent !important;
    color: #7a6c60 !important;
    font-size: 11.5px !important;
    font-weight: 750 !important;
    line-height: 1.2 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}
.pj-saved-card--feed .pj-saved-remove,
.pj-saved-card--event .pj-saved-remove {
    top: 12px !important;
    right: 12px !important;
    bottom: auto !important;
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    background: #fff !important;
    color: #b41f2b !important;
    box-shadow: 0 6px 14px rgba(177,31,43,.16) !important;
}
.pj-saved-card--feed .pj-saved-card-actions {
    left: 12px !important;
    right: 12px !important;
    bottom: 12px !important;
    display: grid !important;
    grid-auto-flow: column !important;
    grid-auto-columns: minmax(0,1fr) !important;
    gap: 8px !important;
    width: auto !important;
    max-width: none !important;
    transform: none !important;
}
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps {
    width: 100% !important;
    min-height: 32px !important;
    padding: 7px 6px !important;
    border-radius: 999px !important;
    font-size: 11px !important;
    font-weight: 900 !important;
    text-align: center !important;
}
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-open { background: #ad4b31 !important; color: #fff !important; }
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps { background: #fff6ed !important; color: #9a3f28 !important; border: 1px solid rgba(154,63,40,.14) !important; }
.pj-saved-empty-actions { grid-template-columns: repeat(2,minmax(0,1fr)) !important; }
.pj-saved-plan .pj-saved-sort-icon svg {
    width: 22px !important;
    height: 22px !important;
    display: block !important;
    fill: none !important;
    stroke: currentColor !important;
    stroke-width: 1.8 !important;
    stroke-linecap: round !important;
    stroke-linejoin: round !important;
}
@media (max-width: 380px) {
    .pj-saved-page { padding-left: 18px !important; padding-right: 18px !important; }
    .pj-saved-actions { gap: 5px !important; }
    .pj-saved-actions button { font-size: 9.6px !important; }
    .pj-saved-card--event .pj-saved-card-link { grid-template-columns: 92px minmax(0,1fr) !important; gap: 10px !important; }
    .pj-saved-card--event .pj-saved-card-media { width: 92px !important; height: 92px !important; }
}


/* PJ 1.5.34: icon fidelity pass for Saved mockup. */
.pj-header-icon--refresh {
    font-size: 0 !important;
}
.pj-header-icon--refresh svg {
    display: block !important;
    width: 23px !important;
    height: 23px !important;
    fill: none !important;
    stroke: currentColor !important;
    stroke-width: 2.1 !important;
    stroke-linecap: round !important;
    stroke-linejoin: round !important;
}
.pj-saved-action-icon {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 15px !important;
    height: 15px !important;
    background: none !important;
    border: 0 !important;
    color: #b24a35 !important;
}
.pj-saved-action-icon::before,
.pj-saved-action-icon::after {
    content: none !important;
    display: none !important;
}
.pj-saved-action-icon svg {
    display: block !important;
    width: 15px !important;
    height: 15px !important;
    fill: none !important;
    stroke: currentColor !important;
    stroke-width: 2 !important;
    stroke-linecap: round !important;
    stroke-linejoin: round !important;
    overflow: visible !important;
}
.pj-saved-action-icon--share svg circle {
    fill: currentColor !important;
    stroke: none !important;
}
.pj-saved-action-icon--share svg path {
    stroke-width: 1.8 !important;
}
.pj-saved-plan-mark svg {
    width: 25px !important;
    height: 25px !important;
    fill: none !important;
    stroke: #a9442f !important;
    stroke-width: 1.8 !important;
    stroke-linecap: round !important;
    stroke-linejoin: round !important;
}
.pj-saved-plan .pj-saved-sort-icon svg {
    width: 23px !important;
    height: 23px !important;
    fill: none !important;
    stroke: currentColor !important;
    stroke-width: 1.75 !important;
    stroke-linecap: round !important;
    stroke-linejoin: round !important;
}
.pj-saved-helper > span {
    font-family: Georgia, serif !important;
    font-style: italic !important;
    font-size: 10px !important;
}
.pj-saved-card--feed .pj-saved-remove span,
.pj-saved-card--feed .pj-save-heart span {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    height: 100% !important;
}
.pj-saved-card--feed .pj-saved-remove svg,
.pj-saved-card--feed .pj-save-heart svg {
    width: 18px !important;
    height: 18px !important;
    display: block !important;
    fill: currentColor !important;
    stroke: none !important;
}
.pj-saved-card--feed .pj-saved-card-actions a::before {
    content: "";
    display: inline-block;
    flex: 0 0 auto;
    width: 13px;
    height: 13px;
    margin-right: 4px;
    background: currentColor;
    opacity: .95;
    vertical-align: -2px;
}
.pj-saved-card--feed .pj-saved-open::before {
    clip-path: polygon(20% 12%, 88% 12%, 88% 80%, 73% 80%, 73% 37%, 28% 82%, 18% 72%, 63% 27%, 20% 27%);
}
.pj-saved-card--feed .pj-saved-calendar::before {
    clip-path: path('M2 4 H11 V12 H2 Z M3 6 V11 H10 V6 Z M4 1 H5 V3 H8 V1 H9 V3 H11 V5 H2 V3 H4 Z');
}
.pj-saved-card--feed .pj-saved-maps::before {
    clip-path: path('M6.5 1 C3.6 1 1.5 3.1 1.5 5.8 C1.5 9.5 6.5 13 6.5 13 C6.5 13 11.5 9.5 11.5 5.8 C11.5 3.1 9.4 1 6.5 1 Z M6.5 4 C7.6 4 8.4 4.8 8.4 5.8 C8.4 6.8 7.6 7.6 6.5 7.6 C5.4 7.6 4.6 6.8 4.6 5.8 C4.6 4.8 5.4 4 6.5 4 Z');
}
.pj-saved-card--event .pj-saved-card-meta span {
    position: relative !important;
    padding-left: 17px !important;
}
.pj-saved-card--event .pj-saved-card-meta span::before {
    content: "";
    position: absolute;
    left: 0;
    top: 1px;
    width: 12px;
    height: 12px;
    background: #a6422e;
    opacity: .82;
}
.pj-saved-card--event .pj-saved-card-meta span:nth-child(1)::before {
    clip-path: path('M2 4 H10 V11 H2 Z M3 6 V10 H9 V6 Z M3 1 H4 V3 H8 V1 H9 V3 H10 V5 H2 V3 H3 Z');
}
.pj-saved-card--event .pj-saved-card-meta span:nth-child(2)::before,
.pj-saved-card--event .pj-saved-card-meta span:nth-child(3)::before {
    clip-path: path('M6 1 C3.7 1 2 2.8 2 5 C2 8 6 11 6 11 C6 11 10 8 10 5 C10 2.8 8.3 1 6 1 Z M6 3.5 C6.9 3.5 7.5 4.1 7.5 5 C7.5 5.9 6.9 6.5 6 6.5 C5.1 6.5 4.5 5.9 4.5 5 C4.5 4.1 5.1 3.5 6 3.5 Z');
}
@supports not (clip-path: path('M0 0')) {
    .pj-saved-card--feed .pj-saved-card-actions a::before,
    .pj-saved-card--event .pj-saved-card-meta span::before { display: none !important; }
    .pj-saved-card--event .pj-saved-card-meta span { padding-left: 0 !important; }
}


/* PJ 1.5.35: center Saved hero to match mockup. */
.pj-saved-header {
    text-align: center !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}
.pj-saved-header .pj-section-kicker,
.pj-saved-header .pj-archive-title,
.pj-saved-header .pj-archive-subtitle {
    text-align: center !important;
}
.pj-saved-header .pj-section-kicker {
    width: 100% !important;
}
.pj-saved-header .pj-archive-title {
    margin-left: auto !important;
    margin-right: auto !important;
}
.pj-saved-header .pj-archive-subtitle {
    max-width: 360px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}
@media (max-width: 560px) {
    .pj-saved-header .pj-archive-subtitle {
        max-width: 330px !important;
    }
}


/* PJ 1.5.36: exact SVG icons in saved-card action pills. */
.pj-saved-card--feed .pj-saved-card-actions a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 4px !important;
}
.pj-saved-card--feed .pj-saved-card-actions a::before {
    display: none !important;
    content: none !important;
}
.pj-saved-card--feed .pj-saved-card-actions a svg {
    display: block !important;
    width: 13px !important;
    height: 13px !important;
    flex: 0 0 auto !important;
    fill: none !important;
    stroke: currentColor !important;
    stroke-width: 2.1 !important;
    stroke-linecap: round !important;
    stroke-linejoin: round !important;
}
.pj-saved-card--feed .pj-saved-card-actions a span {
    display: inline-block !important;
    min-width: 0 !important;
}
.pj-saved-header {
    text-align: center !important;
}
.pj-saved-actions,
.pj-saved-plan,
.pj-saved-helper,
.pj-saved-clear-link,
.pj-saved-filters,
.pj-saved-list {
    margin-left: auto !important;
    margin-right: auto !important;
}


/* PJ 1.5.37: locked mockup geometry for /saved/. */
body { background: #fbf4ea !important; }
.pj-sticky-header { background: #fbf4ea !important; box-shadow: none !important; }
.pj-site-header { padding: 10px 18px 12px !important; background: #fbf4ea !important; border: 0 !important; }
.pj-site-bar { width: min(390px, calc(100vw - 36px)) !important; max-width: 390px !important; grid-template-columns: 38px minmax(0, 1fr) 38px !important; }
.pj-site-title { font-size: 27px !important; line-height: .98 !important; letter-spacing: -.72px !important; }
.pj-site-subtitle { margin-top: 5px !important; font-size: 9.5px !important; letter-spacing: .155em !important; color: #b14b35 !important; }
.pj-top-nav { width: 270px !important; max-width: calc(100vw - 92px) !important; height: 43px !important; margin-top: 14px !important; padding: 5px !important; background: #eee3d5 !important; border: 0 !important; border-radius: 999px !important; }
.pj-top-nav a { height: 33px !important; min-height: 33px !important; font-size: 13px !important; font-weight: 900 !important; }
.pj-top-nav a.active { background: #fff !important; color: #15120f !important; box-shadow: 0 4px 12px rgba(58,39,22,.10) !important; }
.pj-saved-page { width: min(390px, calc(100vw - 40px)) !important; max-width: 390px !important; padding-left: 0 !important; padding-right: 0 !important; margin: 0 auto !important; }
.pj-saved-header { padding: 22px 0 12px !important; text-align: center !important; }
.pj-saved-header .pj-section-kicker { margin: 0 0 8px !important; color: #b14b35 !important; font-size: 10.5px !important; font-weight: 950 !important; letter-spacing: .16em !important; text-align: center !important; }
.pj-saved-header .pj-archive-title { margin: 0 auto !important; color: #15120f !important; font-size: 36px !important; font-weight: 760 !important; line-height: 1.02 !important; letter-spacing: -.82px !important; text-align: center !important; }
.pj-saved-header .pj-archive-subtitle { max-width: 340px !important; margin: 12px auto 0 !important; color: #4e443d !important; font-size: 15px !important; line-height: 1.5 !important; text-align: center !important; }
.pj-saved-shell { margin-top: 8px !important; }
.pj-saved-actions { width: 100% !important; display: grid !important; grid-template-columns: repeat(4, minmax(0, 1fr)) !important; gap: 8px !important; margin: 0 auto 16px !important; }
.pj-saved-actions button { height: 40px !important; min-height: 40px !important; padding: 0 6px !important; border: 1px solid rgba(139,87,52,.14) !important; border-radius: 999px !important; background: #fffdf8 !important; color: #332923 !important; font-size: 10.4px !important; font-weight: 900 !important; box-shadow: 0 6px 15px rgba(68,45,24,.055) !important; }
.pj-saved-action-icon svg { width: 15px !important; height: 15px !important; }
.pj-saved-plan { width: 100% !important; min-height: 122px !important; margin: 0 auto 14px !important; padding: 14px !important; display: grid !important; grid-template-columns: minmax(0, 1fr) 90px !important; gap: 12px !important; border-radius: 26px !important; border: 1px solid rgba(169,76,45,.14) !important; background: linear-gradient(145deg, #fffaf2 0%, #fffefd 56%, #f6e7d6 100%) !important; box-shadow: 0 18px 38px rgba(62,41,22,.12) !important; }
.pj-saved-plan-mark { width: 48px !important; height: 48px !important; border-radius: 50% !important; background: #f4e3d1 !important; }
.pj-saved-plan .pj-saved-plan-label { color: #b14b35 !important; font-size: 10px !important; letter-spacing: .16em !important; }
.pj-saved-plan strong { font-size: 18.5px !important; line-height: 1.12 !important; }
.pj-saved-plan-next { font-size: 13px !important; line-height: 1.22 !important; }
.pj-saved-plan-time { font-size: 12px !important; }
.pj-saved-plan-note { display: inline-flex !important; width: fit-content !important; margin-top: 1px !important; padding: 7px 10px !important; border-radius: 999px !important; border: 1px solid rgba(80,56,35,.07) !important; background: rgba(255,255,255,.72) !important; color: #716357 !important; font-size: 11.5px !important; }
.pj-saved-plan .pj-saved-sort-box { width: 90px !important; min-width: 90px !important; min-height: 90px !important; border-radius: 23px !important; }
.pj-saved-helper { max-width: 350px !important; margin: 3px auto 8px !important; font-size: 12px !important; color: #6f6257 !important; }
.pj-saved-clear-link { margin: 0 auto 14px !important; color: #a6422e !important; }
.pj-saved-filters { width: 100% !important; margin: 0 auto 16px !important; grid-template-columns: repeat(3, minmax(0, 1fr)) !important; gap: 9px !important; }
.pj-saved-filters button { height: 40px !important; min-height: 40px !important; border-radius: 999px !important; font-size: 13px !important; }
.pj-saved-filters button.is-active { background: #ad4b31 !important; border-color: #ad4b31 !important; color: #fff !important; }
.pj-saved-card--feed { width: 100% !important; margin-left: auto !important; margin-right: auto !important; border-radius: 24px !important; }
@media (max-width: 390px) {
    .pj-saved-page { width: calc(100vw - 32px) !important; }
    .pj-saved-actions { gap: 6px !important; }
    .pj-saved-actions button { font-size: 9.8px !important; }
    .pj-top-nav { max-width: calc(100vw - 76px) !important; }
    .pj-saved-plan { grid-template-columns: minmax(0, 1fr) 84px !important; gap: 9px !important; padding: 12px !important; }
    .pj-saved-plan .pj-saved-sort-box { width: 84px !important; min-width: 84px !important; }
}


/* PJ 1.5.38: circled mockup details — action bubbles + Plan card text hierarchy. */
.pj-saved-actions button {
    gap: 4px !important;
    height: 38px !important;
    min-height: 38px !important;
    padding: 0 7px !important;
    font-size: 10.8px !important;
    font-weight: 850 !important;
    letter-spacing: -.01em !important;
    color: #2f2822 !important;
    border-color: rgba(142, 96, 65, .18) !important;
    background: #fffdf8 !important;
}
.pj-saved-action-icon,
.pj-saved-action-icon svg {
    width: 14px !important;
    height: 14px !important;
}
.pj-saved-action-icon svg {
    stroke: #b14b35 !important;
    stroke-width: 1.9 !important;
}
.pj-saved-action-icon--share svg circle {
    fill: #b14b35 !important;
}
.pj-saved-plan-copy {
    text-align: left !important;
}
.pj-saved-plan .pj-saved-plan-label {
    margin-bottom: 5px !important;
    color: #b14b35 !important;
    font-family: var(--font-sans) !important;
    font-size: 9.8px !important;
    font-weight: 950 !important;
    letter-spacing: .155em !important;
    line-height: 1 !important;
}
.pj-saved-plan strong[data-pj-saved-plan-summary] {
    font-family: var(--font-sans) !important;
    color: #201915 !important;
    font-size: 13.5px !important;
    font-weight: 850 !important;
    line-height: 1.22 !important;
    letter-spacing: -.01em !important;
}
.pj-saved-plan-next {
    margin-top: 4px !important;
    font-family: var(--font-sans) !important;
    color: #1d1713 !important;
    font-size: 13px !important;
    font-weight: 900 !important;
    line-height: 1.22 !important;
    letter-spacing: -.01em !important;
}
.pj-saved-plan-time {
    margin-top: 2px !important;
    font-family: var(--font-sans) !important;
    color: #76695e !important;
    font-size: 12px !important;
    font-weight: 750 !important;
    line-height: 1.25 !important;
}
.pj-saved-plan-note {
    margin-top: 8px !important;
    padding: 6px 9px !important;
    color: #716357 !important;
    font-size: 11.3px !important;
    font-weight: 800 !important;
    line-height: 1.15 !important;
}
.pj-saved-plan-mark svg {
    width: 24px !important;
    height: 24px !important;
    stroke-width: 1.9 !important;
}
.pj-saved-plan .pj-saved-sort-box span:not(.pj-saved-sort-icon),
.pj-saved-plan button[data-pj-saved-sort] span:not(.pj-saved-sort-icon) {
    font-size: 11.2px !important;
    font-weight: 900 !important;
    line-height: 1.05 !important;
}
.pj-saved-plan .pj-saved-sort-box small,
.pj-saved-plan button[data-pj-saved-sort] small {
    margin-top: 1px !important;
    font-size: 8.5px !important;
    font-weight: 950 !important;
    letter-spacing: .08em !important;
}


/* PJ 1.5.39: red-circled action bubbles + underlined Clear saved list. */
.pj-saved-actions {
    gap: 8px !important;
}
.pj-saved-actions button {
    height: 39px !important;
    min-height: 39px !important;
    padding: 0 8px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 5px !important;
    border: 1px solid rgba(126, 93, 68, .18) !important;
    border-radius: 999px !important;
    background: #fffdfa !important;
    color: #342b25 !important;
    box-shadow: 0 6px 14px rgba(72, 50, 31, .045) !important;
    font-size: 10.8px !important;
    font-weight: 850 !important;
    line-height: 1 !important;
    letter-spacing: -.015em !important;
    white-space: nowrap !important;
}
.pj-saved-action-icon {
    width: 14px !important;
    height: 14px !important;
    color: #aa4631 !important;
    margin-top: -1px !important;
}
.pj-saved-action-icon svg {
    width: 14px !important;
    height: 14px !important;
    stroke: #aa4631 !important;
    stroke-width: 1.85 !important;
    stroke-linecap: round !important;
    stroke-linejoin: round !important;
}
.pj-saved-action-icon--share svg circle {
    fill: #aa4631 !important;
    stroke: none !important;
}
.pj-saved-action-icon--share svg path {
    stroke: #aa4631 !important;
    stroke-width: 1.65 !important;
}
.pj-saved-action-icon--text svg path,
.pj-saved-action-icon--email svg rect,
.pj-saved-action-icon--email svg path,
.pj-saved-action-icon--copy svg path {
    fill: none !important;
}
.pj-saved-clear-link,
button.pj-saved-clear-link[data-pj-saved-clear] {
    display: block !important;
    width: max-content !important;
    margin: 0 auto 14px !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    color: #a6422e !important;
    font-size: 13px !important;
    font-weight: 800 !important;
    text-decoration: underline !important;
    text-decoration-thickness: 1px !important;
    text-underline-offset: 3px !important;
    cursor: pointer !important;
}
.pj-saved-clear-link[hidden],
button.pj-saved-clear-link[data-pj-saved-clear][hidden] {
    display: none !important;
}

.pj-saved-clear-link:hover,
.pj-saved-clear-link:focus {
    color: #883523 !important;
    text-decoration-color: currentColor !important;
}
@media (max-width: 390px) {
    .pj-saved-actions { gap: 6px !important; }
    .pj-saved-actions button { padding-left: 5px !important; padding-right: 5px !important; font-size: 10px !important; }
    .pj-saved-action-icon, .pj-saved-action-icon svg { width: 13px !important; height: 13px !important; }
}


/* PJ 1.5.40: canonical line-icon set for mockup bubbles. */
.pj-saved-action-icon svg,
.pj-saved-plan-mark svg,
.pj-saved-plan .pj-saved-sort-icon svg {
    fill: none !important;
    stroke: currentColor !important;
    stroke-linecap: round !important;
    stroke-linejoin: round !important;
}
.pj-saved-action-icon svg {
    width: 15px !important;
    height: 15px !important;
    stroke-width: 2 !important;
    color: #aa4631 !important;
}
.pj-saved-action-icon--share svg circle {
    fill: none !important;
    stroke: currentColor !important;
    stroke-width: 2 !important;
}
.pj-saved-action-icon--share svg line {
    stroke: currentColor !important;
    stroke-width: 2 !important;
}
.pj-saved-action-icon--email svg path,
.pj-saved-action-icon--email svg polyline,
.pj-saved-action-icon--copy svg path,
.pj-saved-action-icon--text svg path {
    fill: none !important;
    stroke: currentColor !important;
}
.pj-saved-plan-mark svg {
    width: 25px !important;
    height: 25px !important;
    stroke-width: 1.9 !important;
    color: #a9442f !important;
}
.pj-saved-plan-mark svg rect,
.pj-saved-plan-mark svg path {
    fill: none !important;
    stroke: currentColor !important;
}


/* PJ 1.5.41: Plan card exact left sparkle icon + distinct Day order icon. */
.pj-saved-plan-mark {
    overflow: visible !important;
}
.pj-saved-plan-mark::before,
.pj-saved-plan-mark::after {
    content: none !important;
    display: none !important;
}
.pj-saved-plan-mark .pj-saved-plan-clipboard {
    display: block !important;
    width: 25px !important;
    height: 25px !important;
    fill: none !important;
    stroke: #a9442f !important;
    stroke-width: 1.9 !important;
    stroke-linecap: round !important;
    stroke-linejoin: round !important;
}
.pj-saved-plan-spark {
    position: absolute !important;
    display: block !important;
    fill: #c9895e !important;
    stroke: none !important;
    pointer-events: none !important;
}
.pj-saved-plan-spark--one {
    width: 11px !important;
    height: 11px !important;
    right: -5px !important;
    top: 3px !important;
}
.pj-saved-plan-spark--two {
    width: 8px !important;
    height: 8px !important;
    left: -4px !important;
    bottom: 7px !important;
    opacity: .92 !important;
}
.pj-saved-plan .pj-saved-sort-icon svg {
    width: 24px !important;
    height: 24px !important;
    fill: none !important;
    stroke: currentColor !important;
    stroke-width: 1.8 !important;
    stroke-linecap: round !important;
    stroke-linejoin: round !important;
}
.pj-saved-plan .pj-saved-sort-icon {
    background: #f4e3d1 !important;
    color: #a9442f !important;
}


/* PJ 1.5.42: restore original mockup-style Plan icons: warm circle, rust clipboard sparkles, rust day-order sort glyph. */
.pj-saved-plan-head {
    grid-template-columns: 44px minmax(0, 1fr) !important;
    gap: 12px !important;
}
.pj-saved-plan-mark {
    position: relative !important;
    width: 42px !important;
    height: 42px !important;
    min-width: 42px !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: visible !important;
    color: #a9442f !important;
    background: #f5e2cf !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.86), 0 7px 14px rgba(97,62,36,.08) !important;
}
.pj-saved-plan-mark .pj-saved-plan-clipboard {
    width: 24px !important;
    height: 24px !important;
    fill: none !important;
    stroke: #a9442f !important;
    stroke-width: 1.85 !important;
    stroke-linecap: round !important;
    stroke-linejoin: round !important;
}
.pj-saved-plan-mark .pj-saved-plan-clipboard path {
    fill: none !important;
    stroke: #a9442f !important;
}
.pj-saved-plan-spark {
    position: absolute !important;
    display: block !important;
    fill: #bc603e !important;
    stroke: none !important;
    color: #bc603e !important;
    pointer-events: none !important;
    filter: none !important;
}
.pj-saved-plan-spark path {
    fill: currentColor !important;
    stroke: none !important;
}
.pj-saved-plan-spark--one {
    width: 10px !important;
    height: 10px !important;
    top: 2px !important;
    right: 1px !important;
    opacity: .95 !important;
}
.pj-saved-plan-spark--two {
    width: 7px !important;
    height: 7px !important;
    left: 1px !important;
    bottom: 8px !important;
    opacity: .82 !important;
}
.pj-saved-plan .pj-saved-sort-box,
.pj-saved-plan button[data-pj-saved-sort] {
    border-color: rgba(126,93,68,.16) !important;
    background: #fffdfa !important;
    color: #9f3f2c !important;
    box-shadow: 0 8px 18px rgba(72,50,31,.07), inset 0 1px 0 rgba(255,255,255,.9) !important;
}
.pj-saved-plan .pj-saved-sort-icon,
.pj-saved-plan button[data-pj-saved-sort] .pj-saved-sort-icon {
    width: 28px !important;
    height: 28px !important;
    margin-bottom: 2px !important;
    border-radius: 0 !important;
    background: transparent !important;
    color: #a9442f !important;
    box-shadow: none !important;
}
.pj-saved-plan .pj-saved-sort-icon svg {
    width: 26px !important;
    height: 26px !important;
    fill: none !important;
    stroke: #a9442f !important;
    stroke-width: 1.85 !important;
    stroke-linecap: round !important;
    stroke-linejoin: round !important;
}
.pj-saved-plan .pj-saved-sort-icon svg path {
    fill: none !important;
    stroke: #a9442f !important;
}
.pj-saved-plan .pj-saved-sort-box span:not(.pj-saved-sort-icon),
.pj-saved-plan button[data-pj-saved-sort] span:not(.pj-saved-sort-icon) {
    color: #3b2d25 !important;
}
.pj-saved-plan .pj-saved-sort-box small,
.pj-saved-plan button[data-pj-saved-sort] small {
    color: #9f3f2c !important;
    opacity: .76 !important;
}
@media (max-width: 560px) {
    .pj-saved-plan-head {
        grid-template-columns: 42px minmax(0, 1fr) !important;
        gap: 10px !important;
    }
    .pj-saved-plan-mark {
        width: 40px !important;
        height: 40px !important;
        min-width: 40px !important;
    }
    .pj-saved-plan-mark .pj-saved-plan-clipboard {
        width: 23px !important;
        height: 23px !important;
    }
}


/* PJ 1.5.43: exact four-sparkle clipboard icon from original reference. */
.pj-saved-plan-mark {
    width: 43px !important;
    height: 43px !important;
    min-width: 43px !important;
    border-radius: 50% !important;
    background: #f5e1cd !important;
    color: #aa4631 !important;
    overflow: visible !important;
}
.pj-saved-plan-mark .pj-saved-plan-clipboard {
    width: 24px !important;
    height: 24px !important;
    stroke: #aa4631 !important;
    stroke-width: 1.85 !important;
}
.pj-saved-plan-mark .pj-saved-plan-clipboard path {
    fill: none !important;
    stroke: #aa4631 !important;
}
.pj-saved-plan-spark {
    position: absolute !important;
    display: block !important;
    fill: #aa4631 !important;
    stroke: none !important;
    color: #aa4631 !important;
    pointer-events: none !important;
}
.pj-saved-plan-spark path {
    fill: #aa4631 !important;
    stroke: none !important;
}
.pj-saved-plan-spark--tl {
    width: 7px !important;
    height: 7px !important;
    left: 6px !important;
    top: 8px !important;
    opacity: .88 !important;
}
.pj-saved-plan-spark--tr {
    width: 10px !important;
    height: 10px !important;
    right: 5px !important;
    top: 5px !important;
    opacity: .95 !important;
}
.pj-saved-plan-spark--bl {
    width: 6px !important;
    height: 6px !important;
    left: 8px !important;
    bottom: 8px !important;
    opacity: .78 !important;
}
.pj-saved-plan-spark--br {
    width: 7px !important;
    height: 7px !important;
    right: 7px !important;
    bottom: 7px !important;
    opacity: .82 !important;
}
@media (max-width: 560px) {
    .pj-saved-plan-mark {
        width: 42px !important;
        height: 42px !important;
        min-width: 42px !important;
    }
}


/* PJ 1.5.44: asset-board clipboard details: checklist lines + check, gold sparkles within peach circle. */
.pj-saved-plan-mark {
    width: 46px !important;
    height: 46px !important;
    min-width: 46px !important;
    border-radius: 50% !important;
    background: #f7e3cf !important;
    box-shadow: none !important;
}
.pj-saved-plan-mark .pj-saved-plan-clipboard {
    width: 25px !important;
    height: 25px !important;
    stroke: #a94731 !important;
    stroke-width: 1.75 !important;
    stroke-linecap: round !important;
    stroke-linejoin: round !important;
}
.pj-saved-plan-mark .pj-saved-plan-clipboard path {
    fill: none !important;
    stroke: #a94731 !important;
}
.pj-saved-plan-mark .pj-clip-line {
    stroke-width: 1.65 !important;
}
.pj-saved-plan-mark .pj-clip-check {
    stroke-width: 1.95 !important;
}
.pj-saved-plan-spark,
.pj-saved-plan-spark path {
    fill: #d99661 !important;
    stroke: none !important;
    color: #d99661 !important;
}
.pj-saved-plan-spark--tl {
    width: 6px !important;
    height: 6px !important;
    left: 8px !important;
    top: 10px !important;
    opacity: .9 !important;
}
.pj-saved-plan-spark--tr {
    width: 9px !important;
    height: 9px !important;
    right: 7px !important;
    top: 7px !important;
    opacity: .95 !important;
}
.pj-saved-plan-spark--bl {
    width: 5.5px !important;
    height: 5.5px !important;
    left: 10px !important;
    bottom: 10px !important;
    opacity: .78 !important;
}
.pj-saved-plan-spark--br {
    width: 6.5px !important;
    height: 6.5px !important;
    right: 9px !important;
    bottom: 9px !important;
    opacity: .85 !important;
}
@media (max-width: 560px) {
    .pj-saved-plan-head {
        grid-template-columns: 46px minmax(0, 1fr) !important;
    }
    .pj-saved-plan-mark {
        width: 44px !important;
        height: 44px !important;
        min-width: 44px !important;
    }
}


/* PJ 1.5.45: exact icon-board asset as one SVG, immune to older icon CSS overrides. */
.pj-saved-plan-head {
    grid-template-columns: 48px minmax(0, 1fr) !important;
    gap: 12px !important;
}
.pj-saved-plan-mark--asset {
    width: 48px !important;
    height: 48px !important;
    min-width: 48px !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: visible !important;
}
.pj-saved-plan-mark--asset::before,
.pj-saved-plan-mark--asset::after {
    content: none !important;
    display: none !important;
}
.pj-saved-plan-mark--asset .pj-saved-plan-asset {
    display: block !important;
    width: 48px !important;
    height: 48px !important;
    overflow: visible !important;
}
.pj-saved-plan-mark--asset .pj-plan-asset-bg {
    fill: #f6e2cf !important;
    stroke: none !important;
}
.pj-saved-plan-mark--asset .pj-plan-asset-spark {
    fill: #d89661 !important;
    stroke: none !important;
}
.pj-saved-plan-mark--asset .pj-plan-asset-clip,
.pj-saved-plan-mark--asset .pj-plan-asset-clip rect,
.pj-saved-plan-mark--asset .pj-plan-asset-clip path {
    fill: none !important;
    stroke: #a84631 !important;
    stroke-width: 2.25 !important;
    stroke-linecap: round !important;
    stroke-linejoin: round !important;
}
.pj-saved-plan-mark--asset .pj-plan-asset-clip path:last-child {
    stroke-width: 2.5 !important;
}
@media (max-width: 560px) {
    .pj-saved-plan-head {
        grid-template-columns: 46px minmax(0, 1fr) !important;
        gap: 10px !important;
    }
    .pj-saved-plan-mark--asset,
    .pj-saved-plan-mark--asset .pj-saved-plan-asset {
        width: 46px !important;
        height: 46px !important;
        min-width: 46px !important;
    }
}


/* PJ 1.5.46: match provided icon asset board for both featured assets. */
.pj-saved-plan-mark--asset,
.pj-saved-plan-mark--asset .pj-saved-plan-asset {
    width: 52px !important;
    height: 52px !important;
    min-width: 52px !important;
}
.pj-saved-plan-head {
    grid-template-columns: 52px minmax(0, 1fr) !important;
}
.pj-saved-plan-mark--asset .pj-plan-asset-bg {
    fill: #f5e3d2 !important;
}
.pj-saved-plan-mark--asset .pj-plan-asset-spark {
    fill: #d99a66 !important;
}
.pj-saved-plan-mark--asset .pj-plan-asset-clip,
.pj-saved-plan-mark--asset .pj-plan-asset-clip rect,
.pj-saved-plan-mark--asset .pj-plan-asset-clip path {
    stroke: #a74430 !important;
    stroke-width: 2.15 !important;
}
.pj-saved-plan .pj-saved-sort-box--asset,
.pj-saved-plan button[data-pj-saved-sort].pj-saved-sort-box--asset,
.pj-saved-plan button[data-pj-saved-sort] {
    width: 88px !important;
    min-width: 88px !important;
    min-height: 88px !important;
    padding: 10px 7px !important;
    border-radius: 18px !important;
    border: 1px solid rgba(153, 112, 78, .10) !important;
    background: #f7eadc !important;
    box-shadow: none !important;
    color: #2d241f !important;
    gap: 4px !important;
}
.pj-saved-plan .pj-saved-sort-box--asset .pj-saved-sort-icon,
.pj-saved-plan button[data-pj-saved-sort] .pj-saved-sort-icon {
    width: 31px !important;
    height: 31px !important;
    margin: 0 0 1px !important;
    padding: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    color: #a74430 !important;
    box-shadow: none !important;
}
.pj-saved-plan .pj-saved-sort-box--asset .pj-saved-sort-icon svg,
.pj-saved-plan button[data-pj-saved-sort] .pj-saved-sort-icon svg {
    width: 31px !important;
    height: 31px !important;
    fill: none !important;
    stroke: #a74430 !important;
    stroke-width: 2.25 !important;
    stroke-linecap: round !important;
    stroke-linejoin: round !important;
}
.pj-saved-plan .pj-saved-sort-box--asset span:not(.pj-saved-sort-icon),
.pj-saved-plan button[data-pj-saved-sort] span:not(.pj-saved-sort-icon) {
    color: #2b211d !important;
    font-size: 11.2px !important;
    font-weight: 850 !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
}
.pj-saved-plan .pj-saved-sort-box--asset small,
.pj-saved-plan button[data-pj-saved-sort] small {
    color: #8a7a70 !important;
    opacity: 1 !important;
    font-size: 8px !important;
    font-weight: 850 !important;
    letter-spacing: .075em !important;
    text-transform: uppercase !important;
}
.pj-saved-plan button[data-pj-saved-sort].is-active {
    background: #f7eadc !important;
    color: #2b211d !important;
    border-color: rgba(153, 112, 78, .10) !important;
    box-shadow: none !important;
}
.pj-saved-plan button[data-pj-saved-sort].is-active .pj-saved-sort-icon {
    background: transparent !important;
    color: #a74430 !important;
}
@media (max-width: 560px) {
    .pj-saved-plan {
        grid-template-columns: minmax(0,1fr) 88px !important;
    }
    .pj-saved-plan-head {
        grid-template-columns: 50px minmax(0, 1fr) !important;
    }
    .pj-saved-plan-mark--asset,
    .pj-saved-plan-mark--asset .pj-saved-plan-asset {
        width: 50px !important;
        height: 50px !important;
        min-width: 50px !important;
    }
}


/* PJ 1.5.47: reference image Plan icon — textured pale circle, one line + check, binder clip. */
.pj-saved-plan-mark--reference,
.pj-saved-plan-mark--reference .pj-saved-plan-asset {
    width: 52px !important;
    height: 52px !important;
    min-width: 52px !important;
}
.pj-saved-plan-mark--reference .pj-plan-asset-bg {
    fill: #f6e6d6 !important;
    stroke: none !important;
}
.pj-saved-plan-mark--reference .pj-plan-asset-grain {
    fill: rgba(143, 100, 70, .18) !important;
    mix-blend-mode: multiply !important;
    opacity: .28 !important;
    stroke: none !important;
}
.pj-saved-plan-mark--reference .pj-plan-asset-spark {
    fill: #dda16d !important;
    stroke: none !important;
}
.pj-saved-plan-mark--reference .pj-plan-asset-clip,
.pj-saved-plan-mark--reference .pj-plan-asset-clip path {
    fill: none !important;
    stroke: #a84631 !important;
    stroke-width: 2.35 !important;
    stroke-linecap: round !important;
    stroke-linejoin: round !important;
}
.pj-saved-plan-mark--reference .pj-plan-clip-top {
    stroke-width: 2.15 !important;
}
.pj-saved-plan-mark--reference .pj-plan-line {
    stroke-width: 2.2 !important;
}
.pj-saved-plan-mark--reference .pj-plan-check {
    stroke-width: 2.65 !important;
}
@media (max-width: 560px) {
    .pj-saved-plan-mark--reference,
    .pj-saved-plan-mark--reference .pj-saved-plan-asset {
        width: 50px !important;
        height: 50px !important;
        min-width: 50px !important;
    }
}


/* PJ 1.5.48: use the exact uploaded Plan icon PNG; no redraw/approximation. */
.pj-saved-plan-head {
    grid-template-columns: 54px minmax(0, 1fr) !important;
    gap: 12px !important;
}
.pj-saved-plan-mark--exact {
    width: 54px !important;
    height: 54px !important;
    min-width: 54px !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    color: inherit !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: visible !important;
}
.pj-saved-plan-mark--exact::before,
.pj-saved-plan-mark--exact::after {
    content: none !important;
    display: none !important;
}
.pj-saved-plan-mark--exact img {
    display: block !important;
    width: 54px !important;
    height: 54px !important;
    max-width: none !important;
    object-fit: contain !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}
@media (max-width: 560px) {
    .pj-saved-plan-head {
        grid-template-columns: 52px minmax(0, 1fr) !important;
        gap: 10px !important;
    }
    .pj-saved-plan-mark--exact,
    .pj-saved-plan-mark--exact img {
        width: 52px !important;
        height: 52px !important;
        min-width: 52px !important;
    }
}


/* PJ 1.5.49: use exact uploaded Day order / Smart sort PNG; no CSS/SVG recreation. */
.pj-saved-plan {
    grid-template-columns: minmax(0, 1fr) 86px !important;
    align-items: center !important;
}
.pj-saved-plan .pj-saved-sort-box--exact,
.pj-saved-plan button[data-pj-saved-sort].pj-saved-sort-box--exact,
.pj-saved-plan button[data-pj-saved-sort] {
    width: 86px !important;
    min-width: 86px !important;
    height: 130px !important;
    min-height: 130px !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: visible !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}
.pj-saved-plan .pj-saved-sort-box--exact img,
.pj-saved-plan button[data-pj-saved-sort] img {
    display: block !important;
    width: 86px !important;
    height: 130px !important;
    max-width: none !important;
    object-fit: contain !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}
.pj-saved-plan button[data-pj-saved-sort].is-active {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
}
@media (max-width: 560px) {
    .pj-saved-plan {
        grid-template-columns: minmax(0, 1fr) 82px !important;
    }
    .pj-saved-plan .pj-saved-sort-box--exact,
    .pj-saved-plan button[data-pj-saved-sort].pj-saved-sort-box--exact,
    .pj-saved-plan button[data-pj-saved-sort] {
        width: 82px !important;
        min-width: 82px !important;
        height: 124px !important;
        min-height: 124px !important;
    }
    .pj-saved-plan .pj-saved-sort-box--exact img,
    .pj-saved-plan button[data-pj-saved-sort] img {
        width: 82px !important;
        height: 124px !important;
    }
}


/* PJ 1.5.50: match mockup styling for the "Timed events first, then nearby ideas." pill. */
.pj-saved-plan-note {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: fit-content !important;
    max-width: 100% !important;
    margin: 8px 0 0 !important;
    padding: 6px 10px !important;
    border: 1px solid rgba(126, 93, 68, .10) !important;
    border-radius: 999px !important;
    background: rgba(255, 253, 250, .78) !important;
    box-shadow: none !important;
    font-family: var(--font-sans) !important;
    color: #74675d !important;
    font-size: 11.2px !important;
    font-weight: 760 !important;
    line-height: 1.1 !important;
    letter-spacing: -0.01em !important;
    white-space: nowrap !important;
}
@media (max-width: 390px) {
    .pj-saved-plan-note {
        padding: 6px 8px !important;
        font-size: 10.7px !important;
        white-space: normal !important;
        text-align: center !important;
    }
}


/* PJ 1.5.51: center the timed-events pill like the mockup. */
.pj-saved-plan-main {
    align-items: stretch !important;
}
.pj-saved-plan-note {
    margin: 8px auto 0 !important;
    align-self: center !important;
    text-align: center !important;
}


/* PJ 1.5.52: use exact uploaded Timed events pill PNG, centered. */
.pj-saved-plan-note--exact {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 8px auto 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    line-height: 0 !important;
    text-align: center !important;
}
.pj-saved-plan-note--exact img {
    display: block !important;
    width: min(224px, 100%) !important;
    height: auto !important;
    max-width: 224px !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    object-fit: contain !important;
}
@media (max-width: 390px) {
    .pj-saved-plan-note--exact img {
        width: min(208px, 100%) !important;
        max-width: 208px !important;
    }
}


/* PJ 1.5.53: center timed-events pill under the text block, not the icon+text group. */
.pj-saved-plan-note--exact {
    width: calc(100% - 64px) !important;
    max-width: calc(100% - 64px) !important;
    margin: 8px 0 0 64px !important;
    justify-content: center !important;
    align-self: stretch !important;
}
.pj-saved-plan-note--exact img {
    margin-left: auto !important;
    margin-right: auto !important;
}
@media (max-width: 560px) {
    .pj-saved-plan-note--exact {
        width: calc(100% - 60px) !important;
        max-width: calc(100% - 60px) !important;
        margin-left: 60px !important;
    }
}
@media (max-width: 390px) {
    .pj-saved-plan-note--exact {
        width: calc(100% - 56px) !important;
        max-width: calc(100% - 56px) !important;
        margin-left: 56px !important;
    }
}


/* PJ 1.5.54: make exact Day order / SMART SORT asset readable like mockup, not faded. */
.pj-saved-plan .pj-saved-sort-box--exact img,
.pj-saved-plan button[data-pj-saved-sort] img[src*="day-order-smart-sort-exact"] {
    opacity: 1 !important;
    filter: contrast(1.22) saturate(1.08) brightness(0.96) !important;
    -webkit-filter: contrast(1.22) saturate(1.08) brightness(0.96) !important;
}
.pj-saved-plan .pj-saved-sort-box--exact,
.pj-saved-plan button[data-pj-saved-sort].pj-saved-sort-box--exact,
.pj-saved-plan button[data-pj-saved-sort] {
    opacity: 1 !important;
}


/* PJ 1.5.55: Plan card spec — keep "Next:" event on ONE LINE with ellipsis. */
.pj-saved-plan-copy {
    min-width: 0 !important;
    overflow: hidden !important;
}
.pj-saved-plan-next {
    display: block !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    text-overflow: ellipsis !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    hyphens: none !important;
}
.pj-saved-plan-next[hidden] {
    display: none !important;
}




/* PJ 1.5.56: make the "Tap a saved card..." helper match mockup size and fit on one line. */
.pj-saved-helper {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 5px !important;
    width: 100% !important;
    max-width: none !important;
    margin: 4px auto 8px !important;
    padding: 0 !important;
    color: #6f6257 !important;
    font-family: var(--font-sans) !important;
    font-size: 10.8px !important;
    font-weight: 750 !important;
    line-height: 1.15 !important;
    letter-spacing: -0.02em !important;
    text-align: center !important;
    white-space: nowrap !important;
    overflow: visible !important;
}
.pj-saved-helper > span {
    width: 14px !important;
    height: 14px !important;
    min-width: 14px !important;
    border-width: 1.25px !important;
    font-size: 8.8px !important;
    line-height: 1 !important;
}
@media (max-width: 390px) {
    .pj-saved-helper {
        font-size: 10.2px !important;
        gap: 4px !important;
        letter-spacing: -0.035em !important;
    }
    .pj-saved-helper > span {
        width: 13px !important;
        height: 13px !important;
        min-width: 13px !important;
        font-size: 8px !important;
    }
}


/* PJ 1.5.57: match mockup font/size for "6 saved • 3 events • 3 places" summary line. */
.pj-saved-plan strong[data-pj-saved-plan-summary] {
    display: block !important;
    margin: 2px 0 0 !important;
    font-family: var(--font-sans) !important;
    color: #241d18 !important;
    font-size: 13px !important;
    font-weight: 800 !important;
    line-height: 1.18 !important;
    letter-spacing: -0.015em !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}
@media (max-width: 390px) {
    .pj-saved-plan strong[data-pj-saved-plan-summary] {
        font-size: 12.5px !important;
        letter-spacing: -0.02em !important;
    }
}


/* PJ 1.5.58: summary line should not be bold. */
.pj-saved-plan strong[data-pj-saved-plan-summary] {
    font-weight: 500 !important;
}


/* PJ 1.5.59: make right Day order / SMART SORT image slightly smaller to match reference. */
.pj-saved-plan {
    grid-template-columns: minmax(0, 1fr) 78px !important;
}
.pj-saved-plan .pj-saved-sort-box--exact,
.pj-saved-plan button[data-pj-saved-sort].pj-saved-sort-box--exact,
.pj-saved-plan button[data-pj-saved-sort] {
    width: 78px !important;
    min-width: 78px !important;
    height: 118px !important;
    min-height: 118px !important;
}
.pj-saved-plan .pj-saved-sort-box--exact img,
.pj-saved-plan button[data-pj-saved-sort] img[src*="day-order-smart-sort-exact"] {
    width: 78px !important;
    height: 118px !important;
    max-width: 78px !important;
}
@media (max-width: 560px) {
    .pj-saved-plan {
        grid-template-columns: minmax(0, 1fr) 76px !important;
    }
    .pj-saved-plan .pj-saved-sort-box--exact,
    .pj-saved-plan button[data-pj-saved-sort].pj-saved-sort-box--exact,
    .pj-saved-plan button[data-pj-saved-sort] {
        width: 76px !important;
        min-width: 76px !important;
        height: 115px !important;
        min-height: 115px !important;
    }
    .pj-saved-plan .pj-saved-sort-box--exact img,
    .pj-saved-plan button[data-pj-saved-sort] img[src*="day-order-smart-sort-exact"] {
        width: 76px !important;
        height: 115px !important;
        max-width: 76px !important;
    }
}


/* Petaluma Social conversion/pro polish — v1.5.60 */
.pj-header-conversion-row,
.pj-archive-conversion-row {
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  margin:8px auto 0;
  padding:0 12px;
  flex-wrap:wrap;
}
.pj-header-conversion-row { margin-top:7px; }
.pj-submit-event-cta,
.pj-weekly-email-link {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:8px 13px;
  border-radius:999px;
  text-decoration:none;
  font-family:'Inter',sans-serif;
  font-size:12px;
  font-weight:850;
  letter-spacing:.01em;
  border:1px solid rgba(176,96,48,.22);
  box-shadow:0 4px 12px rgba(78,45,24,.08);
}
.pj-submit-event-cta { background:#b85c35; color:#fff; border-color:#b85c35; }
.pj-weekly-email-link { background:#fffaf2; color:#6f3f28; }
.pj-newsletter-card {
  max-width:1040px;
  margin:14px auto 18px;
  padding:16px;
  border-radius:24px;
  border:1px solid rgba(176,96,48,.16);
  background:radial-gradient(circle at 12% 0%, rgba(255,224,177,.46), transparent 34%), linear-gradient(145deg,#fffbf5,#fff3df);
  box-shadow:0 10px 28px rgba(62,38,20,.08);
}
.pj-newsletter-kicker {
  display:block;
  margin-bottom:5px;
  color:#a24f2e;
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.12em;
}
.pj-newsletter-card h2 {
  margin:0 0 5px;
  font-family:'Playfair Display',serif;
  font-size:24px;
  line-height:1.08;
  color:#241a14;
}
.pj-newsletter-card p {
  margin:0;
  color:#5e5147;
  font-size:14px;
  line-height:1.4;
}
.pj-newsletter-form {
  display:grid;
  grid-template-columns:1fr auto;
  gap:8px;
  margin-top:13px;
}
.pj-newsletter-form input[type="email"] {
  min-width:0;
  height:44px;
  border-radius:999px;
  border:1px solid rgba(84,58,40,.18);
  background:#fff;
  padding:0 15px;
  font-size:14px;
  outline:none;
}
.pj-newsletter-form button {
  height:44px;
  border:0;
  border-radius:999px;
  background:#2f7d46;
  color:#fff;
  padding:0 16px;
  font-weight:900;
  box-shadow:0 6px 14px rgba(47,125,70,.18);
}
.pj-newsletter-message { margin-top:9px !important; font-weight:800; color:#2f7d46 !important; }
.pj-newsletter-message--error { color:#b42318 !important; }
.pj-home-section-note {
  margin:-4px 0 12px;
  color:#65574c;
  font-size:14px;
  line-height:1.4;
}
.pj-home-section--classes {
  position:relative;
  margin:6px 12px 24px;
  padding:18px 14px 22px;
  border:1px solid rgba(184,92,53,.18);
  border-radius:28px;
  background:
    radial-gradient(circle at 12% 0%, rgba(255,224,186,.72), transparent 34%),
    radial-gradient(circle at 88% 16%, rgba(255,244,214,.9), transparent 30%),
    linear-gradient(145deg,#fff8ee 0%,#fffefb 54%,#fdf4e7 100%);
  box-shadow:0 18px 44px rgba(95,62,38,.10);
  overflow:hidden;
}
.pj-home-section--classes::before {
  content:'✦';
  position:absolute;
  right:18px;
  top:8px;
  color:rgba(196,30,58,.18);
  font-size:44px;
  line-height:1;
  pointer-events:none;
}
.pj-home-section--classes .pj-home-section-head {
  position:relative;
  align-items:center;
}
.pj-home-section--classes .pj-home-section-head h2 {
  color:#4b2d1f;
}
.pj-home-section--classes .pj-home-section-head a {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:0 12px;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(196,30,58,.16);
  box-shadow:0 8px 18px rgba(95,62,38,.08);
}
.pj-home-section-chips {
  display:flex;
  flex-wrap:wrap;
  gap:7px;
  margin:-2px 0 14px;
}
.pj-home-section-chips span {
  border-radius:999px;
  padding:7px 10px;
  background:rgba(255,255,255,.76);
  border:1px solid rgba(155,91,54,.16);
  color:#7c4a2e;
  font-size:12px;
  font-weight:900;
  letter-spacing:.01em;
  box-shadow:0 6px 14px rgba(95,62,38,.05);
}
.pj-explore-detail-plan {
  background:linear-gradient(145deg,#fffaf1,#fff);
  border-color:rgba(184,92,53,.18);
}
.pj-explore-detail-plan ul {
  margin:0;
  padding:0;
  list-style:none;
  display:grid;
  gap:8px;
}
.pj-explore-detail-plan li {
  position:relative;
  padding-left:18px;
  color:#3f372f;
  font-size:14.5px;
  line-height:1.42;
}
.pj-explore-detail-plan li::before {
  content:'✓';
  position:absolute;
  left:0;
  top:0;
  color:#2f7d46;
  font-weight:900;
}
.pj-explore-detail-location {
  border-color:rgba(47,125,70,.16);
  background:#f8fcf6;
}
@media (min-width:720px) {
  .pj-newsletter-card {
    display:grid;
    grid-template-columns:minmax(0,1.25fr) minmax(280px,.75fr);
    align-items:center;
    gap:18px;
    padding:18px 20px;
  }
  .pj-newsletter-form { margin-top:0; }
}
@media (max-width:520px) {
  .pj-header-conversion-row { gap:6px; }
  .pj-submit-event-cta,
  .pj-weekly-email-link { min-height:31px; padding:7px 10px; font-size:11px; }
  .pj-newsletter-card { margin-left:12px; margin-right:12px; padding:14px; }
  .pj-newsletter-card h2 { font-size:22px; }
  .pj-newsletter-form { grid-template-columns:1fr; }
  .pj-newsletter-form button { width:100%; }
}



/* ── More Filters panel: divider and date picker layout ───── */
.pj-more-filters-divider {
    width: 100%;
    margin: 12px 0 8px;
    padding-top: 10px;
    border-top: 1px solid var(--pj-gray-300);
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--pj-gray-500);
}
.pj-date-form-wrapper {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    margin: 4px 0 8px;
}
.pj-date-form-wrapper .pj-date-picker-shell {
    position: relative;
    display: inline-block;
}
.pj-date-form-wrapper .pj-calendar-panel {
    position: fixed;
    left: 50%;
    top: 48%;
    transform: translate(-50%, -50%);
    z-index: 2000;
    background: var(--pj-white);
    border: 1px solid var(--pj-gray-300);
    border-radius: 14px;
    padding: 12px;
    box-shadow: 0 8px 24px rgba(0,0,0,.12);
    min-width: 280px;
    max-width: 360px;
    width: min(92vw, 360px);
}
.pj-date-form-wrapper .pj-date-reset--inline {
    font-size: 12px;
    color: var(--pj-red);
    text-decoration: none;
    padding: 4px 8px;
    border-radius: 8px;
}
.pj-date-form-wrapper .pj-date-reset--inline:hover {
    background: var(--pj-red-light);
}

/* ── Explore detail: Add to Calendar date picker ───────────── */
.pj-explore-calendar-wrap {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    margin-top: 10px;
    width: 100%;
}
.pj-explore-calendar-label {
    font-size: 13px;
    font-weight: 500;
    color: #6b4f3a;
    letter-spacing: 0.02em;
}
.pj-explore-calendar-date {
    appearance: none;
    -webkit-appearance: none;
    background: #fff;
    border: 1.5px solid #e0d5c8;
    border-radius: 10px;
    padding: 8px 12px;
    font-size: 14px;
    font-family: inherit;
    color: #3d2b1f;
    min-width: 140px;
    cursor: pointer;
}
.pj-explore-calendar-date:focus {
    outline: none;
    border-color: #c45c3e;
    box-shadow: 0 0 0 3px rgba(196, 92, 62, 0.12);
}
.pj-detail-btn--calendar {
    background: #c45c3e;
    color: #fff;
    border: none;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.pj-detail-btn--calendar::before {
    content: "";
    display: inline-block;
    width: 16px;
    height: 16px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E");
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
}
.pj-detail-btn--calendar.is-disabled {
    opacity: 0.5;
    pointer-events: none;
    cursor: not-allowed;
}
@media (max-width: 480px) {
    .pj-explore-calendar-wrap {
        gap: 6px;
    }
    .pj-explore-calendar-date {
        min-width: 120px;
        padding: 7px 10px;
        font-size: 13px;
    }
    .pj-detail-btn--calendar {
        padding: 8px 14px;
        font-size: 13px;
    }
}

/* ── Explore card: inline Add to Calendar ──────────────────── */
.pj-explore-card-calendar {
    position: absolute;
    right: 14px;
    bottom: 58px;
    z-index: 10;
}
.pj-explore-card-calendar-toggle {
    appearance: none;
    -webkit-appearance: none;
    background: rgba(255,255,255,0.96);
    border: 1.5px solid rgba(196,92,62,0.25);
    border-radius: 8px;
    padding: 5px 9px;
    font-size: 11px;
    font-weight: 600;
    font-family: inherit;
    color: #c45c3e;
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    line-height: 1.2;
    white-space: nowrap;
}
.pj-explore-card-calendar-toggle:active {
    transform: scale(0.97);
}
.pj-explore-card-calendar-panel {
    display: none;
    position: absolute;
    right: 0;
    bottom: calc(100% + 6px);
    background: #fff;
    border: 1.5px solid #e0d5c8;
    border-radius: 12px;
    padding: 10px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.12);
    gap: 8px;
    align-items: center;
    min-width: 190px;
}
.pj-explore-card-calendar-panel.is-open {
    display: flex;
}
.pj-explore-card-calendar-date {
    appearance: none;
    -webkit-appearance: none;
    background: #faf8f5;
    border: 1.5px solid #e0d5c8;
    border-radius: 8px;
    padding: 6px 8px;
    font-size: 13px;
    font-family: inherit;
    color: #3d2b1f;
    flex: 1 1 auto;
    min-width: 0;
}
.pj-explore-card-calendar-date:focus {
    outline: none;
    border-color: #c45c3e;
    box-shadow: 0 0 0 2px rgba(196,92,62,0.12);
}
.pj-explore-card-calendar-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #c45c3e;
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: 6px 12px;
    font-size: 12px;
    font-weight: 600;
    font-family: inherit;
    text-decoration: none;
    cursor: pointer;
    flex-shrink: 0;
    white-space: nowrap;
}
.pj-explore-card-calendar-btn.is-disabled {
    opacity: 0.45;
    pointer-events: none;
}
@media (max-width: 480px) {
    .pj-explore-card-calendar {
        right: 12px;
        bottom: 56px;
    }
    .pj-explore-card-calendar-toggle {
        padding: 4px 7px;
        font-size: 10.5px;
        border-radius: 7px;
    }
    .pj-explore-card-calendar-panel {
        padding: 8px;
        min-width: 170px;
        border-radius: 10px;
    }
    .pj-explore-card-calendar-date {
        padding: 5px 6px;
        font-size: 12px;
    }
    .pj-explore-card-calendar-btn {
        padding: 5px 10px;
        font-size: 11px;
    }
}

/* PJ 1.5.88: cleaner home/search/explore polish */
.pj-top-nav {
    gap: 6px;
}
.pj-top-nav a {
    padding-left: 11px;
    padding-right: 11px;
}
.pj-home-search-form {
    max-width: 640px;
    margin: 16px auto 2px;
    padding: 6px;
    background: rgba(255,255,255,.78);
    border: 1px solid rgba(196,30,58,.12);
    border-radius: 999px;
    box-shadow: 0 12px 30px rgba(31,41,55,.08);
}
.pj-home-quick-links {
    justify-content: center;
    flex-wrap: wrap;
    overflow: visible;
}
.pj-home-quick-links a {
    background: #fff8f1;
    border-color: rgba(159,63,32,.22);
    color: #8f3520;
    box-shadow: 0 5px 0 rgba(159,63,32,.09), 0 10px 22px rgba(31,41,55,.07);
}
/* Clean, non-wrapping primary nav labels */
.pj-nav-label-short { display: none; }
.pj-top-nav a,
.pj-top-nav a span {
    white-space: nowrap;
}
@media (max-width: 760px) {
    .pj-top-nav {
        width: min(100%, 360px);
        max-width: calc(100vw - 24px);
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 3px;
        overflow: hidden;
    }
    .pj-top-nav a {
        min-width: 0;
        padding: 8px 6px;
        overflow: hidden;
        font-size: 12px;
        line-height: 1;
        letter-spacing: -0.01em;
        text-overflow: ellipsis;
    }
    .pj-top-nav a span { overflow: hidden; text-overflow: ellipsis; }
    .pj-nav-label-full { display: none; }
    .pj-nav-label-short { display: inline; }
}
@media (max-width: 480px) {
    .pj-top-nav a { font-size: .78rem; padding: 8px 5px; }
    .pj-home-search-form { border-radius: 18px; }
    .pj-home-search-form input[type="search"] { min-width: 0; }
}

/* Explore mobile card polish: denser text, full-width copy, still photo-forward. */
.pj-event-card--explore .pj-event-body {
    padding-right: 13px;
}
.pj-event-card--explore .pj-anytime-meta-row {
    padding-right: 48px;
}
.pj-event-card--explore .pj-explore-why-go {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
@media (max-width: 760px) {
    .pj-event-card--explore .pj-event-image-wrap {
        aspect-ratio: 16 / 10;
    }
    .pj-event-card--explore .pj-event-body {
        padding: 10px 12px 11px;
    }
    .pj-event-card--explore .pj-event-title {
        font-size: 18px;
        line-height: 1.08;
        margin-bottom: 4px;
    }
    .pj-event-card--explore .pj-event-desc {
        -webkit-line-clamp: 2;
        font-size: 12.5px;
        line-height: 1.3;
        margin-bottom: 6px;
    }
    .pj-event-card--explore .pj-explore-why-go {
        margin-bottom: 6px;
        font-size: 12px;
        line-height: 1.3;
    }
    .pj-event-card--explore .pj-explore-best-for {
        gap: 4px;
        margin-bottom: 6px;
    }
    .pj-event-card--explore .pj-explore-best-for span,
    .pj-event-card--explore .pj-anytime-meta-row span {
        padding: 4px 6px;
        font-size: 10px;
    }
    .pj-event-card--explore .pj-explore-time-needed {
        margin-bottom: 6px;
        font-size: 11.5px;
    }
    .pj-event-card--explore .pj-anytime-meta-row {
        gap: 4px;
        margin-top: 6px;
        padding-right: 46px;
    }
}

/* PJ 1.5.104: small-phone bottom nav label protection */
@media (max-width: 390px), (max-height: 740px) {
    .pj-bottom-nav {
        padding-top: 5px;
        padding-bottom: calc(28px + env(safe-area-inset-bottom, 0px));
        min-height: calc(84px + env(safe-area-inset-bottom, 0px));
    }
    .pj-bottom-nav-is-dropped .pj-bottom-nav {
        padding-bottom: calc(28px + env(safe-area-inset-bottom, 0px));
        min-height: calc(84px + env(safe-area-inset-bottom, 0px));
    }
    .pj-bottom-nav a {
        min-height: 42px;
        gap: 2px;
        padding: 3px 2px;
        font-size: 9px;
        line-height: 1;
        letter-spacing: -0.02em;
        justify-content: flex-start;
    }
    .pj-nav-icon {
        width: 30px;
        height: 23px;
    }
    .pj-nav-icon svg {
        width: 18px;
        height: 18px;
    }
}

/* PJ 1.5.105: prevent narrow-phone event cards from being squeezed by price/action rail */
@media (max-width: 390px), (max-height: 740px) {
    .pj-event-card:not(.pj-event-card--explore) {
        position: relative;
        display: flex;
        padding-bottom: 48px;
        min-height: 146px;
    }
    .pj-event-card:not(.pj-event-card--explore) .pj-card-link {
        flex: 1 1 100%;
        width: 100%;
        min-width: 0;
        padding-right: 0;
    }
    .pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap {
        width: 82px;
        height: 82px;
        flex: 0 0 82px;
    }
    .pj-event-card:not(.pj-event-card--explore) .pj-event-body {
        min-width: 0;
    }
    .pj-event-card:not(.pj-event-card--explore) .pj-event-header {
        min-width: 0;
        flex-wrap: wrap;
        justify-content: flex-start;
    }
    .pj-event-card:not(.pj-event-card--explore) .pj-event-status-badge {
        max-width: 92px;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }
    .pj-event-card:not(.pj-event-card--explore) .pj-event-title {
        font-size: 14.25px;
        line-height: 1.16;
        word-break: normal;
        overflow-wrap: normal;
        hyphens: none;
    }
    .pj-event-card:not(.pj-event-card--explore) .pj-event-desc {
        -webkit-line-clamp: 2;
        font-size: 11.75px;
        line-height: 1.26;
    }
    .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right {
        position: absolute;
        left: 104px;
        right: 10px;
        bottom: 10px;
        min-width: 0;
        padding: 0;
        display: grid;
        grid-template-columns: auto minmax(0, 1fr) auto auto;
        align-items: center;
        gap: 6px;
        text-align: left;
    }
    .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-time {
        font-size: 10.5px;
        white-space: nowrap;
    }
    .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-price {
        min-width: 0;
        max-width: 100%;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        font-size: 10.25px;
        line-height: 1.1;
        text-align: left;
    }
    .pj-event-card:not(.pj-event-card--explore) .pj-save-heart--event {
        position: static;
        width: 30px;
        height: 30px;
        font-size: 18px;
        flex: 0 0 auto;
    }
    .pj-event-card:not(.pj-event-card--explore) .pj-add-calendar-link {
        min-height: 28px;
        padding: 5px 7px;
        font-size: 9px;
        white-space: nowrap;
    }
}


/* ── Summer Camps guide page ───────────────────────────────── */
.pj-guide-page {
  max-width: 980px;
  margin: 0 auto;
  padding: 0 0 34px;
}
.pj-guide-hero {
  margin: 12px 14px 14px;
  padding: 28px 18px;
  text-align: center;
  border-radius: 28px;
  background: linear-gradient(145deg, #fff7e8 0%, #fff 58%, #f7fbef 100%);
  border: 1px solid rgba(196,30,58,.12);
  box-shadow: 0 16px 36px rgba(95,62,38,.08);
}
.pj-guide-hero h1 {
  margin: 2px 0 8px;
  font-family: var(--font-serif);
  font-size: clamp(34px, 8vw, 56px);
  line-height: .96;
  color: #38271f;
}
.pj-guide-hero p {
  max-width: 680px;
  margin: 0 auto;
  color: #6c5b4d;
  font-size: 16px;
  line-height: 1.48;
}
.pj-guide-actions {
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:9px;
  margin-top:18px;
}
.pj-guide-card,
.pj-guide-section {
  margin: 14px;
  padding: 18px;
  border-radius: 22px;
  background: rgba(255,255,255,.84);
  border: 1px solid rgba(120,83,58,.12);
  box-shadow: 0 10px 26px rgba(95,62,38,.06);
}
.pj-guide-card h2,
.pj-guide-section h2 {
  font-family: var(--font-serif);
  color:#3f2b22;
}
.pj-guide-checklist {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin: 12px 0;
}
.pj-guide-checklist span,
.pj-home-guide-link a {
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:8px 11px;
  background:#fff8ef;
  border:1px solid rgba(196,30,58,.14);
  color:#733f29;
  font-size:12px;
  font-weight:850;
  text-decoration:none;
}
.pj-guide-type-grid {
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap:12px;
}
.pj-guide-type-card,
.pj-guide-list-card {
  border-radius:18px;
  padding:14px;
  background:linear-gradient(145deg,#fffaf4,#fff);
  border:1px solid rgba(155,91,54,.13);
}
.pj-guide-type-card h3,
.pj-guide-list-card h3 {
  margin:0 0 6px;
  color:#432c22;
  font-size:17px;
}
.pj-guide-type-card p,
.pj-guide-list-card p {
  margin:0;
  color:#67584c;
  font-size:14px;
  line-height:1.42;
}
.pj-guide-list-card a {
  color:inherit;
  text-decoration:none;
}
.pj-home-guide-link {
  margin: -4px 0 14px;
}
.pj-home-guide-link a::after {
  content:'';
}
@media (max-width:520px) {
  .pj-guide-page { padding-bottom: 78px; }
  .pj-guide-hero { margin: 8px 10px 12px; padding: 22px 14px; }
  .pj-guide-card, .pj-guide-section { margin-left:10px; margin-right:10px; padding:14px; }
  .pj-guide-actions { flex-direction:column; }
  .pj-guide-actions a { width:100%; justify-content:center; }
}
.pj-guide-card-meta {
  display:inline-flex;
  width:fit-content;
  margin:10px 6px 0 0;
  padding:6px 9px;
  border-radius:999px;
  background:#fff4e7;
  border:1px solid rgba(196,30,58,.12);
  color:#7a442c;
  font-size:12px;
  font-weight:850;
}
.pj-camp-provider-grid {
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap:12px;
  margin-top:14px;
}
.pj-camp-provider-card a {
  display:flex;
  flex-direction:column;
  height:100%;
  min-height:230px;
  padding:16px;
  border-radius:20px;
  text-decoration:none;
  color:inherit;
  background:linear-gradient(150deg,#fffaf2 0%,#fff 58%,#f7fbef 100%);
  border:1px solid rgba(196,30,58,.13);
  box-shadow:0 10px 24px rgba(95,62,38,.06);
}
.pj-camp-provider-type {
  width:fit-content;
  margin-bottom:9px;
  padding:6px 9px;
  border-radius:999px;
  background:#fdf0df;
  color:#8b442a;
  font-size:11px;
  font-weight:900;
  letter-spacing:.03em;
  text-transform:uppercase;
}
.pj-camp-provider-card h3 {
  margin:0 0 7px;
  font-family:var(--font-serif);
  font-size:22px;
  line-height:1.05;
  color:#3d281f;
}
.pj-camp-provider-card p {
  margin:0 0 12px;
  color:#645348;
  font-size:14px;
  line-height:1.42;
}
.pj-camp-provider-chips {
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-top:auto;
}
.pj-camp-provider-chips span {
  padding:5px 8px;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(155,91,54,.14);
  color:#76503b;
  font-size:11px;
  font-weight:850;
}
.pj-camp-provider-cta {
  margin-top:12px;
  color:#b71934;
  font-size:13px;
  font-weight:900;
}
.pj-camp-booking-card ol {
  margin:10px 0 0;
  padding-left:22px;
  color:#4f4037;
}
.pj-camp-booking-card li {
  margin:8px 0;
  line-height:1.45;
}
@media (max-width:520px) {
  .pj-camp-provider-grid { grid-template-columns:1fr; }
  .pj-camp-provider-card a { min-height:0; }
}
.pj-camp-provider-image {
  margin: -8px -8px 14px;
  height: 190px;
  border-radius: 16px;
  overflow: hidden;
  background: #f6efe4;
  border: 1px solid rgba(155,91,54,.10);
}
.pj-camp-provider-image img {
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
}
@media (min-width:760px) {
  .pj-camp-provider-image { height: 220px; }
}

/* Sitewide polish pass — date/filter, Saved empty state, Explore cards, single-event planning. */
.pj-archive-header { margin-bottom: 12px !important; padding-bottom: 8px !important; }
.pj-event-filter-form { margin: 8px auto 12px !important; }
.pj-primary-filter-bar { margin-bottom: 8px !important; }
.pj-date-form { margin-top: 0 !important; }
.pj-calendar-panel[hidden],
.pj-date-popover[hidden],
.pj-date-select-panel[hidden],
.pj-saved-actions[hidden],
.pj-saved-plan[hidden],
.pj-saved-helper[hidden],
.pj-saved-clear-link[hidden],
button.pj-saved-clear-link[data-pj-saved-clear][hidden],
.pj-saved-filters[hidden],
.pj-saved-empty[hidden] { display: none !important; }
.pj-event-card--explore { padding-bottom: 10px !important; }
.pj-event-card--explore .pj-event-body { padding-right: 14px !important; padding-bottom: 8px !important; }
.pj-event-card--explore .pj-event-desc { -webkit-line-clamp: 2 !important; line-clamp: 2 !important; margin-bottom: 8px !important; }
.pj-event-card--explore .pj-anytime-meta-row { margin-top: 6px !important; }
.pj-explore-card-actions {
    display: flex;
    gap: 7px;
    flex-wrap: wrap;
    align-items: center;
    padding: 0 14px 8px;
}
.pj-explore-card-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    border: 1px solid rgba(47,111,62,0.18);
    border-radius: 999px;
    padding: 7px 9px;
    background: #fffaf2;
    color: #2f6f3e;
    font-size: 11px;
    font-weight: 850;
    line-height: 1;
    text-decoration: none;
}
.pj-explore-card-action--save {
    position: static !important;
    inset: auto !important;
    width: auto !important;
    height: auto !important;
    min-width: 0 !important;
    transform: none !important;
    box-shadow: none !important;
    cursor: pointer;
}
.pj-explore-card-action--save span { font-size: 14px; line-height: 1; }
.pj-explore-card-action--save em { font-style: normal; }
.pj-explore-card-action--save.is-saved { background: #b13d45; border-color: #b13d45; color: #fff; }
.pj-single-action-row { display: flex; flex-wrap: wrap; gap: 10px; margin: 14px 0 16px; }
.pj-single-action-row .pj-save-heart,
.pj-single-action-row a,
.pj-single-action-row button {
    position: static !important;
    width: auto !important;
    height: auto !important;
    min-height: 42px;
    transform: none !important;
    border-radius: 999px;
    padding: 10px 14px;
    font-weight: 850;
    text-decoration: none;
}
.pj-single-guide-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 10px;
    margin: 12px 0 18px;
}
.pj-single-guide-grid > div {
    border: 1px solid rgba(34,34,34,0.08);
    border-radius: 16px;
    background: #fffaf4;
    padding: 12px 13px;
}
.pj-single-guide-grid span {
    display: block;
    margin-bottom: 4px;
    color: #9b3f26;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .06em;
    text-transform: uppercase;
}
.pj-single-guide-grid p { margin: 0; color: #4f463d; font-size: 14px; line-height: 1.4; }
.pj-single-guide-grid a { color: #2f6f3e; font-weight: 850; }
.pj-home-hero { margin-bottom: 16px !important; }
.pj-home-quick-links { max-height: none; }
.pj-home-section { margin-top: 18px !important; }
.pj-home-section-note { margin-top: -4px !important; }
@media (max-width: 760px) {
    .pj-archive-header { padding-top: 14px !important; }
    .pj-explore-card-actions { padding-left: 12px; padding-right: 12px; gap: 6px; }
    .pj-explore-card-action { font-size: 10.5px; padding: 7px 8px; }
    .pj-single-guide-grid { grid-template-columns: 1fr; }
}
.pj-home-planning-tiles { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.pj-home-planning-tiles a { display: block; border: 1px solid rgba(47,111,62,.15); border-radius: 18px; background: #fffaf2; padding: 14px; text-decoration: none; color: inherit; box-shadow: 0 6px 16px rgba(0,0,0,.045); }
.pj-home-planning-tiles strong { display: block; font-family: var(--font-serif); font-size: 21px; line-height: 1.1; color: #2f6f3e; }
.pj-home-planning-tiles span { display: block; margin-top: 4px; color: #6f6257; font-size: 13px; line-height: 1.35; }
@media (max-width: 520px) { .pj-home-planning-tiles { grid-template-columns: 1fr; } }

/* Emergency fix: keep event date label icons compact on desktop too. */
.pj-section-label {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    min-height: 0 !important;
    height: auto !important;
}
.pj-section-label .pj-section-label-icon {
    width: 28px !important;
    height: 28px !important;
    flex: 0 0 28px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 999px;
    background: #f7eadc;
    color: #9b3f26;
}
.pj-section-label .pj-section-label-icon svg {
    display: block !important;
    width: 15px !important;
    height: 15px !important;
    max-width: 15px !important;
    max-height: 15px !important;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
}

/* Staging cleanup: Saved empty state must show only intro + empty card/actions. */
.pj-saved-shell[data-saved-count="0"] [data-pj-saved-actions],
.pj-saved-shell[data-saved-count="0"] [data-pj-saved-plan],
.pj-saved-shell[data-saved-count="0"] [data-pj-saved-helper],
.pj-saved-shell[data-saved-count="0"] [data-pj-saved-clear],
.pj-saved-shell[data-saved-count="0"] [data-pj-saved-filters],
.pj-saved-shell[data-saved-count="0"] [data-pj-saved-list] {
    display: none !important;
}
.pj-saved-shell[data-saved-count="0"] [data-pj-saved-empty] {
    display: grid !important;
}

/* Staging cleanup: Explore has one visible filter row and one More Filters action row. */
.pj-filter-stack--explore .pj-explore-filter-actions .pj-explore-more-filter-form {
    width: 100%;
}
.pj-filter-stack--explore .pj-explore-filter-actions .pj-filter-go--floating,
.pj-filter-stack--explore .pj-explore-filter-form.is-dirty .pj-explore-filter-actions .pj-filter-go--floating {
    display: none !important;
}
.pj-filter-stack--explore .pj-explore-filter-actions {
    justify-content: flex-start;
}
.pj-explore-newsletter-bottom {
    margin: 28px auto 0;
    max-width: 760px;
}

/* Staging cleanup: details panels must not occupy page space while closed. */
.pj-more-filters:not([open]) > .pj-more-filters-panel {
    display: none !important;
}

/* Staging polish 1.5.148: keep Explore sort visible but separate from More Filters. */
.pj-filter-stack--explore .pj-explore-filter-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}
.pj-filter-stack--explore .pj-explore-filter-actions .pj-explore-more-filter-form {
    width: auto;
    flex: 0 0 auto;
}
.pj-filter-stack--explore .pj-explore-sort-toggle {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    flex-wrap: nowrap;
    font-size: 12px;
    color: #6b6258;
}
.pj-filter-stack--explore .pj-explore-sort-toggle > span {
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .04em;
    font-size: 10px;
}


/* Staging polish 1.5.149: responsive nav text uses one DOM label; short labels are CSS-only on mobile. */
@media (max-width: 640px) {
  .pj-top-nav .pj-nav-label-responsive[data-short] {
    font-size: 0 !important;
    line-height: 1 !important;
  }
  .pj-top-nav .pj-nav-label-responsive[data-short]::after {
    content: attr(data-short);
    font-size: 13px !important;
    line-height: 1.15 !important;
  }
}

/* Staging polish 1.5.149: excerpts are server-trimmed to whole words; do not visually clip mid-word. */
.pj-event-desc,
.pj-event-card--explore .pj-event-desc,
.pj-event-card:not(.pj-event-card--explore) .pj-event-desc {
  display: block !important;
  -webkit-line-clamp: unset !important;
  line-clamp: unset !important;
  -webkit-box-orient: initial !important;
  max-height: none !important;
  min-height: 0 !important;
  overflow: visible !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
}

/* Staging polish 1.5.149: Explore sort is a single separate chip, not Recommended/A-Z pair. */
.pj-filter-stack--explore .pj-explore-sort-toggle .pj-sort-chip {
  white-space: nowrap;
}


/* PJ 1.5.150: global card component system for EventCard, ExploreCard, SavedCard, RelatedCard. */
:root {
  --pj-card-bg: #fffdf8;
  --pj-card-border: rgba(0,0,0,.08);
  --pj-card-shadow: 0 10px 24px rgba(58,37,22,.07);
  --pj-card-radius: 22px;
  --pj-card-pad-mobile: 16px;
  --pj-card-pad-desktop: 20px;
  --pj-card-gap: 12px;
  --pj-card-image-bg: #f3eee7;
}

/* One consistent, mobile-first card shell. */
.pj-event-card,
.pj-saved-card--feed,
.pj-related-card {
  box-sizing: border-box !important;
  position: relative !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 0 !important;
  margin: 0 16px 18px !important;
  padding: 0 !important;
  min-height: 0 !important;
  width: auto !important;
  max-width: 100% !important;
  border-radius: var(--pj-card-radius) !important;
  border: 1px solid var(--pj-card-border) !important;
  background: var(--pj-card-bg) !important;
  box-shadow: var(--pj-card-shadow) !important;
  overflow: hidden !important;
  color: inherit !important;
  text-decoration: none !important;
}
.pj-events-list .pj-event-card,
.pj-search-results .pj-event-card,
.pj-saved-group-grid .pj-saved-card--feed,
.pj-related-grid .pj-related-card {
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.pj-card-link,
.pj-saved-card-link,
.pj-related-card {
  box-sizing: border-box !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 0 !important;
  width: 100% !important;
  min-width: 0 !important;
  flex: 1 1 auto !important;
  color: inherit !important;
  text-decoration: none !important;
}

/* Fixed image frame: never stretch, never collapse. */
.pj-event-image-wrap,
.pj-saved-card-media,
.pj-related-card img {
  box-sizing: border-box !important;
  display: block !important;
  position: relative !important;
  width: 100% !important;
  height: auto !important;
  flex: 0 0 auto !important;
  aspect-ratio: 16 / 9 !important;
  overflow: hidden !important;
  border-radius: var(--pj-card-radius) var(--pj-card-radius) 0 0 !important;
  background: var(--pj-card-image-bg) !important;
}
.pj-event-image,
.pj-saved-card-media img,
.pj-related-card img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  display: block !important;
  object-fit: cover !important;
  object-position: center center !important;
  border-radius: 0 !important;
}
.pj-related-card img {
  position: relative !important;
}
.pj-event-image-wrap--placeholder,
.pj-event-image-wrap:has(.pj-event-image[src=""]),
.pj-event-image-wrap:has(.pj-event-image:not([src])),
.pj-saved-card-media:empty {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.pj-event-image-wrap--placeholder::before,
.pj-event-image-wrap:has(.pj-event-image[src=""])::before,
.pj-event-image-wrap:has(.pj-event-image:not([src]))::before,
.pj-saved-card-media:empty::before {
  content: "Petaluma Social" !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  height: 100% !important;
  font-family: var(--font-serif) !important;
  font-size: 18px !important;
  font-weight: 800 !important;
  color: #9a513d !important;
  background: linear-gradient(145deg,#fbefe2,#fffaf4) !important;
}
.pj-event-image[src=""],
.pj-event-image:not([src]) {
  display: none !important;
}

/* Shared content spacing. */
.pj-event-body,
.pj-saved-card-body,
.pj-related-card span {
  box-sizing: border-box !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
  gap: 8px !important;
  min-width: 0 !important;
  width: 100% !important;
  padding: var(--pj-card-pad-mobile) !important;
}
.pj-event-header,
.pj-saved-card-topline {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  flex-wrap: wrap !important;
  gap: 7px !important;
  margin: 0 !important;
  padding: 0 !important;
}
.pj-event-category,
.pj-event-status-badge,
.pj-saved-kind,
.pj-saved-plan-label,
.pj-explore-image-badge,
.pj-explore-card-number {
  white-space: nowrap !important;
  max-width: 100% !important;
}

/* Text clamps prevent uneven cards from long copy. */
.pj-event-title,
.pj-saved-card-title,
.pj-related-card span {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  white-space: normal !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
  margin: 0 !important;
}
.pj-event-desc,
.pj-explore-why-go,
.pj-saved-card-hint,
.pj-class-price-line,
.pj-explore-time-needed {
  display: -webkit-box !important;
  -webkit-line-clamp: 3 !important;
  line-clamp: 3 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  min-height: 0 !important;
  max-height: none !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
  margin: 0 !important;
}
.pj-event-footer,
.pj-anytime-meta-row,
.pj-explore-best-for,
.pj-saved-card-meta {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 7px !important;
  margin: 2px 0 0 !important;
  padding: 0 !important;
  min-width: 0 !important;
}
.pj-event-venue,
.pj-saved-card-meta span,
.pj-anytime-meta-row span,
.pj-explore-best-for span {
  min-width: 0 !important;
  max-width: 100% !important;
}

/* Shared action rows. */
.pj-event-meta-right,
.pj-explore-card-actions,
.pj-saved-card-actions,
.pj-single-action-row,
.pj-explore-detail-ctas {
  position: static !important;
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 8px !important;
  width: auto !important;
  max-width: none !important;
  min-width: 0 !important;
  margin: auto 0 0 !important;
  padding: 0 var(--pj-card-pad-mobile) var(--pj-card-pad-mobile) !important;
  transform: none !important;
  text-align: left !important;
}
.pj-event-meta-right > *,
.pj-explore-card-actions a,
.pj-explore-card-actions button,
.pj-saved-card-actions a,
.pj-saved-card-actions button,
.pj-single-action-row a,
.pj-single-action-row button,
.pj-explore-detail-ctas a,
.pj-explore-detail-ctas button {
  box-sizing: border-box !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 5px !important;
  min-height: 38px !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: 100% !important;
  border-radius: 999px !important;
  padding: 8px 12px !important;
  white-space: nowrap !important;
  font-size: 12px !important;
  font-weight: 850 !important;
  line-height: 1.1 !important;
}
.pj-event-meta-right .pj-event-time,
.pj-event-meta-right .pj-event-price {
  background: #fff7ed !important;
  border: 1px solid rgba(154,63,40,.12) !important;
  color: #5b4033 !important;
}
.pj-event-meta-right .pj-save-heart--event {
  width: 38px !important;
  min-width: 38px !important;
  padding: 0 !important;
}
.pj-add-calendar-link,
.pj-explore-card-actions a,
.pj-explore-card-actions button,
.pj-saved-card-actions a {
  border: 1px solid rgba(154,63,40,.14) !important;
  background: #fff6ed !important;
  color: #9a3f28 !important;
  box-shadow: none !important;
  text-decoration: none !important;
}
.pj-explore-card-action--save,
.pj-saved-open {
  background: #ad4b31 !important;
  border-color: #ad4b31 !important;
  color: #fff !important;
}

/* Saved cards use the same top-image layout and keep remove heart inside card. */
.pj-saved-card--feed .pj-saved-card-link,
.pj-saved-card--event .pj-saved-card-link {
  display: flex !important;
  grid-template-columns: none !important;
  flex-direction: column !important;
  padding: 0 !important;
  gap: 0 !important;
}
.pj-saved-card--feed .pj-saved-card-media,
.pj-saved-card--event .pj-saved-card-media,
.pj-saved-card--explore .pj-saved-card-media {
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 16 / 9 !important;
  align-self: stretch !important;
}
.pj-saved-card--feed .pj-saved-remove {
  top: 10px !important;
  right: 10px !important;
  bottom: auto !important;
  left: auto !important;
  z-index: 5 !important;
  width: 38px !important;
  height: 38px !important;
}
.pj-saved-card--feed .pj-saved-card-actions {
  display: flex !important;
  grid-auto-flow: initial !important;
  grid-auto-columns: initial !important;
  position: static !important;
  left: auto !important;
  right: auto !important;
  bottom: auto !important;
  padding: 0 var(--pj-card-pad-mobile) var(--pj-card-pad-mobile) !important;
}

/* Related cards align with the same card system. */
.pj-related-grid {
  gap: 14px !important;
}
.pj-related-card span {
  font-size: 14px !important;
  line-height: 1.25 !important;
}

/* Tablet/desktop: dated EventCards may go horizontal, but keep a fixed image frame. */
@media (min-width: 760px) {
  .pj-event-card:not(.pj-event-card--explore):not(.pj-home-best-card) {
    flex-direction: row !important;
    align-items: stretch !important;
  }
  .pj-event-card:not(.pj-event-card--explore):not(.pj-home-best-card) .pj-card-link {
    flex-direction: row !important;
    gap: 0 !important;
  }
  .pj-event-card:not(.pj-event-card--explore):not(.pj-home-best-card) .pj-event-image-wrap {
    width: 168px !important;
    max-width: 168px !important;
    height: auto !important;
    aspect-ratio: 4 / 3 !important;
    border-radius: var(--pj-card-radius) 0 0 var(--pj-card-radius) !important;
    align-self: stretch !important;
  }
  .pj-event-card:not(.pj-event-card--explore):not(.pj-home-best-card) .pj-event-body {
    padding: var(--pj-card-pad-desktop) !important;
  }
  .pj-event-card:not(.pj-event-card--explore):not(.pj-home-best-card) .pj-event-meta-right {
    flex: 0 0 148px !important;
    align-content: center !important;
    justify-content: center !important;
    padding: var(--pj-card-pad-desktop) !important;
    border-left: 1px solid rgba(0,0,0,.06) !important;
  }
  .pj-home-best-card .pj-event-body,
  .pj-event-card--explore .pj-event-body,
  .pj-saved-card-body,
  .pj-related-card span {
    padding: var(--pj-card-pad-desktop) !important;
  }
  .pj-home-best-card .pj-event-meta-right,
  .pj-event-card--explore .pj-explore-card-actions,
  .pj-saved-card--feed .pj-saved-card-actions {
    padding-left: var(--pj-card-pad-desktop) !important;
    padding-right: var(--pj-card-pad-desktop) !important;
    padding-bottom: var(--pj-card-pad-desktop) !important;
  }
}

@media (max-width: 430px) {
  .pj-event-card,
  .pj-saved-card--feed,
  .pj-related-card {
    margin-bottom: 16px !important;
    border-radius: 20px !important;
  }
  .pj-event-body,
  .pj-saved-card-body,
  .pj-related-card span,
  .pj-event-meta-right,
  .pj-explore-card-actions,
  .pj-saved-card-actions {
    padding-left: 14px !important;
    padding-right: 14px !important;
  }
  .pj-event-meta-right > *,
  .pj-explore-card-actions a,
  .pj-explore-card-actions button,
  .pj-saved-card-actions a,
  .pj-saved-card-actions button {
    min-height: 36px !important;
    padding: 8px 10px !important;
    font-size: 11px !important;
  }
}

/* PJ 1.5.150 follow-up: desktop horizontal EventCards keep the image frame fixed, not stretched to text height. */
@media (min-width: 760px) {
  .pj-event-card:not(.pj-event-card--explore):not(.pj-home-best-card) .pj-card-link {
    align-items: center !important;
  }
  .pj-event-card:not(.pj-event-card--explore):not(.pj-home-best-card) .pj-event-image-wrap {
    flex: 0 0 168px !important;
    width: 168px !important;
    height: auto !important;
    aspect-ratio: 4 / 3 !important;
    align-self: center !important;
    border-radius: 18px !important;
    margin-left: 16px !important;
  }
}

/* PJ 1.5.151: prevent Explore archive cards from becoming oversized desktop billboards. */
@media (min-width: 760px) {
  .pj-archive-theme--explore > .pj-event-card--explore {
    max-width: 680px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}

/* PJ 1.5.152 follow-up: Saved is a mobile-first shortlist, so filled cards stay full-width in the 390px shell. */
.pj-saved-list,
.pj-saved-group-grid {
  grid-template-columns: 1fr !important;
}
.pj-saved-card-media.is-placeholder {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-family: var(--font-serif) !important;
  font-size: 18px !important;
  font-weight: 800 !important;
  color: #9a513d !important;
  background: linear-gradient(145deg,#fbefe2,#fffaf4) !important;
}
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-open,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-calendar,
.pj-saved-card--feed .pj-saved-card-actions .pj-saved-maps {
  flex: 1 1 96px !important;
  width: auto !important;
  min-height: 38px !important;
}

/* PJ 1.5.153: homepage sections use card grids on wider screens so images stay card-sized. */
@media (min-width: 760px) {
  .pj-featured-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
    gap: 18px !important;
    align-items: stretch !important;
  }
  .pj-featured-grid .pj-home-best-card {
    width: auto !important;
    max-width: none !important;
    margin: 0 !important;
  }
}

/* PJ 1.5.154 follow-up: RelatedCard images are fixed 16:9 frames with visible title below. */
.pj-related-card img {
  position: relative !important;
  inset: auto !important;
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 16 / 9 !important;
  object-fit: cover !important;
  object-position: center !important;
  flex: 0 0 auto !important;
}
.pj-related-card span {
  flex: 0 0 auto !important;
  min-height: 48px !important;
}

/* PJ 1.5.155 follow-up: detail action buttons align on one clean baseline. */
.pj-single-action-row > *,
.pj-explore-detail-ctas > * {
  margin: 0 !important;
  vertical-align: middle !important;
}

/* PJ 1.5.157: compact mobile-first EventCard list system. Events only; Explore keeps photo-forward cards. */
.pj-event-card:not(.pj-event-card--explore),
.pj-saved-card--event,
.pj-related-card {
  box-sizing: border-box !important;
  position: relative !important;
  display: grid !important;
  grid-template-columns: 96px minmax(0, 1fr) !important;
  gap: 14px !important;
  align-items: start !important;
  padding: 16px !important;
  border-radius: 22px !important;
  background: #fffdf8 !important;
  border: 1px solid rgba(45,35,25,.08) !important;
  box-shadow: 0 8px 24px rgba(0,0,0,.04) !important;
  overflow: hidden !important;
  min-height: 0 !important;
}
.pj-events-list .pj-event-card:not(.pj-event-card--explore),
.pj-home-best-card:not(.pj-event-card--explore),
.pj-saved-group-grid .pj-saved-card--event,
.pj-related-grid .pj-related-card {
  margin-left: 0 !important;
  margin-right: 0 !important;
}
.pj-event-card:not(.pj-event-card--explore) .pj-card-link,
.pj-saved-card--event .pj-saved-card-link,
.pj-related-card {
  display: contents !important;
  color: inherit !important;
  text-decoration: none !important;
}
.pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap,
.pj-saved-card--event .pj-saved-card-media,
.pj-related-card img {
  grid-column: 1 !important;
  grid-row: 1 / span 3 !important;
  width: 96px !important;
  min-width: 96px !important;
  max-width: 96px !important;
  height: 96px !important;
  min-height: 96px !important;
  max-height: 96px !important;
  aspect-ratio: auto !important;
  border-radius: 16px !important;
  overflow: hidden !important;
  align-self: start !important;
  background: #f2ede6 !important;
  position: relative !important;
}
.pj-event-card:not(.pj-event-card--explore) .pj-event-image,
.pj-saved-card--event .pj-saved-card-media img,
.pj-related-card img {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: cover !important;
  object-position: center center !important;
  border-radius: 0 !important;
  max-width: none !important;
}
.pj-related-card img {
  position: relative !important;
}
.pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap--placeholder::before,
.pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap:has(.pj-event-image[src=""])::before,
.pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap:has(.pj-event-image:not([src]))::before,
.pj-saved-card--event .pj-saved-card-media.is-placeholder::before,
.pj-saved-card--event .pj-saved-card-media:empty::before {
  content: "Petaluma Social" !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  height: 100% !important;
  padding: 8px !important;
  text-align: center !important;
  font-family: var(--font-serif) !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  line-height: 1.05 !important;
  color: #9a513d !important;
  background: linear-gradient(145deg,#fbefe2,#fffaf4) !important;
}
.pj-event-card:not(.pj-event-card--explore) .pj-event-body,
.pj-saved-card--event .pj-saved-card-body,
.pj-related-card span {
  grid-column: 2 !important;
  grid-row: 1 !important;
  min-width: 0 !important;
  width: 100% !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
}
.pj-event-card:not(.pj-event-card--explore) .pj-event-header,
.pj-saved-card--event .pj-saved-card-topline {
  min-width: 0 !important;
  padding-right: 44px !important;
  gap: 6px !important;
  flex-wrap: nowrap !important;
  overflow: hidden !important;
}
.pj-event-card:not(.pj-event-card--explore) .pj-event-category,
.pj-event-card:not(.pj-event-card--explore) .pj-event-status-badge,
.pj-saved-card--event .pj-saved-kind,
.pj-saved-card--event .pj-saved-plan-label {
  max-width: 100% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}
.pj-event-card:not(.pj-event-card--explore) .pj-event-title,
.pj-saved-card--event .pj-saved-card-title,
.pj-related-card span {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  margin: 0 !important;
}
.pj-event-card:not(.pj-event-card--explore) .pj-event-title { font-size: clamp(15px, 4vw, 18px) !important; }
.pj-event-card:not(.pj-event-card--explore) .pj-event-desc,
.pj-saved-card--event .pj-saved-card-hint {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
  line-height: 1.35 !important;
  margin: 0 !important;
}
.pj-event-card:not(.pj-event-card--explore) .pj-event-footer,
.pj-saved-card--event .pj-saved-card-meta {
  min-width: 0 !important;
  display: block !important;
  margin: 0 !important;
}
.pj-event-card:not(.pj-event-card--explore) .pj-event-venue,
.pj-saved-card--event .pj-saved-card-meta span {
  display: block !important;
  min-width: 0 !important;
  max-width: 100% !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
.pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right,
.pj-home-best-card:not(.pj-event-card--explore) .pj-event-meta-right,
.pj-saved-card--event .pj-saved-card-actions {
  grid-column: 2 !important;
  grid-row: 2 !important;
  position: static !important;
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 7px !important;
  width: 100% !important;
  min-width: 0 !important;
  margin: 3px 0 0 !important;
  padding: 0 !important;
  border: 0 !important;
  transform: none !important;
}
.pj-event-card:not(.pj-event-card--explore) .pj-save-heart--event,
.pj-saved-card--event .pj-saved-remove {
  position: absolute !important;
  top: 10px !important;
  right: 10px !important;
  z-index: 6 !important;
  width: 36px !important;
  min-width: 36px !important;
  height: 36px !important;
  min-height: 36px !important;
  padding: 0 !important;
  border-radius: 999px !important;
  background: rgba(255,253,248,.94) !important;
  border: 1px solid rgba(154,63,40,.16) !important;
  box-shadow: 0 4px 12px rgba(45,35,25,.08) !important;
}
.pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-time,
.pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-price,
.pj-event-card:not(.pj-event-card--explore) .pj-add-calendar-link,
.pj-saved-card--event .pj-saved-card-actions a,
.pj-saved-card--event .pj-saved-card-actions button {
  box-sizing: border-box !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 36px !important;
  max-width: 100% !important;
  border-radius: 999px !important;
  padding: 7px 11px !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  line-height: 1.1 !important;
  border: 1px solid rgba(154,63,40,.14) !important;
  background: #fff6ed !important;
  color: #7f3d28 !important;
  text-decoration: none !important;
  box-shadow: none !important;
}
.pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-time,
.pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-price {
  background: transparent !important;
  border-color: transparent !important;
  color: #5b4033 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  min-height: 20px !important;
}
.pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-time::after {
  content: "·";
  margin-left: 7px;
  color: #b58f7a;
}
.pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-price { margin-right: auto !important; }
.pj-event-card:not(.pj-event-card--explore) .pj-add-calendar-link { margin-left: 0 !important; }

@media (max-width: 360px) {
  .pj-event-card:not(.pj-event-card--explore),
  .pj-saved-card--event,
  .pj-related-card {
    grid-template-columns: 88px minmax(0, 1fr) !important;
    gap: 12px !important;
    padding: 14px !important;
  }
  .pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap,
  .pj-saved-card--event .pj-saved-card-media,
  .pj-related-card img {
    width: 88px !important;
    min-width: 88px !important;
    max-width: 88px !important;
    height: 88px !important;
    min-height: 88px !important;
    max-height: 88px !important;
  }
  .pj-event-card:not(.pj-event-card--explore) .pj-event-title { font-size: 14.5px !important; }
  .pj-event-card:not(.pj-event-card--explore) .pj-event-desc { font-size: 12.5px !important; }
  .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-time,
  .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-price,
  .pj-event-card:not(.pj-event-card--explore) .pj-add-calendar-link {
    font-size: 11px !important;
    min-height: 34px !important;
    padding: 6px 9px !important;
  }
}

@media (min-width: 768px) {
  .pj-event-card:not(.pj-event-card--explore),
  .pj-saved-card--event,
  .pj-related-card {
    grid-template-columns: 160px minmax(0, 1fr) !important;
    padding: 18px !important;
    gap: 16px !important;
  }
  .pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap,
  .pj-saved-card--event .pj-saved-card-media,
  .pj-related-card img {
    width: 160px !important;
    min-width: 160px !important;
    max-width: 160px !important;
    height: 120px !important;
    min-height: 120px !important;
    max-height: 120px !important;
  }
}

/* PJ 1.5.158: raise EventCard specificity above older desktop/list overrides. */
.pj-events-list .pj-event-card:not(.pj-event-card--explore),
.pj-event-card:not(.pj-event-card--explore):not(.pj-home-best-card),
.pj-home-best-card:not(.pj-event-card--explore) {
  display: grid !important;
  grid-template-columns: 96px minmax(0, 1fr) !important;
  align-items: start !important;
  gap: 14px !important;
  padding: 16px !important;
  min-height: 0 !important;
  flex-direction: initial !important;
}
.pj-events-list .pj-event-card:not(.pj-event-card--explore) .pj-card-link,
.pj-event-card:not(.pj-event-card--explore):not(.pj-home-best-card) .pj-card-link,
.pj-home-best-card:not(.pj-event-card--explore) .pj-card-link {
  display: contents !important;
  flex: initial !important;
  width: auto !important;
  padding: 0 !important;
  gap: 0 !important;
}
.pj-events-list .pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap,
.pj-event-card:not(.pj-event-card--explore):not(.pj-home-best-card) .pj-event-image-wrap,
.pj-home-best-card:not(.pj-event-card--explore) .pj-event-image-wrap {
  grid-column: 1 !important;
  grid-row: 1 / span 2 !important;
  align-self: start !important;
  justify-self: start !important;
  width: 96px !important;
  min-width: 96px !important;
  max-width: 96px !important;
  height: 96px !important;
  min-height: 96px !important;
  max-height: 96px !important;
  aspect-ratio: auto !important;
  border-radius: 16px !important;
}
.pj-events-list .pj-event-card:not(.pj-event-card--explore) .pj-event-body,
.pj-event-card:not(.pj-event-card--explore):not(.pj-home-best-card) .pj-event-body,
.pj-home-best-card:not(.pj-event-card--explore) .pj-event-body {
  grid-column: 2 !important;
  grid-row: 1 !important;
  padding: 0 !important;
  min-width: 0 !important;
}
.pj-events-list .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right,
.pj-event-card:not(.pj-event-card--explore):not(.pj-home-best-card) .pj-event-meta-right,
.pj-home-best-card:not(.pj-event-card--explore) .pj-event-meta-right {
  grid-column: 2 !important;
  grid-row: 2 !important;
  flex: initial !important;
  align-content: initial !important;
  justify-content: flex-start !important;
  width: 100% !important;
  padding: 0 !important;
  margin-top: 6px !important;
  border-left: 0 !important;
}
@media (max-width: 360px) {
  .pj-events-list .pj-event-card:not(.pj-event-card--explore),
  .pj-event-card:not(.pj-event-card--explore):not(.pj-home-best-card),
  .pj-home-best-card:not(.pj-event-card--explore) {
    grid-template-columns: 88px minmax(0, 1fr) !important;
    gap: 12px !important;
    padding: 14px !important;
  }
  .pj-events-list .pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap,
  .pj-event-card:not(.pj-event-card--explore):not(.pj-home-best-card) .pj-event-image-wrap,
  .pj-home-best-card:not(.pj-event-card--explore) .pj-event-image-wrap {
    width: 88px !important;
    min-width: 88px !important;
    max-width: 88px !important;
    height: 88px !important;
    min-height: 88px !important;
    max-height: 88px !important;
  }
}
@media (min-width: 768px) {
  .pj-events-list .pj-event-card:not(.pj-event-card--explore),
  .pj-event-card:not(.pj-event-card--explore):not(.pj-home-best-card),
  .pj-home-best-card:not(.pj-event-card--explore) {
    grid-template-columns: 160px minmax(0, 1fr) !important;
    gap: 16px !important;
    padding: 18px !important;
  }
  .pj-events-list .pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap,
  .pj-event-card:not(.pj-event-card--explore):not(.pj-home-best-card) .pj-event-image-wrap,
  .pj-home-best-card:not(.pj-event-card--explore) .pj-event-image-wrap {
    width: 160px !important;
    min-width: 160px !important;
    max-width: 160px !important;
    height: 120px !important;
    min-height: 120px !important;
    max-height: 120px !important;
  }
}

/* PJ 1.5.159: EventCard meta must be a compact row, not inherited vertical rail. */
.pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right,
.pj-event-card:not(.pj-event-card--explore):not(.pj-home-best-card) .pj-event-meta-right,
.pj-home-best-card:not(.pj-event-card--explore) .pj-event-meta-right {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  align-content: flex-start !important;
  justify-content: flex-start !important;
  row-gap: 6px !important;
  column-gap: 7px !important;
  min-height: 0 !important;
  height: auto !important;
}
.pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-time,
.pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-price {
  margin: 0 !important;
  flex: 0 0 auto !important;
}
.pj-event-card:not(.pj-event-card--explore) .pj-add-calendar-link {
  flex: 0 0 auto !important;
  margin: 0 !important;
}

/* PJ 1.5.159: Saved event action buttons wrap into a compact two-row row, not full-width stack. */
.pj-saved-card--event .pj-saved-card-actions a,
.pj-saved-card--event .pj-saved-card-actions button {
  width: auto !important;
  flex: 1 1 calc(50% - 4px) !important;
  min-width: 78px !important;
  padding-left: 9px !important;
  padding-right: 9px !important;
}
.pj-saved-card--event .pj-saved-card-actions .pj-saved-calendar {
  flex-basis: calc(50% - 4px) !important;
}

/* PJ 1.5.160: Saved event cards use a full-width bottom action row. */
.pj-saved-card--event .pj-saved-card-actions {
  grid-column: 1 / -1 !important;
  grid-row: 2 !important;
  width: 100% !important;
  margin-top: 8px !important;
}
.pj-saved-card--event .pj-saved-card-actions a,
.pj-saved-card--event .pj-saved-card-actions button {
  flex: 1 1 0 !important;
  min-width: 0 !important;
  width: auto !important;
}

/* PJ 1.5.161: homepage EventCard grids need enough width for the shared 160px desktop image frame. */
.pj-featured-grid:has(.pj-home-best-card:not(.pj-event-card--explore)) {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 360px), 1fr)) !important;
}
@media (max-width: 430px) {
  .pj-featured-grid:has(.pj-home-best-card:not(.pj-event-card--explore)) {
    grid-template-columns: 1fr !important;
  }
}

/* PJ 1.5.162: Saved event actions fit three clean compact buttons across. */
.pj-saved-card--event .pj-saved-card-actions {
  gap: 7px !important;
}
.pj-saved-card--event .pj-saved-card-actions a,
.pj-saved-card--event .pj-saved-card-actions button,
.pj-saved-card--event .pj-saved-card-actions .pj-saved-calendar {
  flex: 0 0 calc((100% - 14px) / 3) !important;
  width: calc((100% - 14px) / 3) !important;
  min-width: 0 !important;
  max-width: calc((100% - 14px) / 3) !important;
  font-size: 11px !important;
}

/* PJ 1.5.163: Related cards are real cards, not display:contents. */
.pj-related-grid .pj-related-card {
  box-sizing: border-box !important;
  position: relative !important;
  display: grid !important;
  grid-template-columns: 160px minmax(0, 1fr) !important;
  gap: 16px !important;
  align-items: start !important;
  padding: 18px !important;
  border-radius: 22px !important;
  background: #fffdf8 !important;
  border: 1px solid rgba(45,35,25,.08) !important;
  box-shadow: 0 8px 24px rgba(0,0,0,.04) !important;
  overflow: hidden !important;
  color: inherit !important;
  text-decoration: none !important;
}
.pj-related-grid .pj-related-card img {
  grid-column: 1 !important;
  width: 160px !important;
  height: 120px !important;
  min-width: 160px !important;
  min-height: 120px !important;
  max-width: 160px !important;
  max-height: 120px !important;
  display: block !important;
  object-fit: cover !important;
  object-position: center center !important;
  border-radius: 16px !important;
  background: #f2ede6 !important;
}
.pj-related-grid .pj-related-card span {
  grid-column: 2 !important;
  padding: 0 !important;
  align-self: start !important;
}
@media (max-width: 430px) {
  .pj-related-grid .pj-related-card {
    grid-template-columns: 96px minmax(0, 1fr) !important;
    gap: 14px !important;
    padding: 16px !important;
  }
  .pj-related-grid .pj-related-card img {
    width: 96px !important;
    height: 96px !important;
    min-width: 96px !important;
    min-height: 96px !important;
    max-width: 96px !important;
    max-height: 96px !important;
  }
}
@media (max-width: 360px) {
  .pj-related-grid .pj-related-card {
    grid-template-columns: 88px minmax(0, 1fr) !important;
    gap: 12px !important;
    padding: 14px !important;
  }
  .pj-related-grid .pj-related-card img {
    width: 88px !important;
    height: 88px !important;
    min-width: 88px !important;
    min-height: 88px !important;
    max-width: 88px !important;
    max-height: 88px !important;
  }
}

/* PJ 1.5.164: related-card grid must leave room for fixed EventCard media + title. */
.pj-related-grid {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 360px), 1fr)) !important;
}

/* PJ 1.5.166: make Events list cards feel intentionally designed, not full-width utility rows. */
.pj-archive-theme-scope .pj-events-list,
.post-type-archive-event .pj-events-list {
  max-width: 880px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.pj-archive-theme-scope .pj-section-label,
.post-type-archive-event .pj-section-label {
  max-width: 880px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.pj-events-list .pj-event-card:not(.pj-event-card--explore) {
  width: 100% !important;
  margin: 0 auto 14px !important;
  padding: 14px !important;
  grid-template-columns: 104px minmax(0, 1fr) !important;
  gap: 13px !important;
  border-radius: 22px !important;
  background: linear-gradient(180deg, #fffefa 0%, #fff9f1 100%) !important;
  border: 1px solid rgba(78, 52, 34, .10) !important;
  box-shadow: 0 10px 22px rgba(58, 37, 22, .055) !important;
}
.pj-events-list .pj-event-card:not(.pj-event-card--explore):hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 14px 28px rgba(58, 37, 22, .075) !important;
}
.pj-events-list .pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap {
  width: 104px !important;
  min-width: 104px !important;
  max-width: 104px !important;
  height: 104px !important;
  min-height: 104px !important;
  max-height: 104px !important;
  border-radius: 17px !important;
  box-shadow: inset 0 0 0 1px rgba(78, 52, 34, .08) !important;
}
.pj-events-list .pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap::before {
  content: "Petaluma\A Social" !important;
  white-space: pre-line !important;
  position: absolute !important;
  inset: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  font-family: var(--font-serif) !important;
  font-weight: 800 !important;
  font-size: 13px !important;
  line-height: 1.05 !important;
  color: #9a513d !important;
  background: radial-gradient(circle at 30% 20%, #fffaf2 0%, #f3e6d8 100%) !important;
  z-index: 0 !important;
}
.pj-events-list .pj-event-card:not(.pj-event-card--explore) .pj-event-image {
  z-index: 1 !important;
}
.pj-events-list .pj-event-card:not(.pj-event-card--explore) .pj-event-body {
  gap: 5px !important;
  padding-top: 1px !important;
}
.pj-events-list .pj-event-card:not(.pj-event-card--explore) .pj-event-header {
  padding-right: 42px !important;
  min-height: 24px !important;
}
.pj-events-list .pj-event-card:not(.pj-event-card--explore) .pj-event-category,
.pj-events-list .pj-event-card:not(.pj-event-card--explore) .pj-event-status-badge {
  height: 23px !important;
  display: inline-flex !important;
  align-items: center !important;
  padding: 4px 8px !important;
  border-radius: 999px !important;
  font-size: 10px !important;
  letter-spacing: .045em !important;
  line-height: 1 !important;
}
.pj-events-list .pj-event-card:not(.pj-event-card--explore) .pj-event-title {
  font-size: clamp(16px, 2vw, 18px) !important;
  line-height: 1.18 !important;
  color: #2f211b !important;
  max-width: 92% !important;
}
.pj-events-list .pj-event-card:not(.pj-event-card--explore) .pj-event-desc {
  font-size: 13px !important;
  line-height: 1.32 !important;
  color: #6e5a4f !important;
  max-width: 96% !important;
}
.pj-events-list .pj-event-card:not(.pj-event-card--explore) .pj-event-venue {
  font-size: 12px !important;
  color: #7d6254 !important;
  max-width: 96% !important;
}
.pj-events-list .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right {
  margin-top: 7px !important;
  gap: 6px !important;
}
.pj-events-list .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-time,
.pj-events-list .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-price {
  min-height: 28px !important;
  padding: 5px 8px !important;
  border-radius: 999px !important;
  background: rgba(255, 247, 237, .9) !important;
  border: 1px solid rgba(154, 63, 40, .10) !important;
  font-size: 12px !important;
  color: #5b4033 !important;
}
.pj-events-list .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-time::after {
  content: "" !important;
  margin: 0 !important;
}
.pj-events-list .pj-event-card:not(.pj-event-card--explore) .pj-add-calendar-link {
  min-height: 32px !important;
  padding: 6px 10px !important;
  background: #fff3e8 !important;
  border-color: rgba(173, 75, 49, .20) !important;
  color: #9a3f28 !important;
  font-size: 12px !important;
}
.pj-events-list .pj-event-card:not(.pj-event-card--explore) .pj-save-heart--event {
  top: 12px !important;
  right: 12px !important;
  width: 34px !important;
  min-width: 34px !important;
  height: 34px !important;
  min-height: 34px !important;
  color: #9a3f28 !important;
}
@media (min-width: 768px) {
  .pj-events-list .pj-event-card:not(.pj-event-card--explore) {
    grid-template-columns: 150px minmax(0, 1fr) !important;
    padding: 16px !important;
    gap: 16px !important;
  }
  .pj-events-list .pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap {
    width: 150px !important;
    min-width: 150px !important;
    max-width: 150px !important;
    height: 112px !important;
    min-height: 112px !important;
    max-height: 112px !important;
  }
}
@media (max-width: 430px) {
  .pj-events-list .pj-event-card:not(.pj-event-card--explore) {
    grid-template-columns: 96px minmax(0, 1fr) !important;
    padding: 14px !important;
    gap: 12px !important;
  }
  .pj-events-list .pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap {
    width: 96px !important;
    min-width: 96px !important;
    max-width: 96px !important;
    height: 96px !important;
    min-height: 96px !important;
    max-height: 96px !important;
  }
}
@media (max-width: 360px) {
  .pj-events-list .pj-event-card:not(.pj-event-card--explore) {
    grid-template-columns: 88px minmax(0, 1fr) !important;
    gap: 11px !important;
    padding: 13px !important;
  }
  .pj-events-list .pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap {
    width: 88px !important;
    min-width: 88px !important;
    max-width: 88px !important;
    height: 88px !important;
    min-height: 88px !important;
    max-height: 88px !important;
  }
}

/* PJ 1.5.167: actual Events archive card container is .pj-archive-theme--events, not .pj-events-list. */
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore),
.pj-archive-theme--events > .pj-section-label,
.pj-archive-theme--events > .pj-newsletter-card,
.pj-archive-theme--events > .pj-pagination {
  max-width: 880px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) {
  width: calc(100% - 32px) !important;
  margin-bottom: 14px !important;
  padding: 14px !important;
  grid-template-columns: 104px minmax(0, 1fr) !important;
  gap: 13px !important;
  border-radius: 22px !important;
  background: linear-gradient(180deg, #fffefa 0%, #fff9f1 100%) !important;
  border: 1px solid rgba(78, 52, 34, .10) !important;
  box-shadow: 0 10px 22px rgba(58, 37, 22, .055) !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap {
  width: 104px !important;
  min-width: 104px !important;
  max-width: 104px !important;
  height: 104px !important;
  min-height: 104px !important;
  max-height: 104px !important;
  border-radius: 17px !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-body {
  gap: 5px !important;
  padding-top: 1px !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-title {
  font-size: clamp(16px, 2vw, 18px) !important;
  line-height: 1.18 !important;
  color: #2f211b !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-desc {
  font-size: 13px !important;
  line-height: 1.32 !important;
  color: #6e5a4f !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-venue {
  font-size: 12px !important;
  color: #7d6254 !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right {
  margin-top: 7px !important;
  gap: 6px !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-time,
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-price {
  min-height: 28px !important;
  padding: 5px 8px !important;
  border-radius: 999px !important;
  background: rgba(255, 247, 237, .9) !important;
  border: 1px solid rgba(154, 63, 40, .10) !important;
  font-size: 12px !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-add-calendar-link {
  min-height: 32px !important;
  padding: 6px 10px !important;
  background: #fff3e8 !important;
  border-color: rgba(173, 75, 49, .20) !important;
  color: #9a3f28 !important;
  font-size: 12px !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-save-heart--event {
  top: 12px !important;
  right: 12px !important;
  width: 34px !important;
  min-width: 34px !important;
  height: 34px !important;
  min-height: 34px !important;
}
@media (min-width: 768px) {
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) {
    grid-template-columns: 150px minmax(0, 1fr) !important;
    padding: 16px !important;
    gap: 16px !important;
  }
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap {
    width: 150px !important;
    min-width: 150px !important;
    max-width: 150px !important;
    height: 112px !important;
    min-height: 112px !important;
    max-height: 112px !important;
  }
}
@media (max-width: 430px) {
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) {
    grid-template-columns: 96px minmax(0, 1fr) !important;
    padding: 14px !important;
    gap: 12px !important;
  }
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap {
    width: 96px !important;
    min-width: 96px !important;
    max-width: 96px !important;
    height: 96px !important;
    min-height: 96px !important;
    max-height: 96px !important;
  }
}
@media (max-width: 360px) {
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) {
    grid-template-columns: 88px minmax(0, 1fr) !important;
    gap: 11px !important;
    padding: 13px !important;
  }
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap {
    width: 88px !important;
    min-width: 88px !important;
    max-width: 88px !important;
    height: 88px !important;
    min-height: 88px !important;
    max-height: 88px !important;
  }
}

/* PJ 1.5.168: compact mobile homepage from screenshot feedback. */
.pj-top-nav--browse {
  width: min(100%, 300px) !important;
  max-width: calc(100vw - 40px) !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
@media (max-width: 760px) {
  .pj-top-nav--browse {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 6px !important;
  }
  .pj-top-nav--browse a {
    min-height: 32px !important;
    padding: 8px 10px !important;
    font-size: 12px !important;
  }
}
body.home {
  padding-bottom: calc(130px + env(safe-area-inset-bottom, 0px)) !important;
}
body.home .pj-home-hero {
  padding: 18px 16px 10px !important;
  margin-bottom: 4px !important;
}
body.home .pj-home-kicker {
  margin-bottom: 4px !important;
  font-size: 10px !important;
  letter-spacing: .12em !important;
}
body.home .pj-home-hero h2 {
  max-width: 340px !important;
  margin: 0 auto 5px !important;
  font-size: clamp(27px, 8vw, 34px) !important;
  line-height: 1.03 !important;
}
body.home .pj-home-hero > p:not(.pj-home-kicker) {
  max-width: 335px !important;
  margin: 0 auto !important;
  font-size: 13.5px !important;
  line-height: 1.34 !important;
  color: #625247 !important;
}
body.home .pj-home-search-form {
  position: relative !important;
  top: auto !important;
  z-index: 2 !important;
  max-width: 390px !important;
  margin: 10px auto 0 !important;
  padding: 4px !important;
  gap: 5px !important;
  border-radius: 18px !important;
  box-shadow: 0 8px 20px rgba(62,38,20,.07) !important;
}
body.home .pj-home-search-form input[type="search"] {
  height: 40px !important;
  min-height: 40px !important;
  padding: 0 12px !important;
  font-size: 13.5px !important;
  line-height: 40px !important;
  text-overflow: ellipsis !important;
}
body.home .pj-home-search-form input[type="search"]::placeholder {
  color: #8a7b70 !important;
  opacity: 1 !important;
}
body.home .pj-home-search-form > button {
  min-width: 68px !important;
  height: 40px !important;
  padding: 0 13px !important;
  font-size: 12px !important;
  box-shadow: 0 2px 0 rgba(124,20,31,.18) !important;
}
body.home .pj-home-quick-links {
  max-width: 390px !important;
  margin: 0 auto !important;
  padding: 8px 2px 2px !important;
  gap: 6px !important;
  justify-content: flex-start !important;
  flex-wrap: nowrap !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  scrollbar-width: none !important;
}
body.home .pj-home-quick-links a {
  min-height: 29px !important;
  padding: 6px 9px !important;
  font-size: 11.5px !important;
  line-height: 1 !important;
  box-shadow: 0 4px 10px rgba(31,41,55,.045) !important;
}
body.home .pj-home-section {
  padding: 6px 14px 14px !important;
  margin-top: 4px !important;
}
body.home .pj-home-section--today-weekend {
  padding-top: 2px !important;
  padding-bottom: 8px !important;
}
body.home .pj-home-planning-tiles,
body.home .pj-home-planning-tiles--compact {
  max-width: 390px !important;
  margin: 0 auto !important;
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 8px !important;
}
body.home .pj-home-planning-tiles a,
body.home .pj-home-planning-tiles--compact a {
  min-height: 58px !important;
  padding: 10px 11px !important;
  border-radius: 16px !important;
  background: linear-gradient(180deg, #fffdf8, #fff6ec) !important;
  box-shadow: 0 6px 14px rgba(58,37,22,.045) !important;
}
body.home .pj-home-planning-tiles strong {
  font-family: var(--font-sans) !important;
  font-size: 14px !important;
  line-height: 1.1 !important;
  color: #2f211b !important;
}
body.home .pj-home-planning-tiles span {
  margin-top: 3px !important;
  font-size: 11.5px !important;
  line-height: 1.2 !important;
  color: #7a6254 !important;
}
body.home .pj-home-section-head {
  max-width: 390px !important;
  margin: 0 auto 9px !important;
  align-items: center !important;
  gap: 8px !important;
}
body.home .pj-home-section-head h2 {
  font-size: clamp(23px, 6.4vw, 29px) !important;
  line-height: 1.05 !important;
}
body.home .pj-home-section-head > a,
body.home .pj-home-head-actions > a {
  font-size: 12px !important;
  line-height: 1 !important;
}
body.home .pj-home-head-actions {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 7px !important;
  flex-wrap: wrap !important;
}
body.home .pj-home-head-actions .pj-submit-event-cta {
  min-height: 28px !important;
  padding: 6px 9px !important;
  font-size: 10.5px !important;
  box-shadow: none !important;
  background: #fff7ed !important;
  color: #9a3f28 !important;
  border-color: rgba(154,63,40,.22) !important;
}
body.home .pj-featured-grid {
  max-width: 390px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  gap: 10px !important;
}
body.home .pj-home-best-card:not(.pj-event-card--explore) {
  width: 100% !important;
  grid-template-columns: 96px minmax(0, 1fr) !important;
  gap: 12px !important;
  padding: 14px !important;
  border-radius: 22px !important;
  background: linear-gradient(180deg, #fffefa 0%, #fff9f1 100%) !important;
  border: 1px solid rgba(78,52,34,.10) !important;
  box-shadow: 0 9px 20px rgba(58,37,22,.055) !important;
}
body.home .pj-home-best-card:not(.pj-event-card--explore) .pj-event-image-wrap {
  width: 96px !important;
  min-width: 96px !important;
  max-width: 96px !important;
  height: 96px !important;
  min-height: 96px !important;
  max-height: 96px !important;
  border-radius: 16px !important;
}
body.home .pj-home-best-card:not(.pj-event-card--explore) .pj-event-body {
  gap: 5px !important;
}
body.home .pj-home-best-card:not(.pj-event-card--explore) .pj-event-title {
  font-size: 15.5px !important;
  line-height: 1.17 !important;
}
body.home .pj-home-best-card:not(.pj-event-card--explore) .pj-event-desc {
  font-size: 12.4px !important;
  line-height: 1.27 !important;
}
body.home .pj-home-best-card:not(.pj-event-card--explore) .pj-event-meta-right {
  margin-top: 4px !important;
  gap: 6px !important;
}
body.home .pj-home-best-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-time,
body.home .pj-home-best-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-price {
  min-height: 26px !important;
  padding: 4px 7px !important;
  font-size: 11.5px !important;
}
body.home .pj-home-best-card:not(.pj-event-card--explore) .pj-add-calendar-link {
  min-height: 31px !important;
  padding: 6px 9px !important;
  font-size: 11.5px !important;
}
@media (max-width: 360px) {
  body.home .pj-home-best-card:not(.pj-event-card--explore) {
    grid-template-columns: 88px minmax(0, 1fr) !important;
    gap: 11px !important;
    padding: 13px !important;
  }
  body.home .pj-home-best-card:not(.pj-event-card--explore) .pj-event-image-wrap {
    width: 88px !important;
    min-width: 88px !important;
    max-width: 88px !important;
    height: 88px !important;
    min-height: 88px !important;
    max-height: 88px !important;
  }
}

/* PJ 1.5.170: /events medium compact card — larger image, cleaner bottom action row. */
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) {
  width: calc(100% - 32px) !important;
  max-width: 880px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  margin-bottom: 15px !important;
  grid-template-columns: 112px minmax(0, 1fr) !important;
  gap: 14px !important;
  padding: 16px !important;
  border-radius: 22px !important;
  background: linear-gradient(180deg, #fffefa 0%, #fff8f0 100%) !important;
  border: 1px solid rgba(0, 0, 0, .08) !important;
  box-shadow: 0 10px 24px rgba(58, 37, 22, .06) !important;
  min-height: 168px !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-card-link {
  display: contents !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap {
  grid-column: 1 !important;
  grid-row: 1 / span 2 !important;
  width: 112px !important;
  min-width: 112px !important;
  max-width: 112px !important;
  height: 112px !important;
  min-height: 112px !important;
  max-height: 112px !important;
  border-radius: 16px !important;
  align-self: start !important;
  overflow: hidden !important;
  background: #f2ede6 !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-image {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
  display: block !important;
  max-width: none !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-body {
  grid-column: 2 !important;
  grid-row: 1 !important;
  min-width: 0 !important;
  padding: 0 !important;
  padding-right: 40px !important;
  gap: 6px !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-header {
  padding-right: 0 !important;
  min-height: 24px !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-title {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
  font-size: clamp(16px, 4.2vw, 18px) !important;
  line-height: 1.18 !important;
  font-weight: 760 !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-desc {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
  font-size: 13px !important;
  line-height: 1.32 !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-venue {
  display: block !important;
  max-width: 100% !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  font-size: 12.5px !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-save-heart--event {
  position: absolute !important;
  top: 14px !important;
  right: 14px !important;
  width: 34px !important;
  min-width: 34px !important;
  height: 34px !important;
  min-height: 34px !important;
  z-index: 6 !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right {
  grid-column: 2 !important;
  grid-row: 2 !important;
  align-self: end !important;
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: 0 4px !important;
  width: 100% !important;
  min-width: 0 !important;
  min-height: 34px !important;
  margin: 8px 0 0 !important;
  padding: 0 !important;
  border: 0 !important;
  position: static !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-time,
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-price {
  min-width: 0 !important;
  min-height: 20px !important;
  height: auto !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: #5b4033 !important;
  font-size: 12.5px !important;
  font-weight: 850 !important;
  line-height: 1.15 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-time::after {
  content: "·" !important;
  margin-left: 7px !important;
  color: #b58f7a !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-price {
  padding-left: 3px !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-add-calendar-link {
  justify-self: end !important;
  min-height: 34px !important;
  padding: 7px 11px !important;
  border-radius: 999px !important;
  background: #fff3e8 !important;
  border: 1px solid rgba(173, 75, 49, .20) !important;
  color: #9a3f28 !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  white-space: nowrap !important;
  text-decoration: none !important;
}
@media (max-width: 360px) {
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) {
    grid-template-columns: 104px minmax(0, 1fr) !important;
    gap: 12px !important;
    padding: 14px !important;
    min-height: 160px !important;
  }
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap {
    width: 104px !important;
    min-width: 104px !important;
    max-width: 104px !important;
    height: 104px !important;
    min-height: 104px !important;
    max-height: 104px !important;
  }
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-title {
    font-size: 15px !important;
  }
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-time,
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-price,
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-add-calendar-link {
    font-size: 11.5px !important;
  }
}
@media (min-width: 768px) {
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) {
    grid-template-columns: 150px minmax(0, 1fr) !important;
    min-height: 176px !important;
  }
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap {
    width: 150px !important;
    min-width: 150px !important;
    max-width: 150px !important;
    height: 112px !important;
    min-height: 112px !important;
    max-height: 112px !important;
  }
}

/* PJ 1.5.171: match mobile Events card mockup — roomier card, divider, bottom action row. */
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) {
  grid-template-columns: 112px minmax(0, 1fr) !important;
  grid-template-rows: minmax(0, 1fr) auto !important;
  gap: 0 14px !important;
  padding: 16px !important;
  min-height: 184px !important;
  border-radius: 22px !important;
  background: #fffdf8 !important;
  border: 1px solid rgba(0, 0, 0, .08) !important;
  box-shadow: 0 10px 26px rgba(58, 37, 22, .065) !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap {
  width: 112px !important;
  min-width: 112px !important;
  max-width: 112px !important;
  height: 112px !important;
  min-height: 112px !important;
  max-height: 112px !important;
  border-radius: 16px !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-image {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-body {
  padding-right: 42px !important;
  gap: 6px !important;
  align-self: start !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-category,
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-status-badge {
  height: 24px !important;
  min-height: 24px !important;
  padding: 5px 9px !important;
  border-radius: 999px !important;
  font-size: 10px !important;
  line-height: 1 !important;
  letter-spacing: .045em !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-title {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
  font-size: 17px !important;
  line-height: 1.18 !important;
  font-weight: 760 !important;
  color: #231b16 !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-desc {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
  font-size: 13.5px !important;
  line-height: 1.32 !important;
  color: #65574c !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-venue {
  display: block !important;
  max-width: 100% !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  font-size: 12.75px !important;
  color: #8a3b2b !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-save-heart--event {
  top: 14px !important;
  right: 14px !important;
  width: 36px !important;
  min-width: 36px !important;
  height: 36px !important;
  min-height: 36px !important;
  background: rgba(255, 253, 248, .96) !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right {
  grid-column: 2 !important;
  grid-row: 2 !important;
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: 0 4px !important;
  min-height: 44px !important;
  margin: 10px 0 0 !important;
  padding: 10px 0 0 !important;
  border-top: 1px solid rgba(78, 52, 34, .10) !important;
  position: static !important;
  width: 100% !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-time,
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-price {
  min-height: 22px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  font-size: 13px !important;
  line-height: 1.15 !important;
  font-weight: 850 !important;
  color: #50392f !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-time::after {
  content: "·" !important;
  margin-left: 7px !important;
  color: #b58f7a !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-price {
  padding-left: 3px !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-add-calendar-link {
  justify-self: end !important;
  min-height: 34px !important;
  padding: 7px 12px !important;
  border-radius: 999px !important;
  background: #fff4ea !important;
  border: 1px solid rgba(173, 75, 49, .22) !important;
  color: #9a3f28 !important;
  font-size: 12px !important;
  font-weight: 900 !important;
}
@media (max-width: 360px) {
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) {
    grid-template-columns: 104px minmax(0, 1fr) !important;
    gap: 0 12px !important;
    padding: 14px !important;
    min-height: 174px !important;
  }
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap {
    width: 104px !important;
    min-width: 104px !important;
    max-width: 104px !important;
    height: 104px !important;
    min-height: 104px !important;
    max-height: 104px !important;
  }
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-title {
    font-size: 15.5px !important;
  }
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-desc {
    font-size: 12.5px !important;
  }
}
@media (min-width: 768px) {
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) {
    grid-template-columns: 150px minmax(0, 1fr) !important;
    min-height: 190px !important;
  }
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-image-wrap {
    width: 150px !important;
    min-width: 150px !important;
    max-width: 150px !important;
    height: 112px !important;
    min-height: 112px !important;
    max-height: 112px !important;
  }
}

/* PJ 1.5.172: put date/time/cost/location into one mockup-style bottom details row. */
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-body {
  padding-right: 42px !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right {
  grid-template-columns: auto auto minmax(0, 1fr) auto !important;
  column-gap: 8px !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-time,
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-price,
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-venue {
  display: inline-flex !important;
  align-items: center !important;
  min-width: 0 !important;
  min-height: 22px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  font-size: 13px !important;
  line-height: 1.15 !important;
  font-weight: 850 !important;
  color: #50392f !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-venue {
  color: #8a3b2b !important;
  justify-content: flex-start !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-price::after {
  content: "" !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-time::after {
  content: "·" !important;
  margin-left: 8px !important;
  color: #b58f7a !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-add-calendar-link::before {
  content: "" !important;
}
@media (max-width: 430px) {
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right {
    grid-template-columns: auto auto minmax(0, 1fr) !important;
    row-gap: 7px !important;
  }
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-add-calendar-link {
    grid-column: 3 !important;
    justify-self: end !important;
  }
}

/* PJ 1.5.173: latest mockup match — location in body, details row only time/price + calendar. */
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) {
  min-height: 198px !important;
  background: #fffdf8 !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-body {
  padding-right: 42px !important;
  gap: 7px !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-footer {
  display: block !important;
  margin: 0 !important;
  min-width: 0 !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-body .pj-event-venue {
  display: block !important;
  max-width: 100% !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  font-size: 13px !important;
  line-height: 1.25 !important;
  font-weight: 750 !important;
  color: #8a3b2b !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-venue-icon {
  color: #c64b32 !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right {
  grid-template-columns: auto auto minmax(0, 1fr) auto !important;
  column-gap: 8px !important;
  min-height: 44px !important;
  margin-top: 12px !important;
  padding-top: 10px !important;
  border-top: 1px solid rgba(78, 52, 34, .10) !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right > .pj-event-time {
  grid-column: 1 !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right > .pj-event-price {
  grid-column: 2 !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right > .pj-add-calendar-link {
  grid-column: 4 !important;
  justify-self: end !important;
}
.pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right .pj-event-time::before {
  content: "◷" !important;
  margin-right: 5px !important;
  color: #9a3f28 !important;
  font-size: 12px !important;
  line-height: 1 !important;
}
@media (max-width: 430px) {
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) {
    min-height: 192px !important;
  }
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right {
    grid-template-columns: auto auto minmax(0, 1fr) auto !important;
  }
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) .pj-event-meta-right > .pj-add-calendar-link {
    grid-column: 4 !important;
  }
}
@media (max-width: 360px) {
  .pj-archive-theme--events > .pj-event-card:not(.pj-event-card--explore) {
    min-height: 184px !important;
  }
}

/* PJ 1.5.174: exact medium compact Events card mockup structure */
.pj-event-card.event-card:not(.pj-event-card--explore) {
  background: #fffdf8 !important;
  border: 1px solid rgba(45, 35, 25, 0.08) !important;
  border-radius: 22px !important;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.045) !important;
  padding: 16px !important;
  overflow: hidden !important;
  margin-bottom: 16px !important;
  position: relative !important;
  display: block !important;
  min-height: 0 !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-main,
.pj-event-card.event-card:not(.pj-event-card--explore) .pj-card-link.event-card-main {
  display: grid !important;
  grid-template-columns: 112px minmax(0, 1fr) !important;
  gap: 14px !important;
  align-items: start !important;
  width: 100% !important;
  min-width: 0 !important;
  padding: 0 !important;
  color: inherit !important;
  text-decoration: none !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-image,
.pj-event-card.event-card:not(.pj-event-card--explore) .pj-event-image-wrap.event-card-image {
  width: 112px !important;
  height: 112px !important;
  min-width: 112px !important;
  min-height: 112px !important;
  max-width: 112px !important;
  max-height: 112px !important;
  aspect-ratio: 1 / 1 !important;
  border-radius: 16px !important;
  overflow: hidden !important;
  background: #f2ede6 !important;
  flex: 0 0 112px !important;
  align-self: start !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-image img,
.pj-event-card.event-card:not(.pj-event-card--explore) .pj-event-image {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: cover !important;
  object-position: center !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-content,
.pj-event-card.event-card:not(.pj-event-card--explore) .pj-event-body.event-card-content {
  min-width: 0 !important;
  padding: 0 !important;
  padding-right: 42px !important;
  display: block !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-topline,
.pj-event-card.event-card:not(.pj-event-card--explore) .pj-event-header.event-card-topline {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 8px !important;
  margin: 0 0 6px !important;
  min-width: 0 !important;
  flex-wrap: nowrap !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-category-pill,
.pj-event-card.event-card:not(.pj-event-card--explore) .pj-event-category.event-category-pill {
  display: inline-flex !important;
  align-items: center !important;
  min-height: 26px !important;
  padding: 4px 11px !important;
  border-radius: 999px !important;
  background: #e4f3e6 !important;
  color: #28733f !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
  line-height: 1 !important;
  max-width: min(100%, 180px) !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .pj-event-status-badge {
  display: none !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-save-heart,
.pj-event-card.event-card:not(.pj-event-card--explore) .pj-save-heart--event.event-save-heart {
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  width: 38px !important;
  height: 38px !important;
  border-radius: 999px !important;
  border: 1px solid #eadbd3 !important;
  background: #fffdf8 !important;
  color: #ad3f2e !important;
  font-size: 22px !important;
  line-height: 1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  z-index: 4 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-title,
.pj-event-card.event-card:not(.pj-event-card--explore) .pj-event-title.event-card-title {
  margin: 0 0 6px !important;
  color: #111827 !important;
  font-size: 21px !important;
  line-height: 1.18 !important;
  font-weight: 750 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
  hyphens: none !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-description,
.pj-event-card.event-card:not(.pj-event-card--explore) .pj-event-desc.event-card-description {
  margin: 0 0 8px !important;
  color: #68717c !important;
  font-size: 16px !important;
  line-height: 1.35 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
  hyphens: none !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-location,
.pj-event-card.event-card:not(.pj-event-card--explore) .pj-event-footer.event-card-location {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  color: #68717c !important;
  font-size: 15px !important;
  line-height: 1.25 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  margin: 0 !important;
  min-width: 0 !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-location .pj-event-venue,
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-location span:last-child {
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  min-width: 0 !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-footer,
.pj-event-card.event-card:not(.pj-event-card--explore) .pj-event-meta-right.event-card-footer {
  position: static !important;
  left: auto !important;
  right: auto !important;
  bottom: auto !important;
  width: 100% !important;
  min-width: 0 !important;
  height: auto !important;
  min-height: 0 !important;
  margin-top: 14px !important;
  padding: 12px 0 0 !important;
  border-top: 1px solid rgba(45, 35, 25, 0.08) !important;
  border-left: 0 !important;
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  text-align: left !important;
  background: transparent !important;
  box-shadow: none !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-meta {
  display: flex !important;
  align-items: center !important;
  gap: 9px !important;
  color: #4b352b !important;
  font-size: 16px !important;
  font-weight: 650 !important;
  min-width: 0 !important;
  overflow: hidden !important;
  white-space: nowrap !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-meta .dot {
  color: #b57b68 !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-meta .pj-event-time,
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-meta .pj-event-price {
  display: inline !important;
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  color: inherit !important;
  font: inherit !important;
  min-width: 0 !important;
  max-width: 100% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-calendar-button,
.pj-event-card.event-card:not(.pj-event-card--explore) .pj-add-calendar-link.event-calendar-button {
  min-height: 38px !important;
  padding: 8px 14px !important;
  border-radius: 999px !important;
  border: 1px solid #e2b8a8 !important;
  background: #fff8f4 !important;
  color: #a9482b !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  white-space: nowrap !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 auto !important;
  box-shadow: none !important;
  text-decoration: none !important;
}
@media (max-width: 370px) {
  .pj-event-card.event-card:not(.pj-event-card--explore) {
    padding: 14px !important;
  }
  .pj-event-card.event-card:not(.pj-event-card--explore) .event-card-main,
  .pj-event-card.event-card:not(.pj-event-card--explore) .pj-card-link.event-card-main {
    grid-template-columns: 104px minmax(0, 1fr) !important;
    gap: 12px !important;
  }
  .pj-event-card.event-card:not(.pj-event-card--explore) .event-card-image,
  .pj-event-card.event-card:not(.pj-event-card--explore) .pj-event-image-wrap.event-card-image {
    width: 104px !important;
    height: 104px !important;
    min-width: 104px !important;
    min-height: 104px !important;
    max-width: 104px !important;
    max-height: 104px !important;
    flex-basis: 104px !important;
  }
  .pj-event-card.event-card:not(.pj-event-card--explore) .event-card-title,
  .pj-event-card.event-card:not(.pj-event-card--explore) .pj-event-title.event-card-title {
    font-size: 19px !important;
  }
  .pj-event-card.event-card:not(.pj-event-card--explore) .event-card-description,
  .pj-event-card.event-card:not(.pj-event-card--explore) .pj-event-desc.event-card-description {
    font-size: 15px !important;
  }
}

/* PJ 1.5.175: rebuilt /events EventCard component; no legacy right rail */
.pj-events-list > .event-card.pj-event-card:not(.pj-event-card--explore),
.event-card.pj-event-card:not(.pj-event-card--explore) {
  background: #fffdf8 !important;
  border: 1px solid rgba(45, 35, 25, 0.08) !important;
  border-radius: 22px !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.045) !important;
  padding: 16px !important;
  overflow: hidden !important;
  margin-bottom: 16px !important;
  position: relative !important;
  display: block !important;
  min-height: 0 !important;
}
.event-card .event-card-main {
  display: grid !important;
  grid-template-columns: 112px minmax(0, 1fr) !important;
  gap: 14px !important;
  align-items: start !important;
  width: 100% !important;
  min-width: 0 !important;
}
.event-card .event-card-image {
  width: 112px !important;
  height: 112px !important;
  min-width: 112px !important;
  min-height: 112px !important;
  max-width: 112px !important;
  max-height: 112px !important;
  aspect-ratio: 1 / 1 !important;
  border-radius: 16px !important;
  overflow: hidden !important;
  background: #f2ede6 !important;
  display: block !important;
  flex: 0 0 112px !important;
  text-decoration: none !important;
}
.event-card .event-card-image img,
.event-card .event-card-image .pj-event-image,
.event-card img.pj-event-image {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: cover !important;
  object-position: center !important;
}
.event-card .event-card-content {
  min-width: 0 !important;
  padding: 0 !important;
  padding-right: 42px !important;
}
.event-card .event-card-topline {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
  margin: 0 0 6px !important;
  min-width: 0 !important;
}
.event-card .event-category-pill {
  display: inline-flex !important;
  align-items: center !important;
  min-height: 26px !important;
  padding: 4px 11px !important;
  border-radius: 999px !important;
  background: #e4f3e6 !important;
  color: #28733f !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  max-width: calc(100% - 46px) !important;
  line-height: 1 !important;
}
.event-card .event-save-heart {
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  width: 38px !important;
  height: 38px !important;
  border-radius: 999px !important;
  border: 1px solid #eadbd3 !important;
  background: #fffdf8 !important;
  color: #ad3f2e !important;
  font-size: 22px !important;
  line-height: 1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  z-index: 4 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.event-card .event-card-text-link {
  display: block !important;
  color: inherit !important;
  text-decoration: none !important;
  min-width: 0 !important;
}
.event-card .event-card-title {
  margin: 0 0 6px !important;
  color: #111827 !important;
  font-size: 21px !important;
  line-height: 1.18 !important;
  font-weight: 750 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
}
.event-card .event-card-description {
  margin: 0 0 8px !important;
  color: #68717c !important;
  font-size: 16px !important;
  line-height: 1.35 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
}
.event-card .event-card-location {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  color: #68717c !important;
  font-size: 15px !important;
  line-height: 1.25 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  margin: 0 !important;
  min-width: 0 !important;
}
.event-card .event-card-location .pj-event-venue {
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  min-width: 0 !important;
}
.event-card .event-card-footer {
  margin-top: 14px !important;
  padding-top: 12px !important;
  border-top: 1px solid rgba(45, 35, 25, 0.08) !important;
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  width: 100% !important;
  min-width: 0 !important;
  position: static !important;
  height: auto !important;
  min-height: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}
.event-card .event-card-meta {
  display: flex !important;
  align-items: center !important;
  gap: 9px !important;
  color: #4b352b !important;
  font-size: 16px !important;
  font-weight: 650 !important;
  min-width: 0 !important;
  overflow: hidden !important;
  white-space: nowrap !important;
}
.event-card .event-card-meta .dot { color: #b57b68 !important; }
.event-card .event-card-meta .pj-event-time,
.event-card .event-card-meta .pj-event-price {
  display: inline !important;
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  color: inherit !important;
  font: inherit !important;
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}
.event-card .event-calendar-button {
  min-height: 38px !important;
  padding: 8px 14px !important;
  border-radius: 999px !important;
  border: 1px solid #e2b8a8 !important;
  background: #fff8f4 !important;
  color: #a9482b !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  white-space: nowrap !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 auto !important;
  box-shadow: none !important;
  text-decoration: none !important;
}
@media (max-width: 370px) {
  .event-card.pj-event-card:not(.pj-event-card--explore) { padding: 14px !important; }
  .event-card .event-card-main { grid-template-columns: 104px minmax(0, 1fr) !important; gap: 12px !important; }
  .event-card .event-card-image {
    width: 104px !important;
    height: 104px !important;
    min-width: 104px !important;
    min-height: 104px !important;
    max-width: 104px !important;
    max-height: 104px !important;
    flex-basis: 104px !important;
  }
  .event-card .event-card-title { font-size: 19px !important; }
  .event-card .event-card-description { font-size: 15px !important; }
}

/* PJ 1.5.175b: force rebuilt EventCard location to one horizontal line */
.event-card .event-card-location,
.event-card .event-card-text-link .event-card-location.pj-event-footer {
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 6px !important;
  font-size: 15px !important;
  line-height: 1.25 !important;
  min-height: 0 !important;
  height: auto !important;
}
.event-card .event-card-location .location-icon,
.event-card .event-card-location .pj-venue-icon {
  display: inline-flex !important;
  flex: 0 0 auto !important;
  font-size: 15px !important;
  line-height: 1 !important;
}
.event-card .event-card-location .pj-event-venue {
  display: block !important;
  flex: 1 1 auto !important;
  min-width: 0 !important;
  color: #68717c !important;
  font-size: 15px !important;
  line-height: 1.25 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

/* PJ 1.5.177: authoritative /events EventCard mockup match */
.event-card.pj-event-card:not(.pj-event-card--explore) {
  background: #fffdf8 !important;
  border: 1px solid rgba(45,35,25,0.08) !important;
  border-radius: 22px !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.045) !important;
  padding: 16px !important;
  overflow: hidden !important;
  margin-bottom: 16px !important;
  position: relative !important;
  display: block !important;
  min-height: 0 !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-main {
  display: grid !important;
  grid-template-columns: 112px minmax(0, 1fr) !important;
  gap: 14px !important;
  align-items: start !important;
  width: 100% !important;
  min-width: 0 !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-image {
  width: 112px !important;
  height: 112px !important;
  min-width: 112px !important;
  min-height: 112px !important;
  max-width: 112px !important;
  max-height: 112px !important;
  border-radius: 16px !important;
  overflow: hidden !important;
  background: #f2ede6 !important;
  flex-shrink: 0 !important;
  display: block !important;
  text-decoration: none !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-image img,
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-image .pj-event-image {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: cover !important;
  object-position: center !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-content {
  min-width: 0 !important;
  padding: 0 !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-topline {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
  margin-bottom: 6px !important;
  min-width: 0 !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-category-pill {
  display: inline-flex !important;
  align-items: center !important;
  min-height: 26px !important;
  padding: 4px 11px !important;
  border-radius: 999px !important;
  background: #e4f3e6 !important;
  color: #28733f !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  max-width: calc(100% - 46px) !important;
  line-height: 1 !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-save-heart {
  position: static !important;
  width: 38px !important;
  height: 38px !important;
  border-radius: 999px !important;
  border: 1px solid #eadbd3 !important;
  background: #fffdf8 !important;
  color: #ad3f2e !important;
  font-size: 22px !important;
  line-height: 1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-text-link {
  display: block !important;
  color: inherit !important;
  text-decoration: none !important;
  min-width: 0 !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-title {
  margin: 0 0 6px !important;
  color: #111827 !important;
  font-size: 21px !important;
  line-height: 1.18 !important;
  font-weight: 750 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-description {
  margin: 0 0 8px !important;
  color: #68717c !important;
  font-size: 16px !important;
  line-height: 1.35 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-location {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 6px !important;
  color: #68717c !important;
  font-size: 15px !important;
  line-height: 1.25 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  margin: 0 !important;
  min-width: 0 !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-location .location-icon {
  display: inline-flex !important;
  flex: 0 0 auto !important;
  color: #ad3f2e !important;
  font-size: 15px !important;
  line-height: 1 !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-location .pj-event-venue {
  display: block !important;
  flex: 1 1 auto !important;
  min-width: 0 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  color: #68717c !important;
  font-size: 15px !important;
  line-height: 1.25 !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-footer {
  margin-top: 14px !important;
  padding-top: 12px !important;
  border-top: 1px solid rgba(45,35,25,0.08) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  width: 100% !important;
  min-width: 0 !important;
  position: static !important;
  height: auto !important;
  min-height: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-meta {
  display: flex !important;
  align-items: center !important;
  gap: 9px !important;
  color: #4b352b !important;
  font-size: 16px !important;
  font-weight: 650 !important;
  min-width: 0 !important;
  overflow: hidden !important;
  white-space: nowrap !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-meta .dot {
  color: #b57b68 !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-meta .pj-event-time,
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-meta .pj-event-price {
  display: inline !important;
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  color: inherit !important;
  font: inherit !important;
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-meta .pj-event-price.pj-free {
  color: #2e7d32 !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-calendar-button {
  min-height: 38px !important;
  padding: 8px 14px !important;
  border-radius: 999px !important;
  border: 1px solid #e2b8a8 !important;
  background: #fff8f4 !important;
  color: #a9482b !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  white-space: nowrap !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 auto !important;
  box-shadow: none !important;
  text-decoration: none !important;
}
@media (max-width: 370px) {
  .event-card.pj-event-card:not(.pj-event-card--explore) {
    padding: 16px !important;
  }
  .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-main {
    grid-template-columns: 112px minmax(0, 1fr) !important;
    gap: 14px !important;
  }
  .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-image {
    width: 112px !important;
    height: 112px !important;
    min-width: 112px !important;
    min-height: 112px !important;
    max-width: 112px !important;
    max-height: 112px !important;
  }
}

/* PJ 1.5.178: final specificity locks for exact EventCard mockup */
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-main > .event-card-image.pj-event-image-wrap,
.event-card.pj-event-card:not(.pj-event-card--explore) a.event-card-image.pj-event-image-wrap {
  width: 112px !important;
  height: 112px !important;
  min-width: 112px !important;
  min-height: 112px !important;
  max-width: 112px !important;
  max-height: 112px !important;
  flex: 0 0 112px !important;
  border-radius: 16px !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-topline > .event-save-heart.pj-save-heart.pj-save-heart--event,
.event-card.pj-event-card:not(.pj-event-card--explore) button.event-save-heart.pj-save-heart--event {
  position: static !important;
  top: auto !important;
  right: auto !important;
  left: auto !important;
  bottom: auto !important;
  width: 38px !important;
  height: 38px !important;
  min-width: 38px !important;
  min-height: 38px !important;
  transform: none !important;
}
@media (max-width: 370px) {
  .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-main > .event-card-image.pj-event-image-wrap,
  .event-card.pj-event-card:not(.pj-event-card--explore) a.event-card-image.pj-event-image-wrap {
    width: 112px !important;
    height: 112px !important;
    min-width: 112px !important;
    min-height: 112px !important;
    max-width: 112px !important;
    max-height: 112px !important;
    flex-basis: 112px !important;
  }
}

/* PJ 1.5.179: mobile Events screen closer to supplied mockup */
@media (max-width: 760px) {
  body:has(.pj-archive-theme-scope.pj-archive-theme--events) {
    background: #fbf7ef !important;
  }
  body:has(.pj-archive-theme-scope.pj-archive-theme--events) .pj-sticky-header {
    display: none !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events {
    max-width: 430px !important;
    margin: 0 auto !important;
    padding: 18px 16px calc(120px + env(safe-area-inset-bottom, 0px)) !important;
    background: #fbf7ef !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .pj-archive-header {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    column-gap: 12px !important;
    row-gap: 4px !important;
    align-items: start !important;
    margin: 0 0 16px !important;
    padding: 4px 0 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    text-align: left !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .pj-archive-title {
    grid-column: 1 !important;
    grid-row: 1 !important;
    margin: 0 !important;
    color: #111827 !important;
    font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
    font-size: 34px !important;
    line-height: 1.05 !important;
    font-weight: 800 !important;
    letter-spacing: -0.04em !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .pj-archive-subhead {
    grid-column: 1 / -1 !important;
    grid-row: 2 !important;
    max-width: 300px !important;
    margin: 0 !important;
    color: #6b7280 !important;
    font-size: 15px !important;
    line-height: 1.35 !important;
    font-weight: 500 !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .pj-archive-conversion-row {
    grid-column: 2 !important;
    grid-row: 1 / span 2 !important;
    margin: 0 !important;
    padding: 0 !important;
    align-self: start !important;
    justify-self: end !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .pj-submit-event-cta {
    min-height: 42px !important;
    padding: 10px 13px !important;
    border-radius: 16px !important;
    background: #a9482b !important;
    color: #fff !important;
    font-size: 13px !important;
    font-weight: 800 !important;
    box-shadow: 0 8px 18px rgba(169,72,43,.22) !important;
    border: 0 !important;
    white-space: nowrap !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .pj-submit-event-cta::before {
    content: "◷";
    margin-right: 6px;
    font-weight: 700;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .pj-filter-stack {
    position: static !important;
    top: auto !important;
    z-index: auto !important;
    margin: 0 0 18px !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    overflow: visible !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .pj-primary-filter-bar {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 8px !important;
    overflow-x: auto !important;
    padding: 0 2px 8px 0 !important;
    margin: 0 !important;
    scrollbar-width: none !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .pj-primary-filter-bar::-webkit-scrollbar,
  .pj-archive-theme-scope.pj-archive-theme--events .pj-events-filter-actions::-webkit-scrollbar {
    display: none !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .pj-category-tab,
  .pj-archive-theme-scope.pj-archive-theme--events .pj-filter-chip,
  .pj-archive-theme-scope.pj-archive-theme--events .pj-more-filters > summary {
    min-height: 40px !important;
    padding: 10px 15px !important;
    border-radius: 999px !important;
    background: #fffdf8 !important;
    color: #2f312f !important;
    border: 1px solid rgba(45,35,25,.11) !important;
    box-shadow: none !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    white-space: nowrap !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .pj-category-tab.active,
  .pj-archive-theme-scope.pj-archive-theme--events .pj-filter-chip.active {
    background: #a9482b !important;
    color: #fff !important;
    border-color: #a9482b !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .pj-events-filter-actions {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 8px !important;
    align-items: center !important;
    overflow-x: auto !important;
    padding: 0 2px 4px 0 !important;
    margin: 0 !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .pj-more-filters summary::before {
    content: "☰";
    margin-right: 7px;
    font-size: 13px;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .pj-more-filters summary::after {
    content: "⌄";
    margin-left: 7px;
    font-size: 13px;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .pj-filter-chip--date::before {
    content: "📅";
    margin-right: 6px;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .pj-section-label {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    margin: 12px 0 12px !important;
    padding: 0 !important;
    color: #4b352b !important;
    font-size: 13px !important;
    line-height: 1.2 !important;
    font-weight: 800 !important;
    letter-spacing: .04em !important;
    text-transform: none !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .pj-section-label-icon {
    width: 28px !important;
    height: 28px !important;
    border-radius: 999px !important;
    background: #fff2e8 !important;
    color: #a9482b !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .pj-section-label-icon svg {
    width: 15px !important;
    height: 15px !important;
  }
}

/* PJ 1.5.180: keep page wrapper visible; hide only mobile brand chrome for mockup */
@media (max-width: 760px) {
  body:has(.pj-archive-theme-scope.pj-archive-theme--events) .pj-sticky-header {
    display: block !important;
    background: #fbf7ef !important;
    padding: 0 !important;
  }
  body:has(.pj-archive-theme-scope.pj-archive-theme--events) .pj-site-header {
    display: none !important;
  }
}

/* PJ 1.5.181: make rebuilt /events cards uniform height, not content-variable. */
.event-card.pj-event-card:not(.pj-event-card--explore) {
  box-sizing: border-box !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-main {
  min-height: 158px !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-content {
  display: flex !important;
  flex-direction: column !important;
  min-height: 158px !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-topline {
  flex: 0 0 38px !important;
  min-height: 38px !important;
  margin-bottom: 6px !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-text-link {
  display: flex !important;
  flex-direction: column !important;
  min-height: 114px !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-title {
  min-height: calc(2 * 1.18em) !important;
  max-height: calc(2 * 1.18em) !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-description {
  min-height: calc(2 * 1.35em) !important;
  max-height: calc(2 * 1.35em) !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-location {
  flex: 0 0 auto !important;
  min-height: 19px !important;
  max-height: 19px !important;
}
.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-footer {
  min-height: 51px !important;
}
@media (max-width: 760px) {
  .event-card.pj-event-card:not(.pj-event-card--explore) {
    width: 100% !important;
    max-width: 100% !important;
  }
}

/* PJ 1.5.182: actual mockup-size mobile cards, not oversized variable rows. */
@media (max-width: 760px) {
  .pj-archive-theme-scope.pj-archive-theme--events .pj-events-list {
    display: block !important;
    width: 100% !important;
    max-width: 398px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) {
    width: 100% !important;
    height: 202px !important;
    min-height: 202px !important;
    max-height: 202px !important;
    padding: 16px !important;
    margin: 0 0 16px !important;
    display: grid !important;
    grid-template-rows: 112px 42px !important;
    row-gap: 12px !important;
    overflow: hidden !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-main {
    display: grid !important;
    grid-template-columns: 112px minmax(0, 1fr) !important;
    gap: 14px !important;
    align-items: start !important;
    width: 100% !important;
    height: 112px !important;
    min-height: 112px !important;
    max-height: 112px !important;
    overflow: hidden !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-image,
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) a.event-card-image.pj-event-image-wrap {
    width: 112px !important;
    height: 112px !important;
    min-width: 112px !important;
    min-height: 112px !important;
    max-width: 112px !important;
    max-height: 112px !important;
    flex: 0 0 112px !important;
    border-radius: 16px !important;
    align-self: start !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-content {
    height: 112px !important;
    min-height: 112px !important;
    max-height: 112px !important;
    padding: 0 42px 0 0 !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-topline {
    flex: 0 0 26px !important;
    min-height: 26px !important;
    max-height: 26px !important;
    margin: 0 0 5px !important;
    overflow: visible !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-category-pill {
    min-height: 24px !important;
    height: 24px !important;
    padding: 3px 9px !important;
    font-size: 10.5px !important;
    letter-spacing: .07em !important;
    max-width: 100% !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-save-heart {
    position: absolute !important;
    top: 12px !important;
    right: 12px !important;
    width: 34px !important;
    height: 34px !important;
    min-width: 34px !important;
    min-height: 34px !important;
    font-size: 20px !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-text-link {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    height: 81px !important;
    max-height: 81px !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-title {
    font-size: 16.5px !important;
    line-height: 1.15 !important;
    min-height: 38px !important;
    max-height: 38px !important;
    margin: 0 0 4px !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-description {
    font-size: 13px !important;
    line-height: 1.25 !important;
    min-height: 32px !important;
    max-height: 32px !important;
    margin: 0 0 3px !important;
    overflow: hidden !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-location {
    font-size: 12.5px !important;
    line-height: 1.15 !important;
    min-height: 15px !important;
    max-height: 15px !important;
    overflow: hidden !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-location .pj-event-venue,
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-location .location-icon {
    font-size: 12.5px !important;
    line-height: 1.15 !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-footer {
    height: 42px !important;
    min-height: 42px !important;
    max-height: 42px !important;
    margin: 0 !important;
    padding: 9px 0 0 !important;
    border-top: 1px solid rgba(45,35,25,.08) !important;
    align-self: end !important;
    overflow: hidden !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-meta {
    font-size: 13.5px !important;
    gap: 6px !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-calendar-button {
    min-height: 32px !important;
    height: 32px !important;
    padding: 6px 11px !important;
    font-size: 13px !important;
  }
}
@media (max-width: 370px) {
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) {
    height: 194px !important;
    min-height: 194px !important;
    max-height: 194px !important;
    grid-template-rows: 104px 42px !important;
    row-gap: 12px !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-main {
    grid-template-columns: 104px minmax(0, 1fr) !important;
    height: 104px !important;
    min-height: 104px !important;
    max-height: 104px !important;
    gap: 12px !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-image,
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) a.event-card-image.pj-event-image-wrap {
    width: 104px !important;
    height: 104px !important;
    min-width: 104px !important;
    min-height: 104px !important;
    max-width: 104px !important;
    max-height: 104px !important;
    flex-basis: 104px !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-content {
    height: 104px !important;
    min-height: 104px !important;
    max-height: 104px !important;
  }
}

/* PJ 1.5.183: hard lock the visible /events cards to one mockup-sized component at every viewport. */
.pj-archive-theme-scope.pj-archive-theme--events .pj-events-list {
  display: block !important;
  width: 100% !important;
  max-width: 398px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) {
  box-sizing: border-box !important;
  width: 100% !important;
  max-width: 398px !important;
  height: 202px !important;
  min-height: 202px !important;
  max-height: 202px !important;
  padding: 16px !important;
  margin: 0 auto 16px !important;
  display: grid !important;
  grid-template-rows: 112px 42px !important;
  row-gap: 12px !important;
  overflow: hidden !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-main {
  display: grid !important;
  grid-template-columns: 112px minmax(0, 1fr) !important;
  gap: 14px !important;
  width: 100% !important;
  height: 112px !important;
  min-height: 112px !important;
  max-height: 112px !important;
  overflow: hidden !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-image,
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) a.event-card-image.pj-event-image-wrap {
  width: 112px !important;
  height: 112px !important;
  min-width: 112px !important;
  min-height: 112px !important;
  max-width: 112px !important;
  max-height: 112px !important;
  flex: 0 0 112px !important;
  border-radius: 16px !important;
  align-self: start !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-content {
  box-sizing: border-box !important;
  height: 112px !important;
  min-height: 112px !important;
  max-height: 112px !important;
  padding: 0 40px 0 0 !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-topline {
  flex: 0 0 24px !important;
  height: 24px !important;
  min-height: 24px !important;
  max-height: 24px !important;
  margin: 0 0 5px !important;
  overflow: visible !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-category-pill {
  height: 24px !important;
  min-height: 24px !important;
  padding: 3px 9px !important;
  font-size: 10.5px !important;
  line-height: 1 !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-save-heart {
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  width: 34px !important;
  height: 34px !important;
  min-width: 34px !important;
  min-height: 34px !important;
  font-size: 20px !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-text-link {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  height: 83px !important;
  max-height: 83px !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-title {
  font-size: 16.5px !important;
  line-height: 1.15 !important;
  height: 38px !important;
  min-height: 38px !important;
  max-height: 38px !important;
  margin: 0 0 4px !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-description {
  font-size: 13px !important;
  line-height: 1.25 !important;
  height: 32px !important;
  min-height: 32px !important;
  max-height: 32px !important;
  margin: 0 0 3px !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-location {
  font-size: 12.5px !important;
  line-height: 1.15 !important;
  height: 15px !important;
  min-height: 15px !important;
  max-height: 15px !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-location .pj-event-venue,
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-location .location-icon {
  font-size: 12.5px !important;
  line-height: 1.15 !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-footer {
  box-sizing: border-box !important;
  height: 42px !important;
  min-height: 42px !important;
  max-height: 42px !important;
  margin: 0 !important;
  padding: 9px 0 0 !important;
  border-top: 1px solid rgba(45,35,25,.08) !important;
  overflow: hidden !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-meta {
  font-size: 13.5px !important;
  gap: 6px !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-calendar-button {
  min-height: 32px !important;
  height: 32px !important;
  padding: 6px 11px !important;
  font-size: 13px !important;
}

/* PJ 1.5.184: stretch EventCard grid children across the full card content box. */
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) {
  justify-items: stretch !important;
  align-items: stretch !important;
  grid-template-columns: minmax(0, 1fr) !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) > .event-card-main,
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) > .event-card-footer {
  grid-column: 1 / -1 !important;
  justify-self: stretch !important;
  align-self: stretch !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* PJ 1.5.186: shared medium-compact EventCard component for Events/Home/Saved event cards. */
.pj-events-list,
.pj-featured-grid {
  padding-bottom: 110px;
}
.pj-event-card.event-card:not(.pj-event-card--explore),
.pj-saved-card--event.event-card {
  box-sizing: border-box !important;
  position: relative !important;
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  margin: 0 0 16px !important;
  padding: 16px !important;
  background: #FFFDF8 !important;
  border: 1px solid rgba(45, 35, 25, 0.08) !important;
  border-radius: 22px !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.04) !important;
  overflow: hidden !important;
  color: inherit !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) > .event-card-main,
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-main,
.pj-saved-card--event.event-card > .event-card-main,
.pj-saved-card--event.event-card .event-card-main {
  box-sizing: border-box !important;
  display: grid !important;
  grid-template-columns: 112px minmax(0, 1fr) !important;
  gap: 14px !important;
  align-items: start !important;
  width: 100% !important;
  min-width: 0 !important;
  height: auto !important;
  min-height: 112px !important;
  max-height: none !important;
  padding: 0 !important;
  margin: 0 !important;
  color: inherit !important;
  text-decoration: none !important;
  overflow: visible !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-image,
.pj-event-card.event-card:not(.pj-event-card--explore) .pj-event-image-wrap.event-card-image,
.pj-saved-card--event.event-card .event-card-image,
.pj-saved-card--event.event-card .pj-saved-card-media.event-card-image {
  box-sizing: border-box !important;
  display: block !important;
  position: relative !important;
  width: 112px !important;
  height: 112px !important;
  min-width: 112px !important;
  min-height: 112px !important;
  max-width: 112px !important;
  max-height: 112px !important;
  aspect-ratio: 1 / 1 !important;
  flex: 0 0 112px !important;
  border-radius: 16px !important;
  overflow: hidden !important;
  background: #F2EDE6 !important;
  align-self: start !important;
  margin: 0 !important;
  padding: 0 !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-image img,
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-image .pj-event-image,
.pj-saved-card--event.event-card .event-card-image img {
  display: block !important;
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  object-fit: cover !important;
  object-position: center !important;
  border-radius: 0 !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-content,
.pj-saved-card--event.event-card .event-card-content {
  box-sizing: border-box !important;
  display: flex !important;
  flex-direction: column !important;
  min-width: 0 !important;
  width: 100% !important;
  height: auto !important;
  min-height: 112px !important;
  max-height: none !important;
  padding: 0 38px 0 0 !important;
  margin: 0 !important;
  overflow: hidden !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-topline,
.pj-saved-card--event.event-card .event-card-topline {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 8px !important;
  min-height: 26px !important;
  max-height: 26px !important;
  margin: 0 0 6px !important;
  padding: 0 !important;
  overflow: hidden !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-category-pill,
.pj-saved-card--event.event-card .event-category-pill {
  box-sizing: border-box !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  max-width: 100% !important;
  min-height: 24px !important;
  padding: 4px 10px !important;
  border-radius: 999px !important;
  font-size: 11px !important;
  line-height: 1 !important;
  font-weight: 700 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-save-heart,
.pj-saved-card--event.event-card .pj-saved-remove,
.pj-saved-card--event.event-card .event-save-heart {
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  left: auto !important;
  bottom: auto !important;
  z-index: 5 !important;
  width: 36px !important;
  height: 36px !important;
  min-width: 36px !important;
  min-height: 36px !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 999px !important;
  border: 1px solid #E8D5CA !important;
  background: #FFFDF8 !important;
  color: #A9482B !important;
  box-shadow: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  transform: none !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-text-link {
  display: block !important;
  min-width: 0 !important;
  color: inherit !important;
  text-decoration: none !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-title,
.pj-saved-card--event.event-card .event-card-title {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  margin: 0 0 5px !important;
  max-height: calc(2 * 1.18em) !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  color: #111827 !important;
  font-size: 18px !important;
  line-height: 1.18 !important;
  font-weight: 700 !important;
  letter-spacing: -0.01em !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-description,
.pj-saved-card--event.event-card .event-card-description {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  margin: 0 0 6px !important;
  max-height: calc(2 * 1.35em) !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  color: #667085 !important;
  font-size: 14px !important;
  line-height: 1.35 !important;
  font-weight: 500 !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-location,
.pj-saved-card--event.event-card .event-card-location {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 6px !important;
  min-width: 0 !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  color: #667085 !important;
  font-size: 13.5px !important;
  line-height: 1.25 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-location .pj-event-venue,
.pj-saved-card--event.event-card .event-card-location span {
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) > .event-card-footer,
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-footer,
.pj-saved-card--event.event-card > .event-card-footer,
.pj-saved-card--event.event-card .event-card-footer {
  box-sizing: border-box !important;
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  width: 100% !important;
  min-width: 0 !important;
  height: auto !important;
  min-height: 48px !important;
  max-height: none !important;
  margin: 14px 0 0 !important;
  padding: 10px 0 0 !important;
  border-top: 1px solid rgba(45, 35, 25, 0.08) !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: hidden !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-meta {
  display: flex !important;
  align-items: center !important;
  gap: 7px !important;
  min-width: 0 !important;
  overflow: hidden !important;
  white-space: nowrap !important;
  color: #4B352B !important;
  font-size: 14.5px !important;
  line-height: 1.2 !important;
  font-weight: 650 !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-meta .pj-event-time,
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-meta .pj-event-price {
  display: inline !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  background: transparent !important;
  color: inherit !important;
  font: inherit !important;
  white-space: nowrap !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-calendar-button,
.pj-saved-card--event.event-card .event-calendar-button {
  box-sizing: border-box !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 auto !important;
  min-height: 36px !important;
  height: 36px !important;
  padding: 7px 12px !important;
  border-radius: 999px !important;
  border: 1px solid #E2B8A8 !important;
  background: #FFF8F4 !important;
  color: #A9482B !important;
  box-shadow: none !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  font-size: 14px !important;
  font-weight: 750 !important;
  line-height: 1 !important;
}
/* Saved event cards keep Open/Calendar/Maps, but use the same event-card shell and image/text geometry. */
.pj-saved-card--event.event-card .pj-saved-card-actions a,
.pj-saved-card--event.event-card .pj-saved-card-actions button {
  min-height: 34px !important;
  height: 34px !important;
  padding: 6px 10px !important;
  border-radius: 999px !important;
  white-space: nowrap !important;
}
.pj-saved-card--event.event-card .pj-saved-note,
.pj-saved-card--event.event-card .pj-saved-plan-label {
  display: none !important;
}
@media (max-width: 760px) {
  .pj-archive-theme-scope.pj-archive-theme--events,
  .pj-home-shell,
  .pj-saved-shell,
  .pj-single-event {
    padding-bottom: calc(110px + env(safe-area-inset-bottom, 0px)) !important;
  }
  .pj-featured-grid {
    display: block !important;
  }
}
@media (max-width: 370px) {
  .pj-event-card.event-card:not(.pj-event-card--explore),
  .pj-saved-card--event.event-card {
    padding: 14px !important;
  }
  .pj-event-card.event-card:not(.pj-event-card--explore) > .event-card-main,
  .pj-event-card.event-card:not(.pj-event-card--explore) .event-card-main,
  .pj-saved-card--event.event-card > .event-card-main,
  .pj-saved-card--event.event-card .event-card-main {
    grid-template-columns: 104px minmax(0, 1fr) !important;
    gap: 12px !important;
    min-height: 104px !important;
  }
  .pj-event-card.event-card:not(.pj-event-card--explore) .event-card-image,
  .pj-saved-card--event.event-card .event-card-image {
    width: 104px !important;
    height: 104px !important;
    min-width: 104px !important;
    min-height: 104px !important;
    max-width: 104px !important;
    max-height: 104px !important;
    flex-basis: 104px !important;
  }
  .pj-event-card.event-card:not(.pj-event-card--explore) .event-card-content,
  .pj-saved-card--event.event-card .event-card-content {
    min-height: 104px !important;
    padding-right: 34px !important;
  }
  .pj-event-card.event-card:not(.pj-event-card--explore) .event-card-title,
  .pj-saved-card--event.event-card .event-card-title {
    font-size: 16.5px !important;
  }
  .pj-event-card.event-card:not(.pj-event-card--explore) .event-card-description,
  .pj-saved-card--event.event-card .event-card-description {
    font-size: 13px !important;
  }
  .pj-event-card.event-card:not(.pj-event-card--explore) .event-calendar-button,
  .pj-saved-card--event.event-card .event-calendar-button {
    min-height: 34px !important;
    height: 34px !important;
    padding: 6px 10px !important;
    font-size: 13px !important;
  }
}

/* PJ 1.5.186b: beat older high-specificity homepage heart/static overrides. */
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) > .event-save-heart.pj-save-heart.pj-save-heart--event,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) button.event-save-heart.pj-save-heart.pj-save-heart--event,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .event-save-heart.pj-save-heart.pj-save-heart--event {
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  left: auto !important;
  bottom: auto !important;
  width: 36px !important;
  height: 36px !important;
  min-width: 36px !important;
  min-height: 36px !important;
  transform: none !important;
}
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .pj-card-link.event-card-main {
  display: grid !important;
  grid-template-columns: 112px minmax(0, 1fr) !important;
  gap: 14px !important;
  min-height: 112px !important;
  align-items: start !important;
}
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .pj-event-meta-right.event-card-footer {
  position: static !important;
  flex: none !important;
  width: 100% !important;
  min-height: 48px !important;
  padding: 10px 0 0 !important;
  margin-top: 14px !important;
  border-left: 0 !important;
}

/* PJ 1.5.187: final medium-compact event card sizing — fixed content slots, 112 image, consistent card height. */
.pj-event-card.event-card:not(.pj-event-card--explore),
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore),
.pj-saved-card--event.event-card {
  height: 250px !important;
  min-height: 250px !important;
  max-height: 250px !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) > .event-card-main,
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-main,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .pj-card-link.event-card-main,
.pj-saved-card--event.event-card .event-card-main {
  height: 156px !important;
  min-height: 156px !important;
  max-height: 156px !important;
  display: grid !important;
  grid-template-columns: 112px minmax(0, 1fr) !important;
  gap: 14px !important;
  align-items: start !important;
  overflow: hidden !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-content,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .event-card-content,
.pj-saved-card--event.event-card .event-card-content {
  height: 156px !important;
  min-height: 156px !important;
  max-height: 156px !important;
  overflow: hidden !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-title,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .event-card-title,
.pj-saved-card--event.event-card .event-card-title {
  height: 42px !important;
  min-height: 42px !important;
  max-height: 42px !important;
  font-size: 17.5px !important;
  line-height: 1.18 !important;
  margin: 0 0 5px !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-description,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .event-card-description,
.pj-saved-card--event.event-card .event-card-description {
  height: 38px !important;
  min-height: 38px !important;
  max-height: 38px !important;
  font-size: 14px !important;
  line-height: 1.35 !important;
  margin: 0 0 6px !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-location,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .event-card-location,
.pj-saved-card--event.event-card .event-card-location {
  height: 18px !important;
  min-height: 18px !important;
  max-height: 18px !important;
}
.pj-event-card.event-card:not(.pj-event-card--explore) > .event-card-footer,
.pj-event-card.event-card:not(.pj-event-card--explore) .event-card-footer,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .pj-event-meta-right.event-card-footer,
.pj-saved-card--event.event-card .event-card-footer {
  height: 48px !important;
  min-height: 48px !important;
  max-height: 48px !important;
  margin-top: 12px !important;
  padding-top: 10px !important;
}
@media (max-width: 370px) {
  .pj-event-card.event-card:not(.pj-event-card--explore),
  .pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore),
  .pj-saved-card--event.event-card {
    height: 242px !important;
    min-height: 242px !important;
    max-height: 242px !important;
  }
  .pj-event-card.event-card:not(.pj-event-card--explore) > .event-card-main,
  .pj-event-card.event-card:not(.pj-event-card--explore) .event-card-main,
  .pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .pj-card-link.event-card-main,
  .pj-saved-card--event.event-card .event-card-main {
    grid-template-columns: 104px minmax(0, 1fr) !important;
    gap: 12px !important;
    height: 154px !important;
    min-height: 154px !important;
    max-height: 154px !important;
  }
  .pj-event-card.event-card:not(.pj-event-card--explore) .event-card-content,
  .pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .event-card-content,
  .pj-saved-card--event.event-card .event-card-content {
    height: 154px !important;
    min-height: 154px !important;
    max-height: 154px !important;
  }
}

/* PJ 1.5.188b: override old /events-only 202px hardlock with the final medium card. */
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) {
  height: 250px !important;
  min-height: 250px !important;
  max-height: 250px !important;
  display: block !important;
  padding: 16px !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) > .event-card-main,
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-main {
  height: 156px !important;
  min-height: 156px !important;
  max-height: 156px !important;
  display: grid !important;
  grid-template-columns: 112px minmax(0, 1fr) !important;
  gap: 14px !important;
  align-items: start !important;
  overflow: hidden !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-content {
  height: 156px !important;
  min-height: 156px !important;
  max-height: 156px !important;
  padding: 0 38px 0 0 !important;
  overflow: hidden !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-topline > .event-save-heart.pj-save-heart.pj-save-heart--event,
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) button.event-save-heart.pj-save-heart.pj-save-heart--event,
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-save-heart.pj-save-heart.pj-save-heart--event {
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  left: auto !important;
  bottom: auto !important;
  width: 36px !important;
  height: 36px !important;
  min-width: 36px !important;
  min-height: 36px !important;
  transform: none !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-title {
  height: 42px !important;
  min-height: 42px !important;
  max-height: 42px !important;
  font-size: 17.5px !important;
  line-height: 1.18 !important;
  margin: 0 0 5px !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-description {
  height: 38px !important;
  min-height: 38px !important;
  max-height: 38px !important;
  font-size: 14px !important;
  line-height: 1.35 !important;
  margin: 0 0 6px !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-location {
  height: 18px !important;
  min-height: 18px !important;
  max-height: 18px !important;
  font-size: 13.5px !important;
  line-height: 1.25 !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) > .event-card-footer,
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-footer {
  height: 48px !important;
  min-height: 48px !important;
  max-height: 48px !important;
  margin-top: 12px !important;
  padding-top: 10px !important;
}
@media (max-width: 370px) {
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) {
    height: 242px !important;
    min-height: 242px !important;
    max-height: 242px !important;
    padding: 14px !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) > .event-card-main,
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-main {
    grid-template-columns: 104px minmax(0, 1fr) !important;
    gap: 12px !important;
    height: 154px !important;
    min-height: 154px !important;
    max-height: 154px !important;
  }
}

/* PJ 1.5.189b: small-mobile image fallback must be 104px everywhere, including /events page-scoped rules. */
@media (max-width: 370px) {
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-image,
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) a.event-card-image.pj-event-image-wrap,
  .pj-event-card.event-card:not(.pj-event-card--explore) .event-card-image,
  .pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .event-card-image,
  .pj-saved-card--event.event-card .event-card-image {
    width: 104px !important;
    height: 104px !important;
    min-width: 104px !important;
    min-height: 104px !important;
    max-width: 104px !important;
    max-height: 104px !important;
    flex: 0 0 104px !important;
  }
}

/* PJ 1.5.194: EventCard FINAL v5 from supplied DOCX/asset ZIP.
   Build with real HTML/CSS/SVG assets; no static text-image card. */
:root {
  --pj-v5-rust: #b24a2b;
  --pj-v5-rust-dark: #9e3f25;
  --pj-v5-green: #2f7d32;
  --pj-v5-cream: #fffdf8;
  --pj-v5-soft: #f2ede6;
  --pj-v5-border: rgba(45, 35, 25, 0.08);
  --pj-v5-divider: #e9ded3;
}
.pj-archive-theme-scope.pj-archive-theme--events .pj-events-list {
  width: 100% !important;
  max-width: 390px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-bottom: calc(110px + env(safe-area-inset-bottom, 0px)) !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore),
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore),
.pj-saved-card--event.event-card {
  box-sizing: border-box !important;
  position: relative !important;
  display: grid !important;
  grid-template-columns: 112px minmax(0, 1fr) !important;
  gap: 14px !important;
  width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  padding: 16px !important;
  margin: 0 0 16px !important;
  border-radius: 22px !important;
  background: var(--pj-v5-cream) !important;
  border: 1px solid var(--pj-v5-border) !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.04) !important;
  overflow: hidden !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) > .event-card-main,
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-main,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .pj-card-link.event-card-main,
.pj-saved-card--event.event-card .event-card-main,
.pj-saved-card--event.event-card .pj-saved-card-link.event-card-main {
  display: contents !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: visible !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-image,
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) a.event-card-image.pj-event-image-wrap,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .event-card-image,
.pj-saved-card--event.event-card .event-card-image,
.pj-saved-card--event.event-card .pj-saved-card-media.event-card-image {
  box-sizing: border-box !important;
  display: block !important;
  position: relative !important;
  grid-column: 1 !important;
  width: 112px !important;
  height: 112px !important;
  min-width: 112px !important;
  min-height: 112px !important;
  max-width: 112px !important;
  max-height: 112px !important;
  aspect-ratio: 1 / 1 !important;
  border-radius: 16px !important;
  overflow: hidden !important;
  background: var(--pj-v5-soft) !important;
  margin: 0 !important;
  padding: 0 !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-image img,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .event-card-image img,
.pj-saved-card--event.event-card .event-card-image img,
.pj-saved-card--event.event-card .pj-saved-card-media img {
  position: absolute !important;
  inset: 0 !important;
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  object-fit: cover !important;
  object-position: center !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-content,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .event-card-content,
.pj-saved-card--event.event-card .event-card-content,
.pj-saved-card--event.event-card .pj-saved-card-body.event-card-content {
  box-sizing: border-box !important;
  grid-column: 2 !important;
  min-width: 0 !important;
  width: 100% !important;
  height: auto !important;
  min-height: 112px !important;
  max-height: none !important;
  position: relative !important;
  padding: 0 58px 0 0 !important;
  margin: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
  gap: 0 !important;
  overflow: visible !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-topline,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .event-card-topline,
.pj-saved-card--event.event-card .event-card-topline,
.pj-saved-card--event.event-card .pj-saved-card-topline {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 8px !important;
  min-height: 32px !important;
  height: 32px !important;
  max-height: 32px !important;
  margin: 0 0 6px !important;
  padding: 0 !important;
  overflow: hidden !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-category-pill,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .event-category-pill,
.pj-saved-card--event.event-card .event-category-pill,
.pj-saved-card--event.event-card .pj-saved-kind {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 32px !important;
  height: 32px !important;
  max-height: 32px !important;
  max-width: 100% !important;
  padding: 0 12px !important;
  border-radius: 999px !important;
  font-size: 10.5px !important;
  line-height: 1 !important;
  font-weight: 800 !important;
  letter-spacing: .07em !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-heart,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .event-card-heart,
.pj-saved-card--event.event-card .event-card-heart,
.pj-saved-card--event.event-card .pj-saved-remove {
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  left: auto !important;
  bottom: auto !important;
  width: 50px !important;
  height: 50px !important;
  min-width: 50px !important;
  min-height: 50px !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 999px !important;
  border: 1px solid #e8b4a2 !important;
  background: rgba(255,253,248,.94) !important;
  color: var(--pj-v5-rust) !important;
  box-shadow: none !important;
  transform: none !important;
  z-index: 5 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 0 !important;
}
.event-card-heart > span,
.pj-saved-remove > span {
  display: block !important;
  width: 23px !important;
  height: 23px !important;
  background-color: currentColor !important;
  -webkit-mask: url('assets/event-card-v5/heart_outline.svg') center / contain no-repeat !important;
  mask: url('assets/event-card-v5/heart_outline.svg') center / contain no-repeat !important;
}
.pj-save-heart.is-saved.event-card-heart > span,
.pj-saved-remove.is-saved > span {
  -webkit-mask: url('assets/event-card-v5/heart_outline.svg') center / contain no-repeat !important;
  mask: url('assets/event-card-v5/heart_outline.svg') center / contain no-repeat !important;
  background-color: #b41f2b !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-title,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .event-card-title,
.pj-saved-card--event.event-card .event-card-title,
.pj-saved-card--event.event-card .pj-saved-card-title {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: calc(2 * 1.18em) !important;
  margin: 0 0 6px !important;
  overflow: hidden !important;
  color: #111827 !important;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
  font-size: 17.5px !important;
  line-height: 1.18 !important;
  font-weight: 700 !important;
  letter-spacing: -0.01em !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-description,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .event-card-description,
.pj-saved-card--event.event-card .event-card-description,
.pj-saved-card--event.event-card .pj-saved-card-hint {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: calc(2 * 1.35em) !important;
  margin: 0 0 7px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: hidden !important;
  color: #667085 !important;
  font-size: 13.5px !important;
  line-height: 1.35 !important;
  font-weight: 500 !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
}
.event-card-text-link {
  min-width: 0 !important;
  color: inherit !important;
  text-decoration: none !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-venue,
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-location,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .event-card-location,
.pj-saved-card--event.event-card .event-card-location,
.pj-saved-card--event.event-card .pj-saved-card-meta {
  display: flex !important;
  align-items: center !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  gap: 7px !important;
  min-height: 20px !important;
  height: 20px !important;
  max-height: 20px !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  color: #667085 !important;
  font-size: 13.5px !important;
  line-height: 1.25 !important;
  white-space: nowrap !important;
  text-overflow: ellipsis !important;
}
.event-card-location .pj-event-venue,
.pj-saved-card-meta span {
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  display: block !important;
}
.location-icon,
.pj-venue-icon.location-icon {
  flex: 0 0 auto !important;
  width: 18px !important;
  height: 18px !important;
  display: inline-block !important;
  color: #c7352f !important;
  background-color: currentColor !important;
  font-size: 0 !important;
  -webkit-mask: url('assets/event-card-v5/pin.svg') center / contain no-repeat !important;
  mask: url('assets/event-card-v5/pin.svg') center / contain no-repeat !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-bottom,
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-footer,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .event-card-bottom,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .event-card-footer,
.pj-saved-card--event.event-card .event-card-bottom,
.pj-saved-card--event.event-card .event-card-footer {
  box-sizing: border-box !important;
  grid-column: 1 / -1 !important;
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  width: 100% !important;
  min-width: 0 !important;
  height: auto !important;
  min-height: 42px !important;
  max-height: none !important;
  margin: 12px 0 0 !important;
  padding: 12px 0 0 !important;
  border-top: 1px solid var(--pj-v5-divider) !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: hidden !important;
}
.event-card-meta {
  display: flex !important;
  align-items: center !important;
  gap: 7px !important;
  min-width: 0 !important;
  overflow: hidden !important;
  white-space: nowrap !important;
  color: #2f2f34 !important;
  font-size: 14px !important;
  line-height: 1.2 !important;
  font-weight: 700 !important;
}
.event-card-meta .time-icon {
  flex: 0 0 auto !important;
  width: 18px !important;
  height: 18px !important;
  display: inline-block !important;
  color: #8a5b4a !important;
  background-color: currentColor !important;
  font-size: 0 !important;
  -webkit-mask: url('assets/event-card-v5/clock.svg') center / contain no-repeat !important;
  mask: url('assets/event-card-v5/clock.svg') center / contain no-repeat !important;
}
.event-card-meta .dot { color: #b9aaa0 !important; font-weight: 800 !important; }
.event-card-meta .pj-event-price.pj-free,
.event-card-meta .pj-event-price { font-weight: 800 !important; }
.event-card-meta .pj-event-price.pj-free { color: var(--pj-v5-green) !important; }
.event-card-calendar,
.event-calendar-button {
  box-sizing: border-box !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  flex: 0 0 auto !important;
  min-width: 118px !important;
  min-height: 38px !important;
  height: 38px !important;
  padding: 7px 12px !important;
  border-radius: 999px !important;
  border: 1px solid #e8b4a2 !important;
  background: var(--pj-v5-cream) !important;
  color: var(--pj-v5-rust) !important;
  box-shadow: none !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  font-size: 13.5px !important;
  font-weight: 800 !important;
  line-height: 1 !important;
}
.event-card-calendar-icon,
.event-card-calendar svg {
  flex: 0 0 auto !important;
  width: 18px !important;
  height: 18px !important;
  display: inline-block !important;
}
.event-card-calendar-icon {
  background-color: currentColor !important;
  -webkit-mask: url('assets/event-card-v5/calendar_centered.svg') center / contain no-repeat !important;
  mask: url('assets/event-card-v5/calendar_centered.svg') center / contain no-repeat !important;
}
/* V5 filter/button element styling from asset set: real CSS/SVG, not PNG labels. */
.pj-archive-theme-scope.pj-archive-theme--events .pj-filter-chip,
.pj-archive-theme-scope.pj-archive-theme--events .pj-filter-pill,
.pj-archive-theme-scope.pj-archive-theme--events .pj-more-filters summary,
.pj-archive-theme-scope.pj-archive-theme--events .pj-date-toggle,
.pj-archive-theme-scope.pj-archive-theme--events .pj-date-button {
  min-height: 50px !important;
  border-radius: 999px !important;
  align-items: center !important;
}
.pj-submit-event,
.pj-hero-submit,
a[href*="submit-event"] {
  border-radius: 999px !important;
}
@media (max-width: 370px) {
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore),
  .pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore),
  .pj-saved-card--event.event-card {
    grid-template-columns: 104px minmax(0, 1fr) !important;
    gap: 12px !important;
    padding: 14px !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-image,
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) a.event-card-image.pj-event-image-wrap,
  .pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .event-card-image,
  .pj-saved-card--event.event-card .event-card-image,
  .pj-saved-card--event.event-card .pj-saved-card-media.event-card-image {
    width: 104px !important;
    height: 104px !important;
    min-width: 104px !important;
    min-height: 104px !important;
    max-width: 104px !important;
    max-height: 104px !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-content,
  .pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .event-card-content,
  .pj-saved-card--event.event-card .event-card-content {
    min-height: 104px !important;
    padding-right: 54px !important;
  }
  .event-card-calendar,
  .event-calendar-button {
    min-width: 110px !important;
    padding-left: 10px !important;
    padding-right: 10px !important;
  }
}

/* PJ 1.5.194b: win over legacy heart/calendar high-specificity rules for v5 assets. */
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-content > button.event-card-heart.event-save-heart.pj-save-heart.pj-save-heart--event,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) > button.event-card-heart.event-save-heart.pj-save-heart.pj-save-heart--event,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) > button.event-card-heart.pj-save-heart.pj-save-heart--event,
.pj-saved-card--event.event-card > button.event-card-heart.pj-save-heart.pj-saved-remove {
  width: 50px !important;
  height: 50px !important;
  min-width: 50px !important;
  min-height: 50px !important;
  max-width: 50px !important;
  max-height: 50px !important;
  padding: 0 !important;
  border: 1px solid #e8b4a2 !important;
  border-radius: 999px !important;
  background: rgba(255,253,248,.94) !important;
  color: var(--pj-v5-rust) !important;
  box-shadow: none !important;
  transform: none !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-content > button.event-card-heart.event-save-heart.pj-save-heart.pj-save-heart--event {
  top: 0 !important;
  right: 0 !important;
}
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) > button.event-card-heart.event-save-heart.pj-save-heart.pj-save-heart--event,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) > button.event-card-heart.pj-save-heart.pj-save-heart--event,
.pj-saved-card--event.event-card > button.event-card-heart.pj-save-heart.pj-saved-remove {
  top: 12px !important;
  right: 12px !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) a.event-card-calendar.event-calendar-button.pj-add-calendar-link,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) a.event-card-calendar.event-calendar-button.pj-add-calendar-link,
.pj-saved-card--event.event-card a.event-card-calendar.event-calendar-button,
.pj-saved-card--event.event-card a.pj-saved-calendar.event-card-calendar.event-calendar-button {
  min-width: 118px !important;
  width: auto !important;
  height: 38px !important;
  min-height: 38px !important;
  max-height: 38px !important;
  padding: 7px 12px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  border: 1px solid #e8b4a2 !important;
  border-radius: 999px !important;
  background: var(--pj-v5-cream) !important;
  color: var(--pj-v5-rust) !important;
  font-size: 13.5px !important;
  font-weight: 800 !important;
  line-height: 1 !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) .event-card-calendar-icon,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) .event-card-calendar-icon,
.pj-saved-card--event.event-card .event-card-calendar-icon {
  width: 18px !important;
  height: 18px !important;
  flex: 0 0 18px !important;
}

/* PJ 1.5.195b: v5 saved-heart state must not shrink to the old 36px circle. */
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-topline button.event-card-heart.event-save-heart.pj-save-heart.pj-save-heart--event,
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-topline button.event-card-heart.event-save-heart.pj-save-heart.pj-save-heart--event.is-saved,
body .pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) button.event-card-heart.event-save-heart.pj-save-heart.pj-save-heart--event.is-saved {
  width: 50px !important;
  height: 50px !important;
  min-width: 50px !important;
  min-height: 50px !important;
  max-width: 50px !important;
  max-height: 50px !important;
  top: 0 !important;
  right: 0 !important;
  background: rgba(255,253,248,.94) !important;
  color: var(--pj-v5-rust) !important;
  border: 1px solid #e8b4a2 !important;
}

/* PJ 1.5.196b: existing WordPress markup has .event-card-main wrapper; make that the v5 grid to remove phantom row. */
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore),
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore),
.pj-saved-card--event.event-card {
  display: block !important;
}
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) > .event-card-main,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) > .event-card-main,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) > .pj-card-link.event-card-main,
.pj-saved-card--event.event-card > .event-card-main,
.pj-saved-card--event.event-card > .pj-saved-card-link.event-card-main {
  box-sizing: border-box !important;
  display: grid !important;
  grid-template-columns: 112px minmax(0, 1fr) !important;
  gap: 14px !important;
  align-items: start !important;
  width: 100% !important;
  height: auto !important;
  min-height: 112px !important;
  max-height: none !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: visible !important;
}
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) > .event-card-bottom,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) > .event-card-bottom,
.pj-saved-card--event.event-card > .event-card-bottom {
  grid-column: auto !important;
}
@media (max-width: 370px) {
  .pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) > .event-card-main,
  .pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) > .event-card-main,
  .pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) > .pj-card-link.event-card-main,
  .pj-saved-card--event.event-card > .event-card-main,
  .pj-saved-card--event.event-card > .pj-saved-card-link.event-card-main {
    grid-template-columns: 104px minmax(0, 1fr) !important;
    gap: 12px !important;
    min-height: 104px !important;
  }
}

/* PJ 1.5.198: tighten v5 element-sheet sizing for calendar/filter/date/submit controls. */
.event-card-calendar,
.event-calendar-button,
.pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) a.event-card-calendar.event-calendar-button.pj-add-calendar-link,
.pj-event-card.event-card.pj-home-best-card:not(.pj-event-card--explore) a.event-card-calendar.event-calendar-button.pj-add-calendar-link {
  min-width: 142px !important;
  width: 142px !important;
  height: 42px !important;
  min-height: 42px !important;
  max-height: 42px !important;
  padding: 7px 12px !important;
}
.event-card-calendar-icon,
.event-card-calendar svg {
  width: 18px !important;
  height: 18px !important;
  flex: 0 0 18px !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .event-card-footer,
.pj-archive-theme-scope.pj-archive-theme--events .event-card-bottom {
  min-height: 54px !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .pj-primary-filter-bar .pj-category-tab,
.pj-archive-theme-scope.pj-archive-theme--events .pj-primary-filter-bar .pj-filter-chip {
  box-sizing: border-box !important;
  min-height: 50px !important;
  height: 50px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 18px !important;
  font-weight: 800 !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .pj-primary-filter-bar .pj-category-tab.active,
.pj-archive-theme-scope.pj-archive-theme--events .pj-primary-filter-bar .pj-filter-chip.active {
  background: var(--pj-v5-rust) !important;
  color: #fff !important;
  border-color: var(--pj-v5-rust) !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .pj-events-filter-actions .pj-more-filters > summary {
  box-sizing: border-box !important;
  min-width: 210px !important;
  min-height: 50px !important;
  height: 50px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  padding: 0 20px !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .pj-events-filter-actions .pj-more-filters > summary::before {
  content: '' !important;
  width: 18px !important;
  height: 18px !important;
  flex: 0 0 18px !important;
  display: inline-block !important;
  background-color: currentColor !important;
  -webkit-mask: url('assets/event-card-v5/sliders.svg') center / contain no-repeat !important;
  mask: url('assets/event-card-v5/sliders.svg') center / contain no-repeat !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .pj-filter-chip--date[data-pj-date-open] {
  box-sizing: border-box !important;
  min-width: 146px !important;
  min-height: 50px !important;
  height: 50px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 9px !important;
  padding: 0 18px !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .pj-filter-chip--date[data-pj-date-open]::before {
  content: '' !important;
  width: 18px !important;
  height: 18px !important;
  flex: 0 0 18px !important;
  display: inline-block !important;
  background-color: currentColor !important;
  -webkit-mask: url('assets/event-card-v5/calendar_centered.svg') center / contain no-repeat !important;
  mask: url('assets/event-card-v5/calendar_centered.svg') center / contain no-repeat !important;
}
.pj-submit-event-cta {
  box-sizing: border-box !important;
  min-width: 210px !important;
  min-height: 58px !important;
  height: 58px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  padding: 0 24px !important;
  font-weight: 850 !important;
}
@media (max-width: 370px) {
  .event-card-calendar,
  .event-calendar-button,
  .pj-archive-theme-scope.pj-archive-theme--events .event-card.pj-event-card:not(.pj-event-card--explore) a.event-card-calendar.event-calendar-button.pj-add-calendar-link {
    min-width: 132px !important;
    width: 132px !important;
  }
}

/* PJ 1.5.199: match supplied full-page EventCard mockup — header row, controls, date header. */
.pj-archive-theme-scope.pj-archive-theme--events .pj-archive-header {
  box-sizing: border-box !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  grid-template-areas:
    "title cta"
    "subhead subhead" !important;
  align-items: center !important;
  gap: 8px 12px !important;
  width: calc(100% - 32px) !important;
  max-width: 390px !important;
  margin: 14px auto 14px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  text-align: left !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .pj-archive-title {
  grid-area: title !important;
  margin: 0 !important;
  color: #1f1a17 !important;
  font-family: var(--font-serif) !important;
  font-size: clamp(27px, 7vw, 34px) !important;
  line-height: .98 !important;
  letter-spacing: -0.02em !important;
  white-space: normal !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .pj-archive-subhead {
  grid-area: subhead !important;
  margin: 0 !important;
  color: #6f6257 !important;
  font-size: 14px !important;
  line-height: 1.35 !important;
  max-width: 30rem !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .pj-archive-conversion-row {
  grid-area: cta !important;
  margin: 0 !important;
  display: flex !important;
  justify-content: flex-end !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .pj-submit-event-cta {
  min-width: 142px !important;
  width: 142px !important;
  height: 46px !important;
  min-height: 46px !important;
  padding: 0 15px !important;
  border-radius: 999px !important;
  background: var(--pj-v5-rust) !important;
  color: #fff !important;
  font-size: 13px !important;
  line-height: 1 !important;
  font-weight: 850 !important;
  box-shadow: 0 8px 18px rgba(178,74,43,.18) !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .pj-submit-event-cta::before {
  content: '' !important;
  width: 17px !important;
  height: 17px !important;
  flex: 0 0 17px !important;
  display: inline-block !important;
  background-color: currentColor !important;
  -webkit-mask: url('assets/event-card-v5/calendar_centered.svg') center / contain no-repeat !important;
  mask: url('assets/event-card-v5/calendar_centered.svg') center / contain no-repeat !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .pj-filter-stack {
  width: calc(100% - 32px) !important;
  max-width: 390px !important;
  margin: 0 auto 18px !important;
  padding: 0 !important;
  background: transparent !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .pj-primary-filter-bar,
.pj-archive-theme-scope.pj-archive-theme--events .pj-events-filter-actions {
  background: transparent !important;
  padding: 0 0 8px 0 !important;
  gap: 8px !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .pj-events-filter-actions {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: center !important;
  overflow: visible !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .pj-events-filter-actions .pj-more-filters,
.pj-archive-theme-scope.pj-archive-theme--events .pj-events-filter-actions .pj-date-form {
  min-width: 0 !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .pj-events-filter-actions .pj-more-filters > summary {
  min-width: 0 !important;
  width: 100% !important;
  height: 50px !important;
  justify-content: center !important;
  position: relative !important;
  padding: 0 38px 0 18px !important;
  border: 1px solid rgba(45,35,25,.10) !important;
  box-shadow: 0 4px 12px rgba(58,37,22,.035) !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .pj-events-filter-actions .pj-more-filters > summary::after {
  content: '' !important;
  position: absolute !important;
  right: 16px !important;
  top: 50% !important;
  width: 14px !important;
  height: 14px !important;
  transform: translateY(-50%) !important;
  background-color: currentColor !important;
  -webkit-mask: url('assets/event-card-v5/icon_chevron_down_slate.png') center / contain no-repeat !important;
  mask: url('assets/event-card-v5/icon_chevron_down_slate.png') center / contain no-repeat !important;
  opacity: .85 !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .pj-filter-chip--date[data-pj-date-open] {
  min-width: 146px !important;
  width: 146px !important;
  height: 50px !important;
  border: 1px solid rgba(45,35,25,.10) !important;
  box-shadow: 0 4px 12px rgba(58,37,22,.035) !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .pj-section-label {
  width: calc(100% - 32px) !important;
  max-width: 390px !important;
  margin: 8px auto 12px !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  gap: 9px !important;
  color: #4b352b !important;
  font-size: 13px !important;
  line-height: 1.2 !important;
  font-weight: 850 !important;
  letter-spacing: .01em !important;
  text-transform: none !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .pj-section-label-icon {
  width: 28px !important;
  height: 28px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: #fff3ec !important;
  color: var(--pj-v5-rust) !important;
  flex: 0 0 28px !important;
}
.pj-archive-theme-scope.pj-archive-theme--events .pj-section-label-icon svg {
  width: 15px !important;
  height: 15px !important;
}
@media (min-width: 560px) {
  .pj-archive-theme-scope.pj-archive-theme--events .pj-archive-header,
  .pj-archive-theme-scope.pj-archive-theme--events .pj-filter-stack,
  .pj-archive-theme-scope.pj-archive-theme--events .pj-section-label,
  .pj-archive-theme-scope.pj-archive-theme--events .pj-events-list {
    max-width: 900px !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .pj-submit-event-cta {
    width: 210px !important;
    height: 58px !important;
    min-height: 58px !important;
    font-size: 14px !important;
  }
}
@media (max-width: 370px) {
  .pj-archive-theme-scope.pj-archive-theme--events .pj-archive-header,
  .pj-archive-theme-scope.pj-archive-theme--events .pj-filter-stack,
  .pj-archive-theme-scope.pj-archive-theme--events .pj-section-label {
    width: calc(100% - 28px) !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .pj-archive-title { font-size: 25px !important; }
  .pj-archive-theme-scope.pj-archive-theme--events .pj-submit-event-cta {
    min-width: 132px !important;
    width: 132px !important;
    height: 44px !important;
    font-size: 12px !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .pj-filter-chip--date[data-pj-date-open] {
    width: 132px !important;
    min-width: 132px !important;
  }
}

/* PJ 1.5.200: align mockup header/filter/date label to the same x-column as event cards. */
.pj-archive-theme-scope.pj-archive-theme--events .pj-archive-header,
.pj-archive-theme-scope.pj-archive-theme--events .pj-filter-stack,
.pj-archive-theme-scope.pj-archive-theme--events .pj-section-label {
  width: 100% !important;
  max-width: 390px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
@media (max-width: 559px) {
  .pj-archive-theme-scope.pj-archive-theme--events .pj-archive-header,
  .pj-archive-theme-scope.pj-archive-theme--events .pj-filter-stack,
  .pj-archive-theme-scope.pj-archive-theme--events .pj-section-label {
    width: auto !important;
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events .pj-archive-header { margin-top: 14px !important; margin-bottom: 14px !important; }
  .pj-archive-theme-scope.pj-archive-theme--events .pj-filter-stack { margin-top: 0 !important; margin-bottom: 18px !important; }
  .pj-archive-theme-scope.pj-archive-theme--events .pj-section-label { margin-top: 8px !important; margin-bottom: 12px !important; }
}

/* PJ 1.5.201: structural EventCard rebuild with named grid areas. Stop styling old stack layout. */
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) {
  display: grid !important;
  grid-template-columns: 112px minmax(0, 1fr) 48px !important;
  grid-template-areas:
    "image body heart"
    "bottom bottom bottom" !important;
  column-gap: 14px !important;
  row-gap: 12px !important;
  align-items: start !important;
  width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  padding: 16px !important;
  border-radius: 22px !important;
  background: #fffdf8 !important;
  border: 1px solid rgba(45, 35, 25, 0.08) !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.04) !important;
  overflow: hidden !important;
}
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) > .event-card-image {
  grid-area: image !important;
  width: 112px !important;
  height: 112px !important;
  min-width: 112px !important;
  min-height: 112px !important;
  max-width: 112px !important;
  max-height: 112px !important;
  border-radius: 16px !important;
  overflow: hidden !important;
  background: #f2ede6 !important;
  display: block !important;
  position: relative !important;
  padding: 0 !important;
  margin: 0 !important;
}
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) > .event-card-image img {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: cover !important;
  object-position: center !important;
  position: absolute !important;
  inset: 0 !important;
}
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) > .event-card-body {
  grid-area: body !important;
  min-width: 0 !important;
  padding: 0 4px 0 0 !important;
  margin: 0 !important;
  display: block !important;
  overflow: hidden !important;
}
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) > .event-card-heart {
  grid-area: heart !important;
  position: static !important;
  justify-self: end !important;
  align-self: start !important;
  width: 44px !important;
  height: 44px !important;
  min-width: 44px !important;
  min-height: 44px !important;
  max-width: 44px !important;
  max-height: 44px !important;
  border-radius: 999px !important;
  border: 1px solid #ead8d2 !important;
  background: #fffdf8 !important;
  color: #b24a2b !important;
  font-size: 24px !important;
  line-height: 1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  margin: 0 !important;
  box-shadow: none !important;
  transform: none !important;
}
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) > .event-card-heart > span {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: auto !important;
  height: auto !important;
  background: none !important;
  -webkit-mask: none !important;
  mask: none !important;
  font-size: 24px !important;
  line-height: 1 !important;
}
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-pills {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  margin: 0 0 6px !important;
  padding: 0 4px 0 0 !important;
  overflow: hidden !important;
}
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) .event-pill {
  display: inline-flex !important;
  align-items: center !important;
  height: 28px !important;
  min-height: 28px !important;
  max-height: 28px !important;
  padding: 0 12px !important;
  border-radius: 999px !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
}
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-title {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  color: #111827 !important;
  font-weight: 700 !important;
  line-height: 1.18 !important;
  text-decoration: none !important;
  margin: 0 !important;
  font-size: 17px !important;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
}
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-description {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  color: #667085 !important;
  line-height: 1.35 !important;
  margin: 6px 0 !important;
  font-size: 13.5px !important;
  font-weight: 500 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
}
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-venue {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  min-width: 0 !important;
  color: #667085 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  height: auto !important;
  max-height: 20px !important;
  margin: 0 !important;
  padding: 0 !important;
}
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-venue .pj-event-venue {
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) > .event-card-bottom {
  grid-area: bottom !important;
  border-top: 1px solid #e9ded3 !important;
  padding-top: 12px !important;
  margin-top: 2px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  width: 100% !important;
  min-width: 0 !important;
  min-height: 0 !important;
  height: auto !important;
  max-height: none !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: hidden !important;
}
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-meta {
  min-width: 0 !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  color: #111827 !important;
  font-weight: 650 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  font-size: 14px !important;
  line-height: 1.2 !important;
}
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-meta .price,
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-meta .pj-event-price.pj-free {
  color: #2f7a45 !important;
}
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-calendar {
  flex: 0 0 auto !important;
  width: auto !important;
  min-width: 0 !important;
  min-height: 38px !important;
  height: 38px !important;
  border-radius: 999px !important;
  border: 1px solid #e8b4a2 !important;
  background: #fffdf8 !important;
  color: #b24a2b !important;
  padding: 7px 12px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  white-space: nowrap !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  box-shadow: none !important;
  text-decoration: none !important;
}
@media (max-width: 370px) {
  .pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) {
    grid-template-columns: 104px minmax(0, 1fr) 44px !important;
    column-gap: 12px !important;
    padding: 14px !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) > .event-card-image {
    width: 104px !important;
    height: 104px !important;
    min-width: 104px !important;
    min-height: 104px !important;
    max-width: 104px !important;
    max-height: 104px !important;
  }
  .pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) .event-card-calendar {
    min-height: 36px !important;
    height: 36px !important;
    font-size: 13px !important;
    padding: 7px 10px !important;
  }
}

/* PJ 1.5.202: final structural grid-area cascade guards. */
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) > button.event-card-heart.event-save-heart.pj-save-heart.pj-save-heart--event,
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) > button.event-card-heart.event-save-heart.pj-save-heart.pj-save-heart--event.is-saved,
body .pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) > button.event-card-heart.pj-save-heart.pj-save-heart--event.is-saved {
  grid-area: heart !important;
  position: static !important;
  justify-self: end !important;
  align-self: start !important;
  width: 44px !important;
  height: 44px !important;
  min-width: 44px !important;
  min-height: 44px !important;
  max-width: 44px !important;
  max-height: 44px !important;
  border-radius: 999px !important;
  border: 1px solid #ead8d2 !important;
  background: #fffdf8 !important;
  color: #b24a2b !important;
  padding: 0 !important;
  margin: 0 !important;
  transform: none !important;
  box-shadow: none !important;
  font-size: 24px !important;
  line-height: 1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) > .event-card-bottom.event-card-footer {
  grid-area: bottom !important;
  width: 100% !important;
  min-height: 55px !important;
  height: 55px !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
}
.pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) > .event-card-bottom.event-card-footer .event-card-calendar {
  width: auto !important;
  min-width: 0 !important;
  height: 38px !important;
  min-height: 38px !important;
}

/* PJ 1.5.203: normalize all grid-area EventCard hearts to requested 44px, saved or unsaved. */
html body .pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) > button.event-card-heart,
html body .pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) > button.event-card-heart.is-saved,
html body .pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) > button.event-card-heart.pj-save-heart,
html body .pj-archive-theme-scope.pj-archive-theme--events article.event-card.pj-event-card:not(.pj-event-card--explore) > button.event-card-heart.pj-save-heart.is-saved {
  grid-area: heart !important;
  position: static !important;
  justify-self: end !important;
  align-self: start !important;
  width: 44px !important;
  height: 44px !important;
  min-width: 44px !important;
  min-height: 44px !important;
  max-width: 44px !important;
  max-height: 44px !important;
  border-radius: 999px !important;
  border: 1px solid #ead8d2 !important;
  background: #fffdf8 !important;
  color: #b24a2b !important;
}


/* Isolated-approved EventCard structure applied to dated Events cards (staging). */
.pj-events-list > .ps-event-card,
.ps-event-card {
  width: 100%;
  box-sizing: border-box;
  display: grid;
  grid-template-columns: 112px minmax(0, 1fr) 48px;
  grid-template-areas:
    "image body heart"
    "bottom bottom bottom";
  column-gap: 14px;
  row-gap: 12px;
  padding: 16px;
  border-radius: 22px;
  background: #fffdf8;
  border: 1px solid rgba(45, 35, 25, 0.08);
  box-shadow: 0 8px 24px rgba(0,0,0,0.04);
  overflow: hidden;
  margin: 0 0 16px;
}

.ps-event-image {
  grid-area: image;
  width: 112px;
  height: 112px;
  border-radius: 16px;
  overflow: hidden;
  background: #f2ede6;
  display: block;
  text-decoration: none;
}

.ps-event-image img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center;
}

.ps-event-body {
  grid-area: body;
  min-width: 0;
  height: 112px;
  padding-right: 2px;
  display: flex;
  flex-direction: column;
}

.ps-event-topline {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 5px;
  padding-right: 4px;
  flex: 0 0 auto;
}

.ps-event-pill {
  display: inline-flex;
  align-items: center;
  height: 24px;
  padding: 0 11px;
  border-radius: 999px;
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  white-space: nowrap;
}

.ps-event-title {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  color: #111827;
  font-size: 18.5px;
  font-weight: 750;
  line-height: 1.15;
  text-decoration: none;
  margin: 0;
  flex: 0 0 auto;
}

.ps-event-description {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin: 4px 0 0;
  color: #3f4652;
  font-size: 14px;
  line-height: 1.24;
  flex: 0 1 auto;
}

.ps-event-venue {
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
  color: #3f4652;
  font-size: 14px;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-top: auto;
  flex: 0 0 auto;
}

.ps-event-venue span:last-child {
  overflow: hidden;
  text-overflow: ellipsis;
}

.ps-pin,
.ps-clock,
.ps-calendar-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
}

.ps-pin {
  color: #c43e35;
}

.ps-pin svg {
  width: 13px;
  height: 17px;
  display: block;
}

.ps-event-card .ps-event-heart,
.ps-event-card .ps-event-heart.pj-save-heart,
.ps-event-card .ps-event-heart.pj-save-heart.is-saved {
  grid-area: heart;
  justify-self: end;
  align-self: start;
  width: 44px !important;
  height: 44px !important;
  min-width: 44px !important;
  min-height: 44px !important;
  max-width: 44px !important;
  max-height: 44px !important;
  border-radius: 999px;
  border: 1px solid rgba(234, 216, 210, 0.85);
  background: #ffffff;
  color: #c43e35;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  box-shadow: 0 5px 14px rgba(42, 25, 14, 0.055);
  position: static;
  transform: none;
}

.ps-event-heart svg {
  width: 22px;
  height: 22px;
  display: block;
}

.ps-event-bottom {
  grid-area: bottom;
  border-top: 1px solid #e9ded3;
  padding-top: 12px;
  margin-top: 2px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-width: 0;
}

.ps-event-meta {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 10px;
  color: #111827;
  font-size: 15px;
  font-weight: 700;
  white-space: nowrap;
}

.ps-clock,
.ps-calendar-icon,
.ps-dot {
  color: #b24a2b;
}

.ps-clock svg,
.ps-calendar-icon svg {
  width: 18px;
  height: 18px;
  display: block;
}

.ps-dot {
  font-weight: 800;
}

.ps-price,
.ps-price.pj-free {
  color: #2f7a45;
}

.ps-calendar-button,
.ps-calendar-button:visited {
  flex: 0 0 auto;
  min-height: 38px;
  border-radius: 999px;
  border: 1.4px solid #c84a3d;
  background: #fffdf8;
  color: #c84a3d;
  padding: 7px 12px;
  font-size: 14px;
  font-weight: 750;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  text-decoration: none;
  box-shadow: none;
}

@media (max-width: 370px) {
  .pj-events-list > .ps-event-card,
  .ps-event-card {
    grid-template-columns: 104px minmax(0, 1fr) 44px;
    column-gap: 12px;
    padding: 14px;
  }

  .ps-event-image {
    width: 104px;
    height: 104px;
  }

  .ps-event-body {
    height: 104px;
  }

  .ps-event-title {
    font-size: 18px;
  }

  .ps-event-description,
  .ps-event-venue,
  .ps-event-meta {
    font-size: 14px;
  }

  .ps-calendar-button {
    min-height: 36px;
    font-size: 13px;
    padding: 7px 10px;
  }
}


/* Reference-card exact pass: two pills, green serif title, softer shell. */
.ps-event-card {
  position: relative;
  grid-template-columns: 112px minmax(0, 1fr) !important;
  grid-template-areas:
    "image body"
    "bottom bottom" !important;
  border: 1px solid #ead8d2;
  box-shadow: 0 8px 22px rgba(70, 44, 25, 0.045);
}

.ps-event-image {
  border-radius: 14px;
  background: #e8f3df;
}

.ps-event-body {
  height: 112px;
  padding-right: 0;
}

.ps-event-topline {
  gap: 5px;
  margin-bottom: 5px;
  padding-right: 0;
  overflow: hidden;
  flex-wrap: nowrap;
}

.ps-event-pill {
  height: 22px;
  padding: 0 8px;
  gap: 4px;
  font-size: 9.5px;
  font-weight: 800;
  letter-spacing: 0.045em;
  line-height: 1;
}

.ps-pill-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  line-height: 1;
}

.ps-event-pill-community {
  background: #e8f5e8 !important;
  color: #2f7045 !important;
}

.ps-event-pill-date {
  background: #f1e1db;
  color: #a34732;
}

.ps-event-title {
  color: #214f32;
  font-family: "Playfair Display", Georgia, "Times New Roman", serif;
  font-size: 23px;
  font-weight: 700;
  line-height: 1.04;
}

.ps-event-description {
  margin-top: 4px;
  color: #3f4652;
  font-size: 13.5px;
  line-height: 1.22;
}

.ps-event-venue {
  color: #3f4652;
  font-size: 13.5px;
  line-height: 1.2;
}

.ps-pin {
  color: #4b5563;
}

.ps-event-card .ps-event-heart,
.ps-event-card .ps-event-heart.pj-save-heart,
.ps-event-card .ps-event-heart.pj-save-heart.is-saved {
  position: absolute;
  top: 16px;
  right: 16px;
  grid-area: auto;
  background: #ffffff;
  border-color: #ead8d2;
  color: #b24a2b;
}

.ps-event-bottom {
  border-top-color: #e8ded3;
}

.ps-clock,
.ps-calendar-icon {
  display: none !important;
}

.ps-event-meta {
  gap: 9px;
  color: #3f4652;
  font-size: 14px;
  font-weight: 700;
}

.ps-dot {
  color: #d0a497;
}

.ps-calendar-button,
.ps-calendar-button:visited {
  min-height: 36px;
  background: #f4e4dd;
  border-color: #d8a294;
  color: #a94732;
  padding: 7px 13px;
  font-size: 13.5px;
  gap: 0;
}

@media (max-width: 370px) {
  .ps-event-card {
    grid-template-columns: 104px minmax(0, 1fr) !important;
  }
  .ps-event-body {
    height: 104px;
  }
  .ps-event-card .ps-event-heart,
  .ps-event-card .ps-event-heart.pj-save-heart,
  .ps-event-card .ps-event-heart.pj-save-heart.is-saved {
    top: 14px;
    right: 14px;
  }
  .ps-event-title {
    font-size: 20px;
  }
  .ps-event-description,
  .ps-event-venue,
  .ps-event-meta {
    font-size: 13px;
  }
  .ps-event-pill {
    height: 20px;
    padding: 0 7px;
    font-size: 8.5px;
  }
}


/* Prevent reference top pills from running underneath the absolute heart. */
.ps-event-topline {
  width: calc(100% - 52px);
  max-width: calc(100% - 52px);
}


/* Premium compact Events top UI rebuild. */
.pj-archive-theme--events,
.pj-archive-theme-scope.pj-archive-theme--events {
  background: #f7efe4;
}

.ps-events-hero {
  margin: 0 16px 10px;
  padding: 14px 0 4px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.ps-events-hero-copy {
  min-width: 0;
}

.ps-events-hero h1 {
  margin: 0 0 4px;
  color: #111827;
  font-family: "Playfair Display", Georgia, serif;
  font-size: clamp(30px, 8vw, 38px);
  line-height: 0.98;
  font-weight: 700;
  letter-spacing: -0.025em;
}

.ps-events-hero p {
  margin: 0;
  max-width: 270px;
  color: #4b5563;
  font-size: 14.5px;
  line-height: 1.3;
  font-weight: 500;
}

.ps-events-hero .pj-submit-event-cta {
  flex: 0 0 auto;
  min-height: 36px;
  padding: 8px 12px;
  border-radius: 999px;
  background: #b24a2b;
  color: #fff;
  border: 1px solid rgba(178, 74, 43, 0.25);
  box-shadow: 0 8px 18px rgba(178, 74, 43, 0.16);
  font-size: 13px;
  font-weight: 800;
  text-decoration: none;
  white-space: nowrap;
}

.pj-filter-stack--events {
  margin: 0 16px 12px;
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

.ps-date-chip-row {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding: 4px 0 9px;
}

.ps-date-chip-row::-webkit-scrollbar {
  display: none;
}

.ps-date-chip {
  flex: 0 0 auto;
  min-height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 13px;
  border-radius: 999px;
  background: #fffdf8;
  color: #263241;
  border: 1px solid #e7d7c7;
  text-decoration: none;
  font-size: 13.5px;
  font-weight: 750;
  box-shadow: 0 3px 10px rgba(58, 37, 22, 0.035);
  white-space: nowrap;
}

.ps-date-chip.active {
  background: #b24a2b;
  color: #fff;
  border-color: #b24a2b;
  box-shadow: 0 8px 18px rgba(178, 74, 43, 0.18);
}

.ps-events-utility-row {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.ps-more-filters {
  position: relative;
  flex: 1 1 auto;
}

.ps-more-filters summary,
.ps-utility-button {
  min-height: 40px;
  border-radius: 999px;
  background: #fffdf8;
  border: 1px solid #e7d7c7;
  color: #263241;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  padding: 9px 14px;
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
  box-shadow: 0 5px 14px rgba(58, 37, 22, 0.04);
  cursor: pointer;
}

.ps-more-filters summary {
  list-style: none;
}

.ps-more-filters summary::-webkit-details-marker {
  display: none;
}

.ps-more-filters[open] summary,
.ps-utility-button.active {
  border-color: #cfa18d;
  color: #a94732;
}

.ps-date-form {
  flex: 0 0 auto;
}

.ps-date-picker-shell {
  position: relative;
  display: inline-flex;
}

.ps-more-filters-panel {
  position: absolute;
  z-index: 30;
  top: calc(100% + 10px);
  left: 0;
  right: -132px;
  background: #fffdf8;
  border: 1px solid #ead8d2;
  border-radius: 22px;
  padding: 14px;
  box-shadow: 0 18px 45px rgba(58, 37, 22, 0.16);
}

.ps-filter-drawer-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 11px;
}

.ps-filter-drawer-head strong {
  color: #111827;
  font-size: 16px;
}

.ps-filter-drawer-head span {
  color: #6b7280;
  font-size: 12px;
  font-weight: 700;
}

.ps-filter-choice-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.ps-filter-choice {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 7px 11px;
  border-radius: 999px;
  background: #fffaf4;
  border: 1px solid #e7d7c7;
  color: #263241;
  font-size: 13px;
  font-weight: 750;
  cursor: pointer;
}

.ps-filter-choice input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.ps-filter-choice.active,
.ps-filter-choice:has(input:checked) {
  background: #b24a2b;
  border-color: #b24a2b;
  color: #fff;
}

.ps-filter-drawer-actions {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid #eadfd5;
}

.ps-filter-clear,
.ps-filter-apply {
  min-height: 38px;
  border-radius: 999px;
  padding: 8px 16px;
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}

.ps-filter-clear {
  color: #6b4a3a;
}

.ps-filter-apply {
  border: 0;
  background: #b24a2b;
  color: #fff;
}

.ps-calendar-panel.pj-calendar-panel {
  right: 0;
  left: auto;
  top: calc(100% + 10px);
  border-radius: 22px;
  border-color: #ead8d2;
  box-shadow: 0 18px 45px rgba(58, 37, 22, 0.16);
}

.pj-section-label {
  margin: 10px 16px 10px;
  display: flex;
  align-items: center;
  gap: 10px;
  color: #111827;
  font-size: 17px;
  font-weight: 850;
  letter-spacing: -0.01em;
}

.pj-section-label-icon {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #f1e1db;
  color: #b24a2b;
  flex: 0 0 auto;
}

.pj-section-label-icon svg {
  width: 17px;
  height: 17px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.pj-archive-theme-scope.pj-archive-theme--events {
  padding-bottom: calc(132px + env(safe-area-inset-bottom, 0px));
}

@media (max-width: 370px) {
  .ps-events-hero {
    margin-left: 14px;
    margin-right: 14px;
  }
  .ps-events-hero h1 {
    font-size: 29px;
  }
  .ps-events-hero p {
    font-size: 13.5px;
  }
  .ps-events-hero .pj-submit-event-cta {
    padding-left: 10px;
    padding-right: 10px;
    font-size: 12.5px;
  }
  .pj-filter-stack--events,
  .pj-section-label {
    margin-left: 14px;
    margin-right: 14px;
  }
  .ps-date-chip {
    padding-left: 11px;
    padding-right: 11px;
    font-size: 13px;
  }
  .ps-more-filters-panel {
    right: -120px;
  }
}


/* Event cards: match attached cream/green/peach reference card. */
.pj-events-list > .ps-event-card,
.ps-event-card {
  background: #fffaf1;
  border: 1px solid #edcfc6;
  box-shadow: 0 8px 24px rgba(74, 48, 30, 0.045);
  border-radius: 22px;
  padding: 16px;
  row-gap: 12px;
}

.ps-event-image {
  border-radius: 15px;
  background: #eaf6e8;
  border: 1px solid rgba(47, 112, 69, 0.10);
}

.ps-event-image img {
  object-fit: cover;
  object-position: center;
}

.ps-event-topline {
  gap: 5px;
  margin-bottom: 5px;
  height: 24px;
  width: calc(100% - 52px);
  max-width: calc(100% - 52px);
  overflow: hidden;
}

.ps-event-pill {
  height: 23px;
  padding: 0 8px;
  border-radius: 999px;
  font-size: 9.5px;
  font-weight: 850;
  letter-spacing: 0.055em;
  line-height: 1;
  gap: 4px;
}

.ps-pill-icon svg {
  width: 12px;
  height: 12px;
  display: block;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.65;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.ps-event-pill-community {
  background: #e8f5e8 !important;
  color: #2f7045 !important;
}

.ps-event-pill-date {
  background: #f2e0da;
  color: #a74733;
}

.ps-event-title {
  color: #214f32;
  font-family: "Playfair Display", Georgia, "Times New Roman", serif;
  font-size: 23.5px;
  font-weight: 700;
  line-height: 1.04;
  letter-spacing: -0.015em;
}

.ps-event-description {
  color: #202833;
  font-size: 13.8px;
  line-height: 1.23;
  margin: 4px 0 0;
  font-weight: 500;
}

.ps-event-venue {
  color: #202833;
  font-size: 13.8px;
  line-height: 1.2;
  font-weight: 500;
}

.ps-pin {
  color: #202833;
}

.ps-event-card .ps-event-heart,
.ps-event-card .ps-event-heart.pj-save-heart,
.ps-event-card .ps-event-heart.pj-save-heart.is-saved {
  top: 16px;
  right: 16px;
  background: #fffaf1;
  border: 1px solid #edcfc6;
  color: #a74733;
  box-shadow: none;
}

.ps-event-heart svg {
  width: 21px;
  height: 21px;
}

.ps-event-bottom {
  border-top: 1px solid #e8ded3;
  padding-top: 12px;
  min-height: 48px;
}

.ps-event-meta {
  color: #202833;
  font-size: 14px;
  font-weight: 850;
  gap: 9px;
}

.ps-price,
.ps-price.pj-free {
  color: #202833;
}

.ps-dot {
  color: #d0a497;
  font-size: 14px;
}

.ps-calendar-button,
.ps-calendar-button:visited {
  min-height: 36px;
  border-radius: 999px;
  background: #f3e2dc;
  border: 1px solid #ddb0a3;
  color: #a74733;
  padding: 7px 13px;
  font-size: 13.5px;
  font-weight: 850;
}

.ps-clock,
.ps-calendar-icon {
  display: none !important;
}

@media (max-width: 370px) {
  .ps-event-title {
    font-size: 20.5px;
  }
  .ps-event-description,
  .ps-event-venue,
  .ps-event-meta {
    font-size: 13px;
  }
  .ps-event-pill {
    height: 20px;
    padding: 0 7px;
    font-size: 8.5px;
  }
  .ps-event-card .ps-event-heart,
  .ps-event-card .ps-event-heart.pj-save-heart,
  .ps-event-card .ps-event-heart.pj-save-heart.is-saved {
    top: 14px;
    right: 14px;
  }
}


/* Homepage event cards use the same reference card geometry as Events archive. */
.ps-event-card.pj-home-best-card:not(.pj-event-card--explore) {
  display: grid !important;
  grid-template-columns: 112px minmax(0, 1fr) !important;
  grid-template-areas:
    "image body"
    "bottom bottom" !important;
  column-gap: 14px !important;
  row-gap: 12px !important;
  padding: 16px !important;
}

.ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-image {
  grid-area: image !important;
  width: 112px !important;
  height: 112px !important;
}

.ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-body {
  grid-area: body !important;
  height: 112px !important;
  min-width: 0 !important;
}

.ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-bottom {
  grid-area: bottom !important;
}

.ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-calendar-button {
  min-width: 98px;
  justify-content: center;
}

@media (max-width: 370px) {
  .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) {
    grid-template-columns: 104px minmax(0, 1fr) !important;
    column-gap: 12px !important;
    padding: 14px !important;
  }
  .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-image,
  .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-body {
    width: 104px !important;
    height: 104px !important;
  }
  .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-body {
    width: auto !important;
  }
}


/* Compact real-data EventCard pass: keep reference styling but make cards fit mobile. */
.pj-events-list > .ps-event-card,
.ps-event-card,
.ps-event-card.pj-home-best-card:not(.pj-event-card--explore) {
  display: grid !important;
  grid-template-columns: 96px minmax(0, 1fr) !important;
  grid-template-areas:
    "image body"
    "bottom bottom" !important;
  column-gap: 12px !important;
  row-gap: 10px !important;
  padding: 14px !important;
  border-radius: 20px !important;
}

.ps-event-image,
.ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-image {
  grid-area: image !important;
  width: 96px !important;
  height: 96px !important;
  min-width: 96px !important;
  max-width: 96px !important;
  min-height: 96px !important;
  max-height: 96px !important;
  border-radius: 14px !important;
}

.ps-event-body,
.ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-body {
  grid-area: body !important;
  height: 96px !important;
  min-width: 0 !important;
  padding-right: 0 !important;
}

.ps-event-topline {
  height: 21px !important;
  margin-bottom: 3px !important;
  gap: 4px !important;
  width: calc(100% - 47px) !important;
  max-width: calc(100% - 47px) !important;
}

.ps-event-pill {
  height: 20px !important;
  padding: 0 7px !important;
  font-size: 8.5px !important;
  letter-spacing: 0.045em !important;
  gap: 3px !important;
}

.ps-pill-icon svg {
  width: 10.5px !important;
  height: 10.5px !important;
}

.ps-event-title {
  font-size: 18.5px !important;
  line-height: 1.04 !important;
  -webkit-line-clamp: 2 !important;
}

.ps-event-description {
  margin-top: 3px !important;
  font-size: 12.6px !important;
  line-height: 1.18 !important;
  -webkit-line-clamp: 1 !important;
}

.ps-event-venue {
  font-size: 12.8px !important;
  line-height: 1.15 !important;
}

.ps-pin svg {
  width: 11px !important;
  height: 14px !important;
}

.ps-event-card .ps-event-heart,
.ps-event-card .ps-event-heart.pj-save-heart,
.ps-event-card .ps-event-heart.pj-save-heart.is-saved {
  top: 14px !important;
  right: 14px !important;
  width: 38px !important;
  height: 38px !important;
}

.ps-event-heart svg {
  width: 18px !important;
  height: 18px !important;
}

.ps-event-bottom,
.ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-bottom {
  grid-area: bottom !important;
  min-height: 40px !important;
  padding-top: 10px !important;
}

.ps-event-meta {
  font-size: 13px !important;
  gap: 8px !important;
}

.ps-calendar-button,
.ps-calendar-button:visited,
.ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-calendar-button {
  min-height: 32px !important;
  min-width: 88px !important;
  padding: 6px 10px !important;
  font-size: 12.5px !important;
  justify-content: center !important;
}

@media (max-width: 370px) {
  .pj-events-list > .ps-event-card,
  .ps-event-card,
  .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) {
    grid-template-columns: 88px minmax(0, 1fr) !important;
    column-gap: 10px !important;
    padding: 13px !important;
  }
  .ps-event-image,
  .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-image {
    width: 88px !important;
    height: 88px !important;
    min-width: 88px !important;
    max-width: 88px !important;
    min-height: 88px !important;
    max-height: 88px !important;
  }
  .ps-event-body,
  .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-body {
    height: 88px !important;
  }
  .ps-event-title {
    font-size: 17px !important;
  }
  .ps-event-description {
    font-size: 12px !important;
  }
  .ps-event-venue,
  .ps-event-meta {
    font-size: 12.2px !important;
  }
  .ps-event-card .ps-event-heart,
  .ps-event-card .ps-event-heart.pj-save-heart,
  .ps-event-card .ps-event-heart.pj-save-heart.is-saved {
    top: 13px !important;
    right: 13px !important;
    width: 36px !important;
    height: 36px !important;
  }
}


/* Force compact save button over legacy save-heart dimensions. */
body .ps-event-card button.ps-event-heart.pj-save-heart,
body .ps-event-card button.ps-event-heart.pj-save-heart.is-saved,
body .ps-event-card .ps-event-heart.pj-save-heart.event-save-heart {
  width: 38px !important;
  height: 38px !important;
  min-width: 38px !important;
  min-height: 38px !important;
  max-width: 38px !important;
  max-height: 38px !important;
  padding: 0 !important;
}

@media (max-width: 370px) {
  body .ps-event-card button.ps-event-heart.pj-save-heart,
  body .ps-event-card button.ps-event-heart.pj-save-heart.is-saved,
  body .ps-event-card .ps-event-heart.pj-save-heart.event-save-heart {
    width: 36px !important;
    height: 36px !important;
    min-width: 36px !important;
    min-height: 36px !important;
    max-width: 36px !important;
    max-height: 36px !important;
  }
}


/* Homepage polish: compact curated local-guide top section and faster cards. */
.pj-home-hero--compact {
  margin: 0 14px 12px !important;
  padding: 14px 14px 12px !important;
  border-radius: 24px !important;
  background: linear-gradient(180deg, #fffaf2 0%, #f8eee2 100%) !important;
  border: 1px solid rgba(176, 105, 65, 0.14) !important;
  box-shadow: 0 12px 28px rgba(74, 48, 30, 0.07) !important;
}

.pj-home-brand-block {
  display: flex;
  flex-direction: column;
  gap: 1px;
  margin-bottom: 8px;
  color: #1f2937;
}

.pj-home-brand-block strong {
  font-size: 15px;
  line-height: 1.05;
  font-weight: 900;
  letter-spacing: -0.01em;
}

.pj-home-brand-block span {
  font-size: 11px;
  color: #8a5b42;
  font-weight: 850;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.pj-home-mode-toggle {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
  padding: 4px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(188, 142, 112, 0.26);
  margin: 0 0 12px;
}

.pj-home-mode-toggle a {
  min-height: 34px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  font-size: 14px;
  font-weight: 850;
  color: #263241;
}

.pj-home-mode-toggle a:first-child {
  background: #b24a2b;
  color: #fff;
  box-shadow: 0 7px 14px rgba(178, 74, 43, 0.16);
}

.pj-home-hero--compact .pj-home-kicker {
  margin: 0 0 3px !important;
  color: #b24a2b !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
}

.pj-home-hero--compact h2 {
  margin: 0 0 5px !important;
  font-family: "Playfair Display", Georgia, serif !important;
  color: #172033 !important;
  font-size: clamp(31px, 8.4vw, 38px) !important;
  line-height: 0.96 !important;
  letter-spacing: -0.035em !important;
}

.pj-home-hero--compact > p:not(.pj-home-kicker) {
  margin: 0 0 11px !important;
  max-width: 310px;
  color: #4b5563 !important;
  font-size: 14.5px !important;
  line-height: 1.28 !important;
  font-weight: 550 !important;
}

.pj-home-search-form {
  width: 100% !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  gap: 8px !important;
  margin: 0 0 10px !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.pj-home-search-form input[type="search"] {
  min-width: 0 !important;
  width: 100% !important;
  height: 44px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(188, 142, 112, 0.28) !important;
  background: #fffdf8 !important;
  color: #172033 !important;
  font-size: 14px !important;
  padding: 0 14px !important;
  box-shadow: 0 5px 14px rgba(74, 48, 30, 0.045) !important;
}

.pj-home-search-form input[type="search"]::placeholder {
  color: #8a7b70 !important;
  opacity: 1 !important;
}

.pj-home-search-form button {
  height: 44px !important;
  min-width: 76px !important;
  border-radius: 999px !important;
  background: #b24a2b !important;
  color: #fff !important;
  border: 0 !important;
  padding: 0 15px !important;
  font-size: 13.5px !important;
  font-weight: 900 !important;
  box-shadow: 0 8px 16px rgba(178, 74, 43, 0.18) !important;
}

.pj-home-quick-links {
  display: flex !important;
  gap: 7px !important;
  overflow-x: auto !important;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  flex-wrap: nowrap !important;
  padding: 0 0 2px !important;
  margin: 0 !important;
}

.pj-home-quick-links::-webkit-scrollbar {
  display: none;
}

.pj-home-quick-links a {
  flex: 0 0 auto !important;
  min-height: 32px !important;
  padding: 7px 11px !important;
  border-radius: 999px !important;
  background: #fffdf8 !important;
  border: 1px solid #e7d7c7 !important;
  color: #263241 !important;
  font-size: 12.8px !important;
  font-weight: 800 !important;
  text-decoration: none !important;
  box-shadow: none !important;
}

.pj-home-section--today-weekend,
.pj-home-planning-tiles {
  display: none !important;
}

.pj-home-section {
  margin: 0 14px 18px !important;
}

.pj-home-section--today {
  margin-top: 8px !important;
}

.pj-home-section-head {
  margin-bottom: 9px !important;
  align-items: center !important;
}

.pj-home-section-head h2 {
  font-family: "Playfair Display", Georgia, serif !important;
  font-size: clamp(25px, 6.8vw, 32px) !important;
  line-height: 1 !important;
  letter-spacing: -0.025em !important;
  color: #172033 !important;
}

.pj-home-section-head a,
.pj-home-head-actions a {
  color: #b24a2b !important;
  font-size: 13px !important;
  font-weight: 850 !important;
  white-space: nowrap !important;
  text-decoration: none !important;
}

.pj-home-head-actions .pj-submit-event-cta {
  display: none !important;
}

.pj-featured-grid {
  gap: 12px !important;
}

.pj-home-section-note {
  margin: -4px 0 10px !important;
  font-size: 13.5px !important;
  line-height: 1.35 !important;
  color: #5e6471 !important;
}

.pj-home-explore-actions.pj-explore-card-actions {
  margin-top: 10px !important;
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 8px !important;
}

.pj-home-explore-actions .pj-explore-card-action {
  min-height: 34px !important;
  border-radius: 999px !important;
  padding: 7px 9px !important;
  font-size: 12.2px !important;
  font-weight: 850 !important;
  justify-content: center !important;
  text-align: center !important;
}

.pj-home-all-actions {
  margin: 6px 14px 26px !important;
  padding: 14px !important;
  border: 1px solid rgba(188, 142, 112, 0.22) !important;
  border-radius: 22px !important;
  background: #fffaf2 !important;
  display: grid !important;
  gap: 9px !important;
}

.pj-home-all-actions a,
.pj-home-all-actions .pj-submit-event-cta {
  width: 100% !important;
  justify-content: center !important;
  text-align: center !important;
  min-height: 40px !important;
  border-radius: 999px !important;
  font-weight: 850 !important;
}

@media (max-width: 370px) {
  .pj-home-hero--compact {
    margin-left: 12px !important;
    margin-right: 12px !important;
    padding: 13px 12px 11px !important;
  }
  .pj-home-search-form {
    gap: 6px !important;
  }
  .pj-home-search-form button {
    min-width: 66px !important;
    padding: 0 12px !important;
    font-size: 12.8px !important;
  }
  .pj-home-search-form input[type="search"] {
    font-size: 13px !important;
    padding-left: 12px !important;
  }
  .pj-home-quick-links a {
    font-size: 12.2px !important;
    padding-left: 10px !important;
    padding-right: 10px !important;
  }
  .pj-home-section {
    margin-left: 12px !important;
    margin-right: 12px !important;
  }
}


/* Final homepage compacting: avoid repeating brand inside hero and keep search placeholder visible. */
.pj-home-hero--compact .pj-home-kicker {
  display: none !important;
}

.pj-home-hero--compact h2 {
  margin-top: 0 !important;
}

.pj-home-search-form {
  grid-template-columns: minmax(0, 1fr) 58px !important;
  gap: 6px !important;
}

.pj-home-search-form button {
  min-width: 58px !important;
  width: 58px !important;
  padding: 0 !important;
  font-size: 12.2px !important;
}

.pj-home-search-form input[type="search"] {
  font-size: 13.3px !important;
}

@media (max-width: 370px) {
  .pj-home-search-form {
    grid-template-columns: minmax(0, 1fr) 54px !important;
  }
  .pj-home-search-form button {
    min-width: 54px !important;
    width: 54px !important;
    font-size: 11.8px !important;
  }
  .pj-home-search-form input[type="search"] {
    font-size: 12.8px !important;
  }
}

/* PJ 1.5.217: reserve real text space for the absolute save heart on compact Home/Event cards.
   Keep the two-column image/body grid for mobile width, but prevent the top-right
   save control from covering category, title, description, or venue text. */
body .ps-event-card .ps-event-body,
body .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-body {
  padding-right: 48px !important;
  box-sizing: border-box !important;
}

body .ps-event-card .ps-event-topline,
body .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-topline {
  width: 100% !important;
  max-width: 100% !important;
}

body .ps-event-card .ps-event-title,
body .ps-event-card .ps-event-description,
body .ps-event-card .ps-event-venue {
  max-width: 100% !important;
}

@media (max-width: 370px) {
  body .ps-event-card .ps-event-body,
  body .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-body {
    padding-right: 43px !important;
  }
}

/* PJ 1.5.219: Date picker must open as a centered fixed overlay.
   The ps-calendar-panel restyle had forced right:0/left:auto/top:100%, which placed
   the panel off-screen on mobile. Keep the standalone Date chip, but center its panel. */
body .ps-calendar-panel.pj-calendar-panel,
body .pj-calendar-panel.pj-calendar-panel--range {
  position: fixed !important;
  left: 50% !important;
  right: auto !important;
  top: 48% !important;
  transform: translate(-50%, -50%) !important;
  z-index: 2147483000 !important;
  width: min(92vw, 360px) !important;
  max-width: 360px !important;
}

body .ps-calendar-panel.pj-calendar-panel[hidden],
body .pj-calendar-panel.pj-calendar-panel--range[hidden] {
  display: none !important;
}

/* PJ 1.5.220: make the Events Date calendar more legible and keep it fully inside mobile viewport. */
body .ps-calendar-panel.pj-calendar-panel,
body .pj-calendar-panel.pj-calendar-panel--range {
  top: 50% !important;
  width: min(92vw, 350px) !important;
  max-width: 350px !important;
  max-height: calc(100dvh - 28px) !important;
  overflow-y: auto !important;
  overscroll-behavior: contain !important;
  padding: 12px !important;
  background: rgba(255, 253, 248, 0.94) !important;
  border: 1px solid rgba(178, 74, 43, 0.22) !important;
  box-shadow: 0 18px 48px rgba(36, 24, 14, 0.28) !important;
  backdrop-filter: blur(14px) saturate(1.08) !important;
  -webkit-backdrop-filter: blur(14px) saturate(1.08) !important;
}

body .pj-calendar-head {
  color: #172033 !important;
}

body .pj-calendar-help {
  color: #5b4637 !important;
  font-weight: 700 !important;
}

body .pj-calendar-weekdays span {
  color: #6b4a3a !important;
  font-weight: 850 !important;
}

body .pj-calendar-grid {
  gap: 5px !important;
}

body .pj-calendar-day {
  min-height: 36px !important;
  border-color: rgba(45, 35, 25, 0.12) !important;
  background: #fffaf1 !important;
  color: #182233 !important;
  font-weight: 800 !important;
}

body .pj-calendar-day.is-selected,
body .pj-calendar-day[aria-pressed="true"] {
  background: #b24a2b !important;
  border-color: #b24a2b !important;
  color: #fff !important;
}

body .pj-calendar-actions {
  position: sticky !important;
  bottom: 0 !important;
  margin: 8px -4px -4px !important;
  padding: 8px 4px 4px !important;
  background: linear-gradient(180deg, rgba(255,253,248,0.78), #fffdf8 45%) !important;
}

body .pj-date-apply.pj-date-apply--calendar {
  background: #b24a2b !important;
  color: #fff !important;
  box-shadow: 0 8px 16px rgba(178, 74, 43, 0.18) !important;
}

@media (max-height: 740px) {
  body .ps-calendar-panel.pj-calendar-panel,
  body .pj-calendar-panel.pj-calendar-panel--range {
    top: 14px !important;
    transform: translateX(-50%) !important;
    max-height: calc(100dvh - 28px) !important;
  }
  body .pj-calendar-day {
    min-height: 32px !important;
  }
}

/* PJ 1.5.221: darker, shorter Events Date picker that cannot disappear under the mobile bottom nav. */
body .ps-calendar-panel.pj-calendar-panel,
body .pj-calendar-panel.pj-calendar-panel--range {
  top: 56px !important;
  bottom: auto !important;
  transform: translateX(-50%) !important;
  width: min(88vw, 330px) !important;
  max-width: 330px !important;
  max-height: calc(100dvh - 176px) !important;
  padding: 10px !important;
  overflow-y: auto !important;
  background: rgba(39, 28, 21, 0.97) !important;
  border: 1px solid rgba(255, 242, 228, 0.22) !important;
  color: #fff8ef !important;
  box-shadow: 0 22px 58px rgba(0, 0, 0, 0.48) !important;
  backdrop-filter: blur(10px) saturate(1.05) !important;
  -webkit-backdrop-filter: blur(10px) saturate(1.05) !important;
}

body .pj-calendar-head {
  margin-bottom: 6px !important;
  color: #fff8ef !important;
}

body .pj-calendar-head strong,
body .pj-calendar-title,
body [data-pj-calendar-title] {
  color: #fff8ef !important;
  font-size: 16px !important;
}

body .pj-calendar-nav {
  width: 34px !important;
  height: 34px !important;
  min-height: 34px !important;
  background: rgba(255,255,255,0.12) !important;
  border-color: rgba(255,255,255,0.18) !important;
  color: #fff8ef !important;
}

body .pj-calendar-help {
  margin: 0 0 7px !important;
  color: #f6dccd !important;
  font-size: 12px !important;
  line-height: 1.22 !important;
  font-weight: 750 !important;
}

body .pj-calendar-weekdays {
  margin-bottom: 4px !important;
}

body .pj-calendar-weekdays span {
  color: #f3c7b3 !important;
  font-size: 10px !important;
  font-weight: 900 !important;
}

body .pj-calendar-grid {
  gap: 4px !important;
}

body .pj-calendar-day {
  min-height: 28px !important;
  height: 28px !important;
  padding: 0 !important;
  border-radius: 10px !important;
  border-color: rgba(255,255,255,0.16) !important;
  background: rgba(255,255,255,0.09) !important;
  color: #fff8ef !important;
  font-size: 12px !important;
  font-weight: 850 !important;
}

body .pj-calendar-day.is-disabled,
body .pj-calendar-day:disabled {
  background: rgba(255,255,255,0.035) !important;
  color: rgba(255,248,239,0.38) !important;
  border-color: rgba(255,255,255,0.07) !important;
}

body .pj-calendar-day.is-today {
  background: rgba(255, 214, 180, 0.18) !important;
  border-color: rgba(255, 214, 180, 0.56) !important;
  color: #ffe4d1 !important;
  box-shadow: none !important;
}

body .pj-calendar-day.is-selected,
body .pj-calendar-day[aria-pressed="true"] {
  background: #e26a3d !important;
  border-color: #f09a78 !important;
  color: #fff !important;
}

body .pj-calendar-day.is-in-range {
  background: rgba(226, 106, 61, 0.28) !important;
  color: #fff8ef !important;
}

body .pj-calendar-actions {
  position: sticky !important;
  bottom: 0 !important;
  margin: 7px -2px -2px !important;
  padding: 7px 2px 2px !important;
  background: linear-gradient(180deg, rgba(39,28,21,0), rgba(39,28,21,0.98) 36%) !important;
  gap: 8px !important;
}

body .pj-date-reset.pj-date-reset--calendar,
body .pj-date-apply.pj-date-apply--calendar {
  min-height: 36px !important;
  border-radius: 999px !important;
  font-size: 13px !important;
  font-weight: 900 !important;
}

body .pj-date-reset.pj-date-reset--calendar {
  color: #ffe6d7 !important;
  border-color: rgba(255,230,215,0.34) !important;
  background: rgba(255,255,255,0.08) !important;
}

body .pj-date-apply.pj-date-apply--calendar {
  background: #f07845 !important;
  color: #fff !important;
  box-shadow: 0 9px 18px rgba(0,0,0,0.28) !important;
}

@media (max-height: 740px) {
  body .ps-calendar-panel.pj-calendar-panel,
  body .pj-calendar-panel.pj-calendar-panel--range {
    top: 44px !important;
    max-height: calc(100dvh - 162px) !important;
  }
}

@media (max-height: 620px) {
  body .ps-calendar-panel.pj-calendar-panel,
  body .pj-calendar-panel.pj-calendar-panel--range {
    top: 20px !important;
    max-height: calc(100dvh - 126px) !important;
  }
  body .pj-calendar-help {
    display: none !important;
  }
  body .pj-calendar-day {
    min-height: 25px !important;
    height: 25px !important;
  }
}

/* PJ 1.5.222: lift the entire filter stack above event cards while the Date calendar is open. */
body .pj-sticky-header:has(.pj-calendar-panel:not([hidden])),
body .pj-archive-theme-scope:has(.pj-calendar-panel:not([hidden])),
body .pj-filter-stack:has(.pj-calendar-panel:not([hidden])),
body .ps-events-utility-row:has(.pj-calendar-panel:not([hidden])),
body .pj-date-form:has(.pj-calendar-panel:not([hidden])),
body .pj-date-picker-shell:has(.pj-calendar-panel:not([hidden])) {
  position: relative !important;
  z-index: 2147483500 !important;
  overflow: visible !important;
  isolation: isolate !important;
}

body .ps-event-card,
body .pj-event-card,
body .pj-events-list,
body .pj-section-label {
  z-index: auto !important;
}

body .pj-calendar-panel:not([hidden]) {
  z-index: 2147483600 !important;
  pointer-events: auto !important;
}

/* PJ 1.5.223: polish the standalone Events Date button. */
body .ps-utility-button.ps-utility-button--date {
  gap: 8px !important;
  min-height: 42px !important;
  padding: 6px 13px 6px 8px !important;
  border-radius: 999px !important;
  background: linear-gradient(180deg, #fffdf8 0%, #f7eadf 100%) !important;
  border: 1px solid rgba(178, 74, 43, 0.20) !important;
  color: #4a2d20 !important;
  box-shadow: 0 8px 18px rgba(58, 37, 22, 0.075), inset 0 1px 0 rgba(255,255,255,0.86) !important;
  font-weight: 900 !important;
  letter-spacing: -0.01em !important;
}

body .ps-utility-button.ps-utility-button--date:hover,
body .ps-utility-button.ps-utility-button--date:focus-visible {
  border-color: rgba(178, 74, 43, 0.34) !important;
  box-shadow: 0 10px 22px rgba(58, 37, 22, 0.11), 0 0 0 3px rgba(178, 74, 43, 0.10) !important;
}

body .ps-utility-button.ps-utility-button--date.active,
body .pj-date-form.is-date-open .ps-utility-button.ps-utility-button--date,
body .ps-utility-button.ps-utility-button--date[aria-expanded="true"] {
  background: linear-gradient(180deg, #b24a2b 0%, #983c23 100%) !important;
  border-color: rgba(137, 47, 25, 0.70) !important;
  color: #fffdf8 !important;
  box-shadow: 0 10px 24px rgba(178, 74, 43, 0.24), inset 0 1px 0 rgba(255,255,255,0.20) !important;
}

body .ps-date-button-icon {
  width: 28px !important;
  height: 28px !important;
  min-width: 28px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: rgba(178, 74, 43, 0.12) !important;
  color: #b24a2b !important;
}

body .ps-utility-button.ps-utility-button--date.active .ps-date-button-icon,
body .pj-date-form.is-date-open .ps-utility-button.ps-utility-button--date .ps-date-button-icon,
body .ps-utility-button.ps-utility-button--date[aria-expanded="true"] .ps-date-button-icon {
  background: rgba(255,255,255,0.18) !important;
  color: #fff7ed !important;
}

body .ps-date-button-icon svg {
  width: 18px !important;
  height: 18px !important;
  display: block !important;
  fill: none !important;
  stroke: currentColor !important;
  stroke-width: 1.65 !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
}

body .ps-date-button-icon circle {
  fill: currentColor !important;
  stroke: none !important;
}


/* PJ 1.5.224: Saved mobile screenshot polish — make saved Event cards match the medium compact card system. */
@media (max-width: 640px) {
  .pj-saved-page {
    padding-left: 14px !important;
    padding-right: 14px !important;
    padding-bottom: 108px !important;
  }
  .pj-saved-actions:not([hidden]) {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 7px !important;
    overflow: visible !important;
    margin: 0 0 12px !important;
    padding: 0 !important;
  }
  .pj-saved-actions button {
    min-width: 0 !important;
    width: 100% !important;
    min-height: 38px !important;
    padding: 7px 6px !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 4px !important;
    font-size: 10.5px !important;
    line-height: 1 !important;
    white-space: nowrap !important;
  }
  .pj-saved-action-icon {
    width: 13px !important;
    height: 13px !important;
    flex: 0 0 13px !important;
  }
  .pj-saved-plan {
    grid-template-columns: minmax(0, 1fr) 88px !important;
    gap: 10px !important;
    padding: 12px !important;
    margin-bottom: 8px !important;
  }
  .pj-saved-plan-main,
  .pj-saved-plan-copy {
    min-width: 0 !important;
    overflow: hidden !important;
  }
  .pj-saved-plan-mark--exact {
    width: 42px !important;
    height: 42px !important;
    flex: 0 0 42px !important;
  }
  .pj-saved-plan-label {
    font-size: 10px !important;
    letter-spacing: .08em !important;
  }
  .pj-saved-plan [data-pj-saved-plan-summary] {
    display: block !important;
    font-size: 12.5px !important;
    line-height: 1.15 !important;
    font-weight: 500 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }
  .pj-saved-plan-next {
    display: block !important;
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    text-overflow: ellipsis !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    hyphens: none !important;
    font-size: 12px !important;
    line-height: 1.15 !important;
  }
  .pj-saved-plan-time {
    font-size: 11px !important;
    line-height: 1.1 !important;
  }
  .pj-saved-sort-box--exact {
    width: 88px !important;
    min-width: 88px !important;
    align-self: center !important;
  }
  .pj-saved-plan-note--exact img {
    max-width: 178px !important;
  }
  .pj-saved-helper {
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    font-size: 10.5px !important;
    line-height: 1.2 !important;
    gap: 5px !important;
  }

  .pj-saved-card--event.pj-saved-card--feed {
    box-sizing: border-box !important;
    display: grid !important;
    grid-template-columns: 112px minmax(0, 1fr) !important;
    grid-template-areas:
      "image body"
      "actions actions" !important;
    column-gap: 14px !important;
    row-gap: 12px !important;
    padding: 16px !important;
    border-radius: 22px !important;
    background: #fffdf8 !important;
    border: 1px solid rgba(45,35,25,.08) !important;
    box-shadow: 0 8px 24px rgba(0,0,0,.045) !important;
    overflow: hidden !important;
  }
  .pj-saved-card--event .pj-saved-card-link {
    display: contents !important;
  }
  .pj-saved-card--event .pj-saved-card-media {
    grid-area: image !important;
    width: 112px !important;
    min-width: 112px !important;
    max-width: 112px !important;
    height: 112px !important;
    min-height: 112px !important;
    max-height: 112px !important;
    aspect-ratio: auto !important;
    border-radius: 16px !important;
    overflow: hidden !important;
    background: #f2ede6 !important;
    position: relative !important;
  }
  .pj-saved-card--event .pj-saved-card-media img {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    max-width: none !important;
    object-fit: cover !important;
    object-position: center !important;
    display: block !important;
  }
  .pj-saved-card--event .pj-saved-card-body {
    grid-area: body !important;
    min-width: 0 !important;
    width: 100% !important;
    padding: 0 42px 0 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
  }
  .pj-saved-card--event .pj-saved-card-topline {
    min-width: 0 !important;
    padding-right: 0 !important;
    gap: 5px !important;
    overflow: hidden !important;
    flex-wrap: nowrap !important;
  }
  .pj-saved-card--event .pj-saved-card-title {
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    margin: 0 !important;
    font-size: 17px !important;
    line-height: 1.18 !important;
    font-weight: 700 !important;
    color: #111827 !important;
  }
  .pj-saved-card--event .pj-saved-card-hint {
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    margin: 0 !important;
    color: #667085 !important;
    font-size: 13.5px !important;
    line-height: 1.28 !important;
  }
  .pj-saved-card--event .pj-saved-card-meta,
  .pj-saved-card--event .pj-saved-card-meta span {
    display: block !important;
    min-width: 0 !important;
    max-width: 100% !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    color: #667085 !important;
    font-size: 12.5px !important;
    line-height: 1.2 !important;
  }
  .pj-saved-card--event .pj-saved-remove {
    position: absolute !important;
    top: 12px !important;
    right: 12px !important;
    width: 38px !important;
    min-width: 38px !important;
    height: 38px !important;
    min-height: 38px !important;
    border-radius: 50% !important;
    z-index: 6 !important;
  }
  .pj-saved-card--event .pj-saved-card-actions {
    grid-area: actions !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 12px 0 0 !important;
    border-top: 1px solid rgba(45,35,25,.06) !important;
  }
  .pj-saved-card--event .pj-saved-card-actions a {
    width: 100% !important;
    min-width: 0 !important;
    min-height: 36px !important;
    padding: 8px 8px !important;
    justify-content: center !important;
    border-radius: 999px !important;
    white-space: nowrap !important;
    font-size: 11.5px !important;
    line-height: 1 !important;
  }
  .pj-saved-card--event .pj-saved-calendar {
    order: 2 !important;
  }
  .pj-saved-card--event .pj-saved-maps {
    order: 3 !important;
  }
}

@media (max-width: 370px) {
  .pj-saved-card--event.pj-saved-card--feed {
    grid-template-columns: 104px minmax(0, 1fr) !important;
    column-gap: 12px !important;
    padding: 14px !important;
  }
  .pj-saved-card--event .pj-saved-card-media {
    width: 104px !important;
    min-width: 104px !important;
    max-width: 104px !important;
    height: 104px !important;
    min-height: 104px !important;
    max-height: 104px !important;
  }
  .pj-saved-card--event .pj-saved-card-title { font-size: 15.5px !important; }
  .pj-saved-card--event .pj-saved-card-hint { font-size: 12.5px !important; }
  .pj-saved-card--event .pj-saved-card-actions a { font-size: 10.8px !important; padding-left: 6px !important; padding-right: 6px !important; }
}


/* PJ 1.5.225: Saved Event action row hard-lock — keep Open | + Calendar | Maps on one full-width row. */
@media (max-width: 640px) {
  .pj-saved-card--event .pj-saved-card-actions {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    grid-auto-flow: column !important;
    align-items: center !important;
    overflow: visible !important;
  }
  .pj-saved-card--event .pj-saved-card-actions .pj-saved-open,
  .pj-saved-card--event .pj-saved-card-actions .pj-saved-calendar,
  .pj-saved-card--event .pj-saved-card-actions .pj-saved-maps,
  .pj-saved-card--event .pj-saved-card-actions .event-card-calendar,
  .pj-saved-card--event .pj-saved-card-actions .event-calendar-button {
    box-sizing: border-box !important;
    flex: none !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    margin: 0 !important;
  }
  .pj-saved-card--event .pj-saved-card-actions .pj-saved-open { grid-column: 1 !important; order: 1 !important; }
  .pj-saved-card--event .pj-saved-card-actions .pj-saved-calendar { grid-column: 2 !important; order: 2 !important; }
  .pj-saved-card--event .pj-saved-card-actions .pj-saved-maps { grid-column: 3 !important; order: 3 !important; }
}


/* PJ 1.5.226: override legacy EventCard footer flex rules on Saved cards. */
@media (max-width: 640px) {
  body .pj-saved-page .pj-saved-card--event.pj-saved-card--feed > .pj-saved-card-actions.event-card-bottom.event-card-footer {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr) !important;
    grid-auto-flow: row !important;
    align-items: center !important;
    justify-content: stretch !important;
    gap: 8px !important;
  }
  body .pj-saved-page .pj-saved-card--event.pj-saved-card--feed > .pj-saved-card-actions.event-card-bottom.event-card-footer > a,
  body .pj-saved-page .pj-saved-card--event.pj-saved-card--feed > .pj-saved-card-actions.event-card-bottom.event-card-footer > .event-calendar-button,
  body .pj-saved-page .pj-saved-card--event.pj-saved-card--feed > .pj-saved-card-actions.event-card-bottom.event-card-footer > .event-card-calendar {
    display: inline-flex !important;
    box-sizing: border-box !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    flex: 0 1 auto !important;
    margin: 0 !important;
  }
  body .pj-saved-page .pj-saved-card--event.pj-saved-card--feed > .pj-saved-card-actions.event-card-bottom.event-card-footer > .pj-saved-open { grid-column: 1 !important; grid-row: 1 !important; }
  body .pj-saved-page .pj-saved-card--event.pj-saved-card--feed > .pj-saved-card-actions.event-card-bottom.event-card-footer > .pj-saved-calendar { grid-column: 2 !important; grid-row: 1 !important; }
  body .pj-saved-page .pj-saved-card--event.pj-saved-card--feed > .pj-saved-card-actions.event-card-bottom.event-card-footer > .pj-saved-maps { grid-column: 3 !important; grid-row: 1 !important; }
}


/* PJ 1.5.227: Saved plan/date text should never be visually clipped. */
@media (max-width: 640px) {
  body .pj-saved-page .pj-saved-plan-main,
  body .pj-saved-page .pj-saved-plan-copy {
    overflow: visible !important;
  }
  body .pj-saved-page .pj-saved-plan-time,
  body .pj-saved-page .pj-saved-card--event .pj-saved-card-hint {
    display: block !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: 100% !important;
    white-space: nowrap !important;
    overflow: visible !important;
    text-overflow: clip !important;
    word-break: keep-all !important;
    overflow-wrap: normal !important;
    hyphens: none !important;
  }
  body .pj-saved-page .pj-saved-plan-time {
    color: #8b5f46 !important;
    font-size: 12px !important;
    line-height: 1.2 !important;
    padding-top: 1px !important;
  }
  body .pj-saved-page .pj-saved-card--event .pj-saved-card-hint {
    -webkit-line-clamp: 1 !important;
    line-clamp: 1 !important;
  }
}


/* PJ 1.5.229: Saved mobile circled-fix pass — widen content, stop label/button truncation. */
@media (max-width: 640px) {
  body .pj-saved-page {
    box-sizing: border-box !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding-left: 14px !important;
    padding-right: 14px !important;
  }
  body .pj-saved-page .pj-saved-shell,
  body .pj-saved-page .pj-saved-list,
  body .pj-saved-page .pj-saved-group,
  body .pj-saved-page .pj-saved-group-grid {
    box-sizing: border-box !important;
    width: 100% !important;
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  body .pj-saved-page .pj-saved-plan {
    width: 100% !important;
    grid-template-columns: minmax(0, 1fr) 72px !important;
    gap: 8px !important;
    padding: 12px !important;
  }
  body .pj-saved-page .pj-saved-plan-head {
    gap: 8px !important;
    min-width: 0 !important;
  }
  body .pj-saved-page .pj-saved-plan-mark--exact {
    width: 38px !important;
    height: 38px !important;
    flex-basis: 38px !important;
  }
  body .pj-saved-page .pj-saved-plan-copy {
    min-width: 0 !important;
    overflow: hidden !important;
  }
  body .pj-saved-page .pj-saved-plan-next {
    font-size: 12px !important;
    max-width: 100% !important;
  }
  body .pj-saved-page .pj-saved-plan-time {
    font-size: 12px !important;
    overflow: visible !important;
  }
  body .pj-saved-page .pj-saved-sort-box--exact {
    width: 72px !important;
    min-width: 72px !important;
    max-width: 72px !important;
    justify-self: end !important;
    align-self: center !important;
  }
  body .pj-saved-page .pj-saved-sort-box--exact img {
    width: 72px !important;
    max-width: 72px !important;
    height: auto !important;
  }
  body .pj-saved-page .pj-saved-filters:not([hidden]) {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
    overflow: visible !important;
    padding: 0 !important;
    margin: 10px 0 14px !important;
  }
  body .pj-saved-page .pj-saved-filters button {
    width: 100% !important;
    min-width: 0 !important;
    justify-content: center !important;
    text-align: center !important;
    padding: 9px 10px !important;
    white-space: nowrap !important;
  }
  body .pj-saved-page .pj-saved-card--event.pj-saved-card--feed {
    width: 100% !important;
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    grid-template-columns: 104px minmax(0, 1fr) !important;
    column-gap: 12px !important;
    padding: 14px !important;
  }
  body .pj-saved-page .pj-saved-card--event .pj-saved-card-media {
    width: 104px !important;
    min-width: 104px !important;
    max-width: 104px !important;
    height: 104px !important;
    min-height: 104px !important;
    max-height: 104px !important;
  }
  body .pj-saved-page .pj-saved-card--event .pj-saved-card-body {
    padding-right: 40px !important;
  }
  body .pj-saved-page .pj-saved-card--event .pj-saved-card-title {
    font-size: 16px !important;
    line-height: 1.16 !important;
    max-width: 100% !important;
  }
  body .pj-saved-page .pj-saved-card--event .pj-saved-card-hint,
  body .pj-saved-page .pj-saved-card--event .pj-saved-card-meta span {
    font-size: 12.5px !important;
  }
  body .pj-saved-page .pj-saved-card--event.pj-saved-card--feed > .pj-saved-card-actions.event-card-bottom.event-card-footer {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.22fr) minmax(0, 1fr) !important;
    gap: 7px !important;
    padding-top: 11px !important;
  }
  body .pj-saved-page .pj-saved-card--event.pj-saved-card--feed > .pj-saved-card-actions.event-card-bottom.event-card-footer > a {
    min-height: 36px !important;
    padding: 8px 6px !important;
    font-size: 10.6px !important;
    letter-spacing: -0.01em !important;
    gap: 3px !important;
    overflow: visible !important;
  }
  body .pj-saved-page .pj-saved-card--event.pj-saved-card--feed > .pj-saved-card-actions.event-card-bottom.event-card-footer svg,
  body .pj-saved-page .pj-saved-card--event.pj-saved-card--feed > .pj-saved-card-actions.event-card-bottom.event-card-footer .event-card-calendar-icon {
    width: 12px !important;
    min-width: 12px !important;
    height: 12px !important;
  }
}


/* PJ 1.5.230: Saved plan next title may wrap to avoid looking cut off. */
@media (max-width: 640px) {
  body .pj-saved-page .pj-saved-plan-next {
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
    line-height: 1.16 !important;
    max-height: none !important;
  }
}


/* PJ 1.5.231: Saved card venue line fit on 360px phones. */
@media (max-width: 370px) {
  body .pj-saved-page .pj-saved-card--event .pj-saved-card-meta span {
    font-size: 11.3px !important;
    letter-spacing: -0.015em !important;
  }
}


/* PJ 1.5.232: Saved date/time text must not clip capital M in May/PM. */
@media (max-width: 640px) {
  body .pj-saved-page .pj-saved-plan-time,
  body .pj-saved-page .pj-saved-card--event .pj-saved-card-hint {
    box-sizing: border-box !important;
    display: block !important;
    width: fit-content !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: 20px !important;
    max-height: none !important;
    line-height: 1.45 !important;
    padding-top: 2px !important;
    padding-bottom: 2px !important;
    overflow: visible !important;
    text-overflow: clip !important;
    white-space: nowrap !important;
    -webkit-line-clamp: unset !important;
    line-clamp: unset !important;
    -webkit-box-orient: initial !important;
  }
  body .pj-saved-page .pj-saved-card--event .pj-saved-card-hint {
    margin-top: 3px !important;
    font-size: 13px !important;
    color: #5f4b3e !important;
  }
  body .pj-saved-page .pj-saved-plan-time {
    font-size: 12px !important;
  }
}


/* PJ 1.5.233: non-media Saved date/time unclipping for iPhone Safari viewport quirks. */
body .pj-saved-page .pj-saved-plan-time,
body .pj-saved-page .pj-saved-card--event.event-card .pj-saved-card-hint.event-card-description,
body .pj-saved-page .pj-saved-card--event .pj-saved-card-hint {
  box-sizing: border-box !important;
  display: block !important;
  width: fit-content !important;
  max-width: 100% !important;
  height: auto !important;
  min-height: 21px !important;
  max-height: none !important;
  line-height: 1.48 !important;
  padding-top: 2px !important;
  padding-bottom: 2px !important;
  overflow: visible !important;
  text-overflow: clip !important;
  white-space: nowrap !important;
  -webkit-line-clamp: unset !important;
  line-clamp: unset !important;
  -webkit-box-orient: initial !important;
}
body .pj-saved-page .pj-saved-card--event.event-card .pj-saved-card-hint.event-card-description,
body .pj-saved-page .pj-saved-card--event .pj-saved-card-hint {
  margin-top: 3px !important;
  margin-bottom: 0 !important;
  font-size: 13px !important;
  color: #5f4b3e !important;
}


/* PJ 1.5.234: Saved card heart should be compact, not the 50px EventCard control. */
body .pj-saved-page .pj-saved-card--event.event-card > button.event-card-heart.pj-save-heart.pj-saved-remove,
body .pj-saved-page .pj-saved-card--event.event-card > button.event-card-heart.pj-save-heart.pj-saved-remove.is-saved,
body .pj-saved-page article.pj-saved-card--event.event-card button.event-card-heart.pj-save-heart.pj-saved-remove {
  width: 34px !important;
  height: 34px !important;
  min-width: 34px !important;
  min-height: 34px !important;
  max-width: 34px !important;
  max-height: 34px !important;
  top: 12px !important;
  right: 12px !important;
  border-radius: 999px !important;
  padding: 0 !important;
  box-shadow: 0 6px 14px rgba(177, 61, 69, 0.16) !important;
}
body .pj-saved-page .pj-saved-card--event.event-card > button.event-card-heart.pj-save-heart.pj-saved-remove > span,
body .pj-saved-page article.pj-saved-card--event.event-card button.event-card-heart.pj-save-heart.pj-saved-remove > span {
  width: 16px !important;
  height: 16px !important;
  min-width: 16px !important;
  min-height: 16px !important;
}


/* PJ 1.5.235: Saved card bottom action row needs a little more vertical room. */
body .pj-saved-page .pj-saved-card--event.pj-saved-card--feed > .pj-saved-card-actions.event-card-bottom.event-card-footer {
  height: auto !important;
  min-height: 56px !important;
  max-height: none !important;
  padding-top: 11px !important;
  padding-bottom: 6px !important;
  overflow: visible !important;
  align-items: center !important;
}
body .pj-saved-page .pj-saved-card--event.pj-saved-card--feed > .pj-saved-card-actions.event-card-bottom.event-card-footer > a,
body .pj-saved-page .pj-saved-card--event.pj-saved-card--feed > .pj-saved-card-actions.event-card-bottom.event-card-footer > .event-calendar-button,
body .pj-saved-page .pj-saved-card--event.pj-saved-card--feed > .pj-saved-card-actions.event-card-bottom.event-card-footer > .event-card-calendar {
  min-height: 38px !important;
  height: 38px !important;
  line-height: 1.15 !important;
  padding-top: 8px !important;
  padding-bottom: 8px !important;
  overflow: visible !important;
}


/* PJ 1.5.276: My Petaluma List saved/remove hearts mirror saved Event-card hearts. */
body .pj-saved-page article.pj-saved-card.pj-saved-card--feed > button.pj-save-heart.pj-saved-remove,
body .pj-saved-page article.pj-saved-card.pj-saved-card--feed > button.pj-save-heart.pj-saved-remove.is-saved,
body .pj-saved-page .pj-saved-card--event.ps-event-card > button.pj-save-heart.pj-saved-remove,
body .pj-saved-page .pj-saved-card--explore > button.pj-save-heart.pj-saved-remove {
  width: 38px !important;
  height: 38px !important;
  min-width: 38px !important;
  min-height: 38px !important;
  max-width: 38px !important;
  max-height: 38px !important;
  border-radius: 999px !important;
  background: #fffaf1 !important;
  color: #a74733 !important;
  border: 1px solid #edcfc6 !important;
  box-shadow: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
}
body .pj-saved-page article.pj-saved-card.pj-saved-card--feed > button.pj-save-heart.pj-saved-remove > span,
body .pj-saved-page article.pj-saved-card.pj-saved-card--feed > button.pj-save-heart.pj-saved-remove [data-pj-save-icon] {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  min-height: 18px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
body .pj-saved-page button.pj-saved-remove svg {
  width: 18px !important;
  height: 18px !important;
  display: block !important;
  fill: #b13d45 !important;
  stroke: none !important;
}
body .pj-saved-page button.pj-saved-remove svg path {
  fill: #b13d45 !important;
  stroke: none !important;
}


/* PJ 1.5.277: remove redundant tiny Saved label/heart from My Petaluma List cards. */
body .pj-saved-page .pj-saved-card .pj-saved-note,
body .pj-saved-page .pj-saved-card .pj-saved-note-heart {
  display: none !important;
}


/* PJ 1.5.279: My Petaluma List selected hearts — keep the circle soft, fill only the heart red. */
body .pj-saved-page article.pj-saved-card.pj-saved-card--feed > button.pj-save-heart.pj-saved-remove,
body .pj-saved-page article.pj-saved-card.pj-saved-card--feed > button.pj-save-heart.pj-saved-remove.is-saved,
body .pj-saved-page .pj-saved-card--event.ps-event-card > button.pj-save-heart.pj-saved-remove,
body .pj-saved-page .pj-saved-card--explore > button.pj-save-heart.pj-saved-remove {
  width: 44px !important;
  height: 44px !important;
  min-width: 44px !important;
  min-height: 44px !important;
  max-width: 44px !important;
  max-height: 44px !important;
  border-radius: 999px !important;
  background: #fffdf8 !important;
  color: #b13d45 !important;
  border: 1px solid #ead8d2 !important;
  box-shadow: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  position: absolute !important;
  overflow: hidden !important;
}
body .pj-saved-page article.pj-saved-card.pj-saved-card--feed > button.pj-save-heart.pj-saved-remove::before {
  content: "" !important;
  position: absolute !important;
  width: 29px !important;
  height: 29px !important;
  border-radius: 999px !important;
  background: #ead8d2 !important;
  left: 50% !important;
  top: 50% !important;
  transform: translate(-50%, -50%) !important;
  z-index: 0 !important;
}
body .pj-saved-page article.pj-saved-card.pj-saved-card--feed > button.pj-save-heart.pj-saved-remove > span,
body .pj-saved-page article.pj-saved-card.pj-saved-card--feed > button.pj-save-heart.pj-saved-remove [data-pj-save-icon] {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  min-height: 18px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  position: relative !important;
  z-index: 1 !important;
}
body .pj-saved-page button.pj-saved-remove svg {
  width: 18px !important;
  height: 18px !important;
  display: block !important;
  fill: #b13d45 !important;
  stroke: none !important;
  position: relative !important;
  z-index: 1 !important;
}
body .pj-saved-page button.pj-saved-remove svg path {
  fill: #b13d45 !important;
  stroke: none !important;
}


/* PJ 1.5.280: shared sitewide SaveButton state — saved means filled heart, unsaved means outline heart. */
body .pj-save-heart,
body .save-button {
  color: #b5531e;
}
body .pj-save-heart svg,
body .save-button svg {
  width: 22px;
  height: 22px;
  display: block;
}
body .pj-save-heart:not(.is-saved) svg,
body .pj-save-heart[data-save-state="unsaved"] svg,
body .save-button:not(.is-saved) svg,
body .save-button[data-save-state="unsaved"] svg {
  fill: none !important;
  stroke: currentColor !important;
}
body .pj-save-heart:not(.is-saved) svg path,
body .pj-save-heart[data-save-state="unsaved"] svg path,
body .save-button:not(.is-saved) svg path,
body .save-button[data-save-state="unsaved"] svg path {
  fill: none !important;
  stroke: currentColor !important;
}
body .pj-save-heart.is-saved,
body .pj-save-heart[data-save-state="saved"],
body .save-button.is-saved,
body .save-button[data-save-state="saved"] {
  color: #b13d45 !important;
}
body .pj-save-heart.is-saved svg,
body .pj-save-heart[data-save-state="saved"] svg,
body .save-button.is-saved svg,
body .save-button[data-save-state="saved"] svg {
  fill: currentColor !important;
  stroke: currentColor !important;
}
body .pj-save-heart.is-saved svg path,
body .pj-save-heart[data-save-state="saved"] svg path,
body .save-button.is-saved svg path,
body .save-button[data-save-state="saved"] svg path {
  fill: currentColor !important;
  stroke: none !important;
}
body .pj-save-heart [data-pj-save-icon],
body .save-button [data-pj-save-icon] {
  -webkit-mask: none !important;
  mask: none !important;
  background: transparent !important;
}
body .pj-save-heart.is-saved [data-pj-save-icon],
body .pj-save-heart[data-save-state="saved"] [data-pj-save-icon],
body .save-button.is-saved [data-pj-save-icon],
body .save-button[data-save-state="saved"] [data-pj-save-icon] {
  color: #b13d45 !important;
}
body .pj-save-heart.is-saved span:not([data-pj-save-label]),
body .pj-save-heart[data-save-state="saved"] span:not([data-pj-save-label]) {
  -webkit-mask: none !important;
  mask: none !important;
}


/* PJ 1.5.281: saved buttons use a soft active button; the heart itself carries the red fill. */
body .pj-save-heart.is-saved:not(.pj-saved-remove),
body .pj-save-heart[data-save-state="saved"]:not(.pj-saved-remove),
body .save-button.is-saved:not(.pj-saved-remove),
body .save-button[data-save-state="saved"]:not(.pj-saved-remove) {
  background: #f7e8df !important;
  border-color: #e2b9a6 !important;
  color: #b13d45 !important;
  box-shadow: none !important;
}
body .pj-save-heart.is-saved:not(.pj-saved-remove) svg,
body .pj-save-heart[data-save-state="saved"]:not(.pj-saved-remove) svg,
body .save-button.is-saved:not(.pj-saved-remove) svg,
body .save-button[data-save-state="saved"]:not(.pj-saved-remove) svg,
body .pj-save-heart.is-saved:not(.pj-saved-remove) svg path,
body .pj-save-heart[data-save-state="saved"]:not(.pj-saved-remove) svg path,
body .save-button.is-saved:not(.pj-saved-remove) svg path,
body .save-button[data-save-state="saved"]:not(.pj-saved-remove) svg path {
  fill: #b13d45 !important;
  stroke: none !important;
}


/* PJ 1.5.283: saved state is only a filled red heart — no inner shaded circle, no square active fill. */
body .pj-saved-page article.pj-saved-card.pj-saved-card--feed > button.pj-save-heart.pj-saved-remove::before {
  content: none !important;
  display: none !important;
}
body .pj-saved-page article.pj-saved-card.pj-saved-card--feed > button.pj-save-heart.pj-saved-remove,
body .pj-saved-page article.pj-saved-card.pj-saved-card--feed > button.pj-save-heart.pj-saved-remove.is-saved,
body .pj-saved-page .pj-saved-card--event.ps-event-card > button.pj-save-heart.pj-saved-remove,
body .pj-saved-page .pj-saved-card--explore > button.pj-save-heart.pj-saved-remove {
  background: #fffdf8 !important;
  border: 1px solid #ead8d2 !important;
  border-radius: 999px !important;
  box-shadow: none !important;
  color: #b13d45 !important;
}
body .pj-save-heart.is-saved:not(.pj-saved-remove),
body .pj-save-heart[data-save-state="saved"]:not(.pj-saved-remove),
body .save-button.is-saved:not(.pj-saved-remove),
body .save-button[data-save-state="saved"]:not(.pj-saved-remove) {
  background: #fffdf8 !important;
  border-color: #ead8cf !important;
  border-radius: 999px !important;
  color: #b13d45 !important;
  box-shadow: none !important;
}
body .pj-explore-card-action.pj-save-heart.is-saved,
body .pj-explore-card-action.pj-save-heart[data-save-state="saved"],
body .pj-detail-btn.pj-save-heart.is-saved,
body .pj-detail-btn.pj-save-heart[data-save-state="saved"] {
  border-radius: 999px !important;
}
body .pj-save-heart.is-saved svg,
body .pj-save-heart[data-save-state="saved"] svg,
body .save-button.is-saved svg,
body .save-button[data-save-state="saved"] svg,
body .pj-save-heart.is-saved svg path,
body .pj-save-heart[data-save-state="saved"] svg path,
body .save-button.is-saved svg path,
body .save-button[data-save-state="saved"] svg path {
  fill: #b13d45 !important;
  stroke: none !important;
}
body .pj-save-heart:not(.is-saved) svg,
body .pj-save-heart[data-save-state="unsaved"] svg,
body .pj-save-heart:not(.is-saved) svg path,
body .pj-save-heart[data-save-state="unsaved"] svg path {
  fill: none !important;
  stroke: currentColor !important;
}


/* PJ 1.5.284: exact saved-heart circle target — cream circle, pale border, centered filled red heart. */
body .ps-event-heart.pj-save-heart,
body .pj-search-save.pj-save-heart,
body .pj-related-save.pj-save-heart,
body .pj-saved-page article.pj-saved-card.pj-saved-card--feed > button.pj-save-heart.pj-saved-remove {
  width: 46px !important;
  height: 46px !important;
  min-width: 46px !important;
  min-height: 46px !important;
  max-width: 46px !important;
  max-height: 46px !important;
  aspect-ratio: 1 / 1 !important;
  border-radius: 999px !important;
  background: #fffdf8 !important;
  border: 1px solid #ead8d2 !important;
  color: #8f2430 !important;
  box-shadow: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  overflow: hidden !important;
  background-clip: padding-box !important;
}
body .ps-event-heart.pj-save-heart::before,
body .pj-search-save.pj-save-heart::before,
body .pj-related-save.pj-save-heart::before,
body .pj-saved-page article.pj-saved-card.pj-saved-card--feed > button.pj-save-heart.pj-saved-remove::before {
  content: none !important;
  display: none !important;
}
body .ps-event-heart.pj-save-heart svg,
body .pj-search-save.pj-save-heart svg,
body .pj-related-save.pj-save-heart svg,
body .pj-saved-page button.pj-saved-remove svg {
  width: 22px !important;
  height: 22px !important;
  display: block !important;
}
body .ps-event-heart.pj-save-heart.is-saved,
body .ps-event-heart.pj-save-heart[data-save-state="saved"],
body .pj-search-save.pj-save-heart.is-saved,
body .pj-search-save.pj-save-heart[data-save-state="saved"],
body .pj-related-save.pj-save-heart.is-saved,
body .pj-related-save.pj-save-heart[data-save-state="saved"],
body .pj-saved-page button.pj-saved-remove.is-saved,
body .pj-saved-page button.pj-saved-remove[data-save-state="saved"] {
  background: #fffdf8 !important;
  border-color: #ead8d2 !important;
  color: #8f2430 !important;
  border-radius: 999px !important;
}
body .ps-event-heart.pj-save-heart.is-saved svg,
body .ps-event-heart.pj-save-heart[data-save-state="saved"] svg,
body .pj-search-save.pj-save-heart.is-saved svg,
body .pj-search-save.pj-save-heart[data-save-state="saved"] svg,
body .pj-related-save.pj-save-heart.is-saved svg,
body .pj-related-save.pj-save-heart[data-save-state="saved"] svg,
body .pj-saved-page button.pj-saved-remove svg,
body .ps-event-heart.pj-save-heart.is-saved svg path,
body .ps-event-heart.pj-save-heart[data-save-state="saved"] svg path,
body .pj-search-save.pj-save-heart.is-saved svg path,
body .pj-search-save.pj-save-heart[data-save-state="saved"] svg path,
body .pj-related-save.pj-save-heart.is-saved svg path,
body .pj-related-save.pj-save-heart[data-save-state="saved"] svg path,
body .pj-saved-page button.pj-saved-remove svg path {
  fill: #8f2430 !important;
  stroke: none !important;
}
body .ps-event-heart.pj-save-heart:not(.is-saved) svg,
body .ps-event-heart.pj-save-heart[data-save-state="unsaved"] svg,
body .pj-search-save.pj-save-heart:not(.is-saved) svg,
body .pj-search-save.pj-save-heart[data-save-state="unsaved"] svg,
body .pj-related-save.pj-save-heart:not(.is-saved) svg,
body .pj-related-save.pj-save-heart[data-save-state="unsaved"] svg,
body .ps-event-heart.pj-save-heart:not(.is-saved) svg path,
body .ps-event-heart.pj-save-heart[data-save-state="unsaved"] svg path,
body .pj-search-save.pj-save-heart:not(.is-saved) svg path,
body .pj-search-save.pj-save-heart[data-save-state="unsaved"] svg path,
body .pj-related-save.pj-save-heart:not(.is-saved) svg path,
body .pj-related-save.pj-save-heart[data-save-state="unsaved"] svg path {
  fill: none !important;
  stroke: currentColor !important;
}


/* PJ 1.5.285: final high-specificity guard — no square, no inner disk; just cream circle + filled red heart. */
html body .pj-saved-page article.pj-saved-card.pj-saved-card--feed > button.event-card-heart.pj-save-heart.pj-saved-remove,
html body .pj-saved-page article.pj-saved-card.pj-saved-card--feed > button.event-card-heart.pj-save-heart.pj-saved-remove.is-saved,
html body .pj-saved-page article.pj-saved-card.pj-saved-card--feed > button.event-card-heart.pj-save-heart.pj-saved-remove[data-save-state="saved"] {
  width: 44px !important;
  height: 44px !important;
  min-width: 44px !important;
  min-height: 44px !important;
  max-width: 44px !important;
  max-height: 44px !important;
  aspect-ratio: 1 / 1 !important;
  background: #fffdf8 !important;
  border: 1px solid #ead8d2 !important;
  border-radius: 50% !important;
  color: #8f2430 !important;
  box-shadow: none !important;
  padding: 0 !important;
  overflow: hidden !important;
}
html body .pj-saved-page article.pj-saved-card.pj-saved-card--feed > button.event-card-heart.pj-save-heart.pj-saved-remove::before,
html body .pj-saved-page article.pj-saved-card.pj-saved-card--feed > button.event-card-heart.pj-save-heart.pj-saved-remove::after {
  content: none !important;
  display: none !important;
}
html body .pj-save-heart.is-saved,
html body .pj-save-heart[data-save-state="saved"],
html body .save-button.is-saved,
html body .save-button[data-save-state="saved"] {
  background: #fffdf8 !important;
  border-color: #ead8d2 !important;
  border-radius: 999px !important;
  color: #8f2430 !important;
  box-shadow: none !important;
}
html body .pj-save-heart.is-saved svg,
html body .pj-save-heart[data-save-state="saved"] svg,
html body .save-button.is-saved svg,
html body .save-button[data-save-state="saved"] svg {
  fill: #8f2430 !important;
  stroke: none !important;
}
html body .pj-save-heart.is-saved svg path,
html body .pj-save-heart[data-save-state="saved"] svg path,
html body .save-button.is-saved svg path,
html body .save-button[data-save-state="saved"] svg path {
  fill: #8f2430 !important;
  stroke: none !important;
}


/* PJ 1.5.286: remove red square/mask behind filled hearts; only the SVG heart should be red. */
html body .pj-save-heart > span:not([data-pj-save-label]),
html body .pj-save-heart.is-saved > span:not([data-pj-save-label]),
html body .pj-save-heart[data-save-state="saved"] > span:not([data-pj-save-label]),
html body .save-button > span:not([data-pj-save-label]),
html body .save-button.is-saved > span:not([data-pj-save-label]),
html body .save-button[data-save-state="saved"] > span:not([data-pj-save-label]) {
  background: transparent !important;
  background-color: transparent !important;
  -webkit-mask: none !important;
  mask: none !important;
  border: 0 !important;
  box-shadow: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}
html body .pj-save-heart svg,
html body .pj-save-heart svg path,
html body .save-button svg,
html body .save-button svg path {
  background: transparent !important;
  background-color: transparent !important;
  -webkit-mask: none !important;
  mask: none !important;
}
html body .pj-save-heart.is-saved svg,
html body .pj-save-heart[data-save-state="saved"] svg,
html body .pj-save-heart.is-saved svg path,
html body .pj-save-heart[data-save-state="saved"] svg path,
html body .save-button.is-saved svg,
html body .save-button[data-save-state="saved"] svg,
html body .save-button.is-saved svg path,
html body .save-button[data-save-state="saved"] svg path {
  fill: #8f2430 !important;
  stroke: none !important;
}


/* PJ 1.5.287: remove section-level Save All controls from Events/Home UI. */
.pj-save-all-button,
[data-pj-save-all] {
  display: none !important;
}


/* PJ 1.5.288: remove the divider line under Events More Filters / Date row. */
body .pj-archive-theme--events .pj-filter-stack,
body .pj-archive-theme-scope.pj-archive-theme--events .pj-filter-stack,
body .pj-filter-stack--events,
body .pj-filter-stack--events .pj-primary-filter-bar,
body .pj-filter-stack--events .pj-events-filter-actions,
body .pj-archive-theme-scope .pj-filter-stack--events .pj-primary-filter-bar,
body .pj-archive-theme-scope .pj-events-filter-actions {
  border-bottom: 0 !important;
  box-shadow: none !important;
}
body .pj-filter-stack--events::after,
body .pj-filter-stack--events .pj-events-filter-actions::after,
body .pj-filter-stack--events .pj-primary-filter-bar::before {
  content: none !important;
  display: none !important;
}


/* PJ 1.5.289: remove the visible divider under the compact Events utility row. */
body .pj-filter-stack--events,
body .pj-filter-stack--events.ps-events-compact,
body .pj-filter-stack--events .ps-date-chip-row,
body .pj-filter-stack--events .ps-events-utility-row,
body .pj-filter-stack--events .ps-more-filters,
body .pj-filter-stack--events .pj-date-form {
  border-bottom: 0 !important;
  box-shadow: none !important;
}
body .pj-filter-stack--events .ps-events-utility-row::before,
body .pj-filter-stack--events .ps-events-utility-row::after,
body .pj-filter-stack--events .ps-date-chip-row::before {
  content: none !important;
  display: none !important;
}

/* PJ 1.5.290: Saved Plan Your Day mobile cleanup — keep text lanes separate and stop overlap. */
@media (max-width: 640px) {
  body .pj-saved-page .pj-saved-plan {
    box-sizing: border-box !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 82px !important;
    align-items: center !important;
    gap: 10px !important;
    width: 100% !important;
    min-height: 142px !important;
    padding: 12px !important;
    overflow: hidden !important;
  }
  body .pj-saved-page .pj-saved-plan-main {
    min-width: 0 !important;
    display: grid !important;
    align-content: center !important;
    gap: 8px !important;
    overflow: hidden !important;
  }
  body .pj-saved-page .pj-saved-plan-head {
    min-width: 0 !important;
    display: grid !important;
    grid-template-columns: 40px minmax(0, 1fr) !important;
    align-items: center !important;
    gap: 9px !important;
    overflow: hidden !important;
  }
  body .pj-saved-page .pj-saved-plan-mark--exact {
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    flex-basis: 40px !important;
  }
  body .pj-saved-page .pj-saved-plan-copy {
    min-width: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 3px !important;
    overflow: hidden !important;
  }
  body .pj-saved-page .pj-saved-plan .pj-saved-plan-label {
    display: block !important;
    font-size: 10px !important;
    line-height: 1.15 !important;
    letter-spacing: .13em !important;
    white-space: nowrap !important;
  }
  body .pj-saved-page .pj-saved-plan [data-pj-saved-plan-summary] {
    display: block !important;
    margin: 0 !important;
    font-family: var(--font-sans) !important;
    font-size: 12.5px !important;
    font-weight: 800 !important;
    line-height: 1.25 !important;
    color: #5f4b3e !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }
  body .pj-saved-page .pj-saved-plan-next {
    display: block !important;
    margin: 1px 0 0 !important;
    max-width: 100% !important;
    min-height: 16px !important;
    max-height: 18px !important;
    font-family: var(--font-sans) !important;
    font-size: 12.5px !important;
    font-weight: 850 !important;
    line-height: 1.3 !important;
    color: #201a16 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    -webkit-line-clamp: unset !important;
    line-clamp: unset !important;
    -webkit-box-orient: initial !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    hyphens: none !important;
  }
  body .pj-saved-page .pj-saved-plan-next[hidden] {
    display: none !important;
  }
  body .pj-saved-page .pj-saved-plan-time {
    display: block !important;
    margin: 0 !important;
    max-width: 100% !important;
    min-height: 18px !important;
    height: auto !important;
    font-family: var(--font-sans) !important;
    font-size: 12px !important;
    font-weight: 800 !important;
    line-height: 1.45 !important;
    color: #8b5f46 !important;
    white-space: nowrap !important;
    overflow: visible !important;
    text-overflow: clip !important;
    padding: 1px 0 !important;
  }
  body .pj-saved-page .pj-saved-plan-time[hidden] {
    display: none !important;
  }
  body .pj-saved-page .pj-saved-plan-note--exact {
    box-sizing: border-box !important;
    display: block !important;
    width: min(178px, 100%) !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: hidden !important;
  }
  body .pj-saved-page .pj-saved-plan-note--exact img {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
  }
  body .pj-saved-page .pj-saved-sort-box--exact,
  body .pj-saved-page button[data-pj-saved-sort].pj-saved-sort-box--exact {
    box-sizing: border-box !important;
    justify-self: end !important;
    align-self: center !important;
    width: 82px !important;
    min-width: 82px !important;
    max-width: 82px !important;
    height: 124px !important;
    min-height: 124px !important;
    max-height: 124px !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 18px !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: visible !important;
  }
  body .pj-saved-page .pj-saved-sort-box--exact img,
  body .pj-saved-page button[data-pj-saved-sort].pj-saved-sort-box--exact img[src*="day-order-smart-sort-exact"] {
    display: block !important;
    width: 80px !important;
    max-width: 80px !important;
    height: 121px !important;
    max-height: 121px !important;
    object-fit: contain !important;
  }
}
@media (max-width: 370px) {
  body .pj-saved-page .pj-saved-plan {
    grid-template-columns: minmax(0, 1fr) 76px !important;
    gap: 8px !important;
    min-height: 136px !important;
    padding: 11px !important;
  }
  body .pj-saved-page .pj-saved-plan-head {
    grid-template-columns: 36px minmax(0, 1fr) !important;
    gap: 8px !important;
  }
  body .pj-saved-page .pj-saved-plan-mark--exact {
    width: 36px !important;
    height: 36px !important;
    min-width: 36px !important;
  }
  body .pj-saved-page .pj-saved-plan [data-pj-saved-plan-summary],
  body .pj-saved-page .pj-saved-plan-next {
    font-size: 12px !important;
  }
  body .pj-saved-page .pj-saved-plan-time {
    font-size: 11.5px !important;
  }
  body .pj-saved-page .pj-saved-sort-box--exact,
  body .pj-saved-page button[data-pj-saved-sort].pj-saved-sort-box--exact {
    width: 76px !important;
    min-width: 76px !important;
    max-width: 76px !important;
    height: 115px !important;
    min-height: 115px !important;
    max-height: 115px !important;
  }
  body .pj-saved-page .pj-saved-sort-box--exact img,
  body .pj-saved-page button[data-pj-saved-sort].pj-saved-sort-box--exact img[src*="day-order-smart-sort-exact"] {
    width: 74px !important;
    max-width: 74px !important;
    height: 112px !important;
    max-height: 112px !important;
  }
}

/* PJ 1.5.291: focused hamburger menu drawer. */
html.pj-menu-is-open,
body.pj-menu-is-open {
  overflow: hidden !important;
  overscroll-behavior: none;
  touch-action: none;
}
.pj-header-icon--menu {
  appearance: none;
  -webkit-appearance: none;
  border: 0;
  background: transparent;
  cursor: pointer;
}
.pj-menu-overlay[hidden],
.pj-menu-drawer[aria-hidden="true"] {
  display: none !important;
}
.pj-menu-overlay {
  position: fixed;
  inset: 0;
  z-index: 39990;
  background: rgba(39, 31, 24, 0.34);
  backdrop-filter: blur(4px);
}
.pj-menu-drawer {
  position: fixed;
  inset: 0;
  z-index: 40000;
  display: flex;
  justify-content: flex-start;
  pointer-events: none;
}
.pj-menu-panel {
  pointer-events: auto;
  box-sizing: border-box;
  width: min(88vw, 390px);
  height: 100dvh;
  max-height: 100dvh;
  overflow-y: auto;
  padding: calc(18px + env(safe-area-inset-top)) 18px calc(22px + env(safe-area-inset-bottom));
  background: #fff8ec;
  color: #2d2118;
  border-right: 1px solid rgba(116, 78, 45, 0.14);
  box-shadow: 18px 0 42px rgba(39,31,24,.18);
}
.pj-menu-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 4px 0 16px;
  border-bottom: 1px solid rgba(116, 78, 45, 0.12);
}
.pj-menu-head strong {
  display: block;
  font-family: 'Playfair Display', Georgia, serif;
  color: #2d2118;
  font-size: 25px;
  line-height: 1.05;
  letter-spacing: -0.02em;
}
.pj-menu-head span {
  display: block;
  margin-top: 4px;
  color: #a74733;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .16em;
  text-transform: uppercase;
}
.pj-menu-close {
  width: 44px;
  height: 44px;
  min-width: 44px;
  border: 1px solid rgba(167, 71, 51, .18);
  border-radius: 999px;
  background: #fffdf8;
  color: #8f2430;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
}
.pj-menu-sections {
  display: grid;
  gap: 0;
}
.pj-menu-section {
  padding: 15px 0;
  border-bottom: 1px solid rgba(116, 78, 45, 0.10);
}
.pj-menu-section:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}
.pj-menu-section h2 {
  margin: 0 0 8px;
  color: #a74733;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .14em;
  line-height: 1.15;
  text-transform: uppercase;
}
.pj-menu-row {
  box-sizing: border-box;
  min-height: 46px;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 13px;
  border-radius: 15px;
  color: #33261d;
  text-decoration: none;
  font-size: 15px;
  font-weight: 780;
  line-height: 1.2;
  -webkit-tap-highlight-color: transparent;
}
.pj-menu-row:hover,
.pj-menu-row:focus-visible {
  background: rgba(167, 71, 51, .08);
  outline: none;
}
.pj-menu-row.is-active {
  background: #f7e8df;
  color: #8f2430;
  box-shadow: inset 0 0 0 1px rgba(143, 36, 48, .11);
}
.pj-menu-row--primary {
  margin: 5px 0;
  min-height: 48px;
  justify-content: center;
  border-radius: 999px;
  background: linear-gradient(135deg, #b5531e, #8f2430);
  color: #fff !important;
  text-align: center;
  box-shadow: 0 10px 20px rgba(143,36,48,.16);
}
.pj-menu-row--primary:hover,
.pj-menu-row--primary:focus-visible,
.pj-menu-row--primary.is-active {
  background: linear-gradient(135deg, #9f421c, #7b1f2a);
  color: #fff !important;
  box-shadow: 0 12px 24px rgba(143,36,48,.20);
}
.pj-info-page {
  width: min(760px, calc(100% - 28px));
  margin: 0 auto;
  padding: 34px 0 120px;
}
.pj-info-card {
  padding: 26px;
  border-radius: 28px;
  background: #fffdf8;
  border: 1px solid rgba(45, 35, 25, .08);
  box-shadow: 0 16px 36px rgba(39,31,24,.08);
}
.pj-info-eyebrow {
  margin: 0 0 8px;
  color: #a74733;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .16em;
  text-transform: uppercase;
}
.pj-info-card h1 {
  margin: 0 0 12px;
  font-family: 'Playfair Display', Georgia, serif;
  font-size: clamp(32px, 9vw, 54px);
  line-height: .98;
  letter-spacing: -.045em;
  color: #251c16;
}
.pj-info-card p {
  margin: 0 0 20px;
  color: #6f5f54;
  font-size: 16px;
  line-height: 1.55;
}
.pj-info-primary {
  display: inline-flex;
  min-height: 46px;
  align-items: center;
  justify-content: center;
  padding: 12px 18px;
  border-radius: 999px;
  background: linear-gradient(135deg, #b5531e, #8f2430);
  color: #fff;
  text-decoration: none;
  font-weight: 900;
}
@media (max-width: 520px) {
  .pj-menu-drawer {
    align-items: flex-end;
    justify-content: center;
  }
  .pj-menu-panel {
    width: 100%;
    height: min(88dvh, 760px);
    max-height: 88dvh;
    border-right: 0;
    border-top: 1px solid rgba(116, 78, 45, 0.14);
    border-radius: 28px 28px 0 0;
    box-shadow: 0 -18px 42px rgba(39,31,24,.20);
  }
}

/* Staging fix: keep the global header/nav pinned above Explore filters while scrolling. */
.pj-sticky-header {
    z-index: 12000;
}
.pj-filter-stack {
    top: var(--pj-sticky-header-offset, 120px);
}
@media (min-width: 768px) {
    .pj-filter-stack {
        top: var(--pj-sticky-header-offset, 120px);
    }
}

/* Staging fix: make Explore sticky filter area opaque/full-bleed so scrolled cards never show through. */
.pj-archive-theme-scope .pj-filter-stack--explore {
    background: var(--pj-theme-soft) !important;
    box-shadow: 0 1px 0 var(--pj-theme-border) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}
.pj-archive-theme-scope .pj-filter-stack--explore::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: -12px;
    height: 12px;
    background: var(--pj-theme-soft);
    pointer-events: none;
}
.pj-archive-theme-scope .pj-filter-stack--explore .pj-primary-filter-bar,
.pj-archive-theme-scope .pj-filter-stack--explore .pj-explore-filter-actions,
.pj-archive-theme-scope .pj-filter-stack--explore .pj-more-filters,
.pj-archive-theme-scope .pj-filter-stack--explore .pj-explore-filter-form {
    background: var(--pj-theme-soft) !important;
}


/* PJ 1.5.298: subtle line icons inside the curated hamburger menu. */
.pj-menu-row {
  justify-content: flex-start;
}
.pj-menu-icon {
  flex: 0 0 20px;
  width: 20px;
  height: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #9f4b2f;
  opacity: .9;
}
.pj-menu-icon svg {
  width: 19px;
  height: 19px;
  display: block;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.pj-menu-label {
  min-width: 0;
  flex: 1 1 auto;
}
.pj-menu-section[aria-labelledby="pj-menu-browse-title"] .pj-menu-icon {
  color: #6f5f54;
  opacity: .72;
}
.pj-menu-row.is-active .pj-menu-icon,
.pj-menu-row:hover .pj-menu-icon,
.pj-menu-row:focus-visible .pj-menu-icon {
  color: #8f2430;
  opacity: 1;
}
.pj-menu-row--primary {
  justify-content: flex-start;
}
.pj-menu-row--primary .pj-menu-icon {
  color: #fff8ec;
  opacity: .96;
}
.pj-menu-row--primary .pj-menu-label {
  color: inherit;
}

/* ── Services browse section ───────────────────────────────── */
.pj-top-nav--browse {
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}
.pj-top-nav--browse::-webkit-scrollbar { display: none; }
.pj-top-nav--browse a {
    flex: 1 0 0;
    min-width: 0;
}
.pj-top-nav--browse a.active {
    background: #b95b34;
    border-color: #b95b34;
    color: #fffdf8;
    box-shadow: 0 5px 14px rgba(185,91,52,.18);
}
.pj-services-page {
    min-height: 70vh;
    background: linear-gradient(180deg, #fff8f1 0, #fffdf9 260px, #fffaf2 100%);
    padding: 18px 18px 120px;
}
.pj-services-hero,
.pj-services-intro,
.pj-services-categories {
    max-width: 980px;
    margin: 0 auto;
}
.pj-services-hero {
    text-align: center;
    padding: 26px 12px 16px;
}
.pj-services-kicker {
    color: #a25d35;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .16em;
    text-transform: uppercase;
}
.pj-services-hero h1 {
    margin-top: 6px;
    font-family: var(--font-serif);
    font-size: clamp(32px, 6vw, 54px);
    line-height: .98;
    color: #271f18;
    letter-spacing: -.04em;
}
.pj-services-hero p {
    max-width: 560px;
    margin: 12px auto 0;
    color: #6f5c4c;
    font-size: 16px;
    line-height: 1.45;
}
.pj-services-purpose-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    margin: 10px auto 24px;
}
.pj-services-purpose-grid div {
    border: 1px solid rgba(39,31,24,.12);
    border-radius: 18px;
    background: rgba(255,255,255,.72);
    padding: 14px 14px;
    box-shadow: 0 10px 26px rgba(95,36,48,.05);
}
.pj-services-purpose-grid .is-active {
    border-color: rgba(185,91,52,.30);
    background: #fff1e7;
}
.pj-services-purpose-grid strong,
.pj-services-purpose-grid span {
    display: block;
}
.pj-services-purpose-grid strong {
    color: #271f18;
    font-size: 14px;
    font-weight: 900;
}
.pj-services-purpose-grid span {
    margin-top: 2px;
    color: #766252;
    font-size: 12.5px;
    line-height: 1.25;
}
.pj-services-section-head {
    text-align: center;
    margin: 8px auto 18px;
}
.pj-services-section-head h2 {
    margin-top: 4px;
    font-family: var(--font-serif);
    font-size: clamp(26px, 4vw, 36px);
    line-height: 1;
    color: #271f18;
}
.pj-services-section-head p:not(.pj-services-kicker) {
    max-width: 620px;
    margin: 8px auto 0;
    color: #6f5c4c;
    font-size: 14px;
}
.pj-services-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}
.pj-service-category-card {
    position: relative;
    min-height: 150px;
    border: 1px solid rgba(39,31,24,.12);
    border-radius: 22px;
    background: #fffdf9;
    padding: 18px 16px 16px;
    box-shadow: 0 14px 34px rgba(95,36,48,.055);
}
.pj-service-category-dot {
    display: inline-block;
    width: 28px;
    height: 28px;
    border-radius: 999px;
    background: radial-gradient(circle at 35% 30%, #ffd9bd, #c96c3c 62%, #8f3a2b 100%);
    box-shadow: 0 7px 16px rgba(185,91,52,.20);
}
.pj-service-category-card h3 {
    margin-top: 12px;
    color: #271f18;
    font-size: 16px;
    line-height: 1.12;
    font-weight: 900;
}
.pj-service-category-card p {
    margin-top: 7px;
    color: #6f5c4c;
    font-size: 13px;
    line-height: 1.35;
}
@media (max-width: 760px) {
    .pj-top-nav--browse {
        justify-content: flex-start;
        max-width: min(100%, 360px);
        gap: 0;
        padding: 3px;
    }
    .pj-top-nav--browse a {
        flex: 1 0 33.333%;
        min-width: 92px;
        padding: 8px 8px;
        font-size: 12px;
    }
    .pj-services-page {
        padding: 10px 14px 120px;
    }
    .pj-services-hero {
        padding-top: 20px;
    }
    .pj-services-hero h1 {
        font-size: 34px;
    }
    .pj-services-hero p {
        font-size: 14px;
    }
    .pj-services-purpose-grid {
        grid-template-columns: 1fr;
        gap: 8px;
        margin-bottom: 22px;
    }
    .pj-services-purpose-grid div {
        padding: 12px 14px;
    }
    .pj-services-grid {
        grid-template-columns: 1fr;
        gap: 10px;
    }
    .pj-service-category-card {
        min-height: 0;
        padding: 16px;
    }
}
@media (min-width: 761px) and (max-width: 980px) {
    .pj-services-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* Final Services nav no-wrap guard: three browse tabs must stay visible. */
.pj-top-nav--browse {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    width: min(100%, 360px);
    max-width: 360px;
    overflow: visible;
}
.pj-top-nav--browse a {
    min-width: 0 !important;
    width: auto;
    white-space: nowrap;
}
@media (max-width: 760px) {
    .pj-top-nav--browse {
        width: min(100%, 342px);
        max-width: 342px;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 0;
    }
    .pj-top-nav--browse a {
        flex: none;
        min-width: 0 !important;
        padding-left: 5px;
        padding-right: 5px;
        font-size: 11.5px;
        letter-spacing: -.01em;
    }
}

/* Services top browse nav hard no-wrap fix. Keep Events / Explore / Services in one row. */
.pj-site-header .pj-top-nav.pj-top-nav--browse {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    justify-content: center !important;
    width: min(100%, 360px) !important;
    max-width: calc(100vw - 32px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    gap: 0 !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    box-sizing: border-box !important;
    scrollbar-width: none;
}
.pj-site-header .pj-top-nav.pj-top-nav--browse::-webkit-scrollbar { display: none; }
.pj-site-header .pj-top-nav.pj-top-nav--browse a {
    flex: 1 1 0 !important;
    min-width: 0 !important;
    max-width: none !important;
    width: auto !important;
    box-sizing: border-box !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}
@media (max-width: 760px) {
    .pj-site-header .pj-top-nav.pj-top-nav--browse {
        width: min(100%, 342px) !important;
        max-width: calc(100vw - 32px) !important;
        padding: 3px !important;
    }
    .pj-site-header .pj-top-nav.pj-top-nav--browse a {
        min-height: 31px !important;
        padding: 7px 4px !important;
        font-size: 11px !important;
        line-height: 1 !important;
        letter-spacing: -.02em !important;
    }
}

/* v1.5.300: iPhone hard fix for 3-tab browse nav — never wrap Services. */
.pj-site-header nav.pj-top-nav.pj-top-nav--browse {
    display: flex !important;
    flex-flow: row nowrap !important;
    justify-content: center !important;
    align-items: stretch !important;
    gap: 0 !important;
    width: calc(100vw - 32px) !important;
    max-width: 342px !important;
    min-width: 0 !important;
    margin: 7px auto 0 !important;
    padding: 3px !important;
    overflow: hidden !important;
}
.pj-site-header nav.pj-top-nav.pj-top-nav--browse > a {
    display: flex !important;
    flex: 0 1 33.333% !important;
    width: 33.333% !important;
    min-width: 0 !important;
    max-width: 33.333% !important;
    margin: 0 !important;
    padding: 7px 2px !important;
    box-sizing: border-box !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: clip !important;
    font-size: 10.75px !important;
    line-height: 1 !important;
    letter-spacing: -.035em !important;
}
.pj-site-header nav.pj-top-nav.pj-top-nav--browse > a > span {
    display: block !important;
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    text-overflow: clip !important;
}
@media (max-width: 374px) {
    .pj-site-header nav.pj-top-nav.pj-top-nav--browse {
        width: calc(100vw - 24px) !important;
    }
    .pj-site-header nav.pj-top-nav.pj-top-nav--browse > a {
        font-size: 10.25px !important;
        padding-left: 1px !important;
        padding-right: 1px !important;
    }
}


/* Services scalable directory shell v1.5.301 */
.pj-services-hero-actions,
.pj-services-empty {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
    justify-content: center;
}
.pj-services-primary-cta,
.pj-services-secondary-cta,
.pj-service-business-actions a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 10px 16px;
    border-radius: 999px;
    font-weight: 900;
    text-decoration: none;
}
.pj-services-primary-cta {
    background: #b94726;
    color: #fff;
    box-shadow: 0 10px 22px rgba(145, 64, 33, .18);
}
.pj-services-secondary-cta,
.pj-service-business-actions a {
    background: #fffaf3;
    color: #4d3326;
    border: 1px solid rgba(108, 70, 42, .16);
}
.pj-service-category-card {
    color: inherit;
    text-decoration: none;
}
.pj-service-category-card:focus-visible,
.pj-service-business-card a:focus-visible,
.pj-services-primary-cta:focus-visible,
.pj-services-secondary-cta:focus-visible {
    outline: 3px solid rgba(185, 71, 38, .35);
    outline-offset: 3px;
}
.pj-service-category-examples {
    display: block;
    margin-top: 12px;
    color: #8a6b57;
    font-size: .9rem;
    font-weight: 800;
}
.pj-services-search,
.pj-service-listings,
.pj-service-profile-card,
.pj-services-empty {
    width: min(980px, calc(100% - 32px));
    margin: 18px auto;
    background: rgba(255, 250, 243, .92);
    border: 1px solid rgba(108, 70, 42, .12);
    border-radius: 24px;
    padding: 20px;
    box-shadow: 0 14px 30px rgba(75, 49, 28, .07);
}
.pj-services-search label {
    display: block;
    margin-bottom: 8px;
    color: #3d2b22;
    font-weight: 900;
}
.pj-services-search div {
    display: flex;
    gap: 10px;
}
.pj-services-search input {
    flex: 1 1 auto;
    min-width: 0;
    border: 1px solid rgba(108, 70, 42, .16);
    border-radius: 999px;
    padding: 12px 14px;
    font: inherit;
    background: #fff;
}
.pj-services-search button {
    border: 0;
    border-radius: 999px;
    padding: 12px 16px;
    background: #b94726;
    color: #fff;
    font-weight: 900;
}
.pj-services-search p,
.pj-service-business-meta,
.pj-service-business-area {
    color: #7f6757;
    font-size: .92rem;
}
.pj-service-business-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 14px;
    padding: 16px 0;
    border-top: 1px solid rgba(108, 70, 42, .10);
}
.pj-service-business-card:first-of-type { border-top: 0; }
.pj-service-business-card h3 {
    margin: 6px 0;
    font-family: 'Playfair Display', Georgia, serif;
    font-size: clamp(1.25rem, 3.8vw, 1.7rem);
}
.pj-service-business-card h3 a { color: #271b15; text-decoration: none; }
.pj-service-business-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
    align-items: flex-end;
}
.pj-service-paid-label {
    display: inline-flex;
    width: fit-content;
    border-radius: 999px;
    padding: 5px 9px;
    background: #f2dfc7;
    color: #7b3d22;
    font-size: .76rem;
    font-weight: 950;
    letter-spacing: .04em;
    text-transform: uppercase;
}
.pj-service-paid-label--hero { margin-bottom: 10px; }
.pj-service-profile-card dl { margin: 0; }
.pj-service-profile-card div {
    display: grid;
    grid-template-columns: 150px minmax(0, 1fr);
    gap: 12px;
    padding: 12px 0;
    border-top: 1px solid rgba(108, 70, 42, .10);
}
.pj-service-profile-card div:first-child { border-top: 0; }
.pj-service-profile-card dt { color: #7b604e; font-weight: 900; }
.pj-service-profile-card dd { margin: 0; color: #2b211c; }
.pj-services-empty { text-align: center; flex-direction: column; }
.pj-services-empty h2,
.pj-services-empty h3 { margin: 0; font-family: 'Playfair Display', Georgia, serif; }
.pj-services-empty p { margin: 0; color: #6f594b; }
@media (max-width: 640px) {
    .pj-services-search,
    .pj-service-listings,
    .pj-service-profile-card,
    .pj-services-empty { width: min(100% - 24px, 560px); padding: 16px; border-radius: 20px; }
    .pj-services-search div { flex-direction: column; }
    .pj-service-business-card { grid-template-columns: 1fr; }
    .pj-service-business-actions { flex-direction: row; align-items: stretch; }
    .pj-service-business-actions a { flex: 1 1 0; }
    .pj-service-profile-card div { grid-template-columns: 1fr; gap: 4px; }
}

/* Final staging fixes: Saved empty state, Services polish, compact event filters v1.5.302 */
.pj-saved-shell[data-saved-state="loading"] [data-pj-saved-actions],
.pj-saved-shell[data-saved-state="loading"] [data-pj-saved-plan],
.pj-saved-shell[data-saved-state="loading"] [data-pj-saved-helper],
.pj-saved-shell[data-saved-state="loading"] [data-pj-saved-clear],
.pj-saved-shell[data-saved-state="loading"] [data-pj-saved-filters],
.pj-saved-shell[data-saved-state="loading"] [data-pj-saved-list],
.pj-saved-shell[data-saved-state="loading"] [data-pj-saved-empty],
.pj-saved-shell.is-empty [data-pj-saved-actions],
.pj-saved-shell.is-empty [data-pj-saved-plan],
.pj-saved-shell.is-empty [data-pj-saved-helper],
.pj-saved-shell.is-empty [data-pj-saved-clear],
.pj-saved-shell.is-empty [data-pj-saved-filters],
.pj-saved-shell.is-empty [data-pj-saved-list],
.pj-saved-actions[hidden],
.pj-saved-plan[hidden],
.pj-saved-helper[hidden],
.pj-saved-clear-link[hidden],
.pj-saved-filters[hidden],
.pj-saved-list[hidden],
.pj-saved-empty[hidden],
.pj-calendar-panel[hidden] {
    display: none !important;
}
.pj-saved-shell.is-filled [data-pj-saved-empty] {
    display: none !important;
}
.pj-services-page {
    background: linear-gradient(180deg, #fff5ea 0, #fffaf3 280px, #fffdf8 100%);
}
.pj-services-hero .pj-services-search {
    margin-top: 18px;
    margin-bottom: 12px;
    background: transparent;
    border: 0;
    box-shadow: none;
    padding: 0;
}
.pj-services-hero .pj-services-search label,
.pj-services-hero .pj-services-search p {
    display: none;
}
.pj-services-hero .pj-services-search div {
    max-width: 620px;
    margin: 0 auto;
    background: #fffaf3;
    border: 1px solid rgba(157, 93, 48, .20);
    border-radius: 999px;
    padding: 6px;
    box-shadow: 0 16px 34px rgba(105, 61, 31, .09);
}
.pj-services-hero .pj-services-search input {
    border: 0;
    background: transparent;
    padding-left: 16px;
}
.pj-service-category-card {
    position: relative;
    display: block;
    background: #fffaf3;
    border: 1px solid rgba(135, 82, 47, .16);
    border-radius: 24px;
    box-shadow: 0 12px 28px rgba(92, 54, 31, .07);
    transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.pj-service-category-card:hover {
    transform: translateY(-2px);
    border-color: rgba(185, 91, 52, .32);
    box-shadow: 0 18px 36px rgba(92, 54, 31, .11);
}
.pj-service-line-icon {
    display: inline-flex;
    width: 42px;
    height: 42px;
    align-items: center;
    justify-content: center;
    border-radius: 14px;
    background: #fff0e2;
    color: #b94726;
    border: 1px solid rgba(185, 71, 38, .18);
    margin-bottom: 14px;
}
.pj-service-line-icon svg {
    width: 24px;
    height: 24px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.9;
    stroke-linecap: round;
    stroke-linejoin: round;
}
.pj-service-category-examples {
    color: #7a6150;
    font-weight: 750;
    line-height: 1.35;
}
.ps-date-chip-row {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: 8px;
    padding-bottom: 2px;
    scrollbar-width: none;
}
.ps-date-chip-row::-webkit-scrollbar { display: none; }
.ps-date-chip-row .ps-date-chip {
    flex: 0 0 auto;
}
.ps-events-utility-row {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    justify-content: center;
    flex-wrap: nowrap;
    margin-top: 10px;
}
.ps-more-filters,
.ps-date-form {
    flex: 0 1 auto;
}
.ps-more-filters > summary,
.ps-utility-button--date {
    min-height: 42px;
}
.ps-more-filters-panel .ps-filter-drawer-actions,
.pj-calendar-actions {
    display: flex;
    gap: 10px;
    justify-content: flex-end;
}
@media (max-width: 640px) {
    .pj-services-hero .pj-services-search div {
        border-radius: 22px;
        flex-direction: column;
    }
    .pj-services-hero .pj-services-search input,
    .pj-services-hero .pj-services-search button {
        width: 100%;
    }
    .ps-events-utility-row {
        justify-content: flex-start;
        padding-inline: 2px;
    }
}

/* More Filters overlay layering fix v1.5.303 */
.pj-archive-theme-scope,
.pj-filter-stack,
.pj-filter-stack--events,
.pj-filter-stack--events .ps-events-utility-row,
.pj-filter-stack--events .ps-more-filters {
    overflow: visible !important;
}
.pj-filter-stack--events {
    position: relative !important;
    z-index: 2147481000 !important;
}
.pj-filter-stack--events .ps-events-utility-row {
    position: relative !important;
    z-index: 2147481200 !important;
}
.pj-filter-stack--events .ps-more-filters {
    position: relative !important;
    z-index: 2147481300 !important;
}
.pj-filter-stack--events .ps-more-filters[open] {
    z-index: 2147482200 !important;
}
.pj-filter-stack--events .ps-more-filters-panel {
    z-index: 2147482400 !important;
    max-height: min(62vh, 520px);
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
}
@media (max-width: 640px) {
    .pj-filter-stack--events .ps-more-filters-panel {
        position: absolute !important;
        left: 0 !important;
        right: auto !important;
        width: min(calc(100vw - 28px), 390px) !important;
        max-height: calc(100vh - 235px);
    }
}

/* More Filters in-flow drawer fix v1.5.304
   Do not overlay the category panel above event cards. When opened, it becomes
   part of the page flow and pushes cards down, so it cannot be hidden behind
   card stacking contexts or clipped by parent overflow. */
.pj-filter-stack--events,
.pj-filter-stack--events .ps-events-utility-row,
.pj-filter-stack--events .ps-more-filters {
    overflow: visible !important;
}
.pj-filter-stack--events .ps-events-utility-row {
    align-items: flex-start !important;
    flex-wrap: wrap !important;
    position: relative !important;
    z-index: 40 !important;
}
.pj-filter-stack--events .ps-more-filters {
    position: static !important;
    flex: 1 1 calc(100% - 116px) !important;
    min-width: 0 !important;
}
.pj-filter-stack--events .ps-date-form {
    flex: 0 0 auto !important;
}
.pj-filter-stack--events .ps-more-filters-panel {
    position: static !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    width: 100% !important;
    max-width: none !important;
    max-height: none !important;
    overflow: visible !important;
    margin-top: 10px !important;
    z-index: auto !important;
    box-sizing: border-box !important;
}
.pj-filter-stack--events .ps-more-filters:not([open]) .ps-more-filters-panel {
    display: none !important;
}
.pj-filter-stack--events .ps-more-filters[open] {
    flex-basis: 100% !important;
    order: 2 !important;
}
.pj-filter-stack--events .ps-more-filters[open] + .ps-date-form {
    order: 1 !important;
}
.pj-filter-stack--events .ps-more-filters[open] > summary {
    width: fit-content !important;
}
@media (max-width: 640px) {
    .pj-filter-stack--events .ps-events-utility-row {
        justify-content: flex-start !important;
    }
    .pj-filter-stack--events .ps-more-filters:not([open]) {
        flex: 0 0 auto !important;
    }
    .pj-filter-stack--events .ps-more-filters[open] {
        flex: 0 0 100% !important;
    }
    .pj-filter-stack--events .ps-more-filters-panel {
        border-radius: 20px !important;
        padding: 14px !important;
    }
}

/* Events Filter panel polish — approved inline card redesign */
.pj-filter-stack--events .ps-events-utility-row {
  align-items: flex-start;
  overflow: visible !important;
}

.pj-filter-stack--events .ps-more-filters {
  position: static !important;
  flex: 0 1 auto;
  overflow: visible !important;
}

.pj-filter-stack--events .ps-more-filters > summary {
  cursor: pointer;
  user-select: none;
  gap: 7px;
}

.pj-filter-stack--events .ps-more-filters > summary::before {
  content: "";
  width: 15px;
  height: 15px;
  display: inline-block;
  flex: 0 0 auto;
  background: currentColor;
  opacity: .82;
  -webkit-mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M3 5.25h8.1a2.25 2.25 0 0 0 4.3 0H17a.75.75 0 0 0 0-1.5h-1.6a2.25 2.25 0 0 0-4.3 0H3a.75.75 0 0 0 0 1.5Zm0 5.5h1.6a2.25 2.25 0 0 0 4.3 0H17a.75.75 0 0 0 0-1.5H8.9a2.25 2.25 0 0 0-4.3 0H3a.75.75 0 0 0 0 1.5Zm0 5.5h8.1a2.25 2.25 0 0 0 4.3 0H17a.75.75 0 0 0 0-1.5h-1.6a2.25 2.25 0 0 0-4.3 0H3a.75.75 0 0 0 0 1.5Z'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M3 5.25h8.1a2.25 2.25 0 0 0 4.3 0H17a.75.75 0 0 0 0-1.5h-1.6a2.25 2.25 0 0 0-4.3 0H3a.75.75 0 0 0 0 1.5Zm0 5.5h1.6a2.25 2.25 0 0 0 4.3 0H17a.75.75 0 0 0 0-1.5H8.9a2.25 2.25 0 0 0-4.3 0H3a.75.75 0 0 0 0 1.5Zm0 5.5h8.1a2.25 2.25 0 0 0 4.3 0H17a.75.75 0 0 0 0-1.5h-1.6a2.25 2.25 0 0 0-4.3 0H3a.75.75 0 0 0 0 1.5Z'/%3E%3C/svg%3E") center / contain no-repeat;
}

.pj-filter-stack--events .ps-more-filters.has-active-filters > summary {
  background: #b24a2b !important;
  border-color: #b24a2b !important;
  color: #fffaf3 !important;
  box-shadow: 0 8px 18px rgba(178, 74, 43, .18);
}

.pj-filter-stack--events .ps-more-filters-panel {
  position: static !important;
  inset: auto !important;
  width: min(100%, 640px) !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin-top: 12px !important;
  padding: 16px !important;
  background: #fffaf3 !important;
  border: 1px solid rgba(122, 66, 43, .16) !important;
  border-radius: 22px !important;
  box-shadow: 0 18px 42px rgba(55, 36, 26, .13) !important;
  overflow: hidden !important;
  z-index: auto !important;
}

.pj-filter-stack--events .ps-filter-panel-head {
  margin: 0 0 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(122, 66, 43, .10);
}

.pj-filter-stack--events .ps-filter-panel-title {
  margin: 0;
  color: #2f241d;
  font-family: "Playfair Display", Georgia, serif;
  font-size: 22px;
  line-height: 1.1;
  font-weight: 700;
}

.pj-filter-stack--events .ps-filter-panel-help {
  margin: 5px 0 0;
  color: #715f52;
  font-size: 13.5px;
  line-height: 1.4;
}

.pj-filter-stack--events .ps-event-filter-form {
  display: grid;
  gap: 14px;
}

.pj-filter-stack--events .ps-filter-section {
  display: grid;
  gap: 8px;
}

.pj-filter-stack--events .ps-filter-section-title {
  color: #6d4a38;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.pj-filter-stack--events .ps-filter-choice-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px !important;
}

.pj-filter-stack--events .ps-filter-choice-grid--cost {
  grid-template-columns: minmax(0, 1fr);
  max-width: 220px;
}

.pj-filter-stack--events .ps-filter-choice {
  display: inline-flex !important;
  align-items: center;
  justify-content: flex-start;
  min-height: 42px;
  width: 100%;
  gap: 7px;
  padding: 10px 12px !important;
  border-radius: 14px !important;
  border: 1px solid rgba(122, 66, 43, .18) !important;
  background: rgba(255, 255, 255, .72) !important;
  color: #33261f !important;
  box-shadow: 0 1px 0 rgba(255,255,255,.7) inset;
  font-size: 13.5px;
  font-weight: 750;
  line-height: 1.12;
  white-space: nowrap;
  cursor: pointer;
}

.pj-filter-stack--events .ps-filter-choice input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.pj-filter-stack--events .ps-filter-check {
  display: inline-grid;
  place-items: center;
  width: 17px;
  height: 17px;
  flex: 0 0 17px;
  border-radius: 999px;
  background: rgba(122, 66, 43, .10);
  color: transparent;
  font-size: 12px;
  font-weight: 900;
}

.pj-filter-stack--events .ps-filter-choice.active,
.pj-filter-stack--events .ps-filter-choice:has(input:checked) {
  background: #b24a2b !important;
  border-color: #b24a2b !important;
  color: #fffaf3 !important;
  box-shadow: 0 10px 20px rgba(178, 74, 43, .16);
}

.pj-filter-stack--events .ps-filter-choice.active .ps-filter-check,
.pj-filter-stack--events .ps-filter-choice:has(input:checked) .ps-filter-check {
  background: rgba(255, 250, 243, .22);
  color: #fffaf3;
}

.pj-filter-stack--events .ps-filter-drawer-actions {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center;
  gap: 12px;
  margin-top: 2px;
  padding-top: 12px;
  border-top: 1px solid rgba(122, 66, 43, .10);
}

.pj-filter-stack--events .ps-filter-clear {
  color: #76543f !important;
  font-weight: 800;
  text-decoration: none;
  padding: 10px 6px;
}

.pj-filter-stack--events .ps-filter-apply {
  min-height: 42px;
  padding: 10px 18px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: #b24a2b !important;
  color: #fffaf3 !important;
  font-weight: 850;
  box-shadow: 0 10px 20px rgba(178, 74, 43, .18);
}

@media (max-width: 430px) {
  .pj-filter-stack--events .ps-more-filters-panel {
    padding: 14px !important;
    border-radius: 20px !important;
  }
  .pj-filter-stack--events .ps-filter-choice {
    min-height: 40px;
    padding: 9px 9px !important;
    gap: 5px;
    font-size: 12.5px;
  }
  .pj-filter-stack--events .ps-filter-check {
    width: 15px;
    height: 15px;
    flex-basis: 15px;
    font-size: 11px;
  }
}

/* Events Filter spacing fix — keep controls out of the card and tighten open state */
.pj-filter-stack--events {
  padding-top: 0 !important;
}

.pj-filter-stack--events .ps-date-chip-row {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

.pj-filter-stack--events .ps-events-utility-row {
  margin-top: 7px !important;
  row-gap: 8px !important;
  column-gap: 10px !important;
}

/* When Filter is open, use a real two-row grid:
   row 1 = Filter + Date controls, row 2 = filter card. */
.pj-filter-stack--events .ps-events-utility-row:has(.ps-more-filters[open]) {
  display: grid !important;
  grid-template-columns: max-content max-content;
  align-items: start !important;
  justify-content: start !important;
  gap: 8px 10px !important;
}

.pj-filter-stack--events .ps-events-utility-row:has(.ps-more-filters[open]) .ps-more-filters[open] {
  display: contents !important;
  position: static !important;
  flex: none !important;
  order: 0 !important;
  min-width: 0 !important;
}

.pj-filter-stack--events .ps-events-utility-row:has(.ps-more-filters[open]) .ps-more-filters[open] > summary {
  grid-column: 1 !important;
  grid-row: 1 !important;
  width: auto !important;
  margin: 0 !important;
}

.pj-filter-stack--events .ps-events-utility-row:has(.ps-more-filters[open]) .ps-date-form {
  grid-column: 2 !important;
  grid-row: 1 !important;
  order: 0 !important;
  margin: 0 !important;
}

.pj-filter-stack--events .ps-events-utility-row:has(.ps-more-filters[open]) .ps-more-filters-panel {
  grid-column: 1 / -1 !important;
  grid-row: 2 !important;
  width: min(calc(100vw - 28px), 640px) !important;
  margin-top: 0 !important;
  clear: both !important;
}

@media (max-width: 430px) {
  .pj-filter-stack--events .ps-more-filters-panel {
    padding: 13px !important;
  }
  .pj-filter-stack--events .ps-filter-panel-head {
    margin-bottom: 11px !important;
    padding-bottom: 10px !important;
  }
}

/* Events applied-filter overlap fix — mobile filters must not cover event cards */
@media (max-width: 700px) {
  .pj-filter-stack--events {
    position: relative !important;
    top: auto !important;
    z-index: 1 !important;
    margin-bottom: 14px !important;
    box-shadow: 0 1px 0 rgba(122, 66, 43, .08) !important;
  }

  .pj-filter-stack--events .ps-events-utility-row {
    position: relative !important;
    z-index: 1 !important;
    margin-bottom: 0 !important;
  }

  .pj-filter-stack--events .ps-more-filters,
  .pj-filter-stack--events .ps-date-form,
  .pj-filter-stack--events .ps-more-filters-panel {
    z-index: auto !important;
  }

  .pj-archive-theme-scope .pj-filter-stack--events + .pj-section-label,
  .pj-archive-theme-scope .pj-filter-stack--events + .pj-explore-curation-head,
  .pj-archive-theme-scope .pj-filter-stack--events + .pj-card-grid,
  .pj-archive-theme-scope .pj-filter-stack--events + .pj-event-card,
  .pj-archive-theme-scope .pj-filter-stack--events + h2 {
    margin-top: 14px !important;
  }
}

/* Events mobile Filter/Date row fit fix — closed state must not stretch */
@media (max-width: 700px) {
  html,
  body {
    overflow-x: hidden !important;
    max-width: 100% !important;
  }

  .pj-archive-theme-scope,
  .pj-filter-stack--events {
    max-width: 100vw !important;
  }

  .pj-filter-stack--events .ps-events-utility-row {
    display: flex !important;
    width: auto !important;
    max-width: calc(100vw - 28px) !important;
    margin-left: 14px !important;
    margin-right: 14px !important;
    padding-inline: 0 !important;
    justify-content: flex-start !important;
    align-items: flex-start !important;
    flex-wrap: wrap !important;
    gap: 8px 10px !important;
  }

  .pj-filter-stack--events .ps-more-filters:not([open]),
  .pj-filter-stack--events .ps-date-form {
    flex: 0 0 auto !important;
    width: auto !important;
    max-width: max-content !important;
    min-width: 0 !important;
  }

  .pj-filter-stack--events .ps-more-filters:not([open]) > summary,
  .pj-filter-stack--events .ps-utility-button--date {
    width: auto !important;
    max-width: max-content !important;
    margin: 0 !important;
  }

  /* Re-apply the two-row layout only while the Filter drawer is open. */
  .pj-filter-stack--events .ps-events-utility-row:has(.ps-more-filters[open]) {
    display: grid !important;
    grid-template-columns: max-content max-content !important;
    width: auto !important;
    max-width: calc(100vw - 28px) !important;
    justify-content: start !important;
    align-items: start !important;
    gap: 8px 10px !important;
  }

  .pj-filter-stack--events .ps-events-utility-row:has(.ps-more-filters[open]) .ps-more-filters[open] {
    display: contents !important;
    flex: none !important;
    width: auto !important;
    max-width: none !important;
  }

  .pj-filter-stack--events .ps-events-utility-row:has(.ps-more-filters[open]) .ps-more-filters[open] > summary {
    grid-column: 1 !important;
    grid-row: 1 !important;
  }

  .pj-filter-stack--events .ps-events-utility-row:has(.ps-more-filters[open]) .ps-date-form {
    grid-column: 2 !important;
    grid-row: 1 !important;
  }

  .pj-filter-stack--events .ps-events-utility-row:has(.ps-more-filters[open]) .ps-more-filters-panel {
    grid-column: 1 / -1 !important;
    grid-row: 2 !important;
    width: min(calc(100vw - 28px), 640px) !important;
    max-width: calc(100vw - 28px) !important;
  }
}

/* Events Filter icon chips — line icons instead of checkmark clutter */
.pj-filter-stack--events .ps-filter-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 17px;
  height: 17px;
  flex: 0 0 17px;
  color: currentColor;
  opacity: .92;
}

.pj-filter-stack--events .ps-filter-icon svg {
  width: 17px;
  height: 17px;
  display: block;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.85;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.pj-filter-stack--events .ps-filter-label {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Hide old checkmark treatment if stale markup ever appears; active color is the selected state. */
.pj-filter-stack--events .ps-filter-check {
  display: none !important;
}

.pj-filter-stack--events .ps-filter-choice {
  gap: 7px !important;
}

.pj-filter-stack--events .ps-filter-choice.active .ps-filter-icon,
.pj-filter-stack--events .ps-filter-choice:has(input:checked) .ps-filter-icon {
  color: #fffaf3;
  opacity: 1;
}

@media (max-width: 430px) {
  .pj-filter-stack--events .ps-filter-icon {
    width: 16px;
    height: 16px;
    flex-basis: 16px;
  }
  .pj-filter-stack--events .ps-filter-icon svg {
    width: 16px;
    height: 16px;
    stroke-width: 1.8;
  }
  .pj-filter-stack--events .ps-filter-choice {
    gap: 6px !important;
  }
}

/* Events Filter icons overflow guard */
@media (max-width: 700px) {
  .pj-filter-stack--events .ps-events-utility-row,
  .pj-filter-stack--events .ps-events-utility-row:has(.ps-more-filters[open]) {
    max-width: calc(100vw - 28px) !important;
    overflow: visible !important;
  }

  .pj-filter-stack--events .ps-more-filters-panel,
  .pj-filter-stack--events .ps-events-utility-row:has(.ps-more-filters[open]) .ps-more-filters-panel {
    width: calc(100vw - 28px) !important;
    max-width: calc(100vw - 28px) !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  .pj-filter-stack--events .ps-filter-choice-grid {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }
}

/* Events Filter icon panel final width clamp — fit parent row, not viewport math */
@media (max-width: 700px) {
  .pj-filter-stack--events .ps-more-filters-panel,
  .pj-filter-stack--events .ps-events-utility-row:has(.ps-more-filters[open]) .ps-more-filters-panel {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    justify-self: stretch !important;
  }

  .pj-filter-stack--events .ps-events-utility-row:has(.ps-more-filters[open]) {
    grid-template-columns: max-content max-content !important;
    width: calc(100vw - 28px) !important;
    max-width: calc(100vw - 28px) !important;
    box-sizing: border-box !important;
  }

  .pj-filter-stack--events .ps-filter-choice {
    min-width: 0 !important;
  }
}

/* Events Filter icon panel width final: use parent width, not viewport width */
@media (max-width: 700px) {
  .pj-filter-stack--events .ps-events-utility-row:has(.ps-more-filters[open]) {
    display: grid !important;
    grid-template-columns: max-content max-content minmax(0, 1fr) !important;
    width: calc(100% - 28px) !important;
    max-width: calc(100% - 28px) !important;
    margin-left: 14px !important;
    margin-right: 14px !important;
    box-sizing: border-box !important;
  }

  .pj-filter-stack--events .ps-events-utility-row:has(.ps-more-filters[open]) .ps-more-filters-panel {
    grid-column: 1 / -1 !important;
    width: 100% !important;
    max-width: 100% !important;
    justify-self: stretch !important;
  }
}

/* Events Filter icons stable open layout — full-width card, no narrow grid artifacts */
@media (max-width: 700px) {
  .pj-filter-stack--events .ps-events-utility-row:has(.ps-more-filters[open]) {
    display: flex !important;
    flex-wrap: wrap !important;
    width: auto !important;
    max-width: calc(100vw - 28px) !important;
    margin-left: 14px !important;
    margin-right: 14px !important;
    align-items: flex-start !important;
    justify-content: flex-start !important;
    gap: 8px 10px !important;
  }

  .pj-filter-stack--events .ps-events-utility-row:has(.ps-more-filters[open]) .ps-more-filters[open] {
    display: block !important;
    flex: 0 0 100% !important;
    width: 100% !important;
    max-width: 100% !important;
    order: 2 !important;
  }

  .pj-filter-stack--events .ps-events-utility-row:has(.ps-more-filters[open]) .ps-date-form {
    flex: 0 0 auto !important;
    order: 1 !important;
  }

  .pj-filter-stack--events .ps-events-utility-row:has(.ps-more-filters[open]) .ps-more-filters[open] > summary {
    width: max-content !important;
    max-width: 100% !important;
    margin: 0 !important;
  }

  .pj-filter-stack--events .ps-events-utility-row:has(.ps-more-filters[open]) .ps-more-filters-panel {
    display: block !important;
    position: static !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin-top: 8px !important;
    box-sizing: border-box !important;
  }
}

/* Events Filter compact 3-column chip grid — reduce scrolling to Apply */
@media (max-width: 700px) {
  .pj-filter-stack--events .ps-filter-choice-grid:not(.ps-filter-choice-grid--cost) {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 7px !important;
  }

  .pj-filter-stack--events .ps-filter-choice-grid--cost {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    max-width: 100% !important;
  }

  .pj-filter-stack--events .ps-filter-choice {
    min-height: 36px !important;
    padding: 8px 7px !important;
    border-radius: 12px !important;
    gap: 5px !important;
    font-size: 11.5px !important;
    line-height: 1.05 !important;
    font-weight: 800 !important;
    letter-spacing: -0.01em;
  }

  .pj-filter-stack--events .ps-filter-icon {
    width: 14px !important;
    height: 14px !important;
    flex-basis: 14px !important;
  }

  .pj-filter-stack--events .ps-filter-icon svg {
    width: 14px !important;
    height: 14px !important;
    stroke-width: 1.8;
  }

  .pj-filter-stack--events .ps-filter-label {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .pj-filter-stack--events .ps-event-filter-form {
    gap: 11px !important;
  }

  .pj-filter-stack--events .ps-filter-section {
    gap: 7px !important;
  }

  .pj-filter-stack--events .ps-filter-panel-head {
    margin-bottom: 10px !important;
    padding-bottom: 9px !important;
  }

  .pj-filter-stack--events .ps-filter-drawer-actions {
    padding-top: 10px !important;
  }
}

/* Events Filter 3-column readability pass — prevent label truncation */
@media (max-width: 700px) {
  .pj-filter-stack--events .ps-filter-choice {
    min-height: 34px !important;
    padding: 7px 5px !important;
    gap: 4px !important;
    font-size: 10.5px !important;
    line-height: 1 !important;
    letter-spacing: -0.025em !important;
  }

  .pj-filter-stack--events .ps-filter-icon {
    width: 13px !important;
    height: 13px !important;
    flex-basis: 13px !important;
  }

  .pj-filter-stack--events .ps-filter-icon svg {
    width: 13px !important;
    height: 13px !important;
    stroke-width: 1.75 !important;
  }
}

/* Explore Browse panel redesign — guided discovery */
.pj-filter-stack--explore .pj-primary-filter-bar--explore {
  gap: 7px;
}

.pj-filter-stack--explore .pj-explore-browse-actions {
  align-items: flex-start;
  justify-content: center;
  gap: 10px;
  overflow: visible !important;
}

.pj-filter-stack--explore .pj-explore-more-filter-form,
.pj-filter-stack--explore .pj-explore-sort-toggle {
  flex: 0 0 auto;
}

.pj-filter-stack--explore .pj-explore-browse {
  position: static !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  text-align: left !important;
  overflow: visible !important;
}

.pj-filter-stack--explore .pj-explore-browse > summary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(122, 66, 43, .18);
  background: #fffaf3;
  color: #33261f;
  font-size: 13px;
  font-weight: 850;
  line-height: 1;
  cursor: pointer;
  list-style: none;
  box-shadow: 0 1px 0 rgba(255,255,255,.8) inset;
  transform: none !important;
}

.pj-filter-stack--explore .pj-explore-browse > summary::-webkit-details-marker {
  display: none;
}

.pj-filter-stack--explore .pj-explore-browse > summary::after {
  content: '▾';
  margin-left: 7px;
  font-size: 10px;
}

.pj-filter-stack--explore .pj-explore-browse[open] > summary::after {
  content: '▴';
}

.pj-filter-stack--explore .pj-explore-browse.has-active-filters > summary {
  background: #b24a2b;
  border-color: #b24a2b;
  color: #fffaf3;
  box-shadow: 0 8px 18px rgba(178, 74, 43, .18);
}

.pj-filter-stack--explore .pj-explore-browse-panel {
  position: static !important;
  width: min(100%, 640px) !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin-top: 10px !important;
  padding: 16px !important;
  background: #fffaf3 !important;
  border: 1px solid rgba(122, 66, 43, .16) !important;
  border-radius: 22px !important;
  box-shadow: 0 18px 42px rgba(55, 36, 26, .13) !important;
  display: grid !important;
  gap: 14px !important;
  overflow: hidden !important;
}

.pj-filter-stack--explore .pj-explore-browse:not([open]) .pj-explore-browse-panel {
  display: none !important;
}

.pj-filter-stack--explore .pj-explore-browse-head {
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(122, 66, 43, .10);
}

.pj-filter-stack--explore .pj-explore-browse-title {
  margin: 0;
  color: #2f241d;
  font-family: "Playfair Display", Georgia, serif;
  font-size: 23px;
  line-height: 1.08;
  font-weight: 700;
  letter-spacing: -.01em;
}

.pj-filter-stack--explore .pj-explore-browse-help {
  margin: 5px 0 0;
  color: #715f52;
  font-size: 13.5px;
  line-height: 1.4;
  font-weight: 600;
}

.pj-filter-stack--explore .pj-explore-browse-section {
  display: grid;
  gap: 8px;
}

.pj-filter-stack--explore .pj-explore-browse-section-title {
  color: #6d4a38;
  font-size: 12px;
  font-weight: 850;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.pj-filter-stack--explore .pj-explore-browse-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.pj-filter-stack--explore .pj-explore-choice {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  min-height: 40px;
  width: 100%;
  min-width: 0;
  gap: 7px;
  padding: 9px 10px;
  border-radius: 14px;
  border: 1px solid rgba(122, 66, 43, .18);
  background: rgba(255,255,255,.72);
  color: #33261f;
  box-shadow: 0 1px 0 rgba(255,255,255,.7) inset;
  font-size: 13px;
  font-weight: 800;
  line-height: 1.08;
  cursor: pointer;
}

.pj-filter-stack--explore .pj-explore-choice input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.pj-filter-stack--explore .pj-explore-choice-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  flex: 0 0 16px;
  color: currentColor;
  opacity: .92;
}

.pj-filter-stack--explore .pj-explore-choice-icon svg {
  width: 16px;
  height: 16px;
  display: block;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.85;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.pj-filter-stack--explore .pj-explore-choice-label {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.pj-filter-stack--explore .pj-explore-choice.active,
.pj-filter-stack--explore .pj-explore-choice:has(input:checked) {
  background: #b24a2b;
  border-color: #b24a2b;
  color: #fffaf3;
  box-shadow: 0 10px 20px rgba(178, 74, 43, .16);
}

.pj-filter-stack--explore .pj-explore-browse-actions-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(122, 66, 43, .10);
}

.pj-filter-stack--explore .pj-explore-browse-clear {
  color: #76543f;
  font-weight: 850;
  text-decoration: none;
  padding: 10px 6px;
}

.pj-filter-stack--explore .pj-explore-browse-apply {
  min-height: 42px;
  padding: 10px 18px;
  border: 0;
  border-radius: 999px;
  background: #b24a2b;
  color: #fffaf3;
  font-weight: 850;
  box-shadow: 0 10px 20px rgba(178, 74, 43, .18);
}

@media (max-width: 700px) {
  .pj-filter-stack--explore {
    overflow: visible !important;
  }
  .pj-filter-stack--explore .pj-primary-filter-bar--explore {
    padding-top: 8px !important;
    padding-bottom: 5px !important;
  }
  .pj-filter-stack--explore .pj-explore-browse-actions {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: flex-start !important;
    align-items: flex-start !important;
    width: auto !important;
    max-width: calc(100vw - 28px) !important;
    margin-left: 14px !important;
    margin-right: 14px !important;
    padding: 0 0 8px !important;
    background: transparent !important;
  }
  .pj-filter-stack--explore .pj-explore-browse-actions:has(.pj-explore-browse[open]) .pj-explore-more-filter-form {
    flex: 0 0 100% !important;
    width: 100% !important;
    order: 2 !important;
  }
  .pj-filter-stack--explore .pj-explore-browse-actions:has(.pj-explore-browse[open]) .pj-explore-sort-toggle {
    order: 1 !important;
  }
  .pj-filter-stack--explore .pj-explore-browse-actions:has(.pj-explore-browse[open]) .pj-explore-browse > summary {
    width: max-content !important;
    max-width: 100% !important;
  }
  .pj-filter-stack--explore .pj-explore-browse-panel {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    margin-top: 8px !important;
    padding: 14px !important;
    border-radius: 20px !important;
  }
  .pj-filter-stack--explore .pj-explore-browse-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 7px;
  }
  .pj-filter-stack--explore .pj-explore-choice {
    min-height: 38px;
    padding: 8px 8px;
    gap: 6px;
    font-size: 12px;
    border-radius: 13px;
  }
  .pj-filter-stack--explore .pj-explore-choice-icon {
    width: 15px;
    height: 15px;
    flex-basis: 15px;
  }
  .pj-filter-stack--explore .pj-explore-choice-icon svg {
    width: 15px;
    height: 15px;
  }
}

/* Explore Browse panel layout fix — stack sections vertically */
.pj-filter-stack--explore .pj-explore-browse-panel {
  grid-template-columns: 1fr !important;
  align-items: stretch !important;
}

.pj-filter-stack--explore .pj-explore-browse-section,
.pj-filter-stack--explore .pj-explore-browse-head,
.pj-filter-stack--explore .pj-explore-browse-actions-row {
  grid-column: 1 / -1 !important;
  width: 100% !important;
  min-width: 0 !important;
}

.pj-filter-stack--explore .pj-explore-browse-grid {
  width: 100% !important;
  min-width: 0 !important;
}

/* Explore Browse in-flow overlap fix — keep panel above cards by pushing content */
@media (max-width: 700px) {
  .pj-filter-stack--explore:has(.pj-explore-browse[open]) {
    position: relative !important;
    top: auto !important;
    z-index: 1 !important;
    overflow: visible !important;
    margin-bottom: 18px !important;
    box-shadow: 0 1px 0 rgba(122, 66, 43, .08) !important;
  }

  .pj-filter-stack--explore:has(.pj-explore-browse[open]) .pj-explore-browse-actions,
  .pj-filter-stack--explore:has(.pj-explore-browse[open]) .pj-explore-more-filter-form,
  .pj-filter-stack--explore:has(.pj-explore-browse[open]) .pj-explore-browse,
  .pj-filter-stack--explore:has(.pj-explore-browse[open]) .pj-explore-browse-panel {
    position: static !important;
    z-index: auto !important;
    overflow: visible !important;
  }

  .pj-filter-stack--explore:has(.pj-explore-browse[open]) + .pj-explore-curation-head,
  .pj-filter-stack--explore:has(.pj-explore-browse[open]) + .pj-section-label,
  .pj-filter-stack--explore:has(.pj-explore-browse[open]) + .pj-card-grid,
  .pj-filter-stack--explore:has(.pj-explore-browse[open]) + .pj-event-card {
    margin-top: 18px !important;
  }
}
/* Explore Browse compact 3-column chips — reduce scroll and keep panel in flow */
@media (max-width: 700px) {
  .pj-filter-stack--explore .pj-explore-browse-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 6px !important;
  }

  .pj-filter-stack--explore .pj-explore-choice {
    min-height: 34px !important;
    padding: 7px 5px !important;
    gap: 4px !important;
    border-radius: 12px !important;
    font-size: 10.5px !important;
    line-height: 1 !important;
    letter-spacing: -0.025em !important;
    font-weight: 820 !important;
  }

  .pj-filter-stack--explore .pj-explore-choice-icon {
    width: 13px !important;
    height: 13px !important;
    flex-basis: 13px !important;
  }

  .pj-filter-stack--explore .pj-explore-choice-icon svg {
    width: 13px !important;
    height: 13px !important;
    stroke-width: 1.75 !important;
  }

  .pj-filter-stack--explore .pj-explore-choice-label {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  .pj-filter-stack--explore .pj-explore-browse-panel {
    gap: 11px !important;
    padding: 13px !important;
    overflow: visible !important;
  }

  .pj-filter-stack--explore .pj-explore-browse-head {
    padding-bottom: 10px !important;
  }

  .pj-filter-stack--explore .pj-explore-browse-section {
    gap: 6px !important;
  }

  .pj-filter-stack--explore .pj-explore-browse-actions-row {
    padding-top: 9px !important;
  }

  .pj-filter-stack--explore:has(.pj-explore-browse[open]) {
    position: relative !important;
    margin-bottom: 20px !important;
    overflow: visible !important;
  }

  .pj-filter-stack--explore:has(.pj-explore-browse[open]) + .pj-explore-curation-head,
  .pj-filter-stack--explore:has(.pj-explore-browse[open]) + .pj-section-label,
  .pj-filter-stack--explore:has(.pj-explore-browse[open]) + .pj-card-grid,
  .pj-filter-stack--explore:has(.pj-explore-browse[open]) + .pj-event-card {
    margin-top: 20px !important;
  }
}
/* Explore Browse action overlap fix — panel height must include Show Picks row */
@media (max-width: 700px) {
  .pj-filter-stack--explore .pj-explore-browse[open] {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    overflow: visible !important;
  }

  .pj-filter-stack--explore .pj-explore-browse[open] .pj-explore-browse-panel,
  .pj-filter-stack--explore .pj-explore-browse[open] .pj-more-filters-panel {
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    max-width: 100% !important;
    max-height: none !important;
    height: auto !important;
    overflow: visible !important;
    box-sizing: border-box !important;
    padding-bottom: 14px !important;
  }

  .pj-filter-stack--explore .pj-explore-browse-actions-row {
    position: static !important;
    flex: 0 0 auto !important;
    width: 100% !important;
    box-sizing: border-box !important;
    margin: 2px 0 0 !important;
    padding-top: 10px !important;
    padding-bottom: 0 !important;
    background: #fffaf3 !important;
  }

  .pj-filter-stack--explore:has(.pj-explore-browse[open]) {
    margin-bottom: 26px !important;
    padding-bottom: 0 !important;
  }

  .pj-filter-stack--explore:has(.pj-explore-browse[open]) + .pj-explore-curation-head,
  .pj-filter-stack--explore:has(.pj-explore-browse[open]) + .pj-section-label,
  .pj-filter-stack--explore:has(.pj-explore-browse[open]) + .pj-card-grid,
  .pj-filter-stack--explore:has(.pj-explore-browse[open]) + .pj-event-card {
    margin-top: 26px !important;
  }
}
/* Bottom nav lower fit — reduce internal lift so tab bar hugs the screen bottom */
@media (max-width: 700px) {
  .pj-bottom-nav,
  .pj-bottom-nav-is-dropped .pj-bottom-nav {
    bottom: 0 !important;
    top: auto !important;
    padding-top: 6px !important;
    padding-bottom: calc(7px + env(safe-area-inset-bottom, 0px)) !important;
    min-height: calc(64px + env(safe-area-inset-bottom, 0px)) !important;
    align-items: center !important;
  }

  .pj-bottom-nav a {
    min-height: 47px !important;
    padding-top: 4px !important;
    padding-bottom: 3px !important;
  }
}
/* Saved page state gate — zero saved items must never show active planning controls */
.pj-saved-shell[data-saved-state="loading"] [data-pj-saved-actions],
.pj-saved-shell[data-saved-state="loading"] [data-pj-saved-plan],
.pj-saved-shell[data-saved-state="loading"] [data-pj-saved-helper],
.pj-saved-shell[data-saved-state="loading"] [data-pj-saved-clear],
.pj-saved-shell[data-saved-state="loading"] [data-pj-saved-filters],
.pj-saved-shell[data-saved-state="loading"] [data-pj-saved-filter-empty],
.pj-saved-shell[data-saved-state="loading"] [data-pj-saved-list],
.pj-saved-shell[data-saved-state="loading"] [data-pj-saved-empty] {
  display: none !important;
}

.pj-saved-shell[data-saved-state="loaded"][data-saved-count="0"] [data-pj-saved-actions],
.pj-saved-shell[data-saved-state="loaded"][data-saved-count="0"] [data-pj-saved-plan],
.pj-saved-shell[data-saved-state="loaded"][data-saved-count="0"] [data-pj-saved-helper],
.pj-saved-shell[data-saved-state="loaded"][data-saved-count="0"] [data-pj-saved-clear],
.pj-saved-shell[data-saved-state="loaded"][data-saved-count="0"] [data-pj-saved-filters],
.pj-saved-shell[data-saved-state="loaded"][data-saved-count="0"] [data-pj-saved-filter-empty],
.pj-saved-shell[data-saved-state="loaded"][data-saved-count="0"] [data-pj-saved-list] {
  display: none !important;
}

.pj-saved-shell[data-saved-state="loaded"][data-saved-count="0"] [data-pj-saved-empty] {
  display: grid !important;
}

.pj-saved-shell[data-saved-state="loaded"]:not([data-saved-count="0"]) [data-pj-saved-empty] {
  display: none !important;
}

.pj-saved-filter-empty[hidden],
.pj-saved-shell[data-saved-count="0"] .pj-saved-filter-empty {
  display: none !important;
}
/* Events filter behavior fix — closed panels take no space, two simple rows by default */
.pj-filter-stack--events .ps-date-chip-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 7px !important;
  padding: 8px 14px 6px !important;
  margin: 0 !important;
  overflow: visible !important;
}

.pj-filter-stack--events .ps-events-utility-row {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: flex-start !important;
  justify-content: flex-start !important;
  gap: 8px 10px !important;
  width: auto !important;
  max-width: calc(100vw - 28px) !important;
  margin: 0 14px 10px !important;
  padding: 0 !important;
  background: transparent !important;
  overflow: visible !important;
  position: relative !important;
}

.pj-filter-stack--events .ps-more-filters,
.pj-filter-stack--events .ps-date-form {
  flex: 0 0 auto !important;
  width: auto !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  position: static !important;
}

.pj-filter-stack--events .ps-more-filters > summary,
.pj-filter-stack--events .ps-utility-button--date {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 40px !important;
  width: auto !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 10px 14px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(122, 66, 43, .18) !important;
  background: #fffaf3 !important;
  color: #33261f !important;
  box-shadow: 0 1px 0 rgba(255,255,255,.8) inset !important;
  font-size: 13px !important;
  font-weight: 850 !important;
  line-height: 1 !important;
  list-style: none !important;
  cursor: pointer !important;
  transform: none !important;
}

.pj-filter-stack--events .ps-more-filters > summary::-webkit-details-marker {
  display: none !important;
}

.pj-filter-stack--events .ps-more-filters.has-active-filters > summary,
.pj-filter-stack--events .ps-more-filters[open] > summary,
.pj-filter-stack--events .ps-utility-button--date.active,
.pj-filter-stack--events .pj-date-form.is-date-open .ps-utility-button--date {
  background: #b24a2b !important;
  border-color: #b24a2b !important;
  color: #fffaf3 !important;
  box-shadow: 0 8px 18px rgba(178,74,43,.18) !important;
}

.pj-filter-stack--events .ps-more-filters:not([open]) > .ps-more-filters-panel,
.pj-filter-stack--events .pj-date-form:not(.is-date-open) [data-pj-calendar-panel],
.pj-filter-stack--events [data-pj-calendar-panel][hidden],
.pj-filter-stack--events .pj-calendar-panel[hidden] {
  display: none !important;
  height: 0 !important;
  min-height: 0 !important;
  max-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  overflow: hidden !important;
  visibility: hidden !important;
}

.pj-filter-stack--events .ps-more-filters[open],
.pj-filter-stack--events .pj-date-form.is-date-open {
  flex: 0 0 100% !important;
  width: 100% !important;
  order: 2 !important;
}

.pj-filter-stack--events .ps-date-form:not(.is-date-open) {
  order: 1 !important;
}

.pj-filter-stack--events .ps-more-filters:not([open]) {
  order: 0 !important;
}

.pj-filter-stack--events .ps-more-filters[open] > summary,
.pj-filter-stack--events .pj-date-form.is-date-open [data-pj-date-open] {
  width: max-content !important;
}

.pj-filter-stack--events .ps-more-filters[open] > .ps-more-filters-panel,
.pj-filter-stack--events .pj-date-form.is-date-open [data-pj-calendar-panel] {
  display: block !important;
  visibility: visible !important;
  position: static !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  margin: 8px 0 0 !important;
  box-sizing: border-box !important;
  overflow: visible !important;
}

.pj-filter-stack--events .pj-date-form.is-date-open [data-pj-calendar-panel] {
  padding: 13px !important;
  border: 1px solid rgba(122, 66, 43, .16) !important;
  border-radius: 20px !important;
  background: #fffaf3 !important;
  box-shadow: 0 18px 42px rgba(55,36,26,.13) !important;
}

.pj-filter-stack--events .ps-filter-drawer-actions,
.pj-filter-stack--events .pj-calendar-actions {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 12px !important;
}

.pj-filter-stack--events .ps-filter-apply::after,
.pj-filter-stack--events .pj-date-apply--calendar::after,
.pj-filter-stack--events .pj-date-reset--calendar::after {
  content: none !important;
}

.pj-filter-stack--events + .pj-section-label {
  margin-top: 10px !important;
}

@media (max-width: 430px) {
  .pj-filter-stack--events .ps-date-chip-row {
    gap: 6px !important;
    padding-left: 14px !important;
    padding-right: 14px !important;
  }
  .pj-filter-stack--events .ps-date-chip {
    padding: 8px 10px !important;
    font-size: 12.5px !important;
  }
}
/* Events quick-date row: keep default controls to one compact row */
.pj-filter-stack--events .ps-date-chip-row {
  flex-wrap: nowrap !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  -webkit-overflow-scrolling: touch !important;
  scrollbar-width: none !important;
  min-height: 42px !important;
  max-height: 46px !important;
  align-items: center !important;
}
.pj-filter-stack--events .ps-date-chip-row::-webkit-scrollbar {
  display: none !important;
}
.pj-filter-stack--events .ps-date-chip {
  flex: 0 0 auto !important;
  white-space: nowrap !important;
}
/* Events date picker: keep calendar panel in-flow and fully inside mobile viewport */
.pj-filter-stack--events .pj-date-form.is-date-open [data-pj-calendar-panel] {
  position: static !important;
  inset: auto !important;
  left: auto !important;
  right: auto !important;
  top: auto !important;
  bottom: auto !important;
  transform: none !important;
  translate: none !important;
  margin: 8px 0 0 !important;
  width: min(100%, calc(100vw - 28px)) !important;
  max-width: calc(100vw - 28px) !important;
  box-sizing: border-box !important;
}

.pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-help,
.pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-weekdays,
.pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-grid,
.pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-actions,
.pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-head {
  max-width: 100% !important;
  box-sizing: border-box !important;
}
/* Events date picker: stack the opened calendar below the Date button, not beside it */
.pj-filter-stack--events .pj-date-form.is-date-open [data-pj-range-picker] {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
}

.pj-filter-stack--events .pj-date-form.is-date-open [data-pj-calendar-panel] {
  display: block !important;
  clear: both !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 8px 0 0 !important;
}
/* PJ 1.5.332: premium mobile Events Date calendar — fully visible, legible dates. */
.pj-filter-stack--events .pj-date-form.is-date-open [data-pj-calendar-panel] {
  background: linear-gradient(180deg, #fffdf8 0%, #fff7ec 100%) !important;
  border: 1px solid rgba(178, 74, 43, 0.18) !important;
  border-radius: 24px !important;
  box-shadow: 0 16px 40px rgba(64, 39, 21, 0.18), 0 2px 10px rgba(64, 39, 21, 0.08) !important;
  color: #251b16 !important;
  padding: 14px !important;
  overflow: visible !important;
}

.pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-head {
  margin-bottom: 10px !important;
}

.pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-head strong,
.pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-title,
.pj-filter-stack--events .pj-date-form.is-date-open [data-pj-calendar-title] {
  color: #261814 !important;
  font-size: 17px !important;
  font-weight: 900 !important;
  letter-spacing: -0.01em !important;
}

.pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-nav {
  width: 36px !important;
  height: 36px !important;
  min-height: 36px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: #fff3e4 !important;
  border: 1px solid rgba(178, 74, 43, 0.16) !important;
  color: #7e321f !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.82) !important;
}

.pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-help {
  margin: 0 2px 12px !important;
  color: #725241 !important;
  font-size: 12px !important;
  line-height: 1.35 !important;
  font-weight: 750 !important;
}

.pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-weekdays,
.pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-grid {
  grid-template-columns: repeat(7, minmax(0, 1fr)) !important;
  gap: 6px !important;
}

.pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-weekdays {
  margin-bottom: 7px !important;
}

.pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-weekdays span {
  color: #9a6044 !important;
  font-size: 10.5px !important;
  line-height: 1.1 !important;
  font-weight: 950 !important;
  letter-spacing: 0.035em !important;
}

.pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-day {
  width: 100% !important;
  min-width: 0 !important;
  min-height: 40px !important;
  height: 40px !important;
  aspect-ratio: auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  border-radius: 14px !important;
  border: 1px solid rgba(98, 63, 39, 0.12) !important;
  background: rgba(255, 255, 255, 0.74) !important;
  color: #2b211c !important;
  font: 900 15px/1 var(--font-sans) !important;
  text-indent: 0 !important;
  opacity: 1 !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.92) !important;
}

.pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-day.is-disabled,
.pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-day:disabled {
  background: rgba(255, 255, 255, 0.38) !important;
  color: #a79082 !important;
  border-color: rgba(98, 63, 39, 0.07) !important;
  opacity: 1 !important;
}

.pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-day.is-today {
  background: #fff0df !important;
  border-color: rgba(198, 90, 46, 0.45) !important;
  color: #8a341d !important;
  box-shadow: 0 0 0 2px rgba(198,90,46,0.10), inset 0 1px 0 rgba(255,255,255,0.92) !important;
}

.pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-day.is-today::after {
  width: 4px !important;
  height: 4px !important;
  bottom: 5px !important;
  background: #c65a2e !important;
  opacity: 0.85 !important;
}

.pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-day.is-selected,
.pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-day[aria-pressed="true"] {
  background: linear-gradient(180deg, #cf5d33 0%, #a63f22 100%) !important;
  border-color: #9f3f20 !important;
  color: #fffdf8 !important;
  box-shadow: 0 8px 16px rgba(178,74,43,0.24), inset 0 1px 0 rgba(255,255,255,0.24) !important;
}

.pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-day.is-selected::after,
.pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-day[aria-pressed="true"]::after {
  background: #fffdf8 !important;
}

.pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-day.is-in-range {
  background: #ffe1cd !important;
  color: #7e321f !important;
}

.pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-actions {
  position: static !important;
  margin: 13px 0 0 !important;
  padding: 0 !important;
  gap: 10px !important;
  background: transparent !important;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr) !important;
}

.pj-filter-stack--events .pj-date-form.is-date-open .pj-date-reset.pj-date-reset--calendar,
.pj-filter-stack--events .pj-date-form.is-date-open .pj-date-apply.pj-date-apply--calendar {
  min-height: 42px !important;
  border-radius: 999px !important;
  font-size: 13px !important;
  line-height: 1 !important;
  font-weight: 950 !important;
  margin: 0 !important;
}

.pj-filter-stack--events .pj-date-form.is-date-open .pj-date-reset.pj-date-reset--calendar {
  background: #2f2a27 !important;
  color: #fff8ef !important;
  border: 0 !important;
}

.pj-filter-stack--events .pj-date-form.is-date-open .pj-date-apply.pj-date-apply--calendar {
  background: linear-gradient(180deg, #f08245 0%, #d75f32 100%) !important;
  color: #fff !important;
  border: 0 !important;
  box-shadow: 0 10px 18px rgba(215, 95, 50, 0.22) !important;
}

@media (max-width: 374px) {
  .pj-filter-stack--events .pj-date-form.is-date-open [data-pj-calendar-panel] {
    padding: 12px !important;
  }
  .pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-weekdays,
  .pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-grid {
    gap: 4px !important;
  }
  .pj-filter-stack--events .pj-date-form.is-date-open .pj-calendar-day {
    height: 36px !important;
    min-height: 36px !important;
    border-radius: 12px !important;
    font-size: 14px !important;
  }
}
/* Services page v1.5.333 — clean local-services pillar polish */
.pj-services-page .pj-services-categories {
  margin-top: 4px;
}
.pj-service-category-card {
  overflow: hidden;
}
.pj-service-category-card::after {
  content: "›";
  position: absolute;
  right: 16px;
  top: 18px;
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: #fff3e8;
  color: #b94726;
  font-size: 24px;
  line-height: 1;
  font-weight: 700;
  border: 1px solid rgba(185, 71, 38, .14);
  opacity: .86;
  transition: transform .16s ease, background-color .16s ease;
}
.pj-service-category-card:hover::after,
.pj-service-category-card:active::after {
  transform: translateX(2px);
  background: #ffe5d2;
}
.pj-service-category-card:active {
  transform: translateY(0) scale(.995);
  border-color: rgba(185, 91, 52, .36);
  background: #fff6ed;
}
.pj-service-category-card h3,
.pj-service-category-card p {
  padding-right: 22px;
}
.pj-service-category-card p {
  min-height: 54px;
}
.pj-services-business-cta {
  background: linear-gradient(135deg, #fff4e8 0%, #fffaf4 100%);
  border-color: rgba(185, 91, 52, .22);
}
.pj-services-business-cta h2 {
  color: #271f18;
}
@media (max-width: 640px) {
  .pj-service-category-card p { min-height: 0; }
  .pj-service-category-card::after {
    right: 14px;
    top: 16px;
  }
}

/* Explore filters: mobile-first default + in-place More Filters drawer */
.pj-filter-stack--explore {
  overflow: visible;
}
.pj-filter-stack--explore .pj-explore-filter-form {
  padding-bottom: 2px;
}
.pj-filter-stack--explore .pj-primary-filter-bar--explore {
  display: flex;
  align-items: center;
  gap: 7px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding: 9px 12px 5px;
  border-bottom: 0;
}
.pj-filter-stack--explore .pj-primary-filter-bar--explore::-webkit-scrollbar { display: none; }
.pj-filter-stack--explore .pj-explore-filter-actions {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  padding: 5px 12px 8px;
  background: transparent;
  border: 0;
  overflow: visible;
}
.pj-filter-stack--explore .pj-explore-more-filter-form {
  margin: 0;
  flex: 0 0 auto;
}
.pj-more-filters-button,
.pj-explore-browse-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 8px 13px;
  border: 1px solid rgba(176, 130, 91, .35);
  border-radius: 999px;
  background: #fffdf8;
  color: #493729;
  font-size: 12px;
  font-weight: 850;
  line-height: 1;
  white-space: nowrap;
  box-shadow: 0 1px 4px rgba(111, 67, 43, .08);
  cursor: pointer;
}
.pj-more-filters-button::after,
.pj-explore-browse-toggle::after {
  content: '▾';
  margin-left: 6px;
  font-size: 10px;
  color: #9d5b35;
}
.pj-explore-more-filter-form.is-more-open .pj-more-filters-button::after,
.pj-explore-more-filter-form.is-more-open .pj-explore-browse-toggle::after { content: '▴'; }
.pj-more-filters-button.has-active-filters,
.pj-explore-browse-toggle.has-active-filters {
  border-color: rgba(198, 90, 46, .62);
  background: #fff3e7;
  color: #7f351d;
}
.pj-filter-stack--explore .pj-explore-browse-panel[hidden] {
  display: none !important;
}
.pj-filter-stack--explore .pj-explore-browse-panel {
  position: absolute;
  z-index: 80;
  left: 12px;
  right: 12px;
  top: calc(100% - 2px);
  display: block;
  padding: 12px;
  border: 1px solid rgba(176, 130, 91, .28);
  border-radius: 20px;
  background: #fffaf2;
  box-shadow: 0 16px 34px rgba(57, 37, 22, .18);
}
.pj-filter-stack--explore .pj-explore-browse-panel .pj-explore-browse-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.pj-filter-stack--explore .pj-explore-choice {
  min-width: 0;
  min-height: 68px;
  padding: 8px 5px 7px;
  border-radius: 16px;
  background: #fffdf8;
}
.pj-filter-stack--explore .pj-explore-choice-label {
  font-size: 10.8px;
  line-height: 1.12;
}
.pj-filter-stack--explore .pj-explore-browse-actions-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid rgba(176, 130, 91, .22);
}
.pj-filter-stack--explore .pj-explore-browse-clear,
.pj-filter-stack--explore .pj-explore-browse-apply {
  min-height: 36px;
  padding: 9px 15px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 850;
  text-decoration: none;
  cursor: pointer;
}
.pj-filter-stack--explore .pj-explore-browse-clear {
  border: 1px solid rgba(176, 130, 91, .32);
  background: #fffdf8;
  color: #7b5a44;
}
.pj-filter-stack--explore .pj-explore-browse-apply {
  border: 1px solid #c65a2e;
  background: #c65a2e;
  color: #fff;
}
.pj-filter-stack--explore .pj-sort-chip {
  min-height: 34px;
  padding: 8px 13px;
  border-color: rgba(176, 130, 91, .35);
  background: #fffdf8;
  color: #493729;
  font-size: 12px;
  font-weight: 850;
  box-shadow: 0 1px 4px rgba(111, 67, 43, .08);
}
.pj-explore-curation-head {
  display: none !important;
}
.pj-filter-stack--explore + .pj-explore-curation-head + .pj-event-card,
.pj-filter-stack--explore + .pj-event-card {
  margin-top: 6px;
}
@media (max-width: 760px) {
  .pj-filter-stack--explore .pj-primary-filter-bar--explore { padding: 8px 10px 4px; gap: 6px; }
  .pj-filter-stack--explore .pj-explore-filter-actions { padding: 4px 10px 7px; gap: 7px; }
  .pj-filter-stack--explore .pj-explore-browse-panel { left: 10px; right: 10px; border-radius: 18px; }
  .pj-filter-stack--explore .pj-explore-browse-panel .pj-explore-browse-grid { gap: 7px; }
}

/* Explore filter chip overflow fix: show the 8 primary chips inside the mobile viewport */
@media (max-width: 760px) {
  .pj-filter-stack--explore .pj-primary-filter-bar--explore {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 6px;
    overflow: visible !important;
    padding: 8px 10px 5px;
  }
  .pj-filter-stack--explore .pj-primary-filter-bar--explore .pj-category-tab {
    width: 100%;
    min-width: 0;
    justify-content: center;
    text-align: center;
    white-space: normal;
    line-height: 1.05;
    min-height: 34px;
    padding: 7px 5px;
    font-size: 11.2px;
  }
}

/* Tighter mobile Explore chip grid so cards still appear quickly after fixing overflow */
@media (max-width: 760px) {
  .pj-filter-stack--explore .pj-primary-filter-bar--explore {
    gap: 4px !important;
    padding-top: 6px !important;
    padding-bottom: 3px !important;
  }
  .pj-filter-stack--explore .pj-primary-filter-bar--explore .pj-category-tab {
    min-height: 30px !important;
    padding: 5px 4px !important;
    font-size: 10.8px !important;
    line-height: 1.02 !important;
  }
}

/* Hard mobile viewport guard for Explore filters and More Filters drawer */
@media (max-width: 760px) {
  html,
  body {
    overflow-x: hidden;
  }
  .pj-filter-stack--explore,
  .pj-filter-stack--explore .pj-explore-filter-form,
  .pj-filter-stack--explore .pj-primary-filter-bar--explore,
  .pj-filter-stack--explore .pj-explore-filter-actions {
    width: 100% !important;
    max-width: calc(100vw - 20px) !important;
    box-sizing: border-box !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  .pj-filter-stack--explore .pj-primary-filter-bar--explore {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    padding-left: 6px !important;
    padding-right: 6px !important;
  }
  .pj-filter-stack--explore .pj-explore-filter-actions {
    flex-wrap: wrap;
    padding-left: 6px !important;
    padding-right: 6px !important;
    overflow: visible !important;
  }
  .pj-filter-stack--explore .pj-explore-more-filter-form {
    min-width: 0 !important;
    max-width: 100% !important;
  }
  .pj-filter-stack--explore .pj-explore-browse-panel {
    left: 0 !important;
    right: auto !important;
    width: 100% !important;
    max-width: calc(100vw - 20px) !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
  }
  .pj-filter-stack--explore .pj-explore-browse-panel .pj-explore-browse-grid,
  .pj-filter-stack--explore .pj-explore-browse-actions-row {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
  .pj-filter-stack--explore .pj-explore-browse-actions-row {
    gap: 8px !important;
  }
  .pj-filter-stack--explore .pj-explore-browse-clear,
  .pj-filter-stack--explore .pj-explore-browse-apply {
    flex: 1 1 0 !important;
    min-width: 0 !important;
    max-width: 100% !important;
    text-align: center !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
  }
}

@media (max-width: 374px) {
  .pj-filter-stack--explore .pj-primary-filter-bar--explore {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

/* Shared card-system standardization pass (staging 1.5.340).
   Scope: list/search/saved/related cards only; detail-page hero media is untouched. */
:root {
  --pj-card-bg: #fffdf8;
  --pj-card-border: rgba(45, 35, 25, 0.08);
  --pj-card-shadow: 0 8px 24px rgba(0, 0, 0, 0.04);
  --pj-card-image-bg: #f3eee7;
  --pj-card-rust: #a74733;
  --pj-card-rust-soft: #f3e2dc;
}

/* More breathing room above the sticky bottom nav on card-list pages. */
body.home .pj-main,
body.post-type-archive-event .pj-main,
.pj-search-main,
.pj-saved-shell,
.pj-events-list,
.pj-explore-list {
  padding-bottom: max(118px, calc(96px + env(safe-area-inset-bottom, 0px))) !important;
}

/* Shared shell treatment for reusable card components. */
.pj-event-card,
.ps-event-card,
.pj-saved-card--feed,
.pj-related-card,
.pj-search-card {
  background: var(--pj-card-bg) !important;
  border: 1px solid var(--pj-card-border) !important;
  border-radius: 22px !important;
  box-shadow: var(--pj-card-shadow) !important;
  overflow: hidden !important;
}

/* Standard EventCard: compact left image, right content, safe action row. */
.pj-events-list > .ps-event-card,
.ps-event-card,
.ps-event-card.pj-home-best-card:not(.pj-event-card--explore),
.pj-search-card.ps-search-event-card {
  display: grid !important;
  grid-template-columns: 112px minmax(0, 1fr) !important;
  grid-template-areas:
    "image body"
    "bottom bottom" !important;
  column-gap: 12px !important;
  row-gap: 10px !important;
  padding: 14px !important;
  align-items: stretch !important;
}

.ps-event-image,
.ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-image,
.pj-search-card.ps-search-event-card .pj-event-image-wrap {
  grid-area: image !important;
  width: 112px !important;
  height: 112px !important;
  min-width: 112px !important;
  max-width: 112px !important;
  min-height: 112px !important;
  max-height: 112px !important;
  border-radius: 16px !important;
  overflow: hidden !important;
  background: var(--pj-card-image-bg) !important;
  position: relative !important;
}
.ps-event-image img,
.pj-search-card.ps-search-event-card .pj-event-image {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: cover !important;
  object-position: center center !important;
  transform: none !important;
}

.ps-event-body,
.ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-body,
.pj-search-card.ps-search-event-card .pj-event-body {
  grid-area: body !important;
  min-width: 0 !important;
  height: 112px !important;
  min-height: 112px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
  padding-right: 42px !important;
  overflow: hidden !important;
}
.ps-event-title,
.pj-search-card.ps-search-event-card .pj-event-title {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  white-space: normal !important;
  text-overflow: ellipsis !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
  hyphens: none !important;
  font-size: clamp(18px, 5vw, 21px) !important;
  line-height: 1.08 !important;
}
.ps-event-description,
.pj-search-card.ps-search-event-card .pj-event-desc {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  min-height: 0 !important;
  white-space: normal !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
  hyphens: none !important;
}
.ps-event-venue,
.pj-search-card.ps-search-event-card .pj-event-venue {
  min-width: 0 !important;
  overflow: hidden !important;
  white-space: nowrap !important;
  text-overflow: ellipsis !important;
  margin-top: auto !important;
}
.ps-event-bottom {
  grid-area: bottom !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
  min-width: 0 !important;
}
.ps-event-meta {
  min-width: 0 !important;
  flex: 1 1 auto !important;
  overflow: hidden !important;
  white-space: nowrap !important;
  text-overflow: ellipsis !important;
}
.ps-calendar-button,
.ps-calendar-button:visited,
.pj-add-calendar-link,
.pj-add-calendar-link:visited {
  flex: 0 0 auto !important;
  min-height: 34px !important;
  border-radius: 999px !important;
  background: var(--pj-card-rust-soft) !important;
  border: 1px solid rgba(167, 71, 51, 0.22) !important;
  color: var(--pj-card-rust) !important;
  padding: 7px 12px !important;
  font-size: 12.5px !important;
  line-height: 1 !important;
  font-weight: 850 !important;
  text-decoration: none !important;
  white-space: nowrap !important;
}
.ps-event-card .ps-event-heart,
.ps-event-card .ps-event-heart.pj-save-heart,
.ps-event-card .ps-event-heart.pj-save-heart.is-saved {
  top: 14px !important;
  right: 14px !important;
  z-index: 4 !important;
}

/* Explore/place cards: top media, consistent 16:9 frame, no Calendar treatment. */
.pj-event-card--explore,
.pj-search-card.ps-explore-card,
.pj-saved-card--explore {
  border-radius: 22px !important;
}
.pj-event-card--explore .pj-event-image-wrap,
.pj-search-card.ps-explore-card .pj-event-image-wrap,
.pj-saved-card--explore .pj-saved-card-media,
.pj-related-card--explore img {
  width: 100% !important;
  aspect-ratio: 16 / 9 !important;
  height: auto !important;
  min-height: 0 !important;
  border-radius: 22px 22px 0 0 !important;
  overflow: hidden !important;
  background: var(--pj-card-image-bg) !important;
}
.pj-event-card--explore .pj-event-image,
.pj-search-card.ps-explore-card .pj-event-image,
.pj-saved-card--explore .pj-saved-card-media img,
.pj-related-card--explore img {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: cover !important;
  object-position: center center !important;
  transform: none !important;
}
.pj-event-card--explore .pj-event-desc,
.pj-search-card.ps-explore-card .pj-event-desc,
.pj-saved-card--explore .pj-saved-card-hint {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  min-height: 0 !important;
  word-break: normal !important;
  hyphens: none !important;
}
.pj-explore-card-actions,
.pj-search-explore-actions,
.pj-saved-card-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  align-items: center !important;
}
.pj-explore-card-action,
.pj-saved-open,
.pj-saved-calendar,
.pj-saved-maps {
  min-height: 34px !important;
  border-radius: 999px !important;
  padding: 7px 11px !important;
  font-size: 12px !important;
  line-height: 1 !important;
  font-weight: 850 !important;
  white-space: nowrap !important;
}

/* Saved cards should preserve the source card type. */
.pj-saved-card--event .pj-saved-card-link {
  display: grid !important;
  grid-template-columns: 112px minmax(0, 1fr) !important;
  gap: 12px !important;
  padding: 14px 58px 10px 14px !important;
}
.pj-saved-card--event .pj-saved-card-media {
  width: 112px !important;
  height: 112px !important;
  border-radius: 16px !important;
  align-self: start !important;
}
.pj-saved-card--event .pj-saved-card-body {
  min-height: 112px !important;
  justify-content: flex-start !important;
  overflow: hidden !important;
}
.pj-saved-card-title {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  word-break: normal !important;
  hyphens: none !important;
}
.pj-saved-card--event .pj-saved-card-hint {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}
.pj-saved-card--event .pj-saved-remove {
  top: 14px !important;
  right: 14px !important;
  transform: none !important;
}
.pj-saved-card--event .pj-saved-card-actions {
  padding: 0 14px 14px !important;
  justify-content: flex-end !important;
}

/* Related cards: fixed media frame and consistent title clamp. */
.pj-related-card img {
  width: 100% !important;
  aspect-ratio: 16 / 9 !important;
  height: auto !important;
  display: block !important;
  object-fit: cover !important;
  object-position: center !important;
  background: var(--pj-card-image-bg) !important;
}
.pj-related-card span,
.pj-related-card small {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  word-break: normal !important;
  hyphens: none !important;
}

@media (min-width: 761px) {
  .pj-events-list > .ps-event-card,
  .ps-event-card,
  .ps-event-card.pj-home-best-card:not(.pj-event-card--explore),
  .pj-search-card.ps-search-event-card {
    grid-template-columns: 160px minmax(0, 1fr) !important;
  }
  .ps-event-image,
  .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-image,
  .pj-search-card.ps-search-event-card .pj-event-image-wrap {
    width: 160px !important;
    height: 120px !important;
    min-width: 160px !important;
    max-width: 160px !important;
    min-height: 120px !important;
    max-height: 120px !important;
  }
  .ps-event-body,
  .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-body,
  .pj-search-card.ps-search-event-card .pj-event-body {
    min-height: 120px !important;
    height: 120px !important;
  }
  .pj-saved-card--event .pj-saved-card-link {
    grid-template-columns: 160px minmax(0, 1fr) !important;
  }
  .pj-saved-card--event .pj-saved-card-media {
    width: 160px !important;
    height: 120px !important;
  }
  .pj-saved-card--event .pj-saved-card-body {
    min-height: 120px !important;
  }
}

@media (max-width: 370px) {
  .pj-events-list > .ps-event-card,
  .ps-event-card,
  .ps-event-card.pj-home-best-card:not(.pj-event-card--explore),
  .pj-search-card.ps-search-event-card {
    grid-template-columns: 104px minmax(0, 1fr) !important;
    padding: 12px !important;
    column-gap: 10px !important;
  }
  .ps-event-image,
  .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-image,
  .pj-search-card.ps-search-event-card .pj-event-image-wrap {
    width: 104px !important;
    height: 104px !important;
    min-width: 104px !important;
    max-width: 104px !important;
    min-height: 104px !important;
    max-height: 104px !important;
  }
  .ps-event-body,
  .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-body,
  .pj-search-card.ps-search-event-card .pj-event-body {
    height: 104px !important;
    min-height: 104px !important;
    padding-right: 38px !important;
  }
  .ps-event-title,
  .pj-search-card.ps-search-event-card .pj-event-title {
    font-size: 17.5px !important;
  }
  .ps-event-description,
  .pj-search-card.ps-search-event-card .pj-event-desc {
    font-size: 12px !important;
    line-height: 1.18 !important;
  }
  .ps-calendar-button,
  .ps-calendar-button:visited,
  .pj-add-calendar-link,
  .pj-add-calendar-link:visited {
    min-height: 32px !important;
    padding: 6px 10px !important;
    font-size: 12px !important;
  }
  .pj-saved-card--event .pj-saved-card-link {
    grid-template-columns: 104px minmax(0, 1fr) !important;
    padding-left: 12px !important;
  }
  .pj-saved-card--event .pj-saved-card-media {
    width: 104px !important;
    height: 104px !important;
  }
  .pj-saved-card--event .pj-saved-card-body {
    min-height: 104px !important;
  }
}

/* Shared card-system specificity corrections (staging 1.5.340b). */
body .pj-search-card.ps-search-event-card .pj-event-image-wrap,
body .pj-search-card.ps-search-event-card:not(.pj-event-card--explore) .pj-event-image-wrap {
  width: 112px !important;
  height: 112px !important;
  min-width: 112px !important;
  max-width: 112px !important;
  min-height: 112px !important;
  max-height: 112px !important;
  flex: 0 0 112px !important;
  aspect-ratio: auto !important;
}
body .pj-search-card.ps-search-event-card .pj-event-body,
body .pj-search-card.ps-search-event-card:not(.pj-event-card--explore) .pj-event-body {
  height: 112px !important;
  min-height: 112px !important;
  max-height: 112px !important;
}
body .pj-search-card.ps-search-event-card .pj-card-link {
  display: grid !important;
  grid-template-columns: 112px minmax(0, 1fr) !important;
  gap: 12px !important;
  align-items: stretch !important;
}
body .pj-search-card.ps-search-event-card:not(.pj-event-card--explore) {
  padding: 14px !important;
}
body .pj-search-card.ps-search-event-card:not(.pj-event-card--explore) .pj-event-title {
  white-space: normal !important;
}

/* Related cards need a real frame around the img element; keep hero/gallery selectors untouched. */
body .pj-related-card .pj-related-card-link {
  display: block !important;
  color: inherit !important;
  text-decoration: none !important;
}
body .pj-related-card .pj-related-card-link::before {
  content: "";
  display: block;
  aspect-ratio: 16 / 9;
  background: var(--pj-card-image-bg);
}
body .pj-related-card .pj-related-card-link > img {
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 16 / 9 !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
  margin-top: calc(-100% * 9 / 16);
}

@media (min-width: 761px) {
  body .pj-search-card.ps-search-event-card .pj-card-link {
    grid-template-columns: 160px minmax(0, 1fr) !important;
  }
  body .pj-search-card.ps-search-event-card .pj-event-image-wrap,
  body .pj-search-card.ps-search-event-card:not(.pj-event-card--explore) .pj-event-image-wrap {
    width: 160px !important;
    height: 120px !important;
    min-width: 160px !important;
    max-width: 160px !important;
    min-height: 120px !important;
    max-height: 120px !important;
    flex-basis: 160px !important;
  }
  body .pj-search-card.ps-search-event-card .pj-event-body,
  body .pj-search-card.ps-search-event-card:not(.pj-event-card--explore) .pj-event-body {
    height: 120px !important;
    min-height: 120px !important;
    max-height: 120px !important;
  }
}
@media (max-width: 370px) {
  body .pj-search-card.ps-search-event-card .pj-card-link {
    grid-template-columns: 104px minmax(0, 1fr) !important;
    gap: 10px !important;
  }
  body .pj-search-card.ps-search-event-card .pj-event-image-wrap,
  body .pj-search-card.ps-search-event-card:not(.pj-event-card--explore) .pj-event-image-wrap {
    width: 104px !important;
    height: 104px !important;
    min-width: 104px !important;
    max-width: 104px !important;
    min-height: 104px !important;
    max-height: 104px !important;
    flex-basis: 104px !important;
  }
  body .pj-search-card.ps-search-event-card .pj-event-body,
  body .pj-search-card.ps-search-event-card:not(.pj-event-card--explore) .pj-event-body {
    height: 104px !important;
    min-height: 104px !important;
    max-height: 104px !important;
  }
}

/* RelatedCard fixed media wrappers + SavedEventCard 390px correction. */
body .pj-related-card .pj-related-card-link::before { content: none !important; display: none !important; }
body .pj-related-image-wrap {
  width: 100% !important;
  aspect-ratio: 16 / 9 !important;
  overflow: hidden !important;
  background: var(--pj-card-image-bg) !important;
}
body .pj-related-image-wrap img {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: cover !important;
  object-position: center !important;
  margin: 0 !important;
}
@media (min-width: 371px) and (max-width: 760px) {
  body .pj-saved-card--event .pj-saved-card-link {
    grid-template-columns: 112px minmax(0, 1fr) !important;
  }
  body .pj-saved-card--event .pj-saved-card-media {
    width: 112px !important;
    height: 112px !important;
    min-width: 112px !important;
    max-width: 112px !important;
    min-height: 112px !important;
    max-height: 112px !important;
  }
  body .pj-saved-card--event .pj-saved-card-body {
    min-height: 112px !important;
    height: 112px !important;
  }
}

/* SavedEventCard must not inherit the standalone EventCard grid from its saved-card shell. */
body .pj-saved-card--event.ps-event-card,
body .pj-saved-card--feed.ps-event-card {
  display: block !important;
  padding: 0 !important;
}
body .pj-saved-card--event.ps-event-card .pj-saved-card-link {
  display: grid !important;
  grid-template-columns: 112px minmax(0, 1fr) !important;
}
body .pj-saved-card--event.ps-event-card .pj-saved-card-media {
  width: 112px !important;
  height: 112px !important;
  min-width: 112px !important;
  max-width: 112px !important;
  min-height: 112px !important;
  max-height: 112px !important;
}
@media (max-width: 370px) {
  body .pj-saved-card--event.ps-event-card .pj-saved-card-link { grid-template-columns: 104px minmax(0, 1fr) !important; }
  body .pj-saved-card--event.ps-event-card .pj-saved-card-media {
    width: 104px !important; height: 104px !important; min-width: 104px !important; max-width: 104px !important; min-height: 104px !important; max-height: 104px !important;
  }
}
@media (min-width: 761px) {
  body .pj-saved-card--event.ps-event-card .pj-saved-card-link { grid-template-columns: 160px minmax(0, 1fr) !important; }
  body .pj-saved-card--event.ps-event-card .pj-saved-card-media {
    width: 160px !important; height: 120px !important; min-width: 160px !important; max-width: 160px !important; min-height: 120px !important; max-height: 120px !important;
  }
}

/* Final EventCard geometry guard: grid column must equal fixed image frame.
   Prevents text/body from sliding underneath the image on homepage/list/search cards. */
body .pj-events-list > .ps-event-card,
body .ps-event-card:not(.pj-saved-card--feed),
body .ps-event-card.pj-home-best-card:not(.pj-event-card--explore),
body .pj-search-card.ps-search-event-card:not(.pj-event-card--explore) {
  grid-template-columns: 112px minmax(0, 1fr) !important;
  column-gap: 12px !important;
}
body .ps-event-card:not(.pj-saved-card--feed) .ps-event-image,
body .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-image,
body .pj-search-card.ps-search-event-card:not(.pj-event-card--explore) .pj-event-image-wrap {
  width: 112px !important;
  height: 112px !important;
  min-width: 112px !important;
  max-width: 112px !important;
  min-height: 112px !important;
  max-height: 112px !important;
  flex-basis: 112px !important;
}
body .ps-event-card:not(.pj-saved-card--feed) .ps-event-body,
body .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-body,
body .pj-search-card.ps-search-event-card:not(.pj-event-card--explore) .pj-event-body {
  height: 112px !important;
  min-height: 112px !important;
  max-height: 112px !important;
}
@media (max-width: 370px) {
  body .pj-events-list > .ps-event-card,
  body .ps-event-card:not(.pj-saved-card--feed),
  body .ps-event-card.pj-home-best-card:not(.pj-event-card--explore),
  body .pj-search-card.ps-search-event-card:not(.pj-event-card--explore) {
    grid-template-columns: 104px minmax(0, 1fr) !important;
    column-gap: 10px !important;
  }
  body .ps-event-card:not(.pj-saved-card--feed) .ps-event-image,
  body .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-image,
  body .pj-search-card.ps-search-event-card:not(.pj-event-card--explore) .pj-event-image-wrap {
    width: 104px !important;
    height: 104px !important;
    min-width: 104px !important;
    max-width: 104px !important;
    min-height: 104px !important;
    max-height: 104px !important;
    flex-basis: 104px !important;
  }
  body .ps-event-card:not(.pj-saved-card--feed) .ps-event-body,
  body .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-body,
  body .pj-search-card.ps-search-event-card:not(.pj-event-card--explore) .pj-event-body {
    height: 104px !important;
    min-height: 104px !important;
    max-height: 104px !important;
  }
}
@media (min-width: 761px) {
  body .pj-events-list > .ps-event-card,
  body .ps-event-card:not(.pj-saved-card--feed),
  body .ps-event-card.pj-home-best-card:not(.pj-event-card--explore),
  body .pj-search-card.ps-search-event-card:not(.pj-event-card--explore) {
    grid-template-columns: 160px minmax(0, 1fr) !important;
    column-gap: 14px !important;
  }
  body .ps-event-card:not(.pj-saved-card--feed) .ps-event-image,
  body .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-image,
  body .pj-search-card.ps-search-event-card:not(.pj-event-card--explore) .pj-event-image-wrap {
    width: 160px !important;
    height: 120px !important;
    min-width: 160px !important;
    max-width: 160px !important;
    min-height: 120px !important;
    max-height: 120px !important;
    flex-basis: 160px !important;
  }
  body .ps-event-card:not(.pj-saved-card--feed) .ps-event-body,
  body .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-body,
  body .pj-search-card.ps-search-event-card:not(.pj-event-card--explore) .pj-event-body {
    height: 120px !important;
    min-height: 120px !important;
    max-height: 120px !important;
  }
}

/* Homepage EventCard venue spacing: add a small amount of breathing room above the location line. */
body.home .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-venue {
  margin-top: 4px !important;
}
body.home .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-description + .ps-event-venue {
  margin-top: 5px !important;
}
@media (max-width: 370px) {
  body.home .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-venue,
  body.home .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-description + .ps-event-venue {
    margin-top: 3px !important;
  }
}

/* Homepage EventCard venue spacing: give the location line one more small step of breathing room. */
body.home .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-venue {
  margin-top: 6px !important;
}
body.home .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-description + .ps-event-venue {
  margin-top: 7px !important;
}
@media (max-width: 370px) {
  body.home .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-venue,
  body.home .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-description + .ps-event-venue {
    margin-top: 5px !important;
  }
}

/* Homepage EventCard venue spacing: final subtle nudge for a less cramped location line. */
body.home .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-venue {
  margin-top: 8px !important;
}
body.home .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-description + .ps-event-venue {
  margin-top: 9px !important;
}
@media (max-width: 370px) {
  body.home .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-venue,
  body.home .ps-event-card.pj-home-best-card:not(.pj-event-card--explore) .ps-event-description + .ps-event-venue {
    margin-top: 6px !important;
  }
}

/* Services expanded local-guide staging preview (v1.5.349) */
.pj-services-page { background: #f8f1e7; }
.pj-services-short-intro { margin-top: 8px !important; color: #6d584a !important; font-size: 1rem !important; }
.pj-services-grid { grid-template-columns: repeat(auto-fit, minmax(245px, 1fr)); align-items: stretch; }
.pj-service-category-card { position: relative; min-height: 260px; display: flex; flex-direction: column; gap: 12px; border-radius: 24px; border: 1px solid rgba(139, 92, 59, .2); background: linear-gradient(180deg, #fffdf8 0%, #fbf3e8 100%); box-shadow: 0 18px 42px rgba(83, 49, 28, .08); }
.pj-service-category-card .pj-service-category-chips { display: flex; flex-wrap: wrap; gap: 7px; margin-top: auto; }
.pj-service-category-card .pj-service-category-chips span { display: inline-flex; align-items: center; min-height: 26px; padding: 5px 9px; border-radius: 999px; background: rgba(196, 107, 68, .08); border: 1px solid rgba(196, 107, 68, .18); color: #6e4632; font-size: .78rem; font-weight: 800; line-height: 1.1; }
.pj-service-category-card > strong { display: inline-flex; align-self: flex-start; align-items: center; min-height: 34px; padding: 0 13px; border-radius: 999px; background: #c85d35; color: #fff8ef; font-size: .86rem; font-weight: 900; }
.pj-services-preview-sections { width: min(100% - 32px, 1120px); margin: 0 auto; display: grid; gap: 18px; }
.pj-service-preview-group { padding: 18px; border-radius: 24px; border: 1px solid rgba(139, 92, 59, .18); background: rgba(255, 253, 248, .76); box-shadow: 0 14px 34px rgba(83, 49, 28, .06); }
.pj-service-preview-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 12px; }
.pj-service-preview-head h3 { margin: 0; font-family: 'Playfair Display', Georgia, serif; font-size: clamp(1.25rem, 4vw, 1.75rem); color: #2b211c; }
.pj-service-preview-head a { color: #9f4429; font-weight: 900; text-decoration: none; }
.pj-service-preview-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.pj-service-business-card { position: relative; grid-template-columns: 1fr; align-items: stretch; gap: 14px; padding: 18px; border: 1px solid rgba(139, 92, 59, .18); border-radius: 22px; background: #fffdf8; box-shadow: 0 14px 32px rgba(83, 49, 28, .07); }
.pj-service-business-card:first-of-type { border-top: 1px solid rgba(139, 92, 59, .18); }
.pj-service-business-card h3 { font-size: 1.08rem; line-height: 1.15; }
.pj-service-business-card p { margin: 0; color: #4f4037; line-height: 1.42; }
.pj-service-business-meta { color: #9f4429 !important; font-weight: 900; text-transform: none; letter-spacing: 0; }
.pj-service-business-area { font-size: .86rem; }
.pj-service-business-media { width: 54px; height: 54px; border-radius: 16px; overflow: hidden; background: #f2e2d0; border: 1px solid rgba(139, 92, 59, .18); }
.pj-service-business-media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.pj-service-paid-label { width: max-content; background: rgba(196, 107, 68, .12); color: #8a3d28; border: 1px solid rgba(196, 107, 68, .22); }
.pj-service-paid-label.is-demo-label { background: #2f2a25; color: #fff4df; border-color: #2f2a25; }
.pj-service-business-card.is-demo { border-style: dashed; background: repeating-linear-gradient(-45deg, #fffdf8, #fffdf8 12px, #fbf2e7 12px, #fbf2e7 24px); }
.pj-service-business-actions { display: flex; flex-wrap: wrap; gap: 8px; }
.pj-service-business-actions a, .pj-service-save-button { flex: 1 1 auto; min-height: 38px; border-radius: 999px; border: 1px solid rgba(139, 92, 59, .22); background: #fffaf2; color: #6c3b27; font-weight: 900; text-align: center; text-decoration: none; padding: 9px 12px; font: inherit; cursor: pointer; }
.pj-service-save-button { background: #2f2a25; color: #fff4df; border-color: #2f2a25; }
.pj-service-simple-filters { width: min(100% - 32px, 960px); margin: 0 auto; padding: 16px; border-radius: 22px; border: 1px solid rgba(139, 92, 59, .18); background: #fffdf8; display: grid; gap: 14px; }
.pj-service-filter-group { display: grid; gap: 8px; }
.pj-service-filter-group > span { color: #755745; font-weight: 900; font-size: .8rem; text-transform: uppercase; letter-spacing: .08em; }
.pj-service-filter-group div { display: flex; flex-wrap: wrap; gap: 8px; }
.pj-service-filter-group a, .pj-service-clear-filters { padding: 8px 11px; border-radius: 999px; border: 1px solid rgba(139, 92, 59, .2); color: #5f4535; background: #fff8ee; text-decoration: none; font-size: .86rem; font-weight: 850; }
.pj-service-filter-group a.is-active { background: #c85d35; color: #fff8ef; border-color: #c85d35; }
.pj-services-browse-wellness { align-self: flex-start; margin-top: 12px; }
.pj-services-cta-row { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px; }
@media (max-width: 760px) {
  .pj-services-preview-sections { width: min(100% - 22px, 560px); gap: 14px; }
  .pj-service-preview-group { padding: 14px; border-radius: 20px; }
  .pj-service-preview-grid { grid-template-columns: 1fr; }
  .pj-service-category-card { min-height: 0; padding: 16px; }
  .pj-service-category-card .pj-service-category-chips span { font-size: .74rem; padding: 4px 8px; }
  .pj-service-business-card { padding: 15px; }
  .pj-service-business-actions a, .pj-service-save-button { flex-basis: calc(50% - 5px); }
  .pj-services-hero .pj-services-search input { font-size: 16px; }
}

/* Services business cards: make approved business images obvious (v1.5.351) */
.pj-service-business-card:has(.pj-service-business-media) {
  padding: 0;
  overflow: hidden;
  border-radius: 24px;
  gap: 0;
}
.pj-service-business-card:has(.pj-service-business-media) .pj-service-business-media {
  width: 100%;
  height: 150px;
  border: 0;
  border-radius: 0;
  background: #f0dfcf;
  display: block;
}
.pj-service-business-card:has(.pj-service-business-media) .pj-service-business-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.pj-service-business-card:has(.pj-service-business-media) .pj-service-business-card__main {
  padding: 16px 16px 4px;
}
.pj-service-business-card:has(.pj-service-business-media) .pj-service-business-actions {
  padding: 10px 16px 16px;
}
.pj-service-preview-grid .pj-service-business-card:has(.pj-service-business-media) .pj-service-business-media {
  height: 165px;
}
.pj-service-business-card:has(.pj-service-business-media) .pj-service-paid-label {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 2;
  box-shadow: 0 8px 18px rgba(43, 33, 28, .16);
}
@media (max-width: 760px) {
  .pj-service-business-card:has(.pj-service-business-media) .pj-service-business-media,
  .pj-service-preview-grid .pj-service-business-card:has(.pj-service-business-media) .pj-service-business-media {
    height: 172px;
  }
}

/* Services cards: better crop for location/interior photos (v1.5.360) */
.pj-service-business-card:has(.pj-service-business-media) .pj-service-business-media {
  height: clamp(172px, 45vw, 210px) !important;
  aspect-ratio: 16 / 9;
  background: #ead8c6;
}
.pj-service-business-card:has(.pj-service-business-media) .pj-service-business-media img {
  object-fit: cover !important;
  object-position: center center;
}

/* Services homepage simplification: curated, fun, mobile-first guide. */
.pj-services-page--simple {
    background: linear-gradient(180deg, #fff6ec 0, #fffdf9 320px, #fff8f0 100%);
}
.pj-services-page--simple .pj-services-hero--simple {
    max-width: 760px;
    padding: 24px 0 10px;
}
.pj-services-page--simple .pj-services-hero--simple h1 {
    max-width: 680px;
    margin-left: auto;
    margin-right: auto;
    font-size: clamp(38px, 8vw, 64px);
    letter-spacing: -.055em;
}
.pj-services-page--simple .pj-services-hero--simple > p:not(.pj-services-kicker) {
    max-width: 620px;
    font-size: 17px;
    color: #5f4c3d;
}
.pj-services-quick-search {
    width: min(100%, 640px);
    margin: 18px auto 0;
    padding: 8px;
    border: 1px solid rgba(129,78,47,.16);
    border-radius: 999px;
    background: rgba(255,255,255,.86);
    box-shadow: 0 16px 34px rgba(95,36,48,.08);
}
.pj-services-quick-search label {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
}
.pj-services-quick-search div {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 8px;
    align-items: center;
}
.pj-services-quick-search input {
    min-width: 0;
    border: 0;
    background: transparent;
    padding: 12px 14px;
    color: #2b211c;
    font: inherit;
    outline: none;
}
.pj-services-quick-search button {
    border: 0;
    border-radius: 999px;
    background: #b95b34;
    color: #fffdf8;
    font-weight: 900;
    padding: 12px 18px;
    cursor: pointer;
}
.pj-services-top-chips {
    display: flex;
    gap: 8px;
    justify-content: center;
    flex-wrap: wrap;
    margin: 16px auto 0;
    max-width: 680px;
}
.pj-services-top-chips a,
.pj-services-everyday-links a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    border: 1px solid rgba(129,78,47,.17);
    border-radius: 999px;
    background: #fffdf9;
    color: #4b3326;
    text-decoration: none;
    font-size: 13px;
    font-weight: 900;
    padding: 8px 13px;
    box-shadow: 0 8px 20px rgba(95,36,48,.045);
}
.pj-services-top-chips a:first-child {
    background: #b95b34;
    border-color: #b95b34;
    color: #fffdf8;
}
.pj-services-page--simple .pj-service-listings,
.pj-services-intent-sections,
.pj-services-more-help,
.pj-services-page--simple .pj-services-empty--home {
    max-width: 1040px;
    width: min(100%, 1040px);
    margin: 20px auto 0;
}
.pj-services-page--simple .pj-service-listings,
.pj-services-intent-sections,
.pj-services-more-help {
    border: 1px solid rgba(129,78,47,.12);
    border-radius: 28px;
    background: rgba(255,255,255,.74);
    padding: 20px;
    box-shadow: 0 18px 45px rgba(95,36,48,.055);
}
.pj-service-preview-grid--featured {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}
.pj-service-intent-group {
    margin-top: 18px;
    padding-top: 18px;
    border-top: 1px solid rgba(129,78,47,.12);
}
.pj-service-intent-group:first-of-type {
    border-top: 0;
    padding-top: 0;
}
.pj-service-intent-group .pj-service-preview-head {
    align-items: flex-end;
    gap: 12px;
}
.pj-service-preview-head p {
    max-width: 600px;
    margin: 5px 0 0;
    color: #6f594b;
    font-size: 14px;
    line-height: 1.35;
}
.pj-services-everyday-links {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: center;
}
.pj-services-more-help .pj-services-section-head {
    margin-bottom: 12px;
}
.pj-services-page--simple .pj-service-business-area {
    display: none;
}
.pj-services-page--simple .pj-service-business-card__main > p:not(.pj-service-business-meta) {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
@media (max-width: 760px) {
    .pj-services-page--simple {
        padding-left: 12px;
        padding-right: 12px;
    }
    .pj-services-page--simple .pj-services-hero--simple {
        padding-top: 18px;
    }
    .pj-services-page--simple .pj-services-hero--simple h1 {
        font-size: 39px;
        line-height: .96;
    }
    .pj-services-page--simple .pj-services-hero--simple > p:not(.pj-services-kicker) {
        font-size: 15px;
    }
    .pj-services-quick-search {
        border-radius: 24px;
        padding: 7px;
    }
    .pj-services-quick-search div {
        grid-template-columns: 1fr;
    }
    .pj-services-quick-search input,
    .pj-services-quick-search button {
        width: 100%;
    }
    .pj-services-top-chips {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
    }
    .pj-services-top-chips a {
        min-width: 0;
        padding-left: 8px;
        padding-right: 8px;
        text-align: center;
    }
    .pj-services-page--simple .pj-service-listings,
    .pj-services-intent-sections,
    .pj-services-more-help {
        padding: 14px;
        border-radius: 24px;
        margin-top: 16px;
    }
    .pj-service-preview-grid--featured,
    .pj-service-preview-grid {
        grid-template-columns: 1fr;
    }
    .pj-service-intent-group .pj-service-preview-head {
        align-items: flex-start;
    }
    .pj-services-everyday-links {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .pj-services-everyday-links a {
        min-width: 0;
    }
}

/* Services profile images: show approved media on detail pages, never blank placeholders. */
.pj-service-profile-media {
    width: min(100%, 760px);
    margin: 0 auto 18px;
    border: 1px solid rgba(129,78,47,.13);
    border-radius: 28px;
    overflow: hidden;
    background: #fffdf9;
    box-shadow: 0 18px 45px rgba(95,36,48,.07);
}
.pj-service-profile-media img {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    background: #fff4e8;
}
@media (max-width: 760px) {
    .pj-service-profile-media {
        width: min(100% - 24px, 560px);
        border-radius: 22px;
        margin-bottom: 14px;
    }
}

/* Saved cards final polish: clean, readable, mobile-first itinerary cards. */
.pj-saved-page {
    max-width: 820px;
}
.pj-saved-group-title {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 4px 0 2px;
    font-size: 21px;
    line-height: 1.15;
}
.pj-saved-group-title::after {
    content: "";
    flex: 1;
    height: 1px;
    background: linear-gradient(90deg, rgba(129,78,47,.18), rgba(129,78,47,0));
}
.pj-saved-card--feed {
    border-color: rgba(129,78,47,.13) !important;
    border-radius: 24px !important;
    background: #fffdf9 !important;
    box-shadow: 0 12px 30px rgba(95,36,48,.075) !important;
}
.pj-saved-card--event .pj-saved-card-link {
    display: grid !important;
    grid-template-columns: 104px minmax(0, 1fr) !important;
    gap: 12px !important;
    align-items: stretch !important;
    min-height: 128px !important;
    padding: 12px 52px 58px 12px !important;
}
.pj-saved-card--event .pj-saved-card-media {
    width: 104px !important;
    height: 104px !important;
    align-self: start !important;
    border-radius: 18px !important;
    background: #fff4e8 !important;
}
.pj-saved-card--event .pj-saved-card-body {
    justify-content: flex-start !important;
    gap: 6px !important;
    padding: 1px 0 0 !important;
    min-width: 0 !important;
}
.pj-saved-card--event .pj-saved-card-topline {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    margin: 0 0 1px !important;
    min-height: 24px !important;
}
.pj-saved-card--feed .pj-saved-kind,
.pj-saved-card--event .pj-saved-kind {
    border-radius: 999px !important;
    padding: 4px 8px !important;
    font-size: 10px !important;
    line-height: 1 !important;
    letter-spacing: .07em !important;
}
.pj-saved-card--feed .pj-saved-plan-label {
    color: #8c6d54;
    font-size: 10.5px;
    font-weight: 850;
    line-height: 1.1;
    white-space: nowrap;
}
.pj-saved-card--feed .pj-saved-card-title {
    display: -webkit-box !important;
    overflow: hidden !important;
    -webkit-box-orient: vertical !important;
    -webkit-line-clamp: 2 !important;
    color: #201915 !important;
    font-size: 18px !important;
    line-height: 1.15 !important;
}
.pj-saved-card--event .pj-saved-card-hint {
    display: inline-flex !important;
    width: fit-content !important;
    max-width: 100% !important;
    margin: 1px 0 0 !important;
    padding: 5px 8px !important;
    border-radius: 999px !important;
    background: #fff3df !important;
    color: #6b461b !important;
    font-size: 12px !important;
    font-weight: 900 !important;
    line-height: 1.15 !important;
}
.pj-saved-card--feed .pj-saved-card-meta {
    display: flex !important;
    gap: 6px !important;
    margin-top: 2px !important;
    padding-top: 0 !important;
}
.pj-saved-card--feed .pj-saved-card-meta span {
    max-width: 100% !important;
    padding: 4px 8px !important;
    overflow: hidden !important;
    border-radius: 999px !important;
    background: #f6efe5 !important;
    color: #6a5848 !important;
    font-size: 10.5px !important;
    font-weight: 850 !important;
    line-height: 1.15 !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}
.pj-saved-card--feed .pj-saved-remove,
.pj-saved-card--event .pj-saved-remove,
.pj-saved-card--explore .pj-saved-remove {
    top: 10px !important;
    right: 10px !important;
    bottom: auto !important;
    width: 34px !important;
    height: 34px !important;
    border: 1px solid rgba(177,61,69,.18) !important;
    border-radius: 999px !important;
    background: #fff8ef !important;
    color: #b13d45 !important;
    box-shadow: 0 6px 16px rgba(95,36,48,.12) !important;
    transform: none !important;
}
.pj-saved-card--feed .pj-saved-remove svg,
.pj-saved-card--event .pj-saved-remove svg,
.pj-saved-card--explore .pj-saved-remove svg {
    width: 18px !important;
    height: 18px !important;
    fill: #b13d45 !important;
    stroke: #b13d45 !important;
}
.pj-saved-card--feed .pj-saved-card-actions {
    position: absolute !important;
    left: 12px !important;
    right: 12px !important;
    bottom: 12px !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
    width: auto !important;
    max-width: none !important;
    transform: none !important;
    z-index: 8 !important;
}
.pj-saved-card--feed .pj-saved-card-actions a {
    position: static !important;
    inset: auto !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    min-width: 0 !important;
    min-height: 34px !important;
    padding: 7px 8px !important;
    border-radius: 999px !important;
    font-size: 11.5px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    text-align: center !important;
    text-decoration: none !important;
    white-space: nowrap !important;
    transform: none !important;
}
.pj-saved-card--feed .pj-saved-open {
    border: 1px solid rgba(47,111,62,.22) !important;
    background: #2f6f3e !important;
    color: #fff !important;
}
.pj-saved-card--feed .pj-saved-calendar,
.pj-saved-card--feed .pj-saved-maps {
    border: 1px solid rgba(129,78,47,.16) !important;
    background: #fffaf3 !important;
    color: #6b4d35 !important;
    box-shadow: none !important;
}
.pj-saved-card--explore .pj-saved-card-link {
    display: flex !important;
    flex-direction: column !important;
    padding: 0 0 58px !important;
}
.pj-saved-card--explore .pj-saved-card-media {
    width: 100% !important;
    aspect-ratio: 16 / 9 !important;
    border-radius: 24px 24px 0 0 !important;
}
.pj-saved-card--explore .pj-saved-card-body {
    gap: 7px !important;
    padding: 12px 52px 0 13px !important;
}
.pj-saved-card--explore .pj-saved-card-title {
    font-size: 19px !important;
}
.pj-saved-card--explore .pj-saved-card-hint {
    margin-top: 0 !important;
    color: #665545 !important;
    font-size: 13px !important;
    line-height: 1.35 !important;
}
@media (max-width: 390px) {
    .pj-saved-card--event .pj-saved-card-link {
        grid-template-columns: 96px minmax(0, 1fr) !important;
        gap: 10px !important;
        padding-left: 10px !important;
        padding-right: 48px !important;
    }
    .pj-saved-card--event .pj-saved-card-media {
        width: 96px !important;
        height: 96px !important;
    }
    .pj-saved-card--feed .pj-saved-card-actions {
        left: 10px !important;
        right: 10px !important;
        gap: 6px !important;
    }
    .pj-saved-card--feed .pj-saved-card-actions a {
        min-height: 32px !important;
        padding-left: 5px !important;
        padding-right: 5px !important;
        font-size: 10.5px !important;
    }
    .pj-saved-card--feed .pj-saved-remove,
    .pj-saved-card--event .pj-saved-remove,
    .pj-saved-card--explore .pj-saved-remove {
        right: 9px !important;
        width: 32px !important;
        height: 32px !important;
    }
}

/* Saved list overlap fix: keep controls in a normal vertical stack on mobile. */
.pj-saved-shell {
    display: block !important;
    position: relative !important;
    overflow: visible !important;
}
.pj-saved-shell[data-saved-state="loaded"]:not([data-saved-count="0"]) {
    padding-top: 10px !important;
}
.pj-saved-helper {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: center !important;
    gap: 7px !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 8px 0 10px !important;
    padding: 9px 12px !important;
    overflow: visible !important;
    border: 1px solid rgba(129,78,47,.12) !important;
    border-radius: 16px !important;
    background: #fffaf3 !important;
    color: #6b5a4b !important;
    font-size: 12px !important;
    line-height: 1.35 !important;
    text-align: left !important;
    box-sizing: border-box !important;
}
.pj-saved-helper span {
    flex: 0 0 auto !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 18px !important;
    height: 18px !important;
    margin-top: 0 !important;
    border-radius: 999px !important;
    background: #b95b34 !important;
    color: #fffdf8 !important;
    font-size: 11px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
}
.pj-saved-clear-link {
    display: block !important;
    margin: 0 auto 12px !important;
    padding: 3px 4px !important;
    line-height: 1.25 !important;
}
.pj-saved-filters {
    margin: 0 0 16px !important;
    padding: 0 !important;
    position: relative !important;
    z-index: 1 !important;
}
.pj-saved-list {
    clear: both !important;
    margin-top: 0 !important;
    position: relative !important;
    z-index: 0 !important;
}
.pj-saved-group {
    margin-top: 0 !important;
}
.pj-saved-group-grid {
    display: grid !important;
    gap: 14px !important;
}
@media (max-width: 760px) {
    .pj-saved-page {
        padding-top: max(16px, env(safe-area-inset-top)) !important;
    }
    .pj-saved-shell[data-saved-state="loaded"]:not([data-saved-count="0"]) {
        padding-top: 12px !important;
    }
    .pj-saved-helper {
        margin-top: 10px !important;
        padding: 10px 12px !important;
        font-size: 12px !important;
    }
    .pj-saved-filters {
        gap: 8px !important;
        margin-bottom: 18px !important;
    }
}

/* Saved card layout fix: every saved card is a left-image card; text must remain visible. */
.pj-saved-card--feed,
.pj-saved-card--event,
.pj-saved-card--explore {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-height: 0 !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
}
.pj-saved-card--feed .pj-saved-card-link,
.pj-saved-card--event .pj-saved-card-link,
.pj-saved-card--explore .pj-saved-card-link {
    display: grid !important;
    width: 100% !important;
    max-width: 100% !important;
    grid-template-columns: 104px minmax(0, 1fr) !important;
    gap: 12px !important;
    align-items: start !important;
    min-height: 0 !important;
    padding: 12px 50px 8px 12px !important;
    color: inherit !important;
    text-decoration: none !important;
    box-sizing: border-box !important;
}
.pj-saved-card--feed .pj-saved-card-media,
.pj-saved-card--event .pj-saved-card-media,
.pj-saved-card--explore .pj-saved-card-media {
    grid-column: 1 !important;
    width: 104px !important;
    height: 104px !important;
    min-width: 104px !important;
    max-width: 104px !important;
    aspect-ratio: 1 / 1 !important;
    align-self: start !important;
    border-radius: 18px !important;
    overflow: hidden !important;
}
.pj-saved-card--feed .pj-saved-card-media img,
.pj-saved-card--event .pj-saved-card-media img,
.pj-saved-card--explore .pj-saved-card-media img {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    max-width: none !important;
    object-fit: cover !important;
    border-radius: inherit !important;
}
.pj-saved-card--feed .pj-saved-card-body,
.pj-saved-card--event .pj-saved-card-body,
.pj-saved-card--explore .pj-saved-card-body {
    grid-column: 2 !important;
    display: flex !important;
    min-width: 0 !important;
    max-width: 100% !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    gap: 6px !important;
    padding: 1px 0 0 !important;
    overflow: visible !important;
}
.pj-saved-card--feed .pj-saved-card-title,
.pj-saved-card--event .pj-saved-card-title,
.pj-saved-card--explore .pj-saved-card-title {
    display: -webkit-box !important;
    -webkit-box-orient: vertical !important;
    -webkit-line-clamp: 2 !important;
    overflow: hidden !important;
    margin: 0 !important;
    max-width: 100% !important;
    color: #201915 !important;
    font-size: 17px !important;
    line-height: 1.16 !important;
}
.pj-saved-card--feed .pj-saved-card-hint,
.pj-saved-card--event .pj-saved-card-hint,
.pj-saved-card--explore .pj-saved-card-hint {
    display: -webkit-box !important;
    -webkit-box-orient: vertical !important;
    -webkit-line-clamp: 2 !important;
    overflow: hidden !important;
    margin: 0 !important;
    max-width: 100% !important;
    color: #665545 !important;
    background: transparent !important;
    box-shadow: none !important;
    padding: 0 !important;
    border-radius: 0 !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    line-height: 1.25 !important;
}
.pj-saved-card--feed .pj-saved-card-meta,
.pj-saved-card--event .pj-saved-card-meta,
.pj-saved-card--explore .pj-saved-card-meta {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 5px !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}
.pj-saved-card--feed .pj-saved-card-actions,
.pj-saved-card--event .pj-saved-card-actions,
.pj-saved-card--explore .pj-saved-card-actions {
    position: static !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
    margin: 0 12px 12px !important;
    width: auto !important;
}
@media (max-width: 390px) {
    .pj-saved-card--feed .pj-saved-card-link,
    .pj-saved-card--event .pj-saved-card-link,
    .pj-saved-card--explore .pj-saved-card-link {
        grid-template-columns: 96px minmax(0, 1fr) !important;
        gap: 10px !important;
        padding: 10px 44px 54px 10px !important;
    }
    .pj-saved-card--feed .pj-saved-card-media,
    .pj-saved-card--event .pj-saved-card-media,
    .pj-saved-card--explore .pj-saved-card-media {
        width: 96px !important;
        height: 96px !important;
        min-width: 96px !important;
        max-width: 96px !important;
    }
    .pj-saved-card--feed .pj-saved-card-title,
    .pj-saved-card--event .pj-saved-card-title,
    .pj-saved-card--explore .pj-saved-card-title {
        font-size: 16px !important;
    }
}

/* Saved text cutoff fix: give copy more room and stop inherited truncation. */
.pj-saved-card--feed .pj-saved-card-topline {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: visible !important;
}
.pj-saved-card--feed .pj-saved-plan-label {
    display: none !important;
}
.pj-saved-card--feed .pj-saved-kind {
    max-width: 100% !important;
    overflow: visible !important;
    white-space: nowrap !important;
}
.pj-saved-card--feed .pj-saved-card-title,
.pj-saved-card--feed .pj-saved-card-hint,
.pj-saved-card--feed .pj-saved-card-meta span {
    word-break: normal !important;
    overflow-wrap: normal !important;
    hyphens: none !important;
}
.pj-saved-card--feed .pj-saved-card-title {
    display: block !important;
    -webkit-line-clamp: initial !important;
    overflow: visible !important;
}
.pj-saved-card--feed .pj-saved-card-hint {
    -webkit-line-clamp: 2 !important;
}
@media (max-width: 760px) {
    .pj-saved-card--feed,
    .pj-saved-card--event,
    .pj-saved-card--explore {
        min-height: 0 !important;
    }
    .pj-saved-card--feed .pj-saved-card-link,
    .pj-saved-card--event .pj-saved-card-link,
    .pj-saved-card--explore .pj-saved-card-link {
        grid-template-columns: 98px minmax(0, 1fr) !important;
        padding-right: 44px !important;
    }
    .pj-saved-card--feed .pj-saved-card-media,
    .pj-saved-card--event .pj-saved-card-media,
    .pj-saved-card--explore .pj-saved-card-media {
        width: 98px !important;
        height: 98px !important;
        min-width: 98px !important;
        max-width: 98px !important;
    }
    .pj-saved-card--feed .pj-saved-card-title {
        font-size: 16px !important;
        line-height: 1.18 !important;
    }
}

/* Saved emergency reset: isolate saved cards from every older event/explore card rule. */
.pj-saved-card.pj-saved-card--feed,
.pj-saved-card.pj-saved-card--feed.pj-saved-card--event,
.pj-saved-card.pj-saved-card--feed.pj-saved-card--explore {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
}
.pj-saved-group-grid > .pj-saved-card.pj-saved-card--feed > .pj-saved-card-link {
    display: grid !important;
    width: 100% !important;
    max-width: 100% !important;
    grid-template-columns: 96px minmax(0, 1fr) !important;
    gap: 12px !important;
    align-items: start !important;
    padding: 12px 46px 8px 12px !important;
    box-sizing: border-box !important;
    overflow: visible !important;
}
.pj-saved-group-grid > .pj-saved-card.pj-saved-card--feed > .pj-saved-card-link > .pj-saved-card-media {
    width: 96px !important;
    height: 96px !important;
    min-width: 96px !important;
    max-width: 96px !important;
    min-height: 96px !important;
    max-height: 96px !important;
    grid-column: 1 !important;
}
.pj-saved-group-grid > .pj-saved-card.pj-saved-card--feed > .pj-saved-card-link > .pj-saved-card-body {
    grid-column: 2 !important;
    display: block !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: visible !important;
    color: #201915 !important;
}
.pj-saved-group-grid .pj-saved-card-title,
.pj-saved-group-grid .pj-saved-card-hint,
.pj-saved-group-grid .pj-saved-card-meta,
.pj-saved-group-grid .pj-saved-card-meta span {
    display: block !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: auto !important;
    max-height: none !important;
    margin: 0 0 5px !important;
    padding: 0 !important;
    overflow: visible !important;
    visibility: visible !important;
    opacity: 1 !important;
    color: #201915 !important;
    white-space: normal !important;
    text-overflow: clip !important;
    -webkit-line-clamp: initial !important;
    -webkit-box-orient: initial !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
}
.pj-saved-group-grid .pj-saved-card-title {
    font-size: 16px !important;
    line-height: 1.18 !important;
    font-weight: 850 !important;
}
.pj-saved-group-grid .pj-saved-card-hint,
.pj-saved-group-grid .pj-saved-card-meta span {
    color: #5f4b3e !important;
    font-size: 12px !important;
    line-height: 1.25 !important;
    font-weight: 750 !important;
}
.pj-saved-group-grid .pj-saved-card-actions {
    position: static !important;
    display: grid !important;
    width: auto !important;
    max-width: none !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
    margin: 0 12px 12px !important;
    padding: 0 !important;
}

/* Saved cards v2: isolated classes so older event/explore CSS cannot break text. */
.pj-saved-group-grid {
    display: grid !important;
    gap: 14px !important;
}
.pj-list-card {
    position: relative !important;
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
    border: 1px solid rgba(129,78,47,.13) !important;
    border-radius: 22px !important;
    background: #fffdf9 !important;
    box-shadow: 0 10px 24px rgba(95,36,48,.075) !important;
    box-sizing: border-box !important;
}
.pj-list-card-link {
    display: grid !important;
    grid-template-columns: 96px minmax(0, 1fr) !important;
    gap: 12px !important;
    align-items: start !important;
    width: 100% !important;
    max-width: 100% !important;
    min-height: 0 !important;
    padding: 12px 46px 8px 12px !important;
    color: inherit !important;
    text-decoration: none !important;
    box-sizing: border-box !important;
}
.pj-list-card-media {
    position: relative !important;
    grid-column: 1 !important;
    width: 96px !important;
    height: 96px !important;
    min-width: 96px !important;
    max-width: 96px !important;
    overflow: hidden !important;
    border-radius: 16px !important;
    background: #fff4e8 !important;
}
.pj-list-card-media img {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: inherit !important;
}
.pj-list-card-body {
    grid-column: 2 !important;
    display: block !important;
    min-width: 0 !important;
    max-width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: visible !important;
    color: #201915 !important;
}
.pj-list-card-topline {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 5px !important;
    align-items: center !important;
    margin: 0 0 6px !important;
    min-width: 0 !important;
}
.pj-list-kind {
    display: inline-flex !important;
    align-items: center !important;
    width: auto !important;
    max-width: 100% !important;
    padding: 4px 8px !important;
    border-radius: 999px !important;
    background: #b95b34 !important;
    color: #fffdf8 !important;
    font-size: 10px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    letter-spacing: .06em !important;
    text-transform: uppercase !important;
    white-space: nowrap !important;
}
.pj-list-plan-label {
    display: none !important;
}
.pj-list-card-title {
    display: block !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: auto !important;
    margin: 0 0 5px !important;
    padding: 0 !important;
    overflow: visible !important;
    color: #201915 !important;
    font-family: var(--font-serif, Georgia, serif) !important;
    font-size: 16px !important;
    font-weight: 850 !important;
    line-height: 1.18 !important;
    white-space: normal !important;
    text-overflow: clip !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
}
.pj-list-card-hint,
.pj-list-card-meta,
.pj-list-card-meta span {
    display: block !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: 100% !important;
    margin: 0 0 4px !important;
    padding: 0 !important;
    overflow: hidden !important;
    color: #5f4b3e !important;
    font-size: 12px !important;
    font-weight: 750 !important;
    line-height: 1.25 !important;
    white-space: nowrap !important;
    text-overflow: ellipsis !important;
}
.pj-list-card-actions {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
    margin: 0 12px 12px !important;
    padding: 0 !important;
}
.pj-list-card-actions a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 0 !important;
    min-height: 34px !important;
    padding: 7px 8px !important;
    border: 1px solid rgba(129,78,47,.16) !important;
    border-radius: 999px !important;
    background: #fffaf3 !important;
    color: #6b4d35 !important;
    font-size: 11.5px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    text-decoration: none !important;
    white-space: nowrap !important;
}
.pj-list-card-actions .pj-list-open {
    border-color: rgba(47,111,62,.22) !important;
    background: #2f6f3e !important;
    color: #fff !important;
}
.pj-list-card-actions svg {
    display: none !important;
}
.pj-list-remove {
    position: absolute !important;
    top: 10px !important;
    right: 10px !important;
    left: auto !important;
    bottom: auto !important;
    width: 32px !important;
    height: 32px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border: 1px solid rgba(177,61,69,.18) !important;
    border-radius: 999px !important;
    background: #fff8ef !important;
    color: #b13d45 !important;
    box-shadow: 0 5px 14px rgba(95,36,48,.12) !important;
    transform: none !important;
    z-index: 4 !important;
}
@media (max-width: 380px) {
    .pj-list-card-link {
        grid-template-columns: 88px minmax(0, 1fr) !important;
        gap: 10px !important;
        padding-right: 42px !important;
    }
    .pj-list-card-media {
        width: 88px !important;
        height: 88px !important;
        min-width: 88px !important;
        max-width: 88px !important;
    }
    .pj-list-card-title {
        font-size: 15.5px !important;
    }
}

/* Homepage launcher simplification: make / a clear front door, not another feed. */
body.home .pj-home-launcher {
    max-width: 1120px !important;
    margin: 8px auto 12px !important;
    padding: 0 14px 8px !important;
}
body.home .pj-home-launcher-head {
    max-width: 720px !important;
    margin: 0 auto 12px !important;
    text-align: center !important;
}
body.home .pj-home-launcher-head h2 {
    margin: 0 !important;
    color: #432619 !important;
    font-family: "Playfair Display", Georgia, serif !important;
    font-size: clamp(27px, 7.2vw, 42px) !important;
    line-height: 1.04 !important;
    letter-spacing: -.02em !important;
}
body.home .pj-home-launcher-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    max-width: 720px !important;
    margin: 0 auto !important;
}
body.home .pj-home-launcher-card {
    position: relative !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 72px !important;
    grid-template-areas:
        "label art"
        "title art"
        "copy art"
        "cta art" !important;
    align-items: center !important;
    gap: 7px 12px !important;
    min-height: 164px !important;
    padding: 18px 16px 16px 18px !important;
    border: 1px solid rgba(129,78,47,.16) !important;
    border-radius: 28px !important;
    color: #fffaf3 !important;
    text-decoration: none !important;
    overflow: hidden !important;
    isolation: isolate !important;
    box-shadow: 0 18px 34px rgba(67,38,25,.18) !important;
}
body.home .pj-home-launcher-card::before {
    content: '' !important;
    position: absolute !important;
    inset: 0 !important;
    z-index: -2 !important;
    background: linear-gradient(135deg, #b13d45, #df7b37) !important;
}
body.home .pj-home-launcher-card::after {
    content: '' !important;
    position: absolute !important;
    right: -42px !important;
    top: -46px !important;
    width: 150px !important;
    height: 150px !important;
    border-radius: 999px !important;
    background: rgba(255,255,255,.20) !important;
    z-index: -1 !important;
}
body.home .pj-home-launcher-card--events::before { background: linear-gradient(135deg, #b13d45 0%, #e47a36 100%) !important; }
body.home .pj-home-launcher-card--activities::before { background: linear-gradient(135deg, #2f6f3e 0%, #d49b3c 100%) !important; }
body.home .pj-home-launcher-card--experiences::before { background: linear-gradient(135deg, #723a83 0%, #cf5f67 100%) !important; }
body.home .pj-home-launcher-art {
    grid-area: art !important;
    width: 72px !important;
    height: 72px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 24px !important;
    background: rgba(255,255,255,.18) !important;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.24) !important;
}
body.home .pj-home-launcher-art svg {
    width: 48px !important;
    height: 48px !important;
    fill: none !important;
    stroke: currentColor !important;
    stroke-width: 4 !important;
    stroke-linecap: round !important;
    stroke-linejoin: round !important;
}
body.home .pj-home-launcher-art circle {
    fill: currentColor !important;
    stroke: none !important;
}
body.home .pj-home-launcher-label {
    grid-area: label !important;
    display: inline-flex !important;
    align-items: center !important;
    width: fit-content !important;
    min-height: 26px !important;
    padding: 5px 10px !important;
    border-radius: 999px !important;
    background: rgba(255,255,255,.18) !important;
    color: #fffaf3 !important;
    font-size: 11.5px !important;
    font-weight: 950 !important;
    letter-spacing: .055em !important;
    text-transform: uppercase !important;
}
body.home .pj-home-launcher-card strong {
    grid-area: title !important;
    display: block !important;
    color: #fffaf3 !important;
    font-family: "Playfair Display", Georgia, serif !important;
    font-size: clamp(25px, 7vw, 34px) !important;
    line-height: .98 !important;
    text-shadow: 0 2px 14px rgba(47,24,18,.24) !important;
}
body.home .pj-home-launcher-card p {
    grid-area: copy !important;
    max-width: 16em !important;
    margin: 0 !important;
    color: rgba(255,250,243,.92) !important;
    font-size: 14px !important;
    font-weight: 750 !important;
    line-height: 1.26 !important;
}
body.home .pj-home-launcher-card em {
    grid-area: cta !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: fit-content !important;
    min-height: 36px !important;
    margin-top: 4px !important;
    padding: 9px 14px !important;
    border-radius: 999px !important;
    background: rgba(255,255,255,.92) !important;
    color: #8f3038 !important;
    font-size: 13px !important;
    font-style: normal !important;
    font-weight: 950 !important;
    line-height: 1 !important;
    box-shadow: 0 8px 18px rgba(43,25,18,.16) !important;
}
body.home .pj-home-hero--compact {
    margin-bottom: 8px !important;
}
body.home .pj-home-section--today {
    margin-top: 14px !important;
}
@media (min-width: 860px) {
    body.home .pj-home-launcher-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        max-width: 1120px !important;
    }
    body.home .pj-home-launcher-card {
        min-height: 230px !important;
        align-content: start !important;
    }
}

/* Homepage bottom-half polish: compact, visual, and consistent with the launcher. */
body.home .pj-home-today-preview {
    max-width: 1120px !important;
    margin: 18px auto 8px !important;
    padding: 18px 14px 12px !important;
}
body.home .pj-home-section-head--stacked {
    display: flex !important;
    align-items: end !important;
    justify-content: space-between !important;
    gap: 14px !important;
    max-width: 720px !important;
    margin: 0 auto 12px !important;
    padding: 0 !important;
}
body.home .pj-home-section-head--stacked > div {
    min-width: 0 !important;
}
body.home .pj-home-section-head--stacked h2,
body.home .pj-home-shortcuts-head h2 {
    margin: 0 !important;
    color: #432619 !important;
    font-family: "Playfair Display", Georgia, serif !important;
    font-size: clamp(27px, 7vw, 38px) !important;
    line-height: 1.02 !important;
    letter-spacing: -.02em !important;
}
body.home .pj-home-section-head--stacked span:not(.pj-home-head-actions) {
    display: block !important;
    margin-top: 4px !important;
    color: #796150 !important;
    font-size: 13.5px !important;
    font-weight: 750 !important;
    line-height: 1.25 !important;
}
body.home .pj-home-head-actions a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 36px !important;
    padding: 9px 12px !important;
    border-radius: 999px !important;
    background: #fff8ef !important;
    border: 1px solid rgba(129,78,47,.16) !important;
    color: #9a2f36 !important;
    font-size: 12px !important;
    font-weight: 950 !important;
    white-space: nowrap !important;
    text-decoration: none !important;
}
body.home .pj-home-today-preview .pj-featured-grid {
    max-width: 720px !important;
    margin: 0 auto !important;
}
body.home .pj-home-today-preview--empty {
    margin-bottom: 0 !important;
}
body.home .pj-home-shortcuts {
    max-width: 1120px !important;
    margin: 2px auto 14px !important;
    padding: 0 14px !important;
}
body.home .pj-home-shortcuts-head {
    max-width: 720px !important;
    margin: 0 auto 10px !important;
    text-align: left !important;
}
body.home .pj-home-shortcuts-head h2 {
    font-size: clamp(23px, 6vw, 31px) !important;
}
body.home .pj-home-shortcut-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
    max-width: 720px !important;
    margin: 0 auto !important;
}
body.home .pj-home-shortcut-grid a {
    display: grid !important;
    gap: 3px !important;
    min-height: 78px !important;
    padding: 13px 13px 12px !important;
    border: 1px solid rgba(129,78,47,.15) !important;
    border-radius: 20px !important;
    background: #fffaf3 !important;
    color: #432619 !important;
    text-decoration: none !important;
    box-shadow: 0 8px 20px rgba(67,38,25,.08) !important;
}
body.home .pj-home-shortcut-grid a:nth-child(1) { background: linear-gradient(145deg, #fffaf3, #fff0df) !important; }
body.home .pj-home-shortcut-grid a:nth-child(2) { background: linear-gradient(145deg, #fffaf3, #f4f8e9) !important; }
body.home .pj-home-shortcut-grid a:nth-child(3) { background: linear-gradient(145deg, #fffaf3, #edf5fb) !important; }
body.home .pj-home-shortcut-grid a:nth-child(4) { background: linear-gradient(145deg, #fffaf3, #f8edf4) !important; }
body.home .pj-home-shortcut-grid span {
    font-size: 15px !important;
    font-weight: 950 !important;
    line-height: 1.05 !important;
}
body.home .pj-home-shortcut-grid em {
    color: #7b6250 !important;
    font-size: 12px !important;
    font-style: normal !important;
    font-weight: 800 !important;
}
body.home .pj-newsletter-card--home {
    max-width: 720px !important;
    margin: 18px auto 12px !important;
    border: 1px solid rgba(129,78,47,.16) !important;
    border-radius: 28px !important;
    background: linear-gradient(135deg, #432619, #b13d45) !important;
    color: #fffaf3 !important;
    box-shadow: 0 18px 34px rgba(67,38,25,.16) !important;
}
body.home .pj-newsletter-card--home .pj-newsletter-copy h2,
body.home .pj-newsletter-card--home .pj-newsletter-success h2 {
    color: #fffaf3 !important;
    font-size: clamp(27px, 7vw, 38px) !important;
    line-height: 1 !important;
}
body.home .pj-newsletter-card--home .pj-newsletter-copy p,
body.home .pj-newsletter-card--home .pj-newsletter-success p {
    color: rgba(255,250,243,.88) !important;
    font-weight: 750 !important;
}
body.home .pj-newsletter-card--home .pj-newsletter-form button {
    background: #fffaf3 !important;
    color: #9a2f36 !important;
    font-weight: 950 !important;
}
body.home .pj-home-final-actions {
    max-width: 720px !important;
    margin: 12px auto 92px !important;
    padding: 0 14px !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
}
body.home .pj-home-final-actions a {
    min-height: 52px !important;
    border-radius: 18px !important;
    font-size: 13px !important;
    font-weight: 950 !important;
    text-align: center !important;
}
@media (max-width: 390px) {
    body.home .pj-home-section-head--stacked {
        align-items: start !important;
        flex-direction: column !important;
        gap: 8px !important;
    }
    body.home .pj-home-head-actions a {
        min-height: 34px !important;
    }
}

/* Image-led section tops: visual paths first, filters/search second */
.pj-image-top {
    position: relative;
    max-width: 390px;
    margin: 0 auto 12px;
    padding: 0;
}
.pj-image-top-mode {
    position: absolute;
    right: 16px;
    top: 0;
    z-index: 3;
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    background: #2f2924;
    color: #fff;
    padding: 5px 9px;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: .08em;
    line-height: 1;
    text-transform: uppercase;
}
.pj-image-top-hero {
    margin: 0 16px 12px;
}
.pj-image-top-kicker {
    margin: 0 0 8px;
    color: #b85b3d;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .14em;
    line-height: 1;
    text-transform: uppercase;
}
.pj-image-top-hero h1 {
    margin: 0 0 8px;
    color: #302923;
    font-family: var(--font-serif);
    font-size: 32px;
    font-weight: 800;
    line-height: 1;
    letter-spacing: -.055em;
}
.pj-image-top-hero p:not(.pj-image-top-kicker) {
    margin: 0;
    color: #5f5248;
    font-size: 14.5px;
    font-weight: 650;
    line-height: 1.38;
}
.pj-image-top-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin: 0;
    padding: 0 16px 12px;
}
.pj-image-top-tile {
    position: relative;
    overflow: hidden;
    min-height: 118px;
    border: 1px solid rgba(255,255,255,.28);
    border-radius: 24px;
    background: #604531;
    color: #fff;
    box-shadow: 0 12px 26px rgba(83,55,31,.16);
    isolation: isolate;
}
.pj-image-top-tile--big,
.pj-image-top--events .pj-image-top-tile--big {
    grid-column: span 2;
    min-height: 156px;
}
.pj-image-top-tile img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.pj-image-top-tile::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.62));
}
.pj-image-top-tile-copy {
    position: absolute;
    left: 13px;
    right: 13px;
    bottom: 12px;
    z-index: 2;
    text-shadow: 0 1px 8px rgba(0,0,0,.35);
}
.pj-image-top-tile-copy small {
    display: block;
    margin: 0 0 4px;
    color: #ffe1cc;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: .1em;
    line-height: 1;
    text-transform: uppercase;
}
.pj-image-top-tile-copy strong {
    display: block;
    color: #fffaf3;
    font-size: 16px;
    font-weight: 900;
    line-height: 1.05;
    letter-spacing: -.025em;
}
.pj-image-top-tile--big .pj-image-top-tile-copy strong {
    max-width: 92%;
    font-size: 22px;
    letter-spacing: -.035em;
}
.pj-image-top--events .pj-image-top-tile--big .pj-image-top-tile-copy strong {
    max-width: 100%;
    font-size: 20px;
    letter-spacing: -.04em;
}
.pj-image-top-tile-copy em {
    display: block;
    margin-top: 5px;
    color: rgba(255,255,255,.92);
    font-size: 12px;
    font-style: normal;
    font-weight: 700;
    line-height: 1.25;
}
.pj-image-top-chips {
    display: flex;
    gap: 8px;
    margin: 0;
    overflow: hidden;
    padding: 0 16px 10px;
}
.pj-image-top-chip {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #dfcdb8;
    border-radius: 999px;
    background: #fff7ec;
    color: #594b41;
    padding: 9px 12px;
    font-size: 12.5px;
    font-weight: 850;
    line-height: 1;
    white-space: nowrap;
}
.pj-image-top-chip.active {
    background: #b95d3f;
    border-color: #b95d3f;
    color: #fffaf3;
}
.pj-image-top-toolbar {
    margin: 2px 16px 12px;
}
.pj-image-top-toolbar {
    display: flex;
    align-items: flex-start;
    gap: 8px;
}
.pj-image-top-toolbar form.pj-image-top-search-form {
    display: flex;
    align-items: center;
    gap: 8px;
    border: 1px solid #e0cfb8;
    border-radius: 22px;
    background: #fff9f0;
    padding: 10px;
    flex: 1 1 auto;
    min-width: 0;
}
.pj-image-top-toolbar input[type="search"] {
    min-width: 0;
    flex: 1 1 auto;
    min-height: 40px;
    border: 1px solid #decbb4;
    border-radius: 16px;
    background: #fff;
    color: #4d4037;
    padding: 0 12px;
    font: inherit;
    font-size: 13px;
    font-weight: 650;
}
.pj-image-top-toolbar input[type="search"]::placeholder { color: #8b7867; }
.pj-image-top-filter-link {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    border: 0;
    border-radius: 16px;
    background: #2f2924;
    color: #fff !important;
    padding: 0 13px;
    font: inherit;
    font-size: 13px;
    font-weight: 900;
    line-height: 1;
}
.pj-filter-stack--events,
.pj-filter-stack--explore {
    display: none;
    max-width: 390px;
    margin-left: auto;
    margin-right: auto;
}
.pj-filter-stack--events:target,
.pj-filter-stack--explore:target {
    display: block;
}
.ps-events-utility-row--image-top {
    justify-content: flex-start;
    padding-top: 4px !important;
}
@media (max-width: 390px) {
    .pj-image-top,
    .pj-filter-stack--events,
    .pj-filter-stack--explore {
        max-width: 100%;
    }
}

/* Final Activities clean-card overrides: keep save heart as the only separate action. */
.pj-event-card--explore-clean .pj-explore-card-action--save {
    position: absolute !important;
    left: auto !important;
    right: 13px !important;
    top: 13px !important;
    bottom: auto !important;
    z-index: 20 !important;
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    min-height: 40px !important;
    max-width: 40px !important;
    padding: 0 !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}
.pj-event-card--explore-clean .pj-explore-card-action--save em { display: none !important; }
.pj-event-card--explore-clean .pj-explore-card-action--save span { font-size: 20px !important; }
/* PJ 1.5.400: no-scroll compact Events filter dropdown beside search. */
.pj-image-top-toolbar--events-compact .ps-more-filters--compact-dropdown {
    flex: 0 0 auto;
    position: relative;
}
.pj-image-top-toolbar--events-compact .ps-more-filters--compact-dropdown > summary {
    min-height: 62px;
    border: 0;
    border-radius: 18px;
    background: #2f2924;
    color: #fff !important;
    padding: 0 12px;
    font-size: 13px;
    font-weight: 900;
    box-shadow: none;
}
.pj-image-top-toolbar--events-compact .ps-more-filters--compact-dropdown[open] > summary,
.pj-image-top-toolbar--events-compact .ps-more-filters--compact-dropdown.has-active-filters > summary {
    background: #a85d3d;
    color: #fff !important;
}
.pj-image-top-toolbar--events-compact .ps-more-filters-panel--compact {
    left: auto;
    right: 0;
    top: calc(100% + 8px);
    width: min(358px, calc(100vw - 32px));
    padding: 0;
    border-radius: 18px;
    background: #fffdf8;
    border-color: #ead7c6;
    overflow: hidden;
    box-shadow: 0 16px 36px rgba(85, 52, 28, .14);
}
.ps-event-filter-form--compact {
    margin: 0;
}
.ps-filter-panel-head--compact {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 8px 10px 7px;
    border-bottom: 1px solid #f0dfd1;
}
.ps-filter-panel-head--compact .ps-filter-panel-title {
    margin: 0;
    font-family: var(--font-serif, Georgia, serif);
    font-size: 19px;
    line-height: 1;
    color: #2a211b;
}
.ps-filter-active-count {
    border-radius: 999px;
    background: #f4e3d6;
    color: #9b5438;
    padding: 4px 7px;
    font-size: 10px;
    line-height: 1;
    font-weight: 900;
    white-space: nowrap;
}
.ps-filter-section--compact {
    padding: 7px 10px;
    border-bottom: 1px solid #f5e8dc;
}
.ps-filter-section--compact .ps-filter-section-title {
    margin: 0 0 5px;
    color: #8f705e;
    font-size: 9px;
    line-height: 1;
    font-weight: 900;
    letter-spacing: .13em;
    text-transform: uppercase;
}
.ps-filter-choice-grid--compact {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}
.ps-filter-choice--compact {
    min-height: 0;
    padding: 6px 8px;
    border-radius: 999px;
    background: #fff8ef;
    border: 1px solid #e8d2be;
    color: #463a31;
    font-size: 11.5px;
    line-height: 1;
    font-weight: 850;
    gap: 0;
}
.ps-filter-choice--compact .ps-filter-icon {
    display: none;
}
.ps-filter-choice--compact.active,
.ps-filter-choice--compact:has(input:checked) {
    background: #a85d3d;
    border-color: #a85d3d;
    color: #fff;
}
.ps-filter-date-input {
    width: 100%;
    margin-top: 6px;
    min-height: 30px;
    border-radius: 999px;
    border: 1px solid #ead8c8;
    background: #fff8ef;
    color: #4d4037;
    padding: 4px 9px;
    font: inherit;
    font-size: 12px;
    font-weight: 750;
}
.ps-filter-drawer-actions--compact {
    display: flex;
    gap: 8px;
    margin: 0;
    padding: 8px 10px;
    border-top: 0;
    background: #fffaf5;
}
.ps-filter-drawer-actions--compact .ps-filter-clear,
.ps-filter-drawer-actions--compact .ps-filter-apply {
    min-height: 36px;
    padding: 7px 12px;
    font-size: 12.5px;
}
.ps-filter-drawer-actions--compact .ps-filter-clear {
    width: 28%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #e1cdbb;
    border-radius: 999px;
    background: #fff;
}
.ps-filter-drawer-actions--compact .ps-filter-apply {
    flex: 1;
}
@media (max-width: 390px) {
    .pj-image-top-toolbar--events-compact .ps-more-filters-panel--compact {
        width: calc(100vw - 32px);
    }
    .pj-image-top-toolbar--events-compact .ps-more-filters--compact-dropdown > summary {
        padding-left: 10px;
        padding-right: 10px;
    }
}
/* PJ 1.5.400b: compress Events dropdown enough to show all controls without scrolling. */
.pj-image-top-toolbar--events-compact .ps-more-filters-panel--compact {
    border-radius: 16px;
}
.ps-filter-panel-head--compact {
    padding: 6px 9px 5px;
}
.ps-filter-panel-head--compact .ps-filter-panel-title {
    font-size: 17px;
}
.ps-filter-section--compact {
    padding: 5px 9px;
}
.ps-filter-section--compact .ps-filter-section-title {
    margin-bottom: 4px;
    font-size: 8.5px;
}
.ps-filter-choice-grid--compact {
    gap: 4px;
}
.ps-filter-choice--compact {
    padding: 5px 7px;
    font-size: 10.75px;
}
.ps-filter-drawer-actions--compact {
    padding: 6px 9px;
}

/* PJ 1.5.405: approved clean image-led Experiences landing. */
.pj-services-image-hero {
    max-width: 720px;
    margin: 8px auto 20px;
    padding: 0 0 4px;
}
.pj-services-image-hero__copy {
    padding: 6px 2px 14px;
}
.pj-services-image-hero__copy h1 {
    margin: 7px 0 0;
    font-family: var(--font-serif, Georgia, serif);
    font-size: clamp(40px, 9vw, 64px);
    line-height: .92;
    letter-spacing: -.055em;
    color: #241d18;
}
.pj-services-image-hero__copy p:not(.pj-services-kicker) {
    max-width: 520px;
    margin: 10px 0 0;
    color: #6e5a4b;
    font-size: 15.5px;
    line-height: 1.38;
}
.pj-services-image-hero__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}
.pj-services-image-hero__tile {
    position: relative;
    display: block;
    min-height: 118px;
    overflow: hidden;
    border-radius: 24px;
    background: #dbcbb7;
    text-decoration: none;
    box-shadow: 0 12px 24px rgba(73, 47, 26, .10);
}
.pj-services-image-hero__tile--big {
    grid-column: 1 / -1;
    min-height: 168px;
}
.pj-services-image-hero__tile img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.pj-services-image-hero__tile::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,.02) 24%, rgba(0,0,0,.68) 100%);
}
.pj-services-image-hero__tile span {
    position: absolute;
    z-index: 1;
    left: 14px;
    right: 14px;
    bottom: 13px;
    color: #fff;
}
.pj-services-image-hero__tile small {
    display: block;
    font-size: 10px;
    line-height: 1;
    font-weight: 950;
    letter-spacing: .15em;
    text-transform: uppercase;
    opacity: .9;
}
.pj-services-image-hero__tile strong {
    display: block;
    margin-top: 3px;
    font-family: var(--font-serif, Georgia, serif);
    font-size: 19px;
    line-height: 1;
    letter-spacing: -.035em;
}
.pj-services-image-hero__tile--big strong {
    font-size: 24px;
}
.pj-services-image-hero__tile em {
    display: block;
    max-width: 270px;
    margin-top: 5px;
    color: #fff3e8;
    font-size: 12px;
    line-height: 1.25;
    font-style: normal;
}
.pj-services-image-hero .pj-services-clean-search {
    margin-top: 12px;
}

/* PJ 1.5.404: clean Experiences landing — quiet hero, search first, no filter wall above the fold. */
.pj-services-page--simple {
    background:
        radial-gradient(circle at 15% 0%, rgba(221, 151, 103, .22), transparent 32%),
        linear-gradient(180deg, #fff8f1 0, #fffdf8 46%, #fff8ef 100%);
}
.pj-services-clean-hero {
    max-width: 720px;
    margin: 12px auto 22px;
    padding: 30px 18px 18px;
    border: 1px solid rgba(160, 101, 58, .14);
    border-radius: 30px;
    background: linear-gradient(180deg, rgba(255,255,255,.86), rgba(255,248,240,.94));
    box-shadow: 0 18px 48px rgba(91, 51, 25, .08);
    text-align: center;
}
.pj-services-clean-hero__copy h1 {
    margin: 7px auto 0;
    font-family: var(--font-serif, Georgia, serif);
    font-size: clamp(38px, 9vw, 62px);
    line-height: .92;
    letter-spacing: -.055em;
    color: #241d18;
}
.pj-services-clean-hero__copy p:not(.pj-services-kicker) {
    max-width: 520px;
    margin: 12px auto 0;
    color: #6e5a4b;
    font-size: 15.5px;
    line-height: 1.42;
}
.pj-services-clean-search {
    display: flex;
    gap: 8px;
    margin: 20px auto 0;
    max-width: 560px;
}
.pj-services-clean-search input[type="search"] {
    min-width: 0;
    flex: 1 1 auto;
    min-height: 52px;
    border: 1px solid #dfcbb7;
    border-radius: 18px;
    background: #fffdf8;
    color: #44372e;
    padding: 0 14px;
    font: inherit;
    font-size: 13px;
    font-weight: 700;
    box-shadow: 0 8px 18px rgba(82, 55, 34, .055);
}
.pj-services-clean-search button {
    flex: 0 0 auto;
    min-height: 52px;
    border: 0;
    border-radius: 18px;
    background: #2f2924;
    color: #fff;
    padding: 0 16px;
    font: inherit;
    font-size: 13px;
    font-weight: 900;
}
.pj-services-clean-quicklinks {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 7px;
    margin-top: 14px;
}
.pj-services-clean-quicklinks a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    border: 1px solid rgba(166, 96, 57, .16);
    border-radius: 999px;
    background: rgba(255, 255, 255, .68);
    color: #8e5238;
    padding: 0 12px;
    font-size: 12px;
    font-weight: 850;
    text-decoration: none;
}
.pj-services-page--simple .pj-service-listings--popular {
    margin-top: 8px;
}
.pj-services-page--simple .pj-service-listings--popular .pj-services-section-head {
    margin-bottom: 12px;
}
.pj-services-page--simple .pj-service-listings--popular .pj-services-section-head p:not(.pj-services-kicker) {
    display: none;
}
@media (max-width: 430px) {
    .pj-services-clean-hero {
        margin: 8px auto 18px;
        padding: 26px 14px 16px;
        border-radius: 26px;
    }
    .pj-services-clean-search {
        margin-top: 18px;
    }
    .pj-services-clean-search input[type="search"] {
        font-size: 12.5px;
        padding-inline: 12px;
    }
    .pj-services-clean-search button {
        padding-inline: 14px;
    }
}

/* PJ 1.5.403: clean Events search row — one search bubble, not nested bubbles. */
.pj-image-top-toolbar--events-compact {
    align-items: stretch;
    gap: 8px;
}
.pj-image-top-toolbar--events-compact form.pj-image-top-search-form {
    border: 0;
    border-radius: 0;
    background: transparent;
    padding: 0;
    box-shadow: none;
}
.pj-image-top-toolbar--events-compact input[type="search"] {
    min-height: 52px;
    border-radius: 18px;
    border: 1px solid #dfcbb7;
    background: #fffdf8;
    box-shadow: 0 8px 18px rgba(82, 55, 34, .06);
    padding: 0 14px;
}
.pj-image-top-toolbar--events-compact .ps-more-filters--compact-dropdown > summary {
    min-height: 52px;
    border-radius: 18px;
    padding-inline: 13px;
}
.ps-filter-drawer-actions--compact .ps-filter-clear,
.ps-filter-drawer-actions--compact .ps-filter-apply {
    min-height: 32px;
    padding-top: 5px;
    padding-bottom: 5px;
    font-size: 12px;
}
.ps-filter-choice--date {
    position: relative;
    overflow: hidden;
}
.ps-filter-choice--date input[type="date"] {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
}

/* PJ 1.5.408: Saved Option B gallery board — exact mockup implementation. */
body .pj-saved-page{max-width:430px!important;margin:0 auto!important;padding:0 16px 112px!important}
body .pj-saved-board-header{padding:15px 0 10px!important;margin:0!important;text-align:left!important}
body .pj-saved-board-title-row{display:grid!important;grid-template-columns:minmax(0,1fr) auto!important;gap:12px!important;align-items:end!important}
body .pj-saved-board-header .pj-section-kicker{margin:0 0 4px!important;color:#9b3f26!important;font-size:11px!important;font-weight:950!important;letter-spacing:.14em!important;text-transform:uppercase!important}
body .pj-saved-board-header .pj-archive-title{margin:0!important;max-width:260px!important;font-family:var(--font-serif,Georgia,serif)!important;font-size:clamp(34px,9.6vw,39px)!important;line-height:.94!important;letter-spacing:-.04em!important}
body .pj-saved-board-share:not([hidden]){display:inline-flex!important;align-items:center!important;justify-content:center!important;min-height:38px!important;border:0!important;border-radius:999px!important;background:#2d261f!important;color:#fff7ed!important;padding:10px 14px!important;font-size:12px!important;font-weight:900!important;box-shadow:0 10px 22px rgba(41,34,28,.14)!important}
body .pj-saved-page .pj-saved-actions,body .pj-saved-page .pj-saved-helper,body .pj-saved-page .pj-saved-clear-link,body .pj-saved-page .pj-saved-device-note,body .pj-saved-page .pj-archive-subtitle{display:none!important}
body .pj-saved-board-gallery:not([hidden]){display:grid!important;grid-template-columns:1.15fr .85fr!important;grid-auto-rows:125px!important;gap:10px!important;margin:0 0 13px!important}
body .pj-saved-board-gallery[data-count="1"]{grid-template-columns:1fr!important;grid-auto-rows:260px!important}
body .pj-saved-board-gallery[data-count="2"]{grid-template-columns:1fr 1fr!important;grid-auto-rows:190px!important}
body .pj-saved-board-gallery[data-count="2"] .pj-saved-board-tile{grid-row:auto!important}
body .pj-saved-board-tile{position:relative!important;display:block!important;overflow:hidden!important;min-width:0!important;border-radius:25px!important;background:#ead9c3!important;color:#fff!important;text-decoration:none!important;box-shadow:0 18px 42px rgba(68,43,25,.13)!important;isolation:isolate!important}
body .pj-saved-board-tile--big{grid-row:span 2!important}
body .pj-saved-board-tile img{width:100%!important;height:100%!important;display:block!important;object-fit:cover!important}
body .pj-saved-board-tile:after{content:""!important;position:absolute!important;inset:0!important;z-index:1!important;background:linear-gradient(180deg,rgba(0,0,0,.02),rgba(0,0,0,.04) 42%,rgba(0,0,0,.64))!important;pointer-events:none!important}
body .pj-saved-board-tile strong,body .pj-saved-board-tile span{position:absolute!important;left:12px!important;right:10px!important;z-index:2!important;color:#fff!important;text-shadow:0 1px 7px rgba(0,0,0,.35)!important;overflow:hidden!important;text-overflow:ellipsis!important;display:block!important}
body .pj-saved-board-tile strong{bottom:24px!important;font-family:var(--font-serif,Georgia,serif)!important;font-size:22px!important;font-weight:850!important;line-height:1!important;letter-spacing:-.02em!important;white-space:nowrap!important}
body .pj-saved-board-tile--small strong{font-size:18px!important}
body .pj-saved-board-tile span{bottom:9px!important;font-size:11px!important;font-weight:850!important;line-height:1.1!important;white-space:nowrap!important}
body .pj-saved-board-tile.is-placeholder:before{content:"Petaluma Social"!important;position:absolute!important;inset:0!important;display:grid!important;place-items:center!important;color:#9b3f26!important;font-weight:900!important;background:#f7eadc!important}
body .pj-saved-page .pj-saved-filters:not([hidden]){display:flex!important;gap:8px!important;margin:0 0 12px!important;padding:0!important;overflow-x:auto!important;scrollbar-width:none!important}
body .pj-saved-page .pj-saved-filters::-webkit-scrollbar{display:none!important}
body .pj-saved-page .pj-saved-filters button{flex:0 0 auto!important;min-width:0!important;width:auto!important;border:1px solid rgba(41,34,28,.10)!important;border-radius:999px!important;background:#fffdf8!important;color:#5d5249!important;padding:8px 11px!important;font-size:12px!important;font-weight:900!important;white-space:nowrap!important}
body .pj-saved-page .pj-saved-filters button.is-active{background:#f7eadc!important;color:#9b3f26!important;border-color:#e8c2ae!important}
body .pj-saved-board-plan:not([hidden]){display:flex!important;align-items:center!important;justify-content:space-between!important;gap:12px!important;margin:0 0 12px!important;padding:13px!important;border-radius:24px!important;border:1px solid rgba(155,63,38,.12)!important;background:#fffdf8!important;box-shadow:0 12px 28px rgba(75,52,34,.08)!important}
body .pj-saved-board-plan strong{display:block!important;color:#29221c!important;font-size:15px!important;font-weight:900!important;line-height:1.1!important}
body .pj-saved-board-plan [data-pj-saved-plan-summary]{display:block!important;margin-top:2px!important;color:#75695f!important;font-size:12.5px!important;font-weight:750!important;line-height:1.2!important}
body .pj-saved-board-sort{flex:0 0 auto!important;min-height:38px!important;border:0!important;border-radius:999px!important;background:#9b3f26!important;color:#fff!important;padding:9px 13px!important;font-size:12px!important;font-weight:900!important}
body .pj-saved-board-sort.is-active{background:#315a45!important}
body .pj-saved-board-rows .pj-saved-group-title{margin:0 0 9px!important;color:#8b7c6f!important;font-size:11px!important;font-weight:950!important;letter-spacing:.13em!important;text-transform:uppercase!important}
body .pj-saved-board-rows .pj-saved-group-grid{display:grid!important;gap:10px!important}
body .pj-saved-board-rows .pj-list-card{position:relative!important;overflow:hidden!important;border:1px solid rgba(41,34,28,.10)!important;border-radius:22px!important;background:#fffdf8!important;box-shadow:0 8px 20px rgba(65,44,28,.07)!important}
body .pj-saved-board-rows .pj-list-card-link{display:grid!important;grid-template-columns:86px minmax(0,1fr)!important;gap:10px!important;align-items:center!important;min-height:92px!important;padding:8px 46px 8px 8px!important;color:inherit!important;text-decoration:none!important}
body .pj-saved-board-rows .pj-list-card-media{width:86px!important;min-width:86px!important;max-width:86px!important;height:76px!important;border-radius:17px!important;overflow:hidden!important;background:#f7eadc!important}
body .pj-saved-board-rows .pj-list-card-media img{width:100%!important;height:100%!important;display:block!important;object-fit:cover!important}
body .pj-saved-board-rows .pj-list-card-body{min-width:0!important;padding:0!important;overflow:hidden!important}
body .pj-saved-board-rows .pj-list-card-topline{margin:0 0 4px!important}
body .pj-saved-board-rows .pj-list-kind{display:inline-flex!important;border-radius:999px!important;background:transparent!important;color:#9b3f26!important;padding:0!important;font-size:10px!important;font-weight:950!important;letter-spacing:.09em!important;text-transform:uppercase!important}
body .pj-saved-board-rows .pj-list-plan-label{display:none!important}
body .pj-saved-board-rows .pj-list-card-title{margin:0 0 4px!important;color:#29221c!important;font-family:var(--font-serif,Georgia,serif)!important;font-size:19px!important;font-weight:850!important;line-height:1.02!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}
body .pj-saved-board-rows .pj-list-card-hint{display:block!important;margin:0!important;color:#72665c!important;font-size:12px!important;font-weight:750!important;line-height:1.2!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}
body .pj-saved-board-rows .pj-list-card-meta,body .pj-saved-board-rows .pj-list-card-actions,body .pj-saved-board-rows .pj-list-image-badge{display:none!important}
body .pj-saved-board-rows .pj-list-remove{position:absolute!important;top:27px!important;right:10px!important;width:34px!important;height:34px!important;min-width:34px!important;min-height:34px!important;border-radius:999px!important;background:#fffaf1!important;color:#9b3f26!important;border:1px solid #edcfc6!important;padding:0!important;box-shadow:none!important}
@media(max-width:370px){body .pj-saved-page{padding-left:12px!important;padding-right:12px!important}body .pj-saved-board-gallery:not([hidden]){grid-template-columns:1fr .82fr!important;gap:8px!important}body .pj-saved-board-tile strong{font-size:19px!important}body .pj-saved-board-tile--small strong{font-size:16px!important}}

/* PJ 1.5.410: tighten Saved Image 525 row match. */
body .pj-saved-board-rows .pj-saved-group-title,
body .pj-saved-board-rows .pj-list-card-topline {
    display: none !important;
}
body .pj-saved-board-rows .pj-saved-group-grid {
    gap: 9px !important;
}
body .pj-saved-board-rows .pj-list-card {
    border-radius: 21px !important;
}
body .pj-saved-board-rows .pj-list-card-link {
    grid-template-columns: 66px minmax(0, 1fr) !important;
    gap: 12px !important;
    min-height: 82px !important;
    padding: 8px 48px 8px 8px !important;
}
body .pj-saved-board-rows .pj-list-card-media {
    width: 66px !important;
    min-width: 66px !important;
    max-width: 66px !important;
    height: 66px !important;
    border-radius: 15px !important;
}
body .pj-saved-board-rows .pj-list-card-title {
    margin: 0 0 5px !important;
    font-size: 19px !important;
    line-height: 1.05 !important;
}
body .pj-saved-board-rows .pj-list-card-hint {
    color: #70645b !important;
    font-size: 12.5px !important;
    font-weight: 800 !important;
}
body .pj-saved-board-rows .pj-list-remove {
    top: 24px !important;
    right: 11px !important;
    width: 32px !important;
    height: 32px !important;
    min-width: 32px !important;
    min-height: 32px !important;
    background: #fff8ef !important;
    color: #9b3f26 !important;
}

/* PJ 1.5.411: match Image 525 title break exactly. */
body .pj-saved-board-header .pj-archive-title {
    max-width: 218px !important;
    font-size: clamp(35px, 9.8vw, 38px) !important;
    line-height: .94 !important;
}
body .pj-saved-board-title-row {
    align-items: center !important;
}

/* PJ 1.5.412: compact saved-page header/nav to follow the provided target crop. */
body:has(.pj-saved-page) .pj-site-header {
    padding-top: 5px !important;
    padding-bottom: 7px !important;
}
body:has(.pj-saved-page) .pj-site-bar {
    min-height: 38px !important;
}
body:has(.pj-saved-page) .pj-site-title {
    font-size: 24px !important;
}
body:has(.pj-saved-page) .pj-site-subtitle {
    margin-top: 2px !important;
    font-size: 8px !important;
}
body:has(.pj-saved-page) .pj-top-nav {
    height: 36px !important;
    margin-top: 6px !important;
    padding: 4px !important;
}
body:has(.pj-saved-page) .pj-top-nav a {
    height: 28px !important;
    min-height: 28px !important;
    font-size: 12.5px !important;
}
body .pj-saved-board-header {
    margin-top: -18px !important;
    padding-top: 8px !important;
    padding-bottom: 8px !important;
}

/* PJ 1.5.414: make Saved "Plan your day" a compact strip, not a large card. */
body .pj-saved-board-plan:not([hidden]) {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    width: 100% !important;
    min-height: 58px !important;
    height: auto !important;
    margin: 0 0 10px !important;
    padding: 10px 12px !important;
    border-radius: 18px !important;
    border: 1px solid rgba(155,63,38,.12) !important;
    background: #fffdf8 !important;
    box-shadow: 0 7px 18px rgba(75,52,34,.055) !important;
}
body .pj-saved-board-plan::before,
body .pj-saved-board-plan .pj-saved-plan-mark,
body .pj-saved-board-plan .pj-saved-plan-label,
body .pj-saved-board-plan .pj-saved-plan-next,
body .pj-saved-board-plan .pj-saved-plan-time,
body .pj-saved-board-plan .pj-saved-plan-note {
    display: none !important;
}
body .pj-saved-board-plan strong {
    margin: 0 !important;
    font-size: 15px !important;
    line-height: 1.05 !important;
}
body .pj-saved-board-plan [data-pj-saved-plan-summary] {
    margin-top: 2px !important;
    font-size: 12px !important;
    line-height: 1.15 !important;
}
body .pj-saved-board-sort {
    flex: 0 0 auto !important;
    min-height: 34px !important;
    border: 0 !important;
    background: #9b3f26 !important;
    color: #fff !important;
    padding: 8px 12px !important;
    border-radius: 999px !important;
    font-size: 12px !important;
    font-weight: 900 !important;
}

/* PJ 1.5.416: restore the top-level browse bubble on mobile Events. */
@media (max-width: 760px) {
    body:has(.pj-archive-theme-scope.pj-archive-theme--events) .pj-sticky-header {
        display: block !important;
        position: sticky !important;
        top: 0 !important;
        z-index: 100 !important;
        background: #fbf7ef !important;
        padding: 0 !important;
    }
    body:has(.pj-archive-theme-scope.pj-archive-theme--events) .pj-site-header {
        display: block !important;
        padding: 8px 16px 10px !important;
        background: #fbf7ef !important;
        border: 0 !important;
        box-shadow: none !important;
    }
    body:has(.pj-archive-theme-scope.pj-archive-theme--events) .pj-site-bar {
        display: none !important;
    }
    body:has(.pj-archive-theme-scope.pj-archive-theme--events) .pj-top-nav.pj-top-nav--browse {
        display: grid !important;
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        width: min(358px, calc(100vw - 32px)) !important;
        max-width: 358px !important;
        height: 42px !important;
        min-height: 42px !important;
        margin: 0 auto !important;
        padding: 5px !important;
        border: 0 !important;
        border-radius: 999px !important;
        background: #eee3d5 !important;
        box-shadow: inset 0 1px 2px rgba(63,43,25,.035) !important;
        overflow: visible !important;
    }
    body:has(.pj-archive-theme-scope.pj-archive-theme--events) .pj-top-nav.pj-top-nav--browse > a {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        min-width: 0 !important;
        height: 32px !important;
        min-height: 32px !important;
        padding: 0 8px !important;
        border: 0 !important;
        border-radius: 999px !important;
        background: transparent !important;
        color: #81796f !important;
        font-size: 12.8px !important;
        font-weight: 900 !important;
        line-height: 1 !important;
        text-decoration: none !important;
        white-space: nowrap !important;
        box-shadow: none !important;
    }
/* PJ 1.5.419: Match Events nav exactly to Activities/Services nav styling */
/* PJ 1.5.419: Match Events nav exactly to Activities/Services nav styling */
@media (max-width: 760px) {
    body:has(.pj-archive-theme-scope.pj-archive-theme--events) .pj-top-nav.pj-top-nav--browse {
        display: grid !important;
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        width: min(358px, calc(100vw - 32px)) !important;
        max-width: 358px !important;
        height: 42px !important;
        min-height: 42px !important;
        margin: 0 auto !important;
        padding: 5px !important;
        border: 0 !important;
        border-radius: 999px !important;
        background: #eee3d5 !important;
        box-shadow: inset 0 1px 2px rgba(63,43,25,.035) !important;
        overflow: visible !important;
    }
    body:has(.pj-archive-theme-scope.pj-archive-theme--events) .pj-top-nav.pj-top-nav--browse > a {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        min-width: 0 !important;
        height: 32px !important;
        min-height: 32px !important;
        padding: 0 8px !important;
        border: 0 !important;
        border-radius: 999px !important;
        background: transparent !important;
        color: #81796f !important;
        font-size: 12.8px !important;
        font-weight: 900 !important;
        line-height: 1 !important;
        text-decoration: none !important;
        white-space: nowrap !important;
        box-shadow: none !important;
    }
    body:has(.pj-archive-theme-scope.pj-archive-theme--events) .pj-top-nav.pj-top-nav--browse > a.active {
        background: #fffdf8 !important;
        color: #181411 !important;
        box-shadow: 0 4px 12px rgba(58,39,22,.10) !important;
    }
    body:has(.pj-archive-theme-scope.pj-archive-theme--events) .pj-top-nav.pj-top-nav--browse > a:hover {
        background: #fffdf8 !important;
        color: #181411 !important;
    }
    body:has(.pj-archive-theme-scope.pj-archive-theme--events) .pj-top-nav.pj-top-nav--browse > a span {
        overflow: visible !important;
        text-overflow: unset !important;
        max-width: none !important;
        letter-spacing: -.02em !important;
    }
}/* PJ 1.5.420: Complete fix for Events page navigation to match reference */
/* PJ 1.5.420: Complete fix for Events page navigation to match reference */
@media (max-width: 760px) {
    body:has(.pj-archive-theme-scope.pj-archive-theme--events) .pj-top-nav.pj-top-nav--browse {
        display: flex !important;
        flex-direction: row !important;
        justify-content: center !important;
        align-items: center !important;
        width: 100% !important;
        max-width: 358px !important;
        height: 42px !important;
        min-height: 42px !important;
        margin: 0 auto !important;
        padding: 5px !important;
        border: 0 !important;
        border-radius: 999px !important;
        background: #eee3d5 !important;
        box-shadow: inset 0 1px 2px rgba(63,43,25,.035) !important;
        overflow: visible !important;
        position: relative !important;
        z-index: 1 !important;
    }
    
    body:has(.pj-archive-theme-scope.pj-archive-theme--events) .pj-top-nav.pj-top-nav--browse > a {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        min-width: 0 !important;
        height: 32px !important;
        min-height: 32px !important;
        padding: 0 10px !important;
        border: 0 !important;
        border-radius: 999px !important;
        background: transparent !important;
        color: #81796f !important;
        font-size: 12.8px !important;
        font-weight: 900 !important;
        line-height: 1 !important;
        text-decoration: none !important;
        white-space: nowrap !important;
        box-shadow: none !important;
        transition: all 0.2s ease !important;
        flex: 1 !important;
        margin: 0 2px !important;
        text-align: center !important;
    }
    
    body:has(.pj-archive-theme-scope.pj-archive-theme--events) .pj-top-nav.pj-top-nav--browse > a.active {
        background: #fffdf8 !important;
        color: #181411 !important;
        box-shadow: 0 4px 12px rgba(58,39,22,.10) !important;
        z-index: 2 !important;
        position: relative !important;
    }
    
    body:has(.pj-archive-theme-scope.pj-archive-theme--events) .pj-top-nav.pj-top-nav--browse > a:hover {
        background: #fffdf8 !important;
        color: #181411 !important;
        z-index: 2 !important;
        position: relative !important;
    }
    
    body:has(.pj-archive-theme-scope.pj-archive-theme--events) .pj-top-nav.pj-top-nav--browse > a span {
        overflow: visible !important;
        text-overflow: unset !important;
        max-width: none !important;
        letter-spacing: -.02em !important;
        display: block !important;
        width: 100% !important;
        text-align: center !important;
    }
}/* PJ 1.5.421: Clean, isolated Events nav fix */
/* PJ 1.5.421: Clean, isolated Events nav fix */
@media (max-width: 760px) {
    /* Force the Events page navigation to match reference exactly */
    body:has(.pj-archive-theme-scope.pj-archive-theme--events) .pj-top-nav.pj-top-nav--browse {
        display: flex !important;
        flex-direction: row !important;
        justify-content: center !important;
        align-items: center !important;
        width: 100% !important;
        max-width: 358px !important;
        height: 42px !important;
        min-height: 42px !important;
        margin: 0 auto !important;
        padding: 5px !important;
        border: 0 !important;
        border-radius: 999px !important;
        background: #eee3d5 !important;
        box-shadow: inset 0 1px 2px rgba(63,43,25,.035) !important;
        overflow: visible !important;
        position: relative !important;
        z-index: 1 !important;
    }
    
    body:has(.pj-archive-theme-scope.pj-archive-theme--events) .pj-top-nav.pj-top-nav--browse > a {
        flex: 1 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        min-width: 0 !important;
        height: 32px !important;
        min-height: 32px !important;
        padding: 0 10px !important;
        border: 0 !important;
        border-radius: 999px !important;
        background: transparent !important;
        color: #81796f !important;
        font-size: 12.8px !important;
        font-weight: 900 !important;
        line-height: 1 !important;
        text-decoration: none !important;
        white-space: nowrap !important;
        box-shadow: none !important;
        transition: all 0.2s ease !important;
        margin: 0 2px !important;
        text-align: center !important;
    }
    
    body:has(.pj-archive-theme-scope.pj-archive-theme--events) .pj-top-nav.pj-top-nav--browse > a.active {
        background: #fffdf8 !important;
        color: #181411 !important;
        box-shadow: 0 4px 12px rgba(58,39,22,.10) !important;
        z-index: 2 !important;
        position: relative !important;
        margin: 0 2px !important;
    }
    
    body:has(.pj-archive-theme-scope.pj-archive-theme--events) .pj-top-nav.pj-top-nav--browse > a:hover {
        background: #fffdf8 !important;
        color: #181411 !important;
        z-index: 2 !important;
        position: relative !important;
    }
    
    body:has(.pj-archive-theme-scope.pj-archive-theme--events) .pj-top-nav.pj-top-nav--browse > a span {
        overflow: visible !important;
        text-overflow: unset !important;
        max-width: none !important;
        letter-spacing: -.02em !important;
        display: block !important;
        width: 100% !important;
        text-align: center !important;
    }
}