:root {
    --color-bg-0: #fdf8f5;
    --color-bg-1: #f9f4ee;
    --color-bg-2: #ffffff;
    --color-bg-3: #f3efea;
    --color-text: #2a2522;
    --color-muted: #6f665f;
    --color-line: #dfd7cf;
    --color-accent: #8d77b4;
    --shadow-soft: 0 18px 42px rgba(42, 37, 34, 0.08);
    --container-wide: 1080px;
    --surface-card: rgba(255, 255, 255, 0.55);
    --radius-lg: 1rem;
}

body {
    background-color: var(--color-bg-0);
    color: var(--color-text);
    margin: 0;
}

.opacity-10 { opacity: 0.1; }
.opacity-20 { opacity: 0.2; }
.opacity-30 { opacity: 0.3; }
.opacity-40 { opacity: 0.4; }
.opacity-60 { opacity: 0.6; }
.opacity-70 { opacity: 0.7; }
.opacity-80 { opacity: 0.8; }
.opacity-90 { opacity: 0.9; }

.text-accent {
    color: var(--color-accent);
}

.site-nav-wrap {
    border-bottom: 1px solid var(--color-line);
    padding: 0.9rem 1.6rem;
}

.site-nav {
    max-width: var(--container-wide);
    margin: 0 auto;
}

.landing {
    min-height: 100vh;
    max-width: var(--container-wide);
    margin: 0 auto;
    padding: 1.3rem 1.6rem 1.2rem;
    /* background: radial-gradient(circle at 72% 38%, #f3efea 0%, var(--color-bg-0) 52%); */
}

.topbar {
    align-items: center;
    display: flex;
    justify-content: space-between;
    gap: 1rem;
}

.topbar-main {
    align-items: center;
    display: inline-flex;
    gap: 1.1rem;
}

.topbar-nav-links {
    align-items: center;
    display: inline-flex;
    gap: 1.6rem;
}

.brand {
    align-items: center;
    color: inherit;
    display: inline-flex;
    gap: 0.8rem;
    text-decoration: none;
}

.brand-logo {
    display: block;
    height: 2.9rem;
    width: auto;
}

.brand-mark {
    align-items: center;
    border: 2px solid var(--color-text);
    border-radius: 0.75rem;
    display: inline-flex;
    font-size: 1.2rem;
    height: 2.3rem;
    justify-content: center;
    width: 2.3rem;
}

.brand-copy {
    display: grid;
    font-size: 1.32rem;
    font-weight: 900;
    letter-spacing: 0.03em;
    line-height: 0.9;
}

.topbar-tools {
    align-items: center;
    display: inline-flex;
    gap: 0.8rem;
}

.topbar-mobile-menu {
    display: none;
}

.topbar-actions {
    justify-content: flex-end;
}

.topbar-link,
.about-back-link,
.footer-col a {
    color: var(--color-muted);
    text-decoration: none;
    margin:0 0.75em;
}

.topbar-link {
    color: var(--color-accent);
    font-size: 1.1rem;
    font-weight: 700;
}

.topbar-link-shows {
    position: relative;
    display: inline-flex;
    align-items: center;
    padding-right: 1.2rem;
}

.topbar-link-badge {
    align-items: center;
    background: #7d3cff;
    border: 2px solid #fdf8f5;
    border-radius: 999px;
    box-shadow: 0 4px 10px rgba(125, 60, 255, 0.28);
    color: #fff;
    display: inline-flex;
    font-size: 0.7rem;
    font-weight: 800;
    height: 1.35rem;
    justify-content: center;
    line-height: 1;
    min-width: 1.35rem;
    padding: 0 0.28rem;
    position: absolute;
    right: -0.3rem;
    top: -0.45rem;
}

.topbar-link:hover,
.about-back-link:hover,
.footer-col a:hover {
    color: var(--color-text);
}

.auth-user {
    color: var(--color-muted);
    font-size: 0.95rem;
    font-weight: 600;
}
.auth-user a {
    text-decoration: none;
    font-weight: bold;
    color: var(--color-accent);
}

.task-badge {
    font-size: 0.95rem;
    font-weight: 700;
}

.task-badge[data-bs-toggle="tooltip"] {
    cursor: help;
}

.task-badge i {
    color: #f19b38;
    margin-right: 0.2rem;
}

.topbar-auth {
    align-items: center;
    display: inline-flex;
    gap: 0.8rem;
}

.logout-form {
    margin: 0;
    padding: 0;
}

.logout-form button {
    color: var(--color-accent);
    /* background: transparent;
    border: 2px solid #d4c6ec;
    border-radius: 0.65rem;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    font-weight: 700;
    gap: 0.45rem;
    justify-content: center;
    padding: 0.65rem 1.15rem;
    text-decoration: none; */
}

.logout-form button:hover,
.logout-form button:focus {
    background: rgba(141, 119, 180, 0.08);
    border:none;
} 

.auth-navbar {
    display: flex;
    gap: 1.5rem;
    padding: 0;
}

.auth-nav-wrap {
    padding-top: 0.5rem;
    padding-bottom: 0.7rem;
    background-color: var(--color-bg-3);
}

.auth-navbar-left {
    align-items: center;
    display: flex;
    flex: 1;
    gap: 0.8rem;
}

.auth-navbar-right {
    align-items: center;
    display: flex;
    gap: 0.6rem;
    justify-content: flex-end;
}

.auth-active-event-panel {
    align-items: center;
    /* background: var(--color-bg-1); */
    /* border: 1px solid var(--color-line); */
    /* border-radius: 0.4rem; */
    color: var(--color-muted);
    display: flex;
    font-size: 0.8rem;
    /* gap: 0.6rem; */
    justify-content: space-between;
    margin: 0.4rem auto 0;
    max-width: var(--container-wide);
    /* padding: 0.3rem 0.6rem; */
}

.auth-active-event-panel div {
    align-items: center;
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.auth-active-event-panel strong {
    color: #4f9d63;
    font-weight: 600;
}

.auth-active-event-panel span {
    color: var(--color-muted);
    font-size: 0.78rem;
}

.auth-active-event-panel .btn {
    font-size: 0.78rem;
    padding: 0.15rem 0.5rem;
}

.ghost-btn {
    align-items: center;
    background: transparent;
    border: 2px solid #d4c6ec;
    border-radius: 0.65rem;
    color: var(--color-accent);
    display: inline-flex;
    font-weight: 700;
    gap: 0.2rem;
    justify-content: center;
    padding: 0.5rem 1.15rem;
    text-decoration: none;
}

.topbar-menu-btn {
    aspect-ratio: 1;
    padding: 0;
    width: 2.6rem;
}

.hero-grid {
    align-items: center;
    display: grid;
    gap: 1.2rem;
    grid-template-columns: 1.1fr 0.9fr;
    margin-top: 2rem;
}

.home-carousel {
    position: relative;
}

.carousel-inner {
    border-radius: var(--radius-lg);
    position: relative;
    display: block;
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

.carousel-control-prev,
.carousel-control-next {
    background: rgba(141, 119, 180, 0.15);
    border: none;
    border-radius: 99rem;
    color: var(--color-accent);
    height: 2.8rem;
    opacity: 0.7;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 2.8rem;
    z-index: 5;
}

.carousel-control-prev {
    left: 0.5rem;
}

.carousel-control-next {
    right: 0.5rem;
}

.carousel-control-prev:hover,
.carousel-control-next:hover {
    opacity: 1;
    background: rgba(141, 119, 180, 0.25);
}

.carousel-control-prev-icon,
.carousel-control-next-icon {
    background-image: none;
    display: inline-block;
    font-size: 1.5rem;
}

.carousel-control-prev-icon::before {
    content: "‹";
}

.carousel-control-next-icon::before {
    content: "›";
}

.carousel-indicators {
    position: relative;
    bottom: auto;
    margin-top: 1rem;
    padding: 0;
    justify-content: center;
    display: flex;
    gap: 0.5rem;
}

.carousel-indicators button {
    background-color: var(--color-line);
    border: none;
    border-radius: 99rem;
    cursor: pointer;
    height: 0.6rem;
    margin: 0 0.4rem;
    opacity: 0.5;
    padding: 0;
    transition: all 0.3s ease;
    width: 0.6rem;
}

.carousel-indicators button.active {
    background-color: var(--color-accent);
    opacity: 1;
    width: 1.8rem;
}

.carousel-slide {
    animation: slideIn 0.6s ease-out;
    display: block;
    width: 100%;
}

@keyframes slideIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.visual-orb.is-alt {
    background: linear-gradient(135deg, #f3efea 0%, #e8dfd8 100%);
    color: var(--color-accent);
    font-size: 3rem;
}

.visual-orb.is-alt-2 {
    background: linear-gradient(135deg, #f9f4ee 0%, #f3efea 100%);
    color: #d4a574;
    font-size: 3rem;
}

.hero-copy h1 {
    font-family: "Archivo Black", "Arial Black", sans-serif;
    font-size: clamp(2rem, 4.8vw, 3.55rem);
    line-height: 1.05;
    margin: 0;
}

.hero-copy > p {
    color: #3a3632;
    font-size: clamp(1.06rem, 1.8vw, 1.95rem);
    font-weight: 500;
    line-height: 1.28;
    margin: 1.1rem 0 1.5rem;
}

.feature-grid {
    display: grid;
    gap: 0.8rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.feature {
    align-items: flex-start;
    display: flex;
    gap: 0.6rem;
}

.feature-icon {
    align-items: center;
    border: 1px solid var(--color-line);
    border-radius: 50%;
    color: #7f7670;
    display: inline-flex;
    flex: 0 0 1.9rem;
    height: 1.9rem;
    justify-content: center;
    line-height: 1;
    width: 1.9rem;
}

.feature h2 {
    font-size: 1.02rem;
    margin: 0;
}

.feature p {
    color: var(--color-muted);
    font-size: 0.95rem;
    margin: 0.22rem 0 0;
}

.hero-visual {
    display: flex;
    justify-content: center;
}

.hero-group-visual {
    align-items: center;
    display: flex;
    justify-content: center;
}

.hero-group-orb {
    align-items: center;
    display: flex;
    justify-content: center;
    overflow: visible;
    padding: clamp(1.1rem, 2.5vw, 2.1rem);
    width: min(29rem, 100%);
}

.hero-group-orb .home-stat-groups {
    margin: 0;
    max-width: min(28rem, 112%);
}

.hero-group-orb .home-stat-group {
    box-shadow: 0 0.55rem 1.35rem rgba(39, 34, 29, 0.08);
}

.hero-group-orb .home-stat-group-avatar {
    flex: 0 0 auto;
}

.visual-orb {
    align-items: center;
    aspect-ratio: 1;
    background: #f3efea;
    border-radius: 999px;
    display: inline-flex;
    font-size: clamp(5rem, 16vw, 10rem);
    justify-content: center;
    overflow: hidden;
    width: min(30rem, 100%);
}

.visual-orb-photo {
    display: block;
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.auth-panel {
    border-top: 1px solid var(--color-line);
    margin-top: 1.8rem;
    padding-top: 1.1rem;
}

.home-shows-preview {
    display: grid;
    gap: 1rem;
    grid-template-columns: 1.15fr 0.85fr;
    margin-top: 1.4rem;
}

.home-video-spot {
    display: grid;
    gap: 0.85rem;
    grid-template-columns: 1fr 1fr;
    margin-top: 1rem;
    position: relative;
    border-radius: var(--radius-lg);
    overflow: visible;
}

.home-about-teaser {
    margin-top: 1rem;
}

.ui-card,
.home-about-card,
.home-nearest-show,
.home-other-shows,
.profile-card,
.about-card,
.contact-card,
.shows-card,
.supers-card,
.supers-table-wrap {
    background: var(--surface-card);
    border: 1px solid var(--color-line);
    border-radius: var(--radius-lg);
}

.home-about-card {
    padding: 1rem 1.05rem;
}

.home-about-lead {
    font-size: 1.22rem;
    line-height: 1.38;
    margin: 0;
}

.home-about-lead i {
    color: var(--color-accent);
    margin-right: 0.3rem;
}

.home-about-card p {
    color: var(--color-muted);
    margin: 0.72rem 0 0;
}

.home-video-player {
    width: 100%;
    aspect-ratio: 16 / 9;
    background: #000;
    display: block;
    object-fit: cover;
    border-radius: 0.5em;;
}
.home-video-player.aspect43 {
    aspect-ratio: 4 / 3;
}

.home-video-actions {
    margin-top: 1rem;
    display: flex;
    justify-content: flex-start;
}

.home-video-gif-badge {
    position: absolute;
    bottom: 1rem;
    left: 1rem;
    width: clamp(4rem, 10vw, 7rem);
    border-radius: 0.75rem;
    box-shadow: 0 0.4rem 1.2rem rgba(0, 0, 0, 0.32);
    z-index: 2;
}

.home-nearest-show,
.home-other-shows {
    padding: 1rem 1.05rem;
}

.home-other-shows-flat {
    background: transparent;
    border: 0;
}

.home-nearest-show {
    align-items: center;
    background: linear-gradient(135deg, #faf8ff 0%, #f4eff9 100%);
    border-color: #d4c6ec;
    box-shadow: 0 2px 16px rgba(141, 119, 180, 0.13);
    display: grid;
    gap: 1rem;
    grid-template-columns: 1fr minmax(8rem, 11rem);
}

.home-nearest-copy {
    min-width: 0;
}

.home-nearest-image {
    aspect-ratio: 1 / 1;
    border: 1px solid var(--color-line);
    border-radius: 0.8rem;
    display: block;
    height: auto;
    object-fit: cover;
    object-position: center;
    width: 100%;
}

.home-shows-eyebrow {
    color: var(--color-accent);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    margin: 0 0 0.45rem;
    text-transform: uppercase;
}

.home-nearest-show h2 {
    font-size: 1.35rem;
    margin: 0;
}

.home-nearest-show p {
    color: var(--color-muted);
    margin: 0.55rem 0 0.85rem;
}

.home-nearest-status {
    align-items: center;
    color: #5c4f7a;
    display: inline-flex;
    font-size: 0.88rem;
    font-weight: 800;
    gap: 0.45rem;
    margin: 0 0 0.6rem;
}

.home-nearest-status.is-active {
    color: #b42328;
}

.home-nearest-status-active {
    align-items: center;
    background: rgba(180, 35, 40, 0.1);
    border: 1px solid rgba(180, 35, 40, 0.3);
    border-radius: 999px;
    display: inline-flex;
    font-size: 0.78rem;
    gap: 0.35rem;
    padding: 0.15rem 0.55rem;
}

.home-nearest-status-active i {
    animation: homeActivePulse 1.2s ease-in-out infinite;
    color: #d4222b;
    font-size: 0.52rem;
}

@keyframes homeActivePulse {
    0% {
        opacity: 0.4;
        transform: scale(0.88);
    }
    50% {
        opacity: 1;
        transform: scale(1.18);
    }
    100% {
        opacity: 0.4;
        transform: scale(0.88);
    }
}

.home-nearest-show p i {
    margin-right: 0.2rem;
}

.home-nearest-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.home-nearest-actions .home-nearest-action-btn,
.home-nearest-actions .shows-action-btn {
    flex: 0 0 auto;
    font-size: 0.92rem;
    min-height: 2.05rem;
    justify-content: center;
    padding: 0.34rem 0.52rem;
    white-space: nowrap;
}

.home-nearest-actions .home-nearest-action-btn i,
.home-nearest-actions .shows-action-btn i {
    margin-right: 0.15rem;
}

.home-nearest-actions .home-nearest-poll-btn i {
    margin-right: 0;
}

.home-nearest-timing-badge {
    align-items: center;
    background: #f4f0fb;
    border: 1px solid #d8ccef;
    border-radius: 0.8rem;
    color: #7a55cf;
    display: inline-flex;
    font-size: 0.95rem;
    font-weight: 800;
    gap: 0.48rem;
    line-height: 1;
    min-height: 2.05rem;
    padding: 0.34rem 0.7rem;
}

.home-nearest-timing-badge i {
    font-size: 0.9rem;
}

.home-nearest-timing-badge.is-hours {
    background: #f2eefc;
    border-color: #d6cbf0;
    color: #6f4fc8;
}

.home-nearest-timing-badge.is-soon {
    background: linear-gradient(135deg, #8b67db 0%, #7b55d6 100%);
    border-color: #7f59d4;
    color: #fff;
}

.home-nearest-timing-badge.is-live {
    background: #fff3f3;
    border-color: #f2cdcd;
    color: #cd6363;
}

.home-nearest-timing-badge.is-live i {
    animation: homeActivePulse 2s ease-in-out infinite;
}

.home-nearest-action-btn.is-fb {
    border-color: #b7d1f8;
    color: #1877f2;
}

.home-nearest-action-btn.is-fb:hover,
.home-nearest-action-btn.is-calendar:hover {
    background: rgba(24, 119, 242, 0.08);
}

.nearest-show-toast {
    background: linear-gradient(135deg, #faf8ff 0%, #f4eff9 100%);
    border: 1px solid #d4c6ec;
    outline: 0.3em solid #ffffff88;
    border-radius: 0.95rem;
    box-shadow: 0 10px 24px rgba(88, 63, 141, 0.18);
    max-width: min(26rem, calc(100vw - 1.5rem));
    width: 100%;
}

.nearest-show-toast .toast-header {
    background: transparent;
    border-bottom: 1px solid rgba(122, 85, 207, 0.14);
    color: #5a4688;
    font-size: 0.9rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.nearest-show-toast .toast-body {
    padding: 0.7rem;
}

.nearest-show-toast-body {
    align-items: stretch;
    display: grid;
    gap: 0.65rem;
    grid-template-columns: auto 5rem 1fr;
}

.nearest-show-toast-groups {
    align-items: center;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin: 0;
}

.nearest-show-toast-date-column {
    display: flex;
    align-items: center;
    justify-content: center;
}

.nearest-show-toast-date {
    text-align: center;
    margin: 0;
}

.nearest-show-toast-date-day {
    font-size: 1.75rem;
    font-weight: 900;
    line-height: 1;
    color: #5a4688;
    margin: 0;
}

.nearest-show-toast-date-month {
    font-size: 0.85rem;
    font-weight: 800;
    letter-spacing: 0.05em;
    color: #7a5bcf;
    margin: 0.15rem 0 0;
    text-transform: uppercase;
}

.nearest-show-toast-date-time {
    font-size: 0.8rem;
    color: #9988bb;
    margin: 0.08rem 0 0;
}

.nearest-show-toast-info {
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-width: 0;
}

.nearest-show-toast-poster-link {
    display: block;
}

.nearest-show-toast-poster {
    border: 1px solid var(--color-line);
    border-radius: 0.55rem;
    display: block;
    height: 4.2rem;
    object-fit: cover;
    width: 4.2rem;
}

.nearest-show-toast-copy {
    min-width: 0;
}

.nearest-show-toast-kicker {
    display: none;
}

.nearest-show-toast-title {
    color: var(--color-text);
    font-size: 1.02rem;
    font-weight: 800;
    line-height: 1.15;
    margin: 0;
}

.nearest-show-toast-meta {
    color: var(--color-muted);
    font-size: 0.86rem;
    margin: 0.2rem 0 0;
}

.nearest-show-toast-action-row {
    align-items: center;
    display: flex;
    gap: 0.5rem;
    justify-content: flex-start;
    margin: 0.42rem 0 0;
}

.nearest-show-toast-meta i {
    margin-right: 0.24rem;
}

.nearest-show-toast-cta {
    margin-top: 0;
    white-space: nowrap;
}

.nearest-show-toast-fb-btn {
    background: #1877f2;
    border: 1px solid #1877f2;
    color: #fff;
}

.nearest-show-toast-fb-btn:hover,
.nearest-show-toast-fb-btn:focus {
    background: #0f66d0;
    border-color: #0f66d0;
    color: #fff;
}

.nearest-show-toast-fb-btn i {
    margin-right: 0.28rem;
}

.nearest-show-toast-poll-btn {
    background: #5a91c8;
    border: 1px solid #5a91c8;
    color: #fff;
}

.nearest-show-toast-poll-btn:hover,
.nearest-show-toast-poll-btn:focus {
    background: #477dad;
    border-color: #477dad;
    color: #fff;
}

.nearest-show-toast-poll-btn i {
    margin-right: 0.28rem;
}

/* ── Show Timeline ─────────────────────────────────────────── */
.show-timeline {
    align-items: flex-start;
    display: flex;
    gap: 0;
    grid-column: 1 / -1;
    justify-content: space-between;
    margin-top: 0.5rem;
    overflow-x: auto;
    padding: 0.5rem 0 0.25rem;
    position: relative;
    scrollbar-width: none;
}

.show-timeline::-webkit-scrollbar {
    display: none;
}

.show-timeline-track {
    align-items: flex-start;
    display: flex;
    gap: 0;
    justify-content: stretch;
    min-width: 100%;
    position: relative;
}

/* connector line between stages */
.show-timeline-track::before {
    background: #d4c6ec;
    content: '';
    height: 2px;
    left: 0;
    margin-top: calc(1.35rem - 1px);
    position: absolute;
    right: 0;
    top: 0;
    z-index: 0;
}

.show-timeline-stage {
    align-items: center;
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: 0.28rem;
    min-width: 4.5rem;
    padding: 0 0.1rem;
    position: relative;
    z-index: 1;
}

/* completed connector segment */
.show-timeline-stage.is-done::before {
    background: #8b67db;
    content: '';
    height: 2px;
    left: -50%;
    position: absolute;
    right: 50%;
    top: calc(1.35rem - 1px);
    z-index: 0;
}

.show-timeline-stage:first-child::before {
    display: none;
}

.show-timeline-icon {
    align-items: center;
    background: #eee8f9;
    border: 2px solid #d4c6ec;
    border-radius: 50%;
    color: #b8a8d8;
    display: flex;
    font-size: 0.9rem;
    height: 2.7rem;
    justify-content: center;
    position: relative;
    transition: background 200ms, border-color 200ms, color 200ms;
    width: 2.7rem;
}

.show-timeline-stage.is-done .show-timeline-icon {
    background: #8b67db;
    border-color: #7a55cf;
    color: #fff;
}

.show-timeline-stage.is-live .show-timeline-icon {
    background: #6c3fd6;
    border-color: #5a2fc4;
    box-shadow: 0 0 0 4px rgba(108, 63, 214, 0.18);
    color: #fff;
}

.show-timeline-check {
    align-items: center;
    background: #fff;
    border-radius: 50%;
    bottom: -4px;
    color: #8b67db;
    display: flex;
    font-size: 0.55rem;
    height: 0.95rem;
    justify-content: center;
    position: absolute;
    right: -4px;
    width: 0.95rem;
}

.show-timeline-live-badge {
    background: #6c3fd6;
    border-radius: 0.6rem;
    bottom: -0.85rem;
    color: #fff;
    font-size: 0.6rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    padding: 0.05rem 0.35rem;
    position: absolute;
    white-space: nowrap;
}

.show-timeline-name {
    color: #6b5a8e;
    font-size: 0.7rem;
    font-weight: 700;
    margin-top: 0.55rem;
    text-align: center;
    white-space: nowrap;
}

.show-timeline-stage.is-live .show-timeline-name {
    color: #6c3fd6;
    font-size: 0.75rem;
}

.show-timeline-time {
    color: #a898c0;
    font-size: 0.62rem;
    text-align: center;
    white-space: nowrap;
}

.show-timeline-stage.is-live .show-timeline-time {
    color: #6c3fd6;
    font-weight: 700;
}

@media (max-width: 480px) {
    .show-timeline-name,
    .show-timeline-time {
        font-size: 0.6rem;
    }

    .show-timeline-icon {
        font-size: 0.78rem;
        height: 2.2rem;
        width: 2.2rem;
    }

    .show-timeline-stage {
        min-width: 3.8rem;
    }
}

.home-shows-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.home-shows-list li + li {
    margin-top: 0.45rem;
}

.home-shows-item {
    border-radius: 0.75rem;
    margin-left: -0.35rem;
    padding: 0.12rem 0.35rem;
    transition: background-color 240ms ease, box-shadow 240ms ease, transform 240ms ease;
}

.home-shows-item.is-highlighted {
    background: rgba(141, 119, 180, 0.08);
    box-shadow: 0 0 0 1px rgba(141, 119, 180, 0.12);
    transform: translateX(0.12rem);
}

.home-shows-list a,
.home-all-shows-link {
    color: var(--color-text);
    text-decoration: none;
}

.home-shows-item-icon {
    color: #968c84;
}

.home-shows-item-time {
    color: var(--color-muted);
}

@media (prefers-reduced-motion: reduce) {
    .home-shows-item {
        transition: none;
    }
}

.home-all-shows-link {
    color: var(--color-accent);
    display: inline-block;
    font-weight: 700;
    margin-top: 0.8rem;
}

.support-panel {
    align-self: stretch;
    background:
        url("/public/img/mix/heart.png") right 0.85rem top 0.75rem / 10rem auto no-repeat,
        linear-gradient(135deg, #fffdfb 0%, #f8f2ff 100%);
    /* box-shadow: 0 2px 16px rgba(141, 119, 180, 0.11); */
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
    justify-content: space-between;
    padding: 1rem 1.05rem;
}

.support-head {
    align-items: center;
    display: flex;
    gap: 0.75rem;
}

.support-icon {
    align-items: center;
    aspect-ratio: 1;
    border: 2px solid #d4c6ec;
    border-radius: 999px;
    color: var(--color-accent);
    display: inline-flex;
    flex: 0 0 auto;
    font-size: 1.45rem;
    justify-content: center;
    width: 3.1rem;
}

.support-qr-image {
    border-radius: 0.3em;;
}

.support-title {
    font-size: clamp(1.7rem, 4.4vw, 2.0rem);
    font-weight: 900;
    line-height: 1.05;
    margin: 0;
}

.support-text {
    color: var(--color-muted);
    font-size: 1.05rem;
    line-height: 1.45;
    margin: 0;
}

.support-actions {
    align-items: center;
    border-top: 1px dashed #d8ccef;
    display: grid;
    gap: 0.9rem;
    grid-template-columns: 1fr auto;
    padding-top: 0.9rem;
}

.support-donate-btn {
    align-items: center;
    background: linear-gradient(135deg, #8b67db 0%, #7b55d6 100%);
    border: 0;
    border-radius: 0.75rem;
    color: #fff;
    cursor: default;
    display: inline-flex;
    font-size: 1.35rem;
    font-weight: 800;
    gap: 0.65rem;
    justify-content: center;
    min-height: 3.2rem;
    padding: 0.7rem 0.9rem;
    text-decoration: none;
    cursor: pointer;
}
.support-donate-btn:hover {
    background: linear-gradient(135deg, #7b55d6 0%, #8b67db 100%);
    & .fa-heart {
        opacity: 1;
        /* font-size: 1.2em;; */
        transform: scale(1.4);
    }
    
}

.support-donate {
    display: grid;
    gap: 0.4rem;
}

.support-donate-btn:hover,
.support-donate-btn:focus {
    color: #fff;
}

.support-donate-btn:disabled {
    opacity: 1;
}

.support-help-text {
    color: var(--color-muted);
    font-size: 0.9rem;
    margin: 0;
    text-align: center;
}

.support-qr {
    color: var(--color-accent);
    display: grid;
    font-weight: 800;
    gap: 0.35rem;
    justify-items: center;
    text-align: center;
}

.support-qr-placeholder {
    align-items: center;
    aspect-ratio: 1;
    background: #fff;
    border: 2px solid #d4c6ec;
    border-radius: 0.75rem;
    color: var(--color-text);
    display: inline-flex;
    font-size: 5.4rem;
    justify-content: center;
    width: 10rem;
}

.support-book {
    align-items: center;
    /* background: rgba(255, 255, 255, 0.62); */
    /* border: 1px solid #e2d7f1; */
    /* border-radius: 0.8rem; */
    display: flex;
    gap: 0.8rem;
    padding: 0.4rem 0.5rem;
}

.support-book i {
    color: var(--color-accent);
    font-size: 1.55rem;
}

.support-book p {
    color: var(--color-muted);
    margin: 0;
}

.support-book a {
    color: inherit;
    text-decoration: none;
    text-decoration: underline;
}

.support-book a:hover,
.support-book a:focus {
    color: inherit;
    text-decoration: underline;
}

.support-book strong {
    font-size: 0.9em;
    color: var(--color-text);
}

.home-sponsor-strip {
    align-items: center;
    display: grid;
    gap: 0.9rem;
    grid-template-columns: 1fr auto;
    margin-top: 1rem;
    padding: 1rem 1.05rem;
}

.home-sponsor-title {
    font-size: 1.2rem;
    margin: 0;
}

.home-sponsor-text {
    color: var(--color-muted);
    margin: 0.45rem 0 0;
}

.home-sponsor-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    justify-content: flex-end;
}

.home-sponsor-actions .ghost-btn,
.home-sponsor-actions .shows-action-btn {
    min-height: 2.3rem;
}

.auth-panel > p {
    color: #433f3b;
    font-size: 0.95rem;
    font-weight: 600;
    margin: 0 0 0.95rem;
    text-align: center;
}

.auth-grid {
    display: grid;
    gap: 0.72rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.auth-btn {
    align-items: center;
    background: var(--color-bg-2);
    border: 1px solid #d5ccc3;
    border-radius: 0.72rem;
    color: var(--color-text);
    display: inline-flex;
    font-size: 1.02rem;
    font-weight: 700;
    justify-content: center;
    min-height: 3.1rem;
    text-decoration: none;
}

.auth-btn.is-disabled {
    cursor: not-allowed;
    opacity: 0.55;
}

.auth-btn i {
    margin-right: 0.5rem;
}

.auth-btn .fa-google {
    color: #ea4335;
}

.auth-btn .fa-facebook {
    color: #1e69d6;
}

.site-footer {
    border-top: 1px solid var(--color-line);
    /* margin-top: 3rem; */
    padding: 2.5rem 1.6rem 2rem;
}

.footer-inner {
    display: grid;
    gap: 2rem;
    grid-template-columns: 0.6fr 1fr 1fr 1fr;
    max-width: var(--container-wide);
    margin: 0 auto;
    align-items: start;
}

.footer-col {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    min-width: 0; /* allow the grid track to shrink instead of forcing the column off-screen */
    overflow-wrap: anywhere;
}

.footer-col-title {
    color: var(--color-text);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    margin: 0 0 0.4rem;
    text-transform: uppercase;
}

.footer-col a {
    font-size: 0.9rem;
}

.footer-social-link {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    flex-wrap: wrap;
}

.footer-social-link.is-instagram {
    color: #e1306c;
}

.footer-social-link.is-facebook {
    color: #1877f2;
}

.footer-social-link.is-instagram:hover,
.footer-social-link.is-facebook:hover {
    opacity: 0.85;
}

.footer-brand {
    align-items: flex-end;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    opacity: 0.35;
}

.footer-logo {
    height: 6rem;
    width: auto;
    display: block;
}

.footer-copy {
    color: var(--color-muted);
    font-size: 0.8rem;
}

.profile-page,
.about-page,
.shows-page {
    margin: 0 auto;
    padding: 2rem 1.6rem 3rem;
}

.profile-page {
    max-width: 860px;
}

.profile-shell {
    display: grid;
    gap: 1.5rem;
}

.profile-head {
    align-items: flex-start;
    display: flex;
    justify-content: space-between;
    gap: 1rem;
}

.profile-eyebrow,
.about-eyebrow,
.shows-eyebrow {
    color: var(--color-accent);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    margin: 0 0 0.35rem;
    text-transform: uppercase;
}

.profile-head h1 {
    margin: 0;
    font-size: clamp(2rem, 4vw, 3rem);
}

.profile-subtitle {
    color: var(--color-muted);
    margin: 0.45rem 0 0;
}

.profile-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.profile-card {
    padding: 1rem 1.1rem;
}

.profile-reasons h2 {
    font-size: 1.05rem;
    margin: 0 0 0.7rem;
}

.profile-reasons ul {
    margin: 0;
    padding-left: 1.15rem;
}

.profile-reasons li {
    color: var(--color-muted);
    margin: 0.45rem 0;
}

.profile-row {
    align-items: center;
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.9rem 0;
}

.profile-row + .profile-row {
    border-top: 1px solid var(--color-line);
}

.profile-label {
    color: var(--color-muted);
    font-size: 0.92rem;
}

.profile-code {
    background: var(--color-bg-1);
    border-radius: 0.5rem;
    padding: 0.35rem 0.55rem;
}

.profile-points strong {
    color: var(--color-accent);
}

.profile-emoji-row {
    align-items: center;
}

.profile-emoji-form {
    display: inline-flex;
    margin: 0;
}

.profile-emoji-button {
    align-items: center;
    background: var(--color-bg-1);
    border: 1px solid var(--color-line);
    border-radius: 999px;
    cursor: pointer;
    display: inline-flex;
    font-size: 0.95rem;
    gap: 0.45rem;
    justify-content: center;
    line-height: 1;
    padding: 0.4rem 0.9rem;
}

.profile-emoji-glyph {
    font-size: 1.25rem;
    line-height: 1;
}

.profile-emoji-button:hover,
.profile-emoji-button:focus-visible {
    border-color: var(--color-accent);
    outline: none;
}

.profile-emoji-help {
    color: var(--color-muted);
    font-size: 0.9rem;
    margin: -0.15rem 0 0.35rem;
    max-width: 42rem;
}

.profile-notify-row {
    align-items: center;
}

.profile-notify-form {
    display: inline-flex;
    margin: 0;
}

.profile-notify-button {
    align-items: center;
    background: var(--color-bg-1);
    border: 1px solid var(--color-line);
    border-radius: 999px;
    color: inherit;
    cursor: pointer;
    display: inline-flex;
    font-size: 0.95rem;
    gap: 0.5rem;
    justify-content: center;
    line-height: 1;
    padding: 0.45rem 1rem;
}

.profile-notify-button.is-on {
    background: var(--color-accent);
    border-color: var(--color-accent);
    color: #fff;
}

.profile-notify-button:hover,
.profile-notify-button:focus-visible {
    border-color: var(--color-accent);
    outline: none;
}

.profile-notify-help,
.subscribe-notify-help {
    font-size: 0.9rem;
    margin: 0.6rem 0 0;
    padding: 0.6rem 0.9rem;
}

.subscribe-notify-section {
    margin-top: 1.75rem;
}

.subscribe-notify-section .subscribe-notify-help {
    max-width: 36rem;
}

.profile-note {
    color: var(--color-muted);
    font-size: 0.88rem;
    margin: 0.4rem 0 0;
}

.profile-note.is-success {
    color: var(--color-accent);
}

.about-page {
    max-width: 940px;
}

.about-shell {
    display: grid;
    gap: 1rem;
}

.about-head {
    align-items: flex-start;
    display: flex;
    justify-content: space-between;
    gap: 0.85rem;
}

.about-intro {
    max-width: 44rem;
}

.about-head h1,
.about-head h4 {
    font-size: clamp(1.75rem, 3.2vw, 2.7rem);
    font-weight: 700;
    line-height: 1.13;
    margin: 0;
}

.about-subtitle {
    color: var(--color-muted);
    font-size: 1.28rem;
    margin: 0.5rem 0 0;
    max-width: 38rem;
}

.about-actions {
    align-items: flex-end;
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.about-back-link {
    color: var(--color-accent);
    font-size: 0.96rem;
    font-weight: 700;
}

.about-back-link i {
    margin-right: 0.35rem;
}

.about-back-link:hover {
    text-decoration: underline;
    text-underline-offset: 0.15rem;
}

.about-contact-btn {
    font-size: 0.98rem;
    padding: 0.55rem 0.95rem;
}

.wishlist-page {
    margin: 0 auto;
    max-width: 1040px;
    padding: 3rem 1.6rem 4rem;
}

.wishlist-shell {
    display: grid;
    gap: 2.5rem;
}

.wishlist-head {
    max-width: 50rem;
}

.wishlist-eyebrow {
    color: var(--color-accent);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    margin: 0 0 0.45rem;
    text-transform: uppercase;
}

.wishlist-head h1 {
    font-size: clamp(3rem, 7vw, 5.4rem);
    font-weight: 800;
    letter-spacing: -0.04em;
    line-height: 0.98;
    margin: 0;
}

.wishlist-head > p:last-child {
    color: var(--color-muted);
    font-size: clamp(1.1rem, 2.2vw, 1.35rem);
    line-height: 1.65;
    margin: 1rem 0 0;
}

.wishlist-list {
    border-top: 1px solid var(--color-line);
}

.wishlist-item {
    align-items: center;
    border-bottom: 1px solid var(--color-line);
    display: grid;
    gap: clamp(2rem, 6vw, 5rem);
    grid-template-columns: minmax(220px, 0.8fr) minmax(0, 1.7fr);
    min-height: 22rem;
    padding: 2.5rem 0;
}

.wishlist-item:nth-child(even) {
    grid-template-columns: minmax(0, 1.7fr) minmax(220px, 0.8fr);
}

.wishlist-item:nth-child(even) .wishlist-visual {
    grid-column: 2;
    grid-row: 1;
}

.wishlist-item:nth-child(even) .wishlist-copy {
    grid-column: 1;
    grid-row: 1;
}

.wishlist-visual {
    align-items: center;
    display: flex;
    justify-content: center;
}

.wishlist-visual img {
    display: block;
    height: auto;
    /* max-height: 17rem; */
    max-width: 100%;
    object-fit: contain;
}

.wishlist-complete-mark {
    align-items: center;
    border: 0.45rem solid #35805a;
    border-radius: 50%;
    color: #35805a;
    display: flex;
    font-size: clamp(4.5rem, 9vw, 6.5rem);
    height: clamp(10rem, 20vw, 14rem);
    justify-content: center;
    width: clamp(10rem, 20vw, 14rem);
}

.wishlist-copy h2 {
    font-size: clamp(1.8rem, 3.5vw, 2.65rem);
    font-weight: 750;
    line-height: 1.15;
    margin: 0 0 1rem;
}

.wishlist-copy > p:last-child {
    color: var(--color-muted);
    font-size: 1.1rem;
    line-height: 1.75;
    margin: 0;
}

.wishlist-status {
    color: var(--color-accent);
    font-size: 0.85rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    margin: 0 0 0.65rem;
    text-transform: uppercase;
}

.wishlist-status i {
    margin-right: 0.35rem;
}

.wishlist-item.is-complete {
    opacity: 0.6;
    color:gray;
    /* background: linear-gradient(90deg, transparent, rgba(125, 60, 255, 0.06), transparent); */
}
.wishlist-item.is-complete:hover {
    opacity: 1;
}

.wishlist-item.is-complete .wishlist-status {
    color: #35805a;
}

.about-card,
.contact-card {
    padding: 1.1rem 1.2rem;
}

.about-story {
    max-width: 54rem;
}

.about-card p {
    font-size: 1.1rem;
    line-height: 1.6;
    margin: 0;
}

.about-card .about-lead {
    font-weight: 600;
}

.about-card p + p {
    margin-top: 0.95rem;
}

.about-gallery {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin: 0 auto;
    max-width: 1000px;
    width: 100%;
}

.about-photo-slot {
    margin: 0;
    position: relative;
}

.about-photo {
    aspect-ratio: 4 / 5;
    border: 1px solid var(--color-line);
    border-radius: 1rem;
    display: block;
    height: auto;
    max-width: 1000px;
    object-fit: cover;
    width: 100%;
    transition: opacity 0.6s ease;
}

.about-photo.is-fading {
    opacity: 0;
}

@media (prefers-reduced-motion: reduce) {
    .about-photo {
        transition: none;
    }
}

.photo-credit {
    position: absolute;
    bottom: 3.9rem;
    left: 0.5rem;
    font-size: 0.75rem;
    color: white;
    opacity: 0.3;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5);
    pointer-events: none;
    padding: 0.2em 0.8em;;
    border-radius: 0.9em;
}
.about-photo-slot:hover .photo-credit {
    opacity: 0.75;
    background-color: #00000055;
}

.about-photo-slot figcaption {
    color: var(--color-muted);
    font-size: 0.92rem;
    margin-top: 0.6rem;
    text-align: center;
}

.contact-card h2 {
    font-size: 1.35rem;
    margin: 0;
}

.contact-card p {
    color: var(--color-muted);
    margin: 0.55rem 0 0.85rem;
}

.about-press-list {
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
    list-style: none;
    margin: 0.55rem 0 0;
    padding: 0;
}

.about-press-list a {
    font-size: 0.95rem;
}

.contact-mail {
    align-items: center;
    color: var(--color-accent);
    display: inline-flex;
    font-size: 1.05rem;
    font-weight: 700;
    gap: 0.45rem;
    text-decoration: none;
}

.contact-socials {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 0.7rem;
    margin-top: 0.9rem;
}

.contact-socials a {
    color: var(--color-accent);
    font-weight: 700;
    text-decoration: none;
}

.about-link[href^="https://instagram.com"],
.about-link[href^="https://www.instagram.com"] {
    color: #e1306c;
}

.about-link[href^="https://facebook.com"],
.about-link[href^="https://www.facebook.com"] {
    color: #1877f2;
}

.about-link[href^="https://instagram.com"]:hover,
.about-link[href^="https://www.instagram.com"]:hover,
.about-link[href^="https://facebook.com"]:hover,
.about-link[href^="https://www.facebook.com"]:hover {
    filter: brightness(0.9);
}

.contact-socials a i {
    margin-right: 0.3rem;
}

.shows-page {
    max-width: 980px;
}

.faq-page {
    margin: 0 auto;
    max-width: 1120px;
    padding: 2rem 1.6rem 3rem;
}

.faq-shell {
    display: grid;
    gap: 1.2rem;
}

.faq-eyebrow {
    color: var(--color-accent);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    margin: 0 0 0.35rem;
    text-transform: uppercase;
}

.faq-head h1 {
    font-size: clamp(1.9rem, 3.4vw, 2.85rem);
    margin: 0;
}

.faq-subtitle {
    color: var(--color-muted);
    margin: 0.45rem 0 0;
    max-width: 50rem;
}

.faq-card {
    border: none;
    padding: 0;
    margin:0 ;
}

.faq-topic-list {
    position: sticky;
    top: 5.5rem;
}

.faq-topic-list .list-group-item {
    border-color: var(--color-line);
    font-weight: 600;
}

.faq-topic-list .list-group-item.active {
    background: var(--color-accent);
    border-color: var(--color-accent);
    color: #fff;
}

.faq-scroll {
    border: 1px solid var(--color-line);
    border-radius: 0.85rem;
    height: 68vh;
    max-height: 720px;
    overflow: auto;
    padding: 0.8rem 1rem;
}

.faq-topic-block {
    padding: 0.45rem 0.1rem 0.85rem;
    scroll-margin-top: 5.5rem;
}

.faq-topic-block + .faq-topic-block {
    border-top: 1px dashed color-mix(in srgb, var(--color-line) 82%, #ddd);
    margin-top: 0.35rem;
    padding-top: 1rem;
}

.faq-topic-block h2 {
    font-size: 1.35rem;
    margin: 0 0 0.75rem;
}

.faq-item {
    background: color-mix(in srgb, var(--color-bg-1) 72%, white);
    border: 1px solid var(--color-line);
    border-radius: 0.8rem;
    margin-bottom: 0.65rem;
    padding: 0.75rem 0.85rem;
}

.faq-item h3 {
    font-size: 1.03rem;
    margin: 0 0 0.38rem;
}

.faq-item p {
    color: var(--color-muted);
    margin: 0;
}

.faq-item a {
    color: var(--color-accent);
    font-weight: 600;
}

.privacy-page {
    margin: 0 auto;
    max-width: 960px;
    padding: 2rem 1.6rem 3rem;
}

.privacy-shell {
    display: grid;
    gap: 1.2rem;
}

.privacy-eyebrow {
    color: var(--color-accent);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    margin: 0 0 0.35rem;
    text-transform: uppercase;
}

.privacy-head h1 {
    font-size: clamp(1.9rem, 3.4vw, 2.85rem);
    margin: 0;
}

.privacy-subtitle {
    color: var(--color-muted);
    margin: 0.45rem 0 0;
    max-width: 48rem;
}

.privacy-content {
    border: 1px solid var(--color-line);
    border-radius: 0.85rem;
    padding: 1rem;
}

.privacy-section {
    padding: 0.35rem 0.1rem 0.9rem;
}

.privacy-section + .privacy-section {
    border-top: 1px dashed color-mix(in srgb, var(--color-line) 82%, #ddd);
    margin-top: 0.35rem;
    padding-top: 1rem;
}

.privacy-section h2 {
    font-size: 1.22rem;
    margin: 0 0 0.55rem;
}

.privacy-section p {
    color: var(--color-muted);
    margin: 0;
}

.privacy-section p + p {
    margin-top: 0.55rem;
}

.privacy-section a {
    color: var(--color-accent);
    font-weight: 600;
}

.shows-shell {
    display: grid;
    gap: 1rem;
}

.shows-head h1 {
    font-size: clamp(1.9rem, 3.4vw, 2.85rem);
    margin: 0;
}

.shows-subtitle {
    color: var(--color-muted);
    margin: 0.45rem 0 0;
    max-width: 48rem;
}

.calendar-strip-wrap {
    overflow: visible;
}

.calendar-strip {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    overflow: visible;
    padding: 0.2rem 0 0.35rem;
}

.calendar-strip-item {
    background: rgba(255, 255, 255, 0.4);
    border: 1px solid #cccccc55;
    border-radius: 0.5rem;
    flex: 0 0 min(5.5rem, calc(50vw - 1.6rem));
    overflow: visible;
    position: relative;
    text-align: center;
}

.calendar-strip-item:hover {
    background-color: var(--color-bg-2);
}

.calendar-strip-summary {
    cursor: pointer;
    display: grid;
    gap: 0.2rem;
    list-style: none;
    padding: 0.45rem 0.55rem;
}

.calendar-strip-summary::-webkit-details-marker {
    display: none;
}

.calendar-strip-subtle-icon {
    color: #b6accc;
    font-size: 0.72rem;
    line-height: 1;
    opacity: 0.65;
}

.calendar-strip-date,
.calendar-strip-time,
.calendar-strip-weekday {
    display: block;
}

.calendar-strip-date {
    color: var(--color-accent);
    font-size: 0.96rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.calendar-strip-time {
    font-size: 0.9rem;
    display: none;
}

.calendar-strip-weekday {
    color: var(--color-muted);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.calendar-strip-caret {
    color: #aba1c0;
    font-size: 0.66rem;
    line-height: 1;
    transition: transform 180ms ease;
}

.calendar-strip-item[open] .calendar-strip-caret {
    transform: rotate(180deg);
}

.calendar-strip-panel {
    border-top: 1px solid var(--color-line);
    display: grid;
    gap: 0.7rem;
    left: -1px;
    min-width: 14rem;
    position: absolute;
    padding: 0.9rem 1rem 1rem;
    top: calc(100% + 0.45rem);
    width: max-content;
    z-index: 20;
    background: rgba(255, 255, 255, 0.98);
    border: 1px solid var(--color-line);
    border-radius: 1rem;
    box-shadow: 0 1rem 2rem rgba(42, 37, 34, 0.14);
}

.calendar-strip-title {
    font-size: 0.98rem;
    font-weight: 700;
    margin: 0;
}

.calendar-strip-meta {
    color: var(--color-muted);
    font-size: 0.92rem;
    margin: 0;
}

.calendar-strip-meta i {
    margin-right: 0.3rem;
}

.calendar-strip-meta span[title],
.shows-meta span[title],
.home-nearest-show p span[title] {
    border-bottom: 1px dotted color-mix(in srgb, var(--color-muted) 45%, transparent);
    cursor: help;
}

.calendar-strip-actions {
    display: grid;
    gap: 0.55rem;
}

.calendar-strip-actions .shows-action-btn {
    min-height: 2.7rem;
}

.shows-timeline-wrap {
    overflow: hidden;
}

.shows-timeline {
    display: flex;
    gap: 0.55rem;
    overflow-x: auto;
    padding: 0.15rem 0 0.35rem;
    scrollbar-width: thin;
}

.shows-timeline-item {
    background: rgba(255, 255, 255, 0.75);
    border: 1px solid var(--color-line);
    border-radius: 99rem;
    color: var(--color-muted);
    flex: 0 0 auto;
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    padding: 0.35rem 0.7rem;
    text-decoration: none;
}

.shows-timeline-item.is-active {
    border-color: #d4c6ec;
    color: var(--color-accent);
}

.shows-list-title {
    font-size: 1.05rem;
    letter-spacing: 0.08em;
    margin: 0.1rem 0 0;
    text-transform: uppercase;
}

.shows-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.shows-card {
    display: grid;
    gap: 0.65rem;
    padding: 1.1rem 1.2rem;
}

.shows-single-decor {
    align-items: center;
    display: flex;
    justify-content: center;
}

.shows-single-decor img {
    height: auto;
    max-width: min(80%, 22rem);
    width: 100%;
}

.shows-card.is-nearest {
    border-color: #d4c6ec;
    box-shadow: 0 0.3em 2em #00000055;
    position: relative;
    outline: 0.5em solid #ffffff99;
    transform: translateY(-0.2rem) rotate(-2deg) scale(1.02);
}

.shows-card.is-nearest::before {
    content: "Tuvākā izrāde";
    background: #efe6fb;
    border: 1px solid #d4c6ec;
    border-radius: 99rem;
    color: var(--color-accent);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    padding: 0.22rem 0.55rem;
    position: absolute;
    right: 0.9rem;
    top: 0.8rem;
    text-transform: uppercase;
}

.shows-card-image-placeholder {
    align-items: center;
    aspect-ratio: 16 / 10;
    background: rgba(255, 255, 255, 0.65);
    border: 1px dashed #cdbfb1;
    border-radius: 0.8rem;
    color: #897e74;
    display: flex;
    flex-direction: column;
    gap: 0.42rem;
    justify-content: center;
}

.shows-card-image {
    aspect-ratio: 1/1;
    border: 1px solid var(--color-line);
    border-radius: 0.8rem;
    display: block;
    height: auto;
    object-fit: cover;
    object-position: center;
    width: 100%;
}

.shows-card-image-link {
    display: block;
}

.shows-card-image-placeholder i {
    font-size: 1.35rem;
}

.shows-card-image-placeholder span {
    font-size: 0.88rem;
    font-weight: 700;
}

.shows-date-time {
    align-items: center;
    display: flex;
    gap: 0.7rem;
    justify-content: space-between;
}

.shows-card-date {
    color: var(--color-accent);
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.shows-card h2 {
    font-size: 1.28rem;
    margin: 0;
}

.shows-meta {
    color: var(--color-muted);
    margin: 0;
}

.shows-meta-inline {
    align-items: center;
    display: flex;
    gap: 0.45rem;
}

.shows-group-avatars-inline {
    display: inline-flex;
}

.shows-meta-separator {
    color: #b8ada3;
    line-height: 1;
}

.shows-time {
    white-space: nowrap;
}

.shows-meta i {
    margin-right: 0.35rem;
}

.shows-card p {
    margin: 0;
}

.shows-card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    margin-top: 0.35rem;
}

.shows-placeholder-note {
    color: #7a6d63;
    font-size: 0.9rem;
    margin-top: 0.35rem;
}

.shows-fb-link-subtle {
    color: #1877f2;
    font-size: 0.78rem;
    line-height: 1.25;
    max-width: 100%;
    opacity: 0.86;
    text-decoration: none;
    word-break: break-all;
}

.shows-fb-link-subtle:hover {
    opacity: 1;
    text-decoration: underline;
}

.shows-action-btn {
    align-items: center;
    border: 1px solid #d4c6ec;
    border-radius: 0.65rem;
    color: var(--color-accent);
    display: inline-flex;
    flex: 1 1 0;
    font-weight: 700;
    justify-content: center;
    min-height: 2.45rem;
    padding: 0.5rem 0.7rem;
    text-decoration: none;
    white-space: nowrap;
}

.shows-action-btn i {
    margin-right: 0.35rem;
}

.shows-action-icon-btn {
    flex: 0 0 2.45rem;
    padding-left: 0.6rem;
    padding-right: 0.6rem;
}

.shows-action-icon-btn i {
    margin-right: 0;
}

.shows-poll-action-btn {
    gap: 0.35rem;
}

.shows-poll-action-btn i {
    margin-right: 0;
}

.shows-action-btn .fa-stack {
    margin-right: 0.35rem;
}

.shows-nearest-poll-note {
    align-items: flex-start;
    background: #fbf8ff;
    border: 1px solid #ded2f2;
    border-radius: 0.75rem;
    color: #5f5470;
    display: flex;
    gap: 0.65rem;
    line-height: 1.35;
    margin-top: 0.35rem;
    padding: 0.7rem 0.8rem;
    position: relative;
}

.shows-nearest-poll-note > i {
    color: var(--color-accent);
    font-size: 1.15rem;
    margin-top: 0.1rem;
}

.shows-nearest-poll-note .shows-nearest-poll-note-arrow {
    --fa-animation-duration: 2.8s;
    color: #9a7ed7;
    font-size: 2rem;
    left: 2.35rem;
    margin: 0;
    opacity: 0.5;
    position: absolute;
    top: -1.6rem;
}

.shows-nearest-poll-note strong,
.shows-nearest-poll-note span {
    display: block;
}

.shows-nearest-poll-note strong {
    color: var(--color-ink);
    font-weight: 800;
}

.shows-nearest-poll-note span {
    font-size: 0.92rem;
}

.shows-modal-eyebrow {
    color: var(--color-muted);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.event-polls-modal .modal-content {
    border: 0;
    border-radius: 1rem;
}

.event-polls-modal-body {
    background: #fbf8f5;
    display: grid;
    gap: 1rem;
}

.event-poll-modal-item {
    margin-bottom: 1rem;
    padding-bottom:1.5rem;
    /* border-bottom: 0.5rem dashed #ffffff99; */
}
.event-poll-modal-item .poll-card {
    margin: 0;
}

.poll-login-fish {
    max-width: 8.5rem;
}

.poll-login-raffle {
    font-size: 0.9rem;
}

.shows-calendar-stack-plus {
    color: var(--color-accent);
    font-size: 0.56em;
    transform: translate(0.55em, -0.45em);
}

.shows-action-btn.is-fb {
    color: #1877f2;
}

.shows-action-btn.is-book:hover,
.shows-action-btn.is-fb:hover {
    background: rgba(141, 119, 180, 0.08);
}

.shows-archive {
    display: grid;
    gap: 0.8rem;
    margin-top: 1.1rem;
}

.shows-archive-head h2 {
    font-size: 1.2rem;
    margin: 0;
}

.shows-archive-grid {
    display: grid;
    gap: 1.3rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.shows-archive-card {
    align-items: center;
    /* border: 1px solid #d9cdef; */
    border-radius: 1rem;
    display: grid;
    gap: 0.8rem;
    grid-template-columns: 1fr 10rem;
    padding: 0.8rem 0.9rem;    
    background-color: #f5ede9;
    background: linear-gradient(0deg,rgba(245, 237, 233, 0) 0%, rgba(245, 237, 233, 1) 100%);



}

.shows-archive-main {
    display: grid;
    gap: 0.55rem;
    min-width: 0;
}

.shows-archive-main h3 {
    font-size: 1.2rem;
    margin: 0;
    color: #666;
}

.shows-archive-image-link,
.shows-archive-image {
    display: block;
}

.shows-archive-image {
    aspect-ratio: 1 / 1;
    border: 1px solid var(--color-line);
    border-radius: 0.8rem;
    height: auto;
    object-fit: cover;
    object-position: center;
    width: 100%;
}

.shows-archive-actions .shows-action-btn {
    flex: 0 1 auto;
    min-height: 2.1rem;
    width: fit-content;
}

.shows-archive-fb-link {
    color: #1877f2;
    display: inline-block;
    font-size: 0.78rem;
    line-height: 1.25;
    max-width: 100%;
    overflow-wrap: anywhere;
    text-decoration: underline;
}

.shows-archive-fb-link:hover {
    filter: brightness(0.88);
}

.shows-archive-commentary-row {
    grid-column: 1 / -1;
    margin-top: 0.2rem;
}

.aftershow-commentary-wrap {
    align-items: flex-start;
    display: grid;
    gap: 0.6rem;
    grid-template-columns: 2.1rem 1fr;
}

.aftershow-commentary-avatar {
    background: #fff;
    border: 1px solid var(--color-line);
    border-radius: 50%;
    height: 2.1rem;
    object-fit: cover;
    width: 2.1rem;
}

.aftershow-commentary-bubble {
    background: #fff;
    border: 1px solid var(--color-line);
    border-radius: 0.9rem;
    box-shadow: 0 8px 20px rgba(26, 18, 42, 0.08);
    padding: 0.55rem 0.7rem;
    position: relative;
}

.aftershow-commentary-bubble:before {
    background: #fff;
    border-left: 1px solid var(--color-line);
    border-top: 1px solid var(--color-line);
    content: "";
    height: 0.6rem;
    left: -0.34rem;
    position: absolute;
    top: 0.9rem;
    transform: rotate(-45deg);
    width: 0.6rem;
}

.aftershow-commentary-quote {
    color: var(--color-text);
    margin: 0;
}

.aftershow-commentary-quote i {
    color: var(--color-muted);
    font-size: 0.78rem;
}

.aftershow-commentary-more {
    background: transparent;
    border: 0;
    color: var(--color-accent);
    font-size: 0.82rem;
    font-weight: 700;
    margin-top: 0.2rem;
    padding: 0;
    text-decoration: underline;
}

.aftershow-modal .modal-dialog {
    max-width: 36rem;
}

.aftershow-modal-content {
    border: 0;
    border-radius: 1.1rem;
    box-shadow: 0 30px 80px rgba(12, 8, 24, 0.18);
}

.aftershow-modal-header {
    align-items: center;
    border-bottom: 1px solid var(--color-line);
    display: flex;
    justify-content: space-between;
    padding: 1rem 1.2rem;
}

.aftershow-modal-title-group {
    align-items: center;
    display: flex;
    flex: 1 1 auto;
    gap: 0.55rem;
    min-width: 0;
}

.aftershow-modal-avatar {
    background: #fff;
    border: 1px solid var(--color-line);
    border-radius: 50%;
    flex: 0 0 1.8rem;
    height: 1.8rem;
    object-fit: cover;
    width: 1.8rem;
}

.aftershow-modal-icon {
    align-items: center;
    background: rgba(141, 119, 180, 0.14);
    border-radius: 0.6rem;
    color: var(--color-accent);
    display: inline-flex;
    flex: 0 0 2.2rem;
    font-size: 1rem;
    height: 2.2rem;
    justify-content: center;
    width: 2.2rem;
}

.aftershow-modal-title {
    color: var(--color-text);
    font-size: 1.05rem;
    font-weight: 700;
    margin: 0;
    overflow-wrap: anywhere;
}

.aftershow-modal-close {
    align-items: center;
    background: rgba(141, 119, 180, 0.1);
    border: 0;
    border-radius: 999px;
    color: var(--color-accent);
    display: inline-flex;
    flex: 0 0 2.2rem;
    height: 2.2rem;
    justify-content: center;
    transition: background 0.15s ease;
    width: 2.2rem;
}

.aftershow-modal-close:hover {
    background: rgba(141, 119, 180, 0.22);
}

.aftershow-modal-body {
    color: var(--color-text);
    font-style: italic;
    line-height: 1.55;
    padding: 1.1rem 1.2rem;
    scrollbar-color: var(--color-accent) transparent;
    scrollbar-width: thin;
}

.aftershow-modal-body::-webkit-scrollbar {
    width: 0.45rem;
}

.aftershow-modal-body::-webkit-scrollbar-thumb {
    background: var(--color-accent);
    border-radius: 999px;
}

.aftershow-modal-body em {
    font-style: italic;
}

.aftershow-modal-body img,
.aftershow-modal-body iframe,
.aftershow-modal-body blockquote {
    max-width: 100%;
}

.aftershow-modal-footer {
    align-items: center;
    border-top: 1px solid var(--color-line);
    display: flex;
    gap: 0.6rem;
    justify-content: space-between;
    padding: 0.8rem 1.2rem;
}

.aftershow-modal-credits {
    align-items: center;
    display: flex;
    flex: 1 1 auto;
    flex-wrap: wrap;
    gap: 0.5rem;
    min-width: 0;
}

.aftershow-modal-credit-group {
    border-radius: 50%;
    display: inline-flex;
    flex: 0 0 1.9rem;
    height: 1.9rem;
    overflow: hidden;
    width: 1.9rem;
}

.aftershow-modal-credit-group img {
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.aftershow-modal-credit-group:hover {
    box-shadow: 0 0 0 2px rgba(141, 119, 180, 0.35);
}

.aftershow-modal-credit-guest {
    align-items: center;
    background: rgba(141, 119, 180, 0.08);
    border-radius: 999px;
    color: var(--color-accent);
    display: inline-flex;
    gap: 0.3rem;
    padding: 0.2rem 0.55rem;
}

.aftershow-modal-credit-guest a {
    color: var(--color-accent);
    display: inline-flex;
    font-size: 0.85rem;
    line-height: 1;
}

.aftershow-modal-credit-guest a:hover {
    color: var(--color-text);
}

.aftershow-modal-credit-musician-icon {
    color: #b8860b;
    font-size: 0.78rem;
}

.aftershow-modal-aizvert {
    background: rgba(141, 119, 180, 0.14);
    border: 0;
    border-radius: 0.7rem;
    color: var(--color-accent);
    font-weight: 600;
    padding: 0.5rem 1.2rem;
    transition: background 0.15s ease;
}

.aftershow-modal-aizvert:hover,
.aftershow-modal-aizvert:focus {
    background: rgba(141, 119, 180, 0.26);
    color: var(--color-accent);
}

.shows-guest {
    color: var(--color-text);
    font-weight: 400;
}

.shows-guest a {
    color: var(--color-accent);
    font-weight: 600;
    text-decoration: none;
}

.shows-note {
    color: var(--color-muted);
    margin: 0.2rem 0 0;
}

.shows-note a {
    color: var(--color-accent);
    font-weight: 700;
    text-decoration: none;
}

.shows-empty,
.home-shows-empty {
    align-items: center;
    display: flex;
    flex-direction: column;
    gap: 0.7rem;
    margin: 1.25rem 0 0.2rem;
    text-align: center;
}

.shows-empty p,
.home-shows-empty-text {
    font-size: clamp(1.0rem, 2.0vw, 1.4rem);
    font-weight: 800;
    letter-spacing: 0.01em;
    margin: 0;
}

.shows-empty-sun {
    animation: showsSunSpin 8s linear infinite;
    color: #ef8f00;
    filter: drop-shadow(0 0 0.55rem rgba(239, 143, 0, 0.35));
    font-size: clamp(1.8rem, 3.6vw, 2.5rem);
}

@keyframes showsSunSpin {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}

.supers-page {
    max-width: 920px;
    margin: 0 auto;
    padding: 2rem 1.6rem 3rem;
}

.supers-shell {
    display: grid;
    gap: 1rem;
}

.supers-eyebrow {
    color: var(--color-accent);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    margin: 0 0 0.35rem;
    text-transform: uppercase;
}

.supers-head h1 {
    font-size: clamp(1.95rem, 3.4vw, 2.9rem);
    margin: 0;
}

.supers-subtitle {
    color: var(--color-muted);
    margin: 0.55rem 0 0;
    max-width: 48rem;
}

.supers-vote-saved {
    align-items: center;
    background: #ebf9f0;
    border: 1px solid #b8dfc5;
    border-radius: 0.75rem;
    color: #1f6b3d;
    display: inline-flex;
    font-weight: 700;
    gap: 0.5rem;
    margin: 0;
    padding: 0.5rem 0.7rem;
}

.supers-card {
    padding: 1.1rem 1.2rem;
}

.supers-card h2 {
    font-size: 1.35rem;
    margin: 0;
}

.supers-card p {
    line-height: 1.58;
    margin: 0.72rem 0 0;
}

.supers-video-card {
    background: var(--surface-card);
    border: 1px solid var(--color-line);
    border-radius: var(--radius-lg);
    padding: 1.1rem 1.2rem;
}

.supers-video-card h2 {
    font-size: 1.2rem;
    margin: 0 0 0.6rem;
}

.supers-video-placeholder {
    align-items: center;
    aspect-ratio: 16 / 9;
    background: linear-gradient(145deg, #f8f2ea, #efe5d9);
    border: 1px dashed #d2c4b4;
    border-radius: 0.8rem;
    color: #6d5f50;
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
    justify-content: center;
    padding: 0.8rem;
    text-align: center;
}

.supers-video-placeholder i {
    font-size: 1.6rem;
}

.supers-video-placeholder p {
    margin: 0;
    max-width: 26rem;
}

.supers-top-panel {
    /* background: linear-gradient(135deg, #fffaf7 0%, #fff 56%, #fbf7ff 100%);
    border: 1px solid #eadfd8;
    border-radius: 0.75rem;
    box-shadow: 0 1.1rem 2.8rem rgba(79, 56, 43, 0.09);
    margin: 1.5rem 0; */
    overflow: hidden;
    /* padding: 1.55rem 1.8rem 1.65rem; */
    position: relative;
}

.supers-top-panel::before,
.supers-top-panel::after {
    border: 1px solid rgba(128, 88, 207, 0.22);
    border-radius: 0.35rem;
    content: "";
    height: 1.8rem;
    opacity: 0.65;
    position: absolute;
    transform: rotate(-18deg);
    width: 1.8rem;
}

.supers-top-panel::before {
    right: 14%;
    top: 1.4rem;
}

.supers-top-panel::after {
    bottom: 1.7rem;
    left: 2rem;
}

.supers-top-spark {
    color: rgba(128, 88, 207, 0.38);
    font-size: 1.05rem;
    line-height: 1;
    position: absolute;
    z-index: 1;
}

.supers-top-spark-a {
    left: 1.45rem;
    top: 4.3rem;
}

.supers-top-spark-b {
    right: 2.7rem;
    top: 2.35rem;
}

.supers-top-head {
    align-items: center;
    display: grid;
    gap: 1.25rem;
    grid-template-columns: auto minmax(0, 1fr) minmax(8rem, 13rem);
    margin-bottom: 1.35rem;
    min-height: 8.5rem;
    position: relative;
    z-index: 2;
}

.supers-top-trophy {
    align-items: center;
    background: rgba(128, 88, 207, 0.09);
    border-radius: 999px;
    color: #7f58cf;
    display: flex;
    font-size: 2rem;
    height: 5rem;
    justify-content: center;
    width: 5rem;
}

.supers-top-copy h2 {
    font-size: clamp(1.55rem, 3.3vw, 2.25rem);
    line-height: 1.08;
    margin: 0;
}

.supers-top-copy p {
    color: #77728f;
    font-size: 1.02rem;
    line-height: 1.48;
    margin: 0.55rem 0 0;
    max-width: 34rem;
}

.supers-top-illustration {
    display: block;
    filter: sepia(0.25) saturate(0.75) opacity(0.66);
    justify-self: end;
    max-height: 9rem;
    object-fit: contain;
    width: 100%;
}

.supers-top-list {
    counter-reset: supers-top-rank;
    display: grid;
    gap: 0.72rem 0.95rem;
    grid-auto-flow: column;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: repeat(5, auto);
    list-style: none;
    margin: 0;
    padding: 0;
    position: relative;
    z-index: 2;
}

.supers-top-item {
    align-items: center;
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(231, 219, 214, 0.92);
    border-radius: 0.45rem;
    box-shadow: 0 0.75rem 1.7rem rgba(82, 65, 55, 0.08);
    counter-increment: supers-top-rank;
    display: grid;
    gap: 0.85rem;
    grid-template-columns: auto auto minmax(0, 1fr) auto;
    min-height: 4.6rem;
    padding: 0.8rem 0.85rem;
}

.supers-top-rank {
    align-items: center;
    background: #fbf7ff;
    border: 1px solid #ebe2f8;
    border-radius: 0.45rem;
    color: #7f58cf;
    display: flex;
    font-size: 1.25rem;
    font-weight: 800;
    height: 2.45rem;
    justify-content: center;
    min-width: 2.45rem;
}

.supers-top-rank::before {
    content: counter(supers-top-rank);
}

.supers-top-emoji {
    align-items: center;
    background: #fbf0e9;
    border-radius: 999px;
    display: flex;
    font-size: 1.55rem;
    height: 3.1rem;
    justify-content: center;
    min-width: 3.1rem;
}

.supers-top-text {
    min-width: 0;
}

.supers-top-text strong {
    display: block;
    font-size: 1.06rem;
    line-height: 1.18;
}

.supers-top-text small {
    color: #77728f;
    display: block;
    font-size: 0.93rem;
    line-height: 1.36;
    margin-top: 0.22rem;
}

.supers-top-count {
    background: #fbf7ff;
    border: 1px solid #eadff7;
    border-radius: 999px;
    color: #7f58cf;
    font-size: 0.88rem;
    font-weight: 800;
    padding: 0.38rem 0.72rem;
    white-space: nowrap;
}

.subscribe-page {
    margin: 0 auto;
    max-width: 760px;
    padding: 2rem 1.6rem 3rem;
}

.subscribe-shell {
    display: grid;
    gap: 1rem;
}

.subscribe-eyebrow {
    color: var(--color-accent);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    margin: 0 0 0.35rem;
    text-transform: uppercase;
}

.subscribe-head h1 {
    font-size: clamp(1.8rem, 3.2vw, 2.5rem);
    margin: 0;
}

.subscribe-subtitle {
    color: var(--color-muted);
    margin: 0.55rem 0 0;
}

.subscribe-card {
    background: var(--surface-card);
    border: 1px solid var(--color-line);
    border-radius: var(--radius-lg);
    padding: 1.6rem 1.4rem;
}

.subscribe-form {
    display: grid;
    gap: 0.85rem;
    max-width: 100%;
}

.subscribe-submit-btn {
    align-items: center;
    background: var(--color-accent);
    border: 1px solid var(--color-accent);
    border-radius: 0.65rem;
    color: #fff;
    cursor: pointer;
    display: flex;
    font-size: 1.05rem;
    font-weight: 700;
    gap: 0.4rem;
    justify-content: center;
    margin-top: 0.15rem;
    padding: 0.75rem 1.4rem;
    text-decoration: none;
    transition: background 0.15s, border-color 0.15s;
    width: 100%;
}

.subscribe-submit-btn:hover {
    background: #7a65a0;
    border-color: #7a65a0;
    color: #fff;
}

.subscribe-social-label {
    color: var(--color-muted);
    font-size: 0.9rem;
}

.subscribe-social-btn {
    align-items: center;
    border-radius: 0.75rem;
    border: 2px solid transparent;
    color: #fff;
    display: inline-flex;
    font-weight: 700;
    gap: 0.65rem;
    padding: 0.6rem 1rem;
    text-decoration: none;
    transition: filter 0.15s;
}

.subscribe-social-btn:hover {
    color: #fff;
    filter: brightness(1.12);
}

.subscribe-social-btn i {
    font-size: 2rem;
    line-height: 1;
}

.subscribe-social-btn__text {
    display: flex;
    flex-direction: column;
    line-height: 1.2;
}

.subscribe-social-btn__network {
    font-size: 1rem;
}

.subscribe-social-btn__handle {
    font-size: 1.2rem;
    font-weight: 500;
    opacity: 0.85;
    white-space: nowrap;
}

.subscribe-social-btn--ig {
    background: #d6249f;
}

.subscribe-social-btn--fb {
    background: #1877f2;
}

.subscribe-social-btn--th {
    background: #000;
}

.subscribe-input-wrap {
    align-items: center;
    display: flex;
    gap: 0.5rem;
}

.subscribe-input-wrap i {
    color: var(--color-muted);
}

.subscribe-input {
    flex: 1;
}

.sponsors-page {
    max-width: 860px;
}

.sponsors-shell {
    gap: 1.1rem;
}

.sponsors-card {
    display: grid;
    gap: 0.85rem;
}

.sponsors-title {
    font-size: 1.3rem;
    margin: 0;
}

.sponsors-list {
    margin: 0;
    padding-left: 1.15rem;
}

.sponsors-list li {
    margin: 0.35rem 0;
}

.sponsors-note {
    color: var(--color-muted);
    margin: 0;
}

.sponsors-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.sponsors-cta {
    width: auto;
}

.sponsors-cta-secondary {
    min-height: 3rem;
}

.supers-table-wrap {
    overflow: auto;
}

.supers-table {
    border-collapse: collapse;
    min-width: 44rem;
    width: 100%;
}

.supers-table th,
.supers-table td {
    border-bottom: 1px solid var(--color-line);
    padding: 0.72rem 0.8rem;
    text-align: left;
    vertical-align: top;
}

.supers-table th {
    background: #f6f1eb;
    font-size: 0.92rem;
    letter-spacing: 0.03em;
    position: sticky;
    text-transform: uppercase;
    top: 0;
    z-index: 1;
}

.supers-descr {
    margin: 0;
}

.supers-vote-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin-top: 0.6rem;
}

.supers-vote-form {
    margin: 0;
}

.supers-vote-btn {
    align-items: center;
    background: #fff;
    border: 1px solid #d7cdc3;
    border-radius: 999px;
    color: #5f5348;
    cursor: pointer;
    display: inline-flex;
    font-size: 0.84rem;
    font-weight: 700;
    gap: 0.38rem;
    line-height: 1;
    padding: 0.34rem 0.62rem;
}

.supers-vote-btn span {
    background: #f3ece4;
    border-radius: 999px;
    color: #6c6055;
    font-size: 0.78rem;
    padding: 0.15rem 0.4rem;
}

.supers-vote-btn:hover,
.supers-vote-btn.is-selected {
    background: #edf8f0;
    border-color: #b2d9bc;
    color: #1f6b3d;
}

.supers-vote-btn:hover span,
.supers-vote-btn.is-selected span {
    background: #d7eddc;
    color: #14522d;
}

.supers-table tbody tr:last-child td {
    border-bottom: 0;
}

.supers-emoji {
    font-size: 1.25rem;
    line-height: 1;
    white-space: nowrap;
    width: 3.4rem;
}

.supers-name {
    font-weight: 700;
    white-space: nowrap;
}

.supers-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.supers-item {
    background: var(--surface-card);
    border: 1px solid var(--color-line);
    border-radius: var(--radius-lg);
    padding: 1rem;
}

.supers-item h3 {
    font-size: 1.03rem;
    margin: 0;
}

.supers-item h3 i {
    color: var(--color-accent);
    margin-right: 0.3rem;
}

.supers-item p {
    color: var(--color-muted);
    margin: 0.65rem 0 0;
}

.supers-note {
    color: var(--color-muted);
    margin: 0;
}

.supers-note a {
    color: var(--color-accent);
    font-weight: 700;
    text-decoration: none;
}

@media (max-width: 920px) {
    .wishlist-page {
        padding: 2rem 1.2rem 3rem;
    }

    .wishlist-shell {
        gap: 1.75rem;
    }

    .wishlist-item,
    .wishlist-item:nth-child(even) {
        gap: 1rem;
        grid-template-columns: 1fr;
        min-height: 0;
        padding: 2rem 0 2.5rem;
    }

    .wishlist-item:nth-child(even) .wishlist-visual,
    .wishlist-item:nth-child(even) .wishlist-copy {
        grid-column: auto;
        grid-row: auto;
    }

    .wishlist-visual img {
        max-height: 12rem;
    }

    .hero-grid {
        grid-template-columns: 1fr;
    }

    .supers-top-head {
        grid-template-columns: auto minmax(0, 1fr);
        min-height: 0;
    }

    .supers-top-illustration {
        display: none;
    }

    .supers-top-list {
        grid-auto-flow: row;
        grid-template-columns: 1fr;
        grid-template-rows: none;
    }


    .faq-page {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .faq-topic-list {
        position: static;
    }

    .faq-scroll {
        height: auto;
        max-height: none;
    }
    .carousel-control-prev,
    .carousel-control-next {
        height: 2.4rem;
        width: 2.4rem;
        opacity: 0.6;
    }

    .carousel-control-prev {
        left: 0.3rem;
    }

    .carousel-control-next {
        right: 0.3rem;
    }

    .carousel-indicators {
        margin-top: 0.8rem;
        gap: 0.35rem;
    }

    .feature-grid,
    .auth-grid,
    .home-shows-preview,
    .home-video-spot,
    .about-gallery,
    .shows-grid,
    .supers-grid {
        grid-template-columns: 1fr;
    }

    .shows-single-decor {
        display: none;
    }

    .calendar-strip {
        gap: 0.55rem;
    }

    .calendar-strip-item {
        flex-basis: calc(50% - 0.3rem);
    }

    .calendar-strip-panel {
        left: 0;
        min-width: min(15rem, calc(100vw - 3.2rem));
        width: min(15rem, calc(100vw - 3.2rem));
    }

    .site-nav-wrap {
        padding: 0.75rem 1rem;
    }

    .topbar {
        align-items: center;
        flex-direction: row;
        gap: 0.7rem;
    }

    .topbar-main {
        flex: 1 1 auto;
        gap: 0.65rem;
        min-width: 0;
    }

    .brand {
        min-width: 0;
    }

    .brand-logo {
        height: 2.4rem;
        max-width: min(44vw, 11rem);
    }

    .topbar-nav-links {
        flex: 0 0 auto;
        gap: clamp(0.9rem, 3.5vw, 1.4rem);
    }

    .topbar-nav-links .topbar-link:not(.topbar-link-shows):not(.topbar-link-mobile-primary) {
        display: none;
    }

    .topbar-link {
        font-size: clamp(0.72rem, 2.8vw, 1rem);
        margin: 0;
        white-space: nowrap;
    }

    .topbar-link-shows {
        padding-right: 1rem;
    }

    .topbar-tools {
        display: none;
    }

    .topbar-mobile-menu {
        display: block;
        flex: 0 0 auto;
    }

    .topbar-mobile-menu .dropdown-menu {
        min-width: 14rem;
    }

    .home-nearest-show {
        grid-template-columns: 1fr;
    }

    .support-actions {
        grid-template-columns: 1fr;
        justify-items: stretch;
    }

    .support-qr-placeholder {
        width: min(8.5rem, 100%);
    }

    .home-sponsor-strip {
        grid-template-columns: 1fr;
    }

    .home-sponsor-actions {
        justify-content: flex-start;
    }

    .home-video-gif-badge {
        width: clamp(3.5rem, 18vw, 5.5rem);
        bottom: 0.7rem;
        left: 0.7rem;
    }

    .home-nearest-image-link {
        display: block;
        margin-inline: auto;
        max-width: 22rem;
        width: 100%;
    }

    .home-nearest-image {
        width: 100%;
        max-width: 22rem;
        margin-inline: auto;
    }

    .home-nearest-show .add2cal-label {
        display: none;
    }

    .home-nearest-show .home-nearest-copy h2 .btn.float-end {
        padding-inline: 0.5rem;
    }

    .shows-date-time {
        align-items: flex-start;
        flex-direction: column;
        gap: 0.22rem;
    }

    .shows-archive-card {
        grid-template-columns: 1fr 7rem;
    }

    .shows-archive-grid {
        grid-template-columns: 1fr;
    }

    .profile-head,
    .profile-row,
    .about-head {
        align-items: flex-start;
        flex-direction: column;
    }

    .about-actions {
        align-items: flex-start;
    }

    .footer-inner {
        grid-template-columns: 1fr 1fr;
    }

    .footer-inner .footer-col:first-child {
        grid-column: 1 / -1;
    }

    .footer-brand {
        align-items: flex-start;
        grid-column: 1 / -1;
    }
}




.floating {
    position: relative;
    animation: float 5s ease-in-out infinite;
}

@media (prefers-reduced-motion: reduce) {
    .floating {
        animation: none;
    }
}

@keyframes float {
    0% {
        transform: translateY(0);
    }

    50% {
        transform: translateY(-3vh);
    }

    100% {
        transform: translateY(0);
    }
}

/* ── Homepage stats ─────────────────────────────────────── */
.big-stats {
    display: grid;
    grid-template-columns: repeat(2, minmax(16rem, 1fr));
    gap: 1.2rem;
    padding: 2.2rem 0.3rem 3.2rem;
}

.home-stat-block {
    /* background: #fff;
    border: 1px solid #eee8f4;
    border-radius: 1.9rem;
    box-shadow: 0 10px 30px rgba(42, 37, 34, 0.04); */
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.3rem;
    padding: 3rem 1.8rem 2.2rem;
    text-align: center;
}

.home-stat-icon {
    align-items: center;
    /* background: #f1ebf9;
    border-radius: 50%;
    color: var(--color-accent); */
    display: inline-flex;
    font-size: clamp(2.2rem, 5.2vw, 3rem);
    height: clamp(7.2rem, 11vw, 8.6rem);
    justify-content: center;
    margin-bottom: 1.35rem;
    width: clamp(7.2rem, 11vw, 8.6rem);
}

.home-stat-number {
    color: var(--color-accent);
    font-size: clamp(5.1rem, 10.5vw, 9rem);
    font-weight: 800;
    line-height: 0.92;
    letter-spacing: -0.03em;
    margin: -3rem 0 0;
    -webkit-text-stroke: 0.02em rgba(255, 255, 255, 0.5);
    text-shadow: 0 0.08em 0.16em rgba(255, 255, 255, 0.45);
}

.home-stat-label {
    color: #202432;
    display: block;
    font-size: clamp(1.9rem, 2.9vw, 2.55rem);
    font-weight: 700;
    letter-spacing: 0;
    line-height: 1.2;
    margin-top: 1rem;
    text-transform: none;
}

.home-stat-subtext {
    color: #6f7480;
    font-size: clamp(1.1rem, 1.65vw, 1.5rem);
    line-height: 1.35;
    margin: 0.7rem 0 0;
}

.home-stat-groups {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
    list-style: none;
    margin: 2rem 0 0;
    padding: 0;
}
.carousel-slide .home-stat-groups {
    gap: 0.4em;
    line-height: 1em;;
}

.home-stat-group {
    align-items: center;
    background: #fff;
    border: 1px solid #e8e1ef;
    border-radius: 999px;
    color: #2f3340;
    display: inline-flex;
    font-size: 1.2rem;
    font-weight: 700;
    gap: 0.45rem;
    line-height: 1.15;
    max-width: 100%;
    padding: 0.3rem 0.65rem 0.3rem 0.35rem;
    text-decoration: none;
    transition: border-color 0.15s ease, color 0.15s ease, transform 0.15s ease;
}

a.home-stat-group:hover {
    border-color: #cbb9df;
    color: var(--color-accent);
    transform: translateY(-1px);
}

.home-stat-group-tooltip .tooltip-inner {
    max-width: min(22rem, calc(100vw - 2rem));
    text-align: left;
}

.home-stat-group-tooltip-line {
    align-items: center;
    display: inline-flex;
    gap: 0.45rem;
    white-space: nowrap;
}

.home-stat-group-tooltip-line i {
    text-align: center;
    width: 1rem;
}

.home-stat-group-tooltip-line.is-instagram i {
    color: #e4405f;
}

.home-stat-group-tooltip-line.is-facebook i {
    color: #1877f2;
}

.home-stat-group-tooltip-line.is-threads i {
    color: #f7f7f7;
}

.home-stat-group-tooltip-line.is-web i {
    color: #52b788;
}

.home-stat-group-avatar {
    background: #f4f0f7;
    border: 1px solid #ded2ea;
    border-radius: 50%;
    height: 2rem;
    object-fit: cover;
    width: 2rem;
}
.carousel-item .home-stat-groups {
    gap: 0.3rem;
}
.home-stat-groups .home-stat-group-item {
}

@media (max-width: 860px) {
    .big-stats {
        grid-template-columns: 1fr;
    }

    .home-stat-block {
        padding: 2.4rem 1.1rem 1.7rem;
    }

    .home-stat-label {
        font-size: clamp(1.5rem, 6vw, 2.1rem);
    }

    .home-stat-subtext {
        font-size: clamp(1rem, 4vw, 1.3rem);
    }

    .home-stat-group {
        font-size: 0.9rem;
    }
}

/* ── Guest/Musician role icons ─────────────────────────── */
.shows-role-icon {
    display: inline-flex;
    align-items: center;
    margin-left: 0.4em;
    color: var(--color-accent, #555);
    cursor: default;
    font-size: 0.85em;
    opacity: 0.8;
}

.shows-role-icon:hover {
    opacity: 1;
}

.shows-group-avatars,
.home-nearest-group-avatars {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.shows-group-avatar-link {
    border-radius: 999px;
    display: inline-flex;
    line-height: 1;
    text-decoration: none;
}

.shows-group-avatar {
    background: #fff;
    border: 1px solid var(--color-line);
    border-radius: 999px;
    box-shadow: 0 2px 8px rgba(42, 37, 34, 0.08);
    display: block;
    height: 2rem;
    object-fit: cover;
    width: 2rem;
}

.home-nearest-group-avatars {
    margin-top: 0;
}

/* ── Event onboarding page ─────────────────────────────── */
.onboard-page {
    margin: 0 auto;
    max-width: 1120px;
    padding: 2rem 1.4rem 3rem;
    background-color: #faf4f2;
}

.onboard-hero {
    align-items: center;
    display: flex;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.onboard-hero-poster {
    aspect-ratio: 1 / 1;
    flex: 0 0 auto;
    object-fit: cover;
    width: min(12rem, 40vw);
}

.onboard-hero-banner {
    flex: 0 1 auto;
    height: auto;
    max-height: 11.5rem;
    max-width: 100%;
    width: auto;
}

.onboard-shell {
    display: grid;
    gap: 1rem;
}

.onboard-head {
    align-items: stretch;
    display: grid;
    gap: 1rem;
    grid-template-columns: 1fr auto;
}

.onboard-eyebrow {
    color: #8c79b3;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    margin: 0 0 0.25rem;
    text-transform: uppercase;
}

.onboard-head-logo {
    display: block;
    height: 3rem;
    margin-bottom: 0.35rem;
    width: auto;
}

.onboard-head h1 {
    font-size: clamp(2rem, 4vw, 3.35rem);
    line-height: 1.03;
    margin: 0;
}

.onboard-subtitle {
    color: var(--color-muted);
    margin: 0.55rem 0 0;
    max-width: 42rem;
}

.onboard-head-poster {
    background: #fff;
    border: 1px solid var(--color-line);
    border-radius: 0.8rem;
    overflow: hidden;
    width: min(14rem, 30vw);
}

.onboard-head-poster-img {
    display: block;
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.onboard-main-card {
    background: var(--surface-card);
    border: 1px solid var(--color-line);
    border-radius: var(--radius-lg);
    padding: 1rem 1.1rem;
}

.onboard-main-card--meta {
    padding: 0.85rem 1.1rem;
}

.onboard-main-card--meta-top {
    /* border-width: 2px; */
    outline: 0.2em solid #00000011;
}

.onboard-checklist-card {
    background: linear-gradient(130deg, #faf6ff, #f4eefc);
    border-color: #e2d8f2;
}

.onboard-checklist-head {
    display: grid;
    gap: 0.25rem;
    margin-bottom: 0.45rem;
}

.onboard-checklist-title {
    color: #4f397f;
    font-size: 1.12rem;
    margin: 0;
}

.onboard-checklist-subtitle {
    color: var(--color-muted);
    margin: 0;
}

.onboard-checklist-kicker {
    color: #5f4691;
    font-size: 0.88rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    margin: 0.35rem 0 0.6rem;
}

.onboard-checklist-list {
    display: grid;
    gap: 0.45rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

.onboard-checklist-item {
    background: #fff;
    border: 1px solid #e6dbf7;
    border-radius: 0.65rem;
    color: var(--color-text);
    line-height: 1.4;
    margin: 0;
    padding: 0.55rem 0.7rem;
}

.onboard-meta-line {
    align-items: stretch;
    display: flex;
    flex-wrap: wrap;
    gap: 0;
}

.onboard-meta-item {
    border-right: 1px solid var(--color-line);
    color: var(--color-text);
    display: flex;
    flex-direction: column;
    font-size: 1.06rem;
    gap: 0.15rem;
    padding: 0.5rem 1.25rem 0.5rem 0;
    margin-right: 1.25rem;
}

.onboard-meta-item:last-child {
    border-right: none;
    margin-right: 0;
    padding-right: 0;
}

.onboard-meta-item--cast {
    flex: 1 1 24rem;
    min-width: min(100%, 18rem);
}

.onboard-meta-item--venue {
    align-items: flex-end;
    flex: 0 1 12rem;
    margin-left: auto;
    text-align: right;
}

.onboard-meta-label {
    color: var(--color-muted);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    white-space: nowrap;
}

.onboard-meta-label i {
    color: #7f64b5;
    margin-right: 0.3rem;
}

.onboard-meta-value {
    font-size: 0.97rem;
    font-weight: 500;
    white-space: normal;
}

.onboard-venue-value {
    display: grid;
    gap: 0.1rem;
}

.onboard-venue-name {
    color: var(--color-accent);
    font-size: 1.16rem;
    font-weight: 800;
    line-height: 1.2;
}

.onboard-venue-address {
    color: var(--color-muted);
    font-size: 0.92rem;
    font-weight: 500;
    line-height: 1.25;
}

.onboard-meta-item--date {
    gap: 0;
}

.onboard-meta-date-big {
    color: var(--color-text);
    font-size: 1.8rem;
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1.1;
}

.onboard-meta-date-sub {
    color: var(--color-muted);
    font-size: 0.9rem;
    font-weight: 500;
}

.onboard-meta-actions {
    border-top: 1px solid var(--color-line);
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.75rem;
    padding-top: 0.75rem;
    a {
        text-decoration: none;
    }
}


.onboard-guests-card {
    display: grid;
    gap: 0.6rem;

}

.onboard-guests-title {
    color: #4f397f;
    font-size: 1.04rem;
    margin: 0;
}

.onboard-guests-title i {
    color: #7f64b5;
    margin-right: 0.3rem;
}

.onboard-guests-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

.onboard-guests-list--meta {
    gap: 0.5rem;
    margin-top: 0.12rem;
}

.onboard-guests-item {
    align-items: center;
    background: #f4effc;
    border: 1px solid #ddd2f1;
    border-radius: 999px;
    color: #4b3a79;
    display: inline-flex;
    font-size: 0.85rem;
    font-weight: 600;
    gap: 0.45rem;
    padding: 0.22rem 0.62rem 0.22rem 0.28rem;

    &.is-musician {
        background-color: transparent;
    }
    &.is-group {
        background-color: #333;
        color:#fff;
    }
}

.onboard-guests-link {
    align-items: center;
    color: inherit;
    display: inline-flex;
    gap: 0.45rem;
    min-width: 0;
    text-decoration: none;
}

a.onboard-guests-link:hover,
a.onboard-guests-link:focus {
    color: #382864;
    text-decoration: none;
}

a.onboard-guests-link:hover .onboard-guests-social-icon,
a.onboard-guests-link:focus .onboard-guests-social-icon {
    opacity: 1;
}

.onboard-guests-list--meta .onboard-guests-item {
    font-size: 0.98rem;
    gap: 0.5rem;
    padding: 0.28rem 0.72rem 0.28rem 0.34rem;
}

.onboard-guests-avatar {
    align-items: center;
    background: #fff;
    border: 1px solid #d8caef;
    border-radius: 50%;
    color: #7155b3;
    display: inline-flex;
    flex-shrink: 0;
    height: 1.55rem;
    justify-content: center;
    overflow: hidden;
    width: 1.55rem;
}

.onboard-guests-list--meta .onboard-guests-avatar {
    height: 1.85rem;
    width: 1.85rem;
}

.onboard-guests-social-icon {
    color: var(--color-accent);
    font-size: 0.72rem;
    opacity: 0.65;
}

.onboard-guests-avatar img {
    display: block;
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.onboard-form-error,
.onboard-form-success {
    border-radius: 0.65rem;
    font-size: 0.95rem;
    margin: 0 0 0.8rem;
    padding: 0.6rem 0.75rem;
}

.onboard-form-error {
    background: #fff1f0;
    border: 1px solid #f3b6b0;
    color: #9f2f2f;
}

.onboard-form-success {
    background: #eefaf2;
    border: 1px solid #bfe8c9;
    color: #23653b;
}

.onboard-info-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: 1fr 1fr;
}

.onboard-info-col {
    display: grid;
    gap: 0.65rem;
}

.onboard-info-row {
    align-items: flex-start;
    display: grid;
    gap: 0.65rem;
    grid-template-columns: 2rem 1fr;
}

.onboard-info-icon {
    align-items: center;
    background: #efe8fb;
    border-radius: 0.55rem;
    color: #7f64b5;
    display: inline-flex;
    height: 2rem;
    justify-content: center;
    width: 2rem;
}

.onboard-info-label {
    color: var(--color-text);
    font-size: 0.82rem;
    font-weight: 700;
    margin: 0;
}

.onboard-info-value {
    color: var(--color-muted);
    margin: 0.2rem 0 0;
}

.onboard-cta-card {
    align-items: center;
    background: linear-gradient(132deg, #f4eefc, #ede5fa);
    border: 1px solid #e2d8f2;
    border-radius: var(--radius-lg);
    display: grid;
    gap: 0.9rem;
    grid-template-columns: 1fr auto;
    padding: 1rem 1.1rem;
}

.onboard-cta-card h2 {
    font-size: 1.2rem;
    margin: 0;
}

.onboard-cta-card p {
    color: var(--color-muted);
    margin: 0.35rem 0 0;
}

.onboard-cta-btn {
    align-items: center;
    background: #7b63b7;
    border-radius: 0.65rem;
    color: #fff;
    display: inline-flex;
    font-weight: 700;
    gap: 0.45rem;
    padding: 0.75rem 1rem;
    text-decoration: none;
}

.onboard-cta-btn:hover {
    background: #6f59a7;
    color: #fff;
}

.onboard-assets-card {
    background: var(--surface-card);
    border: 1px solid var(--color-line);
    border-radius: var(--radius-lg);
    padding: 1rem 1.2rem;
}

.onboard-assets-title {
    font-size: 1.1rem;
    margin: 0 0 0.75rem;
}

.onboard-assets-row {
    align-items: flex-start;
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
}

.onboard-asset-link {
    display: inline-block;
    line-height: 0;
}

.onboard-asset-thumb {
    border-radius: 0.5rem;
    cursor: pointer;
    display: block;
    height: 9.4rem;
    transition: opacity 0.15s ease, outline-color 0.15s ease;
    width: auto;
}

.onboard-asset-thumb:hover {
    opacity: 0.85;
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
}

.onboard-asset-placeholder {
    align-items: center;
    aspect-ratio: 9 / 16;
    background: #e9ecef;
    border: 1px dashed #a9b1b9;
    border-radius: 0.55rem;
    color: #6b7280;
    display: flex;
    font-size: 0.82rem;
    font-weight: 700;
    height: 9.4rem;
    justify-content: center;
}

.onboard-assets-note {
    color: var(--color-text-muted, #6b7280);
    font-size: 0.85rem;
    margin: 0.75rem 0 0;
}

.onboard-card-title {
    font-size: 1.2rem;
    margin: 0;
}

.onboard-card-title--step {
    font-size: 1.45rem;
}

.onboard-card-subtitle {
    color: var(--color-muted);
    margin: 0.35rem 0 0;
}

.onboard-supers-form {
    display: grid;
    gap: 0.8rem;
    margin-top: 0.8rem;
}

.onboard-selection-count {
    color: var(--color-muted);
    font-size: 0.92rem;
}

.onboard-supers-grid {
    display: grid;
    gap: 0.65rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.onboard-supers-item {
    background: #fff;
    border: 1px solid var(--color-line);
    border-radius: 0.75rem;
    cursor: pointer;
    display: grid;
    gap: 0.3rem;
    grid-template-columns: auto auto 1fr;
    padding: 0.6rem 0.7rem;
}

.onboard-supers-item--selected {
    background: #efe8fb;
    border-color: #ab95d6;
    box-shadow: 0 0 0 1px #ab95d6;
}

.onboard-supers-item input[type="checkbox"] {
    accent-color: #7b63b7;
    margin-top: 0.15rem;
}

.onboard-supers-emoji {
    align-items: center;
    display: inline-flex;
    font-size: 1.05rem;
    line-height: 1;
    margin-top: 0.05rem;
}

.onboard-supers-name {
    color: var(--color-text);
    font-weight: 700;
    grid-column: 3 / 4;
}

.onboard-supers-descr {
    color: var(--color-muted);
    font-size: 0.86rem;
    grid-column: 3 / 4;
}

.onboard-supers-actions {
    display: flex;
    justify-content: flex-end;
}

.onboard-poster-wrap {
    background: #fff;
    border: 1px solid var(--color-line);
    border-radius: 0.75rem;
    overflow: hidden;
}

.onboard-poster-image {
    display: block;
    width: 100%;
    height: auto;
}

.onboard-steps-card .accordion-item {
    border: 1px solid var(--color-line);
}

.onboard-steps-card .accordion-item + .accordion-item {
    margin-top: 0.45rem;
}

.onboard-steps-card .accordion-button {
    font-weight: 700;
}

.onboard-steps-card .accordion-button:not(.collapsed) {
    background: #f4eefc;
    color: #503a84;
}

@media (max-width: 960px) {
    .onboard-head {
        grid-template-columns: 1fr;
    }

    .onboard-head-poster {
        width: min(100%, 16rem);
    }

    .onboard-info-grid {
        grid-template-columns: 1fr 1fr;
    }

    .onboard-supers-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .onboard-cta-card {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .onboard-hero-poster {
        display: none;
    }

    .onboard-hero-banner {
        max-height: none;
        width: 100%;
    }

    .supers-top-panel {
        padding: 1.15rem;
    }

    .supers-top-head {
        gap: 0.85rem;
    }

    .supers-top-trophy {
        font-size: 1.45rem;
        height: 3.6rem;
        width: 3.6rem;
    }

    .supers-top-item {
        gap: 0.62rem;
        grid-template-columns: auto auto minmax(0, 1fr);
    }

    .supers-top-count {
        grid-column: 3;
        justify-self: start;
        margin-top: -0.35rem;
    }

    .onboard-page {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .onboard-info-grid {
        grid-template-columns: 1fr;
    }

    .onboard-meta-line {
        flex-wrap: wrap;
        white-space: normal;
    }

    .onboard-meta-item--venue {
        align-items: flex-start;
        margin-left: 0;
        text-align: left;
    }

    .onboard-supers-grid {
        grid-template-columns: 1fr;
    }

    .onboard-supers-actions {
        justify-content: stretch;
    }

    .onboard-supers-actions .onboard-cta-btn {
        width: 100%;
        justify-content: center;
    }
}

/* Smaller stats for shows page */
.shows-stats-wrap .big-stats {
    grid-template-columns: 1fr 1fr;
    gap: 0.7rem;
    padding: 1.1rem 0.1rem 1.2rem;
}
.shows-stats-wrap .home-stat-block {
    padding: 3rem 0.7rem 0.9rem;
}
.shows-stats-wrap .home-stat-icon {
    font-size: clamp(1.2rem, 3vw, 1.7rem);
    height: clamp(3.2rem, 6vw, 4.2rem);
    width: clamp(3.2rem, 6vw, 4.2rem);
    margin-bottom: 0.7rem;
}
.shows-stats-wrap .home-stat-number {
    font-size: clamp(5.2rem, 9vw, 6rem);
    margin: -1.2rem 0 0;
}
.shows-stats-wrap .home-stat-label {
    font-size: clamp(1.1rem, 2.5vw, 1.3rem);
    margin-top: 0.5rem;
    opacity: 0.6;;
}
.shows-stats-wrap .home-stat-subtext {
    font-size: clamp(0.8rem, 2vw, 1rem);
    margin-top: 0.3rem;
}


.shows-archive-grid  .home-stat-subtext {
    gap:0;
    display: none;
}
.shows-archive-grid  .home-stat-icon {
    margin-top: 1em;
}
.shows-archive-grid  .home-stat-number {
    margin-top: -1em;
}
.shows-archive-grid  .home-stat-label {
    margin-top: -0.5rem;
    line-height: 1.1em;;
}
.shows-archive-grid  .home-stat-icon img {
    /* height: 4em; */
    z-index: -1;;
    opacity: 0.3;;
}

/* ── Share landing pages ─────────────────────────────── */
.share-page {
    /* min-height: 100vh; */
    padding: 3rem 1rem 5rem;
    background: url(/public/img/bg_poll.png) center top no-repeat;
    background-size: cover;
}
.share-shell {
    max-width: 620px;
    margin: 0 auto;
}
.share-poll-wrap {
    padding: 0.25rem 0 0;
}
.share-card {
    background: var(--surface-card);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-soft);
    padding: 2.5rem 2rem;
    text-align: center;
}
.share-card-img {
    width: 100%;
    max-height: 260px;
    object-fit: cover;
    border-radius: calc(var(--radius-lg) - 0.25rem);
    margin-bottom: 1.5rem;
}
.share-card-title {
    font-size: 1.6rem;
    margin-bottom: 0.75rem;
}
.share-card-description {
    color: var(--color-muted);
    margin-bottom: 1.75rem;
}
.share-status-message {
    border-radius: var(--radius-md);
    /* font-weight: 700; */
    padding: 1rem;
}
.share-status-message.is-not-yet {
    background: #fff8e6;
    border: 1px solid #e2bc66;
    color: #724800;
}
.share-status-message.is-expired {
    background: #f5f2ee;
    border: 1px solid #d9cec4;
    color: #6f6257;
}
.share-cta-btn {
    display: inline-block;
    background: var(--color-accent);
    color: #fff;
    padding: 0.75rem 2.5rem;
    border-radius: 2rem;
    font-weight: 600;
    text-decoration: none;
    transition: opacity 0.15s;
}
.share-cta-btn:hover {
    opacity: 0.88;
    color: #fff;
}
@media (max-width: 576px) {
    .footer-logo { display: none; }
    .share-page  { padding: 1.5rem 0.75rem 3rem; }
    .share-card  { padding: 1.75rem 1.25rem; }
    .share-card-title { font-size: 1.35rem; }
    .share-poll-wrap { padding: 1.5rem 1rem; }
}

/* ── Improv formas: redesigned list + client-side filter ──────────── */
/* Shared with no other page; safe to evolve independently of supers-*. */

.formas-filters {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    justify-content: space-between;
}

.formas-search {
    align-items: center;
    background: var(--color-bg-2);
    border: 1px solid var(--color-line);
    border-radius: 999px;
    display: flex;
    flex: 1 1 16rem;
    gap: 0.6rem;
    max-width: 28rem;
    padding: 0.55rem 1rem;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.formas-lengths {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.formas-length {
    background: var(--color-bg-2);
    border: 1px solid var(--color-line);
    border-radius: 999px;
    color: var(--color-muted);
    cursor: pointer;
    font-size: 0.88rem;
    font-weight: 600;
    padding: 0.5rem 0.95rem;
    transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.formas-length:hover {
    border-color: var(--color-accent);
    color: var(--color-text);
}

.formas-length.is-active {
    background: var(--color-accent);
    border-color: var(--color-accent);
    color: #fff;
}

.formas-search:focus-within {
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(141, 119, 180, 0.18);
}

.formas-search-icon {
    color: var(--color-muted);
    font-size: 0.95rem;
}

.formas-search-input {
    background: transparent;
    border: 0;
    color: var(--color-text);
    flex: 1;
    font-size: 1rem;
    outline: none;
}

.formas-table-wrap {
    overflow: auto;
}

.formas-table {
    border-collapse: collapse;
    min-width: 44rem;
    width: 100%;
}

.formas-table th,
.formas-table td {
    border-bottom: 1px solid var(--color-line);
    padding: 0.8rem 0.9rem;
    text-align: left;
    vertical-align: top;
}

.formas-table th {
    background: #f6f1eb;
    font-size: 0.92rem;
    letter-spacing: 0.03em;
    position: sticky;
    text-transform: uppercase;
    top: 0;
    z-index: 1;
}

.formas-table th i {
    color: var(--color-accent);
    margin-right: 0.25rem;
}

.formas-table tbody tr:nth-child(even) {
    background: rgba(243, 239, 234, 0.5);
}

.formas-table tbody tr:hover {
    background: rgba(141, 119, 180, 0.08);
}

.formas-name {
    font-weight: 700;
    white-space: nowrap;
}

.formas-descr {
    color: var(--color-muted);
    margin: 0;
}

.formas-facet {
    align-items: center;
    background: var(--color-bg-3);
    border-radius: 999px;
    color: var(--color-text);
    display: inline-flex;
    font-size: 0.85rem;
    font-weight: 600;
    gap: 0.35rem;
    padding: 0.2rem 0.6rem;
    white-space: nowrap;
}

.formas-facet i {
    color: var(--color-accent);
}

.formas-poll {
    margin-inline: auto;
    max-width: 40rem;
    text-align: center;
}

.formas-poll-title {
    font-size: 1.5rem;
    margin: 0 0 0.4rem;
}

.formas-poll-descr {
    color: var(--color-muted);
    margin: 0 0 1rem;
}

.formas-collapse-toggle {
    background: transparent;
    border: 0;
    color: var(--color-accent);
    cursor: pointer;
    display: inline-flex;
    font-size: 0.82rem;
    font-weight: 600;
    gap: 0.35rem;
    margin-top: 0.4rem;
    padding: 0;
}

.formas-collapse-toggle:hover {
    text-decoration: underline;
}

.formas-aliases,
.formas-variations {
    color: var(--color-muted);
    font-size: 0.9rem;
    list-style: none;
    margin: 0.35rem 0 0;
    padding-left: 0;
}

.formas-aliases li,
.formas-variations li {
    padding: 0.15rem 0;
}

.formas-variations li {
    border-left: 2px solid var(--color-line);
    margin-top: 0.4rem;
    padding-left: 0.6rem;
    white-space: pre-line;
}

/* Filter hide class (toggled by JS). */
.formas-table .is-hidden {
    display: none !important;
}

@media (max-width: 48rem) {
    .formas-table-wrap {
        overflow: visible;
    }

    .formas-table {
        min-width: 0;
    }

    .formas-table thead {
        border: 0;
        clip: rect(0 0 0 0);
        height: 1px;
        margin: -1px;
        overflow: hidden;
        padding: 0;
        position: absolute;
        width: 1px;
    }

    .formas-table tbody tr {
        background: var(--surface-card);
        border: 1px solid var(--color-line);
        border-radius: var(--radius-lg);
        display: block;
        margin-bottom: 1rem;
        padding: 0.4rem 0.9rem;
    }

    .formas-table tbody tr:nth-child(even),
    .formas-table tbody tr:hover {
        background: var(--surface-card);
    }

    .formas-table td {
        border-bottom: 1px solid var(--color-line);
        display: flex;
        gap: 1rem;
        justify-content: space-between;
        padding: 0.5rem 0;
    }

    .formas-table tr td:last-child {
        border-bottom: 0;
    }

    .formas-table td::before {
        color: var(--color-muted);
        content: attr(data-label);
        font-size: 0.82rem;
        font-weight: 700;
        letter-spacing: 0.03em;
        text-transform: uppercase;
    }

    .formas-name {
        white-space: normal;
    }
}
